s390/dasd: Fix inconsistent kobject removal
authorJan Höppner <hoeppner@linux.ibm.com>
Mon, 18 Jan 2021 16:55:18 +0000 (17:55 +0100)
committerJens Axboe <axboe@kernel.dk>
Mon, 25 Jan 2021 16:22:16 +0000 (09:22 -0700)
commitac55ad2b5fadb6af8826963d7d3331c9950a2608
tree1344602b9d37ab03762e09196d20724b762c7f79
parentef49d40b61a3e18a11edd5eb1c30b0183af9e850
s390/dasd: Fix inconsistent kobject removal

Our intention was to only remove path kobjects whenever a device is
being set offline. However, one corner case was missing.

If a device is disabled and enabled (using the IOCTLs BIODASDDISABLE and
BIODASDENABLE respectively), the enabling process will call
dasd_eckd_reload_device() which itself calls dasd_eckd_read_conf() in
order to update path information. During that update,
dasd_eckd_clear_conf_data() clears all old data and also removes all
kobjects. This will leave us with an inconsistent state of path kobjects
and a subsequent path verification leads to a failing kobject creation.

Fix this by removing kobjects only in the context of offlining a device
as initially intended.

Fixes: 19508b204740 ("s390/dasd: Display FC Endpoint Security information via sysfs")
Reported-by: Stefan Haberland <sth@linux.ibm.com>
Signed-off-by: Jan Höppner <hoeppner@linux.ibm.com>
Reviewed-by: Stefan Haberland <sth@linux.ibm.com>
Reviewed-by: Cornelia Huck <cohuck@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/s390/block/dasd_devmap.c
drivers/s390/block/dasd_eckd.c
drivers/s390/block/dasd_int.h