-Added some SWI changes Mighty Max sent me. Relocating SWI routines should work now.
This commit is contained in:
parent
c5c1ac7895
commit
2f32db41cb
|
@ -7772,10 +7772,28 @@ static u32 FASTCALL OP_MRC(armcpu_t *cpu)
|
|||
|
||||
//--------------SWI-------------------------------
|
||||
static u32 FASTCALL OP_SWI(armcpu_t *cpu)
|
||||
{
|
||||
if (((cpu->intVector != 0) ^ (cpu->proc_ID == ARMCPU_ARM9)))
|
||||
{
|
||||
/* TODO (#1#): translocated SWI vectors */
|
||||
/* we use an irq thats not in the irq tab, as
|
||||
it was replaced duie to a changed intVector */
|
||||
Status_Reg tmp = cpu->CPSR;
|
||||
armcpu_switchMode(cpu, SVC); /* enter svc mode */
|
||||
cpu->R[14] = cpu->R[15] - 4; /* jump to swi Vector */
|
||||
cpu->SPSR = tmp; /* save old CPSR as new SPSR */
|
||||
cpu->CPSR.bits.T = 0; /* handle as ARM32 code */
|
||||
cpu->CPSR.bits.I = cpu->SPSR.bits.I; /* keep int disable flag */
|
||||
cpu->R[15] = cpu->intVector + 0x08;
|
||||
cpu->next_instruction = cpu->R[15];
|
||||
return 4;
|
||||
}
|
||||
else
|
||||
{
|
||||
u32 swinum = (cpu->instruction>>16)&0x1F;
|
||||
return cpu->swi_tab[swinum](cpu) + 3;
|
||||
}
|
||||
}
|
||||
|
||||
//----------------BKPT-------------------------
|
||||
static u32 FASTCALL OP_BKPT(armcpu_t *cpu)
|
||||
|
|
|
@ -860,9 +860,26 @@ static u32 FASTCALL OP_B_COND(armcpu_t *cpu)
|
|||
}
|
||||
|
||||
static u32 FASTCALL OP_SWI_THUMB(armcpu_t *cpu)
|
||||
{
|
||||
if (((cpu->intVector != 0) ^ (cpu->proc_ID == ARMCPU_ARM9)))
|
||||
{
|
||||
/* we use an irq thats not in the irq tab, as
|
||||
it was replaced duie to a changed intVector */
|
||||
Status_Reg tmp = cpu->CPSR;
|
||||
armcpu_switchMode(cpu, SVC); /* enter svc mode */
|
||||
cpu->R[14] = cpu->R[15] - 4; /* jump to swi Vector */
|
||||
cpu->SPSR = tmp; /* save old CPSR as new SPSR */
|
||||
cpu->CPSR.bits.T = 0; /* handle as ARM32 code */
|
||||
cpu->CPSR.bits.I = cpu->SPSR.bits.I; /* keep int disable flag */
|
||||
cpu->R[15] = cpu->intVector + 0x08;
|
||||
cpu->next_instruction = cpu->R[15];
|
||||
return 3;
|
||||
}
|
||||
else
|
||||
{
|
||||
u32 swinum = cpu->instruction & 0xFF;
|
||||
return cpu->swi_tab[swinum](cpu) + 3;
|
||||
}
|
||||
//return 3;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue