radeon: fix scissor calcs.
authorDave Airlie <airlied@redhat.com>
Thu, 27 Aug 2009 05:36:35 +0000 (15:36 +1000)
committerDave Airlie <airlied@itt42.(none)>
Thu, 27 Aug 2009 05:38:00 +0000 (15:38 +1000)
For non-FBOs we need to invert, for FBOs the scissors are non-inverted.

no matter what we need to clamp them to the buffer sizes.

src/mesa/drivers/dri/radeon/radeon_common.c

index 0894372fad1e6c4b672b06a34182dfecea62b5c1..bed75f3d733255775fcc78e14344eef3090fac03 100644 (file)
@@ -231,26 +231,31 @@ void radeonSetCliprects(radeonContextPtr radeon)
 void radeonUpdateScissor( GLcontext *ctx )
 {
        radeonContextPtr rmesa = RADEON_CONTEXT(ctx);
+       GLint x = ctx->Scissor.X, y = ctx->Scissor.Y;
+       GLsizei w = ctx->Scissor.Width, h = ctx->Scissor.Height;
+       int x1, y1, x2, y2;
 
-       if ( !ctx->DrawBuffer->Name ) {
-               __DRIdrawablePrivate *dPriv = radeon_get_drawable(rmesa);
-
-               int x = ctx->Scissor.X;
-               int y = dPriv->h - ctx->Scissor.Y - ctx->Scissor.Height;
-               int w = ctx->Scissor.X + ctx->Scissor.Width - 1;
-               int h = dPriv->h - ctx->Scissor.Y - 1;
+       if (!ctx->DrawBuffer)
+           return;
 
-               rmesa->state.scissor.rect.x1 = x + dPriv->x;
-               rmesa->state.scissor.rect.y1 = y + dPriv->y;
-               rmesa->state.scissor.rect.x2 = w + dPriv->x + 1;
-               rmesa->state.scissor.rect.y2 = h + dPriv->y + 1;
+       if ( !ctx->DrawBuffer->Name ) {
+               x1 = x;
+               y1 = ctx->DrawBuffer->Height - (y + h);
+               x2 = x + w - 1;
+               y2 = y1 + h - 1;
        } else {
-               rmesa->state.scissor.rect.x1 = ctx->Scissor.X;
-               rmesa->state.scissor.rect.y1 = ctx->Scissor.Y;
-               rmesa->state.scissor.rect.x2 = ctx->Scissor.X + ctx->Scissor.Width;
-               rmesa->state.scissor.rect.y2 = ctx->Scissor.Y + ctx->Scissor.Height;
+               x1 = x;
+               y1 = y;
+               x2 = x + w - 1;
+               y2 = y + h - 1;
+
        }
 
+       rmesa->state.scissor.rect.x1 = CLAMP(x1,  0, ctx->DrawBuffer->Width - 1);
+       rmesa->state.scissor.rect.y1 = CLAMP(y1,  0, ctx->DrawBuffer->Height - 1);
+       rmesa->state.scissor.rect.x2 = CLAMP(x2,  0, ctx->DrawBuffer->Width - 1);
+       rmesa->state.scissor.rect.y2 = CLAMP(y2,  0, ctx->DrawBuffer->Height - 1);
+
        radeonRecalcScissorRects( rmesa );
 }