1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
/* $OpenBSD: if_bmreg.h,v 1.2 2001/07/04 08:38:51 niklas Exp $ */
/* $NetBSD: if_bmreg.h,v 1.1 1999/01/01 01:27:52 tsubai Exp $ */
/*
* Copyright 1991-1998 by Open Software Foundation, Inc.
* 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.
*
* OSF DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE.
*
* 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.
*/
/* -------------------------------------------------------------------- */
/* Heathrow (F)eature (C)ontrol (R)egister Addresses */
/* -------------------------------------------------------------------- */
#define EnetEnable 0x60000000 /* enable Enet Xcvr/Controller */
#define ResetEnetCell 0x80000000 /* reset Enet cell */
/* -------------------------------------------------------------------- */
/* BigMac Register Numbers & Bit Assignments */
/* -------------------------------------------------------------------- */
#define XIFC 0x0000
#define TxOutputEnable 0x0001
#define MIILoopbackBits 0x0006
#define MIIBufferEnable 0x0008
#define SQETestEnable 0x0010
#define LinkStatus 0x0100
#define TXFIFOCSR 0x0100
#define TxFIFOEnable 0x0001
#define TxFIFO128 0x0000
#define TXTH 0x0110
#define RXFIFOCSR 0x0120
#define RxFIFOEnable TxFIFOEnable
#define RxFIFO128 TxFIFO128
#define MEMADD 0x0130
#define MEMDATAHI 0x0140
#define MEMDATALO 0x0150
#define XCVRIF 0x0160
#define COLActiveLow 0x0002
#define SerialMode 0x0004
#define ClkBit 0x0008
#define CHIPID 0x0170
#define MIFCSR 0x0180
#define SROMCSR 0x0190
#define TXPNTR 0x01A0
#define RXPNTR 0x01B0
#define STATUS 0x0200
#define INTDISABLE 0x0210
#define IntFrameReceived 0x0001
#define IntRxFrameCntExp 0x0002
#define IntRxAlignCntExp 0x0004
#define IntRxCRCCntExp 0x0008
#define IntRxLenCntExp 0x0010
#define IntRxOverFlow 0x0020
#define IntRxCodeViolation 0x0040
#define IntSQETestError 0x0080
#define IntFrameSent 0x0100
#define IntTxUnderrun 0x0200
#define IntTxMaxSizeError 0x0400
#define IntTxNormalCollExp 0x0800
#define IntTxExcessCollExp 0x1000
#define IntTxLateCollExp 0x2000
#define IntTxNetworkCollExp 0x4000
#define IntTxDeferTimerExp 0x8000
#define NormalIntEvents ~(IntFrameSent)
#define NoEventsMask 0xFFFF
#define TxNeverGiveUp 0x0400
#define TXRST 0x0420
#define TxResetBit 0x0001
#define TXCFG 0x0430
#define TxMACEnable 0x0001
#define TxThreshold 0x0004
#define IPG1 0x0440
#define IPG2 0x0450
#define ALIMIT 0x0460
#define SLOT 0x0470
#define PALEN 0x0480
#define PAPAT 0x0490
#define TXSFD 0x04A0
#define JAM 0x04B0
#define TXMAX 0x04C0
#define TXMIN 0x04D0
#define PAREG 0x04E0
#define DCNT 0x04F0
#define NCCNT 0x0500
#define NTCNT 0x0510
#define EXCNT 0x0520
#define LTCNT 0x0530
#define RSEED 0x0540
#define TXSM 0x0550
#define RXRST 0x0620
#define RxResetValue 0x0000
#define RXCFG 0x0630
#define RxMACEnable 0x0001
#define ReservedValue 0x0004
#define RxPromiscEnable 0x0040
#define RxCRCEnable 0x0100
#define RxRejectOwnPackets 0x0200
#define RxHashFilterEnable 0x0800
#define RxAddrFilterEnable 0x1000
#define RXMAX 0x0640
#define RXMIN 0x0650
#define MADD2 0x0660
#define MADD1 0x0670
#define MADD0 0x0680
#define FRCNT 0x0690
#define LECNT 0x06A0
#define AECNT 0x06B0
#define FECNT 0x06C0
#define RXSM 0x06D0
#define RXCV 0x06E0
#define HASH3 0x0700
#define HASH2 0x0710
#define HASH1 0x0720
#define HASH0 0x0730
#define AFR2 0x0740
#define AFR1 0x0750
#define AFR0 0x0760
#define AFCR 0x0770
#define EnableAllCompares 0x0fff
/* -------------------------------------------------------------------- */
/* Misc. Bit definitions for BMac Status word */
/* -------------------------------------------------------------------- */
#define RxAbortBit 0x8000 /* status bit in BMac status for rx packets */
#define RxLengthMask 0x3FFF /* bits that determine length of rx packets */
#define NETWORK_BUFSIZE (ETHERMAXPACKET + ETHERCRC + 2)
|