1 /* sundance.c: A Linux device driver for the Sundance ST201 "Alta". */
3 Written 1999-2000 by Donald Becker.
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.
12 The author may be reached as becker@scyld.com, or C/O
13 Scyld Computing Corporation
14 410 Severn Ave., Suite 210
17 Support and updates available at
18 http://www.scyld.com/network/sundance.html
19 [link no longer provides useful info -jgarzik]
20 Archives of the mailing list are still available at
21 http://www.beowulf.org/pipermail/netdrivers/
25 #define DRV_NAME "sundance"
26 #define DRV_VERSION "1.2"
27 #define DRV_RELDATE "11-Sep-2006"
30 /* The user-configurable values.
31 These may be modified when a driver module is loaded.*/
32 static int debug
= 1; /* 1 normal messages, 0 quiet .. 7 verbose. */
33 /* Maximum number of multicast addresses to filter (vs. rx-all-multicast).
34 Typical is a 64 element hash table based on the Ethernet CRC. */
35 static const int multicast_filter_limit
= 32;
37 /* Set the copy breakpoint for the copy-only-tiny-frames scheme.
38 Setting to > 1518 effectively disables this feature.
39 This chip can receive into offset buffers, so the Alpha does not
41 static int rx_copybreak
;
42 static int flowctrl
=1;
44 /* media[] specifies the media type the NIC operates at.
45 autosense Autosensing active media.
46 10mbps_hd 10Mbps half duplex.
47 10mbps_fd 10Mbps full duplex.
48 100mbps_hd 100Mbps half duplex.
49 100mbps_fd 100Mbps full duplex.
50 0 Autosensing active media.
53 3 100Mbps half duplex.
54 4 100Mbps full duplex.
57 static char *media
[MAX_UNITS
];
60 /* Operational parameters that are set at compile time. */
62 /* Keep the ring sizes a power of two for compile efficiency.
63 The compiler will convert <unsigned>'%'<2^N> into a bit mask.
64 Making the Tx ring too large decreases the effectiveness of channel
65 bonding and packet priority, and more than 128 requires modifying the
67 Large receive rings merely waste memory. */
68 #define TX_RING_SIZE 32
69 #define TX_QUEUE_LEN (TX_RING_SIZE - 1) /* Limit ring entries actually used. */
70 #define RX_RING_SIZE 64
72 #define TX_TOTAL_SIZE TX_RING_SIZE*sizeof(struct netdev_desc)
73 #define RX_TOTAL_SIZE RX_RING_SIZE*sizeof(struct netdev_desc)
75 /* Operational parameters that usually are not changed. */
76 /* Time in jiffies before concluding the transmitter is hung. */
77 #define TX_TIMEOUT (4*HZ)
78 #define PKT_BUF_SZ 1536 /* Size of each temporary Rx buffer.*/
80 /* Include files, designed to support most kernel versions 2.0.0 and later. */
81 #include <linux/module.h>
82 #include <linux/kernel.h>
83 #include <linux/string.h>
84 #include <linux/timer.h>
85 #include <linux/errno.h>
86 #include <linux/ioport.h>
87 #include <linux/slab.h>
88 #include <linux/interrupt.h>
89 #include <linux/pci.h>
90 #include <linux/netdevice.h>
91 #include <linux/etherdevice.h>
92 #include <linux/skbuff.h>
93 #include <linux/init.h>
94 #include <linux/bitops.h>
95 #include <asm/uaccess.h>
96 #include <asm/processor.h> /* Processor type for cache alignment. */
98 #include <linux/delay.h>
99 #include <linux/spinlock.h>
100 #ifndef _COMPAT_WITH_OLD_KERNEL
101 #include <linux/crc32.h>
102 #include <linux/ethtool.h>
103 #include <linux/mii.h>
111 /* These identify the driver base version and may not be removed. */
112 static char version
[] =
113 KERN_INFO DRV_NAME
".c:v" DRV_VERSION
" " DRV_RELDATE
" Written by Donald Becker\n"
114 KERN_INFO
" http://www.scyld.com/network/sundance.html\n";
116 MODULE_AUTHOR("Donald Becker <becker@scyld.com>");
117 MODULE_DESCRIPTION("Sundance Alta Ethernet driver");
118 MODULE_LICENSE("GPL");
120 module_param(debug
, int, 0);
121 module_param(rx_copybreak
, int, 0);
122 module_param_array(media
, charp
, NULL
, 0);
123 module_param(flowctrl
, int, 0);
124 MODULE_PARM_DESC(debug
, "Sundance Alta debug level (0-5)");
125 MODULE_PARM_DESC(rx_copybreak
, "Sundance Alta copy breakpoint for copy-only-tiny-frames");
126 MODULE_PARM_DESC(flowctrl
, "Sundance Alta flow control [0|1]");
131 I. Board Compatibility
133 This driver is designed for the Sundance Technologies "Alta" ST201 chip.
135 II. Board-specific settings
137 III. Driver operation
141 This driver uses two statically allocated fixed-size descriptor lists
142 formed into rings by a branch from the final descriptor to the beginning of
143 the list. The ring sizes are set at compile time by RX/TX_RING_SIZE.
144 Some chips explicitly use only 2^N sized rings, while others use a
145 'next descriptor' pointer that the driver forms into rings.
147 IIIb/c. Transmit/Receive Structure
149 This driver uses a zero-copy receive and transmit scheme.
150 The driver allocates full frame size skbuffs for the Rx ring buffers at
151 open() time and passes the skb->data field to the chip as receive data
152 buffers. When an incoming frame is less than RX_COPYBREAK bytes long,
153 a fresh skbuff is allocated and the frame is copied to the new skbuff.
154 When the incoming frame is larger, the skbuff is passed directly up the
155 protocol stack. Buffers consumed this way are replaced by newly allocated
156 skbuffs in a later phase of receives.
158 The RX_COPYBREAK value is chosen to trade-off the memory wasted by
159 using a full-sized skbuff for small frames vs. the copying costs of larger
160 frames. New boards are typically used in generously configured machines
161 and the underfilled buffers have negligible impact compared to the benefit of
162 a single allocation size, so the default value of zero results in never
163 copying packets. When copying is done, the cost is usually mitigated by using
164 a combined copy/checksum routine. Copying also preloads the cache, which is
165 most useful with small frames.
167 A subtle aspect of the operation is that the IP header at offset 14 in an
168 ethernet frame isn't longword aligned for further processing.
169 Unaligned buffers are permitted by the Sundance hardware, so
170 frames are received into the skbuff at an offset of "+2", 16-byte aligning
173 IIId. Synchronization
175 The driver runs as two independent, single-threaded flows of control. One
176 is the send-packet routine, which enforces single-threaded use by the
177 dev->tbusy flag. The other thread is the interrupt handler, which is single
178 threaded by the hardware and interrupt handling software.
180 The send packet thread has partial control over the Tx ring and 'dev->tbusy'
181 flag. It sets the tbusy flag whenever it's queuing a Tx packet. If the next
182 queue slot is empty, it clears the tbusy flag when finished otherwise it sets
183 the 'lp->tx_full' flag.
185 The interrupt handler has exclusive control over the Rx ring and records stats
186 from the Tx ring. After reaping the stats, it marks the Tx queue entry as
187 empty by incrementing the dirty_tx mark. Iff the 'lp->tx_full' flag is set, it
188 clears both the tx_full and tbusy flags.
194 The Sundance ST201 datasheet, preliminary version.
195 The Kendin KS8723 datasheet, preliminary version.
196 The ICplus IP100 datasheet, preliminary version.
197 http://www.scyld.com/expert/100mbps.html
198 http://www.scyld.com/expert/NWay.html
204 /* Work-around for Kendin chip bugs. */
205 #ifndef CONFIG_SUNDANCE_MMIO
209 static const struct pci_device_id sundance_pci_tbl
[] = {
210 { 0x1186, 0x1002, 0x1186, 0x1002, 0, 0, 0 },
211 { 0x1186, 0x1002, 0x1186, 0x1003, 0, 0, 1 },
212 { 0x1186, 0x1002, 0x1186, 0x1012, 0, 0, 2 },
213 { 0x1186, 0x1002, 0x1186, 0x1040, 0, 0, 3 },
214 { 0x1186, 0x1002, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, 4 },
215 { 0x13F0, 0x0201, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, 5 },
216 { 0x13F0, 0x0200, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, 6 },
219 MODULE_DEVICE_TABLE(pci
, sundance_pci_tbl
);
228 static const struct pci_id_info pci_id_tbl
[] __devinitdata
= {
229 {"D-Link DFE-550TX FAST Ethernet Adapter"},
230 {"D-Link DFE-550FX 100Mbps Fiber-optics Adapter"},
231 {"D-Link DFE-580TX 4 port Server Adapter"},
232 {"D-Link DFE-530TXS FAST Ethernet Adapter"},
233 {"D-Link DL10050-based FAST Ethernet Adapter"},
234 {"Sundance Technology Alta"},
235 {"IC Plus Corporation IP100A FAST Ethernet Adapter"},
236 { } /* terminate list. */
239 /* This driver was written to use PCI memory space, however x86-oriented
240 hardware often uses I/O space accesses. */
242 /* Offsets to the device registers.
243 Unlike software-only systems, device drivers interact with complex hardware.
244 It's not useful to define symbolic names for every register bit in the
245 device. The name can only partially document the semantics and make
246 the driver longer and more difficult to read.
247 In general, only the important configuration values or bits changed
248 multiple times should be defined symbolically.
253 TxDMABurstThresh
= 0x08,
254 TxDMAUrgentThresh
= 0x09,
255 TxDMAPollPeriod
= 0x0a,
260 RxDMABurstThresh
= 0x14,
261 RxDMAUrgentThresh
= 0x15,
262 RxDMAPollPeriod
= 0x16,
267 TxStartThresh
= 0x3c,
268 RxEarlyThresh
= 0x3e,
283 MulticastFilter0
= 0x60,
284 MulticastFilter1
= 0x64,
291 StatsCarrierError
= 0x74,
292 StatsLateColl
= 0x75,
293 StatsMultiColl
= 0x76,
297 StatsTxXSDefer
= 0x7a,
303 /* Aliased and bogus values! */
306 enum ASICCtrl_HiWord_bit
{
307 GlobalReset
= 0x0001,
312 NetworkReset
= 0x0020,
317 /* Bits in the interrupt status/mask registers. */
318 enum intr_status_bits
{
319 IntrSummary
=0x0001, IntrPCIErr
=0x0002, IntrMACCtrl
=0x0008,
320 IntrTxDone
=0x0004, IntrRxDone
=0x0010, IntrRxStart
=0x0020,
322 StatsMax
=0x0080, LinkChange
=0x0100,
323 IntrTxDMADone
=0x0200, IntrRxDMADone
=0x0400,
326 /* Bits in the RxMode register. */
328 AcceptAllIPMulti
=0x20, AcceptMultiHash
=0x10, AcceptAll
=0x08,
329 AcceptBroadcast
=0x04, AcceptMulticast
=0x02, AcceptMyPhys
=0x01,
331 /* Bits in MACCtrl. */
332 enum mac_ctrl0_bits
{
333 EnbFullDuplex
=0x20, EnbRcvLargeFrame
=0x40,
334 EnbFlowCtrl
=0x100, EnbPassRxCRC
=0x200,
336 enum mac_ctrl1_bits
{
337 StatsEnable
=0x0020, StatsDisable
=0x0040, StatsEnabled
=0x0080,
338 TxEnable
=0x0100, TxDisable
=0x0200, TxEnabled
=0x0400,
339 RxEnable
=0x0800, RxDisable
=0x1000, RxEnabled
=0x2000,
342 /* The Rx and Tx buffer descriptors. */
343 /* Note that using only 32 bit fields simplifies conversion to big-endian
348 struct desc_frag
{ u32 addr
, length
; } frag
[1];
351 /* Bits in netdev_desc.status */
352 enum desc_status_bits
{
354 DescEndPacket
=0x4000,
358 DescIntrOnDMADone
=0x80000000,
359 DisableAlign
= 0x00000001,
362 #define PRIV_ALIGN 15 /* Required alignment mask */
363 /* Use __attribute__((aligned (L1_CACHE_BYTES))) to maintain alignment
364 within the structure. */
366 struct netdev_private
{
367 /* Descriptor rings first for alignment. */
368 struct netdev_desc
*rx_ring
;
369 struct netdev_desc
*tx_ring
;
370 struct sk_buff
* rx_skbuff
[RX_RING_SIZE
];
371 struct sk_buff
* tx_skbuff
[TX_RING_SIZE
];
372 dma_addr_t tx_ring_dma
;
373 dma_addr_t rx_ring_dma
;
374 struct net_device_stats stats
;
375 struct timer_list timer
; /* Media monitoring timer. */
376 /* Frequently used values: keep some adjacent for cache effect. */
378 spinlock_t rx_lock
; /* Group with Tx control cache line. */
381 unsigned int cur_rx
, dirty_rx
; /* Producer/consumer ring indices */
382 unsigned int rx_buf_sz
; /* Based on MTU+slack. */
383 struct netdev_desc
*last_tx
; /* Last Tx descriptor used. */
384 unsigned int cur_tx
, dirty_tx
;
385 /* These values are keep track of the transceiver/media in use. */
386 unsigned int flowctrl
:1;
387 unsigned int default_port
:4; /* Last dev->if_port value. */
388 unsigned int an_enable
:1;
390 struct tasklet_struct rx_tasklet
;
391 struct tasklet_struct tx_tasklet
;
394 /* Multicast and receive mode. */
395 spinlock_t mcastlock
; /* SMP lock multicast updates. */
397 /* MII transceiver section. */
398 struct mii_if_info mii_if
;
399 int mii_preamble_required
;
400 unsigned char phys
[MII_CNT
]; /* MII device addresses, only first one used. */
401 struct pci_dev
*pci_dev
;
403 unsigned char pci_rev_id
;
406 /* The station address location in the EEPROM. */
407 #define EEPROM_SA_OFFSET 0x10
408 #define DEFAULT_INTR (IntrRxDMADone | IntrPCIErr | \
409 IntrDrvRqst | IntrTxDone | StatsMax | \
412 static int change_mtu(struct net_device
*dev
, int new_mtu
);
413 static int eeprom_read(void __iomem
*ioaddr
, int location
);
414 static int mdio_read(struct net_device
*dev
, int phy_id
, int location
);
415 static void mdio_write(struct net_device
*dev
, int phy_id
, int location
, int value
);
416 static int netdev_open(struct net_device
*dev
);
417 static void check_duplex(struct net_device
*dev
);
418 static void netdev_timer(unsigned long data
);
419 static void tx_timeout(struct net_device
*dev
);
420 static void init_ring(struct net_device
*dev
);
421 static int start_tx(struct sk_buff
*skb
, struct net_device
*dev
);
422 static int reset_tx (struct net_device
*dev
);
423 static irqreturn_t
intr_handler(int irq
, void *dev_instance
, struct pt_regs
*regs
);
424 static void rx_poll(unsigned long data
);
425 static void tx_poll(unsigned long data
);
426 static void refill_rx (struct net_device
*dev
);
427 static void netdev_error(struct net_device
*dev
, int intr_status
);
428 static void netdev_error(struct net_device
*dev
, int intr_status
);
429 static void set_rx_mode(struct net_device
*dev
);
430 static int __set_mac_addr(struct net_device
*dev
);
431 static struct net_device_stats
*get_stats(struct net_device
*dev
);
432 static int netdev_ioctl(struct net_device
*dev
, struct ifreq
*rq
, int cmd
);
433 static int netdev_close(struct net_device
*dev
);
434 static const struct ethtool_ops ethtool_ops
;
436 static void sundance_reset(struct net_device
*dev
, unsigned long reset_cmd
)
438 struct netdev_private
*np
= netdev_priv(dev
);
439 void __iomem
*ioaddr
= np
->base
+ ASICCtrl
;
442 /* ST201 documentation states ASICCtrl is a 32bit register */
443 iowrite32 (reset_cmd
| ioread32 (ioaddr
), ioaddr
);
444 /* ST201 documentation states reset can take up to 1 ms */
446 while (ioread32 (ioaddr
) & (ResetBusy
<< 16)) {
447 if (--countdown
== 0) {
448 printk(KERN_WARNING
"%s : reset not completed !!\n", dev
->name
);
455 static int __devinit
sundance_probe1 (struct pci_dev
*pdev
,
456 const struct pci_device_id
*ent
)
458 struct net_device
*dev
;
459 struct netdev_private
*np
;
461 int chip_idx
= ent
->driver_data
;
464 void __iomem
*ioaddr
;
473 int phy
, phy_idx
= 0;
476 /* when built into the kernel, we only print version if device is found */
478 static int printed_version
;
479 if (!printed_version
++)
483 if (pci_enable_device(pdev
))
485 pci_set_master(pdev
);
489 dev
= alloc_etherdev(sizeof(*np
));
492 SET_MODULE_OWNER(dev
);
493 SET_NETDEV_DEV(dev
, &pdev
->dev
);
495 if (pci_request_regions(pdev
, DRV_NAME
))
498 ioaddr
= pci_iomap(pdev
, bar
, netdev_io_size
);
502 for (i
= 0; i
< 3; i
++)
503 ((u16
*)dev
->dev_addr
)[i
] =
504 le16_to_cpu(eeprom_read(ioaddr
, i
+ EEPROM_SA_OFFSET
));
505 memcpy(dev
->perm_addr
, dev
->dev_addr
, dev
->addr_len
);
507 dev
->base_addr
= (unsigned long)ioaddr
;
510 np
= netdev_priv(dev
);
513 np
->chip_id
= chip_idx
;
514 np
->msg_enable
= (1 << debug
) - 1;
515 spin_lock_init(&np
->lock
);
516 tasklet_init(&np
->rx_tasklet
, rx_poll
, (unsigned long)dev
);
517 tasklet_init(&np
->tx_tasklet
, tx_poll
, (unsigned long)dev
);
519 ring_space
= pci_alloc_consistent(pdev
, TX_TOTAL_SIZE
, &ring_dma
);
521 goto err_out_cleardev
;
522 np
->tx_ring
= (struct netdev_desc
*)ring_space
;
523 np
->tx_ring_dma
= ring_dma
;
525 ring_space
= pci_alloc_consistent(pdev
, RX_TOTAL_SIZE
, &ring_dma
);
527 goto err_out_unmap_tx
;
528 np
->rx_ring
= (struct netdev_desc
*)ring_space
;
529 np
->rx_ring_dma
= ring_dma
;
531 np
->mii_if
.dev
= dev
;
532 np
->mii_if
.mdio_read
= mdio_read
;
533 np
->mii_if
.mdio_write
= mdio_write
;
534 np
->mii_if
.phy_id_mask
= 0x1f;
535 np
->mii_if
.reg_num_mask
= 0x1f;
537 /* The chip-specific entries in the device structure. */
538 dev
->open
= &netdev_open
;
539 dev
->hard_start_xmit
= &start_tx
;
540 dev
->stop
= &netdev_close
;
541 dev
->get_stats
= &get_stats
;
542 dev
->set_multicast_list
= &set_rx_mode
;
543 dev
->do_ioctl
= &netdev_ioctl
;
544 SET_ETHTOOL_OPS(dev
, ðtool_ops
);
545 dev
->tx_timeout
= &tx_timeout
;
546 dev
->watchdog_timeo
= TX_TIMEOUT
;
547 dev
->change_mtu
= &change_mtu
;
548 pci_set_drvdata(pdev
, dev
);
550 pci_read_config_byte(pdev
, PCI_REVISION_ID
, &np
->pci_rev_id
);
552 i
= register_netdev(dev
);
554 goto err_out_unmap_rx
;
556 printk(KERN_INFO
"%s: %s at %p, ",
557 dev
->name
, pci_id_tbl
[chip_idx
].name
, ioaddr
);
558 for (i
= 0; i
< 5; i
++)
559 printk("%2.2x:", dev
->dev_addr
[i
]);
560 printk("%2.2x, IRQ %d.\n", dev
->dev_addr
[i
], irq
);
562 np
->phys
[0] = 1; /* Default setting */
563 np
->mii_preamble_required
++;
565 * It seems some phys doesn't deal well with address 0 being accessed
566 * first, so leave address zero to the end of the loop (32 & 31).
568 for (phy
= 1; phy
<= 32 && phy_idx
< MII_CNT
; phy
++) {
569 int phyx
= phy
& 0x1f;
570 int mii_status
= mdio_read(dev
, phyx
, MII_BMSR
);
571 if (mii_status
!= 0xffff && mii_status
!= 0x0000) {
572 np
->phys
[phy_idx
++] = phyx
;
573 np
->mii_if
.advertising
= mdio_read(dev
, phyx
, MII_ADVERTISE
);
574 if ((mii_status
& 0x0040) == 0)
575 np
->mii_preamble_required
++;
576 printk(KERN_INFO
"%s: MII PHY found at address %d, status "
577 "0x%4.4x advertising %4.4x.\n",
578 dev
->name
, phyx
, mii_status
, np
->mii_if
.advertising
);
581 np
->mii_preamble_required
--;
584 printk(KERN_INFO
"%s: No MII transceiver found, aborting. ASIC status %x\n",
585 dev
->name
, ioread32(ioaddr
+ ASICCtrl
));
586 goto err_out_unregister
;
589 np
->mii_if
.phy_id
= np
->phys
[0];
591 /* Parse override configuration */
593 if (card_idx
< MAX_UNITS
) {
594 if (media
[card_idx
] != NULL
) {
596 if (strcmp (media
[card_idx
], "100mbps_fd") == 0 ||
597 strcmp (media
[card_idx
], "4") == 0) {
599 np
->mii_if
.full_duplex
= 1;
600 } else if (strcmp (media
[card_idx
], "100mbps_hd") == 0
601 || strcmp (media
[card_idx
], "3") == 0) {
603 np
->mii_if
.full_duplex
= 0;
604 } else if (strcmp (media
[card_idx
], "10mbps_fd") == 0 ||
605 strcmp (media
[card_idx
], "2") == 0) {
607 np
->mii_if
.full_duplex
= 1;
608 } else if (strcmp (media
[card_idx
], "10mbps_hd") == 0 ||
609 strcmp (media
[card_idx
], "1") == 0) {
611 np
->mii_if
.full_duplex
= 0;
621 if (ioread32 (ioaddr
+ ASICCtrl
) & 0x80) {
622 /* Default 100Mbps Full */
625 np
->mii_if
.full_duplex
= 1;
630 mdio_write (dev
, np
->phys
[0], MII_BMCR
, BMCR_RESET
);
632 /* If flow control enabled, we need to advertise it.*/
634 mdio_write (dev
, np
->phys
[0], MII_ADVERTISE
, np
->mii_if
.advertising
| 0x0400);
635 mdio_write (dev
, np
->phys
[0], MII_BMCR
, BMCR_ANENABLE
|BMCR_ANRESTART
);
636 /* Force media type */
637 if (!np
->an_enable
) {
639 mii_ctl
|= (np
->speed
== 100) ? BMCR_SPEED100
: 0;
640 mii_ctl
|= (np
->mii_if
.full_duplex
) ? BMCR_FULLDPLX
: 0;
641 mdio_write (dev
, np
->phys
[0], MII_BMCR
, mii_ctl
);
642 printk (KERN_INFO
"Override speed=%d, %s duplex\n",
643 np
->speed
, np
->mii_if
.full_duplex
? "Full" : "Half");
647 /* Perhaps move the reset here? */
648 /* Reset the chip to erase previous misconfiguration. */
649 if (netif_msg_hw(np
))
650 printk("ASIC Control is %x.\n", ioread32(ioaddr
+ ASICCtrl
));
651 sundance_reset(dev
, 0x00ff << 16);
652 if (netif_msg_hw(np
))
653 printk("ASIC Control is now %x.\n", ioread32(ioaddr
+ ASICCtrl
));
659 unregister_netdev(dev
);
661 pci_free_consistent(pdev
, RX_TOTAL_SIZE
, np
->rx_ring
, np
->rx_ring_dma
);
663 pci_free_consistent(pdev
, TX_TOTAL_SIZE
, np
->tx_ring
, np
->tx_ring_dma
);
665 pci_set_drvdata(pdev
, NULL
);
666 pci_iounmap(pdev
, ioaddr
);
668 pci_release_regions(pdev
);
674 static int change_mtu(struct net_device
*dev
, int new_mtu
)
676 if ((new_mtu
< 68) || (new_mtu
> 8191)) /* Set by RxDMAFrameLen */
678 if (netif_running(dev
))
684 #define eeprom_delay(ee_addr) ioread32(ee_addr)
685 /* Read the EEPROM and MII Management Data I/O (MDIO) interfaces. */
686 static int __devinit
eeprom_read(void __iomem
*ioaddr
, int location
)
688 int boguscnt
= 10000; /* Typical 1900 ticks. */
689 iowrite16(0x0200 | (location
& 0xff), ioaddr
+ EECtrl
);
691 eeprom_delay(ioaddr
+ EECtrl
);
692 if (! (ioread16(ioaddr
+ EECtrl
) & 0x8000)) {
693 return ioread16(ioaddr
+ EEData
);
695 } while (--boguscnt
> 0);
699 /* MII transceiver control section.
700 Read and write the MII registers using software-generated serial
701 MDIO protocol. See the MII specifications or DP83840A data sheet
704 The maximum data clock rate is 2.5 Mhz. The minimum timing is usually
705 met by back-to-back 33Mhz PCI cycles. */
706 #define mdio_delay() ioread8(mdio_addr)
709 MDIO_ShiftClk
=0x0001, MDIO_Data
=0x0002, MDIO_EnbOutput
=0x0004,
711 #define MDIO_EnbIn (0)
712 #define MDIO_WRITE0 (MDIO_EnbOutput)
713 #define MDIO_WRITE1 (MDIO_Data | MDIO_EnbOutput)
715 /* Generate the preamble required for initial synchronization and
716 a few older transceivers. */
717 static void mdio_sync(void __iomem
*mdio_addr
)
721 /* Establish sync by sending at least 32 logic ones. */
722 while (--bits
>= 0) {
723 iowrite8(MDIO_WRITE1
, mdio_addr
);
725 iowrite8(MDIO_WRITE1
| MDIO_ShiftClk
, mdio_addr
);
730 static int mdio_read(struct net_device
*dev
, int phy_id
, int location
)
732 struct netdev_private
*np
= netdev_priv(dev
);
733 void __iomem
*mdio_addr
= np
->base
+ MIICtrl
;
734 int mii_cmd
= (0xf6 << 10) | (phy_id
<< 5) | location
;
737 if (np
->mii_preamble_required
)
738 mdio_sync(mdio_addr
);
740 /* Shift the read command bits out. */
741 for (i
= 15; i
>= 0; i
--) {
742 int dataval
= (mii_cmd
& (1 << i
)) ? MDIO_WRITE1
: MDIO_WRITE0
;
744 iowrite8(dataval
, mdio_addr
);
746 iowrite8(dataval
| MDIO_ShiftClk
, mdio_addr
);
749 /* Read the two transition, 16 data, and wire-idle bits. */
750 for (i
= 19; i
> 0; i
--) {
751 iowrite8(MDIO_EnbIn
, mdio_addr
);
753 retval
= (retval
<< 1) | ((ioread8(mdio_addr
) & MDIO_Data
) ? 1 : 0);
754 iowrite8(MDIO_EnbIn
| MDIO_ShiftClk
, mdio_addr
);
757 return (retval
>>1) & 0xffff;
760 static void mdio_write(struct net_device
*dev
, int phy_id
, int location
, int value
)
762 struct netdev_private
*np
= netdev_priv(dev
);
763 void __iomem
*mdio_addr
= np
->base
+ MIICtrl
;
764 int mii_cmd
= (0x5002 << 16) | (phy_id
<< 23) | (location
<<18) | value
;
767 if (np
->mii_preamble_required
)
768 mdio_sync(mdio_addr
);
770 /* Shift the command bits out. */
771 for (i
= 31; i
>= 0; i
--) {
772 int dataval
= (mii_cmd
& (1 << i
)) ? MDIO_WRITE1
: MDIO_WRITE0
;
774 iowrite8(dataval
, mdio_addr
);
776 iowrite8(dataval
| MDIO_ShiftClk
, mdio_addr
);
779 /* Clear out extra bits. */
780 for (i
= 2; i
> 0; i
--) {
781 iowrite8(MDIO_EnbIn
, mdio_addr
);
783 iowrite8(MDIO_EnbIn
| MDIO_ShiftClk
, mdio_addr
);
789 static int netdev_open(struct net_device
*dev
)
791 struct netdev_private
*np
= netdev_priv(dev
);
792 void __iomem
*ioaddr
= np
->base
;
795 /* Do we need to reset the chip??? */
797 i
= request_irq(dev
->irq
, &intr_handler
, IRQF_SHARED
, dev
->name
, dev
);
801 if (netif_msg_ifup(np
))
802 printk(KERN_DEBUG
"%s: netdev_open() irq %d.\n",
803 dev
->name
, dev
->irq
);
806 iowrite32(np
->rx_ring_dma
, ioaddr
+ RxListPtr
);
807 /* The Tx list pointer is written as packets are queued. */
809 /* Initialize other registers. */
811 #if defined(CONFIG_VLAN_8021Q) || defined(CONFIG_VLAN_8021Q_MODULE)
812 iowrite16(dev
->mtu
+ 18, ioaddr
+ MaxFrameSize
);
814 iowrite16(dev
->mtu
+ 14, ioaddr
+ MaxFrameSize
);
817 iowrite32(ioread32(ioaddr
+ ASICCtrl
) | 0x0C, ioaddr
+ ASICCtrl
);
819 /* Configure the PCI bus bursts and FIFO thresholds. */
821 if (dev
->if_port
== 0)
822 dev
->if_port
= np
->default_port
;
824 spin_lock_init(&np
->mcastlock
);
827 iowrite16(0, ioaddr
+ IntrEnable
);
828 iowrite16(0, ioaddr
+ DownCounter
);
829 /* Set the chip to poll every N*320nsec. */
830 iowrite8(100, ioaddr
+ RxDMAPollPeriod
);
831 iowrite8(127, ioaddr
+ TxDMAPollPeriod
);
832 /* Fix DFE-580TX packet drop issue */
833 if (np
->pci_rev_id
>= 0x14)
834 iowrite8(0x01, ioaddr
+ DebugCtrl1
);
835 netif_start_queue(dev
);
837 iowrite16 (StatsEnable
| RxEnable
| TxEnable
, ioaddr
+ MACCtrl1
);
839 if (netif_msg_ifup(np
))
840 printk(KERN_DEBUG
"%s: Done netdev_open(), status: Rx %x Tx %x "
841 "MAC Control %x, %4.4x %4.4x.\n",
842 dev
->name
, ioread32(ioaddr
+ RxStatus
), ioread8(ioaddr
+ TxStatus
),
843 ioread32(ioaddr
+ MACCtrl0
),
844 ioread16(ioaddr
+ MACCtrl1
), ioread16(ioaddr
+ MACCtrl0
));
846 /* Set the timer to check for link beat. */
847 init_timer(&np
->timer
);
848 np
->timer
.expires
= jiffies
+ 3*HZ
;
849 np
->timer
.data
= (unsigned long)dev
;
850 np
->timer
.function
= &netdev_timer
; /* timer handler */
851 add_timer(&np
->timer
);
853 /* Enable interrupts by setting the interrupt mask. */
854 iowrite16(DEFAULT_INTR
, ioaddr
+ IntrEnable
);
859 static void check_duplex(struct net_device
*dev
)
861 struct netdev_private
*np
= netdev_priv(dev
);
862 void __iomem
*ioaddr
= np
->base
;
863 int mii_lpa
= mdio_read(dev
, np
->phys
[0], MII_LPA
);
864 int negotiated
= mii_lpa
& np
->mii_if
.advertising
;
868 if (!np
->an_enable
|| mii_lpa
== 0xffff) {
869 if (np
->mii_if
.full_duplex
)
870 iowrite16 (ioread16 (ioaddr
+ MACCtrl0
) | EnbFullDuplex
,
875 /* Autonegotiation */
876 duplex
= (negotiated
& 0x0100) || (negotiated
& 0x01C0) == 0x0040;
877 if (np
->mii_if
.full_duplex
!= duplex
) {
878 np
->mii_if
.full_duplex
= duplex
;
879 if (netif_msg_link(np
))
880 printk(KERN_INFO
"%s: Setting %s-duplex based on MII #%d "
881 "negotiated capability %4.4x.\n", dev
->name
,
882 duplex
? "full" : "half", np
->phys
[0], negotiated
);
883 iowrite16(ioread16(ioaddr
+ MACCtrl0
) | duplex
? 0x20 : 0, ioaddr
+ MACCtrl0
);
887 static void netdev_timer(unsigned long data
)
889 struct net_device
*dev
= (struct net_device
*)data
;
890 struct netdev_private
*np
= netdev_priv(dev
);
891 void __iomem
*ioaddr
= np
->base
;
892 int next_tick
= 10*HZ
;
894 if (netif_msg_timer(np
)) {
895 printk(KERN_DEBUG
"%s: Media selection timer tick, intr status %4.4x, "
897 dev
->name
, ioread16(ioaddr
+ IntrEnable
),
898 ioread8(ioaddr
+ TxStatus
), ioread32(ioaddr
+ RxStatus
));
901 np
->timer
.expires
= jiffies
+ next_tick
;
902 add_timer(&np
->timer
);
905 static void tx_timeout(struct net_device
*dev
)
907 struct netdev_private
*np
= netdev_priv(dev
);
908 void __iomem
*ioaddr
= np
->base
;
911 netif_stop_queue(dev
);
912 tasklet_disable(&np
->tx_tasklet
);
913 iowrite16(0, ioaddr
+ IntrEnable
);
914 printk(KERN_WARNING
"%s: Transmit timed out, TxStatus %2.2x "
916 " resetting...\n", dev
->name
, ioread8(ioaddr
+ TxStatus
),
917 ioread8(ioaddr
+ TxFrameId
));
921 for (i
=0; i
<TX_RING_SIZE
; i
++) {
922 printk(KERN_DEBUG
"%02x %08llx %08x %08x(%02x) %08x %08x\n", i
,
923 (unsigned long long)(np
->tx_ring_dma
+ i
*sizeof(*np
->tx_ring
)),
924 le32_to_cpu(np
->tx_ring
[i
].next_desc
),
925 le32_to_cpu(np
->tx_ring
[i
].status
),
926 (le32_to_cpu(np
->tx_ring
[i
].status
) >> 2) & 0xff,
927 le32_to_cpu(np
->tx_ring
[i
].frag
[0].addr
),
928 le32_to_cpu(np
->tx_ring
[i
].frag
[0].length
));
930 printk(KERN_DEBUG
"TxListPtr=%08x netif_queue_stopped=%d\n",
931 ioread32(np
->base
+ TxListPtr
),
932 netif_queue_stopped(dev
));
933 printk(KERN_DEBUG
"cur_tx=%d(%02x) dirty_tx=%d(%02x)\n",
934 np
->cur_tx
, np
->cur_tx
% TX_RING_SIZE
,
935 np
->dirty_tx
, np
->dirty_tx
% TX_RING_SIZE
);
936 printk(KERN_DEBUG
"cur_rx=%d dirty_rx=%d\n", np
->cur_rx
, np
->dirty_rx
);
937 printk(KERN_DEBUG
"cur_task=%d\n", np
->cur_task
);
939 spin_lock_irqsave(&np
->lock
, flag
);
941 /* Stop and restart the chip's Tx processes . */
943 spin_unlock_irqrestore(&np
->lock
, flag
);
947 dev
->trans_start
= jiffies
;
948 np
->stats
.tx_errors
++;
949 if (np
->cur_tx
- np
->dirty_tx
< TX_QUEUE_LEN
- 4) {
950 netif_wake_queue(dev
);
952 iowrite16(DEFAULT_INTR
, ioaddr
+ IntrEnable
);
953 tasklet_enable(&np
->tx_tasklet
);
957 /* Initialize the Rx and Tx rings, along with various 'dev' bits. */
958 static void init_ring(struct net_device
*dev
)
960 struct netdev_private
*np
= netdev_priv(dev
);
963 np
->cur_rx
= np
->cur_tx
= 0;
964 np
->dirty_rx
= np
->dirty_tx
= 0;
967 np
->rx_buf_sz
= (dev
->mtu
<= 1520 ? PKT_BUF_SZ
: dev
->mtu
+ 16);
969 /* Initialize all Rx descriptors. */
970 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
971 np
->rx_ring
[i
].next_desc
= cpu_to_le32(np
->rx_ring_dma
+
972 ((i
+1)%RX_RING_SIZE
)*sizeof(*np
->rx_ring
));
973 np
->rx_ring
[i
].status
= 0;
974 np
->rx_ring
[i
].frag
[0].length
= 0;
975 np
->rx_skbuff
[i
] = NULL
;
978 /* Fill in the Rx buffers. Handle allocation failure gracefully. */
979 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
980 struct sk_buff
*skb
= dev_alloc_skb(np
->rx_buf_sz
);
981 np
->rx_skbuff
[i
] = skb
;
984 skb
->dev
= dev
; /* Mark as being used by this device. */
985 skb_reserve(skb
, 2); /* 16 byte align the IP header. */
986 np
->rx_ring
[i
].frag
[0].addr
= cpu_to_le32(
987 pci_map_single(np
->pci_dev
, skb
->data
, np
->rx_buf_sz
,
988 PCI_DMA_FROMDEVICE
));
989 np
->rx_ring
[i
].frag
[0].length
= cpu_to_le32(np
->rx_buf_sz
| LastFrag
);
991 np
->dirty_rx
= (unsigned int)(i
- RX_RING_SIZE
);
993 for (i
= 0; i
< TX_RING_SIZE
; i
++) {
994 np
->tx_skbuff
[i
] = NULL
;
995 np
->tx_ring
[i
].status
= 0;
1000 static void tx_poll (unsigned long data
)
1002 struct net_device
*dev
= (struct net_device
*)data
;
1003 struct netdev_private
*np
= netdev_priv(dev
);
1004 unsigned head
= np
->cur_task
% TX_RING_SIZE
;
1005 struct netdev_desc
*txdesc
=
1006 &np
->tx_ring
[(np
->cur_tx
- 1) % TX_RING_SIZE
];
1008 /* Chain the next pointer */
1009 for (; np
->cur_tx
- np
->cur_task
> 0; np
->cur_task
++) {
1010 int entry
= np
->cur_task
% TX_RING_SIZE
;
1011 txdesc
= &np
->tx_ring
[entry
];
1013 np
->last_tx
->next_desc
= cpu_to_le32(np
->tx_ring_dma
+
1014 entry
*sizeof(struct netdev_desc
));
1016 np
->last_tx
= txdesc
;
1018 /* Indicate the latest descriptor of tx ring */
1019 txdesc
->status
|= cpu_to_le32(DescIntrOnTx
);
1021 if (ioread32 (np
->base
+ TxListPtr
) == 0)
1022 iowrite32 (np
->tx_ring_dma
+ head
* sizeof(struct netdev_desc
),
1023 np
->base
+ TxListPtr
);
1028 start_tx (struct sk_buff
*skb
, struct net_device
*dev
)
1030 struct netdev_private
*np
= netdev_priv(dev
);
1031 struct netdev_desc
*txdesc
;
1034 /* Calculate the next Tx descriptor entry. */
1035 entry
= np
->cur_tx
% TX_RING_SIZE
;
1036 np
->tx_skbuff
[entry
] = skb
;
1037 txdesc
= &np
->tx_ring
[entry
];
1039 txdesc
->next_desc
= 0;
1040 txdesc
->status
= cpu_to_le32 ((entry
<< 2) | DisableAlign
);
1041 txdesc
->frag
[0].addr
= cpu_to_le32 (pci_map_single (np
->pci_dev
, skb
->data
,
1044 txdesc
->frag
[0].length
= cpu_to_le32 (skb
->len
| LastFrag
);
1046 /* Increment cur_tx before tasklet_schedule() */
1049 /* Schedule a tx_poll() task */
1050 tasklet_schedule(&np
->tx_tasklet
);
1052 /* On some architectures: explicitly flush cache lines here. */
1053 if (np
->cur_tx
- np
->dirty_tx
< TX_QUEUE_LEN
- 1
1054 && !netif_queue_stopped(dev
)) {
1057 netif_stop_queue (dev
);
1059 dev
->trans_start
= jiffies
;
1060 if (netif_msg_tx_queued(np
)) {
1062 "%s: Transmit frame #%d queued in slot %d.\n",
1063 dev
->name
, np
->cur_tx
, entry
);
1068 /* Reset hardware tx and free all of tx buffers */
1070 reset_tx (struct net_device
*dev
)
1072 struct netdev_private
*np
= netdev_priv(dev
);
1073 void __iomem
*ioaddr
= np
->base
;
1074 struct sk_buff
*skb
;
1076 int irq
= in_interrupt();
1078 /* Reset tx logic, TxListPtr will be cleaned */
1079 iowrite16 (TxDisable
, ioaddr
+ MACCtrl1
);
1080 sundance_reset(dev
, (NetworkReset
|FIFOReset
|DMAReset
|TxReset
) << 16);
1082 /* free all tx skbuff */
1083 for (i
= 0; i
< TX_RING_SIZE
; i
++) {
1084 skb
= np
->tx_skbuff
[i
];
1086 pci_unmap_single(np
->pci_dev
,
1087 np
->tx_ring
[i
].frag
[0].addr
, skb
->len
,
1090 dev_kfree_skb_irq (skb
);
1092 dev_kfree_skb (skb
);
1093 np
->tx_skbuff
[i
] = NULL
;
1094 np
->stats
.tx_dropped
++;
1097 np
->cur_tx
= np
->dirty_tx
= 0;
1099 iowrite16 (StatsEnable
| RxEnable
| TxEnable
, ioaddr
+ MACCtrl1
);
1103 /* The interrupt handler cleans up after the Tx thread,
1104 and schedule a Rx thread work */
1105 static irqreturn_t
intr_handler(int irq
, void *dev_instance
, struct pt_regs
*rgs
)
1107 struct net_device
*dev
= (struct net_device
*)dev_instance
;
1108 struct netdev_private
*np
= netdev_priv(dev
);
1109 void __iomem
*ioaddr
= np
->base
;
1117 int intr_status
= ioread16(ioaddr
+ IntrStatus
);
1118 iowrite16(intr_status
, ioaddr
+ IntrStatus
);
1120 if (netif_msg_intr(np
))
1121 printk(KERN_DEBUG
"%s: Interrupt, status %4.4x.\n",
1122 dev
->name
, intr_status
);
1124 if (!(intr_status
& DEFAULT_INTR
))
1129 if (intr_status
& (IntrRxDMADone
)) {
1130 iowrite16(DEFAULT_INTR
& ~(IntrRxDone
|IntrRxDMADone
),
1131 ioaddr
+ IntrEnable
);
1133 np
->budget
= RX_BUDGET
;
1134 tasklet_schedule(&np
->rx_tasklet
);
1136 if (intr_status
& (IntrTxDone
| IntrDrvRqst
)) {
1137 tx_status
= ioread16 (ioaddr
+ TxStatus
);
1138 for (tx_cnt
=32; tx_status
& 0x80; --tx_cnt
) {
1139 if (netif_msg_tx_done(np
))
1141 ("%s: Transmit status is %2.2x.\n",
1142 dev
->name
, tx_status
);
1143 if (tx_status
& 0x1e) {
1144 if (netif_msg_tx_err(np
))
1145 printk("%s: Transmit error status %4.4x.\n",
1146 dev
->name
, tx_status
);
1147 np
->stats
.tx_errors
++;
1148 if (tx_status
& 0x10)
1149 np
->stats
.tx_fifo_errors
++;
1150 if (tx_status
& 0x08)
1151 np
->stats
.collisions
++;
1152 if (tx_status
& 0x04)
1153 np
->stats
.tx_fifo_errors
++;
1154 if (tx_status
& 0x02)
1155 np
->stats
.tx_window_errors
++;
1157 ** This reset has been verified on
1158 ** DFE-580TX boards ! phdm@macqel.be.
1160 if (tx_status
& 0x10) { /* TxUnderrun */
1161 unsigned short txthreshold
;
1163 txthreshold
= ioread16 (ioaddr
+ TxStartThresh
);
1164 /* Restart Tx FIFO and transmitter */
1165 sundance_reset(dev
, (NetworkReset
|FIFOReset
|TxReset
) << 16);
1166 iowrite16 (txthreshold
, ioaddr
+ TxStartThresh
);
1167 /* No need to reset the Tx pointer here */
1169 /* Restart the Tx. */
1170 iowrite16 (TxEnable
, ioaddr
+ MACCtrl1
);
1172 /* Yup, this is a documentation bug. It cost me *hours*. */
1173 iowrite16 (0, ioaddr
+ TxStatus
);
1175 iowrite32(5000, ioaddr
+ DownCounter
);
1178 tx_status
= ioread16 (ioaddr
+ TxStatus
);
1180 hw_frame_id
= (tx_status
>> 8) & 0xff;
1182 hw_frame_id
= ioread8(ioaddr
+ TxFrameId
);
1185 if (np
->pci_rev_id
>= 0x14) {
1186 spin_lock(&np
->lock
);
1187 for (; np
->cur_tx
- np
->dirty_tx
> 0; np
->dirty_tx
++) {
1188 int entry
= np
->dirty_tx
% TX_RING_SIZE
;
1189 struct sk_buff
*skb
;
1191 sw_frame_id
= (le32_to_cpu(
1192 np
->tx_ring
[entry
].status
) >> 2) & 0xff;
1193 if (sw_frame_id
== hw_frame_id
&&
1194 !(le32_to_cpu(np
->tx_ring
[entry
].status
)
1197 if (sw_frame_id
== (hw_frame_id
+ 1) %
1200 skb
= np
->tx_skbuff
[entry
];
1201 /* Free the original skb. */
1202 pci_unmap_single(np
->pci_dev
,
1203 np
->tx_ring
[entry
].frag
[0].addr
,
1204 skb
->len
, PCI_DMA_TODEVICE
);
1205 dev_kfree_skb_irq (np
->tx_skbuff
[entry
]);
1206 np
->tx_skbuff
[entry
] = NULL
;
1207 np
->tx_ring
[entry
].frag
[0].addr
= 0;
1208 np
->tx_ring
[entry
].frag
[0].length
= 0;
1210 spin_unlock(&np
->lock
);
1212 spin_lock(&np
->lock
);
1213 for (; np
->cur_tx
- np
->dirty_tx
> 0; np
->dirty_tx
++) {
1214 int entry
= np
->dirty_tx
% TX_RING_SIZE
;
1215 struct sk_buff
*skb
;
1216 if (!(le32_to_cpu(np
->tx_ring
[entry
].status
)
1219 skb
= np
->tx_skbuff
[entry
];
1220 /* Free the original skb. */
1221 pci_unmap_single(np
->pci_dev
,
1222 np
->tx_ring
[entry
].frag
[0].addr
,
1223 skb
->len
, PCI_DMA_TODEVICE
);
1224 dev_kfree_skb_irq (np
->tx_skbuff
[entry
]);
1225 np
->tx_skbuff
[entry
] = NULL
;
1226 np
->tx_ring
[entry
].frag
[0].addr
= 0;
1227 np
->tx_ring
[entry
].frag
[0].length
= 0;
1229 spin_unlock(&np
->lock
);
1232 if (netif_queue_stopped(dev
) &&
1233 np
->cur_tx
- np
->dirty_tx
< TX_QUEUE_LEN
- 4) {
1234 /* The ring is no longer full, clear busy flag. */
1235 netif_wake_queue (dev
);
1237 /* Abnormal error summary/uncommon events handlers. */
1238 if (intr_status
& (IntrPCIErr
| LinkChange
| StatsMax
))
1239 netdev_error(dev
, intr_status
);
1241 if (netif_msg_intr(np
))
1242 printk(KERN_DEBUG
"%s: exiting interrupt, status=%#4.4x.\n",
1243 dev
->name
, ioread16(ioaddr
+ IntrStatus
));
1244 return IRQ_RETVAL(handled
);
1247 static void rx_poll(unsigned long data
)
1249 struct net_device
*dev
= (struct net_device
*)data
;
1250 struct netdev_private
*np
= netdev_priv(dev
);
1251 int entry
= np
->cur_rx
% RX_RING_SIZE
;
1252 int boguscnt
= np
->budget
;
1253 void __iomem
*ioaddr
= np
->base
;
1256 /* If EOP is set on the next entry, it's a new packet. Send it up. */
1258 struct netdev_desc
*desc
= &(np
->rx_ring
[entry
]);
1259 u32 frame_status
= le32_to_cpu(desc
->status
);
1262 if (--boguscnt
< 0) {
1265 if (!(frame_status
& DescOwn
))
1267 pkt_len
= frame_status
& 0x1fff; /* Chip omits the CRC. */
1268 if (netif_msg_rx_status(np
))
1269 printk(KERN_DEBUG
" netdev_rx() status was %8.8x.\n",
1271 if (frame_status
& 0x001f4000) {
1272 /* There was a error. */
1273 if (netif_msg_rx_err(np
))
1274 printk(KERN_DEBUG
" netdev_rx() Rx error was %8.8x.\n",
1276 np
->stats
.rx_errors
++;
1277 if (frame_status
& 0x00100000) np
->stats
.rx_length_errors
++;
1278 if (frame_status
& 0x00010000) np
->stats
.rx_fifo_errors
++;
1279 if (frame_status
& 0x00060000) np
->stats
.rx_frame_errors
++;
1280 if (frame_status
& 0x00080000) np
->stats
.rx_crc_errors
++;
1281 if (frame_status
& 0x00100000) {
1282 printk(KERN_WARNING
"%s: Oversized Ethernet frame,"
1284 dev
->name
, frame_status
);
1287 struct sk_buff
*skb
;
1288 #ifndef final_version
1289 if (netif_msg_rx_status(np
))
1290 printk(KERN_DEBUG
" netdev_rx() normal Rx pkt length %d"
1291 ", bogus_cnt %d.\n",
1294 /* Check if the packet is long enough to accept without copying
1295 to a minimally-sized skbuff. */
1296 if (pkt_len
< rx_copybreak
1297 && (skb
= dev_alloc_skb(pkt_len
+ 2)) != NULL
) {
1299 skb_reserve(skb
, 2); /* 16 byte align the IP header */
1300 pci_dma_sync_single_for_cpu(np
->pci_dev
,
1303 PCI_DMA_FROMDEVICE
);
1305 eth_copy_and_sum(skb
, np
->rx_skbuff
[entry
]->data
, pkt_len
, 0);
1306 pci_dma_sync_single_for_device(np
->pci_dev
,
1309 PCI_DMA_FROMDEVICE
);
1310 skb_put(skb
, pkt_len
);
1312 pci_unmap_single(np
->pci_dev
,
1315 PCI_DMA_FROMDEVICE
);
1316 skb_put(skb
= np
->rx_skbuff
[entry
], pkt_len
);
1317 np
->rx_skbuff
[entry
] = NULL
;
1319 skb
->protocol
= eth_type_trans(skb
, dev
);
1320 /* Note: checksum -> skb->ip_summed = CHECKSUM_UNNECESSARY; */
1322 dev
->last_rx
= jiffies
;
1324 entry
= (entry
+ 1) % RX_RING_SIZE
;
1329 np
->budget
-= received
;
1330 iowrite16(DEFAULT_INTR
, ioaddr
+ IntrEnable
);
1338 np
->budget
-= received
;
1339 if (np
->budget
<= 0)
1340 np
->budget
= RX_BUDGET
;
1341 tasklet_schedule(&np
->rx_tasklet
);
1345 static void refill_rx (struct net_device
*dev
)
1347 struct netdev_private
*np
= netdev_priv(dev
);
1351 /* Refill the Rx ring buffers. */
1352 for (;(np
->cur_rx
- np
->dirty_rx
+ RX_RING_SIZE
) % RX_RING_SIZE
> 0;
1353 np
->dirty_rx
= (np
->dirty_rx
+ 1) % RX_RING_SIZE
) {
1354 struct sk_buff
*skb
;
1355 entry
= np
->dirty_rx
% RX_RING_SIZE
;
1356 if (np
->rx_skbuff
[entry
] == NULL
) {
1357 skb
= dev_alloc_skb(np
->rx_buf_sz
);
1358 np
->rx_skbuff
[entry
] = skb
;
1360 break; /* Better luck next round. */
1361 skb
->dev
= dev
; /* Mark as being used by this device. */
1362 skb_reserve(skb
, 2); /* Align IP on 16 byte boundaries */
1363 np
->rx_ring
[entry
].frag
[0].addr
= cpu_to_le32(
1364 pci_map_single(np
->pci_dev
, skb
->data
,
1365 np
->rx_buf_sz
, PCI_DMA_FROMDEVICE
));
1367 /* Perhaps we need not reset this field. */
1368 np
->rx_ring
[entry
].frag
[0].length
=
1369 cpu_to_le32(np
->rx_buf_sz
| LastFrag
);
1370 np
->rx_ring
[entry
].status
= 0;
1375 static void netdev_error(struct net_device
*dev
, int intr_status
)
1377 struct netdev_private
*np
= netdev_priv(dev
);
1378 void __iomem
*ioaddr
= np
->base
;
1379 u16 mii_ctl
, mii_advertise
, mii_lpa
;
1382 if (intr_status
& LinkChange
) {
1383 if (np
->an_enable
) {
1384 mii_advertise
= mdio_read (dev
, np
->phys
[0], MII_ADVERTISE
);
1385 mii_lpa
= mdio_read (dev
, np
->phys
[0], MII_LPA
);
1386 mii_advertise
&= mii_lpa
;
1387 printk (KERN_INFO
"%s: Link changed: ", dev
->name
);
1388 if (mii_advertise
& ADVERTISE_100FULL
) {
1390 printk ("100Mbps, full duplex\n");
1391 } else if (mii_advertise
& ADVERTISE_100HALF
) {
1393 printk ("100Mbps, half duplex\n");
1394 } else if (mii_advertise
& ADVERTISE_10FULL
) {
1396 printk ("10Mbps, full duplex\n");
1397 } else if (mii_advertise
& ADVERTISE_10HALF
) {
1399 printk ("10Mbps, half duplex\n");
1404 mii_ctl
= mdio_read (dev
, np
->phys
[0], MII_BMCR
);
1405 speed
= (mii_ctl
& BMCR_SPEED100
) ? 100 : 10;
1407 printk (KERN_INFO
"%s: Link changed: %dMbps ,",
1409 printk ("%s duplex.\n", (mii_ctl
& BMCR_FULLDPLX
) ?
1413 if (np
->flowctrl
&& np
->mii_if
.full_duplex
) {
1414 iowrite16(ioread16(ioaddr
+ MulticastFilter1
+2) | 0x0200,
1415 ioaddr
+ MulticastFilter1
+2);
1416 iowrite16(ioread16(ioaddr
+ MACCtrl0
) | EnbFlowCtrl
,
1420 if (intr_status
& StatsMax
) {
1423 if (intr_status
& IntrPCIErr
) {
1424 printk(KERN_ERR
"%s: Something Wicked happened! %4.4x.\n",
1425 dev
->name
, intr_status
);
1426 /* We must do a global reset of DMA to continue. */
1430 static struct net_device_stats
*get_stats(struct net_device
*dev
)
1432 struct netdev_private
*np
= netdev_priv(dev
);
1433 void __iomem
*ioaddr
= np
->base
;
1436 /* We should lock this segment of code for SMP eventually, although
1437 the vulnerability window is very small and statistics are
1439 /* The chip only need report frame silently dropped. */
1440 np
->stats
.rx_missed_errors
+= ioread8(ioaddr
+ RxMissed
);
1441 np
->stats
.tx_packets
+= ioread16(ioaddr
+ TxFramesOK
);
1442 np
->stats
.rx_packets
+= ioread16(ioaddr
+ RxFramesOK
);
1443 np
->stats
.collisions
+= ioread8(ioaddr
+ StatsLateColl
);
1444 np
->stats
.collisions
+= ioread8(ioaddr
+ StatsMultiColl
);
1445 np
->stats
.collisions
+= ioread8(ioaddr
+ StatsOneColl
);
1446 np
->stats
.tx_carrier_errors
+= ioread8(ioaddr
+ StatsCarrierError
);
1447 ioread8(ioaddr
+ StatsTxDefer
);
1448 for (i
= StatsTxDefer
; i
<= StatsMcastRx
; i
++)
1449 ioread8(ioaddr
+ i
);
1450 np
->stats
.tx_bytes
+= ioread16(ioaddr
+ TxOctetsLow
);
1451 np
->stats
.tx_bytes
+= ioread16(ioaddr
+ TxOctetsHigh
) << 16;
1452 np
->stats
.rx_bytes
+= ioread16(ioaddr
+ RxOctetsLow
);
1453 np
->stats
.rx_bytes
+= ioread16(ioaddr
+ RxOctetsHigh
) << 16;
1458 static void set_rx_mode(struct net_device
*dev
)
1460 struct netdev_private
*np
= netdev_priv(dev
);
1461 void __iomem
*ioaddr
= np
->base
;
1462 u16 mc_filter
[4]; /* Multicast hash filter */
1466 if (dev
->flags
& IFF_PROMISC
) { /* Set promiscuous. */
1467 memset(mc_filter
, 0xff, sizeof(mc_filter
));
1468 rx_mode
= AcceptBroadcast
| AcceptMulticast
| AcceptAll
| AcceptMyPhys
;
1469 } else if ((dev
->mc_count
> multicast_filter_limit
)
1470 || (dev
->flags
& IFF_ALLMULTI
)) {
1471 /* Too many to match, or accept all multicasts. */
1472 memset(mc_filter
, 0xff, sizeof(mc_filter
));
1473 rx_mode
= AcceptBroadcast
| AcceptMulticast
| AcceptMyPhys
;
1474 } else if (dev
->mc_count
) {
1475 struct dev_mc_list
*mclist
;
1479 memset (mc_filter
, 0, sizeof (mc_filter
));
1480 for (i
= 0, mclist
= dev
->mc_list
; mclist
&& i
< dev
->mc_count
;
1481 i
++, mclist
= mclist
->next
) {
1482 crc
= ether_crc_le (ETH_ALEN
, mclist
->dmi_addr
);
1483 for (index
=0, bit
=0; bit
< 6; bit
++, crc
<<= 1)
1484 if (crc
& 0x80000000) index
|= 1 << bit
;
1485 mc_filter
[index
/16] |= (1 << (index
% 16));
1487 rx_mode
= AcceptBroadcast
| AcceptMultiHash
| AcceptMyPhys
;
1489 iowrite8(AcceptBroadcast
| AcceptMyPhys
, ioaddr
+ RxMode
);
1492 if (np
->mii_if
.full_duplex
&& np
->flowctrl
)
1493 mc_filter
[3] |= 0x0200;
1495 for (i
= 0; i
< 4; i
++)
1496 iowrite16(mc_filter
[i
], ioaddr
+ MulticastFilter0
+ i
*2);
1497 iowrite8(rx_mode
, ioaddr
+ RxMode
);
1500 static int __set_mac_addr(struct net_device
*dev
)
1502 struct netdev_private
*np
= netdev_priv(dev
);
1505 addr16
= (dev
->dev_addr
[0] | (dev
->dev_addr
[1] << 8));
1506 iowrite16(addr16
, np
->base
+ StationAddr
);
1507 addr16
= (dev
->dev_addr
[2] | (dev
->dev_addr
[3] << 8));
1508 iowrite16(addr16
, np
->base
+ StationAddr
+2);
1509 addr16
= (dev
->dev_addr
[4] | (dev
->dev_addr
[5] << 8));
1510 iowrite16(addr16
, np
->base
+ StationAddr
+4);
1514 static int check_if_running(struct net_device
*dev
)
1516 if (!netif_running(dev
))
1521 static void get_drvinfo(struct net_device
*dev
, struct ethtool_drvinfo
*info
)
1523 struct netdev_private
*np
= netdev_priv(dev
);
1524 strcpy(info
->driver
, DRV_NAME
);
1525 strcpy(info
->version
, DRV_VERSION
);
1526 strcpy(info
->bus_info
, pci_name(np
->pci_dev
));
1529 static int get_settings(struct net_device
*dev
, struct ethtool_cmd
*ecmd
)
1531 struct netdev_private
*np
= netdev_priv(dev
);
1532 spin_lock_irq(&np
->lock
);
1533 mii_ethtool_gset(&np
->mii_if
, ecmd
);
1534 spin_unlock_irq(&np
->lock
);
1538 static int set_settings(struct net_device
*dev
, struct ethtool_cmd
*ecmd
)
1540 struct netdev_private
*np
= netdev_priv(dev
);
1542 spin_lock_irq(&np
->lock
);
1543 res
= mii_ethtool_sset(&np
->mii_if
, ecmd
);
1544 spin_unlock_irq(&np
->lock
);
1548 static int nway_reset(struct net_device
*dev
)
1550 struct netdev_private
*np
= netdev_priv(dev
);
1551 return mii_nway_restart(&np
->mii_if
);
1554 static u32
get_link(struct net_device
*dev
)
1556 struct netdev_private
*np
= netdev_priv(dev
);
1557 return mii_link_ok(&np
->mii_if
);
1560 static u32
get_msglevel(struct net_device
*dev
)
1562 struct netdev_private
*np
= netdev_priv(dev
);
1563 return np
->msg_enable
;
1566 static void set_msglevel(struct net_device
*dev
, u32 val
)
1568 struct netdev_private
*np
= netdev_priv(dev
);
1569 np
->msg_enable
= val
;
1572 static const struct ethtool_ops ethtool_ops
= {
1573 .begin
= check_if_running
,
1574 .get_drvinfo
= get_drvinfo
,
1575 .get_settings
= get_settings
,
1576 .set_settings
= set_settings
,
1577 .nway_reset
= nway_reset
,
1578 .get_link
= get_link
,
1579 .get_msglevel
= get_msglevel
,
1580 .set_msglevel
= set_msglevel
,
1581 .get_perm_addr
= ethtool_op_get_perm_addr
,
1584 static int netdev_ioctl(struct net_device
*dev
, struct ifreq
*rq
, int cmd
)
1586 struct netdev_private
*np
= netdev_priv(dev
);
1587 void __iomem
*ioaddr
= np
->base
;
1591 if (!netif_running(dev
))
1594 spin_lock_irq(&np
->lock
);
1595 rc
= generic_mii_ioctl(&np
->mii_if
, if_mii(rq
), cmd
, NULL
);
1596 spin_unlock_irq(&np
->lock
);
1598 case SIOCDEVPRIVATE
:
1599 for (i
=0; i
<TX_RING_SIZE
; i
++) {
1600 printk(KERN_DEBUG
"%02x %08llx %08x %08x(%02x) %08x %08x\n", i
,
1601 (unsigned long long)(np
->tx_ring_dma
+ i
*sizeof(*np
->tx_ring
)),
1602 le32_to_cpu(np
->tx_ring
[i
].next_desc
),
1603 le32_to_cpu(np
->tx_ring
[i
].status
),
1604 (le32_to_cpu(np
->tx_ring
[i
].status
) >> 2)
1606 le32_to_cpu(np
->tx_ring
[i
].frag
[0].addr
),
1607 le32_to_cpu(np
->tx_ring
[i
].frag
[0].length
));
1609 printk(KERN_DEBUG
"TxListPtr=%08x netif_queue_stopped=%d\n",
1610 ioread32(np
->base
+ TxListPtr
),
1611 netif_queue_stopped(dev
));
1612 printk(KERN_DEBUG
"cur_tx=%d(%02x) dirty_tx=%d(%02x)\n",
1613 np
->cur_tx
, np
->cur_tx
% TX_RING_SIZE
,
1614 np
->dirty_tx
, np
->dirty_tx
% TX_RING_SIZE
);
1615 printk(KERN_DEBUG
"cur_rx=%d dirty_rx=%d\n", np
->cur_rx
, np
->dirty_rx
);
1616 printk(KERN_DEBUG
"cur_task=%d\n", np
->cur_task
);
1617 printk(KERN_DEBUG
"TxStatus=%04x\n", ioread16(ioaddr
+ TxStatus
));
1625 static int netdev_close(struct net_device
*dev
)
1627 struct netdev_private
*np
= netdev_priv(dev
);
1628 void __iomem
*ioaddr
= np
->base
;
1629 struct sk_buff
*skb
;
1632 netif_stop_queue(dev
);
1634 if (netif_msg_ifdown(np
)) {
1635 printk(KERN_DEBUG
"%s: Shutting down ethercard, status was Tx %2.2x "
1636 "Rx %4.4x Int %2.2x.\n",
1637 dev
->name
, ioread8(ioaddr
+ TxStatus
),
1638 ioread32(ioaddr
+ RxStatus
), ioread16(ioaddr
+ IntrStatus
));
1639 printk(KERN_DEBUG
"%s: Queue pointers were Tx %d / %d, Rx %d / %d.\n",
1640 dev
->name
, np
->cur_tx
, np
->dirty_tx
, np
->cur_rx
, np
->dirty_rx
);
1643 /* Disable interrupts by clearing the interrupt mask. */
1644 iowrite16(0x0000, ioaddr
+ IntrEnable
);
1646 /* Stop the chip's Tx and Rx processes. */
1647 iowrite16(TxDisable
| RxDisable
| StatsDisable
, ioaddr
+ MACCtrl1
);
1649 /* Wait and kill tasklet */
1650 tasklet_kill(&np
->rx_tasklet
);
1651 tasklet_kill(&np
->tx_tasklet
);
1654 if (netif_msg_hw(np
)) {
1655 printk("\n"KERN_DEBUG
" Tx ring at %8.8x:\n",
1656 (int)(np
->tx_ring_dma
));
1657 for (i
= 0; i
< TX_RING_SIZE
; i
++)
1658 printk(" #%d desc. %4.4x %8.8x %8.8x.\n",
1659 i
, np
->tx_ring
[i
].status
, np
->tx_ring
[i
].frag
[0].addr
,
1660 np
->tx_ring
[i
].frag
[0].length
);
1661 printk("\n"KERN_DEBUG
" Rx ring %8.8x:\n",
1662 (int)(np
->rx_ring_dma
));
1663 for (i
= 0; i
< /*RX_RING_SIZE*/4 ; i
++) {
1664 printk(KERN_DEBUG
" #%d desc. %4.4x %4.4x %8.8x\n",
1665 i
, np
->rx_ring
[i
].status
, np
->rx_ring
[i
].frag
[0].addr
,
1666 np
->rx_ring
[i
].frag
[0].length
);
1669 #endif /* __i386__ debugging only */
1671 free_irq(dev
->irq
, dev
);
1673 del_timer_sync(&np
->timer
);
1675 /* Free all the skbuffs in the Rx queue. */
1676 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
1677 np
->rx_ring
[i
].status
= 0;
1678 np
->rx_ring
[i
].frag
[0].addr
= 0xBADF00D0; /* An invalid address. */
1679 skb
= np
->rx_skbuff
[i
];
1681 pci_unmap_single(np
->pci_dev
,
1682 np
->rx_ring
[i
].frag
[0].addr
, np
->rx_buf_sz
,
1683 PCI_DMA_FROMDEVICE
);
1685 np
->rx_skbuff
[i
] = NULL
;
1688 for (i
= 0; i
< TX_RING_SIZE
; i
++) {
1689 skb
= np
->tx_skbuff
[i
];
1691 pci_unmap_single(np
->pci_dev
,
1692 np
->tx_ring
[i
].frag
[0].addr
, skb
->len
,
1695 np
->tx_skbuff
[i
] = NULL
;
1702 static void __devexit
sundance_remove1 (struct pci_dev
*pdev
)
1704 struct net_device
*dev
= pci_get_drvdata(pdev
);
1707 struct netdev_private
*np
= netdev_priv(dev
);
1709 unregister_netdev(dev
);
1710 pci_free_consistent(pdev
, RX_TOTAL_SIZE
, np
->rx_ring
,
1712 pci_free_consistent(pdev
, TX_TOTAL_SIZE
, np
->tx_ring
,
1714 pci_iounmap(pdev
, np
->base
);
1715 pci_release_regions(pdev
);
1717 pci_set_drvdata(pdev
, NULL
);
1721 static struct pci_driver sundance_driver
= {
1723 .id_table
= sundance_pci_tbl
,
1724 .probe
= sundance_probe1
,
1725 .remove
= __devexit_p(sundance_remove1
),
1728 static int __init
sundance_init(void)
1730 /* when a module, this is printed whether or not devices are found in probe */
1734 return pci_register_driver(&sundance_driver
);
1737 static void __exit
sundance_exit(void)
1739 pci_unregister_driver(&sundance_driver
);
1742 module_init(sundance_init
);
1743 module_exit(sundance_exit
);