- fix IRQ handler for ARM7 when use external SWI (big speedup);
This commit is contained in:
mtabachenko 2010-07-04 15:19:16 +00:00
parent 54c80ae16e
commit b1db5d2080
3 changed files with 91 additions and 58 deletions

View File

@ -1074,7 +1074,7 @@ static void execdiv() {
} }
// TODO: // TODO:
// NAND flash support (used in Made in Ore/WariWare D.I.Y.) // NAND flash support (used in Made in Ore/WarioWare D.I.Y.)
template<int PROCNUM> template<int PROCNUM>
void FASTCALL MMU_writeToGCControl(u32 val) void FASTCALL MMU_writeToGCControl(u32 val)
{ {
@ -1146,7 +1146,9 @@ void FASTCALL MMU_writeToGCControl(u32 val)
case 0x85: case 0x85:
{ {
card.address = 0; card.address = 0;
card.transfer_count = 0x80; //card.transfer_count = 0x80;
// needs for WarioWare D.I.Y - ingame saves don't work but game don't freeze in main menu
card.transfer_count = 0;
} }
break; break;
@ -3657,8 +3659,7 @@ void FASTCALL _MMU_ARM7_write08(u32 adr, u8 val)
switch(val) switch(val)
{ {
case 0xC0: NDS_Sleep(); break; case 0xC0: NDS_Sleep(); break;
// TODO: its break firmware booting? but BIG speedup with ext. SWI case 0x80: armcpu_Wait4IRQ(&NDS_ARM7); break;
//case 0x80: NDS_ARM7.waitIRQ = 1; break;
default: break; default: break;
} }
break; break;

View File

@ -371,6 +371,35 @@ u32 armcpu_switchMode(armcpu_t *armcpu, u8 mode)
return oldmode; return oldmode;
} }
u32 armcpu_Wait4IRQ(armcpu_t *cpu)
{
u32 instructAddr = cpu->instruct_adr;
// on the first call, wirq is not set
if(cpu->wirq)
{
// check wether an irq was issued
if(!cpu->waitIRQ)
{
cpu->waitIRQ = 0;
cpu->wirq = 0;
return 1; // return execution
}
// otherwise, repeat this instruction
cpu->R[15] = instructAddr;
cpu->next_instruction = instructAddr;
return 1;
}
// first run, set us into waiting state
cpu->waitIRQ = 1;
cpu->wirq = 1;
// and set next instruction to repeat this
cpu->R[15] = instructAddr;
cpu->next_instruction = instructAddr;
// only SWI set IME to 1
return 1;
}
template<u32 PROCNUM> template<u32 PROCNUM>
FORCEINLINE static u32 armcpu_prefetch() FORCEINLINE static u32 armcpu_prefetch()
{ {
@ -554,7 +583,8 @@ BOOL armcpu_irqException(armcpu_t *armcpu)
u32 TRAPUNDEF(armcpu_t* cpu) u32 TRAPUNDEF(armcpu_t* cpu)
{ {
LOG("Undefined instruction: %#08X PC = %#08X \n", cpu->instruction, cpu->instruct_adr); INFO("ARM%c: Undefined instruction: 0x%08X (%s) PC=0x%08X\n", cpu->proc_ID?'7':'9', cpu->instruction, decodeIntruction(false, cpu->instruction), cpu->instruct_adr);
if (((cpu->intVector != 0) ^ (cpu->proc_ID == ARMCPU_ARM9))) if (((cpu->intVector != 0) ^ (cpu->proc_ID == ARMCPU_ARM9)))
{ {
armcpu_exception(&NDS_ARM9,0x04); armcpu_exception(&NDS_ARM9,0x04);
@ -592,59 +622,60 @@ u32 armcpu_exec()
//this assert is annoying. but sometimes it is handy. //this assert is annoying. but sometimes it is handy.
//assert(ARMPROC.instruct_adr!=0x00000000); //assert(ARMPROC.instruct_adr!=0x00000000);
//#ifdef DEVELOPER //#ifdef DEVELOPER
// if ((((ARMPROC.instruct_adr & 0x0F000000) == 0x0F000000) && (PROCNUM == 0)) || #if 0
// (((ARMPROC.instruct_adr & 0x0F000000) == 0x00000000) && (PROCNUM == 1))) if ((((ARMPROC.instruct_adr & 0x0F000000) == 0x0F000000) && (PROCNUM == 0)) ||
// { (((ARMPROC.instruct_adr & 0x0F000000) == 0x00000000) && (PROCNUM == 1)))
// switch (ARMPROC.instruct_adr & 0xFFFF) {
// { switch (ARMPROC.instruct_adr & 0xFFFF)
// case 0x00000000: {
// printf("BIOS%c: Reset!!!\n", PROCNUM?'7':'9'); case 0x00000000:
// emu_halt(); printf("BIOS%c: Reset!!!\n", PROCNUM?'7':'9');
// break; emu_halt();
// case 0x00000004: break;
// printf("BIOS%c: Undefined instruction\n", PROCNUM?'7':'9'); case 0x00000004:
// //emu_halt(); printf("BIOS%c: Undefined instruction\n", PROCNUM?'7':'9');
// break; //emu_halt();
// case 0x00000008: break;
// //printf("BIOS%c: SWI\n", PROCNUM?'7':'9'); case 0x00000008:
// break; //printf("BIOS%c: SWI\n", PROCNUM?'7':'9');
// case 0x0000000C: break;
// printf("BIOS%c: Prefetch Abort!!!\n", PROCNUM?'7':'9'); case 0x0000000C:
// //emu_halt(); printf("BIOS%c: Prefetch Abort!!!\n", PROCNUM?'7':'9');
// break; //emu_halt();
// case 0x00000010: break;
// //printf("BIOS%c: Data Abort!!!\n", PROCNUM?'7':'9'); case 0x00000010:
// //emu_halt(); //printf("BIOS%c: Data Abort!!!\n", PROCNUM?'7':'9');
// break; //emu_halt();
// case 0x00000014: break;
// printf("BIOS%c: Reserved!!!\n", PROCNUM?'7':'9'); case 0x00000014:
// break; printf("BIOS%c: Reserved!!!\n", PROCNUM?'7':'9');
// case 0x00000018: break;
// //printf("BIOS%c: IRQ\n", PROCNUM?'7':'9'); case 0x00000018:
// break; //printf("BIOS%c: IRQ\n", PROCNUM?'7':'9');
// case 0x0000001C: break;
// printf("BIOS%c: Fast IRQ\n", PROCNUM?'7':'9'); case 0x0000001C:
// break; printf("BIOS%c: Fast IRQ\n", PROCNUM?'7':'9');
// } break;
// } }
//#endif }
// #endif
//#ifdef GDB_STUB
// if (ARMPROC.stalled) { #ifdef GDB_STUB
// return STALLED_CYCLE_COUNT; if (ARMPROC.stalled) {
// } return STALLED_CYCLE_COUNT;
// }
// /* check for interrupts */
// if (ARMPROC.irq_flag) { /* check for interrupts */
// armcpu_irqException(&ARMPROC); if (ARMPROC.irq_flag) {
// } armcpu_irqException(&ARMPROC);
// }
// cFetch = armcpu_prefetch(&ARMPROC);
// cFetch = armcpu_prefetch(&ARMPROC);
// if (ARMPROC.stalled) {
// return MMU_fetchExecuteCycles<PROCNUM>(cExecute, cFetch); if (ARMPROC.stalled) {
// } return MMU_fetchExecuteCycles<PROCNUM>(cExecute, cFetch);
//#endif }
#endif
//cFetch = armcpu_prefetch(&ARMPROC); //cFetch = armcpu_prefetch(&ARMPROC);

View File

@ -253,6 +253,7 @@ BOOL armcpu_irqException(armcpu_t *armcpu);
BOOL armcpu_flagIrq( armcpu_t *armcpu); BOOL armcpu_flagIrq( armcpu_t *armcpu);
void armcpu_exception(armcpu_t *cpu, u32 number); void armcpu_exception(armcpu_t *cpu, u32 number);
u32 TRAPUNDEF(armcpu_t* cpu); u32 TRAPUNDEF(armcpu_t* cpu);
u32 armcpu_Wait4IRQ(armcpu_t *cpu);
extern armcpu_t NDS_ARM7; extern armcpu_t NDS_ARM7;
extern armcpu_t NDS_ARM9; extern armcpu_t NDS_ARM9;