1*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* 2*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Ported to U-Boot by Christian Pellegrin <chri@ascensit.com> 3*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 4*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Based on sources from the Linux kernel (pcnet_cs.c, 8390.h) and 5*2439e4bfSJean-Christophe PLAGNIOL-VILLARD eCOS(if_dp83902a.c, if_dp83902a.h). Both of these 2 wonderful world 6*2439e4bfSJean-Christophe PLAGNIOL-VILLARD are GPL, so this is, of course, GPL. 7*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 8*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 9*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ========================================================================== 10*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 11*2439e4bfSJean-Christophe PLAGNIOL-VILLARD dev/dp83902a.h 12*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 13*2439e4bfSJean-Christophe PLAGNIOL-VILLARD National Semiconductor DP83902a ethernet chip 14*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 15*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ========================================================================== 16*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ####ECOSGPLCOPYRIGHTBEGIN#### 17*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ------------------------------------------- 18*2439e4bfSJean-Christophe PLAGNIOL-VILLARD This file is part of eCos, the Embedded Configurable Operating System. 19*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc. 20*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 21*2439e4bfSJean-Christophe PLAGNIOL-VILLARD eCos is free software; you can redistribute it and/or modify it under 22*2439e4bfSJean-Christophe PLAGNIOL-VILLARD the terms of the GNU General Public License as published by the Free 23*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Software Foundation; either version 2 or (at your option) any later version. 24*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 25*2439e4bfSJean-Christophe PLAGNIOL-VILLARD eCos is distributed in the hope that it will be useful, but WITHOUT ANY 26*2439e4bfSJean-Christophe PLAGNIOL-VILLARD WARRANTY; without even the implied warranty of MERCHANTABILITY or 27*2439e4bfSJean-Christophe PLAGNIOL-VILLARD FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 28*2439e4bfSJean-Christophe PLAGNIOL-VILLARD for more details. 29*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 30*2439e4bfSJean-Christophe PLAGNIOL-VILLARD You should have received a copy of the GNU General Public License along 31*2439e4bfSJean-Christophe PLAGNIOL-VILLARD with eCos; if not, write to the Free Software Foundation, Inc., 32*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. 33*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 34*2439e4bfSJean-Christophe PLAGNIOL-VILLARD As a special exception, if other files instantiate templates or use macros 35*2439e4bfSJean-Christophe PLAGNIOL-VILLARD or inline functions from this file, or you compile this file and link it 36*2439e4bfSJean-Christophe PLAGNIOL-VILLARD with other works to produce a work based on this file, this file does not 37*2439e4bfSJean-Christophe PLAGNIOL-VILLARD by itself cause the resulting work to be covered by the GNU General Public 38*2439e4bfSJean-Christophe PLAGNIOL-VILLARD License. However the source code for this file must still be made available 39*2439e4bfSJean-Christophe PLAGNIOL-VILLARD in accordance with section (3) of the GNU General Public License. 40*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 41*2439e4bfSJean-Christophe PLAGNIOL-VILLARD This exception does not invalidate any other reasons why a work based on 42*2439e4bfSJean-Christophe PLAGNIOL-VILLARD this file might be covered by the GNU General Public License. 43*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 44*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Alternative licenses for eCos may be arranged by contacting Red Hat, Inc. 45*2439e4bfSJean-Christophe PLAGNIOL-VILLARD at http://sources.redhat.com/ecos/ecos-license/ 46*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ------------------------------------------- 47*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ####ECOSGPLCOPYRIGHTEND#### 48*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ####BSDCOPYRIGHTBEGIN#### 49*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 50*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ------------------------------------------- 51*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 52*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Portions of this software may have been derived from OpenBSD or other sources, 53*2439e4bfSJean-Christophe PLAGNIOL-VILLARD and are covered by the appropriate copyright disclaimers included herein. 54*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 55*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ------------------------------------------- 56*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 57*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ####BSDCOPYRIGHTEND#### 58*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ========================================================================== 59*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #####DESCRIPTIONBEGIN#### 60*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 61*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Author(s): gthomas 62*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Contributors: gthomas, jskov 63*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Date: 2001-06-13 64*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Purpose: 65*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Description: 66*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 67*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ####DESCRIPTIONEND#### 68*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 69*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ========================================================================== 70*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 71*2439e4bfSJean-Christophe PLAGNIOL-VILLARD */ 72*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 73*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* 74*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ------------------------------------------------------------------------ 75*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Macros for accessing DP registers 76*2439e4bfSJean-Christophe PLAGNIOL-VILLARD These can be overridden by the platform header 77*2439e4bfSJean-Christophe PLAGNIOL-VILLARD */ 78*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 79*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IN(_b_, _o_, _d_) (_d_) = *( (volatile unsigned char *) ((_b_)+(_o_))) 80*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_OUT(_b_, _o_, _d_) *( (volatile unsigned char *) ((_b_)+(_o_))) = (_d_) 81*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 82*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IN_DATA(_b_, _d_) (_d_) = *( (volatile unsigned char *) ((_b_))) 83*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_OUT_DATA(_b_, _d_) *( (volatile unsigned char *) ((_b_))) = (_d_) 84*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 85*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 86*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* here is all the data */ 87*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 88*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define cyg_uint8 unsigned char 89*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define cyg_uint16 unsigned short 90*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define bool int 91*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 92*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define false 0 93*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define true 1 94*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 95*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define CYGHWR_NS_DP83902A_PLF_BROKEN_TX_DMA 1 96*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define CYGACC_CALL_IF_DELAY_US(X) my_udelay(X) 97*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 98*2439e4bfSJean-Christophe PLAGNIOL-VILLARD typedef struct dp83902a_priv_data { 99*2439e4bfSJean-Christophe PLAGNIOL-VILLARD cyg_uint8* base; 100*2439e4bfSJean-Christophe PLAGNIOL-VILLARD cyg_uint8* data; 101*2439e4bfSJean-Christophe PLAGNIOL-VILLARD cyg_uint8* reset; 102*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int tx_next; /* First free Tx page */ 103*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int tx_int; /* Expecting interrupt from this buffer */ 104*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int rx_next; /* First free Rx page */ 105*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int tx1, tx2; /* Page numbers for Tx buffers */ 106*2439e4bfSJean-Christophe PLAGNIOL-VILLARD unsigned long tx1_key, tx2_key; /* Used to ack when packet sent */ 107*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int tx1_len, tx2_len; 108*2439e4bfSJean-Christophe PLAGNIOL-VILLARD bool tx_started, running, hardwired_esa; 109*2439e4bfSJean-Christophe PLAGNIOL-VILLARD cyg_uint8 esa[6]; 110*2439e4bfSJean-Christophe PLAGNIOL-VILLARD void* plf_priv; 111*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 112*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Buffer allocation */ 113*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int tx_buf1, tx_buf2; 114*2439e4bfSJean-Christophe PLAGNIOL-VILLARD int rx_buf_start, rx_buf_end; 115*2439e4bfSJean-Christophe PLAGNIOL-VILLARD } dp83902a_priv_data_t; 116*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 117*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* 118*2439e4bfSJean-Christophe PLAGNIOL-VILLARD ------------------------------------------------------------------------ 119*2439e4bfSJean-Christophe PLAGNIOL-VILLARD Some forward declarations 120*2439e4bfSJean-Christophe PLAGNIOL-VILLARD */ 121*2439e4bfSJean-Christophe PLAGNIOL-VILLARD static void dp83902a_poll(void); 122*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 123*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* ------------------------------------------------------------------------ */ 124*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Register offsets */ 125*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 126*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR 0x00 127*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CLDA0 0x01 128*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_PSTART 0x01 /* write */ 129*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CLDA1 0x02 130*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_PSTOP 0x02 /* write */ 131*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_BNDRY 0x03 132*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR 0x04 133*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TPSR 0x04 /* write */ 134*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_NCR 0x05 135*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TBCL 0x05 /* write */ 136*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_FIFO 0x06 137*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TBCH 0x06 /* write */ 138*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR 0x07 139*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CRDA0 0x08 140*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSAL 0x08 /* write */ 141*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CRDA1 0x09 142*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSAH 0x09 /* write */ 143*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RBCL 0x0a /* write */ 144*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RBCH 0x0b /* write */ 145*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR 0x0c 146*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR 0x0c /* write */ 147*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_FER 0x0d 148*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR 0x0d /* write */ 149*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CER 0x0e 150*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR 0x0e /* write */ 151*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_MISSED 0x0f 152*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR 0x0f /* write */ 153*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DATAPORT 0x10 /* "eprom" data port */ 154*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 155*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_CR 0x00 156*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_PAR0 0x01 157*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_PAR1 0x02 158*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_PAR2 0x03 159*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_PAR3 0x04 160*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_PAR4 0x05 161*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_PAR5 0x06 162*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_CURP 0x07 163*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR0 0x08 164*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR1 0x09 165*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR2 0x0a 166*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR3 0x0b 167*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR4 0x0c 168*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR5 0x0d 169*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR6 0x0e 170*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P1_MAR7 0x0f 171*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 172*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_CR 0x00 173*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_PSTART 0x01 174*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_CLDA0 0x01 /* write */ 175*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_PSTOP 0x02 176*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_CLDA1 0x02 /* write */ 177*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_RNPP 0x03 178*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_TPSR 0x04 179*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_LNPP 0x05 180*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_ACH 0x06 181*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_ACL 0x07 182*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_RCR 0x0c 183*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_TCR 0x0d 184*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_DCR 0x0e 185*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_P2_IMR 0x0f 186*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 187*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Command register - common to all pages */ 188*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 189*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_STOP 0x01 /* Stop: software reset */ 190*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_START 0x02 /* Start: initialize device */ 191*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_TXPKT 0x04 /* Transmit packet */ 192*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_RDMA 0x08 /* Read DMA (recv data from device) */ 193*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_WDMA 0x10 /* Write DMA (send data to device) */ 194*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_SEND 0x18 /* Send packet */ 195*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_NODMA 0x20 /* Remote (or no) DMA */ 196*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_PAGE0 0x00 /* Page select */ 197*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_PAGE1 0x40 198*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_PAGE2 0x80 199*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_CR_PAGEMSK 0x3F /* Used to mask out page bits */ 200*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 201*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Data configuration register */ 202*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 203*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_WTS 0x01 /* 1=16 bit word transfers */ 204*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_BOS 0x02 /* 1=Little Endian */ 205*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_LAS 0x04 /* 1=Single 32 bit DMA mode */ 206*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_LS 0x08 /* 1=normal mode, 0=loopback */ 207*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_ARM 0x10 /* 0=no send command (program I/O) */ 208*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_FIFO_1 0x00 /* FIFO threshold */ 209*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_FIFO_2 0x20 210*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_FIFO_4 0x40 211*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_FIFO_6 0x60 212*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 213*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_DCR_INIT (DP_DCR_LS|DP_DCR_FIFO_4) 214*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 215*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Interrupt status register */ 216*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 217*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_RxP 0x01 /* Packet received */ 218*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_TxP 0x02 /* Packet transmitted */ 219*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_RxE 0x04 /* Receive error */ 220*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_TxE 0x08 /* Transmit error */ 221*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_OFLW 0x10 /* Receive overflow */ 222*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_CNT 0x20 /* Tally counters need emptying */ 223*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_RDC 0x40 /* Remote DMA complete */ 224*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_ISR_RESET 0x80 /* Device has reset (shutdown, error) */ 225*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 226*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Interrupt mask register */ 227*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 228*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_RxP 0x01 /* Packet received */ 229*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_TxP 0x02 /* Packet transmitted */ 230*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_RxE 0x04 /* Receive error */ 231*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_TxE 0x08 /* Transmit error */ 232*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_OFLW 0x10 /* Receive overflow */ 233*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_CNT 0x20 /* Tall counters need emptying */ 234*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_RDC 0x40 /* Remote DMA complete */ 235*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 236*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_IMR_All 0x3F /* Everything but remote DMA */ 237*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 238*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Receiver control register */ 239*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 240*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR_SEP 0x01 /* Save bad(error) packets */ 241*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR_AR 0x02 /* Accept runt packets */ 242*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR_AB 0x04 /* Accept broadcast packets */ 243*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR_AM 0x08 /* Accept multicast packets */ 244*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR_PROM 0x10 /* Promiscuous mode */ 245*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RCR_MON 0x20 /* Monitor mode - 1=accept no packets */ 246*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 247*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Receiver status register */ 248*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 249*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_RxP 0x01 /* Packet received */ 250*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_CRC 0x02 /* CRC error */ 251*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_FRAME 0x04 /* Framing error */ 252*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_FO 0x08 /* FIFO overrun */ 253*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_MISS 0x10 /* Missed packet */ 254*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_PHY 0x20 /* 0=pad match, 1=mad match */ 255*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_DIS 0x40 /* Receiver disabled */ 256*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_RSR_DFR 0x80 /* Receiver processing deferred */ 257*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 258*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Transmitter control register */ 259*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 260*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_NOCRC 0x01 /* 1=inhibit CRC */ 261*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_NORMAL 0x00 /* Normal transmitter operation */ 262*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_LOCAL 0x02 /* Internal NIC loopback */ 263*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_INLOOP 0x04 /* Full internal loopback */ 264*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_OUTLOOP 0x08 /* External loopback */ 265*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_ATD 0x10 /* Auto transmit disable */ 266*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TCR_OFFSET 0x20 /* Collision offset adjust */ 267*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 268*2439e4bfSJean-Christophe PLAGNIOL-VILLARD /* Transmit status register */ 269*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 270*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_TxP 0x01 /* Packet transmitted */ 271*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_COL 0x04 /* Collision (at least one) */ 272*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_ABT 0x08 /* Aborted because of too many collisions */ 273*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_CRS 0x10 /* Lost carrier */ 274*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_FU 0x20 /* FIFO underrun */ 275*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_CDH 0x40 /* Collision Detect Heartbeat */ 276*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define DP_TSR_OWC 0x80 /* Collision outside normal window */ 277*2439e4bfSJean-Christophe PLAGNIOL-VILLARD 278*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define IEEE_8023_MAX_FRAME 1518 /* Largest possible ethernet frame */ 279*2439e4bfSJean-Christophe PLAGNIOL-VILLARD #define IEEE_8023_MIN_FRAME 64 /* Smallest possible ethernet frame */ 280