xref: /csrg-svn/sys/deprecated/netimp/if_imp.h (revision 44468)
123167Smckusick /*
234853Sbostic  * Copyright (c) 1982, 1986, 1988 Regents of the University of California.
333453Skarels  * All rights reserved.
423167Smckusick  *
5*44468Sbostic  * %sccs.include.redist.c%
633453Skarels  *
7*44468Sbostic  *	@(#)if_imp.h	7.7 (Berkeley) 06/28/90
823167Smckusick  */
95686Ssam 
105686Ssam /*
115686Ssam  * Structure of IMP 1822 long leader.
125686Ssam  */
135772Swnj struct control_leader {
1433427Skarels 	u_char	dl_format;	/* 1-8   leader format */
1533427Skarels 	u_char	dl_network;	/* 9-16  src/dest network */
1633427Skarels 	u_char	dl_flags;	/* 17-24 leader flags */
1733427Skarels 	u_char	dl_mtype;	/* 25-32 message type */
1833427Skarels 	u_char	dl_htype;	/* 33-40 handling type */
1933427Skarels 	u_char	dl_host;	/* 41-48 host number */
2033427Skarels 	u_short	dl_imp;		/* 49-64 imp field */
2133427Skarels 	u_char	dl_link;	/* 65-72 link number */
2233427Skarels 	u_char	dl_subtype;	/* 73-80 message subtype */
235772Swnj };
245772Swnj 
255686Ssam struct imp_leader {
265772Swnj 	struct	control_leader il_dl;
275772Swnj #define	il_format	il_dl.dl_format
285772Swnj #define	il_network	il_dl.dl_network
295772Swnj #define	il_flags	il_dl.dl_flags
305772Swnj #define	il_mtype	il_dl.dl_mtype
315772Swnj #define	il_htype	il_dl.dl_htype
325772Swnj #define	il_host		il_dl.dl_host
335772Swnj #define	il_imp		il_dl.dl_imp
345772Swnj #define	il_link		il_dl.dl_link
355772Swnj #define	il_subtype	il_dl.dl_subtype
365686Ssam 	u_short	il_length;	/* message length */
375686Ssam };
385686Ssam 
3933453Skarels #define	IMP_MAXHOSTMSG	8	/* max messages in flight to a host */
4033427Skarels #define	IMP_NOOPCNT	3	/* # of noops to send imp on reset */
416270Sroot /* insure things are even... */
426270Sroot #define	IMPMTU		((8159 / NBBY) & ~01)
4333427Skarels #define	IMP_RCVBUF	((8159 / NBBY + 2) & ~01)
445686Ssam 
455686Ssam /*
465686Ssam  * IMP-host flags
475686Ssam  */
4834209Skarels #define	IMP_1822L_H2I	0xd	/* 1822L host-to-imp, 96-bit format */
4934209Skarels #define	IMP_1822L_I2H	0xe	/* 1822L imp-to-host, 96-bit format */
505686Ssam #define	IMP_NFF		0xf	/* 96-bit (new) format */
515686Ssam #define	IMP_TRACE	0x8	/* trace message route */
525686Ssam 
535686Ssam /*
545686Ssam  * IMP-host message types.
555686Ssam  */
565686Ssam #define	IMPTYPE_DATA		0	/* data for protocol */
575686Ssam #define	IMPTYPE_BADLEADER	1	/* leader error */
585686Ssam #define	IMPTYPE_DOWN		2	/* imp going down */
595686Ssam #define	IMPTYPE_NOOP		4	/* noop seen during initialization */
605686Ssam #define	IMPTYPE_RFNM		5	/* request for new messages */
615686Ssam #define	IMPTYPE_HOSTDEAD	6	/* host doesn't respond */
625686Ssam #define	IMPTYPE_HOSTUNREACH	7	/* host unreachable */
635686Ssam #define	IMPTYPE_BADDATA		8	/* data error */
645686Ssam #define	IMPTYPE_INCOMPLETE	9	/* incomplete message, send rest */
655686Ssam #define	IMPTYPE_RESET		10	/* reset complete */
665686Ssam /* non-blocking IMP interface */
675686Ssam #define	IMPTYPE_RETRY		11	/* IMP refused, try again */
685686Ssam #define	IMPTYPE_NOTIFY		12	/* IMP refused, will notify */
695686Ssam #define	IMPTYPE_TRYING		13	/* IMP refused, still rexmt'ng */
705686Ssam #define	IMPTYPE_READY		14	/* ready for next message */
715686Ssam 
725686Ssam /*
7344414Skarels  * Link numbers
7444414Skarels  */
7544414Skarels #define	IMPLINK_IP		155
7644414Skarels #define	IMPLINK_LOWEXPER	156
7744414Skarels #define	IMPLINK_HIGHEXPER	158
7844414Skarels 
7944414Skarels /*
8033427Skarels  * IMPTYPE_DOWN subtypes, in link number field.
815686Ssam  */
8233427Skarels #define	IMP_DMASK		0x3	/* host going down mask */
835686Ssam #define	IMPDOWN_GOING		0	/* 30 secs */
845686Ssam #define	IMPDOWN_PM		1	/* hardware PM */
855686Ssam #define	IMPDOWN_RELOAD		2	/* software reload */
865686Ssam #define	IMPDOWN_RESTART		3	/* emergency restart */
8733427Skarels #define	IMPDOWN_WHENMASK	0x3c	/* mask for "how soon" */
8833427Skarels #define	IMPDOWN_WHENSHIFT	2	/* shift for "how soon" */
8933427Skarels #define	IMPDOWN_WHENUNIT	5	/* unit for "how soon", 5 min. */
905686Ssam 
9133427Skarels #define	IMPTV_DOWN	30		/* going down timer 30 secs */
9233427Skarels 
9333427Skarels #ifdef IMPMESSAGES
945686Ssam /*
9533427Skarels  * Messages from IMP regarding why
9633427Skarels  * it's going down.
9733427Skarels  */
9833427Skarels char *impmessage[] = {
9933427Skarels 	"in 30 seconds",
10033427Skarels 	"for hardware PM",
10133427Skarels 	"to reload software",
10233427Skarels 	"for emergency reset"
10333427Skarels };
10433427Skarels #endif
10533427Skarels 
10633427Skarels /*
1075686Ssam  * IMPTYPE_BADLEADER subtypes.
1085686Ssam  */
1095686Ssam #define	IMPLEADER_ERR		0	/* error flip-flop set */
1105686Ssam #define	IMPLEADER_SHORT		1	/* leader < 80 bits */
1115686Ssam #define	IMPLEADER_TYPE		2	/* illegal type field */
1125686Ssam #define	IMPLEADER_OPPOSITE	3	/* opposite leader type */
1135686Ssam 
1145686Ssam /*
1155686Ssam  * IMPTYPE_HOSTDEAD subtypes.
1165686Ssam  */
1175686Ssam #define	IMPHOST_NORDY		1	/* ready-line negated */
1185686Ssam #define	IMPHOST_TARDY		2	/* tardy receiving mesgs */
1195686Ssam #define	IMPHOST_NOEXIST		3	/* NCC doesn't know host */
1205686Ssam #define	IMPHOST_IMPSOFT		4	/* IMP software won't allow mesgs */
1215686Ssam #define	IMPHOST_PM		5	/* host down for scheduled PM */
1225686Ssam #define	IMPHOST_HARDSCHED	6	/* " " " " hardware work */
1235686Ssam #define	IMPHOST_SOFTSCHED	7	/* " " " " software work */
1245686Ssam #define	IMPHOST_RESTART		8	/* host down for emergency restart */
1255686Ssam #define	IMPHOST_POWER		9	/* down because of power outage */
1265686Ssam #define	IMPHOST_BREAKPOINT	10	/* host stopped at a breakpoint */
1275686Ssam #define	IMPHOST_HARDWARE	11	/* hardware failure */
1285686Ssam #define	IMPHOST_NOTUP		12	/* host not scheduled to be up */
1295686Ssam /* 13-14 currently unused */
1305686Ssam #define	IMPHOST_COMINGUP	15	/* host in process of coming up */
1315686Ssam 
1325686Ssam /*
1335686Ssam  * IMPTYPE_HOSTUNREACH subtypes.
1345686Ssam  */
1355686Ssam #define	IMPREACH_IMP		0	/* destination IMP can't be reached */
1365686Ssam #define	IMPREACH_HOSTUP		1	/* destination host isn't up */
1375686Ssam #define	IMPREACH_LEADER		2	/* host doesn't support long leader */
1385686Ssam #define	IMPREACH_PROHIBITED	3	/* communication is prohibited */
1395686Ssam 
1405686Ssam /*
1415686Ssam  * IMPTYPE_INCOMPLETE subtypes.
1425686Ssam  */
1435686Ssam #define	IMPCOMPLETE_SLOW	0	/* host didn't take data fast enough */
1445686Ssam #define	IMPCOMPLETE_TOOLONG	1	/* message was too long */
1455686Ssam #define	IMPCOMPLETE_TIMEOUT	2	/* mesg transmission time > 15 sec. */
1465686Ssam #define	IMPCOMPLETE_FAILURE	3	/* IMP/circuit failure */
1475686Ssam #define	IMPCOMPLETE_NOSPACE	4	/* no resources within 15 sec. */
1485686Ssam #define	IMPCOMPLETE_IMPIO	5	/* src IMP I/O failure during receipt */
1495686Ssam 
1505686Ssam /*
1515686Ssam  * IMPTYPE_RETRY subtypes.
1525686Ssam  */
1535686Ssam #define	IMPRETRY_BUFFER		0	/* IMP buffer wasn't available */
1545686Ssam #define	IMPRETRY_BLOCK		1	/* connection block unavailable */
1555686Ssam 
15634209Skarels #define	RFNMTIMER	(120*PR_SLOWHZ)	 /* time to wait for RFNM for msg. */
15734209Skarels #define	IMP_OTIMER	(5*IFNET_SLOWHZ) /* max output time unless blocked */
15833453Skarels 
1595686Ssam /*
1605686Ssam  * Data structure shared between IMP protocol module and hardware
1615686Ssam  * interface driver.  Used to allow layering of IMP routines on top
16233427Skarels  * of varying device drivers.
1635686Ssam  */
1645922Ssam struct impcb {
16533427Skarels 	int	ic_hwunit;		/* H/W unit number */
16633427Skarels 	char	*ic_hwname;		/* H/W type name */
1675686Ssam 	char	ic_oactive;		/* output in progress */
1685686Ssam 	int	(*ic_init)();		/* hardware init routine */
16933453Skarels 	int	(*ic_output)();		/* hardware output routine */
17033453Skarels 	int	(*ic_down)();		/* hardware "drop ready" routine */
1715686Ssam };
1725686Ssam 
1735686Ssam /*
17433427Skarels  * IMP software status per interface.
17533427Skarels  * (partially shared with the hardware specific module)
17633427Skarels  *
17733427Skarels  * Each interface is referenced by a network interface structure,
17833427Skarels  * imp_if, which the routing code uses to locate the interface.
17933427Skarels  * This structure contains the output queue for the interface, its
18033427Skarels  * address, ...  IMP specific structures used in connecting the
18133427Skarels  * IMP software modules to the hardware specific interface routines
18233427Skarels  * are stored here.  The common structures are made visible to the
18333427Skarels  * interface driver by passing a pointer to the hardware routine
18433427Skarels  * at "attach" time.
18533427Skarels  */
18633427Skarels struct imp_softc {
18733427Skarels 	struct	ifnet imp_if;		/* network visible interface */
18833427Skarels 	struct	impcb imp_cb;		/* hooks to hardware module */
18933427Skarels 	int	imp_state;		/* current state of IMP */
19033427Skarels 	int	imp_dropcnt;		/* used during initialization */
19133453Skarels 	struct	mbuf *imp_hosts;	/* Head of host table hash chains. */
19233453Skarels 	struct	mbuf *imp_hostq;	/* current round-robin-output mark */
19333453Skarels 	u_int	imp_hostent;		/* current round-robin-output mark */
19433453Skarels 	int	imp_msgready;		/* number of messages ready to send */
19533453Skarels 	u_long	imp_block;		/* times imp blocked output */
19633427Skarels 	u_long	imp_lostrfnm;		/* rfnm's timed out */
19733427Skarels 	u_long	imp_badrfnm;		/* rfnm/incompl after timeout/bogus */
19833427Skarels 	u_long	imp_incomplete;		/* incomplete's received */
19933427Skarels 	u_long	imp_garbage;		/* bad messages received */
20033427Skarels };
20133453Skarels 
20233427Skarels struct	imp_softc *impattach();
20333427Skarels 
20433427Skarels /*
2055686Ssam  * State of an IMP.
2065686Ssam  */
20733427Skarels #define	IMPS_DOWN	0		/* unavailable, host not ready */
20833427Skarels #define	IMPS_WINIT	1		/* imp not ready, waiting for init */
2095686Ssam #define	IMPS_INIT	2		/* coming up */
2105686Ssam #define	IMPS_UP		3		/* ready to go */
21133427Skarels #define	IMPS_GOINGDOWN	4		/* been told we go down soon */
2125686Ssam 
21333427Skarels #define	IMPS_RUNNING(s)	((s) >= IMPS_UP)	/* ready for messages */
21433427Skarels #define	IMPS_IMPREADY(s) ((s) >= IMPS_INIT)	/* IMP ready line on */
2155772Swnj 
2165772Swnj #ifdef IMPLEADERS
2175922Ssam char *impleaders[IMPTYPE_READY+1] = {
2185772Swnj 	"DATA", "BADLEADER", "DOWN", "bad", "NOOP", "RFNM", "HOSTDEAD",
2195772Swnj 	"HOSTUNREACH", "BADDATA", "INCOMPLETE", "RESET", "RETRY",
2205772Swnj 	"NOTIFY", "TRYING", "READY"
2215772Swnj };
2225772Swnj #endif
223