1 /* Endian macros for string.h functions 2 Copyright (C) 1992-2022 Free Software Foundation, Inc. 3 This file is part of the GNU C Library. 4 5 The GNU C Library is free software; you can redistribute it and/or 6 modify it under the terms of the GNU Lesser General Public 7 License as published by the Free Software Foundation; either 8 version 2.1 of the License, or (at your option) any later version. 9 10 The GNU C Library is distributed in the hope that it will be useful, 11 but WITHOUT ANY WARRANTY; without even the implied warranty of 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 13 Lesser General Public License for more details. 14 15 You should have received a copy of the GNU Lesser General Public 16 License along with the GNU C Library; if not, see 17 <http://www.gnu.org/licenses/>. */ 18 19 #ifndef _BITS_ENDIAN_H 20 #define _BITS_ENDIAN_H 1 21 22 /* Definitions for byte order, according to significance of bytes, 23 from low addresses to high addresses. The value is what you get by 24 putting '4' in the most significant byte, '3' in the second most 25 significant byte, '2' in the second least significant byte, and '1' 26 in the least significant byte, and then writing down one digit for 27 each byte, starting with the byte at the lowest address at the left, 28 and proceeding to the byte with the highest address at the right. */ 29 30 #define __LITTLE_ENDIAN 1234 31 #define __BIG_ENDIAN 4321 32 #define __PDP_ENDIAN 3412 33 34 /* This file defines `__BYTE_ORDER' for the particular machine. */ 35 #include <bits/endianness.h> 36 37 /* Some machines may need to use a different endianness for floating point 38 values. */ 39 #ifndef __FLOAT_WORD_ORDER 40 # define __FLOAT_WORD_ORDER __BYTE_ORDER 41 #endif 42 43 #if __BYTE_ORDER == __LITTLE_ENDIAN 44 # define __LONG_LONG_PAIR(HI, LO) LO, HI 45 #elif __BYTE_ORDER == __BIG_ENDIAN 46 # define __LONG_LONG_PAIR(HI, LO) HI, LO 47 #endif 48 49 #endif /* bits/endian.h */ 50