diff options
-rw-r--r-- | drivers/net/gianfar.c | 364 | ||||
-rw-r--r-- | drivers/net/gianfar.h | 38 | ||||
-rw-r--r-- | drivers/net/gianfar_ethtool.c | 14 | ||||
-rw-r--r-- | drivers/net/gianfar_sysfs.c | 34 |
4 files changed, 250 insertions, 200 deletions
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 354b2b5936ea..fa0188ea9233 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c | |||
@@ -151,7 +151,6 @@ MODULE_LICENSE("GPL"); | |||
151 | static void gfar_init_rxbdp(struct gfar_priv_rx_q *rx_queue, struct rxbd8 *bdp, | 151 | static void gfar_init_rxbdp(struct gfar_priv_rx_q *rx_queue, struct rxbd8 *bdp, |
152 | dma_addr_t buf) | 152 | dma_addr_t buf) |
153 | { | 153 | { |
154 | struct net_device *dev = rx_queue->dev; | ||
155 | u32 lstatus; | 154 | u32 lstatus; |
156 | 155 | ||
157 | bdp->bufPtr = buf; | 156 | bdp->bufPtr = buf; |
@@ -290,9 +289,9 @@ cleanup: | |||
290 | static void gfar_init_mac(struct net_device *ndev) | 289 | static void gfar_init_mac(struct net_device *ndev) |
291 | { | 290 | { |
292 | struct gfar_private *priv = netdev_priv(ndev); | 291 | struct gfar_private *priv = netdev_priv(ndev); |
293 | struct gfar __iomem *regs = priv->regs; | ||
294 | struct gfar_priv_tx_q *tx_queue = NULL; | 292 | struct gfar_priv_tx_q *tx_queue = NULL; |
295 | struct gfar_priv_rx_q *rx_queue = NULL; | 293 | struct gfar_priv_rx_q *rx_queue = NULL; |
294 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
296 | u32 rctrl = 0; | 295 | u32 rctrl = 0; |
297 | u32 tctrl = 0; | 296 | u32 tctrl = 0; |
298 | u32 attrs = 0; | 297 | u32 attrs = 0; |
@@ -407,24 +406,25 @@ static int gfar_of_init(struct net_device *dev) | |||
407 | 406 | ||
408 | /* get a pointer to the register memory */ | 407 | /* get a pointer to the register memory */ |
409 | addr = of_translate_address(np, of_get_address(np, 0, &size, NULL)); | 408 | addr = of_translate_address(np, of_get_address(np, 0, &size, NULL)); |
410 | priv->regs = ioremap(addr, size); | 409 | priv->gfargrp.regs = ioremap(addr, size); |
411 | 410 | ||
412 | if (priv->regs == NULL) | 411 | if (priv->gfargrp.regs == NULL) |
413 | return -ENOMEM; | 412 | return -ENOMEM; |
414 | 413 | ||
415 | priv->interruptTransmit = irq_of_parse_and_map(np, 0); | 414 | priv->gfargrp.priv = priv; /* back pointer from group to priv */ |
415 | priv->gfargrp.interruptTransmit = irq_of_parse_and_map(np, 0); | ||
416 | 416 | ||
417 | model = of_get_property(np, "model", NULL); | 417 | model = of_get_property(np, "model", NULL); |
418 | 418 | ||
419 | /* If we aren't the FEC we have multiple interrupts */ | 419 | /* If we aren't the FEC we have multiple interrupts */ |
420 | if (model && strcasecmp(model, "FEC")) { | 420 | if (model && strcasecmp(model, "FEC")) { |
421 | priv->interruptReceive = irq_of_parse_and_map(np, 1); | 421 | priv->gfargrp.interruptReceive = irq_of_parse_and_map(np, 1); |
422 | 422 | ||
423 | priv->interruptError = irq_of_parse_and_map(np, 2); | 423 | priv->gfargrp.interruptError = irq_of_parse_and_map(np, 2); |
424 | 424 | ||
425 | if (priv->interruptTransmit < 0 || | 425 | if (priv->gfargrp.interruptTransmit < 0 || |
426 | priv->interruptReceive < 0 || | 426 | priv->gfargrp.interruptReceive < 0 || |
427 | priv->interruptError < 0) { | 427 | priv->gfargrp.interruptError < 0) { |
428 | err = -EINVAL; | 428 | err = -EINVAL; |
429 | goto err_out; | 429 | goto err_out; |
430 | } | 430 | } |
@@ -491,7 +491,7 @@ static int gfar_of_init(struct net_device *dev) | |||
491 | return 0; | 491 | return 0; |
492 | 492 | ||
493 | err_out: | 493 | err_out: |
494 | iounmap(priv->regs); | 494 | iounmap(priv->gfargrp.regs); |
495 | return err; | 495 | return err; |
496 | } | 496 | } |
497 | 497 | ||
@@ -517,6 +517,7 @@ static int gfar_probe(struct of_device *ofdev, | |||
517 | u32 tempval; | 517 | u32 tempval; |
518 | struct net_device *dev = NULL; | 518 | struct net_device *dev = NULL; |
519 | struct gfar_private *priv = NULL; | 519 | struct gfar_private *priv = NULL; |
520 | struct gfar __iomem *regs = NULL; | ||
520 | int err = 0; | 521 | int err = 0; |
521 | int len_devname; | 522 | int len_devname; |
522 | 523 | ||
@@ -549,32 +550,34 @@ static int gfar_probe(struct of_device *ofdev, | |||
549 | 550 | ||
550 | spin_lock_init(&priv->tx_queue->txlock); | 551 | spin_lock_init(&priv->tx_queue->txlock); |
551 | spin_lock_init(&priv->rx_queue->rxlock); | 552 | spin_lock_init(&priv->rx_queue->rxlock); |
553 | spin_lock_init(&priv->gfargrp.grplock); | ||
552 | spin_lock_init(&priv->bflock); | 554 | spin_lock_init(&priv->bflock); |
553 | INIT_WORK(&priv->reset_task, gfar_reset_task); | 555 | INIT_WORK(&priv->reset_task, gfar_reset_task); |
554 | 556 | ||
555 | dev_set_drvdata(&ofdev->dev, priv); | 557 | dev_set_drvdata(&ofdev->dev, priv); |
558 | regs = priv->gfargrp.regs; | ||
556 | 559 | ||
557 | /* Stop the DMA engine now, in case it was running before */ | 560 | /* Stop the DMA engine now, in case it was running before */ |
558 | /* (The firmware could have used it, and left it running). */ | 561 | /* (The firmware could have used it, and left it running). */ |
559 | gfar_halt(dev); | 562 | gfar_halt(dev); |
560 | 563 | ||
561 | /* Reset MAC layer */ | 564 | /* Reset MAC layer */ |
562 | gfar_write(&priv->regs->maccfg1, MACCFG1_SOFT_RESET); | 565 | gfar_write(®s->maccfg1, MACCFG1_SOFT_RESET); |
563 | 566 | ||
564 | /* We need to delay at least 3 TX clocks */ | 567 | /* We need to delay at least 3 TX clocks */ |
565 | udelay(2); | 568 | udelay(2); |
566 | 569 | ||
567 | tempval = (MACCFG1_TX_FLOW | MACCFG1_RX_FLOW); | 570 | tempval = (MACCFG1_TX_FLOW | MACCFG1_RX_FLOW); |
568 | gfar_write(&priv->regs->maccfg1, tempval); | 571 | gfar_write(®s->maccfg1, tempval); |
569 | 572 | ||
570 | /* Initialize MACCFG2. */ | 573 | /* Initialize MACCFG2. */ |
571 | gfar_write(&priv->regs->maccfg2, MACCFG2_INIT_SETTINGS); | 574 | gfar_write(®s->maccfg2, MACCFG2_INIT_SETTINGS); |
572 | 575 | ||
573 | /* Initialize ECNTRL */ | 576 | /* Initialize ECNTRL */ |
574 | gfar_write(&priv->regs->ecntrl, ECNTRL_INIT_SETTINGS); | 577 | gfar_write(®s->ecntrl, ECNTRL_INIT_SETTINGS); |
575 | 578 | ||
576 | /* Set the dev->base_addr to the gfar reg region */ | 579 | /* Set the dev->base_addr to the gfar reg region */ |
577 | dev->base_addr = (unsigned long) (priv->regs); | 580 | dev->base_addr = (unsigned long) regs; |
578 | 581 | ||
579 | SET_NETDEV_DEV(dev, &ofdev->dev); | 582 | SET_NETDEV_DEV(dev, &ofdev->dev); |
580 | 583 | ||
@@ -602,35 +605,35 @@ static int gfar_probe(struct of_device *ofdev, | |||
602 | priv->extended_hash = 1; | 605 | priv->extended_hash = 1; |
603 | priv->hash_width = 9; | 606 | priv->hash_width = 9; |
604 | 607 | ||
605 | priv->hash_regs[0] = &priv->regs->igaddr0; | 608 | priv->hash_regs[0] = ®s->igaddr0; |
606 | priv->hash_regs[1] = &priv->regs->igaddr1; | 609 | priv->hash_regs[1] = ®s->igaddr1; |
607 | priv->hash_regs[2] = &priv->regs->igaddr2; | 610 | priv->hash_regs[2] = ®s->igaddr2; |
608 | priv->hash_regs[3] = &priv->regs->igaddr3; | 611 | priv->hash_regs[3] = ®s->igaddr3; |
609 | priv->hash_regs[4] = &priv->regs->igaddr4; | 612 | priv->hash_regs[4] = ®s->igaddr4; |
610 | priv->hash_regs[5] = &priv->regs->igaddr5; | 613 | priv->hash_regs[5] = ®s->igaddr5; |
611 | priv->hash_regs[6] = &priv->regs->igaddr6; | 614 | priv->hash_regs[6] = ®s->igaddr6; |
612 | priv->hash_regs[7] = &priv->regs->igaddr7; | 615 | priv->hash_regs[7] = ®s->igaddr7; |
613 | priv->hash_regs[8] = &priv->regs->gaddr0; | 616 | priv->hash_regs[8] = ®s->gaddr0; |
614 | priv->hash_regs[9] = &priv->regs->gaddr1; | 617 | priv->hash_regs[9] = ®s->gaddr1; |
615 | priv->hash_regs[10] = &priv->regs->gaddr2; | 618 | priv->hash_regs[10] = ®s->gaddr2; |
616 | priv->hash_regs[11] = &priv->regs->gaddr3; | 619 | priv->hash_regs[11] = ®s->gaddr3; |
617 | priv->hash_regs[12] = &priv->regs->gaddr4; | 620 | priv->hash_regs[12] = ®s->gaddr4; |
618 | priv->hash_regs[13] = &priv->regs->gaddr5; | 621 | priv->hash_regs[13] = ®s->gaddr5; |
619 | priv->hash_regs[14] = &priv->regs->gaddr6; | 622 | priv->hash_regs[14] = ®s->gaddr6; |
620 | priv->hash_regs[15] = &priv->regs->gaddr7; | 623 | priv->hash_regs[15] = ®s->gaddr7; |
621 | 624 | ||
622 | } else { | 625 | } else { |
623 | priv->extended_hash = 0; | 626 | priv->extended_hash = 0; |
624 | priv->hash_width = 8; | 627 | priv->hash_width = 8; |
625 | 628 | ||
626 | priv->hash_regs[0] = &priv->regs->gaddr0; | 629 | priv->hash_regs[0] = ®s->gaddr0; |
627 | priv->hash_regs[1] = &priv->regs->gaddr1; | 630 | priv->hash_regs[1] = ®s->gaddr1; |
628 | priv->hash_regs[2] = &priv->regs->gaddr2; | 631 | priv->hash_regs[2] = ®s->gaddr2; |
629 | priv->hash_regs[3] = &priv->regs->gaddr3; | 632 | priv->hash_regs[3] = ®s->gaddr3; |
630 | priv->hash_regs[4] = &priv->regs->gaddr4; | 633 | priv->hash_regs[4] = ®s->gaddr4; |
631 | priv->hash_regs[5] = &priv->regs->gaddr5; | 634 | priv->hash_regs[5] = ®s->gaddr5; |
632 | priv->hash_regs[6] = &priv->regs->gaddr6; | 635 | priv->hash_regs[6] = ®s->gaddr6; |
633 | priv->hash_regs[7] = &priv->regs->gaddr7; | 636 | priv->hash_regs[7] = ®s->gaddr7; |
634 | } | 637 | } |
635 | 638 | ||
636 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_PADDING) | 639 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_PADDING) |
@@ -672,20 +675,20 @@ static int gfar_probe(struct of_device *ofdev, | |||
672 | 675 | ||
673 | /* fill out IRQ number and name fields */ | 676 | /* fill out IRQ number and name fields */ |
674 | len_devname = strlen(dev->name); | 677 | len_devname = strlen(dev->name); |
675 | strncpy(&priv->int_name_tx[0], dev->name, len_devname); | 678 | strncpy(&priv->gfargrp.int_name_tx[0], dev->name, len_devname); |
676 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { | 679 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { |
677 | strncpy(&priv->int_name_tx[len_devname], | 680 | strncpy(&priv->gfargrp.int_name_tx[len_devname], |
678 | "_tx", sizeof("_tx") + 1); | 681 | "_tx", sizeof("_tx") + 1); |
679 | 682 | ||
680 | strncpy(&priv->int_name_rx[0], dev->name, len_devname); | 683 | strncpy(&priv->gfargrp.int_name_rx[0], dev->name, len_devname); |
681 | strncpy(&priv->int_name_rx[len_devname], | 684 | strncpy(&priv->gfargrp.int_name_rx[len_devname], |
682 | "_rx", sizeof("_rx") + 1); | 685 | "_rx", sizeof("_rx") + 1); |
683 | 686 | ||
684 | strncpy(&priv->int_name_er[0], dev->name, len_devname); | 687 | strncpy(&priv->gfargrp.int_name_er[0], dev->name, len_devname); |
685 | strncpy(&priv->int_name_er[len_devname], | 688 | strncpy(&priv->gfargrp.int_name_er[len_devname], |
686 | "_er", sizeof("_er") + 1); | 689 | "_er", sizeof("_er") + 1); |
687 | } else | 690 | } else |
688 | priv->int_name_tx[len_devname] = '\0'; | 691 | priv->gfargrp.int_name_tx[len_devname] = '\0'; |
689 | 692 | ||
690 | /* Create all the sysfs files */ | 693 | /* Create all the sysfs files */ |
691 | gfar_init_sysfs(dev); | 694 | gfar_init_sysfs(dev); |
@@ -702,7 +705,7 @@ static int gfar_probe(struct of_device *ofdev, | |||
702 | return 0; | 705 | return 0; |
703 | 706 | ||
704 | register_fail: | 707 | register_fail: |
705 | iounmap(priv->regs); | 708 | iounmap(priv->gfargrp.regs); |
706 | kfree(priv->rx_queue); | 709 | kfree(priv->rx_queue); |
707 | rx_queue_fail: | 710 | rx_queue_fail: |
708 | kfree(priv->tx_queue); | 711 | kfree(priv->tx_queue); |
@@ -727,7 +730,7 @@ static int gfar_remove(struct of_device *ofdev) | |||
727 | dev_set_drvdata(&ofdev->dev, NULL); | 730 | dev_set_drvdata(&ofdev->dev, NULL); |
728 | 731 | ||
729 | unregister_netdev(priv->ndev); | 732 | unregister_netdev(priv->ndev); |
730 | iounmap(priv->regs); | 733 | iounmap(priv->gfargrp.regs); |
731 | free_netdev(priv->ndev); | 734 | free_netdev(priv->ndev); |
732 | 735 | ||
733 | return 0; | 736 | return 0; |
@@ -741,6 +744,7 @@ static int gfar_suspend(struct device *dev) | |||
741 | struct net_device *ndev = priv->ndev; | 744 | struct net_device *ndev = priv->ndev; |
742 | struct gfar_priv_tx_q *tx_queue = NULL; | 745 | struct gfar_priv_tx_q *tx_queue = NULL; |
743 | struct gfar_priv_rx_q *rx_queue = NULL; | 746 | struct gfar_priv_rx_q *rx_queue = NULL; |
747 | struct gfar __iomem *regs = NULL; | ||
744 | unsigned long flags; | 748 | unsigned long flags; |
745 | u32 tempval; | 749 | u32 tempval; |
746 | 750 | ||
@@ -750,6 +754,7 @@ static int gfar_suspend(struct device *dev) | |||
750 | netif_device_detach(ndev); | 754 | netif_device_detach(ndev); |
751 | tx_queue = priv->tx_queue; | 755 | tx_queue = priv->tx_queue; |
752 | rx_queue = priv->rx_queue; | 756 | rx_queue = priv->rx_queue; |
757 | regs = priv->gfargrp.regs; | ||
753 | 758 | ||
754 | if (netif_running(ndev)) { | 759 | if (netif_running(ndev)) { |
755 | spin_lock_irqsave(&tx_queue->txlock, flags); | 760 | spin_lock_irqsave(&tx_queue->txlock, flags); |
@@ -758,14 +763,14 @@ static int gfar_suspend(struct device *dev) | |||
758 | gfar_halt_nodisable(ndev); | 763 | gfar_halt_nodisable(ndev); |
759 | 764 | ||
760 | /* Disable Tx, and Rx if wake-on-LAN is disabled. */ | 765 | /* Disable Tx, and Rx if wake-on-LAN is disabled. */ |
761 | tempval = gfar_read(&priv->regs->maccfg1); | 766 | tempval = gfar_read(®s->maccfg1); |
762 | 767 | ||
763 | tempval &= ~MACCFG1_TX_EN; | 768 | tempval &= ~MACCFG1_TX_EN; |
764 | 769 | ||
765 | if (!magic_packet) | 770 | if (!magic_packet) |
766 | tempval &= ~MACCFG1_RX_EN; | 771 | tempval &= ~MACCFG1_RX_EN; |
767 | 772 | ||
768 | gfar_write(&priv->regs->maccfg1, tempval); | 773 | gfar_write(®s->maccfg1, tempval); |
769 | 774 | ||
770 | spin_unlock(&rx_queue->rxlock); | 775 | spin_unlock(&rx_queue->rxlock); |
771 | spin_unlock_irqrestore(&tx_queue->txlock, flags); | 776 | spin_unlock_irqrestore(&tx_queue->txlock, flags); |
@@ -774,12 +779,12 @@ static int gfar_suspend(struct device *dev) | |||
774 | 779 | ||
775 | if (magic_packet) { | 780 | if (magic_packet) { |
776 | /* Enable interrupt on Magic Packet */ | 781 | /* Enable interrupt on Magic Packet */ |
777 | gfar_write(&priv->regs->imask, IMASK_MAG); | 782 | gfar_write(®s->imask, IMASK_MAG); |
778 | 783 | ||
779 | /* Enable Magic Packet mode */ | 784 | /* Enable Magic Packet mode */ |
780 | tempval = gfar_read(&priv->regs->maccfg2); | 785 | tempval = gfar_read(®s->maccfg2); |
781 | tempval |= MACCFG2_MPEN; | 786 | tempval |= MACCFG2_MPEN; |
782 | gfar_write(&priv->regs->maccfg2, tempval); | 787 | gfar_write(®s->maccfg2, tempval); |
783 | } else { | 788 | } else { |
784 | phy_stop(priv->phydev); | 789 | phy_stop(priv->phydev); |
785 | } | 790 | } |
@@ -794,6 +799,7 @@ static int gfar_resume(struct device *dev) | |||
794 | struct net_device *ndev = priv->ndev; | 799 | struct net_device *ndev = priv->ndev; |
795 | struct gfar_priv_tx_q *tx_queue = NULL; | 800 | struct gfar_priv_tx_q *tx_queue = NULL; |
796 | struct gfar_priv_rx_q *rx_queue = NULL; | 801 | struct gfar_priv_rx_q *rx_queue = NULL; |
802 | struct gfar __iomem *regs = NULL; | ||
797 | unsigned long flags; | 803 | unsigned long flags; |
798 | u32 tempval; | 804 | u32 tempval; |
799 | int magic_packet = priv->wol_en && | 805 | int magic_packet = priv->wol_en && |
@@ -812,13 +818,14 @@ static int gfar_resume(struct device *dev) | |||
812 | */ | 818 | */ |
813 | rx_queue = priv->rx_queue; | 819 | rx_queue = priv->rx_queue; |
814 | tx_queue = priv->tx_queue; | 820 | tx_queue = priv->tx_queue; |
821 | regs = priv->gfargrp.regs; | ||
815 | 822 | ||
816 | spin_lock_irqsave(&tx_queue->txlock, flags); | 823 | spin_lock_irqsave(&tx_queue->txlock, flags); |
817 | spin_lock(&rx_queue->rxlock); | 824 | spin_lock(&rx_queue->rxlock); |
818 | 825 | ||
819 | tempval = gfar_read(&priv->regs->maccfg2); | 826 | tempval = gfar_read(®s->maccfg2); |
820 | tempval &= ~MACCFG2_MPEN; | 827 | tempval &= ~MACCFG2_MPEN; |
821 | gfar_write(&priv->regs->maccfg2, tempval); | 828 | gfar_write(®s->maccfg2, tempval); |
822 | 829 | ||
823 | gfar_start(ndev); | 830 | gfar_start(ndev); |
824 | 831 | ||
@@ -893,7 +900,11 @@ static int gfar_legacy_resume(struct of_device *ofdev) | |||
893 | static phy_interface_t gfar_get_interface(struct net_device *dev) | 900 | static phy_interface_t gfar_get_interface(struct net_device *dev) |
894 | { | 901 | { |
895 | struct gfar_private *priv = netdev_priv(dev); | 902 | struct gfar_private *priv = netdev_priv(dev); |
896 | u32 ecntrl = gfar_read(&priv->regs->ecntrl); | 903 | struct gfar __iomem *regs = NULL; |
904 | u32 ecntrl; | ||
905 | |||
906 | regs = priv->gfargrp.regs; | ||
907 | ecntrl = gfar_read(®s->ecntrl); | ||
897 | 908 | ||
898 | if (ecntrl & ECNTRL_SGMII_MODE) | 909 | if (ecntrl & ECNTRL_SGMII_MODE) |
899 | return PHY_INTERFACE_MODE_SGMII; | 910 | return PHY_INTERFACE_MODE_SGMII; |
@@ -1015,46 +1026,48 @@ static void gfar_configure_serdes(struct net_device *dev) | |||
1015 | static void init_registers(struct net_device *dev) | 1026 | static void init_registers(struct net_device *dev) |
1016 | { | 1027 | { |
1017 | struct gfar_private *priv = netdev_priv(dev); | 1028 | struct gfar_private *priv = netdev_priv(dev); |
1029 | struct gfar __iomem *regs = NULL; | ||
1018 | 1030 | ||
1031 | regs = priv->gfargrp.regs; | ||
1019 | /* Clear IEVENT */ | 1032 | /* Clear IEVENT */ |
1020 | gfar_write(&priv->regs->ievent, IEVENT_INIT_CLEAR); | 1033 | gfar_write(®s->ievent, IEVENT_INIT_CLEAR); |
1021 | 1034 | ||
1022 | /* Initialize IMASK */ | 1035 | /* Initialize IMASK */ |
1023 | gfar_write(&priv->regs->imask, IMASK_INIT_CLEAR); | 1036 | gfar_write(®s->imask, IMASK_INIT_CLEAR); |
1024 | 1037 | ||
1025 | /* Init hash registers to zero */ | 1038 | /* Init hash registers to zero */ |
1026 | gfar_write(&priv->regs->igaddr0, 0); | 1039 | gfar_write(®s->igaddr0, 0); |
1027 | gfar_write(&priv->regs->igaddr1, 0); | 1040 | gfar_write(®s->igaddr1, 0); |
1028 | gfar_write(&priv->regs->igaddr2, 0); | 1041 | gfar_write(®s->igaddr2, 0); |
1029 | gfar_write(&priv->regs->igaddr3, 0); | 1042 | gfar_write(®s->igaddr3, 0); |
1030 | gfar_write(&priv->regs->igaddr4, 0); | 1043 | gfar_write(®s->igaddr4, 0); |
1031 | gfar_write(&priv->regs->igaddr5, 0); | 1044 | gfar_write(®s->igaddr5, 0); |
1032 | gfar_write(&priv->regs->igaddr6, 0); | 1045 | gfar_write(®s->igaddr6, 0); |
1033 | gfar_write(&priv->regs->igaddr7, 0); | 1046 | gfar_write(®s->igaddr7, 0); |
1034 | 1047 | ||
1035 | gfar_write(&priv->regs->gaddr0, 0); | 1048 | gfar_write(®s->gaddr0, 0); |
1036 | gfar_write(&priv->regs->gaddr1, 0); | 1049 | gfar_write(®s->gaddr1, 0); |
1037 | gfar_write(&priv->regs->gaddr2, 0); | 1050 | gfar_write(®s->gaddr2, 0); |
1038 | gfar_write(&priv->regs->gaddr3, 0); | 1051 | gfar_write(®s->gaddr3, 0); |
1039 | gfar_write(&priv->regs->gaddr4, 0); | 1052 | gfar_write(®s->gaddr4, 0); |
1040 | gfar_write(&priv->regs->gaddr5, 0); | 1053 | gfar_write(®s->gaddr5, 0); |
1041 | gfar_write(&priv->regs->gaddr6, 0); | 1054 | gfar_write(®s->gaddr6, 0); |
1042 | gfar_write(&priv->regs->gaddr7, 0); | 1055 | gfar_write(®s->gaddr7, 0); |
1043 | 1056 | ||
1044 | /* Zero out the rmon mib registers if it has them */ | 1057 | /* Zero out the rmon mib registers if it has them */ |
1045 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_RMON) { | 1058 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_RMON) { |
1046 | memset_io(&(priv->regs->rmon), 0, sizeof (struct rmon_mib)); | 1059 | memset_io(&(regs->rmon), 0, sizeof (struct rmon_mib)); |
1047 | 1060 | ||
1048 | /* Mask off the CAM interrupts */ | 1061 | /* Mask off the CAM interrupts */ |
1049 | gfar_write(&priv->regs->rmon.cam1, 0xffffffff); | 1062 | gfar_write(®s->rmon.cam1, 0xffffffff); |
1050 | gfar_write(&priv->regs->rmon.cam2, 0xffffffff); | 1063 | gfar_write(®s->rmon.cam2, 0xffffffff); |
1051 | } | 1064 | } |
1052 | 1065 | ||
1053 | /* Initialize the max receive buffer length */ | 1066 | /* Initialize the max receive buffer length */ |
1054 | gfar_write(&priv->regs->mrblr, priv->rx_buffer_size); | 1067 | gfar_write(®s->mrblr, priv->rx_buffer_size); |
1055 | 1068 | ||
1056 | /* Initialize the Minimum Frame Length Register */ | 1069 | /* Initialize the Minimum Frame Length Register */ |
1057 | gfar_write(&priv->regs->minflr, MINFLR_INIT_SETTINGS); | 1070 | gfar_write(®s->minflr, MINFLR_INIT_SETTINGS); |
1058 | } | 1071 | } |
1059 | 1072 | ||
1060 | 1073 | ||
@@ -1062,7 +1075,7 @@ static void init_registers(struct net_device *dev) | |||
1062 | static void gfar_halt_nodisable(struct net_device *dev) | 1075 | static void gfar_halt_nodisable(struct net_device *dev) |
1063 | { | 1076 | { |
1064 | struct gfar_private *priv = netdev_priv(dev); | 1077 | struct gfar_private *priv = netdev_priv(dev); |
1065 | struct gfar __iomem *regs = priv->regs; | 1078 | struct gfar __iomem *regs = priv->gfargrp.regs; |
1066 | u32 tempval; | 1079 | u32 tempval; |
1067 | 1080 | ||
1068 | /* Mask all interrupts */ | 1081 | /* Mask all interrupts */ |
@@ -1072,13 +1085,13 @@ static void gfar_halt_nodisable(struct net_device *dev) | |||
1072 | gfar_write(®s->ievent, IEVENT_INIT_CLEAR); | 1085 | gfar_write(®s->ievent, IEVENT_INIT_CLEAR); |
1073 | 1086 | ||
1074 | /* Stop the DMA, and wait for it to stop */ | 1087 | /* Stop the DMA, and wait for it to stop */ |
1075 | tempval = gfar_read(&priv->regs->dmactrl); | 1088 | tempval = gfar_read(®s->dmactrl); |
1076 | if ((tempval & (DMACTRL_GRS | DMACTRL_GTS)) | 1089 | if ((tempval & (DMACTRL_GRS | DMACTRL_GTS)) |
1077 | != (DMACTRL_GRS | DMACTRL_GTS)) { | 1090 | != (DMACTRL_GRS | DMACTRL_GTS)) { |
1078 | tempval |= (DMACTRL_GRS | DMACTRL_GTS); | 1091 | tempval |= (DMACTRL_GRS | DMACTRL_GTS); |
1079 | gfar_write(&priv->regs->dmactrl, tempval); | 1092 | gfar_write(®s->dmactrl, tempval); |
1080 | 1093 | ||
1081 | while (!(gfar_read(&priv->regs->ievent) & | 1094 | while (!(gfar_read(®s->ievent) & |
1082 | (IEVENT_GRSC | IEVENT_GTSC))) | 1095 | (IEVENT_GRSC | IEVENT_GTSC))) |
1083 | cpu_relax(); | 1096 | cpu_relax(); |
1084 | } | 1097 | } |
@@ -1088,7 +1101,7 @@ static void gfar_halt_nodisable(struct net_device *dev) | |||
1088 | void gfar_halt(struct net_device *dev) | 1101 | void gfar_halt(struct net_device *dev) |
1089 | { | 1102 | { |
1090 | struct gfar_private *priv = netdev_priv(dev); | 1103 | struct gfar_private *priv = netdev_priv(dev); |
1091 | struct gfar __iomem *regs = priv->regs; | 1104 | struct gfar __iomem *regs = priv->gfargrp.regs; |
1092 | u32 tempval; | 1105 | u32 tempval; |
1093 | 1106 | ||
1094 | gfar_halt_nodisable(dev); | 1107 | gfar_halt_nodisable(dev); |
@@ -1122,11 +1135,11 @@ void stop_gfar(struct net_device *dev) | |||
1122 | 1135 | ||
1123 | /* Free the IRQs */ | 1136 | /* Free the IRQs */ |
1124 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { | 1137 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { |
1125 | free_irq(priv->interruptError, dev); | 1138 | free_irq(priv->gfargrp.interruptError, &priv->gfargrp); |
1126 | free_irq(priv->interruptTransmit, dev); | 1139 | free_irq(priv->gfargrp.interruptTransmit, &priv->gfargrp); |
1127 | free_irq(priv->interruptReceive, dev); | 1140 | free_irq(priv->gfargrp.interruptReceive, &priv->gfargrp); |
1128 | } else { | 1141 | } else { |
1129 | free_irq(priv->interruptTransmit, dev); | 1142 | free_irq(priv->gfargrp.interruptTransmit, &priv->gfargrp); |
1130 | } | 1143 | } |
1131 | 1144 | ||
1132 | free_skb_resources(priv); | 1145 | free_skb_resources(priv); |
@@ -1201,9 +1214,7 @@ skip_rx_skbuff: | |||
1201 | void gfar_start(struct net_device *dev) | 1214 | void gfar_start(struct net_device *dev) |
1202 | { | 1215 | { |
1203 | struct gfar_private *priv = netdev_priv(dev); | 1216 | struct gfar_private *priv = netdev_priv(dev); |
1204 | struct gfar_priv_tx_q *tx_queue; | 1217 | struct gfar __iomem *regs = priv->gfargrp.regs; |
1205 | struct gfar_priv_rx_q *rx_queue; | ||
1206 | struct gfar __iomem *regs = priv->regs; | ||
1207 | u32 tempval; | 1218 | u32 tempval; |
1208 | 1219 | ||
1209 | /* Enable Rx and Tx in MACCFG1 */ | 1220 | /* Enable Rx and Tx in MACCFG1 */ |
@@ -1212,14 +1223,14 @@ void gfar_start(struct net_device *dev) | |||
1212 | gfar_write(®s->maccfg1, tempval); | 1223 | gfar_write(®s->maccfg1, tempval); |
1213 | 1224 | ||
1214 | /* Initialize DMACTRL to have WWR and WOP */ | 1225 | /* Initialize DMACTRL to have WWR and WOP */ |
1215 | tempval = gfar_read(&priv->regs->dmactrl); | 1226 | tempval = gfar_read(®s->dmactrl); |
1216 | tempval |= DMACTRL_INIT_SETTINGS; | 1227 | tempval |= DMACTRL_INIT_SETTINGS; |
1217 | gfar_write(&priv->regs->dmactrl, tempval); | 1228 | gfar_write(®s->dmactrl, tempval); |
1218 | 1229 | ||
1219 | /* Make sure we aren't stopped */ | 1230 | /* Make sure we aren't stopped */ |
1220 | tempval = gfar_read(&priv->regs->dmactrl); | 1231 | tempval = gfar_read(®s->dmactrl); |
1221 | tempval &= ~(DMACTRL_GRS | DMACTRL_GTS); | 1232 | tempval &= ~(DMACTRL_GRS | DMACTRL_GTS); |
1222 | gfar_write(&priv->regs->dmactrl, tempval); | 1233 | gfar_write(®s->dmactrl, tempval); |
1223 | 1234 | ||
1224 | /* Clear THLT/RHLT, so that the DMA starts polling now */ | 1235 | /* Clear THLT/RHLT, so that the DMA starts polling now */ |
1225 | gfar_write(®s->tstat, TSTAT_CLEAR_THALT); | 1236 | gfar_write(®s->tstat, TSTAT_CLEAR_THALT); |
@@ -1235,7 +1246,7 @@ void gfar_start(struct net_device *dev) | |||
1235 | int startup_gfar(struct net_device *ndev) | 1246 | int startup_gfar(struct net_device *ndev) |
1236 | { | 1247 | { |
1237 | struct gfar_private *priv = netdev_priv(ndev); | 1248 | struct gfar_private *priv = netdev_priv(ndev); |
1238 | struct gfar __iomem *regs = priv->regs; | 1249 | struct gfar __iomem *regs = priv->gfargrp.regs; |
1239 | int err; | 1250 | int err; |
1240 | 1251 | ||
1241 | gfar_write(®s->imask, IMASK_INIT_CLEAR); | 1252 | gfar_write(®s->imask, IMASK_INIT_CLEAR); |
@@ -1251,39 +1262,46 @@ int startup_gfar(struct net_device *ndev) | |||
1251 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { | 1262 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { |
1252 | /* Install our interrupt handlers for Error, | 1263 | /* Install our interrupt handlers for Error, |
1253 | * Transmit, and Receive */ | 1264 | * Transmit, and Receive */ |
1254 | err = request_irq(priv->interruptError, gfar_error, 0, | 1265 | err = request_irq(priv->gfargrp.interruptError, gfar_error, 0, |
1255 | priv->int_name_er, ndev); | 1266 | priv->gfargrp.int_name_er, &priv->gfargrp); |
1256 | if (err) { | 1267 | if (err) { |
1257 | if (netif_msg_intr(priv)) | 1268 | if (netif_msg_intr(priv)) |
1258 | pr_err("%s: Can't get IRQ %d\n", ndev->name, | 1269 | pr_err("%s: Can't get IRQ %d\n", ndev->name, |
1259 | priv->interruptError); | 1270 | priv->gfargrp.interruptError); |
1260 | goto err_irq_fail; | 1271 | goto err_irq_fail; |
1261 | } | 1272 | } |
1262 | 1273 | ||
1263 | err = request_irq(priv->interruptTransmit, gfar_transmit, 0, | 1274 | err = request_irq(priv->gfargrp.interruptTransmit, |
1264 | priv->int_name_tx, ndev); | 1275 | gfar_transmit, 0, |
1276 | priv->gfargrp.int_name_tx, | ||
1277 | &priv->gfargrp); | ||
1265 | if (err) { | 1278 | if (err) { |
1266 | if (netif_msg_intr(priv)) | 1279 | if (netif_msg_intr(priv)) |
1267 | pr_err("%s: Can't get IRQ %d\n", ndev->name, | 1280 | pr_err("%s: Can't get IRQ %d\n", ndev->name, |
1268 | priv->interruptTransmit); | 1281 | priv->gfargrp.interruptTransmit); |
1269 | goto tx_irq_fail; | 1282 | goto tx_irq_fail; |
1270 | } | 1283 | } |
1271 | 1284 | ||
1272 | err = request_irq(priv->interruptReceive, gfar_receive, 0, | 1285 | err = request_irq(priv->gfargrp.interruptReceive, |
1273 | priv->int_name_rx, ndev); | 1286 | gfar_receive, 0, |
1287 | priv->gfargrp.int_name_rx, | ||
1288 | &priv->gfargrp); | ||
1274 | if (err) { | 1289 | if (err) { |
1275 | if (netif_msg_intr(priv)) | 1290 | if (netif_msg_intr(priv)) |
1276 | pr_err("%s: Can't get IRQ %d (receive0)\n", | 1291 | pr_err("%s: Can't get IRQ %d (receive0)\n", |
1277 | ndev->name, priv->interruptReceive); | 1292 | ndev->name, |
1293 | priv->gfargrp.interruptReceive); | ||
1278 | goto rx_irq_fail; | 1294 | goto rx_irq_fail; |
1279 | } | 1295 | } |
1280 | } else { | 1296 | } else { |
1281 | err = request_irq(priv->interruptTransmit, gfar_interrupt, | 1297 | err = request_irq(priv->gfargrp.interruptTransmit, |
1282 | 0, priv->int_name_tx, ndev); | 1298 | gfar_interrupt, 0, |
1299 | priv->gfargrp.int_name_tx, | ||
1300 | &priv->gfargrp); | ||
1283 | if (err) { | 1301 | if (err) { |
1284 | if (netif_msg_intr(priv)) | 1302 | if (netif_msg_intr(priv)) |
1285 | pr_err("%s: Can't get IRQ %d\n", ndev->name, | 1303 | pr_err("%s: Can't get IRQ %d\n", ndev->name, |
1286 | priv->interruptTransmit); | 1304 | priv->gfargrp.interruptTransmit); |
1287 | goto err_irq_fail; | 1305 | goto err_irq_fail; |
1288 | } | 1306 | } |
1289 | } | 1307 | } |
@@ -1296,9 +1314,9 @@ int startup_gfar(struct net_device *ndev) | |||
1296 | return 0; | 1314 | return 0; |
1297 | 1315 | ||
1298 | rx_irq_fail: | 1316 | rx_irq_fail: |
1299 | free_irq(priv->interruptTransmit, ndev); | 1317 | free_irq(priv->gfargrp.interruptTransmit, &priv->gfargrp); |
1300 | tx_irq_fail: | 1318 | tx_irq_fail: |
1301 | free_irq(priv->interruptError, ndev); | 1319 | free_irq(priv->gfargrp.interruptError, &priv->gfargrp); |
1302 | err_irq_fail: | 1320 | err_irq_fail: |
1303 | free_skb_resources(priv); | 1321 | free_skb_resources(priv); |
1304 | return err; | 1322 | return err; |
@@ -1403,6 +1421,7 @@ static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
1403 | { | 1421 | { |
1404 | struct gfar_private *priv = netdev_priv(dev); | 1422 | struct gfar_private *priv = netdev_priv(dev); |
1405 | struct gfar_priv_tx_q *tx_queue = NULL; | 1423 | struct gfar_priv_tx_q *tx_queue = NULL; |
1424 | struct gfar __iomem *regs = NULL; | ||
1406 | struct txfcb *fcb = NULL; | 1425 | struct txfcb *fcb = NULL; |
1407 | struct txbd8 *txbdp, *txbdp_start, *base; | 1426 | struct txbd8 *txbdp, *txbdp_start, *base; |
1408 | u32 lstatus; | 1427 | u32 lstatus; |
@@ -1413,6 +1432,7 @@ static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
1413 | 1432 | ||
1414 | tx_queue = priv->tx_queue; | 1433 | tx_queue = priv->tx_queue; |
1415 | base = tx_queue->tx_bd_base; | 1434 | base = tx_queue->tx_bd_base; |
1435 | regs = priv->gfargrp.regs; | ||
1416 | 1436 | ||
1417 | /* make space for additional header when fcb is needed */ | 1437 | /* make space for additional header when fcb is needed */ |
1418 | if (((skb->ip_summed == CHECKSUM_PARTIAL) || | 1438 | if (((skb->ip_summed == CHECKSUM_PARTIAL) || |
@@ -1536,7 +1556,7 @@ static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
1536 | } | 1556 | } |
1537 | 1557 | ||
1538 | /* Tell the DMA to go go go */ | 1558 | /* Tell the DMA to go go go */ |
1539 | gfar_write(&priv->regs->tstat, TSTAT_CLEAR_THALT); | 1559 | gfar_write(®s->tstat, TSTAT_CLEAR_THALT); |
1540 | 1560 | ||
1541 | /* Unlock priv */ | 1561 | /* Unlock priv */ |
1542 | spin_unlock_irqrestore(&tx_queue->txlock, flags); | 1562 | spin_unlock_irqrestore(&tx_queue->txlock, flags); |
@@ -1579,40 +1599,42 @@ static void gfar_vlan_rx_register(struct net_device *dev, | |||
1579 | { | 1599 | { |
1580 | struct gfar_private *priv = netdev_priv(dev); | 1600 | struct gfar_private *priv = netdev_priv(dev); |
1581 | struct gfar_priv_rx_q *rx_queue = NULL; | 1601 | struct gfar_priv_rx_q *rx_queue = NULL; |
1602 | struct gfar __iomem *regs = NULL; | ||
1582 | unsigned long flags; | 1603 | unsigned long flags; |
1583 | u32 tempval; | 1604 | u32 tempval; |
1584 | 1605 | ||
1585 | rx_queue = priv->rx_queue; | 1606 | rx_queue = priv->rx_queue; |
1607 | regs = priv->gfargrp.regs; | ||
1586 | spin_lock_irqsave(&rx_queue->rxlock, flags); | 1608 | spin_lock_irqsave(&rx_queue->rxlock, flags); |
1587 | 1609 | ||
1588 | priv->vlgrp = grp; | 1610 | priv->vlgrp = grp; |
1589 | 1611 | ||
1590 | if (grp) { | 1612 | if (grp) { |
1591 | /* Enable VLAN tag insertion */ | 1613 | /* Enable VLAN tag insertion */ |
1592 | tempval = gfar_read(&priv->regs->tctrl); | 1614 | tempval = gfar_read(®s->tctrl); |
1593 | tempval |= TCTRL_VLINS; | 1615 | tempval |= TCTRL_VLINS; |
1594 | 1616 | ||
1595 | gfar_write(&priv->regs->tctrl, tempval); | 1617 | gfar_write(®s->tctrl, tempval); |
1596 | 1618 | ||
1597 | /* Enable VLAN tag extraction */ | 1619 | /* Enable VLAN tag extraction */ |
1598 | tempval = gfar_read(&priv->regs->rctrl); | 1620 | tempval = gfar_read(®s->rctrl); |
1599 | tempval |= (RCTRL_VLEX | RCTRL_PRSDEP_INIT); | 1621 | tempval |= (RCTRL_VLEX | RCTRL_PRSDEP_INIT); |
1600 | gfar_write(&priv->regs->rctrl, tempval); | 1622 | gfar_write(®s->rctrl, tempval); |
1601 | } else { | 1623 | } else { |
1602 | /* Disable VLAN tag insertion */ | 1624 | /* Disable VLAN tag insertion */ |
1603 | tempval = gfar_read(&priv->regs->tctrl); | 1625 | tempval = gfar_read(®s->tctrl); |
1604 | tempval &= ~TCTRL_VLINS; | 1626 | tempval &= ~TCTRL_VLINS; |
1605 | gfar_write(&priv->regs->tctrl, tempval); | 1627 | gfar_write(®s->tctrl, tempval); |
1606 | 1628 | ||
1607 | /* Disable VLAN tag extraction */ | 1629 | /* Disable VLAN tag extraction */ |
1608 | tempval = gfar_read(&priv->regs->rctrl); | 1630 | tempval = gfar_read(®s->rctrl); |
1609 | tempval &= ~RCTRL_VLEX; | 1631 | tempval &= ~RCTRL_VLEX; |
1610 | /* If parse is no longer required, then disable parser */ | 1632 | /* If parse is no longer required, then disable parser */ |
1611 | if (tempval & RCTRL_REQ_PARSER) | 1633 | if (tempval & RCTRL_REQ_PARSER) |
1612 | tempval |= RCTRL_PRSDEP_INIT; | 1634 | tempval |= RCTRL_PRSDEP_INIT; |
1613 | else | 1635 | else |
1614 | tempval &= ~RCTRL_PRSDEP_INIT; | 1636 | tempval &= ~RCTRL_PRSDEP_INIT; |
1615 | gfar_write(&priv->regs->rctrl, tempval); | 1637 | gfar_write(®s->rctrl, tempval); |
1616 | } | 1638 | } |
1617 | 1639 | ||
1618 | gfar_change_mtu(dev, dev->mtu); | 1640 | gfar_change_mtu(dev, dev->mtu); |
@@ -1624,6 +1646,7 @@ static int gfar_change_mtu(struct net_device *dev, int new_mtu) | |||
1624 | { | 1646 | { |
1625 | int tempsize, tempval; | 1647 | int tempsize, tempval; |
1626 | struct gfar_private *priv = netdev_priv(dev); | 1648 | struct gfar_private *priv = netdev_priv(dev); |
1649 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
1627 | int oldsize = priv->rx_buffer_size; | 1650 | int oldsize = priv->rx_buffer_size; |
1628 | int frame_size = new_mtu + ETH_HLEN; | 1651 | int frame_size = new_mtu + ETH_HLEN; |
1629 | 1652 | ||
@@ -1655,20 +1678,20 @@ static int gfar_change_mtu(struct net_device *dev, int new_mtu) | |||
1655 | 1678 | ||
1656 | dev->mtu = new_mtu; | 1679 | dev->mtu = new_mtu; |
1657 | 1680 | ||
1658 | gfar_write(&priv->regs->mrblr, priv->rx_buffer_size); | 1681 | gfar_write(®s->mrblr, priv->rx_buffer_size); |
1659 | gfar_write(&priv->regs->maxfrm, priv->rx_buffer_size); | 1682 | gfar_write(®s->maxfrm, priv->rx_buffer_size); |
1660 | 1683 | ||
1661 | /* If the mtu is larger than the max size for standard | 1684 | /* If the mtu is larger than the max size for standard |
1662 | * ethernet frames (ie, a jumbo frame), then set maccfg2 | 1685 | * ethernet frames (ie, a jumbo frame), then set maccfg2 |
1663 | * to allow huge frames, and to check the length */ | 1686 | * to allow huge frames, and to check the length */ |
1664 | tempval = gfar_read(&priv->regs->maccfg2); | 1687 | tempval = gfar_read(®s->maccfg2); |
1665 | 1688 | ||
1666 | if (priv->rx_buffer_size > DEFAULT_RX_BUFFER_SIZE) | 1689 | if (priv->rx_buffer_size > DEFAULT_RX_BUFFER_SIZE) |
1667 | tempval |= (MACCFG2_HUGEFRAME | MACCFG2_LENGTHCHECK); | 1690 | tempval |= (MACCFG2_HUGEFRAME | MACCFG2_LENGTHCHECK); |
1668 | else | 1691 | else |
1669 | tempval &= ~(MACCFG2_HUGEFRAME | MACCFG2_LENGTHCHECK); | 1692 | tempval &= ~(MACCFG2_HUGEFRAME | MACCFG2_LENGTHCHECK); |
1670 | 1693 | ||
1671 | gfar_write(&priv->regs->maccfg2, tempval); | 1694 | gfar_write(®s->maccfg2, tempval); |
1672 | 1695 | ||
1673 | if ((oldsize != tempsize) && (dev->flags & IFF_UP)) | 1696 | if ((oldsize != tempsize) && (dev->flags & IFF_UP)) |
1674 | startup_gfar(dev); | 1697 | startup_gfar(dev); |
@@ -1787,9 +1810,9 @@ static int gfar_clean_tx_ring(struct gfar_priv_tx_q *tx_queue) | |||
1787 | return howmany; | 1810 | return howmany; |
1788 | } | 1811 | } |
1789 | 1812 | ||
1790 | static void gfar_schedule_cleanup(struct net_device *dev) | 1813 | static void gfar_schedule_cleanup(struct gfar_priv_grp *gfargrp) |
1791 | { | 1814 | { |
1792 | struct gfar_private *priv = netdev_priv(dev); | 1815 | struct gfar_private *priv = gfargrp->priv; |
1793 | struct gfar_priv_tx_q *tx_queue = NULL; | 1816 | struct gfar_priv_tx_q *tx_queue = NULL; |
1794 | struct gfar_priv_rx_q *rx_queue = NULL; | 1817 | struct gfar_priv_rx_q *rx_queue = NULL; |
1795 | unsigned long flags; | 1818 | unsigned long flags; |
@@ -1800,14 +1823,14 @@ static void gfar_schedule_cleanup(struct net_device *dev) | |||
1800 | spin_lock(&rx_queue->rxlock); | 1823 | spin_lock(&rx_queue->rxlock); |
1801 | 1824 | ||
1802 | if (napi_schedule_prep(&rx_queue->napi)) { | 1825 | if (napi_schedule_prep(&rx_queue->napi)) { |
1803 | gfar_write(&priv->regs->imask, IMASK_RTX_DISABLED); | 1826 | gfar_write(&gfargrp->regs->imask, IMASK_RTX_DISABLED); |
1804 | __napi_schedule(&rx_queue->napi); | 1827 | __napi_schedule(&rx_queue->napi); |
1805 | } else { | 1828 | } else { |
1806 | /* | 1829 | /* |
1807 | * Clear IEVENT, so interrupts aren't called again | 1830 | * Clear IEVENT, so interrupts aren't called again |
1808 | * because of the packets that have already arrived. | 1831 | * because of the packets that have already arrived. |
1809 | */ | 1832 | */ |
1810 | gfar_write(&priv->regs->ievent, IEVENT_RTX_MASK); | 1833 | gfar_write(&gfargrp->regs->ievent, IEVENT_RTX_MASK); |
1811 | } | 1834 | } |
1812 | 1835 | ||
1813 | spin_unlock(&rx_queue->rxlock); | 1836 | spin_unlock(&rx_queue->rxlock); |
@@ -1815,9 +1838,9 @@ static void gfar_schedule_cleanup(struct net_device *dev) | |||
1815 | } | 1838 | } |
1816 | 1839 | ||
1817 | /* Interrupt Handler for Transmit complete */ | 1840 | /* Interrupt Handler for Transmit complete */ |
1818 | static irqreturn_t gfar_transmit(int irq, void *dev_id) | 1841 | static irqreturn_t gfar_transmit(int irq, void *grp_id) |
1819 | { | 1842 | { |
1820 | gfar_schedule_cleanup((struct net_device *)dev_id); | 1843 | gfar_schedule_cleanup((struct gfar_priv_grp *)grp_id); |
1821 | return IRQ_HANDLED; | 1844 | return IRQ_HANDLED; |
1822 | } | 1845 | } |
1823 | 1846 | ||
@@ -1897,9 +1920,9 @@ static inline void count_errors(unsigned short status, struct net_device *dev) | |||
1897 | } | 1920 | } |
1898 | } | 1921 | } |
1899 | 1922 | ||
1900 | irqreturn_t gfar_receive(int irq, void *dev_id) | 1923 | irqreturn_t gfar_receive(int irq, void *grp_id) |
1901 | { | 1924 | { |
1902 | gfar_schedule_cleanup((struct net_device *)dev_id); | 1925 | gfar_schedule_cleanup((struct gfar_priv_grp *)grp_id); |
1903 | return IRQ_HANDLED; | 1926 | return IRQ_HANDLED; |
1904 | } | 1927 | } |
1905 | 1928 | ||
@@ -2053,6 +2076,7 @@ static int gfar_poll(struct napi_struct *napi, int budget) | |||
2053 | struct gfar_priv_rx_q, napi); | 2076 | struct gfar_priv_rx_q, napi); |
2054 | struct net_device *dev = rx_queue->dev; | 2077 | struct net_device *dev = rx_queue->dev; |
2055 | struct gfar_private *priv = netdev_priv(dev); | 2078 | struct gfar_private *priv = netdev_priv(dev); |
2079 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
2056 | struct gfar_priv_tx_q *tx_queue = NULL; | 2080 | struct gfar_priv_tx_q *tx_queue = NULL; |
2057 | int tx_cleaned = 0; | 2081 | int tx_cleaned = 0; |
2058 | int rx_cleaned = 0; | 2082 | int rx_cleaned = 0; |
@@ -2060,7 +2084,7 @@ static int gfar_poll(struct napi_struct *napi, int budget) | |||
2060 | 2084 | ||
2061 | /* Clear IEVENT, so interrupts aren't called again | 2085 | /* Clear IEVENT, so interrupts aren't called again |
2062 | * because of the packets that have already arrived */ | 2086 | * because of the packets that have already arrived */ |
2063 | gfar_write(&priv->regs->ievent, IEVENT_RTX_MASK); | 2087 | gfar_write(®s->ievent, IEVENT_RTX_MASK); |
2064 | tx_queue = priv->tx_queue; | 2088 | tx_queue = priv->tx_queue; |
2065 | 2089 | ||
2066 | /* If we fail to get the lock, don't bother with the TX BDs */ | 2090 | /* If we fail to get the lock, don't bother with the TX BDs */ |
@@ -2078,19 +2102,19 @@ static int gfar_poll(struct napi_struct *napi, int budget) | |||
2078 | napi_complete(napi); | 2102 | napi_complete(napi); |
2079 | 2103 | ||
2080 | /* Clear the halt bit in RSTAT */ | 2104 | /* Clear the halt bit in RSTAT */ |
2081 | gfar_write(&priv->regs->rstat, RSTAT_CLEAR_RHALT); | 2105 | gfar_write(®s->rstat, RSTAT_CLEAR_RHALT); |
2082 | 2106 | ||
2083 | gfar_write(&priv->regs->imask, IMASK_DEFAULT); | 2107 | gfar_write(®s->imask, IMASK_DEFAULT); |
2084 | 2108 | ||
2085 | /* If we are coalescing interrupts, update the timer */ | 2109 | /* If we are coalescing interrupts, update the timer */ |
2086 | /* Otherwise, clear it */ | 2110 | /* Otherwise, clear it */ |
2087 | if (likely(rx_queue->rxcoalescing)) { | 2111 | if (likely(rx_queue->rxcoalescing)) { |
2088 | gfar_write(&priv->regs->rxic, 0); | 2112 | gfar_write(®s->rxic, 0); |
2089 | gfar_write(&priv->regs->rxic, rx_queue->rxic); | 2113 | gfar_write(®s->rxic, rx_queue->rxic); |
2090 | } | 2114 | } |
2091 | if (likely(tx_queue->txcoalescing)) { | 2115 | if (likely(tx_queue->txcoalescing)) { |
2092 | gfar_write(&priv->regs->txic, 0); | 2116 | gfar_write(®s->txic, 0); |
2093 | gfar_write(&priv->regs->txic, tx_queue->txic); | 2117 | gfar_write(®s->txic, tx_queue->txic); |
2094 | } | 2118 | } |
2095 | } | 2119 | } |
2096 | 2120 | ||
@@ -2109,41 +2133,40 @@ static void gfar_netpoll(struct net_device *dev) | |||
2109 | 2133 | ||
2110 | /* If the device has multiple interrupts, run tx/rx */ | 2134 | /* If the device has multiple interrupts, run tx/rx */ |
2111 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { | 2135 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_MULTI_INTR) { |
2112 | disable_irq(priv->interruptTransmit); | 2136 | disable_irq(priv->gfargrp.interruptTransmit); |
2113 | disable_irq(priv->interruptReceive); | 2137 | disable_irq(priv->gfargrp.interruptReceive); |
2114 | disable_irq(priv->interruptError); | 2138 | disable_irq(priv->gfargrp.interruptError); |
2115 | gfar_interrupt(priv->interruptTransmit, dev); | 2139 | gfar_interrupt(priv->gfargrp.interruptTransmit, &priv->gfargrp); |
2116 | enable_irq(priv->interruptError); | 2140 | enable_irq(priv->gfargrp.interruptError); |
2117 | enable_irq(priv->interruptReceive); | 2141 | enable_irq(priv->gfargrp.interruptReceive); |
2118 | enable_irq(priv->interruptTransmit); | 2142 | enable_irq(priv->gfargrp.interruptTransmit); |
2119 | } else { | 2143 | } else { |
2120 | disable_irq(priv->interruptTransmit); | 2144 | disable_irq(priv->gfargrp.interruptTransmit); |
2121 | gfar_interrupt(priv->interruptTransmit, dev); | 2145 | gfar_interrupt(priv->gfargrp.interruptTransmit, &priv->gfargrp); |
2122 | enable_irq(priv->interruptTransmit); | 2146 | enable_irq(priv->gfargrp.interruptTransmit); |
2123 | } | 2147 | } |
2124 | } | 2148 | } |
2125 | #endif | 2149 | #endif |
2126 | 2150 | ||
2127 | /* The interrupt handler for devices with one interrupt */ | 2151 | /* The interrupt handler for devices with one interrupt */ |
2128 | static irqreturn_t gfar_interrupt(int irq, void *dev_id) | 2152 | static irqreturn_t gfar_interrupt(int irq, void *grp_id) |
2129 | { | 2153 | { |
2130 | struct net_device *dev = dev_id; | 2154 | struct gfar_priv_grp *gfargrp = grp_id; |
2131 | struct gfar_private *priv = netdev_priv(dev); | ||
2132 | 2155 | ||
2133 | /* Save ievent for future reference */ | 2156 | /* Save ievent for future reference */ |
2134 | u32 events = gfar_read(&priv->regs->ievent); | 2157 | u32 events = gfar_read(&gfargrp->regs->ievent); |
2135 | 2158 | ||
2136 | /* Check for reception */ | 2159 | /* Check for reception */ |
2137 | if (events & IEVENT_RX_MASK) | 2160 | if (events & IEVENT_RX_MASK) |
2138 | gfar_receive(irq, dev_id); | 2161 | gfar_receive(irq, grp_id); |
2139 | 2162 | ||
2140 | /* Check for transmit completion */ | 2163 | /* Check for transmit completion */ |
2141 | if (events & IEVENT_TX_MASK) | 2164 | if (events & IEVENT_TX_MASK) |
2142 | gfar_transmit(irq, dev_id); | 2165 | gfar_transmit(irq, grp_id); |
2143 | 2166 | ||
2144 | /* Check for errors */ | 2167 | /* Check for errors */ |
2145 | if (events & IEVENT_ERR_MASK) | 2168 | if (events & IEVENT_ERR_MASK) |
2146 | gfar_error(irq, dev_id); | 2169 | gfar_error(irq, grp_id); |
2147 | 2170 | ||
2148 | return IRQ_HANDLED; | 2171 | return IRQ_HANDLED; |
2149 | } | 2172 | } |
@@ -2158,7 +2181,7 @@ static void adjust_link(struct net_device *dev) | |||
2158 | { | 2181 | { |
2159 | struct gfar_private *priv = netdev_priv(dev); | 2182 | struct gfar_private *priv = netdev_priv(dev); |
2160 | struct gfar_priv_tx_q *tx_queue = NULL; | 2183 | struct gfar_priv_tx_q *tx_queue = NULL; |
2161 | struct gfar __iomem *regs = priv->regs; | 2184 | struct gfar __iomem *regs = priv->gfargrp.regs; |
2162 | unsigned long flags; | 2185 | unsigned long flags; |
2163 | struct phy_device *phydev = priv->phydev; | 2186 | struct phy_device *phydev = priv->phydev; |
2164 | int new_state = 0; | 2187 | int new_state = 0; |
@@ -2241,7 +2264,7 @@ static void gfar_set_multi(struct net_device *dev) | |||
2241 | { | 2264 | { |
2242 | struct dev_mc_list *mc_ptr; | 2265 | struct dev_mc_list *mc_ptr; |
2243 | struct gfar_private *priv = netdev_priv(dev); | 2266 | struct gfar_private *priv = netdev_priv(dev); |
2244 | struct gfar __iomem *regs = priv->regs; | 2267 | struct gfar __iomem *regs = priv->gfargrp.regs; |
2245 | u32 tempval; | 2268 | u32 tempval; |
2246 | 2269 | ||
2247 | if (dev->flags & IFF_PROMISC) { | 2270 | if (dev->flags & IFF_PROMISC) { |
@@ -2374,10 +2397,11 @@ static void gfar_set_hash_for_addr(struct net_device *dev, u8 *addr) | |||
2374 | static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr) | 2397 | static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr) |
2375 | { | 2398 | { |
2376 | struct gfar_private *priv = netdev_priv(dev); | 2399 | struct gfar_private *priv = netdev_priv(dev); |
2400 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
2377 | int idx; | 2401 | int idx; |
2378 | char tmpbuf[MAC_ADDR_LEN]; | 2402 | char tmpbuf[MAC_ADDR_LEN]; |
2379 | u32 tempval; | 2403 | u32 tempval; |
2380 | u32 __iomem *macptr = &priv->regs->macstnaddr1; | 2404 | u32 __iomem *macptr = ®s->macstnaddr1; |
2381 | 2405 | ||
2382 | macptr += num*2; | 2406 | macptr += num*2; |
2383 | 2407 | ||
@@ -2394,16 +2418,18 @@ static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr) | |||
2394 | } | 2418 | } |
2395 | 2419 | ||
2396 | /* GFAR error interrupt handler */ | 2420 | /* GFAR error interrupt handler */ |
2397 | static irqreturn_t gfar_error(int irq, void *dev_id) | 2421 | static irqreturn_t gfar_error(int irq, void *grp_id) |
2398 | { | 2422 | { |
2399 | struct net_device *dev = dev_id; | 2423 | struct gfar_priv_grp *gfargrp = grp_id; |
2400 | struct gfar_private *priv = netdev_priv(dev); | 2424 | struct gfar __iomem *regs = gfargrp->regs; |
2425 | struct gfar_private *priv= gfargrp->priv; | ||
2426 | struct net_device *dev = priv->ndev; | ||
2401 | 2427 | ||
2402 | /* Save ievent for future reference */ | 2428 | /* Save ievent for future reference */ |
2403 | u32 events = gfar_read(&priv->regs->ievent); | 2429 | u32 events = gfar_read(®s->ievent); |
2404 | 2430 | ||
2405 | /* Clear IEVENT */ | 2431 | /* Clear IEVENT */ |
2406 | gfar_write(&priv->regs->ievent, events & IEVENT_ERR_MASK); | 2432 | gfar_write(®s->ievent, events & IEVENT_ERR_MASK); |
2407 | 2433 | ||
2408 | /* Magic Packet is not an error. */ | 2434 | /* Magic Packet is not an error. */ |
2409 | if ((priv->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET) && | 2435 | if ((priv->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET) && |
@@ -2413,7 +2439,7 @@ static irqreturn_t gfar_error(int irq, void *dev_id) | |||
2413 | /* Hmm... */ | 2439 | /* Hmm... */ |
2414 | if (netif_msg_rx_err(priv) || netif_msg_tx_err(priv)) | 2440 | if (netif_msg_rx_err(priv) || netif_msg_tx_err(priv)) |
2415 | printk(KERN_DEBUG "%s: error interrupt (ievent=0x%08x imask=0x%08x)\n", | 2441 | printk(KERN_DEBUG "%s: error interrupt (ievent=0x%08x imask=0x%08x)\n", |
2416 | dev->name, events, gfar_read(&priv->regs->imask)); | 2442 | dev->name, events, gfar_read(®s->imask)); |
2417 | 2443 | ||
2418 | /* Update the error counters */ | 2444 | /* Update the error counters */ |
2419 | if (events & IEVENT_TXE) { | 2445 | if (events & IEVENT_TXE) { |
@@ -2431,7 +2457,7 @@ static irqreturn_t gfar_error(int irq, void *dev_id) | |||
2431 | priv->extra_stats.tx_underrun++; | 2457 | priv->extra_stats.tx_underrun++; |
2432 | 2458 | ||
2433 | /* Reactivate the Tx Queues */ | 2459 | /* Reactivate the Tx Queues */ |
2434 | gfar_write(&priv->regs->tstat, TSTAT_CLEAR_THALT); | 2460 | gfar_write(®s->tstat, TSTAT_CLEAR_THALT); |
2435 | } | 2461 | } |
2436 | if (netif_msg_tx_err(priv)) | 2462 | if (netif_msg_tx_err(priv)) |
2437 | printk(KERN_DEBUG "%s: Transmit Error\n", dev->name); | 2463 | printk(KERN_DEBUG "%s: Transmit Error\n", dev->name); |
@@ -2440,11 +2466,11 @@ static irqreturn_t gfar_error(int irq, void *dev_id) | |||
2440 | dev->stats.rx_errors++; | 2466 | dev->stats.rx_errors++; |
2441 | priv->extra_stats.rx_bsy++; | 2467 | priv->extra_stats.rx_bsy++; |
2442 | 2468 | ||
2443 | gfar_receive(irq, dev_id); | 2469 | gfar_receive(irq, grp_id); |
2444 | 2470 | ||
2445 | if (netif_msg_rx_err(priv)) | 2471 | if (netif_msg_rx_err(priv)) |
2446 | printk(KERN_DEBUG "%s: busy error (rstat: %x)\n", | 2472 | printk(KERN_DEBUG "%s: busy error (rstat: %x)\n", |
2447 | dev->name, gfar_read(&priv->regs->rstat)); | 2473 | dev->name, gfar_read(®s->rstat)); |
2448 | } | 2474 | } |
2449 | if (events & IEVENT_BABR) { | 2475 | if (events & IEVENT_BABR) { |
2450 | dev->stats.rx_errors++; | 2476 | dev->stats.rx_errors++; |
diff --git a/drivers/net/gianfar.h b/drivers/net/gianfar.h index a60f93f1ae07..79e8471584ea 100644 --- a/drivers/net/gianfar.h +++ b/drivers/net/gianfar.h | |||
@@ -770,6 +770,32 @@ struct gfar_priv_rx_q { | |||
770 | unsigned long rxic; | 770 | unsigned long rxic; |
771 | }; | 771 | }; |
772 | 772 | ||
773 | /** | ||
774 | * struct gfar_priv_grp - per group structure | ||
775 | * @priv: back pointer to the priv structure | ||
776 | * @regs: the ioremapped register space for this group | ||
777 | * @grp_id: group id for this group | ||
778 | * @interruptTransmit: The TX interrupt number for this group | ||
779 | * @interruptReceive: The RX interrupt number for this group | ||
780 | * @interruptError: The ERROR interrupt number for this group | ||
781 | * @int_name_tx: tx interrupt name for this group | ||
782 | * @int_name_rx: rx interrupt name for this group | ||
783 | * @int_name_er: er interrupt name for this group | ||
784 | */ | ||
785 | |||
786 | struct gfar_priv_grp { | ||
787 | spinlock_t grplock __attribute__ ((aligned (SMP_CACHE_BYTES))); | ||
788 | struct gfar_private *priv; | ||
789 | struct gfar __iomem *regs; | ||
790 | unsigned int interruptTransmit; | ||
791 | unsigned int interruptReceive; | ||
792 | unsigned int interruptError; | ||
793 | |||
794 | char int_name_tx[GFAR_INT_NAME_MAX]; | ||
795 | char int_name_rx[GFAR_INT_NAME_MAX]; | ||
796 | char int_name_er[GFAR_INT_NAME_MAX]; | ||
797 | }; | ||
798 | |||
773 | /* Struct stolen almost completely (and shamelessly) from the FCC enet source | 799 | /* Struct stolen almost completely (and shamelessly) from the FCC enet source |
774 | * (Ok, that's not so true anymore, but there is a family resemblence) | 800 | * (Ok, that's not so true anymore, but there is a family resemblence) |
775 | * The GFAR buffer descriptors track the ring buffers. The rx_bd_base | 801 | * The GFAR buffer descriptors track the ring buffers. The rx_bd_base |
@@ -785,6 +811,7 @@ struct gfar_private { | |||
785 | struct net_device *ndev; | 811 | struct net_device *ndev; |
786 | struct of_device *ofdev; | 812 | struct of_device *ofdev; |
787 | 813 | ||
814 | struct gfar_priv_grp gfargrp; | ||
788 | struct gfar_priv_tx_q *tx_queue; | 815 | struct gfar_priv_tx_q *tx_queue; |
789 | struct gfar_priv_rx_q *rx_queue; | 816 | struct gfar_priv_rx_q *rx_queue; |
790 | 817 | ||
@@ -797,9 +824,6 @@ struct gfar_private { | |||
797 | 824 | ||
798 | struct vlan_group *vlgrp; | 825 | struct vlan_group *vlgrp; |
799 | 826 | ||
800 | /* Unprotected fields */ | ||
801 | /* Pointer to the GFAR memory mapped Registers */ | ||
802 | struct gfar __iomem *regs; | ||
803 | 827 | ||
804 | /* Hash registers and their width */ | 828 | /* Hash registers and their width */ |
805 | u32 __iomem *hash_regs[16]; | 829 | u32 __iomem *hash_regs[16]; |
@@ -823,10 +847,6 @@ struct gfar_private { | |||
823 | wol_en:1; /* Wake-on-LAN enabled */ | 847 | wol_en:1; /* Wake-on-LAN enabled */ |
824 | unsigned short padding; | 848 | unsigned short padding; |
825 | 849 | ||
826 | unsigned int interruptTransmit; | ||
827 | unsigned int interruptReceive; | ||
828 | unsigned int interruptError; | ||
829 | |||
830 | /* PHY stuff */ | 850 | /* PHY stuff */ |
831 | struct phy_device *phydev; | 851 | struct phy_device *phydev; |
832 | struct mii_bus *mii_bus; | 852 | struct mii_bus *mii_bus; |
@@ -838,10 +858,6 @@ struct gfar_private { | |||
838 | 858 | ||
839 | struct work_struct reset_task; | 859 | struct work_struct reset_task; |
840 | 860 | ||
841 | char int_name_tx[GFAR_INT_NAME_MAX]; | ||
842 | char int_name_rx[GFAR_INT_NAME_MAX]; | ||
843 | char int_name_er[GFAR_INT_NAME_MAX]; | ||
844 | |||
845 | /* Network Statistics */ | 861 | /* Network Statistics */ |
846 | struct gfar_extra_stats extra_stats; | 862 | struct gfar_extra_stats extra_stats; |
847 | }; | 863 | }; |
diff --git a/drivers/net/gianfar_ethtool.c b/drivers/net/gianfar_ethtool.c index 6d0d1714c2f2..c681b414767a 100644 --- a/drivers/net/gianfar_ethtool.c +++ b/drivers/net/gianfar_ethtool.c | |||
@@ -137,10 +137,11 @@ static void gfar_fill_stats(struct net_device *dev, struct ethtool_stats *dummy, | |||
137 | { | 137 | { |
138 | int i; | 138 | int i; |
139 | struct gfar_private *priv = netdev_priv(dev); | 139 | struct gfar_private *priv = netdev_priv(dev); |
140 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
140 | u64 *extra = (u64 *) & priv->extra_stats; | 141 | u64 *extra = (u64 *) & priv->extra_stats; |
141 | 142 | ||
142 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_RMON) { | 143 | if (priv->device_flags & FSL_GIANFAR_DEV_HAS_RMON) { |
143 | u32 __iomem *rmon = (u32 __iomem *) & priv->regs->rmon; | 144 | u32 __iomem *rmon = (u32 __iomem *) ®s->rmon; |
144 | struct gfar_stats *stats = (struct gfar_stats *) buf; | 145 | struct gfar_stats *stats = (struct gfar_stats *) buf; |
145 | 146 | ||
146 | for (i = 0; i < GFAR_RMON_LEN; i++) | 147 | for (i = 0; i < GFAR_RMON_LEN; i++) |
@@ -223,7 +224,7 @@ static void gfar_get_regs(struct net_device *dev, struct ethtool_regs *regs, voi | |||
223 | { | 224 | { |
224 | int i; | 225 | int i; |
225 | struct gfar_private *priv = netdev_priv(dev); | 226 | struct gfar_private *priv = netdev_priv(dev); |
226 | u32 __iomem *theregs = (u32 __iomem *) priv->regs; | 227 | u32 __iomem *theregs = (u32 __iomem *) priv->gfargrp.regs; |
227 | u32 *buf = (u32 *) regbuf; | 228 | u32 *buf = (u32 *) regbuf; |
228 | 229 | ||
229 | for (i = 0; i < sizeof (struct gfar) / sizeof (u32); i++) | 230 | for (i = 0; i < sizeof (struct gfar) / sizeof (u32); i++) |
@@ -349,6 +350,7 @@ static int gfar_gcoalesce(struct net_device *dev, struct ethtool_coalesce *cvals | |||
349 | static int gfar_scoalesce(struct net_device *dev, struct ethtool_coalesce *cvals) | 350 | static int gfar_scoalesce(struct net_device *dev, struct ethtool_coalesce *cvals) |
350 | { | 351 | { |
351 | struct gfar_private *priv = netdev_priv(dev); | 352 | struct gfar_private *priv = netdev_priv(dev); |
353 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
352 | struct gfar_priv_tx_q *tx_queue = NULL; | 354 | struct gfar_priv_tx_q *tx_queue = NULL; |
353 | struct gfar_priv_rx_q *rx_queue = NULL; | 355 | struct gfar_priv_rx_q *rx_queue = NULL; |
354 | 356 | ||
@@ -407,13 +409,13 @@ static int gfar_scoalesce(struct net_device *dev, struct ethtool_coalesce *cvals | |||
407 | tx_queue->txic = mk_ic_value(cvals->tx_max_coalesced_frames, | 409 | tx_queue->txic = mk_ic_value(cvals->tx_max_coalesced_frames, |
408 | gfar_usecs2ticks(priv, cvals->tx_coalesce_usecs)); | 410 | gfar_usecs2ticks(priv, cvals->tx_coalesce_usecs)); |
409 | 411 | ||
410 | gfar_write(&priv->regs->rxic, 0); | 412 | gfar_write(®s->rxic, 0); |
411 | if (rx_queue->rxcoalescing) | 413 | if (rx_queue->rxcoalescing) |
412 | gfar_write(&priv->regs->rxic, rx_queue->rxic); | 414 | gfar_write(®s->rxic, rx_queue->rxic); |
413 | 415 | ||
414 | gfar_write(&priv->regs->txic, 0); | 416 | gfar_write(®s->txic, 0); |
415 | if (tx_queue->txcoalescing) | 417 | if (tx_queue->txcoalescing) |
416 | gfar_write(&priv->regs->txic, tx_queue->txic); | 418 | gfar_write(®s->txic, tx_queue->txic); |
417 | 419 | ||
418 | return 0; | 420 | return 0; |
419 | } | 421 | } |
diff --git a/drivers/net/gianfar_sysfs.c b/drivers/net/gianfar_sysfs.c index 9c664f85705c..adea11ea4038 100644 --- a/drivers/net/gianfar_sysfs.c +++ b/drivers/net/gianfar_sysfs.c | |||
@@ -50,6 +50,7 @@ static ssize_t gfar_set_bd_stash(struct device *dev, | |||
50 | const char *buf, size_t count) | 50 | const char *buf, size_t count) |
51 | { | 51 | { |
52 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); | 52 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); |
53 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
53 | struct gfar_priv_rx_q *rx_queue = NULL; | 54 | struct gfar_priv_rx_q *rx_queue = NULL; |
54 | int new_setting = 0; | 55 | int new_setting = 0; |
55 | u32 temp; | 56 | u32 temp; |
@@ -74,14 +75,14 @@ static ssize_t gfar_set_bd_stash(struct device *dev, | |||
74 | /* Set the new stashing value */ | 75 | /* Set the new stashing value */ |
75 | priv->bd_stash_en = new_setting; | 76 | priv->bd_stash_en = new_setting; |
76 | 77 | ||
77 | temp = gfar_read(&priv->regs->attr); | 78 | temp = gfar_read(®s->attr); |
78 | 79 | ||
79 | if (new_setting) | 80 | if (new_setting) |
80 | temp |= ATTR_BDSTASH; | 81 | temp |= ATTR_BDSTASH; |
81 | else | 82 | else |
82 | temp &= ~(ATTR_BDSTASH); | 83 | temp &= ~(ATTR_BDSTASH); |
83 | 84 | ||
84 | gfar_write(&priv->regs->attr, temp); | 85 | gfar_write(®s->attr, temp); |
85 | 86 | ||
86 | spin_unlock_irqrestore(&rx_queue->rxlock, flags); | 87 | spin_unlock_irqrestore(&rx_queue->rxlock, flags); |
87 | 88 | ||
@@ -103,6 +104,7 @@ static ssize_t gfar_set_rx_stash_size(struct device *dev, | |||
103 | const char *buf, size_t count) | 104 | const char *buf, size_t count) |
104 | { | 105 | { |
105 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); | 106 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); |
107 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
106 | struct gfar_priv_rx_q *rx_queue = NULL; | 108 | struct gfar_priv_rx_q *rx_queue = NULL; |
107 | unsigned int length = simple_strtoul(buf, NULL, 0); | 109 | unsigned int length = simple_strtoul(buf, NULL, 0); |
108 | u32 temp; | 110 | u32 temp; |
@@ -122,20 +124,20 @@ static ssize_t gfar_set_rx_stash_size(struct device *dev, | |||
122 | 124 | ||
123 | priv->rx_stash_size = length; | 125 | priv->rx_stash_size = length; |
124 | 126 | ||
125 | temp = gfar_read(&priv->regs->attreli); | 127 | temp = gfar_read(®s->attreli); |
126 | temp &= ~ATTRELI_EL_MASK; | 128 | temp &= ~ATTRELI_EL_MASK; |
127 | temp |= ATTRELI_EL(length); | 129 | temp |= ATTRELI_EL(length); |
128 | gfar_write(&priv->regs->attreli, temp); | 130 | gfar_write(®s->attreli, temp); |
129 | 131 | ||
130 | /* Turn stashing on/off as appropriate */ | 132 | /* Turn stashing on/off as appropriate */ |
131 | temp = gfar_read(&priv->regs->attr); | 133 | temp = gfar_read(®s->attr); |
132 | 134 | ||
133 | if (length) | 135 | if (length) |
134 | temp |= ATTR_BUFSTASH; | 136 | temp |= ATTR_BUFSTASH; |
135 | else | 137 | else |
136 | temp &= ~(ATTR_BUFSTASH); | 138 | temp &= ~(ATTR_BUFSTASH); |
137 | 139 | ||
138 | gfar_write(&priv->regs->attr, temp); | 140 | gfar_write(®s->attr, temp); |
139 | 141 | ||
140 | out: | 142 | out: |
141 | spin_unlock_irqrestore(&rx_queue->rxlock, flags); | 143 | spin_unlock_irqrestore(&rx_queue->rxlock, flags); |
@@ -161,6 +163,7 @@ static ssize_t gfar_set_rx_stash_index(struct device *dev, | |||
161 | const char *buf, size_t count) | 163 | const char *buf, size_t count) |
162 | { | 164 | { |
163 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); | 165 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); |
166 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
164 | struct gfar_priv_rx_q *rx_queue = NULL; | 167 | struct gfar_priv_rx_q *rx_queue = NULL; |
165 | unsigned short index = simple_strtoul(buf, NULL, 0); | 168 | unsigned short index = simple_strtoul(buf, NULL, 0); |
166 | u32 temp; | 169 | u32 temp; |
@@ -180,10 +183,10 @@ static ssize_t gfar_set_rx_stash_index(struct device *dev, | |||
180 | 183 | ||
181 | priv->rx_stash_index = index; | 184 | priv->rx_stash_index = index; |
182 | 185 | ||
183 | temp = gfar_read(&priv->regs->attreli); | 186 | temp = gfar_read(®s->attreli); |
184 | temp &= ~ATTRELI_EI_MASK; | 187 | temp &= ~ATTRELI_EI_MASK; |
185 | temp |= ATTRELI_EI(index); | 188 | temp |= ATTRELI_EI(index); |
186 | gfar_write(&priv->regs->attreli, flags); | 189 | gfar_write(®s->attreli, flags); |
187 | 190 | ||
188 | out: | 191 | out: |
189 | spin_unlock_irqrestore(&rx_queue->rxlock, flags); | 192 | spin_unlock_irqrestore(&rx_queue->rxlock, flags); |
@@ -208,6 +211,7 @@ static ssize_t gfar_set_fifo_threshold(struct device *dev, | |||
208 | const char *buf, size_t count) | 211 | const char *buf, size_t count) |
209 | { | 212 | { |
210 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); | 213 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); |
214 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
211 | struct gfar_priv_tx_q *tx_queue = NULL; | 215 | struct gfar_priv_tx_q *tx_queue = NULL; |
212 | unsigned int length = simple_strtoul(buf, NULL, 0); | 216 | unsigned int length = simple_strtoul(buf, NULL, 0); |
213 | u32 temp; | 217 | u32 temp; |
@@ -222,10 +226,10 @@ static ssize_t gfar_set_fifo_threshold(struct device *dev, | |||
222 | 226 | ||
223 | priv->fifo_threshold = length; | 227 | priv->fifo_threshold = length; |
224 | 228 | ||
225 | temp = gfar_read(&priv->regs->fifo_tx_thr); | 229 | temp = gfar_read(®s->fifo_tx_thr); |
226 | temp &= ~FIFO_TX_THR_MASK; | 230 | temp &= ~FIFO_TX_THR_MASK; |
227 | temp |= length; | 231 | temp |= length; |
228 | gfar_write(&priv->regs->fifo_tx_thr, temp); | 232 | gfar_write(®s->fifo_tx_thr, temp); |
229 | 233 | ||
230 | spin_unlock_irqrestore(&tx_queue->txlock, flags); | 234 | spin_unlock_irqrestore(&tx_queue->txlock, flags); |
231 | 235 | ||
@@ -248,6 +252,7 @@ static ssize_t gfar_set_fifo_starve(struct device *dev, | |||
248 | const char *buf, size_t count) | 252 | const char *buf, size_t count) |
249 | { | 253 | { |
250 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); | 254 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); |
255 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
251 | struct gfar_priv_tx_q *tx_queue = NULL; | 256 | struct gfar_priv_tx_q *tx_queue = NULL; |
252 | unsigned int num = simple_strtoul(buf, NULL, 0); | 257 | unsigned int num = simple_strtoul(buf, NULL, 0); |
253 | u32 temp; | 258 | u32 temp; |
@@ -261,10 +266,10 @@ static ssize_t gfar_set_fifo_starve(struct device *dev, | |||
261 | 266 | ||
262 | priv->fifo_starve = num; | 267 | priv->fifo_starve = num; |
263 | 268 | ||
264 | temp = gfar_read(&priv->regs->fifo_tx_starve); | 269 | temp = gfar_read(®s->fifo_tx_starve); |
265 | temp &= ~FIFO_TX_STARVE_MASK; | 270 | temp &= ~FIFO_TX_STARVE_MASK; |
266 | temp |= num; | 271 | temp |= num; |
267 | gfar_write(&priv->regs->fifo_tx_starve, temp); | 272 | gfar_write(®s->fifo_tx_starve, temp); |
268 | 273 | ||
269 | spin_unlock_irqrestore(&tx_queue->txlock, flags); | 274 | spin_unlock_irqrestore(&tx_queue->txlock, flags); |
270 | 275 | ||
@@ -288,6 +293,7 @@ static ssize_t gfar_set_fifo_starve_off(struct device *dev, | |||
288 | const char *buf, size_t count) | 293 | const char *buf, size_t count) |
289 | { | 294 | { |
290 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); | 295 | struct gfar_private *priv = netdev_priv(to_net_dev(dev)); |
296 | struct gfar __iomem *regs = priv->gfargrp.regs; | ||
291 | struct gfar_priv_tx_q *tx_queue = NULL; | 297 | struct gfar_priv_tx_q *tx_queue = NULL; |
292 | unsigned int num = simple_strtoul(buf, NULL, 0); | 298 | unsigned int num = simple_strtoul(buf, NULL, 0); |
293 | u32 temp; | 299 | u32 temp; |
@@ -301,10 +307,10 @@ static ssize_t gfar_set_fifo_starve_off(struct device *dev, | |||
301 | 307 | ||
302 | priv->fifo_starve_off = num; | 308 | priv->fifo_starve_off = num; |
303 | 309 | ||
304 | temp = gfar_read(&priv->regs->fifo_tx_starve_shutoff); | 310 | temp = gfar_read(®s->fifo_tx_starve_shutoff); |
305 | temp &= ~FIFO_TX_STARVE_OFF_MASK; | 311 | temp &= ~FIFO_TX_STARVE_OFF_MASK; |
306 | temp |= num; | 312 | temp |= num; |
307 | gfar_write(&priv->regs->fifo_tx_starve_shutoff, temp); | 313 | gfar_write(®s->fifo_tx_starve_shutoff, temp); |
308 | 314 | ||
309 | spin_unlock_irqrestore(&tx_queue->txlock, flags); | 315 | spin_unlock_irqrestore(&tx_queue->txlock, flags); |
310 | 316 | ||