Enum cranelift_codegen::ir::GlobalValueData
source · [−]pub enum GlobalValueData {
VMContext,
Load {
base: GlobalValue,
offset: Offset32,
global_type: Type,
readonly: bool,
},
IAddImm {
base: GlobalValue,
offset: Imm64,
global_type: Type,
},
Symbol {
name: ExternalName,
offset: Imm64,
colocated: bool,
tls: bool,
},
}
Expand description
Information about a global value declaration.
Variants
VMContext
Value is the address of the VM context struct.
Load
Fields
base: GlobalValue
The base pointer global value.
offset: Offset32
Offset added to the base pointer before doing the load.
global_type: Type
Type of the loaded value.
readonly: bool
Specifies whether the memory that this refers to is readonly, allowing for the elimination of redundant loads.
Value is pointed to by another global value.
The base
global value is assumed to contain a pointer. This global value is computed
by loading from memory at that pointer value. The memory must be accessible, and
naturally aligned to hold a value of the type. The data at this address is assumed
to never change while the current function is executing.
IAddImm
Fields
base: GlobalValue
The base pointer global value.
offset: Imm64
Byte offset to be added to the value.
global_type: Type
Type of the iadd.
Value is an offset from another global value.
Symbol
Fields
name: ExternalName
The symbolic name.
offset: Imm64
Offset from the symbol. This can be used instead of IAddImm to represent folding an offset into a symbol.
colocated: bool
Will this symbol be defined nearby, such that it will always be a certain distance away, after linking? If so, references to it can avoid going through a GOT. Note that symbols meant to be preemptible cannot be colocated.
If true
, some backends may use relocation forms that have limited range: for example,
a +/- 2^27-byte range on AArch64. See the documentation for
RelocDistance
for more details.
tls: bool
Does this symbol refer to a thread local storage value?
Value is symbolic, meaning it’s a name which will be resolved to an actual value later (eg. by linking). Cranelift itself does not interpret this name; it’s used by embedders to link with other data structures.
For now, symbolic values always have pointer type, and represent addresses, however in the future they could be used to represent other things as well.
Implementations
sourceimpl GlobalValueData
impl GlobalValueData
sourcepub fn symbol_name(&self) -> &ExternalName
pub fn symbol_name(&self) -> &ExternalName
Assume that self
is an GlobalValueData::Symbol
and return its name.
sourcepub fn global_type(&self, isa: &dyn TargetIsa) -> Type
pub fn global_type(&self, isa: &dyn TargetIsa) -> Type
Return the type of this global.
sourcepub fn maybe_reloc_distance(&self) -> Option<RelocDistance>
pub fn maybe_reloc_distance(&self) -> Option<RelocDistance>
If this global references a symbol, return an estimate of the relocation distance,
based on the colocated
flag.
Trait Implementations
sourceimpl Clone for GlobalValueData
impl Clone for GlobalValueData
sourcefn clone(&self) -> GlobalValueData
fn clone(&self) -> GlobalValueData
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
Auto Trait Implementations
impl RefUnwindSafe for GlobalValueData
impl Send for GlobalValueData
impl Sync for GlobalValueData
impl Unpin for GlobalValueData
impl UnwindSafe for GlobalValueData
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more