mirror of
https://github.com/Lime3DS/Lime3DS.git
synced 2024-11-11 12:45:05 +01:00
Merge pull request #294 from lioncash/var
armemu: Narrow the scope of some variables in handle_v6_insn
This commit is contained in:
commit
245abb4125
@ -5681,10 +5681,7 @@ L_stm_s_takeabort:
|
|||||||
/* Attempt to emulate an ARMv6 instruction.
|
/* Attempt to emulate an ARMv6 instruction.
|
||||||
Returns non-zero upon success. */
|
Returns non-zero upon success. */
|
||||||
|
|
||||||
static int
|
static int handle_v6_insn(ARMul_State* state, ARMword instr) {
|
||||||
handle_v6_insn (ARMul_State * state, ARMword instr) {
|
|
||||||
ARMword lhs, temp;
|
|
||||||
|
|
||||||
switch (BITS(20, 27)) {
|
switch (BITS(20, 27)) {
|
||||||
case 0x03:
|
case 0x03:
|
||||||
printf ("Unhandled v6 insn: ldr\n");
|
printf ("Unhandled v6 insn: ldr\n");
|
||||||
@ -5719,7 +5716,7 @@ L_stm_s_takeabort:
|
|||||||
/* strex */
|
/* strex */
|
||||||
u32 l = LHSReg;
|
u32 l = LHSReg;
|
||||||
u32 r = RHSReg;
|
u32 r = RHSReg;
|
||||||
lhs = LHS;
|
u32 lhs = LHS;
|
||||||
|
|
||||||
bool enter = false;
|
bool enter = false;
|
||||||
|
|
||||||
@ -5744,7 +5741,7 @@ L_stm_s_takeabort:
|
|||||||
case 0x19:
|
case 0x19:
|
||||||
/* ldrex */
|
/* ldrex */
|
||||||
if (BITS(4, 7) == 0x9) {
|
if (BITS(4, 7) == 0x9) {
|
||||||
lhs = LHS;
|
u32 lhs = LHS;
|
||||||
|
|
||||||
state->currentexaddr = lhs;
|
state->currentexaddr = lhs;
|
||||||
state->currentexval = ARMul_ReadWord(state, lhs);
|
state->currentexval = ARMul_ReadWord(state, lhs);
|
||||||
@ -5763,7 +5760,7 @@ L_stm_s_takeabort:
|
|||||||
case 0x1c:
|
case 0x1c:
|
||||||
if (BITS(4, 7) == 0x9) {
|
if (BITS(4, 7) == 0x9) {
|
||||||
/* strexb */
|
/* strexb */
|
||||||
lhs = LHS;
|
u32 lhs = LHS;
|
||||||
|
|
||||||
bool enter = false;
|
bool enter = false;
|
||||||
|
|
||||||
@ -5793,11 +5790,11 @@ L_stm_s_takeabort:
|
|||||||
case 0x1d:
|
case 0x1d:
|
||||||
if ((BITS(4, 7)) == 0x9) {
|
if ((BITS(4, 7)) == 0x9) {
|
||||||
/* ldrexb */
|
/* ldrexb */
|
||||||
temp = LHS;
|
u32 lhs = LHS;
|
||||||
LoadByte(state, instr, temp, LUNSIGNED);
|
LoadByte(state, instr, lhs, LUNSIGNED);
|
||||||
|
|
||||||
state->currentexaddr = temp;
|
state->currentexaddr = lhs;
|
||||||
state->currentexval = (u32)ARMul_ReadByte(state, temp);
|
state->currentexval = (u32)ARMul_ReadByte(state, lhs);
|
||||||
|
|
||||||
//state->Reg[BITS(12, 15)] = ARMul_LoadByte(state, state->Reg[BITS(16, 19)]);
|
//state->Reg[BITS(12, 15)] = ARMul_LoadByte(state, state->Reg[BITS(16, 19)]);
|
||||||
//printf("ldrexb\n");
|
//printf("ldrexb\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user