22/08/2022 20:27, Long Li:
> > Subject: Re: [Patch v4 01/17] net/mana: add basic driver, build environment
> > and doc
> > 
> > On 8/22/2022 4:03 PM, Ferruh Yigit wrote:
> > >> +                             struct rte_pci_device *pci_dev,
> > >> +                             struct rte_ether_addr *mac_addr) {
> > >> +       struct ibv_device **ibv_list;
> > >> +       int ibv_idx;
> > >> +       struct ibv_context *ctx;
> > >> +       struct ibv_device_attr_ex dev_attr;
> > >> +       int num_devices;
> > >> +       int ret = 0;
> > >> +       uint8_t port;
> > >> +       struct mana_priv *priv = NULL;
> > >> +       struct rte_eth_dev *eth_dev = NULL;
> > >> +       bool found_port;
> > >> +
> > >> +       ibv_list = ibv_get_device_list(&num_devices);
> > >> +       for (ibv_idx = 0; ibv_idx < num_devices; ibv_idx++) {
> > >> +               struct ibv_device *ibdev = ibv_list[ibv_idx];
> > >> +               struct rte_pci_addr pci_addr;
> > >> +
> > >> +               DRV_LOG(INFO, "Probe device name %s dev_name %s
> > >> ibdev_path %s",
> > >> +                       ibdev->name, ibdev->dev_name,
> > >> +ibdev->ibdev_path);
> > >> +
> > >> +               if (mana_ibv_device_to_pci_addr(ibdev, &pci_addr))
> > >> +                       continue;
> > >> +
> > >> +               /* Ignore if this IB device is not this PCI device */
> > >> +               if (pci_dev->addr.domain != pci_addr.domain ||
> > >> +                   pci_dev->addr.bus != pci_addr.bus ||
> > >> +                   pci_dev->addr.devid != pci_addr.devid ||
> > >> +                   pci_dev->addr.function != pci_addr.function)
> > >> +                       continue;
> > >> +
> > >
> > > As far as I understand, intention of this loop is to find 'ibdev'
> > > matching this device, code gooes through all "ibv device list" for
> > > this, I wonder if there is a easy way for doing this, like a sysfs
> > > entry to help getting this information?
> > > And how mlx4/5 does this?
> > 
> > Since there are multiple RDMA devices now, does it make sense to have
> > RDMA bus driver, which can hide some PCIe details under bus, and driver can
> > get PCI and ibdev information during probe?
> 
> Mellanox drivers use a similar way to go through the list of IB devices.
> 
> Matan, Viacheslav, what are your thoughts on implementing a bus for RDMA 
> devices?

These are PCI devices first.
Is it a good idea to have a bus driver on top of another one?
What would be the responsibility of such a bus driver?


Reply via email to