]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
wifi: mt76: connac: fix possible unaligned access in mt76_connac_mcu_add_nested_tlv
authorLorenzo Bianconi <lorenzo@kernel.org>
Mon, 25 Jul 2022 14:12:06 +0000 (16:12 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 24 Oct 2022 07:57:10 +0000 (09:57 +0200)
[ Upstream commit 0a4860f627f1f2b2b777f54f993de1638a79da9f ]

Fix possible unaligned pointer in mt76_connac_mcu_add_nested_tlv
routine.

Reported-by: kernel test robot <lkp@intel.com>
Fixes: 25702d9c55dc5 ("mt76: connac: rely on le16_add_cpu in mt76_connac_mcu_add_nested_tlv")
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.c

index 7eb23805aa9421eb8b9d781149817f8c3351fbe4..d10b441eac4f8a5c9076025fd9ef924546f28b5d 100644 (file)
@@ -258,8 +258,10 @@ mt76_connac_mcu_add_nested_tlv(struct sk_buff *skb, int tag, int len,
        ntlv = le16_to_cpu(ntlv_hdr->tlv_num);
        ntlv_hdr->tlv_num = cpu_to_le16(ntlv + 1);
 
-       if (sta_hdr)
-               le16_add_cpu(&sta_hdr->len, len);
+       if (sta_hdr) {
+               len += le16_to_cpu(sta_hdr->len);
+               sta_hdr->len = cpu_to_le16(len);
+       }
 
        return ptlv;
 }