Crates.io | ev3dev-lang-rust |
lib.rs | ev3dev-lang-rust |
version | 0.14.0 |
source | src |
created_at | 2018-09-19 13:44:22.543246 |
updated_at | 2024-02-25 06:38:32.304876 |
description | Rust language bindings for ev3dev |
homepage | |
repository | https://github.com/pixix4/ev3dev-lang-rust |
max_upload_size | |
id | 85487 |
size | 216,209 |
To use this project with the BrickPi platform the corresponding feature has to be enabled. The features ev3
, brickpi
and brickpi3
are mutual exclusive.
[dependencies]
ev3dev_lang_rust = { version="0.13.0" default-features=false, features=["brickpi"] }
extern crate ev3dev_lang_rust;
use ev3dev_lang_rust::Ev3Result;
use ev3dev_lang_rust::motors::{LargeMotor, MotorPort};
use ev3dev_lang_rust::sensors::ColorSensor;
fn main() -> Ev3Result<()> {
// Get large motor on port outA.
let large_motor = LargeMotor::get(MotorPort::OutA)?;
// Set command "run-direct".
large_motor.run_direct()?;
// Run motor.
large_motor.set_duty_cycle_sp(50)?;
// Find color sensor. Always returns the first recognized one.
let color_sensor = ColorSensor::find()?;
// Switch to rgb mode.
color_sensor.set_mode_rgb_raw()?;
// Get current rgb color tuple.
println!("Current rgb color: {:?}", color_sensor.get_rgb()?);
Ok(())
}
There is a template repository that contains all the required configurations for cross-compilation and performance/binary-size optimizations for this "Hello World" example.
LargeMotor
[lego-ev3-l-motor
, lego-nxt-motor
]MediumMotor
[lego-ev3-m-motor
]TachoMotor
: Useful wrapper around LargeMotor
and MediumMotor
to make common functions easier to useColorSensor
[lego-ev3-color
]CompassSensor
[ht-nxt-compass
]GyroSensor
[lego-ev3-gyro
]InfraredSensor
[lego-ev3-ir
]IrSeekerSensor
[ht-nxt-ir-seek-v2
]LightSensor
[lego-nxt-light
]TouchSensor
[lego-ev3-touch
, lego-nxt-touch
]UltrasonicSensor
[lego-ev3-us
, lego-nxt-us
]Button
: Provides access to the integrated buttons on the ev3 brickLed
: Provides access to the integrated led's on the ev3 brickPowerSupply
: Provides access to the power supply informationScreen
: Provides access to the integrated display of the ev3 bricksound
: Provides access to the integrated speakers of the ev3 brickmusl
toolchainInstall the armv5te-musl
toolchain
rustup target add armv5te-unknown-linux-musleabi
Create .cargo/config.toml
with the following content
[build]
target = "armv5te-unknown-linux-musleabi"
[target.armv5te-unknown-linux-musleabi]
linker = "rust-lld"
Build binary
cargo build --release
The --release
flag is optional. However, it can speed up the execution time by a factor of 30.
The target binary is now in target/armv5te-unknown-linux-musleabi/release/{application_name}
.
If you need to cross compile other dependencies (eg. openssl
or paho-mqtt
) it is much easier to use a complete cross compile toolchain. For this you can use the provided docker image pixix4/ev3dev-rust:latest
.
Setup a docker environment
Create .cargo/config.toml
with the following content
[build]
target = "armv5te-unknown-linux-gnueabi"
[target.armv5te-unknown-linux-gnueabi]
linker = "/usr/bin/arm-linux-gnueabi-gcc"
Build binary
docker run --rm -it -v $(pwd):/build -w /build pixix4/ev3dev-rust:latest \
cargo build --release
The --release
flag is optional. However, it can speed up the execution time by a factor of 30.
The target binary is now in target/armv5te-unknown-linux-gnueabi/release/{application_name}
.
If you do this you will notice that each build gets stuck at Updating crates.io index
for a long time. To speed up this step you can use the vendoring mechanic of cargo.
cargo vendor
Execute the above command and add this additional config to .cargo/config
.
[source.crates-io]
replace-with = "vendored-sources"
[source.vendored-sources]
directory = "vendor"
Enable "fat" link time optimizations and strip debug symbols:
By default rust only performs lto for each crate individually. To enable global lto (which result in a much more aggressive dead code elimination) add the following additional config to your Cargo.toml
. This also removes additional debug symbols from the binary. With this you can reduce the binary size of the "Hello World" example by more than 90%.
[profile.release]
lto = true
strip = "debuginfo"
The strip option requires rust 1.59.0
. If you are using an older version you can do this manually with docker:
# Run in interactive docker shell
docker run -it --rm -v $(PWD):/build/ -w /build pixix4/ev3dev-rust
/usr/bin/arm-linux-gnueabi-strip /build/target/armv5te-unknown-linux-gnueabi/release/{application_name}
# Run directly (e.g. via Makefile)
docker run --rm -v $(PWD):/build/ -w /build pixix4/ev3dev-rust \
/usr/bin/arm-linux-gnueabi-strip /build/target/armv5te-unknown-linux-gnueabi/release/{application_name}
If you have problems with code completion or inline documentation with rust analyzer it may help to enable to following settings:
{
"rust-analyzer.cargo.loadOutDirsFromCheck": true,
"rust-analyzer.procMacro.enable": true
}
(Example from VSCode settings.json
)
To build the complete documentation (including the screen
feature) use:
RUSTDOCFLAGS="--cfg docsrs" cargo +nightly doc --features ev3,screen