Commit 48bf8b8a authored by Robert Hancock's avatar Robert Hancock Committed by David S. Miller

net: dsa: microchip: Add property to disable reference clock

Add a new microchip,synclko-disable property which can be specified
to disable the reference clock output from the device if not required
by the board design.
Signed-off-by: default avatarRobert Hancock <robert.hancock@calian.com>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent eccfecfe
...@@ -222,9 +222,12 @@ static int ksz9477_reset_switch(struct ksz_device *dev) ...@@ -222,9 +222,12 @@ static int ksz9477_reset_switch(struct ksz_device *dev)
(BROADCAST_STORM_VALUE * (BROADCAST_STORM_VALUE *
BROADCAST_STORM_PROT_RATE) / 100); BROADCAST_STORM_PROT_RATE) / 100);
if (dev->synclko_125) data8 = SW_ENABLE_REFCLKO;
ksz_write8(dev, REG_SW_GLOBAL_OUTPUT_CTRL__1, if (dev->synclko_disable)
SW_ENABLE_REFCLKO | SW_REFCLKO_IS_125MHZ); data8 = 0;
else if (dev->synclko_125)
data8 = SW_ENABLE_REFCLKO | SW_REFCLKO_IS_125MHZ;
ksz_write8(dev, REG_SW_GLOBAL_OUTPUT_CTRL__1, data8);
return 0; return 0;
} }
......
...@@ -434,6 +434,12 @@ int ksz_switch_register(struct ksz_device *dev, ...@@ -434,6 +434,12 @@ int ksz_switch_register(struct ksz_device *dev,
} }
dev->synclko_125 = of_property_read_bool(dev->dev->of_node, dev->synclko_125 = of_property_read_bool(dev->dev->of_node,
"microchip,synclko-125"); "microchip,synclko-125");
dev->synclko_disable = of_property_read_bool(dev->dev->of_node,
"microchip,synclko-disable");
if (dev->synclko_125 && dev->synclko_disable) {
dev_err(dev->dev, "inconsistent synclko settings\n");
return -EINVAL;
}
} }
ret = dsa_register_switch(dev->ds); ret = dsa_register_switch(dev->ds);
......
...@@ -75,6 +75,7 @@ struct ksz_device { ...@@ -75,6 +75,7 @@ struct ksz_device {
u32 regs_size; u32 regs_size;
bool phy_errata_9477; bool phy_errata_9477;
bool synclko_125; bool synclko_125;
bool synclko_disable;
struct vlan_table *vlan_cache; struct vlan_table *vlan_cache;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment