lets commit the right version of the arm patch this time eh.

This commit is contained in:
squall-leonhart 2013-02-04 06:26:16 +00:00
parent 9958c493bd
commit 66ac24cde5
1 changed files with 42 additions and 44 deletions

View File

@ -753,31 +753,31 @@ static void count(u32 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 \
u32 shift = reg[(opcode >> 8)&15].B.B0; \ unsigned int shift = reg[(opcode >> 8)&15].B.B0; \
u32 rm = reg[opcode & 0x0F].I; \ unsigned int rm = reg[opcode & 0x0F].I; \
if((opcode & 0x0F) == 15) { \ if((opcode & 0x0F) == 15) { \
rm += 4; \ rm += 4; \
} \ } \
if (LIKELY(shift)) { \ if (LIKELY(shift)) { \
if (shift == 32) { \ if (shift == 32) { \
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)) { \
u32 v = rm; \ u32 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 { \
value = 0; \ value = 0; \
C_OUT = false; \ C_OUT = false; \
} \ } \
} else { \ } else { \
value = rm; \ value = rm; \
} }
#endif #endif
// 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 \
u32 shift = (opcode >> 7) & 0x1F; \ unsigned int shift = (opcode >> 7) & 0x1F; \
if (LIKELY(shift)) { \ if (LIKELY(shift)) { \
u32 v = reg[opcode & 0x0F].I; \ u32 v = reg[opcode & 0x0F].I; \
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \ C_OUT = (v >> (shift - 1)) & 1 ? true : false; \
@ -791,18 +791,17 @@ static void count(u32 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; \
u32 rm = reg[opcode & 0x0F].I; \ unsigned int rm = reg[opcode & 0x0F].I; \
if((opcode & 0x0F) == 15) { \ if((opcode & 0x0F) == 15) { \
rm += 4; \ rm += 4; \
} \ } \
if (LIKELY(shift)) { \ if (LIKELY(shift)) { \
if (shift == 32) { \ if (shift == 32) { \
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)) { \
u32 v = rm; \ C_OUT = (rm >> (shift - 1)) & 1 ? true : false;\
C_OUT = (v >> (shift - 1)) & 1 ? true : false;\ value = rm >> shift; \
value = v >> shift; \
} else { \ } else { \
value = 0; \ value = 0; \
C_OUT = false; \ C_OUT = false; \
@ -834,20 +833,19 @@ static void count(u32 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; \
u32 rm = reg[opcode & 0x0F].I; \ unsigned int 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)) { \
s32 v = rm; \ C_OUT = (rm >> (int)(shift - 1)) & 1 ? true : false;\
C_OUT = (v >> (int)(shift - 1)) & 1 ? true : false;\ value = rm >> (int)shift; \
value = v >> (int)shift; \
} else { \ } else { \
value = rm; \ value = rm; \
} \ } \
} else { \ } else { \
if (reg[opcode & 0x0F].I & 0x80000000) { \ if (rm & 0x80000000) { \
value = 0xFFFFFFFF; \ value = 0xFFFFFFFF; \
C_OUT = true; \ C_OUT = true; \
} else { \ } else { \
@ -876,20 +874,20 @@ static void count(u32 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; \
u32 rm = reg[opcode & 0x0F].I; \ unsigned int 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)) { \
u32 v = rm; \ C_OUT = (rm >> (shift - 1)) & 1 ? true : false; \
C_OUT = (v >> (shift - 1)) & 1 ? true : false; \ value = ((rm << (32 - shift)) | \
value = ((v << (32 - shift)) | \ (rm >> shift)); \
(v >> shift)); \
} else { \ } else { \
value = rm; \ value = rm; \
if (shift) \ if (shift) \
C_OUT = (value & 0x80000000 ? true : false);\ C_OUT = (value & 0x80000000 ? true : false);\
}#endif }
#endif
// OP Rd,Rb,# ROR # // OP Rd,Rb,# ROR #
#ifndef VALUE_IMM_C #ifndef VALUE_IMM_C
#define VALUE_IMM_C \ #define VALUE_IMM_C \