Re: [RFC v3 2/3] virtio: Introduce Vdmabuf driver

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

 



Hi Vivek,

Am 12.02.21 um 09:36 schrieb Kasireddy, Vivek:
Hi Christian,

Hi Vivek,

[Kasireddy, Vivek] What if I do mmap() on the fd followed by mlock()
or mmap() followed by get_user_pages()? If it still fails, would
ioremapping the device memory and poking at the backing storage be an
option? Or, if I bind the passthrough'd GPU device to vfio-pci and tap
into the memory region associated with the device memory, can it be made to work?
get_user_pages() is not allowed on mmaped DMA-bufs in the first place.

Daniel is currently adding code to make sure that this is never ever used.

And, I noticed that for PFNs that do not have valid struct page
associated with it, KVM does a memremap() to access/map them. Is this an option?
No, even for system memory which has a valid struct page touching it when it is part of a
DMA-buf is illegal since the reference count and mapping fields in struct page might be
used for something different.

Keep in mind that struct page is a heavily overloaded structure for different use cases. You
can't just use it for a different use case than what the owner of the page has intended it.
[Kasireddy, Vivek] What is your recommended/acceptable way for doing what I am trying to
do?

I'm not an expert on virtualisation, but Gerd seems to have a couple of ideas of how to get this working.

In general I think it is pretty much impossible to export stuff from the guest to the host by DMA-buf.

This is because of the fundamental concept of DMA-buf that the exporter needs to setup mappings (both CPU page tables as well as stuff like IOMMU). When the guest exports something it would mean that you give the guest control over the IOMMU and/or host page tables. And that is not something you can do as far as I can see.

You can only export stuff the other way around so that the host is providing the memory and the guest is consuming it. If I understand it correctly that's exactly what Gerd is suggesting here.

Regards,
Christian.


Thanks,
Vivek

Regards,
Christian.


Thanks,
Vivek
take care,
    Gerd

_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel



[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux