Commit 17263905 authored by Akinobu Mita's avatar Akinobu Mita Committed by Tejun Heo

ata: pata_platform: fix owner module reference mismatch for scsi host

The owner module reference of the pata_of_platform's scsi_host is
initialized to pata_platform's one, because pata_of_platform driver
use a scsi_host_template defined in pata_platform.  So this drivers
can be unloaded even if the scsi device is being accessed.

This fixes it by propagating the scsi_host_template to pata_of_platform
driver.  The scsi_host_template is passed through a new
argument of __pata_platform_probe().
Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Cc: Hans de Goede <hdegoede@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: "James E.J. Bottomley" <JBottomley@parallels.com>
Cc: linux-ide@vger.kernel.org
Cc: linux-scsi@vger.kernel.org
parent 018d5ef2
...@@ -16,6 +16,12 @@ ...@@ -16,6 +16,12 @@
#include <linux/ata_platform.h> #include <linux/ata_platform.h>
#include <linux/libata.h> #include <linux/libata.h>
#define DRV_NAME "pata_of_platform"
static struct scsi_host_template pata_platform_sht = {
ATA_PIO_SHT(DRV_NAME),
};
static int pata_of_platform_probe(struct platform_device *ofdev) static int pata_of_platform_probe(struct platform_device *ofdev)
{ {
int ret; int ret;
...@@ -63,7 +69,7 @@ static int pata_of_platform_probe(struct platform_device *ofdev) ...@@ -63,7 +69,7 @@ static int pata_of_platform_probe(struct platform_device *ofdev)
pio_mask |= (1 << pio_mode) - 1; pio_mask |= (1 << pio_mode) - 1;
return __pata_platform_probe(&ofdev->dev, &io_res, &ctl_res, irq_res, return __pata_platform_probe(&ofdev->dev, &io_res, &ctl_res, irq_res,
reg_shift, pio_mask); reg_shift, pio_mask, &pata_platform_sht);
} }
static struct of_device_id pata_of_platform_match[] = { static struct of_device_id pata_of_platform_match[] = {
...@@ -74,7 +80,7 @@ MODULE_DEVICE_TABLE(of, pata_of_platform_match); ...@@ -74,7 +80,7 @@ MODULE_DEVICE_TABLE(of, pata_of_platform_match);
static struct platform_driver pata_of_platform_driver = { static struct platform_driver pata_of_platform_driver = {
.driver = { .driver = {
.name = "pata_of_platform", .name = DRV_NAME,
.of_match_table = pata_of_platform_match, .of_match_table = pata_of_platform_match,
}, },
.probe = pata_of_platform_probe, .probe = pata_of_platform_probe,
......
...@@ -78,6 +78,7 @@ static void pata_platform_setup_port(struct ata_ioports *ioaddr, ...@@ -78,6 +78,7 @@ static void pata_platform_setup_port(struct ata_ioports *ioaddr,
* @irq_res: Resource representing IRQ and its flags * @irq_res: Resource representing IRQ and its flags
* @ioport_shift: I/O port shift * @ioport_shift: I/O port shift
* @__pio_mask: PIO mask * @__pio_mask: PIO mask
* @sht: scsi_host_template to use when registering
* *
* Register a platform bus IDE interface. Such interfaces are PIO and we * Register a platform bus IDE interface. Such interfaces are PIO and we
* assume do not support IRQ sharing. * assume do not support IRQ sharing.
...@@ -99,7 +100,8 @@ static void pata_platform_setup_port(struct ata_ioports *ioaddr, ...@@ -99,7 +100,8 @@ static void pata_platform_setup_port(struct ata_ioports *ioaddr,
*/ */
int __pata_platform_probe(struct device *dev, struct resource *io_res, int __pata_platform_probe(struct device *dev, struct resource *io_res,
struct resource *ctl_res, struct resource *irq_res, struct resource *ctl_res, struct resource *irq_res,
unsigned int ioport_shift, int __pio_mask) unsigned int ioport_shift, int __pio_mask,
struct scsi_host_template *sht)
{ {
struct ata_host *host; struct ata_host *host;
struct ata_port *ap; struct ata_port *ap;
...@@ -170,7 +172,7 @@ int __pata_platform_probe(struct device *dev, struct resource *io_res, ...@@ -170,7 +172,7 @@ int __pata_platform_probe(struct device *dev, struct resource *io_res,
/* activate */ /* activate */
return ata_host_activate(host, irq, irq ? ata_sff_interrupt : NULL, return ata_host_activate(host, irq, irq ? ata_sff_interrupt : NULL,
irq_flags, &pata_platform_sht); irq_flags, sht);
} }
EXPORT_SYMBOL_GPL(__pata_platform_probe); EXPORT_SYMBOL_GPL(__pata_platform_probe);
...@@ -216,7 +218,7 @@ static int pata_platform_probe(struct platform_device *pdev) ...@@ -216,7 +218,7 @@ static int pata_platform_probe(struct platform_device *pdev)
return __pata_platform_probe(&pdev->dev, io_res, ctl_res, irq_res, return __pata_platform_probe(&pdev->dev, io_res, ctl_res, irq_res,
pp_info ? pp_info->ioport_shift : 0, pp_info ? pp_info->ioport_shift : 0,
pio_mask); pio_mask, &pata_platform_sht);
} }
static struct platform_driver pata_platform_driver = { static struct platform_driver pata_platform_driver = {
......
...@@ -10,12 +10,15 @@ struct pata_platform_info { ...@@ -10,12 +10,15 @@ struct pata_platform_info {
unsigned int ioport_shift; unsigned int ioport_shift;
}; };
struct scsi_host_template;
extern int __pata_platform_probe(struct device *dev, extern int __pata_platform_probe(struct device *dev,
struct resource *io_res, struct resource *io_res,
struct resource *ctl_res, struct resource *ctl_res,
struct resource *irq_res, struct resource *irq_res,
unsigned int ioport_shift, unsigned int ioport_shift,
int __pio_mask); int __pio_mask,
struct scsi_host_template *sht);
/* /*
* Marvell SATA private data * Marvell SATA private data
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment