ia64: split 16bit funcs out of byteswap.h and into byteswap-16.h
authorMike Frysinger <vapier@gentoo.org>
Tue, 17 Apr 2012 02:47:48 +0000 (22:47 -0400)
committerMike Frysinger <vapier@gentoo.org>
Sat, 28 Apr 2012 03:13:19 +0000 (23:13 -0400)
The main tree split the 16bit byteswap funcs out into a dedicated header.
Do the same for ia64.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
ChangeLog.ia64
sysdeps/ia64/bits/byteswap-16.h [new file with mode: 0644]
sysdeps/ia64/bits/byteswap.h

index 803a24857fd65110a7d1683732071542369dbbab..f9469b2a119c7fc306ee364696585e788ee87792 100644 (file)
@@ -1,3 +1,9 @@
+2012-04-27  Mike Frysinger  <vapier@gentoo.org>
+
+       * sysdeps/ia64/bits/byteswap.h (__bswap_16): Removed.
+       Include <bits/byteswap-16.h> to get __bswap_16.
+       * sysdeps/ia64/bits/byteswap-16.h: New file.
+
 2012-04-27  Mike Frysinger  <vapier@gentoo.org>
 
        * sysdeps/unix/sysv/linux/ia64/sys/ucontext.h: Delete __cplusplus
diff --git a/sysdeps/ia64/bits/byteswap-16.h b/sysdeps/ia64/bits/byteswap-16.h
new file mode 100644 (file)
index 0000000..0a85909
--- /dev/null
@@ -0,0 +1,42 @@
+/* Macros to swap the order of bytes in 16-bit integer values.
+   Copyright (C) 1997-2012 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library 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.
+
+   The GNU C Library 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 the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#ifndef _BITS_BYTESWAP_H
+# error "Never use <bits/byteswap-16.h> directly; include <byteswap.h> instead."
+#endif
+
+#if defined __GNUC__ && __GNUC__ >= 2
+# define __bswap_16(x) \
+     (__extension__                                                          \
+      ({ register unsigned short int __v, __x = (x);                         \
+        if (__builtin_constant_p (x))                                        \
+          __v = __bswap_constant_16 (__x);                                   \
+        else                                                                 \
+          __asm__ __volatile__ ("shl %0 = %1, 48 ;;"                         \
+                                "mux1 %0 = %0, @rev ;;"                      \
+                                : "=r" (__v)                                 \
+                                : "r" ((unsigned short int) (__x)));         \
+        __v; }))
+#else
+/* This is better than nothing.  */
+static __inline unsigned short int
+__bswap_16 (unsigned short int __bsx)
+{
+  return __bswap_constant_16 (__bsx);
+}
+#endif
index db7824a42f8eba15b4ba8248698fdff45691b7e8..68612487d38f4d924fbfe962b1c9f200782eb792 100644 (file)
@@ -1,6 +1,5 @@
 /* Macros to swap the order of bytes in integer values.
-   Copyright (C) 1997,1998,2000,2002,2003,2008,2011
-   Free Software Foundation, Inc.
+   Copyright (C) 1997-2012 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
 #define __bswap_constant_16(x) \
      ((((x) >> 8) & 0xff) | (((x) & 0xff) << 8))
 
-#if defined __GNUC__ && __GNUC__ >= 2
-# define __bswap_16(x) \
-     (__extension__                                                          \
-      ({ register unsigned short int __v, __x = (x);                         \
-        if (__builtin_constant_p (x))                                        \
-          __v = __bswap_constant_16 (__x);                                   \
-        else                                                                 \
-          __asm__ __volatile__ ("shl %0 = %1, 48 ;;"                         \
-                                "mux1 %0 = %0, @rev ;;"                      \
-                                : "=r" (__v)                                 \
-                                : "r" ((unsigned short int) (__x)));         \
-        __v; }))
-#else
-/* This is better than nothing.  */
-static __inline unsigned short int
-__bswap_16 (unsigned short int __bsx)
-{
-  return __bswap_constant_16 (__bsx);
-}
-#endif
-
+/* Get __bswap_16.  */
+#include <bits/byteswap-16.h>
 
 /* Swap bytes in 32 bit value.  */
 #define __bswap_constant_32(x) \