Re: [PATCH 2/2] counter: intel-qep: Use to_pci_dev() helper

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 14 Jun 2021 11:37:22 +0200
Uwe Kleine-König <u.kleine-koenig@xxxxxxxxxxxxxx> wrote:

> On Mon, Jun 14, 2021 at 11:57:46AM +0300, Andy Shevchenko wrote:
> > +Uwe Kleine-König
> > 
> > On Mon, Jun 14, 2021 at 11:24 AM Jarkko Nikula
> > <jarkko.nikula@xxxxxxxxxxxxxxx> wrote:  
> > > On 6/13/21 1:36 PM, Andy Shevchenko wrote:  
> > > > On Fri, Jun 11, 2021 at 2:57 PM Jarkko Nikula
> > > > <jarkko.nikula@xxxxxxxxxxxxxxx> wrote:  
> > > >>
> > > >> Use to_pci_dev() helper instead of container_of(d, struct pci_dev, dev);  
> > > >
> > > > ...
> > > >  
> > > >> -       struct pci_dev *pdev = container_of(dev, struct pci_dev, dev);
> > > >> +       struct pci_dev *pdev = to_pci_dev(dev);
> > > >>          struct intel_qep *qep = pci_get_drvdata(pdev);  
> > > >
> > > > Why not change both lines to dev_get_drvdata()?
> > > >  
> > > I thought it before and Uwe had a good point why it isn't necessarily a
> > > good idea:
> > >
> > > https://www.spinics.net/lists/linux-pwm/msg15325.html  
> > 
> > I understand this point, but the problem is that we often use
> > different callbacks for different layers. For example, the PM
> > callbacks are operating with generic 'struct device' and using the PCI
> > device there is non-flexible layering violation, so in my opinion it's
> > the opposite to what Uwe says. I.o.w. we need to use corresponding API
> > to what we have in the callbacks. If the callback comes from generic
> > level ==> generic APIs more appropriate.  
> 
> Without having looked at the driver in question: I (think I) understand
> both sides here and both variants have their own downside.
> 
>  - Using dev_get_drvdata() makes use of the fact that pci_set_drvdata()
>    is a wrapper around dev_set_drvdata for the pcidev's struct device.
> 
>  - Using pci_get_drvdata() adds overhead (for humans only though, the
>    compiler doesn't care and creates the same code) and having the pci
>    device in the callback isn't necessary.
> 
> My personal opinion is: The first is the graver layer violation because
> it relies on an implementation detail in the PCI framework. The latter
> is relying on a fact that is local to the driver only: All devices this
> driver is bound to are pci devices. The main benefit of explicitly using
> pci_get_drvdata ∘ to_pci_dev I see is that someone having only shallow
> knowledge of the PCI stuff can easier match a pci_get_drvdata() to the
> pci_set_drvdata() called in .probe() than a dev_get_drvdata() and so
> while it uses a function call/code line more, it is more explicit and
> more obviously correct.
> 
> And regarding your argument about the matching API: I think the above
> code uses the matching API, that is make a pci_dev from a device using
> to_pci_dev().
> 
> So this is about weighting up- and downsides. How you judge them is
> subjective. (Though my judgement is naturally the better one :-)

Personally I'm happy with either

dev_set_drvdata / dev_get_drvdata
or 
pci_set_drvdata / pci_get_drvdata

In this particular case there is a convenient struct device *dev local
variable anyway in the probe() (IIRC) so could have done option 1 with
no loss of readability and a tiny saving in code.

Not worth changing it though is my 0.02€

Jonathan

> 
> Just my 0.02€
> Uwe
> 




[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux