nv20: Z-mapping parameters
authorPekka Paalanen <pq@iki.fi>
Sat, 31 Jan 2009 12:39:08 +0000 (14:39 +0200)
committerPekka Paalanen <pq@iki.fi>
Sat, 31 Jan 2009 21:41:23 +0000 (23:41 +0200)
Based on my renouveau dump, adjust initial hw state related to Z-mapping,
and add one unknown depth reg into depth/stencil/alpha emission.

Now trivial/tri-z on nv20 looks identical to swrast rendered one.

Signed-off-by: Pekka Paalanen <pq@iki.fi>
src/gallium/drivers/nv20/nv20_context.c
src/gallium/drivers/nv20/nv20_state_emit.c

index c8fb690ee9cabea41b17a6a6569fbd3c461783f0..877ef5dcefd7269498e8f9fb96167ecdeaf13cd4 100644 (file)
@@ -349,7 +349,7 @@ static void nv20_init_hwctx(struct nv20_context *nv20)
        memset(projectionmatrix, 0, sizeof(projectionmatrix));
        projectionmatrix[0*4+0] = 1.0;
        projectionmatrix[1*4+1] = 1.0;
-       projectionmatrix[2*4+2] = 1.0;
+       projectionmatrix[2*4+2] = 16777215.0;
        projectionmatrix[3*4+3] = 1.0;
        BEGIN_RING(kelvin, NV20TCL_PROJECTION_MATRIX(0), 16);
        for (i = 0; i < 16; i++) {
@@ -357,20 +357,20 @@ static void nv20_init_hwctx(struct nv20_context *nv20)
        }
 
        BEGIN_RING(kelvin, NV20TCL_DEPTH_RANGE_NEAR, 2);
-       OUT_RINGf  (0.0);
-       OUT_RINGf  (16777216.0); /* bpp dependant? */
+       OUT_RINGf (0.0);
+       OUT_RINGf (16777216.0); /* [0, 1] scaled approx to [0, 2^24] */
 
        BEGIN_RING(kelvin, NV20TCL_VIEWPORT_SCALE0_X, 4);
-       OUT_RINGf  (0.0); /* x-offset */
-       OUT_RINGf  (0.0); /* y-offset */
-       OUT_RINGf  (16777215.0 * 0.5);
-       OUT_RING  (0);
+       OUT_RINGf (0.0); /* x-offset, w/2 + 1.031250 */
+       OUT_RINGf (0.0); /* y-offset, h/2 + 0.030762 */
+       OUT_RINGf (0.0);
+       OUT_RINGf (16777215.0);
 
        BEGIN_RING(kelvin, NV20TCL_VIEWPORT_SCALE1_X, 4);
-       OUT_RINGf  (0.0); /* no effect? */
-       OUT_RINGf  (0.0); /* no effect? */
-       OUT_RINGf  (16777215.0 * 0.5);
-       OUT_RINGf  (65535.0);
+       OUT_RINGf (0.0); /* no effect?, w/2 */
+       OUT_RINGf (0.0); /* no effect?, h/2 */
+       OUT_RINGf (16777215.0 * 0.5);
+       OUT_RINGf (65535.0);
 
        FIRE_RING (NULL);
 }
index cbdc674b09dd7972884c20e44b24e96b9eedd72e..5d5f4cdc082bb011b1fb6bddf5de46dfba380fe8 100644 (file)
@@ -73,6 +73,9 @@ static void nv20_state_emit_dsa(struct nv20_context* nv20)
        BEGIN_RING(kelvin, NV20TCL_DEPTH_TEST_ENABLE, 1);
        OUT_RING (d->depth.test_enable);
 
+       BEGIN_RING(kelvin, NV20TCL_DEPTH_UNK17D8, 1);
+       OUT_RING (1);
+
 #if 0
        BEGIN_RING(kelvin, NV20TCL_STENCIL_ENABLE, 1);
        OUT_RING (d->stencil.enable);