Skip site navigation (1)Skip section navigation (2)



index | | raw e-mail

diff --git a/emulators/mame/files/patch-src_emu_video_rgbutil.cpp b/emulators/mame/files/patch-src_emu_video_rgbutil.cpp
new file mode 100644
index 000000000000..46b30a1fba5d
--- /dev/null
+++ b/emulators/mame/files/patch-src_emu_video_rgbutil.cpp
@@ -0,0 +1,28 @@
+--- src/emu/video/rgbutil.cpp.orig	2026-01-08 15:01:14 UTC
++++ src/emu/video/rgbutil.cpp
+@@ -362,7 +362,7 @@ const VECS16 scale_table[256] =
+ 
+ } // anonymous namespace
+ 
+-u32 rgbaint_t::bilinear_filter(const u32 &rgb00, const u32 &rgb01, const u32 &rgb10, const u32 &rgb11, u8 u, u8 v)
++u32 rgbaint_t::bilinear_filter(u32 rgb00, u32 rgb01, u32 rgb10, u32 rgb11, u8 u, u8 v) noexcept
+ {
+ 	const VECS32 zero = vec_splat_s32(0);
+ 
+@@ -405,7 +405,7 @@ u32 rgbaint_t::bilinear_filter(const u32 &rgb00, const
+ 	return result;
+ }
+ 
+-void rgbaint_t::bilinear_filter_rgbaint(const u32 &rgb00, const u32 &rgb01, const u32 &rgb10, const u32 &rgb11, u8 u, u8 v)
++void rgbaint_t::bilinear_filter_rgbaint(u32 rgb00, u32 rgb01, u32 rgb10, u32 rgb11, u8 u, u8 v) noexcept
+ {
+ 	const VECS32 zero = vec_splat_s32(0);
+ 
+@@ -439,6 +439,7 @@ void rgbaint_t::bilinear_filter_rgbaint(const u32 &rgb
+ 	color11 = vec_sr(color11, vec_splat_u32(1));
+ 	color01 = VECS32(vec_max(VECS16(color01), VECS16(color11)));
+ 	color01 = vec_msum(VECS16(color01), scale_table[v], zero);
++	color01 = vec_sr(color01, vec_splat_u32(15));
+ 
+ #ifdef __LITTLE_ENDIAN__
+ 	vec_ste(vec_splat(color01, 3), 0, &m_a);


home | help