tempi 0.1.0

Control your Raspberry Pi's temperature with a fan.
tempi-0.1.0 is not a library.

Tempi

Control your Raspberry Pi's temperature with a fan.

Description

This program control a GPIO pin depending on the temperature of your CPU. It is thought of as a way to regulate the CPU's temperature by connecting a fan to the GPIO and letting the program check the temperature at a regular interval in the background.

Installation

From Crates.io

cargo install tempi

From source

First you need to install Rust. Then you can do the Rust's standard installation procedure:

git clone https://zykino.net/gitea/zykino/Tempi.git
cd Tempi
cargo build --release

If you prefer to cross-compile from a non raspberry computer I followed the manual instructions at https://mudge.name/2019/01/02/cross-compiling-rust-for-a-raspberry-pi-on-travis-ci/. Once build, transfert the binary to your target and test it.

scp target/arm-unknown-linux-gnueabihf/release/tempi pi@<YOUR_PI_IP>:<PATH_TO_WHERE_YOU_WANT_YOUR_BINARY>

Usage

To use the application you just have to start the tempi executable. If you want to use it on a daily basis, it is recommanded to start the application at logon or startup.

Configuration

The only way to configure tempi is with a configuration file. The configuration file is written in yaml, you can copy one of the examples below and twist the values as you like.
On Linux the configuration file is ~/.config/tempi/tempi.yml.

By default tempi will control the pin 18 (physical 12) in an Hysteresis mode. The configuration file corresponding is the following:

---
check_interval:
  secs: 10
  nanos: 0
mode:
  Hysteresis:               # Either Hysteresis or Pwm ith th appropriate parameters
    max_temperature: 70.0
    hysteresis: 10.0
    bcm_pin: 18
verbosity_mode: Human       # One of Human, Machine or Quiet

If you prefer using the PWM mode you first need to follow this instructions to enable PWM on your Raspberry Pi. It is also recommended to let the members of the gpio group configure PWM without being root. Then you can use and adapt the following configuration file:

---
check_interval:
  secs: 10
  nanos: 0
mode:
  Pwm:
    max_temperature: 70.0
    min_temperature: 60.0
    frequency: 1          # You should tweak this value depending on your fan and expected percentage of normal usage.
    channel: Pwm0
verbosity_mode: Human

State of the project

I feel that this project is fully featured for what it is right now: a raspberry pi temperature controler.
If someone would create a circuit using a 5V PIN and a GPIO as switch, I would love to elaborate and test new cooling strategies.

It is also still possible to support more boards and have a better output for logging/plotting on an other application.

Code wise it is one of my first Rust projets so any hint on how to upgrade my code and the ergonomics of tempi is welcome. Including adding tests, better usage of error, understanding if I should use embedded-hal, ...
I also need to document the code and maybe expose an interface to use it as a library.