diff options
Diffstat (limited to 'drivers/net/ucc_geth.c')
-rw-r--r-- | drivers/net/ucc_geth.c | 23 |
1 files changed, 7 insertions, 16 deletions
diff --git a/drivers/net/ucc_geth.c b/drivers/net/ucc_geth.c index ca476a58087c..52a6750b8201 100644 --- a/drivers/net/ucc_geth.c +++ b/drivers/net/ucc_geth.c | |||
@@ -1591,13 +1591,13 @@ static int init_phy(struct net_device *dev) | |||
1591 | priv->oldspeed = 0; | 1591 | priv->oldspeed = 0; |
1592 | priv->oldduplex = -1; | 1592 | priv->oldduplex = -1; |
1593 | 1593 | ||
1594 | if (!ug_info->phy_node) | ||
1595 | return 0; | ||
1596 | |||
1597 | phydev = of_phy_connect(dev, ug_info->phy_node, &adjust_link, 0, | 1594 | phydev = of_phy_connect(dev, ug_info->phy_node, &adjust_link, 0, |
1598 | priv->phy_interface); | 1595 | priv->phy_interface); |
1596 | if (!phydev) | ||
1597 | phydev = of_phy_connect_fixed_link(dev, &adjust_link, | ||
1598 | priv->phy_interface); | ||
1599 | if (!phydev) { | 1599 | if (!phydev) { |
1600 | printk("%s: Could not attach to PHY\n", dev->name); | 1600 | dev_err(&dev->dev, "Could not attach to PHY\n"); |
1601 | return -ENODEV; | 1601 | return -ENODEV; |
1602 | } | 1602 | } |
1603 | 1603 | ||
@@ -3624,9 +3624,7 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma | |||
3624 | struct ucc_geth_private *ugeth = NULL; | 3624 | struct ucc_geth_private *ugeth = NULL; |
3625 | struct ucc_geth_info *ug_info; | 3625 | struct ucc_geth_info *ug_info; |
3626 | struct resource res; | 3626 | struct resource res; |
3627 | struct device_node *phy; | ||
3628 | int err, ucc_num, max_speed = 0; | 3627 | int err, ucc_num, max_speed = 0; |
3629 | const u32 *fixed_link; | ||
3630 | const unsigned int *prop; | 3628 | const unsigned int *prop; |
3631 | const char *sprop; | 3629 | const char *sprop; |
3632 | const void *mac_addr; | 3630 | const void *mac_addr; |
@@ -3724,15 +3722,8 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma | |||
3724 | 3722 | ||
3725 | ug_info->uf_info.regs = res.start; | 3723 | ug_info->uf_info.regs = res.start; |
3726 | ug_info->uf_info.irq = irq_of_parse_and_map(np, 0); | 3724 | ug_info->uf_info.irq = irq_of_parse_and_map(np, 0); |
3727 | fixed_link = of_get_property(np, "fixed-link", NULL); | 3725 | |
3728 | if (fixed_link) { | 3726 | ug_info->phy_node = of_parse_phandle(np, "phy-handle", 0); |
3729 | phy = NULL; | ||
3730 | } else { | ||
3731 | phy = of_parse_phandle(np, "phy-handle", 0); | ||
3732 | if (phy == NULL) | ||
3733 | return -ENODEV; | ||
3734 | } | ||
3735 | ug_info->phy_node = phy; | ||
3736 | 3727 | ||
3737 | /* Find the TBI PHY node. If it's not there, we don't support SGMII */ | 3728 | /* Find the TBI PHY node. If it's not there, we don't support SGMII */ |
3738 | ug_info->tbi_node = of_parse_phandle(np, "tbi-handle", 0); | 3729 | ug_info->tbi_node = of_parse_phandle(np, "tbi-handle", 0); |
@@ -3741,7 +3732,7 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma | |||
3741 | prop = of_get_property(np, "phy-connection-type", NULL); | 3732 | prop = of_get_property(np, "phy-connection-type", NULL); |
3742 | if (!prop) { | 3733 | if (!prop) { |
3743 | /* handle interface property present in old trees */ | 3734 | /* handle interface property present in old trees */ |
3744 | prop = of_get_property(phy, "interface", NULL); | 3735 | prop = of_get_property(ug_info->phy_node, "interface", NULL); |
3745 | if (prop != NULL) { | 3736 | if (prop != NULL) { |
3746 | phy_interface = enet_to_phy_interface[*prop]; | 3737 | phy_interface = enet_to_phy_interface[*prop]; |
3747 | max_speed = enet_to_speed[*prop]; | 3738 | max_speed = enet_to_speed[*prop]; |