mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 17:57:15 +00:00 
			
		
		
		
	s390: remove driver_data direct access of struct device
In the near future, the driver core is going to not allow direct access to the driver_data pointer in struct device. Instead, the functions dev_get_drvdata() and dev_set_drvdata() should be used. These functions have been around since the beginning, so are backwards compatible with all older kernel versions. Thanks to Sebastian Ott <sebott@linux.vnet.ibm.com> for fixing a few typos in my original version of this patch. Cc: Martin Schwidefsky <schwidefsky@de.ibm.com> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Cc: Sebastian Ott <sebott@linux.vnet.ibm.com> Cc: linux-s390@vger.kernel.org Cc: linux390@de.ibm.com Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
		
							parent
							
								
									61616115d7
								
							
						
					
					
						commit
						dff59b64af
					
				| @ -368,7 +368,7 @@ raw3215_irq(struct ccw_device *cdev, unsigned long intparm, struct irb *irb) | |||||||
| 	int cstat, dstat; | 	int cstat, dstat; | ||||||
| 	int count; | 	int count; | ||||||
| 
 | 
 | ||||||
| 	raw = cdev->dev.driver_data; | 	raw = dev_get_drvdata(&cdev->dev); | ||||||
| 	req = (struct raw3215_req *) intparm; | 	req = (struct raw3215_req *) intparm; | ||||||
| 	cstat = irb->scsw.cmd.cstat; | 	cstat = irb->scsw.cmd.cstat; | ||||||
| 	dstat = irb->scsw.cmd.dstat; | 	dstat = irb->scsw.cmd.dstat; | ||||||
| @ -635,7 +635,7 @@ raw3215_probe (struct ccw_device *cdev) | |||||||
| 	int line; | 	int line; | ||||||
| 
 | 
 | ||||||
| 	/* Console is special. */ | 	/* Console is special. */ | ||||||
| 	if (raw3215[0] && (cdev->dev.driver_data == raw3215[0])) | 	if (raw3215[0] && (raw3215[0] == dev_get_drvdata(&cdev->dev))) | ||||||
| 		return 0; | 		return 0; | ||||||
| 	raw = kmalloc(sizeof(struct raw3215_info) + | 	raw = kmalloc(sizeof(struct raw3215_info) + | ||||||
| 		      RAW3215_INBUF_SIZE, GFP_KERNEL|GFP_DMA); | 		      RAW3215_INBUF_SIZE, GFP_KERNEL|GFP_DMA); | ||||||
| @ -669,7 +669,7 @@ raw3215_probe (struct ccw_device *cdev) | |||||||
| 	} | 	} | ||||||
| 	init_waitqueue_head(&raw->empty_wait); | 	init_waitqueue_head(&raw->empty_wait); | ||||||
| 
 | 
 | ||||||
| 	cdev->dev.driver_data = raw; | 	dev_set_drvdata(&cdev->dev, raw); | ||||||
| 	cdev->handler = raw3215_irq; | 	cdev->handler = raw3215_irq; | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
| @ -681,9 +681,9 @@ raw3215_remove (struct ccw_device *cdev) | |||||||
| 	struct raw3215_info *raw; | 	struct raw3215_info *raw; | ||||||
| 
 | 
 | ||||||
| 	ccw_device_set_offline(cdev); | 	ccw_device_set_offline(cdev); | ||||||
| 	raw = cdev->dev.driver_data; | 	raw = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (raw) { | 	if (raw) { | ||||||
| 		cdev->dev.driver_data = NULL; | 		dev_set_drvdata(&cdev->dev, NULL); | ||||||
| 		kfree(raw->buffer); | 		kfree(raw->buffer); | ||||||
| 		kfree(raw); | 		kfree(raw); | ||||||
| 	} | 	} | ||||||
| @ -694,7 +694,7 @@ raw3215_set_online (struct ccw_device *cdev) | |||||||
| { | { | ||||||
| 	struct raw3215_info *raw; | 	struct raw3215_info *raw; | ||||||
| 
 | 
 | ||||||
| 	raw = cdev->dev.driver_data; | 	raw = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (!raw) | 	if (!raw) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 
 | 
 | ||||||
| @ -706,7 +706,7 @@ raw3215_set_offline (struct ccw_device *cdev) | |||||||
| { | { | ||||||
| 	struct raw3215_info *raw; | 	struct raw3215_info *raw; | ||||||
| 
 | 
 | ||||||
| 	raw = cdev->dev.driver_data; | 	raw = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (!raw) | 	if (!raw) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 
 | 
 | ||||||
| @ -848,7 +848,7 @@ con3215_init(void) | |||||||
| 	raw->buffer = (char *) alloc_bootmem_low(RAW3215_BUFFER_SIZE); | 	raw->buffer = (char *) alloc_bootmem_low(RAW3215_BUFFER_SIZE); | ||||||
| 	raw->inbuf = (char *) alloc_bootmem_low(RAW3215_INBUF_SIZE); | 	raw->inbuf = (char *) alloc_bootmem_low(RAW3215_INBUF_SIZE); | ||||||
| 	raw->cdev = cdev; | 	raw->cdev = cdev; | ||||||
| 	cdev->dev.driver_data = raw; | 	dev_set_drvdata(&cdev->dev, raw); | ||||||
| 	cdev->handler = raw3215_irq; | 	cdev->handler = raw3215_irq; | ||||||
| 
 | 
 | ||||||
| 	raw->flags |= RAW3215_FIXED; | 	raw->flags |= RAW3215_FIXED; | ||||||
|  | |||||||
| @ -355,7 +355,7 @@ raw3270_irq (struct ccw_device *cdev, unsigned long intparm, struct irb *irb) | |||||||
| 	struct raw3270_request *rq; | 	struct raw3270_request *rq; | ||||||
| 	int rc; | 	int rc; | ||||||
| 
 | 
 | ||||||
| 	rp = (struct raw3270 *) cdev->dev.driver_data; | 	rp = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (!rp) | 	if (!rp) | ||||||
| 		return; | 		return; | ||||||
| 	rq = (struct raw3270_request *) intparm; | 	rq = (struct raw3270_request *) intparm; | ||||||
| @ -828,7 +828,7 @@ raw3270_setup_device(struct ccw_device *cdev, struct raw3270 *rp, char *ascebc) | |||||||
| 	if (rp->minor == -1) | 	if (rp->minor == -1) | ||||||
| 		return -EUSERS; | 		return -EUSERS; | ||||||
| 	rp->cdev = cdev; | 	rp->cdev = cdev; | ||||||
| 	cdev->dev.driver_data = rp; | 	dev_set_drvdata(&cdev->dev, rp); | ||||||
| 	cdev->handler = raw3270_irq; | 	cdev->handler = raw3270_irq; | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| @ -1105,7 +1105,7 @@ raw3270_delete_device(struct raw3270 *rp) | |||||||
| 	/* Disconnect from ccw_device. */ | 	/* Disconnect from ccw_device. */ | ||||||
| 	cdev = rp->cdev; | 	cdev = rp->cdev; | ||||||
| 	rp->cdev = NULL; | 	rp->cdev = NULL; | ||||||
| 	cdev->dev.driver_data = NULL; | 	dev_set_drvdata(&cdev->dev, NULL); | ||||||
| 	cdev->handler = NULL; | 	cdev->handler = NULL; | ||||||
| 
 | 
 | ||||||
| 	/* Put ccw_device structure. */ | 	/* Put ccw_device structure. */ | ||||||
| @ -1129,7 +1129,7 @@ static ssize_t | |||||||
| raw3270_model_show(struct device *dev, struct device_attribute *attr, char *buf) | raw3270_model_show(struct device *dev, struct device_attribute *attr, char *buf) | ||||||
| { | { | ||||||
| 	return snprintf(buf, PAGE_SIZE, "%i\n", | 	return snprintf(buf, PAGE_SIZE, "%i\n", | ||||||
| 			((struct raw3270 *) dev->driver_data)->model); | 			((struct raw3270 *) dev_get_drvdata(dev))->model); | ||||||
| } | } | ||||||
| static DEVICE_ATTR(model, 0444, raw3270_model_show, NULL); | static DEVICE_ATTR(model, 0444, raw3270_model_show, NULL); | ||||||
| 
 | 
 | ||||||
| @ -1137,7 +1137,7 @@ static ssize_t | |||||||
| raw3270_rows_show(struct device *dev, struct device_attribute *attr, char *buf) | raw3270_rows_show(struct device *dev, struct device_attribute *attr, char *buf) | ||||||
| { | { | ||||||
| 	return snprintf(buf, PAGE_SIZE, "%i\n", | 	return snprintf(buf, PAGE_SIZE, "%i\n", | ||||||
| 			((struct raw3270 *) dev->driver_data)->rows); | 			((struct raw3270 *) dev_get_drvdata(dev))->rows); | ||||||
| } | } | ||||||
| static DEVICE_ATTR(rows, 0444, raw3270_rows_show, NULL); | static DEVICE_ATTR(rows, 0444, raw3270_rows_show, NULL); | ||||||
| 
 | 
 | ||||||
| @ -1145,7 +1145,7 @@ static ssize_t | |||||||
| raw3270_columns_show(struct device *dev, struct device_attribute *attr, char *buf) | raw3270_columns_show(struct device *dev, struct device_attribute *attr, char *buf) | ||||||
| { | { | ||||||
| 	return snprintf(buf, PAGE_SIZE, "%i\n", | 	return snprintf(buf, PAGE_SIZE, "%i\n", | ||||||
| 			((struct raw3270 *) dev->driver_data)->cols); | 			((struct raw3270 *) dev_get_drvdata(dev))->cols); | ||||||
| } | } | ||||||
| static DEVICE_ATTR(columns, 0444, raw3270_columns_show, NULL); | static DEVICE_ATTR(columns, 0444, raw3270_columns_show, NULL); | ||||||
| 
 | 
 | ||||||
| @ -1282,7 +1282,7 @@ raw3270_remove (struct ccw_device *cdev) | |||||||
| 	struct raw3270_view *v; | 	struct raw3270_view *v; | ||||||
| 	struct raw3270_notifier *np; | 	struct raw3270_notifier *np; | ||||||
| 
 | 
 | ||||||
| 	rp = cdev->dev.driver_data; | 	rp = dev_get_drvdata(&cdev->dev); | ||||||
| 	/*
 | 	/*
 | ||||||
| 	 * _remove is the opposite of _probe; it's probe that | 	 * _remove is the opposite of _probe; it's probe that | ||||||
| 	 * should set up rp.  raw3270_remove gets entered for | 	 * should set up rp.  raw3270_remove gets entered for | ||||||
| @ -1330,7 +1330,7 @@ raw3270_set_offline (struct ccw_device *cdev) | |||||||
| { | { | ||||||
| 	struct raw3270 *rp; | 	struct raw3270 *rp; | ||||||
| 
 | 
 | ||||||
| 	rp = cdev->dev.driver_data; | 	rp = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (test_bit(RAW3270_FLAGS_CONSOLE, &rp->flags)) | 	if (test_bit(RAW3270_FLAGS_CONSOLE, &rp->flags)) | ||||||
| 		return -EBUSY; | 		return -EBUSY; | ||||||
| 	raw3270_remove(cdev); | 	raw3270_remove(cdev); | ||||||
|  | |||||||
| @ -1289,7 +1289,7 @@ static int | |||||||
| tape_34xx_online(struct ccw_device *cdev) | tape_34xx_online(struct ccw_device *cdev) | ||||||
| { | { | ||||||
| 	return tape_generic_online( | 	return tape_generic_online( | ||||||
| 		cdev->dev.driver_data, | 		dev_get_drvdata(&cdev->dev), | ||||||
| 		&tape_discipline_34xx | 		&tape_discipline_34xx | ||||||
| 	); | 	); | ||||||
| } | } | ||||||
|  | |||||||
| @ -1703,7 +1703,7 @@ static struct ccw_device_id tape_3590_ids[] = { | |||||||
| static int | static int | ||||||
| tape_3590_online(struct ccw_device *cdev) | tape_3590_online(struct ccw_device *cdev) | ||||||
| { | { | ||||||
| 	return tape_generic_online(cdev->dev.driver_data, | 	return tape_generic_online(dev_get_drvdata(&cdev->dev), | ||||||
| 				   &tape_discipline_3590); | 				   &tape_discipline_3590); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -92,7 +92,7 @@ tape_medium_state_show(struct device *dev, struct device_attribute *attr, char * | |||||||
| { | { | ||||||
| 	struct tape_device *tdev; | 	struct tape_device *tdev; | ||||||
| 
 | 
 | ||||||
| 	tdev = (struct tape_device *) dev->driver_data; | 	tdev = dev_get_drvdata(dev); | ||||||
| 	return scnprintf(buf, PAGE_SIZE, "%i\n", tdev->medium_state); | 	return scnprintf(buf, PAGE_SIZE, "%i\n", tdev->medium_state); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -104,7 +104,7 @@ tape_first_minor_show(struct device *dev, struct device_attribute *attr, char *b | |||||||
| { | { | ||||||
| 	struct tape_device *tdev; | 	struct tape_device *tdev; | ||||||
| 
 | 
 | ||||||
| 	tdev = (struct tape_device *) dev->driver_data; | 	tdev = dev_get_drvdata(dev); | ||||||
| 	return scnprintf(buf, PAGE_SIZE, "%i\n", tdev->first_minor); | 	return scnprintf(buf, PAGE_SIZE, "%i\n", tdev->first_minor); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -116,7 +116,7 @@ tape_state_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| { | { | ||||||
| 	struct tape_device *tdev; | 	struct tape_device *tdev; | ||||||
| 
 | 
 | ||||||
| 	tdev = (struct tape_device *) dev->driver_data; | 	tdev = dev_get_drvdata(dev); | ||||||
| 	return scnprintf(buf, PAGE_SIZE, "%s\n", (tdev->first_minor < 0) ? | 	return scnprintf(buf, PAGE_SIZE, "%s\n", (tdev->first_minor < 0) ? | ||||||
| 		"OFFLINE" : tape_state_verbose[tdev->tape_state]); | 		"OFFLINE" : tape_state_verbose[tdev->tape_state]); | ||||||
| } | } | ||||||
| @ -130,7 +130,7 @@ tape_operation_show(struct device *dev, struct device_attribute *attr, char *buf | |||||||
| 	struct tape_device *tdev; | 	struct tape_device *tdev; | ||||||
| 	ssize_t rc; | 	ssize_t rc; | ||||||
| 
 | 
 | ||||||
| 	tdev = (struct tape_device *) dev->driver_data; | 	tdev = dev_get_drvdata(dev); | ||||||
| 	if (tdev->first_minor < 0) | 	if (tdev->first_minor < 0) | ||||||
| 		return scnprintf(buf, PAGE_SIZE, "N/A\n"); | 		return scnprintf(buf, PAGE_SIZE, "N/A\n"); | ||||||
| 
 | 
 | ||||||
| @ -156,7 +156,7 @@ tape_blocksize_show(struct device *dev, struct device_attribute *attr, char *buf | |||||||
| { | { | ||||||
| 	struct tape_device *tdev; | 	struct tape_device *tdev; | ||||||
| 
 | 
 | ||||||
| 	tdev = (struct tape_device *) dev->driver_data; | 	tdev = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	return scnprintf(buf, PAGE_SIZE, "%i\n", tdev->char_data.block_size); | 	return scnprintf(buf, PAGE_SIZE, "%i\n", tdev->char_data.block_size); | ||||||
| } | } | ||||||
| @ -391,7 +391,7 @@ tape_generic_offline(struct ccw_device *cdev) | |||||||
| { | { | ||||||
| 	struct tape_device *device; | 	struct tape_device *device; | ||||||
| 
 | 
 | ||||||
| 	device = cdev->dev.driver_data; | 	device = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (!device) { | 	if (!device) { | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	} | 	} | ||||||
| @ -534,7 +534,7 @@ tape_generic_probe(struct ccw_device *cdev) | |||||||
| 		tape_put_device(device); | 		tape_put_device(device); | ||||||
| 		return ret; | 		return ret; | ||||||
| 	} | 	} | ||||||
| 	cdev->dev.driver_data = device; | 	dev_set_drvdata(&cdev->dev, device); | ||||||
| 	cdev->handler = __tape_do_irq; | 	cdev->handler = __tape_do_irq; | ||||||
| 	device->cdev = cdev; | 	device->cdev = cdev; | ||||||
| 	ccw_device_get_id(cdev, &dev_id); | 	ccw_device_get_id(cdev, &dev_id); | ||||||
| @ -573,7 +573,7 @@ tape_generic_remove(struct ccw_device *cdev) | |||||||
| { | { | ||||||
| 	struct tape_device *	device; | 	struct tape_device *	device; | ||||||
| 
 | 
 | ||||||
| 	device = cdev->dev.driver_data; | 	device = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (!device) { | 	if (!device) { | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| @ -613,9 +613,9 @@ tape_generic_remove(struct ccw_device *cdev) | |||||||
| 			tape_cleanup_device(device); | 			tape_cleanup_device(device); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (cdev->dev.driver_data != NULL) { | 	if (!dev_get_drvdata(&cdev->dev)) { | ||||||
| 		sysfs_remove_group(&cdev->dev.kobj, &tape_attr_group); | 		sysfs_remove_group(&cdev->dev.kobj, &tape_attr_group); | ||||||
| 		cdev->dev.driver_data = tape_put_device(cdev->dev.driver_data); | 		dev_set_drvdata(&cdev->dev, tape_put_device(dev_get_drvdata(&cdev->dev))); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1011,7 +1011,7 @@ __tape_do_irq (struct ccw_device *cdev, unsigned long intparm, struct irb *irb) | |||||||
| 	struct tape_request *request; | 	struct tape_request *request; | ||||||
| 	int rc; | 	int rc; | ||||||
| 
 | 
 | ||||||
| 	device = (struct tape_device *) cdev->dev.driver_data; | 	device = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (device == NULL) { | 	if (device == NULL) { | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -504,7 +504,7 @@ static ssize_t vmlogrdr_autopurge_store(struct device * dev, | |||||||
| 					struct device_attribute *attr, | 					struct device_attribute *attr, | ||||||
| 					const char * buf, size_t count) | 					const char * buf, size_t count) | ||||||
| { | { | ||||||
| 	struct vmlogrdr_priv_t *priv = dev->driver_data; | 	struct vmlogrdr_priv_t *priv = dev_get_drvdata(dev); | ||||||
| 	ssize_t ret = count; | 	ssize_t ret = count; | ||||||
| 
 | 
 | ||||||
| 	switch (buf[0]) { | 	switch (buf[0]) { | ||||||
| @ -525,7 +525,7 @@ static ssize_t vmlogrdr_autopurge_show(struct device *dev, | |||||||
| 				       struct device_attribute *attr, | 				       struct device_attribute *attr, | ||||||
| 				       char *buf) | 				       char *buf) | ||||||
| { | { | ||||||
| 	struct vmlogrdr_priv_t *priv = dev->driver_data; | 	struct vmlogrdr_priv_t *priv = dev_get_drvdata(dev); | ||||||
| 	return sprintf(buf, "%u\n", priv->autopurge); | 	return sprintf(buf, "%u\n", priv->autopurge); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -541,7 +541,7 @@ static ssize_t vmlogrdr_purge_store(struct device * dev, | |||||||
| 
 | 
 | ||||||
| 	char cp_command[80]; | 	char cp_command[80]; | ||||||
| 	char cp_response[80]; | 	char cp_response[80]; | ||||||
| 	struct vmlogrdr_priv_t *priv = dev->driver_data; | 	struct vmlogrdr_priv_t *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	if (buf[0] != '1') | 	if (buf[0] != '1') | ||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| @ -578,7 +578,7 @@ static ssize_t vmlogrdr_autorecording_store(struct device *dev, | |||||||
| 					    struct device_attribute *attr, | 					    struct device_attribute *attr, | ||||||
| 					    const char *buf, size_t count) | 					    const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct vmlogrdr_priv_t *priv = dev->driver_data; | 	struct vmlogrdr_priv_t *priv = dev_get_drvdata(dev); | ||||||
| 	ssize_t ret = count; | 	ssize_t ret = count; | ||||||
| 
 | 
 | ||||||
| 	switch (buf[0]) { | 	switch (buf[0]) { | ||||||
| @ -599,7 +599,7 @@ static ssize_t vmlogrdr_autorecording_show(struct device *dev, | |||||||
| 					   struct device_attribute *attr, | 					   struct device_attribute *attr, | ||||||
| 					   char *buf) | 					   char *buf) | ||||||
| { | { | ||||||
| 	struct vmlogrdr_priv_t *priv = dev->driver_data; | 	struct vmlogrdr_priv_t *priv = dev_get_drvdata(dev); | ||||||
| 	return sprintf(buf, "%u\n", priv->autorecording); | 	return sprintf(buf, "%u\n", priv->autorecording); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -612,7 +612,7 @@ static ssize_t vmlogrdr_recording_store(struct device * dev, | |||||||
| 					struct device_attribute *attr, | 					struct device_attribute *attr, | ||||||
| 					const char * buf, size_t count) | 					const char * buf, size_t count) | ||||||
| { | { | ||||||
| 	struct vmlogrdr_priv_t *priv = dev->driver_data; | 	struct vmlogrdr_priv_t *priv = dev_get_drvdata(dev); | ||||||
| 	ssize_t ret; | 	ssize_t ret; | ||||||
| 
 | 
 | ||||||
| 	switch (buf[0]) { | 	switch (buf[0]) { | ||||||
|  | |||||||
| @ -78,11 +78,11 @@ static DEFINE_MUTEX(vmur_mutex); | |||||||
|  * |  * | ||||||
|  * Each ur device (urd) contains a reference to its corresponding ccw device |  * Each ur device (urd) contains a reference to its corresponding ccw device | ||||||
|  * (cdev) using the urd->cdev pointer. Each ccw device has a reference to the |  * (cdev) using the urd->cdev pointer. Each ccw device has a reference to the | ||||||
|  * ur device using the cdev->dev.driver_data pointer. |  * ur device using dev_get_drvdata(&cdev->dev) pointer. | ||||||
|  * |  * | ||||||
|  * urd references: |  * urd references: | ||||||
|  * - ur_probe gets a urd reference, ur_remove drops the reference |  * - ur_probe gets a urd reference, ur_remove drops the reference | ||||||
|  *   (cdev->dev.driver_data) |  *   dev_get_drvdata(&cdev->dev) | ||||||
|  * - ur_open gets a urd reference, ur_relase drops the reference |  * - ur_open gets a urd reference, ur_relase drops the reference | ||||||
|  *   (urf->urd) |  *   (urf->urd) | ||||||
|  * |  * | ||||||
| @ -90,7 +90,7 @@ static DEFINE_MUTEX(vmur_mutex); | |||||||
|  * - urdev_alloc get a cdev reference (urd->cdev) |  * - urdev_alloc get a cdev reference (urd->cdev) | ||||||
|  * - urdev_free drops the cdev reference (urd->cdev) |  * - urdev_free drops the cdev reference (urd->cdev) | ||||||
|  * |  * | ||||||
|  * Setting and clearing of cdev->dev.driver_data is protected by the ccwdev lock |  * Setting and clearing of dev_get_drvdata(&cdev->dev) is protected by the ccwdev lock | ||||||
|  */ |  */ | ||||||
| static struct urdev *urdev_alloc(struct ccw_device *cdev) | static struct urdev *urdev_alloc(struct ccw_device *cdev) | ||||||
| { | { | ||||||
| @ -129,7 +129,7 @@ static struct urdev *urdev_get_from_cdev(struct ccw_device *cdev) | |||||||
| 	unsigned long flags; | 	unsigned long flags; | ||||||
| 
 | 
 | ||||||
| 	spin_lock_irqsave(get_ccwdev_lock(cdev), flags); | 	spin_lock_irqsave(get_ccwdev_lock(cdev), flags); | ||||||
| 	urd = cdev->dev.driver_data; | 	urd = dev_get_drvdata(&cdev->dev); | ||||||
| 	if (urd) | 	if (urd) | ||||||
| 		urdev_get(urd); | 		urdev_get(urd); | ||||||
| 	spin_unlock_irqrestore(get_ccwdev_lock(cdev), flags); | 	spin_unlock_irqrestore(get_ccwdev_lock(cdev), flags); | ||||||
| @ -286,7 +286,7 @@ static void ur_int_handler(struct ccw_device *cdev, unsigned long intparm, | |||||||
| 		TRACE("ur_int_handler: unsolicited interrupt\n"); | 		TRACE("ur_int_handler: unsolicited interrupt\n"); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 	urd = cdev->dev.driver_data; | 	urd = dev_get_drvdata(&cdev->dev); | ||||||
| 	BUG_ON(!urd); | 	BUG_ON(!urd); | ||||||
| 	/* On special conditions irb is an error pointer */ | 	/* On special conditions irb is an error pointer */ | ||||||
| 	if (IS_ERR(irb)) | 	if (IS_ERR(irb)) | ||||||
| @ -832,7 +832,7 @@ static int ur_probe(struct ccw_device *cdev) | |||||||
| 		goto fail_remove_attr; | 		goto fail_remove_attr; | ||||||
| 	} | 	} | ||||||
| 	spin_lock_irq(get_ccwdev_lock(cdev)); | 	spin_lock_irq(get_ccwdev_lock(cdev)); | ||||||
| 	cdev->dev.driver_data = urd; | 	dev_set_drvdata(&cdev->dev, urd); | ||||||
| 	spin_unlock_irq(get_ccwdev_lock(cdev)); | 	spin_unlock_irq(get_ccwdev_lock(cdev)); | ||||||
| 
 | 
 | ||||||
| 	mutex_unlock(&vmur_mutex); | 	mutex_unlock(&vmur_mutex); | ||||||
| @ -972,8 +972,8 @@ static void ur_remove(struct ccw_device *cdev) | |||||||
| 	ur_remove_attributes(&cdev->dev); | 	ur_remove_attributes(&cdev->dev); | ||||||
| 
 | 
 | ||||||
| 	spin_lock_irqsave(get_ccwdev_lock(cdev), flags); | 	spin_lock_irqsave(get_ccwdev_lock(cdev), flags); | ||||||
| 	urdev_put(cdev->dev.driver_data); | 	urdev_put(dev_get_drvdata(&cdev->dev)); | ||||||
| 	cdev->dev.driver_data = NULL; | 	dev_set_drvdata(&cdev->dev, NULL); | ||||||
| 	spin_unlock_irqrestore(get_ccwdev_lock(cdev), flags); | 	spin_unlock_irqrestore(get_ccwdev_lock(cdev), flags); | ||||||
| 
 | 
 | ||||||
| 	mutex_unlock(&vmur_mutex); | 	mutex_unlock(&vmur_mutex); | ||||||
|  | |||||||
| @ -284,7 +284,7 @@ claw_probe(struct ccwgroup_device *cgdev) | |||||||
| 	if (!get_device(&cgdev->dev)) | 	if (!get_device(&cgdev->dev)) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	privptr = kzalloc(sizeof(struct claw_privbk), GFP_KERNEL); | 	privptr = kzalloc(sizeof(struct claw_privbk), GFP_KERNEL); | ||||||
| 	cgdev->dev.driver_data = privptr; | 	dev_set_drvdata(&cgdev->dev, privptr); | ||||||
| 	if (privptr == NULL) { | 	if (privptr == NULL) { | ||||||
| 		probe_error(cgdev); | 		probe_error(cgdev); | ||||||
| 		put_device(&cgdev->dev); | 		put_device(&cgdev->dev); | ||||||
| @ -591,14 +591,14 @@ claw_irq_handler(struct ccw_device *cdev, | |||||||
| 
 | 
 | ||||||
| 	CLAW_DBF_TEXT(4, trace, "clawirq"); | 	CLAW_DBF_TEXT(4, trace, "clawirq"); | ||||||
|         /* Bypass all 'unsolicited interrupts' */ |         /* Bypass all 'unsolicited interrupts' */ | ||||||
| 	if (!cdev->dev.driver_data) { | 	privptr = dev_get_drvdata(&cdev->dev); | ||||||
|  | 	if (!privptr) { | ||||||
| 		dev_warn(&cdev->dev, "An uninitialized CLAW device received an" | 		dev_warn(&cdev->dev, "An uninitialized CLAW device received an" | ||||||
| 			" IRQ, c-%02x d-%02x\n", | 			" IRQ, c-%02x d-%02x\n", | ||||||
| 			irb->scsw.cmd.cstat, irb->scsw.cmd.dstat); | 			irb->scsw.cmd.cstat, irb->scsw.cmd.dstat); | ||||||
| 		CLAW_DBF_TEXT(2, trace, "badirq"); | 		CLAW_DBF_TEXT(2, trace, "badirq"); | ||||||
|                 return; |                 return; | ||||||
|         } |         } | ||||||
| 	privptr = (struct claw_privbk *)cdev->dev.driver_data; |  | ||||||
| 
 | 
 | ||||||
| 	/* Try to extract channel from driver data. */ | 	/* Try to extract channel from driver data. */ | ||||||
| 	if (privptr->channel[READ].cdev == cdev) | 	if (privptr->channel[READ].cdev == cdev) | ||||||
| @ -1980,9 +1980,9 @@ probe_error( struct ccwgroup_device *cgdev) | |||||||
| 	struct claw_privbk *privptr; | 	struct claw_privbk *privptr; | ||||||
| 
 | 
 | ||||||
| 	CLAW_DBF_TEXT(4, trace, "proberr"); | 	CLAW_DBF_TEXT(4, trace, "proberr"); | ||||||
| 	privptr = (struct claw_privbk *) cgdev->dev.driver_data; | 	privptr = dev_get_drvdata(&cgdev->dev); | ||||||
| 	if (privptr != NULL) { | 	if (privptr != NULL) { | ||||||
| 		cgdev->dev.driver_data = NULL; | 		dev_set_drvdata(&cgdev->dev, NULL); | ||||||
| 		kfree(privptr->p_env); | 		kfree(privptr->p_env); | ||||||
| 		kfree(privptr->p_mtc_envelope); | 		kfree(privptr->p_mtc_envelope); | ||||||
| 		kfree(privptr); | 		kfree(privptr); | ||||||
| @ -2911,9 +2911,9 @@ claw_new_device(struct ccwgroup_device *cgdev) | |||||||
| 	dev_info(&cgdev->dev, "add for %s\n", | 	dev_info(&cgdev->dev, "add for %s\n", | ||||||
| 		 dev_name(&cgdev->cdev[READ]->dev)); | 		 dev_name(&cgdev->cdev[READ]->dev)); | ||||||
| 	CLAW_DBF_TEXT(2, setup, "new_dev"); | 	CLAW_DBF_TEXT(2, setup, "new_dev"); | ||||||
| 	privptr = cgdev->dev.driver_data; | 	privptr = dev_get_drvdata(&cgdev->dev); | ||||||
| 	cgdev->cdev[READ]->dev.driver_data = privptr; | 	dev_set_drvdata(&cgdev->cdev[READ]->dev, privptr); | ||||||
| 	cgdev->cdev[WRITE]->dev.driver_data = privptr; | 	dev_set_drvdata(&cgdev->cdev[WRITE]->dev, privptr); | ||||||
| 	if (!privptr) | 	if (!privptr) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = privptr->p_env; | 	p_env = privptr->p_env; | ||||||
| @ -2950,9 +2950,9 @@ claw_new_device(struct ccwgroup_device *cgdev) | |||||||
| 		goto out; | 		goto out; | ||||||
| 	} | 	} | ||||||
| 	dev->ml_priv = privptr; | 	dev->ml_priv = privptr; | ||||||
| 	cgdev->dev.driver_data = privptr; | 	dev_set_drvdata(&cgdev->dev, privptr); | ||||||
|         cgdev->cdev[READ]->dev.driver_data = privptr; | 	dev_set_drvdata(&cgdev->cdev[READ]->dev, privptr); | ||||||
|         cgdev->cdev[WRITE]->dev.driver_data = privptr; | 	dev_set_drvdata(&cgdev->cdev[WRITE]->dev, privptr); | ||||||
| 	/* sysfs magic */ | 	/* sysfs magic */ | ||||||
|         SET_NETDEV_DEV(dev, &cgdev->dev); |         SET_NETDEV_DEV(dev, &cgdev->dev); | ||||||
| 	if (register_netdev(dev) != 0) { | 	if (register_netdev(dev) != 0) { | ||||||
| @ -3018,7 +3018,7 @@ claw_shutdown_device(struct ccwgroup_device *cgdev) | |||||||
| 	int	ret; | 	int	ret; | ||||||
| 
 | 
 | ||||||
| 	CLAW_DBF_TEXT_(2, setup, "%s", dev_name(&cgdev->dev)); | 	CLAW_DBF_TEXT_(2, setup, "%s", dev_name(&cgdev->dev)); | ||||||
| 	priv = cgdev->dev.driver_data; | 	priv = dev_get_drvdata(&cgdev->dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	ndev = priv->channel[READ].ndev; | 	ndev = priv->channel[READ].ndev; | ||||||
| @ -3048,7 +3048,7 @@ claw_remove_device(struct ccwgroup_device *cgdev) | |||||||
| 
 | 
 | ||||||
| 	BUG_ON(!cgdev); | 	BUG_ON(!cgdev); | ||||||
| 	CLAW_DBF_TEXT_(2, setup, "%s", dev_name(&cgdev->dev)); | 	CLAW_DBF_TEXT_(2, setup, "%s", dev_name(&cgdev->dev)); | ||||||
| 	priv = cgdev->dev.driver_data; | 	priv = dev_get_drvdata(&cgdev->dev); | ||||||
| 	BUG_ON(!priv); | 	BUG_ON(!priv); | ||||||
| 	dev_info(&cgdev->dev, " will be removed.\n"); | 	dev_info(&cgdev->dev, " will be removed.\n"); | ||||||
| 	if (cgdev->state == CCWGROUP_ONLINE) | 	if (cgdev->state == CCWGROUP_ONLINE) | ||||||
| @ -3063,9 +3063,9 @@ claw_remove_device(struct ccwgroup_device *cgdev) | |||||||
| 	kfree(priv->channel[1].irb); | 	kfree(priv->channel[1].irb); | ||||||
| 	priv->channel[1].irb=NULL; | 	priv->channel[1].irb=NULL; | ||||||
| 	kfree(priv); | 	kfree(priv); | ||||||
| 	cgdev->dev.driver_data=NULL; | 	dev_set_drvdata(&cgdev->dev, NULL); | ||||||
| 	cgdev->cdev[READ]->dev.driver_data = NULL; | 	dev_set_drvdata(&cgdev->cdev[READ]->dev, NULL); | ||||||
| 	cgdev->cdev[WRITE]->dev.driver_data = NULL; | 	dev_set_drvdata(&cgdev->cdev[WRITE]->dev, NULL); | ||||||
| 	put_device(&cgdev->dev); | 	put_device(&cgdev->dev); | ||||||
| 
 | 
 | ||||||
| 	return; | 	return; | ||||||
| @ -3081,7 +3081,7 @@ claw_hname_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3095,7 +3095,7 @@ claw_hname_write(struct device *dev, struct device_attribute *attr, | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3119,7 +3119,7 @@ claw_adname_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3133,7 +3133,7 @@ claw_adname_write(struct device *dev, struct device_attribute *attr, | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3157,7 +3157,7 @@ claw_apname_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3172,7 +3172,7 @@ claw_apname_write(struct device *dev, struct device_attribute *attr, | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3206,7 +3206,7 @@ claw_wbuff_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env * p_env; | 	struct claw_env * p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3221,7 +3221,7 @@ claw_wbuff_write(struct device *dev, struct device_attribute *attr, | |||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 	int nnn,max; | 	int nnn,max; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3248,7 +3248,7 @@ claw_rbuff_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| 	struct claw_privbk *priv; | 	struct claw_privbk *priv; | ||||||
| 	struct claw_env *  p_env; | 	struct claw_env *  p_env; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
| @ -3263,7 +3263,7 @@ claw_rbuff_write(struct device *dev, struct device_attribute *attr, | |||||||
| 	struct claw_env *p_env; | 	struct claw_env *p_env; | ||||||
| 	int nnn,max; | 	int nnn,max; | ||||||
| 
 | 
 | ||||||
| 	priv = dev->driver_data; | 	priv = dev_get_drvdata(dev); | ||||||
| 	if (!priv) | 	if (!priv) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	p_env = priv->p_env; | 	p_env = priv->p_env; | ||||||
|  | |||||||
| @ -1939,7 +1939,7 @@ lcs_portno_show (struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| { | { | ||||||
|         struct lcs_card *card; |         struct lcs_card *card; | ||||||
| 
 | 
 | ||||||
| 	card = (struct lcs_card *)dev->driver_data; | 	card = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
|         if (!card) |         if (!card) | ||||||
|                 return 0; |                 return 0; | ||||||
| @ -1956,7 +1956,7 @@ lcs_portno_store (struct device *dev, struct device_attribute *attr, const char | |||||||
|         struct lcs_card *card; |         struct lcs_card *card; | ||||||
|         int value; |         int value; | ||||||
| 
 | 
 | ||||||
| 	card = (struct lcs_card *)dev->driver_data; | 	card = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
|         if (!card) |         if (!card) | ||||||
|                 return 0; |                 return 0; | ||||||
| @ -1990,7 +1990,7 @@ lcs_timeout_show(struct device *dev, struct device_attribute *attr, char *buf) | |||||||
| { | { | ||||||
| 	struct lcs_card *card; | 	struct lcs_card *card; | ||||||
| 
 | 
 | ||||||
| 	card = (struct lcs_card *)dev->driver_data; | 	card = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	return card ? sprintf(buf, "%u\n", card->lancmd_timeout) : 0; | 	return card ? sprintf(buf, "%u\n", card->lancmd_timeout) : 0; | ||||||
| } | } | ||||||
| @ -2001,7 +2001,7 @@ lcs_timeout_store (struct device *dev, struct device_attribute *attr, const char | |||||||
|         struct lcs_card *card; |         struct lcs_card *card; | ||||||
|         int value; |         int value; | ||||||
| 
 | 
 | ||||||
| 	card = (struct lcs_card *)dev->driver_data; | 	card = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
|         if (!card) |         if (!card) | ||||||
|                 return 0; |                 return 0; | ||||||
| @ -2020,7 +2020,7 @@ static ssize_t | |||||||
| lcs_dev_recover_store(struct device *dev, struct device_attribute *attr, | lcs_dev_recover_store(struct device *dev, struct device_attribute *attr, | ||||||
| 		      const char *buf, size_t count) | 		      const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct lcs_card *card = dev->driver_data; | 	struct lcs_card *card = dev_get_drvdata(dev); | ||||||
| 	char *tmp; | 	char *tmp; | ||||||
| 	int i; | 	int i; | ||||||
| 
 | 
 | ||||||
| @ -2073,7 +2073,7 @@ lcs_probe_device(struct ccwgroup_device *ccwgdev) | |||||||
| 		put_device(&ccwgdev->dev); | 		put_device(&ccwgdev->dev); | ||||||
| 		return ret; | 		return ret; | ||||||
|         } |         } | ||||||
| 	ccwgdev->dev.driver_data = card; | 	dev_set_drvdata(&ccwgdev->dev, card); | ||||||
| 	ccwgdev->cdev[0]->handler = lcs_irq; | 	ccwgdev->cdev[0]->handler = lcs_irq; | ||||||
| 	ccwgdev->cdev[1]->handler = lcs_irq; | 	ccwgdev->cdev[1]->handler = lcs_irq; | ||||||
| 	card->gdev = ccwgdev; | 	card->gdev = ccwgdev; | ||||||
| @ -2090,7 +2090,7 @@ lcs_register_netdev(struct ccwgroup_device *ccwgdev) | |||||||
| 	struct lcs_card *card; | 	struct lcs_card *card; | ||||||
| 
 | 
 | ||||||
| 	LCS_DBF_TEXT(2, setup, "regnetdv"); | 	LCS_DBF_TEXT(2, setup, "regnetdv"); | ||||||
| 	card = (struct lcs_card *)ccwgdev->dev.driver_data; | 	card = dev_get_drvdata(&ccwgdev->dev); | ||||||
| 	if (card->dev->reg_state != NETREG_UNINITIALIZED) | 	if (card->dev->reg_state != NETREG_UNINITIALIZED) | ||||||
| 		return 0; | 		return 0; | ||||||
| 	SET_NETDEV_DEV(card->dev, &ccwgdev->dev); | 	SET_NETDEV_DEV(card->dev, &ccwgdev->dev); | ||||||
| @ -2123,7 +2123,7 @@ lcs_new_device(struct ccwgroup_device *ccwgdev) | |||||||
| 	enum lcs_dev_states recover_state; | 	enum lcs_dev_states recover_state; | ||||||
| 	int rc; | 	int rc; | ||||||
| 
 | 
 | ||||||
| 	card = (struct lcs_card *)ccwgdev->dev.driver_data; | 	card = dev_get_drvdata(&ccwgdev->dev); | ||||||
| 	if (!card) | 	if (!card) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 
 | 
 | ||||||
| @ -2229,7 +2229,7 @@ __lcs_shutdown_device(struct ccwgroup_device *ccwgdev, int recovery_mode) | |||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	LCS_DBF_TEXT(3, setup, "shtdndev"); | 	LCS_DBF_TEXT(3, setup, "shtdndev"); | ||||||
| 	card = (struct lcs_card *)ccwgdev->dev.driver_data; | 	card = dev_get_drvdata(&ccwgdev->dev); | ||||||
| 	if (!card) | 	if (!card) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 	if (recovery_mode == 0) { | 	if (recovery_mode == 0) { | ||||||
| @ -2296,7 +2296,7 @@ lcs_remove_device(struct ccwgroup_device *ccwgdev) | |||||||
| { | { | ||||||
| 	struct lcs_card *card; | 	struct lcs_card *card; | ||||||
| 
 | 
 | ||||||
| 	card = (struct lcs_card *)ccwgdev->dev.driver_data; | 	card = dev_get_drvdata(&ccwgdev->dev); | ||||||
| 	if (!card) | 	if (!card) | ||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ static inline int lcs_dbf_passes(debug_info_t *dbf_grp, int level) | |||||||
|  *	sysfs related stuff |  *	sysfs related stuff | ||||||
|  */ |  */ | ||||||
| #define CARD_FROM_DEV(cdev) \ | #define CARD_FROM_DEV(cdev) \ | ||||||
| 	(struct lcs_card *) \ | 	(struct lcs_card *) dev_get_drvdata( \ | ||||||
| 	((struct ccwgroup_device *)cdev->dev.driver_data)->dev.driver_data; | 		&((struct ccwgroup_device *)dev_get_drvdata(&cdev->dev))->dev); | ||||||
| /**
 | /**
 | ||||||
|  * CCW commands used in this driver |  * CCW commands used in this driver | ||||||
|  */ |  */ | ||||||
|  | |||||||
| @ -1364,7 +1364,7 @@ static int netiucv_change_mtu(struct net_device * dev, int new_mtu) | |||||||
| static ssize_t user_show(struct device *dev, struct device_attribute *attr, | static ssize_t user_show(struct device *dev, struct device_attribute *attr, | ||||||
| 			 char *buf) | 			 char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%s\n", netiucv_printname(priv->conn->userid)); | 	return sprintf(buf, "%s\n", netiucv_printname(priv->conn->userid)); | ||||||
| @ -1373,7 +1373,7 @@ static ssize_t user_show(struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t user_write(struct device *dev, struct device_attribute *attr, | static ssize_t user_write(struct device *dev, struct device_attribute *attr, | ||||||
| 			  const char *buf, size_t count) | 			  const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 	struct net_device *ndev = priv->conn->netdev; | 	struct net_device *ndev = priv->conn->netdev; | ||||||
| 	char    *p; | 	char    *p; | ||||||
| 	char    *tmp; | 	char    *tmp; | ||||||
| @ -1430,7 +1430,8 @@ static DEVICE_ATTR(user, 0644, user_show, user_write); | |||||||
| 
 | 
 | ||||||
| static ssize_t buffer_show (struct device *dev, struct device_attribute *attr, | static ssize_t buffer_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			    char *buf) | 			    char *buf) | ||||||
| {	struct netiucv_priv *priv = dev->driver_data; | { | ||||||
|  | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%d\n", priv->conn->max_buffsize); | 	return sprintf(buf, "%d\n", priv->conn->max_buffsize); | ||||||
| @ -1439,7 +1440,7 @@ static ssize_t buffer_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t buffer_write (struct device *dev, struct device_attribute *attr, | static ssize_t buffer_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			     const char *buf, size_t count) | 			     const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 	struct net_device *ndev = priv->conn->netdev; | 	struct net_device *ndev = priv->conn->netdev; | ||||||
| 	char         *e; | 	char         *e; | ||||||
| 	int          bs1; | 	int          bs1; | ||||||
| @ -1487,7 +1488,7 @@ static DEVICE_ATTR(buffer, 0644, buffer_show, buffer_write); | |||||||
| static ssize_t dev_fsm_show (struct device *dev, struct device_attribute *attr, | static ssize_t dev_fsm_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			     char *buf) | 			     char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%s\n", fsm_getstate_str(priv->fsm)); | 	return sprintf(buf, "%s\n", fsm_getstate_str(priv->fsm)); | ||||||
| @ -1498,7 +1499,7 @@ static DEVICE_ATTR(device_fsm_state, 0444, dev_fsm_show, NULL); | |||||||
| static ssize_t conn_fsm_show (struct device *dev, | static ssize_t conn_fsm_show (struct device *dev, | ||||||
| 			      struct device_attribute *attr, char *buf) | 			      struct device_attribute *attr, char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%s\n", fsm_getstate_str(priv->conn->fsm)); | 	return sprintf(buf, "%s\n", fsm_getstate_str(priv->conn->fsm)); | ||||||
| @ -1509,7 +1510,7 @@ static DEVICE_ATTR(connection_fsm_state, 0444, conn_fsm_show, NULL); | |||||||
| static ssize_t maxmulti_show (struct device *dev, | static ssize_t maxmulti_show (struct device *dev, | ||||||
| 			      struct device_attribute *attr, char *buf) | 			      struct device_attribute *attr, char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.maxmulti); | 	return sprintf(buf, "%ld\n", priv->conn->prof.maxmulti); | ||||||
| @ -1519,7 +1520,7 @@ static ssize_t maxmulti_write (struct device *dev, | |||||||
| 			       struct device_attribute *attr, | 			       struct device_attribute *attr, | ||||||
| 			       const char *buf, size_t count) | 			       const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.maxmulti = 0; | 	priv->conn->prof.maxmulti = 0; | ||||||
| @ -1531,7 +1532,7 @@ static DEVICE_ATTR(max_tx_buffer_used, 0644, maxmulti_show, maxmulti_write); | |||||||
| static ssize_t maxcq_show (struct device *dev, struct device_attribute *attr, | static ssize_t maxcq_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			   char *buf) | 			   char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.maxcqueue); | 	return sprintf(buf, "%ld\n", priv->conn->prof.maxcqueue); | ||||||
| @ -1540,7 +1541,7 @@ static ssize_t maxcq_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t maxcq_write (struct device *dev, struct device_attribute *attr, | static ssize_t maxcq_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			    const char *buf, size_t count) | 			    const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.maxcqueue = 0; | 	priv->conn->prof.maxcqueue = 0; | ||||||
| @ -1552,7 +1553,7 @@ static DEVICE_ATTR(max_chained_skbs, 0644, maxcq_show, maxcq_write); | |||||||
| static ssize_t sdoio_show (struct device *dev, struct device_attribute *attr, | static ssize_t sdoio_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			   char *buf) | 			   char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.doios_single); | 	return sprintf(buf, "%ld\n", priv->conn->prof.doios_single); | ||||||
| @ -1561,7 +1562,7 @@ static ssize_t sdoio_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t sdoio_write (struct device *dev, struct device_attribute *attr, | static ssize_t sdoio_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			    const char *buf, size_t count) | 			    const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.doios_single = 0; | 	priv->conn->prof.doios_single = 0; | ||||||
| @ -1573,7 +1574,7 @@ static DEVICE_ATTR(tx_single_write_ops, 0644, sdoio_show, sdoio_write); | |||||||
| static ssize_t mdoio_show (struct device *dev, struct device_attribute *attr, | static ssize_t mdoio_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			   char *buf) | 			   char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.doios_multi); | 	return sprintf(buf, "%ld\n", priv->conn->prof.doios_multi); | ||||||
| @ -1582,7 +1583,7 @@ static ssize_t mdoio_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t mdoio_write (struct device *dev, struct device_attribute *attr, | static ssize_t mdoio_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			    const char *buf, size_t count) | 			    const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	priv->conn->prof.doios_multi = 0; | 	priv->conn->prof.doios_multi = 0; | ||||||
| @ -1594,7 +1595,7 @@ static DEVICE_ATTR(tx_multi_write_ops, 0644, mdoio_show, mdoio_write); | |||||||
| static ssize_t txlen_show (struct device *dev, struct device_attribute *attr, | static ssize_t txlen_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			   char *buf) | 			   char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.txlen); | 	return sprintf(buf, "%ld\n", priv->conn->prof.txlen); | ||||||
| @ -1603,7 +1604,7 @@ static ssize_t txlen_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t txlen_write (struct device *dev, struct device_attribute *attr, | static ssize_t txlen_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			    const char *buf, size_t count) | 			    const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.txlen = 0; | 	priv->conn->prof.txlen = 0; | ||||||
| @ -1615,7 +1616,7 @@ static DEVICE_ATTR(netto_bytes, 0644, txlen_show, txlen_write); | |||||||
| static ssize_t txtime_show (struct device *dev, struct device_attribute *attr, | static ssize_t txtime_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			    char *buf) | 			    char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.tx_time); | 	return sprintf(buf, "%ld\n", priv->conn->prof.tx_time); | ||||||
| @ -1624,7 +1625,7 @@ static ssize_t txtime_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t txtime_write (struct device *dev, struct device_attribute *attr, | static ssize_t txtime_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			     const char *buf, size_t count) | 			     const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.tx_time = 0; | 	priv->conn->prof.tx_time = 0; | ||||||
| @ -1636,7 +1637,7 @@ static DEVICE_ATTR(max_tx_io_time, 0644, txtime_show, txtime_write); | |||||||
| static ssize_t txpend_show (struct device *dev, struct device_attribute *attr, | static ssize_t txpend_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			    char *buf) | 			    char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.tx_pending); | 	return sprintf(buf, "%ld\n", priv->conn->prof.tx_pending); | ||||||
| @ -1645,7 +1646,7 @@ static ssize_t txpend_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t txpend_write (struct device *dev, struct device_attribute *attr, | static ssize_t txpend_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			     const char *buf, size_t count) | 			     const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.tx_pending = 0; | 	priv->conn->prof.tx_pending = 0; | ||||||
| @ -1657,7 +1658,7 @@ static DEVICE_ATTR(tx_pending, 0644, txpend_show, txpend_write); | |||||||
| static ssize_t txmpnd_show (struct device *dev, struct device_attribute *attr, | static ssize_t txmpnd_show (struct device *dev, struct device_attribute *attr, | ||||||
| 			    char *buf) | 			    char *buf) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 5, __func__); | 	IUCV_DBF_TEXT(trace, 5, __func__); | ||||||
| 	return sprintf(buf, "%ld\n", priv->conn->prof.tx_max_pending); | 	return sprintf(buf, "%ld\n", priv->conn->prof.tx_max_pending); | ||||||
| @ -1666,7 +1667,7 @@ static ssize_t txmpnd_show (struct device *dev, struct device_attribute *attr, | |||||||
| static ssize_t txmpnd_write (struct device *dev, struct device_attribute *attr, | static ssize_t txmpnd_write (struct device *dev, struct device_attribute *attr, | ||||||
| 			     const char *buf, size_t count) | 			     const char *buf, size_t count) | ||||||
| { | { | ||||||
| 	struct netiucv_priv *priv = dev->driver_data; | 	struct netiucv_priv *priv = dev_get_drvdata(dev); | ||||||
| 
 | 
 | ||||||
| 	IUCV_DBF_TEXT(trace, 4, __func__); | 	IUCV_DBF_TEXT(trace, 4, __func__); | ||||||
| 	priv->conn->prof.tx_max_pending = 0; | 	priv->conn->prof.tx_max_pending = 0; | ||||||
| @ -1758,7 +1759,7 @@ static int netiucv_register_device(struct net_device *ndev) | |||||||
| 	if (ret) | 	if (ret) | ||||||
| 		goto out_unreg; | 		goto out_unreg; | ||||||
| 	priv->dev = dev; | 	priv->dev = dev; | ||||||
| 	dev->driver_data = priv; | 	dev_set_drvdata(dev, priv); | ||||||
| 	return 0; | 	return 0; | ||||||
| 
 | 
 | ||||||
| out_unreg: | out_unreg: | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Greg Kroah-Hartman
						Greg Kroah-Hartman