aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/3c507.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/3c507.c')
-rw-r--r--drivers/net/3c507.c55
1 files changed, 26 insertions, 29 deletions
diff --git a/drivers/net/3c507.c b/drivers/net/3c507.c
index fbbaf826deff..96b86659381a 100644
--- a/drivers/net/3c507.c
+++ b/drivers/net/3c507.c
@@ -364,7 +364,7 @@ static const struct net_device_ops netdev_ops = {
364 364
365static int __init el16_probe1(struct net_device *dev, int ioaddr) 365static int __init el16_probe1(struct net_device *dev, int ioaddr)
366{ 366{
367 static unsigned char init_ID_done, version_printed; 367 static unsigned char init_ID_done;
368 int i, irq, irqval, retval; 368 int i, irq, irqval, retval;
369 struct net_local *lp; 369 struct net_local *lp;
370 370
@@ -391,10 +391,7 @@ static int __init el16_probe1(struct net_device *dev, int ioaddr)
391 goto out; 391 goto out;
392 } 392 }
393 393
394 if (net_debug && version_printed++ == 0) 394 pr_info("%s: 3c507 at %#x,", dev->name, ioaddr);
395 printk(version);
396
397 printk("%s: 3c507 at %#x,", dev->name, ioaddr);
398 395
399 /* We should make a few more checks here, like the first three octets of 396 /* We should make a few more checks here, like the first three octets of
400 the S.A. for the manufacturer's code. */ 397 the S.A. for the manufacturer's code. */
@@ -403,7 +400,8 @@ static int __init el16_probe1(struct net_device *dev, int ioaddr)
403 400
404 irqval = request_irq(irq, &el16_interrupt, 0, DRV_NAME, dev); 401 irqval = request_irq(irq, &el16_interrupt, 0, DRV_NAME, dev);
405 if (irqval) { 402 if (irqval) {
406 printk(KERN_ERR "3c507: unable to get IRQ %d (irqval=%d).\n", irq, irqval); 403 pr_cont("\n");
404 pr_err("3c507: unable to get IRQ %d (irqval=%d).\n", irq, irqval);
407 retval = -EAGAIN; 405 retval = -EAGAIN;
408 goto out; 406 goto out;
409 } 407 }
@@ -414,7 +412,7 @@ static int __init el16_probe1(struct net_device *dev, int ioaddr)
414 outb(0x01, ioaddr + MISC_CTRL); 412 outb(0x01, ioaddr + MISC_CTRL);
415 for (i = 0; i < 6; i++) 413 for (i = 0; i < 6; i++)
416 dev->dev_addr[i] = inb(ioaddr + i); 414 dev->dev_addr[i] = inb(ioaddr + i);
417 printk(" %pM", dev->dev_addr); 415 pr_cont(" %pM", dev->dev_addr);
418 416
419 if (mem_start) 417 if (mem_start)
420 net_debug = mem_start & 7; 418 net_debug = mem_start & 7;
@@ -443,18 +441,18 @@ static int __init el16_probe1(struct net_device *dev, int ioaddr)
443 dev->if_port = (inb(ioaddr + ROM_CONFIG) & 0x80) ? 1 : 0; 441 dev->if_port = (inb(ioaddr + ROM_CONFIG) & 0x80) ? 1 : 0;
444 dev->irq = inb(ioaddr + IRQ_CONFIG) & 0x0f; 442 dev->irq = inb(ioaddr + IRQ_CONFIG) & 0x0f;
445 443
446 printk(", IRQ %d, %sternal xcvr, memory %#lx-%#lx.\n", dev->irq, 444 pr_cont(", IRQ %d, %sternal xcvr, memory %#lx-%#lx.\n", dev->irq,
447 dev->if_port ? "ex" : "in", dev->mem_start, dev->mem_end-1); 445 dev->if_port ? "ex" : "in", dev->mem_start, dev->mem_end-1);
448 446
449 if (net_debug) 447 if (net_debug)
450 printk(version); 448 pr_debug("%s", version);
451 449
452 lp = netdev_priv(dev); 450 lp = netdev_priv(dev);
453 memset(lp, 0, sizeof(*lp)); 451 memset(lp, 0, sizeof(*lp));
454 spin_lock_init(&lp->lock); 452 spin_lock_init(&lp->lock);
455 lp->base = ioremap(dev->mem_start, RX_BUF_END); 453 lp->base = ioremap(dev->mem_start, RX_BUF_END);
456 if (!lp->base) { 454 if (!lp->base) {
457 printk(KERN_ERR "3c507: unable to remap memory\n"); 455 pr_err("3c507: unable to remap memory\n");
458 retval = -EAGAIN; 456 retval = -EAGAIN;
459 goto out1; 457 goto out1;
460 } 458 }
@@ -488,20 +486,20 @@ static void el16_tx_timeout (struct net_device *dev)
488 void __iomem *shmem = lp->base; 486 void __iomem *shmem = lp->base;
489 487
490 if (net_debug > 1) 488 if (net_debug > 1)
491 printk ("%s: transmit timed out, %s? ", dev->name, 489 pr_debug("%s: transmit timed out, %s? ", dev->name,
492 readw(shmem + iSCB_STATUS) & 0x8000 ? "IRQ conflict" : 490 readw(shmem + iSCB_STATUS) & 0x8000 ? "IRQ conflict" :
493 "network cable problem"); 491 "network cable problem");
494 /* Try to restart the adaptor. */ 492 /* Try to restart the adaptor. */
495 if (lp->last_restart == dev->stats.tx_packets) { 493 if (lp->last_restart == dev->stats.tx_packets) {
496 if (net_debug > 1) 494 if (net_debug > 1)
497 printk ("Resetting board.\n"); 495 pr_cont("Resetting board.\n");
498 /* Completely reset the adaptor. */ 496 /* Completely reset the adaptor. */
499 init_82586_mem (dev); 497 init_82586_mem (dev);
500 lp->tx_pkts_in_ring = 0; 498 lp->tx_pkts_in_ring = 0;
501 } else { 499 } else {
502 /* Issue the channel attention signal and hope it "gets better". */ 500 /* Issue the channel attention signal and hope it "gets better". */
503 if (net_debug > 1) 501 if (net_debug > 1)
504 printk ("Kicking board.\n"); 502 pr_cont("Kicking board.\n");
505 writew(0xf000 | CUC_START | RX_START, shmem + iSCB_CMD); 503 writew(0xf000 | CUC_START | RX_START, shmem + iSCB_CMD);
506 outb (0, ioaddr + SIGNAL_CA); /* Issue channel-attn. */ 504 outb (0, ioaddr + SIGNAL_CA); /* Issue channel-attn. */
507 lp->last_restart = dev->stats.tx_packets; 505 lp->last_restart = dev->stats.tx_packets;
@@ -553,7 +551,8 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
553 void __iomem *shmem; 551 void __iomem *shmem;
554 552
555 if (dev == NULL) { 553 if (dev == NULL) {
556 printk ("net_interrupt(): irq %d for unknown device.\n", irq); 554 pr_err("%s: net_interrupt(): irq %d for unknown device.\n",
555 dev->name, irq);
557 return IRQ_NONE; 556 return IRQ_NONE;
558 } 557 }
559 558
@@ -566,7 +565,7 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
566 status = readw(shmem+iSCB_STATUS); 565 status = readw(shmem+iSCB_STATUS);
567 566
568 if (net_debug > 4) { 567 if (net_debug > 4) {
569 printk("%s: 3c507 interrupt, status %4.4x.\n", dev->name, status); 568 pr_debug("%s: 3c507 interrupt, status %4.4x.\n", dev->name, status);
570 } 569 }
571 570
572 /* Disable the 82586's input to the interrupt line. */ 571 /* Disable the 82586's input to the interrupt line. */
@@ -577,7 +576,7 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
577 unsigned short tx_status = readw(shmem+lp->tx_reap); 576 unsigned short tx_status = readw(shmem+lp->tx_reap);
578 if (!(tx_status & 0x8000)) { 577 if (!(tx_status & 0x8000)) {
579 if (net_debug > 5) 578 if (net_debug > 5)
580 printk("Tx command incomplete (%#x).\n", lp->tx_reap); 579 pr_debug("Tx command incomplete (%#x).\n", lp->tx_reap);
581 break; 580 break;
582 } 581 }
583 /* Tx unsuccessful or some interesting status bit set. */ 582 /* Tx unsuccessful or some interesting status bit set. */
@@ -591,7 +590,7 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
591 } 590 }
592 dev->stats.tx_packets++; 591 dev->stats.tx_packets++;
593 if (net_debug > 5) 592 if (net_debug > 5)
594 printk("Reaped %x, Tx status %04x.\n" , lp->tx_reap, tx_status); 593 pr_debug("Reaped %x, Tx status %04x.\n" , lp->tx_reap, tx_status);
595 lp->tx_reap += TX_BUF_SIZE; 594 lp->tx_reap += TX_BUF_SIZE;
596 if (lp->tx_reap > RX_BUF_START - TX_BUF_SIZE) 595 if (lp->tx_reap > RX_BUF_START - TX_BUF_SIZE)
597 lp->tx_reap = TX_BUF_START; 596 lp->tx_reap = TX_BUF_START;
@@ -606,7 +605,7 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
606 605
607 if (status & 0x4000) { /* Packet received. */ 606 if (status & 0x4000) { /* Packet received. */
608 if (net_debug > 5) 607 if (net_debug > 5)
609 printk("Received packet, rx_head %04x.\n", lp->rx_head); 608 pr_debug("Received packet, rx_head %04x.\n", lp->rx_head);
610 el16_rx(dev); 609 el16_rx(dev);
611 } 610 }
612 611
@@ -615,7 +614,7 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
615 614
616 if ((status & 0x0700) != 0x0200 && netif_running(dev)) { 615 if ((status & 0x0700) != 0x0200 && netif_running(dev)) {
617 if (net_debug) 616 if (net_debug)
618 printk("%s: Command unit stopped, status %04x, restarting.\n", 617 pr_debug("%s: Command unit stopped, status %04x, restarting.\n",
619 dev->name, status); 618 dev->name, status);
620 /* If this ever occurs we should really re-write the idle loop, reset 619 /* If this ever occurs we should really re-write the idle loop, reset
621 the Tx list, and do a complete restart of the command unit. 620 the Tx list, and do a complete restart of the command unit.
@@ -627,7 +626,7 @@ static irqreturn_t el16_interrupt(int irq, void *dev_id)
627 /* The Rx unit is not ready, it must be hung. Restart the receiver by 626 /* The Rx unit is not ready, it must be hung. Restart the receiver by
628 initializing the rx buffers, and issuing an Rx start command. */ 627 initializing the rx buffers, and issuing an Rx start command. */
629 if (net_debug) 628 if (net_debug)
630 printk("%s: Rx unit stopped, status %04x, restarting.\n", 629 pr_debug("%s: Rx unit stopped, status %04x, restarting.\n",
631 dev->name, status); 630 dev->name, status);
632 init_rx_bufs(dev); 631 init_rx_bufs(dev);
633 writew(RX_BUF_START,shmem+iSCB_RFA); 632 writew(RX_BUF_START,shmem+iSCB_RFA);
@@ -753,9 +752,8 @@ static void init_82586_mem(struct net_device *dev)
753 int boguscnt = 50; 752 int boguscnt = 50;
754 while (readw(shmem+iSCB_STATUS) == 0) 753 while (readw(shmem+iSCB_STATUS) == 0)
755 if (--boguscnt == 0) { 754 if (--boguscnt == 0) {
756 printk("%s: i82586 initialization timed out with status %04x, " 755 pr_warning("%s: i82586 initialization timed out with status %04x, cmd %04x.\n",
757 "cmd %04x.\n", dev->name, 756 dev->name, readw(shmem+iSCB_STATUS), readw(shmem+iSCB_CMD));
758 readw(shmem+iSCB_STATUS), readw(shmem+iSCB_CMD));
759 break; 757 break;
760 } 758 }
761 /* Issue channel-attn -- the 82586 won't start. */ 759 /* Issue channel-attn -- the 82586 won't start. */
@@ -765,7 +763,7 @@ static void init_82586_mem(struct net_device *dev)
765 /* Disable loopback and enable interrupts. */ 763 /* Disable loopback and enable interrupts. */
766 outb(0x84, ioaddr + MISC_CTRL); 764 outb(0x84, ioaddr + MISC_CTRL);
767 if (net_debug > 4) 765 if (net_debug > 4)
768 printk("%s: Initialized 82586, status %04x.\n", dev->name, 766 pr_debug("%s: Initialized 82586, status %04x.\n", dev->name,
769 readw(shmem+iSCB_STATUS)); 767 readw(shmem+iSCB_STATUS));
770 return; 768 return;
771} 769}
@@ -810,7 +808,7 @@ static void hardware_send_packet(struct net_device *dev, void *buf, short length
810 lp->tx_head = TX_BUF_START; 808 lp->tx_head = TX_BUF_START;
811 809
812 if (net_debug > 4) { 810 if (net_debug > 4) {
813 printk("%s: 3c507 @%x send length = %d, tx_block %3x, next %3x.\n", 811 pr_debug("%s: 3c507 @%x send length = %d, tx_block %3x, next %3x.\n",
814 dev->name, ioaddr, length, tx_block, lp->tx_head); 812 dev->name, ioaddr, length, tx_block, lp->tx_head);
815 } 813 }
816 814
@@ -838,7 +836,7 @@ static void el16_rx(struct net_device *dev)
838 836
839 if (rfd_cmd != 0 || data_buffer_addr != rx_head + 22 837 if (rfd_cmd != 0 || data_buffer_addr != rx_head + 22
840 || (pkt_len & 0xC000) != 0xC000) { 838 || (pkt_len & 0xC000) != 0xC000) {
841 printk(KERN_ERR "%s: Rx frame at %#x corrupted, " 839 pr_err("%s: Rx frame at %#x corrupted, "
842 "status %04x cmd %04x next %04x " 840 "status %04x cmd %04x next %04x "
843 "data-buf @%04x %04x.\n", 841 "data-buf @%04x %04x.\n",
844 dev->name, rx_head, frame_status, rfd_cmd, 842 dev->name, rx_head, frame_status, rfd_cmd,
@@ -858,8 +856,7 @@ static void el16_rx(struct net_device *dev)
858 pkt_len &= 0x3fff; 856 pkt_len &= 0x3fff;
859 skb = dev_alloc_skb(pkt_len+2); 857 skb = dev_alloc_skb(pkt_len+2);
860 if (skb == NULL) { 858 if (skb == NULL) {
861 printk(KERN_ERR "%s: Memory squeeze, " 859 pr_err("%s: Memory squeeze, dropping packet.\n",
862 "dropping packet.\n",
863 dev->name); 860 dev->name);
864 dev->stats.rx_dropped++; 861 dev->stats.rx_dropped++;
865 break; 862 break;
@@ -926,7 +923,7 @@ MODULE_PARM_DESC(irq, "(ignored)");
926int __init init_module(void) 923int __init init_module(void)
927{ 924{
928 if (io == 0) 925 if (io == 0)
929 printk("3c507: You should not use auto-probing with insmod!\n"); 926 pr_notice("3c507: You should not use auto-probing with insmod!\n");
930 dev_3c507 = el16_probe(-1); 927 dev_3c507 = el16_probe(-1);
931 return IS_ERR(dev_3c507) ? PTR_ERR(dev_3c507) : 0; 928 return IS_ERR(dev_3c507) ? PTR_ERR(dev_3c507) : 0;
932} 929}