]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
wifi: rtw89: phy: fix uninitialized variable access in rtw89_phy_cfo_set_crystal_cap()
authorAlexey Velichayshiy <a.velichayshiy@ispras.ru>
Mon, 23 Mar 2026 14:05:53 +0000 (17:05 +0300)
committerPing-Ke Shih <pkshih@realtek.com>
Mon, 30 Mar 2026 01:48:10 +0000 (09:48 +0800)
In the rtw89_phy_cfo_set_crystal_cap() function, for chips other than
RTL8852A/RTL8851B, the values read by rtw89_mac_read_xtal_si() are
stored into the local variables sc_xi_val and sc_xo_val. If either
read fails, these variables remain uninitialized, they are later
used to update cfo->crystal_cap and in debug print statements. This
can lead to undefined behavior.

Fix the issue by initializing sc_xi_val and sc_xo_val to zero,
like is implemented in vendor driver.

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

Fixes: 8379fa611536 ("rtw89: 8852c: add write/read crystal function in CFO tracking")
Signed-off-by: Alexey Velichayshiy <a.velichayshiy@ispras.ru>
Acked-by: Ping-Ke Shih <pkshih@realtek.com>
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Link: https://patch.msgid.link/20260323140613.1615574-1-a.velichayshiy@ispras.ru
drivers/net/wireless/realtek/rtw89/phy.c

index 3a241738ac069c52720992362e3145452d159e3a..d205561f1f5ca20027822d41a31eaa8b7d6a1c6d 100644 (file)
@@ -4898,7 +4898,7 @@ static void rtw89_phy_cfo_set_crystal_cap(struct rtw89_dev *rtwdev,
 {
        struct rtw89_cfo_tracking_info *cfo = &rtwdev->cfo_tracking;
        const struct rtw89_chip_info *chip = rtwdev->chip;
-       u8 sc_xi_val, sc_xo_val;
+       u8 sc_xi_val = 0, sc_xo_val = 0;
 
        if (!force && cfo->crystal_cap == crystal_cap)
                return;