aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-01-13 14:36:04 +0100
committerMichael Niedermayer <michaelni@gmx.at>2014-01-13 14:36:55 +0100
commit9ace154186d853f56f9e713c2fd67f92c851ec04 (patch)
treee6a7af05ed6262e91e92abc8c636f2085ac87ba4
parenta067445b45fbf4519daf5551c0cb588120ad27ba (diff)
parent99e20125232d40ea239a5b54d26bbfe526506114 (diff)
downloadffmpeg-9ace154186d853f56f9e713c2fd67f92c851ec04.tar.gz
Merge commit '99e20125232d40ea239a5b54d26bbfe526506114'
* commit '99e20125232d40ea239a5b54d26bbfe526506114': x86/arm: Add clobber tests to libavresample Merged-by: Michael Niedermayer <michaelni@gmx.at>
-rwxr-xr-xconfigure4
-rw-r--r--libavresample/arm/Makefile3
-rw-r--r--libavresample/arm/neontest.c31
-rw-r--r--libavresample/x86/Makefile2
-rw-r--r--libavresample/x86/w64xmmtest.c31
5 files changed, 70 insertions, 1 deletions
diff --git a/configure b/configure
index df1cb6041a..8d4833e116 100755
--- a/configure
+++ b/configure
@@ -4639,7 +4639,8 @@ enabled neon_clobber_test &&
-Wl,--wrap,avcodec_decode_subtitle2 \
-Wl,--wrap,avcodec_encode_audio2 \
-Wl,--wrap,avcodec_encode_video2 \
- -Wl,--wrap,avcodec_encode_subtitle ||
+ -Wl,--wrap,avcodec_encode_subtitle \
+ -Wl,--wrap,avresample_convert ||
disable neon_clobber_test
enabled xmm_clobber_test &&
@@ -4651,6 +4652,7 @@ enabled xmm_clobber_test &&
-Wl,--wrap,avcodec_encode_video \
-Wl,--wrap,avcodec_encode_video2 \
-Wl,--wrap,avcodec_encode_subtitle \
+ -Wl,--wrap,avresample_convert \
-Wl,--wrap,sws_scale ||
disable xmm_clobber_test
diff --git a/libavresample/arm/Makefile b/libavresample/arm/Makefile
index 55683cbfae..60f3f6d6b8 100644
--- a/libavresample/arm/Makefile
+++ b/libavresample/arm/Makefile
@@ -1,2 +1,5 @@
OBJS += arm/audio_convert_init.o
+
+OBJS-$(CONFIG_NEON_CLOBBER_TEST) += arm/neontest.o
+
NEON-OBJS += arm/audio_convert_neon.o
diff --git a/libavresample/arm/neontest.c b/libavresample/arm/neontest.c
new file mode 100644
index 0000000000..22afedbc60
--- /dev/null
+++ b/libavresample/arm/neontest.c
@@ -0,0 +1,31 @@
+/*
+ * check NEON registers for clobbers
+ * Copyright (c) 2013 Martin Storsjo
+ *
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "libavresample/avresample.h"
+#include "libavutil/arm/neontest.h"
+
+wrap(avresample_convert(AVAudioResampleContext *avr, uint8_t **output,
+ int out_plane_size, int out_samples, uint8_t **input,
+ int in_plane_size, int in_samples))
+{
+ testneonclobbers(avresample_convert, avr, output, out_plane_size,
+ out_samples, input, in_plane_size, in_samples);
+}
diff --git a/libavresample/x86/Makefile b/libavresample/x86/Makefile
index 2e8786fb90..0ca2d79045 100644
--- a/libavresample/x86/Makefile
+++ b/libavresample/x86/Makefile
@@ -2,6 +2,8 @@ OBJS += x86/audio_convert_init.o \
x86/audio_mix_init.o \
x86/dither_init.o \
+OBJS-$(CONFIG_XMM_CLOBBER_TEST) += x86/w64xmmtest.o
+
YASM-OBJS += x86/audio_convert.o \
x86/audio_mix.o \
x86/dither.o \
diff --git a/libavresample/x86/w64xmmtest.c b/libavresample/x86/w64xmmtest.c
new file mode 100644
index 0000000000..0f42bd185c
--- /dev/null
+++ b/libavresample/x86/w64xmmtest.c
@@ -0,0 +1,31 @@
+/*
+ * check XMM registers for clobbers on Win64
+ * Copyright (c) 2013 Martin Storsjo
+ *
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "libavresample/avresample.h"
+#include "libavutil/x86/w64xmmtest.h"
+
+wrap(avresample_convert(AVAudioResampleContext *avr, uint8_t **output,
+ int out_plane_size, int out_samples, uint8_t **input,
+ int in_plane_size, int in_samples))
+{
+ testxmmclobbers(avresample_convert, avr, output, out_plane_size,
+ out_samples, input, in_plane_size, in_samples);
+}