On Thu, Dec 14, 2017 at 03:05:39PM +0800, Figo.zhang wrote: > 2017-12-14 12:16 GMT+08:00 Jerome Glisse <jglisse@xxxxxxxxxx>: > > On Thu, Dec 14, 2017 at 11:53:40AM +0800, Figo.zhang wrote: > > > 2017-12-14 11:16 GMT+08:00 Jerome Glisse <jglisse@xxxxxxxxxx>: > > > > On Thu, Dec 14, 2017 at 10:48:36AM +0800, Figo.zhang wrote: > > > > > 2017-12-14 0:12 GMT+08:00 Jerome Glisse <jglisse@xxxxxxxxxx>: > > > > > > On Wed, Dec 13, 2017 at 08:10:42PM +0800, Figo.zhang wrote: [...] > > This slide is for the case where you use device memory on PCIE platform. > > When that happen only the device can access the virtual address back by > > device memory. If CPU try to access such address a page fault is trigger > > and it migrate the data back to regular memory where both GPU and CPU can > > access it concurently. > > > > And again this behavior only happen if you use HMM non cache coherent > > device memory model. If you use the device cache coherent model with HMM > > then CPU can access the device memory directly too and above scenario > > never happen. > > > > Note that memory copy when data move from device to system or from system > > to device memory are inevitable. This is exactly as with autoNUMA. Also > > note that in some case thing can get allocated directly on GPU and never > > copied back to regular memory (only use by GPU and freed once GPU is done > > with them) the zero copy case. But i want to stress that the zero copy > > case is unlikely to happen for input buffer. Usualy you do not get your > > input data set directly on the GPU but from network or disk and you might > > do pre-processing on CPU (uncompress input, or do something that is better > > done on the CPU). Then you feed your data to the GPU and you do computation > > there. > > > > Great!very detail about the HMM explanation, Thanks a lot. > so would you like see my conclusion is correct? > * if support CCIX/CAPI, CPU can access GPU memory directly, and GPU also > can access CPU memory directly, > so it no need copy on kernel space in HMM solutions. Yes but migration do imply copy. The physical address backing a virtual address can change over the lifetime of a virtual address (between mmap and munmap). As a result of various activity (auto NUMA, compaction, swap out then swap back in, ...) and in the case that interest us as the result of a device driver migrating thing to its device memory. > * if no support CCIX/CAPI, CPU cannot access GPU memory in cache > coherency method, also GPU cannot access CPU memory at > cache coherency. it need some copies like John Hobburt's slides. > *when GPU page fault, need copy data from CPU page to GPU page, and > HMM unmap the CPU page... > * when CPU page fault, need copy data from GPU page to CPU page > and ummap GPU page and map the CPU page... No, GPU can access main memory just fine (snoop PCIE transaction and in a full cache coherent way with CPU). Only the CPU can not access the device memory. So there is a special case only when migrating some virtual address to use device memory. What is described inside John's slides is what happen when you migrate some virtual addresses to device memory where the CPU can not access it. This migration is not necessary for the GPU to access memory. It only happens as an optimization when the device driver suspect it will make frequent access to that memory and that CPU will not try to access it. [...] > > No. Here we are always talking about virtual address that are the outcome > > of an mmap syscall either as private anonymous memory or as mmap of regular > > file (ie not a device file but a regular file on a filesystem). > > > > Device driver can migrate any virtual address to use device memory for > > performance reasons (how, why and when such migration happens is totaly > > opaque to HMM it is under the control of the device driver). > > > > So if you do: > > BUFA = malloc(size); > > Then do something with BUFA on the CPU (like reading input or network, ...) > > the memory is likely to be allocated with regular main memory (like DDR). > > > > Now if you start some job on your GPU that access BUFA the device driver > > might call migrate_vma() helper to migrate the memory to device memory. At > > that point the virtual address of BUFA point to physical device memory here > > CAPI or CCIX. If it is not CAPI/CCIX than the GPU page table point to > > device > > memory while the CPU page table point to invalid special entry. The GPU can > > work on BUFA that now reside inside the device memory. Finaly, in the non > > CAPI/CCIX case, if CPU try to access that memory then a migration back to > > regular memory happen. > > > > in this scenario: > *if CAPI/CCIX support, the CPU's page table and GPU's also point to the > device physical page? > in this case, it still need the ZONE_DEVICE infrastructure for > CPU page table? Correct, in CAPI/CCIX case there is only one page table and thus after migration they both point to same physical address for the virtual addresses of BUFA. > *if no CAPI/CCIX support, the CPU's page table filled a invalid special pte. Correct. This is the case described by John's slides. The physical memory backing a virtual address can change at anytime for many different reasons (autonuma, compaction, swap out follow by swap in, ...) and migration (from one physical memory type to another) for accelerator purposes is just a new reasons in that list. Cheers, Jérôme -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>