Fix some formatting alignments in arm/thumb opcodes
This commit is contained in:
parent
893269d897
commit
26c8c61b88
|
@ -593,10 +593,10 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
EMIT2(cmp, KONST(0x3C), esi) \
|
EMIT2(cmp, KONST(0x3C), esi) \
|
||||||
EMIT1(je, LABELREF(8, f)) \
|
EMIT1(je, LABELREF(8, f)) \
|
||||||
OP SETCOND \
|
OP SETCOND \
|
||||||
EMIT1(jmp, LABELREF(9, f)) \
|
EMIT1(jmp, LABELREF(9, f)) \
|
||||||
LABEL(8) \
|
LABEL(8) \
|
||||||
OP \
|
OP \
|
||||||
LABEL(9)
|
LABEL(9)
|
||||||
|
|
||||||
#define OP_AND \
|
#define OP_AND \
|
||||||
EMIT2(and, eax, edx) \
|
EMIT2(and, eax, edx) \
|
||||||
|
@ -692,19 +692,19 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define ROR_IMM_MSR \
|
#define ROR_IMM_MSR \
|
||||||
__asm { \
|
__asm { \
|
||||||
__asm mov ecx, shift \
|
__asm mov ecx, shift \
|
||||||
__asm ror value, cl \
|
__asm ror value, cl \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ROR_OFFSET \
|
#define ROR_OFFSET \
|
||||||
__asm { \
|
__asm { \
|
||||||
__asm mov ecx, shift \
|
__asm mov ecx, shift \
|
||||||
__asm ror offset, cl \
|
__asm ror offset, cl \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define RRX_OFFSET \
|
#define RRX_OFFSET \
|
||||||
__asm { \
|
__asm { \
|
||||||
__asm bt dword ptr C_FLAG, 0 \
|
__asm bt dword ptr C_FLAG, 0 \
|
||||||
__asm rcr offset, 1 \
|
__asm rcr offset, 1 \
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // !__GNUC__
|
#endif // !__GNUC__
|
||||||
|
@ -714,19 +714,19 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
|
|
||||||
// C core
|
// C core
|
||||||
|
|
||||||
#define C_SETCOND_LOGICAL \
|
#define C_SETCOND_LOGICAL \
|
||||||
N_FLAG = ((int32_t)res < 0) ? true : false; \
|
N_FLAG = ((int32_t)res < 0) ? true : false; \
|
||||||
Z_FLAG = (res == 0) ? true : false; \
|
Z_FLAG = (res == 0) ? true : false; \
|
||||||
C_FLAG = C_OUT;
|
C_FLAG = C_OUT;
|
||||||
#define C_SETCOND_ADD \
|
#define C_SETCOND_ADD \
|
||||||
N_FLAG = ((int32_t)res < 0) ? true : false; \
|
N_FLAG = ((int32_t)res < 0) ? true : false; \
|
||||||
Z_FLAG = (res == 0) ? true : false; \
|
Z_FLAG = (res == 0) ? true : false; \
|
||||||
V_FLAG = ((NEG(lhs) & NEG(rhs) & POS(res)) | (POS(lhs) & POS(rhs) & NEG(res))) ? true : false; \
|
V_FLAG = ((NEG(lhs) & NEG(rhs) & POS(res)) | (POS(lhs) & POS(rhs) & NEG(res))) ? true : false; \
|
||||||
C_FLAG = ((NEG(lhs) & NEG(rhs)) | (NEG(lhs) & POS(res)) | (NEG(rhs) & POS(res))) ? true : false;
|
C_FLAG = ((NEG(lhs) & NEG(rhs)) | (NEG(lhs) & POS(res)) | (NEG(rhs) & POS(res))) ? true : false;
|
||||||
#define C_SETCOND_SUB \
|
#define C_SETCOND_SUB \
|
||||||
N_FLAG = ((int32_t)res < 0) ? true : false; \
|
N_FLAG = ((int32_t)res < 0) ? true : false; \
|
||||||
Z_FLAG = (res == 0) ? true : false; \
|
Z_FLAG = (res == 0) ? true : false; \
|
||||||
V_FLAG = ((NEG(lhs) & POS(rhs) & POS(res)) | (POS(lhs) & NEG(rhs) & NEG(res))) ? true : false; \
|
V_FLAG = ((NEG(lhs) & POS(rhs) & POS(res)) | (POS(lhs) & NEG(rhs) & NEG(res))) ? true : false; \
|
||||||
C_FLAG = ((NEG(lhs) & POS(rhs)) | (NEG(lhs) & POS(res)) | (POS(rhs) & POS(res))) ? true : false;
|
C_FLAG = ((NEG(lhs) & POS(rhs)) | (NEG(lhs) & POS(res)) | (POS(rhs) & POS(res))) ? true : false;
|
||||||
|
|
||||||
#define maybe_unused(var) (void) var
|
#define maybe_unused(var) (void) var
|
||||||
|
@ -744,7 +744,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
if (LIKELY(!shift)) { /* LSL #0 most common? */ \
|
if (LIKELY(!shift)) { /* LSL #0 most common? */ \
|
||||||
value = reg[opcode & 0x0F].I; \
|
value = reg[opcode & 0x0F].I; \
|
||||||
} else { \
|
} else { \
|
||||||
uint32_t v = reg[opcode & 0x0F].I; \
|
uint32_t v = reg[opcode & 0x0F].I; \
|
||||||
C_OUT = (v >> (32 - shift)) & 1 ? true : false; \
|
C_OUT = (v >> (32 - shift)) & 1 ? true : false; \
|
||||||
value = v << shift; \
|
value = v << shift; \
|
||||||
}
|
}
|
||||||
|
@ -752,8 +752,8 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
// OP Rd,Rb,Rm LSL Rs
|
// OP Rd,Rb,Rm LSL Rs
|
||||||
#ifndef VALUE_LSL_REG_C
|
#ifndef VALUE_LSL_REG_C
|
||||||
#define VALUE_LSL_REG_C \
|
#define VALUE_LSL_REG_C \
|
||||||
uint32_t shift = reg[(opcode >> 8) & 15].B.B0; \
|
uint32_t shift = reg[(opcode >> 8) & 15].B.B0; \
|
||||||
uint32_t rm = reg[opcode & 0x0F].I; \
|
uint32_t rm = reg[opcode & 0x0F].I; \
|
||||||
if ((opcode & 0x0F) == 15) { \
|
if ((opcode & 0x0F) == 15) { \
|
||||||
rm += 4; \
|
rm += 4; \
|
||||||
} \
|
} \
|
||||||
|
@ -762,7 +762,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
value = 0; \
|
value = 0; \
|
||||||
C_OUT = (rm & 1 ? true : false); \
|
C_OUT = (rm & 1 ? true : false); \
|
||||||
} else if (LIKELY(shift < 32)) { \
|
} else if (LIKELY(shift < 32)) { \
|
||||||
uint32_t v = rm; \
|
uint32_t v = rm; \
|
||||||
C_OUT = (v >> (32 - shift)) & 1 ? true : false; \
|
C_OUT = (v >> (32 - shift)) & 1 ? true : false; \
|
||||||
value = v << shift; \
|
value = v << shift; \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -776,9 +776,9 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
// OP Rd,Rb,Rm LSR #
|
// OP Rd,Rb,Rm LSR #
|
||||||
#ifndef VALUE_LSR_IMM_C
|
#ifndef VALUE_LSR_IMM_C
|
||||||
#define VALUE_LSR_IMM_C \
|
#define VALUE_LSR_IMM_C \
|
||||||
uint32_t shift = (opcode >> 7) & 0x1F; \
|
uint32_t shift = (opcode >> 7) & 0x1F; \
|
||||||
if (LIKELY(shift)) { \
|
if (LIKELY(shift)) { \
|
||||||
uint32_t v = reg[opcode & 0x0F].I; \
|
uint32_t v = reg[opcode & 0x0F].I; \
|
||||||
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
||||||
value = v >> shift; \
|
value = v >> shift; \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -790,7 +790,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#ifndef VALUE_LSR_REG_C
|
#ifndef VALUE_LSR_REG_C
|
||||||
#define VALUE_LSR_REG_C \
|
#define VALUE_LSR_REG_C \
|
||||||
unsigned int shift = reg[(opcode >> 8) & 15].B.B0; \
|
unsigned int shift = reg[(opcode >> 8) & 15].B.B0; \
|
||||||
uint32_t rm = reg[opcode & 0x0F].I; \
|
uint32_t rm = reg[opcode & 0x0F].I; \
|
||||||
if ((opcode & 0x0F) == 15) { \
|
if ((opcode & 0x0F) == 15) { \
|
||||||
rm += 4; \
|
rm += 4; \
|
||||||
} \
|
} \
|
||||||
|
@ -799,7 +799,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
value = 0; \
|
value = 0; \
|
||||||
C_OUT = (rm & 0x80000000 ? true : false); \
|
C_OUT = (rm & 0x80000000 ? true : false); \
|
||||||
} else if (LIKELY(shift < 32)) { \
|
} else if (LIKELY(shift < 32)) { \
|
||||||
uint32_t v = rm; \
|
uint32_t v = rm; \
|
||||||
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
||||||
value = v >> shift; \
|
value = v >> shift; \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -816,7 +816,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
unsigned int shift = (opcode >> 7) & 0x1F; \
|
unsigned int shift = (opcode >> 7) & 0x1F; \
|
||||||
if (LIKELY(shift)) { \
|
if (LIKELY(shift)) { \
|
||||||
/* VC++ BUG: uint32_t v; (int32_t)v>>n is optimized to shr! */ \
|
/* VC++ BUG: uint32_t v; (int32_t)v>>n is optimized to shr! */ \
|
||||||
int32_t v = reg[opcode & 0x0F].I; \
|
int32_t v = reg[opcode & 0x0F].I; \
|
||||||
C_OUT = (v >> (int)(shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (int)(shift - 1)) & 1 ? true : false; \
|
||||||
value = v >> (int)shift; \
|
value = v >> (int)shift; \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -833,13 +833,13 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#ifndef VALUE_ASR_REG_C
|
#ifndef VALUE_ASR_REG_C
|
||||||
#define VALUE_ASR_REG_C \
|
#define VALUE_ASR_REG_C \
|
||||||
unsigned int shift = reg[(opcode >> 8) & 15].B.B0; \
|
unsigned int shift = reg[(opcode >> 8) & 15].B.B0; \
|
||||||
uint32_t rm = reg[opcode & 0x0F].I; \
|
uint32_t rm = reg[opcode & 0x0F].I; \
|
||||||
if ((opcode & 0x0F) == 15) { \
|
if ((opcode & 0x0F) == 15) { \
|
||||||
rm += 4; \
|
rm += 4; \
|
||||||
} \
|
} \
|
||||||
if (LIKELY(shift < 32)) { \
|
if (LIKELY(shift < 32)) { \
|
||||||
if (LIKELY(shift)) { \
|
if (LIKELY(shift)) { \
|
||||||
int32_t v = rm; \
|
int32_t v = rm; \
|
||||||
C_OUT = (v >> (int)(shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (int)(shift - 1)) & 1 ? true : false; \
|
||||||
value = v >> (int)shift; \
|
value = v >> (int)shift; \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -860,11 +860,11 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define VALUE_ROR_IMM_C \
|
#define VALUE_ROR_IMM_C \
|
||||||
unsigned int shift = (opcode >> 7) & 0x1F; \
|
unsigned int shift = (opcode >> 7) & 0x1F; \
|
||||||
if (LIKELY(shift)) { \
|
if (LIKELY(shift)) { \
|
||||||
uint32_t v = reg[opcode & 0x0F].I; \
|
uint32_t v = reg[opcode & 0x0F].I; \
|
||||||
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
||||||
value = ((v << (32 - shift)) | (v >> shift)); \
|
value = ((v << (32 - shift)) | (v >> shift)); \
|
||||||
} else { \
|
} else { \
|
||||||
uint32_t v = reg[opcode & 0x0F].I; \
|
uint32_t v = reg[opcode & 0x0F].I; \
|
||||||
C_OUT = (v & 1) ? true : false; \
|
C_OUT = (v & 1) ? true : false; \
|
||||||
value = ((v >> 1) | (C_FLAG << 31)); \
|
value = ((v >> 1) | (C_FLAG << 31)); \
|
||||||
}
|
}
|
||||||
|
@ -873,12 +873,12 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#ifndef VALUE_ROR_REG_C
|
#ifndef VALUE_ROR_REG_C
|
||||||
#define VALUE_ROR_REG_C \
|
#define VALUE_ROR_REG_C \
|
||||||
unsigned int shift = reg[(opcode >> 8) & 15].B.B0; \
|
unsigned int shift = reg[(opcode >> 8) & 15].B.B0; \
|
||||||
uint32_t rm = reg[opcode & 0x0F].I; \
|
uint32_t rm = reg[opcode & 0x0F].I; \
|
||||||
if ((opcode & 0x0F) == 15) { \
|
if ((opcode & 0x0F) == 15) { \
|
||||||
rm += 4; \
|
rm += 4; \
|
||||||
} \
|
} \
|
||||||
if (LIKELY(shift & 0x1F)) { \
|
if (LIKELY(shift & 0x1F)) { \
|
||||||
uint32_t v = rm; \
|
uint32_t v = rm; \
|
||||||
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
||||||
value = ((v << (32 - shift)) | (v >> shift)); \
|
value = ((v << (32 - shift)) | (v >> shift)); \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -892,7 +892,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define VALUE_IMM_C \
|
#define VALUE_IMM_C \
|
||||||
int shift = (opcode & 0xF00) >> 7; \
|
int shift = (opcode & 0xF00) >> 7; \
|
||||||
if (UNLIKELY(shift)) { \
|
if (UNLIKELY(shift)) { \
|
||||||
uint32_t v = opcode & 0xFF; \
|
uint32_t v = opcode & 0xFF; \
|
||||||
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
|
||||||
value = ((v << (32 - shift)) | (v >> shift)); \
|
value = ((v << (32 - shift)) | (v >> shift)); \
|
||||||
} else { \
|
} else { \
|
||||||
|
@ -938,7 +938,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
SETCOND \
|
SETCOND \
|
||||||
}
|
}
|
||||||
#ifndef OP_AND
|
#ifndef OP_AND
|
||||||
#define OP_AND \
|
#define OP_AND \
|
||||||
uint32_t res = reg[(opcode >> 16) & 15].I & value; \
|
uint32_t res = reg[(opcode >> 16) & 15].I & value; \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -946,7 +946,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_ANDS OP_AND C_CHECK_PC(C_SETCOND_LOGICAL)
|
#define OP_ANDS OP_AND C_CHECK_PC(C_SETCOND_LOGICAL)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_EOR
|
#ifndef OP_EOR
|
||||||
#define OP_EOR \
|
#define OP_EOR \
|
||||||
uint32_t res = reg[(opcode >> 16) & 15].I ^ value; \
|
uint32_t res = reg[(opcode >> 16) & 15].I ^ value; \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -954,7 +954,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_EORS OP_EOR C_CHECK_PC(C_SETCOND_LOGICAL)
|
#define OP_EORS OP_EOR C_CHECK_PC(C_SETCOND_LOGICAL)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_SUB
|
#ifndef OP_SUB
|
||||||
#define OP_SUB \
|
#define OP_SUB \
|
||||||
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t rhs = value; \
|
uint32_t rhs = value; \
|
||||||
uint32_t res = lhs - rhs; \
|
uint32_t res = lhs - rhs; \
|
||||||
|
@ -964,7 +964,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_SUBS OP_SUB C_CHECK_PC(C_SETCOND_SUB)
|
#define OP_SUBS OP_SUB C_CHECK_PC(C_SETCOND_SUB)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_RSB
|
#ifndef OP_RSB
|
||||||
#define OP_RSB \
|
#define OP_RSB \
|
||||||
uint32_t lhs = value; \
|
uint32_t lhs = value; \
|
||||||
uint32_t rhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t rhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t res = lhs - rhs; \
|
uint32_t res = lhs - rhs; \
|
||||||
|
@ -974,7 +974,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_RSBS OP_RSB C_CHECK_PC(C_SETCOND_SUB)
|
#define OP_RSBS OP_RSB C_CHECK_PC(C_SETCOND_SUB)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_ADD
|
#ifndef OP_ADD
|
||||||
#define OP_ADD \
|
#define OP_ADD \
|
||||||
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t rhs = value; \
|
uint32_t rhs = value; \
|
||||||
uint32_t res = lhs + rhs; \
|
uint32_t res = lhs + rhs; \
|
||||||
|
@ -984,19 +984,19 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_ADDS OP_ADD C_CHECK_PC(C_SETCOND_ADD)
|
#define OP_ADDS OP_ADD C_CHECK_PC(C_SETCOND_ADD)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_ADC
|
#ifndef OP_ADC
|
||||||
#define OP_ADC \
|
#define OP_ADC \
|
||||||
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t rhs = value; \
|
uint32_t rhs = value; \
|
||||||
uint32_t res = lhs + rhs + (uint32_t)C_FLAG; \
|
uint32_t res = lhs + rhs + (uint32_t)C_FLAG; \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_ADCS
|
#ifndef OP_ADCS
|
||||||
#define OP_ADCS OP_ADC C_CHECK_PC(C_SETCOND_ADD)
|
#define OP_ADCS OP_ADC C_CHECK_PC(C_SETCOND_ADD)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_SBC
|
#ifndef OP_SBC
|
||||||
#define OP_SBC \
|
#define OP_SBC \
|
||||||
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t rhs = value; \
|
uint32_t rhs = value; \
|
||||||
uint32_t res = lhs - rhs - !((uint32_t)C_FLAG); \
|
uint32_t res = lhs - rhs - !((uint32_t)C_FLAG); \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1004,9 +1004,9 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_SBCS OP_SBC C_CHECK_PC(C_SETCOND_SUB)
|
#define OP_SBCS OP_SBC C_CHECK_PC(C_SETCOND_SUB)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_RSC
|
#ifndef OP_RSC
|
||||||
#define OP_RSC \
|
#define OP_RSC \
|
||||||
uint32_t lhs = value; \
|
uint32_t lhs = value; \
|
||||||
uint32_t rhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t rhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t res = lhs - rhs - !((uint32_t)C_FLAG); \
|
uint32_t res = lhs - rhs - !((uint32_t)C_FLAG); \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1014,31 +1014,31 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_RSCS OP_RSC C_CHECK_PC(C_SETCOND_SUB)
|
#define OP_RSCS OP_RSC C_CHECK_PC(C_SETCOND_SUB)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_TST
|
#ifndef OP_TST
|
||||||
#define OP_TST \
|
#define OP_TST \
|
||||||
uint32_t res = reg[(opcode >> 16) & 0x0F].I & value; \
|
uint32_t res = reg[(opcode >> 16) & 0x0F].I & value; \
|
||||||
C_SETCOND_LOGICAL;
|
C_SETCOND_LOGICAL;
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_TEQ
|
#ifndef OP_TEQ
|
||||||
#define OP_TEQ \
|
#define OP_TEQ \
|
||||||
uint32_t res = reg[(opcode >> 16) & 0x0F].I ^ value; \
|
uint32_t res = reg[(opcode >> 16) & 0x0F].I ^ value; \
|
||||||
C_SETCOND_LOGICAL;
|
C_SETCOND_LOGICAL;
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_CMP
|
#ifndef OP_CMP
|
||||||
#define OP_CMP \
|
#define OP_CMP \
|
||||||
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t rhs = value; \
|
uint32_t rhs = value; \
|
||||||
uint32_t res = lhs - rhs; \
|
uint32_t res = lhs - rhs; \
|
||||||
C_SETCOND_SUB;
|
C_SETCOND_SUB;
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_CMN
|
#ifndef OP_CMN
|
||||||
#define OP_CMN \
|
#define OP_CMN \
|
||||||
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
uint32_t lhs = reg[(opcode >> 16) & 15].I; \
|
||||||
uint32_t rhs = value; \
|
uint32_t rhs = value; \
|
||||||
uint32_t res = lhs + rhs; \
|
uint32_t res = lhs + rhs; \
|
||||||
C_SETCOND_ADD;
|
C_SETCOND_ADD;
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_ORR
|
#ifndef OP_ORR
|
||||||
#define OP_ORR \
|
#define OP_ORR \
|
||||||
uint32_t res = reg[(opcode >> 16) & 0x0F].I | value; \
|
uint32_t res = reg[(opcode >> 16) & 0x0F].I | value; \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1046,7 +1046,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_ORRS OP_ORR C_CHECK_PC(C_SETCOND_LOGICAL)
|
#define OP_ORRS OP_ORR C_CHECK_PC(C_SETCOND_LOGICAL)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_MOV
|
#ifndef OP_MOV
|
||||||
#define OP_MOV \
|
#define OP_MOV \
|
||||||
uint32_t res = value; \
|
uint32_t res = value; \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1054,7 +1054,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_MOVS OP_MOV C_CHECK_PC(C_SETCOND_LOGICAL)
|
#define OP_MOVS OP_MOV C_CHECK_PC(C_SETCOND_LOGICAL)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_BIC
|
#ifndef OP_BIC
|
||||||
#define OP_BIC \
|
#define OP_BIC \
|
||||||
uint32_t res = reg[(opcode >> 16) & 0x0F].I & (~value); \
|
uint32_t res = reg[(opcode >> 16) & 0x0F].I & (~value); \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1062,7 +1062,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define OP_BICS OP_BIC C_CHECK_PC(C_SETCOND_LOGICAL)
|
#define OP_BICS OP_BIC C_CHECK_PC(C_SETCOND_LOGICAL)
|
||||||
#endif
|
#endif
|
||||||
#ifndef OP_MVN
|
#ifndef OP_MVN
|
||||||
#define OP_MVN \
|
#define OP_MVN \
|
||||||
uint32_t res = ~value; \
|
uint32_t res = ~value; \
|
||||||
reg[dest].I = res;
|
reg[dest].I = res;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1074,7 +1074,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define SETCOND_NONE /*nothing*/
|
#define SETCOND_NONE /*nothing*/
|
||||||
#endif
|
#endif
|
||||||
#ifndef SETCOND_MUL
|
#ifndef SETCOND_MUL
|
||||||
#define SETCOND_MUL \
|
#define SETCOND_MUL \
|
||||||
N_FLAG = ((int32_t)reg[dest].I < 0) ? true : false; \
|
N_FLAG = ((int32_t)reg[dest].I < 0) ? true : false; \
|
||||||
Z_FLAG = reg[dest].I ? false : true;
|
Z_FLAG = reg[dest].I ? false : true;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1089,7 +1089,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef ROR_IMM_MSR
|
#ifndef ROR_IMM_MSR
|
||||||
#define ROR_IMM_MSR \
|
#define ROR_IMM_MSR \
|
||||||
uint32_t v = opcode & 0xff; \
|
uint32_t v = opcode & 0xff; \
|
||||||
value = ((v << (32 - shift)) | (v >> shift));
|
value = ((v << (32 - shift)) | (v >> shift));
|
||||||
#endif
|
#endif
|
||||||
|
@ -1137,7 +1137,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
#define MODECHANGE_NO /*nothing*/
|
#define MODECHANGE_NO /*nothing*/
|
||||||
#define MODECHANGE_YES CPUSwitchMode(reg[17].I & 0x1f, false);
|
#define MODECHANGE_YES CPUSwitchMode(reg[17].I & 0x1f, false);
|
||||||
|
|
||||||
#define DEFINE_ALU_INSN_C(CODE1, CODE2, OP, MODECHANGE) \
|
#define DEFINE_ALU_INSN_C(CODE1, CODE2, OP, MODECHANGE) \
|
||||||
static INSN_REGPARM void arm##CODE1##0(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_LSL_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
static INSN_REGPARM void arm##CODE1##0(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_LSL_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
||||||
static INSN_REGPARM void arm##CODE1##1(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_LSL_REG_C, OP_##OP, MODECHANGE_##MODECHANGE, 1); } \
|
static INSN_REGPARM void arm##CODE1##1(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_LSL_REG_C, OP_##OP, MODECHANGE_##MODECHANGE, 1); } \
|
||||||
static INSN_REGPARM void arm##CODE1##2(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_LSR_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
static INSN_REGPARM void arm##CODE1##2(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_LSR_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
||||||
|
@ -1147,7 +1147,7 @@ static void count(uint32_t opcode, int cond_res)
|
||||||
static INSN_REGPARM void arm##CODE1##6(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_ROR_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
static INSN_REGPARM void arm##CODE1##6(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_ROR_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
||||||
static INSN_REGPARM void arm##CODE1##7(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_ROR_REG_C, OP_##OP, MODECHANGE_##MODECHANGE, 1); } \
|
static INSN_REGPARM void arm##CODE1##7(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_ROR_REG_C, OP_##OP, MODECHANGE_##MODECHANGE, 1); } \
|
||||||
static INSN_REGPARM void arm##CODE2##0(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); }
|
static INSN_REGPARM void arm##CODE2##0(uint32_t opcode) { ALU_INSN(ALU_INIT_C, VALUE_IMM_C, OP_##OP, MODECHANGE_##MODECHANGE, 0); }
|
||||||
#define DEFINE_ALU_INSN_NC(CODE1, CODE2, OP, MODECHANGE) \
|
#define DEFINE_ALU_INSN_NC(CODE1, CODE2, OP, MODECHANGE) \
|
||||||
static INSN_REGPARM void arm##CODE1##0(uint32_t opcode) { ALU_INSN(ALU_INIT_NC, VALUE_LSL_IMM_NC, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
static INSN_REGPARM void arm##CODE1##0(uint32_t opcode) { ALU_INSN(ALU_INIT_NC, VALUE_LSL_IMM_NC, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
||||||
static INSN_REGPARM void arm##CODE1##1(uint32_t opcode) { ALU_INSN(ALU_INIT_NC, VALUE_LSL_REG_NC, OP_##OP, MODECHANGE_##MODECHANGE, 1); } \
|
static INSN_REGPARM void arm##CODE1##1(uint32_t opcode) { ALU_INSN(ALU_INIT_NC, VALUE_LSL_REG_NC, OP_##OP, MODECHANGE_##MODECHANGE, 1); } \
|
||||||
static INSN_REGPARM void arm##CODE1##2(uint32_t opcode) { ALU_INSN(ALU_INIT_NC, VALUE_LSR_IMM_NC, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
static INSN_REGPARM void arm##CODE1##2(uint32_t opcode) { ALU_INSN(ALU_INIT_NC, VALUE_LSR_IMM_NC, OP_##OP, MODECHANGE_##MODECHANGE, 0); } \
|
||||||
|
@ -1237,12 +1237,12 @@ DEFINE_ALU_INSN_C(1F, 3F, MVNS, YES)
|
||||||
// CYCLES: base cycle count (1, 2, or 3)
|
// CYCLES: base cycle count (1, 2, or 3)
|
||||||
#define MUL_INSN(OP, SETCOND, CYCLES) \
|
#define MUL_INSN(OP, SETCOND, CYCLES) \
|
||||||
int mult = (opcode & 0x0F); \
|
int mult = (opcode & 0x0F); \
|
||||||
uint32_t rs = reg[(opcode >> 8) & 0x0F].I; \
|
uint32_t rs = reg[(opcode >> 8) & 0x0F].I; \
|
||||||
int acc = (opcode >> 12) & 0x0F; /* or destLo */ \
|
int acc = (opcode >> 12) & 0x0F; /* or destLo */ \
|
||||||
int dest = (opcode >> 16) & 0x0F; /* or destHi */ \
|
int dest = (opcode >> 16) & 0x0F; /* or destHi */ \
|
||||||
OP; \
|
OP; \
|
||||||
SETCOND; \
|
SETCOND; \
|
||||||
if ((int32_t)rs < 0) \
|
if ((int32_t)rs < 0) \
|
||||||
rs = ~rs; \
|
rs = ~rs; \
|
||||||
if ((rs & 0xFFFFFF00) == 0) \
|
if ((rs & 0xFFFFFF00) == 0) \
|
||||||
clockTicks += 0; \
|
clockTicks += 0; \
|
||||||
|
@ -1268,13 +1268,13 @@ typedef int64_t s32;
|
||||||
#define OP_MULL(SIGN) \
|
#define OP_MULL(SIGN) \
|
||||||
SIGN##64 res = (SIGN##64)(SIGN##32)reg[mult].I \
|
SIGN##64 res = (SIGN##64)(SIGN##32)reg[mult].I \
|
||||||
* (SIGN##64)(SIGN##32)rs; \
|
* (SIGN##64)(SIGN##32)rs; \
|
||||||
reg[acc].I = (uint32_t)res; \
|
reg[acc].I = (uint32_t)res; \
|
||||||
reg[dest].I = (uint32_t)(res >> 32);
|
reg[dest].I = (uint32_t)(res >> 32);
|
||||||
#define OP_MLAL(SIGN) \
|
#define OP_MLAL(SIGN) \
|
||||||
SIGN##64 res = ((SIGN##64)reg[dest].I << 32 | reg[acc].I) \
|
SIGN##64 res = ((SIGN##64)reg[dest].I << 32 | reg[acc].I) \
|
||||||
+ ((SIGN##64)(SIGN##32)reg[mult].I \
|
+ ((SIGN##64)(SIGN##32)reg[mult].I \
|
||||||
* (SIGN##64)(SIGN##32)rs); \
|
* (SIGN##64)(SIGN##32)rs); \
|
||||||
reg[acc].I = (uint32_t)res; \
|
reg[acc].I = (uint32_t)res; \
|
||||||
reg[dest].I = (uint32_t)(res >> 32);
|
reg[dest].I = (uint32_t)(res >> 32);
|
||||||
#define OP_UMULL OP_MULL(u)
|
#define OP_UMULL OP_MULL(u)
|
||||||
#define OP_UMLAL OP_MLAL(u)
|
#define OP_UMLAL OP_MLAL(u)
|
||||||
|
@ -1508,22 +1508,22 @@ static INSN_REGPARM void arm121(uint32_t opcode)
|
||||||
#define OFFSET_LSR \
|
#define OFFSET_LSR \
|
||||||
int shift = (opcode >> 7) & 31; \
|
int shift = (opcode >> 7) & 31; \
|
||||||
int offset = shift ? reg[opcode & 15].I >> shift : 0;
|
int offset = shift ? reg[opcode & 15].I >> shift : 0;
|
||||||
#define OFFSET_ASR \
|
#define OFFSET_ASR \
|
||||||
int shift = (opcode >> 7) & 31; \
|
int shift = (opcode >> 7) & 31; \
|
||||||
int offset; \
|
int offset; \
|
||||||
if (shift) \
|
if (shift) \
|
||||||
offset = (int)((int32_t)reg[opcode & 15].I >> shift); \
|
offset = (int)((int32_t)reg[opcode & 15].I >> shift); \
|
||||||
else if (reg[opcode & 15].I & 0x80000000) \
|
else if (reg[opcode & 15].I & 0x80000000) \
|
||||||
offset = 0xFFFFFFFF; \
|
offset = 0xFFFFFFFF; \
|
||||||
else \
|
else \
|
||||||
offset = 0;
|
offset = 0;
|
||||||
#define OFFSET_ROR \
|
#define OFFSET_ROR \
|
||||||
int shift = (opcode >> 7) & 31; \
|
int shift = (opcode >> 7) & 31; \
|
||||||
uint32_t offset = reg[opcode & 15].I; \
|
uint32_t offset = reg[opcode & 15].I; \
|
||||||
if (shift) { \
|
if (shift) { \
|
||||||
ROR_OFFSET; \
|
ROR_OFFSET; \
|
||||||
} else { \
|
} else { \
|
||||||
RRX_OFFSET; \
|
RRX_OFFSET; \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ADDRESS_POST (reg[base].I)
|
#define ADDRESS_POST (reg[base].I)
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue