Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samcrow/cmsis_dsp.rs
Rust bindings to the CMSIS-DSP library for Cortex-M processors
https://github.com/samcrow/cmsis_dsp.rs
Last synced: 3 months ago
JSON representation
Rust bindings to the CMSIS-DSP library for Cortex-M processors
- Host: GitHub
- URL: https://github.com/samcrow/cmsis_dsp.rs
- Owner: samcrow
- License: 0bsd
- Created: 2021-01-25T22:48:48.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2021-12-16T08:27:06.000Z (about 3 years ago)
- Last Synced: 2024-09-13T22:46:25.366Z (4 months ago)
- Language: C
- Size: 17.1 MB
- Stars: 14
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# CMSIS-DSP bindings
The CMSIS-DSP library provides "a suite of common signal processing functions for use on Cortex-M and Cortex-A processor
based devices."This package provides Rust bindings to CMSIS-DSP for Cortex-M0, M0+, M3, M4, M7, M23, and M33 devices.
## Supported features
High-level bindings are currently provided for basic functions and fast Fourier transforms. The CMSIS-DSP library also
has other functionality, but nobody has written Rust bindings for it yet.### Limitations
#### Inline functions
Some CMSIS-DSP functions, like `arm_sqrt_f32`, are defined inline in the header files and are missing from the compiled
libraries. This package currently does not provide those functions.#### Basic C math functions
Some CMSIS-DSP functions depend on math functions from the C standard library, like `sqrtf`. These C standard library
math functions are not included in the CMSIS-DSP libraries. This may cause linker errors like this:```
= note: rust-lld: error: undefined symbol: sqrtf
>>> referenced by arm_math.h:6841 (../../Include/arm_math.h:6841)
>>> arm_cmplx_mag_f32.o:(arm_cmplx_mag_f32) in archive /path/cmsis_dsp_sys/ARM.CMSIS.5.7.0/CMSIS/DSP/Lib/GCC/libarm_cortexM4lf_math.a
>>> referenced by arm_math.h:6841 (../../Include/arm_math.h:6841)
>>> arm_cmplx_mag_f32.o:(arm_cmplx_mag_f32) in archive /path/cmsis_dsp_sys/ARM.CMSIS.5.7.0/CMSIS/DSP/Lib/GCC/libarm_cortexM4lf_math.a
>>> referenced by arm_math.h:6841 (../../Include/arm_math.h:6841)
>>> arm_cmplx_mag_f32.o:(arm_cmplx_mag_f32) in archive /path/cmsis_dsp_sys/ARM.CMSIS.5.7.0/CMSIS/DSP/Lib/GCC/libarm_cortexM4lf_math.a
>>> referenced 4 more times
```The easiest way to fix this is to enable the `libm` or `micromath` feature on the `cmsis_dsp` package.
This will add a dependency on [libm](https://crates.io/crates/libm) or [micromath](https://crates.io/crates/micromath)
and implement some of the C standard library math functions.The `libm` library implements more functions than `micromath`. Its implementations may be more precise but take up
more code space.If both `libm` and `micromath` features are enabled, the `libm` implementations will be used.
Alternatively, you can implement only the functions you need with an implementation of your choice, for example:
```rust
#[no_mangle]
pub extern "C" fn sqrtf(value: f32) -> f32 {
// Implementation goes here
}
```## Configuring the bindings
Different versions of the library will be linked depending on the type of processor the code will run on.
You may need to enable some Cargo features depending on the target:* Cortex-M7: Enable the feature `cortex-m7`. Also, if the processor has a double-precision floating point unit, enable
the `double-precision-fpu` feature.
* Cortex-M33 (target `thumbv8m.main-none-eabi` or `thumbv8m.main-none-eabihf`): If the processor supports DSP
instructions, enable the `dsp-instructions` feature
All other options will be configured automatically based on the target passed to cargo. If you forget to enable a
feature, everything should still work but it may be slower.## Licensing
ARM provides the CMSIS-DSP library under the Apache license 2.0. This package of bindings (cmsis_dsp and
cmsis_dsp_sys_pregenerated) is released under the 0-clause BSD license, which is extremely permissive and does not
require attribution. This means that using CMSIS-DSP in Rust does not require any more license compliance work than
using CMSIS-DSP in C.## Links
* [CMSIS information page](https://www.arm.com/why-arm/technologies/cmsis)
* [CMSIS GitHub repository](https://github.com/ARM-software/CMSIS_5/)
* [CMSIS-DSP documentation](https://arm-software.github.io/CMSIS_5/DSP/html/index.html)