1 /* xircom_tulip_cb.c: A Xircom CBE-100 ethernet driver for Linux. */
3 Written/copyright 1994-1999 by Donald Becker.
5 This software may be used and distributed according to the terms
6 of the GNU General Public License, incorporated herein by reference.
8 The author may be reached as becker@scyld.com, or C/O
9 Scyld Computing Corporation
10 410 Severn Ave., Suite 210
13 -----------------------------------------------------------
15 Linux kernel-specific changes:
21 - Rewrite perfect filter/hash code
22 - Use interrupts for media changes
25 - Disallow negotiation of unsupported full-duplex modes
28 #define DRV_NAME "xircom_tulip_cb"
29 #define DRV_VERSION "0.91+LK1.1"
30 #define DRV_RELDATE "October 11, 2001"
34 /* A few user-configurable values. */
36 #define xircom_debug debug
38 static int xircom_debug
= XIRCOM_DEBUG
;
40 static int xircom_debug
= 1;
43 /* Maximum events (Rx packets, etc.) to handle at each interrupt. */
44 static int max_interrupt_work
= 25;
47 /* Used to pass the full-duplex flag, etc. */
48 static int full_duplex
[MAX_UNITS
];
49 static int options
[MAX_UNITS
];
50 static int mtu
[MAX_UNITS
]; /* Jumbo MTU for interfaces. */
52 /* Keep the ring sizes a power of two for efficiency.
53 Making the Tx ring too large decreases the effectiveness of channel
54 bonding and packet priority.
55 There are no ill effects from too-large receive rings. */
56 #define TX_RING_SIZE 16
57 #define RX_RING_SIZE 32
59 /* Set the copy breakpoint for the copy-only-tiny-buffer Rx structure. */
61 static int rx_copybreak
= 1518;
63 static int rx_copybreak
= 100;
67 Set the bus performance register.
68 Typical: Set 16 longword cache alignment, no burst limit.
69 Cache alignment bits 15:14 Burst length 13:8
70 0000 No alignment 0x00000000 unlimited 0800 8 longwords
71 4000 8 longwords 0100 1 longword 1000 16 longwords
72 8000 16 longwords 0200 2 longwords 2000 32 longwords
73 C000 32 longwords 0400 4 longwords
74 Warning: many older 486 systems are broken and require setting 0x00A04800
75 8 longword cache alignment, 8 longword burst.
76 ToDo: Non-Intel setting could be better.
79 #if defined(__alpha__) || defined(__ia64__) || defined(__x86_64__)
80 static int csr0
= 0x01A00000 | 0xE000;
81 #elif defined(__powerpc__)
82 static int csr0
= 0x01B00000 | 0x8000;
83 #elif defined(__sparc__)
84 static int csr0
= 0x01B00080 | 0x8000;
85 #elif defined(__i386__)
86 static int csr0
= 0x01A00000 | 0x8000;
88 #warning Processor architecture undefined!
89 static int csr0
= 0x00A00000 | 0x4800;
92 /* Operational parameters that usually are not changed. */
93 /* Time in jiffies before concluding the transmitter is hung. */
94 #define TX_TIMEOUT (4 * HZ)
95 #define PKT_BUF_SZ 1536 /* Size of each temporary Rx buffer.*/
96 #define PKT_SETUP_SZ 192 /* Size of the setup frame */
99 #define PCI_POWERMGMT 0x40
101 #include <linux/config.h>
102 #include <linux/module.h>
103 #include <linux/moduleparam.h>
104 #include <linux/kernel.h>
105 #include <linux/pci.h>
106 #include <linux/netdevice.h>
107 #include <linux/etherdevice.h>
108 #include <linux/delay.h>
109 #include <linux/init.h>
110 #include <linux/mii.h>
111 #include <linux/ethtool.h>
112 #include <linux/crc32.h>
115 #include <asm/processor.h> /* Processor type for cache alignment. */
116 #include <asm/uaccess.h>
119 /* These identify the driver base version and may not be removed. */
120 static char version
[] __devinitdata
=
121 KERN_INFO DRV_NAME
".c derived from tulip.c:v0.91 4/14/99 becker@scyld.com\n"
122 KERN_INFO
" unofficial 2.4.x kernel port, version " DRV_VERSION
", " DRV_RELDATE
"\n";
124 MODULE_AUTHOR("Donald Becker <becker@scyld.com>");
125 MODULE_DESCRIPTION("Xircom CBE-100 ethernet driver");
126 MODULE_LICENSE("GPL v2");
127 MODULE_VERSION(DRV_VERSION
);
129 module_param(debug
, int, 0);
130 module_param(max_interrupt_work
, int, 0);
131 module_param(rx_copybreak
, int, 0);
132 module_param(csr0
, int, 0);
134 module_param_array(options
, int, NULL
, 0);
135 module_param_array(full_duplex
, int, NULL
, 0);
137 #define RUN_AT(x) (jiffies + (x))
142 I. Board Compatibility
144 This device driver was forked from the driver for the DECchip "Tulip",
145 Digital's single-chip ethernet controllers for PCI. It supports Xircom's
146 almost-Tulip-compatible CBE-100 CardBus adapters.
148 II. Board-specific settings
150 PCI bus devices are configured by the system at boot time, so no jumpers
151 need to be set on the board. The system BIOS preferably should assign the
152 PCI INTA signal to an otherwise unused system IRQ line.
154 III. Driver operation
158 The Xircom can use either ring buffers or lists of Tx and Rx descriptors.
159 This driver uses statically allocated rings of Rx and Tx descriptors, set at
160 compile time by RX/TX_RING_SIZE. This version of the driver allocates skbuffs
161 for the Rx ring buffers at open() time and passes the skb->data field to the
162 Xircom as receive data buffers. When an incoming frame is less than
163 RX_COPYBREAK bytes long, a fresh skbuff is allocated and the frame is
164 copied to the new skbuff. When the incoming frame is larger, the skbuff is
165 passed directly up the protocol stack and replaced by a newly allocated
168 The RX_COPYBREAK value is chosen to trade-off the memory wasted by
169 using a full-sized skbuff for small frames vs. the copying costs of larger
170 frames. For small frames the copying cost is negligible (esp. considering
171 that we are pre-loading the cache with immediately useful header
172 information). For large frames the copying cost is non-trivial, and the
173 larger copy might flush the cache of useful data. A subtle aspect of this
174 choice is that the Xircom only receives into longword aligned buffers, thus
175 the IP header at offset 14 isn't longword aligned for further processing.
176 Copied frames are put into the new skbuff at an offset of "+2", thus copying
177 has the beneficial effect of aligning the IP header and preloading the
180 IIIC. Synchronization
181 The driver runs as two independent, single-threaded flows of control. One
182 is the send-packet routine, which enforces single-threaded use by the
183 dev->tbusy flag. The other thread is the interrupt handler, which is single
184 threaded by the hardware and other software.
186 The send packet thread has partial control over the Tx ring and 'dev->tbusy'
187 flag. It sets the tbusy flag whenever it's queuing a Tx packet. If the next
188 queue slot is empty, it clears the tbusy flag when finished otherwise it sets
189 the 'tp->tx_full' flag.
191 The interrupt handler has exclusive control over the Rx ring and records stats
192 from the Tx ring. (The Tx-done interrupt can't be selectively turned off, so
193 we can't avoid the interrupt overhead by having the Tx routine reap the Tx
194 stats.) After reaping the stats, it marks the queue entry as empty by setting
195 the 'base' to zero. Iff the 'tp->tx_full' flag is set, it clears both the
196 tx_full and tbusy flags.
202 http://cesdis.gsfc.nasa.gov/linux/misc/NWay.html
203 http://www.digital.com (search for current 21*4* datasheets and "21X4 SROM")
204 http://www.national.com/pf/DP/DP83840A.html
210 /* A full-duplex map for media types. */
212 MediaIsFD
= 1, MediaAlwaysFD
=2, MediaIsMII
=4, MediaIsFx
=8,
214 static const char media_cap
[] =
215 {0,0,0,16, 3,19,16,24, 27,4,7,5, 0,20,23,20 };
217 /* Offsets to the Command and Status Registers, "CSRs". All accesses
218 must be longword instructions and quadword aligned. */
219 enum xircom_offsets
{
220 CSR0
=0, CSR1
=0x08, CSR2
=0x10, CSR3
=0x18, CSR4
=0x20, CSR5
=0x28,
221 CSR6
=0x30, CSR7
=0x38, CSR8
=0x40, CSR9
=0x48, CSR10
=0x50, CSR11
=0x58,
222 CSR12
=0x60, CSR13
=0x68, CSR14
=0x70, CSR15
=0x78, CSR16
=0x04, };
224 /* The bits in the CSR5 status registers, mostly interrupt sources. */
226 LinkChange
=0x08000000,
227 NormalIntr
=0x10000, NormalIntrMask
=0x00014045,
228 AbnormalIntr
=0x8000, AbnormalIntrMask
=0x0a00a5a2,
229 ReservedIntrMask
=0xe0001a18,
230 EarlyRxIntr
=0x4000, BusErrorIntr
=0x2000,
231 EarlyTxIntr
=0x400, RxDied
=0x100, RxNoBuf
=0x80, RxIntr
=0x40,
232 TxFIFOUnderflow
=0x20, TxNoBuf
=0x04, TxDied
=0x02, TxIntr
=0x01,
235 enum csr0_control_bits
{
236 EnableMWI
=0x01000000, EnableMRL
=0x00800000,
237 EnableMRM
=0x00200000, EqualBusPrio
=0x02,
241 enum csr6_control_bits
{
242 ReceiveAllBit
=0x40000000, AllMultiBit
=0x80, PromiscBit
=0x40,
243 HashFilterBit
=0x01, FullDuplexBit
=0x0200,
244 TxThresh10
=0x400000, TxStoreForw
=0x200000,
245 TxThreshMask
=0xc000, TxThreshShift
=14,
246 EnableTx
=0x2000, EnableRx
=0x02,
247 ReservedZeroMask
=0x8d930134, ReservedOneMask
=0x320c0000,
248 EnableTxRx
=(EnableTx
| EnableRx
),
253 HAS_MII
=1, HAS_ACPI
=2,
255 static struct xircom_chip_table
{
257 int valid_intrs
; /* CSR7 interrupt enable settings */
260 { "Xircom Cardbus Adapter",
261 LinkChange
| NormalIntr
| AbnormalIntr
| BusErrorIntr
|
262 RxDied
| RxNoBuf
| RxIntr
| TxFIFOUnderflow
| TxNoBuf
| TxDied
| TxIntr
,
263 HAS_MII
| HAS_ACPI
, },
266 /* This matches the table above. */
272 /* The Xircom Rx and Tx buffer descriptors. */
273 struct xircom_rx_desc
{
276 u32 buffer1
, buffer2
;
279 struct xircom_tx_desc
{
282 u32 buffer1
, buffer2
; /* We use only buffer 1. */
285 enum tx_desc0_status_bits
{
286 Tx0DescOwned
=0x80000000, Tx0DescError
=0x8000, Tx0NoCarrier
=0x0800,
287 Tx0LateColl
=0x0200, Tx0ManyColl
=0x0100, Tx0Underflow
=0x02,
289 enum tx_desc1_status_bits
{
290 Tx1ComplIntr
=0x80000000, Tx1LastSeg
=0x40000000, Tx1FirstSeg
=0x20000000,
291 Tx1SetupPkt
=0x08000000, Tx1DisableCRC
=0x04000000, Tx1RingWrap
=0x02000000,
292 Tx1ChainDesc
=0x01000000, Tx1NoPad
=0x800000, Tx1HashSetup
=0x400000,
293 Tx1WholePkt
=(Tx1FirstSeg
| Tx1LastSeg
),
295 enum rx_desc0_status_bits
{
296 Rx0DescOwned
=0x80000000, Rx0DescError
=0x8000, Rx0NoSpace
=0x4000,
297 Rx0Runt
=0x0800, Rx0McastPkt
=0x0400, Rx0FirstSeg
=0x0200, Rx0LastSeg
=0x0100,
298 Rx0HugeFrame
=0x80, Rx0CRCError
=0x02,
299 Rx0WholePkt
=(Rx0FirstSeg
| Rx0LastSeg
),
301 enum rx_desc1_status_bits
{
302 Rx1RingWrap
=0x02000000, Rx1ChainDesc
=0x01000000,
305 struct xircom_private
{
306 struct xircom_rx_desc rx_ring
[RX_RING_SIZE
];
307 struct xircom_tx_desc tx_ring
[TX_RING_SIZE
];
308 /* The saved address of a sent-in-place packet/buffer, for skfree(). */
309 struct sk_buff
* tx_skbuff
[TX_RING_SIZE
];
311 /* The X3201-3 requires 4-byte aligned tx bufs */
312 struct sk_buff
* tx_aligned_skbuff
[TX_RING_SIZE
];
314 /* The addresses of receive-in-place skbuffs. */
315 struct sk_buff
* rx_skbuff
[RX_RING_SIZE
];
316 u16 setup_frame
[PKT_SETUP_SZ
/ sizeof(u16
)]; /* Pseudo-Tx frame to init address table. */
318 struct net_device_stats stats
;
319 unsigned int cur_rx
, cur_tx
; /* The next free ring entry */
320 unsigned int dirty_rx
, dirty_tx
; /* The ring entries to be free()ed. */
321 unsigned int tx_full
:1; /* The Tx queue is full. */
322 unsigned int speed100
:1;
323 unsigned int full_duplex
:1; /* Full-duplex operation requested. */
324 unsigned int autoneg
:1;
325 unsigned int default_port
:4; /* Last dev->if_port value. */
327 unsigned int csr0
; /* CSR0 setting. */
328 unsigned int csr6
; /* Current CSR6 control settings. */
329 u16 to_advertise
; /* NWay capabilities advertised. */
331 signed char phys
[4], mii_cnt
; /* MII device addresses. */
333 struct pci_dev
*pdev
;
337 static int mdio_read(struct net_device
*dev
, int phy_id
, int location
);
338 static void mdio_write(struct net_device
*dev
, int phy_id
, int location
, int value
);
339 static void xircom_up(struct net_device
*dev
);
340 static void xircom_down(struct net_device
*dev
);
341 static int xircom_open(struct net_device
*dev
);
342 static void xircom_tx_timeout(struct net_device
*dev
);
343 static void xircom_init_ring(struct net_device
*dev
);
344 static int xircom_start_xmit(struct sk_buff
*skb
, struct net_device
*dev
);
345 static int xircom_rx(struct net_device
*dev
);
346 static void xircom_media_change(struct net_device
*dev
);
347 static irqreturn_t
xircom_interrupt(int irq
, void *dev_instance
, struct pt_regs
*regs
);
348 static int xircom_close(struct net_device
*dev
);
349 static struct net_device_stats
*xircom_get_stats(struct net_device
*dev
);
350 static int xircom_ioctl(struct net_device
*dev
, struct ifreq
*rq
, int cmd
);
351 static void set_rx_mode(struct net_device
*dev
);
352 static void check_duplex(struct net_device
*dev
);
353 static struct ethtool_ops ops
;
356 /* The Xircom cards are picky about when certain bits in CSR6 can be
357 manipulated. Keith Owens <kaos@ocs.com.au>. */
358 static void outl_CSR6(u32 newcsr6
, long ioaddr
)
360 const int strict_bits
=
361 TxThresh10
| TxStoreForw
| TxThreshMask
| EnableTxRx
| FullDuplexBit
;
362 int csr5
, csr5_22_20
, csr5_19_17
, currcsr6
, attempts
= 200;
366 /* mask out the reserved bits that always read 0 on the Xircom cards */
367 newcsr6
&= ~ReservedZeroMask
;
368 /* or in the reserved bits that always read 1 */
369 newcsr6
|= ReservedOneMask
;
370 currcsr6
= inl(ioaddr
+ CSR6
);
371 if (((newcsr6
& strict_bits
) == (currcsr6
& strict_bits
)) ||
372 ((currcsr6
& ~EnableTxRx
) == 0)) {
373 outl(newcsr6
, ioaddr
+ CSR6
); /* safe */
374 restore_flags(flags
);
377 /* make sure the transmitter and receiver are stopped first */
378 currcsr6
&= ~EnableTxRx
;
380 csr5
= inl(ioaddr
+ CSR5
);
381 if (csr5
== 0xffffffff)
382 break; /* cannot read csr5, card removed? */
383 csr5_22_20
= csr5
& 0x700000;
384 csr5_19_17
= csr5
& 0x0e0000;
385 if ((csr5_22_20
== 0 || csr5_22_20
== 0x600000) &&
386 (csr5_19_17
== 0 || csr5_19_17
== 0x80000 || csr5_19_17
== 0xc0000))
387 break; /* both are stopped or suspended */
389 printk(KERN_INFO DRV_NAME
": outl_CSR6 too many attempts,"
390 "csr5=0x%08x\n", csr5
);
391 outl(newcsr6
, ioaddr
+ CSR6
); /* unsafe but do it anyway */
392 restore_flags(flags
);
395 outl(currcsr6
, ioaddr
+ CSR6
);
398 /* now it is safe to change csr6 */
399 outl(newcsr6
, ioaddr
+ CSR6
);
400 restore_flags(flags
);
404 static void __devinit
read_mac_address(struct net_device
*dev
)
406 long ioaddr
= dev
->base_addr
;
408 unsigned char tuple
, link
, data_id
, data_count
;
410 /* Xircom has its address stored in the CIS;
411 * we access it through the boot rom interface for now
412 * this might not work, as the CIS is not parsed but I
413 * (danilo) use the offset I found on my card's CIS !!!
415 * Doug Ledford: I changed this routine around so that it
416 * walks the CIS memory space, parsing the config items, and
417 * finds the proper lan_node_id tuple and uses the data
420 outl(1 << 12, ioaddr
+ CSR9
); /* enable boot rom access */
421 for (i
= 0x100; i
< 0x1f7; i
+= link
+2) {
422 outl(i
, ioaddr
+ CSR10
);
423 tuple
= inl(ioaddr
+ CSR9
) & 0xff;
424 outl(i
+ 1, ioaddr
+ CSR10
);
425 link
= inl(ioaddr
+ CSR9
) & 0xff;
426 outl(i
+ 2, ioaddr
+ CSR10
);
427 data_id
= inl(ioaddr
+ CSR9
) & 0xff;
428 outl(i
+ 3, ioaddr
+ CSR10
);
429 data_count
= inl(ioaddr
+ CSR9
) & 0xff;
430 if ( (tuple
== 0x22) &&
431 (data_id
== 0x04) && (data_count
== 0x06) ) {
433 * This is it. We have the data we want.
435 for (j
= 0; j
< 6; j
++) {
436 outl(i
+ j
+ 4, ioaddr
+ CSR10
);
437 dev
->dev_addr
[j
] = inl(ioaddr
+ CSR9
) & 0xff;
440 } else if (link
== 0) {
448 * locate the MII interfaces and initialize them.
449 * we disable full-duplex modes here,
450 * because we don't know how to handle them.
452 static void find_mii_transceivers(struct net_device
*dev
)
454 struct xircom_private
*tp
= netdev_priv(dev
);
457 if (media_cap
[tp
->default_port
] & MediaIsMII
) {
458 u16 media2advert
[] = { 0x20, 0x40, 0x03e0, 0x60, 0x80, 0x100, 0x200 };
459 tp
->to_advertise
= media2advert
[tp
->default_port
- 9];
462 /*ADVERTISE_100BASE4 | ADVERTISE_100FULL |*/ ADVERTISE_100HALF
|
463 /*ADVERTISE_10FULL |*/ ADVERTISE_10HALF
| ADVERTISE_CSMA
;
465 /* Find the connected MII xcvrs.
466 Doing this in open() would allow detecting external xcvrs later,
467 but takes much time. */
468 for (phy
= 0, phy_idx
= 0; phy
< 32 && phy_idx
< sizeof(tp
->phys
); phy
++) {
469 int mii_status
= mdio_read(dev
, phy
, MII_BMSR
);
470 if ((mii_status
& (BMSR_100BASE4
| BMSR_100HALF
| BMSR_10HALF
)) == BMSR_100BASE4
||
471 ((mii_status
& BMSR_100BASE4
) == 0 &&
472 (mii_status
& (BMSR_100FULL
| BMSR_100HALF
| BMSR_10FULL
| BMSR_10HALF
)) != 0)) {
473 int mii_reg0
= mdio_read(dev
, phy
, MII_BMCR
);
474 int mii_advert
= mdio_read(dev
, phy
, MII_ADVERTISE
);
475 int reg4
= ((mii_status
>> 6) & tp
->to_advertise
) | ADVERTISE_CSMA
;
476 tp
->phys
[phy_idx
] = phy
;
477 tp
->advertising
[phy_idx
++] = reg4
;
478 printk(KERN_INFO
"%s: MII transceiver #%d "
479 "config %4.4x status %4.4x advertising %4.4x.\n",
480 dev
->name
, phy
, mii_reg0
, mii_status
, mii_advert
);
483 tp
->mii_cnt
= phy_idx
;
485 printk(KERN_INFO
"%s: ***WARNING***: No MII transceiver found!\n",
493 * To quote Arjan van de Ven:
494 * transceiver_voodoo() enables the external UTP plug thingy.
495 * it's called voodoo as I stole this code and cannot cross-reference
496 * it with the specification.
497 * Actually it seems to go like this:
498 * - GPIO2 enables the MII itself so we can talk to it. The MII gets reset
499 * so any prior MII settings are lost.
500 * - GPIO0 enables the TP port so the MII can talk to the network.
501 * - a software reset will reset both GPIO pins.
502 * I also moved the software reset here, because doing it in xircom_up()
503 * required enabling the GPIO pins each time, which reset the MII each time.
504 * Thus we couldn't control the MII -- which sucks because we don't know
505 * how to handle full-duplex modes so we *must* disable them.
507 static void transceiver_voodoo(struct net_device
*dev
)
509 struct xircom_private
*tp
= netdev_priv(dev
);
510 long ioaddr
= dev
->base_addr
;
512 /* Reset the chip, holding bit 0 set at least 50 PCI cycles. */
513 outl(SoftwareReset
, ioaddr
+ CSR0
);
516 /* Deassert reset. */
517 outl(tp
->csr0
, ioaddr
+ CSR0
);
519 /* Reset the xcvr interface and turn on heartbeat. */
520 outl(0x0008, ioaddr
+ CSR15
);
521 udelay(5); /* The delays are Xircom-recommended to give the
522 * chipset time to reset the actual hardware
525 outl(0xa8050000, ioaddr
+ CSR15
);
527 outl(0xa00f0000, ioaddr
+ CSR15
);
530 outl_CSR6(0, ioaddr
);
531 //outl_CSR6(FullDuplexBit, ioaddr);
535 static int __devinit
xircom_init_one(struct pci_dev
*pdev
, const struct pci_device_id
*id
)
537 struct net_device
*dev
;
538 struct xircom_private
*tp
;
539 static int board_idx
= -1;
540 int chip_idx
= id
->driver_data
;
545 /* when built into the kernel, we only print version if device is found */
547 static int printed_version
;
548 if (!printed_version
++)
552 //printk(KERN_INFO "xircom_init_one(%s)\n", pci_name(pdev));
556 if (pci_enable_device(pdev
))
559 pci_set_master(pdev
);
561 ioaddr
= pci_resource_start(pdev
, 0);
562 dev
= alloc_etherdev(sizeof(*tp
));
564 printk (KERN_ERR DRV_NAME
"%d: cannot alloc etherdev, aborting\n", board_idx
);
567 SET_MODULE_OWNER(dev
);
568 SET_NETDEV_DEV(dev
, &pdev
->dev
);
570 dev
->base_addr
= ioaddr
;
571 dev
->irq
= pdev
->irq
;
573 if (pci_request_regions(pdev
, dev
->name
)) {
574 printk (KERN_ERR DRV_NAME
" %d: cannot reserve PCI resources, aborting\n", board_idx
);
575 goto err_out_free_netdev
;
578 /* Bring the chip out of sleep mode.
579 Caution: Snooze mode does not work with some boards! */
580 if (xircom_tbl
[chip_idx
].flags
& HAS_ACPI
)
581 pci_write_config_dword(pdev
, PCI_POWERMGMT
, 0);
583 /* Stop the chip's Tx and Rx processes. */
584 outl_CSR6(inl(ioaddr
+ CSR6
) & ~EnableTxRx
, ioaddr
);
585 /* Clear the missed-packet counter. */
586 (volatile int)inl(ioaddr
+ CSR8
);
588 tp
= netdev_priv(dev
);
590 spin_lock_init(&tp
->lock
);
592 tp
->chip_id
= chip_idx
;
593 /* BugFixes: The 21143-TD hangs with PCI Write-and-Invalidate cycles. */
594 /* XXX: is this necessary for Xircom? */
595 tp
->csr0
= csr0
& ~EnableMWI
;
597 pci_set_drvdata(pdev
, dev
);
599 /* The lower four bits are the media type. */
600 if (board_idx
>= 0 && board_idx
< MAX_UNITS
) {
601 tp
->default_port
= options
[board_idx
] & 15;
602 if ((options
[board_idx
] & 0x90) || full_duplex
[board_idx
] > 0)
604 if (mtu
[board_idx
] > 0)
605 dev
->mtu
= mtu
[board_idx
];
608 tp
->default_port
= dev
->mem_start
;
609 if (tp
->default_port
) {
610 if (media_cap
[tp
->default_port
] & MediaAlwaysFD
)
619 /* The Xircom-specific entries in the device structure. */
620 dev
->open
= &xircom_open
;
621 dev
->hard_start_xmit
= &xircom_start_xmit
;
622 dev
->stop
= &xircom_close
;
623 dev
->get_stats
= &xircom_get_stats
;
624 dev
->do_ioctl
= &xircom_ioctl
;
625 #ifdef HAVE_MULTICAST
626 dev
->set_multicast_list
= &set_rx_mode
;
628 dev
->tx_timeout
= xircom_tx_timeout
;
629 dev
->watchdog_timeo
= TX_TIMEOUT
;
630 SET_ETHTOOL_OPS(dev
, &ops
);
632 transceiver_voodoo(dev
);
634 read_mac_address(dev
);
636 if (register_netdev(dev
))
637 goto err_out_cleardev
;
639 pci_read_config_byte(pdev
, PCI_REVISION_ID
, &chip_rev
);
640 printk(KERN_INFO
"%s: %s rev %d at %#3lx,",
641 dev
->name
, xircom_tbl
[chip_idx
].chip_name
, chip_rev
, ioaddr
);
642 for (i
= 0; i
< 6; i
++)
643 printk("%c%2.2X", i
? ':' : ' ', dev
->dev_addr
[i
]);
644 printk(", IRQ %d.\n", dev
->irq
);
646 if (xircom_tbl
[chip_idx
].flags
& HAS_MII
) {
647 find_mii_transceivers(dev
);
654 pci_set_drvdata(pdev
, NULL
);
655 pci_release_regions(pdev
);
662 /* MII transceiver control section.
663 Read and write the MII registers using software-generated serial
664 MDIO protocol. See the MII specifications or DP83840A data sheet
667 /* The maximum data clock rate is 2.5 Mhz. The minimum timing is usually
668 met by back-to-back PCI I/O cycles, but we insert a delay to avoid
669 "overclocking" issues or future 66Mhz PCI. */
670 #define mdio_delay() inl(mdio_addr)
672 /* Read and write the MII registers using software-generated serial
673 MDIO protocol. It is just different enough from the EEPROM protocol
674 to not share code. The maxium data clock rate is 2.5 Mhz. */
675 #define MDIO_SHIFT_CLK 0x10000
676 #define MDIO_DATA_WRITE0 0x00000
677 #define MDIO_DATA_WRITE1 0x20000
678 #define MDIO_ENB 0x00000 /* Ignore the 0x02000 databook setting. */
679 #define MDIO_ENB_IN 0x40000
680 #define MDIO_DATA_READ 0x80000
682 static int mdio_read(struct net_device
*dev
, int phy_id
, int location
)
685 int read_cmd
= (0xf6 << 10) | (phy_id
<< 5) | location
;
687 long ioaddr
= dev
->base_addr
;
688 long mdio_addr
= ioaddr
+ CSR9
;
690 /* Establish sync by sending at least 32 logic ones. */
691 for (i
= 32; i
>= 0; i
--) {
692 outl(MDIO_ENB
| MDIO_DATA_WRITE1
, mdio_addr
);
694 outl(MDIO_ENB
| MDIO_DATA_WRITE1
| MDIO_SHIFT_CLK
, mdio_addr
);
697 /* Shift the read command bits out. */
698 for (i
= 15; i
>= 0; i
--) {
699 int dataval
= (read_cmd
& (1 << i
)) ? MDIO_DATA_WRITE1
: 0;
701 outl(MDIO_ENB
| dataval
, mdio_addr
);
703 outl(MDIO_ENB
| dataval
| MDIO_SHIFT_CLK
, mdio_addr
);
706 /* Read the two transition, 16 data, and wire-idle bits. */
707 for (i
= 19; i
> 0; i
--) {
708 outl(MDIO_ENB_IN
, mdio_addr
);
710 retval
= (retval
<< 1) | ((inl(mdio_addr
) & MDIO_DATA_READ
) ? 1 : 0);
711 outl(MDIO_ENB_IN
| MDIO_SHIFT_CLK
, mdio_addr
);
714 return (retval
>>1) & 0xffff;
718 static void mdio_write(struct net_device
*dev
, int phy_id
, int location
, int value
)
721 int cmd
= (0x5002 << 16) | (phy_id
<< 23) | (location
<< 18) | value
;
722 long ioaddr
= dev
->base_addr
;
723 long mdio_addr
= ioaddr
+ CSR9
;
725 /* Establish sync by sending 32 logic ones. */
726 for (i
= 32; i
>= 0; i
--) {
727 outl(MDIO_ENB
| MDIO_DATA_WRITE1
, mdio_addr
);
729 outl(MDIO_ENB
| MDIO_DATA_WRITE1
| MDIO_SHIFT_CLK
, mdio_addr
);
732 /* Shift the command bits out. */
733 for (i
= 31; i
>= 0; i
--) {
734 int dataval
= (cmd
& (1 << i
)) ? MDIO_DATA_WRITE1
: 0;
735 outl(MDIO_ENB
| dataval
, mdio_addr
);
737 outl(MDIO_ENB
| dataval
| MDIO_SHIFT_CLK
, mdio_addr
);
740 /* Clear out extra bits. */
741 for (i
= 2; i
> 0; i
--) {
742 outl(MDIO_ENB_IN
, mdio_addr
);
744 outl(MDIO_ENB_IN
| MDIO_SHIFT_CLK
, mdio_addr
);
752 xircom_up(struct net_device
*dev
)
754 struct xircom_private
*tp
= netdev_priv(dev
);
755 long ioaddr
= dev
->base_addr
;
758 xircom_init_ring(dev
);
759 /* Clear the tx ring */
760 for (i
= 0; i
< TX_RING_SIZE
; i
++) {
761 tp
->tx_skbuff
[i
] = NULL
;
762 tp
->tx_ring
[i
].status
= 0;
765 if (xircom_debug
> 1)
766 printk(KERN_DEBUG
"%s: xircom_up() irq %d.\n", dev
->name
, dev
->irq
);
768 outl(virt_to_bus(tp
->rx_ring
), ioaddr
+ CSR3
);
769 outl(virt_to_bus(tp
->tx_ring
), ioaddr
+ CSR4
);
771 tp
->saved_if_port
= dev
->if_port
;
772 if (dev
->if_port
== 0)
773 dev
->if_port
= tp
->default_port
;
775 tp
->csr6
= TxThresh10
/*| FullDuplexBit*/; /* XXX: why 10 and not 100? */
779 /* Start the chip's Tx to process setup frame. */
780 outl_CSR6(tp
->csr6
, ioaddr
);
781 outl_CSR6(tp
->csr6
| EnableTx
, ioaddr
);
783 /* Acknowledge all outstanding interrupts sources */
784 outl(xircom_tbl
[tp
->chip_id
].valid_intrs
, ioaddr
+ CSR5
);
785 /* Enable interrupts by setting the interrupt mask. */
786 outl(xircom_tbl
[tp
->chip_id
].valid_intrs
, ioaddr
+ CSR7
);
788 outl_CSR6(tp
->csr6
| EnableTxRx
, ioaddr
);
790 outl(0, ioaddr
+ CSR2
);
792 /* Tell the net layer we're ready */
793 netif_start_queue (dev
);
795 /* Check current media state */
796 xircom_media_change(dev
);
798 if (xircom_debug
> 2) {
799 printk(KERN_DEBUG
"%s: Done xircom_up(), CSR0 %8.8x, CSR5 %8.8x CSR6 %8.8x.\n",
800 dev
->name
, inl(ioaddr
+ CSR0
), inl(ioaddr
+ CSR5
),
807 xircom_open(struct net_device
*dev
)
809 struct xircom_private
*tp
= netdev_priv(dev
);
811 if (request_irq(dev
->irq
, &xircom_interrupt
, SA_SHIRQ
, dev
->name
, dev
))
821 static void xircom_tx_timeout(struct net_device
*dev
)
823 struct xircom_private
*tp
= netdev_priv(dev
);
824 long ioaddr
= dev
->base_addr
;
826 if (media_cap
[dev
->if_port
] & MediaIsMII
) {
827 /* Do nothing -- the media monitor should handle this. */
828 if (xircom_debug
> 1)
829 printk(KERN_WARNING
"%s: Transmit timeout using MII device.\n",
833 #if defined(way_too_many_messages)
834 if (xircom_debug
> 3) {
836 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
837 u8
*buf
= (u8
*)(tp
->rx_ring
[i
].buffer1
);
839 printk(KERN_DEBUG
"%2d: %8.8x %8.8x %8.8x %8.8x "
840 "%2.2x %2.2x %2.2x.\n",
841 i
, (unsigned int)tp
->rx_ring
[i
].status
,
842 (unsigned int)tp
->rx_ring
[i
].length
,
843 (unsigned int)tp
->rx_ring
[i
].buffer1
,
844 (unsigned int)tp
->rx_ring
[i
].buffer2
,
845 buf
[0], buf
[1], buf
[2]);
846 for (j
= 0; buf
[j
] != 0xee && j
< 1600; j
++)
847 if (j
< 100) printk(" %2.2x", buf
[j
]);
848 printk(" j=%d.\n", j
);
850 printk(KERN_DEBUG
" Rx ring %8.8x: ", (int)tp
->rx_ring
);
851 for (i
= 0; i
< RX_RING_SIZE
; i
++)
852 printk(" %8.8x", (unsigned int)tp
->rx_ring
[i
].status
);
853 printk("\n" KERN_DEBUG
" Tx ring %8.8x: ", (int)tp
->tx_ring
);
854 for (i
= 0; i
< TX_RING_SIZE
; i
++)
855 printk(" %8.8x", (unsigned int)tp
->tx_ring
[i
].status
);
860 /* Stop and restart the chip's Tx/Rx processes . */
861 outl_CSR6(tp
->csr6
| EnableRx
, ioaddr
);
862 outl_CSR6(tp
->csr6
| EnableTxRx
, ioaddr
);
863 /* Trigger an immediate transmit demand. */
864 outl(0, ioaddr
+ CSR1
);
866 dev
->trans_start
= jiffies
;
867 netif_wake_queue (dev
);
868 tp
->stats
.tx_errors
++;
872 /* Initialize the Rx and Tx rings, along with various 'dev' bits. */
873 static void xircom_init_ring(struct net_device
*dev
)
875 struct xircom_private
*tp
= netdev_priv(dev
);
879 tp
->cur_rx
= tp
->cur_tx
= 0;
880 tp
->dirty_rx
= tp
->dirty_tx
= 0;
882 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
883 tp
->rx_ring
[i
].status
= 0;
884 tp
->rx_ring
[i
].length
= PKT_BUF_SZ
;
885 tp
->rx_ring
[i
].buffer2
= virt_to_bus(&tp
->rx_ring
[i
+1]);
886 tp
->rx_skbuff
[i
] = NULL
;
888 /* Mark the last entry as wrapping the ring. */
889 tp
->rx_ring
[i
-1].length
= PKT_BUF_SZ
| Rx1RingWrap
;
890 tp
->rx_ring
[i
-1].buffer2
= virt_to_bus(&tp
->rx_ring
[0]);
892 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
893 /* Note the receive buffer must be longword aligned.
894 dev_alloc_skb() provides 16 byte alignment. But do *not*
895 use skb_reserve() to align the IP header! */
896 struct sk_buff
*skb
= dev_alloc_skb(PKT_BUF_SZ
);
897 tp
->rx_skbuff
[i
] = skb
;
900 skb
->dev
= dev
; /* Mark as being used by this device. */
901 tp
->rx_ring
[i
].status
= Rx0DescOwned
; /* Owned by Xircom chip */
902 tp
->rx_ring
[i
].buffer1
= virt_to_bus(skb
->data
);
904 tp
->dirty_rx
= (unsigned int)(i
- RX_RING_SIZE
);
906 /* The Tx buffer descriptor is filled in as needed, but we
907 do need to clear the ownership bit. */
908 for (i
= 0; i
< TX_RING_SIZE
; i
++) {
909 tp
->tx_skbuff
[i
] = NULL
;
910 tp
->tx_ring
[i
].status
= 0;
911 tp
->tx_ring
[i
].buffer2
= virt_to_bus(&tp
->tx_ring
[i
+1]);
913 if (tp
->chip_id
== X3201_3
)
914 tp
->tx_aligned_skbuff
[i
] = dev_alloc_skb(PKT_BUF_SZ
);
917 tp
->tx_ring
[i
-1].buffer2
= virt_to_bus(&tp
->tx_ring
[0]);
922 xircom_start_xmit(struct sk_buff
*skb
, struct net_device
*dev
)
924 struct xircom_private
*tp
= netdev_priv(dev
);
928 /* Caution: the write order is important here, set the base address
929 with the "ownership" bits last. */
931 /* Calculate the next Tx descriptor entry. */
932 entry
= tp
->cur_tx
% TX_RING_SIZE
;
934 tp
->tx_skbuff
[entry
] = skb
;
936 if (tp
->chip_id
== X3201_3
) {
937 memcpy(tp
->tx_aligned_skbuff
[entry
]->data
,skb
->data
,skb
->len
);
938 tp
->tx_ring
[entry
].buffer1
= virt_to_bus(tp
->tx_aligned_skbuff
[entry
]->data
);
941 tp
->tx_ring
[entry
].buffer1
= virt_to_bus(skb
->data
);
943 if (tp
->cur_tx
- tp
->dirty_tx
< TX_RING_SIZE
/2) {/* Typical path */
944 flag
= Tx1WholePkt
; /* No interrupt */
945 } else if (tp
->cur_tx
- tp
->dirty_tx
== TX_RING_SIZE
/2) {
946 flag
= Tx1WholePkt
| Tx1ComplIntr
; /* Tx-done intr. */
947 } else if (tp
->cur_tx
- tp
->dirty_tx
< TX_RING_SIZE
- 2) {
948 flag
= Tx1WholePkt
; /* No Tx-done intr. */
950 /* Leave room for set_rx_mode() to fill entries. */
951 flag
= Tx1WholePkt
| Tx1ComplIntr
; /* Tx-done intr. */
954 if (entry
== TX_RING_SIZE
- 1)
955 flag
|= Tx1WholePkt
| Tx1ComplIntr
| Tx1RingWrap
;
957 tp
->tx_ring
[entry
].length
= skb
->len
| flag
;
958 tp
->tx_ring
[entry
].status
= Tx0DescOwned
; /* Pass ownership to the chip. */
961 netif_stop_queue (dev
);
963 netif_wake_queue (dev
);
965 /* Trigger an immediate transmit demand. */
966 outl(0, dev
->base_addr
+ CSR1
);
968 dev
->trans_start
= jiffies
;
974 static void xircom_media_change(struct net_device
*dev
)
976 struct xircom_private
*tp
= netdev_priv(dev
);
977 long ioaddr
= dev
->base_addr
;
978 u16 reg0
, reg1
, reg4
, reg5
;
979 u32 csr6
= inl(ioaddr
+ CSR6
), newcsr6
;
981 /* reset status first */
982 mdio_read(dev
, tp
->phys
[0], MII_BMCR
);
983 mdio_read(dev
, tp
->phys
[0], MII_BMSR
);
985 reg0
= mdio_read(dev
, tp
->phys
[0], MII_BMCR
);
986 reg1
= mdio_read(dev
, tp
->phys
[0], MII_BMSR
);
988 if (reg1
& BMSR_LSTATUS
) {
990 if (reg0
& BMCR_ANENABLE
) {
991 /* autonegotiation is enabled */
992 reg4
= mdio_read(dev
, tp
->phys
[0], MII_ADVERTISE
);
993 reg5
= mdio_read(dev
, tp
->phys
[0], MII_LPA
);
994 if (reg4
& ADVERTISE_100FULL
&& reg5
& LPA_100FULL
) {
997 } else if (reg4
& ADVERTISE_100HALF
&& reg5
& LPA_100HALF
) {
1000 } else if (reg4
& ADVERTISE_10FULL
&& reg5
& LPA_10FULL
) {
1002 tp
->full_duplex
= 1;
1005 tp
->full_duplex
= 0;
1008 /* autonegotiation is disabled */
1009 if (reg0
& BMCR_SPEED100
)
1013 if (reg0
& BMCR_FULLDPLX
)
1014 tp
->full_duplex
= 1;
1016 tp
->full_duplex
= 0;
1018 printk(KERN_DEBUG
"%s: Link is up, running at %sMbit %s-duplex\n",
1020 tp
->speed100
? "100" : "10",
1021 tp
->full_duplex
? "full" : "half");
1022 netif_carrier_on(dev
);
1023 newcsr6
= csr6
& ~FullDuplexBit
;
1024 if (tp
->full_duplex
)
1025 newcsr6
|= FullDuplexBit
;
1026 if (newcsr6
!= csr6
)
1027 outl_CSR6(newcsr6
, ioaddr
+ CSR6
);
1029 printk(KERN_DEBUG
"%s: Link is down\n", dev
->name
);
1030 netif_carrier_off(dev
);
1035 static void check_duplex(struct net_device
*dev
)
1037 struct xircom_private
*tp
= netdev_priv(dev
);
1040 mdio_write(dev
, tp
->phys
[0], MII_BMCR
, BMCR_RESET
);
1042 while (mdio_read(dev
, tp
->phys
[0], MII_BMCR
) & BMCR_RESET
);
1044 reg0
= mdio_read(dev
, tp
->phys
[0], MII_BMCR
);
1045 mdio_write(dev
, tp
->phys
[0], MII_ADVERTISE
, tp
->advertising
[0]);
1048 reg0
&= ~(BMCR_SPEED100
| BMCR_FULLDPLX
);
1049 reg0
|= BMCR_ANENABLE
| BMCR_ANRESTART
;
1051 reg0
&= ~(BMCR_ANENABLE
| BMCR_ANRESTART
);
1053 reg0
|= BMCR_SPEED100
;
1054 if (tp
->full_duplex
)
1055 reg0
|= BMCR_FULLDPLX
;
1056 printk(KERN_DEBUG
"%s: Link forced to %sMbit %s-duplex\n",
1058 tp
->speed100
? "100" : "10",
1059 tp
->full_duplex
? "full" : "half");
1061 mdio_write(dev
, tp
->phys
[0], MII_BMCR
, reg0
);
1065 /* The interrupt handler does all of the Rx thread work and cleans up
1066 after the Tx thread. */
1067 static irqreturn_t
xircom_interrupt(int irq
, void *dev_instance
, struct pt_regs
*regs
)
1069 struct net_device
*dev
= dev_instance
;
1070 struct xircom_private
*tp
= netdev_priv(dev
);
1071 long ioaddr
= dev
->base_addr
;
1072 int csr5
, work_budget
= max_interrupt_work
;
1075 spin_lock (&tp
->lock
);
1078 csr5
= inl(ioaddr
+ CSR5
);
1079 /* Acknowledge all of the current interrupt sources ASAP. */
1080 outl(csr5
& 0x0001ffff, ioaddr
+ CSR5
);
1082 if (xircom_debug
> 4)
1083 printk(KERN_DEBUG
"%s: interrupt csr5=%#8.8x new csr5=%#8.8x.\n",
1084 dev
->name
, csr5
, inl(dev
->base_addr
+ CSR5
));
1086 if (csr5
== 0xffffffff)
1087 break; /* all bits set, assume PCMCIA card removed */
1089 if ((csr5
& (NormalIntr
|AbnormalIntr
)) == 0)
1094 if (csr5
& (RxIntr
| RxNoBuf
))
1095 work_budget
-= xircom_rx(dev
);
1097 if (csr5
& (TxNoBuf
| TxDied
| TxIntr
)) {
1098 unsigned int dirty_tx
;
1100 for (dirty_tx
= tp
->dirty_tx
; tp
->cur_tx
- dirty_tx
> 0;
1102 int entry
= dirty_tx
% TX_RING_SIZE
;
1103 int status
= tp
->tx_ring
[entry
].status
;
1106 break; /* It still hasn't been Txed */
1107 /* Check for Rx filter setup frames. */
1108 if (tp
->tx_skbuff
[entry
] == NULL
)
1111 if (status
& Tx0DescError
) {
1112 /* There was an major error, log it. */
1113 #ifndef final_version
1114 if (xircom_debug
> 1)
1115 printk(KERN_DEBUG
"%s: Transmit error, Tx status %8.8x.\n",
1118 tp
->stats
.tx_errors
++;
1119 if (status
& Tx0ManyColl
) {
1120 tp
->stats
.tx_aborted_errors
++;
1122 if (status
& Tx0NoCarrier
) tp
->stats
.tx_carrier_errors
++;
1123 if (status
& Tx0LateColl
) tp
->stats
.tx_window_errors
++;
1124 if (status
& Tx0Underflow
) tp
->stats
.tx_fifo_errors
++;
1126 tp
->stats
.tx_bytes
+= tp
->tx_ring
[entry
].length
& 0x7ff;
1127 tp
->stats
.collisions
+= (status
>> 3) & 15;
1128 tp
->stats
.tx_packets
++;
1131 /* Free the original skb. */
1132 dev_kfree_skb_irq(tp
->tx_skbuff
[entry
]);
1133 tp
->tx_skbuff
[entry
] = NULL
;
1136 #ifndef final_version
1137 if (tp
->cur_tx
- dirty_tx
> TX_RING_SIZE
) {
1138 printk(KERN_ERR
"%s: Out-of-sync dirty pointer, %d vs. %d, full=%d.\n",
1139 dev
->name
, dirty_tx
, tp
->cur_tx
, tp
->tx_full
);
1140 dirty_tx
+= TX_RING_SIZE
;
1145 tp
->cur_tx
- dirty_tx
< TX_RING_SIZE
- 2)
1146 /* The ring is no longer full */
1150 netif_stop_queue (dev
);
1152 netif_wake_queue (dev
);
1154 tp
->dirty_tx
= dirty_tx
;
1155 if (csr5
& TxDied
) {
1156 if (xircom_debug
> 2)
1157 printk(KERN_WARNING
"%s: The transmitter stopped."
1158 " CSR5 is %x, CSR6 %x, new CSR6 %x.\n",
1159 dev
->name
, csr5
, inl(ioaddr
+ CSR6
), tp
->csr6
);
1160 outl_CSR6(tp
->csr6
| EnableRx
, ioaddr
);
1161 outl_CSR6(tp
->csr6
| EnableTxRx
, ioaddr
);
1166 if (csr5
& AbnormalIntr
) { /* Abnormal error summary bit. */
1167 if (csr5
& LinkChange
)
1168 xircom_media_change(dev
);
1169 if (csr5
& TxFIFOUnderflow
) {
1170 if ((tp
->csr6
& TxThreshMask
) != TxThreshMask
)
1171 tp
->csr6
+= (1 << TxThreshShift
); /* Bump up the Tx threshold */
1173 tp
->csr6
|= TxStoreForw
; /* Store-n-forward. */
1174 /* Restart the transmit process. */
1175 outl_CSR6(tp
->csr6
| EnableRx
, ioaddr
);
1176 outl_CSR6(tp
->csr6
| EnableTxRx
, ioaddr
);
1178 if (csr5
& RxDied
) { /* Missed a Rx frame. */
1179 tp
->stats
.rx_errors
++;
1180 tp
->stats
.rx_missed_errors
+= inl(ioaddr
+ CSR8
) & 0xffff;
1181 outl_CSR6(tp
->csr6
| EnableTxRx
, ioaddr
);
1183 /* Clear all error sources, included undocumented ones! */
1184 outl(0x0800f7ba, ioaddr
+ CSR5
);
1186 if (--work_budget
< 0) {
1187 if (xircom_debug
> 1)
1188 printk(KERN_WARNING
"%s: Too much work during an interrupt, "
1189 "csr5=0x%8.8x.\n", dev
->name
, csr5
);
1190 /* Acknowledge all interrupt sources. */
1191 outl(0x8001ffff, ioaddr
+ CSR5
);
1196 if (xircom_debug
> 3)
1197 printk(KERN_DEBUG
"%s: exiting interrupt, csr5=%#4.4x.\n",
1198 dev
->name
, inl(ioaddr
+ CSR5
));
1200 spin_unlock (&tp
->lock
);
1201 return IRQ_RETVAL(handled
);
1206 xircom_rx(struct net_device
*dev
)
1208 struct xircom_private
*tp
= netdev_priv(dev
);
1209 int entry
= tp
->cur_rx
% RX_RING_SIZE
;
1210 int rx_work_limit
= tp
->dirty_rx
+ RX_RING_SIZE
- tp
->cur_rx
;
1213 if (xircom_debug
> 4)
1214 printk(KERN_DEBUG
" In xircom_rx(), entry %d %8.8x.\n", entry
,
1215 tp
->rx_ring
[entry
].status
);
1216 /* If we own the next entry, it's a new packet. Send it up. */
1217 while (tp
->rx_ring
[entry
].status
>= 0) {
1218 s32 status
= tp
->rx_ring
[entry
].status
;
1220 if (xircom_debug
> 5)
1221 printk(KERN_DEBUG
" In xircom_rx(), entry %d %8.8x.\n", entry
,
1222 tp
->rx_ring
[entry
].status
);
1223 if (--rx_work_limit
< 0)
1225 if ((status
& 0x38008300) != 0x0300) {
1226 if ((status
& 0x38000300) != 0x0300) {
1227 /* Ignore earlier buffers. */
1228 if ((status
& 0xffff) != 0x7fff) {
1229 if (xircom_debug
> 1)
1230 printk(KERN_WARNING
"%s: Oversized Ethernet frame "
1231 "spanned multiple buffers, status %8.8x!\n",
1233 tp
->stats
.rx_length_errors
++;
1235 } else if (status
& Rx0DescError
) {
1236 /* There was a fatal error. */
1237 if (xircom_debug
> 2)
1238 printk(KERN_DEBUG
"%s: Receive error, Rx status %8.8x.\n",
1240 tp
->stats
.rx_errors
++; /* end of a packet.*/
1241 if (status
& (Rx0Runt
| Rx0HugeFrame
)) tp
->stats
.rx_length_errors
++;
1242 if (status
& Rx0CRCError
) tp
->stats
.rx_crc_errors
++;
1245 /* Omit the four octet CRC from the length. */
1246 short pkt_len
= ((status
>> 16) & 0x7ff) - 4;
1247 struct sk_buff
*skb
;
1249 #ifndef final_version
1250 if (pkt_len
> 1518) {
1251 printk(KERN_WARNING
"%s: Bogus packet size of %d (%#x).\n",
1252 dev
->name
, pkt_len
, pkt_len
);
1254 tp
->stats
.rx_length_errors
++;
1257 /* Check if the packet is long enough to accept without copying
1258 to a minimally-sized skbuff. */
1259 if (pkt_len
< rx_copybreak
1260 && (skb
= dev_alloc_skb(pkt_len
+ 2)) != NULL
) {
1262 skb_reserve(skb
, 2); /* 16 byte align the IP header */
1263 #if ! defined(__alpha__)
1264 eth_copy_and_sum(skb
, bus_to_virt(tp
->rx_ring
[entry
].buffer1
),
1266 skb_put(skb
, pkt_len
);
1268 memcpy(skb_put(skb
, pkt_len
),
1269 bus_to_virt(tp
->rx_ring
[entry
].buffer1
), pkt_len
);
1272 } else { /* Pass up the skb already on the Rx ring. */
1273 skb_put(skb
= tp
->rx_skbuff
[entry
], pkt_len
);
1274 tp
->rx_skbuff
[entry
] = NULL
;
1276 skb
->protocol
= eth_type_trans(skb
, dev
);
1278 dev
->last_rx
= jiffies
;
1279 tp
->stats
.rx_packets
++;
1280 tp
->stats
.rx_bytes
+= pkt_len
;
1282 entry
= (++tp
->cur_rx
) % RX_RING_SIZE
;
1285 /* Refill the Rx ring buffers. */
1286 for (; tp
->cur_rx
- tp
->dirty_rx
> 0; tp
->dirty_rx
++) {
1287 entry
= tp
->dirty_rx
% RX_RING_SIZE
;
1288 if (tp
->rx_skbuff
[entry
] == NULL
) {
1289 struct sk_buff
*skb
;
1290 skb
= tp
->rx_skbuff
[entry
] = dev_alloc_skb(PKT_BUF_SZ
);
1293 skb
->dev
= dev
; /* Mark as being used by this device. */
1294 tp
->rx_ring
[entry
].buffer1
= virt_to_bus(skb
->data
);
1297 tp
->rx_ring
[entry
].status
= Rx0DescOwned
;
1305 xircom_down(struct net_device
*dev
)
1307 long ioaddr
= dev
->base_addr
;
1308 struct xircom_private
*tp
= netdev_priv(dev
);
1310 /* Disable interrupts by clearing the interrupt mask. */
1311 outl(0, ioaddr
+ CSR7
);
1312 /* Stop the chip's Tx and Rx processes. */
1313 outl_CSR6(inl(ioaddr
+ CSR6
) & ~EnableTxRx
, ioaddr
);
1315 if (inl(ioaddr
+ CSR6
) != 0xffffffff)
1316 tp
->stats
.rx_missed_errors
+= inl(ioaddr
+ CSR8
) & 0xffff;
1318 dev
->if_port
= tp
->saved_if_port
;
1323 xircom_close(struct net_device
*dev
)
1325 long ioaddr
= dev
->base_addr
;
1326 struct xircom_private
*tp
= netdev_priv(dev
);
1329 if (xircom_debug
> 1)
1330 printk(KERN_DEBUG
"%s: Shutting down ethercard, status was %2.2x.\n",
1331 dev
->name
, inl(ioaddr
+ CSR5
));
1333 netif_stop_queue(dev
);
1335 if (netif_device_present(dev
))
1338 free_irq(dev
->irq
, dev
);
1340 /* Free all the skbuffs in the Rx queue. */
1341 for (i
= 0; i
< RX_RING_SIZE
; i
++) {
1342 struct sk_buff
*skb
= tp
->rx_skbuff
[i
];
1343 tp
->rx_skbuff
[i
] = NULL
;
1344 tp
->rx_ring
[i
].status
= 0; /* Not owned by Xircom chip. */
1345 tp
->rx_ring
[i
].length
= 0;
1346 tp
->rx_ring
[i
].buffer1
= 0xBADF00D0; /* An invalid address. */
1351 for (i
= 0; i
< TX_RING_SIZE
; i
++) {
1352 if (tp
->tx_skbuff
[i
])
1353 dev_kfree_skb(tp
->tx_skbuff
[i
]);
1354 tp
->tx_skbuff
[i
] = NULL
;
1362 static struct net_device_stats
*xircom_get_stats(struct net_device
*dev
)
1364 struct xircom_private
*tp
= netdev_priv(dev
);
1365 long ioaddr
= dev
->base_addr
;
1367 if (netif_device_present(dev
))
1368 tp
->stats
.rx_missed_errors
+= inl(ioaddr
+ CSR8
) & 0xffff;
1373 static int xircom_get_settings(struct net_device
*dev
, struct ethtool_cmd
*ecmd
)
1375 struct xircom_private
*tp
= netdev_priv(dev
);
1377 SUPPORTED_10baseT_Half
|
1378 SUPPORTED_10baseT_Full
|
1379 SUPPORTED_100baseT_Half
|
1380 SUPPORTED_100baseT_Full
|
1384 ecmd
->advertising
= ADVERTISED_MII
;
1385 if (tp
->advertising
[0] & ADVERTISE_10HALF
)
1386 ecmd
->advertising
|= ADVERTISED_10baseT_Half
;
1387 if (tp
->advertising
[0] & ADVERTISE_10FULL
)
1388 ecmd
->advertising
|= ADVERTISED_10baseT_Full
;
1389 if (tp
->advertising
[0] & ADVERTISE_100HALF
)
1390 ecmd
->advertising
|= ADVERTISED_100baseT_Half
;
1391 if (tp
->advertising
[0] & ADVERTISE_100FULL
)
1392 ecmd
->advertising
|= ADVERTISED_100baseT_Full
;
1394 ecmd
->advertising
|= ADVERTISED_Autoneg
;
1395 ecmd
->autoneg
= AUTONEG_ENABLE
;
1397 ecmd
->autoneg
= AUTONEG_DISABLE
;
1399 ecmd
->port
= PORT_MII
;
1400 ecmd
->transceiver
= XCVR_INTERNAL
;
1401 ecmd
->phy_address
= tp
->phys
[0];
1402 ecmd
->speed
= tp
->speed100
? SPEED_100
: SPEED_10
;
1403 ecmd
->duplex
= tp
->full_duplex
? DUPLEX_FULL
: DUPLEX_HALF
;
1404 ecmd
->maxtxpkt
= TX_RING_SIZE
/ 2;
1409 static int xircom_set_settings(struct net_device
*dev
, struct ethtool_cmd
*ecmd
)
1411 struct xircom_private
*tp
= netdev_priv(dev
);
1412 u16 autoneg
, speed100
, full_duplex
;
1414 autoneg
= (ecmd
->autoneg
== AUTONEG_ENABLE
);
1415 speed100
= (ecmd
->speed
== SPEED_100
);
1416 full_duplex
= (ecmd
->duplex
== DUPLEX_FULL
);
1418 tp
->autoneg
= autoneg
;
1419 if (speed100
!= tp
->speed100
||
1420 full_duplex
!= tp
->full_duplex
) {
1421 tp
->speed100
= speed100
;
1422 tp
->full_duplex
= full_duplex
;
1423 /* change advertising bits */
1424 tp
->advertising
[0] &= ~(ADVERTISE_10HALF
|
1428 ADVERTISE_100BASE4
);
1431 tp
->advertising
[0] |= ADVERTISE_100FULL
;
1433 tp
->advertising
[0] |= ADVERTISE_100HALF
;
1436 tp
->advertising
[0] |= ADVERTISE_10FULL
;
1438 tp
->advertising
[0] |= ADVERTISE_10HALF
;
1445 static void xircom_get_drvinfo(struct net_device
*dev
, struct ethtool_drvinfo
*info
)
1447 struct xircom_private
*tp
= netdev_priv(dev
);
1448 strcpy(info
->driver
, DRV_NAME
);
1449 strcpy(info
->version
, DRV_VERSION
);
1450 strcpy(info
->bus_info
, pci_name(tp
->pdev
));
1453 static struct ethtool_ops ops
= {
1454 .get_settings
= xircom_get_settings
,
1455 .set_settings
= xircom_set_settings
,
1456 .get_drvinfo
= xircom_get_drvinfo
,
1459 /* Provide ioctl() calls to examine the MII xcvr state. */
1460 static int xircom_ioctl(struct net_device
*dev
, struct ifreq
*rq
, int cmd
)
1462 struct xircom_private
*tp
= netdev_priv(dev
);
1463 u16
*data
= (u16
*)&rq
->ifr_ifru
;
1464 int phy
= tp
->phys
[0] & 0x1f;
1465 unsigned long flags
;
1468 /* Legacy mii-diag interface */
1469 case SIOCGMIIPHY
: /* Get address of MII PHY in use. */
1475 case SIOCGMIIREG
: /* Read MII PHY register. */
1478 data
[3] = mdio_read(dev
, data
[0] & 0x1f, data
[1] & 0x1f);
1479 restore_flags(flags
);
1481 case SIOCSMIIREG
: /* Write MII PHY register. */
1482 if (!capable(CAP_NET_ADMIN
))
1486 if (data
[0] == tp
->phys
[0]) {
1487 u16 value
= data
[2];
1490 if (value
& (BMCR_RESET
| BMCR_ANENABLE
))
1491 /* Autonegotiation. */
1494 tp
->full_duplex
= (value
& BMCR_FULLDPLX
) ? 1 : 0;
1499 tp
->advertising
[0] = value
;
1504 mdio_write(dev
, data
[0] & 0x1f, data
[1] & 0x1f, data
[2]);
1505 restore_flags(flags
);
1514 /* Set or clear the multicast filter for this adaptor.
1515 Note that we only use exclusion around actually queueing the
1516 new frame, not around filling tp->setup_frame. This is non-deterministic
1517 when re-entered but still correct. */
1518 static void set_rx_mode(struct net_device
*dev
)
1520 struct xircom_private
*tp
= netdev_priv(dev
);
1521 struct dev_mc_list
*mclist
;
1522 long ioaddr
= dev
->base_addr
;
1523 int csr6
= inl(ioaddr
+ CSR6
);
1524 u16
*eaddrs
, *setup_frm
;
1528 tp
->csr6
&= ~(AllMultiBit
| PromiscBit
| HashFilterBit
);
1529 csr6
&= ~(AllMultiBit
| PromiscBit
| HashFilterBit
);
1530 if (dev
->flags
& IFF_PROMISC
) { /* Set promiscuous. */
1531 tp
->csr6
|= PromiscBit
;
1536 if ((dev
->mc_count
> 1000) || (dev
->flags
& IFF_ALLMULTI
)) {
1537 /* Too many to filter well -- accept all multicasts. */
1538 tp
->csr6
|= AllMultiBit
;
1539 csr6
|= AllMultiBit
;
1543 tx_flags
= Tx1WholePkt
| Tx1SetupPkt
| PKT_SETUP_SZ
;
1545 /* Note that only the low-address shortword of setup_frame is valid! */
1546 setup_frm
= tp
->setup_frame
;
1547 mclist
= dev
->mc_list
;
1549 /* Fill the first entry with our physical address. */
1550 eaddrs
= (u16
*)dev
->dev_addr
;
1551 *setup_frm
= cpu_to_le16(eaddrs
[0]); setup_frm
+= 2;
1552 *setup_frm
= cpu_to_le16(eaddrs
[1]); setup_frm
+= 2;
1553 *setup_frm
= cpu_to_le16(eaddrs
[2]); setup_frm
+= 2;
1555 if (dev
->mc_count
> 14) { /* Must use a multicast hash table. */
1556 u32
*hash_table
= (u32
*)(tp
->setup_frame
+ 4 * 12);
1559 tx_flags
|= Tx1HashSetup
;
1560 tp
->csr6
|= HashFilterBit
;
1561 csr6
|= HashFilterBit
;
1563 /* Fill the unused 3 entries with the broadcast address.
1564 At least one entry *must* contain the broadcast address!!!*/
1565 for (i
= 0; i
< 3; i
++) {
1566 *setup_frm
= 0xffff; setup_frm
+= 2;
1567 *setup_frm
= 0xffff; setup_frm
+= 2;
1568 *setup_frm
= 0xffff; setup_frm
+= 2;
1571 /* Truly brain-damaged hash filter layout */
1572 /* XXX: not sure if I should take the last or the first 9 bits */
1573 for (i
= 0; i
< dev
->mc_count
; i
++, mclist
= mclist
->next
) {
1575 hash
= ether_crc(ETH_ALEN
, mclist
->dmi_addr
) & 0x1ff;
1577 hash2
= hash
+ ((hash
>> 4) << 4) +
1581 hash2
= 64 + hash
+ (hash
>> 4) * 80;
1583 hptr
= &hash_table
[hash2
& ~0x1f];
1584 *hptr
|= cpu_to_le32(1 << (hash2
& 0x1f));
1587 /* We have <= 14 mcast addresses so we can use Xircom's
1588 wonderful 16-address perfect filter. */
1589 for (i
= 0; i
< dev
->mc_count
; i
++, mclist
= mclist
->next
) {
1590 eaddrs
= (u16
*)mclist
->dmi_addr
;
1591 *setup_frm
= cpu_to_le16(eaddrs
[0]); setup_frm
+= 2;
1592 *setup_frm
= cpu_to_le16(eaddrs
[1]); setup_frm
+= 2;
1593 *setup_frm
= cpu_to_le16(eaddrs
[2]); setup_frm
+= 2;
1595 /* Fill the unused entries with the broadcast address.
1596 At least one entry *must* contain the broadcast address!!!*/
1597 for (; i
< 15; i
++) {
1598 *setup_frm
= 0xffff; setup_frm
+= 2;
1599 *setup_frm
= 0xffff; setup_frm
+= 2;
1600 *setup_frm
= 0xffff; setup_frm
+= 2;
1604 /* Now add this frame to the Tx list. */
1605 if (tp
->cur_tx
- tp
->dirty_tx
> TX_RING_SIZE
- 2) {
1606 /* Same setup recently queued, we need not add it. */
1607 /* XXX: Huh? All it means is that the Tx list is full...*/
1609 unsigned long flags
;
1613 save_flags(flags
); cli();
1614 entry
= tp
->cur_tx
++ % TX_RING_SIZE
;
1617 /* Avoid a chip errata by prefixing a dummy entry. */
1618 tp
->tx_skbuff
[entry
] = NULL
;
1619 tp
->tx_ring
[entry
].length
=
1620 (entry
== TX_RING_SIZE
- 1) ? Tx1RingWrap
: 0;
1621 tp
->tx_ring
[entry
].buffer1
= 0;
1622 /* race with chip, set Tx0DescOwned later */
1624 entry
= tp
->cur_tx
++ % TX_RING_SIZE
;
1627 tp
->tx_skbuff
[entry
] = NULL
;
1628 /* Put the setup frame on the Tx list. */
1629 if (entry
== TX_RING_SIZE
- 1)
1630 tx_flags
|= Tx1RingWrap
; /* Wrap ring. */
1631 tp
->tx_ring
[entry
].length
= tx_flags
;
1632 tp
->tx_ring
[entry
].buffer1
= virt_to_bus(tp
->setup_frame
);
1633 tp
->tx_ring
[entry
].status
= Tx0DescOwned
;
1634 if (tp
->cur_tx
- tp
->dirty_tx
>= TX_RING_SIZE
- 2) {
1636 netif_stop_queue (dev
);
1639 tp
->tx_ring
[dummy
].status
= Tx0DescOwned
;
1640 restore_flags(flags
);
1641 /* Trigger an immediate transmit demand. */
1642 outl(0, ioaddr
+ CSR1
);
1646 outl_CSR6(csr6
, ioaddr
);
1650 static struct pci_device_id xircom_pci_table
[] = {
1651 { 0x115D, 0x0003, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, X3201_3
},
1654 MODULE_DEVICE_TABLE(pci
, xircom_pci_table
);
1658 static int xircom_suspend(struct pci_dev
*pdev
, pm_message_t state
)
1660 struct net_device
*dev
= pci_get_drvdata(pdev
);
1661 struct xircom_private
*tp
= netdev_priv(dev
);
1662 printk(KERN_INFO
"xircom_suspend(%s)\n", dev
->name
);
1666 pci_save_state(pdev
);
1667 pci_disable_device(pdev
);
1668 pci_set_power_state(pdev
, 3);
1674 static int xircom_resume(struct pci_dev
*pdev
)
1676 struct net_device
*dev
= pci_get_drvdata(pdev
);
1677 struct xircom_private
*tp
= netdev_priv(dev
);
1678 printk(KERN_INFO
"xircom_resume(%s)\n", dev
->name
);
1680 pci_set_power_state(pdev
,0);
1681 pci_enable_device(pdev
);
1682 pci_restore_state(pdev
);
1684 /* Bring the chip out of sleep mode.
1685 Caution: Snooze mode does not work with some boards! */
1686 if (xircom_tbl
[tp
->chip_id
].flags
& HAS_ACPI
)
1687 pci_write_config_dword(tp
->pdev
, PCI_POWERMGMT
, 0);
1689 transceiver_voodoo(dev
);
1690 if (xircom_tbl
[tp
->chip_id
].flags
& HAS_MII
)
1697 #endif /* CONFIG_PM */
1700 static void __devexit
xircom_remove_one(struct pci_dev
*pdev
)
1702 struct net_device
*dev
= pci_get_drvdata(pdev
);
1704 printk(KERN_INFO
"xircom_remove_one(%s)\n", dev
->name
);
1705 unregister_netdev(dev
);
1706 pci_release_regions(pdev
);
1708 pci_set_drvdata(pdev
, NULL
);
1712 static struct pci_driver xircom_driver
= {
1714 .id_table
= xircom_pci_table
,
1715 .probe
= xircom_init_one
,
1716 .remove
= __devexit_p(xircom_remove_one
),
1718 .suspend
= xircom_suspend
,
1719 .resume
= xircom_resume
1720 #endif /* CONFIG_PM */
1724 static int __init
xircom_init(void)
1726 /* when a module, this is printed whether or not devices are found in probe */
1730 return pci_module_init(&xircom_driver
);
1734 static void __exit
xircom_exit(void)
1736 pci_unregister_driver(&xircom_driver
);
1739 module_init(xircom_init
)
1740 module_exit(xircom_exit
)