diff options
author | Mathias Kresin <dev@kresin.me> | 2018-07-02 22:09:04 +0200 |
---|---|---|
committer | Mathias Kresin <dev@kresin.me> | 2018-07-04 01:19:05 +0200 |
commit | eccde89aa4764fd16b490e96e5dbbdb51cb0051b (patch) | |
tree | 4382655bae8555eb0537ca32c46fbaac19e96cab /target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch | |
parent | 89b59994eb44b5cd2fac594144c20c63fd05ef25 (diff) | |
download | upstream-eccde89aa4764fd16b490e96e5dbbdb51cb0051b.tar.gz upstream-eccde89aa4764fd16b490e96e5dbbdb51cb0051b.tar.bz2 upstream-eccde89aa4764fd16b490e96e5dbbdb51cb0051b.zip |
kernel: fix AT8032 PHY phy id mask
Don't mask bit 4 of the AT8022 phy id. If bit 4 of the AT8022 phy id
(0x004dd023) is masked, it will match the phy id of the AR8327 switch
(0x004dd033) as well.
It results in applied at803x driver settings/callbacks, which will at
least limit the AR8327 phys to 100MBit operation instead of the possible
1000MBit.
Signed-off-by: Mathias Kresin <dev@kresin.me>
Diffstat (limited to 'target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch')
-rw-r--r-- | target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch b/target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch index a217f750bc..27bbf572e9 100644 --- a/target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch +++ b/target/linux/generic/pending-4.14/734-net-phy-at803x-allow-to-configure-via-pdata.patch @@ -40,7 +40,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> #define AT803X_DEBUG_ADDR 0x1D #define AT803X_DEBUG_DATA 0x1E -@@ -73,6 +80,7 @@ MODULE_LICENSE("GPL"); +@@ -74,6 +81,7 @@ MODULE_LICENSE("GPL"); struct at803x_priv { bool phy_reset:1; struct gpio_desc *gpiod_reset; @@ -48,7 +48,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> }; struct at803x_context { -@@ -273,8 +281,16 @@ does_not_require_reset_workaround: +@@ -274,8 +282,16 @@ does_not_require_reset_workaround: return 0; } @@ -65,7 +65,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> int ret; ret = genphy_config_init(phydev); -@@ -295,6 +311,26 @@ static int at803x_config_init(struct phy +@@ -296,6 +312,26 @@ static int at803x_config_init(struct phy return ret; } @@ -92,7 +92,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> return 0; } -@@ -332,6 +368,8 @@ static int at803x_config_intr(struct phy +@@ -333,6 +369,8 @@ static int at803x_config_intr(struct phy static void at803x_link_change_notify(struct phy_device *phydev) { struct at803x_priv *priv = phydev->priv; @@ -101,7 +101,7 @@ Signed-off-by: Gabor Juhos <juhosg@openwrt.org> /* * Conduct a hardware reset for AT8030/2 every time a link loss is -@@ -360,6 +398,24 @@ static void at803x_link_change_notify(st +@@ -361,6 +399,24 @@ static void at803x_link_change_notify(st } else { priv->phy_reset = false; } |