On Fri, Sep 30, 2022 at 09:10:55AM +0200, David Marchand wrote: > On Thu, Sep 29, 2022 at 2:05 PM Olivier Matz <olivier.m...@6wind.com> wrote: > > > > The dev->device.numa_node field is set by each bus driver for > > every device it manages to indicate on which NUMA node this device lies. > > > > When this information is unknown, the assigned value is not consistent > > across the bus drivers. > > > > Set the default value to SOCKET_ID_ANY (-1) by all bus drivers > > when the NUMA information is unavailable. > > > > Signed-off-by: Olivier Matz <olivier.m...@6wind.com> > > - The dma/idxd driver, which has its own bus, seems ok, though I > would align its code for readability. > > @@ -322,7 +322,7 @@ dsa_scan(void) > > while ((wq = readdir(dev_dir)) != NULL) { > struct rte_dsa_device *dev; > - int numa_node = -1; > + int numa_node = SOCKET_ID_ANY; > > if (strncmp(wq->d_name, "wq", 2) != 0) > continue; > > > - There is an impact on upper classes of devices. > > For ethdev, a port inherits the numa_node value from the rte_device object. > Yet, rte_eth_dev_socket_id() is described as: > * @return > * The NUMA socket ID to which the Ethernet device is connected or > * a default of zero if the socket could not be determined. > * -1 is returned is the port_id value is out of range.
Good catches, I'll fix them in v2. Thanks, Olivier