]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
wifi: rtw89: avoid reading out of bounds when loading TX power FW elements
authorZong-Zhe Yang <kevin_yang@realtek.com>
Mon, 2 Sep 2024 01:58:03 +0000 (09:58 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 10 Oct 2024 10:00:21 +0000 (12:00 +0200)
[ Upstream commit ed2e4bb17a4884cf29c3347353d8aabb7265b46c ]

Because the loop-expression will do one more time before getting false from
cond-expression, the original code copied one more entry size beyond valid
region.

Fix it by moving the entry copy to loop-body.

Signed-off-by: Zong-Zhe Yang <kevin_yang@realtek.com>
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Link: https://patch.msgid.link/20240902015803.20420-1-pkshih@realtek.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/wireless/realtek/rtw89/core.h

index 112bdd95fc6ead4a3c0981ebe9d10a9998390764..504660ee3cba32f3ab1ed258ba4533489440e96d 100644 (file)
@@ -3888,16 +3888,22 @@ struct rtw89_txpwr_conf {
        const void *data;
 };
 
+static inline bool rtw89_txpwr_entcpy(void *entry, const void *cursor, u8 size,
+                                     const struct rtw89_txpwr_conf *conf)
+{
+       u8 valid_size = min(size, conf->ent_sz);
+
+       memcpy(entry, cursor, valid_size);
+       return true;
+}
+
 #define rtw89_txpwr_conf_valid(conf) (!!(conf)->data)
 
 #define rtw89_for_each_in_txpwr_conf(entry, cursor, conf) \
-       for (typecheck(const void *, cursor), (cursor) = (conf)->data, \
-            memcpy(&(entry), cursor, \
-                   min_t(u8, sizeof(entry), (conf)->ent_sz)); \
+       for (typecheck(const void *, cursor), (cursor) = (conf)->data; \
             (cursor) < (conf)->data + (conf)->num_ents * (conf)->ent_sz; \
-            (cursor) += (conf)->ent_sz, \
-            memcpy(&(entry), cursor, \
-                   min_t(u8, sizeof(entry), (conf)->ent_sz)))
+            (cursor) += (conf)->ent_sz) \
+               if (rtw89_txpwr_entcpy(&(entry), cursor, sizeof(entry), conf))
 
 struct rtw89_txpwr_byrate_data {
        struct rtw89_txpwr_conf conf;