2  * Amiga Linux/68k A2065 Ethernet Driver
 
   4  * (C) Copyright 1995 by Geert Uytterhoeven <geert@linux-m68k.org>
 
   6  * ---------------------------------------------------------------------------
 
   8  * This program is based on
 
  10  *      ariadne.?:      Amiga Linux/68k Ariadne Ethernet Driver
 
  11  *                      (C) Copyright 1995 by Geert Uytterhoeven,
 
  14  *      lance.c:        An AMD LANCE ethernet driver for linux.
 
  15  *                      Written 1993-94 by Donald Becker.
 
  17  *      Am79C960:       PCnet(tm)-ISA Single-Chip Ethernet Controller
 
  18  *                      Advanced Micro Devices
 
  19  *                      Publication #16907, Rev. B, Amendment/0, May 1994
 
  21  * ---------------------------------------------------------------------------
 
  23  * This file is subject to the terms and conditions of the GNU General Public
 
  24  * License.  See the file COPYING in the main directory of the Linux
 
  25  * distribution for more details.
 
  27  * ---------------------------------------------------------------------------
 
  29  * The A2065 is a Zorro-II board made by Commodore/Ameristar. It contains:
 
  31  *      - an Am7990 Local Area Network Controller for Ethernet (LANCE) with
 
  32  *        both 10BASE-2 (thin coax) and AUI (DB-15) connectors
 
  37  *              Am7990 Local Area Network Controller for Ethernet (LANCE)
 
  41         unsigned short rdp;             /* Register Data Port */
 
  42         unsigned short rap;             /* Register Address Port */
 
  47  *              Am7990 Control and Status Registers
 
  50 #define LE_CSR0         0x0000          /* LANCE Controller Status */
 
  51 #define LE_CSR1         0x0001          /* IADR[15:0] */
 
  52 #define LE_CSR2         0x0002          /* IADR[23:16] */
 
  53 #define LE_CSR3         0x0003          /* Misc */
 
  57  *              Bit definitions for CSR0 (LANCE Controller Status)
 
  60 #define LE_C0_ERR       0x8000          /* Error */
 
  61 #define LE_C0_BABL      0x4000          /* Babble: Transmitted too many bits */
 
  62 #define LE_C0_CERR      0x2000          /* No Heartbeat (10BASE-T) */
 
  63 #define LE_C0_MISS      0x1000          /* Missed Frame */
 
  64 #define LE_C0_MERR      0x0800          /* Memory Error */
 
  65 #define LE_C0_RINT      0x0400          /* Receive Interrupt */
 
  66 #define LE_C0_TINT      0x0200          /* Transmit Interrupt */
 
  67 #define LE_C0_IDON      0x0100          /* Initialization Done */
 
  68 #define LE_C0_INTR      0x0080          /* Interrupt Flag */
 
  69 #define LE_C0_INEA      0x0040          /* Interrupt Enable */
 
  70 #define LE_C0_RXON      0x0020          /* Receive On */
 
  71 #define LE_C0_TXON      0x0010          /* Transmit On */
 
  72 #define LE_C0_TDMD      0x0008          /* Transmit Demand */
 
  73 #define LE_C0_STOP      0x0004          /* Stop */
 
  74 #define LE_C0_STRT      0x0002          /* Start */
 
  75 #define LE_C0_INIT      0x0001          /* Initialize */
 
  79  *              Bit definitions for CSR3
 
  82 #define LE_C3_BSWP      0x0004          /* Byte Swap
 
  83                                            (on for big endian byte order) */
 
  84 #define LE_C3_ACON      0x0002          /* ALE Control
 
  85                                            (on for active low ALE) */
 
  86 #define LE_C3_BCON      0x0001          /* Byte Control */
 
  93 #define LE_MO_PROM      0x8000          /* Promiscuous Mode */
 
  94 #define LE_MO_INTL      0x0040          /* Internal Loopback */
 
  95 #define LE_MO_DRTY      0x0020          /* Disable Retry */
 
  96 #define LE_MO_FCOLL     0x0010          /* Force Collision */
 
  97 #define LE_MO_DXMTFCS   0x0008          /* Disable Transmit CRC */
 
  98 #define LE_MO_LOOP      0x0004          /* Loopback Enable */
 
  99 #define LE_MO_DTX       0x0002          /* Disable Transmitter */
 
 100 #define LE_MO_DRX       0x0001          /* Disable Receiver */
 
 103 struct lance_rx_desc {
 
 104         unsigned short rmd0;        /* low address of packet */
 
 105         unsigned char  rmd1_bits;   /* descriptor bits */
 
 106         unsigned char  rmd1_hadr;   /* high address of packet */
 
 107         short    length;            /* This length is 2s complement (negative)!
 
 110         unsigned short mblength;    /* Aactual number of bytes received */
 
 113 struct lance_tx_desc {
 
 114         unsigned short tmd0;        /* low address of packet */
 
 115         unsigned char  tmd1_bits;   /* descriptor bits */
 
 116         unsigned char  tmd1_hadr;   /* high address of packet */
 
 117         short    length;            /* Length is 2s complement (negative)! */
 
 126 #define LE_R1_OWN       0x80            /* LANCE owns the descriptor */
 
 127 #define LE_R1_ERR       0x40            /* Error */
 
 128 #define LE_R1_FRA       0x20            /* Framing Error */
 
 129 #define LE_R1_OFL       0x10            /* Overflow Error */
 
 130 #define LE_R1_CRC       0x08            /* CRC Error */
 
 131 #define LE_R1_BUF       0x04            /* Buffer Error */
 
 132 #define LE_R1_SOP       0x02            /* Start of Packet */
 
 133 #define LE_R1_EOP       0x01            /* End of Packet */
 
 134 #define LE_R1_POK       0x03            /* Packet is complete: SOP + EOP */
 
 141 #define LE_T1_OWN       0x80            /* LANCE owns the descriptor */
 
 142 #define LE_T1_ERR       0x40            /* Error */
 
 143 #define LE_T1_RES       0x20            /* Reserved,
 
 144                                            LANCE writes this with a zero */
 
 145 #define LE_T1_EMORE     0x10            /* More than one retry needed */
 
 146 #define LE_T1_EONE      0x08            /* One retry needed */
 
 147 #define LE_T1_EDEF      0x04            /* Deferred */
 
 148 #define LE_T1_SOP       0x02            /* Start of Packet */
 
 149 #define LE_T1_EOP       0x01            /* End of Packet */
 
 150 #define LE_T1_POK       0x03            /* Packet is complete: SOP + EOP */
 
 157 #define LE_T3_BUF       0x8000          /* Buffer Error */
 
 158 #define LE_T3_UFL       0x4000          /* Underflow Error */
 
 159 #define LE_T3_LCOL      0x1000          /* Late Collision */
 
 160 #define LE_T3_CLOS      0x0800          /* Loss of Carrier */
 
 161 #define LE_T3_RTY       0x0400          /* Retry Error */
 
 162 #define LE_T3_TDR       0x03ff          /* Time Domain Reflectometry */
 
 166  *              A2065 Expansion Board Structure
 
 169 #define A2065_LANCE             0x4000
 
 171 #define A2065_RAM               0x8000
 
 172 #define A2065_RAM_SIZE          0x8000