aboutsummaryrefslogtreecommitdiff
path: root/i386/i386at/if_wd8003.h
diff options
context:
space:
mode:
Diffstat (limited to 'i386/i386at/if_wd8003.h')
-rw-r--r--i386/i386at/if_wd8003.h315
1 files changed, 315 insertions, 0 deletions
diff --git a/i386/i386at/if_wd8003.h b/i386/i386at/if_wd8003.h
new file mode 100644
index 00000000..3fa35ddc
--- /dev/null
+++ b/i386/i386at/if_wd8003.h
@@ -0,0 +1,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