> -----Original Message----- > From: Parav Pandit <pa...@nvidia.com> > Sent: Thursday, October 8, 2020 10:35 AM > To: Ertman, David M <david.m.ert...@intel.com>; Pierre-Louis Bossart > <pierre-louis.boss...@linux.intel.com>; Leon Romanovsky > <l...@kernel.org> > Cc: alsa-de...@alsa-project.org; pa...@mellanox.com; ti...@suse.de; > netdev@vger.kernel.org; ranjani.sridha...@linux.intel.com; > fred...@linux.intel.com; linux-r...@vger.kernel.org; > dledf...@redhat.com; broo...@kernel.org; Jason Gunthorpe > <j...@nvidia.com>; gre...@linuxfoundation.org; k...@kernel.org; Williams, > Dan J <dan.j.willi...@intel.com>; Saleem, Shiraz > <shiraz.sal...@intel.com>; da...@davemloft.net; Patil, Kiran > <kiran.pa...@intel.com> > Subject: RE: [PATCH v2 1/6] Add ancillary bus support > > > > > From: Ertman, David M <david.m.ert...@intel.com> > > Sent: Thursday, October 8, 2020 10:24 PM > > > > From: Parav Pandit <pa...@nvidia.com> > > > Sent: Wednesday, October 7, 2020 9:56 PM > > > > > /** > > > * ancillar_device_register() - register an ancillary device > > > * NOTE: __never directly free @adev after calling this function, even > > > if it returned > > > * an error. Always use ancillary_device_put() to give up the > > > reference initialized by this function. > > > * This note matches with the core and caller knows exactly what to be > > done. > > > */ > > > ancillary_device_register() > > > { > > > device_initialize(&adev->dev); > > > if (!dev->parent || !adev->name) > > > return -EINVAL; > > > if (!dev->release && !(dev->type && dev->type->release)) { > > > /* core is already capable and throws the warning when > > release > > > callback is not set. > > > * It is done at drivers/base/core.c:1798. > > > * For NULL release it says, "does not have a release() > > function, it > > > is broken and must be fixed" > > > */ > > > return -EINVAL; > > > } > > That code is in device_release(). Because of this check we will never hit > that > > code. > > > > We either need to leave the error message here, or if we are going to rely > on > > the core to find this condition at the end of the process, then we need to > > completely remove this check from the registration flow. > > > Yes. Since the core is checking it, ancillary bus doesn't need to check here > and > release callback check can be removed.
Will do > > > -DaveE