Enum cranelift_codegen::ir::ArgumentPurpose [−][src]
pub enum ArgumentPurpose {
Normal,
StructArgument(u32),
StructReturn,
Link,
FramePointer,
CalleeSaved,
VMContext,
SignatureId,
StackLimit,
CalleeTLS,
CallerTLS,
}
Expand description
The special purpose of a function argument.
Function arguments and return values are used to pass user program values between functions, but they are also used to represent special registers with significance to the ABI such as frame pointers and callee-saved registers.
The argument purpose is used to indicate any special meaning of an argument or return value.
Variants
Normal
A normal user program value passed to or from a function.
StructArgument(u32)
Tuple Fields
0: u32
A C struct passed as argument.
StructReturn
Struct return pointer.
When a function needs to return more data than will fit in registers, the caller passes a pointer to a memory location where the return value can be written. In some ABIs, this struct return pointer is passed in a specific register.
This argument kind can also appear as a return value for ABIs that require a function with
a StructReturn
pointer argument to also return that pointer in a register.
Link
The link register.
Most RISC architectures implement calls by saving the return address in a designated
register rather than pushing it on the stack. This is represented with a Link
argument.
Similarly, some return instructions expect the return address in a register represented as
a Link
return value.
FramePointer
The frame pointer.
This indicates the frame pointer register which has a special meaning in some ABIs.
The frame pointer appears as an argument and as a return value since it is a callee-saved register.
CalleeSaved
A callee-saved register.
Some calling conventions have registers that must be saved by the callee. These registers
are represented as CalleeSaved
arguments and return values.
VMContext
A VM context pointer.
This is a pointer to a context struct containing details about the current sandbox. It is
used as a base pointer for vmctx
global values.
SignatureId
A signature identifier.
This is a special-purpose argument used to identify the calling convention expected by the caller in an indirect call. The callee can verify that the expected signature ID matches.
StackLimit
A stack limit pointer.
This is a pointer to a stack limit. It is used to check the current stack pointer against. Can only appear once in a signature.
CalleeTLS
A callee TLS value.
In the Baldrdash-2020 calling convention, the stack upon entry to the callee contains the TLS-register values for the caller and the callee. This argument is used to provide the value for the callee.
CallerTLS
A caller TLS value.
In the Baldrdash-2020 calling convention, the stack upon entry to the callee contains the TLS-register values for the caller and the callee. This argument is used to provide the value for the caller.
Trait Implementations
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
This method tests for !=
.
Auto Trait Implementations
impl RefUnwindSafe for ArgumentPurpose
impl Send for ArgumentPurpose
impl Sync for ArgumentPurpose
impl Unpin for ArgumentPurpose
impl UnwindSafe for ArgumentPurpose
Blanket Implementations
Mutably borrows from an owned value. Read more
Compare self to key
and return true
if they are equal.