2015-05-24 06:55:12 +02:00
|
|
|
// Copyright 2008 Dolphin Emulator Project
|
2015-05-18 01:08:10 +02:00
|
|
|
// Licensed under GPLv2+
|
2013-04-17 22:43:11 -04:00
|
|
|
// Refer to the license.txt file included.
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-02-10 13:54:46 -05:00
|
|
|
#pragma once
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-02-17 05:18:15 -05:00
|
|
|
#include "Common/CommonTypes.h"
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2017-01-18 22:52:56 -05:00
|
|
|
class PointerWrap;
|
|
|
|
|
|
2010-06-09 01:37:08 +00:00
|
|
|
namespace PowerPC
|
|
|
|
|
{
|
2016-06-24 10:43:46 +02:00
|
|
|
const u32 ICACHE_SETS = 128;
|
|
|
|
|
const u32 ICACHE_WAYS = 8;
|
|
|
|
|
// size of an instruction cache block in words
|
|
|
|
|
const u32 ICACHE_BLOCK_SIZE = 8;
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
const u32 ICACHE_EXRAM_BIT = 0x10000000;
|
|
|
|
|
const u32 ICACHE_VMEM_BIT = 0x20000000;
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
struct InstructionCache
|
|
|
|
|
{
|
|
|
|
|
u32 data[ICACHE_SETS][ICACHE_WAYS][ICACHE_BLOCK_SIZE];
|
|
|
|
|
u32 tags[ICACHE_SETS][ICACHE_WAYS];
|
|
|
|
|
u32 plru[ICACHE_SETS];
|
|
|
|
|
u32 valid[ICACHE_SETS];
|
|
|
|
|
|
|
|
|
|
u32 way_from_valid[255];
|
|
|
|
|
u32 way_from_plru[128];
|
|
|
|
|
|
|
|
|
|
u8 lookup_table[1 << 20];
|
|
|
|
|
u8 lookup_table_ex[1 << 21];
|
|
|
|
|
u8 lookup_table_vmem[1 << 20];
|
|
|
|
|
|
|
|
|
|
InstructionCache();
|
|
|
|
|
u32 ReadInstruction(u32 addr);
|
|
|
|
|
void Invalidate(u32 addr);
|
|
|
|
|
void Init();
|
|
|
|
|
void Reset();
|
2017-01-18 22:52:56 -05:00
|
|
|
void DoState(PointerWrap& p);
|
2016-06-24 10:43:46 +02:00
|
|
|
};
|
2017-01-18 22:52:56 -05:00
|
|
|
} // namespace PowerPC
|