summaryrefslogtreecommitdiffstats
path: root/net/dsa/dsa.c
diff options
context:
space:
mode:
authorAndrew Lunn <andrew@lunn.ch>2016-03-11 18:01:38 -0500
committerDavid S. Miller <davem@davemloft.net>2016-03-14 15:43:11 -0400
commit3a44514ff979d7b0192a9f67445509f4ea7dfe2f (patch)
treedbc89ddc9ca5785600340f1b952f859cbcb694e3 /net/dsa/dsa.c
parentb71be352f76ac3c0559feec2fd960ab9c31404c9 (diff)
dsa: Destroy fixed link phys after the phy has been disconnected
The phy is disconnected from the slave in dsa_slave_destroy(). Don't destroy fixed link phys until after this, since there can be fixed linked phys connected to ports. Signed-off-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/dsa/dsa.c')
-rw-r--r--net/dsa/dsa.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c
index d8fb47fcad05..1018e7dcfcc9 100644
--- a/net/dsa/dsa.c
+++ b/net/dsa/dsa.c
@@ -430,7 +430,18 @@ static void dsa_switch_destroy(struct dsa_switch *ds)
430 hwmon_device_unregister(ds->hwmon_dev); 430 hwmon_device_unregister(ds->hwmon_dev);
431#endif 431#endif
432 432
433 /* Disable configuration of the CPU and DSA ports */ 433 /* Destroy network devices for physical switch ports. */
434 for (port = 0; port < DSA_MAX_PORTS; port++) {
435 if (!(ds->phys_port_mask & (1 << port)))
436 continue;
437
438 if (!ds->ports[port])
439 continue;
440
441 dsa_slave_destroy(ds->ports[port]);
442 }
443
444 /* Remove any fixed link PHYs */
434 for (port = 0; port < DSA_MAX_PORTS; port++) { 445 for (port = 0; port < DSA_MAX_PORTS; port++) {
435 if (!(dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port))) 446 if (!(dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)))
436 continue; 447 continue;
@@ -448,17 +459,6 @@ static void dsa_switch_destroy(struct dsa_switch *ds)
448 } 459 }
449 } 460 }
450 461
451 /* Destroy network devices for physical switch ports. */
452 for (port = 0; port < DSA_MAX_PORTS; port++) {
453 if (!(ds->phys_port_mask & (1 << port)))
454 continue;
455
456 if (!ds->ports[port])
457 continue;
458
459 dsa_slave_destroy(ds->ports[port]);
460 }
461
462 mdiobus_unregister(ds->slave_mii_bus); 462 mdiobus_unregister(ds->slave_mii_bus);
463} 463}
464 464