]> granicus.if.org Git - strace/commitdiff
Move gcc compat macros to gcc_compat.h
authorDmitry V. Levin <ldv@altlinux.org>
Thu, 31 Dec 2015 14:19:41 +0000 (14:19 +0000)
committerDmitry V. Levin <ldv@altlinux.org>
Sat, 2 Jan 2016 14:29:33 +0000 (14:29 +0000)
* defs.h: Include "gcc_compat.h".
(GNUC_PREREQ, ATTRIBUTE_NORETURN, ATTRIBUTE_FORMAT,
ATTRIBUTE_ALIGNED, ATTRIBUTE_PACKED, ATTRIBUTE_MALLOC,
ATTRIBUTE_NOINLINE, ATTRIBUTE_ALLOC_SIZE): Move ...
* gcc_compat.h: ... here.
* Makefile.am (strace_SOURCES): Add gcc_compat.h.

Makefile.am
defs.h
gcc_compat.h [new file with mode: 0644]

index ab527788f9161ccfe76e895f23440a3297a0da83..d43608d904ae6ddd4e7f77f05b673fbf2ec74576 100644 (file)
@@ -97,6 +97,7 @@ strace_SOURCES =      \
        flock.c         \
        flock.h         \
        futex.c         \
+       gcc_compat.h    \
        get_robust_list.c \
        getcpu.c        \
        getcwd.c        \
diff --git a/defs.h b/defs.h
index 283ab1fe0ad9d2a5f5fd213c74e15ef3607a6a01..bae212c6eefd6fd92659e18ffd681847d5868435 100644 (file)
--- a/defs.h
+++ b/defs.h
@@ -55,6 +55,7 @@
 #include <sys/syscall.h>
 
 #include "mpers_type.h"
+#include "gcc_compat.h"
 
 #ifndef HAVE_STRERROR
 const char *strerror(int);
@@ -68,48 +69,6 @@ const char *strerror(int);
 extern char *stpcpy(char *dst, const char *src);
 #endif
 
-#if defined __GNUC__ && defined __GNUC_MINOR__
-# define GNUC_PREREQ(maj, min) \
-       ((__GNUC__ << 16) + __GNUC_MINOR__ >= ((maj) << 16) + (min))
-#else
-# define __attribute__(x)      /* empty */
-# define GNUC_PREREQ(maj, min) 0
-#endif
-
-#if GNUC_PREREQ(2, 5)
-# define ATTRIBUTE_NORETURN    __attribute__((__noreturn__))
-#else
-# define ATTRIBUTE_NORETURN    /* empty */
-#endif
-
-#if GNUC_PREREQ(2, 7)
-# define ATTRIBUTE_FORMAT(args)        __attribute__((__format__ args))
-# define ATTRIBUTE_ALIGNED(arg)        __attribute__((__aligned__(arg)))
-# define ATTRIBUTE_PACKED      __attribute__((__packed__))
-#else
-# define ATTRIBUTE_FORMAT(args)        /* empty */
-# define ATTRIBUTE_ALIGNED(arg)        /* empty */
-# define ATTRIBUTE_PACKED      /* empty */
-#endif
-
-#if GNUC_PREREQ(3, 0)
-# define ATTRIBUTE_MALLOC      __attribute__((__malloc__))
-#else
-# define ATTRIBUTE_MALLOC      /* empty */
-#endif
-
-#if GNUC_PREREQ(3, 1)
-# define ATTRIBUTE_NOINLINE    __attribute__((__noinline__))
-#else
-# define ATTRIBUTE_NOINLINE    /* empty */
-#endif
-
-#if GNUC_PREREQ(4, 3)
-# define ATTRIBUTE_ALLOC_SIZE(args)    __attribute__((__alloc_size__ args))
-#else
-# define ATTRIBUTE_ALLOC_SIZE(args)    /* empty */
-#endif
-
 #ifndef offsetof
 # define offsetof(type, member)        \
        (((char *) &(((type *) NULL)->member)) - ((char *) (type *) NULL))
diff --git a/gcc_compat.h b/gcc_compat.h
new file mode 100644 (file)
index 0000000..1f2c835
--- /dev/null
@@ -0,0 +1,73 @@
+/*
+ * Copyright (c) 2015 Dmitry V. Levin <ldv@altlinux.org>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote products
+ *    derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef GCC_COMPAT_H_
+#define GCC_COMPAT_H_
+
+#if defined __GNUC__ && defined __GNUC_MINOR__
+# define GNUC_PREREQ(maj, min) \
+       ((__GNUC__ << 16) + __GNUC_MINOR__ >= ((maj) << 16) + (min))
+#else
+# define __attribute__(x)      /* empty */
+# define GNUC_PREREQ(maj, min) 0
+#endif
+
+#if GNUC_PREREQ(2, 5)
+# define ATTRIBUTE_NORETURN    __attribute__((__noreturn__))
+#else
+# define ATTRIBUTE_NORETURN    /* empty */
+#endif
+
+#if GNUC_PREREQ(2, 7)
+# define ATTRIBUTE_FORMAT(args)        __attribute__((__format__ args))
+# define ATTRIBUTE_ALIGNED(arg)        __attribute__((__aligned__(arg)))
+# define ATTRIBUTE_PACKED      __attribute__((__packed__))
+#else
+# define ATTRIBUTE_FORMAT(args)        /* empty */
+# define ATTRIBUTE_ALIGNED(arg)        /* empty */
+# define ATTRIBUTE_PACKED      /* empty */
+#endif
+
+#if GNUC_PREREQ(3, 0)
+# define ATTRIBUTE_MALLOC      __attribute__((__malloc__))
+#else
+# define ATTRIBUTE_MALLOC      /* empty */
+#endif
+
+#if GNUC_PREREQ(3, 1)
+# define ATTRIBUTE_NOINLINE    __attribute__((__noinline__))
+#else
+# define ATTRIBUTE_NOINLINE    /* empty */
+#endif
+
+#if GNUC_PREREQ(4, 3)
+# define ATTRIBUTE_ALLOC_SIZE(args)    __attribute__((__alloc_size__ args))
+#else
+# define ATTRIBUTE_ALLOC_SIZE(args)    /* empty */
+#endif
+
+#endif