drc: hook even to detect irq unmasking
authornotaz <notasas@gmail.com>
Fri, 10 Dec 2010 15:57:35 +0000 (17:57 +0200)
committernotaz <notasas@gmail.com>
Tue, 14 Dec 2010 13:25:05 +0000 (15:25 +0200)
libpcsxcore/new_dynarec/emu_if.c
libpcsxcore/new_dynarec/linkage_arm.s
libpcsxcore/psxhw.c
libpcsxcore/psxmem.h

index 3403d45..08d9f57 100644 (file)
 #define evprintf(...)
 
 char invalid_code[0x100000];
 #define evprintf(...)
 
 char invalid_code[0x100000];
-u32 event_cycles[6];
-
-void MTC0_()
-{
-       extern void psxMTC0();
-
-       memprintf("ari64 MTC0 %08x\n", psxRegs.code);
-       psxMTC0();
-       pending_exception = 1; /* FIXME? */
-}
+u32 event_cycles[7];
 
 static void schedule_timeslice(void)
 {
 
 static void schedule_timeslice(void)
 {
@@ -54,7 +45,6 @@ static void schedule_timeslice(void)
 
 void gen_interupt()
 {
 
 void gen_interupt()
 {
-       //evprintf("ari64_gen_interupt\n");
        evprintf("  +ge %08x, %u->%u\n", psxRegs.pc, psxRegs.cycle, next_interupt);
 #ifdef DRC_DBG
        psxRegs.cycle += 2;
        evprintf("  +ge %08x, %u->%u\n", psxRegs.pc, psxRegs.cycle, next_interupt);
 #ifdef DRC_DBG
        psxRegs.cycle += 2;
@@ -70,6 +60,15 @@ void gen_interupt()
        pending_exception = 1; /* FIXME */
 }
 
        pending_exception = 1; /* FIXME */
 }
 
+void MTC0_()
+{
+       extern void psxMTC0();
+
+       evprintf("ari64 MTC0 %08x %08x %u\n", psxRegs.code, psxRegs.pc, psxRegs.cycle);
+       psxMTC0();
+       gen_interupt(); /* FIXME: checking pending irqs should be enough */
+}
+
 void check_interupt()
 {
        printf("ari64_check_interupt\n");
 void check_interupt()
 {
        printf("ari64_check_interupt\n");
@@ -82,37 +81,37 @@ void read_nomem_new()
 
 static void read_mem8()
 {
 
 static void read_mem8()
 {
-       memprintf("ari64_read_mem8  %08x, PC~=%08x\n", address, psxRegs.pc);
+       memprintf("ari64_read_mem8  %08x @%08x %u\n", address, psxRegs.pc, psxRegs.cycle);
        readmem_word = psxMemRead8(address) & 0xff;
 }
 
 static void read_mem16()
 {
        readmem_word = psxMemRead8(address) & 0xff;
 }
 
 static void read_mem16()
 {
-       memprintf("ari64_read_mem16 %08x, PC~=%08x\n", address, psxRegs.pc);
+       memprintf("ari64_read_mem16 %08x @%08x %u\n", address, psxRegs.pc, psxRegs.cycle);
        readmem_word = psxMemRead16(address) & 0xffff;
 }
 
 static void read_mem32()
 {
        readmem_word = psxMemRead16(address) & 0xffff;
 }
 
 static void read_mem32()
 {
-       memprintf("ari64_read_mem32 %08x, PC~=%08x\n", address, psxRegs.pc);
+       memprintf("ari64_read_mem32 %08x @%08x %u\n", address, psxRegs.pc, psxRegs.cycle);
        readmem_word = psxMemRead32(address);
 }
 
 static void write_mem8()
 {
        readmem_word = psxMemRead32(address);
 }
 
 static void write_mem8()
 {
-       memprintf("ari64_write_mem8  %08x,       %02x, PC~=%08x\n", address, byte, psxRegs.pc);
+       memprintf("ari64_write_mem8  %08x,       %02x @%08x %u\n", address, byte, psxRegs.pc, psxRegs.cycle);
        psxMemWrite8(address, byte);
 }
 
 static void write_mem16()
 {
        psxMemWrite8(address, byte);
 }
 
 static void write_mem16()
 {
-       memprintf("ari64_write_mem16 %08x,     %04x, PC~=%08x\n", address, hword, psxRegs.pc);
+       memprintf("ari64_write_mem16 %08x,     %04x @%08x %u\n", address, hword, psxRegs.pc, psxRegs.cycle);
        psxMemWrite16(address, hword);
 }
 
 static void write_mem32()
 {
        psxMemWrite16(address, hword);
 }
 
 static void write_mem32()
 {
-       memprintf("ari64_write_mem32 %08x, %08x, PC~=%08x\n", address, word, psxRegs.pc);
+       memprintf("ari64_write_mem32 %08x, %08x @%08x %u\n", address, word, psxRegs.pc, psxRegs.cycle);
        psxMemWrite32(address, word);
 }
 
        psxMemWrite32(address, word);
 }
 
index 5b7d783..b13df81 100644 (file)
@@ -587,6 +587,7 @@ cc_interrupt:
        .global do_interrupt
        .type   do_interrupt, %function
 do_interrupt:
        .global do_interrupt
        .type   do_interrupt, %function
 do_interrupt:
+       /* FIXME: cycles already calculated, not needed? */
        ldr     r0, [fp, #pcaddr-dynarec_local]
        bl      get_addr_ht
        ldr     r1, [fp, #next_interupt-dynarec_local]
        ldr     r0, [fp, #pcaddr-dynarec_local]
        bl      get_addr_ht
        ldr     r1, [fp, #next_interupt-dynarec_local]
index 9123f76..f265e19 100644 (file)
@@ -431,6 +431,8 @@ void psxHwWrite16(u32 add, u16 value) {
                        PSXHW_LOG("IMASK 16bit write %x\n", value);
 #endif
                        psxHu16ref(0x1074) = SWAPu16(value);
                        PSXHW_LOG("IMASK 16bit write %x\n", value);
 #endif
                        psxHu16ref(0x1074) = SWAPu16(value);
+                       if (psxHu16ref(0x1070) & value)
+                               new_dyna_set_event(6, 1);
                        return;
 
                case 0x1f801100:
                        return;
 
                case 0x1f801100:
@@ -543,6 +545,8 @@ void psxHwWrite32(u32 add, u32 value) {
                        PSXHW_LOG("IMASK 32bit write %x\n", value);
 #endif
                        psxHu32ref(0x1074) = SWAPu32(value);
                        PSXHW_LOG("IMASK 32bit write %x\n", value);
 #endif
                        psxHu32ref(0x1074) = SWAPu32(value);
+                       if (psxHu32ref(0x1070) & value)
+                               new_dyna_set_event(6, 1);
                        return;
 
 #ifdef PSXHW_LOG
                        return;
 
 #ifdef PSXHW_LOG
index b409603..a5c6c4a 100644 (file)
@@ -138,7 +138,7 @@ void psxMemWrite16(u32 mem, u16 value);
 void psxMemWrite32(u32 mem, u32 value);
 void *psxMemPointer(u32 mem);
 
 void psxMemWrite32(u32 mem, u32 value);
 void *psxMemPointer(u32 mem);
 
-extern u32 event_cycles[6];
+extern u32 event_cycles[7];
 extern u32 next_interupt;
 
 #define new_dyna_set_event(e, c) { \
 extern u32 next_interupt;
 
 #define new_dyna_set_event(e, c) { \