aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/include/xalloc.h
diff options
authorArd Biesheuvel <ardb@kernel.org>2025-05-14 17:55:08 +0200
committerArd Biesheuvel <ardb@kernel.org>2025-05-14 18:13:14 +0200
commitdce834638a8447634151f792f9be22fcb1d0da31 (patch)
treed60324f668ab204a5a30c8048e5ae47db862bf87 /scripts/include/xalloc.h
parente35a7ba40271f9d0f44315ffb3fbb3561997ff9f (diff)
downloadlinux-for-kernelci.tar.gz
arm64/efi: Call EFI runtime services without disabling preemptionHEADfor-kernelciefi-preemptible-rt
The only remaining reason why EFI runtime services are invoked with preemption disabled is the fact that the mm is swapped out behind the back of the context switching code. The kernel no longer disables preemption when in kernel_neon_begin(). Furthermore, the EFI spec is being clarified to explicitly state that only baseline FP/SIMD is permitted in EFI runtime service implementations, and so the existing kernel mode NEON context switching code is sufficient to preserve and restore the execution context of an in-progress EFI runtime service call. Most EFI calls are made from the efi_rts_wq, which is serviced by a kthread. As kthreads never return to user space, they usually don't have an mm, and so we can use the existing infrastructure to swap in the efi_mm while the EFI call is in progress. This is visible to the scheduler, which will therefore reactivate the selected mm when switching out the kthread and back in again. Given that the EFI spec explicitly permits runtime services to be called with interrupts enabled, firmware code is already required to tolerate interruptions. So rather than disable preemption, disable only migration so that EFI runtime services are less likely to cause scheduling delays. Note, though, that the firmware executes at the same privilege level as the kernel, and is therefore able to disable interrupts altogether. Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Diffstat (limited to 'scripts/include/xalloc.h')
0 files changed, 0 insertions, 0 deletions