summaryrefslogtreecommitdiff
path: root/libavutil/internal.h
diff options
context:
space:
mode:
authorDiego Biurrun <diego@biurrun.de>2013-02-08 00:31:13 +0100
committerDiego Biurrun <diego@biurrun.de>2013-02-08 23:13:37 +0100
commit218aefce4472dc02ee3f12830a9a894bf7916da9 (patch)
tree3b6772260e9a11f65aa66c4594f888d60a888b3b /libavutil/internal.h
parent059866eb17cd3c66422a61d3e9c3305f55830a50 (diff)
dsputil: Move LOCAL_ALIGNED macros to libavutil
Diffstat (limited to 'libavutil/internal.h')
-rw-r--r--libavutil/internal.h26
1 files changed, 26 insertions, 0 deletions
diff --git a/libavutil/internal.h b/libavutil/internal.h
index 5bc6a085d6..43cbaeaca2 100644
--- a/libavutil/internal.h
+++ b/libavutil/internal.h
@@ -57,6 +57,32 @@
# define INT_BIT (CHAR_BIT * sizeof(int))
#endif
+// Some broken preprocessors need a second expansion
+// to be forced to tokenize __VA_ARGS__
+#define E(x) x
+
+#define LOCAL_ALIGNED_A(a, t, v, s, o, ...) \
+ uint8_t la_##v[sizeof(t s o) + (a)]; \
+ t (*v) o = (void *)FFALIGN((uintptr_t)la_##v, a)
+
+#define LOCAL_ALIGNED_D(a, t, v, s, o, ...) \
+ DECLARE_ALIGNED(a, t, la_##v) s o; \
+ t (*v) o = la_##v
+
+#define LOCAL_ALIGNED(a, t, v, ...) E(LOCAL_ALIGNED_A(a, t, v, __VA_ARGS__,,))
+
+#if HAVE_LOCAL_ALIGNED_8
+# define LOCAL_ALIGNED_8(t, v, ...) E(LOCAL_ALIGNED_D(8, t, v, __VA_ARGS__,,))
+#else
+# define LOCAL_ALIGNED_8(t, v, ...) LOCAL_ALIGNED(8, t, v, __VA_ARGS__)
+#endif
+
+#if HAVE_LOCAL_ALIGNED_16
+# define LOCAL_ALIGNED_16(t, v, ...) E(LOCAL_ALIGNED_D(16, t, v, __VA_ARGS__,,))
+#else
+# define LOCAL_ALIGNED_16(t, v, ...) LOCAL_ALIGNED(16, t, v, __VA_ARGS__)
+#endif
+
#define FF_ALLOC_OR_GOTO(ctx, p, size, label)\
{\
p = av_malloc(size);\