summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar Squall Leonhart2023-09-18 23:28:53 +1000
committerGravatar GitHub2023-09-18 23:28:53 +1000
commit79f02020454af9ba055c3302b54693109623f812 (patch)
treefe8805ed33c5ca4d8d82b32dbce9210b1860eec8 /src
parentMerge pull request #11529 from lat9nq/no-oob-names-pls (diff)
downloadyuzu-79f02020454af9ba055c3302b54693109623f812.tar.gz
yuzu-79f02020454af9ba055c3302b54693109623f812.tar.xz
yuzu-79f02020454af9ba055c3302b54693109623f812.zip
Partial revert of #10433
The If block in this change was causing some 2D textures to be treated as if their mip 0 was a 3D Slice, this could be ascertained as the same texture viewed from different distances would render fine, but then close up would look like a decoding failure. It also resulted in some 3D ASTC textures not being scaled appropriate leading to broken graphical effects such as the jagged TOTK recall animation being a circle, as the If block was only accepting the image based on its original info without any adjustments applied.
Diffstat (limited to 'src')
-rw-r--r--src/video_core/texture_cache/util.cpp11
1 files changed, 2 insertions, 9 deletions
diff --git a/src/video_core/texture_cache/util.cpp b/src/video_core/texture_cache/util.cpp
index a83f5d41c..d36145eaa 100644
--- a/src/video_core/texture_cache/util.cpp
+++ b/src/video_core/texture_cache/util.cpp
@@ -166,13 +166,6 @@ template <u32 GOB_EXTENT>
166} 166}
167 167
168[[nodiscard]] constexpr Extent3D TileShift(const LevelInfo& info, u32 level) { 168[[nodiscard]] constexpr Extent3D TileShift(const LevelInfo& info, u32 level) {
169 if (level == 0) {
170 return Extent3D{
171 .width = info.block.width,
172 .height = info.block.height,
173 .depth = info.block.depth,
174 };
175 }
176 const Extent3D blocks = NumLevelBlocks(info, level); 169 const Extent3D blocks = NumLevelBlocks(info, level);
177 return Extent3D{ 170 return Extent3D{
178 .width = AdjustTileSize(info.block.width, GOB_SIZE_X, blocks.width), 171 .width = AdjustTileSize(info.block.width, GOB_SIZE_X, blocks.width),
@@ -1294,9 +1287,9 @@ u32 MapSizeBytes(const ImageBase& image) {
1294 1287
1295static_assert(CalculateLevelSize(LevelInfo{{1920, 1080, 1}, {0, 2, 0}, {1, 1}, 2, 0}, 0) == 1288static_assert(CalculateLevelSize(LevelInfo{{1920, 1080, 1}, {0, 2, 0}, {1, 1}, 2, 0}, 0) ==
1296 0x7f8000); 1289 0x7f8000);
1297static_assert(CalculateLevelSize(LevelInfo{{32, 32, 1}, {0, 0, 4}, {1, 1}, 4, 0}, 0) == 0x40000); 1290static_assert(CalculateLevelSize(LevelInfo{{32, 32, 1}, {0, 0, 4}, {1, 1}, 4, 0}, 0) == 0x4000);
1298 1291
1299static_assert(CalculateLevelSize(LevelInfo{{128, 8, 1}, {0, 4, 0}, {1, 1}, 4, 0}, 0) == 0x40000); 1292static_assert(CalculateLevelSize(LevelInfo{{128, 8, 1}, {0, 4, 0}, {1, 1}, 4, 0}, 0) == 0x4000);
1300 1293
1301static_assert(CalculateLevelOffset(PixelFormat::R8_SINT, {1920, 1080, 1}, {0, 2, 0}, 0, 7) == 1294static_assert(CalculateLevelOffset(PixelFormat::R8_SINT, {1920, 1080, 1}, {0, 2, 0}, 0, 7) ==
1302 0x2afc00); 1295 0x2afc00);