diff options
author | Horst Hummel <horst.hummel@de.ibm.com> | 2006-04-11 01:53:47 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-04-11 09:18:38 -0400 |
commit | dafd87aaef7d95a6ad3ff92e0d512e5b166c0716 (patch) | |
tree | e60cb58ab85a874c07e9a1d93ffc8b5c94858aa1 /drivers/s390/block/dasd.c | |
parent | 06fbcb104ad16c22eb5718ae598b306c777be8af (diff) |
[PATCH] s390: dasd device offline messages
The dasd driver sometimes print the misleading message "Can't offline dasd
device with open count = 0". The reason why it can't offline the device in
this case is that the device is still in the startup phase. Print a more
meaningful message.
Signed-off-by: Horst Hummel <horst.hummel@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/s390/block/dasd.c')
-rw-r--r-- | drivers/s390/block/dasd.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c index 0a9f12c4e911..170aae004ceb 100644 --- a/drivers/s390/block/dasd.c +++ b/drivers/s390/block/dasd.c | |||
@@ -1968,7 +1968,7 @@ int | |||
1968 | dasd_generic_set_offline (struct ccw_device *cdev) | 1968 | dasd_generic_set_offline (struct ccw_device *cdev) |
1969 | { | 1969 | { |
1970 | struct dasd_device *device; | 1970 | struct dasd_device *device; |
1971 | int max_count; | 1971 | int max_count, open_count; |
1972 | 1972 | ||
1973 | device = dasd_device_from_cdev(cdev); | 1973 | device = dasd_device_from_cdev(cdev); |
1974 | if (IS_ERR(device)) | 1974 | if (IS_ERR(device)) |
@@ -1985,10 +1985,16 @@ dasd_generic_set_offline (struct ccw_device *cdev) | |||
1985 | * in the other openers. | 1985 | * in the other openers. |
1986 | */ | 1986 | */ |
1987 | max_count = device->bdev ? 0 : -1; | 1987 | max_count = device->bdev ? 0 : -1; |
1988 | if (atomic_read(&device->open_count) > max_count) { | 1988 | open_count = (int) atomic_read(&device->open_count); |
1989 | printk (KERN_WARNING "Can't offline dasd device with open" | 1989 | if (open_count > max_count) { |
1990 | " count = %i.\n", | 1990 | if (open_count > 0) |
1991 | atomic_read(&device->open_count)); | 1991 | printk (KERN_WARNING "Can't offline dasd device with " |
1992 | "open count = %i.\n", | ||
1993 | open_count); | ||
1994 | else | ||
1995 | printk (KERN_WARNING "%s", | ||
1996 | "Can't offline dasd device due to internal " | ||
1997 | "use\n"); | ||
1992 | clear_bit(DASD_FLAG_OFFLINE, &device->flags); | 1998 | clear_bit(DASD_FLAG_OFFLINE, &device->flags); |
1993 | dasd_put_device(device); | 1999 | dasd_put_device(device); |
1994 | return -EBUSY; | 2000 | return -EBUSY; |