CVE-2026-22986

Source
https://cve.org/CVERecord?id=CVE-2026-22986
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-22986.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2026-22986
Downstream
Related
Published
2026-01-23T15:24:07.932Z
Modified
2026-03-13T04:06:40.833523Z
Summary
gpiolib: fix race condition for gdev->srcu
Details

In the Linux kernel, the following vulnerability has been resolved:

gpiolib: fix race condition for gdev->srcu

If two drivers were calling gpiochipadddatawithkey(), one may be traversing the srcu-protected list in gpionametodesc(), meanwhile other has just added its gdev in gpiodevaddtolist_unlocked(). This creates a non-mutexed and non-protected timeframe, when one instance is dereferencing and using &gdev->srcu, before the other has initialized it, resulting in crash:

[ 4.935481] Unable to handle kernel paging request at virtual address ffff800272bcc000 [ 4.943396] Mem abort info: [ 4.943400] ESR = 0x0000000096000005 [ 4.943403] EC = 0x25: DABT (current EL), IL = 32 bits [ 4.943407] SET = 0, FnV = 0 [ 4.943410] EA = 0, S1PTW = 0 [ 4.943413] FSC = 0x05: level 1 translation fault [ 4.943416] Data abort info: [ 4.943418] ISV = 0, ISS = 0x00000005, ISS2 = 0x00000000 [ 4.946220] CM = 0, WnR = 0, TnD = 0, TagAccess = 0 [ 4.955261] GCS = 0, Overlay = 0, DirtyBit = 0, Xs = 0 [ 4.955268] swapper pgtable: 4k pages, 48-bit VAs, pgdp=0000000038e6c000 [ 4.961449] [ffff800272bcc000] pgd=0000000000000000 [ 4.969203] , p4d=1000000039739003 [ 4.979730] , pud=0000000000000000 [ 4.980210] phandle (CPU): 0x0000005e, phandle (BE): 0x5e000000 for node "reset" [ 4.991736] Internal error: Oops: 0000000096000005 [#1] PREEMPT SMP ... [ 5.121359] pc : __srcureadlock+0x44/0x98 [ 5.131091] lr : gpio_nametodesc+0x60/0x1a0 [ 5.153671] sp : ffff8000833bb430 [ 5.298440] [ 5.298443] Call trace: [ 5.298445] _srcureadlock+0x44/0x98 [ 5.309484] gpionametodesc+0x60/0x1a0 [ 5.320692] gpiochipadddatawithkey+0x488/0xf00 5.946419] ---[ end trace 0000000000000000 ]---

Move initialization code for gdev fields before it is added to gpio_devices, with adjacent initialization code. Adjust goto statements to reflect modified order of operations

[Bartosz: fixed a build issue, removed stray newline]

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/22xxx/CVE-2026-22986.json"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
47d8b4c1d868148c8fb51b785a89e58ca2d02c4d
Fixed
fb674c8f1a5d8dd3113a7326030f963fa2d79c02
Fixed
a7ac22d53d0990152b108c3f4fe30df45fcb0181

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-22986.json"