mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 15:31:17 +01:00
Use ROUND_UP instead of custom bittwiddling.
This commit is contained in:
parent
137856bd00
commit
d797b5d0b5
@ -354,11 +354,11 @@ TextureCache::TCacheEntryBase* TextureCache::Load(const u32 stage)
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
// TexelSizeInNibbles(format) * width * height / 16;
|
// TexelSizeInNibbles(format) * width * height / 16;
|
||||||
const unsigned int bsw = TexDecoder_GetBlockWidthInTexels(texformat) - 1;
|
const unsigned int bsw = TexDecoder_GetBlockWidthInTexels(texformat);
|
||||||
const unsigned int bsh = TexDecoder_GetBlockHeightInTexels(texformat) - 1;
|
const unsigned int bsh = TexDecoder_GetBlockHeightInTexels(texformat);
|
||||||
|
|
||||||
unsigned int expandedWidth = (width + bsw) & (~bsw);
|
unsigned int expandedWidth = ROUND_UP(width, bsw);
|
||||||
unsigned int expandedHeight = (height + bsh) & (~bsh);
|
unsigned int expandedHeight = ROUND_UP(height, bsh);
|
||||||
const unsigned int nativeW = width;
|
const unsigned int nativeW = width;
|
||||||
const unsigned int nativeH = height;
|
const unsigned int nativeH = height;
|
||||||
|
|
||||||
@ -650,8 +650,8 @@ TextureCache::TCacheEntryBase* TextureCache::Load(const u32 stage)
|
|||||||
{
|
{
|
||||||
const u32 mip_width = CalculateLevelSize(width, level);
|
const u32 mip_width = CalculateLevelSize(width, level);
|
||||||
const u32 mip_height = CalculateLevelSize(height, level);
|
const u32 mip_height = CalculateLevelSize(height, level);
|
||||||
const u32 expanded_mip_width = (mip_width + bsw) & (~bsw);
|
const u32 expanded_mip_width = ROUND_UP(mip_width, bsw);
|
||||||
const u32 expanded_mip_height = (mip_height + bsh) & (~bsh);
|
const u32 expanded_mip_height = ROUND_UP(mip_height, bsh);
|
||||||
|
|
||||||
const u8*& mip_src_data = from_tmem
|
const u8*& mip_src_data = from_tmem
|
||||||
? ((level % 2) ? ptr_odd : ptr_even)
|
? ((level % 2) ? ptr_odd : ptr_even)
|
||||||
@ -1080,11 +1080,11 @@ TextureCache::TexCache::iterator TextureCache::FreeTexture(TexCache::iterator it
|
|||||||
|
|
||||||
u32 TextureCache::TCacheEntryBase::CacheLinesPerRow() const
|
u32 TextureCache::TCacheEntryBase::CacheLinesPerRow() const
|
||||||
{
|
{
|
||||||
u32 blockW = TexDecoder_GetBlockWidthInTexels(format) - 1;
|
u32 blockW = TexDecoder_GetBlockWidthInTexels(format);
|
||||||
// Round up source height to multiple of block size
|
// Round up source height to multiple of block size
|
||||||
u32 actualWidth = (native_width + blockW) & ~(blockW);
|
u32 actualWidth = ROUND_UP(native_width, blockW);
|
||||||
|
|
||||||
u32 numBlocksX = actualWidth / TexDecoder_GetBlockWidthInTexels(format);
|
u32 numBlocksX = actualWidth / blockW;
|
||||||
|
|
||||||
// RGBA takes two cache lines per block; all others take one
|
// RGBA takes two cache lines per block; all others take one
|
||||||
if (format == GX_TF_RGBA8)
|
if (format == GX_TF_RGBA8)
|
||||||
@ -1094,11 +1094,11 @@ u32 TextureCache::TCacheEntryBase::CacheLinesPerRow() const
|
|||||||
|
|
||||||
u32 TextureCache::TCacheEntryBase::NumBlocksY() const
|
u32 TextureCache::TCacheEntryBase::NumBlocksY() const
|
||||||
{
|
{
|
||||||
u32 blockH = TexDecoder_GetBlockHeightInTexels(format) - 1;
|
u32 blockH = TexDecoder_GetBlockHeightInTexels(format);
|
||||||
// Round up source height to multiple of block size
|
// Round up source height to multiple of block size
|
||||||
u32 actualHeight = (native_height + blockH) & ~(blockH);
|
u32 actualHeight = ROUND_UP(native_height, blockH);
|
||||||
|
|
||||||
return actualHeight / TexDecoder_GetBlockHeightInTexels(format);
|
return actualHeight / blockH;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TextureCache::TCacheEntryBase::SetEfbCopy(u32 stride)
|
void TextureCache::TCacheEntryBase::SetEfbCopy(u32 stride)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user