Annotation of 43BSDTahoe/sys/netimp/if_imp.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 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_imp.h    7.5 (Berkeley) 6/29/88
                     18:  */
                     19: 
                     20: /*
                     21:  * Structure of IMP 1822 long leader.
                     22:  */
                     23: struct control_leader {
                     24:        u_char  dl_format;      /* 1-8   leader format */
                     25:        u_char  dl_network;     /* 9-16  src/dest network */
                     26:        u_char  dl_flags;       /* 17-24 leader flags */
                     27:        u_char  dl_mtype;       /* 25-32 message type */
                     28:        u_char  dl_htype;       /* 33-40 handling type */
                     29:        u_char  dl_host;        /* 41-48 host number */
                     30:        u_short dl_imp;         /* 49-64 imp field */
                     31:        u_char  dl_link;        /* 65-72 link number */
                     32:        u_char  dl_subtype;     /* 73-80 message subtype */
                     33: };
                     34: 
                     35: struct imp_leader {
                     36:        struct  control_leader il_dl;
                     37: #define        il_format       il_dl.dl_format
                     38: #define        il_network      il_dl.dl_network
                     39: #define        il_flags        il_dl.dl_flags
                     40: #define        il_mtype        il_dl.dl_mtype
                     41: #define        il_htype        il_dl.dl_htype
                     42: #define        il_host         il_dl.dl_host
                     43: #define        il_imp          il_dl.dl_imp
                     44: #define        il_link         il_dl.dl_link
                     45: #define        il_subtype      il_dl.dl_subtype
                     46:        u_short il_length;      /* message length */
                     47: };
                     48: 
                     49: #define        IMP_MAXHOSTMSG  8       /* max messages in flight to a host */
                     50: #define        IMP_NOOPCNT     3       /* # of noops to send imp on reset */
                     51: /* insure things are even... */
                     52: #define        IMPMTU          ((8159 / NBBY) & ~01)
                     53: #define        IMP_RCVBUF      ((8159 / NBBY + 2) & ~01)
                     54: 
                     55: /*
                     56:  * IMP-host flags
                     57:  */
                     58: #define        IMP_1822L_H2I   0xd     /* 1822L host-to-imp, 96-bit format */
                     59: #define        IMP_1822L_I2H   0xe     /* 1822L imp-to-host, 96-bit format */
                     60: #define        IMP_NFF         0xf     /* 96-bit (new) format */
                     61: #define        IMP_TRACE       0x8     /* trace message route */
                     62: 
                     63: /*
                     64:  * IMP-host message types.
                     65:  */
                     66: #define        IMPTYPE_DATA            0       /* data for protocol */
                     67: #define        IMPTYPE_BADLEADER       1       /* leader error */
                     68: #define        IMPTYPE_DOWN            2       /* imp going down */
                     69: #define        IMPTYPE_NOOP            4       /* noop seen during initialization */
                     70: #define        IMPTYPE_RFNM            5       /* request for new messages */
                     71: #define        IMPTYPE_HOSTDEAD        6       /* host doesn't respond */
                     72: #define        IMPTYPE_HOSTUNREACH     7       /* host unreachable */
                     73: #define        IMPTYPE_BADDATA         8       /* data error */
                     74: #define        IMPTYPE_INCOMPLETE      9       /* incomplete message, send rest */
                     75: #define        IMPTYPE_RESET           10      /* reset complete */
                     76: /* non-blocking IMP interface */
                     77: #define        IMPTYPE_RETRY           11      /* IMP refused, try again */
                     78: #define        IMPTYPE_NOTIFY          12      /* IMP refused, will notify */
                     79: #define        IMPTYPE_TRYING          13      /* IMP refused, still rexmt'ng */
                     80: #define        IMPTYPE_READY           14      /* ready for next message */
                     81: 
                     82: /*
                     83:  * IMPTYPE_DOWN subtypes, in link number field.
                     84:  */
                     85: #define        IMP_DMASK               0x3     /* host going down mask */
                     86: #define        IMPDOWN_GOING           0       /* 30 secs */
                     87: #define        IMPDOWN_PM              1       /* hardware PM */
                     88: #define        IMPDOWN_RELOAD          2       /* software reload */
                     89: #define        IMPDOWN_RESTART         3       /* emergency restart */
                     90: #define        IMPDOWN_WHENMASK        0x3c    /* mask for "how soon" */
                     91: #define        IMPDOWN_WHENSHIFT       2       /* shift for "how soon" */
                     92: #define        IMPDOWN_WHENUNIT        5       /* unit for "how soon", 5 min. */
                     93: 
                     94: #define        IMPTV_DOWN      30              /* going down timer 30 secs */
                     95: 
                     96: #ifdef IMPMESSAGES
                     97: /*
                     98:  * Messages from IMP regarding why
                     99:  * it's going down.
                    100:  */
                    101: char *impmessage[] = {
                    102:        "in 30 seconds",
                    103:        "for hardware PM",
                    104:        "to reload software",
                    105:        "for emergency reset"
                    106: };
                    107: #endif
                    108: 
                    109: /*
                    110:  * IMPTYPE_BADLEADER subtypes.
                    111:  */
                    112: #define        IMPLEADER_ERR           0       /* error flip-flop set */
                    113: #define        IMPLEADER_SHORT         1       /* leader < 80 bits */
                    114: #define        IMPLEADER_TYPE          2       /* illegal type field */
                    115: #define        IMPLEADER_OPPOSITE      3       /* opposite leader type */
                    116: 
                    117: /*
                    118:  * IMPTYPE_HOSTDEAD subtypes.
                    119:  */
                    120: #define        IMPHOST_NORDY           1       /* ready-line negated */
                    121: #define        IMPHOST_TARDY           2       /* tardy receiving mesgs */
                    122: #define        IMPHOST_NOEXIST         3       /* NCC doesn't know host */
                    123: #define        IMPHOST_IMPSOFT         4       /* IMP software won't allow mesgs */
                    124: #define        IMPHOST_PM              5       /* host down for scheduled PM */
                    125: #define        IMPHOST_HARDSCHED       6       /* " " " " hardware work */
                    126: #define        IMPHOST_SOFTSCHED       7       /* " " " " software work */
                    127: #define        IMPHOST_RESTART         8       /* host down for emergency restart */
                    128: #define        IMPHOST_POWER           9       /* down because of power outage */
                    129: #define        IMPHOST_BREAKPOINT      10      /* host stopped at a breakpoint */
                    130: #define        IMPHOST_HARDWARE        11      /* hardware failure */
                    131: #define        IMPHOST_NOTUP           12      /* host not scheduled to be up */
                    132: /* 13-14 currently unused */
                    133: #define        IMPHOST_COMINGUP        15      /* host in process of coming up */
                    134: 
                    135: /*
                    136:  * IMPTYPE_HOSTUNREACH subtypes.
                    137:  */
                    138: #define        IMPREACH_IMP            0       /* destination IMP can't be reached */
                    139: #define        IMPREACH_HOSTUP         1       /* destination host isn't up */
                    140: #define        IMPREACH_LEADER         2       /* host doesn't support long leader */
                    141: #define        IMPREACH_PROHIBITED     3       /* communication is prohibited */
                    142: 
                    143: /*
                    144:  * IMPTYPE_INCOMPLETE subtypes.
                    145:  */
                    146: #define        IMPCOMPLETE_SLOW        0       /* host didn't take data fast enough */
                    147: #define        IMPCOMPLETE_TOOLONG     1       /* message was too long */
                    148: #define        IMPCOMPLETE_TIMEOUT     2       /* mesg transmission time > 15 sec. */
                    149: #define        IMPCOMPLETE_FAILURE     3       /* IMP/circuit failure */
                    150: #define        IMPCOMPLETE_NOSPACE     4       /* no resources within 15 sec. */
                    151: #define        IMPCOMPLETE_IMPIO       5       /* src IMP I/O failure during receipt */
                    152: 
                    153: /*
                    154:  * IMPTYPE_RETRY subtypes.
                    155:  */
                    156: #define        IMPRETRY_BUFFER         0       /* IMP buffer wasn't available */
                    157: #define        IMPRETRY_BLOCK          1       /* connection block unavailable */
                    158: 
                    159: #define        RFNMTIMER       (120*PR_SLOWHZ)  /* time to wait for RFNM for msg. */
                    160: #define        IMP_OTIMER      (5*IFNET_SLOWHZ) /* max output time unless blocked */
                    161: 
                    162: /*
                    163:  * Data structure shared between IMP protocol module and hardware
                    164:  * interface driver.  Used to allow layering of IMP routines on top
                    165:  * of varying device drivers.
                    166:  */
                    167: struct impcb {
                    168:        int     ic_hwunit;              /* H/W unit number */
                    169:        char    *ic_hwname;             /* H/W type name */
                    170:        char    ic_oactive;             /* output in progress */
                    171:        int     (*ic_init)();           /* hardware init routine */
                    172:        int     (*ic_output)();         /* hardware output routine */
                    173:        int     (*ic_down)();           /* hardware "drop ready" routine */
                    174: };
                    175: 
                    176: /*
                    177:  * IMP software status per interface.
                    178:  * (partially shared with the hardware specific module)
                    179:  *
                    180:  * Each interface is referenced by a network interface structure,
                    181:  * imp_if, which the routing code uses to locate the interface.
                    182:  * This structure contains the output queue for the interface, its
                    183:  * address, ...  IMP specific structures used in connecting the
                    184:  * IMP software modules to the hardware specific interface routines
                    185:  * are stored here.  The common structures are made visible to the
                    186:  * interface driver by passing a pointer to the hardware routine
                    187:  * at "attach" time.
                    188:  */
                    189: struct imp_softc {
                    190:        struct  ifnet imp_if;           /* network visible interface */
                    191:        struct  impcb imp_cb;           /* hooks to hardware module */
                    192:        int     imp_state;              /* current state of IMP */
                    193:        int     imp_dropcnt;            /* used during initialization */
                    194:        struct  mbuf *imp_hosts;        /* Head of host table hash chains. */
                    195:        struct  mbuf *imp_hostq;        /* current round-robin-output mark */
                    196:        u_int   imp_hostent;            /* current round-robin-output mark */
                    197:        int     imp_msgready;           /* number of messages ready to send */
                    198:        u_long  imp_block;              /* times imp blocked output */
                    199:        u_long  imp_lostrfnm;           /* rfnm's timed out */
                    200:        u_long  imp_badrfnm;            /* rfnm/incompl after timeout/bogus */
                    201:        u_long  imp_incomplete;         /* incomplete's received */
                    202:        u_long  imp_garbage;            /* bad messages received */
                    203: };
                    204: 
                    205: struct imp_softc *impattach();
                    206: 
                    207: /*
                    208:  * State of an IMP.
                    209:  */
                    210: #define        IMPS_DOWN       0               /* unavailable, host not ready */
                    211: #define        IMPS_WINIT      1               /* imp not ready, waiting for init */
                    212: #define        IMPS_INIT       2               /* coming up */
                    213: #define        IMPS_UP         3               /* ready to go */
                    214: #define        IMPS_GOINGDOWN  4               /* been told we go down soon */
                    215: 
                    216: #define        IMPS_RUNNING(s) ((s) >= IMPS_UP)        /* ready for messages */
                    217: #define        IMPS_IMPREADY(s) ((s) >= IMPS_INIT)     /* IMP ready line on */
                    218: 
                    219: #ifdef IMPLEADERS
                    220: char *impleaders[IMPTYPE_READY+1] = {
                    221:        "DATA", "BADLEADER", "DOWN", "bad", "NOOP", "RFNM", "HOSTDEAD",
                    222:        "HOSTUNREACH", "BADDATA", "INCOMPLETE", "RESET", "RETRY",
                    223:        "NOTIFY", "TRYING", "READY"
                    224: };
                    225: #endif

unix.superglobalmegacorp.com

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