1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
|
/*
* Mach Operating System
* Copyright (c) 1991,1990,1989 Carnegie Mellon University
* All Rights Reserved.
*
* Permission to use, copy, modify and distribute this software and its
* documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
* ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie Mellon
* the rights to redistribute these changes.
*/
/*
* Western Digital Mach Ethernet driver
* Copyright (c) 1990 OSF Research Institute
*/
/*
Copyright 1990 by Open Software Foundation,
Cambridge, MA.
All Rights Reserved
Permission to use, copy, modify, and distribute this software and
its documentation for any purpose and without fee is hereby granted,
provided that the above copyright notice appears in all copies and
that both the copyright notice and this permission notice appear in
supporting documentation, and that the name of OSF or Open Software
Foundation not be used in advertising or publicity pertaining to
distribution of the software without specific, written prior
permission.
OSF DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS,
IN NO EVENT SHALL OSF BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
/***********************************************************/
/* Defines for the 583 chip. */
/***********************************************************/
/*--- 8390 Registers ---*/
#define OFF_8390 0x10 /* offset of the 8390 chip */
/* Register offsets */
#define IFWD_REG_0 0x00
#define IFWD_REG_1 0x01
#define IFWD_REG_2 0x02
#define IFWD_REG_3 0x03
#define IFWD_REG_4 0x04
#define IFWD_REG_5 0x05
#define IFWD_REG_6 0x06
#define IFWD_REG_7 0x07
/* Register offset definitions for all boards */
#define IFWD_LAR_0 0x08
#define IFWD_LAR_1 0x09
#define IFWD_LAR_2 0x0a
#define IFWD_LAR_3 0x0b
#define IFWD_LAR_4 0x0c
#define IFWD_LAR_5 0x0d
#define IFWD_BOARD_ID 0x0e
#define IFWD_CHKSUM 0x0f
/* revision number mask for BOARD_ID */
#define IFWD_BOARD_REV_MASK 0x1e
/* REG 1 */
#define IFWD_MEMSIZE 0x08
#define IFWD_16BIT 0x01
/* REG 5 */
#define IFWD_REG5_MEM_MASK 0x3f /* B23-B19 of address of the memory */
#define IFWD_LA19 0x01 /* B19 of address of the memory */
#define IFWD_MEM16ENB 0x80 /* Enable 16 bit memory access from bus */
#define IFWD_LAN16ENB 0x40 /* Enable 16 bit memory access from chip*/
#define IFWD_INIT_LAAR IFWD_LA19
#define IFWD_SOFTINT 0x20 /* Enable interrupt from pc */
/* Defs for board rev numbers > 1 */
#define IFWD_MEDIA_TYPE 0x01
#define IFWD_SOFT_CONFIG 0x20
#define IFWD_RAM_SIZE 0x40
#define IFWD_BUS_TYPE 0x80
/* Register offsets for reading the EEPROM in the 584 chip */
#define IFWD_EEPROM_0 0x08
#define IFWD_EEPROM_1 0x09
#define IFWD_EEPROM_2 0x0A
#define IFWD_EEPROM_3 0x0B
#define IFWD_EEPROM_4 0x0C
#define IFWD_EEPROM_5 0x0D
#define IFWD_EEPROM_6 0x0E
#define IFWD_EEPROM_7 0x0F
/**** defs for manipulating the 584 ****/
#define IFWD_OTHER_BIT 0x02
#define IFWD_ICR_MASK 0x0C
#define IFWD_EAR_MASK 0x0F
#define IFWD_ENGR_PAGE 0xA0
/* #define IFWD_RLA 0x10 defined in ICR defs */
#define IFWD_EA6 0x80
#define IFWD_RECALL_DONE_MASK 0x10
#define IFWD_EEPROM_MEDIA_MASK 0x07
#define IFWD_STARLAN_TYPE 0x00
#define IFWD_ETHERNET_TYPE 0x01
#define IFWD_TP_TYPE 0x02
#define IFWD_EW_TYPE 0x03
#define IFWD_EEPROM_IRQ_MASK 0x18
#define IFWD_PRIMARY_IRQ 0x00
#define IFWD_ALTERNATE_IRQ_1 0x08
#define IFWD_ALTERNATE_IRQ_2 0x10
#define IFWD_ALTERNATE_IRQ_3 0x18
#define IFWD_EEPROM_RAM_SIZE_MASK 0xE0
#define IFWD_EEPROM_RAM_SIZE_RES1 0x00
#define IFWD_EEPROM_RAM_SIZE_RES2 0x20
#define IFWD_EEPROM_RAM_SIZE_8K 0x40
#define IFWD_EEPROM_RAM_SIZE_16K 0x60
#define IFWD_EEPROM_RAM_SIZE_32K 0x80
#define IFWD_EEPROM_RAM_SIZE_64K 0xA0
#define IFWD_EEPROM_RAM_SIZE_RES3 0xC0
#define IFWD_EEPROM_RAM_SIZE_RES4 0xE0
#define IFWD_EEPROM_BUS_TYPE_MASK 0x07
#define IFWD_EEPROM_BUS_TYPE_AT 0x00
#define IFWD_EEPROM_BUS_TYPE_MCA 0x01
#define IFWD_EEPROM_BUS_TYPE_EISA 0x02
#define IFWD_EEPROM_BUS_SIZE_MASK 0x18
#define IFWD_EEPROM_BUS_SIZE_8BIT 0x00
#define IFWD_EEPROM_BUS_SIZE_16BIT 0x08
#define IFWD_EEPROM_BUS_SIZE_32BIT 0x10
#define IFWD_EEPROM_BUS_SIZE_64BIT 0x18
/*****************************************************************************
* *
* Definitions for board ID. *
* *
* note: board ID should be ANDed with the STATIC_ID_MASK *
* before comparing to a specific board ID *
* The high order 16 bits correspond to the Extra Bits which do not *
* change the boards ID. *
* *
* Note: not all are implemented. Rest are here for future enhancements...*
* *
*****************************************************************************/
#define IFWD_STARLAN_MEDIA 0x00000001 /* StarLAN */
#define IFWD_ETHERNET_MEDIA 0x00000002 /* Ethernet */
#define IFWD_TWISTED_PAIR_MEDIA 0x00000003 /* Twisted Pair */
#define IFWD_EW_MEDIA 0x00000004 /* Ethernet and Twisted Pair */
#define IFWD_MICROCHANNEL 0x00000008 /* MicroChannel Adapter */
#define IFWD_INTERFACE_CHIP 0x00000010 /* Soft Config Adapter */
/* #define IFWD_UNUSED 0x00000020 */ /* used to be INTELLIGENT */
#define IFWD_BOARD_16BIT 0x00000040 /* 16 bit capability */
#define IFWD_RAM_SIZE_UNKNOWN 0x00000000 /* 000 => Unknown RAM Size */
#define IFWD_RAM_SIZE_RES_1 0x00010000 /* 001 => Reserved */
#define IFWD_RAM_SIZE_8K 0x00020000 /* 010 => 8k RAM */
#define IFWD_RAM_SIZE_16K 0x00030000 /* 011 => 16k RAM */
#define IFWD_RAM_SIZE_32K 0x00040000 /* 100 => 32k RAM */
#define IFWD_RAM_SIZE_64K 0x00050000 /* 101 => 64k RAM */
#define IFWD_RAM_SIZE_RES_6 0x00060000 /* 110 => Reserved */
#define IFWD_RAM_SIZE_RES_7 0x00070000 /* 111 => Reserved */
#define IFWD_SLOT_16BIT 0x00080000 /* 16 bit board - 16 bit slot*/
#define IFWD_NIC_690_BIT 0x00100000 /* NIC is 690 */
#define IFWD_ALTERNATE_IRQ_BIT 0x00200000 /* Alternate IRQ is used */
#define IFWD_INTERFACE_584_CHIP 0x00400000 /* Interface chip is a 584 */
#define IFWD_MEDIA_MASK 0x00000007 /* Isolates Media Type */
#define IFWD_RAM_SIZE_MASK 0x00070000 /* Isolates RAM Size */
#define IFWD_STATIC_ID_MASK 0x0000FFFF /* Isolates Board ID */
/* Word definitions for board types */
#define WD8003E IFWD_ETHERNET_MEDIA
#define WD8003EBT WD8003E /* functionally identical to WD8003E */
#define WD8003S IFWD_STARLAN_MEDIA
#define WD8003SH WD8003S /* functionally identical to WD8003S */
#define WD8003WT IFWD_TWISTED_PAIR_MEDIA
#define WD8003W (IFWD_TWISTED_PAIR_MEDIA | IFWD_INTERFACE_CHIP)
#define WD8003EB (IFWD_ETHERNET_MEDIA | IFWD_INTERFACE_CHIP)
#define WD8003EP WD8003EB /* with IFWD_INTERFACE_584_CHIP bit set */a
#define WD8003EW (IFWD_EW_MEDIA | IFWD_INTERFACE_CHIP)
#define WD8003ETA (IFWD_ETHERNET_MEDIA | IFWD_MICROCHANNEL)
#define WD8003STA (IFWD_STARLAN_MEDIA | IFWD_MICROCHANNEL)
#define WD8003EA (IFWD_ETHERNET_MEDIA | IFWD_MICROCHANNEL | \
IFWD_INTERFACE_CHIP)
#define WD8003SHA (IFWD_STARLAN_MEDIA | IFWD_MICROCHANNEL | \
IFWD_INTERFACE_CHIP)
#define WD8003WA (IFWD_TWISTED_PAIR_MEDIA | IFWD_MICROCHANNEL | \
IFWD_INTERFACE_CHIP)
#define WD8013EBT (IFWD_ETHERNET_MEDIA | IFWD_BOARD_16BIT)
#define WD8013EB (IFWD_ETHERNET_MEDIA | IFWD_BOARD_16BIT | \
IFWD_INTERFACE_CHIP)
#define WD8013EP WD8013EB /* with IFWD_INTERFACE_584_CHIP bit set */
#define WD8013W (IFWD_TWISTED_PAIR_MEDIA | IFWD_BOARD_16BIT | \
IFWD_INTERFACE_CHIP)
#define WD8013EW (IFWD_EW_MEDIA | IFWD_BOARD_16BIT | \
IFWD_INTERFACE_CHIP)
/**** Western digital node bytes ****/
#define WD_NODE_ADDR_0 0x00
#define WD_NODE_ADDR_1 0x00
#define WD_NODE_ADDR_2 0xC0
/*--- 83c583 registers ---*/
#define IFWD_MSR 0x00 /* memory select register */
/* In 584 Board's command register */
#define IFWD_ICR 0x01 /* interface configuration register */
/* In 584 8013 bus size register */
#define IFWD_IAR 0x02 /* io address register */
#define IFWD_BIO 0x03 /* bios ROM address register */
#define IFWD_IRR 0x04 /* interrupt request register */
#define IFWD_GP1 0x05 /* general purpose register 1 */
#define IFWD_IOD 0x06 /* io data latch */
#define IFWD_GP2 0x07 /* general purpose register 2 */
#define IFWD_LAR 0x08 /* LAN address register */
#define IFWD_LAR2 0x09 /* */
#define IFWD_LAR3 0x0A /* */
#define IFWD_LAR4 0x0B /* */
#define IFWD_LAR5 0x0C /* */
#define IFWD_LAR6 0x0D /* */
#define IFWD_LAR7 0x0E /* */
#define IFWD_LAR8 0x0F /* LAN address register */
/********************* Register Bit Definitions **************************/
/* MSR definitions */
#define IFWD_RST 0x80 /* 1 => reset */
#define IFWD_MENB 0x40 /* 1 => memory enable */
#define IFWD_SA18 0x20 /* Memory enable bits */
#define IFWD_SA17 0x10 /* telling where shared */
#define IFWD_SA16 0x08 /* mem is to start. */
#define IFWD_SA15 0x04 /* Assume SA19 = 1 */
#define IFWD_SA14 0x02 /* */
#define IFWD_SA13 0x01 /* */
/* ICR definitions */
#define IFWD_STR 0x80 /* Non-volatile EEPROM store */
#define IFWD_RCL 0x40 /* Recall I/O Address from EEPROM */
#define IFWD_RX7 0x20 /* Recall all but I/O and LAN address*/
#define IFWD_RLA 0x10 /* Recall LAN Address */
#define IFWD_MSZ 0x08 /* Shared Memory Size */
#define IFWD_DMAE 0x04 /* DMA Enable */
#define IFWD_IOPE 0x02 /* I/O Port Enable */
#define IFWD_WTS 0x01 /* Word Transfer Select */
/* IAR definitions */
#define IFWD_IA15 0x80 /* I/O Address Bits */
/* . */
/* . */
/* . */
#define IFWD_IA5 0x01 /* */
/* BIO definitions */
#define IFWD_RS1 0x80 /* BIOS size bit 1 */
#define IFWD_RS0 0x40 /* BIOS size bit 0 */
#define IFWD_BA18 0x20 /* BIOS ROM Memory Address Bits */
#define IFWD_BA17 0x10 /* */
#define IFWD_BA16 0x08 /* */
#define IFWD_BA15 0x04 /* */
#define IFWD_BA14 0x02 /* BIOS ROM Memory Address Bits */
#define IFWD_WINT 0x01 /* W8003 interrupt */
/* IRR definitions */
#define IFWD_IEN 0x80 /* Interrupt Enable */
#define IFWD_IR1 0x40 /* Interrupt request bit 1 */
#define IFWD_IR0 0x20 /* Interrupt request bit 0 */
#define IFWD_AMD 0x10 /* Alternate mode */
#define IFWD_AINT 0x08 /* Alternate interrupt */
#define IFWD_BW1 0x04 /* BIOS Wait State Control bit 1 */
#define IFWD_BW0 0x02 /* BIOS Wait State Control bit 0 */
#define IFWD_OWS 0x01 /* Zero Wait State Enable */
/* GP1 definitions */
/* IOD definitions */
/* GP2 definitions */
/*************************************************************/
/* Shared RAM buffer definitions */
/*************************************************************/
/**** NIC definitions ****/
#define NIC_8003_SRAM_SIZE 0x2000 /* size of shared RAM buffer */
#define NIC_HEADER_SIZE 4 /* size of receive header */
#define NIC_PAGE_SIZE 0x100 /* each page of rcv ring is 256 byte */
#define ETHER_ADDR_SIZE 6 /* size of a MAC address */
#ifdef MACH
#define HZ 100
#endif
#define DSF_LOCK 1
#define DSF_RUNNING 2
#define MOD_ENAL 1
#define MOD_PROM 2
|