aboutsummaryrefslogtreecommitdiff
path: root/scripts/gdb/linux/utils.py
diff options
context:
space:
mode:
authorRafael J. Wysocki <[email protected]>2022-11-07 18:42:36 +0100
committerRafael J. Wysocki <[email protected]>2022-11-08 20:37:23 +0100
commit404ec60438add1afadaffaed34bb5fe4ddcadd40 (patch)
treeda8d06bd9b7662c47f142dee538f387fb7e4bfea /scripts/gdb/linux/utils.py
parent2b6bab68917223e8ca52573de1132ab137ebc928 (diff)
ACPICA: Fix error code path in acpi_ds_call_control_method()
A use-after-free in acpi_ps_parse_aml() after a failing invocaion of acpi_ds_call_control_method() is reported by KASAN [1] and code inspection reveals that next_walk_state pushed to the thread by acpi_ds_create_walk_state() is freed on errors, but it is not popped from the thread beforehand. Thus acpi_ds_get_current_walk_state() called by acpi_ps_parse_aml() subsequently returns it as the new walk state which is incorrect. To address this, make acpi_ds_call_control_method() call acpi_ds_pop_walk_state() to pop next_walk_state from the thread before returning an error. Link: https://lore.kernel.org/linux-acpi/[email protected]/ # [1] Reported-by: Chen Zhongjin <[email protected]> Signed-off-by: Rafael J. Wysocki <[email protected]> Reviewed-by: Chen Zhongjin <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/utils.py')
0 files changed, 0 insertions, 0 deletions