[−][src]Struct rustc_ap_rustc_target::abi::TargetDataLayout
Parsed Data layout for a target, which contains everything needed to compute layouts.
Fields
endian: Endian
i1_align: AbiAndPrefAlign
i8_align: AbiAndPrefAlign
i16_align: AbiAndPrefAlign
i32_align: AbiAndPrefAlign
i64_align: AbiAndPrefAlign
i128_align: AbiAndPrefAlign
f32_align: AbiAndPrefAlign
f64_align: AbiAndPrefAlign
pointer_size: Size
pointer_align: AbiAndPrefAlign
aggregate_align: AbiAndPrefAlign
vector_align: Vec<(Size, AbiAndPrefAlign)>
Alignments for vector types.
instruction_address_space: u32
Methods
impl TargetDataLayout
[src]
pub fn parse(target: &Target) -> Result<TargetDataLayout, String>
[src]
pub fn obj_size_bound(&self) -> u64
[src]
Returns exclusive upper bound on object size.
The theoretical maximum object size is defined as the maximum positive isize
value.
This ensures that the offset
semantics remain well-defined by allowing it to correctly
index every address within an object along with one byte past the end, along with allowing
isize
to store the difference between any two pointers into an object.
The upper bound on 64-bit currently needs to be lower because LLVM uses a 64-bit integer to represent object size in bits. It would need to be 1 << 61 to account for this, but is currently conservatively bounded to 1 << 47 as that is enough to cover the current usable address space on 64-bit ARMv8 and x86_64.
pub fn ptr_sized_integer(&self) -> Integer
[src]
pub fn vector_align(&self, vec_size: Size) -> AbiAndPrefAlign
[src]
Trait Implementations
impl Default for TargetDataLayout
[src]
fn default() -> TargetDataLayout
[src]
Creates an instance of TargetDataLayout
.
impl HasDataLayout for TargetDataLayout
[src]
fn data_layout(&self) -> &TargetDataLayout
[src]
Auto Trait Implementations
impl RefUnwindSafe for TargetDataLayout
impl Send for TargetDataLayout
impl Sync for TargetDataLayout
impl Unpin for TargetDataLayout
impl UnwindSafe for TargetDataLayout
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<'a, T> Captures<'a> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Erased for T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> MaybeResult<T> for T
[src]
type Error = !
fn from(Result<T, <T as MaybeResult<T>>::Error>) -> T
[src]
fn to_result(Self) -> Result<T, <T as MaybeResult<T>>::Error>
[src]
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<E> SpecializationError for E
[src]
default fn not_found<S, T>(
trait_name: &'static str,
method_name: &'static str
) -> E where
T: ?Sized,
[src]
trait_name: &'static str,
method_name: &'static str
) -> E where
T: ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,