From: Conor Walsh Date: Wed, 21 Apr 2021 12:48:42 +0000 (+0000) Subject: examples/l3fwd: skip Tx queue drain on first FIB iteration X-Git-Url: http://git.droids-corp.org/?a=commitdiff_plain;h=91470c0ddfabc61655f6ed1516efd495d9271324;p=dpdk.git examples/l3fwd: skip Tx queue drain on first FIB iteration The commit a8f8b672d575 ("examples/l3fwd: skip Tx queue drain on first iteration") implemented a change to the EM and LPM lookup methods to prevent the Tx queue drain running in the first iteration of their packet processing loops. This patch applies the same change into the new FIB lookup method. Signed-off-by: Conor Walsh Acked-by: Konstantin Ananyev Acked-by: Vladimir Medvedkin --- diff --git a/examples/l3fwd/l3fwd_fib.c b/examples/l3fwd/l3fwd_fib.c index c7d7689a94..1787229942 100644 --- a/examples/l3fwd/l3fwd_fib.c +++ b/examples/l3fwd/l3fwd_fib.c @@ -179,8 +179,6 @@ fib_main_loop(__rte_unused void *dummy) const uint64_t drain_tsc = (rte_get_tsc_hz() + US_PER_S - 1) / US_PER_S * BURST_TX_DRAIN_US; - prev_tsc = 0; - lcore_id = rte_lcore_id(); qconf = &lcore_conf[lcore_id]; @@ -200,9 +198,10 @@ fib_main_loop(__rte_unused void *dummy) lcore_id, portid, queueid); } - while (!force_quit) { + cur_tsc = rte_rdtsc(); + prev_tsc = cur_tsc; - cur_tsc = rte_rdtsc(); + while (!force_quit) { /* TX burst queue drain. */ diff_tsc = cur_tsc - prev_tsc; @@ -233,6 +232,8 @@ fib_main_loop(__rte_unused void *dummy) /* Use fib to lookup port IDs and transmit them. */ fib_send_packets(nb_rx, pkts_burst, portid, qconf); } + + cur_tsc = rte_rdtsc(); } return 0;