#![no_std]
#![no_main]
use cortex_m_rt::{entry, exception, ExceptionFrame};
use display_interface_i2c::I2CInterface;
use embedded_graphics::{
image::{Image, ImageRawLE},
pixelcolor::BinaryColor,
prelude::*,
};
use panic_semihosting as _;
use sh1108::{prelude::*, Builder};
use stm32f1xx_hal::{
i2c::{BlockingI2c, DutyCycle, Mode},
prelude::*,
stm32,
};
#[entry]
fn main() -> ! {
let dp = stm32::Peripherals::take().unwrap();
let cp = cortex_m::Peripherals::take().unwrap();
let mut flash = dp.FLASH.constrain();
let rcc = dp.RCC.constrain();
let clocks = rcc.cfgr.freeze(&mut flash.acr);
let mut afio = dp.AFIO.constrain();
let mut gpiob = dp.GPIOB.split();
let mut res = gpiob.pb7.into_push_pull_output(&mut gpiob.crl);
let scl = gpiob.pb8.into_alternate_open_drain(&mut gpiob.crh);
let sda = gpiob.pb9.into_alternate_open_drain(&mut gpiob.crh);
let mut delay = cp.SYST.delay(&clocks);
let i2c = BlockingI2c::i2c1(
dp.I2C1,
(scl, sda),
&mut afio.mapr,
Mode::Fast {
frequency: 100u32.kHz(),
duty_cycle: DutyCycle::Ratio2to1,
},
clocks,
1000,
10,
1000,
1000,
);
let i2c_interface = I2CInterface::new(i2c, 0x3C, 0x40);
let mut disp: GraphicsMode<_> = Builder::new()
.with_rotation(DisplayRotation::Rotate90)
.connect(i2c_interface)
.into();
disp.reset(&mut res, &mut delay).unwrap();
disp.init().unwrap();
disp.flush().unwrap();
disp.set_rotation(DisplayRotation::Rotate270).unwrap();
let (w, h) = disp.get_dimensions();
let im: ImageRawLE<BinaryColor> = ImageRawLE::new(include_bytes!("./rust.raw"), 64);
Image::new(
&im,
Point::new(w as i32 / 2 - 64 / 2, h as i32 / 2 - 64 / 2),
)
.draw(&mut disp)
.unwrap();
disp.flush().unwrap();
loop {}
}
#[exception]
unsafe fn HardFault(ef: &ExceptionFrame) -> ! {
panic!("{:#?}", ef);
}