CVE-2022-48704

Source
https://cve.org/CVERecord?id=CVE-2022-48704
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-48704.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-48704
Downstream
Related
Published
2024-05-03T17:45:51.299Z
Modified
2026-03-13T05:59:28.453876Z
Summary
drm/radeon: add a force flush to delay work when radeon
Details

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

drm/radeon: add a force flush to delay work when radeon

Although radeon card fence and wait for gpu to finish processing current batch rings, there is still a corner case that radeon lockup work queue may not be fully flushed, and meanwhile the radeonsuspendkms() function has called pcisetpower_state() to put device in D3hot state. Per PCI spec rev 4.0 on 5.3.1.4.1 D3hot State.

Configuration and Message requests are the only TLPs accepted by a Function in the D3hot state. All other received Requests must be handled as Unsupported Requests, and all received Completions may optionally be handled as Unexpected Completions. This issue will happen in following logs: Unable to handle kernel paging request at virtual address 00008800e0008010 CPU 0 kworker/0:3(131): Oops 0 pc = [<ffffffff811bea5c>] ra = [<ffffffff81240844>] ps = 0000 Tainted: G W pc is at sigpuchecksoftreset+0x3c/0x240 ra is at sidmaislockup+0x34/0xd0 v0 = 0000000000000000 t0 = fff08800e0008010 t1 = 0000000000010000 t2 = 0000000000008010 t3 = fff00007e3c00000 t4 = fff00007e3c00258 t5 = 000000000000ffff t6 = 0000000000000001 t7 = fff00007ef078000 s0 = fff00007e3c016e8 s1 = fff00007e3c00000 s2 = fff00007e3c00018 s3 = fff00007e3c00000 s4 = fff00007fff59d80 s5 = 0000000000000000 s6 = fff00007ef07bd98 a0 = fff00007e3c00000 a1 = fff00007e3c016e8 a2 = 0000000000000008 a3 = 0000000000000001 a4 = 8f5c28f5c28f5c29 a5 = ffffffff810f4338 t8 = 0000000000000275 t9 = ffffffff809b66f8 t10 = ff6769c5d964b800 t11= 000000000000b886 pv = ffffffff811bea20 at = 0000000000000000 gp = ffffffff81d89690 sp = 00000000aa814126 Disabling lock debugging due to kernel taint Trace: [<ffffffff81240844>] sidmaislockup+0x34/0xd0 [<ffffffff81119610>] radeonfencechecklockup+0xd0/0x290 [<ffffffff80977010>] processonework+0x280/0x550 [<ffffffff80977350>] workerthread+0x70/0x7c0 [<ffffffff80977410>] workerthread+0x130/0x7c0 [<ffffffff80982040>] kthread+0x200/0x210 [<ffffffff809772e0>] workerthread+0x0/0x7c0 [<ffffffff80981f8c>] kthread+0x14c/0x210 [<ffffffff80911658>] retfromkernel_thread+0x18/0x20 [<ffffffff80981e40>] kthread+0x0/0x210 Code: ad3e0008 43f0074a ad7e0018 ad9e0020 8c3001e8 40230101 <88210000> 4821ed21 So force lockup work queue flush to fix this problem.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/48xxx/CVE-2022-48704.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
0bfa4b41268ad5fd741f16f484e4fee190822ec6
Fixed
b878da58df2c40b08914d3960e2224040fd1fbfe
Fixed
4e25e8f27fdbdc6fd55cc572a9939bf24500b9e8
Fixed
c0a45f41fde4a0f2c900f719817493ee5c4a5aa3
Fixed
c72d97146fc5a4dff381b1737f6167e89860430d
Fixed
826b46fd5974113515abe9e4fc8178009a8ce18c
Fixed
5a7a5b2edac4b05abd744eeaebda46d9dacd952d
Fixed
16cb367daa446923d82e332537f446a4cc784b40
Fixed
f461950fdc374a3ada5a63c669d997de4600dffe

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-48704.json"