 
            Hi Alex and Stefano,
2020年10月20日(火) 2:14 Stefano Stabellini stefano.stabellini@xilinx.com:
On Fri, 16 Oct 2020, Alex Bennée via Stratos-dev wrote:
Masami Hiramatsu masami.hiramatsu@linaro.org writes:
Hi Alex,
2020年10月16日(金) 2:01 Alex Bennée alex.bennee@linaro.org:
Masami Hiramatsu masami.hiramatsu@linaro.org writes:
Hi,
I've succeeded to make the X.org running on Dom0. It seems that Xorg's nouveau driver caused SIGBUS issue. Custom nouveau kernel driver + Xorg fbdev driver seems stable. (Even if it doesn't work again, I'll try to use USB-HDMI adaptor next time)
So, I would like to test the virtio-video for the next step. Alex, how can I help you to test it?
In one window you need the vhost-user gpu daemon:
./vhost-user-gpu --socket-path=vgpu.sock -v
Hmm, I couldn't find vhost-user-gpu (I've installed xen tools under /usr/local, but I can not find vhost* tools)
The vhost-user-gpu tool is part of the QEMU source tree (contrib/vhost-user-gpu).
and then on the QEMU command line you need the memory sharing and the socket connection as well as the device:
$QEMU $ARGS \ -object memory-backend-file,id=mem,size=4G,mem-path=/dev/shm,share=on \ -numa node,memdev=mem \ -chardev socket,path=vgpu.sock,id=vgpu \ -device vhost-user-gpu-pci,chardev=vgpu
BTW, what "$ARGS" you usually pass? And should I use /dev/shm as a memory backend? (is that mandatory for vhost-gpu?)
I'm using xl command ( xl create -dc CONFIGFILE ) to boot up guest domain. Can I boot it up via qemu too?
Hmm so this is where we might need some extra tooling. I'm not sure how QEMU gets invoked by the xl tooling but QEMU for Xen is a fairly different beast to the normal hypervisor interaction as rather than handling vmexits from the hypervisor it just gets commands via the Xen control interface to service emulation and I/O requests.
The above QEMU commands ensure that:
- the guest memory space is shared wit the vhost-user-gpu daemon
- a control path is wired up so vhost-user messages can be sent during setup (inititalise the device etc)
- the same socket path is fed eventfd messages as the guest triggers virtio events. These can all come from QEMU if the kernel isn't translating mmio access to the virtqueues to eventfd events.
Steffano, how does the XL tooling invoke QEMU and can the command line be modified?
Yes, it can, in a couple of different ways. You can add arguments to the QEMU command line by specifying:
device_model_args=["arg1", "arg2", "etc."]
OK, so as above command, we need device_model_args=[ ..., "-object memory-backend-file,id=mem,size=4G,mem-path=/dev/shm,share=on", "-numa node,memdev=mem", "-chardev socket,path=vgpu.sock,id=vgpu", "-device vhost-user-gpu-pci,chardev=vgpu" ] (the ... is a placeholder for $ARGS)
in the vm config file. You can also choose a different QEMU binary to run with:
device_model_override="/path/to/your/qemu"
You can use it to have your own qemu script that adds additional arguments before calling the actual qemu binary (by default is /usr/lib/xen/bin/qemu-system-i386 even on ARM.)
Should I use qemu-system-i386 even if I rebuild qemu outside Xen?
Thank you,