Message ID | 20190913093213.27254-1-thomas_os@shipmail.org (mailing list archive) |
---|---|
Headers | show |
Series | Emulated coherent graphics memory take 2 | expand |
On Fri, 13 Sep 2019 11:32:09 +0200 > > err = ttm_mem_io_lock(man, true); > - if (unlikely(err != 0)) { > - ret = VM_FAULT_NOPAGE; > - goto out_unlock; > - } > + if (unlikely(err != 0)) > + return VM_FAULT_NOPAGE; > err = ttm_mem_io_reserve_vm(bo); > - if (unlikely(err != 0)) { > - ret = VM_FAULT_SIGBUS; > - goto out_io_unlock; > - } > + if (unlikely(err != 0)) > + return VM_FAULT_SIGBUS; > Hehe, no hurry. > @@ -295,8 +307,28 @@ static vm_fault_t ttm_bo_vm_fault(struct vm_fault *vmf) > ret = VM_FAULT_NOPAGE; > out_io_unlock: > ttm_mem_io_unlock(man); > -out_unlock: > + return ret; > +} > +EXPORT_SYMBOL(ttm_bo_vm_fault_reserved);
On 9/13/19 3:40 PM, Hillf Danton wrote: > On Fri, 13 Sep 2019 11:32:09 +0200 >> err = ttm_mem_io_lock(man, true); >> - if (unlikely(err != 0)) { >> - ret = VM_FAULT_NOPAGE; >> - goto out_unlock; >> - } >> + if (unlikely(err != 0)) >> + return VM_FAULT_NOPAGE; >> err = ttm_mem_io_reserve_vm(bo); >> - if (unlikely(err != 0)) { >> - ret = VM_FAULT_SIGBUS; >> - goto out_io_unlock; >> - } >> + if (unlikely(err != 0)) >> + return VM_FAULT_SIGBUS; >> > Hehe, no hurry. Could you be a bit more specific? Thanks, Thomas > >> @@ -295,8 +307,28 @@ static vm_fault_t ttm_bo_vm_fault(struct vm_fault *vmf) >> ret = VM_FAULT_NOPAGE; >> out_io_unlock: >> ttm_mem_io_unlock(man); >> -out_unlock: >> + return ret; >> +} >> +EXPORT_SYMBOL(ttm_bo_vm_fault_reserved);
On 9/13/19 3:40 PM, Hillf Danton wrote: > On Fri, 13 Sep 2019 11:32:09 +0200 >> err = ttm_mem_io_lock(man, true); >> - if (unlikely(err != 0)) { >> - ret = VM_FAULT_NOPAGE; >> - goto out_unlock; >> - } >> + if (unlikely(err != 0)) >> + return VM_FAULT_NOPAGE; >> err = ttm_mem_io_reserve_vm(bo); >> - if (unlikely(err != 0)) { >> - ret = VM_FAULT_SIGBUS; >> - goto out_io_unlock; >> - } >> + if (unlikely(err != 0)) >> + return VM_FAULT_SIGBUS; >> > Hehe, no hurry. Ah. I get the point :) Yes, I'll update. Haven't been looking at these patches for a while. Thanks, Thomas
From: Thomas Hellström <thellstrom@vmware.com> Graphics APIs like OpenGL 4.4 and Vulkan require the graphics driver to provide coherent graphics memory, meaning that the GPU sees any content written to the coherent memory on the next GPU operation that touches that memory, and the CPU sees any content written by the GPU to that memory immediately after any fence object trailing the GPU operation has signaled. Paravirtual drivers that otherwise require explicit synchronization needs to do this by hooking up dirty tracking to pagefault handlers and buffer object validation. The mm patch page walk interface has been reworked to be similar to the reworked page-walk code (mm/pagewalk.c). There have been two other solutions to consider: 1) Using the page-walk code. That is currently not possible since it requires the mmap-sem to be held for the struct vm_area_struct vm_flags and for huge page splitting. The pagewalk code in this patchset can't hold the mmap sems since it will lead to locking inversion. Instead it uses an operation mode similar to unmap_mapping_range where the i_mmap_lock is held. 2) Using apply_to_page_range(). The primary use of this code is to fill page tables. The operation modes are IMO sufficiently different to motivate re-implementing the page-walk. For the TTM changes they are hopefully in line with the long-term strategy of making helpers out of what's left of TTM. The code has been tested and exercised by a tailored version of mesa where we disable all explicit synchronization and assume graphics memory is coherent. The performance loss varies of course; a typical number is around 5%. I would like to merge this code through the DRM tree, so an ack to do that from an mm maintainer would be greatly appreciated. Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Matthew Wilcox <willy@infradead.org> Cc: Will Deacon <will.deacon@arm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Rik van Riel <riel@surriel.com> Cc: Minchan Kim <minchan@kernel.org> Cc: Michal Hocko <mhocko@suse.com> Cc: Huang Ying <ying.huang@intel.com> Cc: Souptick Joarder <jrdr.linux@gmail.com> Cc: "Jérôme Glisse" <jglisse@redhat.com> Cc: "Christian König" <christian.koenig@amd.com> Cc: Christoph Hellwig <hch@infradead.org>