/* ----> DO NOT REMOVE THE FOLLOWING NOTICE <---- Copyright (c) 2014-2015 Datalight, Inc. All Rights Reserved Worldwide. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; use version 2 of the License. This program is distributed in the hope that it will be useful, but "AS-IS," WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ /* Businesses and individuals that for commercial or other reasons cannot comply with the terms of the GPLv2 license may obtain a commercial license before incorporating Reliance Edge into proprietary software for distribution in any form. Visit http://www.datalight.com/reliance-edge for more information. */ /** @file @brief Implements utilities for performing endian swaps. */ #include #ifdef REDCONF_ENDIAN_SWAP /** @brief Reverse the byte order of a 64-bit number. @param ullToRev Number whose bytes will be reversed @retval @p ullToRev with its bytes reversed. */ uint64_t RedRev64( uint64_t ullToRev) { uint64_t ullRet = ullToRev; ullRet = ((ullRet & UINT64_SUFFIX(0x00000000FFFFFFFF)) << 32U) | ((ullRet & UINT64_SUFFIX(0xFFFFFFFF00000000)) >> 32U); ullRet = ((ullRet & UINT64_SUFFIX(0x0000FFFF0000FFFF)) << 16U) | ((ullRet & UINT64_SUFFIX(0xFFFF0000FFFF0000)) >> 16U); ullRet = ((ullRet & UINT64_SUFFIX(0x00FF00FF00FF00FF)) << 8U) | ((ullRet & UINT64_SUFFIX(0xFF00FF00FF00FF00)) >> 8U); return ullRet; } /** @brief Reverse the byte order of a 32-bit number. @param ulToRev Number whose bytes will be reversed @retval @p ulToRev with its bytes reversed. */ uint32_t RedRev32( uint32_t ulToRev) { return ((ulToRev & 0x000000FFU) << 24U) | ((ulToRev & 0x0000FF00U) << 8U) | ((ulToRev & 0x00FF0000U) >> 8U) | ((ulToRev & 0xFF000000U) >> 24U); } /** @brief Reverse the byte order of a 16-bit number. @param uToRev Number whose bytes will be reversed @retval @p uToRev with its bytes reversed. */ uint16_t RedRev16( uint16_t uToRev) { return ((uToRev & 0xFF00U) >> 8U) | ((uToRev & 0x00FFU) << 8U); } #endif