Annotation of embedaddon/curl/lib/curl_endian.c, revision 1.1

1.1     ! misho       1: /***************************************************************************
        !             2:  *                                  _   _ ____  _
        !             3:  *  Project                     ___| | | |  _ \| |
        !             4:  *                             / __| | | | |_) | |
        !             5:  *                            | (__| |_| |  _ <| |___
        !             6:  *                             \___|\___/|_| \_\_____|
        !             7:  *
        !             8:  * Copyright (C) 1998 - 2019, Daniel Stenberg, <daniel@haxx.se>, et al.
        !             9:  *
        !            10:  * This software is licensed as described in the file COPYING, which
        !            11:  * you should have received as part of this distribution. The terms
        !            12:  * are also available at https://curl.haxx.se/docs/copyright.html.
        !            13:  *
        !            14:  * You may opt to use, copy, modify, merge, publish, distribute and/or sell
        !            15:  * copies of the Software, and permit persons to whom the Software is
        !            16:  * furnished to do so, under the terms of the COPYING file.
        !            17:  *
        !            18:  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
        !            19:  * KIND, either express or implied.
        !            20:  *
        !            21:  ***************************************************************************/
        !            22: 
        !            23: #include "curl_setup.h"
        !            24: 
        !            25: #include "curl_endian.h"
        !            26: 
        !            27: /*
        !            28:  * Curl_read16_le()
        !            29:  *
        !            30:  * This function converts a 16-bit integer from the little endian format, as
        !            31:  * used in the incoming package to whatever endian format we're using
        !            32:  * natively.
        !            33:  *
        !            34:  * Parameters:
        !            35:  *
        !            36:  * buf      [in]     - A pointer to a 2 byte buffer.
        !            37:  *
        !            38:  * Returns the integer.
        !            39:  */
        !            40: unsigned short Curl_read16_le(const unsigned char *buf)
        !            41: {
        !            42:   return (unsigned short)(((unsigned short)buf[0]) |
        !            43:                           ((unsigned short)buf[1] << 8));
        !            44: }
        !            45: 
        !            46: /*
        !            47:  * Curl_read32_le()
        !            48:  *
        !            49:  * This function converts a 32-bit integer from the little endian format, as
        !            50:  * used in the incoming package to whatever endian format we're using
        !            51:  * natively.
        !            52:  *
        !            53:  * Parameters:
        !            54:  *
        !            55:  * buf      [in]     - A pointer to a 4 byte buffer.
        !            56:  *
        !            57:  * Returns the integer.
        !            58:  */
        !            59: unsigned int Curl_read32_le(const unsigned char *buf)
        !            60: {
        !            61:   return ((unsigned int)buf[0]) | ((unsigned int)buf[1] << 8) |
        !            62:          ((unsigned int)buf[2] << 16) | ((unsigned int)buf[3] << 24);
        !            63: }
        !            64: 
        !            65: /*
        !            66:  * Curl_read16_be()
        !            67:  *
        !            68:  * This function converts a 16-bit integer from the big endian format, as
        !            69:  * used in the incoming package to whatever endian format we're using
        !            70:  * natively.
        !            71:  *
        !            72:  * Parameters:
        !            73:  *
        !            74:  * buf      [in]     - A pointer to a 2 byte buffer.
        !            75:  *
        !            76:  * Returns the integer.
        !            77:  */
        !            78: unsigned short Curl_read16_be(const unsigned char *buf)
        !            79: {
        !            80:   return (unsigned short)(((unsigned short)buf[0] << 8) |
        !            81:                           ((unsigned short)buf[1]));
        !            82: }
        !            83: 
        !            84: #if (CURL_SIZEOF_CURL_OFF_T > 4)
        !            85: /*
        !            86:  * write32_le()
        !            87:  *
        !            88:  * This function converts a 32-bit integer from the native endian format,
        !            89:  * to little endian format ready for sending down the wire.
        !            90:  *
        !            91:  * Parameters:
        !            92:  *
        !            93:  * value    [in]     - The 32-bit integer value.
        !            94:  * buffer   [in]     - A pointer to the output buffer.
        !            95:  */
        !            96: static void write32_le(const int value, unsigned char *buffer)
        !            97: {
        !            98:   buffer[0] = (char)(value & 0x000000FF);
        !            99:   buffer[1] = (char)((value & 0x0000FF00) >> 8);
        !           100:   buffer[2] = (char)((value & 0x00FF0000) >> 16);
        !           101:   buffer[3] = (char)((value & 0xFF000000) >> 24);
        !           102: }
        !           103: 
        !           104: /*
        !           105:  * Curl_write64_le()
        !           106:  *
        !           107:  * This function converts a 64-bit integer from the native endian format,
        !           108:  * to little endian format ready for sending down the wire.
        !           109:  *
        !           110:  * Parameters:
        !           111:  *
        !           112:  * value    [in]     - The 64-bit integer value.
        !           113:  * buffer   [in]     - A pointer to the output buffer.
        !           114:  */
        !           115: #if defined(HAVE_LONGLONG)
        !           116: void Curl_write64_le(const long long value, unsigned char *buffer)
        !           117: #else
        !           118: void Curl_write64_le(const __int64 value, unsigned char *buffer)
        !           119: #endif
        !           120: {
        !           121:   write32_le((int)value, buffer);
        !           122:   write32_le((int)(value >> 32), buffer + 4);
        !           123: }
        !           124: #endif /* CURL_SIZEOF_CURL_OFF_T > 4 */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>