From: "Uwe Kleine-König" <u.kleine-koenig@pengutronix.de>
To: Greg KH <gregkh@suse.de>
Cc: linux-kernel@vger.kernel.org
Subject: Re: [PATCH] platform_driver_register: warn if probe is in .init.text
Date: Fri, 19 Jun 2009 16:43:54 +0200 [thread overview]
Message-ID: <20090619144354.GA20985@pengutronix.de> (raw)
In-Reply-To: <20090619141128.GA11506@suse.de>
Hi Greg,
On Fri, Jun 19, 2009 at 07:11:28AM -0700, Greg KH wrote:
> On Fri, Jun 19, 2009 at 03:42:19PM +0200, Uwe Kleine-König wrote:
> > Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
> > ---
> > drivers/base/platform.c | 42 ++++++++++++++++++++++++++++++++++++------
> > include/linux/kernel.h | 2 ++
> > include/linux/module.h | 12 ++++++++++++
> > kernel/extable.c | 12 ++++++++++++
> > kernel/module.c | 36 ++++++++++++++++++++++++++++++++++++
> > 5 files changed, 98 insertions(+), 6 deletions(-)
> >
> > diff --git a/drivers/base/platform.c b/drivers/base/platform.c
> > index 81cb01b..851ba84 100644
> > --- a/drivers/base/platform.c
> > +++ b/drivers/base/platform.c
> > @@ -470,11 +470,7 @@ static void platform_drv_shutdown(struct device *_dev)
> > drv->shutdown(dev);
> > }
> >
> > -/**
> > - * platform_driver_register
> > - * @drv: platform driver structure
> > - */
> > -int platform_driver_register(struct platform_driver *drv)
> > +static int __platform_driver_register(struct platform_driver *drv)
> > {
> > drv->driver.bus = &platform_bus_type;
> > if (drv->probe)
> > @@ -489,6 +485,40 @@ int platform_driver_register(struct platform_driver *drv)
> >
> > return driver_register(&drv->driver);
> > }
> > +
> > +/**
> > + * platform_driver_register
> > + * @drv: platform driver structure
> > + */
> > +int platform_driver_register(struct platform_driver *drv)
> > +{
> > + int ret = __platform_driver_register(drv);
> > +
> > +#if defined(CONFIG_HOTPLUG)
> > + /*
> > + * drivers that are registered by platform_driver_register
> > + * should not have their probe function in .init.text. The
> > + * reason is that a probe can happen after .init.text is
> > + * discarded which then results in an oops. The alternatives
> > + * are using .devinit.text for the probe function or "register"
> > + * with platform_driver_probe.
> > + */
>
> That's not true, remember, drivers built into the system, like platform
> ones, can have their probe function in .init.text, as it will be called
> before we discard .init.text, and will never be called again as the
> device will never be "hot added" at any future time.
>
> So this could trigger a lot of false positives :(
IMHO this is not a false positive. You can still do
for f in unbind bind do echo $deviceid > /sys/bus/platform/drivers/$drivername/$f; done
This type of driver should use platform_driver_probe.
Best regards
Uwe
--
Pengutronix e.K. | Uwe Kleine-König |
Industrial Linux Solutions | http://www.pengutronix.de/ |
next prev parent reply other threads:[~2009-06-19 14:44 UTC|newest]
Thread overview: 188+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-06-16 5:13 [GIT PATCH] USB patches for 2.6.30-git Greg KH
[not found] ` <1245129858-23818-12-git-send-email-gregkh@suse.de>
2009-06-16 6:05 ` [PATCH 012/143] USB: move twl4030_usb's probe function to .devinit.text Uwe Kleine-König
2009-06-16 6:20 ` Greg KH
2009-06-16 9:14 ` Uwe Kleine-König
2009-06-16 16:21 ` Greg KH
2009-06-16 17:59 ` Uwe Kleine-König
2009-06-16 18:00 ` Greg KH
2009-06-16 18:23 ` Uwe Kleine-König
2009-06-19 13:42 ` [PATCH] platform_driver_register: warn if probe is in .init.text Uwe Kleine-König
2009-06-19 14:11 ` Greg KH
2009-06-19 14:43 ` Uwe Kleine-König [this message]
2009-06-29 7:55 ` Uwe Kleine-König
2009-07-11 3:34 ` Greg KH
2009-07-11 10:00 ` Uwe Kleine-König
2009-07-11 17:05 ` Greg KH
2009-07-11 20:52 ` [PATCH] move acornfb's probe function to .devinit.text Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move am79c961's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move arcfb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move at91_ether's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move cfag12864bfb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move leds-clevo-mail's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move cobalt-lcd's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move corgi-ssp's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move efifb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move epson1355fb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move sh_flctl's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move gbefb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move h1940-bt's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move hgafb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move hitfb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move hp680-bl's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move hp-wmi's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move jazzsonic's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move jornada_ssp's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move macsonic's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move meth's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move omap24xxcam's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move omap_hdq's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move i2c_omap's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move mmci-omap-hs's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move orion_nand's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move q40fb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move s3c241xfb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move sa11x0-fb's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move sb1250-mac's " Uwe Kleine-König
2009-07-11 20:52 ` [PATCH] move sgiseeq's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move sgivwfb's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move sgiwd93's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move sharpsl-pm's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move sh_mobile_lcdc_fb's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move snirm_53c710's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move stk17ta8's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move omap_udc's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move vesafb's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move vfb's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move vga16fb's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move w100fb's " Uwe Kleine-König
2009-07-11 20:53 ` [PATCH] move xtsonic's " Uwe Kleine-König
2009-07-11 22:26 ` [PATCH] move w100fb's " Ian molton
2009-07-11 22:30 ` [PATCH] move omap_udc's " David Brownell
2009-07-12 8:35 ` Uwe Kleine-König
2009-07-12 8:47 ` Russell King
2009-07-12 9:30 ` David Brownell
2009-07-12 13:17 ` Russell King
2009-07-12 20:07 ` David Brownell
2009-07-12 22:21 ` David Brownell
2009-07-13 9:10 ` Uwe Kleine-König
2009-07-13 21:31 ` David Brownell
2009-07-12 9:37 ` David Brownell
2009-07-12 20:48 ` Uwe Kleine-König
2009-07-12 22:12 ` David Brownell
2009-07-13 9:12 ` [PATCH] don't add clevo_mail_led_driver's probe function to the driver struct Uwe Kleine-König
2009-08-13 9:59 ` [PATCH] move stk17ta8's probe function to .devinit.text Jiri Kosina
2009-10-09 15:24 ` Jiri Kosina
2009-10-09 18:33 ` Alessandro Zummo
2009-10-09 21:22 ` Jiri Kosina
2009-10-09 21:55 ` Alessandro Zummo
2009-07-12 0:36 ` [PATCH] move sb1250-mac's " Maciej W. Rozycki
2009-07-13 19:37 ` [PATCH] move orion_nand's " Nicolas Pitre
2009-07-14 8:09 ` Uwe Kleine-König
2009-07-14 16:12 ` Nicolas Pitre
2009-07-14 17:17 ` Uwe Kleine-König
2009-07-21 20:46 ` [PATCH] register orion_nand using platform_driver_probe Uwe Kleine-König
2009-07-21 22:26 ` Nicolas Pitre
2009-07-22 5:17 ` Uwe Kleine-König
2009-07-11 22:29 ` [PATCH] move mmci-omap-hs's probe function to .devinit.text David Brownell
2009-07-21 20:36 ` [PATCH] register mmci-omap-hs using platform_driver_probe Uwe Kleine-König
2009-07-22 17:38 ` David Brownell
2009-07-21 15:14 ` [PATCH] move macsonic's probe function to .devinit.text Finn Thain
2009-07-21 19:20 ` Uwe Kleine-König
2009-07-21 19:20 ` David Miller
2009-07-21 19:40 ` Uwe Kleine-König
2009-07-21 19:41 ` David Miller
2009-09-19 23:09 ` [PATCH] move sh_flctl's " David Woodhouse
2009-09-21 7:43 ` Uwe Kleine-König
2009-07-13 13:51 ` [PATCH] move efifb's " Peter Jones
2009-07-13 8:44 ` [PATCH] move corgi-ssp's " Eric Miao
2009-07-13 9:01 ` Uwe Kleine-König
2009-07-11 22:27 ` [PATCH] move at91_ether's " David Brownell
2009-07-21 20:11 ` [PATCH] register at91_ether using platform_driver_probe Uwe Kleine-König
2009-07-22 17:37 ` David Brownell
2009-07-22 17:46 ` Andrew Victor
2009-07-22 18:24 ` David Miller
2009-09-07 14:19 ` [PATCH] platform_driver_register: warn if probe is in .init.text Uwe Kleine-König
2010-01-22 17:06 ` Uwe Kleine-König
2010-01-22 17:38 ` Greg KH
2010-01-22 19:49 ` Uwe Kleine-König
2010-01-22 23:49 ` Dmitry Torokhov
2010-01-23 9:49 ` Uwe Kleine-König
2010-01-25 17:14 ` Dmitry Torokhov
2010-01-25 19:25 ` Uwe Kleine-König
2010-01-25 19:31 ` Dmitry Torokhov
2010-01-23 20:35 ` [PATCH 01/29] move acornfb's probe function to .devinit.text Uwe Kleine-König
2010-01-23 23:25 ` Alexey Dobriyan
2010-01-23 23:28 ` Alexey Dobriyan
2010-01-26 8:46 ` Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 02/29] move am79c961's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 03/29] move arcfb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 04/29] move cfag12864bfb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 05/29] move cobalt-lcd's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 06/29] move corgi-ssp's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 07/29] move efifb's " Uwe Kleine-König
2010-01-26 16:20 ` Peter Jones
2010-01-23 20:35 ` [PATCH 08/29] move epson1355fb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 09/29] move gbefb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 10/29] move h1940-bt's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 11/29] move hgafb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 12/29] move hitfb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 13/29] move hp-wmi's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 14/29] move jornada_ssp's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 15/29] move omap24xxcam's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 16/29] move omap_hdq's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 17/29] move i2c_omap's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 18/29] move q40fb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 19/29] move s3c241xfb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 20/29] move sa11x0-fb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 21/29] move sgivwfb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 22/29] move sgiwd93's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 23/29] move sharpsl-pm's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 24/29] move sh_mobile_lcdc_fb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 25/29] move snirm_53c710's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 26/29] move vesafb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 27/29] move vfb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 28/29] move vga16fb's " Uwe Kleine-König
2010-01-23 20:35 ` [PATCH 29/29] move w100fb's " Uwe Kleine-König
2010-01-24 21:09 ` [PATCH] platform_driver_register: warn if probe is in .init.text OGAWA Hirofumi
2010-01-26 8:47 ` Uwe Kleine-König
2010-01-28 1:14 ` Greg KH
2010-01-30 20:44 ` Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 1/7] modpost: members of *driver structs should not point to __init functions Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 2/7] modpost: define ALL_XYX{IN,EX}IT_SECTIONS Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 3/7] modpost: give most mismatch constants a better name Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 4/7] modpost: pass around const struct sectioncheck * instead of enum mismatch Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 5/7] modpost: remove now unused NO_MISMATCH constant Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 6/7] modpost: make symbol white list a per mismatch type variable Uwe Kleine-König
2010-01-30 20:46 ` [PATCH 7/7] modpost: don't allow *driver to reference .init.* Uwe Kleine-König
2010-01-31 16:02 ` [PATCH] platform_driver_register: warn if probe is in .init.text Sam Ravnborg
2010-01-31 20:13 ` Uwe Kleine-König
2010-02-02 15:25 ` Michal Marek
2010-02-01 14:57 ` [PATCH] i2c/imx: don't add probe function to the driver struct Uwe Kleine-König
2010-01-26 8:59 ` [PATCH] platform_driver_register: warn if probe is in .init.text Uwe Kleine-König
2010-01-26 14:30 ` Greg KH
2010-01-28 18:02 ` Greg KH
2010-02-03 9:42 ` Uwe Kleine-König
2010-02-03 15:08 ` Greg KH
2010-02-04 19:56 ` [PATCH 1/9] platform-drivers: move probe to .devinit.text in arch/arm Uwe Kleine-König
2010-02-04 20:56 ` Dmitry Eremin-Solenikov
2010-02-04 21:09 ` Kristoffer Ericson
2010-02-04 21:20 ` Arnaud Patard
2010-02-04 19:56 ` [PATCH 2/9] platform-drivers: move probe to .devinit.text in drivers/scsi Uwe Kleine-König
2010-02-04 20:25 ` Ralf Baechle
2010-02-04 21:31 ` Uwe Kleine-König
2010-02-04 19:56 ` [PATCH 4/9] x86: move hp-wmi's probe function to .devinit.text Uwe Kleine-König
2010-02-04 20:05 ` Matthew Garrett
2010-02-04 19:56 ` [PATCH 5/9] i2c: move i2c_omap's " Uwe Kleine-König
2010-02-04 19:56 ` [PATCH 6/9] w1: move omap_hdq's " Uwe Kleine-König
2010-02-04 19:56 ` [PATCH 7/9] media: move omap24xxcam's " Uwe Kleine-König
2010-02-04 19:56 ` [PATCH 8/9] auxdisplay: move cfag12864bfb's " Uwe Kleine-König
2010-02-04 19:56 ` [PATCH 9/9] net: move am79c961's " Uwe Kleine-König
2010-02-04 20:05 ` David Miller
2010-02-04 20:06 ` Uwe Kleine-König
2010-02-12 20:11 ` David Miller
2010-02-17 20:46 ` Greg KH
2009-09-21 7:54 ` [PATCH] platform_driver_register: warn if probe is in .init.text Uwe Kleine-König
2009-07-11 18:59 ` Greg KH
2009-07-11 20:46 ` Uwe Kleine-König
2009-07-16 22:58 ` Greg KH
2009-07-17 8:34 ` Uwe Kleine-König
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=20090619144354.GA20985@pengutronix.de \
--to=u.kleine-koenig@pengutronix.de \
--cc=gregkh@suse.de \
--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;
as well as URLs for NNTP newsgroup(s).