changeset 1137:0f9d463bf09c

Byte order detection fixes in SDL_endian.h ... --ryan. From: Mike Frysinger <vapier@gentoo.org> To: sdl@libsdl.org Date: Thu, 1 Sep 2005 20:25:01 -0400 Subject: [SDL] [patch] add support for arm/thumb and superh to endian find attached a patch to add support for detecting endian on superh and arm/thumb ... also, ive incorporated a patch from Fedora which will gather the correct endian on a linux host from the system endian.h instead of just trying to maintain an ever-growing list of architectures -mike
author Ryan C. Gordon <icculus@icculus.org>
date Thu, 08 Sep 2005 06:49:20 +0000
parents d16c010d5d98
children fcfb783a3ca2
files include/SDL_byteorder.h
diffstat 1 files changed, 14 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/include/SDL_byteorder.h	Thu Sep 08 06:43:51 2005 +0000
+++ b/include/SDL_byteorder.h	Thu Sep 08 06:49:20 2005 +0000
@@ -34,6 +34,16 @@
 #define SDL_LIL_ENDIAN	1234
 #define SDL_BIG_ENDIAN	4321
 
+#ifdef __linux__
+# include <endian.h>
+# if BYTE_ORDER == LITTLE_ENDIAN
+#  define SDL_BYTEORDER SDL_LIL_ENDIAN
+# else
+#  define SDL_BYTEORDER SDL_BIG_ENDIAN
+# endif
+
+#else
+
 /* Pardon the mess, I'm trying to determine the endianness of this host.
    I'm doing it by preprocessor defines rather than some sort of configure
    script so that application code can use this too.  The "right" way would
@@ -42,7 +52,8 @@
 #if (defined(__i386__) || defined(__i386)) || \
      defined(__ia64__) || defined(WIN32) || \
     (defined(__alpha__) || defined(__alpha)) || \
-     defined(__arm__) || \
+    (defined(__arm__) || defined(__thumb__)) || \
+    (defined(__sh__) || defined(__sh64__)) || \
     (defined(__mips__) && defined(__MIPSEL__)) || \
      defined(__SYMBIAN32__) || \
      defined(__x86_64__) || \
@@ -52,4 +63,6 @@
 #define SDL_BYTEORDER	SDL_BIG_ENDIAN
 #endif
 
+#endif /* __linux__ */
+
 #endif /* _SDL_byteorder_h */