i965/fs: Switch W and 1/W in Sandybridge interpolation setup.
authorKenneth Graunke <kenneth@whitecape.org>
Sun, 3 Apr 2011 08:39:28 +0000 (01:39 -0700)
committerKenneth Graunke <kenneth@whitecape.org>
Sun, 3 Apr 2011 01:58:16 +0000 (18:58 -0700)
Various documentation mentions that "W" is handed to the WM stage,
but further digging seems to indicate that they really mean 1/W.

The code here is still unclear, but changing this fixes piglit
test "fragcoord_w" on Sandybridge as well as a Khronos ES2 conformance
test.  I also tested 3DMarkMobile ES2.0's taiji and hoverjet demos, as
well as Nexuiz, just to be safe.

NOTE: This is a candidate for the 7.10 branch.

src/mesa/drivers/dri/i965/brw_fs.cpp

index bea6b18..cada140 100644 (file)
@@ -1989,10 +1989,10 @@ fs_visitor::emit_interpolation_setup_gen6()
    emit(BRW_OPCODE_MOV, this->pixel_x, int_pixel_x);
    emit(BRW_OPCODE_MOV, this->pixel_y, int_pixel_y);
 
-   this->current_annotation = "compute 1/pos.w";
-   this->wpos_w = fs_reg(brw_vec8_grf(c->source_w_reg, 0));
-   this->pixel_w = fs_reg(this, glsl_type::float_type);
-   emit_math(FS_OPCODE_RCP, this->pixel_w, wpos_w);
+   this->current_annotation = "compute pos.w";
+   this->pixel_w = fs_reg(brw_vec8_grf(c->source_w_reg, 0));
+   this->wpos_w = fs_reg(this, glsl_type::float_type);
+   emit_math(FS_OPCODE_RCP, this->wpos_w, this->pixel_w);
 
    this->delta_x = fs_reg(brw_vec8_grf(2, 0));
    this->delta_y = fs_reg(brw_vec8_grf(3, 0));