TunePulse is an upcoming open-source firmware designed to:
- Control a wide range of motors (
DC
,STEPPERS
,BLDC
,PMSM
,LINEAR
) - Operate across various control modes (
CLOSED-LOOP
,FOC
,POSITION
,SPEED
,TORQUE
, etc.) - Feature compatibility with multiple interfaces (
STEP-DIR
,UART
,I2C
,CAN/CAN-FD
,USB
) - Support various protocols (
GCODE
,KLIPPER
, etc.)
Its primary goal is to advance the development of closed-loop systems and simplify their integration into existing 32bit MCU applications.
Note: This firmware is under active development and currently lacks documentation. For more information, join the Creapunk community on Discord.
To get started with TunePulse, ensure you have the required Rust tools installed:
rustup target add thumbv7em-none-eabihf
cargo install flip-link
For using the rtt plotter, you will need a downgraded version of probe-rs. To get it run the following commands:
rustup default 1.79.0
cargo update
cargo install probe-rs --locked --features cli --version 0.21.1 --force
After that, you can upgrade rust to the latest version or perfered version again.
For additional setup instructions, see the Probe.rs Installation Guide and Probe Setup Guide.
- Connect the ST-Link port to your computer and run the updater downloaded from the official ST-Link website.
- Plug the controller into the programmer's single port and flash the blink example for testing:
cargo flash --release --package blink --chip STM32G431CBTx
After flashing, the controller should cycle through the Red, Green, and Blue LEDs.
Optional: Install the Probe.rs Debugger extension for VSCode.
- Connect your computer to the ST-Link port on the programmer.
- Connect the controller to the programmer's single port.
- Run the following command to flash main firmware to CLN17 V2:
cargo run --package app
or this if you whant to get access to debug messages (tested on Windows PowerShell)
$env:DEFMT_LOG = "debug"; cargo run --package app
If you want to use the RTT plotter, you can find it in the tools/plotter
directory. It runs off of a seprate workspace so it can be compiled on a host platform. You will need to edit the .cargo/config.toml
file in the tools/plotter
directory to match your host platform. Then you can run the cargo run
command to start the plotter.
- Non-blocking Operation: Avoid the use of
delay
and other blocking functions to ensure maximum performance for secondary systems. - Interrupt-driven Telemetry Updates: System telemetry is updated at fixed periodic intervals using interrupts, reducing the need for frequent checks and ensuring predictable, high-speed operation.
- Data Normalization: Normalize data wherever possible to minimize the need for additional checks.
- Integer/Fixed-point Arithmetic: Use integer or fixed-point mathematics wherever feasible, avoiding significant overhead, to maintain high performance across all controllers.
- Optimized Computations: Minimize type conversions and optimize calculations for efficiency.
- Modular Design: Divide the system into fundamental functional blocks whenever possible for better maintainability.
- Separation of Concerns: Keep mathematical operations, algorithms, and hardware drivers in distinct parts of the codebase to enhance clarity and modularity.
- ☑️ PID controller with a FeedForward component (integer and floating-point implementations)
- ☑️ Integer-math LPF filter with handling zero-crossing transitions
- ☑️ Encoder coordinate system with zero-crossing handling and full rotation counting
- ☑️ Calculation of motor instantaneous speed using a circular buffer
- ☑️ Normalization of ADC input channels relative to
vref
- ☑️ Calculation of supply voltage with filtering
- ☑️ Motor type selection algorithm via selector:
- ☑️ DC motor
- ☑️ Stepper motor
- ☑️ BLDC motor (SVPWM with limiting for insufficient supply voltage)
- ☑️ Phase commutation algorithm based on a predefined pattern
- ☑️ Fast sine/cosine calculation via lookup table
- ☑️ Pole count calculation
- ☑️ Direction detection
- ☑️ Linearity check
- ☑️ Lookup calibration table
- ☑️ PWM center-aligned timer
- ☑️ Encoder readings with DMA
- ☑️ ADC voltage and current readings with DMA