blob: 3cc5452a1dafc3e3ef55c1ecd8ab759158d70a65 [file] [log] [blame]
/* ----> 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 <redfs.h>
#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