From: Eric Farman <farman@linux.vnet.ibm.com>
To: linux-scsi@vger.kernel.org
Cc: jejb@linux.vnet.ibm.com, martin.petersen@oracle.com,
Eric Farman <farman@linux.vnet.ibm.com>
Subject: [PATCH] virtio_scsi: Reject commands when virtqueue is broken
Date: Wed, 11 Jan 2017 17:02:01 -0500 [thread overview]
Message-ID: <1484172122-18882-1-git-send-email-farman@linux.vnet.ibm.com> (raw)
While doing some disruptive testing with QEMU/KVM, I have encountered some
guest problems during hot unplug of virtio-scsi devices depending on the
order of operations in which they are performed. The following notes
describe my setup (s390x), and how I'm able to reproduce the error and
test the attached fix.
In both the "working" and "failing" case, the detaches appear to work
just fine. Any sign of problems only begin to appear later based on
other actions I may perform, such as powering off the guest system.
Host:
# lsscsi -g | grep sg6
[6:0:6:1074151456]disk IBM 2107900 .217 /dev/sdg /dev/sg6
QEMU:
- Include the following parameters
-device virtio-scsi-ccw,id=scsi0
-drive file=/dev/sg6,if=none,id=drive0,format=raw
-device scsi-generic,bus=scsi0.0,channel=0,scsi-id=0,lun=0,drive=drive0,id=hostdev6
- QMP commands (working)
- device_del hostdev6
- device_del scsi0
- QMP commands (failing)
- device_del scsi0
Libvirt:
- Note: A preventative fix went into Libvirt 2.5.0
(libvirt commit 655429a0d4a5 ("qemu: Prevent detaching SCSI controller used by hostdev"))
- Include the following XML
# cat scsicontroller.xml
<controller type='scsi' model='virtio-scsi' index='0'/>
# cat scsihostdev.xml
<hostdev mode='subsystem' type='scsi'>
<source>
<adapter name='scsi_host6'/>
<address bus='0' target='6' unit='1074151456'/>
</source>
</hostdev>
- virsh commands (working)
- virsh detach-device guest scsihostdev.xml
- virsh detach-device guest scsicontroller.xml
- virsh commands (failing)
- virsh detach-device guest scsicontroller.xml
Eric Farman (1):
virtio_scsi: Reject commands when virtqueue is broken
drivers/scsi/virtio_scsi.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
--
1.9.1
next reply other threads:[~2017-01-11 22:02 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-01-11 22:02 Eric Farman [this message]
2017-01-11 22:02 ` [PATCH] virtio_scsi: Reject commands when virtqueue is broken Eric Farman
2017-01-12 3:11 ` Fam Zheng
2017-01-12 13:28 ` Eric Farman
2017-01-12 13:45 ` Fam Zheng
2017-01-12 14:02 ` Eric Farman
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1484172122-18882-1-git-send-email-farman@linux.vnet.ibm.com \
--to=farman@linux.vnet.ibm.com \
--cc=jejb@linux.vnet.ibm.com \
--cc=linux-scsi@vger.kernel.org \
--cc=martin.petersen@oracle.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox