summaryrefslogtreecommitdiffstats
path: root/fs/debugfs
diff options
context:
space:
mode:
authorJames Smart <jsmart2021@gmail.com>2017-09-14 11:03:09 -0700
committerJens Axboe <axboe@kernel.dk>2017-09-25 08:56:05 -0600
commitcd48282cc736377d5abf7c04de8c6ba864ba3794 (patch)
tree9ec3b321ff9471b07d1a2119673259f67313c049 /fs/debugfs
parentd08774738446e77734777adcf5d1045237b4475a (diff)
downloadlinux-cd48282cc736377d5abf7c04de8c6ba864ba3794.tar.bz2
nvme: stop aer posting if controller state not live
If an nvme async_event command completes, in most cases, a new async event is posted. However, if the controller enters a resetting or reconnecting state, there is nothing to block the scheduled work element from posting the async event again. Nor are there calls from the transport to stop async events when an association dies. In the case of FC, where the association is torn down, the aer must be aborted on the FC link and completes through the normal job completion path. Thus the terminated async event ends up being rescheduled even though the controller isn't in a valid state for the aer, and the reposting gets the transport into a partially torn down data structure. It's possible to hit the scenario on rdma, although much less likely due to an aer completing right as the association is terminated and as the association teardown reclaims the blk requests via nvme_cancel_request() so its immediate, not a link-related action like on FC. Fix by putting controller state checks in both the async event completion routine where it schedules the async event and in the async event work routine before it calls into the transport. It's effectively a "stop_async_events()" behavior. The transport, when it creates a new association with the subsystem will transition the state back to live and is already restarting the async event posting. Signed-off-by: James Smart <james.smart@broadcom.com> [hch: remove taking a lock over reading the controller state] Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'fs/debugfs')
0 files changed, 0 insertions, 0 deletions