pub enum Abi {
Show 25 variants
Rust,
C {
unwind: bool,
},
Cdecl {
unwind: bool,
},
Stdcall {
unwind: bool,
},
Fastcall {
unwind: bool,
},
Vectorcall {
unwind: bool,
},
Thiscall {
unwind: bool,
},
Aapcs {
unwind: bool,
},
Win64 {
unwind: bool,
},
SysV64 {
unwind: bool,
},
PtxKernel,
Msp430Interrupt,
X86Interrupt,
EfiApi,
AvrInterrupt,
AvrNonBlockingInterrupt,
CCmseNonSecureCall,
CCmseNonSecureEntry,
System {
unwind: bool,
},
RustIntrinsic,
RustCall,
Unadjusted,
RustCold,
RiscvInterruptM,
RiscvInterruptS,
}
Variants§
Rust
C
Cdecl
Stdcall
Fastcall
Vectorcall
Thiscall
Aapcs
Win64
SysV64
PtxKernel
Msp430Interrupt
X86Interrupt
EfiApi
AvrInterrupt
AvrNonBlockingInterrupt
CCmseNonSecureCall
CCmseNonSecureEntry
System
RustIntrinsic
RustCall
Unadjusted
Not a stable ABI, just directly use the Rust types to describe the ABI for LLVM. Even normally ABI-compatible Rust types can become ABI-incompatible with this ABI!
RustCold
For things unlikely to be called, where reducing register pressure in
extern "Rust"
callers is worth paying extra cost in the callee.
Stronger than just #[cold]
because fn
pointers might be incompatible.
RiscvInterruptM
RiscvInterruptS
Implementations§
Trait Implementations§
source§impl<__CTX> HashStable<__CTX> for Abiwhere
__CTX: HashStableContext,
impl<__CTX> HashStable<__CTX> for Abiwhere
__CTX: HashStableContext,
fn hash_stable(&self, __hcx: &mut __CTX, __hasher: &mut StableHasher)
source§impl Ord for Abi
impl Ord for Abi
source§impl PartialOrd for Abi
impl PartialOrd for Abi
impl Copy for Abi
impl Eq for Abi
impl StructuralPartialEq for Abi
Auto Trait Implementations§
impl Freeze for Abi
impl RefUnwindSafe for Abi
impl Send for Abi
impl Sync for Abi
impl Unpin for Abi
impl UnwindSafe for Abi
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 2 bytes
Size for each variant:
Rust
: 0 bytesC
: 1 byteCdecl
: 1 byteStdcall
: 1 byteFastcall
: 1 byteVectorcall
: 1 byteThiscall
: 1 byteAapcs
: 1 byteWin64
: 1 byteSysV64
: 1 bytePtxKernel
: 0 bytesMsp430Interrupt
: 0 bytesX86Interrupt
: 0 bytesEfiApi
: 0 bytesAvrInterrupt
: 0 bytesAvrNonBlockingInterrupt
: 0 bytesCCmseNonSecureCall
: 0 bytesCCmseNonSecureEntry
: 0 bytesSystem
: 1 byteRustIntrinsic
: 0 bytesRustCall
: 0 bytesUnadjusted
: 0 bytesRustCold
: 0 bytesRiscvInterruptM
: 0 bytesRiscvInterruptS
: 0 bytes