xref: /csrg-svn/sys/vax/if/if_vv.h (revision 44565)
123306Smckusick /*
229290Smckusick  * Copyright (c) 1982, 1986 Regents of the University of California.
335328Sbostic  * All rights reserved.
423306Smckusick  *
5*44565Sbostic  * %sccs.include.redist.c%
635328Sbostic  *
7*44565Sbostic  *	@(#)if_vv.h	7.4 (Berkeley) 06/28/90
823306Smckusick  */
921780Skarels 
107025Ssam /*
1121780Skarels  * ECO 176-748 changed the braodcast address from 0 to 0xff, at
1221780Skarels  * CTL (p1002) serial number around 150.
1321780Skarels  * It was implemented in August, 1982. This is a field-installable ECO,
1421780Skarels  * which improves net reliability. If the broadcast address has not been
1521780Skarels  * changed, comment out the following line.
167025Ssam  */
1721780Skarels #define	NEW_BROADCAST		/* new chip for broadcast problem */
1811193Ssam 
1921780Skarels /*
2021780Skarels  * Local network header for proNET Ring
2121780Skarels  * This is arbitrated by "jas@proteon"
2221780Skarels  * (aka John Shriver, 617-655-3340)
2321780Skarels  */
2411193Ssam 
257025Ssam struct vv_header {
267025Ssam 	 /* the first two fields are required by the hardware */
277025Ssam 	u_char	vh_dhost;	/* destination address */
287025Ssam 	u_char	vh_shost;	/* source address */
297025Ssam 	/* the next three fields are the local network header */
307025Ssam 	u_char	vh_version;	/* header version */
317025Ssam 	u_char	vh_type;	/* packet type => protocol number */
327025Ssam 	short	vh_info;	/* protocol-specific information */
337025Ssam };
347025Ssam 
3511193Ssam #define	RING_VERSION	2	/* current version of v2lni header */
367025Ssam 
377025Ssam /*
3821780Skarels  * Packet types (protocol numbers) in proNET protocol header
3921780Skarels  * Other types are defined, but are proprietary.
407025Ssam  */
417025Ssam #define	RING_IP		1
4226951Sjas #define	RING_TRAILER	2	/* offset now in vh_info only */
4326951Sjas #define RING_ARP	3
4421780Skarels #define RING_HDLC	4
4521780Skarels #define RING_VAXDB	5
4621780Skarels #define RING_RINGWAY	6
4721780Skarels #define RING_RINGWAYM	8
4821780Skarels #define	RING_NOVELL	10
4921780Skarels #define RING_PUP	12
5021780Skarels #define RING_XNS	14
5121780Skarels #define	RING_DIAGNOSTICS 15	/* protocol type for testing */
5221780Skarels #define	RING_ECHO	16
5340841Ssklower #define RING_8022	23
547025Ssam 
5511193Ssam #ifdef NEW_BROADCAST
5611193Ssam #define	VV_BROADCAST	0xff	/* hardware-defined broadcast address */
5711193Ssam #else
5811193Ssam #define	VV_BROADCAST	0x00	/* hardware-defined broadcast address */
5911193Ssam #endif
607025Ssam 
617025Ssam /*
6221780Skarels  * Proteon proNET Hardware definitions
6321780Skarels  * register bit definitions
647025Ssam  */
657025Ssam #define	VV_ENB	01		/* Enable Operation */
667025Ssam #define	VV_DEN	02		/* Enable DMA */
677025Ssam #define	VV_HEN	04		/* Host Relay Enable (Rcv) */
687025Ssam #define	VV_CPB	04		/* Clear Packet Buffer (Xmit) */
697025Ssam #define	VV_STE	010		/* Self Test Enable (Rcv) */
707025Ssam #define	VV_UT1	010		/* Unused (Xmit) */
717025Ssam #define	VV_LPB	020		/* Modem Disable (Rcv) */
727025Ssam #define	VV_INR	020		/* Initialize Ring (Xmit) */
737025Ssam #define	VV_RST	040		/* Reset */
747025Ssam #define	VV_IEN	0100		/* Interrupt Enable */
757025Ssam #define	VV_RDY	0200		/* Done */
767025Ssam #define	VV_DPR	0400		/* Data Present (Rcv) */
777025Ssam #define	VV_RFS	0400		/* Refused (Xmit) */
787025Ssam #define	VV_NXM	01000		/* Non Existent Memory */
797025Ssam #define	VV_OVR	02000		/* Overrun */
8021780Skarels #define	VV_ODB	04000		/* Odd Byte (Rcv) */
817025Ssam #define	VV_UT2	04000		/* Unused (Xmit) */
8221780Skarels #define	VV_LDE	010000		/* Parity on 10 megabit (Rcv), */
8321780Skarels 				/* Link Data Error on 80 megabit (Rcv) */
847025Ssam #define	VV_OPT	010000		/* Output Timeout (Xmit) */
857025Ssam #define	VV_NOK	020000		/* Ring Not OK */
867025Ssam #define	VV_BDF	040000		/* Bad Format in Operation */
877025Ssam #define	VV_NIR	0100000		/* Not in Ring */
887025Ssam 
897025Ssam #define	VVXERR	(VV_NXM|VV_OVR|VV_OPT|VV_BDF)	/* Xmit errs */
9026904Sjas #define	VVRERR	(VV_NXM|VV_OVR|VV_ODB|VV_BDF|VV_DPR)	/* Rcv errs */
917025Ssam #define	VVFE	(VV_NXM|VV_OVR)			/* Fatal errors */
927025Ssam 
937025Ssam #define VV_IBITS \
947025Ssam "\10\20NIR\17BDF\16NOK\15LDE\14ODB\13OVR\12NXM\11DPR\10RDY\7IEN\6RST\5LPB\4STE\3HEN\2DEN\1ENB"
957025Ssam 
967025Ssam #define VV_OBITS \
977025Ssam "\10\20NIR\17BDF\16NOK\15OPT\13OVR\12NXM\11RFS\10RDY\7IEN\6RST\5INR\3HEN\2DEN\1ENB"
987025Ssam 
997025Ssam /* device registers */
1007025Ssam struct vvreg {
1017025Ssam 	short	vvicsr;		/* input csr */
1027025Ssam 	u_short	vviwc;		/* input word count */
1037025Ssam 	u_short	vviba;		/* input addr lo */
1047025Ssam 	u_short	vviea;		/* input addr hi */
1057025Ssam 	short	vvocsr;		/* output csr */
1067025Ssam 	u_short	vvowc;		/* output word count */
1077025Ssam 	u_short	vvoba;		/* output addr lo */
1087025Ssam 	u_short	vvoea;		/* output addr hi */
1097025Ssam };
1107025Ssam 
11115793Sleres #define	VVRETRY	7		/* output retry limit */
11221780Skarels #define VVIDENTSUCC 5		/* number of successes required in self-test */
11321780Skarels #define VVIDENTRETRY 10		/* identify loop attempt limit */
11415793Sleres #define VVTIMEOUT 60		/* seconds before a transmit timeout */
115