JitCache: Use a pointer in block_map.
This commit is contained in:
parent
74a27d9742
commit
928ccbef53
|
@ -153,7 +153,7 @@ void JitBaseBlockCache::FinalizeBlock(JitBlock& b, bool block_link, const u8* co
|
||||||
for (u32 block = pAddr / 32; block <= (pAddr + (b.originalSize - 1) * 4) / 32; ++block)
|
for (u32 block = pAddr / 32; block <= (pAddr + (b.originalSize - 1) * 4) / 32; ++block)
|
||||||
valid_block.Set(block);
|
valid_block.Set(block);
|
||||||
|
|
||||||
block_map[std::make_pair(pAddr + 4 * b.originalSize - 1, pAddr)] = block_num;
|
block_map[std::make_pair(pAddr + 4 * b.originalSize - 1, pAddr)] = &b;
|
||||||
|
|
||||||
if (block_link)
|
if (block_link)
|
||||||
{
|
{
|
||||||
|
@ -233,7 +233,7 @@ void JitBaseBlockCache::InvalidateICache(u32 address, const u32 length, bool for
|
||||||
auto it = block_map.lower_bound(std::make_pair(pAddr, 0));
|
auto it = block_map.lower_bound(std::make_pair(pAddr, 0));
|
||||||
while (it != block_map.end() && it->first.second < pAddr + length)
|
while (it != block_map.end() && it->first.second < pAddr + length)
|
||||||
{
|
{
|
||||||
DestroyBlock(blocks[it->second], true);
|
DestroyBlock(*it->second, true);
|
||||||
it = block_map.erase(it);
|
it = block_map.erase(it);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -177,7 +177,7 @@ private:
|
||||||
|
|
||||||
// Map indexed by the physical memory location.
|
// Map indexed by the physical memory location.
|
||||||
// It is used to invalidate blocks based on memory location.
|
// It is used to invalidate blocks based on memory location.
|
||||||
std::map<std::pair<u32, u32>, u32> block_map; // (end_addr, start_addr) -> number
|
std::map<std::pair<u32, u32>, JitBlock*> block_map; // (end_addr, start_addr) -> block
|
||||||
|
|
||||||
// Map indexed by the physical address of the entry point.
|
// Map indexed by the physical address of the entry point.
|
||||||
// This is used to query the block based on the current PC in a slow way.
|
// This is used to query the block based on the current PC in a slow way.
|
||||||
|
|
Loading…
Reference in New Issue