[PATCH] net/af_xdp: parse numa node id from sysfs
Frank Du
frank.du at intel.com
Mon Dec 12 01:48:57 CET 2022
Get from /sys/class/net/{if}/device/numa_node.
Signed-off-by: Frank Du <frank.du at 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
More information about the dev
mailing list