drm/nv50: assume smaller tiles for bo moves
authorBen Skeggs <bskeggs@redhat.com>
Thu, 23 Sep 2010 05:21:17 +0000 (15:21 +1000)
committerBen Skeggs <bskeggs@redhat.com>
Fri, 24 Sep 2010 06:28:39 +0000 (16:28 +1000)
Somehow fixes some corruption seen in KDE..

Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/nouveau_bo.c

index 2b97d97f14936a3c3e4a29ec1eac6227ba3dc062..c900aaa5cffa79b9ed0e388971a8e69f97ea7dc3 100644 (file)
@@ -529,8 +529,8 @@ nv50_bo_move_m2mf(struct nouveau_channel *chan, struct ttm_buffer_object *bo,
        while (length) {
                u32 amount, stride, height;
 
-               amount  = min(length, (u64)(16 * 1024 * 1024));
-               stride  = 64 * 4;
+               amount  = min(length, (u64)(4 * 1024 * 1024));
+               stride  = 16 * 4;
                height  = amount / stride;
 
                if (new_mem->mem_type == TTM_PL_VRAM && nvbo->tile_flags) {
@@ -540,7 +540,7 @@ nv50_bo_move_m2mf(struct nouveau_channel *chan, struct ttm_buffer_object *bo,
 
                        BEGIN_RING(chan, NvSubM2MF, 0x0200, 7);
                        OUT_RING  (chan, 0);
-                       OUT_RING  (chan, 0x20);
+                       OUT_RING  (chan, 0);
                        OUT_RING  (chan, stride);
                        OUT_RING  (chan, height);
                        OUT_RING  (chan, 1);
@@ -561,7 +561,7 @@ nv50_bo_move_m2mf(struct nouveau_channel *chan, struct ttm_buffer_object *bo,
 
                        BEGIN_RING(chan, NvSubM2MF, 0x021c, 7);
                        OUT_RING  (chan, 0);
-                       OUT_RING  (chan, 0x20);
+                       OUT_RING  (chan, 0);
                        OUT_RING  (chan, stride);
                        OUT_RING  (chan, height);
                        OUT_RING  (chan, 1);