mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 f8477ce6b5
			
		
	
	
		f8477ce6b5
		
	
	
	
	
		
			
			Use the new MMU_NOTIFY_MIGRATE event to skip GPU MMU invalidations of device private memory and handle the invalidation in the driver as part of migrating device private memory. Link: https://lore.kernel.org/r/20200723223004.9586-5-rcampbell@nvidia.com Signed-off-by: Ralph Campbell <rcampbell@nvidia.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
		
			
				
	
	
		
			65 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __NOUVEAU_SVM_H__
 | |
| #define __NOUVEAU_SVM_H__
 | |
| #include <nvif/os.h>
 | |
| #include <linux/mmu_notifier.h>
 | |
| struct drm_device;
 | |
| struct drm_file;
 | |
| struct nouveau_drm;
 | |
| 
 | |
| struct nouveau_svmm {
 | |
| 	struct mmu_notifier notifier;
 | |
| 	struct nouveau_vmm *vmm;
 | |
| 	struct {
 | |
| 		unsigned long start;
 | |
| 		unsigned long limit;
 | |
| 	} unmanaged;
 | |
| 
 | |
| 	struct mutex mutex;
 | |
| };
 | |
| 
 | |
| #if IS_ENABLED(CONFIG_DRM_NOUVEAU_SVM)
 | |
| void nouveau_svm_init(struct nouveau_drm *);
 | |
| void nouveau_svm_fini(struct nouveau_drm *);
 | |
| void nouveau_svm_suspend(struct nouveau_drm *);
 | |
| void nouveau_svm_resume(struct nouveau_drm *);
 | |
| 
 | |
| int nouveau_svmm_init(struct drm_device *, void *, struct drm_file *);
 | |
| void nouveau_svmm_fini(struct nouveau_svmm **);
 | |
| int nouveau_svmm_join(struct nouveau_svmm *, u64 inst);
 | |
| void nouveau_svmm_part(struct nouveau_svmm *, u64 inst);
 | |
| int nouveau_svmm_bind(struct drm_device *, void *, struct drm_file *);
 | |
| 
 | |
| void nouveau_svmm_invalidate(struct nouveau_svmm *svmm, u64 start, u64 limit);
 | |
| u64 *nouveau_pfns_alloc(unsigned long npages);
 | |
| void nouveau_pfns_free(u64 *pfns);
 | |
| void nouveau_pfns_map(struct nouveau_svmm *svmm, struct mm_struct *mm,
 | |
| 		      unsigned long addr, u64 *pfns, unsigned long npages);
 | |
| #else /* IS_ENABLED(CONFIG_DRM_NOUVEAU_SVM) */
 | |
| static inline void nouveau_svm_init(struct nouveau_drm *drm) {}
 | |
| static inline void nouveau_svm_fini(struct nouveau_drm *drm) {}
 | |
| static inline void nouveau_svm_suspend(struct nouveau_drm *drm) {}
 | |
| static inline void nouveau_svm_resume(struct nouveau_drm *drm) {}
 | |
| 
 | |
| static inline int nouveau_svmm_init(struct drm_device *device, void *p,
 | |
| 				    struct drm_file *file)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| static inline void nouveau_svmm_fini(struct nouveau_svmm **svmmp) {}
 | |
| 
 | |
| static inline int nouveau_svmm_join(struct nouveau_svmm *svmm, u64 inst)
 | |
| {
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static inline void nouveau_svmm_part(struct nouveau_svmm *svmm, u64 inst) {}
 | |
| 
 | |
| static inline int nouveau_svmm_bind(struct drm_device *device, void *p,
 | |
| 				    struct drm_file *file)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| #endif /* IS_ENABLED(CONFIG_DRM_NOUVEAU_SVM) */
 | |
| #endif
 |