X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fplugins%2Faf_xdp%2Fdevice.c;h=30d3c9571e68b3fbbb069b4a1b07004332447d63;hb=1ae9819908ca2ba78c6fa0c0051bb1d4b2066be8;hp=c82b700bbeadfba8ddbbbf0c46499d4897c69775;hpb=11c7cdd590a06a9681c43bde53055183c9d0058b;p=vpp.git diff --git a/src/plugins/af_xdp/device.c b/src/plugins/af_xdp/device.c index c82b700bbea..30d3c9571e6 100644 --- a/src/plugins/af_xdp/device.c +++ b/src/plugins/af_xdp/device.c @@ -477,12 +477,6 @@ af_xdp_create_if (vlib_main_t * vm, af_xdp_create_if_args_t * args) out */ } - if (i < txq_num) - { - /* we created less txq than threads not an error but initialize lock for shared txq */ - for (i = 0; i < ad->txq_num; i++) - clib_spinlock_init (&vec_elt (ad->txqs, i).lock); - } args->rv = 0; clib_error_free (args->error); @@ -490,6 +484,13 @@ af_xdp_create_if (vlib_main_t * vm, af_xdp_create_if_args_t * args) } } + if (ad->txq_num < tm->n_vlib_mains) + { + /* initialize lock for shared txq */ + for (i = 0; i < ad->txq_num; i++) + clib_spinlock_init (&vec_elt (ad->txqs, i).lock); + } + ad->dev_instance = ad - am->devices; ad->per_interface_next_index = VNET_DEVICE_INPUT_NEXT_ETHERNET_INPUT; ad->pool =