| /* SPDX-License-Identifier: GPL-2.0 */ |
| #include <asm/asm-offsets.h> |
| #include <asm/asm.h> |
| |
| #include <linux/linkage.h> |
| #include <linux/errno.h> |
| |
| #include "../../virt/vmx/tdx/tdxcall.S" |
| |
| .section .noinstr.text, "ax" |
| |
| /* |
| * __tdcall() - Used by TDX guests to request services from the TDX |
| * module (does not include VMM services) using TDCALL instruction. |
| * |
| * __tdcall() function ABI: |
| * |
| * @fn (RDI) - TDCALL Leaf ID, moved to RAX |
| * @args (RSI) - struct tdx_module_args for input |
| * |
| * Only RCX/RDX/R8-R11 are used as input registers. |
| * |
| * Return status of TDCALL via RAX. |
| */ |
| SYM_FUNC_START(__tdcall) |
| TDX_MODULE_CALL host=0 |
| SYM_FUNC_END(__tdcall) |
| |
| /* |
| * __tdcall_ret() - Used by TDX guests to request services from the TDX |
| * module (does not include VMM services) using TDCALL instruction, with |
| * saving output registers to the 'struct tdx_module_args' used as input. |
| * |
| * __tdcall_ret() function ABI: |
| * |
| * @fn (RDI) - TDCALL Leaf ID, moved to RAX |
| * @args (RSI) - struct tdx_module_args for input and output |
| * |
| * Only RCX/RDX/R8-R11 are used as input/output registers. |
| * |
| * Return status of TDCALL via RAX. |
| */ |
| SYM_FUNC_START(__tdcall_ret) |
| TDX_MODULE_CALL host=0 ret=1 |
| SYM_FUNC_END(__tdcall_ret) |
| |
| /* |
| * __tdcall_saved_ret() - Used by TDX guests to request services from the |
| * TDX module (including VMM services) using TDCALL instruction, with |
| * saving output registers to the 'struct tdx_module_args' used as input. |
| * |
| * __tdcall_saved_ret() function ABI: |
| * |
| * @fn (RDI) - TDCALL leaf ID, moved to RAX |
| * @args (RSI) - struct tdx_module_args for input/output |
| * |
| * All registers in @args are used as input/output registers. |
| * |
| * On successful completion, return the hypercall error code. |
| */ |
| SYM_FUNC_START(__tdcall_saved_ret) |
| TDX_MODULE_CALL host=0 ret=1 saved=1 |
| SYM_FUNC_END(__tdcall_saved_ret) |