Annotation of XNU/osfmk/ppc/endian.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
        !             3:  *
        !             4:  * @APPLE_LICENSE_HEADER_START@
        !             5:  * 
        !             6:  * The contents of this file constitute Original Code as defined in and
        !             7:  * are subject to the Apple Public Source License Version 1.1 (the
        !             8:  * "License").  You may not use this file except in compliance with the
        !             9:  * License.  Please obtain a copy of the License at
        !            10:  * http://www.apple.com/publicsource and read it before using this file.
        !            11:  * 
        !            12:  * This Original Code and all software distributed under the License are
        !            13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
        !            14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
        !            15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
        !            16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
        !            17:  * License for the specific language governing rights and limitations
        !            18:  * under the License.
        !            19:  * 
        !            20:  * @APPLE_LICENSE_HEADER_END@
        !            21:  */
        !            22: /*
        !            23:  * @OSF_COPYRIGHT@
        !            24:  * 
        !            25:  */
        !            26: 
        !            27: #ifndef _MACHINE_ENDIAN_H_
        !            28: #define _MACHINE_ENDIAN_H_
        !            29: 
        !            30: /*
        !            31:  * Definitions for byte order,
        !            32:  * according to byte significance from low address to high.
        !            33:  */
        !            34: #define        LITTLE_ENDIAN   1234    /* least-significant byte first (vax) */
        !            35: #define        BIG_ENDIAN      4321    /* most-significant byte first (IBM, net) */
        !            36: #define        PDP_ENDIAN      3412    /* LSB first in word, MSW first in long (pdp) */
        !            37: 
        !            38: #if _BIG_ENDIAN                        /* Predefined by compiler */
        !            39: #define        BYTE_ORDER      BIG_ENDIAN      /* byte order we use on ppc */
        !            40: #define ENDIAN         BIG
        !            41: #else
        !            42: #error code has not been ported to little endian targets yet
        !            43: #endif
        !            44: 
        !            45: /*
        !            46:  * Macros for network/external number representation conversion.
        !            47:  */
        !            48: #if BYTE_ORDER == BIG_ENDIAN && !defined(lint)
        !            49: #define        ntohl(x)        (x)
        !            50: #define        ntohs(x)        (x)
        !            51: #define        htonl(x)        (x)
        !            52: #define        htons(x)        (x)
        !            53: 
        !            54: static __inline__ unsigned int byte_reverse_word(unsigned int word);
        !            55: static __inline__ unsigned int byte_reverse_word(unsigned int word) {
        !            56:        unsigned int result;
        !            57:        __asm__ volatile("lwbrx %0, 0, %1" : "=r" (result) : "r" (&word));
        !            58:        return result;
        !            59: }
        !            60: 
        !            61: /* The above function is commutative, so we can use it for
        !            62:  * translations in both directions (to/from little endianness)
        !            63:  * Note that htolx and ltohx are probably identical, they are
        !            64:  * included for completeness.
        !            65:  */
        !            66: #define htoll(x)  byte_reverse_word(x)
        !            67: #define htols(x)  (byte_reverse_word(x) >> 16)
        !            68: #define ltohl(x)  htoll(x)
        !            69: #define ltohs(x)  htols(x)
        !            70: 
        !            71: #define htobl(x) (x)
        !            72: #define htobs(x) (x)
        !            73: #define btohl(x) (x)
        !            74: #define btohs(x) (x)
        !            75: 
        !            76: #else
        !            77: unsigned short ntohs(), htons();
        !            78: unsigned long  ntohl(), htonl();
        !            79: #endif
        !            80: 
        !            81: /* This defines the order of elements in a bitfield,
        !            82:  * it is principally used by the SCSI subsystem in
        !            83:  * the definitions of mapped registers
        !            84:  */
        !            85: #define BYTE_MSF 1
        !            86: 
        !            87: #endif /* _MACHINE_ENDIAN_H_ */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.