summaryrefslogtreecommitdiffstats
path: root/drivers/char/nwbutton.h
diff options
context:
space:
mode:
authorAmit Shah <amit.shah@redhat.com>2013-03-29 12:00:08 +0100
committerRusty Russell <rusty@rustcorp.com.au>2013-03-30 04:55:46 +0100
commit9ba5c80b1aea8648a3efe5f22dc1f7cacdfbeeb8 (patch)
treecdb191b7987323a4e454c9033ba4e449483ad57d /drivers/char/nwbutton.h
parentvirtio: console: rename cvq_lock to c_ivq_lock (diff)
downloadlinux-9ba5c80b1aea8648a3efe5f22dc1f7cacdfbeeb8.tar.xz
linux-9ba5c80b1aea8648a3efe5f22dc1f7cacdfbeeb8.zip
virtio: console: add locking around c_ovq operations
When multiple ovq operations are being performed (lots of open/close operations on virtio_console fds), the __send_control_msg() function can get confused without locking. A simple recipe to cause badness is: * create a QEMU VM with two virtio-serial ports * in the guest, do while true;do echo abc >/dev/vport0p1;done while true;do echo edf >/dev/vport0p2;done In one run, this caused a panic in __send_control_msg(). In another, I got virtio_console virtio0: control-o:id 0 is not a head! This also results repeated messages similar to these on the host: qemu-kvm: virtio-serial-bus: Unexpected port id 478762112 for device virtio-serial-bus.0 qemu-kvm: virtio-serial-bus: Unexpected port id 478762368 for device virtio-serial-bus.0 Reported-by: FuXiangChun <xfu@redhat.com> Signed-off-by: Amit Shah <amit.shah@redhat.com> Reviewed-by: Wanlong Gao <gaowanlong@cn.fujitsu.com> Reviewed-by: Asias He <asias@redhat.com> Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Cc: stable@kernel.org
Diffstat (limited to 'drivers/char/nwbutton.h')
0 files changed, 0 insertions, 0 deletions