aboutsummaryrefslogtreecommitdiff
path: root/libpcsxcore/new_dynarec
diff options
context:
space:
mode:
authornotaz2010-12-10 17:57:35 +0200
committernotaz2010-12-14 15:25:05 +0200
commit28bc5688589e5f2d6cfa86bb22441e763de468cd (patch)
tree1ba279382d93edf79b2ce9e57c2ef55d07098cfd /libpcsxcore/new_dynarec
parentccf51908872ddeb811b1245e6751600b860d90b5 (diff)
downloadpcsx_rearmed-28bc5688589e5f2d6cfa86bb22441e763de468cd.tar.gz
pcsx_rearmed-28bc5688589e5f2d6cfa86bb22441e763de468cd.tar.bz2
pcsx_rearmed-28bc5688589e5f2d6cfa86bb22441e763de468cd.zip
drc: hook even to detect irq unmasking
Diffstat (limited to 'libpcsxcore/new_dynarec')
-rw-r--r--libpcsxcore/new_dynarec/emu_if.c33
-rw-r--r--libpcsxcore/new_dynarec/linkage_arm.s1
2 files changed, 17 insertions, 17 deletions
diff --git a/libpcsxcore/new_dynarec/emu_if.c b/libpcsxcore/new_dynarec/emu_if.c
index 3403d45..08d9f57 100644
--- a/libpcsxcore/new_dynarec/emu_if.c
+++ b/libpcsxcore/new_dynarec/emu_if.c
@@ -14,16 +14,7 @@
#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)
{
@@ -54,7 +45,6 @@ static void schedule_timeslice(void)
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;
@@ -70,6 +60,15 @@ void gen_interupt()
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");
@@ -82,37 +81,37 @@ void read_nomem_new()
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()
{
- 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()
{
- 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()
{
- 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()
{
- 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()
{
- 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);
}
diff --git a/libpcsxcore/new_dynarec/linkage_arm.s b/libpcsxcore/new_dynarec/linkage_arm.s
index 5b7d783..b13df81 100644
--- a/libpcsxcore/new_dynarec/linkage_arm.s
+++ b/libpcsxcore/new_dynarec/linkage_arm.s
@@ -587,6 +587,7 @@ cc_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]