8999ad99f4
* Handle retrying/resuming page conversion hypercalls * Make sure to use the (shockingly) reliable TSC in TDX guests -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEV76QKkVc4xCGURexaDWVMHDJkrAFAmVBlqMACgkQaDWVMHDJ krBrhBAArKay0MvzmdzS4IQs8JqkmuMEHI6WabYv2POPjJNXrn5MelLH972pLuX9 NJ3+yeOLmNMYwqu5qwLCxyeO5CtqEyT2lNumUrxAtHQG4+oS2RYJYUalxMuoGxt8 fAHxbItFg0TobBSUtwcnN2R2WdXwPuUW0Co+pJfLlZV4umVM7QANO1nf1g8YmlDD sVtpDaeKJRdylmwgWgAyGow0tDKd6oZB9j/vOHvZRrEQ+DMjEtG75fjwbjbu43Cl tI/fbxKjzAkOFcZ7PEPsQ8jE1h9DXU+JzTML9Nu/cPMalxMeBg3Dol/JOEbqgreI 4W8Lg7g071EkUcQDxpwfe4aS6rsfsbwUIV4gJVkg9ZhlT7RayWsFik2CfBpJ4IMQ TM8BxtCEGCz3cxVvg3mstX9rRA7eNlXOzcKE/8Y7cpSsp94bA9jtf2GgUSUoi9St y+fIEei8mgeHutdiFh8psrmR7hp6iX/ldMFqHtjNo6xatf2KjdVHhVSU13Jz544z 43ATNi1gZeHOgfwlAlIxLPDVDJidHuux3f6g2vfMkAqItyEqFauC1HA1pIDgckoY 9FpBPp9vNUToSPp6reB6z/PkEBIrG2XtQh82JLt2CnCb6aTUtnPds+psjtT4sSE/ a9SQvZLWWmpj+BlI2yrtfJzhy7SwhltgdjItQHidmCNEn0PYfTc= =FJ1Y -----END PGP SIGNATURE----- Merge tag 'x86_tdx_for_6.7' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull x86 TDX updates from Dave Hansen: "The majority of this is a rework of the assembly and C wrappers that are used to talk to the TDX module and VMM. This is a nice cleanup in general but is also clearing the way for using this code when Linux is the TDX VMM. There are also some tidbits to make TDX guests play nicer with Hyper-V and to take advantage the hardware TSC. Summary: - Refactor and clean up TDX hypercall/module call infrastructure - Handle retrying/resuming page conversion hypercalls - Make sure to use the (shockingly) reliable TSC in TDX guests" [ TLA reminder: TDX is "Trust Domain Extensions", Intel's guest VM confidentiality technology ] * tag 'x86_tdx_for_6.7' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: x86/tdx: Mark TSC reliable x86/tdx: Fix __noreturn build warning around __tdx_hypercall_failed() x86/virt/tdx: Make TDX_MODULE_CALL handle SEAMCALL #UD and #GP x86/virt/tdx: Wire up basic SEAMCALL functions x86/tdx: Remove 'struct tdx_hypercall_args' x86/tdx: Reimplement __tdx_hypercall() using TDX_MODULE_CALL asm x86/tdx: Make TDX_HYPERCALL asm similar to TDX_MODULE_CALL x86/tdx: Extend TDX_MODULE_CALL to support more TDCALL/SEAMCALL leafs x86/tdx: Pass TDCALL/SEAMCALL input/output registers via a structure x86/tdx: Rename __tdx_module_call() to __tdcall() x86/tdx: Make macros of TDCALLs consistent with the spec x86/tdx: Skip saving output regs when SEAMCALL fails with VMFailInvalid x86/tdx: Zero out the missing RSI in TDX_HYPERCALL macro x86/tdx: Retry partially-completed page conversion hypercalls
49 lines
1.4 KiB
C
49 lines
1.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/*
|
|
* This is a (sorted!) list of all known __noreturn functions in the kernel.
|
|
* It's needed for objtool to properly reverse-engineer the control flow graph.
|
|
*
|
|
* Yes, this is unfortunate. A better solution is in the works.
|
|
*/
|
|
NORETURN(__invalid_creds)
|
|
NORETURN(__kunit_abort)
|
|
NORETURN(__module_put_and_kthread_exit)
|
|
NORETURN(__reiserfs_panic)
|
|
NORETURN(__stack_chk_fail)
|
|
NORETURN(__tdx_hypercall_failed)
|
|
NORETURN(__ubsan_handle_builtin_unreachable)
|
|
NORETURN(arch_call_rest_init)
|
|
NORETURN(arch_cpu_idle_dead)
|
|
NORETURN(bch2_trans_in_restart_error)
|
|
NORETURN(bch2_trans_restart_error)
|
|
NORETURN(cpu_bringup_and_idle)
|
|
NORETURN(cpu_startup_entry)
|
|
NORETURN(do_exit)
|
|
NORETURN(do_group_exit)
|
|
NORETURN(do_task_dead)
|
|
NORETURN(ex_handler_msr_mce)
|
|
NORETURN(fortify_panic)
|
|
NORETURN(hlt_play_dead)
|
|
NORETURN(hv_ghcb_terminate)
|
|
NORETURN(kthread_complete_and_exit)
|
|
NORETURN(kthread_exit)
|
|
NORETURN(kunit_try_catch_throw)
|
|
NORETURN(machine_real_restart)
|
|
NORETURN(make_task_dead)
|
|
NORETURN(mpt_halt_firmware)
|
|
NORETURN(nmi_panic_self_stop)
|
|
NORETURN(panic)
|
|
NORETURN(panic_smp_self_stop)
|
|
NORETURN(rest_init)
|
|
NORETURN(rewind_stack_and_make_dead)
|
|
NORETURN(sev_es_terminate)
|
|
NORETURN(snp_abort)
|
|
NORETURN(start_kernel)
|
|
NORETURN(stop_this_cpu)
|
|
NORETURN(usercopy_abort)
|
|
NORETURN(x86_64_start_kernel)
|
|
NORETURN(x86_64_start_reservations)
|
|
NORETURN(xen_cpu_bringup_again)
|
|
NORETURN(xen_start_kernel)
|