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