rubidium@8113: /* $Id$ */ rubidium@8113: rubidium@9111: /** @file endian_func.hpp Function to handling different endian machines. */ rubidium@8113: rubidium@8113: #ifndef ENDIAN_FUNC_H rubidium@8113: #define ENDIAN_FUNC_H rubidium@8113: smatz@9543: #include "endian_type.hpp" rubidium@8132: #include "bitmath_func.hpp" rubidium@8132: rubidium@8132: /* Setup alignment and conversion macros */ smatz@9543: #if TTD_ENDIAN == TTD_BIG_ENDIAN skidd13@8133: #define FROM_BE16(x) (x) rubidium@8132: #define FROM_BE32(x) (x) skidd13@8133: #define TO_BE16(x) (x) rubidium@8132: #define TO_BE32(x) (x) skidd13@8133: #define TO_BE32X(x) (x) skidd13@8133: #define FROM_LE16(x) BSWAP16(x) skidd13@8133: #define FROM_LE32(x) BSWAP32(x) skidd13@8133: #define TO_LE16(x) BSWAP16(x) skidd13@8133: #define TO_LE32(x) BSWAP32(x) rubidium@8132: #define TO_LE32X(x) BSWAP32(x) rubidium@8132: #else skidd13@8133: #define FROM_BE16(x) BSWAP16(x) skidd13@8133: #define FROM_BE32(x) BSWAP32(x) skidd13@8133: #define TO_BE16(x) BSWAP16(x) skidd13@8133: #define TO_BE32(x) BSWAP32(x) rubidium@8132: #define TO_BE32X(x) BSWAP32(x) skidd13@8133: #define FROM_LE16(x) (x) skidd13@8133: #define FROM_LE32(x) (x) skidd13@8133: #define TO_LE16(x) (x) skidd13@8133: #define TO_LE32(x) (x) rubidium@8132: #define TO_LE32X(x) (x) smatz@9543: #endif /* TTD_ENDIAN == TTD_BIG_ENDIAN */ rubidium@8132: skidd13@9575: static FORCEINLINE uint16 ReadLE16Aligned(const void *x) rubidium@8113: { rubidium@8113: return FROM_LE16(*(const uint16*)x); rubidium@8113: } rubidium@8113: skidd13@9575: static FORCEINLINE uint16 ReadLE16Unaligned(const void *x) rubidium@8113: { smatz@9543: #if OTTD_ALIGNMENT == 1 rubidium@8113: return ((const byte*)x)[0] | ((const byte*)x)[1] << 8; rubidium@8113: #else rubidium@8113: return FROM_LE16(*(const uint16*)x); smatz@9543: #endif /* OTTD_ALIGNMENT == 1 */ rubidium@8113: } rubidium@8113: rubidium@8132: #endif /* ENDIAN_FUNC_HPP */