Annotation of researchv9/sys.vax/h/inet/ip_var.h, revision 1.1

1.1     ! root        1: /*     ip_var.h        6.1     83/07/29        */
        !             2: 
        !             3: /*
        !             4:  * Overlay for ip header used by other protocols (tcp, udp).
        !             5:  */
        !             6: struct ipovly {
        !             7:        caddr_t ih_next, ih_prev;       /* for protocol sequence q's */
        !             8:        u_char  ih_x1;                  /* (unused) */
        !             9:        u_char  ih_pr;                  /* protocol */
        !            10:        short   ih_len;                 /* protocol length */
        !            11:        in_addr ih_src;         /* source internet address */
        !            12:        in_addr ih_dst;         /* destination internet address */
        !            13: };
        !            14: 
        !            15: /*
        !            16:  * Ip reassembly queue structure.  Each fragment
        !            17:  * being reassembled is attached to one of these structures.
        !            18:  * They are timed out after ipq_ttl drops to 0, and may also
        !            19:  * be reclaimed if memory becomes tight.
        !            20:  */
        !            21: struct ipq {
        !            22:        struct  ipq *next,*prev;        /* to other reass headers */
        !            23:        u_char  ipq_ttl;                /* time for reass q to live */
        !            24:        u_char  ipq_p;                  /* protocol of this fragment */
        !            25:        u_short ipq_id;                 /* sequence id for reassembly */
        !            26:        struct  ipasfrag *ipq_next,*ipq_prev;
        !            27:                                        /* to ip headers of fragments */
        !            28:        in_addr ipq_src,ipq_dst;
        !            29: };
        !            30: 
        !            31: /*
        !            32:  * Ip header, when holding a fragment.
        !            33:  *
        !            34:  * Note: ipf_next must be at same offset as ipq_next above
        !            35:  */
        !            36: struct ipasfrag {
        !            37: #ifdef vax
        !            38:        u_char  ip_hl:4,
        !            39:                ip_v:4;
        !            40: #endif
        !            41:        u_char  ipf_mff;                /* copied from (ip_off&IP_MF) */
        !            42:        short   ip_len;
        !            43:        u_short ip_id;
        !            44:        short   ip_off;
        !            45:        u_char  ip_ttl;
        !            46:        u_char  ip_p;
        !            47:        u_short ip_sum;
        !            48:        struct  ipasfrag *ipf_next;     /* next fragment */
        !            49:        struct  ipasfrag *ipf_prev;     /* previous fragment */
        !            50: };
        !            51: 
        !            52: struct ipstat {
        !            53:        int     ips_badsum;             /* checksum bad */
        !            54:        int     ips_tooshort;           /* packet too short */
        !            55:        int     ips_toosmall;           /* not enough data */
        !            56:        int     ips_badhlen;            /* ip header length < data size */
        !            57:        int     ips_badlen;             /* ip length < ip header length */
        !            58:        int     ips_qfull;
        !            59:        int     ips_route;              /* routing output errors */
        !            60:        int     ips_fragout;            /* fragmented packets */
        !            61: };
        !            62: 
        !            63: /* flags passed to ip_output as last parameter */
        !            64: #define        IP_FORWARDING           0x1     /* most of ip header exists */
        !            65: #define        IP_ROUTETOIF            0x10    /* same as SO_DONTROUTE */
        !            66: 
        !            67: #ifdef KERNEL
        !            68: struct ipstat  ipstat;
        !            69: struct ipq     ipq;                    /* ip reass. queue */
        !            70: u_short        ip_id;                          /* ip packet ctr, for ids */
        !            71: #endif
        !            72: 
        !            73: /*
        !            74:  * interface stuff
        !            75:  */
        !            76: struct ipif{
        !            77:        struct queue *queue;
        !            78:        int flags;
        !            79:        int mtu;
        !            80:        in_addr thishost;
        !            81:        in_addr that;
        !            82:        in_addr mask;
        !            83:        int ipackets, ierrors;
        !            84:        int opackets, oerrors;
        !            85:        int arp;
        !            86:        int dev;
        !            87: };
        !            88: #define IFF_UP         0x1
        !            89: #define IFF_HOST       0x2
        !            90: #define IFF_ARP                0x4
        !            91: 
        !            92: #ifdef KERNEL
        !            93: extern struct ipif ipif[];
        !            94: extern struct ipif *ip_ifwithaddr(), *ip_ifonnetof();
        !            95: #endif
        !            96: 
        !            97: #define IPIOHOST       (('i'<<8)|1)
        !            98: #define IPIONET                (('i'<<8)|2)
        !            99: #define IPIOLOCAL      (('i'<<8)|3)
        !           100: #define IPIOARP                (('i'<<8)|4)
        !           101: #define IPIORESOLVE    (('i'<<8)|5)
        !           102: #define IPIOMTU                (('i'<<8)|6)
        !           103: #define IPIOROUTE      (('i'<<8)|7)
        !           104: #define IPIOGETIFS     (('i'<<8)|8)
        !           105: 
        !           106: #define IP_BODY_LIMIT 8192
        !           107: #define IP_MSG_LIMIT (sizeof(struct ipovly) + IP_BODY_LIMIT)
        !           108: 
        !           109: /* an ip routing record */
        !           110: struct ip_route{
        !           111:        long time;              /* time of last access */
        !           112:        in_addr dst;            /* destination */
        !           113:        in_addr gate;           /* gate to use for this destination */
        !           114: };
        !           115: 
        !           116: #ifdef KERNEL
        !           117: /* structure returned by "ip_route" */
        !           118: struct ip_route_info {
        !           119:        in_addr addr;
        !           120:        struct ipif *ifp;
        !           121: };
        !           122: struct ip_route_info ip_route();
        !           123: #endif KERNEL
        !           124: 
        !           125: /* an ip to ethernet address mapping */
        !           126: struct ip_arp{
        !           127:        long time;                      /* time of last access */
        !           128:        in_addr inaddr;                 /* inet address */
        !           129:        unsigned char enaddr[6];        /* ethernet address */
        !           130: };

unix.superglobalmegacorp.com

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