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