Merge pull request #457 from sabretooth/shader-relative-constant-fix

Shader relative constant fix
This commit is contained in:
Ben Vanik 2015-11-11 15:33:26 -08:00
commit bc34e00f22
2 changed files with 20 additions and 10 deletions

View File

@ -174,13 +174,13 @@ void GL4ShaderTranslator::AppendSrcReg(const ucode::instr_alu_t& op, int i) {
break; break;
} }
case 2: { case 2: {
int const_slot = op.src1_sel ? 1 : 0; int const_slot = op.src1_sel ? 0 : 1;
AppendSrcReg(op, op.src2_reg, op.src2_sel, op.src2_swiz, AppendSrcReg(op, op.src2_reg, op.src2_sel, op.src2_swiz,
op.src2_reg_negate, const_slot); op.src2_reg_negate, const_slot);
break; break;
} }
case 3: { case 3: {
int const_slot = (op.src1_sel || op.src2_sel) ? 1 : 0; int const_slot = (op.src1_sel && op.src2_sel) ? 0 : 1;
AppendSrcReg(op, op.src3_reg, op.src3_sel, op.src3_swiz, AppendSrcReg(op, op.src3_reg, op.src3_sel, op.src3_swiz,
op.src3_reg_negate, const_slot); op.src3_reg_negate, const_slot);
break; break;

View File

@ -76,7 +76,7 @@ static const char chan_names[] = {
}; };
void print_srcreg(StringBuffer* output, uint32_t num, uint32_t type, void print_srcreg(StringBuffer* output, uint32_t num, uint32_t type,
uint32_t swiz, uint32_t negate, uint32_t abs_constants, uint32_t swiz, uint32_t negate, uint32_t abs_constants, bool const_rel,
ShaderType shader_type) { ShaderType shader_type) {
if (negate) { if (negate) {
output->Append('-'); output->Append('-');
@ -94,7 +94,13 @@ void print_srcreg(StringBuffer* output, uint32_t num, uint32_t type,
output->Append('|'); output->Append('|');
} }
num += shader_type == ShaderType::kPixel ? 256 : 0; num += shader_type == ShaderType::kPixel ? 256 : 0;
output->AppendFormat("C%u", num);
if (const_rel) {
output->AppendFormat("C[%u + a0]", num);
} else {
output->AppendFormat("C%u", num);
}
if (abs_constants) { if (abs_constants) {
output->Append('|'); output->Append('|');
} }
@ -272,15 +278,19 @@ int disasm_alu(StringBuffer* output, const uint32_t* dwords, uint32_t alu_off,
output->Append(" = "); output->Append(" = ");
if (vector_instructions[alu->vector_opc].num_srcs == 3) { if (vector_instructions[alu->vector_opc].num_srcs == 3) {
print_srcreg(output, alu->src3_reg, alu->src3_sel, alu->src3_swiz, print_srcreg(output, alu->src3_reg, alu->src3_sel, alu->src3_swiz,
alu->src3_reg_negate, alu->abs_constants, type); alu->src3_reg_negate, alu->abs_constants, false, type);
output->Append(", "); output->Append(", ");
} }
bool const_rel = alu->const_0_rel_abs && alu->relative_addr;
print_srcreg(output, alu->src1_reg, alu->src1_sel, alu->src1_swiz, print_srcreg(output, alu->src1_reg, alu->src1_sel, alu->src1_swiz,
alu->src1_reg_negate, alu->abs_constants, type); alu->src1_reg_negate, alu->abs_constants, const_rel, type);
if (vector_instructions[alu->vector_opc].num_srcs > 1) { if (vector_instructions[alu->vector_opc].num_srcs > 1) {
if (alu->src1_sel == 0) {
const_rel = alu->const_1_rel_abs && alu->relative_addr;
}
output->Append(", "); output->Append(", ");
print_srcreg(output, alu->src2_reg, alu->src2_sel, alu->src2_swiz, print_srcreg(output, alu->src2_reg, alu->src2_sel, alu->src2_swiz,
alu->src2_reg_negate, alu->abs_constants, type); alu->src2_reg_negate, alu->abs_constants, const_rel, type);
} }
if (alu->vector_clamp) { if (alu->vector_clamp) {
@ -321,17 +331,17 @@ int disasm_alu(StringBuffer* output, const uint32_t* dwords, uint32_t alu_off,
uint32_t swiz_a = ((src3_swiz >> 6) - 1) & 0x3; uint32_t swiz_a = ((src3_swiz >> 6) - 1) & 0x3;
uint32_t swiz_b = (src3_swiz & 0x3); uint32_t swiz_b = (src3_swiz & 0x3);
print_srcreg(output, alu->src3_reg, 0, 0, alu->src3_reg_negate, print_srcreg(output, alu->src3_reg, 0, 0, alu->src3_reg_negate,
alu->abs_constants, type); alu->abs_constants, false, type);
output->AppendFormat(".%c", chan_names[swiz_a]); output->AppendFormat(".%c", chan_names[swiz_a]);
output->Append(", "); output->Append(", ");
uint32_t reg2 = (alu->scalar_opc & 1) | (alu->src3_swiz & 0x3C) | uint32_t reg2 = (alu->scalar_opc & 1) | (alu->src3_swiz & 0x3C) |
(alu->src3_sel << 1); (alu->src3_sel << 1);
print_srcreg(output, reg2, 1, 0, alu->src3_reg_negate, alu->abs_constants, print_srcreg(output, reg2, 1, 0, alu->src3_reg_negate, alu->abs_constants,
type); false, type);
output->AppendFormat(".%c", chan_names[swiz_b]); output->AppendFormat(".%c", chan_names[swiz_b]);
} else { } else {
print_srcreg(output, alu->src3_reg, alu->src3_sel, alu->src3_swiz, print_srcreg(output, alu->src3_reg, alu->src3_sel, alu->src3_swiz,
alu->src3_reg_negate, alu->abs_constants, type); alu->src3_reg_negate, alu->abs_constants, false, type);
} }
if (alu->scalar_clamp) { if (alu->scalar_clamp) {
output->Append(" CLAMP"); output->Append(" CLAMP");