diff options
Diffstat (limited to 'drivers/net/phy/phy.c')
-rw-r--r-- | drivers/net/phy/phy.c | 27 |
1 files changed, 20 insertions, 7 deletions
diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c index 1b6d09aef427..3bc079a67a3d 100644 --- a/drivers/net/phy/phy.c +++ b/drivers/net/phy/phy.c | |||
@@ -715,7 +715,7 @@ void phy_state_machine(struct work_struct *work) | |||
715 | struct delayed_work *dwork = to_delayed_work(work); | 715 | struct delayed_work *dwork = to_delayed_work(work); |
716 | struct phy_device *phydev = | 716 | struct phy_device *phydev = |
717 | container_of(dwork, struct phy_device, state_queue); | 717 | container_of(dwork, struct phy_device, state_queue); |
718 | int needs_aneg = 0, do_suspend = 0; | 718 | bool needs_aneg = false, do_suspend = false, do_resume = false; |
719 | int err = 0; | 719 | int err = 0; |
720 | 720 | ||
721 | mutex_lock(&phydev->lock); | 721 | mutex_lock(&phydev->lock); |
@@ -727,7 +727,7 @@ void phy_state_machine(struct work_struct *work) | |||
727 | case PHY_PENDING: | 727 | case PHY_PENDING: |
728 | break; | 728 | break; |
729 | case PHY_UP: | 729 | case PHY_UP: |
730 | needs_aneg = 1; | 730 | needs_aneg = true; |
731 | 731 | ||
732 | phydev->link_timeout = PHY_AN_TIMEOUT; | 732 | phydev->link_timeout = PHY_AN_TIMEOUT; |
733 | 733 | ||
@@ -757,7 +757,7 @@ void phy_state_machine(struct work_struct *work) | |||
757 | phydev->adjust_link(phydev->attached_dev); | 757 | phydev->adjust_link(phydev->attached_dev); |
758 | 758 | ||
759 | } else if (0 == phydev->link_timeout--) | 759 | } else if (0 == phydev->link_timeout--) |
760 | needs_aneg = 1; | 760 | needs_aneg = true; |
761 | break; | 761 | break; |
762 | case PHY_NOLINK: | 762 | case PHY_NOLINK: |
763 | err = phy_read_status(phydev); | 763 | err = phy_read_status(phydev); |
@@ -765,6 +765,17 @@ void phy_state_machine(struct work_struct *work) | |||
765 | break; | 765 | break; |
766 | 766 | ||
767 | if (phydev->link) { | 767 | if (phydev->link) { |
768 | if (AUTONEG_ENABLE == phydev->autoneg) { | ||
769 | err = phy_aneg_done(phydev); | ||
770 | if (err < 0) | ||
771 | break; | ||
772 | |||
773 | if (!err) { | ||
774 | phydev->state = PHY_AN; | ||
775 | phydev->link_timeout = PHY_AN_TIMEOUT; | ||
776 | break; | ||
777 | } | ||
778 | } | ||
768 | phydev->state = PHY_RUNNING; | 779 | phydev->state = PHY_RUNNING; |
769 | netif_carrier_on(phydev->attached_dev); | 780 | netif_carrier_on(phydev->attached_dev); |
770 | phydev->adjust_link(phydev->attached_dev); | 781 | phydev->adjust_link(phydev->attached_dev); |
@@ -780,7 +791,7 @@ void phy_state_machine(struct work_struct *work) | |||
780 | netif_carrier_on(phydev->attached_dev); | 791 | netif_carrier_on(phydev->attached_dev); |
781 | } else { | 792 | } else { |
782 | if (0 == phydev->link_timeout--) | 793 | if (0 == phydev->link_timeout--) |
783 | needs_aneg = 1; | 794 | needs_aneg = true; |
784 | } | 795 | } |
785 | 796 | ||
786 | phydev->adjust_link(phydev->attached_dev); | 797 | phydev->adjust_link(phydev->attached_dev); |
@@ -816,7 +827,7 @@ void phy_state_machine(struct work_struct *work) | |||
816 | phydev->link = 0; | 827 | phydev->link = 0; |
817 | netif_carrier_off(phydev->attached_dev); | 828 | netif_carrier_off(phydev->attached_dev); |
818 | phydev->adjust_link(phydev->attached_dev); | 829 | phydev->adjust_link(phydev->attached_dev); |
819 | do_suspend = 1; | 830 | do_suspend = true; |
820 | } | 831 | } |
821 | break; | 832 | break; |
822 | case PHY_RESUMING: | 833 | case PHY_RESUMING: |
@@ -865,6 +876,7 @@ void phy_state_machine(struct work_struct *work) | |||
865 | } | 876 | } |
866 | phydev->adjust_link(phydev->attached_dev); | 877 | phydev->adjust_link(phydev->attached_dev); |
867 | } | 878 | } |
879 | do_resume = true; | ||
868 | break; | 880 | break; |
869 | } | 881 | } |
870 | 882 | ||
@@ -872,9 +884,10 @@ void phy_state_machine(struct work_struct *work) | |||
872 | 884 | ||
873 | if (needs_aneg) | 885 | if (needs_aneg) |
874 | err = phy_start_aneg(phydev); | 886 | err = phy_start_aneg(phydev); |
875 | 887 | else if (do_suspend) | |
876 | if (do_suspend) | ||
877 | phy_suspend(phydev); | 888 | phy_suspend(phydev); |
889 | else if (do_resume) | ||
890 | phy_resume(phydev); | ||
878 | 891 | ||
879 | if (err < 0) | 892 | if (err < 0) |
880 | phy_error(phydev); | 893 | phy_error(phydev); |