Annotation of 43BSDTahoe/sys/netimp/if_imphost.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1982, 1986, 1988 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * Redistribution and use in source and binary forms are permitted
        !             6:  * provided that the above copyright notice and this paragraph are
        !             7:  * duplicated in all such forms and that any documentation,
        !             8:  * advertising materials, and other materials related to such
        !             9:  * distribution and use acknowledge that the software was developed
        !            10:  * by the University of California, Berkeley.  The name of the
        !            11:  * University may not be used to endorse or promote products derived
        !            12:  * from this software without specific prior written permission.
        !            13:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
        !            14:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
        !            15:  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            16:  *
        !            17:  *     @(#)if_imphost.h        7.6 (Berkeley) 6/29/88
        !            18:  */
        !            19: 
        !            20: /*
        !            21:  * Host structure used with IMP's.
        !            22:  * Used to hold outgoing packets which
        !            23:  * would exceed allowed RFNM count.
        !            24:  *
        !            25:  * These structures are packed into
        !            26:  * mbuf's and kept as small as possible.
        !            27:  */
        !            28: struct host {
        !            29:        struct  mbuf *h_q;              /* holding queue */
        !            30:        u_short h_timer;                /* used to stay off deletion */
        !            31:        u_short h_imp;                  /* host's imp number */
        !            32:        u_char  h_host;                 /* host's number on imp */
        !            33:        u_char  h_qcnt;                 /* size of holding q */
        !            34:        u_char  h_rfnm;                 /* # outstanding rfnm's */
        !            35:        u_char  h_flags;                /* see below */
        !            36: };
        !            37: 
        !            38: /*
        !            39:  * A host structure is kept around (even when there are no
        !            40:  * references to it) for a spell to avoid constant reallocation
        !            41:  * and also to reflect IMP status back to sites which aren't
        !            42:  * directly connected to the IMP.  When structures are marked
        !            43:  * idle, a timer is started; when the timer expires the structure
        !            44:  * is deallocated.  A structure may be reused before the timer expires.
        !            45:  * A structure holds a reference on the containing mbuf when it is marked
        !            46:  * HF_INUSE.
        !            47:  */
        !            48: #define        HF_INUSE        0x1
        !            49: #define        HF_DEAD         (1<<IMPTYPE_HOSTDEAD)
        !            50: #define        HF_UNREACH      (1<<IMPTYPE_HOSTUNREACH)
        !            51: 
        !            52: #define        HOSTTIMER       128             /* keep structure around awhile */
        !            53: 
        !            54: /*
        !            55:  * Mark a host structure free; used if host entry returned by hostlookup 
        !            56:  * isn't needed.  h_rfnm must be zero.
        !            57:  */
        !            58: #define        hostfree(hp) { \
        !            59:        if ((hp)->h_timer == 0 && (hp)->h_qcnt == 0 && \
        !            60:            (hp)->h_flags & HF_INUSE) \
        !            61:                hostrelease(hp); \
        !            62: }
        !            63: 
        !            64: /*
        !            65:  * Release a host entry when last rfnm is received.
        !            66:  */
        !            67: #define        hostidle(hp)    { (hp)->h_timer = HOSTTIMER; }
        !            68: 
        !            69: /*
        !            70:  * Host structures, as seen inside an mbuf.
        !            71:  * Hashing on the host and imp is used to
        !            72:  * select an index into the first mbuf.  Collisions
        !            73:  * are then resolved by searching successive
        !            74:  * mbuf's at the same index.  Reclamation is done
        !            75:  * automatically at the time a structure is freed.
        !            76:  */
        !            77: #define        HPMBUF  ((MLEN - sizeof(int)) / sizeof(struct host))
        !            78: /* don't need to swab as long as HPMBUF is odd */
        !            79: #if defined(notdef) && BYTE_ORDER == BIG_ENDIAN
        !            80: #define        HOSTHASH(imp, host)     ((unsigned)(ntohs(imp)+(host)) % HPMBUF)
        !            81: #else
        !            82: #define        HOSTHASH(imp, host)     ((unsigned)((imp)+(host)) % HPMBUF)
        !            83: #endif
        !            84: 
        !            85: /*
        !            86:  * In-line expansions for queuing operations on
        !            87:  * host message holding queue.  Queue is maintained
        !            88:  * as circular list with the head pointing to the
        !            89:  * last message in the queue.
        !            90:  */
        !            91: #define        HOST_ENQUE(hp, m) { \
        !            92:        register struct mbuf *n; \
        !            93:        (hp)->h_qcnt++; \
        !            94:        if ((n = (hp)->h_q) == 0) \
        !            95:                (hp)->h_q = (m)->m_act = (m); \
        !            96:        else { \
        !            97:                (m)->m_act = n->m_act; \
        !            98:                (hp)->h_q = n->m_act = (m); \
        !            99:        } \
        !           100: }
        !           101: #define        HOST_DEQUE(hp, m) { \
        !           102:        if ((m) = (hp)->h_q) { \
        !           103:                if ((m)->m_act == (m)) \
        !           104:                        (hp)->h_q = 0; \
        !           105:                else { \
        !           106:                        (m) = (m)->m_act; \
        !           107:                        (hp)->h_q->m_act = (m)->m_act; \
        !           108:                } \
        !           109:                (hp)->h_qcnt--; \
        !           110:                (m)->m_act = 0; \
        !           111:        } \
        !           112: }
        !           113: 
        !           114: struct hmbuf {
        !           115:        int     hm_count;               /* # of struct's in use */
        !           116:        struct  host hm_hosts[HPMBUF];  /* data structures proper */
        !           117: };
        !           118: 
        !           119: #ifdef KERNEL
        !           120: struct host *hostlookup();
        !           121: struct host *hostenter();
        !           122: #endif

unix.superglobalmegacorp.com

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