On Thu, Mar 01, 2018 at 02:15:01PM -0700, Logan Gunthorpe wrote: > > > On 01/03/18 02:10 PM, Jerome Glisse wrote: > > It seems people miss-understand HMM :( you do not have to use all of > > its features. If all you care about is having struct page then just > > use that for instance in your case only use those following 3 functions: > > > > hmm_devmem_add() or hmm_devmem_add_resource() and hmm_devmem_remove() > > for cleanup. > > To what benefit over just using devm_memremap_pages()? If I'm using the hmm > interface and disabling all the features, I don't see the point. We've also > cleaned up the devm_memremap_pages() interface to be more usefully generic > in such a way that I'd hope HMM starts using it too and gets rid of the code > duplication. > The first HMM variant find a hole and do not require a resource as input parameter. Beside that internaly for PCIE device memory devm_memremap_pages() does not do the right thing last time i check it always create a linear mapping of the range ie HMM call add_pages() while devm_memremap_pages() call arch_add_memory() When i upstreamed HMM, Dan didn't want me to touch devm_memremap_pages() to match my need. I am more than happy to modify devm_memremap_pages() to also handle HMM needs. Note that the intention of HMM is to be a middle layer between low level infrastructure and device driver. Idea is that such impedance layer should make it easier down the road to change how thing are handled down below without having to touch many device driver. Cheers, Jérôme