diff options
Diffstat (limited to 'net/dsa/slave.c')
| -rw-r--r-- | net/dsa/slave.c | 22 |
1 files changed, 7 insertions, 15 deletions
diff --git a/net/dsa/slave.c b/net/dsa/slave.c index 589aafd01fc5..f23deadf42a0 100644 --- a/net/dsa/slave.c +++ b/net/dsa/slave.c | |||
| @@ -521,10 +521,13 @@ static int dsa_slave_phy_setup(struct dsa_slave_priv *p, | |||
| 521 | struct device_node *phy_dn, *port_dn; | 521 | struct device_node *phy_dn, *port_dn; |
| 522 | bool phy_is_fixed = false; | 522 | bool phy_is_fixed = false; |
| 523 | u32 phy_flags = 0; | 523 | u32 phy_flags = 0; |
| 524 | int ret; | 524 | int mode, ret; |
| 525 | 525 | ||
| 526 | port_dn = cd->port_dn[p->port]; | 526 | port_dn = cd->port_dn[p->port]; |
| 527 | p->phy_interface = of_get_phy_mode(port_dn); | 527 | mode = of_get_phy_mode(port_dn); |
| 528 | if (mode < 0) | ||
| 529 | mode = PHY_INTERFACE_MODE_NA; | ||
| 530 | p->phy_interface = mode; | ||
| 528 | 531 | ||
| 529 | phy_dn = of_parse_phandle(port_dn, "phy-handle", 0); | 532 | phy_dn = of_parse_phandle(port_dn, "phy-handle", 0); |
| 530 | if (of_phy_is_fixed_link(port_dn)) { | 533 | if (of_phy_is_fixed_link(port_dn)) { |
| @@ -559,6 +562,8 @@ static int dsa_slave_phy_setup(struct dsa_slave_priv *p, | |||
| 559 | if (!p->phy) | 562 | if (!p->phy) |
| 560 | return -ENODEV; | 563 | return -ENODEV; |
| 561 | 564 | ||
| 565 | /* Use already configured phy mode */ | ||
| 566 | p->phy_interface = p->phy->interface; | ||
| 562 | phy_connect_direct(slave_dev, p->phy, dsa_slave_adjust_link, | 567 | phy_connect_direct(slave_dev, p->phy, dsa_slave_adjust_link, |
| 563 | p->phy_interface); | 568 | p->phy_interface); |
| 564 | } else { | 569 | } else { |
| @@ -676,18 +681,5 @@ dsa_slave_create(struct dsa_switch *ds, struct device *parent, | |||
| 676 | 681 | ||
| 677 | netif_carrier_off(slave_dev); | 682 | netif_carrier_off(slave_dev); |
| 678 | 683 | ||
| 679 | if (p->phy != NULL) { | ||
| 680 | if (ds->drv->get_phy_flags) | ||
| 681 | p->phy->dev_flags |= ds->drv->get_phy_flags(ds, port); | ||
| 682 | |||
| 683 | phy_attach(slave_dev, dev_name(&p->phy->dev), | ||
| 684 | PHY_INTERFACE_MODE_GMII); | ||
| 685 | |||
| 686 | p->phy->autoneg = AUTONEG_ENABLE; | ||
| 687 | p->phy->speed = 0; | ||
| 688 | p->phy->duplex = 0; | ||
| 689 | p->phy->advertising = p->phy->supported | ADVERTISED_Autoneg; | ||
| 690 | } | ||
| 691 | |||
| 692 | return slave_dev; | 684 | return slave_dev; |
| 693 | } | 685 | } |
