summaryrefslogtreecommitdiff
path: root/src/video_core/rasterizer.cpp
diff options
context:
space:
mode:
authorGravatar Tony Wasserka2015-01-03 13:33:57 +0100
committerGravatar Tony Wasserka2015-02-18 14:50:28 +0100
commit6ca752ccbc7c59dab66f476ca02d3b53527c57da (patch)
treed5578562d0ea9d4c06dbd1050ae1460bf2e842bd /src/video_core/rasterizer.cpp
parentPica: Fix a bug in the register definitions, relating to texture wrapping. (diff)
downloadyuzu-6ca752ccbc7c59dab66f476ca02d3b53527c57da.tar.gz
yuzu-6ca752ccbc7c59dab66f476ca02d3b53527c57da.tar.xz
yuzu-6ca752ccbc7c59dab66f476ca02d3b53527c57da.zip
Pica/TextureUnit: Implement mirrored repeating texture wrapping.
Diffstat (limited to 'src/video_core/rasterizer.cpp')
-rw-r--r--src/video_core/rasterizer.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/video_core/rasterizer.cpp b/src/video_core/rasterizer.cpp
index 65dddb47c..f788122d8 100644
--- a/src/video_core/rasterizer.cpp
+++ b/src/video_core/rasterizer.cpp
@@ -251,7 +251,15 @@ static void ProcessTriangleInternal(const VertexShader::OutputVertex& v0,
251 return val; 251 return val;
252 252
253 case Regs::TextureConfig::Repeat: 253 case Regs::TextureConfig::Repeat:
254 return (int)(((unsigned)val) % size); 254 return (int)((unsigned)val % size);
255
256 case Regs::TextureConfig::MirroredRepeat:
257 {
258 int val = (int)((unsigned)val % (2 * size));
259 if (val >= size)
260 val = 2 * size - 1 - val;
261 return val;
262 }
255 263
256 default: 264 default:
257 LOG_ERROR(HW_GPU, "Unknown texture coordinate wrapping mode %x\n", (int)mode); 265 LOG_ERROR(HW_GPU, "Unknown texture coordinate wrapping mode %x\n", (int)mode);