New revision for updated HAL

- API changes in GPIO code, therefore update revision
This commit is contained in:
Robin Müller 2021-11-11 17:47:51 +01:00
parent 215b5eb3d1
commit e7ae72cef6
3 changed files with 20 additions and 28 deletions

View File

@ -1,6 +1,6 @@
[package] [package]
name = "vorago-reb1" name = "vorago-reb1"
version = "0.1.0" version = "0.1.1"
authors = ["Robin Mueller <robin.mueller.m@gmail.com>"] authors = ["Robin Mueller <robin.mueller.m@gmail.com>"]
edition = "2021" edition = "2021"
description = "Board Support Crate for the Vorago REB1 development board" description = "Board Support Crate for the Vorago REB1 development board"
@ -20,5 +20,5 @@ panic-rtt-target = { version = "0.1", features = ["cortex-m"] }
rtt-target = { version = "0.3", features = ["cortex-m"] } rtt-target = { version = "0.3", features = ["cortex-m"] }
[dependencies.va108xx-hal] [dependencies.va108xx-hal]
version = "0.1" version = "0.2"
features = ["rt"] features = ["rt"]

View File

@ -9,7 +9,7 @@
use cortex_m_rt::entry; use cortex_m_rt::entry;
use embedded_hal::digital::v2::ToggleableOutputPin; use embedded_hal::digital::v2::ToggleableOutputPin;
use panic_halt as _; use panic_halt as _;
use va108xx_hal::{pac, prelude::*}; use va108xx_hal::{gpio::pins::PinsA, pac, prelude::*};
use vorago_reb1::leds::Leds; use vorago_reb1::leds::Leds;
// REB LED pin definitions. All on port A // REB LED pin definitions. All on port A
@ -27,7 +27,7 @@ enum LibType {
#[entry] #[entry]
fn main() -> ! { fn main() -> ! {
let mut dp = pac::Peripherals::take().unwrap(); let mut dp = pac::Peripherals::take().unwrap();
let porta = dp.PORTA.split(&mut dp.SYSCONFIG).unwrap();
let lib_type = LibType::Bsp; let lib_type = LibType::Bsp;
match lib_type { match lib_type {
@ -60,15 +60,10 @@ fn main() -> ! {
} }
} }
LibType::Hal => { LibType::Hal => {
let mut led1 = porta let pins = PinsA::new(&mut dp.SYSCONFIG, Some(dp.IOCONFIG), dp.PORTA);
.pa10 let mut led1 = pins.pa10.into_push_pull_output();
.into_push_pull_output(&mut dp.IOCONFIG, &mut dp.PORTA); let mut led2 = pins.pa7.into_push_pull_output();
let mut led2 = porta let mut led3 = pins.pa6.into_push_pull_output();
.pa7
.into_push_pull_output(&mut dp.IOCONFIG, &mut dp.PORTA);
let mut led3 = porta
.pa6
.into_push_pull_output(&mut dp.IOCONFIG, &mut dp.PORTA);
for _ in 0..10 { for _ in 0..10 {
led1.set_low().ok(); led1.set_low().ok();
led2.set_low().ok(); led2.set_low().ok();
@ -89,7 +84,7 @@ fn main() -> ! {
} }
} }
LibType::Bsp => { LibType::Bsp => {
let mut leds = Leds::new(porta, &mut dp.IOCONFIG, &mut dp.PORTA); let mut leds = Leds::new(PinsA::new(&mut dp.SYSCONFIG, Some(dp.IOCONFIG), dp.PORTA));
loop { loop {
for _ in 0..10 { for _ in 0..10 {
// Blink all LEDs quickly // Blink all LEDs quickly

View File

@ -1,25 +1,22 @@
use va108xx_hal::{ use va108xx_hal::{
gpio::{ gpio::dynpins::DynPin,
porta::{Parts, PA10, PA6, PA7}, gpio::pins::{Pin, PinsA, PushPullOutput, PA10, PA6, PA7},
Output, Pin, PushPull,
},
pac::{IOCONFIG, PORTA},
prelude::*, prelude::*,
}; };
pub type LD2 = PA10<Output<PushPull>>; pub type LD2 = Pin<PA10, PushPullOutput>;
pub type LD3 = PA7<Output<PushPull>>; pub type LD3 = Pin<PA7, PushPullOutput>;
pub type LD4 = PA6<Output<PushPull>>; pub type LD4 = Pin<PA6, PushPullOutput>;
pub struct Leds { pub struct Leds {
leds: [Led; 3], leds: [Led; 3],
} }
impl Leds { impl Leds {
pub fn new(led_parts: Parts, iocfg: &mut IOCONFIG, porta: &mut PORTA) -> Self { pub fn new(led_parts: PinsA) -> Self {
let led2 = led_parts.pa10.into_push_pull_output(iocfg, porta); let led2 = led_parts.pa10.into_push_pull_output();
let led3 = led_parts.pa7.into_push_pull_output(iocfg, porta); let led3 = led_parts.pa7.into_push_pull_output();
let led4 = led_parts.pa6.into_push_pull_output(iocfg, porta); let led4 = led_parts.pa6.into_push_pull_output();
Leds { Leds {
leds: [led2.into(), led3.into(), led4.into()], leds: [led2.into(), led3.into(), led4.into()],
} }
@ -55,7 +52,7 @@ impl core::ops::IndexMut<usize> for Leds {
} }
pub struct Led { pub struct Led {
pin: Pin<Output<PushPull>>, pin: DynPin,
} }
macro_rules! ctor { macro_rules! ctor {
@ -64,7 +61,7 @@ macro_rules! ctor {
impl From<$ldx> for Led { impl From<$ldx> for Led {
fn from(led: $ldx) -> Self { fn from(led: $ldx) -> Self {
Led { Led {
pin: led.downgrade(), pin: led.into()
} }
} }
} }