Annotation of XNU/bsd/netat/at_ddp_brt.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: /*
        !            24:  *     Copyright (c) 1988, 1989 Apple Computer, Inc. 
        !            25:  */
        !            26: 
        !            27: #ifndef _NETAT_AT_DDP_BRT_H_
        !            28: #define _NETAT_AT_DDP_BRT_H_
        !            29: 
        !            30: typedef struct {
        !            31:        int                             age_flag;
        !            32:        at_ifaddr_t                     *ifID;
        !            33:        union   {
        !            34:                struct  etalk_addr      addr1;
        !            35:                struct  atalk_addr      addr2;
        !            36:        } addrs;
        !            37:        at_net_al                       net;
        !            38: #define et_addr        addrs.addr1
        !            39: #define at_addr        addrs.addr2
        !            40: } ddp_brt_t;
        !            41: 
        !            42: #define BRT_SWEEP_INT          (10 * PR_SLOWHZ)
        !            43: #define        BRT_BSIZ                 4      /* bucket size */
        !            44: #define        BRT_NB                  16      /* number of buckets */
        !            45: #define        BRTSIZE                 (BRT_BSIZ * BRT_NB)
        !            46: 
        !            47: /* age_flag values */
        !            48: #define        BRT_EMPTY               0       /* the BRT entry is empty     */
        !            49:                                        /* (or aged out).             */
        !            50: #define        BRT_VALID               1       /* BRT entry contains valid   */
        !            51:                                        /* tuple                      */
        !            52: #define        BRT_GETTING_OLD         2       /* BRT entry is a candidate   */
        !            53:                                        /* for aging                  */
        !            54: 
        !            55: #define        BRT_HASH(a)   ((a) % BRT_NB)
        !            56: 
        !            57: #define        BRT_LOOK(brt, dst_net) {                                \
        !            58:        register n;                                             \
        !            59:        brt = &at_ddp_brt[BRT_HASH(dst_net) * BRT_BSIZ];        \
        !            60:        for (n = 0 ; ; brt++) {                                 \
        !            61:                if (brt->net == dst_net)                        \
        !            62:                        break;                                  \
        !            63:                if (++n >= BRT_BSIZ) {                          \
        !            64:                        brt = NULL;                             \
        !            65:                        break;                                  \
        !            66:                }                                               \
        !            67:        }                                                       \
        !            68:        }
        !            69: 
        !            70: #define        NEW_BRT(brt, net) {                                     \
        !            71:        register n;                                             \
        !            72:        brt = &at_ddp_brt[BRT_HASH(net) * BRT_BSIZ];            \
        !            73:        for (n = 0 ; ; brt++) {                                 \
        !            74:                if (brt->age_flag == BRT_EMPTY)                 \
        !            75:                        break;                                  \
        !            76:                if (++n >= BRT_BSIZ) {                          \
        !            77:                        brt = NULL;                             \
        !            78:                        break;                                  \
        !            79:                }                                               \
        !            80:         }                                                       \
        !            81:        }
        !            82: 
        !            83: /* Best Router Cache */
        !            84: extern ddp_brt_t       at_ddp_brt[BRTSIZE];
        !            85: 
        !            86: #endif /* _NETAT_AT_DDP_BRT_H_ */
        !            87: 

unix.superglobalmegacorp.com

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