examples/eventdev: modify work cycles

The current work cycles function exchanges source and destination mac
address and also pauses the core for the given cycles.
This patch splits the function into two parts i.e. exchange mac and
pause the cores. The pause cores function is invoked at every stage
where as exchange mac is invoked when packet is transmitted.

Signed-off-by: Pavan Nikhilesh <pbhagavatula@caviumnetworks.com>
Acked-by: Harry van Haaren <harry.van.haaren@intel.com>
This commit is contained in:
Pavan Nikhilesh 2018-01-10 16:40:05 +05:30 committed by Jerin Jacob
parent 52548a6df5
commit 849b2adc57
2 changed files with 10 additions and 8 deletions

View File

@ -99,21 +99,20 @@ struct fastpath_data *fdata;
struct config_data cdata; struct config_data cdata;
static __rte_always_inline void static __rte_always_inline void
work(struct rte_mbuf *m) exchange_mac(struct rte_mbuf *m)
{ {
struct ether_hdr *eth; struct ether_hdr *eth;
struct ether_addr addr; struct ether_addr addr;
/* change mac addresses on packet (to use mbuf data) */ /* change mac addresses on packet (to use mbuf data) */
/*
* FIXME Swap mac address properly and also handle the
* case for both odd and even number of stages that the
* addresses end up the same at the end of the pipeline
*/
eth = rte_pktmbuf_mtod(m, struct ether_hdr *); eth = rte_pktmbuf_mtod(m, struct ether_hdr *);
ether_addr_copy(&eth->d_addr, &addr); ether_addr_copy(&eth->d_addr, &addr);
ether_addr_copy(&addr, &eth->d_addr); ether_addr_copy(&addr, &eth->d_addr);
}
static __rte_always_inline void
work(void)
{
/* do a number of cycles of work per packet */ /* do a number of cycles of work per packet */
volatile uint64_t start_tsc = rte_rdtsc(); volatile uint64_t start_tsc = rte_rdtsc();
while (rte_rdtsc() < start_tsc + cdata.worker_cycles) while (rte_rdtsc() < start_tsc + cdata.worker_cycles)

View File

@ -45,7 +45,7 @@ worker_generic(void *arg)
ev.op = RTE_EVENT_OP_FORWARD; ev.op = RTE_EVENT_OP_FORWARD;
ev.sched_type = cdata.queue_type; ev.sched_type = cdata.queue_type;
work(ev.mbuf); work();
while (rte_event_enqueue_burst(dev_id, port_id, &ev, 1) != 1) while (rte_event_enqueue_burst(dev_id, port_id, &ev, 1) != 1)
rte_pause(); rte_pause();
@ -101,7 +101,7 @@ worker_generic_burst(void *arg)
events[i].op = RTE_EVENT_OP_FORWARD; events[i].op = RTE_EVENT_OP_FORWARD;
events[i].sched_type = cdata.queue_type; events[i].sched_type = cdata.queue_type;
work(events[i].mbuf); work();
} }
uint16_t nb_tx = rte_event_enqueue_burst(dev_id, port_id, uint16_t nb_tx = rte_event_enqueue_burst(dev_id, port_id,
events, nb_rx); events, nb_rx);
@ -148,6 +148,7 @@ consumer(void)
received++; received++;
uint8_t outport = packet.mbuf->port; uint8_t outport = packet.mbuf->port;
exchange_mac(packet.mbuf);
rte_eth_tx_buffer(outport, 0, fdata->tx_buf[outport], rte_eth_tx_buffer(outport, 0, fdata->tx_buf[outport],
packet.mbuf); packet.mbuf);
@ -212,6 +213,8 @@ consumer_burst(void)
received += n; received += n;
for (i = 0; i < n; i++) { for (i = 0; i < n; i++) {
uint8_t outport = packets[i].mbuf->port; uint8_t outport = packets[i].mbuf->port;
exchange_mac(packets[i].mbuf);
rte_eth_tx_buffer(outport, 0, fdata->tx_buf[outport], rte_eth_tx_buffer(outport, 0, fdata->tx_buf[outport],
packets[i].mbuf); packets[i].mbuf);