rustc_target::abi::call

Struct ArgAbi

source
pub struct ArgAbi<'a, Ty> {
    pub layout: TyAndLayout<'a, Ty>,
    pub mode: PassMode,
}
Expand description

Information about how to pass an argument to, or return a value from, a function, under some ABI.

Fields§

§layout: TyAndLayout<'a, Ty>§mode: PassMode

Implementations§

source§

impl<'a, Ty> ArgAbi<'a, Ty>

source

pub fn new( cx: &impl HasDataLayout, layout: TyAndLayout<'a, Ty>, scalar_attrs: impl Fn(&TyAndLayout<'a, Ty>, Scalar, Size) -> ArgAttributes, ) -> Self

This defines the “default ABI” for that type, that is then later adjusted in fn_abi_adjust_for_abi.

source

fn indirect_pass_mode(layout: &TyAndLayout<'a, Ty>) -> PassMode

source

pub fn make_direct_deprecated(&mut self)

Pass this argument directly instead. Should NOT be used! Only exists because of past ABI mistakes that will take time to fix (see https://github.com/rust-lang/rust/issues/115666).

source

pub fn make_indirect(&mut self)

Pass this argument indirectly, by passing a (thin or wide) pointer to the argument instead. This is valid for both sized and unsized arguments.

source

pub fn make_indirect_from_ignore(&mut self)

Same as make_indirect, but for arguments that are ignored. Only needed for ABIs that pass ZSTs indirectly.

source

pub fn pass_by_stack_offset(&mut self, byval_align: Option<Align>)

Pass this argument indirectly, by placing it at a fixed stack offset. This corresponds to the byval LLVM argument attribute. This is only valid for sized arguments.

byval_align specifies the alignment of the byval stack slot, which does not need to correspond to the type’s alignment. This will be Some if the target’s ABI specifies that stack slots used for arguments passed by-value have specific alignment requirements which differ from the alignment used in other situations.

If None, the type’s alignment is used.

If the resulting alignment differs from the type’s alignment, the argument will be copied to an alloca with sufficient alignment, either in the caller (if the type’s alignment is lower than the byval alignment) or in the callee (if the type’s alignment is higher than the byval alignment), to ensure that Rust code never sees an underaligned pointer.

source

pub fn extend_integer_width_to(&mut self, bits: u64)

source

pub fn cast_to<T: Into<CastTarget>>(&mut self, target: T)

source

pub fn cast_to_and_pad_i32<T: Into<CastTarget>>( &mut self, target: T, pad_i32: bool, )

source

pub fn is_indirect(&self) -> bool

source

pub fn is_sized_indirect(&self) -> bool

source

pub fn is_unsized_indirect(&self) -> bool

source

pub fn is_ignore(&self) -> bool

source

pub fn eq_abi(&self, other: &Self) -> bool
where Ty: PartialEq,

Checks if these two ArgAbi are equal enough to be considered “the same for all function call ABIs”.

Trait Implementations§

source§

impl<'a, Ty: Clone> Clone for ArgAbi<'a, Ty>

source§

fn clone(&self) -> ArgAbi<'a, Ty>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<'a, Ty: Display> Debug for ArgAbi<'a, Ty>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'a, Ty: Hash> Hash for ArgAbi<'a, Ty>

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<'a, Ty, __CTX> HashStable<__CTX> for ArgAbi<'a, Ty>
where __CTX: HashStableContext, Ty: HashStable<__CTX>,

source§

fn hash_stable(&self, __hcx: &mut __CTX, __hasher: &mut StableHasher)

source§

impl<'a, Ty: PartialEq> PartialEq for ArgAbi<'a, Ty>

source§

fn eq(&self, other: &ArgAbi<'a, Ty>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'a, Ty: Eq> Eq for ArgAbi<'a, Ty>

source§

impl<'a, Ty> StructuralPartialEq for ArgAbi<'a, Ty>

Auto Trait Implementations§

§

impl<'a, Ty> Freeze for ArgAbi<'a, Ty>
where Ty: Freeze,

§

impl<'a, Ty> RefUnwindSafe for ArgAbi<'a, Ty>
where Ty: RefUnwindSafe,

§

impl<'a, Ty> Send for ArgAbi<'a, Ty>
where Ty: Send,

§

impl<'a, Ty> Sync for ArgAbi<'a, Ty>
where Ty: Sync,

§

impl<'a, Ty> Unpin for ArgAbi<'a, Ty>
where Ty: Unpin,

§

impl<'a, Ty> UnwindSafe for ArgAbi<'a, Ty>
where Ty: UnwindSafe,

Blanket Implementations§

source§

impl<T> Aligned for T

source§

const ALIGN: Alignment = _

Alignment of Self.
source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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 more
source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<'a, T> Captures<'a> for T
where T: ?Sized,

Layout§

Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.