Commit 713f03fa authored by Nikita Danilov's avatar Nikita Danilov Committed by Greg Kroah-Hartman

net: aquantia: fix wol configuration not applied sometimes

[ Upstream commit 930b9a05 ]

WoL magic packet configuration sometimes does not work due to
couple of leakages found.

Mainly there was a regression introduced during readx_poll refactoring.

Next, fw request waiting time was too small. Sometimes that
caused sleep proxy config function to return with an error
and to skip WoL configuration.
At last, WoL data were passed to FW from not clean buffer.
That could cause FW to accept garbage as a random configuration data.

Fixes: 6a7f2277 ("net: aquantia: replace AQ_HW_WAIT_FOR with readx_poll_timeout_atomic")
Signed-off-by: default avatarNikita Danilov <nikita.danilov@aquantia.com>
Signed-off-by: default avatarIgor Russkikh <igor.russkikh@aquantia.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent cba55c16
...@@ -335,13 +335,13 @@ static int hw_atl_utils_fw_upload_dwords(struct aq_hw_s *self, u32 a, u32 *p, ...@@ -335,13 +335,13 @@ static int hw_atl_utils_fw_upload_dwords(struct aq_hw_s *self, u32 a, u32 *p,
{ {
u32 val; u32 val;
int err = 0; int err = 0;
bool is_locked;
is_locked = hw_atl_sem_ram_get(self); err = readx_poll_timeout_atomic(hw_atl_sem_ram_get, self,
if (!is_locked) { val, val == 1U,
err = -ETIME; 10U, 100000U);
if (err < 0)
goto err_exit; goto err_exit;
}
if (IS_CHIP_FEATURE(REVISION_B1)) { if (IS_CHIP_FEATURE(REVISION_B1)) {
u32 offset = 0; u32 offset = 0;
...@@ -353,8 +353,8 @@ static int hw_atl_utils_fw_upload_dwords(struct aq_hw_s *self, u32 a, u32 *p, ...@@ -353,8 +353,8 @@ static int hw_atl_utils_fw_upload_dwords(struct aq_hw_s *self, u32 a, u32 *p,
/* 1000 times by 10us = 10ms */ /* 1000 times by 10us = 10ms */
err = readx_poll_timeout_atomic(hw_atl_scrpad12_get, err = readx_poll_timeout_atomic(hw_atl_scrpad12_get,
self, val, self, val,
(val & 0xF0000000) == (val & 0xF0000000) !=
0x80000000, 0x80000000,
10U, 10000U); 10U, 10000U);
} }
} else { } else {
......
...@@ -349,7 +349,7 @@ static int aq_fw2x_set_sleep_proxy(struct aq_hw_s *self, u8 *mac) ...@@ -349,7 +349,7 @@ static int aq_fw2x_set_sleep_proxy(struct aq_hw_s *self, u8 *mac)
err = readx_poll_timeout_atomic(aq_fw2x_state2_get, err = readx_poll_timeout_atomic(aq_fw2x_state2_get,
self, val, self, val,
val & HW_ATL_FW2X_CTRL_SLEEP_PROXY, val & HW_ATL_FW2X_CTRL_SLEEP_PROXY,
1U, 10000U); 1U, 100000U);
err_exit: err_exit:
return err; return err;
...@@ -369,6 +369,8 @@ static int aq_fw2x_set_wol_params(struct aq_hw_s *self, u8 *mac) ...@@ -369,6 +369,8 @@ static int aq_fw2x_set_wol_params(struct aq_hw_s *self, u8 *mac)
msg = (struct fw2x_msg_wol *)rpc; msg = (struct fw2x_msg_wol *)rpc;
memset(msg, 0, sizeof(*msg));
msg->msg_id = HAL_ATLANTIC_UTILS_FW2X_MSG_WOL; msg->msg_id = HAL_ATLANTIC_UTILS_FW2X_MSG_WOL;
msg->magic_packet_enabled = true; msg->magic_packet_enabled = true;
memcpy(msg->hw_addr, mac, ETH_ALEN); memcpy(msg->hw_addr, mac, ETH_ALEN);
......
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