diff options
author | Amit Shah <[email protected]> | 2013-03-29 16:30:08 +0530 |
---|---|---|
committer | Rusty Russell <[email protected]> | 2013-03-30 14:25:46 +1030 |
commit | 9ba5c80b1aea8648a3efe5f22dc1f7cacdfbeeb8 (patch) | |
tree | cdb191b7987323a4e454c9033ba4e449483ad57d /tools/perf/scripts/python/Perf-Trace-Util/lib | |
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 <[email protected]>
Signed-off-by: Amit Shah <[email protected]>
Reviewed-by: Wanlong Gao <[email protected]>
Reviewed-by: Asias He <[email protected]>
Signed-off-by: Rusty Russell <[email protected]>
Cc: [email protected]
Diffstat (limited to 'tools/perf/scripts/python/Perf-Trace-Util/lib')
0 files changed, 0 insertions, 0 deletions