16 releases
0.4.6 | Aug 27, 2024 |
---|---|
0.4.5 | Aug 2, 2024 |
0.4.3 | Jun 17, 2024 |
0.4.1 | Apr 29, 2024 |
0.1.1 | Feb 28, 2024 |
#107 in No standard library
1,035 downloads per month
81KB
2K
SLoC
MicroRTU SDK
Provides utilities to create wasm blocks for MicroRTU.
Documentation can be generated via cargo doc --open
command.
lib.rs
:
MicroRTU SDK
Provides utilities to create wasm blocks for MicroRTU.
Example
This is a basic example of a block that adds two numbers.
use micrortu_sdk::{
params, ports, register_block, Shared, StepResult, FactoryInput
};
use static_cell::StaticCell;
pub struct Counter;
ports! {
#[block_names(counter)]
pub struct Ports {
count: TI13 InOut 1 1,
}
}
params! {
#[block_names(counter)]
pub struct Params {}
}
pub fn factory(_: &mut FactoryInput) -> Option<&'static mut Counter> {
static COUTNER: StaticCell<Counter> = StaticCell::new();
Some(COUTNER.init(Counter))
}
pub fn init(_: &mut Shared, _: &mut Counter) -> StepResult {
0
}
pub fn step(shared: &mut Shared, _: &mut Counter) -> StepResult {
let mut ports = Ports::parse(&mut shared.latched_ports[..]);
ports.count.value += 1.;
0
}
register_block!(Counter, counter, factory, init, step);
WASM Binary Layout
To define block block_name
, that can be later referenced in MicroRTU
configuration, you need export 3 functions from your final wasm blob.
Required Exports
init
init
function with signature () -> ()
.
SHARED
SHARED
symbol, aligned to 8 bytes, and must be valid
for reads and writes for at least 512 bytes.
COLLECTED_STRINGS
It should be &[u8]
, which is a pointer to the start and length of the slice.
It should point to all names of the ports and params, concatenated.
name_offset
and name_len
are relative to this slice.
factory_{block_name}
factory_{block_name}
is a function that will be called to produce a wasm block.
It's signature should be (i32) -> i32
and code must ensure it follows Rust's
semantics of that signagure:
for<'a> extern "C" fn(&'a FactoryInput) -> Option<&'static mut BlockName>;
Where BlockName
is your block's type.
init_{block_name}
init_{block_name}
is a function that will be called before step
. It's
signature should be (i32, i32) -> i32
and code must ensure it follows Rust's
semantics of that signagure:
for<'a> extern "C" fn(&'a mut Shared, &'a mut BlockName) -> StepResult;
step_{block_name}
step_{block_name}
is a function that will be called to make a "step". It's
signature should be (i32, i32) -> i32
and code must ensure it follows Rust's
semantics of that signature:
for<'a> extern "C" fn(&'a mut Shared, &'a mut BlockName) -> StepResult;
ports_{block_name}
and params_{block_name}
There also must be exports for ports and params of type &[BindingDefinition]
,
which is [i32; 2] in memory - pointer to the start and length of the slice.
Dependencies
~14MB
~274K SLoC