xref: /openbmc/linux/drivers/net/ethernet/smsc/epic100.c (revision 06d5d6b7f9948a89543e1160ef852d57892c750d)
1 /* epic100.c: A SMC 83c170 EPIC/100 Fast Ethernet driver for Linux. */
2 /*
3 	Written/copyright 1997-2001 by Donald Becker.
4 
5 	This software may be used and distributed according to the terms of
6 	the GNU General Public License (GPL), incorporated herein by reference.
7 	Drivers based on or derived from this code fall under the GPL and must
8 	retain the authorship, copyright and license notice.  This file is not
9 	a complete program and may only be used when the entire operating
10 	system is licensed under the GPL.
11 
12 	This driver is for the SMC83c170/175 "EPIC" series, as used on the
13 	SMC EtherPower II 9432 PCI adapter, and several CardBus cards.
14 
15 	The author may be reached as becker@scyld.com, or C/O
16 	Scyld Computing Corporation
17 	410 Severn Ave., Suite 210
18 	Annapolis MD 21403
19 
20 	Information and updates available at
21 	http://www.scyld.com/network/epic100.html
22 	[this link no longer provides anything useful -jgarzik]
23 
24 	---------------------------------------------------------------------
25 
26 */
27 
28 #define DRV_NAME        "epic100"
29 #define DRV_VERSION     "2.1"
30 #define DRV_RELDATE     "Sept 11, 2006"
31 
32 /* The user-configurable values.
33    These may be modified when a driver module is loaded.*/
34 
35 static int debug = 1;			/* 1 normal messages, 0 quiet .. 7 verbose. */
36 
37 /* Used to pass the full-duplex flag, etc. */
38 #define MAX_UNITS 8		/* More are supported, limit only on options */
39 static int options[MAX_UNITS] = {-1, -1, -1, -1, -1, -1, -1, -1};
40 static int full_duplex[MAX_UNITS] = {-1, -1, -1, -1, -1, -1, -1, -1};
41 
42 /* Set the copy breakpoint for the copy-only-tiny-frames scheme.
43    Setting to > 1518 effectively disables this feature. */
44 static int rx_copybreak;
45 
46 /* Operational parameters that are set at compile time. */
47 
48 /* Keep the ring sizes a power of two for operational efficiency.
49    The compiler will convert <unsigned>'%'<2^N> into a bit mask.
50    Making the Tx ring too large decreases the effectiveness of channel
51    bonding and packet priority.
52    There are no ill effects from too-large receive rings. */
53 #define TX_RING_SIZE	256
54 #define TX_QUEUE_LEN	240		/* Limit ring entries actually used.  */
55 #define RX_RING_SIZE	256
56 #define TX_TOTAL_SIZE	TX_RING_SIZE*sizeof(struct epic_tx_desc)
57 #define RX_TOTAL_SIZE	RX_RING_SIZE*sizeof(struct epic_rx_desc)
58 
59 /* Operational parameters that usually are not changed. */
60 /* Time in jiffies before concluding the transmitter is hung. */
61 #define TX_TIMEOUT  (2*HZ)
62 
63 #define PKT_BUF_SZ		1536			/* Size of each temporary Rx buffer.*/
64 
65 /* Bytes transferred to chip before transmission starts. */
66 /* Initial threshold, increased on underflow, rounded down to 4 byte units. */
67 #define TX_FIFO_THRESH 256
68 #define RX_FIFO_THRESH 1		/* 0-3, 0==32, 64,96, or 3==128 bytes  */
69 
70 #include <linux/module.h>
71 #include <linux/kernel.h>
72 #include <linux/string.h>
73 #include <linux/timer.h>
74 #include <linux/errno.h>
75 #include <linux/ioport.h>
76 #include <linux/interrupt.h>
77 #include <linux/pci.h>
78 #include <linux/delay.h>
79 #include <linux/netdevice.h>
80 #include <linux/etherdevice.h>
81 #include <linux/skbuff.h>
82 #include <linux/init.h>
83 #include <linux/spinlock.h>
84 #include <linux/ethtool.h>
85 #include <linux/mii.h>
86 #include <linux/crc32.h>
87 #include <linux/bitops.h>
88 #include <asm/io.h>
89 #include <linux/uaccess.h>
90 #include <asm/byteorder.h>
91 
92 /* These identify the driver base version and may not be removed. */
93 static char version[] =
94 DRV_NAME ".c:v1.11 1/7/2001 Written by Donald Becker <becker@scyld.com>";
95 static char version2[] =
96 "  (unofficial 2.4.x kernel port, version " DRV_VERSION ", " DRV_RELDATE ")";
97 
98 MODULE_AUTHOR("Donald Becker <becker@scyld.com>");
99 MODULE_DESCRIPTION("SMC 83c170 EPIC series Ethernet driver");
100 MODULE_LICENSE("GPL");
101 
102 module_param(debug, int, 0);
103 module_param(rx_copybreak, int, 0);
104 module_param_array(options, int, NULL, 0);
105 module_param_array(full_duplex, int, NULL, 0);
106 MODULE_PARM_DESC(debug, "EPIC/100 debug level (0-5)");
107 MODULE_PARM_DESC(options, "EPIC/100: Bits 0-3: media type, bit 4: full duplex");
108 MODULE_PARM_DESC(rx_copybreak, "EPIC/100 copy breakpoint for copy-only-tiny-frames");
109 MODULE_PARM_DESC(full_duplex, "EPIC/100 full duplex setting(s) (1)");
110 
111 /*
112 				Theory of Operation
113 
114 I. Board Compatibility
115 
116 This device driver is designed for the SMC "EPIC/100", the SMC
117 single-chip Ethernet controllers for PCI.  This chip is used on
118 the SMC EtherPower II boards.
119 
120 II. Board-specific settings
121 
122 PCI bus devices are configured by the system at boot time, so no jumpers
123 need to be set on the board.  The system BIOS will assign the
124 PCI INTA signal to a (preferably otherwise unused) system IRQ line.
125 Note: Kernel versions earlier than 1.3.73 do not support shared PCI
126 interrupt lines.
127 
128 III. Driver operation
129 
130 IIIa. Ring buffers
131 
132 IVb. References
133 
134 http://www.smsc.com/media/Downloads_Public/discontinued/83c171.pdf
135 http://www.smsc.com/media/Downloads_Public/discontinued/83c175.pdf
136 http://scyld.com/expert/NWay.html
137 http://www.national.com/pf/DP/DP83840A.html
138 
139 IVc. Errata
140 
141 */
142 
143 
144 enum chip_capability_flags { MII_PWRDWN=1, TYPE2_INTR=2, NO_MII=4 };
145 
146 #define EPIC_TOTAL_SIZE 0x100
147 #define USE_IO_OPS 1
148 
149 #ifdef USE_IO_OPS
150 #define EPIC_BAR	0
151 #else
152 #define EPIC_BAR	1
153 #endif
154 
155 typedef enum {
156 	SMSC_83C170_0,
157 	SMSC_83C170,
158 	SMSC_83C175,
159 } chip_t;
160 
161 
162 struct epic_chip_info {
163 	const char *name;
164         int drv_flags;                          /* Driver use, intended as capability flags. */
165 };
166 
167 
168 /* indexed by chip_t */
169 static const struct epic_chip_info pci_id_tbl[] = {
170 	{ "SMSC EPIC/100 83c170",	TYPE2_INTR | NO_MII | MII_PWRDWN },
171 	{ "SMSC EPIC/100 83c170",	TYPE2_INTR },
172 	{ "SMSC EPIC/C 83c175",		TYPE2_INTR | MII_PWRDWN },
173 };
174 
175 
176 static const struct pci_device_id epic_pci_tbl[] = {
177 	{ 0x10B8, 0x0005, 0x1092, 0x0AB4, 0, 0, SMSC_83C170_0 },
178 	{ 0x10B8, 0x0005, PCI_ANY_ID, PCI_ANY_ID, 0, 0, SMSC_83C170 },
179 	{ 0x10B8, 0x0006, PCI_ANY_ID, PCI_ANY_ID,
180 	  PCI_CLASS_NETWORK_ETHERNET << 8, 0xffff00, SMSC_83C175 },
181 	{ 0,}
182 };
183 MODULE_DEVICE_TABLE (pci, epic_pci_tbl);
184 
185 #define ew16(reg, val)	iowrite16(val, ioaddr + (reg))
186 #define ew32(reg, val)	iowrite32(val, ioaddr + (reg))
187 #define er8(reg)	ioread8(ioaddr + (reg))
188 #define er16(reg)	ioread16(ioaddr + (reg))
189 #define er32(reg)	ioread32(ioaddr + (reg))
190 
191 /* Offsets to registers, using the (ugh) SMC names. */
192 enum epic_registers {
193   COMMAND=0, INTSTAT=4, INTMASK=8, GENCTL=0x0C, NVCTL=0x10, EECTL=0x14,
194   PCIBurstCnt=0x18,
195   TEST1=0x1C, CRCCNT=0x20, ALICNT=0x24, MPCNT=0x28,	/* Rx error counters. */
196   MIICtrl=0x30, MIIData=0x34, MIICfg=0x38,
197   LAN0=64,						/* MAC address. */
198   MC0=80,						/* Multicast filter table. */
199   RxCtrl=96, TxCtrl=112, TxSTAT=0x74,
200   PRxCDAR=0x84, RxSTAT=0xA4, EarlyRx=0xB0, PTxCDAR=0xC4, TxThresh=0xDC,
201 };
202 
203 /* Interrupt register bits, using my own meaningful names. */
204 enum IntrStatus {
205 	TxIdle=0x40000, RxIdle=0x20000, IntrSummary=0x010000,
206 	PCIBusErr170=0x7000, PCIBusErr175=0x1000, PhyEvent175=0x8000,
207 	RxStarted=0x0800, RxEarlyWarn=0x0400, CntFull=0x0200, TxUnderrun=0x0100,
208 	TxEmpty=0x0080, TxDone=0x0020, RxError=0x0010,
209 	RxOverflow=0x0008, RxFull=0x0004, RxHeader=0x0002, RxDone=0x0001,
210 };
211 enum CommandBits {
212 	StopRx=1, StartRx=2, TxQueued=4, RxQueued=8,
213 	StopTxDMA=0x20, StopRxDMA=0x40, RestartTx=0x80,
214 };
215 
216 #define EpicRemoved	0xffffffff	/* Chip failed or removed (CardBus) */
217 
218 #define EpicNapiEvent	(TxEmpty | TxDone | \
219 			 RxDone | RxStarted | RxEarlyWarn | RxOverflow | RxFull)
220 #define EpicNormalEvent	(0x0000ffff & ~EpicNapiEvent)
221 
222 static const u16 media2miictl[16] = {
223 	0, 0x0C00, 0x0C00, 0x2000,  0x0100, 0x2100, 0, 0,
224 	0, 0, 0, 0,  0, 0, 0, 0 };
225 
226 /*
227  * The EPIC100 Rx and Tx buffer descriptors.  Note that these
228  * really ARE host-endian; it's not a misannotation.  We tell
229  * the card to byteswap them internally on big-endian hosts -
230  * look for #ifdef __BIG_ENDIAN in epic_open().
231  */
232 
233 struct epic_tx_desc {
234 	u32 txstatus;
235 	u32 bufaddr;
236 	u32 buflength;
237 	u32 next;
238 };
239 
240 struct epic_rx_desc {
241 	u32 rxstatus;
242 	u32 bufaddr;
243 	u32 buflength;
244 	u32 next;
245 };
246 
247 enum desc_status_bits {
248 	DescOwn=0x8000,
249 };
250 
251 #define PRIV_ALIGN	15 	/* Required alignment mask */
252 struct epic_private {
253 	struct epic_rx_desc *rx_ring;
254 	struct epic_tx_desc *tx_ring;
255 	/* The saved address of a sent-in-place packet/buffer, for skfree(). */
256 	struct sk_buff* tx_skbuff[TX_RING_SIZE];
257 	/* The addresses of receive-in-place skbuffs. */
258 	struct sk_buff* rx_skbuff[RX_RING_SIZE];
259 
260 	dma_addr_t tx_ring_dma;
261 	dma_addr_t rx_ring_dma;
262 
263 	/* Ring pointers. */
264 	spinlock_t lock;				/* Group with Tx control cache line. */
265 	spinlock_t napi_lock;
266 	struct napi_struct napi;
267 	unsigned int cur_tx, dirty_tx;
268 
269 	unsigned int cur_rx, dirty_rx;
270 	u32 irq_mask;
271 	unsigned int rx_buf_sz;				/* Based on MTU+slack. */
272 
273 	void __iomem *ioaddr;
274 	struct pci_dev *pci_dev;			/* PCI bus location. */
275 	int chip_id, chip_flags;
276 
277 	struct timer_list timer;			/* Media selection timer. */
278 	int tx_threshold;
279 	unsigned char mc_filter[8];
280 	signed char phys[4];				/* MII device addresses. */
281 	u16 advertising;					/* NWay media advertisement */
282 	int mii_phy_cnt;
283 	struct mii_if_info mii;
284 	unsigned int tx_full:1;				/* The Tx queue is full. */
285 	unsigned int default_port:4;		/* Last dev->if_port value. */
286 };
287 
288 static int epic_open(struct net_device *dev);
289 static int read_eeprom(struct epic_private *, int);
290 static int mdio_read(struct net_device *dev, int phy_id, int location);
291 static void mdio_write(struct net_device *dev, int phy_id, int loc, int val);
292 static void epic_restart(struct net_device *dev);
293 static void epic_timer(struct timer_list *t);
294 static void epic_tx_timeout(struct net_device *dev);
295 static void epic_init_ring(struct net_device *dev);
296 static netdev_tx_t epic_start_xmit(struct sk_buff *skb,
297 				   struct net_device *dev);
298 static int epic_rx(struct net_device *dev, int budget);
299 static int epic_poll(struct napi_struct *napi, int budget);
300 static irqreturn_t epic_interrupt(int irq, void *dev_instance);
301 static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
302 static const struct ethtool_ops netdev_ethtool_ops;
303 static int epic_close(struct net_device *dev);
304 static struct net_device_stats *epic_get_stats(struct net_device *dev);
305 static void set_rx_mode(struct net_device *dev);
306 
307 static const struct net_device_ops epic_netdev_ops = {
308 	.ndo_open		= epic_open,
309 	.ndo_stop		= epic_close,
310 	.ndo_start_xmit		= epic_start_xmit,
311 	.ndo_tx_timeout 	= epic_tx_timeout,
312 	.ndo_get_stats		= epic_get_stats,
313 	.ndo_set_rx_mode	= set_rx_mode,
314 	.ndo_do_ioctl 		= netdev_ioctl,
315 	.ndo_set_mac_address 	= eth_mac_addr,
316 	.ndo_validate_addr	= eth_validate_addr,
317 };
318 
319 static int epic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
320 {
321 	static int card_idx = -1;
322 	void __iomem *ioaddr;
323 	int chip_idx = (int) ent->driver_data;
324 	struct net_device *dev;
325 	struct epic_private *ep;
326 	int i, ret, option = 0, duplex = 0;
327 	void *ring_space;
328 	dma_addr_t ring_dma;
329 
330 /* when built into the kernel, we only print version if device is found */
331 #ifndef MODULE
332 	pr_info_once("%s%s\n", version, version2);
333 #endif
334 
335 	card_idx++;
336 
337 	ret = pci_enable_device(pdev);
338 	if (ret)
339 		goto out;
340 
341 	if (pci_resource_len(pdev, 0) < EPIC_TOTAL_SIZE) {
342 		dev_err(&pdev->dev, "no PCI region space\n");
343 		ret = -ENODEV;
344 		goto err_out_disable;
345 	}
346 
347 	pci_set_master(pdev);
348 
349 	ret = pci_request_regions(pdev, DRV_NAME);
350 	if (ret < 0)
351 		goto err_out_disable;
352 
353 	ret = -ENOMEM;
354 
355 	dev = alloc_etherdev(sizeof (*ep));
356 	if (!dev)
357 		goto err_out_free_res;
358 
359 	SET_NETDEV_DEV(dev, &pdev->dev);
360 
361 	ioaddr = pci_iomap(pdev, EPIC_BAR, 0);
362 	if (!ioaddr) {
363 		dev_err(&pdev->dev, "ioremap failed\n");
364 		goto err_out_free_netdev;
365 	}
366 
367 	pci_set_drvdata(pdev, dev);
368 	ep = netdev_priv(dev);
369 	ep->ioaddr = ioaddr;
370 	ep->mii.dev = dev;
371 	ep->mii.mdio_read = mdio_read;
372 	ep->mii.mdio_write = mdio_write;
373 	ep->mii.phy_id_mask = 0x1f;
374 	ep->mii.reg_num_mask = 0x1f;
375 
376 	ring_space = pci_alloc_consistent(pdev, TX_TOTAL_SIZE, &ring_dma);
377 	if (!ring_space)
378 		goto err_out_iounmap;
379 	ep->tx_ring = ring_space;
380 	ep->tx_ring_dma = ring_dma;
381 
382 	ring_space = pci_alloc_consistent(pdev, RX_TOTAL_SIZE, &ring_dma);
383 	if (!ring_space)
384 		goto err_out_unmap_tx;
385 	ep->rx_ring = ring_space;
386 	ep->rx_ring_dma = ring_dma;
387 
388 	if (dev->mem_start) {
389 		option = dev->mem_start;
390 		duplex = (dev->mem_start & 16) ? 1 : 0;
391 	} else if (card_idx >= 0  &&  card_idx < MAX_UNITS) {
392 		if (options[card_idx] >= 0)
393 			option = options[card_idx];
394 		if (full_duplex[card_idx] >= 0)
395 			duplex = full_duplex[card_idx];
396 	}
397 
398 	spin_lock_init(&ep->lock);
399 	spin_lock_init(&ep->napi_lock);
400 
401 	/* Bring the chip out of low-power mode. */
402 	ew32(GENCTL, 0x4200);
403 	/* Magic?!  If we don't set this bit the MII interface won't work. */
404 	/* This magic is documented in SMSC app note 7.15 */
405 	for (i = 16; i > 0; i--)
406 		ew32(TEST1, 0x0008);
407 
408 	/* Turn on the MII transceiver. */
409 	ew32(MIICfg, 0x12);
410 	if (chip_idx == 1)
411 		ew32(NVCTL, (er32(NVCTL) & ~0x003c) | 0x4800);
412 	ew32(GENCTL, 0x0200);
413 
414 	/* Note: the '175 does not have a serial EEPROM. */
415 	for (i = 0; i < 3; i++)
416 		((__le16 *)dev->dev_addr)[i] = cpu_to_le16(er16(LAN0 + i*4));
417 
418 	if (debug > 2) {
419 		dev_dbg(&pdev->dev, "EEPROM contents:\n");
420 		for (i = 0; i < 64; i++)
421 			pr_cont(" %4.4x%s", read_eeprom(ep, i),
422 				   i % 16 == 15 ? "\n" : "");
423 	}
424 
425 	ep->pci_dev = pdev;
426 	ep->chip_id = chip_idx;
427 	ep->chip_flags = pci_id_tbl[chip_idx].drv_flags;
428 	ep->irq_mask =
429 		(ep->chip_flags & TYPE2_INTR ?  PCIBusErr175 : PCIBusErr170)
430 		 | CntFull | TxUnderrun | EpicNapiEvent;
431 
432 	/* Find the connected MII xcvrs.
433 	   Doing this in open() would allow detecting external xcvrs later, but
434 	   takes much time and no cards have external MII. */
435 	{
436 		int phy, phy_idx = 0;
437 		for (phy = 1; phy < 32 && phy_idx < sizeof(ep->phys); phy++) {
438 			int mii_status = mdio_read(dev, phy, MII_BMSR);
439 			if (mii_status != 0xffff  &&  mii_status != 0x0000) {
440 				ep->phys[phy_idx++] = phy;
441 				dev_info(&pdev->dev,
442 					"MII transceiver #%d control "
443 					"%4.4x status %4.4x.\n",
444 					phy, mdio_read(dev, phy, 0), mii_status);
445 			}
446 		}
447 		ep->mii_phy_cnt = phy_idx;
448 		if (phy_idx != 0) {
449 			phy = ep->phys[0];
450 			ep->mii.advertising = mdio_read(dev, phy, MII_ADVERTISE);
451 			dev_info(&pdev->dev,
452 				"Autonegotiation advertising %4.4x link "
453 				   "partner %4.4x.\n",
454 				   ep->mii.advertising, mdio_read(dev, phy, 5));
455 		} else if ( ! (ep->chip_flags & NO_MII)) {
456 			dev_warn(&pdev->dev,
457 				"***WARNING***: No MII transceiver found!\n");
458 			/* Use the known PHY address of the EPII. */
459 			ep->phys[0] = 3;
460 		}
461 		ep->mii.phy_id = ep->phys[0];
462 	}
463 
464 	/* Turn off the MII xcvr (175 only!), leave the chip in low-power mode. */
465 	if (ep->chip_flags & MII_PWRDWN)
466 		ew32(NVCTL, er32(NVCTL) & ~0x483c);
467 	ew32(GENCTL, 0x0008);
468 
469 	/* The lower four bits are the media type. */
470 	if (duplex) {
471 		ep->mii.force_media = ep->mii.full_duplex = 1;
472 		dev_info(&pdev->dev, "Forced full duplex requested.\n");
473 	}
474 	dev->if_port = ep->default_port = option;
475 
476 	/* The Epic-specific entries in the device structure. */
477 	dev->netdev_ops = &epic_netdev_ops;
478 	dev->ethtool_ops = &netdev_ethtool_ops;
479 	dev->watchdog_timeo = TX_TIMEOUT;
480 	netif_napi_add(dev, &ep->napi, epic_poll, 64);
481 
482 	ret = register_netdev(dev);
483 	if (ret < 0)
484 		goto err_out_unmap_rx;
485 
486 	netdev_info(dev, "%s at %lx, IRQ %d, %pM\n",
487 		    pci_id_tbl[chip_idx].name,
488 		    (long)pci_resource_start(pdev, EPIC_BAR), pdev->irq,
489 		    dev->dev_addr);
490 
491 out:
492 	return ret;
493 
494 err_out_unmap_rx:
495 	pci_free_consistent(pdev, RX_TOTAL_SIZE, ep->rx_ring, ep->rx_ring_dma);
496 err_out_unmap_tx:
497 	pci_free_consistent(pdev, TX_TOTAL_SIZE, ep->tx_ring, ep->tx_ring_dma);
498 err_out_iounmap:
499 	pci_iounmap(pdev, ioaddr);
500 err_out_free_netdev:
501 	free_netdev(dev);
502 err_out_free_res:
503 	pci_release_regions(pdev);
504 err_out_disable:
505 	pci_disable_device(pdev);
506 	goto out;
507 }
508 
509 /* Serial EEPROM section. */
510 
511 /*  EEPROM_Ctrl bits. */
512 #define EE_SHIFT_CLK	0x04	/* EEPROM shift clock. */
513 #define EE_CS			0x02	/* EEPROM chip select. */
514 #define EE_DATA_WRITE	0x08	/* EEPROM chip data in. */
515 #define EE_WRITE_0		0x01
516 #define EE_WRITE_1		0x09
517 #define EE_DATA_READ	0x10	/* EEPROM chip data out. */
518 #define EE_ENB			(0x0001 | EE_CS)
519 
520 /* Delay between EEPROM clock transitions.
521    This serves to flush the operation to the PCI bus.
522  */
523 
524 #define eeprom_delay()	er32(EECTL)
525 
526 /* The EEPROM commands include the alway-set leading bit. */
527 #define EE_WRITE_CMD	(5 << 6)
528 #define EE_READ64_CMD	(6 << 6)
529 #define EE_READ256_CMD	(6 << 8)
530 #define EE_ERASE_CMD	(7 << 6)
531 
532 static void epic_disable_int(struct net_device *dev, struct epic_private *ep)
533 {
534 	void __iomem *ioaddr = ep->ioaddr;
535 
536 	ew32(INTMASK, 0x00000000);
537 }
538 
539 static inline void __epic_pci_commit(void __iomem *ioaddr)
540 {
541 #ifndef USE_IO_OPS
542 	er32(INTMASK);
543 #endif
544 }
545 
546 static inline void epic_napi_irq_off(struct net_device *dev,
547 				     struct epic_private *ep)
548 {
549 	void __iomem *ioaddr = ep->ioaddr;
550 
551 	ew32(INTMASK, ep->irq_mask & ~EpicNapiEvent);
552 	__epic_pci_commit(ioaddr);
553 }
554 
555 static inline void epic_napi_irq_on(struct net_device *dev,
556 				    struct epic_private *ep)
557 {
558 	void __iomem *ioaddr = ep->ioaddr;
559 
560 	/* No need to commit possible posted write */
561 	ew32(INTMASK, ep->irq_mask | EpicNapiEvent);
562 }
563 
564 static int read_eeprom(struct epic_private *ep, int location)
565 {
566 	void __iomem *ioaddr = ep->ioaddr;
567 	int i;
568 	int retval = 0;
569 	int read_cmd = location |
570 		(er32(EECTL) & 0x40 ? EE_READ64_CMD : EE_READ256_CMD);
571 
572 	ew32(EECTL, EE_ENB & ~EE_CS);
573 	ew32(EECTL, EE_ENB);
574 
575 	/* Shift the read command bits out. */
576 	for (i = 12; i >= 0; i--) {
577 		short dataval = (read_cmd & (1 << i)) ? EE_WRITE_1 : EE_WRITE_0;
578 		ew32(EECTL, EE_ENB | dataval);
579 		eeprom_delay();
580 		ew32(EECTL, EE_ENB | dataval | EE_SHIFT_CLK);
581 		eeprom_delay();
582 	}
583 	ew32(EECTL, EE_ENB);
584 
585 	for (i = 16; i > 0; i--) {
586 		ew32(EECTL, EE_ENB | EE_SHIFT_CLK);
587 		eeprom_delay();
588 		retval = (retval << 1) | ((er32(EECTL) & EE_DATA_READ) ? 1 : 0);
589 		ew32(EECTL, EE_ENB);
590 		eeprom_delay();
591 	}
592 
593 	/* Terminate the EEPROM access. */
594 	ew32(EECTL, EE_ENB & ~EE_CS);
595 	return retval;
596 }
597 
598 #define MII_READOP		1
599 #define MII_WRITEOP		2
600 static int mdio_read(struct net_device *dev, int phy_id, int location)
601 {
602 	struct epic_private *ep = netdev_priv(dev);
603 	void __iomem *ioaddr = ep->ioaddr;
604 	int read_cmd = (phy_id << 9) | (location << 4) | MII_READOP;
605 	int i;
606 
607 	ew32(MIICtrl, read_cmd);
608 	/* Typical operation takes 25 loops. */
609 	for (i = 400; i > 0; i--) {
610 		barrier();
611 		if ((er32(MIICtrl) & MII_READOP) == 0) {
612 			/* Work around read failure bug. */
613 			if (phy_id == 1 && location < 6 &&
614 			    er16(MIIData) == 0xffff) {
615 				ew32(MIICtrl, read_cmd);
616 				continue;
617 			}
618 			return er16(MIIData);
619 		}
620 	}
621 	return 0xffff;
622 }
623 
624 static void mdio_write(struct net_device *dev, int phy_id, int loc, int value)
625 {
626 	struct epic_private *ep = netdev_priv(dev);
627 	void __iomem *ioaddr = ep->ioaddr;
628 	int i;
629 
630 	ew16(MIIData, value);
631 	ew32(MIICtrl, (phy_id << 9) | (loc << 4) | MII_WRITEOP);
632 	for (i = 10000; i > 0; i--) {
633 		barrier();
634 		if ((er32(MIICtrl) & MII_WRITEOP) == 0)
635 			break;
636 	}
637 }
638 
639 
640 static int epic_open(struct net_device *dev)
641 {
642 	struct epic_private *ep = netdev_priv(dev);
643 	void __iomem *ioaddr = ep->ioaddr;
644 	const int irq = ep->pci_dev->irq;
645 	int rc, i;
646 
647 	/* Soft reset the chip. */
648 	ew32(GENCTL, 0x4001);
649 
650 	napi_enable(&ep->napi);
651 	rc = request_irq(irq, epic_interrupt, IRQF_SHARED, dev->name, dev);
652 	if (rc) {
653 		napi_disable(&ep->napi);
654 		return rc;
655 	}
656 
657 	epic_init_ring(dev);
658 
659 	ew32(GENCTL, 0x4000);
660 	/* This magic is documented in SMSC app note 7.15 */
661 	for (i = 16; i > 0; i--)
662 		ew32(TEST1, 0x0008);
663 
664 	/* Pull the chip out of low-power mode, enable interrupts, and set for
665 	   PCI read multiple.  The MIIcfg setting and strange write order are
666 	   required by the details of which bits are reset and the transceiver
667 	   wiring on the Ositech CardBus card.
668 	*/
669 #if 0
670 	ew32(MIICfg, dev->if_port == 1 ? 0x13 : 0x12);
671 #endif
672 	if (ep->chip_flags & MII_PWRDWN)
673 		ew32(NVCTL, (er32(NVCTL) & ~0x003c) | 0x4800);
674 
675 	/* Tell the chip to byteswap descriptors on big-endian hosts */
676 #ifdef __BIG_ENDIAN
677 	ew32(GENCTL, 0x4432 | (RX_FIFO_THRESH << 8));
678 	er32(GENCTL);
679 	ew32(GENCTL, 0x0432 | (RX_FIFO_THRESH << 8));
680 #else
681 	ew32(GENCTL, 0x4412 | (RX_FIFO_THRESH << 8));
682 	er32(GENCTL);
683 	ew32(GENCTL, 0x0412 | (RX_FIFO_THRESH << 8));
684 #endif
685 
686 	udelay(20); /* Looks like EPII needs that if you want reliable RX init. FIXME: pci posting bug? */
687 
688 	for (i = 0; i < 3; i++)
689 		ew32(LAN0 + i*4, le16_to_cpu(((__le16*)dev->dev_addr)[i]));
690 
691 	ep->tx_threshold = TX_FIFO_THRESH;
692 	ew32(TxThresh, ep->tx_threshold);
693 
694 	if (media2miictl[dev->if_port & 15]) {
695 		if (ep->mii_phy_cnt)
696 			mdio_write(dev, ep->phys[0], MII_BMCR, media2miictl[dev->if_port&15]);
697 		if (dev->if_port == 1) {
698 			if (debug > 1)
699 				netdev_info(dev, "Using the 10base2 transceiver, MII status %4.4x.\n",
700 					    mdio_read(dev, ep->phys[0], MII_BMSR));
701 		}
702 	} else {
703 		int mii_lpa = mdio_read(dev, ep->phys[0], MII_LPA);
704 		if (mii_lpa != 0xffff) {
705 			if ((mii_lpa & LPA_100FULL) || (mii_lpa & 0x01C0) == LPA_10FULL)
706 				ep->mii.full_duplex = 1;
707 			else if (! (mii_lpa & LPA_LPACK))
708 				mdio_write(dev, ep->phys[0], MII_BMCR, BMCR_ANENABLE|BMCR_ANRESTART);
709 			if (debug > 1)
710 				netdev_info(dev, "Setting %s-duplex based on MII xcvr %d register read of %4.4x.\n",
711 					    ep->mii.full_duplex ? "full"
712 								: "half",
713 					    ep->phys[0], mii_lpa);
714 		}
715 	}
716 
717 	ew32(TxCtrl, ep->mii.full_duplex ? 0x7f : 0x79);
718 	ew32(PRxCDAR, ep->rx_ring_dma);
719 	ew32(PTxCDAR, ep->tx_ring_dma);
720 
721 	/* Start the chip's Rx process. */
722 	set_rx_mode(dev);
723 	ew32(COMMAND, StartRx | RxQueued);
724 
725 	netif_start_queue(dev);
726 
727 	/* Enable interrupts by setting the interrupt mask. */
728 	ew32(INTMASK, RxError | RxHeader | EpicNapiEvent | CntFull |
729 	     ((ep->chip_flags & TYPE2_INTR) ? PCIBusErr175 : PCIBusErr170) |
730 	     TxUnderrun);
731 
732 	if (debug > 1) {
733 		netdev_dbg(dev, "epic_open() ioaddr %p IRQ %d status %4.4x %s-duplex.\n",
734 			   ioaddr, irq, er32(GENCTL),
735 			   ep->mii.full_duplex ? "full" : "half");
736 	}
737 
738 	/* Set the timer to switch to check for link beat and perhaps switch
739 	   to an alternate media type. */
740 	timer_setup(&ep->timer, epic_timer, 0);
741 	ep->timer.expires = jiffies + 3*HZ;
742 	add_timer(&ep->timer);
743 
744 	return rc;
745 }
746 
747 /* Reset the chip to recover from a PCI transaction error.
748    This may occur at interrupt time. */
749 static void epic_pause(struct net_device *dev)
750 {
751 	struct net_device_stats *stats = &dev->stats;
752 	struct epic_private *ep = netdev_priv(dev);
753 	void __iomem *ioaddr = ep->ioaddr;
754 
755 	netif_stop_queue (dev);
756 
757 	/* Disable interrupts by clearing the interrupt mask. */
758 	ew32(INTMASK, 0x00000000);
759 	/* Stop the chip's Tx and Rx DMA processes. */
760 	ew16(COMMAND, StopRx | StopTxDMA | StopRxDMA);
761 
762 	/* Update the error counts. */
763 	if (er16(COMMAND) != 0xffff) {
764 		stats->rx_missed_errors	+= er8(MPCNT);
765 		stats->rx_frame_errors	+= er8(ALICNT);
766 		stats->rx_crc_errors	+= er8(CRCCNT);
767 	}
768 
769 	/* Remove the packets on the Rx queue. */
770 	epic_rx(dev, RX_RING_SIZE);
771 }
772 
773 static void epic_restart(struct net_device *dev)
774 {
775 	struct epic_private *ep = netdev_priv(dev);
776 	void __iomem *ioaddr = ep->ioaddr;
777 	int i;
778 
779 	/* Soft reset the chip. */
780 	ew32(GENCTL, 0x4001);
781 
782 	netdev_dbg(dev, "Restarting the EPIC chip, Rx %d/%d Tx %d/%d.\n",
783 		   ep->cur_rx, ep->dirty_rx, ep->dirty_tx, ep->cur_tx);
784 	udelay(1);
785 
786 	/* This magic is documented in SMSC app note 7.15 */
787 	for (i = 16; i > 0; i--)
788 		ew32(TEST1, 0x0008);
789 
790 #ifdef __BIG_ENDIAN
791 	ew32(GENCTL, 0x0432 | (RX_FIFO_THRESH << 8));
792 #else
793 	ew32(GENCTL, 0x0412 | (RX_FIFO_THRESH << 8));
794 #endif
795 	ew32(MIICfg, dev->if_port == 1 ? 0x13 : 0x12);
796 	if (ep->chip_flags & MII_PWRDWN)
797 		ew32(NVCTL, (er32(NVCTL) & ~0x003c) | 0x4800);
798 
799 	for (i = 0; i < 3; i++)
800 		ew32(LAN0 + i*4, le16_to_cpu(((__le16*)dev->dev_addr)[i]));
801 
802 	ep->tx_threshold = TX_FIFO_THRESH;
803 	ew32(TxThresh, ep->tx_threshold);
804 	ew32(TxCtrl, ep->mii.full_duplex ? 0x7f : 0x79);
805 	ew32(PRxCDAR, ep->rx_ring_dma +
806 	     (ep->cur_rx % RX_RING_SIZE) * sizeof(struct epic_rx_desc));
807 	ew32(PTxCDAR, ep->tx_ring_dma +
808 	     (ep->dirty_tx % TX_RING_SIZE) * sizeof(struct epic_tx_desc));
809 
810 	/* Start the chip's Rx process. */
811 	set_rx_mode(dev);
812 	ew32(COMMAND, StartRx | RxQueued);
813 
814 	/* Enable interrupts by setting the interrupt mask. */
815 	ew32(INTMASK, RxError | RxHeader | EpicNapiEvent | CntFull |
816 	     ((ep->chip_flags & TYPE2_INTR) ? PCIBusErr175 : PCIBusErr170) |
817 	     TxUnderrun);
818 
819 	netdev_dbg(dev, "epic_restart() done, cmd status %4.4x, ctl %4.4x interrupt %4.4x.\n",
820 		   er32(COMMAND), er32(GENCTL), er32(INTSTAT));
821 }
822 
823 static void check_media(struct net_device *dev)
824 {
825 	struct epic_private *ep = netdev_priv(dev);
826 	void __iomem *ioaddr = ep->ioaddr;
827 	int mii_lpa = ep->mii_phy_cnt ? mdio_read(dev, ep->phys[0], MII_LPA) : 0;
828 	int negotiated = mii_lpa & ep->mii.advertising;
829 	int duplex = (negotiated & 0x0100) || (negotiated & 0x01C0) == 0x0040;
830 
831 	if (ep->mii.force_media)
832 		return;
833 	if (mii_lpa == 0xffff)		/* Bogus read */
834 		return;
835 	if (ep->mii.full_duplex != duplex) {
836 		ep->mii.full_duplex = duplex;
837 		netdev_info(dev, "Setting %s-duplex based on MII #%d link partner capability of %4.4x.\n",
838 			    ep->mii.full_duplex ? "full" : "half",
839 			    ep->phys[0], mii_lpa);
840 		ew32(TxCtrl, ep->mii.full_duplex ? 0x7F : 0x79);
841 	}
842 }
843 
844 static void epic_timer(struct timer_list *t)
845 {
846 	struct epic_private *ep = from_timer(ep, t, timer);
847 	struct net_device *dev = ep->mii.dev;
848 	void __iomem *ioaddr = ep->ioaddr;
849 	int next_tick = 5*HZ;
850 
851 	if (debug > 3) {
852 		netdev_dbg(dev, "Media monitor tick, Tx status %8.8x.\n",
853 			   er32(TxSTAT));
854 		netdev_dbg(dev, "Other registers are IntMask %4.4x IntStatus %4.4x RxStatus %4.4x.\n",
855 			   er32(INTMASK), er32(INTSTAT), er32(RxSTAT));
856 	}
857 
858 	check_media(dev);
859 
860 	ep->timer.expires = jiffies + next_tick;
861 	add_timer(&ep->timer);
862 }
863 
864 static void epic_tx_timeout(struct net_device *dev)
865 {
866 	struct epic_private *ep = netdev_priv(dev);
867 	void __iomem *ioaddr = ep->ioaddr;
868 
869 	if (debug > 0) {
870 		netdev_warn(dev, "Transmit timeout using MII device, Tx status %4.4x.\n",
871 			    er16(TxSTAT));
872 		if (debug > 1) {
873 			netdev_dbg(dev, "Tx indices: dirty_tx %d, cur_tx %d.\n",
874 				   ep->dirty_tx, ep->cur_tx);
875 		}
876 	}
877 	if (er16(TxSTAT) & 0x10) {		/* Tx FIFO underflow. */
878 		dev->stats.tx_fifo_errors++;
879 		ew32(COMMAND, RestartTx);
880 	} else {
881 		epic_restart(dev);
882 		ew32(COMMAND, TxQueued);
883 	}
884 
885 	netif_trans_update(dev); /* prevent tx timeout */
886 	dev->stats.tx_errors++;
887 	if (!ep->tx_full)
888 		netif_wake_queue(dev);
889 }
890 
891 /* Initialize the Rx and Tx rings, along with various 'dev' bits. */
892 static void epic_init_ring(struct net_device *dev)
893 {
894 	struct epic_private *ep = netdev_priv(dev);
895 	int i;
896 
897 	ep->tx_full = 0;
898 	ep->dirty_tx = ep->cur_tx = 0;
899 	ep->cur_rx = ep->dirty_rx = 0;
900 	ep->rx_buf_sz = (dev->mtu <= 1500 ? PKT_BUF_SZ : dev->mtu + 32);
901 
902 	/* Initialize all Rx descriptors. */
903 	for (i = 0; i < RX_RING_SIZE; i++) {
904 		ep->rx_ring[i].rxstatus = 0;
905 		ep->rx_ring[i].buflength = ep->rx_buf_sz;
906 		ep->rx_ring[i].next = ep->rx_ring_dma +
907 				      (i+1)*sizeof(struct epic_rx_desc);
908 		ep->rx_skbuff[i] = NULL;
909 	}
910 	/* Mark the last entry as wrapping the ring. */
911 	ep->rx_ring[i-1].next = ep->rx_ring_dma;
912 
913 	/* Fill in the Rx buffers.  Handle allocation failure gracefully. */
914 	for (i = 0; i < RX_RING_SIZE; i++) {
915 		struct sk_buff *skb = netdev_alloc_skb(dev, ep->rx_buf_sz + 2);
916 		ep->rx_skbuff[i] = skb;
917 		if (skb == NULL)
918 			break;
919 		skb_reserve(skb, 2);	/* 16 byte align the IP header. */
920 		ep->rx_ring[i].bufaddr = pci_map_single(ep->pci_dev,
921 			skb->data, ep->rx_buf_sz, PCI_DMA_FROMDEVICE);
922 		ep->rx_ring[i].rxstatus = DescOwn;
923 	}
924 	ep->dirty_rx = (unsigned int)(i - RX_RING_SIZE);
925 
926 	/* The Tx buffer descriptor is filled in as needed, but we
927 	   do need to clear the ownership bit. */
928 	for (i = 0; i < TX_RING_SIZE; i++) {
929 		ep->tx_skbuff[i] = NULL;
930 		ep->tx_ring[i].txstatus = 0x0000;
931 		ep->tx_ring[i].next = ep->tx_ring_dma +
932 			(i+1)*sizeof(struct epic_tx_desc);
933 	}
934 	ep->tx_ring[i-1].next = ep->tx_ring_dma;
935 }
936 
937 static netdev_tx_t epic_start_xmit(struct sk_buff *skb, struct net_device *dev)
938 {
939 	struct epic_private *ep = netdev_priv(dev);
940 	void __iomem *ioaddr = ep->ioaddr;
941 	int entry, free_count;
942 	u32 ctrl_word;
943 	unsigned long flags;
944 
945 	if (skb_padto(skb, ETH_ZLEN))
946 		return NETDEV_TX_OK;
947 
948 	/* Caution: the write order is important here, set the field with the
949 	   "ownership" bit last. */
950 
951 	/* Calculate the next Tx descriptor entry. */
952 	spin_lock_irqsave(&ep->lock, flags);
953 	free_count = ep->cur_tx - ep->dirty_tx;
954 	entry = ep->cur_tx % TX_RING_SIZE;
955 
956 	ep->tx_skbuff[entry] = skb;
957 	ep->tx_ring[entry].bufaddr = pci_map_single(ep->pci_dev, skb->data,
958 		 			            skb->len, PCI_DMA_TODEVICE);
959 	if (free_count < TX_QUEUE_LEN/2) {/* Typical path */
960 		ctrl_word = 0x100000; /* No interrupt */
961 	} else if (free_count == TX_QUEUE_LEN/2) {
962 		ctrl_word = 0x140000; /* Tx-done intr. */
963 	} else if (free_count < TX_QUEUE_LEN - 1) {
964 		ctrl_word = 0x100000; /* No Tx-done intr. */
965 	} else {
966 		/* Leave room for an additional entry. */
967 		ctrl_word = 0x140000; /* Tx-done intr. */
968 		ep->tx_full = 1;
969 	}
970 	ep->tx_ring[entry].buflength = ctrl_word | skb->len;
971 	ep->tx_ring[entry].txstatus =
972 		((skb->len >= ETH_ZLEN ? skb->len : ETH_ZLEN) << 16)
973 			    | DescOwn;
974 
975 	ep->cur_tx++;
976 	if (ep->tx_full)
977 		netif_stop_queue(dev);
978 
979 	spin_unlock_irqrestore(&ep->lock, flags);
980 	/* Trigger an immediate transmit demand. */
981 	ew32(COMMAND, TxQueued);
982 
983 	if (debug > 4)
984 		netdev_dbg(dev, "Queued Tx packet size %d to slot %d, flag %2.2x Tx status %8.8x.\n",
985 			   skb->len, entry, ctrl_word, er32(TxSTAT));
986 
987 	return NETDEV_TX_OK;
988 }
989 
990 static void epic_tx_error(struct net_device *dev, struct epic_private *ep,
991 			  int status)
992 {
993 	struct net_device_stats *stats = &dev->stats;
994 
995 #ifndef final_version
996 	/* There was an major error, log it. */
997 	if (debug > 1)
998 		netdev_dbg(dev, "Transmit error, Tx status %8.8x.\n",
999 			   status);
1000 #endif
1001 	stats->tx_errors++;
1002 	if (status & 0x1050)
1003 		stats->tx_aborted_errors++;
1004 	if (status & 0x0008)
1005 		stats->tx_carrier_errors++;
1006 	if (status & 0x0040)
1007 		stats->tx_window_errors++;
1008 	if (status & 0x0010)
1009 		stats->tx_fifo_errors++;
1010 }
1011 
1012 static void epic_tx(struct net_device *dev, struct epic_private *ep)
1013 {
1014 	unsigned int dirty_tx, cur_tx;
1015 
1016 	/*
1017 	 * Note: if this lock becomes a problem we can narrow the locked
1018 	 * region at the cost of occasionally grabbing the lock more times.
1019 	 */
1020 	cur_tx = ep->cur_tx;
1021 	for (dirty_tx = ep->dirty_tx; cur_tx - dirty_tx > 0; dirty_tx++) {
1022 		struct sk_buff *skb;
1023 		int entry = dirty_tx % TX_RING_SIZE;
1024 		int txstatus = ep->tx_ring[entry].txstatus;
1025 
1026 		if (txstatus & DescOwn)
1027 			break;	/* It still hasn't been Txed */
1028 
1029 		if (likely(txstatus & 0x0001)) {
1030 			dev->stats.collisions += (txstatus >> 8) & 15;
1031 			dev->stats.tx_packets++;
1032 			dev->stats.tx_bytes += ep->tx_skbuff[entry]->len;
1033 		} else
1034 			epic_tx_error(dev, ep, txstatus);
1035 
1036 		/* Free the original skb. */
1037 		skb = ep->tx_skbuff[entry];
1038 		pci_unmap_single(ep->pci_dev, ep->tx_ring[entry].bufaddr,
1039 				 skb->len, PCI_DMA_TODEVICE);
1040 		dev_consume_skb_irq(skb);
1041 		ep->tx_skbuff[entry] = NULL;
1042 	}
1043 
1044 #ifndef final_version
1045 	if (cur_tx - dirty_tx > TX_RING_SIZE) {
1046 		netdev_warn(dev, "Out-of-sync dirty pointer, %d vs. %d, full=%d.\n",
1047 			    dirty_tx, cur_tx, ep->tx_full);
1048 		dirty_tx += TX_RING_SIZE;
1049 	}
1050 #endif
1051 	ep->dirty_tx = dirty_tx;
1052 	if (ep->tx_full && cur_tx - dirty_tx < TX_QUEUE_LEN - 4) {
1053 		/* The ring is no longer full, allow new TX entries. */
1054 		ep->tx_full = 0;
1055 		netif_wake_queue(dev);
1056 	}
1057 }
1058 
1059 /* The interrupt handler does all of the Rx thread work and cleans up
1060    after the Tx thread. */
1061 static irqreturn_t epic_interrupt(int irq, void *dev_instance)
1062 {
1063 	struct net_device *dev = dev_instance;
1064 	struct epic_private *ep = netdev_priv(dev);
1065 	void __iomem *ioaddr = ep->ioaddr;
1066 	unsigned int handled = 0;
1067 	int status;
1068 
1069 	status = er32(INTSTAT);
1070 	/* Acknowledge all of the current interrupt sources ASAP. */
1071 	ew32(INTSTAT, status & EpicNormalEvent);
1072 
1073 	if (debug > 4) {
1074 		netdev_dbg(dev, "Interrupt, status=%#8.8x new intstat=%#8.8x.\n",
1075 			   status, er32(INTSTAT));
1076 	}
1077 
1078 	if ((status & IntrSummary) == 0)
1079 		goto out;
1080 
1081 	handled = 1;
1082 
1083 	if (status & EpicNapiEvent) {
1084 		spin_lock(&ep->napi_lock);
1085 		if (napi_schedule_prep(&ep->napi)) {
1086 			epic_napi_irq_off(dev, ep);
1087 			__napi_schedule(&ep->napi);
1088 		}
1089 		spin_unlock(&ep->napi_lock);
1090 	}
1091 	status &= ~EpicNapiEvent;
1092 
1093 	/* Check uncommon events all at once. */
1094 	if (status & (CntFull | TxUnderrun | PCIBusErr170 | PCIBusErr175)) {
1095 		struct net_device_stats *stats = &dev->stats;
1096 
1097 		if (status == EpicRemoved)
1098 			goto out;
1099 
1100 		/* Always update the error counts to avoid overhead later. */
1101 		stats->rx_missed_errors	+= er8(MPCNT);
1102 		stats->rx_frame_errors	+= er8(ALICNT);
1103 		stats->rx_crc_errors	+= er8(CRCCNT);
1104 
1105 		if (status & TxUnderrun) { /* Tx FIFO underflow. */
1106 			stats->tx_fifo_errors++;
1107 			ew32(TxThresh, ep->tx_threshold += 128);
1108 			/* Restart the transmit process. */
1109 			ew32(COMMAND, RestartTx);
1110 		}
1111 		if (status & PCIBusErr170) {
1112 			netdev_err(dev, "PCI Bus Error! status %4.4x.\n",
1113 				   status);
1114 			epic_pause(dev);
1115 			epic_restart(dev);
1116 		}
1117 		/* Clear all error sources. */
1118 		ew32(INTSTAT, status & 0x7f18);
1119 	}
1120 
1121 out:
1122 	if (debug > 3) {
1123 		netdev_dbg(dev, "exit interrupt, intr_status=%#4.4x.\n",
1124 			   status);
1125 	}
1126 
1127 	return IRQ_RETVAL(handled);
1128 }
1129 
1130 static int epic_rx(struct net_device *dev, int budget)
1131 {
1132 	struct epic_private *ep = netdev_priv(dev);
1133 	int entry = ep->cur_rx % RX_RING_SIZE;
1134 	int rx_work_limit = ep->dirty_rx + RX_RING_SIZE - ep->cur_rx;
1135 	int work_done = 0;
1136 
1137 	if (debug > 4)
1138 		netdev_dbg(dev, " In epic_rx(), entry %d %8.8x.\n", entry,
1139 			   ep->rx_ring[entry].rxstatus);
1140 
1141 	if (rx_work_limit > budget)
1142 		rx_work_limit = budget;
1143 
1144 	/* If we own the next entry, it's a new packet. Send it up. */
1145 	while ((ep->rx_ring[entry].rxstatus & DescOwn) == 0) {
1146 		int status = ep->rx_ring[entry].rxstatus;
1147 
1148 		if (debug > 4)
1149 			netdev_dbg(dev, "  epic_rx() status was %8.8x.\n",
1150 				   status);
1151 		if (--rx_work_limit < 0)
1152 			break;
1153 		if (status & 0x2006) {
1154 			if (debug > 2)
1155 				netdev_dbg(dev, "epic_rx() error status was %8.8x.\n",
1156 					   status);
1157 			if (status & 0x2000) {
1158 				netdev_warn(dev, "Oversized Ethernet frame spanned multiple buffers, status %4.4x!\n",
1159 					    status);
1160 				dev->stats.rx_length_errors++;
1161 			} else if (status & 0x0006)
1162 				/* Rx Frame errors are counted in hardware. */
1163 				dev->stats.rx_errors++;
1164 		} else {
1165 			/* Malloc up new buffer, compatible with net-2e. */
1166 			/* Omit the four octet CRC from the length. */
1167 			short pkt_len = (status >> 16) - 4;
1168 			struct sk_buff *skb;
1169 
1170 			if (pkt_len > PKT_BUF_SZ - 4) {
1171 				netdev_err(dev, "Oversized Ethernet frame, status %x %d bytes.\n",
1172 					   status, pkt_len);
1173 				pkt_len = 1514;
1174 			}
1175 			/* Check if the packet is long enough to accept without copying
1176 			   to a minimally-sized skbuff. */
1177 			if (pkt_len < rx_copybreak &&
1178 			    (skb = netdev_alloc_skb(dev, pkt_len + 2)) != NULL) {
1179 				skb_reserve(skb, 2);	/* 16 byte align the IP header */
1180 				pci_dma_sync_single_for_cpu(ep->pci_dev,
1181 							    ep->rx_ring[entry].bufaddr,
1182 							    ep->rx_buf_sz,
1183 							    PCI_DMA_FROMDEVICE);
1184 				skb_copy_to_linear_data(skb, ep->rx_skbuff[entry]->data, pkt_len);
1185 				skb_put(skb, pkt_len);
1186 				pci_dma_sync_single_for_device(ep->pci_dev,
1187 							       ep->rx_ring[entry].bufaddr,
1188 							       ep->rx_buf_sz,
1189 							       PCI_DMA_FROMDEVICE);
1190 			} else {
1191 				pci_unmap_single(ep->pci_dev,
1192 					ep->rx_ring[entry].bufaddr,
1193 					ep->rx_buf_sz, PCI_DMA_FROMDEVICE);
1194 				skb_put(skb = ep->rx_skbuff[entry], pkt_len);
1195 				ep->rx_skbuff[entry] = NULL;
1196 			}
1197 			skb->protocol = eth_type_trans(skb, dev);
1198 			netif_receive_skb(skb);
1199 			dev->stats.rx_packets++;
1200 			dev->stats.rx_bytes += pkt_len;
1201 		}
1202 		work_done++;
1203 		entry = (++ep->cur_rx) % RX_RING_SIZE;
1204 	}
1205 
1206 	/* Refill the Rx ring buffers. */
1207 	for (; ep->cur_rx - ep->dirty_rx > 0; ep->dirty_rx++) {
1208 		entry = ep->dirty_rx % RX_RING_SIZE;
1209 		if (ep->rx_skbuff[entry] == NULL) {
1210 			struct sk_buff *skb;
1211 			skb = ep->rx_skbuff[entry] = netdev_alloc_skb(dev, ep->rx_buf_sz + 2);
1212 			if (skb == NULL)
1213 				break;
1214 			skb_reserve(skb, 2);	/* Align IP on 16 byte boundaries */
1215 			ep->rx_ring[entry].bufaddr = pci_map_single(ep->pci_dev,
1216 				skb->data, ep->rx_buf_sz, PCI_DMA_FROMDEVICE);
1217 			work_done++;
1218 		}
1219 		/* AV: shouldn't we add a barrier here? */
1220 		ep->rx_ring[entry].rxstatus = DescOwn;
1221 	}
1222 	return work_done;
1223 }
1224 
1225 static void epic_rx_err(struct net_device *dev, struct epic_private *ep)
1226 {
1227 	void __iomem *ioaddr = ep->ioaddr;
1228 	int status;
1229 
1230 	status = er32(INTSTAT);
1231 
1232 	if (status == EpicRemoved)
1233 		return;
1234 	if (status & RxOverflow) 	/* Missed a Rx frame. */
1235 		dev->stats.rx_errors++;
1236 	if (status & (RxOverflow | RxFull))
1237 		ew16(COMMAND, RxQueued);
1238 }
1239 
1240 static int epic_poll(struct napi_struct *napi, int budget)
1241 {
1242 	struct epic_private *ep = container_of(napi, struct epic_private, napi);
1243 	struct net_device *dev = ep->mii.dev;
1244 	void __iomem *ioaddr = ep->ioaddr;
1245 	int work_done;
1246 
1247 	epic_tx(dev, ep);
1248 
1249 	work_done = epic_rx(dev, budget);
1250 
1251 	epic_rx_err(dev, ep);
1252 
1253 	if (work_done < budget && napi_complete_done(napi, work_done)) {
1254 		unsigned long flags;
1255 
1256 		spin_lock_irqsave(&ep->napi_lock, flags);
1257 
1258 		ew32(INTSTAT, EpicNapiEvent);
1259 		epic_napi_irq_on(dev, ep);
1260 		spin_unlock_irqrestore(&ep->napi_lock, flags);
1261 	}
1262 
1263 	return work_done;
1264 }
1265 
1266 static int epic_close(struct net_device *dev)
1267 {
1268 	struct epic_private *ep = netdev_priv(dev);
1269 	struct pci_dev *pdev = ep->pci_dev;
1270 	void __iomem *ioaddr = ep->ioaddr;
1271 	struct sk_buff *skb;
1272 	int i;
1273 
1274 	netif_stop_queue(dev);
1275 	napi_disable(&ep->napi);
1276 
1277 	if (debug > 1)
1278 		netdev_dbg(dev, "Shutting down ethercard, status was %2.2x.\n",
1279 			   er32(INTSTAT));
1280 
1281 	del_timer_sync(&ep->timer);
1282 
1283 	epic_disable_int(dev, ep);
1284 
1285 	free_irq(pdev->irq, dev);
1286 
1287 	epic_pause(dev);
1288 
1289 	/* Free all the skbuffs in the Rx queue. */
1290 	for (i = 0; i < RX_RING_SIZE; i++) {
1291 		skb = ep->rx_skbuff[i];
1292 		ep->rx_skbuff[i] = NULL;
1293 		ep->rx_ring[i].rxstatus = 0;		/* Not owned by Epic chip. */
1294 		ep->rx_ring[i].buflength = 0;
1295 		if (skb) {
1296 			pci_unmap_single(pdev, ep->rx_ring[i].bufaddr,
1297 					 ep->rx_buf_sz, PCI_DMA_FROMDEVICE);
1298 			dev_kfree_skb(skb);
1299 		}
1300 		ep->rx_ring[i].bufaddr = 0xBADF00D0; /* An invalid address. */
1301 	}
1302 	for (i = 0; i < TX_RING_SIZE; i++) {
1303 		skb = ep->tx_skbuff[i];
1304 		ep->tx_skbuff[i] = NULL;
1305 		if (!skb)
1306 			continue;
1307 		pci_unmap_single(pdev, ep->tx_ring[i].bufaddr, skb->len,
1308 				 PCI_DMA_TODEVICE);
1309 		dev_kfree_skb(skb);
1310 	}
1311 
1312 	/* Green! Leave the chip in low-power mode. */
1313 	ew32(GENCTL, 0x0008);
1314 
1315 	return 0;
1316 }
1317 
1318 static struct net_device_stats *epic_get_stats(struct net_device *dev)
1319 {
1320 	struct epic_private *ep = netdev_priv(dev);
1321 	void __iomem *ioaddr = ep->ioaddr;
1322 
1323 	if (netif_running(dev)) {
1324 		struct net_device_stats *stats = &dev->stats;
1325 
1326 		stats->rx_missed_errors	+= er8(MPCNT);
1327 		stats->rx_frame_errors	+= er8(ALICNT);
1328 		stats->rx_crc_errors	+= er8(CRCCNT);
1329 	}
1330 
1331 	return &dev->stats;
1332 }
1333 
1334 /* Set or clear the multicast filter for this adaptor.
1335    Note that we only use exclusion around actually queueing the
1336    new frame, not around filling ep->setup_frame.  This is non-deterministic
1337    when re-entered but still correct. */
1338 
1339 static void set_rx_mode(struct net_device *dev)
1340 {
1341 	struct epic_private *ep = netdev_priv(dev);
1342 	void __iomem *ioaddr = ep->ioaddr;
1343 	unsigned char mc_filter[8];		 /* Multicast hash filter */
1344 	int i;
1345 
1346 	if (dev->flags & IFF_PROMISC) {			/* Set promiscuous. */
1347 		ew32(RxCtrl, 0x002c);
1348 		/* Unconditionally log net taps. */
1349 		memset(mc_filter, 0xff, sizeof(mc_filter));
1350 	} else if ((!netdev_mc_empty(dev)) || (dev->flags & IFF_ALLMULTI)) {
1351 		/* There is apparently a chip bug, so the multicast filter
1352 		   is never enabled. */
1353 		/* Too many to filter perfectly -- accept all multicasts. */
1354 		memset(mc_filter, 0xff, sizeof(mc_filter));
1355 		ew32(RxCtrl, 0x000c);
1356 	} else if (netdev_mc_empty(dev)) {
1357 		ew32(RxCtrl, 0x0004);
1358 		return;
1359 	} else {					/* Never executed, for now. */
1360 		struct netdev_hw_addr *ha;
1361 
1362 		memset(mc_filter, 0, sizeof(mc_filter));
1363 		netdev_for_each_mc_addr(ha, dev) {
1364 			unsigned int bit_nr =
1365 				ether_crc_le(ETH_ALEN, ha->addr) & 0x3f;
1366 			mc_filter[bit_nr >> 3] |= (1 << bit_nr);
1367 		}
1368 	}
1369 	/* ToDo: perhaps we need to stop the Tx and Rx process here? */
1370 	if (memcmp(mc_filter, ep->mc_filter, sizeof(mc_filter))) {
1371 		for (i = 0; i < 4; i++)
1372 			ew16(MC0 + i*4, ((u16 *)mc_filter)[i]);
1373 		memcpy(ep->mc_filter, mc_filter, sizeof(mc_filter));
1374 	}
1375 }
1376 
1377 static void netdev_get_drvinfo (struct net_device *dev, struct ethtool_drvinfo *info)
1378 {
1379 	struct epic_private *np = netdev_priv(dev);
1380 
1381 	strlcpy(info->driver, DRV_NAME, sizeof(info->driver));
1382 	strlcpy(info->version, DRV_VERSION, sizeof(info->version));
1383 	strlcpy(info->bus_info, pci_name(np->pci_dev), sizeof(info->bus_info));
1384 }
1385 
1386 static int netdev_get_link_ksettings(struct net_device *dev,
1387 				     struct ethtool_link_ksettings *cmd)
1388 {
1389 	struct epic_private *np = netdev_priv(dev);
1390 
1391 	spin_lock_irq(&np->lock);
1392 	mii_ethtool_get_link_ksettings(&np->mii, cmd);
1393 	spin_unlock_irq(&np->lock);
1394 
1395 	return 0;
1396 }
1397 
1398 static int netdev_set_link_ksettings(struct net_device *dev,
1399 				     const struct ethtool_link_ksettings *cmd)
1400 {
1401 	struct epic_private *np = netdev_priv(dev);
1402 	int rc;
1403 
1404 	spin_lock_irq(&np->lock);
1405 	rc = mii_ethtool_set_link_ksettings(&np->mii, cmd);
1406 	spin_unlock_irq(&np->lock);
1407 
1408 	return rc;
1409 }
1410 
1411 static int netdev_nway_reset(struct net_device *dev)
1412 {
1413 	struct epic_private *np = netdev_priv(dev);
1414 	return mii_nway_restart(&np->mii);
1415 }
1416 
1417 static u32 netdev_get_link(struct net_device *dev)
1418 {
1419 	struct epic_private *np = netdev_priv(dev);
1420 	return mii_link_ok(&np->mii);
1421 }
1422 
1423 static u32 netdev_get_msglevel(struct net_device *dev)
1424 {
1425 	return debug;
1426 }
1427 
1428 static void netdev_set_msglevel(struct net_device *dev, u32 value)
1429 {
1430 	debug = value;
1431 }
1432 
1433 static int ethtool_begin(struct net_device *dev)
1434 {
1435 	struct epic_private *ep = netdev_priv(dev);
1436 	void __iomem *ioaddr = ep->ioaddr;
1437 
1438 	/* power-up, if interface is down */
1439 	if (!netif_running(dev)) {
1440 		ew32(GENCTL, 0x0200);
1441 		ew32(NVCTL, (er32(NVCTL) & ~0x003c) | 0x4800);
1442 	}
1443 	return 0;
1444 }
1445 
1446 static void ethtool_complete(struct net_device *dev)
1447 {
1448 	struct epic_private *ep = netdev_priv(dev);
1449 	void __iomem *ioaddr = ep->ioaddr;
1450 
1451 	/* power-down, if interface is down */
1452 	if (!netif_running(dev)) {
1453 		ew32(GENCTL, 0x0008);
1454 		ew32(NVCTL, (er32(NVCTL) & ~0x483c) | 0x0000);
1455 	}
1456 }
1457 
1458 static const struct ethtool_ops netdev_ethtool_ops = {
1459 	.get_drvinfo		= netdev_get_drvinfo,
1460 	.nway_reset		= netdev_nway_reset,
1461 	.get_link		= netdev_get_link,
1462 	.get_msglevel		= netdev_get_msglevel,
1463 	.set_msglevel		= netdev_set_msglevel,
1464 	.begin			= ethtool_begin,
1465 	.complete		= ethtool_complete,
1466 	.get_link_ksettings	= netdev_get_link_ksettings,
1467 	.set_link_ksettings	= netdev_set_link_ksettings,
1468 };
1469 
1470 static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
1471 {
1472 	struct epic_private *np = netdev_priv(dev);
1473 	void __iomem *ioaddr = np->ioaddr;
1474 	struct mii_ioctl_data *data = if_mii(rq);
1475 	int rc;
1476 
1477 	/* power-up, if interface is down */
1478 	if (! netif_running(dev)) {
1479 		ew32(GENCTL, 0x0200);
1480 		ew32(NVCTL, (er32(NVCTL) & ~0x003c) | 0x4800);
1481 	}
1482 
1483 	/* all non-ethtool ioctls (the SIOC[GS]MIIxxx ioctls) */
1484 	spin_lock_irq(&np->lock);
1485 	rc = generic_mii_ioctl(&np->mii, data, cmd, NULL);
1486 	spin_unlock_irq(&np->lock);
1487 
1488 	/* power-down, if interface is down */
1489 	if (! netif_running(dev)) {
1490 		ew32(GENCTL, 0x0008);
1491 		ew32(NVCTL, (er32(NVCTL) & ~0x483c) | 0x0000);
1492 	}
1493 	return rc;
1494 }
1495 
1496 
1497 static void epic_remove_one(struct pci_dev *pdev)
1498 {
1499 	struct net_device *dev = pci_get_drvdata(pdev);
1500 	struct epic_private *ep = netdev_priv(dev);
1501 
1502 	pci_free_consistent(pdev, TX_TOTAL_SIZE, ep->tx_ring, ep->tx_ring_dma);
1503 	pci_free_consistent(pdev, RX_TOTAL_SIZE, ep->rx_ring, ep->rx_ring_dma);
1504 	unregister_netdev(dev);
1505 	pci_iounmap(pdev, ep->ioaddr);
1506 	pci_release_regions(pdev);
1507 	free_netdev(dev);
1508 	pci_disable_device(pdev);
1509 	/* pci_power_off(pdev, -1); */
1510 }
1511 
1512 
1513 #ifdef CONFIG_PM
1514 
1515 static int epic_suspend (struct pci_dev *pdev, pm_message_t state)
1516 {
1517 	struct net_device *dev = pci_get_drvdata(pdev);
1518 	struct epic_private *ep = netdev_priv(dev);
1519 	void __iomem *ioaddr = ep->ioaddr;
1520 
1521 	if (!netif_running(dev))
1522 		return 0;
1523 	epic_pause(dev);
1524 	/* Put the chip into low-power mode. */
1525 	ew32(GENCTL, 0x0008);
1526 	/* pci_power_off(pdev, -1); */
1527 	return 0;
1528 }
1529 
1530 
1531 static int epic_resume (struct pci_dev *pdev)
1532 {
1533 	struct net_device *dev = pci_get_drvdata(pdev);
1534 
1535 	if (!netif_running(dev))
1536 		return 0;
1537 	epic_restart(dev);
1538 	/* pci_power_on(pdev); */
1539 	return 0;
1540 }
1541 
1542 #endif /* CONFIG_PM */
1543 
1544 
1545 static struct pci_driver epic_driver = {
1546 	.name		= DRV_NAME,
1547 	.id_table	= epic_pci_tbl,
1548 	.probe		= epic_init_one,
1549 	.remove		= epic_remove_one,
1550 #ifdef CONFIG_PM
1551 	.suspend	= epic_suspend,
1552 	.resume		= epic_resume,
1553 #endif /* CONFIG_PM */
1554 };
1555 
1556 
1557 static int __init epic_init (void)
1558 {
1559 /* when a module, this is printed whether or not devices are found in probe */
1560 #ifdef MODULE
1561 	pr_info("%s%s\n", version, version2);
1562 #endif
1563 
1564 	return pci_register_driver(&epic_driver);
1565 }
1566 
1567 
1568 static void __exit epic_cleanup (void)
1569 {
1570 	pci_unregister_driver (&epic_driver);
1571 }
1572 
1573 
1574 module_init(epic_init);
1575 module_exit(epic_cleanup);
1576