> On 2019-11-06 23:41, Gerd Hoffmann wrote: > > On Wed, Nov 06, 2019 at 05:36:22PM +0900, David Stevens wrote: > > > > (1) The virtio device > > > > ===================== > > > > > > > > Has a single virtio queue, so the guest can send commands to register > > > > and unregister buffers. Buffers are allocated in guest ram. Each buffer > > > > has a list of memory ranges for the data. Each buffer also has some > > > > > > Allocating from guest ram would work most of the time, but I think > > > it's insufficient for many use cases. It doesn't really support things > > > such as contiguous allocations, allocations from carveouts or <4GB, > > > protected buffers, etc. > > > > If there are additional constrains (due to gpu hardware I guess) > > I think it is better to leave the buffer allocation to virtio-gpu. > > The entire point of this for our purposes is due to the fact that we can > not allocate the buffer, it's either provided by the GPU driver or > DirectX. If virtio-gpu were to allocate the buffer we might as well forget > all this and continue using the ivshmem device. Well, virtio-gpu resources are in guest ram, like the buffers of a virtio-buffers device would be. So it isn't much of a difference. If the buffer provided by the (nvidia/amd/intel) gpu driver lives in ram you can create a virtio-gpu resource for it. On the linux side that is typically handled with dma-buf, one driver exports the dma-buf and the other imports it. virtio-gpu doesn't support that fully yet though (import is being worked on, export is done and will land upstream in the next merge window). No clue how this looks like for windows guests ... > Currently IVSHMEM is used by two projects that I am aware of, Looking > Glass and SCREAM. While Looking Glass is solving a problem that is out of > scope for QEMU, SCREAM is working around the audio problems in QEMU that > have been present for years now. Side note: sound in qemu 3.1+ should be alot better than in 2.x versions. cheers, Gerd