From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
To: Jean Delvare <khali@linux-fr.org>
Cc: linux-kernel@vger.kernel.org, Peter Wu <lekensteyn@gmail.com>
Subject: Re: Freeing of dev->p
Date: Fri, 10 Jan 2014 07:24:02 -0800 [thread overview]
Message-ID: <20140110152402.GC22533@kroah.com> (raw)
In-Reply-To: <20140110153907.08297202@endymion.delvare>
On Fri, Jan 10, 2014 at 03:39:07PM +0100, Jean Delvare wrote:
> + * @driver_data: Private pointer for driver specific info. Will turn into a
> + * list soon.
Ah, this comment reminds me of why I originally did this. I was working
on moving for a way to have multiple drivers bound to the same device,
as people needed that type of thing for something that I can't remember
at the moment.
As it's been years now with no real movement forward on that idea, I
guess it's not going to happen :)
> * @power: For device power management.
> * See Documentation/power/devices.txt for details.
> * @pm_domain: Provide callbacks that are executed during system suspend,
> @@ -737,6 +739,8 @@ struct device {
> device */
> void *platform_data; /* Platform specific data, device
> core doesn't touch it */
> + void *driver_data; /* Driver data, set and get with
> + dev_set/get_drvdata */
> struct dev_pm_info power;
> struct dev_pm_domain *pm_domain;
>
>
> For performance I'd even question the point of the dev check in
> dev_get_drvdata(), especially when there is no such check in
> dev_set_drvdata() which presumably is always called first.
It's nice to not oops if a NULL pointer is passed in :)
> Plus dev_set_drvdata() can no longer fail (something only 3 drivers in
> the whole kernel tree were checking for anyway) so it could return
> void instead of int.
True.
> Then I suppose we could inline both functions
> again, for performance. Well, put in short, really revering
> b4028437876866aba4747a655ede00f892089e14 would be the way to go IMHO.
Almost, the copyright lines should stay :)
> Really, while I understand your envy to protect driver core internals
> from unwanted access, the cost here was simply too high IMHO, both in
> terms of getting things right and performance. Some drivers are calling
> dev_get_drvdata() directly or indirectly repeatedly at run-time. They
> had no reason not to as this used to be so fast, and now it is no
> longer an inline function, it has conditionals and a double pointer
> indirection...
>
> Plus, I can't think of anything really bad that could result from
> accessing driver_data directly, contrary to the other members of struct
> device_private.
See first response above for why I did this, it wasn't to just make
things "harder" to mess up, I actually had a reason to do it (imagine
that!)
Thanks for the detailed response, I think I'll just revert most of that
patch and see if it's still workable.
greg k-h
next prev parent reply other threads:[~2014-01-10 15:24 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-08 15:40 Freeing of dev->p Jean Delvare
2014-01-08 16:56 ` Greg Kroah-Hartman
2014-01-08 20:33 ` Jean Delvare
2014-01-10 4:18 ` Greg Kroah-Hartman
2014-01-10 14:39 ` Jean Delvare
2014-01-10 15:24 ` Greg Kroah-Hartman [this message]
2014-01-10 22:05 ` Jean Delvare
2014-01-22 7:29 ` Jean Delvare
2014-01-25 18:03 ` Greg Kroah-Hartman
2014-04-08 9:47 ` Grant Likely
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140110152402.GC22533@kroah.com \
--to=gregkh@linuxfoundation.org \
--cc=khali@linux-fr.org \
--cc=lekensteyn@gmail.com \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox