Merge pull request #12734 from mitaclaw/assert-dyna_rec
JIT: Fix Incorrect Assert Category
This commit is contained in:
commit
d6bcbd0115
|
@ -741,7 +741,7 @@ void Jit64::Jit(u32 em_address, bool clear_cache_and_retry_on_failure)
|
||||||
{
|
{
|
||||||
if (!SConfig::GetInstance().bJITNoBlockCache)
|
if (!SConfig::GetInstance().bJITNoBlockCache)
|
||||||
{
|
{
|
||||||
WARN_LOG_FMT(POWERPC, "flushing trampoline code cache, please report if this happens a lot");
|
WARN_LOG_FMT(DYNA_REC, "flushing trampoline code cache, please report if this happens a lot");
|
||||||
}
|
}
|
||||||
ClearCache();
|
ClearCache();
|
||||||
}
|
}
|
||||||
|
@ -830,15 +830,14 @@ void Jit64::Jit(u32 em_address, bool clear_cache_and_retry_on_failure)
|
||||||
{
|
{
|
||||||
// Code generation failed due to not enough free space in either the near or far code regions.
|
// Code generation failed due to not enough free space in either the near or far code regions.
|
||||||
// Clear the entire JIT cache and retry.
|
// Clear the entire JIT cache and retry.
|
||||||
WARN_LOG_FMT(POWERPC, "flushing code caches, please report if this happens a lot");
|
WARN_LOG_FMT(DYNA_REC, "flushing code caches, please report if this happens a lot");
|
||||||
ClearCache();
|
ClearCache();
|
||||||
Jit(em_address, false);
|
Jit(em_address, false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PanicAlertFmtT(
|
PanicAlertFmtT("JIT failed to find code space after a cache clear. This should never happen. "
|
||||||
"JIT failed to find code space after a cache clear. This should never happen. Please "
|
"Please report this incident on the bug tracker. Dolphin will now exit.");
|
||||||
"report this incident on the bug tracker. Dolphin will now exit.");
|
|
||||||
std::exit(-1);
|
std::exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -849,7 +848,7 @@ bool Jit64::SetEmitterStateToFreeCodeRegion()
|
||||||
const auto free_near = m_free_ranges_near.by_size_begin();
|
const auto free_near = m_free_ranges_near.by_size_begin();
|
||||||
if (free_near == m_free_ranges_near.by_size_end())
|
if (free_near == m_free_ranges_near.by_size_end())
|
||||||
{
|
{
|
||||||
WARN_LOG_FMT(POWERPC, "Failed to find free memory region in near code region.");
|
WARN_LOG_FMT(DYNA_REC, "Failed to find free memory region in near code region.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
SetCodePtr(free_near.from(), free_near.to());
|
SetCodePtr(free_near.from(), free_near.to());
|
||||||
|
@ -857,7 +856,7 @@ bool Jit64::SetEmitterStateToFreeCodeRegion()
|
||||||
const auto free_far = m_free_ranges_far.by_size_begin();
|
const auto free_far = m_free_ranges_far.by_size_begin();
|
||||||
if (free_far == m_free_ranges_far.by_size_end())
|
if (free_far == m_free_ranges_far.by_size_end())
|
||||||
{
|
{
|
||||||
WARN_LOG_FMT(POWERPC, "Failed to find free memory region in far code region.");
|
WARN_LOG_FMT(DYNA_REC, "Failed to find free memory region in far code region.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
m_far_code.SetCodePtr(free_far.from(), free_far.to());
|
m_far_code.SetCodePtr(free_far.from(), free_far.to());
|
||||||
|
@ -1187,9 +1186,9 @@ bool Jit64::DoJit(u32 em_address, JitBlock* b, u32 nextPC)
|
||||||
if (HasWriteFailed() || m_far_code.HasWriteFailed())
|
if (HasWriteFailed() || m_far_code.HasWriteFailed())
|
||||||
{
|
{
|
||||||
if (HasWriteFailed())
|
if (HasWriteFailed())
|
||||||
WARN_LOG_FMT(POWERPC, "JIT ran out of space in near code region during code generation.");
|
WARN_LOG_FMT(DYNA_REC, "JIT ran out of space in near code region during code generation.");
|
||||||
if (m_far_code.HasWriteFailed())
|
if (m_far_code.HasWriteFailed())
|
||||||
WARN_LOG_FMT(POWERPC, "JIT ran out of space in far code region during code generation.");
|
WARN_LOG_FMT(DYNA_REC, "JIT ran out of space in far code region during code generation.");
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -973,15 +973,14 @@ void JitArm64::Jit(u32 em_address, bool clear_cache_and_retry_on_failure)
|
||||||
{
|
{
|
||||||
// Code generation failed due to not enough free space in either the near or far code regions.
|
// Code generation failed due to not enough free space in either the near or far code regions.
|
||||||
// Clear the entire JIT cache and retry.
|
// Clear the entire JIT cache and retry.
|
||||||
WARN_LOG_FMT(POWERPC, "flushing code caches, please report if this happens a lot");
|
WARN_LOG_FMT(DYNA_REC, "flushing code caches, please report if this happens a lot");
|
||||||
ClearCache();
|
ClearCache();
|
||||||
Jit(em_address, false);
|
Jit(em_address, false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PanicAlertFmtT(
|
PanicAlertFmtT("JIT failed to find code space after a cache clear. This should never happen. "
|
||||||
"JIT failed to find code space after a cache clear. This should never happen. Please "
|
"Please report this incident on the bug tracker. Dolphin will now exit.");
|
||||||
"report this incident on the bug tracker. Dolphin will now exit.");
|
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -992,7 +991,7 @@ bool JitArm64::SetEmitterStateToFreeCodeRegion()
|
||||||
auto free_near = m_free_ranges_near.by_size_begin();
|
auto free_near = m_free_ranges_near.by_size_begin();
|
||||||
if (free_near == m_free_ranges_near.by_size_end())
|
if (free_near == m_free_ranges_near.by_size_end())
|
||||||
{
|
{
|
||||||
WARN_LOG_FMT(POWERPC, "Failed to find free memory region in near code region.");
|
WARN_LOG_FMT(DYNA_REC, "Failed to find free memory region in near code region.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
SetCodePtr(free_near.from(), free_near.to());
|
SetCodePtr(free_near.from(), free_near.to());
|
||||||
|
@ -1000,7 +999,7 @@ bool JitArm64::SetEmitterStateToFreeCodeRegion()
|
||||||
auto free_far = m_free_ranges_far.by_size_begin();
|
auto free_far = m_free_ranges_far.by_size_begin();
|
||||||
if (free_far == m_free_ranges_far.by_size_end())
|
if (free_far == m_free_ranges_far.by_size_end())
|
||||||
{
|
{
|
||||||
WARN_LOG_FMT(POWERPC, "Failed to find free memory region in far code region.");
|
WARN_LOG_FMT(DYNA_REC, "Failed to find free memory region in far code region.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
m_far_code.SetCodePtr(free_far.from(), free_far.to());
|
m_far_code.SetCodePtr(free_far.from(), free_far.to());
|
||||||
|
@ -1276,9 +1275,9 @@ bool JitArm64::DoJit(u32 em_address, JitBlock* b, u32 nextPC)
|
||||||
if (HasWriteFailed() || m_far_code.HasWriteFailed())
|
if (HasWriteFailed() || m_far_code.HasWriteFailed())
|
||||||
{
|
{
|
||||||
if (HasWriteFailed())
|
if (HasWriteFailed())
|
||||||
WARN_LOG_FMT(POWERPC, "JIT ran out of space in near code region during code generation.");
|
WARN_LOG_FMT(DYNA_REC, "JIT ran out of space in near code region during code generation.");
|
||||||
if (m_far_code.HasWriteFailed())
|
if (m_far_code.HasWriteFailed())
|
||||||
WARN_LOG_FMT(POWERPC, "JIT ran out of space in far code region during code generation.");
|
WARN_LOG_FMT(DYNA_REC, "JIT ran out of space in far code region during code generation.");
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue