Get from /sys/class/net/{if}/device/numa_node. Signed-off-by: Frank Du <frank...@intel.com> --- drivers/net/af_xdp/rte_eth_af_xdp.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-)
diff --git a/drivers/net/af_xdp/rte_eth_af_xdp.c b/drivers/net/af_xdp/rte_eth_af_xdp.c index b6ec9bf490..38b9d36ab5 100644 --- a/drivers/net/af_xdp/rte_eth_af_xdp.c +++ b/drivers/net/af_xdp/rte_eth_af_xdp.c @@ -39,6 +39,7 @@ #include <rte_power_intrinsics.h> #include "compat.h" +#include "eal_filesystem.h" #ifndef SO_PREFER_BUSY_POLL #define SO_PREFER_BUSY_POLL 69 @@ -2038,9 +2039,6 @@ rte_pmd_af_xdp_probe(struct rte_vdev_device *dev) return -EINVAL; } - if (dev->device.numa_node == SOCKET_ID_ANY) - dev->device.numa_node = rte_socket_id(); - if (parse_parameters(kvlist, if_name, &xsk_start_queue_idx, &xsk_queue_cnt, &shared_umem, prog_path, &busy_budget, &force_copy) < 0) { @@ -2053,6 +2051,19 @@ rte_pmd_af_xdp_probe(struct rte_vdev_device *dev) return -EINVAL; } + /* get numa node id from net sysfs */ + if (dev->device.numa_node == SOCKET_ID_ANY) { + unsigned long numa = 0; + char numa_path[PATH_MAX]; + + snprintf(numa_path, sizeof(numa_path), "/sys/class/net/%s/device/numa_node", + if_name); + if (eal_parse_sysfs_value(numa_path, &numa) != 0) + dev->device.numa_node = rte_socket_id(); + else + dev->device.numa_node = numa; + } + busy_budget = busy_budget == -1 ? ETH_AF_XDP_DFLT_BUSY_BUDGET : busy_budget; -- 2.34.1