Re: [PATCH v2 13/15] drm/ttm: Add BO and offset arguments for vm_access and vm_fault ttm handlers.

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

 



Am 18.05.21 um 19:32 schrieb Thomas Hellström:
[SNIP]
PTE handling is the domain of TTM, drivers should never mess with that directly.

Hmm. May I humbly suggest a different view on this:

I agree fully for ttm_bo_type_device bos but for ttm_bo_type_kernel, TTM has no business whatsoever with user-space PTEs. That's really why that bo type exists in the first place. But otoh one can of course argue that then i915 has no business calling the TTM fault helper for these bos.

Well the real question is why does i915 wants to expose kernel BOs to userspace? As the name says only the kernel should be able to access them.

I'd say "kernel" of course refers to how TTM handles them.

Fair enough.



So for discrete we can probably do the right thing with ttm_bo_type_device. What worries me a bit is when we get to older hardware support because whatever we do is by definition going to be ugly. At best we might be able to split the address space between i915's mmos, and hand the rest to TTM, modifying offsets as you suggest. That way a TTM call to unmap_mapping_range() would do the right thing, I think.

Well we do all kind of nasty stuff with the offset in DMA-buf, KFD, overlayfs etc. So adjusting the offset inside the kernel is already well supported and used.

What I don't fully understand is your use case here? Can you briefly describe that?

Do you use different bits of the offset to signal what caching behavior you have? And then based on this adjust the pgprot_t in the vma?

Thanks,
Christian.

TBH I'm not completely sure about the history of this. I think the basic idea is that you want to support different vmas with different caching modes, so you never change the vma pgprot after mmap time, like TTM does. Needless to say this only works with Intel processors on integrated and the more I write about this the more I'm convinced that we should perhaps not concern TTM with that at all.

Yeah, that might be a possibility.

But KFD does something very similar IIRC. They stuff the routing information into the upper bits of the offset and adjust it then to match what TTM wants in the mmap() callback.

Adjusting the caching behavior on the fly is really tricky and I'm pretty sure you should not do that outside of the integrated Intel processor anyway :)

Cheers,
Christian.


/Thomas




/Thomas


Christian.


While we're in the process of killing that offset flexibility for discrete, we can't do so for older hardware unfortunately.

/Thomas



Christian.





/Thomas








[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