aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/xtsonic.c
diff options
context:
space:
mode:
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>2009-07-21 07:25:27 -0400
committerDavid S. Miller <davem@davemloft.net>2009-07-23 21:01:08 -0400
commit0c9cd395faca5ccf549e2bcb6b09086962c112b0 (patch)
treebcad2f9eb8a72ac8dae16310614362469ac20f40 /drivers/net/xtsonic.c
parentffe8553f8871dabf61d49e7f97a2c6cbc7dc23cb (diff)
net: move xtsonic's probe function to .devinit.text
A pointer to xtsonic_probe 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@pengutronix.de> Cc: Chris Zankel <chris@zankel.net> Cc: David S. Miller <davem@davemloft.net> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Greg Kroah-Hartman <gregkh@suse.de> Cc: netdev@vger.kernel.org Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/xtsonic.c')
-rw-r--r--drivers/net/xtsonic.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/xtsonic.c b/drivers/net/xtsonic.c
index 5a4ad156f63e..0c44135c0b1f 100644
--- a/drivers/net/xtsonic.c
+++ b/drivers/net/xtsonic.c
@@ -239,7 +239,7 @@ out:
239 * Actually probing is superfluous but we're paranoid. 239 * Actually probing is superfluous but we're paranoid.
240 */ 240 */
241 241
242int __init xtsonic_probe(struct platform_device *pdev) 242int __devinit xtsonic_probe(struct platform_device *pdev)
243{ 243{
244 struct net_device *dev; 244 struct net_device *dev;
245 struct sonic_local *lp; 245 struct sonic_local *lp;