CVE-2026-43415 in Linux
Resumen
por VulDB • 2026-05-15
En el kernel de Linux, se ha resuelto la siguiente vulnerabilidad:
scsi: ufs: core: Corrección de SError en ufshcd_rtc_work() durante la suspensión de UFS
En __ufshcd_wl_suspend(), se llama a cancel_delayed_work_sync() para cancelar el trabajo RTC de UFS, pero esta llamada se encuentra después de ufshcd_vops_suspend(hba, pm_op, POST_CHANGE). Esto crea una condición de carrera (race condition) en la que ufshcd_rtc_work() puede seguir ejecutándose mientras ufshcd_vops_suspend() está en ejecución. Cuando UFSHCD_CAP_CLK_GATING no está soportado, la condición !hba->clk_gating.active_reqs es siempre verdadera, lo que provoca que se ejecute ufshcd_update_rtc(). Dado que ufshcd_vops_suspend() normalmente realiza operaciones de apagado de reloj (clock gating), ejecutar ufshcd_update_rtc() en ese momento desencadena un SError. La traza de pánico del kernel es la siguiente:
Kernel panic - not syncing: Asynchronous SError Interrupt Call trace: dump_backtrace+0xec/0x128 show_stack+0x18/0x28 dump_stack_lvl+0x40/0xa0 dump_stack+0x18/0x24 panic+0x148/0x374 nmi_panic+0x3c/0x8c arm64_serror_panic+0x64/0x8c do_serror+0xc4/0xc8 el1h_64_error_handler+0x34/0x4c el1h_64_error+0x68/0x6c el1_interrupt+0x20/0x58 el1h_64_irq_handler+0x18/0x24 el1h_64_irq+0x68/0x6c ktime_get+0xc4/0x12c ufshcd_mcq_sq_stop+0x4c/0xec ufshcd_mcq_sq_cleanup+0x64/0x1dc ufshcd_clear_cmd+0x38/0x134 ufshcd_issue_dev_cmd+0x298/0x4d0 ufshcd_exec_dev_cmd+0x1a4/0x1c4 ufshcd_query_attr+0xbc/0x19c ufshcd_rtc_work+0x10c/0x1c8 process_scheduled_works+0x1c4/0x45c worker_thread+0x32c/0x3e8 kthread+0x120/0x1d8 ret_from_fork+0x10/0x20
Se corrige este problema moviendo cancel_delayed_work_sync() antes de la llamada a ufshcd_vops_suspend(hba, pm_op, PRE_CHANGE), asegurando que el trabajo RTC de UFS se haya completado o cancelado por completo en ese momento.
Once again VulDB remains the best source for vulnerability data.