enabling cache emulation. this seems to fix timing bugs in several games. we can worry about the speed later.
This commit is contained in:
parent
6cf200b1e1
commit
0accc4eaf8
|
@ -53,8 +53,7 @@
|
||||||
#define ACCOUNT_FOR_DATA_TCM_SPEED
|
#define ACCOUNT_FOR_DATA_TCM_SPEED
|
||||||
|
|
||||||
// enables simulation of cache hits and cache misses.
|
// enables simulation of cache hits and cache misses.
|
||||||
// currently disabled for a few FPS of emulator speedup.
|
#define ENABLE_CACHE_CONTROLLER_EMULATION
|
||||||
//#define ENABLE_CACHE_CONTROLLER_EMULATION
|
|
||||||
|
|
||||||
//
|
//
|
||||||
////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////
|
||||||
|
@ -283,9 +282,20 @@ FORCEINLINE u32 _MMU_accesstime(u32 addr, bool sequential)
|
||||||
cached = MMU_timing.arm9dataCache.Cached<DIRECTION>(addr);
|
cached = MMU_timing.arm9dataCache.Cached<DIRECTION>(addr);
|
||||||
if(cached)
|
if(cached)
|
||||||
return MC;
|
return MC;
|
||||||
|
u32 c;
|
||||||
if(sequential && AT==MMU_AT_DATA)
|
if(sequential && AT==MMU_AT_DATA)
|
||||||
return M16;
|
c = M16; // bonus for sequential data access
|
||||||
return M16 * ((DIRECTION == MMU_AD_READ) ? 5 : 4);
|
else if(DIRECTION == MMU_AD_READ)
|
||||||
|
c = M16 * 5;
|
||||||
|
else
|
||||||
|
c = M16 * 2; // should be 4, but write buffer isn't emulated yet.
|
||||||
|
if(DIRECTION == MMU_AD_READ)
|
||||||
|
{
|
||||||
|
// cache miss while reading means it has to fill a whole cache line
|
||||||
|
// by reading 32 bytes...
|
||||||
|
c += 8 * M32*2;
|
||||||
|
}
|
||||||
|
return c;
|
||||||
#elif defined(ACCOUNT_FOR_NON_SEQUENTIAL_ACCESS)
|
#elif defined(ACCOUNT_FOR_NON_SEQUENTIAL_ACCESS)
|
||||||
// this is the closest approximation I could find
|
// this is the closest approximation I could find
|
||||||
// to the with-cache-controller timing
|
// to the with-cache-controller timing
|
||||||
|
|
Loading…
Reference in New Issue