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); |
