2 * xircom_cb: A driver for the (tulip-like) Xircom Cardbus ethernet cards
4 * This software is (C) by the respective authors, and licensed under the GPL
7 * Written by Arjan van de Ven for Red Hat, Inc.
8 * Based on work by Jeff Garzik, Doug Ledford and Donald Becker
10 * This software may be used and distributed according to the terms
11 * of the GNU General Public License, incorporated herein by reference.
14 * $Id: xircom_cb.c,v 1.33 2001/03/19 14:02:07 arjanv Exp $
17 #include <linux/module.h>
18 #include <linux/kernel.h>
19 #include <linux/string.h>
20 #include <linux/errno.h>
21 #include <linux/ioport.h>
22 #include <linux/slab.h>
23 #include <linux/interrupt.h>
24 #include <linux/pci.h>
25 #include <linux/netdevice.h>
26 #include <linux/etherdevice.h>
27 #include <linux/skbuff.h>
28 #include <linux/delay.h>
29 #include <linux/init.h>
30 #include <linux/ethtool.h>
31 #include <linux/bitops.h>
33 #include <asm/uaccess.h>
35 #ifdef CONFIG_NET_POLL_CONTROLLER
40 #define enter(x) printk("Enter: %s, %s line %i\n",x,__FILE__,__LINE__)
41 #define leave(x) printk("Leave: %s, %s line %i\n",x,__FILE__,__LINE__)
43 #define enter(x) do {} while (0)
44 #define leave(x) do {} while (0)
48 MODULE_DESCRIPTION("Xircom Cardbus ethernet driver");
49 MODULE_AUTHOR("Arjan van de Ven <arjanv@redhat.com>");
50 MODULE_LICENSE("GPL");
54 /* IO registers on the card, offsets */
74 #define PCI_POWERMGMT 0x40
76 /* Offsets of the buffers within the descriptor pages, in bytes */
78 #define NUMDESCRIPTORS 4
80 static int bufferoffsets
[NUMDESCRIPTORS
] = {128,2048,4096,6144};
83 struct xircom_private
{
84 /* Send and receive buffers, kernel-addressable and dma addressable forms */
89 dma_addr_t rx_dma_handle
;
90 dma_addr_t tx_dma_handle
;
92 struct sk_buff
*tx_skb
[4];
94 unsigned long io_port
;
97 /* transmit_used is the rotating counter that indicates which transmit
98 descriptor has to be used next */
101 /* Spinlock to serialize register operations.
102 It must be helt while manipulating the following registers:
103 CSR0, CSR6, CSR7, CSR9, CSR10, CSR15
107 struct pci_dev
*pdev
;
108 struct net_device
*dev
;
112 /* Function prototypes */
113 static int xircom_probe(struct pci_dev
*pdev
, const struct pci_device_id
*id
);
114 static void xircom_remove(struct pci_dev
*pdev
);
115 static irqreturn_t
xircom_interrupt(int irq
, void *dev_instance
);
116 static int xircom_start_xmit(struct sk_buff
*skb
, struct net_device
*dev
);
117 static int xircom_open(struct net_device
*dev
);
118 static int xircom_close(struct net_device
*dev
);
119 static void xircom_up(struct xircom_private
*card
);
120 #ifdef CONFIG_NET_POLL_CONTROLLER
121 static void xircom_poll_controller(struct net_device
*dev
);
124 static void investigate_read_descriptor(struct net_device
*dev
,struct xircom_private
*card
, int descnr
, unsigned int bufferoffset
);
125 static void investigate_write_descriptor(struct net_device
*dev
, struct xircom_private
*card
, int descnr
, unsigned int bufferoffset
);
126 static void read_mac_address(struct xircom_private
*card
);
127 static void transceiver_voodoo(struct xircom_private
*card
);
128 static void initialize_card(struct xircom_private
*card
);
129 static void trigger_transmit(struct xircom_private
*card
);
130 static void trigger_receive(struct xircom_private
*card
);
131 static void setup_descriptors(struct xircom_private
*card
);
132 static void remove_descriptors(struct xircom_private
*card
);
133 static int link_status_changed(struct xircom_private
*card
);
134 static void activate_receiver(struct xircom_private
*card
);
135 static void deactivate_receiver(struct xircom_private
*card
);
136 static void activate_transmitter(struct xircom_private
*card
);
137 static void deactivate_transmitter(struct xircom_private
*card
);
138 static void enable_transmit_interrupt(struct xircom_private
*card
);
139 static void enable_receive_interrupt(struct xircom_private
*card
);
140 static void enable_link_interrupt(struct xircom_private
*card
);
141 static void disable_all_interrupts(struct xircom_private
*card
);
142 static int link_status(struct xircom_private
*card
);
146 static struct pci_device_id xircom_pci_table
[] = {
147 {0x115D, 0x0003, PCI_ANY_ID
, PCI_ANY_ID
,},
150 MODULE_DEVICE_TABLE(pci
, xircom_pci_table
);
152 static struct pci_driver xircom_ops
= {
154 .id_table
= xircom_pci_table
,
155 .probe
= xircom_probe
,
156 .remove
= xircom_remove
,
163 static void print_binary(unsigned int number
)
169 for (i
=31;i
>=0;i
--) {
177 printk("%s\n",buffer
);
181 static void netdev_get_drvinfo(struct net_device
*dev
,
182 struct ethtool_drvinfo
*info
)
184 struct xircom_private
*private = netdev_priv(dev
);
186 strcpy(info
->driver
, "xircom_cb");
187 strcpy(info
->bus_info
, pci_name(private->pdev
));
190 static const struct ethtool_ops netdev_ethtool_ops
= {
191 .get_drvinfo
= netdev_get_drvinfo
,
194 static const struct net_device_ops netdev_ops
= {
195 .ndo_open
= xircom_open
,
196 .ndo_stop
= xircom_close
,
197 .ndo_start_xmit
= xircom_start_xmit
,
198 .ndo_change_mtu
= eth_change_mtu
,
199 .ndo_set_mac_address
= eth_mac_addr
,
200 .ndo_validate_addr
= eth_validate_addr
,
201 #ifdef CONFIG_NET_POLL_CONTROLLER
202 .ndo_poll_controller
= xircom_poll_controller
,
206 /* xircom_probe is the code that gets called on device insertion.
207 it sets up the hardware and registers the device to the networklayer.
209 TODO: Send 1 or 2 "dummy" packets here as the card seems to discard the
210 first two packets that get send, and pump hates that.
213 static int __devinit
xircom_probe(struct pci_dev
*pdev
, const struct pci_device_id
*id
)
215 struct net_device
*dev
= NULL
;
216 struct xircom_private
*private;
218 unsigned short tmp16
;
219 enter("xircom_probe");
221 /* First do the PCI initialisation */
223 if (pci_enable_device(pdev
))
226 /* disable all powermanagement */
227 pci_write_config_dword(pdev
, PCI_POWERMGMT
, 0x0000);
229 pci_set_master(pdev
); /* Why isn't this done by pci_enable_device ?*/
231 /* clear PCI status, if any */
232 pci_read_config_word (pdev
,PCI_STATUS
, &tmp16
);
233 pci_write_config_word (pdev
, PCI_STATUS
,tmp16
);
235 if (!request_region(pci_resource_start(pdev
, 0), 128, "xircom_cb")) {
236 printk(KERN_ERR
"xircom_probe: failed to allocate io-region\n");
241 Before changing the hardware, allocate the memory.
242 This way, we can fail gracefully if not enough memory
245 dev
= alloc_etherdev(sizeof(struct xircom_private
));
247 printk(KERN_ERR
"xircom_probe: failed to allocate etherdev\n");
250 private = netdev_priv(dev
);
252 /* Allocate the send/receive buffers */
253 private->rx_buffer
= pci_alloc_consistent(pdev
,8192,&private->rx_dma_handle
);
254 if (private->rx_buffer
== NULL
) {
255 printk(KERN_ERR
"xircom_probe: no memory for rx buffer \n");
258 private->tx_buffer
= pci_alloc_consistent(pdev
,8192,&private->tx_dma_handle
);
259 if (private->tx_buffer
== NULL
) {
260 printk(KERN_ERR
"xircom_probe: no memory for tx buffer \n");
264 SET_NETDEV_DEV(dev
, &pdev
->dev
);
268 private->pdev
= pdev
;
269 private->io_port
= pci_resource_start(pdev
, 0);
270 spin_lock_init(&private->lock
);
271 dev
->irq
= pdev
->irq
;
272 dev
->base_addr
= private->io_port
;
274 initialize_card(private);
275 read_mac_address(private);
276 setup_descriptors(private);
278 dev
->netdev_ops
= &netdev_ops
;
279 SET_ETHTOOL_OPS(dev
, &netdev_ethtool_ops
);
280 pci_set_drvdata(pdev
, dev
);
282 if (register_netdev(dev
)) {
283 printk(KERN_ERR
"xircom_probe: netdevice registration failed.\n");
287 printk(KERN_INFO
"%s: Xircom cardbus revision %i at irq %i \n", dev
->name
, pdev
->revision
, pdev
->irq
);
288 /* start the transmitter to get a heartbeat */
289 /* TODO: send 2 dummy packets here */
290 transceiver_voodoo(private);
292 spin_lock_irqsave(&private->lock
,flags
);
293 activate_transmitter(private);
294 activate_receiver(private);
295 spin_unlock_irqrestore(&private->lock
,flags
);
297 trigger_receive(private);
299 leave("xircom_probe");
303 kfree(private->tx_buffer
);
305 kfree(private->rx_buffer
);
314 xircom_remove is called on module-unload or on device-eject.
315 it unregisters the irq, io-region and network device.
316 Interrupts and such are already stopped in the "ifconfig ethX down"
319 static void __devexit
xircom_remove(struct pci_dev
*pdev
)
321 struct net_device
*dev
= pci_get_drvdata(pdev
);
322 struct xircom_private
*card
= netdev_priv(dev
);
324 enter("xircom_remove");
325 pci_free_consistent(pdev
,8192,card
->rx_buffer
,card
->rx_dma_handle
);
326 pci_free_consistent(pdev
,8192,card
->tx_buffer
,card
->tx_dma_handle
);
328 release_region(dev
->base_addr
, 128);
329 unregister_netdev(dev
);
331 pci_set_drvdata(pdev
, NULL
);
332 leave("xircom_remove");
335 static irqreturn_t
xircom_interrupt(int irq
, void *dev_instance
)
337 struct net_device
*dev
= (struct net_device
*) dev_instance
;
338 struct xircom_private
*card
= netdev_priv(dev
);
342 enter("xircom_interrupt\n");
344 spin_lock(&card
->lock
);
345 status
= inl(card
->io_port
+CSR5
);
348 print_binary(status
);
349 printk("tx status 0x%08x 0x%08x \n",card
->tx_buffer
[0],card
->tx_buffer
[4]);
350 printk("rx status 0x%08x 0x%08x \n",card
->rx_buffer
[0],card
->rx_buffer
[4]);
352 /* Handle shared irq and hotplug */
353 if (status
== 0 || status
== 0xffffffff) {
354 spin_unlock(&card
->lock
);
358 if (link_status_changed(card
)) {
360 printk(KERN_DEBUG
"xircom_cb: Link status has changed \n");
361 newlink
= link_status(card
);
362 printk(KERN_INFO
"xircom_cb: Link is %i mbit \n",newlink
);
364 netif_carrier_on(dev
);
366 netif_carrier_off(dev
);
370 /* Clear all remaining interrupts */
371 status
|= 0xffffffff; /* FIXME: make this clear only the
372 real existing bits */
373 outl(status
,card
->io_port
+CSR5
);
376 for (i
=0;i
<NUMDESCRIPTORS
;i
++)
377 investigate_write_descriptor(dev
,card
,i
,bufferoffsets
[i
]);
378 for (i
=0;i
<NUMDESCRIPTORS
;i
++)
379 investigate_read_descriptor(dev
,card
,i
,bufferoffsets
[i
]);
382 spin_unlock(&card
->lock
);
383 leave("xircom_interrupt");
387 static int xircom_start_xmit(struct sk_buff
*skb
, struct net_device
*dev
)
389 struct xircom_private
*card
;
393 enter("xircom_start_xmit");
395 card
= netdev_priv(dev
);
396 spin_lock_irqsave(&card
->lock
,flags
);
398 /* First see if we can free some descriptors */
399 for (desc
=0;desc
<NUMDESCRIPTORS
;desc
++)
400 investigate_write_descriptor(dev
,card
,desc
,bufferoffsets
[desc
]);
403 nextdescriptor
= (card
->transmit_used
+1) % (NUMDESCRIPTORS
);
404 desc
= card
->transmit_used
;
406 /* only send the packet if the descriptor is free */
407 if (card
->tx_buffer
[4*desc
]==0) {
408 /* Copy the packet data; zero the memory first as the card
409 sometimes sends more than you ask it to. */
411 memset(&card
->tx_buffer
[bufferoffsets
[desc
]/4],0,1536);
412 skb_copy_from_linear_data(skb
,
413 &(card
->tx_buffer
[bufferoffsets
[desc
] / 4]),
415 /* FIXME: The specification tells us that the length we send HAS to be a multiple of
418 card
->tx_buffer
[4*desc
+1] = cpu_to_le32(skb
->len
);
419 if (desc
== NUMDESCRIPTORS
- 1) /* bit 25: last descriptor of the ring */
420 card
->tx_buffer
[4*desc
+1] |= cpu_to_le32(1<<25);
422 card
->tx_buffer
[4*desc
+1] |= cpu_to_le32(0xF0000000);
423 /* 0xF0... means want interrupts*/
424 card
->tx_skb
[desc
] = skb
;
427 /* This gives the descriptor to the card */
428 card
->tx_buffer
[4*desc
] = cpu_to_le32(0x80000000);
429 trigger_transmit(card
);
430 if (card
->tx_buffer
[nextdescriptor
*4] & cpu_to_le32(0x8000000)) {
431 /* next descriptor is occupied... */
432 netif_stop_queue(dev
);
434 card
->transmit_used
= nextdescriptor
;
435 leave("xircom-start_xmit - sent");
436 spin_unlock_irqrestore(&card
->lock
,flags
);
442 /* Uh oh... no free descriptor... drop the packet */
443 netif_stop_queue(dev
);
444 spin_unlock_irqrestore(&card
->lock
,flags
);
445 trigger_transmit(card
);
447 return NETDEV_TX_BUSY
;
453 static int xircom_open(struct net_device
*dev
)
455 struct xircom_private
*xp
= netdev_priv(dev
);
457 enter("xircom_open");
458 printk(KERN_INFO
"xircom cardbus adaptor found, registering as %s, using irq %i \n",dev
->name
,dev
->irq
);
459 retval
= request_irq(dev
->irq
, &xircom_interrupt
, IRQF_SHARED
, dev
->name
, dev
);
461 leave("xircom_open - No IRQ");
467 leave("xircom_open");
471 static int xircom_close(struct net_device
*dev
)
473 struct xircom_private
*card
;
476 enter("xircom_close");
477 card
= netdev_priv(dev
);
478 netif_stop_queue(dev
); /* we don't want new packets */
481 spin_lock_irqsave(&card
->lock
,flags
);
483 disable_all_interrupts(card
);
485 /* We can enable this again once we send dummy packets on ifconfig ethX up */
486 deactivate_receiver(card
);
487 deactivate_transmitter(card
);
489 remove_descriptors(card
);
491 spin_unlock_irqrestore(&card
->lock
,flags
);
494 free_irq(dev
->irq
,dev
);
496 leave("xircom_close");
503 #ifdef CONFIG_NET_POLL_CONTROLLER
504 static void xircom_poll_controller(struct net_device
*dev
)
506 disable_irq(dev
->irq
);
507 xircom_interrupt(dev
->irq
, dev
);
508 enable_irq(dev
->irq
);
513 static void initialize_card(struct xircom_private
*card
)
517 enter("initialize_card");
520 spin_lock_irqsave(&card
->lock
, flags
);
522 /* First: reset the card */
523 val
= inl(card
->io_port
+ CSR0
);
524 val
|= 0x01; /* Software reset */
525 outl(val
, card
->io_port
+ CSR0
);
527 udelay(100); /* give the card some time to reset */
529 val
= inl(card
->io_port
+ CSR0
);
530 val
&= ~0x01; /* disable Software reset */
531 outl(val
, card
->io_port
+ CSR0
);
534 val
= 0; /* Value 0x00 is a safe and conservative value
535 for the PCI configuration settings */
536 outl(val
, card
->io_port
+ CSR0
);
539 disable_all_interrupts(card
);
540 deactivate_receiver(card
);
541 deactivate_transmitter(card
);
543 spin_unlock_irqrestore(&card
->lock
, flags
);
545 leave("initialize_card");
549 trigger_transmit causes the card to check for frames to be transmitted.
550 This is accomplished by writing to the CSR1 port. The documentation
551 claims that the act of writing is sufficient and that the value is
552 ignored; I chose zero.
554 static void trigger_transmit(struct xircom_private
*card
)
557 enter("trigger_transmit");
560 outl(val
, card
->io_port
+ CSR1
);
562 leave("trigger_transmit");
566 trigger_receive causes the card to check for empty frames in the
567 descriptor list in which packets can be received.
568 This is accomplished by writing to the CSR2 port. The documentation
569 claims that the act of writing is sufficient and that the value is
570 ignored; I chose zero.
572 static void trigger_receive(struct xircom_private
*card
)
575 enter("trigger_receive");
578 outl(val
, card
->io_port
+ CSR2
);
580 leave("trigger_receive");
584 setup_descriptors initializes the send and receive buffers to be valid
585 descriptors and programs the addresses into the card.
587 static void setup_descriptors(struct xircom_private
*card
)
591 enter("setup_descriptors");
594 BUG_ON(card
->rx_buffer
== NULL
);
595 BUG_ON(card
->tx_buffer
== NULL
);
597 /* Receive descriptors */
598 memset(card
->rx_buffer
, 0, 128); /* clear the descriptors */
599 for (i
=0;i
<NUMDESCRIPTORS
;i
++ ) {
601 /* Rx Descr0: It's empty, let the card own it, no errors -> 0x80000000 */
602 card
->rx_buffer
[i
*4 + 0] = cpu_to_le32(0x80000000);
603 /* Rx Descr1: buffer 1 is 1536 bytes, buffer 2 is 0 bytes */
604 card
->rx_buffer
[i
*4 + 1] = cpu_to_le32(1536);
605 if (i
== NUMDESCRIPTORS
- 1) /* bit 25 is "last descriptor" */
606 card
->rx_buffer
[i
*4 + 1] |= cpu_to_le32(1 << 25);
608 /* Rx Descr2: address of the buffer
609 we store the buffer at the 2nd half of the page */
611 address
= card
->rx_dma_handle
;
612 card
->rx_buffer
[i
*4 + 2] = cpu_to_le32(address
+ bufferoffsets
[i
]);
613 /* Rx Desc3: address of 2nd buffer -> 0 */
614 card
->rx_buffer
[i
*4 + 3] = 0;
618 /* Write the receive descriptor ring address to the card */
619 address
= card
->rx_dma_handle
;
620 outl(address
, card
->io_port
+ CSR3
); /* Receive descr list address */
623 /* transmit descriptors */
624 memset(card
->tx_buffer
, 0, 128); /* clear the descriptors */
626 for (i
=0;i
<NUMDESCRIPTORS
;i
++ ) {
627 /* Tx Descr0: Empty, we own it, no errors -> 0x00000000 */
628 card
->tx_buffer
[i
*4 + 0] = 0x00000000;
629 /* Tx Descr1: buffer 1 is 1536 bytes, buffer 2 is 0 bytes */
630 card
->tx_buffer
[i
*4 + 1] = cpu_to_le32(1536);
631 if (i
== NUMDESCRIPTORS
- 1) /* bit 25 is "last descriptor" */
632 card
->tx_buffer
[i
*4 + 1] |= cpu_to_le32(1 << 25);
634 /* Tx Descr2: address of the buffer
635 we store the buffer at the 2nd half of the page */
636 address
= card
->tx_dma_handle
;
637 card
->tx_buffer
[i
*4 + 2] = cpu_to_le32(address
+ bufferoffsets
[i
]);
638 /* Tx Desc3: address of 2nd buffer -> 0 */
639 card
->tx_buffer
[i
*4 + 3] = 0;
643 /* wite the transmit descriptor ring to the card */
644 address
= card
->tx_dma_handle
;
645 outl(address
, card
->io_port
+ CSR4
); /* xmit descr list address */
647 leave("setup_descriptors");
651 remove_descriptors informs the card the descriptors are no longer
652 valid by setting the address in the card to 0x00.
654 static void remove_descriptors(struct xircom_private
*card
)
657 enter("remove_descriptors");
660 outl(val
, card
->io_port
+ CSR3
); /* Receive descriptor address */
661 outl(val
, card
->io_port
+ CSR4
); /* Send descriptor address */
663 leave("remove_descriptors");
667 link_status_changed returns 1 if the card has indicated that
668 the link status has changed. The new link status has to be read from CSR12.
670 This function also clears the status-bit.
672 static int link_status_changed(struct xircom_private
*card
)
675 enter("link_status_changed");
677 val
= inl(card
->io_port
+ CSR5
); /* Status register */
679 if ((val
& (1 << 27)) == 0) { /* no change */
680 leave("link_status_changed - nochange");
684 /* clear the event by writing a 1 to the bit in the
687 outl(val
, card
->io_port
+ CSR5
);
689 leave("link_status_changed - changed");
695 transmit_active returns 1 if the transmitter on the card is
696 in a non-stopped state.
698 static int transmit_active(struct xircom_private
*card
)
701 enter("transmit_active");
703 val
= inl(card
->io_port
+ CSR5
); /* Status register */
705 if ((val
& (7 << 20)) == 0) { /* transmitter disabled */
706 leave("transmit_active - inactive");
710 leave("transmit_active - active");
715 receive_active returns 1 if the receiver on the card is
716 in a non-stopped state.
718 static int receive_active(struct xircom_private
*card
)
721 enter("receive_active");
724 val
= inl(card
->io_port
+ CSR5
); /* Status register */
726 if ((val
& (7 << 17)) == 0) { /* receiver disabled */
727 leave("receive_active - inactive");
731 leave("receive_active - active");
736 activate_receiver enables the receiver on the card.
737 Before being allowed to active the receiver, the receiver
738 must be completely de-activated. To achieve this,
739 this code actually disables the receiver first; then it waits for the
740 receiver to become inactive, then it activates the receiver and then
741 it waits for the receiver to be active.
743 must be called with the lock held and interrupts disabled.
745 static void activate_receiver(struct xircom_private
*card
)
749 enter("activate_receiver");
752 val
= inl(card
->io_port
+ CSR6
); /* Operation mode */
754 /* If the "active" bit is set and the receiver is already
755 active, no need to do the expensive thing */
756 if ((val
&2) && (receive_active(card
)))
760 val
= val
& ~2; /* disable the receiver */
761 outl(val
, card
->io_port
+ CSR6
);
764 while (counter
> 0) {
765 if (!receive_active(card
))
771 printk(KERN_ERR
"xircom_cb: Receiver failed to deactivate\n");
774 /* enable the receiver */
775 val
= inl(card
->io_port
+ CSR6
); /* Operation mode */
776 val
= val
| 2; /* enable the receiver */
777 outl(val
, card
->io_port
+ CSR6
);
779 /* now wait for the card to activate again */
781 while (counter
> 0) {
782 if (receive_active(card
))
788 printk(KERN_ERR
"xircom_cb: Receiver failed to re-activate\n");
791 leave("activate_receiver");
795 deactivate_receiver disables the receiver on the card.
796 To achieve this this code disables the receiver first;
797 then it waits for the receiver to become inactive.
799 must be called with the lock held and interrupts disabled.
801 static void deactivate_receiver(struct xircom_private
*card
)
805 enter("deactivate_receiver");
807 val
= inl(card
->io_port
+ CSR6
); /* Operation mode */
808 val
= val
& ~2; /* disable the receiver */
809 outl(val
, card
->io_port
+ CSR6
);
812 while (counter
> 0) {
813 if (!receive_active(card
))
819 printk(KERN_ERR
"xircom_cb: Receiver failed to deactivate\n");
823 leave("deactivate_receiver");
828 activate_transmitter enables the transmitter on the card.
829 Before being allowed to active the transmitter, the transmitter
830 must be completely de-activated. To achieve this,
831 this code actually disables the transmitter first; then it waits for the
832 transmitter to become inactive, then it activates the transmitter and then
833 it waits for the transmitter to be active again.
835 must be called with the lock held and interrupts disabled.
837 static void activate_transmitter(struct xircom_private
*card
)
841 enter("activate_transmitter");
844 val
= inl(card
->io_port
+ CSR6
); /* Operation mode */
846 /* If the "active" bit is set and the receiver is already
847 active, no need to do the expensive thing */
848 if ((val
&(1<<13)) && (transmit_active(card
)))
851 val
= val
& ~(1 << 13); /* disable the transmitter */
852 outl(val
, card
->io_port
+ CSR6
);
855 while (counter
> 0) {
856 if (!transmit_active(card
))
862 printk(KERN_ERR
"xircom_cb: Transmitter failed to deactivate\n");
865 /* enable the transmitter */
866 val
= inl(card
->io_port
+ CSR6
); /* Operation mode */
867 val
= val
| (1 << 13); /* enable the transmitter */
868 outl(val
, card
->io_port
+ CSR6
);
870 /* now wait for the card to activate again */
872 while (counter
> 0) {
873 if (transmit_active(card
))
879 printk(KERN_ERR
"xircom_cb: Transmitter failed to re-activate\n");
882 leave("activate_transmitter");
886 deactivate_transmitter disables the transmitter on the card.
887 To achieve this this code disables the transmitter first;
888 then it waits for the transmitter to become inactive.
890 must be called with the lock held and interrupts disabled.
892 static void deactivate_transmitter(struct xircom_private
*card
)
896 enter("deactivate_transmitter");
898 val
= inl(card
->io_port
+ CSR6
); /* Operation mode */
899 val
= val
& ~2; /* disable the transmitter */
900 outl(val
, card
->io_port
+ CSR6
);
903 while (counter
> 0) {
904 if (!transmit_active(card
))
910 printk(KERN_ERR
"xircom_cb: Transmitter failed to deactivate\n");
914 leave("deactivate_transmitter");
919 enable_transmit_interrupt enables the transmit interrupt
921 must be called with the lock held and interrupts disabled.
923 static void enable_transmit_interrupt(struct xircom_private
*card
)
926 enter("enable_transmit_interrupt");
928 val
= inl(card
->io_port
+ CSR7
); /* Interrupt enable register */
929 val
|= 1; /* enable the transmit interrupt */
930 outl(val
, card
->io_port
+ CSR7
);
932 leave("enable_transmit_interrupt");
937 enable_receive_interrupt enables the receive interrupt
939 must be called with the lock held and interrupts disabled.
941 static void enable_receive_interrupt(struct xircom_private
*card
)
944 enter("enable_receive_interrupt");
946 val
= inl(card
->io_port
+ CSR7
); /* Interrupt enable register */
947 val
= val
| (1 << 6); /* enable the receive interrupt */
948 outl(val
, card
->io_port
+ CSR7
);
950 leave("enable_receive_interrupt");
954 enable_link_interrupt enables the link status change interrupt
956 must be called with the lock held and interrupts disabled.
958 static void enable_link_interrupt(struct xircom_private
*card
)
961 enter("enable_link_interrupt");
963 val
= inl(card
->io_port
+ CSR7
); /* Interrupt enable register */
964 val
= val
| (1 << 27); /* enable the link status chage interrupt */
965 outl(val
, card
->io_port
+ CSR7
);
967 leave("enable_link_interrupt");
973 disable_all_interrupts disables all interrupts
975 must be called with the lock held and interrupts disabled.
977 static void disable_all_interrupts(struct xircom_private
*card
)
980 enter("enable_all_interrupts");
982 val
= 0; /* disable all interrupts */
983 outl(val
, card
->io_port
+ CSR7
);
985 leave("disable_all_interrupts");
989 enable_common_interrupts enables several weird interrupts
991 must be called with the lock held and interrupts disabled.
993 static void enable_common_interrupts(struct xircom_private
*card
)
996 enter("enable_link_interrupt");
998 val
= inl(card
->io_port
+ CSR7
); /* Interrupt enable register */
999 val
|= (1<<16); /* Normal Interrupt Summary */
1000 val
|= (1<<15); /* Abnormal Interrupt Summary */
1001 val
|= (1<<13); /* Fatal bus error */
1002 val
|= (1<<8); /* Receive Process Stopped */
1003 val
|= (1<<7); /* Receive Buffer Unavailable */
1004 val
|= (1<<5); /* Transmit Underflow */
1005 val
|= (1<<2); /* Transmit Buffer Unavailable */
1006 val
|= (1<<1); /* Transmit Process Stopped */
1007 outl(val
, card
->io_port
+ CSR7
);
1009 leave("enable_link_interrupt");
1013 enable_promisc starts promisc mode
1015 must be called with the lock held and interrupts disabled.
1017 static int enable_promisc(struct xircom_private
*card
)
1020 enter("enable_promisc");
1022 val
= inl(card
->io_port
+ CSR6
);
1023 val
= val
| (1 << 6);
1024 outl(val
, card
->io_port
+ CSR6
);
1026 leave("enable_promisc");
1034 link_status() checks the links status and will return 0 for no link, 10 for 10mbit link and 100 for.. guess what.
1036 Must be called in locked state with interrupts disabled
1038 static int link_status(struct xircom_private
*card
)
1041 enter("link_status");
1043 val
= inb(card
->io_port
+ CSR12
);
1045 if (!(val
&(1<<2))) /* bit 2 is 0 for 10mbit link, 1 for not an 10mbit link */
1047 if (!(val
&(1<<1))) /* bit 1 is 0 for 100mbit link, 1 for not an 100mbit link */
1050 /* If we get here -> no link at all */
1052 leave("link_status");
1061 read_mac_address() reads the MAC address from the NIC and stores it in the "dev" structure.
1063 This function will take the spinlock itself and can, as a result, not be called with the lock helt.
1065 static void read_mac_address(struct xircom_private
*card
)
1067 unsigned char j
, tuple
, link
, data_id
, data_count
;
1068 unsigned long flags
;
1071 enter("read_mac_address");
1073 spin_lock_irqsave(&card
->lock
, flags
);
1075 outl(1 << 12, card
->io_port
+ CSR9
); /* enable boot rom access */
1076 for (i
= 0x100; i
< 0x1f7; i
+= link
+ 2) {
1077 outl(i
, card
->io_port
+ CSR10
);
1078 tuple
= inl(card
->io_port
+ CSR9
) & 0xff;
1079 outl(i
+ 1, card
->io_port
+ CSR10
);
1080 link
= inl(card
->io_port
+ CSR9
) & 0xff;
1081 outl(i
+ 2, card
->io_port
+ CSR10
);
1082 data_id
= inl(card
->io_port
+ CSR9
) & 0xff;
1083 outl(i
+ 3, card
->io_port
+ CSR10
);
1084 data_count
= inl(card
->io_port
+ CSR9
) & 0xff;
1085 if ((tuple
== 0x22) && (data_id
== 0x04) && (data_count
== 0x06)) {
1087 * This is it. We have the data we want.
1089 for (j
= 0; j
< 6; j
++) {
1090 outl(i
+ j
+ 4, card
->io_port
+ CSR10
);
1091 card
->dev
->dev_addr
[j
] = inl(card
->io_port
+ CSR9
) & 0xff;
1094 } else if (link
== 0) {
1098 spin_unlock_irqrestore(&card
->lock
, flags
);
1099 pr_debug(" %pM\n", card
->dev
->dev_addr
);
1100 leave("read_mac_address");
1105 transceiver_voodoo() enables the external UTP plug thingy.
1106 it's called voodoo as I stole this code and cannot cross-reference
1107 it with the specification.
1109 static void transceiver_voodoo(struct xircom_private
*card
)
1111 unsigned long flags
;
1113 enter("transceiver_voodoo");
1115 /* disable all powermanagement */
1116 pci_write_config_dword(card
->pdev
, PCI_POWERMGMT
, 0x0000);
1118 setup_descriptors(card
);
1120 spin_lock_irqsave(&card
->lock
, flags
);
1122 outl(0x0008, card
->io_port
+ CSR15
);
1124 outl(0xa8050000, card
->io_port
+ CSR15
);
1126 outl(0xa00f0000, card
->io_port
+ CSR15
);
1129 spin_unlock_irqrestore(&card
->lock
, flags
);
1131 netif_start_queue(card
->dev
);
1132 leave("transceiver_voodoo");
1136 static void xircom_up(struct xircom_private
*card
)
1138 unsigned long flags
;
1143 /* disable all powermanagement */
1144 pci_write_config_dword(card
->pdev
, PCI_POWERMGMT
, 0x0000);
1146 setup_descriptors(card
);
1148 spin_lock_irqsave(&card
->lock
, flags
);
1151 enable_link_interrupt(card
);
1152 enable_transmit_interrupt(card
);
1153 enable_receive_interrupt(card
);
1154 enable_common_interrupts(card
);
1155 enable_promisc(card
);
1157 /* The card can have received packets already, read them away now */
1158 for (i
=0;i
<NUMDESCRIPTORS
;i
++)
1159 investigate_read_descriptor(card
->dev
,card
,i
,bufferoffsets
[i
]);
1162 spin_unlock_irqrestore(&card
->lock
, flags
);
1163 trigger_receive(card
);
1164 trigger_transmit(card
);
1165 netif_start_queue(card
->dev
);
1169 /* Bufferoffset is in BYTES */
1170 static void investigate_read_descriptor(struct net_device
*dev
,struct xircom_private
*card
, int descnr
, unsigned int bufferoffset
)
1174 enter("investigate_read_descriptor");
1175 status
= le32_to_cpu(card
->rx_buffer
[4*descnr
]);
1177 if ((status
> 0)) { /* packet received */
1179 /* TODO: discard error packets */
1181 short pkt_len
= ((status
>> 16) & 0x7ff) - 4; /* minus 4, we don't want the CRC */
1182 struct sk_buff
*skb
;
1184 if (pkt_len
> 1518) {
1185 printk(KERN_ERR
"xircom_cb: Packet length %i is bogus \n",pkt_len
);
1189 skb
= dev_alloc_skb(pkt_len
+ 2);
1191 dev
->stats
.rx_dropped
++;
1194 skb_reserve(skb
, 2);
1195 skb_copy_to_linear_data(skb
, (unsigned char*)&card
->rx_buffer
[bufferoffset
/ 4], pkt_len
);
1196 skb_put(skb
, pkt_len
);
1197 skb
->protocol
= eth_type_trans(skb
, dev
);
1199 dev
->stats
.rx_packets
++;
1200 dev
->stats
.rx_bytes
+= pkt_len
;
1203 /* give the buffer back to the card */
1204 card
->rx_buffer
[4*descnr
] = cpu_to_le32(0x80000000);
1205 trigger_receive(card
);
1208 leave("investigate_read_descriptor");
1213 /* Bufferoffset is in BYTES */
1214 static void investigate_write_descriptor(struct net_device
*dev
, struct xircom_private
*card
, int descnr
, unsigned int bufferoffset
)
1218 enter("investigate_write_descriptor");
1220 status
= le32_to_cpu(card
->tx_buffer
[4*descnr
]);
1222 if (status
& 0x8000) { /* Major error */
1223 printk(KERN_ERR
"Major transmit error status %x \n", status
);
1224 card
->tx_buffer
[4*descnr
] = 0;
1225 netif_wake_queue (dev
);
1228 if (status
> 0) { /* bit 31 is 0 when done */
1229 if (card
->tx_skb
[descnr
]!=NULL
) {
1230 dev
->stats
.tx_bytes
+= card
->tx_skb
[descnr
]->len
;
1231 dev_kfree_skb_irq(card
->tx_skb
[descnr
]);
1233 card
->tx_skb
[descnr
] = NULL
;
1234 /* Bit 8 in the status field is 1 if there was a collision */
1236 dev
->stats
.collisions
++;
1237 card
->tx_buffer
[4*descnr
] = 0; /* descriptor is free again */
1238 netif_wake_queue (dev
);
1239 dev
->stats
.tx_packets
++;
1242 leave("investigate_write_descriptor");
1247 static int __init
xircom_init(void)
1249 return pci_register_driver(&xircom_ops
);
1252 static void __exit
xircom_exit(void)
1254 pci_unregister_driver(&xircom_ops
);
1257 module_init(xircom_init
)
1258 module_exit(xircom_exit
)