Hi Thomas, This "rte_bus_close" API is introduced to do the opposite of what "rte_bus_probe" does. Just like there are plug and unplug APIs for plugging and unplugging a single device.
The API you mentioned, "rte_dev_remove" supports only rte_device. But we also need to close/remove private devices of dpaa and fslmc buses which are not exposed directly to user (eg: mempool device). Note that these private devices/bus objects are not associated with a particular rte_device but they are available as a resource to be used by any of the device based on these hardware specific buses. So, to close these devices, we need a new API which can do this for us. That is why "rte_bus_close" is required. Regards, Rohit Raj > -----Original Message----- > From: Thomas Monjalon <tho...@monjalon.net> > Sent: Wednesday, January 19, 2022 4:02 PM > To: Rohit Raj <rohit....@nxp.com> > Cc: Bruce Richardson <bruce.richard...@intel.com>; Ray Kinsella > <m...@ashroe.eu>; Dmitry Kozlyuk <dmitry.kozl...@gmail.com>; Narcisa Ana > Maria Vasile <navas...@linux.microsoft.com>; Dmitry Malloy > <dmit...@microsoft.com>; Pallavi Kadam <pallavi.ka...@intel.com>; > dev@dpdk.org; Nipun Gupta <nipun.gu...@nxp.com>; Sachin Saxena > <sachin.sax...@nxp.com>; Hemant Agrawal <hemant.agra...@nxp.com>; > ferruh.yi...@intel.com; david.march...@redhat.com > Subject: [EXT] Re: [PATCH v5 1/2] eal: add API for bus close > > Caution: EXT Email > > Hi, > > 10/01/2022 06:26, rohit....@nxp.com: > > From: Rohit Raj <rohit....@nxp.com> > > > > As per the current code we have API for bus probe, but the bus close > > API is missing. This breaks the multi process scenarios as objects are > > not cleaned while terminating the secondary processes. > > > > This patch adds a new API rte_bus_close() for cleanup of bus objects > > which were acquired during probe. > > I don't understand how closing all devices of a bus will help better than just > closing all devices. > > As Ferruh already suggested in the past, we could force closing all devices in > rte_eal_cleanup(). > And we already have the function rte_dev_remove(). > >