diff options
| author | Amit Shah <amit.shah@redhat.com> | 2013-03-29 16:30:08 +0530 | 
|---|---|---|
| committer | Rusty Russell <rusty@rustcorp.com.au> | 2013-03-30 14:25:46 +1030 | 
| commit | 9ba5c80b1aea8648a3efe5f22dc1f7cacdfbeeb8 (patch) | |
| tree | cdb191b7987323a4e454c9033ba4e449483ad57d /tools/perf/scripts/python/syscall-counts-by-pid.py | |
| parent | 165b1b8bbc17c9469b053bab78b11b7cbce6d161 (diff) | |
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 'tools/perf/scripts/python/syscall-counts-by-pid.py')
0 files changed, 0 insertions, 0 deletions
