blob: 3ab2156905f0dc6d2411fbe06f75ef2533f3329a [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/* ewrk3.c: A DIGITAL EtherWORKS 3 ethernet driver for Linux.
2
3 Written 1994 by David C. Davies.
4
5 Copyright 1994 Digital Equipment Corporation.
6
7 This software may be used and distributed according to the terms of
8 the GNU General Public License, incorporated herein by reference.
9
10 This driver is written for the Digital Equipment Corporation series
11 of EtherWORKS ethernet cards:
12
13 DE203 Turbo (BNC)
14 DE204 Turbo (TP)
15 DE205 Turbo (TP BNC)
16
17 The driver has been tested on a relatively busy network using the DE205
18 card and benchmarked with 'ttcp': it transferred 16M of data at 975kB/s
19 (7.8Mb/s) to a DECstation 5000/200.
20
21 The author may be reached at davies@maniac.ultranet.com.
22
23 =========================================================================
24 This driver has been written substantially from scratch, although its
25 inheritance of style and stack interface from 'depca.c' and in turn from
26 Donald Becker's 'lance.c' should be obvious.
27
28 The DE203/4/5 boards all use a new proprietary chip in place of the
29 LANCE chip used in prior cards (DEPCA, DE100, DE200/1/2, DE210, DE422).
30 Use the depca.c driver in the standard distribution for the LANCE based
31 cards from DIGITAL; this driver will not work with them.
32
33 The DE203/4/5 cards have 2 main modes: shared memory and I/O only. I/O
34 only makes all the card accesses through I/O transactions and no high
35 (shared) memory is used. This mode provides a >48% performance penalty
36 and is deprecated in this driver, although allowed to provide initial
37 setup when hardstrapped.
38
39 The shared memory mode comes in 3 flavours: 2kB, 32kB and 64kB. There is
40 no point in using any mode other than the 2kB mode - their performances
41 are virtually identical, although the driver has been tested in the 2kB
42 and 32kB modes. I would suggest you uncomment the line:
43
44 FORCE_2K_MODE;
45
46 to allow the driver to configure the card as a 2kB card at your current
47 base address, thus leaving more room to clutter your system box with
48 other memory hungry boards.
49
50 As many ISA and EISA cards can be supported under this driver as you
51 wish, limited primarily by the available IRQ lines, rather than by the
52 available I/O addresses (24 ISA, 16 EISA). I have checked different
53 configurations of multiple depca cards and ewrk3 cards and have not
54 found a problem yet (provided you have at least depca.c v0.38) ...
55
56 The board IRQ setting must be at an unused IRQ which is auto-probed
57 using Donald Becker's autoprobe routines. All these cards are at
58 {5,10,11,15}.
59
60 No 16MB memory limitation should exist with this driver as DMA is not
61 used and the common memory area is in low memory on the network card (my
62 current system has 20MB and I've not had problems yet).
63
64 The ability to load this driver as a loadable module has been included
65 and used extensively during the driver development (to save those long
66 reboot sequences). To utilise this ability, you have to do 8 things:
67
68 0) have a copy of the loadable modules code installed on your system.
69 1) copy ewrk3.c from the /linux/drivers/net directory to your favourite
70 temporary directory.
71 2) edit the source code near line 1898 to reflect the I/O address and
72 IRQ you're using.
73 3) compile ewrk3.c, but include -DMODULE in the command line to ensure
74 that the correct bits are compiled (see end of source code).
75 4) if you are wanting to add a new card, goto 5. Otherwise, recompile a
76 kernel with the ewrk3 configuration turned off and reboot.
77 5) insmod ewrk3.o
78 [Alan Cox: Changed this so you can insmod ewrk3.o irq=x io=y]
79 [Adam Kropelin: now accepts irq=x1,x2 io=y1,y2 for multiple cards]
80 6) run the net startup bits for your new eth?? interface manually
81 (usually /etc/rc.inet[12] at boot time).
82 7) enjoy!
83
84 Note that autoprobing is not allowed in loadable modules - the system is
85 already up and running and you're messing with interrupts.
86
87 To unload a module, turn off the associated interface
88 'ifconfig eth?? down' then 'rmmod ewrk3'.
89
90 Promiscuous mode has been turned off in this driver, but all the
91 multicast address bits have been turned on. This improved the send
92 performance on a busy network by about 13%.
93
94 Ioctl's have now been provided (primarily because I wanted to grab some
95 packet size statistics). They are patterned after 'plipconfig.c' from a
96 suggestion by Alan Cox. Using these ioctls, you can enable promiscuous
97 mode, add/delete multicast addresses, change the hardware address, get
98 packet size distribution statistics and muck around with the control and
99 status register. I'll add others if and when the need arises.
100
101 TO DO:
102 ------
103
104
105 Revision History
106 ----------------
107
108 Version Date Description
109
110 0.1 26-aug-94 Initial writing. ALPHA code release.
111 0.11 31-aug-94 Fixed: 2k mode memory base calc.,
112 LeMAC version calc.,
113 IRQ vector assignments during autoprobe.
114 0.12 31-aug-94 Tested working on LeMAC2 (DE20[345]-AC) card.
115 Fixed up MCA hash table algorithm.
116 0.20 4-sep-94 Added IOCTL functionality.
117 0.21 14-sep-94 Added I/O mode.
118 0.21axp 15-sep-94 Special version for ALPHA AXP Linux V1.0.
119 0.22 16-sep-94 Added more IOCTLs & tidied up.
120 0.23 21-sep-94 Added transmit cut through.
121 0.24 31-oct-94 Added uid checks in some ioctls.
122 0.30 1-nov-94 BETA code release.
123 0.31 5-dec-94 Added check/allocate region code.
124 0.32 16-jan-95 Broadcast packet fix.
125 0.33 10-Feb-95 Fix recognition bug reported by <bkm@star.rl.ac.uk>.
126 0.40 27-Dec-95 Rationalise MODULE and autoprobe code.
127 Rewrite for portability & updated.
128 ALPHA support from <jestabro@amt.tay1.dec.com>
129 Added verify_area() calls in ewrk3_ioctl() from
130 suggestion by <heiko@colossus.escape.de>.
131 Add new multicasting code.
132 0.41 20-Jan-96 Fix IRQ set up problem reported by
133 <kenneth@bbs.sas.ntu.ac.sg>.
134 0.42 22-Apr-96 Fix alloc_device() bug <jari@markkus2.fimr.fi>
135 0.43 16-Aug-96 Update alloc_device() to conform to de4x5.c
136 0.44 08-Nov-01 use library crc32 functions <Matt_Domsch@dell.com>
137 0.45 19-Jul-02 fix unaligned access on alpha <martin@bruli.net>
138 0.46 10-Oct-02 Multiple NIC support when module <akropel1@rochester.rr.com>
139 0.47 18-Oct-02 ethtool support <akropel1@rochester.rr.com>
140 0.48 18-Oct-02 cli/sti removal for 2.5 <vda@port.imtp.ilyichevsk.odessa.ua>
141 ioctl locking, signature search cleanup <akropel1@rochester.rr.com>
142
143 =========================================================================
144 */
145
146#include <linux/module.h>
147#include <linux/kernel.h>
148#include <linux/string.h>
149#include <linux/errno.h>
150#include <linux/ioport.h>
151#include <linux/slab.h>
152#include <linux/interrupt.h>
153#include <linux/delay.h>
154#include <linux/init.h>
155#include <linux/crc32.h>
156#include <linux/netdevice.h>
157#include <linux/etherdevice.h>
158#include <linux/skbuff.h>
159#include <linux/ethtool.h>
160#include <linux/time.h>
161#include <linux/types.h>
162#include <linux/unistd.h>
163#include <linux/ctype.h>
164#include <linux/bitops.h>
165
166#include <asm/io.h>
167#include <asm/dma.h>
168#include <asm/uaccess.h>
169
170#include "ewrk3.h"
171
172#define DRV_NAME "ewrk3"
173#define DRV_VERSION "0.48"
174
175static char version[] __initdata =
176DRV_NAME ":v" DRV_VERSION " 2002/10/18 davies@maniac.ultranet.com\n";
177
178#ifdef EWRK3_DEBUG
179static int ewrk3_debug = EWRK3_DEBUG;
180#else
181static int ewrk3_debug = 1;
182#endif
183
184#define EWRK3_NDA 0xffe0 /* No Device Address */
185
186#define PROBE_LENGTH 32
187#define ETH_PROM_SIG 0xAA5500FFUL
188
189#ifndef EWRK3_SIGNATURE
190#define EWRK3_SIGNATURE {"DE203","DE204","DE205",""}
191#define EWRK3_STRLEN 8
192#endif
193
194#ifndef EWRK3_RAM_BASE_ADDRESSES
195#define EWRK3_RAM_BASE_ADDRESSES {0xc0000,0xd0000,0x00000}
196#endif
197
198/*
199 ** Sets up the I/O area for the autoprobe.
200 */
201#define EWRK3_IO_BASE 0x100 /* Start address for probe search */
202#define EWRK3_IOP_INC 0x20 /* I/O address increment */
203#define EWRK3_TOTAL_SIZE 0x20 /* required I/O address length */
204
205#ifndef MAX_NUM_EWRK3S
206#define MAX_NUM_EWRK3S 21
207#endif
208
209#ifndef EWRK3_EISA_IO_PORTS
210#define EWRK3_EISA_IO_PORTS 0x0c00 /* I/O port base address, slot 0 */
211#endif
212
213#ifndef MAX_EISA_SLOTS
214#define MAX_EISA_SLOTS 16
215#define EISA_SLOT_INC 0x1000
216#endif
217
218#define QUEUE_PKT_TIMEOUT (1*HZ) /* Jiffies */
219
220/*
221 ** EtherWORKS 3 shared memory window sizes
222 */
223#define IO_ONLY 0x00
224#define SHMEM_2K 0x800
225#define SHMEM_32K 0x8000
226#define SHMEM_64K 0x10000
227
228/*
229 ** EtherWORKS 3 IRQ ENABLE/DISABLE
230 */
231#define ENABLE_IRQs { \
232 icr |= lp->irq_mask;\
233 outb(icr, EWRK3_ICR); /* Enable the IRQs */\
234}
235
236#define DISABLE_IRQs { \
237 icr = inb(EWRK3_ICR);\
238 icr &= ~lp->irq_mask;\
239 outb(icr, EWRK3_ICR); /* Disable the IRQs */\
240}
241
242/*
243 ** EtherWORKS 3 START/STOP
244 */
245#define START_EWRK3 { \
246 csr = inb(EWRK3_CSR);\
247 csr &= ~(CSR_TXD|CSR_RXD);\
248 outb(csr, EWRK3_CSR); /* Enable the TX and/or RX */\
249}
250
251#define STOP_EWRK3 { \
252 csr = (CSR_TXD|CSR_RXD);\
253 outb(csr, EWRK3_CSR); /* Disable the TX and/or RX */\
254}
255
256/*
257 ** The EtherWORKS 3 private structure
258 */
259#define EWRK3_PKT_STAT_SZ 16
260#define EWRK3_PKT_BIN_SZ 128 /* Should be >=100 unless you
261 increase EWRK3_PKT_STAT_SZ */
262
263struct ewrk3_stats {
264 u32 bins[EWRK3_PKT_STAT_SZ];
265 u32 unicast;
266 u32 multicast;
267 u32 broadcast;
268 u32 excessive_collisions;
269 u32 tx_underruns;
270 u32 excessive_underruns;
271};
272
273struct ewrk3_private {
274 char adapter_name[80]; /* Name exported to /proc/ioports */
275 u_long shmem_base; /* Shared memory start address */
276 void __iomem *shmem;
277 u_long shmem_length; /* Shared memory window length */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700278 struct ewrk3_stats pktStats; /* Private stats counters */
279 u_char irq_mask; /* Adapter IRQ mask bits */
280 u_char mPage; /* Maximum 2kB Page number */
281 u_char lemac; /* Chip rev. level */
282 u_char hard_strapped; /* Don't allow a full open */
283 u_char txc; /* Transmit cut through */
284 void __iomem *mctbl; /* Pointer to the multicast table */
285 u_char led_mask; /* Used to reserve LED access for ethtool */
286 spinlock_t hw_lock;
287};
288
289/*
290 ** Force the EtherWORKS 3 card to be in 2kB MODE
291 */
292#define FORCE_2K_MODE { \
293 shmem_length = SHMEM_2K;\
294 outb(((mem_start - 0x80000) >> 11), EWRK3_MBR);\
295}
296
297/*
298 ** Public Functions
299 */
300static int ewrk3_open(struct net_device *dev);
301static int ewrk3_queue_pkt(struct sk_buff *skb, struct net_device *dev);
David Howells7d12e782006-10-05 14:55:46 +0100302static irqreturn_t ewrk3_interrupt(int irq, void *dev_id);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700303static int ewrk3_close(struct net_device *dev);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700304static void set_multicast_list(struct net_device *dev);
305static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
Jeff Garzik7282d492006-09-13 14:30:00 -0400306static const struct ethtool_ops ethtool_ops_203;
307static const struct ethtool_ops ethtool_ops;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700308
309/*
310 ** Private functions
311 */
312static int ewrk3_hw_init(struct net_device *dev, u_long iobase);
313static void ewrk3_init(struct net_device *dev);
314static int ewrk3_rx(struct net_device *dev);
315static int ewrk3_tx(struct net_device *dev);
316static void ewrk3_timeout(struct net_device *dev);
317
318static void EthwrkSignature(char *name, char *eeprom_image);
319static int DevicePresent(u_long iobase);
320static void SetMulticastFilter(struct net_device *dev);
321static int EISA_signature(char *name, s32 eisa_id);
322
323static int Read_EEPROM(u_long iobase, u_char eaddr);
324static int Write_EEPROM(short data, u_long iobase, u_char eaddr);
325static u_char get_hw_addr(struct net_device *dev, u_char * eeprom_image, char chipType);
326
327static int ewrk3_probe1(struct net_device *dev, u_long iobase, int irq);
328static int isa_probe(struct net_device *dev, u_long iobase);
329static int eisa_probe(struct net_device *dev, u_long iobase);
330
331static u_char irq[MAX_NUM_EWRK3S+1] = {5, 0, 10, 3, 11, 9, 15, 12};
332
333static char name[EWRK3_STRLEN + 1];
334static int num_ewrks3s;
335
336/*
337 ** Miscellaneous defines...
338 */
339#define INIT_EWRK3 {\
340 outb(EEPROM_INIT, EWRK3_IOPR);\
341 mdelay(1);\
342}
343
344#ifndef MODULE
345struct net_device * __init ewrk3_probe(int unit)
346{
347 struct net_device *dev = alloc_etherdev(sizeof(struct ewrk3_private));
348 int err;
349
350 if (!dev)
351 return ERR_PTR(-ENOMEM);
352
353 if (unit >= 0) {
354 sprintf(dev->name, "eth%d", unit);
355 netdev_boot_setup_check(dev);
356 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700357
358 err = ewrk3_probe1(dev, dev->base_addr, dev->irq);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400359 if (err)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700360 goto out;
361 return dev;
362out:
363 free_netdev(dev);
364 return ERR_PTR(err);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400365
Linus Torvalds1da177e2005-04-16 15:20:36 -0700366}
367#endif
368
369static int __init ewrk3_probe1(struct net_device *dev, u_long iobase, int irq)
370{
371 int err;
372
373 dev->base_addr = iobase;
374 dev->irq = irq;
375
376 /* Address PROM pattern */
377 err = isa_probe(dev, iobase);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400378 if (err != 0)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700379 err = eisa_probe(dev, iobase);
380
381 if (err)
382 return err;
383
384 err = register_netdev(dev);
385 if (err)
386 release_region(dev->base_addr, EWRK3_TOTAL_SIZE);
387
388 return err;
389}
390
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400391static int __init
Linus Torvalds1da177e2005-04-16 15:20:36 -0700392ewrk3_hw_init(struct net_device *dev, u_long iobase)
393{
394 struct ewrk3_private *lp;
395 int i, status = 0;
396 u_long mem_start, shmem_length;
397 u_char cr, cmr, icr, nicsr, lemac, hard_strapped = 0;
398 u_char eeprom_image[EEPROM_MAX], chksum, eisa_cr = 0;
399
400 /*
401 ** Stop the EWRK3. Enable the DBR ROM. Disable interrupts and remote boot.
402 ** This also disables the EISA_ENABLE bit in the EISA Control Register.
403 */
404 if (iobase > 0x400)
405 eisa_cr = inb(EISA_CR);
406 INIT_EWRK3;
407
408 nicsr = inb(EWRK3_CSR);
409
410 icr = inb(EWRK3_ICR);
411 icr &= 0x70;
412 outb(icr, EWRK3_ICR); /* Disable all the IRQs */
413
Jeff Garzik991b5552007-03-23 02:03:29 -0400414 if (nicsr != (CSR_TXD | CSR_RXD))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700415 return -ENXIO;
416
Linus Torvalds1da177e2005-04-16 15:20:36 -0700417 /* Check that the EEPROM is alive and well and not living on Pluto... */
418 for (chksum = 0, i = 0; i < EEPROM_MAX; i += 2) {
419 union {
420 short val;
421 char c[2];
422 } tmp;
423
424 tmp.val = (short) Read_EEPROM(iobase, (i >> 1));
425 eeprom_image[i] = tmp.c[0];
426 eeprom_image[i + 1] = tmp.c[1];
427 chksum += eeprom_image[i] + eeprom_image[i + 1];
428 }
429
430 if (chksum != 0) { /* Bad EEPROM Data! */
431 printk("%s: Device has a bad on-board EEPROM.\n", dev->name);
432 return -ENXIO;
433 }
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400434
Linus Torvalds1da177e2005-04-16 15:20:36 -0700435 EthwrkSignature(name, eeprom_image);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400436 if (*name == '\0')
Linus Torvalds1da177e2005-04-16 15:20:36 -0700437 return -ENXIO;
438
439 dev->base_addr = iobase;
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400440
Linus Torvalds1da177e2005-04-16 15:20:36 -0700441 if (iobase > 0x400) {
442 outb(eisa_cr, EISA_CR); /* Rewrite the EISA CR */
443 }
444 lemac = eeprom_image[EEPROM_CHIPVER];
445 cmr = inb(EWRK3_CMR);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400446
Linus Torvalds1da177e2005-04-16 15:20:36 -0700447 if (((lemac == LeMAC) && ((cmr & CMR_NO_EEPROM) != CMR_NO_EEPROM)) ||
448 ((lemac == LeMAC2) && !(cmr & CMR_HS))) {
449 printk("%s: %s at %#4lx", dev->name, name, iobase);
450 hard_strapped = 1;
451 } else if ((iobase & 0x0fff) == EWRK3_EISA_IO_PORTS) {
452 /* EISA slot address */
453 printk("%s: %s at %#4lx (EISA slot %ld)",
454 dev->name, name, iobase, ((iobase >> 12) & 0x0f));
455 } else { /* ISA port address */
456 printk("%s: %s at %#4lx", dev->name, name, iobase);
457 }
458
459 printk(", h/w address ");
460 if (lemac != LeMAC2)
461 DevicePresent(iobase); /* need after EWRK3_INIT */
462 status = get_hw_addr(dev, eeprom_image, lemac);
Johannes Berge1749612008-10-27 15:59:26 -0700463 printk("%pM\n", dev->dev_addr);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400464
Linus Torvalds1da177e2005-04-16 15:20:36 -0700465 if (status) {
466 printk(" which has an EEPROM CRC error.\n");
467 return -ENXIO;
468 }
469
470 if (lemac == LeMAC2) { /* Special LeMAC2 CMR things */
471 cmr &= ~(CMR_RA | CMR_WB | CMR_LINK | CMR_POLARITY | CMR_0WS);
472 if (eeprom_image[EEPROM_MISC0] & READ_AHEAD)
473 cmr |= CMR_RA;
474 if (eeprom_image[EEPROM_MISC0] & WRITE_BEHIND)
475 cmr |= CMR_WB;
476 if (eeprom_image[EEPROM_NETMAN0] & NETMAN_POL)
477 cmr |= CMR_POLARITY;
478 if (eeprom_image[EEPROM_NETMAN0] & NETMAN_LINK)
479 cmr |= CMR_LINK;
480 if (eeprom_image[EEPROM_MISC0] & _0WS_ENA)
481 cmr |= CMR_0WS;
482 }
483 if (eeprom_image[EEPROM_SETUP] & SETUP_DRAM)
484 cmr |= CMR_DRAM;
485 outb(cmr, EWRK3_CMR);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400486
Linus Torvalds1da177e2005-04-16 15:20:36 -0700487 cr = inb(EWRK3_CR); /* Set up the Control Register */
488 cr |= eeprom_image[EEPROM_SETUP] & SETUP_APD;
489 if (cr & SETUP_APD)
490 cr |= eeprom_image[EEPROM_SETUP] & SETUP_PS;
491 cr |= eeprom_image[EEPROM_MISC0] & FAST_BUS;
492 cr |= eeprom_image[EEPROM_MISC0] & ENA_16;
493 outb(cr, EWRK3_CR);
494
495 /*
496 ** Determine the base address and window length for the EWRK3
497 ** RAM from the memory base register.
498 */
499 mem_start = inb(EWRK3_MBR);
500 shmem_length = 0;
501 if (mem_start != 0) {
502 if ((mem_start >= 0x0a) && (mem_start <= 0x0f)) {
503 mem_start *= SHMEM_64K;
504 shmem_length = SHMEM_64K;
505 } else if ((mem_start >= 0x14) && (mem_start <= 0x1f)) {
506 mem_start *= SHMEM_32K;
507 shmem_length = SHMEM_32K;
508 } else if ((mem_start >= 0x40) && (mem_start <= 0xff)) {
509 mem_start = mem_start * SHMEM_2K + 0x80000;
510 shmem_length = SHMEM_2K;
511 } else {
512 return -ENXIO;
513 }
514 }
515 /*
516 ** See the top of this source code for comments about
517 ** uncommenting this line.
518 */
519/* FORCE_2K_MODE; */
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400520
Linus Torvalds1da177e2005-04-16 15:20:36 -0700521 if (hard_strapped) {
522 printk(" is hard strapped.\n");
523 } else if (mem_start) {
524 printk(" has a %dk RAM window", (int) (shmem_length >> 10));
525 printk(" at 0x%.5lx", mem_start);
526 } else {
527 printk(" is in I/O only mode");
528 }
529
530 lp = netdev_priv(dev);
531 lp->shmem_base = mem_start;
532 lp->shmem = ioremap(mem_start, shmem_length);
533 if (!lp->shmem)
534 return -ENOMEM;
535 lp->shmem_length = shmem_length;
536 lp->lemac = lemac;
537 lp->hard_strapped = hard_strapped;
538 lp->led_mask = CR_LED;
539 spin_lock_init(&lp->hw_lock);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400540
Linus Torvalds1da177e2005-04-16 15:20:36 -0700541 lp->mPage = 64;
542 if (cmr & CMR_DRAM)
543 lp->mPage <<= 1; /* 2 DRAMS on module */
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400544
Linus Torvalds1da177e2005-04-16 15:20:36 -0700545 sprintf(lp->adapter_name, "%s (%s)", name, dev->name);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400546
Linus Torvalds1da177e2005-04-16 15:20:36 -0700547 lp->irq_mask = ICR_TNEM | ICR_TXDM | ICR_RNEM | ICR_RXDM;
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400548
Linus Torvalds1da177e2005-04-16 15:20:36 -0700549 if (!hard_strapped) {
550 /*
551 ** Enable EWRK3 board interrupts for autoprobing
552 */
553 icr |= ICR_IE; /* Enable interrupts */
554 outb(icr, EWRK3_ICR);
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400555
Linus Torvalds1da177e2005-04-16 15:20:36 -0700556 /* The DMA channel may be passed in on this parameter. */
557 dev->dma = 0;
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400558
Linus Torvalds1da177e2005-04-16 15:20:36 -0700559 /* To auto-IRQ we enable the initialization-done and DMA err,
560 interrupts. For now we will always get a DMA error. */
561 if (dev->irq < 2) {
562#ifndef MODULE
563 u_char irqnum;
564 unsigned long irq_mask;
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400565
Linus Torvalds1da177e2005-04-16 15:20:36 -0700566
567 irq_mask = probe_irq_on();
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400568
Linus Torvalds1da177e2005-04-16 15:20:36 -0700569 /*
570 ** Trigger a TNE interrupt.
571 */
572 icr |= ICR_TNEM;
573 outb(1, EWRK3_TDQ); /* Write to the TX done queue */
574 outb(icr, EWRK3_ICR); /* Unmask the TXD interrupt */
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400575
Linus Torvalds1da177e2005-04-16 15:20:36 -0700576 irqnum = irq[((icr & IRQ_SEL) >> 4)];
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400577
Linus Torvalds1da177e2005-04-16 15:20:36 -0700578 mdelay(20);
579 dev->irq = probe_irq_off(irq_mask);
580 if ((dev->irq) && (irqnum == dev->irq)) {
581 printk(" and uses IRQ%d.\n", dev->irq);
582 } else {
583 if (!dev->irq) {
584 printk(" and failed to detect IRQ line.\n");
585 } else if ((irqnum == 1) && (lemac == LeMAC2)) {
586 printk(" and an illegal IRQ line detected.\n");
587 } else {
588 printk(", but incorrect IRQ line detected.\n");
589 }
590 iounmap(lp->shmem);
591 return -ENXIO;
592 }
593
594 DISABLE_IRQs; /* Mask all interrupts */
595
596#endif /* MODULE */
597 } else {
598 printk(" and requires IRQ%d.\n", dev->irq);
599 }
600 }
601
602 if (ewrk3_debug > 1) {
603 printk(version);
604 }
605 /* The EWRK3-specific entries in the device structure. */
606 dev->open = ewrk3_open;
607 dev->hard_start_xmit = ewrk3_queue_pkt;
608 dev->stop = ewrk3_close;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700609 dev->set_multicast_list = set_multicast_list;
610 dev->do_ioctl = ewrk3_ioctl;
611 if (lp->adapter_name[4] == '3')
612 SET_ETHTOOL_OPS(dev, &ethtool_ops_203);
613 else
614 SET_ETHTOOL_OPS(dev, &ethtool_ops);
615 dev->tx_timeout = ewrk3_timeout;
616 dev->watchdog_timeo = QUEUE_PKT_TIMEOUT;
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400617
Linus Torvalds1da177e2005-04-16 15:20:36 -0700618 dev->mem_start = 0;
619
620 return 0;
621}
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400622
Linus Torvalds1da177e2005-04-16 15:20:36 -0700623
624static int ewrk3_open(struct net_device *dev)
625{
626 struct ewrk3_private *lp = netdev_priv(dev);
627 u_long iobase = dev->base_addr;
Joe Perches0795af52007-10-03 17:59:30 -0700628 int status = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700629 u_char icr, csr;
630
631 /*
632 ** Stop the TX and RX...
633 */
634 STOP_EWRK3;
635
636 if (!lp->hard_strapped) {
637 if (request_irq(dev->irq, (void *) ewrk3_interrupt, 0, "ewrk3", dev)) {
638 printk("ewrk3_open(): Requested IRQ%d is busy\n", dev->irq);
639 status = -EAGAIN;
640 } else {
641
642 /*
643 ** Re-initialize the EWRK3...
644 */
645 ewrk3_init(dev);
646
647 if (ewrk3_debug > 1) {
648 printk("%s: ewrk3 open with irq %d\n", dev->name, dev->irq);
Johannes Berge1749612008-10-27 15:59:26 -0700649 printk(" physical address: %pM\n", dev->dev_addr);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700650 if (lp->shmem_length == 0) {
651 printk(" no shared memory, I/O only mode\n");
652 } else {
653 printk(" start of shared memory: 0x%08lx\n", lp->shmem_base);
654 printk(" window length: 0x%04lx\n", lp->shmem_length);
655 }
656 printk(" # of DRAMS: %d\n", ((inb(EWRK3_CMR) & 0x02) ? 2 : 1));
657 printk(" csr: 0x%02x\n", inb(EWRK3_CSR));
658 printk(" cr: 0x%02x\n", inb(EWRK3_CR));
659 printk(" icr: 0x%02x\n", inb(EWRK3_ICR));
660 printk(" cmr: 0x%02x\n", inb(EWRK3_CMR));
661 printk(" fmqc: 0x%02x\n", inb(EWRK3_FMQC));
662 }
663 netif_start_queue(dev);
664 /*
665 ** Unmask EWRK3 board interrupts
666 */
667 icr = inb(EWRK3_ICR);
668 ENABLE_IRQs;
669
670 }
671 } else {
672 printk(KERN_ERR "%s: ewrk3 available for hard strapped set up only.\n", dev->name);
673 printk(KERN_ERR " Run the 'ewrk3setup' utility or remove the hard straps.\n");
674 return -EINVAL;
675 }
676
677 return status;
678}
679
680/*
681 ** Initialize the EtherWORKS 3 operating conditions
682 */
683static void ewrk3_init(struct net_device *dev)
684{
685 struct ewrk3_private *lp = netdev_priv(dev);
686 u_char csr, page;
687 u_long iobase = dev->base_addr;
688 int i;
689
690 /*
691 ** Enable any multicasts
692 */
693 set_multicast_list(dev);
694
695 /*
696 ** Set hardware MAC address. Address is initialized from the EEPROM
697 ** during startup but may have since been changed by the user.
698 */
699 for (i=0; i<ETH_ALEN; i++)
700 outb(dev->dev_addr[i], EWRK3_PAR0 + i);
701
702 /*
703 ** Clean out any remaining entries in all the queues here
704 */
705 while (inb(EWRK3_TQ));
706 while (inb(EWRK3_TDQ));
707 while (inb(EWRK3_RQ));
708 while (inb(EWRK3_FMQ));
709
710 /*
711 ** Write a clean free memory queue
712 */
713 for (page = 1; page < lp->mPage; page++) { /* Write the free page numbers */
714 outb(page, EWRK3_FMQ); /* to the Free Memory Queue */
715 }
716
717 START_EWRK3; /* Enable the TX and/or RX */
718}
719
720/*
721 * Transmit timeout
722 */
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400723
Linus Torvalds1da177e2005-04-16 15:20:36 -0700724static void ewrk3_timeout(struct net_device *dev)
725{
726 struct ewrk3_private *lp = netdev_priv(dev);
727 u_char icr, csr;
728 u_long iobase = dev->base_addr;
Jeff Garzik6aa20a22006-09-13 13:24:59 -0400729
730 if (!lp->hard_strapped)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700731 {
732 printk(KERN_WARNING"%s: transmit timed/locked out, status %04x, resetting.\n",
733 dev->name, inb(EWRK3_CSR));
734
735 /*
736 ** Mask all board interrupts
737 */
738 DISABLE_IRQs;
739
740 /*
741 ** Stop the TX and RX...
742 */
743 STOP_EWRK3;
744
745 ewrk3_init(dev);
746
747 /*
748 ** Unmask EWRK3 board interrupts
749 */
750 ENABLE_IRQs;
751
752 dev->trans_start = jiffies;
753 netif_wake_queue(dev);
754 }
755}
756
757/*
758 ** Writes a socket buffer to the free page queue
759 */
760static int ewrk3_queue_pkt (struct sk_buff *skb, struct net_device *dev)
761{
762 struct ewrk3_private *lp = netdev_priv(dev);
763 u_long iobase = dev->base_addr;
764 void __iomem *buf = NULL;
765 u_char icr;
766 u_char page;
767
768 spin_lock_irq (&lp->hw_lock);
769 DISABLE_IRQs;
770
771 /* if no resources available, exit, request packet be queued */
772 if (inb (EWRK3_FMQC) == 0) {
773 printk (KERN_WARNING "%s: ewrk3_queue_pkt(): No free resources...\n",
774 dev->name);
775 printk (KERN_WARNING "%s: ewrk3_queue_pkt(): CSR: %02x ICR: %02x FMQC: %02x\n",
776 dev->name, inb (EWRK3_CSR), inb (EWRK3_ICR),
777 inb (EWRK3_FMQC));
778 goto err_out;
779 }
780
781 /*
782 ** Get a free page from the FMQ
783 */
784 if ((page = inb (EWRK3_FMQ)) >= lp->mPage) {
785 printk ("ewrk3_queue_pkt(): Invalid free memory page (%d).\n",
786 (u_char) page);
787 goto err_out;
788 }
789
790
791 /*
792 ** Set up shared memory window and pointer into the window
793 */
794 if (lp->shmem_length == IO_ONLY) {
795 outb (page, EWRK3_IOPR);
796 } else if (lp->shmem_length == SHMEM_2K) {
797 buf = lp->shmem;
798 outb (page, EWRK3_MPR);
799 } else if (lp->shmem_length == SHMEM_32K) {
800 buf = (((short) page << 11) & 0x7800) + lp->shmem;
801 outb ((page >> 4), EWRK3_MPR);
802 } else if (lp->shmem_length == SHMEM_64K) {
803 buf = (((short) page << 11) & 0xf800) + lp->shmem;
804 outb ((page >> 5), EWRK3_MPR);
805 } else {
806 printk (KERN_ERR "%s: Oops - your private data area is hosed!\n",
807 dev->name);
808 BUG ();
809 }
810
811 /*
812 ** Set up the buffer control structures and copy the data from
813 ** the socket buffer to the shared memory .
814 */
815 if (lp->shmem_length == IO_ONLY) {
816 int i;
817 u_char *p = skb->data;
818 outb ((char) (TCR_QMODE | TCR_PAD | TCR_IFC), EWRK3_DATA);
819 outb ((char) (skb->len & 0xff), EWRK3_DATA);
820 outb ((char) ((skb->len >> 8) & 0xff), EWRK3_DATA);
821 outb ((char) 0x04, EWRK3_DATA);
822 for (i = 0; i < skb->len; i++) {
823 outb (*p++, EWRK3_DATA);
824 }
825 outb (page, EWRK3_TQ); /* Start sending pkt */
826 } else {
827 writeb ((char) (TCR_QMODE | TCR_PAD | TCR_IFC), buf); /* ctrl byte */
828 buf += 1;
829 writeb ((char) (skb->len & 0xff), buf); /* length (16 bit xfer) */
830 buf += 1;
831 if (lp->txc) {
832 writeb(((skb->len >> 8) & 0xff) | XCT, buf);
833 buf += 1;
834 writeb (0x04, buf); /* index byte */
835 buf += 1;
836 writeb (0x00, (buf + skb->len)); /* Write the XCT flag */
837 memcpy_toio (buf, skb->data, PRELOAD); /* Write PRELOAD bytes */
838 outb (page, EWRK3_TQ); /* Start sending pkt */
839 memcpy_toio (buf + PRELOAD,
840 skb->data + PRELOAD,
841 skb->len - PRELOAD);
842 writeb (0xff, (buf + skb->len)); /* Write the XCT flag */
843 } else {
844 writeb ((skb->len >> 8) & 0xff, buf);
845 buf += 1;
846 writeb (0x04, buf); /* index byte */
847 buf += 1;
848 memcpy_toio (buf, skb->data, skb->len); /* Write data bytes */
849 outb (page, EWRK3_TQ); /* Start sending pkt */
850 }
851 }
852
853 ENABLE_IRQs;
854 spin_unlock_irq (&lp->hw_lock);
855
Jeff Garzik09f75cd2007-10-03 17:41:50 -0700856 dev->stats.tx_bytes += skb->len;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700857 dev->trans_start = jiffies;
858 dev_kfree_skb (skb);
859
860 /* Check for free resources: stop Tx queue if there are none */
861 if (inb (EWRK3_FMQC) == 0)
862 netif_stop_queue (dev);
863
864 return 0;
865
866err_out:
867 ENABLE_IRQs;
868 spin_unlock_irq (&lp->hw_lock);
869 return 1;
870}
871
872/*
873 ** The EWRK3 interrupt handler.
874 */
David Howells7d12e782006-10-05 14:55:46 +0100875static irqreturn_t ewrk3_interrupt(int irq, void *dev_id)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700876{
877 struct net_device *dev = dev_id;
878 struct ewrk3_private *lp;
879 u_long iobase;
880 u_char icr, cr, csr;
881
882 lp = netdev_priv(dev);
883 iobase = dev->base_addr;
884
885 /* get the interrupt information */
886 csr = inb(EWRK3_CSR);
887
888 /*
889 ** Mask the EWRK3 board interrupts and turn on the LED
890 */
891 spin_lock(&lp->hw_lock);
892 DISABLE_IRQs;
893
894 cr = inb(EWRK3_CR);
895 cr |= lp->led_mask;
896 outb(cr, EWRK3_CR);
897
898 if (csr & CSR_RNE) /* Rx interrupt (packet[s] arrived) */
899 ewrk3_rx(dev);
900
901 if (csr & CSR_TNE) /* Tx interrupt (packet sent) */
902 ewrk3_tx(dev);
903
904 /*
905 ** Now deal with the TX/RX disable flags. These are set when there
906 ** are no more resources. If resources free up then enable these
907 ** interrupts, otherwise mask them - failure to do this will result
908 ** in the system hanging in an interrupt loop.
909 */
910 if (inb(EWRK3_FMQC)) { /* any resources available? */
911 lp->irq_mask |= ICR_TXDM | ICR_RXDM; /* enable the interrupt source */
912 csr &= ~(CSR_TXD | CSR_RXD); /* ensure restart of a stalled TX or RX */
913 outb(csr, EWRK3_CSR);
914 netif_wake_queue(dev);
915 } else {
916 lp->irq_mask &= ~(ICR_TXDM | ICR_RXDM); /* disable the interrupt source */
917 }
918
919 /* Unmask the EWRK3 board interrupts and turn off the LED */
920 cr &= ~(lp->led_mask);
921 outb(cr, EWRK3_CR);
922 ENABLE_IRQs;
923 spin_unlock(&lp->hw_lock);
924 return IRQ_HANDLED;
925}
926
927/* Called with lp->hw_lock held */
928static int ewrk3_rx(struct net_device *dev)
929{
930 struct ewrk3_private *lp = netdev_priv(dev);
931 u_long iobase = dev->base_addr;
932 int i, status = 0;
933 u_char page;
934 void __iomem *buf = NULL;
935
936 while (inb(EWRK3_RQC) && !status) { /* Whilst there's incoming data */
937 if ((page = inb(EWRK3_RQ)) < lp->mPage) { /* Get next entry's buffer page */
938 /*
939 ** Set up shared memory window and pointer into the window
940 */
941 if (lp->shmem_length == IO_ONLY) {
942 outb(page, EWRK3_IOPR);
943 } else if (lp->shmem_length == SHMEM_2K) {
944 buf = lp->shmem;
945 outb(page, EWRK3_MPR);
946 } else if (lp->shmem_length == SHMEM_32K) {
947 buf = (((short) page << 11) & 0x7800) + lp->shmem;
948 outb((page >> 4), EWRK3_MPR);
949 } else if (lp->shmem_length == SHMEM_64K) {
950 buf = (((short) page << 11) & 0xf800) + lp->shmem;
951 outb((page >> 5), EWRK3_MPR);
952 } else {
953 status = -1;
954 printk("%s: Oops - your private data area is hosed!\n", dev->name);
955 }
956
957 if (!status) {
958 char rx_status;
959 int pkt_len;
960
961 if (lp->shmem_length == IO_ONLY) {
962 rx_status = inb(EWRK3_DATA);
963 pkt_len = inb(EWRK3_DATA);
964 pkt_len |= ((u_short) inb(EWRK3_DATA) << 8);
965 } else {
966 rx_status = readb(buf);
967 buf += 1;
968 pkt_len = readw(buf);
969 buf += 3;
970 }
971
972 if (!(rx_status & R_ROK)) { /* There was an error. */
Jeff Garzik09f75cd2007-10-03 17:41:50 -0700973 dev->stats.rx_errors++; /* Update the error stats. */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700974 if (rx_status & R_DBE)
Jeff Garzik09f75cd2007-10-03 17:41:50 -0700975 dev->stats.rx_frame_errors++;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700976 if (rx_status & R_CRC)
Jeff Garzik09f75cd2007-10-03 17:41:50 -0700977 dev->stats.rx_crc_errors++;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700978 if (rx_status & R_PLL)
Jeff Garzik09f75cd2007-10-03 17:41:50 -0700979 dev->stats.rx_fifo_errors++;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700980 } else {
981 struct sk_buff *skb;
982
983 if ((skb = dev_alloc_skb(pkt_len + 2)) != NULL) {
984 unsigned char *p;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700985 skb_reserve(skb, 2); /* Align to 16 bytes */
986 p = skb_put(skb, pkt_len);
987
988 if (lp->shmem_length == IO_ONLY) {
989 *p = inb(EWRK3_DATA); /* dummy read */
990 for (i = 0; i < pkt_len; i++) {
991 *p++ = inb(EWRK3_DATA);
992 }
993 } else {
994 memcpy_fromio(p, buf, pkt_len);
995 }
996
997 for (i = 1; i < EWRK3_PKT_STAT_SZ - 1; i++) {
998 if (pkt_len < i * EWRK3_PKT_BIN_SZ) {
999 lp->pktStats.bins[i]++;
1000 i = EWRK3_PKT_STAT_SZ;
1001 }
1002 }
1003 p = skb->data; /* Look at the dest addr */
1004 if (p[0] & 0x01) { /* Multicast/Broadcast */
1005 if ((*(s16 *) & p[0] == -1) && (*(s16 *) & p[2] == -1) && (*(s16 *) & p[4] == -1)) {
1006 lp->pktStats.broadcast++;
1007 } else {
1008 lp->pktStats.multicast++;
1009 }
1010 } else if ((*(s16 *) & p[0] == *(s16 *) & dev->dev_addr[0]) &&
1011 (*(s16 *) & p[2] == *(s16 *) & dev->dev_addr[2]) &&
1012 (*(s16 *) & p[4] == *(s16 *) & dev->dev_addr[4])) {
1013 lp->pktStats.unicast++;
1014 }
1015 lp->pktStats.bins[0]++; /* Duplicates stats.rx_packets */
1016 if (lp->pktStats.bins[0] == 0) { /* Reset counters */
1017 memset(&lp->pktStats, 0, sizeof(lp->pktStats));
1018 }
1019 /*
1020 ** Notify the upper protocol layers that there is another
1021 ** packet to handle
1022 */
1023 skb->protocol = eth_type_trans(skb, dev);
1024 netif_rx(skb);
1025
1026 /*
1027 ** Update stats
1028 */
1029 dev->last_rx = jiffies;
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001030 dev->stats.rx_packets++;
1031 dev->stats.rx_bytes += pkt_len;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001032 } else {
1033 printk("%s: Insufficient memory; nuking packet.\n", dev->name);
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001034 dev->stats.rx_dropped++; /* Really, deferred. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001035 break;
1036 }
1037 }
1038 }
1039 /*
1040 ** Return the received buffer to the free memory queue
1041 */
1042 outb(page, EWRK3_FMQ);
1043 } else {
1044 printk("ewrk3_rx(): Illegal page number, page %d\n", page);
1045 printk("ewrk3_rx(): CSR: %02x ICR: %02x FMQC: %02x\n", inb(EWRK3_CSR), inb(EWRK3_ICR), inb(EWRK3_FMQC));
1046 }
1047 }
1048 return status;
1049}
1050
1051/*
1052** Buffer sent - check for TX buffer errors.
1053** Called with lp->hw_lock held
1054*/
1055static int ewrk3_tx(struct net_device *dev)
1056{
1057 struct ewrk3_private *lp = netdev_priv(dev);
1058 u_long iobase = dev->base_addr;
1059 u_char tx_status;
1060
1061 while ((tx_status = inb(EWRK3_TDQ)) > 0) { /* Whilst there's old buffers */
1062 if (tx_status & T_VSTS) { /* The status is valid */
1063 if (tx_status & T_TXE) {
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001064 dev->stats.tx_errors++;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001065 if (tx_status & T_NCL)
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001066 dev->stats.tx_carrier_errors++;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001067 if (tx_status & T_LCL)
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001068 dev->stats.tx_window_errors++;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001069 if (tx_status & T_CTU) {
1070 if ((tx_status & T_COLL) ^ T_XUR) {
1071 lp->pktStats.tx_underruns++;
1072 } else {
1073 lp->pktStats.excessive_underruns++;
1074 }
1075 } else if (tx_status & T_COLL) {
1076 if ((tx_status & T_COLL) ^ T_XCOLL) {
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001077 dev->stats.collisions++;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001078 } else {
1079 lp->pktStats.excessive_collisions++;
1080 }
1081 }
1082 } else {
Jeff Garzik09f75cd2007-10-03 17:41:50 -07001083 dev->stats.tx_packets++;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001084 }
1085 }
1086 }
1087
1088 return 0;
1089}
1090
1091static int ewrk3_close(struct net_device *dev)
1092{
1093 struct ewrk3_private *lp = netdev_priv(dev);
1094 u_long iobase = dev->base_addr;
1095 u_char icr, csr;
1096
1097 netif_stop_queue(dev);
Jeff Garzik6aa20a22006-09-13 13:24:59 -04001098
Linus Torvalds1da177e2005-04-16 15:20:36 -07001099 if (ewrk3_debug > 1) {
1100 printk("%s: Shutting down ethercard, status was %2.2x.\n",
1101 dev->name, inb(EWRK3_CSR));
1102 }
1103 /*
1104 ** We stop the EWRK3 here... mask interrupts and stop TX & RX
1105 */
1106 DISABLE_IRQs;
1107
1108 STOP_EWRK3;
1109
1110 /*
1111 ** Clean out the TX and RX queues here (note that one entry
1112 ** may get added to either the TXD or RX queues if the TX or RX
1113 ** just starts processing a packet before the STOP_EWRK3 command
1114 ** is received. This will be flushed in the ewrk3_open() call).
1115 */
1116 while (inb(EWRK3_TQ));
1117 while (inb(EWRK3_TDQ));
1118 while (inb(EWRK3_RQ));
1119
1120 if (!lp->hard_strapped) {
1121 free_irq(dev->irq, dev);
1122 }
1123 return 0;
1124}
1125
Linus Torvalds1da177e2005-04-16 15:20:36 -07001126/*
1127 ** Set or clear the multicast filter for this adapter.
1128 */
1129static void set_multicast_list(struct net_device *dev)
1130{
1131 struct ewrk3_private *lp = netdev_priv(dev);
1132 u_long iobase = dev->base_addr;
1133 u_char csr;
1134
1135 csr = inb(EWRK3_CSR);
1136
1137 if (lp->shmem_length == IO_ONLY) {
1138 lp->mctbl = NULL;
1139 } else {
1140 lp->mctbl = lp->shmem + PAGE0_HTE;
1141 }
1142
1143 csr &= ~(CSR_PME | CSR_MCE);
1144 if (dev->flags & IFF_PROMISC) { /* set promiscuous mode */
1145 csr |= CSR_PME;
1146 outb(csr, EWRK3_CSR);
1147 } else {
1148 SetMulticastFilter(dev);
1149 csr |= CSR_MCE;
1150 outb(csr, EWRK3_CSR);
1151 }
1152}
1153
1154/*
1155 ** Calculate the hash code and update the logical address filter
1156 ** from a list of ethernet multicast addresses.
1157 ** Little endian crc one liner from Matt Thomas, DEC.
1158 **
1159 ** Note that when clearing the table, the broadcast bit must remain asserted
1160 ** to receive broadcast messages.
1161 */
1162static void SetMulticastFilter(struct net_device *dev)
1163{
1164 struct ewrk3_private *lp = netdev_priv(dev);
1165 struct dev_mc_list *dmi = dev->mc_list;
1166 u_long iobase = dev->base_addr;
1167 int i;
1168 char *addrs, bit, byte;
1169 short __iomem *p = lp->mctbl;
1170 u16 hashcode;
1171 u32 crc;
1172
1173 spin_lock_irq(&lp->hw_lock);
1174
1175 if (lp->shmem_length == IO_ONLY) {
1176 outb(0, EWRK3_IOPR);
1177 outw(PAGE0_HTE, EWRK3_PIR1);
1178 } else {
1179 outb(0, EWRK3_MPR);
1180 }
1181
1182 if (dev->flags & IFF_ALLMULTI) {
1183 for (i = 0; i < (HASH_TABLE_LEN >> 3); i++) {
1184 if (lp->shmem_length == IO_ONLY) {
1185 outb(0xff, EWRK3_DATA);
1186 } else { /* memset didn't work here */
1187 writew(0xffff, p);
1188 p++;
1189 i++;
1190 }
1191 }
1192 } else {
1193 /* Clear table except for broadcast bit */
1194 if (lp->shmem_length == IO_ONLY) {
1195 for (i = 0; i < (HASH_TABLE_LEN >> 4) - 1; i++) {
1196 outb(0x00, EWRK3_DATA);
1197 }
1198 outb(0x80, EWRK3_DATA);
1199 i++; /* insert the broadcast bit */
1200 for (; i < (HASH_TABLE_LEN >> 3); i++) {
1201 outb(0x00, EWRK3_DATA);
1202 }
1203 } else {
1204 memset_io(lp->mctbl, 0, HASH_TABLE_LEN >> 3);
1205 writeb(0x80, lp->mctbl + (HASH_TABLE_LEN >> 4) - 1);
1206 }
1207
1208 /* Update table */
1209 for (i = 0; i < dev->mc_count; i++) { /* for each address in the list */
1210 addrs = dmi->dmi_addr;
1211 dmi = dmi->next;
1212 if ((*addrs & 0x01) == 1) { /* multicast address? */
1213 crc = ether_crc_le(ETH_ALEN, addrs);
1214 hashcode = crc & ((1 << 9) - 1); /* hashcode is 9 LSb of CRC */
1215
1216 byte = hashcode >> 3; /* bit[3-8] -> byte in filter */
1217 bit = 1 << (hashcode & 0x07); /* bit[0-2] -> bit in byte */
1218
1219 if (lp->shmem_length == IO_ONLY) {
1220 u_char tmp;
1221
1222 outw(PAGE0_HTE + byte, EWRK3_PIR1);
1223 tmp = inb(EWRK3_DATA);
1224 tmp |= bit;
1225 outw(PAGE0_HTE + byte, EWRK3_PIR1);
1226 outb(tmp, EWRK3_DATA);
1227 } else {
1228 writeb(readb(lp->mctbl + byte) | bit, lp->mctbl + byte);
1229 }
1230 }
1231 }
1232 }
1233
1234 spin_unlock_irq(&lp->hw_lock);
1235}
1236
1237/*
1238 ** ISA bus I/O device probe
1239 */
1240static int __init isa_probe(struct net_device *dev, u_long ioaddr)
1241{
1242 int i = num_ewrks3s, maxSlots;
1243 int ret = -ENODEV;
1244
1245 u_long iobase;
1246
1247 if (ioaddr >= 0x400)
1248 goto out;
1249
1250 if (ioaddr == 0) { /* Autoprobing */
1251 iobase = EWRK3_IO_BASE; /* Get the first slot address */
1252 maxSlots = 24;
1253 } else { /* Probe a specific location */
1254 iobase = ioaddr;
1255 maxSlots = i + 1;
1256 }
1257
1258 for (; (i < maxSlots) && (dev != NULL);
1259 iobase += EWRK3_IOP_INC, i++)
1260 {
1261 if (request_region(iobase, EWRK3_TOTAL_SIZE, DRV_NAME)) {
1262 if (DevicePresent(iobase) == 0) {
1263 int irq = dev->irq;
1264 ret = ewrk3_hw_init(dev, iobase);
1265 if (!ret)
1266 break;
1267 dev->irq = irq;
1268 }
1269 release_region(iobase, EWRK3_TOTAL_SIZE);
1270 }
1271 }
1272 out:
1273
1274 return ret;
1275}
1276
1277/*
1278 ** EISA bus I/O device probe. Probe from slot 1 since slot 0 is usually
1279 ** the motherboard.
1280 */
1281static int __init eisa_probe(struct net_device *dev, u_long ioaddr)
1282{
1283 int i, maxSlots;
1284 u_long iobase;
1285 int ret = -ENODEV;
1286
1287 if (ioaddr < 0x1000)
1288 goto out;
1289
Adrian Bunk6835d092005-05-02 03:47:00 +02001290 iobase = ioaddr;
1291 i = (ioaddr >> 12);
1292 maxSlots = i + 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001293
1294 for (i = 1; (i < maxSlots) && (dev != NULL); i++, iobase += EISA_SLOT_INC) {
1295 if (EISA_signature(name, EISA_ID) == 0) {
1296 if (request_region(iobase, EWRK3_TOTAL_SIZE, DRV_NAME) &&
1297 DevicePresent(iobase) == 0) {
1298 int irq = dev->irq;
1299 ret = ewrk3_hw_init(dev, iobase);
1300 if (!ret)
1301 break;
1302 dev->irq = irq;
1303 }
1304 release_region(iobase, EWRK3_TOTAL_SIZE);
1305 }
1306 }
1307
1308 out:
1309 return ret;
1310}
1311
1312
1313/*
1314 ** Read the EWRK3 EEPROM using this routine
1315 */
1316static int Read_EEPROM(u_long iobase, u_char eaddr)
1317{
1318 int i;
1319
1320 outb((eaddr & 0x3f), EWRK3_PIR1); /* set up 6 bits of address info */
1321 outb(EEPROM_RD, EWRK3_IOPR); /* issue read command */
1322 for (i = 0; i < 5000; i++)
1323 inb(EWRK3_CSR); /* wait 1msec */
1324
1325 return inw(EWRK3_EPROM1); /* 16 bits data return */
1326}
1327
1328/*
1329 ** Write the EWRK3 EEPROM using this routine
1330 */
1331static int Write_EEPROM(short data, u_long iobase, u_char eaddr)
1332{
1333 int i;
1334
1335 outb(EEPROM_WR_EN, EWRK3_IOPR); /* issue write enable command */
1336 for (i = 0; i < 5000; i++)
1337 inb(EWRK3_CSR); /* wait 1msec */
1338 outw(data, EWRK3_EPROM1); /* write data to register */
1339 outb((eaddr & 0x3f), EWRK3_PIR1); /* set up 6 bits of address info */
1340 outb(EEPROM_WR, EWRK3_IOPR); /* issue write command */
1341 for (i = 0; i < 75000; i++)
1342 inb(EWRK3_CSR); /* wait 15msec */
1343 outb(EEPROM_WR_DIS, EWRK3_IOPR); /* issue write disable command */
1344 for (i = 0; i < 5000; i++)
1345 inb(EWRK3_CSR); /* wait 1msec */
1346
1347 return 0;
1348}
1349
1350/*
1351 ** Look for a particular board name in the on-board EEPROM.
1352 */
1353static void __init EthwrkSignature(char *name, char *eeprom_image)
1354{
1355 int i;
1356 char *signatures[] = EWRK3_SIGNATURE;
1357
1358 for (i=0; *signatures[i] != '\0'; i++)
1359 if( !strncmp(eeprom_image+EEPROM_PNAME7, signatures[i], strlen(signatures[i])) )
1360 break;
1361
1362 if (*signatures[i] != '\0') {
1363 memcpy(name, eeprom_image+EEPROM_PNAME7, EWRK3_STRLEN);
1364 name[EWRK3_STRLEN] = '\0';
1365 } else
1366 name[0] = '\0';
1367
1368 return;
1369}
1370
1371/*
1372 ** Look for a special sequence in the Ethernet station address PROM that
1373 ** is common across all EWRK3 products.
1374 **
1375 ** Search the Ethernet address ROM for the signature. Since the ROM address
1376 ** counter can start at an arbitrary point, the search must include the entire
1377 ** probe sequence length plus the (length_of_the_signature - 1).
1378 ** Stop the search IMMEDIATELY after the signature is found so that the
1379 ** PROM address counter is correctly positioned at the start of the
1380 ** ethernet address for later read out.
1381 */
1382
1383static int __init DevicePresent(u_long iobase)
1384{
1385 union {
1386 struct {
1387 u32 a;
1388 u32 b;
1389 } llsig;
1390 char Sig[sizeof(u32) << 1];
1391 }
1392 dev;
1393 short sigLength;
1394 char data;
1395 int i, j, status = 0;
1396
1397 dev.llsig.a = ETH_PROM_SIG;
1398 dev.llsig.b = ETH_PROM_SIG;
1399 sigLength = sizeof(u32) << 1;
1400
1401 for (i = 0, j = 0; j < sigLength && i < PROBE_LENGTH + sigLength - 1; i++) {
1402 data = inb(EWRK3_APROM);
1403 if (dev.Sig[j] == data) { /* track signature */
1404 j++;
1405 } else { /* lost signature; begin search again */
1406 if (data == dev.Sig[0]) {
1407 j = 1;
1408 } else {
1409 j = 0;
1410 }
1411 }
1412 }
1413
1414 if (j != sigLength) {
1415 status = -ENODEV; /* search failed */
1416 }
1417 return status;
1418}
1419
1420static u_char __init get_hw_addr(struct net_device *dev, u_char * eeprom_image, char chipType)
1421{
1422 int i, j, k;
1423 u_short chksum;
1424 u_char crc, lfsr, sd, status = 0;
1425 u_long iobase = dev->base_addr;
1426 u16 tmp;
1427
1428 if (chipType == LeMAC2) {
1429 for (crc = 0x6a, j = 0; j < ETH_ALEN; j++) {
1430 sd = dev->dev_addr[j] = eeprom_image[EEPROM_PADDR0 + j];
1431 outb(dev->dev_addr[j], EWRK3_PAR0 + j);
1432 for (k = 0; k < 8; k++, sd >>= 1) {
1433 lfsr = ((((crc & 0x02) >> 1) ^ (crc & 0x01)) ^ (sd & 0x01)) << 7;
1434 crc = (crc >> 1) + lfsr;
1435 }
1436 }
1437 if (crc != eeprom_image[EEPROM_PA_CRC])
1438 status = -1;
1439 } else {
1440 for (i = 0, k = 0; i < ETH_ALEN;) {
1441 k <<= 1;
1442 if (k > 0xffff)
1443 k -= 0xffff;
1444
1445 k += (u_char) (tmp = inb(EWRK3_APROM));
1446 dev->dev_addr[i] = (u_char) tmp;
1447 outb(dev->dev_addr[i], EWRK3_PAR0 + i);
1448 i++;
1449 k += (u_short) ((tmp = inb(EWRK3_APROM)) << 8);
1450 dev->dev_addr[i] = (u_char) tmp;
1451 outb(dev->dev_addr[i], EWRK3_PAR0 + i);
1452 i++;
1453
1454 if (k > 0xffff)
1455 k -= 0xffff;
1456 }
1457 if (k == 0xffff)
1458 k = 0;
1459 chksum = inb(EWRK3_APROM);
1460 chksum |= (inb(EWRK3_APROM) << 8);
1461 if (k != chksum)
1462 status = -1;
1463 }
1464
1465 return status;
1466}
1467
1468/*
1469 ** Look for a particular board name in the EISA configuration space
1470 */
1471static int __init EISA_signature(char *name, s32 eisa_id)
1472{
1473 u_long i;
1474 char *signatures[] = EWRK3_SIGNATURE;
1475 char ManCode[EWRK3_STRLEN];
1476 union {
1477 s32 ID;
1478 char Id[4];
1479 } Eisa;
1480 int status = 0;
1481
1482 *name = '\0';
1483 for (i = 0; i < 4; i++) {
1484 Eisa.Id[i] = inb(eisa_id + i);
1485 }
1486
1487 ManCode[0] = (((Eisa.Id[0] >> 2) & 0x1f) + 0x40);
1488 ManCode[1] = (((Eisa.Id[1] & 0xe0) >> 5) + ((Eisa.Id[0] & 0x03) << 3) + 0x40);
1489 ManCode[2] = (((Eisa.Id[2] >> 4) & 0x0f) + 0x30);
1490 ManCode[3] = ((Eisa.Id[2] & 0x0f) + 0x30);
1491 ManCode[4] = (((Eisa.Id[3] >> 4) & 0x0f) + 0x30);
1492 ManCode[5] = '\0';
1493
1494 for (i = 0; (*signatures[i] != '\0') && (*name == '\0'); i++) {
1495 if (strstr(ManCode, signatures[i]) != NULL) {
1496 strcpy(name, ManCode);
1497 status = 1;
1498 }
1499 }
1500
1501 return status; /* return the device name string */
1502}
1503
1504static void ewrk3_get_drvinfo(struct net_device *dev, struct ethtool_drvinfo *info)
1505{
1506 int fwrev = Read_EEPROM(dev->base_addr, EEPROM_REVLVL);
1507
1508 strcpy(info->driver, DRV_NAME);
1509 strcpy(info->version, DRV_VERSION);
1510 sprintf(info->fw_version, "%d", fwrev);
1511 strcpy(info->bus_info, "N/A");
1512 info->eedump_len = EEPROM_MAX;
1513}
1514
1515static int ewrk3_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd)
1516{
1517 struct ewrk3_private *lp = netdev_priv(dev);
1518 unsigned long iobase = dev->base_addr;
1519 u8 cr = inb(EWRK3_CR);
1520
1521 switch (lp->adapter_name[4]) {
1522 case '3': /* DE203 */
1523 ecmd->supported = SUPPORTED_BNC;
1524 ecmd->port = PORT_BNC;
1525 break;
1526
1527 case '4': /* DE204 */
1528 ecmd->supported = SUPPORTED_TP;
1529 ecmd->port = PORT_TP;
1530 break;
1531
1532 case '5': /* DE205 */
1533 ecmd->supported = SUPPORTED_TP | SUPPORTED_BNC | SUPPORTED_AUI;
1534 ecmd->autoneg = !(cr & CR_APD);
1535 /*
1536 ** Port is only valid if autoneg is disabled
1537 ** and even then we don't know if AUI is jumpered.
1538 */
1539 if (!ecmd->autoneg)
1540 ecmd->port = (cr & CR_PSEL) ? PORT_BNC : PORT_TP;
1541 break;
1542 }
1543
1544 ecmd->supported |= SUPPORTED_10baseT_Half;
1545 ecmd->speed = SPEED_10;
1546 ecmd->duplex = DUPLEX_HALF;
1547 return 0;
1548}
1549
1550static int ewrk3_set_settings(struct net_device *dev, struct ethtool_cmd *ecmd)
1551{
1552 struct ewrk3_private *lp = netdev_priv(dev);
1553 unsigned long iobase = dev->base_addr;
1554 unsigned long flags;
1555 u8 cr;
1556
1557 /* DE205 is the only card with anything to set */
1558 if (lp->adapter_name[4] != '5')
1559 return -EOPNOTSUPP;
1560
1561 /* Sanity-check parameters */
1562 if (ecmd->speed != SPEED_10)
1563 return -EINVAL;
1564 if (ecmd->port != PORT_TP && ecmd->port != PORT_BNC)
1565 return -EINVAL; /* AUI is not software-selectable */
1566 if (ecmd->transceiver != XCVR_INTERNAL)
1567 return -EINVAL;
1568 if (ecmd->duplex != DUPLEX_HALF)
1569 return -EINVAL;
1570 if (ecmd->phy_address != 0)
1571 return -EINVAL;
1572
1573 spin_lock_irqsave(&lp->hw_lock, flags);
1574 cr = inb(EWRK3_CR);
1575
1576 /* If Autoneg is set, change to Auto Port mode */
1577 /* Otherwise, disable Auto Port and set port explicitly */
1578 if (ecmd->autoneg) {
1579 cr &= ~CR_APD;
1580 } else {
1581 cr |= CR_APD;
1582 if (ecmd->port == PORT_TP)
1583 cr &= ~CR_PSEL; /* Force TP */
1584 else
1585 cr |= CR_PSEL; /* Force BNC */
1586 }
1587
1588 /* Commit the changes */
1589 outb(cr, EWRK3_CR);
1590 spin_unlock_irqrestore(&lp->hw_lock, flags);
1591 return 0;
1592}
1593
1594static u32 ewrk3_get_link(struct net_device *dev)
1595{
1596 unsigned long iobase = dev->base_addr;
1597 u8 cmr = inb(EWRK3_CMR);
1598 /* DE203 has BNC only and link status does not apply */
1599 /* On DE204 this is always valid since TP is the only port. */
1600 /* On DE205 this reflects TP status even if BNC or AUI is selected. */
1601 return !(cmr & CMR_LINK);
1602}
1603
1604static int ewrk3_phys_id(struct net_device *dev, u32 data)
1605{
1606 struct ewrk3_private *lp = netdev_priv(dev);
1607 unsigned long iobase = dev->base_addr;
1608 unsigned long flags;
1609 u8 cr;
1610 int count;
1611
1612 /* Toggle LED 4x per second */
1613 count = data << 2;
1614
1615 spin_lock_irqsave(&lp->hw_lock, flags);
1616
1617 /* Bail if a PHYS_ID is already in progress */
1618 if (lp->led_mask == 0) {
1619 spin_unlock_irqrestore(&lp->hw_lock, flags);
1620 return -EBUSY;
1621 }
1622
1623 /* Prevent ISR from twiddling the LED */
1624 lp->led_mask = 0;
1625
1626 while (count--) {
1627 /* Toggle the LED */
1628 cr = inb(EWRK3_CR);
1629 outb(cr ^ CR_LED, EWRK3_CR);
1630
1631 /* Wait a little while */
1632 spin_unlock_irqrestore(&lp->hw_lock, flags);
1633 msleep(250);
1634 spin_lock_irqsave(&lp->hw_lock, flags);
1635
1636 /* Exit if we got a signal */
1637 if (signal_pending(current))
1638 break;
1639 }
1640
1641 lp->led_mask = CR_LED;
1642 cr = inb(EWRK3_CR);
1643 outb(cr & ~CR_LED, EWRK3_CR);
1644 spin_unlock_irqrestore(&lp->hw_lock, flags);
1645 return signal_pending(current) ? -ERESTARTSYS : 0;
1646}
1647
Jeff Garzik7282d492006-09-13 14:30:00 -04001648static const struct ethtool_ops ethtool_ops_203 = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001649 .get_drvinfo = ewrk3_get_drvinfo,
1650 .get_settings = ewrk3_get_settings,
1651 .set_settings = ewrk3_set_settings,
1652 .phys_id = ewrk3_phys_id,
1653};
1654
Jeff Garzik7282d492006-09-13 14:30:00 -04001655static const struct ethtool_ops ethtool_ops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001656 .get_drvinfo = ewrk3_get_drvinfo,
1657 .get_settings = ewrk3_get_settings,
1658 .set_settings = ewrk3_set_settings,
1659 .get_link = ewrk3_get_link,
1660 .phys_id = ewrk3_phys_id,
1661};
1662
1663/*
1664 ** Perform IOCTL call functions here. Some are privileged operations and the
1665 ** effective uid is checked in those cases.
1666 */
1667static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
1668{
1669 struct ewrk3_private *lp = netdev_priv(dev);
1670 struct ewrk3_ioctl *ioc = (struct ewrk3_ioctl *) &rq->ifr_ifru;
1671 u_long iobase = dev->base_addr;
1672 int i, j, status = 0;
1673 u_char csr;
1674 unsigned long flags;
1675 union ewrk3_addr {
1676 u_char addr[HASH_TABLE_LEN * ETH_ALEN];
1677 u_short val[(HASH_TABLE_LEN * ETH_ALEN) >> 1];
1678 };
Jeff Garzik6aa20a22006-09-13 13:24:59 -04001679
Linus Torvalds1da177e2005-04-16 15:20:36 -07001680 union ewrk3_addr *tmp;
1681
1682 /* All we handle are private IOCTLs */
1683 if (cmd != EWRK3IOCTL)
1684 return -EOPNOTSUPP;
1685
1686 tmp = kmalloc(sizeof(union ewrk3_addr), GFP_KERNEL);
1687 if(tmp==NULL)
1688 return -ENOMEM;
1689
1690 switch (ioc->cmd) {
1691 case EWRK3_GET_HWADDR: /* Get the hardware address */
1692 for (i = 0; i < ETH_ALEN; i++) {
1693 tmp->addr[i] = dev->dev_addr[i];
1694 }
1695 ioc->len = ETH_ALEN;
1696 if (copy_to_user(ioc->data, tmp->addr, ioc->len))
1697 status = -EFAULT;
1698 break;
Jeff Garzik6aa20a22006-09-13 13:24:59 -04001699
Linus Torvalds1da177e2005-04-16 15:20:36 -07001700 case EWRK3_SET_HWADDR: /* Set the hardware address */
1701 if (capable(CAP_NET_ADMIN)) {
1702 spin_lock_irqsave(&lp->hw_lock, flags);
1703 csr = inb(EWRK3_CSR);
1704 csr |= (CSR_TXD | CSR_RXD);
1705 outb(csr, EWRK3_CSR); /* Disable the TX and RX */
1706 spin_unlock_irqrestore(&lp->hw_lock, flags);
1707
1708 if (copy_from_user(tmp->addr, ioc->data, ETH_ALEN)) {
1709 status = -EFAULT;
1710 break;
1711 }
1712 spin_lock_irqsave(&lp->hw_lock, flags);
1713 for (i = 0; i < ETH_ALEN; i++) {
1714 dev->dev_addr[i] = tmp->addr[i];
1715 outb(tmp->addr[i], EWRK3_PAR0 + i);
1716 }
1717
1718 csr = inb(EWRK3_CSR);
1719 csr &= ~(CSR_TXD | CSR_RXD); /* Enable the TX and RX */
1720 outb(csr, EWRK3_CSR);
1721 spin_unlock_irqrestore(&lp->hw_lock, flags);
1722 } else {
1723 status = -EPERM;
1724 }
1725
1726 break;
1727 case EWRK3_SET_PROM: /* Set Promiscuous Mode */
1728 if (capable(CAP_NET_ADMIN)) {
1729 spin_lock_irqsave(&lp->hw_lock, flags);
1730 csr = inb(EWRK3_CSR);
1731 csr |= CSR_PME;
1732 csr &= ~CSR_MCE;
1733 outb(csr, EWRK3_CSR);
1734 spin_unlock_irqrestore(&lp->hw_lock, flags);
1735 } else {
1736 status = -EPERM;
1737 }
1738
1739 break;
1740 case EWRK3_CLR_PROM: /* Clear Promiscuous Mode */
1741 if (capable(CAP_NET_ADMIN)) {
1742 spin_lock_irqsave(&lp->hw_lock, flags);
1743 csr = inb(EWRK3_CSR);
1744 csr &= ~CSR_PME;
1745 outb(csr, EWRK3_CSR);
1746 spin_unlock_irqrestore(&lp->hw_lock, flags);
1747 } else {
1748 status = -EPERM;
1749 }
1750
1751 break;
1752 case EWRK3_GET_MCA: /* Get the multicast address table */
1753 spin_lock_irqsave(&lp->hw_lock, flags);
1754 if (lp->shmem_length == IO_ONLY) {
1755 outb(0, EWRK3_IOPR);
1756 outw(PAGE0_HTE, EWRK3_PIR1);
1757 for (i = 0; i < (HASH_TABLE_LEN >> 3); i++) {
1758 tmp->addr[i] = inb(EWRK3_DATA);
1759 }
1760 } else {
1761 outb(0, EWRK3_MPR);
1762 memcpy_fromio(tmp->addr, lp->shmem + PAGE0_HTE, (HASH_TABLE_LEN >> 3));
1763 }
1764 spin_unlock_irqrestore(&lp->hw_lock, flags);
1765
1766 ioc->len = (HASH_TABLE_LEN >> 3);
1767 if (copy_to_user(ioc->data, tmp->addr, ioc->len))
1768 status = -EFAULT;
1769
1770 break;
1771 case EWRK3_SET_MCA: /* Set a multicast address */
1772 if (capable(CAP_NET_ADMIN)) {
1773 if (ioc->len > 1024)
1774 {
1775 status = -EINVAL;
1776 break;
1777 }
1778 if (copy_from_user(tmp->addr, ioc->data, ETH_ALEN * ioc->len)) {
1779 status = -EFAULT;
1780 break;
1781 }
1782 set_multicast_list(dev);
1783 } else {
1784 status = -EPERM;
1785 }
1786
1787 break;
1788 case EWRK3_CLR_MCA: /* Clear all multicast addresses */
1789 if (capable(CAP_NET_ADMIN)) {
1790 set_multicast_list(dev);
1791 } else {
1792 status = -EPERM;
1793 }
1794
1795 break;
1796 case EWRK3_MCA_EN: /* Enable multicast addressing */
1797 if (capable(CAP_NET_ADMIN)) {
1798 spin_lock_irqsave(&lp->hw_lock, flags);
1799 csr = inb(EWRK3_CSR);
1800 csr |= CSR_MCE;
1801 csr &= ~CSR_PME;
1802 outb(csr, EWRK3_CSR);
1803 spin_unlock_irqrestore(&lp->hw_lock, flags);
1804 } else {
1805 status = -EPERM;
1806 }
1807
1808 break;
1809 case EWRK3_GET_STATS: { /* Get the driver statistics */
1810 struct ewrk3_stats *tmp_stats =
1811 kmalloc(sizeof(lp->pktStats), GFP_KERNEL);
1812 if (!tmp_stats) {
1813 status = -ENOMEM;
1814 break;
1815 }
1816
1817 spin_lock_irqsave(&lp->hw_lock, flags);
1818 memcpy(tmp_stats, &lp->pktStats, sizeof(lp->pktStats));
1819 spin_unlock_irqrestore(&lp->hw_lock, flags);
1820
1821 ioc->len = sizeof(lp->pktStats);
1822 if (copy_to_user(ioc->data, tmp_stats, sizeof(lp->pktStats)))
1823 status = -EFAULT;
1824 kfree(tmp_stats);
1825 break;
1826 }
1827 case EWRK3_CLR_STATS: /* Zero out the driver statistics */
1828 if (capable(CAP_NET_ADMIN)) {
1829 spin_lock_irqsave(&lp->hw_lock, flags);
1830 memset(&lp->pktStats, 0, sizeof(lp->pktStats));
1831 spin_unlock_irqrestore(&lp->hw_lock,flags);
1832 } else {
1833 status = -EPERM;
1834 }
1835
1836 break;
1837 case EWRK3_GET_CSR: /* Get the CSR Register contents */
1838 tmp->addr[0] = inb(EWRK3_CSR);
1839 ioc->len = 1;
1840 if (copy_to_user(ioc->data, tmp->addr, ioc->len))
1841 status = -EFAULT;
1842 break;
1843 case EWRK3_SET_CSR: /* Set the CSR Register contents */
1844 if (capable(CAP_NET_ADMIN)) {
1845 if (copy_from_user(tmp->addr, ioc->data, 1)) {
1846 status = -EFAULT;
1847 break;
1848 }
1849 outb(tmp->addr[0], EWRK3_CSR);
1850 } else {
1851 status = -EPERM;
1852 }
1853
1854 break;
1855 case EWRK3_GET_EEPROM: /* Get the EEPROM contents */
1856 if (capable(CAP_NET_ADMIN)) {
1857 for (i = 0; i < (EEPROM_MAX >> 1); i++) {
1858 tmp->val[i] = (short) Read_EEPROM(iobase, i);
1859 }
1860 i = EEPROM_MAX;
1861 tmp->addr[i++] = inb(EWRK3_CMR); /* Config/Management Reg. */
1862 for (j = 0; j < ETH_ALEN; j++) {
1863 tmp->addr[i++] = inb(EWRK3_PAR0 + j);
1864 }
1865 ioc->len = EEPROM_MAX + 1 + ETH_ALEN;
1866 if (copy_to_user(ioc->data, tmp->addr, ioc->len))
1867 status = -EFAULT;
1868 } else {
1869 status = -EPERM;
1870 }
1871
1872 break;
1873 case EWRK3_SET_EEPROM: /* Set the EEPROM contents */
1874 if (capable(CAP_NET_ADMIN)) {
1875 if (copy_from_user(tmp->addr, ioc->data, EEPROM_MAX)) {
1876 status = -EFAULT;
1877 break;
1878 }
1879 for (i = 0; i < (EEPROM_MAX >> 1); i++) {
1880 Write_EEPROM(tmp->val[i], iobase, i);
1881 }
1882 } else {
1883 status = -EPERM;
1884 }
1885
1886 break;
1887 case EWRK3_GET_CMR: /* Get the CMR Register contents */
1888 tmp->addr[0] = inb(EWRK3_CMR);
1889 ioc->len = 1;
1890 if (copy_to_user(ioc->data, tmp->addr, ioc->len))
1891 status = -EFAULT;
1892 break;
1893 case EWRK3_SET_TX_CUT_THRU: /* Set TX cut through mode */
1894 if (capable(CAP_NET_ADMIN)) {
1895 lp->txc = 1;
1896 } else {
1897 status = -EPERM;
1898 }
1899
1900 break;
1901 case EWRK3_CLR_TX_CUT_THRU: /* Clear TX cut through mode */
1902 if (capable(CAP_NET_ADMIN)) {
1903 lp->txc = 0;
1904 } else {
1905 status = -EPERM;
1906 }
1907
1908 break;
1909 default:
1910 status = -EOPNOTSUPP;
1911 }
1912 kfree(tmp);
1913 return status;
1914}
1915
1916#ifdef MODULE
1917static struct net_device *ewrk3_devs[MAX_NUM_EWRK3S];
1918static int ndevs;
1919static int io[MAX_NUM_EWRK3S+1] = { 0x300, 0, };
1920
1921/* '21' below should really be 'MAX_NUM_EWRK3S' */
1922module_param_array(io, int, NULL, 0);
1923module_param_array(irq, int, NULL, 0);
1924MODULE_PARM_DESC(io, "EtherWORKS 3 I/O base address(es)");
1925MODULE_PARM_DESC(irq, "EtherWORKS 3 IRQ number(s)");
1926
1927static __exit void ewrk3_exit_module(void)
1928{
1929 int i;
1930
1931 for( i=0; i<ndevs; i++ ) {
1932 struct net_device *dev = ewrk3_devs[i];
1933 struct ewrk3_private *lp = netdev_priv(dev);
1934 ewrk3_devs[i] = NULL;
1935 unregister_netdev(dev);
1936 release_region(dev->base_addr, EWRK3_TOTAL_SIZE);
1937 iounmap(lp->shmem);
1938 free_netdev(dev);
1939 }
1940}
1941
1942static __init int ewrk3_init_module(void)
1943{
1944 int i=0;
1945
1946 while( io[i] && irq[i] ) {
1947 struct net_device *dev
1948 = alloc_etherdev(sizeof(struct ewrk3_private));
1949
1950 if (!dev)
1951 break;
1952
1953 if (ewrk3_probe1(dev, io[i], irq[i]) != 0) {
1954 free_netdev(dev);
1955 break;
1956 }
1957
1958 ewrk3_devs[ndevs++] = dev;
1959 i++;
1960 }
1961
1962 return ndevs ? 0 : -EIO;
1963}
1964
1965
1966/* Hack for breakage in new module stuff */
1967module_exit(ewrk3_exit_module);
1968module_init(ewrk3_init_module);
1969#endif /* MODULE */
1970MODULE_LICENSE("GPL");
1971
Jeff Garzik6aa20a22006-09-13 13:24:59 -04001972
Linus Torvalds1da177e2005-04-16 15:20:36 -07001973
1974/*
1975 * Local variables:
1976 * compile-command: "gcc -D__KERNEL__ -I/linux/include -Wall -Wstrict-prototypes -fomit-frame-pointer -fno-strength-reduce -malign-loops=2 -malign-jumps=2 -malign-functions=2 -O2 -m486 -c ewrk3.c"
1977 *
1978 * compile-command: "gcc -D__KERNEL__ -DMODULE -I/linux/include -Wall -Wstrict-prototypes -fomit-frame-pointer -fno-strength-reduce -malign-loops=2 -malign-jumps=2 -malign-functions=2 -O2 -m486 -c ewrk3.c"
1979 * End:
1980 */