blob: b1e12028bd32e0c6479716fe182e7a9b873ac6cc [file] [view]
[![Build Status](https://travis-ci.org/tock/libtock-rs.svg?branch=master)](https://travis-ci.org/tock/libtock-rs)
# libtock-rs
Rust userland library for Tock (WIP)
Tested with tock [Release 1.4.1](https://github.com/tock/tock/commit/7e37bf67761d83fd585cace4fb201e2864d300b1).
The library works in principle on most boards, but there is currently the [showstopper
bug #28](https://github.com/tock/libtock-rs/issues/28) that prevents
the generation of relocatable code. This means that all applications
must be installed at the flash address they are compiled with, which
usually means that they must be compiled especially for your board
and that there can only be one application written in rust at a time
and it must be installed as the first application on the board, unless
you want to play games with linker scripts.
There are some `*_layout.ld` files provided that allow to run the
examples on common boards.
Due to MPU region alignment issues they may not work for applications
that use a lot of RAM, in that case you may have to change the SRAM
start address to fit your application.
## Getting Started
This project is nascent and still under heavy development, but first steps:
1. Ensure you have [rustup](https://www.rustup.rs/) installed.
1. Clone the repository.
```bash
git clone https://github.com/tock/libtock-rs
cd libtock-rs
```
1. Install `elf2tab`.
```bash
cargo install -f elf2tab --version 0.4.0
```
1. Add dependencies for cross-compilation.
```bash
rustup target add thumbv7em-none-eabi
```
1. Use the `run_example` script to compile and run the example app you want
to use:
```bash
./run_example.sh blink
```
Due to bug #28 this will currently only work if you are using the nRF52-DK platform.
If you have a nRF52840-DK you must change `link-arg=-Tnrf52_layout.ld` in
`.cargo/config` to `link-arg=-Tnrf52840_layout.ld`
If you have a hail board you can flash your device as follows:
- set the environment variable `hail` to `1`
- change `link-arg=-Tnrf52_layout.ld` in `.cargo/config` to `link-arg=-Thail_layout.ld`
- run `run_example.sh` as above.
For other platforms, you may have to create your own memory layout definition.
## Using libtock-rs
The easiest way to start using libtock-rs is adding an example to the examples folder.
The boiler plate code you would write is
```rust
#![no_std]
use libtock::result::TockResult;
#[libtock::main]
async fn main() -> TockResult<()> {
// Your code
}
```
If you want to use heap based allocation you will have to add
```rust
extern crate alloc;
```
to the preamble.
To run on the code on your board you can use
```bash
./run_example.sh <your app>
```
This script does the following steps for you:
- cross-compile your program
- create a TAB (tock application bundle)
- if you have a nRF52-DK board connected: flash this TAB to your board (using tockloader)
## License
Licensed under either of
- Apache License, Version 2.0
([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license
([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.
The contribution guidelines can be found here: [contribution guidelines](CONTRIBUTING.md)