In the Linux kernel, the following vulnerability has been resolved:
tpm: Change to kvalloc() in eventlog/acpi.c
The following failure was reported on HPE ProLiant D320:
[ 10.693310][ T1] tpmtis STM0925:00: 2.0 TPM (device-id 0x3, rev-id 0) [ 10.848132][ T1] ------------[ cut here ]------------ [ 10.853559][ T1] WARNING: CPU: 59 PID: 1 at mm/pagealloc.c:4727 allocpagesnoprof+0x2ca/0x330 [ 10.862827][ T1] Modules linked in: [ 10.866671][ T1] CPU: 59 UID: 0 PID: 1 Comm: swapper/0 Not tainted 6.12.0-lp155.2.g52785e2-default #1 openSUSE Tumbleweed (unreleased) 588cd98293a7c9eba9013378d807364c088c9375 [ 10.882741][ T1] Hardware name: HPE ProLiant DL320 Gen12/ProLiant DL320 Gen12, BIOS 1.20 10/28/2024 [ 10.892170][ T1] RIP: 0010:allocpagesnoprof+0x2ca/0x330 [ 10.898103][ T1] Code: 24 08 e9 4a fe ff ff e8 34 36 fa ff e9 88 fe ff ff 83 fe 0a 0f 86 b3 fd ff ff 80 3d 01 e7 ce 01 00 75 09 c6 05 f8 e6 ce 01 01 <0f> 0b 45 31 ff e9 e5 fe ff ff f7 c2 00 00 08 00 75 42 89 d9 80 e1 [ 10.917750][ T1] RSP: 0000:ffffb7cf40077980 EFLAGS: 00010246 [ 10.923777][ T1] RAX: 0000000000000000 RBX: 0000000000040cc0 RCX: 0000000000000000 [ 10.931727][ T1] RDX: 0000000000000000 RSI: 000000000000000c RDI: 0000000000040cc0
The above transcript shows that ACPI pointed a 16 MiB buffer for the log events because RSI maps to the 'order' parameter of _allocpagesnoprof(). Address the bug by moving from devmkmalloc() to devmaddaction() and kvmalloc() and devmaddaction().
[
{
"deprecated": false,
"digest": {
"length": 1949.0,
"function_hash": "83596995104332966834900755965216116503"
},
"id": "CVE-2024-58005-031d3c59",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@4c8bfe643bbd00b04ee8f9545ef33bf6a68c38db",
"signature_type": "Function",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-2633fb72",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@50365a6304a57266e8f4d3078060743c3b7a1e0d",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-35ced571",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@0621d2599d6e02d05c85d6bbd58eaea2f15b3503",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"length": 1949.0,
"function_hash": "83596995104332966834900755965216116503"
},
"id": "CVE-2024-58005-52b06567",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@422d7f4e8d817be467986589c7968d3ea402f7da",
"signature_type": "Function",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"length": 1949.0,
"function_hash": "83596995104332966834900755965216116503"
},
"id": "CVE-2024-58005-59acb026",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@a3a860bc0fd6c07332e4911cf9a238d20de90173",
"signature_type": "Function",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"length": 1963.0,
"function_hash": "256978323585208184754446273364003541389"
},
"id": "CVE-2024-58005-6a2acdeb",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@77779d1258a287f2c5c2c6aeae203e0996209c77",
"signature_type": "Function",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-7f6f0deb",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@77779d1258a287f2c5c2c6aeae203e0996209c77",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-861dd425",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@4c8bfe643bbd00b04ee8f9545ef33bf6a68c38db",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"length": 1963.0,
"function_hash": "256978323585208184754446273364003541389"
},
"id": "CVE-2024-58005-9020aa14",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@0621d2599d6e02d05c85d6bbd58eaea2f15b3503",
"signature_type": "Function",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-973e1ca1",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@a3a860bc0fd6c07332e4911cf9a238d20de90173",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-a1b0a2c8",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@a676c0401de59548a5bc1b7aaf98f556ae8ea6db",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"length": 1963.0,
"function_hash": "256978323585208184754446273364003541389"
},
"id": "CVE-2024-58005-c6d8dcea",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@a676c0401de59548a5bc1b7aaf98f556ae8ea6db",
"signature_type": "Function",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"threshold": 0.9,
"line_hashes": [
"172321173056942247409773969790399145336",
"55853292237240772041642904188661994916",
"328274961587783402117362428445098289807",
"227927449930564196362336965719009290799",
"134348320327243681340533279632994405113",
"65830232231497263104937512168581053507",
"49621509754905260966330663170603711056",
"177810480224085935437104581306846957502",
"306335686977306629316789025598880438655",
"292180338452493965421702192351399212491",
"132551484550050064566118499500420949259",
"246424394941691272918338075133248397011",
"332508518547251371069683561910024130778"
]
},
"id": "CVE-2024-58005-d5169deb",
"target": {
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@422d7f4e8d817be467986589c7968d3ea402f7da",
"signature_type": "Line",
"signature_version": "v1"
},
{
"deprecated": false,
"digest": {
"length": 1963.0,
"function_hash": "256978323585208184754446273364003541389"
},
"id": "CVE-2024-58005-d95a4372",
"target": {
"function": "tpm_read_log_acpi",
"file": "drivers/char/tpm/eventlog/acpi.c"
},
"source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@50365a6304a57266e8f4d3078060743c3b7a1e0d",
"signature_type": "Function",
"signature_version": "v1"
}
]