Commit f584bde6 authored by Ben Skeggs's avatar Ben Skeggs

drm/nouveau/imem/nv50: split object map out from api functions

acquire()/boot() will need different logic in addition to performing
the actual mapping.
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent b807270c
...@@ -89,6 +89,34 @@ nv50_instobj_slow = { ...@@ -89,6 +89,34 @@ nv50_instobj_slow = {
.wr32 = nv50_instobj_wr32_slow, .wr32 = nv50_instobj_wr32_slow,
}; };
static void
nv50_instobj_kmap(struct nv50_instobj *iobj, struct nvkm_vmm *vmm)
{
struct nvkm_memory *memory = &iobj->memory;
struct nvkm_subdev *subdev = &iobj->imem->base.subdev;
struct nvkm_device *device = subdev->device;
u64 size = nvkm_memory_size(memory);
void __iomem *map;
int ret;
iobj->map = ERR_PTR(-ENOMEM);
ret = nvkm_vm_get(vmm, size, 12, NV_MEM_ACCESS_RW, &iobj->bar);
if (ret == 0) {
map = ioremap(device->func->resource_addr(device, 3) +
(u32)iobj->bar.offset, size);
if (map) {
nvkm_memory_map(memory, &iobj->bar, 0);
iobj->map = map;
} else {
nvkm_warn(subdev, "PRAMIN ioremap failed\n");
nvkm_vm_put(&iobj->bar);
}
} else {
nvkm_warn(subdev, "PRAMIN exhausted\n");
}
}
static void static void
nv50_instobj_map(struct nvkm_memory *memory, struct nvkm_vma *vma, u64 offset) nv50_instobj_map(struct nvkm_memory *memory, struct nvkm_vma *vma, u64 offset)
{ {
...@@ -112,7 +140,7 @@ nv50_instobj_acquire(struct nvkm_memory *memory) ...@@ -112,7 +140,7 @@ nv50_instobj_acquire(struct nvkm_memory *memory)
unsigned long flags; unsigned long flags;
if (!iobj->map && (vm = nvkm_bar_bar2_vmm(imem->base.subdev.device))) if (!iobj->map && (vm = nvkm_bar_bar2_vmm(imem->base.subdev.device)))
nvkm_memory_boot(memory, vm); nv50_instobj_kmap(iobj, vm);
if (!IS_ERR_OR_NULL(iobj->map)) if (!IS_ERR_OR_NULL(iobj->map))
return iobj->map; return iobj->map;
...@@ -122,31 +150,10 @@ nv50_instobj_acquire(struct nvkm_memory *memory) ...@@ -122,31 +150,10 @@ nv50_instobj_acquire(struct nvkm_memory *memory)
} }
static void static void
nv50_instobj_boot(struct nvkm_memory *memory, struct nvkm_vm *vm) nv50_instobj_boot(struct nvkm_memory *memory, struct nvkm_vmm *vmm)
{ {
struct nv50_instobj *iobj = nv50_instobj(memory); struct nv50_instobj *iobj = nv50_instobj(memory);
struct nvkm_subdev *subdev = &iobj->imem->base.subdev; nv50_instobj_kmap(iobj, vmm);
struct nvkm_device *device = subdev->device;
u64 size = nvkm_memory_size(memory);
void __iomem *map;
int ret;
iobj->map = ERR_PTR(-ENOMEM);
ret = nvkm_vm_get(vm, size, 12, NV_MEM_ACCESS_RW, &iobj->bar);
if (ret == 0) {
map = ioremap(device->func->resource_addr(device, 3) +
(u32)iobj->bar.offset, size);
if (map) {
nvkm_memory_map(memory, &iobj->bar, 0);
iobj->map = map;
} else {
nvkm_warn(subdev, "PRAMIN ioremap failed\n");
nvkm_vm_put(&iobj->bar);
}
} else {
nvkm_warn(subdev, "PRAMIN exhausted\n");
}
} }
static u64 static u64
...@@ -173,8 +180,8 @@ nv50_instobj_dtor(struct nvkm_memory *memory) ...@@ -173,8 +180,8 @@ nv50_instobj_dtor(struct nvkm_memory *memory)
struct nv50_instobj *iobj = nv50_instobj(memory); struct nv50_instobj *iobj = nv50_instobj(memory);
struct nvkm_ram *ram = iobj->imem->base.subdev.device->fb->ram; struct nvkm_ram *ram = iobj->imem->base.subdev.device->fb->ram;
if (!IS_ERR_OR_NULL(iobj->map)) { if (!IS_ERR_OR_NULL(iobj->map)) {
nvkm_vm_put(&iobj->bar);
iounmap(iobj->map); iounmap(iobj->map);
nvkm_vm_put(&iobj->bar);
} }
ram->func->put(ram, &iobj->mem); ram->func->put(ram, &iobj->mem);
return iobj; return iobj;
......
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