[RFC v3 2/3] virtio: Introduce Vdmabuf driver
Christian König
christian.koenig at amd.com
Fri Feb 12 08:47:49 UTC 2021
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
More information about the dri-devel
mailing list