In the Linux kernel, the following vulnerability has been resolved:
ath11k: fix netdev open race
Make sure to allocate resources needed before registering the device.
This specifically avoids having a racing open() trigger a BUGON() in modtimer() when ath11kmacopstart() is called before the monreap_timer as been set up.
I did not see this issue with next-20220310, but I hit it on every probe with next-20220511. Perhaps some timing changed in between.
Here's the backtrace:
[ 51.346947] kernel BUG at kernel/time/timer.c:990! [ 51.346958] Internal error: Oops - BUG: 0 [#1] PREEMPT SMP ... [ 51.578225] Call trace: [ 51.583293] modtimer+0x298/0x390 [ 51.589518] modtimer+0x14/0x20 [ 51.595368] ath11kmacopstart+0x41c/0x4a0 [ath11k] [ 51.603165] drvstart+0x38/0x60 [mac80211] [ 51.610110] ieee80211doopen+0x29c/0x7d0 [mac80211] [ 51.617945] ieee80211open+0x60/0xb0 [mac80211] [ 51.625311] _devopen+0x100/0x1c0 [ 51.631420] _devchangeflags+0x194/0x210 [ 51.638214] devchangeflags+0x24/0x70 [ 51.644646] dosetlink+0x228/0xdb0 [ 51.650723] _rtnlnewlink+0x460/0x830 [ 51.657162] rtnlnewlink+0x4c/0x80 [ 51.663229] rtnetlinkrcvmsg+0x124/0x390 [ 51.669917] netlinkrcvskb+0x58/0x130 [ 51.676314] rtnetlinkrcv+0x18/0x30 [ 51.682460] netlinkunicast+0x250/0x310 [ 51.688960] netlinksendmsg+0x19c/0x3e0 [ 51.695458] _syssendmsg+0x220/0x290 [ 51.701938] _syssendmsg+0x7c/0xc0 [ 51.708148] _syssendmsg+0x68/0xd0 [ 51.714254] _arm64syssendmsg+0x28/0x40 [ 51.720900] invokesyscall+0x48/0x120
Tested-on: WCN6855 hw2.0 PCI WLAN.HSP.1.1-03125-QCAHSPSWPLV1V2SILICONZLITE-3
[
{
"id": "CVE-2022-50187-0294a032",
"digest": {
"function_hash": "244037462633982403929080447148020760945",
"length": 912.0
},
"deprecated": false,
"signature_type": "Function",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@a2c45f8c3d18269e641f0c7da2dde47ef8414034",
"target": {
"function": "ath11k_core_pdev_create",
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-09a7e6d2",
"digest": {
"function_hash": "244037462633982403929080447148020760945",
"length": 912.0
},
"deprecated": false,
"signature_type": "Function",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@d4ba1ff87b17e81686ada8f429300876f55f95ad",
"target": {
"function": "ath11k_core_pdev_create",
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-288149cd",
"digest": {
"function_hash": "244037462633982403929080447148020760945",
"length": 912.0
},
"deprecated": false,
"signature_type": "Function",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@307ce58270b3b50ca21cfcc910568429b06803f7",
"target": {
"function": "ath11k_core_pdev_create",
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-3638aaeb",
"digest": {
"threshold": 0.9,
"line_hashes": [
"331306286097583584806392314705363288572",
"304548681969562695023430010138802706634",
"236718910629179434752586036331112763684",
"56235307693614207894127293676190224514",
"160655460753916770829010402031684624856",
"155982685135572266246306216960003355438",
"173677822716794706141018786661714997040",
"323165604881315219261741908843150977129",
"34880953312206250552096796089035868436",
"36453974049952031327642570308467969611",
"3074293673899994582731795695271353148",
"201162176252166407141390343430874656793",
"307262739838282490037922745849514583388",
"216137643630279222385306830183119296484",
"245592444369585938057216328471371811601",
"223687258897856961322586234407062920116",
"186017797785707609153831395157800110768",
"203719078958941147833179289336036357733",
"19434389481220684353651723621883401201",
"263549781851891803972483555797916838582",
"132658415448656300735099714967472117786",
"150738929190709237733894706024320770894",
"62962848808907417350993459724453558998",
"182164790515762066180559218653234720374",
"124286415210558097999514047889575899680"
]
},
"deprecated": false,
"signature_type": "Line",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@307ce58270b3b50ca21cfcc910568429b06803f7",
"target": {
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-98ace7d0",
"digest": {
"threshold": 0.9,
"line_hashes": [
"331306286097583584806392314705363288572",
"304548681969562695023430010138802706634",
"236718910629179434752586036331112763684",
"56235307693614207894127293676190224514",
"160655460753916770829010402031684624856",
"155982685135572266246306216960003355438",
"173677822716794706141018786661714997040",
"323165604881315219261741908843150977129",
"34880953312206250552096796089035868436",
"36453974049952031327642570308467969611",
"3074293673899994582731795695271353148",
"201162176252166407141390343430874656793",
"307262739838282490037922745849514583388",
"216137643630279222385306830183119296484",
"245592444369585938057216328471371811601",
"223687258897856961322586234407062920116",
"186017797785707609153831395157800110768",
"203719078958941147833179289336036357733",
"19434389481220684353651723621883401201",
"263549781851891803972483555797916838582",
"132658415448656300735099714967472117786",
"150738929190709237733894706024320770894",
"62962848808907417350993459724453558998",
"182164790515762066180559218653234720374",
"124286415210558097999514047889575899680"
]
},
"deprecated": false,
"signature_type": "Line",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@abb7dc8fbb27c15dcc927df56190f3c5ede58bd5",
"target": {
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-a879b2c5",
"digest": {
"function_hash": "244037462633982403929080447148020760945",
"length": 912.0
},
"deprecated": false,
"signature_type": "Function",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@abb7dc8fbb27c15dcc927df56190f3c5ede58bd5",
"target": {
"function": "ath11k_core_pdev_create",
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-b1ba70f6",
"digest": {
"function_hash": "244037462633982403929080447148020760945",
"length": 912.0
},
"deprecated": false,
"signature_type": "Function",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@eaff3946a86fc63280a30158a4ae1e141449817c",
"target": {
"function": "ath11k_core_pdev_create",
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-ca2fdea1",
"digest": {
"threshold": 0.9,
"line_hashes": [
"331306286097583584806392314705363288572",
"304548681969562695023430010138802706634",
"236718910629179434752586036331112763684",
"56235307693614207894127293676190224514",
"160655460753916770829010402031684624856",
"155982685135572266246306216960003355438",
"173677822716794706141018786661714997040",
"323165604881315219261741908843150977129",
"34880953312206250552096796089035868436",
"36453974049952031327642570308467969611",
"3074293673899994582731795695271353148",
"201162176252166407141390343430874656793",
"307262739838282490037922745849514583388",
"216137643630279222385306830183119296484",
"245592444369585938057216328471371811601",
"223687258897856961322586234407062920116",
"186017797785707609153831395157800110768",
"203719078958941147833179289336036357733",
"19434389481220684353651723621883401201",
"263549781851891803972483555797916838582",
"132658415448656300735099714967472117786",
"150738929190709237733894706024320770894",
"62962848808907417350993459724453558998",
"182164790515762066180559218653234720374",
"124286415210558097999514047889575899680"
]
},
"deprecated": false,
"signature_type": "Line",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@eaff3946a86fc63280a30158a4ae1e141449817c",
"target": {
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-e7385f75",
"digest": {
"threshold": 0.9,
"line_hashes": [
"331306286097583584806392314705363288572",
"304548681969562695023430010138802706634",
"236718910629179434752586036331112763684",
"56235307693614207894127293676190224514",
"160655460753916770829010402031684624856",
"155982685135572266246306216960003355438",
"173677822716794706141018786661714997040",
"323165604881315219261741908843150977129",
"34880953312206250552096796089035868436",
"36453974049952031327642570308467969611",
"3074293673899994582731795695271353148",
"201162176252166407141390343430874656793",
"307262739838282490037922745849514583388",
"216137643630279222385306830183119296484",
"245592444369585938057216328471371811601",
"223687258897856961322586234407062920116",
"186017797785707609153831395157800110768",
"203719078958941147833179289336036357733",
"19434389481220684353651723621883401201",
"263549781851891803972483555797916838582",
"132658415448656300735099714967472117786",
"150738929190709237733894706024320770894",
"62962848808907417350993459724453558998",
"182164790515762066180559218653234720374",
"124286415210558097999514047889575899680"
]
},
"deprecated": false,
"signature_type": "Line",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@a2c45f8c3d18269e641f0c7da2dde47ef8414034",
"target": {
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
},
{
"id": "CVE-2022-50187-eae4a2fb",
"digest": {
"threshold": 0.9,
"line_hashes": [
"331306286097583584806392314705363288572",
"304548681969562695023430010138802706634",
"236718910629179434752586036331112763684",
"56235307693614207894127293676190224514",
"160655460753916770829010402031684624856",
"155982685135572266246306216960003355438",
"173677822716794706141018786661714997040",
"323165604881315219261741908843150977129",
"34880953312206250552096796089035868436",
"36453974049952031327642570308467969611",
"3074293673899994582731795695271353148",
"201162176252166407141390343430874656793",
"307262739838282490037922745849514583388",
"216137643630279222385306830183119296484",
"245592444369585938057216328471371811601",
"223687258897856961322586234407062920116",
"186017797785707609153831395157800110768",
"203719078958941147833179289336036357733",
"19434389481220684353651723621883401201",
"263549781851891803972483555797916838582",
"132658415448656300735099714967472117786",
"150738929190709237733894706024320770894",
"62962848808907417350993459724453558998",
"182164790515762066180559218653234720374",
"124286415210558097999514047889575899680"
]
},
"deprecated": false,
"signature_type": "Line",
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@d4ba1ff87b17e81686ada8f429300876f55f95ad",
"target": {
"file": "drivers/net/wireless/ath/ath11k/core.c"
},
"signature_version": "v1"
}
]