JitCache: Also unlink exits of the current block.
We might still be in the current block. This is fine, but the next one might also be invalidated later on. But we may never also call the next one.
This commit is contained in:
parent
c1ddc2678e
commit
ffa61fcf57
|
@ -315,8 +315,14 @@ void JitBaseBlockCache::LinkBlock(JitBlock& block)
|
||||||
|
|
||||||
void JitBaseBlockCache::UnlinkBlock(const JitBlock& block)
|
void JitBaseBlockCache::UnlinkBlock(const JitBlock& block)
|
||||||
{
|
{
|
||||||
auto ppp = links_to.equal_range(block.effectiveAddress);
|
// Unlink all exits of this block.
|
||||||
|
for (auto& e : block.linkData)
|
||||||
|
{
|
||||||
|
WriteLinkBlock(e, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unlink all exits of other blocks which points to this block
|
||||||
|
auto ppp = links_to.equal_range(block.effectiveAddress);
|
||||||
for (auto iter = ppp.first; iter != ppp.second; ++iter)
|
for (auto iter = ppp.first; iter != ppp.second; ++iter)
|
||||||
{
|
{
|
||||||
JitBlock& sourceBlock = *iter->second;
|
JitBlock& sourceBlock = *iter->second;
|
||||||
|
|
Loading…
Reference in New Issue