byteorder.h 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /* MN10300 Byte-order primitive construction
  2. *
  3. * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
  4. * Written by David Howells (dhowells@redhat.com)
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public Licence
  8. * as published by the Free Software Foundation; either version
  9. * 2 of the Licence, or (at your option) any later version.
  10. */
  11. #ifndef _ASM_BYTEORDER_H
  12. #define _ASM_BYTEORDER_H
  13. #include <asm/types.h>
  14. #ifdef __GNUC__
  15. static inline __attribute__((const))
  16. __u32 ___arch__swab32(__u32 x)
  17. {
  18. __u32 ret;
  19. asm("swap %1,%0" : "=r" (ret) : "r" (x));
  20. return ret;
  21. }
  22. static inline __attribute__((const))
  23. __u16 ___arch__swab16(__u16 x)
  24. {
  25. __u16 ret;
  26. asm("swaph %1,%0" : "=r" (ret) : "r" (x));
  27. return ret;
  28. }
  29. #define __arch__swab32(x) ___arch__swab32(x)
  30. #define __arch__swab16(x) ___arch__swab16(x)
  31. #if !defined(__STRICT_ANSI__) || defined(__KERNEL__)
  32. # define __BYTEORDER_HAS_U64__
  33. # define __SWAB_64_THRU_32__
  34. #endif
  35. #endif /* __GNUC__ */
  36. #include <linux/byteorder/little_endian.h>
  37. #endif /* _ASM_BYTEORDER_H */