Commit 02950881 authored by Brian Paul's avatar Brian Paul
Browse files

initialize condition codes before running program

parent 3fdb8fbf
......@@ -494,6 +494,12 @@ init_machine_deriv( GLcontext *ctx,
}
}
}
/* init condition codes */
dMachine->CondCodes[0] = COND_EQ;
dMachine->CondCodes[1] = COND_EQ;
dMachine->CondCodes[2] = COND_EQ;
dMachine->CondCodes[3] = COND_EQ;
}
......@@ -659,9 +665,10 @@ execute_program( GLcontext *ctx,
if (test_cc(machine->CondCodes[swizzle[0]], condMask) ||
test_cc(machine->CondCodes[swizzle[1]], condMask) ||
test_cc(machine->CondCodes[swizzle[2]], condMask) ||
test_cc(machine->CondCodes[swizzle[3]], condMask))
test_cc(machine->CondCodes[swizzle[3]], condMask)) {
return GL_FALSE;
}
}
break;
case FP_OPCODE_LG2: /* log base 2 */
{
......@@ -1147,6 +1154,12 @@ init_machine( GLcontext *ctx, struct fp_machine *machine,
ASSERT(tex[0] != 0 || tex[1] != 0 || tex[2] != 0);
}
}
/* init condition codes */
machine->CondCodes[0] = COND_EQ;
machine->CondCodes[1] = COND_EQ;
machine->CondCodes[2] = COND_EQ;
machine->CondCodes[3] = COND_EQ;
}
......@@ -1162,8 +1175,9 @@ _swrast_exec_nv_fragment_program( GLcontext *ctx, struct sw_span *span )
ctx->FragmentProgram.Current, span, i);
if (!execute_program(ctx, program, ~0,
&ctx->FragmentProgram.Machine, span, i))
&ctx->FragmentProgram.Machine, span, i)) {
span->array->mask[i] = GL_FALSE; /* killed fragment */
}
/* Store output registers */
{
......@@ -1175,7 +1189,7 @@ _swrast_exec_nv_fragment_program( GLcontext *ctx, struct sw_span *span )
UNCLAMPED_FLOAT_TO_CHAN(span->array->rgba[i][ACOMP], colOut[3]);
}
/* depth value */
if (ctx->FragmentProgram.Current->OutputsWritten & 2)
if (program->OutputsWritten & (1 << FRAG_OUTPUT_DEPR))
span->array->z[i] = IROUND(ctx->FragmentProgram.Machine.Registers[FP_OUTPUT_REG_START + 2][0] * ctx->DepthMaxF);
}
}
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment