mirror of
https://git.h3cjp.net/H3cJP/citra.git
synced 2025-01-07 07:46:59 +00:00
video_core: rasterizer_accelerated: Improve error handling & fix implicit conversion.
This commit is contained in:
parent
94da1e8a7e
commit
6ab839462c
|
@ -20,9 +20,15 @@ void RasterizerAccelerated::UpdatePagesCachedCount(VAddr addr, u64 size, int del
|
||||||
for (auto page = addr >> Core::Memory::PAGE_BITS; page != page_end; ++page) {
|
for (auto page = addr >> Core::Memory::PAGE_BITS; page != page_end; ++page) {
|
||||||
auto& count = cached_pages.at(page >> 3).Count(page);
|
auto& count = cached_pages.at(page >> 3).Count(page);
|
||||||
|
|
||||||
ASSERT_MSG(count < UINT8_MAX, "Count may exceed UINT8_MAX!");
|
if (delta < 0) {
|
||||||
|
ASSERT_MSG(count > 0, "Count may underflow!");
|
||||||
|
} else if (delta > 0) {
|
||||||
|
ASSERT_MSG(count < UINT8_MAX, "Count may overflow!");
|
||||||
|
} else {
|
||||||
|
ASSERT_MSG(true, "Delta must be non-zero!");
|
||||||
|
}
|
||||||
|
|
||||||
count += delta;
|
count += static_cast<s8>(delta);
|
||||||
|
|
||||||
// Assume delta is either -1 or 1
|
// Assume delta is either -1 or 1
|
||||||
if (count == 0) {
|
if (count == 0) {
|
||||||
|
@ -31,8 +37,6 @@ void RasterizerAccelerated::UpdatePagesCachedCount(VAddr addr, u64 size, int del
|
||||||
} else if (count == 1 && delta > 0) {
|
} else if (count == 1 && delta > 0) {
|
||||||
cpu_memory.RasterizerMarkRegionCached(page << Core::Memory::PAGE_BITS,
|
cpu_memory.RasterizerMarkRegionCached(page << Core::Memory::PAGE_BITS,
|
||||||
Core::Memory::PAGE_SIZE, true);
|
Core::Memory::PAGE_SIZE, true);
|
||||||
} else {
|
|
||||||
ASSERT(count >= 0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue