diff options
author | Vivien Didelot <vivien.didelot@savoirfairelinux.com> | 2017-08-01 22:32:33 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-08-02 05:09:09 +0200 |
commit | dca20989313aba3288e3a1d3a88007ccafb37e25 (patch) | |
tree | 2ec531a7162a687f43060ef322c5d6a2103689d4 | |
parent | net: dsa: qca8k: fix EEE init (diff) | |
download | linux-dca20989313aba3288e3a1d3a88007ccafb37e25.tar.xz linux-dca20989313aba3288e3a1d3a88007ccafb37e25.zip |
net: dsa: qca8k: enable EEE once
If EEE is queried enabled, qca8k_set_eee calls qca8k_eee_enable_set
twice (because it is already called in qca8k_eee_init). Fix that.
Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/dsa/qca8k.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/net/dsa/qca8k.c b/drivers/net/dsa/qca8k.c index e076ab23d4df..9d6b5d2f7a4a 100644 --- a/drivers/net/dsa/qca8k.c +++ b/drivers/net/dsa/qca8k.c @@ -684,12 +684,13 @@ qca8k_set_eee(struct dsa_switch *ds, int port, p->eee_enabled = e->eee_enabled; - if (e->eee_enabled) { + if (!p->eee_enabled) { + qca8k_eee_enable_set(ds, port, false); + } else { p->eee_enabled = qca8k_eee_init(ds, port, phydev); if (!p->eee_enabled) ret = -EOPNOTSUPP; } - qca8k_eee_enable_set(ds, port, p->eee_enabled); return ret; } |