Annotation of 43BSDTahoe/sys/h/mbuf.h, revision 1.1.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 this notice is preserved and that due credit is given
                      7:  * to the University of California at Berkeley. The name of the University
                      8:  * may not be used to endorse or promote products derived from this
                      9:  * software without specific prior written permission. This software
                     10:  * is provided ``as is'' without express or implied warranty.
                     11:  *
                     12:  *     @(#)mbuf.h      7.10 (Berkeley) 2/8/88
                     13:  */
                     14: 
                     15: /*
                     16:  * Constants related to memory allocator.
                     17:  */
                     18: #define        MSIZE           128                     /* size of an mbuf */
                     19: 
                     20: #if CLBYTES > 1024
                     21: #define        MCLBYTES        1024
                     22: #define        MCLSHIFT        10
                     23: #define        MCLOFSET        (MCLBYTES - 1)
                     24: #else
                     25: #define        MCLBYTES        CLBYTES
                     26: #define        MCLSHIFT        CLSHIFT
                     27: #define        MCLOFSET        CLOFSET
                     28: #endif
                     29: 
                     30: #define        MMINOFF         12                      /* mbuf header length */
                     31: #define        MTAIL           4
                     32: #define        MMAXOFF         (MSIZE-MTAIL)           /* offset where data ends */
                     33: #define        MLEN            (MSIZE-MMINOFF-MTAIL)   /* mbuf data length */
                     34: #ifdef GATEWAY
                     35: #define        NMBCLUSTERS     512
                     36: #else
                     37: #define        NMBCLUSTERS     256
                     38: #endif
                     39: #define        NMBPCL          (CLBYTES/MSIZE)         /* # mbufs per cluster */
                     40: 
                     41: /*
                     42:  * Macros for type conversion
                     43:  */
                     44: 
                     45: /* network cluster number to virtual address, and back */
                     46: #define        cltom(x) ((struct mbuf *)((int)mbutl + ((x) << MCLSHIFT)))
                     47: #define        mtocl(x) (((int)x - (int)mbutl) >> MCLSHIFT)
                     48: 
                     49: /* address in mbuf to mbuf head */
                     50: #define        dtom(x)         ((struct mbuf *)((int)x & ~(MSIZE-1)))
                     51: 
                     52: /* mbuf head, to typed data */
                     53: #define        mtod(x,t)       ((t)((int)(x) + (x)->m_off))
                     54: 
                     55: struct mbuf {
                     56:        struct  mbuf *m_next;           /* next buffer in chain */
                     57:        u_long  m_off;                  /* offset of data */
                     58:        short   m_len;                  /* amount of data in this mbuf */
                     59:        short   m_type;                 /* mbuf type (0 == free) */
                     60:        u_char  m_dat[MLEN];            /* data storage */
                     61:        struct  mbuf *m_act;            /* link in higher-level mbuf list */
                     62: };
                     63: 
                     64: /* mbuf types */
                     65: #define        MT_FREE         0       /* should be on free list */
                     66: #define        MT_DATA         1       /* dynamic (data) allocation */
                     67: #define        MT_HEADER       2       /* packet header */
                     68: #define        MT_SOCKET       3       /* socket structure */
                     69: #define        MT_PCB          4       /* protocol control block */
                     70: #define        MT_RTABLE       5       /* routing tables */
                     71: #define        MT_HTABLE       6       /* IMP host tables */
                     72: #define        MT_ATABLE       7       /* address resolution tables */
                     73: #define        MT_SONAME       8       /* socket name */
                     74: #define        MT_SOOPTS       10      /* socket options */
                     75: #define        MT_FTABLE       11      /* fragment reassembly header */
                     76: #define        MT_RIGHTS       12      /* access rights */
                     77: #define        MT_IFADDR       13      /* interface address */
                     78: 
                     79: /* flags to m_get */
                     80: #define        M_DONTWAIT      0
                     81: #define        M_WAIT          1
                     82: 
                     83: /* flags to m_pgalloc */
                     84: #define        MPG_MBUFS       0               /* put new mbufs on free list */
                     85: #define        MPG_CLUSTERS    1               /* put new clusters on free list */
                     86: 
                     87: /* length to m_copy to copy all */
                     88: #define        M_COPYALL       1000000000
                     89: 
                     90: /*
                     91:  * m_pullup will pull up additional length if convenient;
                     92:  * should be enough to hold headers of second-level and higher protocols. 
                     93:  */
                     94: #define        MPULL_EXTRA     32
                     95: 
                     96: #define        MGET(m, i, t) \
                     97:        { int ms = splimp(); \
                     98:          if ((m)=mfree) \
                     99:                { if ((m)->m_type != MT_FREE) panic("mget"); (m)->m_type = t; \
                    100:                  mbstat.m_mtypes[MT_FREE]--; mbstat.m_mtypes[t]++; \
                    101:                  mfree = (m)->m_next; (m)->m_next = 0; \
                    102:                  (m)->m_off = MMINOFF; } \
                    103:          else \
                    104:                (m) = m_more(i, t); \
                    105:          splx(ms); }
                    106: /*
                    107:  * Mbuf page cluster macros.
                    108:  * MCLALLOC allocates mbuf page clusters.
                    109:  * Note that it works only with a count of 1 at the moment.
                    110:  * MCLGET adds such clusters to a normal mbuf.
                    111:  * m->m_len is set to MCLBYTES upon success, and to MLEN on failure.
                    112:  * MCLFREE frees clusters allocated by MCLALLOC.
                    113:  */
                    114: #define        MCLALLOC(m, i) \
                    115:        { int ms = splimp(); \
                    116:          if (mclfree == 0) \
                    117:                (void)m_clalloc((i), MPG_CLUSTERS, M_DONTWAIT); \
                    118:          if ((m)=mclfree) \
                    119:             {++mclrefcnt[mtocl(m)];mbstat.m_clfree--;mclfree = (m)->m_next;} \
                    120:          splx(ms); }
                    121: #define        M_HASCL(m)      ((m)->m_off >= MSIZE)
                    122: #define        MTOCL(m)        ((struct mbuf *)(mtod((m), int) &~ MCLOFSET))
                    123: 
                    124: #define        MCLGET(m) \
                    125:        { struct mbuf *p; \
                    126:          MCLALLOC(p, 1); \
                    127:          if (p) { \
                    128:                (m)->m_off = (int)p - (int)(m); \
                    129:                (m)->m_len = MCLBYTES; \
                    130:          } else \
                    131:                (m)->m_len = MLEN; \
                    132:        }
                    133: #define        MCLFREE(m) { \
                    134:        if (--mclrefcnt[mtocl(m)] == 0) \
                    135:            { (m)->m_next = mclfree;mclfree = (m);mbstat.m_clfree++;} \
                    136:        }
                    137: #define        MFREE(m, n) \
                    138:        { int ms = splimp(); \
                    139:          if ((m)->m_type == MT_FREE) panic("mfree"); \
                    140:          mbstat.m_mtypes[(m)->m_type]--; mbstat.m_mtypes[MT_FREE]++; \
                    141:          (m)->m_type = MT_FREE; \
                    142:          if (M_HASCL(m)) { \
                    143:                (n) = MTOCL(m); \
                    144:                MCLFREE(n); \
                    145:          } \
                    146:          (n) = (m)->m_next; (m)->m_next = mfree; \
                    147:          (m)->m_off = 0; (m)->m_act = 0; mfree = (m); \
                    148:          splx(ms); \
                    149:          if (m_want) { \
                    150:                  m_want = 0; \
                    151:                  wakeup((caddr_t)&mfree); \
                    152:          } \
                    153:        }
                    154: 
                    155: /*
                    156:  * Mbuf statistics.
                    157:  */
                    158: struct mbstat {
                    159:        u_long  m_mbufs;        /* mbufs obtained from page pool */
                    160:        u_long  m_clusters;     /* clusters obtained from page pool */
                    161:        u_long  m_spare;        /* spare field */
                    162:        u_long  m_clfree;       /* free clusters */
                    163:        u_long  m_drops;        /* times failed to find space */
                    164:        u_long  m_wait;         /* times waited for space */
                    165:        u_long  m_drain;        /* times drained protocols for space */
                    166:        u_short m_mtypes[256];  /* type specific mbuf allocations */
                    167: };
                    168: 
                    169: #ifdef KERNEL
                    170: extern struct mbuf mbutl[];            /* virtual address of net free mem */
                    171: extern struct pte Mbmap[];             /* page tables to map Netutl */
                    172: struct mbstat mbstat;
                    173: int    nmbclusters;
                    174: struct mbuf *mfree, *mclfree;
                    175: char   mclrefcnt[NMBCLUSTERS + 1];
                    176: int    m_want;
                    177: struct mbuf *m_get(),*m_getclr(),*m_free(),*m_more(),*m_copy(),*m_pullup();
                    178: caddr_t        m_clalloc();
                    179: #endif

unix.superglobalmegacorp.com

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