[−][src]Trait cranelift_module::Module
A Module is a utility for collecting functions and data objects, and linking them together.
Required methods
fn isa(&self) -> &dyn TargetIsa
Return the TargetIsa to compile for.
fn declarations(&self) -> &ModuleDeclarations
Get all declarations in this module.
fn declare_function(
&mut self,
name: &str,
linkage: Linkage,
signature: &Signature
) -> ModuleResult<FuncId>
&mut self,
name: &str,
linkage: Linkage,
signature: &Signature
) -> ModuleResult<FuncId>
Declare a function in this module.
fn declare_data(
&mut self,
name: &str,
linkage: Linkage,
writable: bool,
tls: bool
) -> ModuleResult<DataId>
&mut self,
name: &str,
linkage: Linkage,
writable: bool,
tls: bool
) -> ModuleResult<DataId>
Declare a data object in this module.
fn define_function<TS>(
&mut self,
func: FuncId,
ctx: &mut Context,
trap_sink: &mut TS
) -> ModuleResult<ModuleCompiledFunction> where
TS: TrapSink,
&mut self,
func: FuncId,
ctx: &mut Context,
trap_sink: &mut TS
) -> ModuleResult<ModuleCompiledFunction> where
TS: TrapSink,
Define a function, producing the function body from the given Context.
Returns the size of the function's code and constant data.
Note: After calling this function the given Context will contain the compiled function.
fn define_function_bytes(
&mut self,
func: FuncId,
bytes: &[u8]
) -> ModuleResult<ModuleCompiledFunction>
&mut self,
func: FuncId,
bytes: &[u8]
) -> ModuleResult<ModuleCompiledFunction>
Define a function, taking the function body from the given bytes.
This function is generally only useful if you need to precisely specify
the emitted instructions for some reason; otherwise, you should use
define_function.
Returns the size of the function's code.
fn define_data(
&mut self,
data: DataId,
data_ctx: &DataContext
) -> ModuleResult<()>
&mut self,
data: DataId,
data_ctx: &DataContext
) -> ModuleResult<()>
Define a data object, producing the data contents from the given DataContext.
Provided methods
fn get_name(&self, name: &str) -> Option<FuncOrDataId>
Get the module identifier for a given name, if that name has been declared.
fn target_config(&self) -> TargetFrontendConfig
Return the target information needed by frontends to produce Cranelift IR for the current target.
fn make_context(&self) -> Context
Create a new Context initialized for use with this Module.
This ensures that the Context is initialized with the default calling
convention for the TargetIsa.
fn clear_context(&self, ctx: &mut Context)
Clear the given Context and reset it for use with a new function.
This ensures that the Context is initialized with the default calling
convention for the TargetIsa.
fn make_signature(&self) -> Signature
Create a new empty Signature with the default calling convention for
the TargetIsa, to which parameter and return types can be added for
declaring a function to be called by this Module.
fn clear_signature(&self, sig: &mut Signature)
Clear the given Signature and reset for use with a new function.
This ensures that the Signature is initialized with the default
calling convention for the TargetIsa.
fn declare_func_in_func(&self, func: FuncId, in_func: &mut Function) -> FuncRef
Use this when you're building the IR of a function to reference a function.
TODO: Coalesce redundant decls and signatures. TODO: Look into ways to reduce the risk of using a FuncRef in the wrong function.
fn declare_data_in_func(&self, data: DataId, func: &mut Function) -> GlobalValue
Use this when you're building the IR of a function to reference a data object.
TODO: Same as above.
fn declare_func_in_data(&self, func: FuncId, ctx: &mut DataContext) -> FuncRef
TODO: Same as above.
fn declare_data_in_data(
&self,
data: DataId,
ctx: &mut DataContext
) -> GlobalValue
&self,
data: DataId,
ctx: &mut DataContext
) -> GlobalValue
TODO: Same as above.