Generate exti interrupt handlers

Match interrupts starting with ^EXTI and generate init code and irq
handler for them
This commit is contained in:
Ulf Lilleengen 2021-05-19 10:40:57 +02:00 committed by Dario Nieuwenhuis
parent 8172db6d8e
commit 0cd3236fa3
3 changed files with 43 additions and 46 deletions

View File

@ -57,6 +57,7 @@ for chip in chips.values():
af = gpio_afs[chip['gpio_af']]
peripheral_names = [] # USART1, PA5, EXTI8
exti_interrupts = [] # EXTI IRQs, EXTI0, EXTI4_15 etc.
peripheral_versions = {} # usart -> v1, syscfg -> f4
pins = set() # set of all present pins. PA4, PA5...
@ -177,6 +178,12 @@ for chip in chips.values():
if func := funcs.get(f'{name}_D7'):
f.write(f'impl_sdmmc_pin!({name}, D7Pin, {pin}, {func});')
if block_mod == 'exti':
for irq in chip['interrupts']:
if re.match('EXTI', irq):
exti_interrupts.append(irq)
if not custom_singletons:
peripheral_names.append(name)
@ -228,6 +235,15 @@ for chip in chips.values():
}}
{''.join(irq_declares)}
pub mod exti {{
use embassy::interrupt::InterruptExt;
use crate::interrupt;
use super::*;
impl_exti_irq!({','.join(exti_interrupts)});
impl_exti_init!({','.join(exti_interrupts)});
}}
}}
mod interrupt_vector {{
extern "C" {{

View File

@ -21,41 +21,6 @@ const EXTI_COUNT: usize = 16;
const NEW_AW: AtomicWaker = AtomicWaker::new();
static EXTI_WAKERS: [AtomicWaker; EXTI_COUNT] = [NEW_AW; EXTI_COUNT];
#[interrupt]
unsafe fn EXTI0() {
on_irq()
}
#[interrupt]
unsafe fn EXTI1() {
on_irq()
}
#[interrupt]
unsafe fn EXTI2() {
on_irq()
}
#[interrupt]
unsafe fn EXTI3() {
on_irq()
}
#[interrupt]
unsafe fn EXTI4() {
on_irq()
}
#[interrupt]
unsafe fn EXTI9_5() {
on_irq()
}
#[interrupt]
unsafe fn EXTI15_10() {
on_irq()
}
pub unsafe fn on_irq() {
let bits = EXTI.pr().read().0;
@ -249,14 +214,30 @@ impl_exti!(EXTI13, 13);
impl_exti!(EXTI14, 14);
impl_exti!(EXTI15, 15);
/// safety: must be called only once
pub(crate) unsafe fn init() {
interrupt::EXTI0::steal().enable();
interrupt::EXTI1::steal().enable();
interrupt::EXTI2::steal().enable();
interrupt::EXTI3::steal().enable();
interrupt::EXTI4::steal().enable();
interrupt::EXTI9_5::steal().enable();
interrupt::EXTI15_10::steal().enable();
interrupt::EXTI15_10::steal().enable();
macro_rules! impl_exti_irq {
($e:ident) => {
#[interrupt]
unsafe fn $e() {
crate::exti::on_irq()
}
};
($e:ident, $($es:ident),+) => {
impl_exti_irq! { $e }
impl_exti_irq! { $($es),+ }
};
}
macro_rules! impl_exti_init {
($e:ident) => {
crate::interrupt::$e::steal().enable();
};
($e:ident, $($es:ident),+) => {
/// safety: must be called only once
pub(crate) unsafe fn init() {
impl_exti_init! { $e }
impl_exti_init! { $($es),+ }
}
};
}

View File

@ -49,8 +49,8 @@ pub fn init(_config: Config) -> Peripherals {
let p = Peripherals::take();
unsafe {
exti::init();
dma::init();
interrupt::exti::init();
}
p