Lines Matching full:mmu

22 #include <nvif/mmu.h>
28 nvif_mmu_dtor(struct nvif_mmu *mmu) in nvif_mmu_dtor() argument
30 if (!nvif_object_constructed(&mmu->object)) in nvif_mmu_dtor()
33 kfree(mmu->kind); in nvif_mmu_dtor()
34 kfree(mmu->type); in nvif_mmu_dtor()
35 kfree(mmu->heap); in nvif_mmu_dtor()
36 nvif_object_dtor(&mmu->object); in nvif_mmu_dtor()
41 struct nvif_mmu *mmu) in nvif_mmu_ctor() argument
53 mmu->heap = NULL; in nvif_mmu_ctor()
54 mmu->type = NULL; in nvif_mmu_ctor()
55 mmu->kind = NULL; in nvif_mmu_ctor()
58 &args, sizeof(args), &mmu->object); in nvif_mmu_ctor()
62 mmu->dmabits = args.dmabits; in nvif_mmu_ctor()
63 mmu->heap_nr = args.heap_nr; in nvif_mmu_ctor()
64 mmu->type_nr = args.type_nr; in nvif_mmu_ctor()
65 mmu->kind_nr = args.kind_nr; in nvif_mmu_ctor()
67 ret = nvif_mclass(&mmu->object, mems); in nvif_mmu_ctor()
70 mmu->mem = mems[ret].oclass; in nvif_mmu_ctor()
72 mmu->heap = kmalloc_array(mmu->heap_nr, sizeof(*mmu->heap), in nvif_mmu_ctor()
74 mmu->type = kmalloc_array(mmu->type_nr, sizeof(*mmu->type), in nvif_mmu_ctor()
76 if (ret = -ENOMEM, !mmu->heap || !mmu->type) in nvif_mmu_ctor()
79 mmu->kind = kmalloc_array(mmu->kind_nr, sizeof(*mmu->kind), in nvif_mmu_ctor()
81 if (!mmu->kind && mmu->kind_nr) in nvif_mmu_ctor()
84 for (i = 0; i < mmu->heap_nr; i++) { in nvif_mmu_ctor()
87 ret = nvif_object_mthd(&mmu->object, NVIF_MMU_V0_HEAP, in nvif_mmu_ctor()
92 mmu->heap[i].size = args.size; in nvif_mmu_ctor()
95 for (i = 0; i < mmu->type_nr; i++) { in nvif_mmu_ctor()
98 ret = nvif_object_mthd(&mmu->object, NVIF_MMU_V0_TYPE, in nvif_mmu_ctor()
103 mmu->type[i].type = 0; in nvif_mmu_ctor()
104 if (args.vram) mmu->type[i].type |= NVIF_MEM_VRAM; in nvif_mmu_ctor()
105 if (args.host) mmu->type[i].type |= NVIF_MEM_HOST; in nvif_mmu_ctor()
106 if (args.comp) mmu->type[i].type |= NVIF_MEM_COMP; in nvif_mmu_ctor()
107 if (args.disp) mmu->type[i].type |= NVIF_MEM_DISP; in nvif_mmu_ctor()
108 if (args.kind ) mmu->type[i].type |= NVIF_MEM_KIND; in nvif_mmu_ctor()
109 if (args.mappable) mmu->type[i].type |= NVIF_MEM_MAPPABLE; in nvif_mmu_ctor()
110 if (args.coherent) mmu->type[i].type |= NVIF_MEM_COHERENT; in nvif_mmu_ctor()
111 if (args.uncached) mmu->type[i].type |= NVIF_MEM_UNCACHED; in nvif_mmu_ctor()
112 mmu->type[i].heap = args.heap; in nvif_mmu_ctor()
115 if (mmu->kind_nr) { in nvif_mmu_ctor()
117 size_t argc = struct_size(kind, data, mmu->kind_nr); in nvif_mmu_ctor()
122 kind->count = mmu->kind_nr; in nvif_mmu_ctor()
124 ret = nvif_object_mthd(&mmu->object, NVIF_MMU_V0_KIND, in nvif_mmu_ctor()
127 memcpy(mmu->kind, kind->data, kind->count); in nvif_mmu_ctor()
128 mmu->kind_inv = kind->kind_inv; in nvif_mmu_ctor()
134 nvif_mmu_dtor(mmu); in nvif_mmu_ctor()