diff options
author | notaz | 2011-02-05 01:31:47 +0200 |
---|---|---|
committer | notaz | 2011-02-09 14:59:32 +0200 |
commit | 018f9fea66b5ec11e4e7037d34f289e357b4873f (patch) | |
tree | 96ff03b93eb3e1e146159c3322d2273e942d1762 /libpcsxcore/new_dynarec | |
parent | 7cd19de2fd689b38596df1c5821ce02f845dc654 (diff) | |
download | pcsx_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.s | 14 |
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 |