Message ID | 8b19125a825f9dcdd81c667c1e5c48ba28d505a6.1735490770.git.mail@maciej.szmigiero.name (mailing list archive) |
---|---|
State | Accepted |
Commit | a7af435df0e04cfb4a4004136d597c42639a2ae7 |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | [1/2] net: wwan: iosm: Properly check for valid exec stage in ipc_mmio_init() | expand |
Hello: This series was applied to netdev/net.git (main) by Jakub Kicinski <kuba@kernel.org>: On Sun, 29 Dec 2024 17:46:58 +0100 you wrote: > ipc_mmio_init() used the post-decrement operator in its loop continuing > condition of "retries" counter being "> 0", which meant that when this > condition caused loop exit "retries" counter reached -1. > > But the later valid exec stage failure check only tests for "retries" > counter being exactly zero, so it didn't trigger in this case (but > would wrongly trigger if the code reaches a valid exec stage in the > very last loop iteration). > > [...] Here is the summary with links: - [1/2] net: wwan: iosm: Properly check for valid exec stage in ipc_mmio_init() https://git.kernel.org/netdev/net/c/a7af435df0e0 - [2/2] net: wwan: iosm: Fix hibernation by re-binding the driver around it (no matching commit) You are awesome, thank you!
diff --git a/drivers/net/wwan/iosm/iosm_ipc_mmio.c b/drivers/net/wwan/iosm/iosm_ipc_mmio.c index 63eb08c43c05..6764c13530b9 100644 --- a/drivers/net/wwan/iosm/iosm_ipc_mmio.c +++ b/drivers/net/wwan/iosm/iosm_ipc_mmio.c @@ -104,7 +104,7 @@ struct iosm_mmio *ipc_mmio_init(void __iomem *mmio, struct device *dev) break; msleep(20); - } while (retries-- > 0); + } while (--retries > 0); if (!retries) { dev_err(ipc_mmio->dev, "invalid exec stage %X", stage);
ipc_mmio_init() used the post-decrement operator in its loop continuing condition of "retries" counter being "> 0", which meant that when this condition caused loop exit "retries" counter reached -1. But the later valid exec stage failure check only tests for "retries" counter being exactly zero, so it didn't trigger in this case (but would wrongly trigger if the code reaches a valid exec stage in the very last loop iteration). Fix this by using the pre-decrement operator instead, so the loop counter is exactly zero on valid exec stage failure. Fixes: dc0514f5d828 ("net: iosm: mmio scratchpad") Signed-off-by: Maciej S. Szmigiero <mail@maciej.szmigiero.name> --- drivers/net/wwan/iosm/iosm_ipc_mmio.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)