On 02/04/18 01:16 PM, Jerome Glisse wrote: > There isn't good API at the moment AFAIK, closest thing would either be > lookup_resource() or region_intersects(), but a more appropriate one can > easily be added, code to walk down the tree is readily available. More- > over this can be optimize like vma lookup are, even more as resource are > seldomly added so read side (finding a resource) can be heavily favor > over write side (adding|registering a new resource). So someone needs to create a highly optimized tree that registers all physical address on the system and maps them to devices? That seems a long way from being realized. I'd hardly characterize that as "easily". If we can pass both devices to the API I'd suspect it would be preferred over the complicated tree. This, of course, depends on what users of the API need. > cache coherency protocol (bit further than PCIE snoop). But also the > other direction the CPU access to device memory can also be cache coherent, > which is not the case in PCIE. I was not aware that CAPI allows PCI device memory to be cache coherent. That sounds like it would be very tricky... > Note that with mmu_notifier there isn't any need to pin stuff (even > without any special hardware capabilities), as long as you can preempt > what is happening on your hardware to update its page table. I've been told there's a lot of dislike of the mmu_notifier interface. And being able to preempt what's happening on hardware, generally, is not trivial. But, yes, this is essentially how ODP works. Logan