2024-07-12 13:00:36 +00:00
{
2024-07-12 13:01:37 +00:00
"data_version" : "4.0" ,
2024-07-12 13:00:36 +00:00
"data_type" : "CVE" ,
"data_format" : "MITRE" ,
"CVE_data_meta" : {
"ID" : "CVE-2024-40970" ,
2024-07-12 13:01:37 +00:00
"ASSIGNER" : "cve@kernel.org" ,
"STATE" : "PUBLIC"
2024-07-12 13:00:36 +00:00
} ,
"description" : {
"description_data" : [
{
"lang" : "eng" ,
2024-07-12 13:01:37 +00:00
"value" : "In the Linux kernel, the following vulnerability has been resolved:\n\nAvoid hw_desc array overrun in dw-axi-dmac\n\nI have a use case where nr_buffers = 3 and in which each descriptor is composed by 3\nsegments, resulting in the DMA channel descs_allocated to be 9. Since axi_desc_put()\nhandles the hw_desc considering the descs_allocated, this scenario would result in a\nkernel panic (hw_desc array will be overrun).\n\nTo fix this, the proposal is to add a new member to the axi_dma_desc structure,\nwhere we keep the number of allocated hw_descs (axi_desc_alloc()) and use it in\naxi_desc_put() to handle the hw_desc array correctly.\n\nAdditionally I propose to remove the axi_chan_start_first_queued() call after completing\nthe transfer, since it was identified that unbalance can occur (started descriptors can\nbe interrupted and transfer ignored due to DMA channel not being enabled)."
}
]
} ,
"problemtype" : {
"problemtype_data" : [
{
"description" : [
{
"lang" : "eng" ,
"value" : "n/a"
}
]
}
]
} ,
"affects" : {
"vendor" : {
"vendor_data" : [
{
"vendor_name" : "Linux" ,
"product" : {
"product_data" : [
{
"product_name" : "Linux" ,
"version" : {
"version_data" : [
{
"version_affected" : "<" ,
"version_name" : "1da177e4c3f4" ,
"version_value" : "7c3bb96a20cd"
} ,
{
"version_value" : "not down converted" ,
"x_cve_json_5_version_data" : {
"versions" : [
{
"version" : "5.15.162" ,
"lessThanOrEqual" : "5.15.*" ,
"status" : "unaffected" ,
2024-11-05 10:00:33 +00:00
"versionType" : "semver"
2024-07-12 13:01:37 +00:00
} ,
{
"version" : "6.1.96" ,
"lessThanOrEqual" : "6.1.*" ,
"status" : "unaffected" ,
2024-11-05 10:00:33 +00:00
"versionType" : "semver"
2024-07-12 13:01:37 +00:00
} ,
{
"version" : "6.6.36" ,
"lessThanOrEqual" : "6.6.*" ,
"status" : "unaffected" ,
2024-11-05 10:00:33 +00:00
"versionType" : "semver"
2024-07-12 13:01:37 +00:00
} ,
{
"version" : "6.9.7" ,
"lessThanOrEqual" : "6.9.*" ,
"status" : "unaffected" ,
2024-11-05 10:00:33 +00:00
"versionType" : "semver"
2024-07-12 13:01:37 +00:00
} ,
{
2024-07-15 07:00:37 +00:00
"version" : "6.10" ,
2024-07-12 13:01:37 +00:00
"lessThanOrEqual" : "*" ,
"status" : "unaffected" ,
"versionType" : "original_commit_for_fix"
}
] ,
"defaultStatus" : "affected"
}
}
]
}
}
]
}
}
]
}
} ,
"references" : {
"reference_data" : [
{
"url" : "https://git.kernel.org/stable/c/7c3bb96a20cd8db3b8824b2ff08b6cde4505c7e5" ,
"refsource" : "MISC" ,
"name" : "https://git.kernel.org/stable/c/7c3bb96a20cd8db3b8824b2ff08b6cde4505c7e5"
} ,
{
"url" : "https://git.kernel.org/stable/c/dd42570018f5962c10f215ad9c21274ed5d3541e" ,
"refsource" : "MISC" ,
"name" : "https://git.kernel.org/stable/c/dd42570018f5962c10f215ad9c21274ed5d3541e"
} ,
{
"url" : "https://git.kernel.org/stable/c/e151ae1ee065cf4b8ce4394ddb9d9c8df6370c66" ,
"refsource" : "MISC" ,
"name" : "https://git.kernel.org/stable/c/e151ae1ee065cf4b8ce4394ddb9d9c8df6370c66"
} ,
{
"url" : "https://git.kernel.org/stable/c/9004784e8d68bcd1ac1376407ba296fa28f04dbe" ,
"refsource" : "MISC" ,
"name" : "https://git.kernel.org/stable/c/9004784e8d68bcd1ac1376407ba296fa28f04dbe"
} ,
{
"url" : "https://git.kernel.org/stable/c/333e11bf47fa8d477db90e2900b1ed3c9ae9b697" ,
"refsource" : "MISC" ,
"name" : "https://git.kernel.org/stable/c/333e11bf47fa8d477db90e2900b1ed3c9ae9b697"
2024-07-12 13:00:36 +00:00
}
]
2024-07-12 13:01:37 +00:00
} ,
"generator" : {
2024-11-05 10:00:33 +00:00
"engine" : "bippy-9e1c9544281a"
2024-07-12 13:00:36 +00:00
}
}