CVE-2025-22014
Published: Apr 8, 2025
Modified: May 11, 2026
Description
In the Linux kernel, the following vulnerability has been resolved: soc: qcom: pdr: Fix the potential deadlock When some client process A call pdr_add_lookup() to add the look up for the service and does schedule locator work, later a process B got a new server packet indicating locator is up and call pdr_locator_new_server() which eventually sets pdr->locator_init_complete to true which process A sees and takes list lock and queries domain list but it will timeout due to deadlock as the response will queued to the same qmi->wq and it is ordered workqueue and process B is not able to complete new server request work due to deadlock on list lock. Fix it by removing the unnecessary list iteration as the list iteration is already being done inside locator work, so avoid it here and just call schedule_work() here. Process A Process B process_scheduled_works() pdr_add_lookup() qmi_data_ready_work() process_scheduled_works() pdr_locator_new_server() pdr->locator_init_complete=true; pdr_locator_work() mutex_lock(&pdr->list_lock); pdr_locate_service() mutex_lock(&pdr->list_lock); pdr_get_domain_list() pr_err("PDR: %s get domain list txn wait failed: %d\n", req->service_name, ret); Timeout error log due to deadlock: " PDR: tms/servreg get domain list txn wait failed: -110 PDR: service lookup for msm/adsp/sensor_pd:tms/servreg failed: -110 " Thanks to Bjorn and Johan for letting me know that this commit also fixes an audio regression when using the in-kernel pd-mapper as that makes it easier to hit this race. [1]
| Vendor | Product | Versions |
|---|---|---|
Linux | Linux | affected fbe639b44a82755d639df1c5d147c93f02ac5a0f - < 72a222b6af10c2a05a5fad0029246229ed8912c2affected fbe639b44a82755d639df1c5d147c93f02ac5a0f - < daba84612236de3ab39083e62c9e326a654ebd20affected fbe639b44a82755d639df1c5d147c93f02ac5a0f - < 0a566a79aca9851fae140536e0fc5b0853c90a90affected fbe639b44a82755d639df1c5d147c93f02ac5a0f - < f2bbfd50e95bc117360f0f59e629aa03d821ebd6affected fbe639b44a82755d639df1c5d147c93f02ac5a0f - < f4489260f5713c94e1966e5f20445bff262876f4+2 more versions |
Linux | Linux | affected 5.7unaffected 0 - < 5.7unaffected 5.10.236 - <= 5.10.*unaffected 5.15.180 - <= 5.15.*unaffected 6.1.132 - <= 6.1.*+4 more versions |
References
Security Training
Train your team to recognize and prevent security threats with our comprehensive security awareness program.
Start TrainingVulnerability Scanning
Discover vulnerabilities in your applications and infrastructure before attackers do.
Scan Now