working hard real time interrupt
This commit is contained in:
@@ -17,6 +17,8 @@ use esp_hal::{
|
|||||||
timer::timg::TimerGroup,
|
timer::timg::TimerGroup,
|
||||||
time::Duration,
|
time::Duration,
|
||||||
};
|
};
|
||||||
|
use core::cell::RefCell;
|
||||||
|
use critical_section::Mutex;
|
||||||
use esp_hal::handler;
|
use esp_hal::handler;
|
||||||
use log::info;
|
use log::info;
|
||||||
|
|
||||||
@@ -27,6 +29,7 @@ extern crate alloc;
|
|||||||
esp_bootloader_esp_idf::esp_app_desc!();
|
esp_bootloader_esp_idf::esp_app_desc!();
|
||||||
|
|
||||||
static mut INTERRUPT_FIRED: bool = false;
|
static mut INTERRUPT_FIRED: bool = false;
|
||||||
|
static TIMER0: Mutex<RefCell<Option<esp_hal::timer::timg::Timer<'static>>>> = Mutex::new(RefCell::new(None));
|
||||||
|
|
||||||
#[esp_hal_embassy::main]
|
#[esp_hal_embassy::main]
|
||||||
async fn main(spawner: Spawner) {
|
async fn main(spawner: Spawner) {
|
||||||
@@ -37,23 +40,27 @@ async fn main(spawner: Spawner) {
|
|||||||
|
|
||||||
esp_alloc::heap_allocator!(size: 64 * 1024);
|
esp_alloc::heap_allocator!(size: 64 * 1024);
|
||||||
|
|
||||||
let mut timer_group1 = TimerGroup::new(peripherals.TIMG1);
|
let timer_group1 = TimerGroup::new(peripherals.TIMG1);
|
||||||
let mut timer0 = timer_group1.timer0;
|
let timer0 = timer_group1.timer0;
|
||||||
|
|
||||||
// make it periodic, 1 s per tick, enable interrupt
|
timer0.set_interrupt_handler(TG1_T0_LEVEL);
|
||||||
|
timer0.clear_interrupt();
|
||||||
|
timer0.load_value(Duration::from_secs(1)).unwrap();
|
||||||
timer0.enable_interrupt(true);
|
timer0.enable_interrupt(true);
|
||||||
timer0.enable_auto_reload(true);
|
timer0.enable_auto_reload(true);
|
||||||
timer0.load_value(Duration::from_secs(1)).unwrap();
|
|
||||||
timer0.start();
|
timer0.start();
|
||||||
|
|
||||||
|
// Store timer in the static safely
|
||||||
|
critical_section::with(|cs| {
|
||||||
|
TIMER0.borrow_ref_mut(cs).replace(timer0);
|
||||||
|
});
|
||||||
|
|
||||||
// enable NVIC entry for this timer
|
// enable NVIC entry for this timer
|
||||||
unsafe {
|
interrupt::enable(
|
||||||
interrupt::enable(
|
peripherals::Interrupt::TG1_T0_LEVEL,
|
||||||
peripherals::Interrupt::TG1_T0_LEVEL,
|
interrupt::Priority::Priority2, // medium priority
|
||||||
interrupt::Priority::Priority2, // medium priority for now
|
)
|
||||||
)
|
.unwrap();
|
||||||
.unwrap();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize GPIO4 as output (starts LOW)
|
// Initialize GPIO4 as output (starts LOW)
|
||||||
let mut gpio4 = Output::new(peripherals.GPIO4, Level::Low, OutputConfig::default());
|
let mut gpio4 = Output::new(peripherals.GPIO4, Level::Low, OutputConfig::default());
|
||||||
@@ -61,29 +68,27 @@ async fn main(spawner: Spawner) {
|
|||||||
info!("Embassy initialized!");
|
info!("Embassy initialized!");
|
||||||
loop {
|
loop {
|
||||||
|
|
||||||
let mut counter = 0;
|
info!("info!");
|
||||||
while counter < 10000000 {
|
// let mut counter = 0;
|
||||||
counter += 1;
|
// while counter < 10000000 {
|
||||||
}
|
// counter += 1;
|
||||||
|
// }
|
||||||
unsafe {
|
if unsafe { INTERRUPT_FIRED } {
|
||||||
if INTERRUPT_FIRED {
|
gpio4.toggle();
|
||||||
info!("Timer interrupt fired!");
|
info!("tick");
|
||||||
INTERRUPT_FIRED = false;
|
unsafe { INTERRUPT_FIRED = false; }
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
esp_hal::delay::Delay::new().delay_millis(100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[handler]
|
#[handler]
|
||||||
fn TG1_T0_LEVEL() {
|
fn TG1_T0_LEVEL() {
|
||||||
// Clear the interrupt
|
critical_section::with(|cs| {
|
||||||
critical_section::with(|_cs| {
|
if let Some(timer) = TIMER0.borrow_ref_mut(cs).as_mut() {
|
||||||
unsafe {
|
|
||||||
let mut tg1 = TimerGroup::new(peripherals::TIMG1::steal());
|
|
||||||
tg1.timer0.clear_interrupt();
|
|
||||||
|
|
||||||
INTERRUPT_FIRED = true;
|
timer.clear_interrupt();
|
||||||
|
unsafe { INTERRUPT_FIRED = true; }
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user