]>
git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blob - drivers/gpu/drm/nouveau/nvkm/subdev/mmu/priv.h
1 #ifndef __NVKM_MMU_PRIV_H__
2 #define __NVKM_MMU_PRIV_H__
3 #define nvkm_mmu(p) container_of((p), struct nvkm_mmu, subdev)
4 #include <subdev/mmu.h>
6 void nvkm_mmu_ctor(const struct nvkm_mmu_func
*, struct nvkm_device
*,
7 int index
, struct nvkm_mmu
*);
8 int nvkm_mmu_new_(const struct nvkm_mmu_func
*, struct nvkm_device
*,
9 int index
, struct nvkm_mmu
**);
11 struct nvkm_mmu_func
{
12 int (*oneinit
)(struct nvkm_mmu
*);
13 void (*init
)(struct nvkm_mmu
*);
21 void (*map_pgt
)(struct nvkm_vmm
*, u32 pde
,
22 struct nvkm_memory
*pgt
[2]);
23 void (*map
)(struct nvkm_vma
*, struct nvkm_memory
*,
24 struct nvkm_mem
*, u32 pte
, u32 cnt
,
26 void (*map_sg
)(struct nvkm_vma
*, struct nvkm_memory
*,
27 struct nvkm_mem
*, u32 pte
, u32 cnt
, dma_addr_t
*);
28 void (*unmap
)(struct nvkm_vma
*, struct nvkm_memory
*pgt
,
30 void (*flush
)(struct nvkm_vm
*);
33 struct nvkm_sclass user
;
34 int (*ctor
)(struct nvkm_mmu
*, u64 addr
, u64 size
,
35 void *argv
, u32 argc
, struct lock_class_key
*,
36 const char *name
, struct nvkm_vmm
**);
41 const u8
*(*kind
)(struct nvkm_mmu
*, int *count
);
44 extern const struct nvkm_mmu_func nv04_mmu
;
46 const u8
*nv50_mmu_kind(struct nvkm_mmu
*, int *count
);
48 void gf100_vm_map_pgt(struct nvkm_vmm
*, u32
, struct nvkm_memory
**);
49 void gf100_vm_map(struct nvkm_vma
*, struct nvkm_memory
*, struct nvkm_mem
*,
51 void gf100_vm_map_sg(struct nvkm_vma
*, struct nvkm_memory
*, struct nvkm_mem
*,
52 u32
, u32
, dma_addr_t
*);
53 void gf100_vm_unmap(struct nvkm_vma
*, struct nvkm_memory
*, u32
, u32
);
54 void gf100_vm_flush(struct nvkm_vm
*);
58 struct nvkm_mmu_ptc
*ptc
;
59 struct nvkm_mmu_ptp
*ptp
;
61 struct nvkm_memory
*memory
;
65 struct list_head head
;
68 void nvkm_mmu_ptc_dump(struct nvkm_mmu
*);
70 nvkm_mmu_ptc_get(struct nvkm_mmu
*, u32 size
, u32 align
, bool zero
);
71 void nvkm_mmu_ptc_put(struct nvkm_mmu
*, bool force
, struct nvkm_mmu_pt
**);