drm/nouveau/fifo/gf100: take runlist target into account
authorAlexandre Courbot <acourbot@nvidia.com>
Tue, 1 Mar 2016 07:51:57 +0000 (16:51 +0900)
committerBen Skeggs <bskeggs@redhat.com>
Mon, 14 Mar 2016 00:13:30 +0000 (10:13 +1000)
Bits 28:29 of RUNLIST_BASE specify the memory target of the runlist. Set
it to 0x3 (SYS_MEM_NONCOHERENT) if the runlist object resides in system
memory.

Signed-off-by: Alexandre Courbot <acourbot@nvidia.com>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c

index 36a39c7fd8d23e2eaa21bb9e7fc7da8157ba46c0..3cac5ebd0a4b80ef9628d54065ff82456eb6337d 100644 (file)
@@ -54,6 +54,7 @@ gf100_fifo_runlist_commit(struct gf100_fifo *fifo)
        struct nvkm_device *device = subdev->device;
        struct nvkm_memory *cur;
        int nr = 0;
+       int target;
 
        mutex_lock(&subdev->mutex);
        cur = fifo->runlist.mem[fifo->runlist.active];
@@ -67,7 +68,10 @@ gf100_fifo_runlist_commit(struct gf100_fifo *fifo)
        }
        nvkm_done(cur);
 
-       nvkm_wr32(device, 0x002270, nvkm_memory_addr(cur) >> 12);
+       target = (nvkm_memory_target(cur) == NVKM_MEM_TARGET_HOST) ? 0x3 : 0x0;
+
+       nvkm_wr32(device, 0x002270, (nvkm_memory_addr(cur) >> 12) |
+                                   (target << 28));
        nvkm_wr32(device, 0x002274, 0x01f00000 | nr);
 
        if (wait_event_timeout(fifo->runlist.wait,