Merge pull request #1373 from elad335/master

[PPC] disasm: BC formatting improvements
This commit is contained in:
Rick Gibbed 2019-05-13 00:29:08 -05:00 committed by GitHub
commit d7d69369d1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 139 additions and 9 deletions

View File

@ -191,17 +191,147 @@ void PrintDisasm_bclrx(const PPCDecodeData& d, StringBuffer* str) {
str->AppendFormat("%d", d.XL.BI()); str->AppendFormat("%d", d.XL.BI());
} }
void PrintDisasm_bcx(const PPCDecodeData& d, StringBuffer* str) { void PrintDisasm_bcx(const PPCDecodeData& d, StringBuffer* str) {
// bc[LK][AA] [BO], [BI], [ADDR] // [bc][LK][AA][+-] [BO], [BI], [ADDR]
size_t str_start = str->length(); size_t str_start = str->length();
str->Append("bc");
if (d.B.LK()) str->Append('l'); const uint32_t bo = d.B.BO();
if (d.B.AA()) str->Append('a'); const uint32_t bi = d.B.BI();
PadStringBuffer(str, str_start, kNamePad); const uint32_t addr = d.B.ADDR();
str->AppendFormat("%d", d.B.BO());
const bool bo0 = bo & 0x10;
const bool bo1 = bo & 0x08;
const bool bo2 = bo & 0x04;
const bool bo3 = bo & 0x02;
const bool bo4 = bo & 0x01;
int sign_char = 0; // Default no sign
if (bo0 && !bo1 && !bo2 && bo3 && !bo4) {
str->Append("bdz");
} else if (bo0 && bo1 && !bo2 && bo3 && !bo4) {
str->Append("bdz");
sign_char = -1;
} else if (bo0 && bo1 && !bo2 && bo3 && bo4) {
str->Append("bdz");
sign_char = +1;
} else if (bo0 && !bo1 && !bo2 && !bo3 && !bo4) {
str->Append("bdnz");
} else if (bo0 && bo1 && !bo2 && !bo3 && !bo4) {
str->Append("bdnz");
sign_char = -1;
} else if (bo0 && bo1 && !bo2 && !bo3 && bo4) {
str->Append("bdnz");
sign_char = +1;
} else if (!bo0 && !bo1 && bo2 && !bo3 && !bo4) {
switch (bi % 4) {
case 0x0:
str->Append("bge");
break;
case 0x1:
str->Append("ble");
break;
case 0x2:
str->Append("bne");
break;
}
} else if (!bo0 && !bo1 && bo2 && bo3 && !bo4) {
switch (bi % 4) {
case 0x0:
str->Append("bge");
sign_char = -1;
break;
case 0x1:
str->Append("ble");
sign_char = -1;
break;
case 0x2:
str->Append("bne");
sign_char = -1;
break;
}
} else if (!bo0 && !bo1 && bo2 && bo3 && bo4) {
switch (bi % 4) {
case 0x0:
str->Append("bge");
sign_char = +1;
break;
case 0x1:
str->Append("ble");
sign_char = +1;
break;
case 0x2:
str->Append("bne");
sign_char = +1;
break;
}
} else if (!bo0 && bo1 && bo2 && !bo3 && !bo4) {
switch (bi % 4) {
case 0x0:
str->Append("blt");
break;
case 0x1:
str->Append("bgt");
break;
case 0x2:
str->Append("beq");
break;
}
} else if (!bo0 && bo1 && bo2 && bo3 && !bo4) {
switch (bi % 4) {
case 0x0:
str->Append("blt");
sign_char = -1;
break;
case 0x1:
str->Append("bgt");
sign_char = -1;
break;
case 0x2:
str->Append("beq");
sign_char = -1;
break;
}
} else if (!bo0 && bo1 && bo2 && bo3 && bo4) {
switch (bi % 4) {
case 0x0:
str->Append("blt");
sign_char = +1;
break;
case 0x1:
str->Append("bgt");
sign_char = +1;
break;
case 0x2:
str->Append("beq");
sign_char = +1;
break;
}
}
if (str_start == str->length()) {
// Default
str->Append("bc");
if (d.B.LK()) str->Append('l');
if (d.B.AA()) str->Append('a');
PadStringBuffer(str, str_start, kNamePad);
str->AppendFormat("%d", bo);
str->Append(", ");
str->AppendFormat("%d", bi);
} else {
if (d.B.LK()) str->Append('l');
if (d.B.AA()) str->Append('a');
if (sign_char > 0) {
str->Append('+');
} else if (sign_char < 0) {
str->Append('-');
}
PadStringBuffer(str, str_start, kNamePad);
str->AppendFormat("crf%d", bi / 4);
}
str->Append(", "); str->Append(", ");
str->AppendFormat("%d", d.B.BI()); str->AppendFormat("0x%X", addr);
str->Append(", ");
str->AppendFormat("0x%X", d.B.ADDR());
} }
void PrintDisasm_bx(const PPCDecodeData& d, StringBuffer* str) { void PrintDisasm_bx(const PPCDecodeData& d, StringBuffer* str) {
// b[LK][AA] [ADDR] // b[LK][AA] [ADDR]