xref: /rk3399_rockchip-uboot/drivers/net/ne2000.h (revision 2439e4bfa111babf4bc07ba20efbf3e36036813e)
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