]> git.droids-corp.org - dpdk.git/commitdiff
pci: move NUMA node check from scan to probe
authorSergio Gonzalez Monroy <sergio.gonzalez.monroy@intel.com>
Fri, 21 Jul 2017 09:11:19 +0000 (10:11 +0100)
committerThomas Monjalon <thomas@monjalon.net>
Fri, 21 Jul 2017 16:26:29 +0000 (19:26 +0300)
Commit 8a04cb612589 ("pci: set default numa node for broken systems")
added logic to default to NUMA node 0 when sysfs numa_node information
was wrong or not available.

Unfortunately there are many devices with wrong NUMA node information
that DPDK does not care about but still show warnings for them.

Instead, only check for invalid NUMA node information for devices
managed by the DPDK.

Signed-off-by: Sergio Gonzalez Monroy <sergio.gonzalez.monroy@intel.com>
lib/librte_eal/common/eal_common_pci.c
lib/librte_eal/linuxapp/eal/eal_pci.c

index eaa041ea2a15b31ab2aa91694488f2cb8182ad7d..52fd38cdd216ce3292f526f624f942cbb3503507 100644 (file)
@@ -226,6 +226,11 @@ rte_pci_probe_one_driver(struct rte_pci_driver *dr,
                return 1;
        }
 
+       if (dev->device.numa_node < 0) {
+               RTE_LOG(WARNING, EAL, "  Invalid NUMA socket, default to 0\n");
+               dev->device.numa_node = 0;
+       }
+
        RTE_LOG(INFO, EAL, "  probe driver: %x:%x %s\n", dev->id.vendor_id,
                dev->id.device_id, dr->driver.name);
 
index 556ae2c7ac20f1b668a02a0a312bdf4ae4c3679e..2041d5f347426ae2515c7b09cf57c87b0365276d 100644 (file)
@@ -314,15 +314,10 @@ pci_scan_one(const char *dirname, const struct rte_pci_addr *addr)
        snprintf(filename, sizeof(filename), "%s/numa_node",
                 dirname);
 
-       if (eal_parse_sysfs_value(filename, &tmp) == 0 &&
-               tmp < RTE_MAX_NUMA_NODES)
+       if (eal_parse_sysfs_value(filename, &tmp) == 0)
                dev->device.numa_node = tmp;
-       else {
-               RTE_LOG(WARNING, EAL,
-                       "numa_node is invalid or not present. "
-                       "Set it 0 as default\n");
-               dev->device.numa_node = 0;
-       }
+       else
+               dev->device.numa_node = -1;
 
        pci_name_set(dev);