wifi: ath9k: hif_usb: fix memory leak of remain_skbs
Description
In the Linux kernel, the following vulnerability has been resolved:
wifi: ath9k: hif_usb: fix memory leak of remain_skbs
hif_dev->remain_skb is allocated and used exclusively in ath9k_hif_usb_rx_stream(). It is implied that an allocated remain_skb is processed and subsequently freed (in error paths) only during the next call of ath9k_hif_usb_rx_stream().
So, if the urbs are deallocated between those two calls due to the device deinitialization or suspend, it is possible that ath9k_hif_usb_rx_stream() is not called next time and the allocated remain_skb is leaked. Our local Syzkaller instance was able to trigger that.
remain_skb makes sense when receiving two consecutive urbs which are logically linked together, i.e. a specific data field from the first skb indicates a cached skb to be allocated, memcpy'd with some data and subsequently processed in the next call to ath9k_hif_usb_rx_stream(). Urbs deallocation supposedly makes that link irrelevant so we need to free the cached skb in those cases.
Fix the leak by introducing a function to explicitly free remain_skb (if it is not NULL) when the rx urbs have been deallocated. remain_skb is NULL when it has not been allocated at all (hif_dev struct is kzalloced) or when it has been processed in next call to ath9k_hif_usb_rx_stream().
Found by Linux Verification Center (linuxtesting.org) with Syzkaller.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected products
94- osv-coords91 versionspkg:rpm/suse/kernel-64kb&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-64kb&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-64kb&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-64kb&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-64kb&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-64kb&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Micro%205.3pkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Micro%205.4pkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Micro%205.5pkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP4pkg:rpm/suse/kernel-default-base&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP5pkg:rpm/suse/kernel-default-base&distro=SUSE%20Manager%20Proxy%20LTS%204.3pkg:rpm/suse/kernel-default-base&distro=SUSE%20Manager%20Server%20LTS%204.3pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20High%20Availability%20Extension%2015%20SP4pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Live%20Patching%2012%20SP5pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Live%20Patching%2015%20SP4pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Live%20Patching%2015%20SP5pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Micro%205.3pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Micro%205.4pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Micro%205.5pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%2012%20SP5-LTSSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP4pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP5pkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%20LTSS%20Extended%20Security%2012%20SP5pkg:rpm/suse/kernel-default&distro=SUSE%20Manager%20Proxy%20LTS%204.3pkg:rpm/suse/kernel-default&distro=SUSE%20Manager%20Server%20LTS%204.3pkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP4pkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP5pkg:rpm/suse/kernel-livepatch-SLE15-SP4_Update_46&distro=SUSE%20Linux%20Enterprise%20Live%20Patching%2015%20SP4pkg:rpm/suse/kernel-livepatch-SLE15-SP5_Update_32&distro=SUSE%20Linux%20Enterprise%20Live%20Patching%2015%20SP5pkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP4pkg:rpm/suse/kernel-obs-build&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP5pkg:rpm/suse/kernel-rt&distro=SUSE%20Linux%20Enterprise%20Micro%205.3pkg:rpm/suse/kernel-rt&distro=SUSE%20Linux%20Enterprise%20Micro%205.4pkg:rpm/suse/kernel-rt&distro=SUSE%20Linux%20Enterprise%20Micro%205.5pkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Micro%205.5pkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%2012%20SP5-LTSSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP4pkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP5pkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%20LTSS%20Extended%20Security%2012%20SP5pkg:rpm/suse/kernel-source&distro=SUSE%20Manager%20Proxy%20LTS%204.3pkg:rpm/suse/kernel-source&distro=SUSE%20Manager%20Server%20LTS%204.3pkg:rpm/suse/kernel-source-rt&distro=SUSE%20Linux%20Enterprise%20Micro%205.3pkg:rpm/suse/kernel-source-rt&distro=SUSE%20Linux%20Enterprise%20Micro%205.4pkg:rpm/suse/kernel-source-rt&distro=SUSE%20Linux%20Enterprise%20Micro%205.5pkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-ESPOSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP4-LTSSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-ESPOSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20High%20Performance%20Computing%2015%20SP5-LTSSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%2012%20SP5-LTSSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP4pkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%20for%20SAP%20Applications%2015%20SP5pkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%20LTSS%20Extended%20Security%2012%20SP5pkg:rpm/suse/kernel-syms&distro=SUSE%20Manager%20Proxy%20LTS%204.3pkg:rpm/suse/kernel-syms&distro=SUSE%20Manager%20Server%20LTS%204.3pkg:rpm/suse/kernel-zfcpdump&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP4-LTSSpkg:rpm/suse/kernel-zfcpdump&distro=SUSE%20Linux%20Enterprise%20Server%2015%20SP5-LTSSpkg:rpm/suse/kernel-zfcpdump&distro=SUSE%20Manager%20Server%20LTS%204.3pkg:rpm/suse/kgraft-patch-SLE12-SP5_Update_75&distro=SUSE%20Linux%20Enterprise%20Live%20Patching%2012%20SP5
< 5.14.21-150400.24.184.1+ 90 more
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150500.55.127.1.150500.6.61.1
- (no CPE)range: < 5.14.21-150500.55.127.1.150500.6.61.1
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150500.55.127.1.150500.6.61.1
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150500.55.127.1.150500.6.61.1
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150500.55.127.1.150500.6.61.1
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150400.24.184.1.150400.24.94.2
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 1-150400.9.5.1
- (no CPE)range: < 1-150500.11.3.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.15.136.1
- (no CPE)range: < 5.14.21-150400.15.136.1
- (no CPE)range: < 5.14.21-150500.13.112.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.15.136.1
- (no CPE)range: < 5.14.21-150400.15.136.1
- (no CPE)range: < 5.14.21-150500.13.112.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 4.12.14-122.283.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 5.14.21-150500.55.127.1
- (no CPE)range: < 5.14.21-150400.24.184.1
- (no CPE)range: < 1-8.3.1
Patches
Vulnerability mechanics
References
8- git.kernel.org/stable/c/320d760a35273aa815d58b57e4fd9ba5279a3489mitre
- git.kernel.org/stable/c/59073060fe0950c6ecbe12bdc06469dcac62128dmitre
- git.kernel.org/stable/c/6719e3797ec52cd144c8a5ba8aaab36674800585mitre
- git.kernel.org/stable/c/7654cc03eb699297130b693ec34e25f77b17c947mitre
- git.kernel.org/stable/c/8f02d538878c9b1501f624595eb22ee4e5e0ff84mitre
- git.kernel.org/stable/c/9b9356a3014123f0ce4b50d9278c1265173150abmitre
- git.kernel.org/stable/c/d9899318660791141ea6002fda5577b2c5d7386emitre
- git.kernel.org/stable/c/f0931fc8f4b6847c72e170d2326861c0a081d680mitre
News mentions
0No linked articles in our index yet.