diff options
author | Mike Christie <michael.christie@oracle.com> | 2020-11-09 23:33:21 -0600 |
---|---|---|
committer | Michael S. Tsirkin <mst@redhat.com> | 2020-11-15 17:30:55 -0500 |
commit | 47a3565e8bb14ec48a75b48daf57aa830e2691f8 (patch) | |
tree | 303de8739ecd28a81ac9bacac217afd6a9767c83 /fs/block_dev.c | |
parent | 25b98b64e28423b0769313dcaf96423836b1f93d (diff) | |
download | linux-stable-47a3565e8bb14ec48a75b48daf57aa830e2691f8.tar.gz linux-stable-47a3565e8bb14ec48a75b48daf57aa830e2691f8.tar.bz2 linux-stable-47a3565e8bb14ec48a75b48daf57aa830e2691f8.zip |
vhost scsi: fix cmd completion race
We might not do the final se_cmd put from vhost_scsi_complete_cmd_work.
When the last put happens a little later then we could race where
vhost_scsi_complete_cmd_work does vhost_signal, the guest runs and sends
more IO, and vhost_scsi_handle_vq runs but does not find any free cmds.
This patch has us delay completing the cmd until the last lio core ref
is dropped. We then know that once we signal to the guest that the cmd
is completed that if it queues a new command it will find a free cmd.
Signed-off-by: Mike Christie <michael.christie@oracle.com>
Reviewed-by: Maurizio Lombardi <mlombard@redhat.com>
Link: https://lore.kernel.org/r/1604986403-4931-4-git-send-email-michael.christie@oracle.com
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'fs/block_dev.c')
0 files changed, 0 insertions, 0 deletions