Lines Matching +full:tx1 +full:- +full:0

1 // SPDX-License-Identifier: GPL-1.0+
5 A PCMCIA ethernet driver for Asix AX88190-based cards
7 The Asix AX88190 is a NS8390-derived chipset with a few nasty
14 Copyright (C) 2001 David A. Hinds -- dahinds@users.sourceforge.net
51 #define AXNET_CMD 0x00
52 #define AXNET_DATAPORT 0x10 /* NatSemi-defined port window offset. */
53 #define AXNET_RESET 0x1f /* Issue a read to reset, a write to clear. */
54 #define AXNET_MII_EEP 0x14 /* Offset of MII access port */
55 #define AXNET_TEST 0x15 /* Offset of TEST Register port */
56 #define AXNET_GPIO 0x17 /* Offset of General Purpose Register Port */
58 #define AXNET_START_PG 0x40 /* First page of TX buffer */
59 #define AXNET_STOP_PG 0x80 /* Last page +1 of RX ring */
61 #define AXNET_RDC_TIMEOUT 0x02 /* Max wait in jiffies for Tx RDC */
63 #define IS_AX88190 0x0001
64 #define IS_AX88790 0x0002
146 dev_dbg(&link->dev, "axnet_attach()\n"); in axnet_probe()
150 return -ENOMEM; in axnet_probe()
153 spin_lock_init(&ei_local->page_lock); in axnet_probe()
156 info->p_dev = link; in axnet_probe()
157 link->priv = dev; in axnet_probe()
158 link->config_flags |= CONF_ENABLE_IRQ; in axnet_probe()
160 dev->netdev_ops = &axnet_netdev_ops; in axnet_probe()
162 dev->watchdog_timeo = TX_TIMEOUT; in axnet_probe()
169 struct net_device *dev = link->priv; in axnet_detach()
171 dev_dbg(&link->dev, "axnet_detach(0x%p)\n", link); in axnet_detach()
188 struct net_device *dev = link->priv; in get_prom()
189 unsigned int ioaddr = dev->base_addr; in get_prom()
197 {E8390_NODMA+E8390_PAGE0+E8390_STOP, E8390_CMD}, /* Select page 0*/ in get_prom()
198 {0x01, EN0_DCFG}, /* Set word-wide access. */ in get_prom()
199 {0x00, EN0_RCNTLO}, /* Clear the count regs. */ in get_prom()
200 {0x00, EN0_RCNTHI}, in get_prom()
201 {0x00, EN0_IMR}, /* Mask completion irq. */ in get_prom()
202 {0xFF, EN0_ISR}, in get_prom()
203 {E8390_RXOFF|0x40, EN0_RXCR}, /* 0x60 Set to monitor */ in get_prom()
204 {E8390_TXOFF, EN0_TXCR}, /* 0x02 and loopback mode. */ in get_prom()
205 {0x10, EN0_RCNTLO}, in get_prom()
206 {0x00, EN0_RCNTHI}, in get_prom()
207 {0x00, EN0_RSARLO}, /* DMA starting at 0x0400. */ in get_prom()
208 {0x04, EN0_RSARHI}, in get_prom()
213 if (link->config_base != 0x03c0) in get_prom()
214 return 0; in get_prom()
219 for (i = 0; i < ARRAY_SIZE(program_seq); i++) in get_prom()
222 for (i = 0; i < 6; i += 2) { in get_prom()
224 addr[i] = j & 0xff; in get_prom()
235 link->resource[0]->flags &= ~IO_DATA_PATH_WIDTH; in try_io_port()
236 link->resource[1]->flags &= ~IO_DATA_PATH_WIDTH; in try_io_port()
237 if (link->resource[0]->end == 32) { in try_io_port()
238 link->resource[0]->flags |= IO_DATA_PATH_WIDTH_AUTO; in try_io_port()
240 if (link->resource[1]->end > 0) in try_io_port()
241 link->resource[1]->flags |= IO_DATA_PATH_WIDTH_8; in try_io_port()
243 /* This should be two 16-port windows */ in try_io_port()
244 link->resource[0]->flags |= IO_DATA_PATH_WIDTH_8; in try_io_port()
245 link->resource[1]->flags |= IO_DATA_PATH_WIDTH_16; in try_io_port()
247 if (link->resource[0]->start == 0) { in try_io_port()
248 for (j = 0; j < 0x400; j += 0x20) { in try_io_port()
249 link->resource[0]->start = j ^ 0x300; in try_io_port()
250 link->resource[1]->start = (j ^ 0x300) + 0x10; in try_io_port()
251 link->io_lines = 16; in try_io_port()
253 if (ret == 0) in try_io_port()
264 if (p_dev->config_index == 0) in axnet_configcheck()
265 return -EINVAL; in axnet_configcheck()
267 p_dev->config_index = 0x05; in axnet_configcheck()
268 if (p_dev->resource[0]->end + p_dev->resource[1]->end < 32) in axnet_configcheck()
269 return -ENODEV; in axnet_configcheck()
276 struct net_device *dev = link->priv; in axnet_config()
280 dev_dbg(&link->dev, "axnet_config(0x%p)\n", link); in axnet_config()
283 link->config_regs = 0x63; in axnet_config()
284 link->config_flags |= CONF_ENABLE_IRQ | CONF_AUTO_SET_IO; in axnet_config()
286 if (ret != 0) in axnet_config()
289 if (!link->irq) in axnet_config()
292 if (resource_size(link->resource[1]) == 8) in axnet_config()
293 link->config_flags |= CONF_ENABLE_SPKR; in axnet_config()
299 dev->irq = link->irq; in axnet_config()
300 dev->base_addr = link->resource[0]->start; in axnet_config()
318 if (inb(dev->base_addr + AXNET_TEST) != 0) in axnet_config()
319 info->flags |= IS_AX88790; in axnet_config()
321 info->flags |= IS_AX88190; in axnet_config()
323 if (info->flags & IS_AX88790) in axnet_config()
324 outb(0x10, dev->base_addr + AXNET_GPIO); /* select Internal PHY */ in axnet_config()
326 info->active_low = 0; in axnet_config()
328 for (i = 0; i < 32; i++) { in axnet_config()
329 j = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 1); in axnet_config()
330 j2 = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 2); in axnet_config()
332 if ((j != 0) && (j != 0xffff)) break; in axnet_config()
338 pcmcia_write_config_byte(link, CISREG_CCSR, 0x04); in axnet_config()
339 for (i = 0; i < 32; i++) { in axnet_config()
340 j = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 1); in axnet_config()
341 j2 = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 2); in axnet_config()
343 if ((j != 0) && (j != 0xffff)) { in axnet_config()
344 info->active_low = 1; in axnet_config()
350 info->phy_id = (i < 32) ? i : -1; in axnet_config()
351 SET_NETDEV_DEV(dev, &link->dev); in axnet_config()
353 if (register_netdev(dev) != 0) { in axnet_config()
359 ((info->flags & IS_AX88790) ? 7 : 1), in axnet_config()
360 dev->base_addr, dev->irq, dev->dev_addr); in axnet_config()
361 if (info->phy_id != -1) { in axnet_config()
363 info->phy_id, j); in axnet_config()
367 return 0; in axnet_config()
371 return -ENODEV; in axnet_config()
381 struct net_device *dev = link->priv; in axnet_suspend()
383 if (link->open) in axnet_suspend()
386 return 0; in axnet_suspend()
391 struct net_device *dev = link->priv; in axnet_resume()
394 if (link->open) { in axnet_resume()
395 if (info->active_low == 1) in axnet_resume()
396 pcmcia_write_config_byte(link, CISREG_CCSR, 0x04); in axnet_resume()
403 return 0; in axnet_resume()
413 #define MDIO_SHIFT_CLK 0x01
414 #define MDIO_DATA_WRITE0 0x00
415 #define MDIO_DATA_WRITE1 0x08
416 #define MDIO_DATA_READ 0x04
417 #define MDIO_MASK 0x0f
418 #define MDIO_ENB_IN 0x02
423 for (bits = 0; bits < 32; bits++) { in mdio_sync()
431 u_int cmd = (0xf6<<10)|(phy_id<<5)|loc; in mdio_read()
432 int i, retval = 0; in mdio_read()
435 for (i = 14; i >= 0; i--) { in mdio_read()
440 for (i = 19; i > 0; i--) { in mdio_read()
442 retval = (retval << 1) | ((inb_p(addr) & MDIO_DATA_READ) != 0); in mdio_read()
445 return (retval>>1) & 0xffff; in mdio_read()
450 u_int cmd = (0x05<<28)|(phy_id<<23)|(loc<<18)|(1<<17)|value; in mdio_write()
454 for (i = 31; i >= 0; i--) { in mdio_write()
459 for (i = 1; i >= 0; i--) { in mdio_write()
471 struct pcmcia_device *link = info->p_dev; in axnet_open()
472 unsigned int nic_base = dev->base_addr; in axnet_open()
474 dev_dbg(&link->dev, "axnet_open('%s')\n", dev->name); in axnet_open()
477 return -ENODEV; in axnet_open()
479 outb_p(0xFF, nic_base + EN0_ISR); /* Clear bogus intr. */ in axnet_open()
480 ret = request_irq(dev->irq, ei_irq_wrapper, IRQF_SHARED, "axnet_cs", dev); in axnet_open()
484 link->open++; in axnet_open()
486 info->link_status = 0x00; in axnet_open()
487 timer_setup(&info->watchdog, ei_watchdog, 0); in axnet_open()
488 mod_timer(&info->watchdog, jiffies + HZ); in axnet_open()
498 struct pcmcia_device *link = info->p_dev; in axnet_close()
500 dev_dbg(&link->dev, "axnet_close('%s')\n", dev->name); in axnet_close()
503 free_irq(dev->irq, dev); in axnet_close()
505 link->open--; in axnet_close()
507 del_timer_sync(&info->watchdog); in axnet_close()
509 return 0; in axnet_close()
521 unsigned int nic_base = dev->base_addr; in axnet_reset_8390()
524 ei_status.txing = ei_status.dmaing = 0; in axnet_reset_8390()
530 for (i = 0; i < 100; i++) { in axnet_reset_8390()
531 if ((inb_p(nic_base+EN0_ISR) & ENISR_RESET) != 0) in axnet_reset_8390()
547 PRIV(dev)->stale = 0; in ei_irq_wrapper()
554 struct net_device *dev = info->p_dev->priv; in ei_watchdog()
555 unsigned int nic_base = dev->base_addr; in ei_watchdog()
563 if (info->stale++ && (inb_p(nic_base + EN0_ISR) & ENISR_ALL)) { in ei_watchdog()
564 if (!info->fast_poll) in ei_watchdog()
566 ei_irq_wrapper(dev->irq, dev); in ei_watchdog()
567 info->fast_poll = HZ; in ei_watchdog()
569 if (info->fast_poll) { in ei_watchdog()
570 info->fast_poll--; in ei_watchdog()
571 info->watchdog.expires = jiffies + 1; in ei_watchdog()
572 add_timer(&info->watchdog); in ei_watchdog()
576 if (info->phy_id < 0) in ei_watchdog()
578 link = mdio_read(mii_addr, info->phy_id, 1); in ei_watchdog()
579 if (!link || (link == 0xffff)) { in ei_watchdog()
581 info->phy_id = -1; in ei_watchdog()
585 link &= 0x0004; in ei_watchdog()
586 if (link != info->link_status) { in ei_watchdog()
587 u_short p = mdio_read(mii_addr, info->phy_id, 5); in ei_watchdog()
590 info->duplex_flag = (p & 0x0140) ? 0x80 : 0x00; in ei_watchdog()
592 netdev_info(dev, "autonegotiation complete: %dbaseT-%cD selected\n", in ei_watchdog()
593 (p & 0x0180) ? 100 : 10, (p & 0x0140) ? 'F' : 'H'); in ei_watchdog()
598 info->link_status = link; in ei_watchdog()
602 info->watchdog.expires = jiffies + HZ; in ei_watchdog()
603 add_timer(&info->watchdog); in ei_watchdog()
612 unsigned int mii_addr = dev->base_addr + AXNET_MII_EEP; in axnet_ioctl()
615 data->phy_id = info->phy_id; in axnet_ioctl()
618 data->val_out = mdio_read(mii_addr, data->phy_id, data->reg_num & 0x1f); in axnet_ioctl()
619 return 0; in axnet_ioctl()
621 mdio_write(mii_addr, data->phy_id, data->reg_num & 0x1f, data->val_in); in axnet_ioctl()
622 return 0; in axnet_ioctl()
624 return -EOPNOTSUPP; in axnet_ioctl()
633 unsigned int nic_base = dev->base_addr; in get_8390_hdr()
635 outb_p(0, nic_base + EN0_RSARLO); /* On page boundary */ in get_8390_hdr()
642 hdr->count = le16_to_cpu(hdr->count); in get_8390_hdr()
651 unsigned int nic_base = dev->base_addr; in block_input()
653 char *buf = skb->data; in block_input()
657 outb_p(ring_offset & 0xff, nic_base + EN0_RSARLO); in block_input()
662 if (count & 0x01) { in block_input()
663 buf[count-1] = inb(nic_base + AXNET_DATAPORT); in block_input()
672 unsigned int nic_base = dev->base_addr; in block_output()
674 pr_debug("%s: [bo=%d]\n", dev->name, count); in block_output()
679 if (count & 0x01) in block_output()
682 outb_p(0x00, nic_base + EN0_RSARLO); in block_output()
689 PCMCIA_PFC_DEVICE_MANF_CARD(0, 0x016c, 0x0081),
690 PCMCIA_DEVICE_MANF_CARD(0x018a, 0x0301),
691 PCMCIA_DEVICE_MANF_CARD(0x01bf, 0x2328),
692 PCMCIA_DEVICE_MANF_CARD(0x026f, 0x0301),
693 PCMCIA_DEVICE_MANF_CARD(0x026f, 0x0303),
694 PCMCIA_DEVICE_MANF_CARD(0x026f, 0x0309),
695 PCMCIA_DEVICE_MANF_CARD(0x0274, 0x1106),
696 PCMCIA_DEVICE_MANF_CARD(0x8a01, 0xc1ab),
697 PCMCIA_DEVICE_MANF_CARD(0x021b, 0x0202),
698 PCMCIA_DEVICE_MANF_CARD(0xffff, 0x1090),
699 PCMCIA_DEVICE_PROD_ID12("AmbiCom,Inc.", "Fast Ethernet PC Card(AMB8110)", 0x49b020a7, 0x119cc9fc),
700 …PCMCIA_DEVICE_PROD_ID124("Fast Ethernet", "16-bit PC Card", "AX88190", 0xb4be14e3, 0x9a12eb6a, 0xa…
701 PCMCIA_DEVICE_PROD_ID12("ASIX", "AX88190", 0x0959823b, 0xab9be5ef),
702 PCMCIA_DEVICE_PROD_ID12("Billionton", "LNA-100B", 0x552ab682, 0xbc3b87e1),
703 PCMCIA_DEVICE_PROD_ID12("CHEETAH ETHERCARD", "EN2228", 0x00fa7bc8, 0x00e990cc),
704 PCMCIA_DEVICE_PROD_ID12("CNet", "CNF301", 0xbc477dde, 0x78c5f40b),
705 PCMCIA_DEVICE_PROD_ID12("corega K.K.", "corega FEther PCC-TXD", 0x5261440f, 0x436768c5),
706 PCMCIA_DEVICE_PROD_ID12("corega K.K.", "corega FEtherII PCC-TXD", 0x5261440f, 0x730df72e),
707 PCMCIA_DEVICE_PROD_ID12("corega K.K.", "corega FEther PCC-TXM", 0x5261440f, 0x3abbd061),
708 PCMCIA_DEVICE_PROD_ID12("Dynalink", "L100C16", 0x55632fd5, 0x66bc2a90),
709 PCMCIA_DEVICE_PROD_ID12("IO DATA", "ETXPCM", 0x547e66dc, 0x233adac2),
710 …PCMCIA_DEVICE_PROD_ID12("Linksys", "EtherFast 10/100 PC Card (PCMPC100 V3)", 0x0733cc81, 0x232019a…
711 PCMCIA_DEVICE_PROD_ID12("MELCO", "LPC3-TX", 0x481e0094, 0xf91af609),
712 PCMCIA_DEVICE_PROD_ID12("NETGEAR", "FA411", 0x9aa79dc3, 0x40fad875),
713 PCMCIA_DEVICE_PROD_ID12("PCMCIA", "100BASE", 0x281f1c5d, 0x7c2add04),
714 PCMCIA_DEVICE_PROD_ID12("PCMCIA", "FastEtherCard", 0x281f1c5d, 0x7ef26116),
715 PCMCIA_DEVICE_PROD_ID12("PCMCIA", "FEP501", 0x281f1c5d, 0x2e272058),
716 PCMCIA_DEVICE_PROD_ID14("Network Everywhere", "AX88190", 0x820a67b6, 0xab9be5ef),
736 Written 1992-94 by Donald Becker.
749 This is the chip-specific code for many 8390-based ethernet adaptors.
750 This is not a complete driver, it must be combined with board-specific
756 you have found something that needs changing. -- PG
771 Paul Gortmaker : add kmod support for auto-loading of the 8390
789 /* These are the operational function interfaces to board-specific
798 "page" value uses the 8390's 256-byte pages.
807 #define ei_reset_8390 (ei_local->reset_8390)
808 #define ei_block_output (ei_local->block_output)
809 #define ei_block_input (ei_local->block_input)
810 #define ei_get_8390_hdr (ei_local->get_8390_hdr)
818 /* Routines generic to NS8390-based boards. */
828 * this with ei_local->page_lock. Nobody should assume or set the page other
829 * than zero when the lock is not held. Lock holders must restore page 0
831 * page 0.
850 * ax_open - Open/initialize the board.
853 * This routine goes all-out, setting everything
867 spin_lock_irqsave(&ei_local->page_lock, flags); in ax_open()
872 spin_unlock_irqrestore(&ei_local->page_lock, flags); in ax_open()
873 ei_local->irqlock = 0; in ax_open()
874 return 0; in ax_open()
877 #define dev_lock(dev) (((struct ei_device *)netdev_priv(dev))->page_lock)
880 * ax_close - shut down network device
894 AX88190_init(dev, 0); in ax_close()
897 return 0; in ax_close()
901 * axnet_tx_timeout - handle transmit time out condition
906 * completed (or failed) - i.e. never posted a Tx related interrupt.
911 long e8390_base = dev->base_addr; in axnet_tx_timeout()
913 int txsr, isr, tickssofar = jiffies - dev_trans_start(dev); in axnet_tx_timeout()
916 dev->stats.tx_errors++; in axnet_tx_timeout()
918 spin_lock_irqsave(&ei_local->page_lock, flags); in axnet_tx_timeout()
921 spin_unlock_irqrestore(&ei_local->page_lock, flags); in axnet_tx_timeout()
928 if (!isr && !dev->stats.tx_packets) in axnet_tx_timeout()
931 ei_local->interface_num ^= 1; /* Try a different xcvr. */ in axnet_tx_timeout()
936 spin_lock_irqsave(&ei_local->page_lock, flags); in axnet_tx_timeout()
942 spin_unlock_irqrestore(&ei_local->page_lock, flags); in axnet_tx_timeout()
947 * axnet_start_xmit - begin packet transmission
957 long e8390_base = dev->base_addr; in axnet_start_xmit()
965 length = skb->len; in axnet_start_xmit()
972 spin_lock_irqsave(&ei_local->page_lock, flags); in axnet_start_xmit()
973 outb_p(0x00, e8390_base + EN0_IMR); in axnet_start_xmit()
979 ei_local->irqlock = 1; in axnet_start_xmit()
986 * you get very close to transmitting back-to-back packets. With in axnet_start_xmit()
991 if (ei_local->tx1 == 0) in axnet_start_xmit()
993 output_page = ei_local->tx_start_page; in axnet_start_xmit()
994 ei_local->tx1 = send_length; in axnet_start_xmit()
996 ei_local->tx2 > 0) in axnet_start_xmit()
999 ei_local->tx2, ei_local->lasttx, in axnet_start_xmit()
1000 ei_local->txing); in axnet_start_xmit()
1002 else if (ei_local->tx2 == 0) in axnet_start_xmit()
1004 output_page = ei_local->tx_start_page + TX_PAGES/2; in axnet_start_xmit()
1005 ei_local->tx2 = send_length; in axnet_start_xmit()
1007 ei_local->tx1 > 0) in axnet_start_xmit()
1009 "idle transmitter, tx1=%d, lasttx=%d, txing=%d\n", in axnet_start_xmit()
1010 ei_local->tx1, ei_local->lasttx, in axnet_start_xmit()
1011 ei_local->txing); in axnet_start_xmit()
1016 "No Tx buffers free! tx1=%d tx2=%d last=%d\n", in axnet_start_xmit()
1017 ei_local->tx1, ei_local->tx2, in axnet_start_xmit()
1018 ei_local->lasttx); in axnet_start_xmit()
1019 ei_local->irqlock = 0; in axnet_start_xmit()
1022 spin_unlock_irqrestore(&ei_local->page_lock, flags); in axnet_start_xmit()
1023 dev->stats.tx_errors++; in axnet_start_xmit()
1033 if (length == skb->len) in axnet_start_xmit()
1034 ei_block_output(dev, length, skb->data, output_page); in axnet_start_xmit()
1036 memset(packet, 0, ETH_ZLEN); in axnet_start_xmit()
1037 skb_copy_from_linear_data(skb, packet, skb->len); in axnet_start_xmit()
1041 if (! ei_local->txing) in axnet_start_xmit()
1043 ei_local->txing = 1; in axnet_start_xmit()
1046 if (output_page == ei_local->tx_start_page) in axnet_start_xmit()
1048 ei_local->tx1 = -1; in axnet_start_xmit()
1049 ei_local->lasttx = -1; in axnet_start_xmit()
1053 ei_local->tx2 = -1; in axnet_start_xmit()
1054 ei_local->lasttx = -2; in axnet_start_xmit()
1057 else ei_local->txqueue++; in axnet_start_xmit()
1059 if (ei_local->tx1 && ei_local->tx2) in axnet_start_xmit()
1065 ei_local->irqlock = 0; in axnet_start_xmit()
1068 spin_unlock_irqrestore(&ei_local->page_lock, flags); in axnet_start_xmit()
1071 dev->stats.tx_bytes += send_length; in axnet_start_xmit()
1077 * ax_interrupt - handle the interrupts from an 8390
1092 int interrupts, nr_serviced = 0, i; in ax_interrupt()
1094 int handled = 0; in ax_interrupt()
1097 e8390_base = dev->base_addr; in ax_interrupt()
1104 spin_lock_irqsave(&ei_local->page_lock, flags); in ax_interrupt()
1106 if (ei_local->irqlock) { in ax_interrupt()
1110 if (ei_local->irqlock) in ax_interrupt()
1119 spin_unlock_irqrestore(&ei_local->page_lock, flags); in ax_interrupt()
1126 outb_p(0x00, e8390_base + EN0_ISR); in ax_interrupt()
1127 ei_local->irqlock = 1; in ax_interrupt()
1129 /* !!Assumption!! -- we stay in page 0. Don't break this. */ in ax_interrupt()
1130 while ((interrupts = inb_p(e8390_base + EN0_ISR)) != 0 && in ax_interrupt()
1133 if (!netif_running(dev) || (interrupts == 0xff)) { in ax_interrupt()
1137 interrupts = 0; in ax_interrupt()
1144 for (i = 0; i < 10; i++) { in ax_interrupt()
1147 outb_p(0, e8390_base + EN0_ISR); in ax_interrupt()
1157 /* Push the next to-transmit packet through. */ in ax_interrupt()
1165 dev->stats.rx_frame_errors += inb_p(e8390_base + EN0_COUNTER0); in ax_interrupt()
1166 dev->stats.rx_crc_errors += inb_p(e8390_base + EN0_COUNTER1); in ax_interrupt()
1167 dev->stats.rx_missed_errors+= inb_p(e8390_base + EN0_COUNTER2); in ax_interrupt()
1176 /* 0xFF is valid for a card removal */ in ax_interrupt()
1177 if (interrupts != 0xFF) in ax_interrupt()
1185 outb_p(0xff, e8390_base + EN0_ISR); /* Ack. all intrs. */ in ax_interrupt()
1190 ei_local->irqlock = 0; in ax_interrupt()
1193 spin_unlock_irqrestore(&ei_local->page_lock, flags); in ax_interrupt()
1198 * ei_tx_err - handle transmitter error
1213 long e8390_base = dev->base_addr; in ei_tx_err()
1220 pr_cont(" excess-collisions"); in ei_tx_err()
1222 pr_cont(" non-deferral"); in ei_tx_err()
1224 pr_cont(" lost-carrier"); in ei_tx_err()
1226 pr_cont(" FIFO-underrun"); in ei_tx_err()
1228 pr_cont(" lost-heartbeat"); in ei_tx_err()
1236 dev->stats.tx_errors++; in ei_tx_err()
1237 if (txsr & ENTSR_CRS) dev->stats.tx_carrier_errors++; in ei_tx_err()
1238 if (txsr & ENTSR_CDH) dev->stats.tx_heartbeat_errors++; in ei_tx_err()
1239 if (txsr & ENTSR_OWC) dev->stats.tx_window_errors++; in ei_tx_err()
1244 * ei_tx_intr - transmit interrupt handler
1253 long e8390_base = dev->base_addr; in ei_tx_intr()
1261 ei_local->txqueue--; in ei_tx_intr()
1263 if (ei_local->tx1 < 0) in ei_tx_intr()
1265 if (ei_local->lasttx != 1 && ei_local->lasttx != -1) in ei_tx_intr()
1266 netdev_err(dev, "%s: bogus last_tx_buffer %d, tx1=%d\n", in ei_tx_intr()
1267 ei_local->name, ei_local->lasttx, in ei_tx_intr()
1268 ei_local->tx1); in ei_tx_intr()
1269 ei_local->tx1 = 0; in ei_tx_intr()
1270 if (ei_local->tx2 > 0) in ei_tx_intr()
1272 ei_local->txing = 1; in ei_tx_intr()
1273 NS8390_trigger_send(dev, ei_local->tx2, ei_local->tx_start_page + 6); in ei_tx_intr()
1275 ei_local->tx2 = -1; in ei_tx_intr()
1276 ei_local->lasttx = 2; in ei_tx_intr()
1278 ei_local->lasttx = 20; in ei_tx_intr()
1279 ei_local->txing = 0; in ei_tx_intr()
1282 else if (ei_local->tx2 < 0) in ei_tx_intr()
1284 if (ei_local->lasttx != 2 && ei_local->lasttx != -2) in ei_tx_intr()
1286 ei_local->name, ei_local->lasttx, in ei_tx_intr()
1287 ei_local->tx2); in ei_tx_intr()
1288 ei_local->tx2 = 0; in ei_tx_intr()
1289 if (ei_local->tx1 > 0) in ei_tx_intr()
1291 ei_local->txing = 1; in ei_tx_intr()
1292 NS8390_trigger_send(dev, ei_local->tx1, ei_local->tx_start_page); in ei_tx_intr()
1294 ei_local->tx1 = -1; in ei_tx_intr()
1295 ei_local->lasttx = 1; in ei_tx_intr()
1297 ei_local->lasttx = 10; in ei_tx_intr()
1298 ei_local->txing = 0; in ei_tx_intr()
1302 // netdev_warn(dev, "unexpected TX-done interrupt, lasttx=%d\n", in ei_tx_intr()
1303 // ei_local->lasttx); in ei_tx_intr()
1307 dev->stats.collisions++; in ei_tx_intr()
1309 dev->stats.tx_packets++; in ei_tx_intr()
1312 dev->stats.tx_errors++; in ei_tx_intr()
1315 dev->stats.tx_aborted_errors++; in ei_tx_intr()
1316 dev->stats.collisions += 16; in ei_tx_intr()
1319 dev->stats.tx_carrier_errors++; in ei_tx_intr()
1321 dev->stats.tx_fifo_errors++; in ei_tx_intr()
1323 dev->stats.tx_heartbeat_errors++; in ei_tx_intr()
1325 dev->stats.tx_window_errors++; in ei_tx_intr()
1331 * ei_receive - receive some packets
1340 long e8390_base = dev->base_addr; in ei_receive()
1344 int rx_pkt_count = 0; in ei_receive()
1352 rxing_page = inb_p(e8390_base + EN1_CURPAG -1); in ei_receive()
1356 if (this_frame >= ei_local->stop_page) in ei_receive()
1357 this_frame = ei_local->rx_start_page; in ei_receive()
1366 this_frame != ei_local->current_page && in ei_receive()
1367 (this_frame != 0x0 || rxing_page != 0xFF)) in ei_receive()
1369 this_frame, ei_local->current_page); in ei_receive()
1377 pkt_len = rx_frame.count - sizeof(struct e8390_pkt_hdr); in ei_receive()
1388 dev->stats.rx_errors++; in ei_receive()
1389 dev->stats.rx_length_errors++; in ei_receive()
1391 else if ((pkt_stat & 0x0F) == ENRSR_RXOK) in ei_receive()
1401 dev->stats.rx_dropped++; in ei_receive()
1409 skb->protocol=eth_type_trans(skb,dev); in ei_receive()
1411 dev->stats.rx_packets++; in ei_receive()
1412 dev->stats.rx_bytes += pkt_len; in ei_receive()
1414 dev->stats.multicast++; in ei_receive()
1423 dev->stats.rx_errors++; in ei_receive()
1426 dev->stats.rx_fifo_errors++; in ei_receive()
1431 if (next_frame >= ei_local->stop_page) { in ei_receive()
1434 next_frame = ei_local->rx_start_page; in ei_receive()
1436 ei_local->current_page = next_frame; in ei_receive()
1437 outb_p(next_frame-1, e8390_base+EN0_BOUNDARY); in ei_receive()
1442 * ei_rx_overrun - handle receiver overrun
1451 * computer will hate you - it takes 10ms or so.
1457 long e8390_base = dev->base_addr; in ei_rx_overrun()
1458 unsigned char was_txing, must_resend = 0; in ei_rx_overrun()
1469 dev->stats.rx_over_errors++; in ei_rx_overrun()
1481 outb_p(0x00, e8390_base+EN0_RCNTLO); in ei_rx_overrun()
1482 outb_p(0x00, e8390_base+EN0_RCNTHI); in ei_rx_overrun()
1511 outb_p(E8390_TXCONFIG | info->duplex_flag, e8390_base + EN0_TXCR); in ei_rx_overrun()
1522 long ioaddr = dev->base_addr; in get_stats()
1528 return &dev->stats; in get_stats()
1530 spin_lock_irqsave(&ei_local->page_lock,flags); in get_stats()
1531 /* Read the counter registers, assuming we are in page 0. */ in get_stats()
1532 dev->stats.rx_frame_errors += inb_p(ioaddr + EN0_COUNTER0); in get_stats()
1533 dev->stats.rx_crc_errors += inb_p(ioaddr + EN0_COUNTER1); in get_stats()
1534 dev->stats.rx_missed_errors+= inb_p(ioaddr + EN0_COUNTER2); in get_stats()
1535 spin_unlock_irqrestore(&ei_local->page_lock, flags); in get_stats()
1537 return &dev->stats; in get_stats()
1551 crc = ether_crc(ETH_ALEN, ha->addr); in make_mc_bits()
1561 * do_set_multicast_list - set/clear multicast filter
1570 long e8390_base = dev->base_addr; in do_set_multicast_list()
1574 if (!(dev->flags&(IFF_PROMISC|IFF_ALLMULTI))) { in do_set_multicast_list()
1575 memset(ei_local->mcfilter, 0, 8); in do_set_multicast_list()
1577 make_mc_bits(ei_local->mcfilter, dev); in do_set_multicast_list()
1579 /* set to accept-all */ in do_set_multicast_list()
1580 memset(ei_local->mcfilter, 0xFF, 8); in do_set_multicast_list()
1584 for(i = 0; i < 8; i++) in do_set_multicast_list()
1586 outb_p(ei_local->mcfilter[i], e8390_base + EN1_MULT_SHIFT(i)); in do_set_multicast_list()
1590 if(dev->flags&IFF_PROMISC) in do_set_multicast_list()
1591 outb_p(E8390_RXCONFIG | 0x58, e8390_base + EN0_RXCR); in do_set_multicast_list()
1592 else if (dev->flags & IFF_ALLMULTI || !netdev_mc_empty(dev)) in do_set_multicast_list()
1593 outb_p(E8390_RXCONFIG | 0x48, e8390_base + EN0_RXCR); in do_set_multicast_list()
1595 outb_p(E8390_RXCONFIG | 0x40, e8390_base + EN0_RXCR); in do_set_multicast_list()
1619 * AX88190_init - initialize 8390 hardware
1621 * @startp: boolean. non-zero value to initiate chip processing
1629 long e8390_base = dev->base_addr; in AX88190_init()
1632 int endcfg = ei_local->word16 ? (0x48 | ENDCFG_WTS) : 0x48; in AX88190_init()
1637 outb_p(E8390_NODMA+E8390_PAGE0+E8390_STOP, e8390_base+E8390_CMD); /* 0x21 */ in AX88190_init()
1638 outb_p(endcfg, e8390_base + EN0_DCFG); /* 0x48 or 0x49 */ in AX88190_init()
1640 outb_p(0x00, e8390_base + EN0_RCNTLO); in AX88190_init()
1641 outb_p(0x00, e8390_base + EN0_RCNTHI); in AX88190_init()
1642 /* Set to monitor and loopback mode -- this is vital!. */ in AX88190_init()
1643 outb_p(E8390_RXOFF|0x40, e8390_base + EN0_RXCR); /* 0x60 */ in AX88190_init()
1644 outb_p(E8390_TXOFF, e8390_base + EN0_TXCR); /* 0x02 */ in AX88190_init()
1646 outb_p(ei_local->tx_start_page, e8390_base + EN0_TPSR); in AX88190_init()
1647 ei_local->tx1 = ei_local->tx2 = 0; in AX88190_init()
1648 outb_p(ei_local->rx_start_page, e8390_base + EN0_STARTPG); in AX88190_init()
1649 outb_p(ei_local->stop_page-1, e8390_base + EN0_BOUNDARY); /* 3c503 says 0x3f,NS0x26*/ in AX88190_init()
1650 ei_local->current_page = ei_local->rx_start_page; /* assert boundary+1 */ in AX88190_init()
1651 outb_p(ei_local->stop_page, e8390_base + EN0_STOPPG); in AX88190_init()
1653 outb_p(0xFF, e8390_base + EN0_ISR); in AX88190_init()
1654 outb_p(0x00, e8390_base + EN0_IMR); in AX88190_init()
1658 outb_p(E8390_NODMA + E8390_PAGE1 + E8390_STOP, e8390_base+E8390_CMD); /* 0x61 */ in AX88190_init()
1659 for(i = 0; i < 6; i++) in AX88190_init()
1661 outb_p(dev->dev_addr[i], e8390_base + EN1_PHYS_SHIFT(i)); in AX88190_init()
1662 if(inb_p(e8390_base + EN1_PHYS_SHIFT(i))!=dev->dev_addr[i]) in AX88190_init()
1666 outb_p(ei_local->rx_start_page, e8390_base + EN1_CURPAG); in AX88190_init()
1670 ei_local->tx1 = ei_local->tx2 = 0; in AX88190_init()
1671 ei_local->txing = 0; in AX88190_init()
1673 if (info->flags & IS_AX88790) /* select Internal PHY */ in AX88190_init()
1674 outb(0x10, e8390_base + AXNET_GPIO); in AX88190_init()
1678 outb_p(0xff, e8390_base + EN0_ISR); in AX88190_init()
1681 outb_p(E8390_TXCONFIG | info->duplex_flag, in AX88190_init()
1684 outb_p(E8390_RXCONFIG | 0x40, e8390_base + EN0_RXCR); /* rx on, */ in AX88190_init()
1695 long e8390_base = dev->base_addr; in NS8390_trigger_send()
1703 outb_p(length & 0xff, e8390_base + EN0_TCNTLO); in NS8390_trigger_send()