summaryrefslogtreecommitdiff
path: root/sysdeps/unix
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1999-06-17 12:35:18 +0000
committerUlrich Drepper <drepper@redhat.com>1999-06-17 12:35:18 +0000
commitd5a6cf276e0990841caab85c2cdae07d2c97dd8c (patch)
tree01593f1d37d2490e5ea794c66175ff67bab2b219 /sysdeps/unix
parentc8b0c2c05a0a354a8383e406278432a98317145c (diff)
[!__GNUC__]: Use correct word order.
Diffstat (limited to 'sysdeps/unix')
-rw-r--r--sysdeps/unix/sysv/linux/sys/sysmacros.h18
1 files changed, 14 insertions, 4 deletions
diff --git a/sysdeps/unix/sysv/linux/sys/sysmacros.h b/sysdeps/unix/sysv/linux/sys/sysmacros.h
index 63c1343284..35760e5e06 100644
--- a/sysdeps/unix/sysv/linux/sys/sysmacros.h
+++ b/sysdeps/unix/sysv/linux/sys/sysmacros.h
@@ -30,10 +30,20 @@
# define makedev(major, minor) ((((unsigned int) (major)) << 8) \
| ((unsigned int) (minor)))
#else
-# define major(dev) (((dev).__val[0] >> 8) & 0xff)
-# define minor(dev) ((dev).__val[0] & 0xff)
-# define makedev(major, minor) { ((((unsigned int) (major)) << 8) \
- | ((unsigned int) (minor))), 0 }
+/* We need to know the word order here. This assumes that the word order
+ is consistent with the byte order. */
+# include <endian.h>
+# if __BYTE_ORDER == __BIG_ENDIAN
+# define major(dev) (((dev).__val[1] >> 8) & 0xff)
+# define minor(dev) ((dev).__val[1] & 0xff)
+# define makedev(major, minor) { 0, ((((unsigned int) (major)) << 8) \
+ | ((unsigned int) (minor))) }
+# else
+# define major(dev) (((dev).__val[0] >> 8) & 0xff)
+# define minor(dev) ((dev).__val[0] & 0xff)
+# define makedev(major, minor) { ((((unsigned int) (major)) << 8) \
+ | ((unsigned int) (minor))), 0 }
+# endif
#endif
#endif /* sys/sysmacros.h */