]> www.infradead.org Git - users/dwmw2/qemu.git/commit
chardev/char-hub: implement backend chardev aggregator
authorRoman Penyaev <r.peniaev@gmail.com>
Thu, 23 Jan 2025 08:53:22 +0000 (09:53 +0100)
committerMarc-André Lureau <marcandre.lureau@redhat.com>
Mon, 3 Feb 2025 09:57:08 +0000 (13:57 +0400)
commitb66ed232383162dc52d6a1c996599541860d1f1a
tree72f96eaa9ab26da1b5a075abe073e742a6ab2880
parent4e059a9d966703e27c9f15e47c9b5e94509c5538
chardev/char-hub: implement backend chardev aggregator

This patch implements a new chardev backend `hub` device, which
aggregates input from multiple backend devices and forwards it to a
single frontend device. Additionally, `hub` device takes the output
from the frontend device and sends it back to all the connected
backend devices. This allows for seamless interaction between
different backend devices and a single frontend interface.

The idea of the change is trivial: keep list of backend devices
(up to 4), init them on demand and forward data buffer back and
forth.

The following is QEMU command line example:

   -chardev pty,path=/tmp/pty,id=pty0 \
   -chardev vc,id=vc0 \
   -chardev hub,id=hub0,chardevs.0=pty0,chardevs.1=vc0 \
   -device virtconsole,chardev=hub0 \
   -vnc 0.0.0.0:0

Which creates 2 backend devices: text virtual console (`vc0`) and a
pseudo TTY (`pty0`) connected to the single virtio hvc console with
the backend aggregator (`hub0`) help. `vc0` renders text to an image,
which can be shared over the VNC protocol.  `pty0` is a pseudo TTY
backend which provides biderectional communication to the virtio hvc
console.

'chardevs.N' list syntax is used for the sake of compatibility with
the representation of JSON lists in 'key=val' pairs format of the
util/keyval.c, despite the fact that modern QAPI way of parsing,
namely qobject_input_visitor_new_str(), is not used. Choice of keeping
QAPI list syntax may help to smoothly switch to modern parsing in the
future.

Signed-off-by: Roman Penyaev <r.peniaev@gmail.com>
Reviewed-by: "Marc-André Lureau" <marcandre.lureau@redhat.com>
Cc: qemu-devel@nongnu.org
Message-ID: <20250123085327.965501-3-r.peniaev@gmail.com>
chardev/char-hub.c [new file with mode: 0644]
chardev/char.c
chardev/chardev-internal.h
chardev/meson.build
include/chardev/char.h
qapi/char.json