diff options
author | Michel Daenzer <michel@tungstengraphics.com> | 2006-09-21 14:26:35 -0400 |
---|---|---|
committer | Dave Airlie <airlied@linux.ie> | 2006-09-21 15:32:34 -0400 |
commit | 3e14a2867d8ccf555fe6e318eac0f8200399fe1c (patch) | |
tree | a33f49fd5c107c0dc9101217e48602cea3376b32 /drivers/char/drm/radeon_state.c | |
parent | 54a56ac583ac66f3f4bc2c4cc3ef9b0676770742 (diff) |
drm: Use register writes instead of BITBLT_MULTI packets for buffer swap blits
This takes up two more ring buffer entries per rectangle blitted but makes sure
the blit is performed top to bottom, reducing the likelyhood of tearing.
Signed-off-by: Dave Airlie <airlied@linux.ie>
Diffstat (limited to 'drivers/char/drm/radeon_state.c')
-rw-r--r-- | drivers/char/drm/radeon_state.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/char/drm/radeon_state.c b/drivers/char/drm/radeon_state.c index bb4b2e1a78c1..feac5f005d47 100644 --- a/drivers/char/drm/radeon_state.c +++ b/drivers/char/drm/radeon_state.c | |||
@@ -1269,9 +1269,9 @@ static void radeon_cp_dispatch_swap(drm_device_t * dev) | |||
1269 | 1269 | ||
1270 | DRM_DEBUG("dispatch swap %d,%d-%d,%d\n", x, y, w, h); | 1270 | DRM_DEBUG("dispatch swap %d,%d-%d,%d\n", x, y, w, h); |
1271 | 1271 | ||
1272 | BEGIN_RING(7); | 1272 | BEGIN_RING(9); |
1273 | 1273 | ||
1274 | OUT_RING(CP_PACKET3(RADEON_CNTL_BITBLT_MULTI, 5)); | 1274 | OUT_RING(CP_PACKET0(RADEON_DP_GUI_MASTER_CNTL, 0)); |
1275 | OUT_RING(RADEON_GMC_SRC_PITCH_OFFSET_CNTL | | 1275 | OUT_RING(RADEON_GMC_SRC_PITCH_OFFSET_CNTL | |
1276 | RADEON_GMC_DST_PITCH_OFFSET_CNTL | | 1276 | RADEON_GMC_DST_PITCH_OFFSET_CNTL | |
1277 | RADEON_GMC_BRUSH_NONE | | 1277 | RADEON_GMC_BRUSH_NONE | |
@@ -1283,6 +1283,7 @@ static void radeon_cp_dispatch_swap(drm_device_t * dev) | |||
1283 | 1283 | ||
1284 | /* Make this work even if front & back are flipped: | 1284 | /* Make this work even if front & back are flipped: |
1285 | */ | 1285 | */ |
1286 | OUT_RING(CP_PACKET0(RADEON_SRC_PITCH_OFFSET, 1)); | ||
1286 | if (dev_priv->current_page == 0) { | 1287 | if (dev_priv->current_page == 0) { |
1287 | OUT_RING(dev_priv->back_pitch_offset); | 1288 | OUT_RING(dev_priv->back_pitch_offset); |
1288 | OUT_RING(dev_priv->front_pitch_offset); | 1289 | OUT_RING(dev_priv->front_pitch_offset); |
@@ -1291,6 +1292,7 @@ static void radeon_cp_dispatch_swap(drm_device_t * dev) | |||
1291 | OUT_RING(dev_priv->back_pitch_offset); | 1292 | OUT_RING(dev_priv->back_pitch_offset); |
1292 | } | 1293 | } |
1293 | 1294 | ||
1295 | OUT_RING(CP_PACKET0(RADEON_SRC_X_Y, 2)); | ||
1294 | OUT_RING((x << 16) | y); | 1296 | OUT_RING((x << 16) | y); |
1295 | OUT_RING((x << 16) | y); | 1297 | OUT_RING((x << 16) | y); |
1296 | OUT_RING((w << 16) | h); | 1298 | OUT_RING((w << 16) | h); |