]> git.baikalelectronics.ru Git - kernel.git/commit
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)
commitc4127b63fc73e3782d146c3b93b74e186d22d7ae
tree1344602b9d37ab03762e09196d20724b762c7f79
parent182bb2c05c1edd1eab54aab236f4c05191234ff3
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: acd47b8cd4e6 ("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