OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [or1ksim/] [peripheral/] [eth.h] - Blame information for rev 428

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 19 jeremybenn
/* eth.h -- Simulation of Ethernet MAC header
2
 
3
   Copyright (C) 2001 Erez Volk, erez@mailandnews.comopencores.org
4
   Copyright (C) 2008 Embecosm Limited
5
 
6
   Contributor Jeremy Bennett <jeremy.bennett@embecosm.com>
7
 
8
   This file is part of Or1ksim, the OpenRISC 1000 Architectural Simulator.
9
 
10
   This program is free software; you can redistribute it and/or modify it
11
   under the terms of the GNU General Public License as published by the Free
12
   Software Foundation; either version 3 of the License, or (at your option)
13
   any later version.
14
 
15
   This program is distributed in the hope that it will be useful, but WITHOUT
16
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
17
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
18
   more details.
19
 
20
   You should have received a copy of the GNU General Public License along
21
   with this program.  If not, see <http://www.gnu.org/licenses/>.  */
22
 
23
/* This program is commented throughout in a fashion suitable for processing
24
   with Doxygen. */
25
 
26
 
27
#ifndef ETH__H
28
#define ETH__H
29
 
30 82 jeremybenn
#if HAVE_ETH_PHY
31
#include <netpacket/packet.h>
32
#endif /* HAVE_ETH_PHY */
33
 
34
#if HAVE_NET_ETHERNET_H
35
# include <net/ethernet.h>
36
#elif defined(HAVE_SYS_ETHERNET_H)
37
# include <sys/ethernet.h>
38
#else /* !HAVE_NET_ETHERNET_H && !HAVE_SYS_ETHERNET_H - */
39
#include <sys/types.h>
40
#endif
41
 
42
/* Address space required by one Ethernet MAC */
43
#define ETH_ADDR_SPACE 0x1000
44
 
45
/* Relative Register Addresses */
46
#define ETH_MODER       (4 * 0x00)
47
#define ETH_INT_SOURCE  (4 * 0x01)
48
#define ETH_INT_MASK    (4 * 0x02)
49
#define ETH_IPGT        (4 * 0x03)
50
#define ETH_IPGR1       (4 * 0x04)
51
#define ETH_IPGR2       (4 * 0x05)
52
#define ETH_PACKETLEN   (4 * 0x06)
53
#define ETH_COLLCONF    (4 * 0x07)
54
#define ETH_TX_BD_NUM   (4 * 0x08)
55
#define ETH_CTRLMODER   (4 * 0x09)
56
#define ETH_MIIMODER    (4 * 0x0A)
57
#define ETH_MIICOMMAND  (4 * 0x0B)
58
#define ETH_MIIADDRESS  (4 * 0x0C)
59
#define ETH_MIITX_DATA  (4 * 0x0D)
60
#define ETH_MIIRX_DATA  (4 * 0x0E)
61
#define ETH_MIISTATUS   (4 * 0x0F)
62
#define ETH_MAC_ADDR0   (4 * 0x10)
63
#define ETH_MAC_ADDR1   (4 * 0x11)
64
#define ETH_HASH0       (4 * 0x12)
65
#define ETH_HASH1       (4 * 0x13)
66
 
67
/* Where BD's are stored */
68
#define ETH_BD_BASE        0x400
69
#define ETH_BD_COUNT       0x100
70
#define ETH_BD_SPACE       (4 * ETH_BD_COUNT)
71
 
72
/* Where to point DMA to transmit/receive */
73
#define ETH_DMA_RX_TX      0x800
74
 
75
/* Field definitions for MODER */
76
#define ETH_MODER_DMAEN_OFFSET     17
77
#define ETH_MODER_RECSMALL_OFFSET  16
78
#define ETH_MODER_PAD_OFFSET       15
79
#define ETH_MODER_HUGEN_OFFSET     14
80
#define ETH_MODER_CRCEN_OFFSET     13
81
#define ETH_MODER_DLYCRCEN_OFFSET  12
82
#define ETH_MODER_RST_OFFSET       11
83
#define ETH_MODER_FULLD_OFFSET     10
84
#define ETH_MODER_EXDFREN_OFFSET   9
85
#define ETH_MODER_NOBCKOF_OFFSET   8
86
#define ETH_MODER_LOOPBCK_OFFSET   7
87
#define ETH_MODER_IFG_OFFSET       6
88
#define ETH_MODER_PRO_OFFSET       5
89
#define ETH_MODER_IAM_OFFSET       4
90
#define ETH_MODER_BRO_OFFSET       3
91
#define ETH_MODER_NOPRE_OFFSET     2
92
#define ETH_MODER_TXEN_OFFSET      1
93
#define ETH_MODER_RXEN_OFFSET      0
94
 
95
/* Field definitions for INT_SOURCE */
96
#define ETH_INT_SOURCE_RXC_OFFSET  6
97
#define ETH_INT_SOURCE_TXC_OFFSET  5
98
#define ETH_INT_SOURCE_BUSY_OFFSET 4
99
#define ETH_INT_SOURCE_RXE_OFFSET  3
100
#define ETH_INT_SOURCE_RXB_OFFSET  2
101
#define ETH_INT_SOURCE_TXE_OFFSET  1
102
#define ETH_INT_SOURCE_TXB_OFFSET  0
103
 
104
/* Field definitions for INT_MASK */
105
#define ETH_INT_MASK_RXC_M_OFFSET  6
106
#define ETH_INT_MASK_TXC_M_OFFSET  5
107
#define ETH_INT_MASK_BUSY_M_OFFSET 4
108
#define ETH_INT_MASK_RXE_M_OFFSET  3
109
#define ETH_INT_MASK_RXB_M_OFFSET  2
110
#define ETH_INT_MASK_TXE_M_OFFSET  1
111
#define ETH_INT_MASK_TXB_M_OFFSET  0
112
 
113
/* Field definitions for PACKETLEN */
114
#define ETH_PACKETLEN_MINFL_OFFSET 16
115
#define ETH_PACKETLEN_MINFL_WIDTH  16
116
#define ETH_PACKETLEN_MAXFL_OFFSET 0
117
#define ETH_PACKETLEN_MAXFL_WIDTH  16
118
 
119
/* Field definitions for COLLCONF */
120
#define ETH_COLLCONF_MAXRET_OFFSET 16
121
#define ETH_COLLCONF_MAXRET_WIDTH  4
122
#define ETH_COLLCONF_COLLVALID_OFFSET 0
123
#define ETH_COLLCONF_COLLVALID_WIDTH  6
124
 
125
/* Field definitions for CTRLMODER */
126
#define ETH_CMODER_TXFLOW_OFFSET   2
127
#define ETH_CMODER_RXFLOW_OFFSET   1
128
#define ETH_CMODER_PASSALL_OFFSET  0
129
 
130
/* Field definitions for MIIMODER */
131
#define ETH_MIIMODER_NOPRE_OFFSET  8
132
#define ETH_MIIMODER_CLKDIV_OFFSET 0
133 428 julius
#define ETH_MIIMODER_CLKDIV_MASK   0xff
134 82 jeremybenn
 
135
/* Field definitions for MIICOMMAND */
136
#define ETH_MIICOMM_WCDATA_OFFSET  2
137
#define ETH_MIICOMM_RSTAT_OFFSET   1
138
#define ETH_MIICOMM_SCANS_OFFSET   0
139
 
140
/* Field definitions for MIIADDRESS */
141
#define ETH_MIIADDR_RGAD_OFFSET    8
142 428 julius
#define ETH_MIIADDR_RGAD_MASK     0x1f     
143 82 jeremybenn
#define ETH_MIIADDR_FIAD_OFFSET    0
144 428 julius
#define ETH_MIIADDR_FIAD_MASK     0x1f
145 82 jeremybenn
 
146
/* Field definitions for MIISTATUS */
147
#define ETH_MIISTAT_NVALID_OFFSET  1
148
#define ETH_MIISTAT_BUSY_OFFSET    1
149
#define ETH_MIISTAT_FAIL_OFFSET    0
150
 
151
/* Field definitions for TX buffer descriptors */
152
#define ETH_TX_BD_LENGTH_OFFSET        16
153
#define ETH_TX_BD_LENGTH_WIDTH         16
154
#define ETH_TX_BD_READY_OFFSET         15
155
#define ETH_TX_BD_IRQ_OFFSET           14
156
#define ETH_TX_BD_WRAP_OFFSET          13
157
#define ETH_TX_BD_PAD_OFFSET           12
158
#define ETH_TX_BD_CRC_OFFSET           11
159
#define ETH_TX_BD_LAST_OFFSET          10
160
#define ETH_TX_BD_PAUSE_OFFSET         9
161
#define ETH_TX_BD_UNDERRUN_OFFSET      8
162
#define ETH_TX_BD_RETRY_OFFSET         4
163
#define ETH_TX_BD_RETRY_WIDTH          4
164
#define ETH_TX_BD_RETRANSMIT_OFFSET    3
165
#define ETH_TX_BD_COLLISION_OFFSET     2
166
#define ETH_TX_BD_DEFER_OFFSET         1
167
#define ETH_TX_BD_NO_CARRIER_OFFSET    0
168
 
169
 
170
/* Field definitions for RX buffer descriptors */
171
#define ETH_RX_BD_LENGTH_OFFSET        16
172
#define ETH_RX_BD_LENGTH_WIDTH         16
173
#define ETH_RX_BD_READY_OFFSET         15
174
#define ETH_RX_BD_IRQ_OFFSET           14
175
#define ETH_RX_BD_WRAP_OFFSET          13
176
#define ETH_RX_BD_MISS_OFFSET          7
177
#define ETH_RX_BD_UVERRUN_OFFSET       6
178
#define ETH_RX_BD_INVALID_OFFSET       5
179
#define ETH_RX_BD_DRIBBLE_OFFSET       4
180
#define ETH_RX_BD_TOOBIG_OFFSET        3
181
#define ETH_RX_BD_TOOSHORT_OFFSET      2
182
#define ETH_RX_BD_CRC_OFFSET           1
183
#define ETH_RX_BD_COLLISION_OFFSET     0
184
 
185
/*
186
 * Ethernet protocol definitions
187
 */
188
#ifdef HAVE_NET_ETHERNET_H
189
#elif defined(HAVE_SYS_ETHERNET_H)
190
#ifndef ETHER_ADDR_LEN
191
#define ETHER_ADDR_LEN ETHERADDRL
192
#endif
193
#ifndef ETHER_HDR_LEN
194
#define ETHER_HDR_LEN sizeof(struct ether_header)
195
#endif
196
#else /* !HAVE_NET_ETHERNET_H && !HAVE_SYS_ETHERNET_H - */
197
#ifdef __CYGWIN__
198
/* define some missing cygwin defines.
199
 */
200
#define ETH_HLEN      14
201
#endif /* __CYGWIN__ */
202
 
203
#define ETH_ALEN    6
204
 
205
struct ether_addr
206
{
207
  u_int8_t ether_addr_octet[ETH_ALEN];
208
};
209
 
210
struct ether_header
211
{
212
  u_int8_t ether_dhost[ETH_ALEN];       /* destination eth addr */
213
  u_int8_t ether_shost[ETH_ALEN];       /* source ether addr    */
214
  u_int16_t ether_type;         /* packet type ID field */
215
};
216
 
217
/* Ethernet protocol ID's */
218
#define ETHERTYPE_PUP           0x0200  /* Xerox PUP */
219
#define ETHERTYPE_IP            0x0800  /* IP */
220
#define ETHERTYPE_ARP           0x0806  /* Address resolution */
221
#define ETHERTYPE_REVARP        0x8035  /* Reverse ARP */
222
 
223
#define ETHER_ADDR_LEN  ETH_ALEN        /* size of ethernet addr */
224
#define ETHER_TYPE_LEN  2       /* bytes in type field */
225
#define ETHER_CRC_LEN   4       /* bytes in CRC field */
226
#define ETHER_HDR_LEN   ETH_HLEN        /* total octets in header */
227
#define ETHER_MIN_LEN   (ETH_ZLEN + ETHER_CRC_LEN)      /* min packet length */
228
#define ETHER_MAX_LEN   (ETH_FRAME_LEN + ETHER_CRC_LEN) /* max packet length */
229
 
230
/* make sure ethenet length is valid */
231
#define ETHER_IS_VALID_LEN(foo) \
232
        ((foo) >= ETHER_MIN_LEN && (foo) <= ETHER_MAX_LEN)
233
 
234
/*
235
 * The ETHERTYPE_NTRAILER packet types starting at ETHERTYPE_TRAIL have
236
 * (type-ETHERTYPE_TRAIL)*512 bytes of data followed
237
 * by an ETHER type (as given above) and then the (variable-length) header.
238
 */
239
#define ETHERTYPE_TRAIL         0x1000  /* Trailer packet */
240
#define ETHERTYPE_NTRAILER      16
241
 
242
#define ETHERMTU        ETH_DATA_LEN
243
#define ETHERMIN        (ETHER_MIN_LEN-ETHER_HDR_LEN-ETHER_CRC_LEN)
244
 
245
#endif /* HAVE_NET_ETHERNET_H */
246
 
247
/*
248
 * Implementatino of Ethernet MAC Registers and State
249
 */
250
#define ETH_TXSTATE_IDLE        0
251
#define ETH_TXSTATE_WAIT4BD     10
252
#define ETH_TXSTATE_READFIFO    20
253
#define ETH_TXSTATE_TRANSMIT    30
254
 
255
#define ETH_RXSTATE_IDLE        0
256
#define ETH_RXSTATE_WAIT4BD     10
257
#define ETH_RXSTATE_RECV        20
258
#define ETH_RXSTATE_WRITEFIFO   30
259
 
260
#define ETH_RTX_FILE    0
261
#define ETH_RTX_SOCK    1
262
#define ETH_RTX_VAPI    2
263
 
264
#define ETH_MAXPL   0x10000
265
 
266
enum
267
{ ETH_VAPI_DATA = 0,
268
  ETH_VAPI_CTRL,
269
  ETH_NUM_VAPI_IDS
270
};
271
 
272
 
273 19 jeremybenn
/* Prototypes for external use */
274
extern void  reg_ethernet_sec ();
275
 
276 428 julius
 
277
/* Defines taken from linux-2.6.36/include/linux/mii.h for PHY register IF */
278
 
279
#define MII_BMCR            0x00        /* Basic mode control register */
280
#define MII_BMSR            0x01        /* Basic mode status register  */
281
#define MII_PHYSID1         0x02        /* PHYS ID 1                   */
282
#define MII_PHYSID2         0x03        /* PHYS ID 2                   */
283
#define MII_ADVERTISE       0x04        /* Advertisement control reg   */
284
#define MII_LPA             0x05        /* Link partner ability reg    */
285
#define MII_EXPANSION       0x06        /* Expansion register          */
286
#define MII_CTRL1000        0x09        /* 1000BASE-T control          */
287
#define MII_STAT1000        0x0a        /* 1000BASE-T status           */
288
#define MII_ESTATUS         0x0f        /* Extended Status */
289
#define MII_DCOUNTER        0x12        /* Disconnect counter          */
290
#define MII_FCSCOUNTER      0x13        /* False carrier counter       */
291
#define MII_NWAYTEST        0x14        /* N-way auto-neg test reg     */
292
#define MII_RERRCOUNTER     0x15        /* Receive error counter       */
293
#define MII_SREVISION       0x16        /* Silicon revision            */
294
#define MII_RESV1           0x17        /* Reserved...                 */
295
#define MII_LBRERROR        0x18        /* Lpback, rx, bypass error    */
296
#define MII_PHYADDR         0x19        /* PHY address                 */
297
#define MII_RESV2           0x1a        /* Reserved...                 */
298
#define MII_TPISTATUS       0x1b        /* TPI status for 10mbps       */
299
#define MII_NCONFIG         0x1c        /* Network interface config    */
300
 
301
/* Basic mode control register. */
302
#define BMCR_RESV               0x003f  /* Unused...                   */
303
#define BMCR_SPEED1000          0x0040  /* MSB of Speed (1000)         */
304
#define BMCR_CTST               0x0080  /* Collision test              */
305
#define BMCR_FULLDPLX           0x0100  /* Full duplex                 */
306
#define BMCR_ANRESTART          0x0200  /* Auto negotiation restart    */
307
#define BMCR_ISOLATE            0x0400  /* Disconnect DP83840 from MII */
308
#define BMCR_PDOWN              0x0800  /* Powerdown the DP83840       */
309
#define BMCR_ANENABLE           0x1000  /* Enable auto negotiation     */
310
#define BMCR_SPEED100           0x2000  /* Select 100Mbps              */
311
#define BMCR_LOOPBACK           0x4000  /* TXD loopback bits           */
312
#define BMCR_RESET              0x8000  /* Reset the DP83840           */
313
 
314
/* Basic mode status register. */
315
#define BMSR_ERCAP              0x0001  /* Ext-reg capability          */
316
#define BMSR_JCD                0x0002  /* Jabber detected             */
317
#define BMSR_LSTATUS            0x0004  /* Link status                 */
318
#define BMSR_ANEGCAPABLE        0x0008  /* Able to do auto-negotiation */
319
#define BMSR_RFAULT             0x0010  /* Remote fault detected       */
320
#define BMSR_ANEGCOMPLETE       0x0020  /* Auto-negotiation complete   */
321
#define BMSR_RESV               0x00c0  /* Unused...                   */
322
#define BMSR_ESTATEN            0x0100  /* Extended Status in R15 */
323
#define BMSR_100HALF2           0x0200  /* Can do 100BASE-T2 HDX */
324
#define BMSR_100FULL2           0x0400  /* Can do 100BASE-T2 FDX */
325
#define BMSR_10HALF             0x0800  /* Can do 10mbps, half-duplex  */
326
#define BMSR_10FULL             0x1000  /* Can do 10mbps, full-duplex  */
327
#define BMSR_100HALF            0x2000  /* Can do 100mbps, half-duplex */
328
#define BMSR_100FULL            0x4000  /* Can do 100mbps, full-duplex */
329
#define BMSR_100BASE4           0x8000  /* Can do 100mbps, 4k packets  */
330
 
331
/* Advertisement control register. */
332
#define ADVERTISE_SLCT          0x001f  /* Selector bits               */
333
#define ADVERTISE_CSMA          0x0001  /* Only selector supported     */
334
#define ADVERTISE_10HALF        0x0020  /* Try for 10mbps half-duplex  */
335
#define ADVERTISE_1000XFULL     0x0020  /* Try for 1000BASE-X full-duplex */
336
#define ADVERTISE_10FULL        0x0040  /* Try for 10mbps full-duplex  */
337
#define ADVERTISE_1000XHALF     0x0040  /* Try for 1000BASE-X half-duplex */
338
#define ADVERTISE_100HALF       0x0080  /* Try for 100mbps half-duplex */
339
#define ADVERTISE_1000XPAUSE    0x0080  /* Try for 1000BASE-X pause    */
340
#define ADVERTISE_100FULL       0x0100  /* Try for 100mbps full-duplex */
341
#define ADVERTISE_1000XPSE_ASYM 0x0100  /* Try for 1000BASE-X asym pause */
342
#define ADVERTISE_100BASE4      0x0200  /* Try for 100mbps 4k packets  */
343
#define ADVERTISE_PAUSE_CAP     0x0400  /* Try for pause               */
344
#define ADVERTISE_PAUSE_ASYM    0x0800  /* Try for asymetric pause     */
345
#define ADVERTISE_RESV          0x1000  /* Unused...                   */
346
#define ADVERTISE_RFAULT        0x2000  /* Say we can detect faults    */
347
#define ADVERTISE_LPACK         0x4000  /* Ack link partners response  */
348
#define ADVERTISE_NPAGE         0x8000  /* Next page bit               */
349
 
350
#define ADVERTISE_FULL (ADVERTISE_100FULL | ADVERTISE_10FULL | \
351
                        ADVERTISE_CSMA)
352
#define ADVERTISE_ALL (ADVERTISE_10HALF | ADVERTISE_10FULL | \
353
                       ADVERTISE_100HALF | ADVERTISE_100FULL)
354
 
355
/* Link partner ability register. */
356
#define LPA_SLCT                0x001f  /* Same as advertise selector  */
357
#define LPA_10HALF              0x0020  /* Can do 10mbps half-duplex   */
358
#define LPA_1000XFULL           0x0020  /* Can do 1000BASE-X full-duplex */
359
#define LPA_10FULL              0x0040  /* Can do 10mbps full-duplex   */
360
#define LPA_1000XHALF           0x0040  /* Can do 1000BASE-X half-duplex */
361
#define LPA_100HALF             0x0080  /* Can do 100mbps half-duplex  */
362
#define LPA_1000XPAUSE          0x0080  /* Can do 1000BASE-X pause     */
363
#define LPA_100FULL             0x0100  /* Can do 100mbps full-duplex  */
364
#define LPA_1000XPAUSE_ASYM     0x0100  /* Can do 1000BASE-X pause asym*/
365
#define LPA_100BASE4            0x0200  /* Can do 100mbps 4k packets   */
366
#define LPA_PAUSE_CAP           0x0400  /* Can pause                   */
367
#define LPA_PAUSE_ASYM          0x0800  /* Can pause asymetrically     */
368
#define LPA_RESV                0x1000  /* Unused...                   */
369
#define LPA_RFAULT              0x2000  /* Link partner faulted        */
370
#define LPA_LPACK               0x4000  /* Link partner acked us       */
371
#define LPA_NPAGE               0x8000  /* Next page bit               */
372
 
373
#define LPA_DUPLEX              (LPA_10FULL | LPA_100FULL)
374
#define LPA_100                 (LPA_100FULL | LPA_100HALF | LPA_100BASE4)
375
 
376
/* Expansion register for auto-negotiation. */
377
#define EXPANSION_NWAY          0x0001  /* Can do N-way auto-nego      */
378
#define EXPANSION_LCWP          0x0002  /* Got new RX page code word   */
379
#define EXPANSION_ENABLENPAGE   0x0004  /* This enables npage words    */
380
#define EXPANSION_NPCAPABLE     0x0008  /* Link partner supports npage */
381
#define EXPANSION_MFAULTS       0x0010  /* Multiple faults detected    */
382
#define EXPANSION_RESV          0xffe0  /* Unused...                   */
383
 
384
#define ESTATUS_1000_TFULL      0x2000  /* Can do 1000BT Full */
385
#define ESTATUS_1000_THALF      0x1000  /* Can do 1000BT Half */
386
 
387
/* N-way test register. */
388
#define NWAYTEST_RESV1          0x00ff  /* Unused...                   */
389
#define NWAYTEST_LOOPBACK       0x0100  /* Enable loopback for N-way   */
390
#define NWAYTEST_RESV2          0xfe00  /* Unused...                   */
391
 
392
/* 1000BASE-T Control register */
393
#define ADVERTISE_1000FULL      0x0200  /* Advertise 1000BASE-T full duplex */
394
#define ADVERTISE_1000HALF      0x0100  /* Advertise 1000BASE-T half duplex */
395
 
396
/* 1000BASE-T Status register */
397
#define LPA_1000LOCALRXOK       0x2000  /* Link partner local receiver status */
398
#define LPA_1000REMRXOK         0x1000  /* Link partner remote receiver status */
399
#define LPA_1000FULL            0x0800  /* Link partner 1000BASE-T full duplex */
400
#define LPA_1000HALF            0x0400  /* Link partner 1000BASE-T half duplex */
401
 
402
/* Flow control flags */
403
#define FLOW_CTRL_TX            0x01
404
#define FLOW_CTRL_RX            0x02
405
 
406
 
407
 
408 19 jeremybenn
#endif /* ETH__H */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.