Re: passing FDs across domains

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 11/15/2017 09:21 AM, Tomeu Vizoso wrote:
On 11/14/2017 03:19 PM, Gerd Hoffmann wrote:
What kind of shared memory is used by wayland?
sysv shm?  gbm buffers / dmabufs?

Typically, shared memory for CPU-rendered content, and dmabufs for
GPU-rendered content.

Ok.  I guess solving this for virtio-gpu (with virgl enabled) is easiest
then.  Due to opengl rendering being offloaded to the host gpu the
guest window content already is in a host gpu buffer.

Yes, besides, we already have virtio-gpu in place which can be improved as
needed.

I'm more worried about CPU-rendered buffers, as the client is just putting in the socket the output of shm_open or similar. There I don't see any easy
solution which is why I tried to get more "creative".

Will clients actually use cpu rendering of opengl is available?

Don't know of any Wayland clients that would behave in that way.

Sorry, I'm afraid that this actually says the opposite of what I intended to say.

I meant to say that we cannot rely on clients choosing GL rendering over CPU rendering when that's available. In most cases, applications will either do their rendering on the CPU, or on the GPU.

Regards,

Tomeu


Can clients cpu-render into dumb drm buffers?

They could, but dumb buffers aren't generally shareable, besides being intended to be just dumb. We could probably use VGEM for that though.

But the problem is that all Wayland clients are currently expected to do their CPU rendering to a buffer that was created in /dev/shm/ or with the memfd_create syscall.

I know we cannot support all the kinds of objects that can be referenced by FDs, but I think it can be said that all modern protocols that can contain references to big areas of memory make use of passing FDs to shared memory. Depending on the situation that memory would have been allocated in the host or in the client.

Thanks,

Tomeu






[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux