llvmpipe: make the front-face behavior match the gallium spec
authorZack Rusin <zackr@vmware.com>
Fri, 2 Aug 2013 19:50:16 +0000 (15:50 -0400)
committerZack Rusin <zackr@vmware.com>
Fri, 2 Aug 2013 19:50:16 +0000 (15:50 -0400)
The spec says that front-face is true if the value is >0 and false
if it's <0. To make sure that we follow the spec, lets just
subtract 0.5 from our value (llvmpipe did 1 for frontface and 0
otherwise), which will get us a positive num for frontface and
negative for backface.

Signed-off-by: Zack Rusin <zackr@vmware.com>
Reviewed-by: Roland Scheidegger <sroland@vmware.com>
Reviewed-by: Jose Fonseca <jfonseca@vmware.com>
src/gallium/drivers/llvmpipe/lp_state_setup.c

index bb5cfc4be469ec020e00ec48d728b688b6a91e47..cecfbcebe6174ea4646bdb5a9e3d9943a8e6361c 100644 (file)
@@ -182,7 +182,10 @@ emit_facing_coef(struct gallivm_state *gallivm,
    LLVMValueRef a0_0 = args->facing;
    LLVMValueRef a0_0f = LLVMBuildSIToFP(builder, a0_0, float_type, "");
    LLVMValueRef zero = lp_build_const_float(gallivm, 0.0);
-   LLVMValueRef a0 = vec4f(gallivm, a0_0f, zero, zero, zero, "facing");
+   LLVMValueRef face_val = LLVMBuildFSub(builder, a0_0f,
+                                         lp_build_const_float(gallivm, 0.5),
+                                         "");
+   LLVMValueRef a0 = vec4f(gallivm, face_val, zero, zero, zero, "facing");
    LLVMValueRef zerovec = vec4f_from_scalar(gallivm, zero, "zero");
 
    store_coef(gallivm, args, slot, a0, zerovec, zerovec);