mirror of
https://github.com/Feliix42/ssd1675.git
synced 2024-11-25 04:06:30 +00:00
Add interface module
This commit is contained in:
parent
cea8858596
commit
2c17a4310e
4 changed files with 98 additions and 0 deletions
12
Cargo.toml
12
Cargo.toml
|
@ -4,3 +4,15 @@ version = "0.1.0"
|
|||
authors = ["Wesley Moore <wes@wezm.net>"]
|
||||
|
||||
[dependencies]
|
||||
|
||||
[dependencies.embedded-hal]
|
||||
features = ["unproven"]
|
||||
version = "0.2.2"
|
||||
|
||||
[dependencies.embedded-graphics]
|
||||
optional = true
|
||||
version = "0.4.4"
|
||||
|
||||
[features]
|
||||
default = ["graphics"]
|
||||
graphics = ["embedded-graphics"]
|
||||
|
|
|
@ -19,6 +19,7 @@ The library has been tested and confirmed working on these devices:
|
|||
|
||||
## Credits
|
||||
|
||||
* [Waveshare EPD driver](https://github.com/caemor/epd-waveshare)
|
||||
* [SSD1306 OLED display driver](https://github.com/jamwaffles/ssd1306)
|
||||
* [SSD1322 OLED display driver](https://github.com/edarc/ssd1322)
|
||||
* [Pimoroni Python library for the Inky pHAT and Inky wHAT e-paper displays](https://github.com/pimoroni/inky)
|
||||
|
|
81
src/interface.rs
Normal file
81
src/interface.rs
Normal file
|
@ -0,0 +1,81 @@
|
|||
use hal;
|
||||
|
||||
// Section 15.2 of the HINK-E0213A07 data sheet says to hold for 10ms
|
||||
const RESET_DELAY_MS: u8 = 10;
|
||||
|
||||
struct DisplayInterface<SPI, CS, BUSY, DC, RESET> {
|
||||
/// SPI
|
||||
spi: SPI,
|
||||
/// CS for SPI
|
||||
cs: CS,
|
||||
/// Low for busy, Wait until display is ready!
|
||||
busy: BUSY,
|
||||
/// Data/Command Control Pin (High for data, Low for command)
|
||||
dc: DC,
|
||||
/// Pin for Reseting
|
||||
reset: RESET,
|
||||
}
|
||||
|
||||
impl<SPI, CS, BUSY, DC, RESET> DisplayInterface<SPI, CS, BUSY, DC, RESET>
|
||||
where
|
||||
SPI: hal::blocking::spi::Write<u8>,
|
||||
CS: hal::digital::OutputPin,
|
||||
BUSY: hal::digital::InputPin,
|
||||
DC: hal::digital::OutputPin,
|
||||
RESET: hal::digital::OutputPin,
|
||||
{
|
||||
pub fn new(spi: SPI, cs: CS, busy: BUSY, dc: DC, reset: RESET) -> Self {
|
||||
Self {
|
||||
spi,
|
||||
cs,
|
||||
busy,
|
||||
dc,
|
||||
reset,
|
||||
}
|
||||
}
|
||||
|
||||
fn reset<D: hal::blocking::delay::DelayMs<u8>>(&mut self, delay: &mut D) {
|
||||
self.reset.set_low();
|
||||
delay.delay_ms(RESET_DELAY_MS);
|
||||
self.reset.set_high();
|
||||
delay.delay_ms(RESET_DELAY_MS);
|
||||
}
|
||||
|
||||
fn send_command(&mut self, command: u8) -> Result<(), SPI::Error> {
|
||||
self.dc.set_low();
|
||||
self.write(&[command])?;
|
||||
self.dc.set_high();
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn send_data(&mut self, data: &[u8]) -> Result<(), SPI::Error> {
|
||||
self.dc.set_high();
|
||||
self.write(data)
|
||||
}
|
||||
|
||||
fn write(&mut self, data: &[u8]) -> Result<(), SPI::Error> {
|
||||
// Select the controller with chip select (CS)
|
||||
self.cs.set_low();
|
||||
|
||||
// Linux has a default limit of 4096 bytes per SPI transfer
|
||||
// https://github.com/torvalds/linux/blob/ccda4af0f4b92f7b4c308d3acc262f4a7e3affad/drivers/spi/spidev.c#L93
|
||||
if cfg!(target_os = "linux") {
|
||||
for data_chunk in data.chunks(4096) {
|
||||
self.spi.write(data_chunk)?;
|
||||
}
|
||||
} else {
|
||||
self.spi.write(data)?;
|
||||
}
|
||||
|
||||
// Release the controller
|
||||
self.cs.set_high();
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
||||
fn busy_wait(&self) {
|
||||
while self.busy.is_high() {}
|
||||
}
|
||||
}
|
|
@ -1,3 +1,7 @@
|
|||
extern crate embedded_hal as hal;
|
||||
|
||||
mod interface;
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
#[test]
|
||||
|
|
Loading…
Reference in a new issue