diff options
author | notaz | 2011-01-26 18:31:27 +0200 |
---|---|---|
committer | notaz | 2011-01-26 18:31:27 +0200 |
commit | 0ce47d46e07dfb02f3eeef481b963927beeee481 (patch) | |
tree | eda32f73e1dcdaeb6b694dfaf02c412f95900324 /libpcsxcore/new_dynarec/new_dynarec.c | |
parent | 68b3faeed93986cef07197ee2471a9e561803dbc (diff) | |
download | pcsx_rearmed-0ce47d46e07dfb02f3eeef481b963927beeee481.tar.gz pcsx_rearmed-0ce47d46e07dfb02f3eeef481b963927beeee481.tar.bz2 pcsx_rearmed-0ce47d46e07dfb02f3eeef481b963927beeee481.zip |
drc: invalidate RAM mirrors correctly
Diffstat (limited to 'libpcsxcore/new_dynarec/new_dynarec.c')
-rw-r--r-- | libpcsxcore/new_dynarec/new_dynarec.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/libpcsxcore/new_dynarec/new_dynarec.c b/libpcsxcore/new_dynarec/new_dynarec.c index b2b5d28..abfd834 100644 --- a/libpcsxcore/new_dynarec/new_dynarec.c +++ b/libpcsxcore/new_dynarec/new_dynarec.c @@ -309,7 +309,14 @@ static void tlb_hacks() static u_int get_page(u_int vaddr) { +#ifndef PCSX u_int page=(vaddr^0x80000000)>>12; +#else + u_int page=vaddr&~0xe0000000; + if (page < 0x1000000) + page &= ~0x0e00000; // RAM mirrors + page>>=12; +#endif #ifndef DISABLE_TLB if(page>262143&&tlb_LUT_r[vaddr>>12]) page=(tlb_LUT_r[vaddr>>12]^0x80000000)>>12; #endif |