[vlc-commits] contrib: goom: Fix building for i386 with clang
Martin Storsjö
git at videolan.org
Sun Feb 25 21:18:57 CET 2018
vlc | branch: master | Martin Storsjö <martin at martin.st> | Sat Feb 24 00:14:13 2018 +0200| [8743195a1a6b58efb79eeac74d375fb2ff414ce7] | committer: Martin Storsjö
contrib: goom: Fix building for i386 with clang
This is based on a patch from gst-plugins-good (which bundles a copy
of the goom sources), based on a patch from FreeBSD ports.
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=8743195a1a6b58efb79eeac74d375fb2ff414ce7
---
contrib/src/goom/clang-emms.patch | 54 +++++++++++++++++++++++++++++++++++++++
contrib/src/goom/rules.mak | 1 +
2 files changed, 55 insertions(+)
diff --git a/contrib/src/goom/clang-emms.patch b/contrib/src/goom/clang-emms.patch
new file mode 100644
index 0000000000..6fa423cd5e
--- /dev/null
+++ b/contrib/src/goom/clang-emms.patch
@@ -0,0 +1,54 @@
+From 94ad6724ba5c0136d385cc0f052db636bf99a86c Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Sebastian=20Dr=C3=B6ge?= <slomo at circular-chaos.org>
+Date: Sat, 21 Sep 2013 18:46:29 +0200
+Subject: goom: Fix MMX assembly compilation with clang
+
+clang does not want or need a clobber list for emms:
+error: clobbers must be last on the x87 stack
+
+Patch taken from the FreeBSD ports, provided by
+Dan McGregor <dan.mcgregor at usask.ca>
+---
+Adapted from here:
+https://cgit.freedesktop.org/gstreamer/gst-plugins-good/commit/?id=94ad6724ba5c0136d385cc0f052db636bf99a86c
+---
+ src/mmx.h | 12 ++++++++++++
+ 1 file changed, 12 insertions(+)
+
+diff --git a/src/mmx.h b/src/mmx.h
+index 3fae26b..2649e10 100644
+--- a/src/mmx.h
++++ b/src/mmx.h
+@@ -711,17 +711,29 @@ void zoom_filter_xmmx (int prevX, int prevY, Pixel *expix1, Pixel *expix2,
+ */
+ #ifdef MMX_TRACE
+
++#ifdef __clang__
++#define emms() \
++ { \
++ printf("emms()\n"); \
++ __asm__ __volatile__ ("emms"); \
++ }
++#else
+ #define emms() \
+ { \
+ printf("emms()\n"); \
+ __asm__ __volatile__ ("emms" \
+ "st(1)","st(2)","st(3)","st(4)","st(5)","st(6)","st(7)"); \
+ }
++#endif
+
+ #else
+
++#ifdef __clang__
++#define emms() __asm__ __volatile__ ("emms")
++#else
+ #define emms() __asm__ __volatile__ ("emms"::: \
+ "st(1)","st(2)","st(3)","st(4)","st(5)","st(6)","st(7)")
++#endif
+
+ #endif
+
+--
+cgit v1.1
+
diff --git a/contrib/src/goom/rules.mak b/contrib/src/goom/rules.mak
index 7bc27c255d..64e96e6e1e 100644
--- a/contrib/src/goom/rules.mak
+++ b/contrib/src/goom/rules.mak
@@ -26,6 +26,7 @@ endif
ifdef HAVE_MACOSX
$(APPLY) $(SRC)/goom/goom2k4-osx.patch
endif
+ $(APPLY) $(SRC)/goom/clang-emms.patch
$(MOVE)
.goom: goom
More information about the vlc-commits
mailing list