Struct cranelift_codegen::settings::Flags
source · [−]pub struct Flags { /* private fields */ }
Expand description
Flags group shared
.
Implementations
sourceimpl Flags
impl Flags
User-defined settings.
sourcepub fn predicate_view(&self) -> PredicateView<'_>
pub fn predicate_view(&self) -> PredicateView<'_>
Get a view of the boolean predicates.
sourcepub fn regalloc(&self) -> Regalloc
pub fn regalloc(&self) -> Regalloc
Register allocator to use with the MachInst backend.
This selects the register allocator as an option among those offered by the regalloc.rs
crate. Please report register allocation bugs to the maintainers of this crate whenever
possible.
Note: this only applies to target that use the MachInst backend. As of 2020-04-17, this means the x86_64 backend doesn’t use this yet.
Possible values:
backtracking
is a greedy, backtracking register allocator as implemented in Spidermonkey’s optimizing tier IonMonkey. It may take more time to allocate registers, but it should generate better code in general, resulting in better throughput of generated code.backtracking_checked
is the backtracking allocator with additional self checks that may take some time to run, and thus these checks are disabled by default.experimental_linear_scan
is an experimental linear scan allocator. It may take less time to allocate registers, but generated code’s quality may be inferior. As of 2020-04-17, it is still experimental and it should not be used in production settings.experimental_linear_scan_checked
is the linear scan allocator with additional self checks that may take some time to run, and thus these checks are disabled by default.
sourcepub fn opt_level(&self) -> OptLevel
pub fn opt_level(&self) -> OptLevel
Optimization level:
- none: Minimise compile time by disabling most optimizations.
- speed: Generate the fastest possible code
- speed_and_size: like “speed”, but also perform transformations aimed at reducing code size.
sourcepub fn libcall_call_conv(&self) -> LibcallCallConv
pub fn libcall_call_conv(&self) -> LibcallCallConv
Defines the calling convention to use for LibCalls call expansion, since it may be different from the ISA default calling convention.
The default value is to use the same calling convention as the ISA default calling convention.
This list should be kept in sync with the list of calling conventions available in isa/call_conv.rs.
sourcepub fn baldrdash_prologue_words(&self) -> u8
pub fn baldrdash_prologue_words(&self) -> u8
Number of pointer-sized words pushed by the baldrdash prologue.
Functions with the baldrdash
calling convention don’t generate their
own prologue and epilogue. They depend on externally generated code
that pushes a fixed number of words in the prologue and restores them
in the epilogue.
This setting configures the number of pointer-sized words pushed on the stack when the Cranelift-generated code is entered. This includes the pushed return address on x86.
sourcepub fn probestack_size_log2(&self) -> u8
pub fn probestack_size_log2(&self) -> u8
The log2 of the size of the stack guard region.
Stack frames larger than this size will have stack overflow checked by calling the probestack function.
The default is 12, which translates to a size of 4096.
sourcepub fn enable_verifier(&self) -> bool
pub fn enable_verifier(&self) -> bool
Run the Cranelift IR verifier at strategic times during compilation.
This makes compilation slower but catches many bugs. The verifier is always enabled by default, which is useful during development.
sourcepub fn use_colocated_libcalls(&self) -> bool
pub fn use_colocated_libcalls(&self) -> bool
Use colocated libcalls.
Generate code that assumes that libcalls can be declared “colocated”, meaning they will be defined along with the current function, such that they can use more efficient addressing.
sourcepub fn avoid_div_traps(&self) -> bool
pub fn avoid_div_traps(&self) -> bool
Generate explicit checks around native division instructions to avoid their trapping.
This is primarily used by SpiderMonkey which doesn’t install a signal handler for SIGFPE, but expects a SIGILL trap for division by zero.
On ISAs like ARM where the native division instructions don’t trap, this setting has no effect - explicit checks are always inserted.
sourcepub fn enable_float(&self) -> bool
pub fn enable_float(&self) -> bool
Enable the use of floating-point instructions
Disabling use of floating-point instructions is not yet implemented.
sourcepub fn enable_nan_canonicalization(&self) -> bool
pub fn enable_nan_canonicalization(&self) -> bool
Enable NaN canonicalization
This replaces NaNs with a single canonical value, for users requiring entirely deterministic WebAssembly computation. This is not required by the WebAssembly spec, so it is not enabled by default.
sourcepub fn enable_pinned_reg(&self) -> bool
pub fn enable_pinned_reg(&self) -> bool
Enable the use of the pinned register.
This register is excluded from register allocation, and is completely under the control of the end-user. It is possible to read it via the get_pinned_reg instruction, and to set it with the set_pinned_reg instruction.
sourcepub fn use_pinned_reg_as_heap_base(&self) -> bool
pub fn use_pinned_reg_as_heap_base(&self) -> bool
Use the pinned register as the heap base.
Enabling this requires the enable_pinned_reg setting to be set to true. It enables a custom
legalization of the heap_addr
instruction so it will use the pinned register as the heap
base, instead of fetching it from a global value.
Warning! Enabling this means that the pinned register must be maintained to contain the heap base address at all times, during the lifetime of a function. Using the pinned register for other purposes when this is set is very likely to cause crashes.
sourcepub fn enable_simd(&self) -> bool
pub fn enable_simd(&self) -> bool
Enable the use of SIMD instructions.
sourcepub fn enable_atomics(&self) -> bool
pub fn enable_atomics(&self) -> bool
Enable the use of atomic instructions
sourcepub fn enable_safepoints(&self) -> bool
pub fn enable_safepoints(&self) -> bool
Enable safepoint instruction insertions.
This will allow the emit_stack_maps() function to insert the safepoint instruction on top of calls and interrupt traps in order to display the live reference values at that point in the program.
sourcepub fn emit_all_ones_funcaddrs(&self) -> bool
pub fn emit_all_ones_funcaddrs(&self) -> bool
Emit not-yet-relocated function addresses as all-ones bit patterns.
sourcepub fn enable_probestack(&self) -> bool
pub fn enable_probestack(&self) -> bool
Enable the use of stack probes, for calling conventions which support this functionality.
sourcepub fn probestack_func_adjusts_sp(&self) -> bool
pub fn probestack_func_adjusts_sp(&self) -> bool
Set this to true of the stack probe function modifies the stack pointer itself.
sourcepub fn enable_jump_tables(&self) -> bool
pub fn enable_jump_tables(&self) -> bool
Enable the use of jump tables in generated machine code.
sourcepub fn enable_heap_access_spectre_mitigation(&self) -> bool
pub fn enable_heap_access_spectre_mitigation(&self) -> bool
Enable Spectre mitigation on heap bounds checks.
This is a no-op for any heap that needs no bounds checks; e.g., if the limit is static and the guard region is large enough that the index cannot reach past it.
This option is enabled by default because it is highly recommended for secure sandboxing. The embedder should consider the security implications carefully before disabling this option.
Trait Implementations
sourceimpl<'a> From<&'a Flags> for FlagsOrIsa<'a>
impl<'a> From<&'a Flags> for FlagsOrIsa<'a>
sourcefn from(flags: &'a Flags) -> FlagsOrIsa<'_>
fn from(flags: &'a Flags) -> FlagsOrIsa<'_>
Performs the conversion.
Auto Trait Implementations
impl RefUnwindSafe for Flags
impl Send for Flags
impl Sync for Flags
impl Unpin for Flags
impl UnwindSafe for Flags
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more