summaryrefslogtreecommitdiffstats
path: root/src/video_core/swrasterizer/rasterizer.cpp
diff options
context:
space:
mode:
authorwwylele <wwylele@gmail.com>2017-06-01 15:56:46 +0200
committerwwylele <wwylele@gmail.com>2017-06-04 08:47:25 +0200
commit28d1e73d2f1eb5d77568303050d254fd3b4df853 (patch)
tree29f34273ed1a7943a5f32b6e510d6f4caf6e5c02 /src/video_core/swrasterizer/rasterizer.cpp
parentMerge pull request #2734 from yuriks/cmake-imported-libs (diff)
downloadyuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.tar
yuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.tar.gz
yuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.tar.bz2
yuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.tar.lz
yuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.tar.xz
yuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.tar.zst
yuzu-28d1e73d2f1eb5d77568303050d254fd3b4df853.zip
Diffstat (limited to 'src/video_core/swrasterizer/rasterizer.cpp')
-rw-r--r--src/video_core/swrasterizer/rasterizer.cpp20
1 files changed, 16 insertions, 4 deletions
diff --git a/src/video_core/swrasterizer/rasterizer.cpp b/src/video_core/swrasterizer/rasterizer.cpp
index e9edf0360..908c7bb9e 100644
--- a/src/video_core/swrasterizer/rasterizer.cpp
+++ b/src/video_core/swrasterizer/rasterizer.cpp
@@ -307,10 +307,22 @@ static void ProcessTriangleInternal(const Vertex& v0, const Vertex& v1, const Ve
int t = (int)(v * float24::FromFloat32(static_cast<float>(texture.config.height)))
.ToFloat32();
- if ((texture.config.wrap_s == TexturingRegs::TextureConfig::ClampToBorder &&
- (s < 0 || static_cast<u32>(s) >= texture.config.width)) ||
- (texture.config.wrap_t == TexturingRegs::TextureConfig::ClampToBorder &&
- (t < 0 || static_cast<u32>(t) >= texture.config.height))) {
+ bool use_border_s = false;
+ bool use_border_t = false;
+
+ if (texture.config.wrap_s == TexturingRegs::TextureConfig::ClampToBorder) {
+ use_border_s = s < 0 || s >= static_cast<int>(texture.config.width);
+ } else if (texture.config.wrap_s == TexturingRegs::TextureConfig::ClampToBorder2) {
+ use_border_s = s >= static_cast<int>(texture.config.width);
+ }
+
+ if (texture.config.wrap_t == TexturingRegs::TextureConfig::ClampToBorder) {
+ use_border_t = t < 0 || t >= static_cast<int>(texture.config.height);
+ } else if (texture.config.wrap_t == TexturingRegs::TextureConfig::ClampToBorder2) {
+ use_border_t = t >= static_cast<int>(texture.config.height);
+ }
+
+ if (use_border_s || use_border_t) {
auto border_color = texture.config.border_color;
texture_color[i] = {border_color.r, border_color.g, border_color.b,
border_color.a};