aboutsummaryrefslogtreecommitdiff
path: root/lib/zstd/common/zstd_common.c
diff options
context:
space:
mode:
authorArd Biesheuvel <[email protected]>2022-10-28 16:39:14 +0200
committerArd Biesheuvel <[email protected]>2023-01-16 15:27:31 +0100
commit8a9a1a18731eb123e35f48176380a18b9782845e (patch)
treef575285adbe808f8a4b9b7346a6e88a266d4b304 /lib/zstd/common/zstd_common.c
parentd3f450533bbcb6dd4d7d59cadc9b61b7321e4ac1 (diff)
arm64: efi: Avoid workqueue to check whether EFI runtime is live
Comparing current_work() against efi_rts_work.work is sufficient to decide whether current is currently running EFI runtime services code at any level in its call stack. However, there are other potential users of the EFI runtime stack, such as the ACPI subsystem, which may invoke efi_call_virt_pointer() directly, and so any sync exceptions occurring in firmware during those calls are currently misidentified. So instead, let's check whether the stashed value of the thread stack pointer points into current's thread stack. This can only be the case if current was interrupted while running EFI runtime code. Note that this implies that we should clear the stashed value after switching back, to avoid false positives. Reviewed-by: Mark Rutland <[email protected]> Signed-off-by: Ard Biesheuvel <[email protected]>
Diffstat (limited to 'lib/zstd/common/zstd_common.c')
0 files changed, 0 insertions, 0 deletions