Enum cranelift_codegen::ir::ArgumentPurpose
source · 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)
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§
source§impl Clone for ArgumentPurpose
impl Clone for ArgumentPurpose
source§fn clone(&self) -> ArgumentPurpose
fn clone(&self) -> ArgumentPurpose
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ArgumentPurpose
impl Debug for ArgumentPurpose
source§impl Display for ArgumentPurpose
impl Display for ArgumentPurpose
source§impl FromStr for ArgumentPurpose
impl FromStr for ArgumentPurpose
source§impl Hash for ArgumentPurpose
impl Hash for ArgumentPurpose
source§impl PartialEq<ArgumentPurpose> for ArgumentPurpose
impl PartialEq<ArgumentPurpose> for ArgumentPurpose
source§fn eq(&self, other: &ArgumentPurpose) -> bool
fn eq(&self, other: &ArgumentPurpose) -> bool
impl Copy for ArgumentPurpose
impl Eq for ArgumentPurpose
impl StructuralEq for ArgumentPurpose
impl StructuralPartialEq for ArgumentPurpose
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§
source§impl<T> CallHasher for Twhere
T: Hash + ?Sized,
impl<T> CallHasher for Twhere
T: Hash + ?Sized,
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.