wifi: rtl8xxxu: retry firmware download on error
[ Upstream commit 3d3e28feca7ac8c6cf2a390dbbe1f97e3feb7f36 ] Occasionally there is an EPROTO error during firmware download. This error is converted to EAGAIN in the download function. But nobody tries again and so device probe fails. Implement download retry to fix this. This error was observed (and fix tested) on a tbs2910 board [1] with an embedded RTL8188EU (0bda:8179) device behind a USB hub. [1] arch/arm/boot/dts/nxp/imx/imx6q-tbs2910.dts Signed-off-by: Soeren Moch <smoch@web.de> Acked-by: Ping-Ke Shih <pkshih@realtek.com> Signed-off-by: Ping-Ke Shih <pkshih@realtek.com> Link: https://patch.msgid.link/20250127194828.599379-1-smoch@web.de Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
419988f4d0
commit
ee71c34d4f
@@ -900,9 +900,10 @@ rtl8xxxu_writeN(struct rtl8xxxu_priv *priv, u16 addr, u8 *buf, u16 len)
|
||||
return len;
|
||||
|
||||
write_error:
|
||||
dev_info(&udev->dev,
|
||||
"%s: Failed to write block at addr: %04x size: %04x\n",
|
||||
__func__, addr, blocksize);
|
||||
if (rtl8xxxu_debug & RTL8XXXU_DEBUG_REG_WRITE)
|
||||
dev_info(&udev->dev,
|
||||
"%s: Failed to write block at addr: %04x size: %04x\n",
|
||||
__func__, addr, blocksize);
|
||||
return -EAGAIN;
|
||||
}
|
||||
|
||||
@@ -4073,8 +4074,14 @@ static int rtl8xxxu_init_device(struct ieee80211_hw *hw)
|
||||
*/
|
||||
rtl8xxxu_write16(priv, REG_TRXFF_BNDY + 2, fops->trxff_boundary);
|
||||
|
||||
ret = rtl8xxxu_download_firmware(priv);
|
||||
dev_dbg(dev, "%s: download_firmware %i\n", __func__, ret);
|
||||
for (int retry = 5; retry >= 0 ; retry--) {
|
||||
ret = rtl8xxxu_download_firmware(priv);
|
||||
dev_dbg(dev, "%s: download_firmware %i\n", __func__, ret);
|
||||
if (ret != -EAGAIN)
|
||||
break;
|
||||
if (retry)
|
||||
dev_dbg(dev, "%s: retry firmware download\n", __func__);
|
||||
}
|
||||
if (ret)
|
||||
goto exit;
|
||||
ret = rtl8xxxu_start_firmware(priv);
|
||||
|
Reference in New Issue
Block a user