aboutsummaryrefslogtreecommitdiff
path: root/libpcsxcore/new_dynarec
diff options
context:
space:
mode:
authornotaz2011-02-05 01:31:47 +0200
committernotaz2011-02-09 14:59:32 +0200
commit018f9fea66b5ec11e4e7037d34f289e357b4873f (patch)
tree96ff03b93eb3e1e146159c3322d2273e942d1762 /libpcsxcore/new_dynarec
parent7cd19de2fd689b38596df1c5821ce02f845dc654 (diff)
downloadpcsx_rearmed-018f9fea66b5ec11e4e7037d34f289e357b4873f.tar.gz
pcsx_rearmed-018f9fea66b5ec11e4e7037d34f289e357b4873f.tar.bz2
pcsx_rearmed-018f9fea66b5ec11e4e7037d34f289e357b4873f.zip
drc: update memhandler according to pcsxr code
Diffstat (limited to 'libpcsxcore/new_dynarec')
-rw-r--r--libpcsxcore/new_dynarec/linkage_arm.s14
1 files changed, 12 insertions, 2 deletions
diff --git a/libpcsxcore/new_dynarec/linkage_arm.s b/libpcsxcore/new_dynarec/linkage_arm.s
index 7b76aec..8744608 100644
--- a/libpcsxcore/new_dynarec/linkage_arm.s
+++ b/libpcsxcore/new_dynarec/linkage_arm.s
@@ -1000,13 +1000,23 @@ ari_read_io32:
str\pf r1, [r2, r3]
mov pc, lr
1:
-.if \tab_shift == 1 @ write16
cmp r2, #0x1c00
blo 0b
cmp r2, #0x1e00
+.if \tab_shift != 0
ldrlo pc, [fp, #spu_writef-dynarec_local]
- nop
+.else
+ @ write32 to SPU - very rare case (is this correct?)
+ bhs 0b
+ add r2, r0, #2
+ mov r3, r1, lsr #16
+ push {r2,r3,lr}
+ mov lr, pc
+ ldr pc, [fp, #spu_writef-dynarec_local]
+ pop {r0,r1,lr}
+ ldr pc, [fp, #spu_writef-dynarec_local]
.endif
+ nop
b 0b
.endm