The patch titled platform-drivers: move probe to .devinit.text in arch/arm has been added to the -mm tree. Its filename is platform-drivers-move-probe-to-devinittext-in-arch-arm.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/SubmitChecklist when testing your code *** See http://userweb.kernel.org/~akpm/stuff/added-to-mm.txt to find out what to do about this The current -mm tree may be found at http://userweb.kernel.org/~akpm/mmotm/ ------------------------------------------------------ Subject: platform-drivers: move probe to .devinit.text in arch/arm From: Uwe Kleine-König <u.kleine-koenig@xxxxxxxxxxxxxx> A pointer to a probe callback is passed to the core via platform_driver_register and so the function must not disappear when the .init sections are discarded. Otherwise (if also having HOTPLUG=y) unbinding and binding a device to the driver via sysfs will result in an oops as does a device being registered late. An alternative to this patch is using platform_driver_probe instead of platform_driver_register plus removing the pointer to the probe function from the struct platform_driver. Signed-off-by: Uwe Kleine-König <u.kleine-koenig@xxxxxxxxxxxxxx> Acked-by: Dmitry Eremin-Solenikov <dbaryshkov@xxxxxxxxx> Acked-by: Kristoffer Ericson <kristoffer.ericson@xxxxxxxxx> Acked-by: Arnaud Patard <arnaud.patard@xxxxxxxxxxx> Cc: Ben Dooks <ben-linux@xxxxxxxxx> Cc: Eric Miao <eric.miao@xxxxxxxxxxx> Cc: Liam Girdwood <liam.girdwood@xxxxxxxxxxxxxxxx> Cc: Paul Sokolovsky <pmiscml@xxxxxxxxx> Cc: Richard Purdie <rpurdie@xxxxxxxxx> Cc: Russell King <rmk+kernel@xxxxxxxxxxxxxxxx> Cc: Greg KH <greg@xxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- arch/arm/mach-pxa/corgi_ssp.c | 2 +- arch/arm/mach-pxa/sharpsl_pm.c | 2 +- arch/arm/mach-s3c2410/h1940-bluetooth.c | 2 +- arch/arm/mach-sa1100/jornada720_ssp.c | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff -puN arch/arm/mach-pxa/corgi_ssp.c~platform-drivers-move-probe-to-devinittext-in-arch-arm arch/arm/mach-pxa/corgi_ssp.c --- a/arch/arm/mach-pxa/corgi_ssp.c~platform-drivers-move-probe-to-devinittext-in-arch-arm +++ a/arch/arm/mach-pxa/corgi_ssp.c @@ -204,7 +204,7 @@ void __init corgi_ssp_set_machinfo(struc ssp_machinfo = machinfo; } -static int __init corgi_ssp_probe(struct platform_device *dev) +static int __devinit corgi_ssp_probe(struct platform_device *dev) { int ret; diff -puN arch/arm/mach-pxa/sharpsl_pm.c~platform-drivers-move-probe-to-devinittext-in-arch-arm arch/arm/mach-pxa/sharpsl_pm.c --- a/arch/arm/mach-pxa/sharpsl_pm.c~platform-drivers-move-probe-to-devinittext-in-arch-arm +++ a/arch/arm/mach-pxa/sharpsl_pm.c @@ -900,7 +900,7 @@ static struct platform_suspend_ops sharp }; #endif -static int __init sharpsl_pm_probe(struct platform_device *pdev) +static int __devinit sharpsl_pm_probe(struct platform_device *pdev) { int ret; diff -puN arch/arm/mach-s3c2410/h1940-bluetooth.c~platform-drivers-move-probe-to-devinittext-in-arch-arm arch/arm/mach-s3c2410/h1940-bluetooth.c --- a/arch/arm/mach-s3c2410/h1940-bluetooth.c~platform-drivers-move-probe-to-devinittext-in-arch-arm +++ a/arch/arm/mach-s3c2410/h1940-bluetooth.c @@ -56,7 +56,7 @@ static const struct rfkill_ops h1940bt_r .set_block = h1940bt_set_block, }; -static int __init h1940bt_probe(struct platform_device *pdev) +static int __devinit h1940bt_probe(struct platform_device *pdev) { struct rfkill *rfk; int ret = 0; diff -puN arch/arm/mach-sa1100/jornada720_ssp.c~platform-drivers-move-probe-to-devinittext-in-arch-arm arch/arm/mach-sa1100/jornada720_ssp.c --- a/arch/arm/mach-sa1100/jornada720_ssp.c~platform-drivers-move-probe-to-devinittext-in-arch-arm +++ a/arch/arm/mach-sa1100/jornada720_ssp.c @@ -130,7 +130,7 @@ void jornada_ssp_end(void) }; EXPORT_SYMBOL(jornada_ssp_end); -static int __init jornada_ssp_probe(struct platform_device *dev) +static int __devinit jornada_ssp_probe(struct platform_device *dev) { int ret; _ Patches currently in -mm which might be from u.kleine-koenig@xxxxxxxxxxxxxx are origin.patch linux-next.patch mtd-nand-fix-build-failure-caused-by-typo.patch mx1-mx2-einval-overwritten-in-second-iteration-in-mxc_gpio_setup_multiple_pins.patch hrtimer-correct-a-few-numbers-in-comments.patch clockevents-ensure-taht-min_delta_ns-is-increased-in-error-path.patch genirq-warn-about-irqf_sharedirqf_disabled-at-the-right-place.patch rtc-pcf2123-move-pcf2123_remove-to-devexittext.patch platform-drivers-move-probe-to-devinittext-in-arch-arm.patch platform-drivers-move-probe-to-devinittext-in-drivers-scsi.patch platform-drivers-move-probe-to-devinittext-in-drivers-video.patch x86-move-hp-wmis-probe-function-to-devinittext.patch i2c-move-i2c_omaps-probe-function-to-devinittext.patch w1-move-omap_hdqs-probe-function-to-devinittext.patch media-move-omap24xxcams-probe-function-to-devinittext.patch auxdisplay-move-cfag12864bfbs-probe-function-to-devinittext.patch net-move-am79c961s-probe-function-to-devinittext.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html