diff options
| author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2012-03-26 19:06:30 +0000 | 
|---|---|---|
| committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2012-03-28 11:33:24 +1100 | 
| commit | cb52d8970eee65bf2c47d9a91bd4f58b17f595f4 (patch) | |
| tree | 43521ba99805f293e09a284901cb5435afeab789 | |
| parent | 1d9a47315042606b4217691bcea36cfa6ccbde66 (diff) | |
| download | olio-linux-3.10-cb52d8970eee65bf2c47d9a91bd4f58b17f595f4.tar.xz olio-linux-3.10-cb52d8970eee65bf2c47d9a91bd4f58b17f595f4.zip  | |
powerpc+sparc/vio: Modernize driver registration
This makes vio_register_driver() get the module owner & name at compile
time like PCI drivers do, and adds a name pointer directly in struct
vio_driver to avoid having to explicitly initialize the embedded
struct device.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Acked-by: David S. Miller <davem@davemloft.net>
| -rw-r--r-- | arch/powerpc/include/asm/vio.h | 10 | ||||
| -rw-r--r-- | arch/powerpc/kernel/vio.c | 12 | ||||
| -rw-r--r-- | arch/sparc/include/asm/vio.h | 9 | ||||
| -rw-r--r-- | arch/sparc/kernel/ds.c | 5 | ||||
| -rw-r--r-- | arch/sparc/kernel/vio.c | 8 | ||||
| -rw-r--r-- | drivers/block/sunvdc.c | 5 | ||||
| -rw-r--r-- | drivers/net/ethernet/ibm/ibmveth.c | 7 | ||||
| -rw-r--r-- | drivers/net/ethernet/sun/sunvnet.c | 5 | ||||
| -rw-r--r-- | drivers/scsi/ibmvscsi/ibmvfc.c | 7 | ||||
| -rw-r--r-- | drivers/scsi/ibmvscsi/ibmvscsi.c | 7 | ||||
| -rw-r--r-- | drivers/scsi/ibmvscsi/ibmvstgt.c | 5 | ||||
| -rw-r--r-- | drivers/tty/hvc/hvc_vio.c | 7 | ||||
| -rw-r--r-- | drivers/tty/hvc/hvcs.c | 5 | 
13 files changed, 44 insertions, 48 deletions
diff --git a/arch/powerpc/include/asm/vio.h b/arch/powerpc/include/asm/vio.h index 0a290a19594..6bfd5ffe1d4 100644 --- a/arch/powerpc/include/asm/vio.h +++ b/arch/powerpc/include/asm/vio.h @@ -69,6 +69,7 @@ struct vio_dev {  };  struct vio_driver { +	const char *name;  	const struct vio_device_id *id_table;  	int (*probe)(struct vio_dev *dev, const struct vio_device_id *id);  	int (*remove)(struct vio_dev *dev); @@ -76,10 +77,17 @@ struct vio_driver {  	 * be loaded in a CMO environment if it uses DMA.  	 */  	unsigned long (*get_desired_dma)(struct vio_dev *dev); +	const struct dev_pm_ops *pm;  	struct device_driver driver;  }; -extern int vio_register_driver(struct vio_driver *drv); +extern int __vio_register_driver(struct vio_driver *drv, struct module *owner, +				 const char *mod_name); +/* + * vio_register_driver must be a macro so that KBUILD_MODNAME can be expanded + */ +#define vio_register_driver(driver)		\ +	__vio_register_driver(driver, THIS_MODULE, KBUILD_MODNAME)  extern void vio_unregister_driver(struct vio_driver *drv);  extern int vio_cmo_entitlement_update(size_t); diff --git a/arch/powerpc/kernel/vio.c b/arch/powerpc/kernel/vio.c index bca3fc427b4..b2f7c8480bf 100644 --- a/arch/powerpc/kernel/vio.c +++ b/arch/powerpc/kernel/vio.c @@ -1159,17 +1159,21 @@ static int vio_bus_remove(struct device *dev)   * vio_register_driver: - Register a new vio driver   * @drv:	The vio_driver structure to be registered.   */ -int vio_register_driver(struct vio_driver *viodrv) +int __vio_register_driver(struct vio_driver *viodrv, struct module *owner, +			  const char *mod_name)  { -	printk(KERN_DEBUG "%s: driver %s registering\n", __func__, -		viodrv->driver.name); +	pr_debug("%s: driver %s registering\n", __func__, viodrv->name);  	/* fill in 'struct driver' fields */ +	viodrv->driver.name = viodrv->name; +	viodrv->driver.pm = viodrv->pm;  	viodrv->driver.bus = &vio_bus_type; +	viodrv->driver.owner = owner; +	viodrv->driver.mod_name = mod_name;  	return driver_register(&viodrv->driver);  } -EXPORT_SYMBOL(vio_register_driver); +EXPORT_SYMBOL(__vio_register_driver);  /**   * vio_unregister_driver - Remove registration of vio driver. diff --git a/arch/sparc/include/asm/vio.h b/arch/sparc/include/asm/vio.h index 9d83d3bcb49..432afa83886 100644 --- a/arch/sparc/include/asm/vio.h +++ b/arch/sparc/include/asm/vio.h @@ -284,6 +284,7 @@ struct vio_dev {  };  struct vio_driver { +	const char			*name;  	struct list_head		node;  	const struct vio_device_id	*id_table;  	int (*probe)(struct vio_dev *dev, const struct vio_device_id *id); @@ -371,7 +372,13 @@ do {	if (vio->debug & VIO_DEBUG_##TYPE) \  		       vio->vdev->channel_id, ## a); \  } while (0) -extern int vio_register_driver(struct vio_driver *drv); +extern int __vio_register_driver(struct vio_driver *drv, struct module *owner, +				 const char *mod_name); +/* + * vio_register_driver must be a macro so that KBUILD_MODNAME can be expanded + */ +#define vio_register_driver(driver)		\ +	__vio_register_driver(driver, THIS_MODULE, KBUILD_MODNAME)  extern void vio_unregister_driver(struct vio_driver *drv);  static inline struct vio_driver *to_vio_driver(struct device_driver *drv) diff --git a/arch/sparc/kernel/ds.c b/arch/sparc/kernel/ds.c index 381edcd5bc2..fea13c7b1ae 100644 --- a/arch/sparc/kernel/ds.c +++ b/arch/sparc/kernel/ds.c @@ -1244,10 +1244,7 @@ static struct vio_driver ds_driver = {  	.id_table	= ds_match,  	.probe		= ds_probe,  	.remove		= ds_remove, -	.driver		= { -		.name	= "ds", -		.owner	= THIS_MODULE, -	} +	.name		= "ds",  };  static int __init ds_init(void) diff --git a/arch/sparc/kernel/vio.c b/arch/sparc/kernel/vio.c index f67e28ef598..5cffdc55f07 100644 --- a/arch/sparc/kernel/vio.c +++ b/arch/sparc/kernel/vio.c @@ -119,13 +119,17 @@ static struct bus_type vio_bus_type = {  	.remove		= vio_device_remove,  }; -int vio_register_driver(struct vio_driver *viodrv) +int __vio_register_driver(struct vio_driver *viodrv, struct module *owner, +			const char *mod_name)  {  	viodrv->driver.bus = &vio_bus_type; +	viodrv->driver.name = viodrv->name; +	viodrv->driver.owner = owner; +	viodrv->driver.mod_name = mod_name;  	return driver_register(&viodrv->driver);  } -EXPORT_SYMBOL(vio_register_driver); +EXPORT_SYMBOL(__vio_register_driver);  void vio_unregister_driver(struct vio_driver *viodrv)  { diff --git a/drivers/block/sunvdc.c b/drivers/block/sunvdc.c index 48e8fee9f2d..9dcf76a10bb 100644 --- a/drivers/block/sunvdc.c +++ b/drivers/block/sunvdc.c @@ -839,10 +839,7 @@ static struct vio_driver vdc_port_driver = {  	.id_table	= vdc_port_match,  	.probe		= vdc_port_probe,  	.remove		= vdc_port_remove, -	.driver		= { -		.name	= "vdc_port", -		.owner	= THIS_MODULE, -	} +	.name		= "vdc_port",  };  static int __init vdc_init(void) diff --git a/drivers/net/ethernet/ibm/ibmveth.c b/drivers/net/ethernet/ibm/ibmveth.c index e877371680a..9010cea68bc 100644 --- a/drivers/net/ethernet/ibm/ibmveth.c +++ b/drivers/net/ethernet/ibm/ibmveth.c @@ -1616,11 +1616,8 @@ static struct vio_driver ibmveth_driver = {  	.probe		= ibmveth_probe,  	.remove		= ibmveth_remove,  	.get_desired_dma = ibmveth_get_desired_dma, -	.driver		= { -		.name	= ibmveth_driver_name, -		.owner	= THIS_MODULE, -		.pm = &ibmveth_pm_ops, -	} +	.name		= ibmveth_driver_name, +	.pm		= &ibmveth_pm_ops,  };  static int __init ibmveth_module_init(void) diff --git a/drivers/net/ethernet/sun/sunvnet.c b/drivers/net/ethernet/sun/sunvnet.c index 92a037a8228..38e3ae9155b 100644 --- a/drivers/net/ethernet/sun/sunvnet.c +++ b/drivers/net/ethernet/sun/sunvnet.c @@ -1259,10 +1259,7 @@ static struct vio_driver vnet_port_driver = {  	.id_table	= vnet_port_match,  	.probe		= vnet_port_probe,  	.remove		= vnet_port_remove, -	.driver		= { -		.name	= "vnet_port", -		.owner	= THIS_MODULE, -	} +	.name		= "vnet_port",  };  static int __init vnet_init(void) diff --git a/drivers/scsi/ibmvscsi/ibmvfc.c b/drivers/scsi/ibmvscsi/ibmvfc.c index bdfa223a7db..134a0ae85bb 100644 --- a/drivers/scsi/ibmvscsi/ibmvfc.c +++ b/drivers/scsi/ibmvscsi/ibmvfc.c @@ -4890,11 +4890,8 @@ static struct vio_driver ibmvfc_driver = {  	.probe = ibmvfc_probe,  	.remove = ibmvfc_remove,  	.get_desired_dma = ibmvfc_get_desired_dma, -	.driver = { -		.name = IBMVFC_NAME, -		.owner = THIS_MODULE, -		.pm = &ibmvfc_pm_ops, -	} +	.name = IBMVFC_NAME, +	.pm = &ibmvfc_pm_ops,  };  static struct fc_function_template ibmvfc_transport_functions = { diff --git a/drivers/scsi/ibmvscsi/ibmvscsi.c b/drivers/scsi/ibmvscsi/ibmvscsi.c index e984951baeb..3a6c4742951 100644 --- a/drivers/scsi/ibmvscsi/ibmvscsi.c +++ b/drivers/scsi/ibmvscsi/ibmvscsi.c @@ -2061,11 +2061,8 @@ static struct vio_driver ibmvscsi_driver = {  	.probe = ibmvscsi_probe,  	.remove = ibmvscsi_remove,  	.get_desired_dma = ibmvscsi_get_desired_dma, -	.driver = { -		.name = "ibmvscsi", -		.owner = THIS_MODULE, -		.pm = &ibmvscsi_pm_ops, -	} +	.name = "ibmvscsi", +	.pm = &ibmvscsi_pm_ops,  };  static struct srp_function_template ibmvscsi_transport_functions = { diff --git a/drivers/scsi/ibmvscsi/ibmvstgt.c b/drivers/scsi/ibmvscsi/ibmvstgt.c index 2256babe047..aa7ed81e923 100644 --- a/drivers/scsi/ibmvscsi/ibmvstgt.c +++ b/drivers/scsi/ibmvscsi/ibmvstgt.c @@ -918,10 +918,7 @@ static struct vio_driver ibmvstgt_driver = {  	.id_table = ibmvstgt_device_table,  	.probe = ibmvstgt_probe,  	.remove = ibmvstgt_remove, -	.driver = { -		.name = "ibmvscsis", -		.owner = THIS_MODULE, -	} +	.name = "ibmvscsis",  };  static int get_system_info(void) diff --git a/drivers/tty/hvc/hvc_vio.c b/drivers/tty/hvc/hvc_vio.c index 3a0d53d6368..ee307799271 100644 --- a/drivers/tty/hvc/hvc_vio.c +++ b/drivers/tty/hvc/hvc_vio.c @@ -310,11 +310,8 @@ static int __devexit hvc_vio_remove(struct vio_dev *vdev)  static struct vio_driver hvc_vio_driver = {  	.id_table	= hvc_driver_table,  	.probe		= hvc_vio_probe, -	.remove		= __devexit_p(hvc_vio_remove), -	.driver		= { -		.name	= hvc_driver_name, -		.owner	= THIS_MODULE, -	} +	.remove		= hvc_vio_remove, +	.name		= hvc_driver_name,  };  static int __init hvc_vio_init(void) diff --git a/drivers/tty/hvc/hvcs.c b/drivers/tty/hvc/hvcs.c index d23759183b4..3436436fe2d 100644 --- a/drivers/tty/hvc/hvcs.c +++ b/drivers/tty/hvc/hvcs.c @@ -879,10 +879,7 @@ static struct vio_driver hvcs_vio_driver = {  	.id_table	= hvcs_driver_table,  	.probe		= hvcs_probe,  	.remove		= __devexit_p(hvcs_remove), -	.driver		= { -		.name	= hvcs_driver_name, -		.owner	= THIS_MODULE, -	} +	.name		= hvcs_driver_name,  };  /* Only called from hvcs_get_pi please */  |