2009/3/11 Geert Uytterhoeven <geert@xxxxxxxxxxxxxx>: > commit 76afea5b078d36ec080a75c29ff5a3fbc5774fee > Author: Ming Lei <tom.leiming@xxxxxxxxx> > Date: Fri Feb 6 23:40:12 2009 +0800 > > platform driver: fix incorrect use of 'platform_bus_type' with 'struct devic > > This patch fixes the bug reported in > http://bugzilla.kernel.org/show_bug.cgi?id=11681. > > "Lots of device drivers register a 'struct device_driver' with > the '.bus' member set to '&platform_bus_type'. This is wrong, > since the platform_bus functions expect the 'struct device_driver' > to be wrapped up in a 'struct platform_driver' which provides > some additional callbacks (like suspend_late, resume_early). > The effect may be that platform_suspend_late() uses bogus data > outside the device_driver struct as a pointer pointer to the > device driver's suspend_late() function or other hard to > reproduce failures."(Lothar Wassmann) > > Signed-off-by: Ming Lei <tom.leiming@xxxxxxxxx> > Acked-by: Henrique de Moraes Holschuh <hmh@xxxxxxxxxx> > Acked-by: David Brownell <dbrownell@xxxxxxxxxxxxxxxxxxxxx> > Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxx> > > This introduced the following warnings on m68k, as `dev' is now a > `struct platform_device *' instead of a `struct device *': > > | drivers/scsi/a4000t.c:64: warning: passing argument 3 of 'NCR_700_detect' from incompatible pointer type > | drivers/scsi/mvme16x_scsi.c:67: warning: passing argument 3 of 'NCR_700_detect' from incompatible pointer type > | drivers/scsi/bvme6000_scsi.c:61: warning: passing argument 3 of 'NCR_700_detect' from incompatible pointer type > > I think the below is missing (untested on real hardware)? Yes, you are correct. It is really missed. Thanks! > > diff --git a/drivers/scsi/a4000t.c b/drivers/scsi/a4000t.c > index 6d25aca..61af3d9 100644 > --- a/drivers/scsi/a4000t.c > +++ b/drivers/scsi/a4000t.c > @@ -61,7 +61,8 @@ static int __devinit a4000t_probe(struct platform_device *dev) > hostdata->dcntl_extra = EA_710; > > /* and register the chip */ > - host = NCR_700_detect(&a4000t_scsi_driver_template, hostdata, dev); > + host = NCR_700_detect(&a4000t_scsi_driver_template, hostdata, > + &dev->dev); > if (!host) { > printk(KERN_ERR "a4000t-scsi: No host detected; " > "board configuration problem?\n"); > diff --git a/drivers/scsi/bvme6000_scsi.c b/drivers/scsi/bvme6000_scsi.c > index 9e9a82b..5799cb5 100644 > --- a/drivers/scsi/bvme6000_scsi.c > +++ b/drivers/scsi/bvme6000_scsi.c > @@ -58,7 +58,8 @@ bvme6000_probe(struct platform_device *dev) > hostdata->ctest7_extra = CTEST7_TT1; > > /* and register the chip */ > - host = NCR_700_detect(&bvme6000_scsi_driver_template, hostdata, dev); > + host = NCR_700_detect(&bvme6000_scsi_driver_template, hostdata, > + &dev->dev); > if (!host) { > printk(KERN_ERR "bvme6000-scsi: No host detected; " > "board configuration problem?\n"); > diff --git a/drivers/scsi/mvme16x_scsi.c b/drivers/scsi/mvme16x_scsi.c > index 7794fc1..b5fbfd6 100644 > --- a/drivers/scsi/mvme16x_scsi.c > +++ b/drivers/scsi/mvme16x_scsi.c > @@ -64,7 +64,8 @@ mvme16x_probe(struct platform_device *dev) > hostdata->ctest7_extra = CTEST7_TT1; > > /* and register the chip */ > - host = NCR_700_detect(&mvme16x_scsi_driver_template, hostdata, dev); > + host = NCR_700_detect(&mvme16x_scsi_driver_template, hostdata, > + &dev->dev); > if (!host) { > printk(KERN_ERR "mvme16x-scsi: No host detected; " > "board configuration problem?\n"); > > Gr{oetje,eeting}s, > > Geert > > -- > Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx > > In personal conversations with technical people, I call myself a hacker. But > when I'm talking to journalists I just say "programmer" or something like that. > -- Linus Torvalds > -- Lei Ming -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html