wifi: p54: add missing parentheses in p54_flush()
authorRustam Subkhankulov <subkhankulov@ispras.ru>
Thu, 14 Jul 2022 13:48:31 +0000 (16:48 +0300)
committerKalle Valo <kvalo@kernel.org>
Mon, 18 Jul 2022 11:54:50 +0000 (14:54 +0300)
The assignment of the value to the variable total in the loop
condition must be enclosed in additional parentheses, since otherwise,
in accordance with the precedence of the operators, the conjunction
will be performed first, and only then the assignment.

Due to this error, a warning later in the function after the loop may
not occur in the situation when it should.

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Signed-off-by: Rustam Subkhankulov <subkhankulov@ispras.ru>
Fixes: 0d4171e2153b ("p54: implement flush callback")
Acked-by: Christian Lamparter <chunkeey@gmail.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20220714134831.106004-1-subkhankulov@ispras.ru
drivers/net/wireless/intersil/p54/main.c

index 26b28d4..b925e32 100644 (file)
@@ -683,7 +683,7 @@ static void p54_flush(struct ieee80211_hw *dev, struct ieee80211_vif *vif,
         * queues have already been stopped and no new frames can sneak
         * up from behind.
         */
-       while ((total = p54_flush_count(priv) && i--)) {
+       while ((total = p54_flush_count(priv)) && i--) {
                /* waste time */
                msleep(20);
        }