summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorarchshift <gh@archshift.com>2015-05-11 03:59:22 +0200
committerarchshift <gh@archshift.com>2015-05-11 03:59:22 +0200
commit40310e2132ea0b1a48661883e0fbc845488c51eb (patch)
treeff40f5a686cae1ff1775f094cab99652405f2869 /src
parentMerge pull request #740 from yuriks/gsp-shmem (diff)
downloadyuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.tar
yuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.tar.gz
yuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.tar.bz2
yuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.tar.lz
yuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.tar.xz
yuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.tar.zst
yuzu-40310e2132ea0b1a48661883e0fbc845488c51eb.zip
Diffstat (limited to 'src')
-rw-r--r--src/video_core/debug_utils/debug_utils.cpp11
-rw-r--r--src/video_core/pica.h2
2 files changed, 12 insertions, 1 deletions
diff --git a/src/video_core/debug_utils/debug_utils.cpp b/src/video_core/debug_utils/debug_utils.cpp
index 2d9d8ab1f..883df48a5 100644
--- a/src/video_core/debug_utils/debug_utils.cpp
+++ b/src/video_core/debug_utils/debug_utils.cpp
@@ -393,6 +393,17 @@ const Math::Vec4<u8> LookupTexture(const u8* source, int x, int y, const Texture
}
}
+ case Regs::TextureFormat::I4:
+ {
+ u32 morton_offset = VideoCore::GetMortonOffset(x, y, 1);
+ const u8* source_ptr = source + morton_offset / 2;
+
+ u8 i = (morton_offset % 2) ? ((*source_ptr & 0xF0) >> 4) : (*source_ptr & 0xF);
+ i = Color::Convert4To8(i);
+
+ return { i, i, i, 255 };
+ }
+
case Regs::TextureFormat::A4:
{
u32 morton_offset = VideoCore::GetMortonOffset(x, y, 1);
diff --git a/src/video_core/pica.h b/src/video_core/pica.h
index 5e169ff69..a53429716 100644
--- a/src/video_core/pica.h
+++ b/src/video_core/pica.h
@@ -156,7 +156,7 @@ struct Regs {
I8 = 7,
A8 = 8,
IA4 = 9,
-
+ I4 = 10,
A4 = 11,
ETC1 = 12, // compressed
ETC1A4 = 13, // compressed