/** @File Routines for translating between host and network byte-order. Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License that accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license. THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. **/ #include <Library/BaseLib.h> #include <LibConfig.h> #include <sys/endian.h> // Undefine macro versions of the functions to be defined below. #undef htonl #undef htons #undef ntohl #undef ntohs /** 32-bit Host to Network byte order conversion. @param[in] Datum The 32-bit value to be converted. @return Datum, converted to network byte order. **/ uint32_t htonl( IN uint32_t Datum ) { #if BYTE_ORDER == LITTLE_ENDIAN return SwapBytes32(Datum); #else return Datum; #endif } /** 16-bit Host to Network byte order conversion. @param[in] Datum The 16-bit value to be converted. @return Datum, converted to network byte order. **/ uint16_t htons( IN uint16_t Datum ) { #if BYTE_ORDER == LITTLE_ENDIAN return SwapBytes16(Datum); #else return Datum; #endif } /** 32-bit Network to Host byte order conversion. @param[in] Datum The 16-bit value to be converted. @return Datum, converted to host byte order. **/ uint32_t ntohl( IN uint32_t Datum ) { #if BYTE_ORDER == LITTLE_ENDIAN return SwapBytes32(Datum); #else return Datum; #endif } /** 16-bit Network to Host byte order conversion. @param[in] Datum The 16-bit value to be converted. @return Datum, converted to host byte order. **/ uint16_t ntohs( IN uint16_t Datum ) { #if BYTE_ORDER == LITTLE_ENDIAN return SwapBytes16(Datum); #else return Datum; #endif }