diff options
Diffstat (limited to 'drivers/net/ethernet/cirrus')
-rw-r--r-- | drivers/net/ethernet/cirrus/cs89x0.c | 452 |
1 files changed, 272 insertions, 180 deletions
diff --git a/drivers/net/ethernet/cirrus/cs89x0.c b/drivers/net/ethernet/cirrus/cs89x0.c index b6120400d080..6e5b2c79340f 100644 --- a/drivers/net/ethernet/cirrus/cs89x0.c +++ b/drivers/net/ethernet/cirrus/cs89x0.c | |||
@@ -67,8 +67,8 @@ | |||
67 | #include <linux/bitops.h> | 67 | #include <linux/bitops.h> |
68 | #include <linux/delay.h> | 68 | #include <linux/delay.h> |
69 | #include <linux/gfp.h> | 69 | #include <linux/gfp.h> |
70 | #include <linux/io.h> | ||
70 | 71 | ||
71 | #include <asm/io.h> | ||
72 | #include <asm/irq.h> | 72 | #include <asm/irq.h> |
73 | #include <linux/atomic.h> | 73 | #include <linux/atomic.h> |
74 | #if ALLOW_DMA | 74 | #if ALLOW_DMA |
@@ -78,7 +78,7 @@ | |||
78 | #include "cs89x0.h" | 78 | #include "cs89x0.h" |
79 | 79 | ||
80 | static char version[] __initdata = | 80 | static char version[] __initdata = |
81 | "cs89x0.c: v2.4.3-pre1 Russell Nelson <nelson@crynwr.com>, Andrew Morton\n"; | 81 | "v2.4.3-pre1 Russell Nelson <nelson@crynwr.com>, Andrew Morton\n"; |
82 | 82 | ||
83 | #define DRV_NAME "cs89x0" | 83 | #define DRV_NAME "cs89x0" |
84 | 84 | ||
@@ -97,17 +97,29 @@ static char version[] __initdata = | |||
97 | */ | 97 | */ |
98 | #if defined(CONFIG_MACH_IXDP2351) | 98 | #if defined(CONFIG_MACH_IXDP2351) |
99 | #define CS89x0_NONISA_IRQ | 99 | #define CS89x0_NONISA_IRQ |
100 | static unsigned int netcard_portlist[] __used __initdata = {IXDP2351_VIRT_CS8900_BASE, 0}; | 100 | static unsigned int netcard_portlist[] __used __initdata = { |
101 | static unsigned int cs8900_irq_map[] = {IRQ_IXDP2351_CS8900, 0, 0, 0}; | 101 | IXDP2351_VIRT_CS8900_BASE, 0 |
102 | }; | ||
103 | static unsigned int cs8900_irq_map[] = { | ||
104 | IRQ_IXDP2351_CS8900, 0, 0, 0 | ||
105 | }; | ||
102 | #elif defined(CONFIG_ARCH_IXDP2X01) | 106 | #elif defined(CONFIG_ARCH_IXDP2X01) |
103 | #define CS89x0_NONISA_IRQ | 107 | #define CS89x0_NONISA_IRQ |
104 | static unsigned int netcard_portlist[] __used __initdata = {IXDP2X01_CS8900_VIRT_BASE, 0}; | 108 | static unsigned int netcard_portlist[] __used __initdata = { |
105 | static unsigned int cs8900_irq_map[] = {IRQ_IXDP2X01_CS8900, 0, 0, 0}; | 109 | IXDP2X01_CS8900_VIRT_BASE, 0 |
110 | }; | ||
111 | static unsigned int cs8900_irq_map[] = { | ||
112 | IRQ_IXDP2X01_CS8900, 0, 0, 0 | ||
113 | }; | ||
106 | #else | 114 | #else |
107 | #ifndef CONFIG_CS89x0_PLATFORM | 115 | #ifndef CONFIG_CS89x0_PLATFORM |
108 | static unsigned int netcard_portlist[] __used __initdata = | 116 | static unsigned int netcard_portlist[] __used __initdata = { |
109 | { 0x300, 0x320, 0x340, 0x360, 0x200, 0x220, 0x240, 0x260, 0x280, 0x2a0, 0x2c0, 0x2e0, 0}; | 117 | 0x300, 0x320, 0x340, 0x360, 0x200, 0x220, 0x240, |
110 | static unsigned int cs8900_irq_map[] = {10, 11, 12, 5}; | 118 | 0x260, 0x280, 0x2a0, 0x2c0, 0x2e0, 0 |
119 | }; | ||
120 | static unsigned int cs8900_irq_map[] = { | ||
121 | 10, 11, 12, 5 | ||
122 | }; | ||
111 | #endif | 123 | #endif |
112 | #endif | 124 | #endif |
113 | 125 | ||
@@ -201,9 +213,13 @@ static int g_cs89x0_media__force; | |||
201 | 213 | ||
202 | static int __init media_fn(char *str) | 214 | static int __init media_fn(char *str) |
203 | { | 215 | { |
204 | if (!strcmp(str, "rj45")) g_cs89x0_media__force = FORCE_RJ45; | 216 | if (!strcmp(str, "rj45")) |
205 | else if (!strcmp(str, "aui")) g_cs89x0_media__force = FORCE_AUI; | 217 | g_cs89x0_media__force = FORCE_RJ45; |
206 | else if (!strcmp(str, "bnc")) g_cs89x0_media__force = FORCE_BNC; | 218 | else if (!strcmp(str, "aui")) |
219 | g_cs89x0_media__force = FORCE_AUI; | ||
220 | else if (!strcmp(str, "bnc")) | ||
221 | g_cs89x0_media__force = FORCE_BNC; | ||
222 | |||
207 | return 1; | 223 | return 1; |
208 | } | 224 | } |
209 | 225 | ||
@@ -299,16 +315,21 @@ get_eeprom_data(struct net_device *dev, int off, int len, int *buffer) | |||
299 | { | 315 | { |
300 | int i; | 316 | int i; |
301 | 317 | ||
302 | if (net_debug > 3) printk("EEPROM data from %x for %x:\n", off, len); | 318 | if (net_debug > 3) |
319 | printk("EEPROM data from %x for %x:\n", off, len); | ||
303 | for (i = 0; i < len; i++) { | 320 | for (i = 0; i < len; i++) { |
304 | if (wait_eeprom_ready(dev) < 0) return -1; | 321 | if (wait_eeprom_ready(dev) < 0) |
322 | return -1; | ||
305 | /* Now send the EEPROM read command and EEPROM location to read */ | 323 | /* Now send the EEPROM read command and EEPROM location to read */ |
306 | writereg(dev, PP_EECMD, (off + i) | EEPROM_READ_CMD); | 324 | writereg(dev, PP_EECMD, (off + i) | EEPROM_READ_CMD); |
307 | if (wait_eeprom_ready(dev) < 0) return -1; | 325 | if (wait_eeprom_ready(dev) < 0) |
326 | return -1; | ||
308 | buffer[i] = readreg(dev, PP_EEData); | 327 | buffer[i] = readreg(dev, PP_EEData); |
309 | if (net_debug > 3) printk("%04x ", buffer[i]); | 328 | if (net_debug > 3) |
329 | printk("%04x ", buffer[i]); | ||
310 | } | 330 | } |
311 | if (net_debug > 3) printk("\n"); | 331 | if (net_debug > 3) |
332 | printk("\n"); | ||
312 | return 0; | 333 | return 0; |
313 | } | 334 | } |
314 | 335 | ||
@@ -364,7 +385,6 @@ static int __init | |||
364 | cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | 385 | cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) |
365 | { | 386 | { |
366 | struct net_local *lp = netdev_priv(dev); | 387 | struct net_local *lp = netdev_priv(dev); |
367 | static unsigned version_printed; | ||
368 | int i; | 388 | int i; |
369 | int tmp; | 389 | int tmp; |
370 | unsigned rev_type = 0; | 390 | unsigned rev_type = 0; |
@@ -415,8 +435,8 @@ cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | |||
415 | if (lp->chip_type != CS8900 && lp->chip_revision >= 'C') | 435 | if (lp->chip_type != CS8900 && lp->chip_revision >= 'C') |
416 | lp->send_cmd = TX_NOW; | 436 | lp->send_cmd = TX_NOW; |
417 | 437 | ||
418 | if (net_debug && version_printed++ == 0) | 438 | if (net_debug) |
419 | printk(version); | 439 | printk_once(version); |
420 | 440 | ||
421 | pr_info("%s: cs89%c0%s rev %c found at %p ", | 441 | pr_info("%s: cs89%c0%s rev %c found at %p ", |
422 | dev->name, | 442 | dev->name, |
@@ -436,7 +456,7 @@ cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | |||
436 | */ | 456 | */ |
437 | 457 | ||
438 | if ((readreg(dev, PP_SelfST) & (EEPROM_OK | EEPROM_PRESENT)) == | 458 | if ((readreg(dev, PP_SelfST) & (EEPROM_OK | EEPROM_PRESENT)) == |
439 | (EEPROM_OK|EEPROM_PRESENT)) { | 459 | (EEPROM_OK | EEPROM_PRESENT)) { |
440 | /* Load the MAC. */ | 460 | /* Load the MAC. */ |
441 | for (i = 0; i < ETH_ALEN / 2; i++) { | 461 | for (i = 0; i < ETH_ALEN / 2; i++) { |
442 | unsigned int Addr; | 462 | unsigned int Addr; |
@@ -507,12 +527,14 @@ cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | |||
507 | */ | 527 | */ |
508 | 528 | ||
509 | /* get transmission control word but keep the autonegotiation bits */ | 529 | /* get transmission control word but keep the autonegotiation bits */ |
510 | if (!lp->auto_neg_cnf) lp->auto_neg_cnf = eeprom_buff[AUTO_NEG_CNF_OFFSET/2]; | 530 | if (!lp->auto_neg_cnf) |
531 | lp->auto_neg_cnf = eeprom_buff[AUTO_NEG_CNF_OFFSET / 2]; | ||
511 | /* Store adapter configuration */ | 532 | /* Store adapter configuration */ |
512 | if (!lp->adapter_cnf) lp->adapter_cnf = eeprom_buff[ADAPTER_CNF_OFFSET/2]; | 533 | if (!lp->adapter_cnf) |
534 | lp->adapter_cnf = eeprom_buff[ADAPTER_CNF_OFFSET / 2]; | ||
513 | /* Store ISA configuration */ | 535 | /* Store ISA configuration */ |
514 | lp->isa_config = eeprom_buff[ISA_CNF_OFFSET/2]; | 536 | lp->isa_config = eeprom_buff[ISA_CNF_OFFSET / 2]; |
515 | dev->mem_start = eeprom_buff[PACKET_PAGE_OFFSET/2] << 8; | 537 | dev->mem_start = eeprom_buff[PACKET_PAGE_OFFSET / 2] << 8; |
516 | 538 | ||
517 | /* eeprom_buff has 32-bit ints, so we can't just memcpy it */ | 539 | /* eeprom_buff has 32-bit ints, so we can't just memcpy it */ |
518 | /* store the initial memory base address */ | 540 | /* store the initial memory base address */ |
@@ -528,13 +550,26 @@ cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | |||
528 | /* allow them to force multiple transceivers. If they force multiple, autosense */ | 550 | /* allow them to force multiple transceivers. If they force multiple, autosense */ |
529 | { | 551 | { |
530 | int count = 0; | 552 | int count = 0; |
531 | if (lp->force & FORCE_RJ45) {lp->adapter_cnf |= A_CNF_10B_T; count++; } | 553 | if (lp->force & FORCE_RJ45) { |
532 | if (lp->force & FORCE_AUI) {lp->adapter_cnf |= A_CNF_AUI; count++; } | 554 | lp->adapter_cnf |= A_CNF_10B_T; |
533 | if (lp->force & FORCE_BNC) {lp->adapter_cnf |= A_CNF_10B_2; count++; } | 555 | count++; |
534 | if (count > 1) {lp->adapter_cnf |= A_CNF_MEDIA_AUTO; } | 556 | } |
535 | else if (lp->force & FORCE_RJ45){lp->adapter_cnf |= A_CNF_MEDIA_10B_T; } | 557 | if (lp->force & FORCE_AUI) { |
536 | else if (lp->force & FORCE_AUI) {lp->adapter_cnf |= A_CNF_MEDIA_AUI; } | 558 | lp->adapter_cnf |= A_CNF_AUI; |
537 | else if (lp->force & FORCE_BNC) {lp->adapter_cnf |= A_CNF_MEDIA_10B_2; } | 559 | count++; |
560 | } | ||
561 | if (lp->force & FORCE_BNC) { | ||
562 | lp->adapter_cnf |= A_CNF_10B_2; | ||
563 | count++; | ||
564 | } | ||
565 | if (count > 1) | ||
566 | lp->adapter_cnf |= A_CNF_MEDIA_AUTO; | ||
567 | else if (lp->force & FORCE_RJ45) | ||
568 | lp->adapter_cnf |= A_CNF_MEDIA_10B_T; | ||
569 | else if (lp->force & FORCE_AUI) | ||
570 | lp->adapter_cnf |= A_CNF_MEDIA_AUI; | ||
571 | else if (lp->force & FORCE_BNC) | ||
572 | lp->adapter_cnf |= A_CNF_MEDIA_10B_2; | ||
538 | } | 573 | } |
539 | 574 | ||
540 | if (net_debug > 1) | 575 | if (net_debug > 1) |
@@ -584,7 +619,8 @@ cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | |||
584 | IRQ_MAP_LEN / 2, | 619 | IRQ_MAP_LEN / 2, |
585 | irq_map_buff) >= 0) { | 620 | irq_map_buff) >= 0) { |
586 | if ((irq_map_buff[0] & 0xff) == PNP_IRQ_FRMT) | 621 | if ((irq_map_buff[0] & 0xff) == PNP_IRQ_FRMT) |
587 | lp->irq_map = (irq_map_buff[0] >> 8) | (irq_map_buff[1] << 8); | 622 | lp->irq_map = ((irq_map_buff[0] >> 8) | |
623 | (irq_map_buff[1] << 8)); | ||
588 | } | 624 | } |
589 | #endif | 625 | #endif |
590 | } | 626 | } |
@@ -599,20 +635,16 @@ cs89x0_probe1(struct net_device *dev, void __iomem *ioaddr, int modular) | |||
599 | if (lp->use_dma) { | 635 | if (lp->use_dma) { |
600 | get_dma_channel(dev); | 636 | get_dma_channel(dev); |
601 | printk(", DMA %d", dev->dma); | 637 | printk(", DMA %d", dev->dma); |
602 | } | 638 | } else |
603 | else | ||
604 | #endif | 639 | #endif |
605 | { | ||
606 | printk(", programmed I/O"); | 640 | printk(", programmed I/O"); |
607 | } | ||
608 | 641 | ||
609 | /* print the ethernet address. */ | 642 | /* print the ethernet address. */ |
610 | printk(", MAC %pM", dev->dev_addr); | 643 | printk(", MAC %pM\n", dev->dev_addr); |
611 | 644 | ||
612 | dev->netdev_ops = &net_ops; | 645 | dev->netdev_ops = &net_ops; |
613 | dev->watchdog_timeo = HZ; | 646 | dev->watchdog_timeo = HZ; |
614 | 647 | ||
615 | printk("\n"); | ||
616 | if (net_debug) | 648 | if (net_debug) |
617 | printk("cs89x0_probe1() successful\n"); | 649 | printk("cs89x0_probe1() successful\n"); |
618 | 650 | ||
@@ -663,7 +695,7 @@ cs89x0_ioport_probe(struct net_device *dev, unsigned long ioport, int modular) | |||
663 | if (ioport & 1) { | 695 | if (ioport & 1) { |
664 | if (net_debug > 1) | 696 | if (net_debug > 1) |
665 | pr_info("%s: odd ioaddr 0x%lx\n", dev->name, ioport); | 697 | pr_info("%s: odd ioaddr 0x%lx\n", dev->name, ioport); |
666 | if ((ioport & 2) != 2) | 698 | if ((ioport & 2) != 2) { |
667 | if ((ioread16(io_mem + ADD_PORT) & ADD_MASK) != | 699 | if ((ioread16(io_mem + ADD_PORT) & ADD_MASK) != |
668 | ADD_SIG) { | 700 | ADD_SIG) { |
669 | pr_err("%s: bad signature 0x%x\n", | 701 | pr_err("%s: bad signature 0x%x\n", |
@@ -671,6 +703,7 @@ cs89x0_ioport_probe(struct net_device *dev, unsigned long ioport, int modular) | |||
671 | ret = -ENODEV; | 703 | ret = -ENODEV; |
672 | goto unmap; | 704 | goto unmap; |
673 | } | 705 | } |
706 | } | ||
674 | } | 707 | } |
675 | 708 | ||
676 | ret = cs89x0_probe1(dev, io_mem, modular); | 709 | ret = cs89x0_probe1(dev, io_mem, modular); |
@@ -742,7 +775,7 @@ out: | |||
742 | 775 | ||
743 | #if ALLOW_DMA | 776 | #if ALLOW_DMA |
744 | 777 | ||
745 | #define dma_page_eq(ptr1, ptr2) ((long)(ptr1)>>17 == (long)(ptr2)>>17) | 778 | #define dma_page_eq(ptr1, ptr2) ((long)(ptr1) >> 17 == (long)(ptr2) >> 17) |
746 | 779 | ||
747 | static void | 780 | static void |
748 | get_dma_channel(struct net_device *dev) | 781 | get_dma_channel(struct net_device *dev) |
@@ -771,11 +804,10 @@ write_dma(struct net_device *dev, int chip_type, int dma) | |||
771 | struct net_local *lp = netdev_priv(dev); | 804 | struct net_local *lp = netdev_priv(dev); |
772 | if ((lp->isa_config & ANY_ISA_DMA) == 0) | 805 | if ((lp->isa_config & ANY_ISA_DMA) == 0) |
773 | return; | 806 | return; |
774 | if (chip_type == CS8900) { | 807 | if (chip_type == CS8900) |
775 | writereg(dev, PP_CS8900_ISADMA, dma-5); | 808 | writereg(dev, PP_CS8900_ISADMA, dma - 5); |
776 | } else { | 809 | else |
777 | writereg(dev, PP_CS8920_ISADMA, dma); | 810 | writereg(dev, PP_CS8920_ISADMA, dma); |
778 | } | ||
779 | } | 811 | } |
780 | 812 | ||
781 | static void | 813 | static void |
@@ -836,8 +868,8 @@ dma_rx(struct net_device *dev) | |||
836 | int status, length; | 868 | int status, length; |
837 | unsigned char *bp = lp->rx_dma_ptr; | 869 | unsigned char *bp = lp->rx_dma_ptr; |
838 | 870 | ||
839 | status = bp[0] + (bp[1]<<8); | 871 | status = bp[0] + (bp[1] << 8); |
840 | length = bp[2] + (bp[3]<<8); | 872 | length = bp[2] + (bp[3] << 8); |
841 | bp += 4; | 873 | bp += 4; |
842 | if (net_debug > 5) { | 874 | if (net_debug > 5) { |
843 | printk("%s: receiving DMA packet at %lx, status %x, length %x\n", | 875 | printk("%s: receiving DMA packet at %lx, status %x, length %x\n", |
@@ -852,13 +884,15 @@ dma_rx(struct net_device *dev) | |||
852 | skb = netdev_alloc_skb(dev, length + 2); | 884 | skb = netdev_alloc_skb(dev, length + 2); |
853 | if (skb == NULL) { | 885 | if (skb == NULL) { |
854 | if (net_debug) /* I don't think we want to do this to a stressed system */ | 886 | if (net_debug) /* I don't think we want to do this to a stressed system */ |
855 | printk("%s: Memory squeeze, dropping packet.\n", dev->name); | 887 | printk("%s: Memory squeeze, dropping packet\n", |
888 | dev->name); | ||
856 | dev->stats.rx_dropped++; | 889 | dev->stats.rx_dropped++; |
857 | 890 | ||
858 | /* AKPM: advance bp to the next frame */ | 891 | /* AKPM: advance bp to the next frame */ |
859 | skip_this_frame: | 892 | skip_this_frame: |
860 | bp += (length + 3) & ~3; | 893 | bp += (length + 3) & ~3; |
861 | if (bp >= lp->end_dma_buff) bp -= lp->dmasize*1024; | 894 | if (bp >= lp->end_dma_buff) |
895 | bp -= lp->dmasize * 1024; | ||
862 | lp->rx_dma_ptr = bp; | 896 | lp->rx_dma_ptr = bp; |
863 | return; | 897 | return; |
864 | } | 898 | } |
@@ -873,13 +907,15 @@ skip_this_frame: | |||
873 | memcpy(skb_put(skb, length), bp, length); | 907 | memcpy(skb_put(skb, length), bp, length); |
874 | } | 908 | } |
875 | bp += (length + 3) & ~3; | 909 | bp += (length + 3) & ~3; |
876 | if (bp >= lp->end_dma_buff) bp -= lp->dmasize*1024; | 910 | if (bp >= lp->end_dma_buff) |
911 | bp -= lp->dmasize*1024; | ||
877 | lp->rx_dma_ptr = bp; | 912 | lp->rx_dma_ptr = bp; |
878 | 913 | ||
879 | if (net_debug > 3) { | 914 | if (net_debug > 3) { |
880 | printk("%s: received %d byte DMA packet of type %x\n", | 915 | printk("%s: received %d byte DMA packet of type %x\n", |
881 | dev->name, length, | 916 | dev->name, length, |
882 | (skb->data[ETH_ALEN + ETH_ALEN] << 8) | skb->data[ETH_ALEN + ETH_ALEN + 1]); | 917 | ((skb->data[ETH_ALEN + ETH_ALEN] << 8) | |
918 | skb->data[ETH_ALEN + ETH_ALEN + 1])); | ||
883 | } | 919 | } |
884 | skb->protocol = eth_type_trans(skb, dev); | 920 | skb->protocol = eth_type_trans(skb, dev); |
885 | netif_rx(skb); | 921 | netif_rx(skb); |
@@ -919,7 +955,8 @@ static void __init reset_chip(struct net_device *dev) | |||
919 | 955 | ||
920 | /* Wait until the chip is reset */ | 956 | /* Wait until the chip is reset */ |
921 | reset_start_time = jiffies; | 957 | reset_start_time = jiffies; |
922 | while ((readreg(dev, PP_SelfST) & INIT_DONE) == 0 && jiffies - reset_start_time < 2) | 958 | while ((readreg(dev, PP_SelfST) & INIT_DONE) == 0 && |
959 | jiffies - reset_start_time < 2) | ||
923 | ; | 960 | ; |
924 | #endif /* !CONFIG_MACH_MX31ADS */ | 961 | #endif /* !CONFIG_MACH_MX31ADS */ |
925 | } | 962 | } |
@@ -932,8 +969,9 @@ control_dc_dc(struct net_device *dev, int on_not_off) | |||
932 | unsigned int selfcontrol; | 969 | unsigned int selfcontrol; |
933 | int timenow = jiffies; | 970 | int timenow = jiffies; |
934 | /* control the DC to DC convertor in the SelfControl register. | 971 | /* control the DC to DC convertor in the SelfControl register. |
935 | Note: This is hooked up to a general purpose pin, might not | 972 | * Note: This is hooked up to a general purpose pin, might not |
936 | always be a DC to DC convertor. */ | 973 | * always be a DC to DC convertor. |
974 | */ | ||
937 | 975 | ||
938 | selfcontrol = HCB1_ENBL; /* Enable the HCB1 bit as an output */ | 976 | selfcontrol = HCB1_ENBL; /* Enable the HCB1 bit as an output */ |
939 | if (((lp->adapter_cnf & A_CNF_DC_DC_POLARITY) != 0) ^ on_not_off) | 977 | if (((lp->adapter_cnf & A_CNF_DC_DC_POLARITY) != 0) ^ on_not_off) |
@@ -960,18 +998,23 @@ detect_tp(struct net_device *dev) | |||
960 | int timenow = jiffies; | 998 | int timenow = jiffies; |
961 | int fdx; | 999 | int fdx; |
962 | 1000 | ||
963 | if (net_debug > 1) printk("%s: Attempting TP\n", dev->name); | 1001 | if (net_debug > 1) |
964 | 1002 | printk("%s: Attempting TP\n", dev->name); | |
965 | /* If connected to another full duplex capable 10-Base-T card the link pulses | 1003 | |
966 | seem to be lost when the auto detect bit in the LineCTL is set. | 1004 | /* If connected to another full duplex capable 10-Base-T card |
967 | To overcome this the auto detect bit will be cleared whilst testing the | 1005 | * the link pulses seem to be lost when the auto detect bit in |
968 | 10-Base-T interface. This would not be necessary for the sparrow chip but | 1006 | * the LineCTL is set. To overcome this the auto detect bit will |
969 | is simpler to do it anyway. */ | 1007 | * be cleared whilst testing the 10-Base-T interface. This would |
1008 | * not be necessary for the sparrow chip but is simpler to do it | ||
1009 | * anyway. | ||
1010 | */ | ||
970 | writereg(dev, PP_LineCTL, lp->linectl & ~AUI_ONLY); | 1011 | writereg(dev, PP_LineCTL, lp->linectl & ~AUI_ONLY); |
971 | control_dc_dc(dev, 0); | 1012 | control_dc_dc(dev, 0); |
972 | 1013 | ||
973 | /* Delay for the hardware to work out if the TP cable is present - 150ms */ | 1014 | /* Delay for the hardware to work out if the TP cable is present |
974 | for (timenow = jiffies; jiffies - timenow < 15; ) | 1015 | * - 150ms |
1016 | */ | ||
1017 | for (timenow = jiffies; jiffies - timenow < 15;) | ||
975 | ; | 1018 | ; |
976 | if ((readreg(dev, PP_LineST) & LINK_OK) == 0) | 1019 | if ((readreg(dev, PP_LineST) & LINK_OK) == 0) |
977 | return DETECTED_NONE; | 1020 | return DETECTED_NONE; |
@@ -991,7 +1034,8 @@ detect_tp(struct net_device *dev) | |||
991 | case FORCE_HALF: | 1034 | case FORCE_HALF: |
992 | break; | 1035 | break; |
993 | case FORCE_FULL: | 1036 | case FORCE_FULL: |
994 | writereg(dev, PP_TestCTL, readreg(dev, PP_TestCTL) | FDX_8900); | 1037 | writereg(dev, PP_TestCTL, |
1038 | readreg(dev, PP_TestCTL) | FDX_8900); | ||
995 | break; | 1039 | break; |
996 | } | 1040 | } |
997 | fdx = readreg(dev, PP_TestCTL) & FDX_8900; | 1041 | fdx = readreg(dev, PP_TestCTL) & FDX_8900; |
@@ -1032,10 +1076,12 @@ static int | |||
1032 | send_test_pkt(struct net_device *dev) | 1076 | send_test_pkt(struct net_device *dev) |
1033 | { | 1077 | { |
1034 | struct net_local *lp = netdev_priv(dev); | 1078 | struct net_local *lp = netdev_priv(dev); |
1035 | char test_packet[] = { 0,0,0,0,0,0, 0,0,0,0,0,0, | 1079 | char test_packet[] = { |
1036 | 0, 46, /* A 46 in network order */ | 1080 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, |
1037 | 0, 0, /* DSAP=0 & SSAP=0 fields */ | 1081 | 0, 46, /* A 46 in network order */ |
1038 | 0xf3, 0 /* Control (Test Req + P bit set) */ }; | 1082 | 0, 0, /* DSAP=0 & SSAP=0 fields */ |
1083 | 0xf3, 0 /* Control (Test Req + P bit set) */ | ||
1084 | }; | ||
1039 | long timenow = jiffies; | 1085 | long timenow = jiffies; |
1040 | 1086 | ||
1041 | writereg(dev, PP_LineCTL, readreg(dev, PP_LineCTL) | SERIAL_TX_ON); | 1087 | writereg(dev, PP_LineCTL, readreg(dev, PP_LineCTL) | SERIAL_TX_ON); |
@@ -1054,17 +1100,20 @@ send_test_pkt(struct net_device *dev) | |||
1054 | return 0; /* this shouldn't happen */ | 1100 | return 0; /* this shouldn't happen */ |
1055 | 1101 | ||
1056 | /* Write the contents of the packet */ | 1102 | /* Write the contents of the packet */ |
1057 | writewords(lp, TX_FRAME_PORT, test_packet, (ETH_ZLEN+1) >> 1); | 1103 | writewords(lp, TX_FRAME_PORT, test_packet, (ETH_ZLEN + 1) >> 1); |
1058 | 1104 | ||
1059 | if (net_debug > 1) printk("Sending test packet "); | 1105 | if (net_debug > 1) |
1106 | printk("Sending test packet "); | ||
1060 | /* wait a couple of jiffies for packet to be received */ | 1107 | /* wait a couple of jiffies for packet to be received */ |
1061 | for (timenow = jiffies; jiffies - timenow < 3; ) | 1108 | for (timenow = jiffies; jiffies - timenow < 3;) |
1062 | ; | 1109 | ; |
1063 | if ((readreg(dev, PP_TxEvent) & TX_SEND_OK_BITS) == TX_OK) { | 1110 | if ((readreg(dev, PP_TxEvent) & TX_SEND_OK_BITS) == TX_OK) { |
1064 | if (net_debug > 1) printk("succeeded\n"); | 1111 | if (net_debug > 1) |
1112 | printk("succeeded\n"); | ||
1065 | return 1; | 1113 | return 1; |
1066 | } | 1114 | } |
1067 | if (net_debug > 1) printk("failed\n"); | 1115 | if (net_debug > 1) |
1116 | printk("failed\n"); | ||
1068 | return 0; | 1117 | return 0; |
1069 | } | 1118 | } |
1070 | 1119 | ||
@@ -1074,7 +1123,8 @@ detect_aui(struct net_device *dev) | |||
1074 | { | 1123 | { |
1075 | struct net_local *lp = netdev_priv(dev); | 1124 | struct net_local *lp = netdev_priv(dev); |
1076 | 1125 | ||
1077 | if (net_debug > 1) printk("%s: Attempting AUI\n", dev->name); | 1126 | if (net_debug > 1) |
1127 | printk("%s: Attempting AUI\n", dev->name); | ||
1078 | control_dc_dc(dev, 0); | 1128 | control_dc_dc(dev, 0); |
1079 | 1129 | ||
1080 | writereg(dev, PP_LineCTL, (lp->linectl & ~AUTO_AUI_10BASET) | AUI_ONLY); | 1130 | writereg(dev, PP_LineCTL, (lp->linectl & ~AUTO_AUI_10BASET) | AUI_ONLY); |
@@ -1090,7 +1140,8 @@ detect_bnc(struct net_device *dev) | |||
1090 | { | 1140 | { |
1091 | struct net_local *lp = netdev_priv(dev); | 1141 | struct net_local *lp = netdev_priv(dev); |
1092 | 1142 | ||
1093 | if (net_debug > 1) printk("%s: Attempting BNC\n", dev->name); | 1143 | if (net_debug > 1) |
1144 | printk("%s: Attempting BNC\n", dev->name); | ||
1094 | control_dc_dc(dev, 1); | 1145 | control_dc_dc(dev, 1); |
1095 | 1146 | ||
1096 | writereg(dev, PP_LineCTL, (lp->linectl & ~AUTO_AUI_10BASET) | AUI_ONLY); | 1147 | writereg(dev, PP_LineCTL, (lp->linectl & ~AUTO_AUI_10BASET) | AUI_ONLY); |
@@ -1155,7 +1206,8 @@ net_open(struct net_device *dev) | |||
1155 | 1206 | ||
1156 | for (i = 2; i < CS8920_NO_INTS; i++) { | 1207 | for (i = 2; i < CS8920_NO_INTS; i++) { |
1157 | if ((1 << i) & lp->irq_map) { | 1208 | if ((1 << i) & lp->irq_map) { |
1158 | if (request_irq(i, net_interrupt, 0, dev->name, dev) == 0) { | 1209 | if (request_irq(i, net_interrupt, 0, dev->name, |
1210 | dev) == 0) { | ||
1159 | dev->irq = i; | 1211 | dev->irq = i; |
1160 | write_irq(dev, lp->chip_type, i); | 1212 | write_irq(dev, lp->chip_type, i); |
1161 | /* writereg(dev, PP_BufCFG, GENERATE_SW_INTERRUPT); */ | 1213 | /* writereg(dev, PP_BufCFG, GENERATE_SW_INTERRUPT); */ |
@@ -1170,9 +1222,7 @@ net_open(struct net_device *dev) | |||
1170 | ret = -EAGAIN; | 1222 | ret = -EAGAIN; |
1171 | goto bad_out; | 1223 | goto bad_out; |
1172 | } | 1224 | } |
1173 | } | 1225 | } else { |
1174 | else | ||
1175 | { | ||
1176 | #if !defined(CS89x0_NONISA_IRQ) && !defined(CONFIG_CS89x0_PLATFORM) | 1226 | #if !defined(CS89x0_NONISA_IRQ) && !defined(CONFIG_CS89x0_PLATFORM) |
1177 | if (((1 << dev->irq) & lp->irq_map) == 0) { | 1227 | if (((1 << dev->irq) & lp->irq_map) == 0) { |
1178 | pr_err("%s: IRQ %d is not in our map of allowable IRQs, which is %x\n", | 1228 | pr_err("%s: IRQ %d is not in our map of allowable IRQs, which is %x\n", |
@@ -1196,69 +1246,78 @@ net_open(struct net_device *dev) | |||
1196 | } | 1246 | } |
1197 | 1247 | ||
1198 | #if ALLOW_DMA | 1248 | #if ALLOW_DMA |
1199 | if (lp->use_dma) { | 1249 | if (lp->use_dma && (lp->isa_config & ANY_ISA_DMA)) { |
1200 | if (lp->isa_config & ANY_ISA_DMA) { | 1250 | unsigned long flags; |
1201 | unsigned long flags; | 1251 | lp->dma_buff = (unsigned char *)__get_dma_pages(GFP_KERNEL, |
1202 | lp->dma_buff = (unsigned char *)__get_dma_pages(GFP_KERNEL, | 1252 | get_order(lp->dmasize * 1024)); |
1203 | get_order(lp->dmasize * 1024)); | 1253 | if (!lp->dma_buff) { |
1204 | 1254 | pr_err("%s: cannot get %dK memory for DMA\n", | |
1205 | if (!lp->dma_buff) { | 1255 | dev->name, lp->dmasize); |
1206 | pr_err("%s: cannot get %dK memory for DMA\n", | 1256 | goto release_irq; |
1207 | dev->name, lp->dmasize); | 1257 | } |
1208 | goto release_irq; | 1258 | if (net_debug > 1) { |
1209 | } | 1259 | printk("%s: dma %lx %lx\n", |
1210 | if (net_debug > 1) { | 1260 | dev->name, |
1211 | printk("%s: dma %lx %lx\n", | 1261 | (unsigned long)lp->dma_buff, |
1212 | dev->name, | 1262 | (unsigned long)isa_virt_to_bus(lp->dma_buff)); |
1213 | (unsigned long)lp->dma_buff, | 1263 | } |
1214 | (unsigned long)isa_virt_to_bus(lp->dma_buff)); | 1264 | if ((unsigned long)lp->dma_buff >= MAX_DMA_ADDRESS || |
1215 | } | 1265 | !dma_page_eq(lp->dma_buff, |
1216 | if ((unsigned long) lp->dma_buff >= MAX_DMA_ADDRESS || | 1266 | lp->dma_buff + lp->dmasize * 1024 - 1)) { |
1217 | !dma_page_eq(lp->dma_buff, lp->dma_buff+lp->dmasize*1024-1)) { | 1267 | pr_err("%s: not usable as DMA buffer\n", dev->name); |
1218 | pr_err("%s: not usable as DMA buffer\n", | 1268 | goto release_irq; |
1219 | dev->name); | ||
1220 | goto release_irq; | ||
1221 | } | ||
1222 | memset(lp->dma_buff, 0, lp->dmasize * 1024); /* Why? */ | ||
1223 | if (request_dma(dev->dma, dev->name)) { | ||
1224 | pr_err("%s: cannot get dma channel %d\n", | ||
1225 | dev->name, dev->dma); | ||
1226 | goto release_irq; | ||
1227 | } | ||
1228 | write_dma(dev, lp->chip_type, dev->dma); | ||
1229 | lp->rx_dma_ptr = lp->dma_buff; | ||
1230 | lp->end_dma_buff = lp->dma_buff + lp->dmasize*1024; | ||
1231 | spin_lock_irqsave(&lp->lock, flags); | ||
1232 | disable_dma(dev->dma); | ||
1233 | clear_dma_ff(dev->dma); | ||
1234 | set_dma_mode(dev->dma, DMA_RX_MODE); /* auto_init as well */ | ||
1235 | set_dma_addr(dev->dma, isa_virt_to_bus(lp->dma_buff)); | ||
1236 | set_dma_count(dev->dma, lp->dmasize*1024); | ||
1237 | enable_dma(dev->dma); | ||
1238 | spin_unlock_irqrestore(&lp->lock, flags); | ||
1239 | } | 1269 | } |
1270 | memset(lp->dma_buff, 0, lp->dmasize * 1024); /* Why? */ | ||
1271 | if (request_dma(dev->dma, dev->name)) { | ||
1272 | pr_err("%s: cannot get dma channel %d\n", | ||
1273 | dev->name, dev->dma); | ||
1274 | goto release_irq; | ||
1275 | } | ||
1276 | write_dma(dev, lp->chip_type, dev->dma); | ||
1277 | lp->rx_dma_ptr = lp->dma_buff; | ||
1278 | lp->end_dma_buff = lp->dma_buff + lp->dmasize * 1024; | ||
1279 | spin_lock_irqsave(&lp->lock, flags); | ||
1280 | disable_dma(dev->dma); | ||
1281 | clear_dma_ff(dev->dma); | ||
1282 | set_dma_mode(dev->dma, DMA_RX_MODE); /* auto_init as well */ | ||
1283 | set_dma_addr(dev->dma, isa_virt_to_bus(lp->dma_buff)); | ||
1284 | set_dma_count(dev->dma, lp->dmasize * 1024); | ||
1285 | enable_dma(dev->dma); | ||
1286 | spin_unlock_irqrestore(&lp->lock, flags); | ||
1240 | } | 1287 | } |
1241 | #endif /* ALLOW_DMA */ | 1288 | #endif /* ALLOW_DMA */ |
1242 | 1289 | ||
1243 | /* set the Ethernet address */ | 1290 | /* set the Ethernet address */ |
1244 | for (i = 0; i < ETH_ALEN / 2; i++) | 1291 | for (i = 0; i < ETH_ALEN / 2; i++) |
1245 | writereg(dev, PP_IA + i * 2, dev->dev_addr[i * 2] | (dev->dev_addr[i * 2 + 1] << 8)); | 1292 | writereg(dev, PP_IA + i * 2, |
1293 | (dev->dev_addr[i * 2] | | ||
1294 | (dev->dev_addr[i * 2 + 1] << 8))); | ||
1246 | 1295 | ||
1247 | /* while we're testing the interface, leave interrupts disabled */ | 1296 | /* while we're testing the interface, leave interrupts disabled */ |
1248 | writereg(dev, PP_BusCTL, MEMORY_ON); | 1297 | writereg(dev, PP_BusCTL, MEMORY_ON); |
1249 | 1298 | ||
1250 | /* Set the LineCTL quintuplet based on adapter configuration read from EEPROM */ | 1299 | /* Set the LineCTL quintuplet based on adapter configuration read from EEPROM */ |
1251 | if ((lp->adapter_cnf & A_CNF_EXTND_10B_2) && (lp->adapter_cnf & A_CNF_LOW_RX_SQUELCH)) | 1300 | if ((lp->adapter_cnf & A_CNF_EXTND_10B_2) && |
1301 | (lp->adapter_cnf & A_CNF_LOW_RX_SQUELCH)) | ||
1252 | lp->linectl = LOW_RX_SQUELCH; | 1302 | lp->linectl = LOW_RX_SQUELCH; |
1253 | else | 1303 | else |
1254 | lp->linectl = 0; | 1304 | lp->linectl = 0; |
1255 | 1305 | ||
1256 | /* check to make sure that they have the "right" hardware available */ | 1306 | /* check to make sure that they have the "right" hardware available */ |
1257 | switch (lp->adapter_cnf & A_CNF_MEDIA_TYPE) { | 1307 | switch (lp->adapter_cnf & A_CNF_MEDIA_TYPE) { |
1258 | case A_CNF_MEDIA_10B_T: result = lp->adapter_cnf & A_CNF_10B_T; break; | 1308 | case A_CNF_MEDIA_10B_T: |
1259 | case A_CNF_MEDIA_AUI: result = lp->adapter_cnf & A_CNF_AUI; break; | 1309 | result = lp->adapter_cnf & A_CNF_10B_T; |
1260 | case A_CNF_MEDIA_10B_2: result = lp->adapter_cnf & A_CNF_10B_2; break; | 1310 | break; |
1261 | default: result = lp->adapter_cnf & (A_CNF_10B_T | A_CNF_AUI | A_CNF_10B_2); | 1311 | case A_CNF_MEDIA_AUI: |
1312 | result = lp->adapter_cnf & A_CNF_AUI; | ||
1313 | break; | ||
1314 | case A_CNF_MEDIA_10B_2: | ||
1315 | result = lp->adapter_cnf & A_CNF_10B_2; | ||
1316 | break; | ||
1317 | default: | ||
1318 | result = lp->adapter_cnf & (A_CNF_10B_T | | ||
1319 | A_CNF_AUI | | ||
1320 | A_CNF_10B_2); | ||
1262 | } | 1321 | } |
1263 | if (!result) { | 1322 | if (!result) { |
1264 | pr_err("%s: EEPROM is configured for unavailable media\n", | 1323 | pr_err("%s: EEPROM is configured for unavailable media\n", |
@@ -1269,7 +1328,8 @@ release_dma: | |||
1269 | release_irq: | 1328 | release_irq: |
1270 | release_dma_buff(lp); | 1329 | release_dma_buff(lp); |
1271 | #endif | 1330 | #endif |
1272 | writereg(dev, PP_LineCTL, readreg(dev, PP_LineCTL) & ~(SERIAL_TX_ON | SERIAL_RX_ON)); | 1331 | writereg(dev, PP_LineCTL, |
1332 | readreg(dev, PP_LineCTL) & ~(SERIAL_TX_ON | SERIAL_RX_ON)); | ||
1273 | free_irq(dev->irq, dev); | 1333 | free_irq(dev->irq, dev); |
1274 | ret = -EAGAIN; | 1334 | ret = -EAGAIN; |
1275 | goto bad_out; | 1335 | goto bad_out; |
@@ -1304,15 +1364,21 @@ release_irq: | |||
1304 | break; | 1364 | break; |
1305 | case A_CNF_MEDIA_AUTO: | 1365 | case A_CNF_MEDIA_AUTO: |
1306 | writereg(dev, PP_LineCTL, lp->linectl | AUTO_AUI_10BASET); | 1366 | writereg(dev, PP_LineCTL, lp->linectl | AUTO_AUI_10BASET); |
1307 | if (lp->adapter_cnf & A_CNF_10B_T) | 1367 | if (lp->adapter_cnf & A_CNF_10B_T) { |
1308 | if ((result = detect_tp(dev)) != DETECTED_NONE) | 1368 | result = detect_tp(dev); |
1369 | if (result != DETECTED_NONE) | ||
1309 | break; | 1370 | break; |
1310 | if (lp->adapter_cnf & A_CNF_AUI) | 1371 | } |
1311 | if ((result = detect_aui(dev)) != DETECTED_NONE) | 1372 | if (lp->adapter_cnf & A_CNF_AUI) { |
1373 | result = detect_aui(dev); | ||
1374 | if (result != DETECTED_NONE) | ||
1312 | break; | 1375 | break; |
1313 | if (lp->adapter_cnf & A_CNF_10B_2) | 1376 | } |
1314 | if ((result = detect_bnc(dev)) != DETECTED_NONE) | 1377 | if (lp->adapter_cnf & A_CNF_10B_2) { |
1378 | result = detect_bnc(dev); | ||
1379 | if (result != DETECTED_NONE) | ||
1315 | break; | 1380 | break; |
1381 | } | ||
1316 | pr_err("%s: no media detected\n", dev->name); | 1382 | pr_err("%s: no media detected\n", dev->name); |
1317 | goto release_dma; | 1383 | goto release_dma; |
1318 | } | 1384 | } |
@@ -1336,7 +1402,8 @@ release_irq: | |||
1336 | } | 1402 | } |
1337 | 1403 | ||
1338 | /* Turn on both receive and transmit operations */ | 1404 | /* Turn on both receive and transmit operations */ |
1339 | writereg(dev, PP_LineCTL, readreg(dev, PP_LineCTL) | SERIAL_RX_ON | SERIAL_TX_ON); | 1405 | writereg(dev, PP_LineCTL, |
1406 | readreg(dev, PP_LineCTL) | SERIAL_RX_ON | SERIAL_TX_ON); | ||
1340 | 1407 | ||
1341 | /* Receive only error free packets addressed to this card */ | 1408 | /* Receive only error free packets addressed to this card */ |
1342 | lp->rx_mode = 0; | 1409 | lp->rx_mode = 0; |
@@ -1351,22 +1418,29 @@ release_irq: | |||
1351 | #endif | 1418 | #endif |
1352 | writereg(dev, PP_RxCFG, lp->curr_rx_cfg); | 1419 | writereg(dev, PP_RxCFG, lp->curr_rx_cfg); |
1353 | 1420 | ||
1354 | writereg(dev, PP_TxCFG, TX_LOST_CRS_ENBL | TX_SQE_ERROR_ENBL | TX_OK_ENBL | | 1421 | writereg(dev, PP_TxCFG, (TX_LOST_CRS_ENBL | |
1355 | TX_LATE_COL_ENBL | TX_JBR_ENBL | TX_ANY_COL_ENBL | TX_16_COL_ENBL); | 1422 | TX_SQE_ERROR_ENBL | |
1423 | TX_OK_ENBL | | ||
1424 | TX_LATE_COL_ENBL | | ||
1425 | TX_JBR_ENBL | | ||
1426 | TX_ANY_COL_ENBL | | ||
1427 | TX_16_COL_ENBL)); | ||
1356 | 1428 | ||
1357 | writereg(dev, PP_BufCFG, READY_FOR_TX_ENBL | RX_MISS_COUNT_OVRFLOW_ENBL | | 1429 | writereg(dev, PP_BufCFG, (READY_FOR_TX_ENBL | |
1430 | RX_MISS_COUNT_OVRFLOW_ENBL | | ||
1358 | #if ALLOW_DMA | 1431 | #if ALLOW_DMA |
1359 | dma_bufcfg(dev) | | 1432 | dma_bufcfg(dev) | |
1360 | #endif | 1433 | #endif |
1361 | TX_COL_COUNT_OVRFLOW_ENBL | TX_UNDERRUN_ENBL); | 1434 | TX_COL_COUNT_OVRFLOW_ENBL | |
1435 | TX_UNDERRUN_ENBL)); | ||
1362 | 1436 | ||
1363 | /* now that we've got our act together, enable everything */ | 1437 | /* now that we've got our act together, enable everything */ |
1364 | writereg(dev, PP_BusCTL, ENABLE_IRQ | 1438 | writereg(dev, PP_BusCTL, (ENABLE_IRQ |
1365 | | (dev->mem_start ? MEMORY_ON : 0) /* turn memory on */ | 1439 | | (dev->mem_start ? MEMORY_ON : 0) /* turn memory on */ |
1366 | #if ALLOW_DMA | 1440 | #if ALLOW_DMA |
1367 | | dma_busctl(dev) | 1441 | | dma_busctl(dev) |
1368 | #endif | 1442 | #endif |
1369 | ); | 1443 | )); |
1370 | netif_start_queue(dev); | 1444 | netif_start_queue(dev); |
1371 | if (net_debug > 1) | 1445 | if (net_debug > 1) |
1372 | printk("cs89x0: net_open() succeeded\n"); | 1446 | printk("cs89x0: net_open() succeeded\n"); |
@@ -1379,8 +1453,10 @@ static void net_timeout(struct net_device *dev) | |||
1379 | { | 1453 | { |
1380 | /* If we get here, some higher level has decided we are broken. | 1454 | /* If we get here, some higher level has decided we are broken. |
1381 | There should really be a "kick me" function call instead. */ | 1455 | There should really be a "kick me" function call instead. */ |
1382 | if (net_debug > 0) printk("%s: transmit timed out, %s?\n", dev->name, | 1456 | if (net_debug > 0) |
1383 | tx_done(dev) ? "IRQ conflict ?" : "network cable problem"); | 1457 | printk("%s: transmit timed out, %s?\n", |
1458 | dev->name, | ||
1459 | tx_done(dev) ? "IRQ conflict" : "network cable problem"); | ||
1384 | /* Try to restart the adaptor. */ | 1460 | /* Try to restart the adaptor. */ |
1385 | netif_wake_queue(dev); | 1461 | netif_wake_queue(dev); |
1386 | } | 1462 | } |
@@ -1393,12 +1469,14 @@ static netdev_tx_t net_send_packet(struct sk_buff *skb, struct net_device *dev) | |||
1393 | if (net_debug > 3) { | 1469 | if (net_debug > 3) { |
1394 | printk("%s: sent %d byte packet of type %x\n", | 1470 | printk("%s: sent %d byte packet of type %x\n", |
1395 | dev->name, skb->len, | 1471 | dev->name, skb->len, |
1396 | (skb->data[ETH_ALEN + ETH_ALEN] << 8) | skb->data[ETH_ALEN + ETH_ALEN + 1]); | 1472 | ((skb->data[ETH_ALEN + ETH_ALEN] << 8) | |
1473 | skb->data[ETH_ALEN + ETH_ALEN + 1])); | ||
1397 | } | 1474 | } |
1398 | 1475 | ||
1399 | /* keep the upload from being interrupted, since we | 1476 | /* keep the upload from being interrupted, since we |
1400 | ask the chip to start transmitting before the | 1477 | * ask the chip to start transmitting before the |
1401 | whole packet has been completely uploaded. */ | 1478 | * whole packet has been completely uploaded. |
1479 | */ | ||
1402 | 1480 | ||
1403 | spin_lock_irqsave(&lp->lock, flags); | 1481 | spin_lock_irqsave(&lp->lock, flags); |
1404 | netif_stop_queue(dev); | 1482 | netif_stop_queue(dev); |
@@ -1414,11 +1492,12 @@ static netdev_tx_t net_send_packet(struct sk_buff *skb, struct net_device *dev) | |||
1414 | */ | 1492 | */ |
1415 | 1493 | ||
1416 | spin_unlock_irqrestore(&lp->lock, flags); | 1494 | spin_unlock_irqrestore(&lp->lock, flags); |
1417 | if (net_debug) printk("cs89x0: Tx buffer not free!\n"); | 1495 | if (net_debug) |
1496 | printk("cs89x0: Tx buffer not free!\n"); | ||
1418 | return NETDEV_TX_BUSY; | 1497 | return NETDEV_TX_BUSY; |
1419 | } | 1498 | } |
1420 | /* Write the contents of the packet */ | 1499 | /* Write the contents of the packet */ |
1421 | writewords(lp, TX_FRAME_PORT, skb->data, (skb->len+1) >> 1); | 1500 | writewords(lp, TX_FRAME_PORT, skb->data, (skb->len + 1) >> 1); |
1422 | spin_unlock_irqrestore(&lp->lock, flags); | 1501 | spin_unlock_irqrestore(&lp->lock, flags); |
1423 | dev->stats.tx_bytes += skb->len; | 1502 | dev->stats.tx_bytes += skb->len; |
1424 | dev_kfree_skb(skb); | 1503 | dev_kfree_skb(skb); |
@@ -1427,10 +1506,10 @@ static netdev_tx_t net_send_packet(struct sk_buff *skb, struct net_device *dev) | |||
1427 | * We also DO NOT call netif_start_queue(). | 1506 | * We also DO NOT call netif_start_queue(). |
1428 | * | 1507 | * |
1429 | * Either of these would cause another bottom half run through | 1508 | * Either of these would cause another bottom half run through |
1430 | * net_send_packet() before this packet has fully gone out. That causes | 1509 | * net_send_packet() before this packet has fully gone out. |
1431 | * us to hit the "Gasp!" above and the send is rescheduled. it runs like | 1510 | * That causes us to hit the "Gasp!" above and the send is rescheduled. |
1432 | * a dog. We just return and wait for the Tx completion interrupt handler | 1511 | * it runs like a dog. We just return and wait for the Tx completion |
1433 | * to restart the netdevice layer | 1512 | * interrupt handler to restart the netdevice layer |
1434 | */ | 1513 | */ |
1435 | 1514 | ||
1436 | return NETDEV_TX_OK; | 1515 | return NETDEV_TX_OK; |
@@ -1458,7 +1537,8 @@ static irqreturn_t net_interrupt(int irq, void *dev_id) | |||
1458 | * vista, baby! | 1537 | * vista, baby! |
1459 | */ | 1538 | */ |
1460 | while ((status = ioread16(lp->virt_addr + ISQ_PORT))) { | 1539 | while ((status = ioread16(lp->virt_addr + ISQ_PORT))) { |
1461 | if (net_debug > 4)printk("%s: event=%04x\n", dev->name, status); | 1540 | if (net_debug > 4) |
1541 | printk("%s: event=%04x\n", dev->name, status); | ||
1462 | handled = 1; | 1542 | handled = 1; |
1463 | switch (status & ISQ_EVENT_MASK) { | 1543 | switch (status & ISQ_EVENT_MASK) { |
1464 | case ISQ_RECEIVER_EVENT: | 1544 | case ISQ_RECEIVER_EVENT: |
@@ -1496,10 +1576,14 @@ static irqreturn_t net_interrupt(int irq, void *dev_id) | |||
1496 | netif_wake_queue(dev); /* Inform upper layers. */ | 1576 | netif_wake_queue(dev); /* Inform upper layers. */ |
1497 | } | 1577 | } |
1498 | if (status & TX_UNDERRUN) { | 1578 | if (status & TX_UNDERRUN) { |
1499 | if (net_debug > 0) printk("%s: transmit underrun\n", dev->name); | 1579 | if (net_debug > 0) |
1580 | printk("%s: transmit underrun\n", | ||
1581 | dev->name); | ||
1500 | lp->send_underrun++; | 1582 | lp->send_underrun++; |
1501 | if (lp->send_underrun == 3) lp->send_cmd = TX_AFTER_381; | 1583 | if (lp->send_underrun == 3) |
1502 | else if (lp->send_underrun == 6) lp->send_cmd = TX_AFTER_ALL; | 1584 | lp->send_cmd = TX_AFTER_381; |
1585 | else if (lp->send_underrun == 6) | ||
1586 | lp->send_cmd = TX_AFTER_ALL; | ||
1503 | /* transmit cycle is done, although | 1587 | /* transmit cycle is done, although |
1504 | * frame wasn't transmitted - this | 1588 | * frame wasn't transmitted - this |
1505 | * avoids having to wait for the upper | 1589 | * avoids having to wait for the upper |
@@ -1513,14 +1597,17 @@ static irqreturn_t net_interrupt(int irq, void *dev_id) | |||
1513 | int count = readreg(dev, PP_DmaFrameCnt); | 1597 | int count = readreg(dev, PP_DmaFrameCnt); |
1514 | while (count) { | 1598 | while (count) { |
1515 | if (net_debug > 5) | 1599 | if (net_debug > 5) |
1516 | printk("%s: receiving %d DMA frames\n", dev->name, count); | 1600 | printk("%s: receiving %d DMA frames\n", |
1601 | dev->name, count); | ||
1517 | if (net_debug > 2 && count > 1) | 1602 | if (net_debug > 2 && count > 1) |
1518 | printk("%s: receiving %d DMA frames\n", dev->name, count); | 1603 | printk("%s: receiving %d DMA frames\n", |
1604 | dev->name, count); | ||
1519 | dma_rx(dev); | 1605 | dma_rx(dev); |
1520 | if (--count == 0) | 1606 | if (--count == 0) |
1521 | count = readreg(dev, PP_DmaFrameCnt); | 1607 | count = readreg(dev, PP_DmaFrameCnt); |
1522 | if (net_debug > 2 && count > 0) | 1608 | if (net_debug > 2 && count > 0) |
1523 | printk("%s: continuing with %d DMA frames\n", dev->name, count); | 1609 | printk("%s: continuing with %d DMA frames\n", |
1610 | dev->name, count); | ||
1524 | } | 1611 | } |
1525 | } | 1612 | } |
1526 | #endif | 1613 | #endif |
@@ -1544,7 +1631,7 @@ count_rx_errors(int status, struct net_device *dev) | |||
1544 | dev->stats.rx_length_errors++; | 1631 | dev->stats.rx_length_errors++; |
1545 | if (status & RX_EXTRA_DATA) | 1632 | if (status & RX_EXTRA_DATA) |
1546 | dev->stats.rx_length_errors++; | 1633 | dev->stats.rx_length_errors++; |
1547 | if ((status & RX_CRC_ERROR) && !(status & (RX_EXTRA_DATA|RX_RUNT))) | 1634 | if ((status & RX_CRC_ERROR) && !(status & (RX_EXTRA_DATA | RX_RUNT))) |
1548 | /* per str 172 */ | 1635 | /* per str 172 */ |
1549 | dev->stats.rx_crc_errors++; | 1636 | dev->stats.rx_crc_errors++; |
1550 | if (status & RX_DRIBBLE) | 1637 | if (status & RX_DRIBBLE) |
@@ -1585,7 +1672,8 @@ net_rx(struct net_device *dev) | |||
1585 | if (net_debug > 3) { | 1672 | if (net_debug > 3) { |
1586 | printk("%s: received %d byte packet of type %x\n", | 1673 | printk("%s: received %d byte packet of type %x\n", |
1587 | dev->name, length, | 1674 | dev->name, length, |
1588 | (skb->data[ETH_ALEN + ETH_ALEN] << 8) | skb->data[ETH_ALEN + ETH_ALEN + 1]); | 1675 | (skb->data[ETH_ALEN + ETH_ALEN] << 8) | |
1676 | skb->data[ETH_ALEN + ETH_ALEN + 1]); | ||
1589 | } | 1677 | } |
1590 | 1678 | ||
1591 | skb->protocol = eth_type_trans(skb, dev); | 1679 | skb->protocol = eth_type_trans(skb, dev); |
@@ -1598,7 +1686,8 @@ net_rx(struct net_device *dev) | |||
1598 | static void release_dma_buff(struct net_local *lp) | 1686 | static void release_dma_buff(struct net_local *lp) |
1599 | { | 1687 | { |
1600 | if (lp->dma_buff) { | 1688 | if (lp->dma_buff) { |
1601 | free_pages((unsigned long)(lp->dma_buff), get_order(lp->dmasize * 1024)); | 1689 | free_pages((unsigned long)(lp->dma_buff), |
1690 | get_order(lp->dmasize * 1024)); | ||
1602 | lp->dma_buff = NULL; | 1691 | lp->dma_buff = NULL; |
1603 | } | 1692 | } |
1604 | } | 1693 | } |
@@ -1656,28 +1745,29 @@ static void set_multicast_list(struct net_device *dev) | |||
1656 | unsigned long flags; | 1745 | unsigned long flags; |
1657 | 1746 | ||
1658 | spin_lock_irqsave(&lp->lock, flags); | 1747 | spin_lock_irqsave(&lp->lock, flags); |
1659 | if (dev->flags&IFF_PROMISC) | 1748 | if (dev->flags & IFF_PROMISC) |
1660 | { | ||
1661 | lp->rx_mode = RX_ALL_ACCEPT; | 1749 | lp->rx_mode = RX_ALL_ACCEPT; |
1662 | } | ||
1663 | else if ((dev->flags & IFF_ALLMULTI) || !netdev_mc_empty(dev)) | 1750 | else if ((dev->flags & IFF_ALLMULTI) || !netdev_mc_empty(dev)) |
1664 | { | 1751 | /* The multicast-accept list is initialized to accept-all, |
1665 | /* The multicast-accept list is initialized to accept-all, and we | 1752 | * and we rely on higher-level filtering for now. |
1666 | rely on higher-level filtering for now. */ | 1753 | */ |
1667 | lp->rx_mode = RX_MULTCAST_ACCEPT; | 1754 | lp->rx_mode = RX_MULTCAST_ACCEPT; |
1668 | } | ||
1669 | else | 1755 | else |
1670 | lp->rx_mode = 0; | 1756 | lp->rx_mode = 0; |
1671 | 1757 | ||
1672 | writereg(dev, PP_RxCTL, DEF_RX_ACCEPT | lp->rx_mode); | 1758 | writereg(dev, PP_RxCTL, DEF_RX_ACCEPT | lp->rx_mode); |
1673 | 1759 | ||
1674 | /* in promiscuous mode, we accept errored packets, so we have to enable interrupts on them also */ | 1760 | /* in promiscuous mode, we accept errored packets, |
1675 | writereg(dev, PP_RxCFG, lp->curr_rx_cfg | | 1761 | * so we have to enable interrupts on them also |
1676 | (lp->rx_mode == RX_ALL_ACCEPT ? (RX_CRC_ERROR_ENBL|RX_RUNT_ENBL|RX_EXTRA_DATA_ENBL) : 0)); | 1762 | */ |
1763 | writereg(dev, PP_RxCFG, | ||
1764 | (lp->curr_rx_cfg | | ||
1765 | (lp->rx_mode == RX_ALL_ACCEPT) | ||
1766 | ? (RX_CRC_ERROR_ENBL | RX_RUNT_ENBL | RX_EXTRA_DATA_ENBL) | ||
1767 | : 0)); | ||
1677 | spin_unlock_irqrestore(&lp->lock, flags); | 1768 | spin_unlock_irqrestore(&lp->lock, flags); |
1678 | } | 1769 | } |
1679 | 1770 | ||
1680 | |||
1681 | static int set_mac_address(struct net_device *dev, void *p) | 1771 | static int set_mac_address(struct net_device *dev, void *p) |
1682 | { | 1772 | { |
1683 | int i; | 1773 | int i; |
@@ -1689,12 +1779,14 @@ static int set_mac_address(struct net_device *dev, void *p) | |||
1689 | memcpy(dev->dev_addr, addr->sa_data, dev->addr_len); | 1779 | memcpy(dev->dev_addr, addr->sa_data, dev->addr_len); |
1690 | 1780 | ||
1691 | if (net_debug) | 1781 | if (net_debug) |
1692 | printk("%s: Setting MAC address to %pM.\n", | 1782 | printk("%s: Setting MAC address to %pM\n", |
1693 | dev->name, dev->dev_addr); | 1783 | dev->name, dev->dev_addr); |
1694 | 1784 | ||
1695 | /* set the Ethernet address */ | 1785 | /* set the Ethernet address */ |
1696 | for (i = 0; i < ETH_ALEN / 2; i++) | 1786 | for (i = 0; i < ETH_ALEN / 2; i++) |
1697 | writereg(dev, PP_IA + i * 2, dev->dev_addr[i * 2] | (dev->dev_addr[i * 2 + 1] << 8)); | 1787 | writereg(dev, PP_IA + i * 2, |
1788 | (dev->dev_addr[i * 2] | | ||
1789 | (dev->dev_addr[i * 2 + 1] << 8))); | ||
1698 | 1790 | ||
1699 | return 0; | 1791 | return 0; |
1700 | } | 1792 | } |
@@ -1871,28 +1963,28 @@ static int __init cs89x0_platform_probe(struct platform_device *pdev) | |||
1871 | mem_res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 1963 | mem_res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
1872 | dev->irq = platform_get_irq(pdev, 0); | 1964 | dev->irq = platform_get_irq(pdev, 0); |
1873 | if (mem_res == NULL || dev->irq <= 0) { | 1965 | if (mem_res == NULL || dev->irq <= 0) { |
1874 | dev_warn(&dev->dev, "memory/interrupt resource missing.\n"); | 1966 | dev_warn(&dev->dev, "memory/interrupt resource missing\n"); |
1875 | err = -ENXIO; | 1967 | err = -ENXIO; |
1876 | goto free; | 1968 | goto free; |
1877 | } | 1969 | } |
1878 | 1970 | ||
1879 | lp->size = resource_size(mem_res); | 1971 | lp->size = resource_size(mem_res); |
1880 | if (!request_mem_region(mem_res->start, lp->size, DRV_NAME)) { | 1972 | if (!request_mem_region(mem_res->start, lp->size, DRV_NAME)) { |
1881 | dev_warn(&dev->dev, "request_mem_region() failed.\n"); | 1973 | dev_warn(&dev->dev, "request_mem_region() failed\n"); |
1882 | err = -EBUSY; | 1974 | err = -EBUSY; |
1883 | goto free; | 1975 | goto free; |
1884 | } | 1976 | } |
1885 | 1977 | ||
1886 | virt_addr = ioremap(mem_res->start, lp->size); | 1978 | virt_addr = ioremap(mem_res->start, lp->size); |
1887 | if (!virt_addr) { | 1979 | if (!virt_addr) { |
1888 | dev_warn(&dev->dev, "ioremap() failed.\n"); | 1980 | dev_warn(&dev->dev, "ioremap() failed\n"); |
1889 | err = -ENOMEM; | 1981 | err = -ENOMEM; |
1890 | goto release; | 1982 | goto release; |
1891 | } | 1983 | } |
1892 | 1984 | ||
1893 | err = cs89x0_probe1(dev, virt_addr, 0); | 1985 | err = cs89x0_probe1(dev, virt_addr, 0); |
1894 | if (err) { | 1986 | if (err) { |
1895 | dev_warn(&dev->dev, "no cs8900 or cs8920 detected.\n"); | 1987 | dev_warn(&dev->dev, "no cs8900 or cs8920 detected\n"); |
1896 | goto unmap; | 1988 | goto unmap; |
1897 | } | 1989 | } |
1898 | 1990 | ||