Initial commit -- have an eye

This commit is contained in:
puffaboo 2022-07-13 21:54:52 +01:00
commit d632f29dee
8 changed files with 158 additions and 0 deletions

34
.cargo/config.toml Normal file
View File

@ -0,0 +1,34 @@
[build]
# Uncomment the relevant target for your chip here (ESP32, ESP32-S2, ESP32-S3 or ESP32-C3)
target = "xtensa-esp32-espidf"
#target = "xtensa-esp32s2-espidf"
#target = "xtensa-esp32s3-espidf"
#target = "riscv32imc-esp-espidf"
[target.xtensa-esp32-espidf]
linker = "ldproxy"
[target.xtensa-esp32s2-espidf]
linker = "ldproxy"
[target.xtensa-esp32s3-espidf]
linker = "ldproxy"
[target.riscv32imc-esp-espidf]
linker = "ldproxy"
# Future - necessary for the experimental "native build" of esp-idf-sys with ESP32C3
# See also https://github.com/ivmarkov/embuild/issues/16
rustflags = ["-C", "default-linker-libraries"]
[unstable]
build-std = ["std", "panic_abort"]
#build-std-features = ["panic_immediate_abort"] # Required for older ESP-IDF versions without a realpath implementation
[env]
# Note: these variables are not used when using pio builder
# Enables the esp-idf-sys "native" build feature (`cargo build --features native`) to build against ESP-IDF stable (v4.4)
ESP_IDF_VERSION = { value = "branch:release/v4.4" }
# Enables the esp-idf-sys "native" build feature (`cargo build --features native`) to build against ESP-IDF master (mainline)
#ESP_IDF_VERSION = { value = "master" }

4
.gitignore vendored Normal file
View File

@ -0,0 +1,4 @@
/.vscode
/.embuild
/target
/Cargo.lock

30
Cargo.toml Normal file
View File

@ -0,0 +1,30 @@
[package]
name = "eyeiii"
version = "0.1.0"
authors = ["puffaboo <emilis@jigglypuff.club>"]
edition = "2018"
resolver = "2"
[profile.release]
opt-level = "s"
[profile.dev]
debug = true # Symbols are nice and they don't increase the size on Flash
opt-level = "z"
[features]
pio = ["esp-idf-sys/pio"]
[dependencies]
embedded-graphics = "0.7.1"
embedded-hal = "1.0.0-alpha.8"
esp-idf-hal = "0.38.0"
esp-idf-svc = "0.42.0"
esp-idf-sys = { version = "0.31.6", features = ["binstart"] }
ssd1331 = "0.3.0"
tinybmp = "0.3.3"
[build-dependencies]
embuild = "0.29"
anyhow = "1"

5
build.rs Normal file
View File

@ -0,0 +1,5 @@
// Necessary because of this issue: https://github.com/rust-lang/cargo/issues/9641
fn main() -> anyhow::Result<()> {
embuild::build::CfgArgs::output_propagated("ESP_IDF")?;
embuild::build::LinkArgs::output_propagated("ESP_IDF")
}

2
rust-toolchain.toml Normal file
View File

@ -0,0 +1,2 @@
[toolchain]
channel = "esp"

10
sdkconfig.defaults Normal file
View File

@ -0,0 +1,10 @@
# Rust often needs a bit of an extra main task stack size compared to C (the default is 3K)
CONFIG_ESP_MAIN_TASK_STACK_SIZE=20000
# Use this to set FreeRTOS kernel tick frequency to 1000 Hz (100 Hz by default).
# This allows to use 1 ms granuality for thread sleeps (10 ms by default).
#CONFIG_FREERTOS_HZ=1000
# Workaround for https://github.com/espressif/esp-idf/issues/7631
#CONFIG_MBEDTLS_CERTIFICATE_BUNDLE=n
#CONFIG_MBEDTLS_CERTIFICATE_BUNDLE_DEFAULT_FULL=n

BIN
src/eye.bmp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.1 KiB

73
src/main.rs Normal file
View File

@ -0,0 +1,73 @@
use std::{error::Error, thread::sleep, time::Duration};
use embedded_graphics::{image::Image, pixelcolor::Rgb565, prelude::*};
use esp_idf_hal::{
gpio::{Gpio16, Gpio17, Gpio18, Gpio23, Gpio5, Output},
prelude::{Hertz, Peripherals},
spi::{self, Pins, SPI3},
};
use esp_idf_sys as _; // If using the `binstart` feature of `esp-idf-sys`, always keep this module imported
use ssd1331::{DisplayRotation::Rotate0, Ssd1331};
use tinybmp::Bmp;
fn secondary() -> Result<(), Box<dyn Error>> {
// Temporary. Will disappear once ESP-IDF 4.4 is released, but for now it is necessary to call this function once,
// or else some patches to the runtime implemented by esp-idf-sys might not link properly.
esp_idf_sys::link_patches();
// Bind the log crate to the ESP Logging facilities
esp_idf_svc::log::EspLogger::initialize_default();
let peripherals = Peripherals::take().unwrap();
let spi3 = peripherals.spi3;
let pins = peripherals.pins;
let cs: Gpio17<Output> = pins.gpio17.into_output()?;
let dc: Gpio16<Output> = pins.gpio16.into_output()?;
let mosi: Gpio23<Output> = pins.gpio23.into_output()?;
let sclk: Gpio18<Output> = pins.gpio18.into_output()?;
let reset: Gpio5<Output> = pins.gpio5.into_output()?;
// // Set up SPI interface and digital pin. These are stub implementations used in examples.
let spiman =
spi::Master::<SPI3, Gpio18<Output>, Gpio23<Output>, Gpio5<Output>, Gpio17<Output>>::new(
spi3,
Pins {
sclk: sclk,
sdo: mosi,
sdi: Some(reset),
cs: Some(cs),
},
spi::config::Config {
baudrate: Hertz(24000000),
data_mode: embedded_hal::spi::MODE_0,
write_only: false,
dma: spi::Dma::Disabled,
},
)?;
let mut display = Ssd1331::new(spiman, dc, Rotate0);
display.init().unwrap();
display.flush().unwrap();
let (w, h) = display.dimensions();
println!("got resolution {} x {}", w.clone(), h.clone());
let bmp = Bmp::from_slice(include_bytes!("./eye.bmp")).expect("Failed to load BMP image");
let im: Image<Bmp<Rgb565>> = Image::new(&bmp, Point::zero());
// Position image in the center of the display
let moved = im.translate(Point::new(
(w as u32 - bmp.size().width) as i32 / 2,
(h as u32 - bmp.size().height) as i32 / 2,
));
moved.draw(&mut display).unwrap();
display.flush().unwrap();
Ok(())
}
fn main() -> Result<(), Box<dyn Error>> {
sleep(Duration::from_secs(1));
Ok(secondary().unwrap())
}