]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
wifi: mac80211: limit injected antenna index in ieee80211_parse_tx_radiotap
authorDeepanshu Kartikey <kartikey406@gmail.com>
Sun, 31 May 2026 01:17:21 +0000 (06:47 +0530)
committerJohannes Berg <johannes.berg@intel.com>
Tue, 2 Jun 2026 11:26:33 +0000 (13:26 +0200)
When parsing the radiotap header of an injected frame,
ieee80211_parse_tx_radiotap() uses the IEEE80211_RADIOTAP_ANTENNA value
directly as a shift count:

info->control.antennas |= BIT(*iterator.this_arg);

*iterator.this_arg is an 8-bit value taken straight from the frame
supplied by userspace, so BIT() can be asked to shift by up to 255. That
is undefined behaviour on the unsigned long and is reported by UBSAN:

  UBSAN: shift-out-of-bounds in net/mac80211/tx.c:2174:30
  shift exponent 235 is too large for 64-bit type 'unsigned long'
  Call Trace:
   ieee80211_parse_tx_radiotap+0xadb/0x1950 net/mac80211/tx.c:2174
   ieee80211_monitor_start_xmit+0xb1f/0x1250 net/mac80211/tx.c:2451
   ...
   packet_sendmsg+0x3eb6/0x50f0 net/packet/af_packet.c:3109

info->control.antennas is a 2-bit bitmap (u8 antennas:2), so only antenna
indices 0 and 1 can ever be represented. Ignore any larger value instead
of shifting out of bounds.

Reported-by: syzbot+8e0622f6d9446420271f@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=8e0622f6d9446420271f
Fixes: ef246a1480cc ("wifi: mac80211: support antenna control in injection")
Signed-off-by: Deepanshu Kartikey <kartikey406@gmail.com>
Link: https://patch.msgid.link/20260531011721.102941-1-kartikey406@gmail.com
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
net/mac80211/tx.c

index b487d2330f25f119f730b714900815c19c77bf1d..ea7f63e1fc17e10644ead3f5517bec72c316989f 100644 (file)
@@ -2181,7 +2181,9 @@ bool ieee80211_parse_tx_radiotap(struct sk_buff *skb,
 
                case IEEE80211_RADIOTAP_ANTENNA:
                        /* this can appear multiple times, keep a bitmap */
-                       info->control.antennas |= BIT(*iterator.this_arg);
+                       /* control.antennas is only a 2-bit bitmap */
+                       if (*iterator.this_arg < 2)
+                               info->control.antennas |= BIT(*iterator.this_arg);
                        break;
 
                case IEEE80211_RADIOTAP_DATA_RETRIES: