1 /*-
2 * Copyright (c) 1994-1998
3 * Paul Richards. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer,
10 * verbatim and that no modifications are made prior to this
11 * point in the file.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. All advertising materials mentioning features or use of this software
16 * must display the following acknowledgement:
17 * This product includes software developed by Paul Richards.
18 * 4. The name Paul Richards may not be used to endorse or promote products
19 * derived from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY PAUL RICHARDS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL PAUL RICHARDS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 *
33 * $FreeBSD$
34 */
35
36 /*
37 * Initialize multicast address hashing registers to accept
38 * all multicasts (only used when in promiscuous mode)
39 */
40 #define MULTI_INIT_ADDR 0xff
41
42 #define NORMAL 0
43
44 #define NRDRE 3
45 #define NTDRE 3
46 #define RECVBUFSIZE 1518 /* Packet size rounded to dword boundary */
47 #define TRANSBUFSIZE 1518
48 #define MBUF_CACHE_LIMIT 0
49
50 #define MEM_SLEW 8
51
52 /* LNC Flags */
53 #define LNC_INITIALISED 1
54 #define LNC_ALLMULTI 2
55
56 /* BICC port addresses */
57 #define BICC_IOSIZE 16
58 #define BICC_RDP 0x0c /* Register Data Port */
59 #define BICC_RAP 0x0e /* Register Address Port */
60
61 /* NE2100 port addresses */
62 #define NE2100_IOSIZE 24
63 #define PCNET_RDP 0x10 /* Register Data Port */
64 #define PCNET_RAP 0x12 /* Register Address Port */
65 #define PCNET_RESET 0x14
66 #define PCNET_BDP 0x16
67 #define PCNET_VSW 0x18
68
69 /* DEPCA port addresses */
70 #define DEPCA_IOSIZE 16
71 #define DEPCA_CTRL 0x00 /* NIC Control and status register */
72 #define DEPCA_RDP 0x04 /* Register Data Port */
73 #define DEPCA_RAP 0x06 /* Register Address Port */
74 #define DEPCA_ADP 0x0c
75
76 /* DEPCA specific defines */
77 #define DEPCA_ADDR_ROM_SIZE 32
78
79 /* C-NET(98)S port addresses */
80 /* Notice, we can ignore fragmantation by using isa_alloc_resourcev(). */
81 #define CNET98S_IOSIZE 32
82 #define CNET98S_RDP 0x10 /* Register Data Port */
83 #define CNET98S_RAP 0x12 /* Register Address Port */
84 #define CNET98S_RESET 0x14
85 #define CNET98S_IDP 0x16
86 #define CNET98S_EEPROM 0x1e
87
88 /* Chip types */
89 #define LANCE 1 /* Am7990 */
90 #define C_LANCE 2 /* Am79C90 */
91 #define PCnet_ISA 3 /* Am79C960 */
92 #define PCnet_ISAplus 4 /* Am79C961 */
93 #define PCnet_ISA_II 5 /* Am79C961A */
94 #define PCnet_32 6 /* Am79C965 */
95 #define PCnet_PCI 7 /* Am79C970 */
96 #define PCnet_PCI_II 8 /* Am79C970A */
97 #define PCnet_FAST 9 /* Am79C971 */
98 #define PCnet_FASTplus 10 /* Am79C972 */
99 #define PCnet_Home 11 /* Am79C978 */
100
101
102 /* CSR88-89: Chip ID masks */
103 #define AMD_MASK 0x003
104 #define PART_MASK 0xffff
105 #define Am79C960 0x0003
106 #define Am79C961 0x2260
107 #define Am79C961A 0x2261
108 #define Am79C965 0x2430
109 #define Am79C970 0x0242
110 #define Am79C970A 0x2621
111 #define Am79C971 0x2623
112 #define Am79C972 0x2624
113 #define Am79C973 0x2625
114 #define Am79C978 0x2626
115
116 /* Board types */
117 #define UNKNOWN 0
118 #define BICC 1
119 #define NE2100 2
120 #define DEPCA 3
121 #define CNET98S 4 /* PC-98 */
122
123 /* mem_mode values */
124 #define DMA_FIXED 1
125 #define DMA_MBUF 2
126 #define SHMEM 4
127
128 #define MEM_MODES \
129 "\2\3SHMEM\2DMA_MBUF\1DMA_FIXED"
130
131 #define CSR0_FLAGS \
132 "\2\20ERR\17BABL\16CERR\15MISS\14MERR\13RINT\12TINT\11IDON\
133 \10INTR\07INEA\06RXON\05TXON\04TDMD\03STOP\02STRT\01INIT"
134
135 #define INIT_MODE \
136 "\2\20PROM\07INTL\06DRTY\05COLL\04DTCR\03LOOP\02DTX\01DRX"
137
138 #define RECV_MD1 \
139 "\2\10OWN\7ERR\6FRAM\5OFLO\4CRC\3BUFF\2STP\1ENP"
140
141 #define TRANS_MD1 \
142 "\2\10OWN\7ERR\6RES\5MORE\4ONE\3DEF\2STP\1ENP"
143
144 #define TRANS_MD3 \
145 "\2\6BUFF\5UFLO\4RES\3LCOL\2LCAR\1RTRY"
146
147 #ifdef LNC_KEEP_STATS
148 #define LNCSTATS_STRUCT \
149 struct lnc_stats { \
150 int idon; \
151 int rint; \
152 int tint; \
153 int cerr; \
154 int babl; \
155 int miss; \
156 int merr; \
157 int rxoff; \
158 int txoff; \
159 int terr; \
160 int lcol; \
161 int lcar; \
162 int tbuff; \
163 int def; \
164 int more; \
165 int one; \
166 int uflo; \
167 int rtry; \
168 int rerr; \
169 int fram; \
170 int oflo; \
171 int crc; \
172 int rbuff; \
173 int drop_packet; \
174 int trans_ring_full; \
175 } lnc_stats;
176 #define LNCSTATS(X) ++(sc->lnc_stats.X);
177 #else
178 #define LNCSTATS_STRUCT
179 #define LNCSTATS(X)
180 #endif
181
182 struct nic_info {
183 int ident; /* Type of card */
184 int ic; /* Type of ic, Am7990, Am79C960 etc. */
185 int mem_mode;
186 int iobase;
187 int mode; /* Mode setting at initialization */
188 };
189
190 typedef struct lnc_softc {
191 struct resource *irqres;
192 int irqrid;
193 struct resource *drqres;
194 int drqrid;
195 struct resource *portres;
196 int portrid;
197 bus_space_tag_t lnc_btag;
198 bus_space_handle_t lnc_bhandle;
199 void *intrhand;
200 bus_dma_tag_t dmat;
201 bus_dmamap_t dmamap;
202 struct arpcom arpcom; /* see ../../net/if_arp.h */
203 struct nic_info nic; /* NIC specific info */
204 int nrdre;
205 struct host_ring_entry *recv_ring; /* start of alloc'd mem */
206 int recv_next;
207 int ntdre;
208 struct host_ring_entry *trans_ring;
209 int trans_next;
210 struct init_block *init_block; /* Initialisation block */
211 int pending_transmits; /* No. of transmit descriptors in
212 use */
213 int next_to_send;
214 struct mbuf *mbufs;
215 int mbuf_count;
216 int flags;
217 int rap;
218 int rdp;
219 int bdp;
220 #ifdef DEBUG
221 int lnc_debug;
222 #endif
223 LNCSTATS_STRUCT
224 } lnc_softc_t;
225
226 struct host_ring_entry {
227 struct mds *md;
228 union {
229 struct mbuf *mbuf;
230 char *data;
231 }buff;
232 };
233
234 #define NDESC(len2) (1 << len2)
235
236 #define INC_MD_PTR(ptr, no_entries) \
237 if (++ptr >= NDESC(no_entries)) \
238 ptr = 0;
239
240 #define DEC_MD_PTR(ptr, no_entries) \
241 if (--ptr < 0) \
242 ptr = NDESC(no_entries) - 1;
243
244 #define RECV_NEXT (sc->recv_ring->base + sc->recv_next)
245 #define TRANS_NEXT (sc->trans_ring->base + sc->trans_next)
246
247 #define lnc_inb(port) \
248 bus_space_read_1(sc->lnc_btag, sc->lnc_bhandle, (port))
249 #define lnc_inw(port) \
250 bus_space_read_2(sc->lnc_btag, sc->lnc_bhandle, (port))
251 #define lnc_outw(port, val) \
252 bus_space_write_2(sc->lnc_btag, sc->lnc_bhandle, (port), (val))
253
254 /* Functional declarations */
255 extern int lance_probe(struct lnc_softc *);
256 extern void lnc_release_resources(device_t);
257 extern int lnc_attach_common(device_t);
258 extern void lnc_stop(struct lnc_softc *);
259
260 extern void write_csr(struct lnc_softc *, u_short, u_short);
261 extern u_short read_csr(struct lnc_softc *, u_short);
262
263 /* Variable declarations */
264 extern driver_intr_t lncintr;
265 extern devclass_t lnc_devclass;
Cache object: b2b7edb9378e529c8e8d075a912505b4
|