summaryrefslogtreecommitdiffstats
path: root/crypto/fips.c
diff options
context:
space:
mode:
authorStefan Haberland <sth@linux.vnet.ibm.com>2018-02-07 17:39:14 +0100
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2018-02-19 08:00:06 +0100
commit9487cfd3430d07366801886bdf185799a2b6f066 (patch)
treefafddcb9486322303475f687d41b30ce6dad7c34 /crypto/fips.c
parent91ab883eb21325ad80f3473633f794c78ac87f51 (diff)
downloadlinux-9487cfd3430d07366801886bdf185799a2b6f066.tar.bz2
s390/dasd: fix handling of internal requests
Internal DASD device driver I/O such as query host access count or path verification is started using the _sleep_on() function. To mark a request as started or ended the callback_data is set to either DASD_SLEEPON_START_TAG or DASD_SLEEPON_END_TAG. In cases where the request has to be stopped unconditionally the status is set to DASD_SLEEPON_END_TAG as well which leads to immediate clearing of the request. But the request might still be on a device request queue for normal operation which might lead to a panic because of a BUG() statement in __dasd_device_process_final_queue() or a list corruption of the device request queue. Fix by removing the setting of DASD_SLEEPON_END_TAG in the dasd_cancel_req() and dasd_generic_requeue_all_requests() functions and ensure that the request is not deleted in the requeue function. Trigger the device tasklet in the requeue function and let the normal processing cleanup the request. Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com> Reviewed-by: Jan Hoeppner <hoeppner@linux.vnet.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'crypto/fips.c')
0 files changed, 0 insertions, 0 deletions