[S390] duplicate ccw devices in ccwgroup.
Fail to create a ccwgroup device if a ccw device is passed in twice. Signed-off-by: Cornelia Huck <cornelia.huck@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
This commit is contained in:
committed by
Martin Schwidefsky
parent
ba4ba8a69d
commit
1708822984
@ -152,7 +152,6 @@ ccwgroup_create(struct device *root,
|
|||||||
struct ccwgroup_device *gdev;
|
struct ccwgroup_device *gdev;
|
||||||
int i;
|
int i;
|
||||||
int rc;
|
int rc;
|
||||||
int del_drvdata;
|
|
||||||
|
|
||||||
if (argc > 256) /* disallow dumb users */
|
if (argc > 256) /* disallow dumb users */
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -163,7 +162,6 @@ ccwgroup_create(struct device *root,
|
|||||||
|
|
||||||
atomic_set(&gdev->onoff, 0);
|
atomic_set(&gdev->onoff, 0);
|
||||||
|
|
||||||
del_drvdata = 0;
|
|
||||||
for (i = 0; i < argc; i++) {
|
for (i = 0; i < argc; i++) {
|
||||||
gdev->cdev[i] = get_ccwdev_by_busid(cdrv, argv[i]);
|
gdev->cdev[i] = get_ccwdev_by_busid(cdrv, argv[i]);
|
||||||
|
|
||||||
@ -180,10 +178,8 @@ ccwgroup_create(struct device *root,
|
|||||||
rc = -EINVAL;
|
rc = -EINVAL;
|
||||||
goto free_dev;
|
goto free_dev;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
for (i = 0; i < argc; i++)
|
|
||||||
gdev->cdev[i]->dev.driver_data = gdev;
|
gdev->cdev[i]->dev.driver_data = gdev;
|
||||||
del_drvdata = 1;
|
}
|
||||||
|
|
||||||
gdev->creator_id = creator_id;
|
gdev->creator_id = creator_id;
|
||||||
gdev->count = argc;
|
gdev->count = argc;
|
||||||
@ -226,9 +222,9 @@ error:
|
|||||||
free_dev:
|
free_dev:
|
||||||
for (i = 0; i < argc; i++)
|
for (i = 0; i < argc; i++)
|
||||||
if (gdev->cdev[i]) {
|
if (gdev->cdev[i]) {
|
||||||
put_device(&gdev->cdev[i]->dev);
|
if (gdev->cdev[i]->dev.driver_data == gdev)
|
||||||
if (del_drvdata)
|
|
||||||
gdev->cdev[i]->dev.driver_data = NULL;
|
gdev->cdev[i]->dev.driver_data = NULL;
|
||||||
|
put_device(&gdev->cdev[i]->dev);
|
||||||
}
|
}
|
||||||
kfree(gdev);
|
kfree(gdev);
|
||||||
return rc;
|
return rc;
|
||||||
|
Reference in New Issue
Block a user