On Sun, 2017-04-16 at 10:34 -0600, Logan Gunthorpe wrote: > > On 16/04/17 09:53 AM, Dan Williams wrote: > > ZONE_DEVICE allows you to redirect via get_dev_pagemap() to retrieve > > context about the physical address in question. I'm thinking you can > > hang bus address translation data off of that structure. This seems > > vaguely similar to what HMM is doing. > > Thanks! I didn't realize you had the infrastructure to look up a device > from a pfn/page. That would really come in handy for us. It does indeed. I won't be able to play with that much for a few weeks (see my other email) so if you're going to tackle this while I'm away, can you work with Jerome to make sure you don't conflict with HMM ? I really want a way for HMM to be able to layout struct pages over the GPU BARs rather than in "allocated free space" for the case where the BAR is big enough to cover all of the GPU memory. In general, I'd like a simple & generic way for any driver to ask the core to layout DMA'ble struct pages over BAR space. I an not convinced this requires a "p2mem device" to be created on top of this though but that's a different discussion. Of course the actual ability to perform the DMA mapping will be subject to various restrictions that will have to be implemented in the actual "dma_ops override" backend. We can have generic code to handle the case where devices reside on the same domain, which can deal with switch configuration etc... we will need to have iommu specific code to handle the case going through the fabric. Virtualization is a separate can of worms due to how qemu completely fakes the MMIO space, we can look into that later. Cheers, Ben.