Commit 8e68271d authored by Ben Skeggs's avatar Ben Skeggs

drm/nouveau/mmu: store mapped flag separately from memory pointer

This will be used to support a privileged client providing PTEs directly,
without a memory object to use as a reference.
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent 2606f291
...@@ -17,6 +17,7 @@ struct nvkm_vma { ...@@ -17,6 +17,7 @@ struct nvkm_vma {
bool part:1; /* Region was split from an allocated region by map(). */ bool part:1; /* Region was split from an allocated region by map(). */
bool user:1; /* Region user-allocated. */ bool user:1; /* Region user-allocated. */
bool busy:1; /* Region busy (for temporarily preventing user access). */ bool busy:1; /* Region busy (for temporarily preventing user access). */
bool mapped:1; /* Region contains valid pages. */
struct nvkm_memory *memory; /* Memory currently mapped into VMA. */ struct nvkm_memory *memory; /* Memory currently mapped into VMA. */
struct nvkm_tags *tags; /* Compression tag reference. */ struct nvkm_tags *tags; /* Compression tag reference. */
}; };
......
...@@ -763,6 +763,7 @@ nvkm_vma_tail(struct nvkm_vma *vma, u64 tail) ...@@ -763,6 +763,7 @@ nvkm_vma_tail(struct nvkm_vma *vma, u64 tail)
new->part = vma->part; new->part = vma->part;
new->user = vma->user; new->user = vma->user;
new->busy = vma->busy; new->busy = vma->busy;
new->mapped = vma->mapped;
list_add(&new->head, &vma->head); list_add(&new->head, &vma->head);
return new; return new;
} }
...@@ -1112,10 +1113,11 @@ nvkm_vmm_unmap_region(struct nvkm_vmm *vmm, struct nvkm_vma *vma) ...@@ -1112,10 +1113,11 @@ nvkm_vmm_unmap_region(struct nvkm_vmm *vmm, struct nvkm_vma *vma)
nvkm_memory_tags_put(vma->memory, vmm->mmu->subdev.device, &vma->tags); nvkm_memory_tags_put(vma->memory, vmm->mmu->subdev.device, &vma->tags);
nvkm_memory_unref(&vma->memory); nvkm_memory_unref(&vma->memory);
vma->mapped = false;
if (!vma->part || ((prev = node(vma, prev)), prev->memory)) if (!vma->part || ((prev = node(vma, prev)), prev->mapped))
prev = NULL; prev = NULL;
if (!next->part || next->memory) if (!next->part || next->mapped)
next = NULL; next = NULL;
nvkm_vmm_node_merge(vmm, prev, vma, next, vma->size); nvkm_vmm_node_merge(vmm, prev, vma, next, vma->size);
} }
...@@ -1274,6 +1276,7 @@ nvkm_vmm_map_locked(struct nvkm_vmm *vmm, struct nvkm_vma *vma, ...@@ -1274,6 +1276,7 @@ nvkm_vmm_map_locked(struct nvkm_vmm *vmm, struct nvkm_vma *vma,
nvkm_memory_tags_put(vma->memory, vmm->mmu->subdev.device, &vma->tags); nvkm_memory_tags_put(vma->memory, vmm->mmu->subdev.device, &vma->tags);
nvkm_memory_unref(&vma->memory); nvkm_memory_unref(&vma->memory);
vma->memory = nvkm_memory_ref(map->memory); vma->memory = nvkm_memory_ref(map->memory);
vma->mapped = true;
vma->tags = map->tags; vma->tags = map->tags;
return 0; return 0;
} }
...@@ -1319,14 +1322,16 @@ nvkm_vmm_put_locked(struct nvkm_vmm *vmm, struct nvkm_vma *vma) ...@@ -1319,14 +1322,16 @@ nvkm_vmm_put_locked(struct nvkm_vmm *vmm, struct nvkm_vma *vma)
if (vma->mapref || !vma->sparse) { if (vma->mapref || !vma->sparse) {
do { do {
const bool map = next->memory != NULL; const bool mem = next->memory != NULL;
const bool map = next->mapped;
const u8 refd = next->refd; const u8 refd = next->refd;
const u64 addr = next->addr; const u64 addr = next->addr;
u64 size = next->size; u64 size = next->size;
/* Merge regions that are in the same state. */ /* Merge regions that are in the same state. */
while ((next = node(next, next)) && next->part && while ((next = node(next, next)) && next->part &&
(next->memory != NULL) == map && (next->mapped == map) &&
(next->memory != NULL) == mem &&
(next->refd == refd)) (next->refd == refd))
size += next->size; size += next->size;
...@@ -1351,7 +1356,7 @@ nvkm_vmm_put_locked(struct nvkm_vmm *vmm, struct nvkm_vma *vma) ...@@ -1351,7 +1356,7 @@ nvkm_vmm_put_locked(struct nvkm_vmm *vmm, struct nvkm_vma *vma)
*/ */
next = vma; next = vma;
do { do {
if (next->memory) if (next->mapped)
nvkm_vmm_unmap_region(vmm, next); nvkm_vmm_unmap_region(vmm, next);
} while ((next = node(vma, next)) && next->part); } while ((next = node(vma, next)) && next->part);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment