1 #ifndef __NOUVEAU_SVM_H__
2 #define __NOUVEAU_SVM_H__
3 #include <nvif/os.h>
4 #include <linux/mmu_notifier.h>
5 struct drm_device;
6 struct drm_file;
7 struct nouveau_drm;
8
9 struct nouveau_svmm {
10 struct mmu_notifier notifier;
11 struct nouveau_vmm *vmm;
12 struct {
13 unsigned long start;
14 unsigned long limit;
15 } unmanaged;
16
17 struct mutex mutex;
18 };
19
20 #if IS_ENABLED(CONFIG_DRM_NOUVEAU_SVM)
21 void nouveau_svm_init(struct nouveau_drm *);
22 void nouveau_svm_fini(struct nouveau_drm *);
23 void nouveau_svm_suspend(struct nouveau_drm *);
24 void nouveau_svm_resume(struct nouveau_drm *);
25
26 int nouveau_svmm_init(struct drm_device *, void *, struct drm_file *);
27 void nouveau_svmm_fini(struct nouveau_svmm **);
28 int nouveau_svmm_join(struct nouveau_svmm *, u64 inst);
29 void nouveau_svmm_part(struct nouveau_svmm *, u64 inst);
30 int nouveau_svmm_bind(struct drm_device *, void *, struct drm_file *);
31
32 void nouveau_svmm_invalidate(struct nouveau_svmm *svmm, u64 start, u64 limit);
33 u64 *nouveau_pfns_alloc(unsigned long npages);
34 void nouveau_pfns_free(u64 *pfns);
35 void nouveau_pfns_map(struct nouveau_svmm *svmm, struct mm_struct *mm,
36 unsigned long addr, u64 *pfns, unsigned long npages);
37 #else /* IS_ENABLED(CONFIG_DRM_NOUVEAU_SVM) */
nouveau_svm_init(struct nouveau_drm * drm)38 static inline void nouveau_svm_init(struct nouveau_drm *drm) {}
nouveau_svm_fini(struct nouveau_drm * drm)39 static inline void nouveau_svm_fini(struct nouveau_drm *drm) {}
nouveau_svm_suspend(struct nouveau_drm * drm)40 static inline void nouveau_svm_suspend(struct nouveau_drm *drm) {}
nouveau_svm_resume(struct nouveau_drm * drm)41 static inline void nouveau_svm_resume(struct nouveau_drm *drm) {}
42
nouveau_svmm_init(struct drm_device * device,void * p,struct drm_file * file)43 static inline int nouveau_svmm_init(struct drm_device *device, void *p,
44 struct drm_file *file)
45 {
46 return -ENOSYS;
47 }
48
nouveau_svmm_fini(struct nouveau_svmm ** svmmp)49 static inline void nouveau_svmm_fini(struct nouveau_svmm **svmmp) {}
50
nouveau_svmm_join(struct nouveau_svmm * svmm,u64 inst)51 static inline int nouveau_svmm_join(struct nouveau_svmm *svmm, u64 inst)
52 {
53 return 0;
54 }
55
nouveau_svmm_part(struct nouveau_svmm * svmm,u64 inst)56 static inline void nouveau_svmm_part(struct nouveau_svmm *svmm, u64 inst) {}
57
nouveau_svmm_bind(struct drm_device * device,void * p,struct drm_file * file)58 static inline int nouveau_svmm_bind(struct drm_device *device, void *p,
59 struct drm_file *file)
60 {
61 return -ENOSYS;
62 }
63 #endif /* IS_ENABLED(CONFIG_DRM_NOUVEAU_SVM) */
64 #endif
65