Skip to content

Commit

Permalink
Extract common setup fn
Browse files Browse the repository at this point in the history
  • Loading branch information
bugadani committed Oct 13, 2023
1 parent 1f67e5e commit efcb954
Show file tree
Hide file tree
Showing 9 changed files with 33 additions and 92 deletions.
9 changes: 9 additions & 0 deletions esp-wifi/src/timer/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,13 @@ mod chip_specific;
#[cfg_attr(any(esp32c2, esp32c3, esp32c6), path = "riscv.rs")]
mod arch_specific;

pub use arch_specific::*;
pub use chip_specific::*;

pub fn setup_timer_isr(timebase: TimeBase) {
setup_radio_isr();

setup_timer(timebase);

setup_multitasking();
}
5 changes: 3 additions & 2 deletions esp-wifi/src/timer/riscv.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ use core::cell::RefCell;
use critical_section::Mutex;

use crate::{
binary,
hal::{
interrupt::{self, TrapFrame},
peripherals::{self, Interrupt},
Expand All @@ -19,13 +18,15 @@ use peripherals::INTPRI as SystemPeripheral;
#[cfg(not(feature = "esp32c6"))]
use peripherals::SYSTEM as SystemPeripheral;

pub type TimeBase = Alarm<Target, 0>;

pub const TICKS_PER_SECOND: u64 = 16_000_000;

const TIMER_DELAY: fugit::HertzU32 = fugit::HertzU32::from_raw(crate::CONFIG.tick_rate_hz);

static ALARM0: Mutex<RefCell<Option<Alarm<Periodic, 0>>>> = Mutex::new(RefCell::new(None));

pub fn setup_timer(systimer: Alarm<Target, 0>) {
pub fn setup_timer(systimer: TimeBase) {
let alarm0 = systimer.into_periodic();
alarm0.set_period(TIMER_DELAY.into());
alarm0.clear_interrupt();
Expand Down
16 changes: 2 additions & 14 deletions esp-wifi/src/timer/timer_esp32.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,6 @@
use crate::hal::{
interrupt,
macros::interrupt,
peripherals::{self, TIMG1},
timer::{Timer, Timer0},
};
use crate::hal::{interrupt, macros::interrupt, peripherals};

pub use super::arch_specific::{get_systimer_count, yield_task, TICKS_PER_SECOND};
use super::arch_specific::{setup_multitasking, setup_timer};

pub fn setup_timer_isr(timg1_timer0: Timer<Timer0<TIMG1>>) {
pub fn setup_radio_isr() {
#[cfg(feature = "wifi")]
unwrap!(interrupt::enable(
peripherals::Interrupt::WIFI_MAC,
Expand All @@ -31,10 +23,6 @@ pub fn setup_timer_isr(timg1_timer0: Timer<Timer0<TIMG1>>) {
interrupt::disable(crate::hal::Cpu::ProCpu, peripherals::Interrupt::ETH_MAC);
interrupt::disable(crate::hal::Cpu::ProCpu, peripherals::Interrupt::UART0);
}

setup_timer(timg1_timer0);

setup_multitasking();
}

#[cfg(feature = "ble")]
Expand Down
17 changes: 2 additions & 15 deletions esp-wifi/src/timer/timer_esp32c2.rs
Original file line number Diff line number Diff line change
@@ -1,20 +1,9 @@
use crate::{
binary,
hal::{
interrupt::{self, TrapFrame},
peripherals::{self, Interrupt},
prelude::*,
riscv,
systimer::{Alarm, Periodic, SystemTimer, Target},
},
hal::{interrupt, macros::interrupt, peripherals::Interrupt},
};

pub use super::arch_specific::{get_systimer_count, yield_task, TICKS_PER_SECOND};
use super::arch_specific::{setup_multitasking, setup_timer};

pub fn setup_timer_isr(systimer: Alarm<Target, 0>) {
setup_timer(systimer);

pub fn setup_radio_isr() {
#[cfg(feature = "wifi")]
{
unwrap!(interrupt::enable(
Expand All @@ -38,8 +27,6 @@ pub fn setup_timer_isr(systimer: Alarm<Target, 0>) {
interrupt::Priority::Priority1
));
}

setup_multitasking();
}

#[cfg(feature = "wifi")]
Expand Down
15 changes: 3 additions & 12 deletions esp-wifi/src/timer/timer_esp32c3.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,19 +2,12 @@ use crate::{
binary,
hal::{
interrupt::{self, TrapFrame},
peripherals::{self, Interrupt},
prelude::*,
riscv,
systimer::{Alarm, Periodic, SystemTimer, Target},
macros::interrupt,
peripherals::Interrupt,
},
};

pub use super::arch_specific::{get_systimer_count, yield_task, TICKS_PER_SECOND};
use super::arch_specific::{setup_multitasking, setup_timer};

pub fn setup_timer_isr(systimer: Alarm<Target, 0>) {
setup_timer(systimer);

pub fn setup_radio_isr() {
#[cfg(feature = "wifi")]
{
unwrap!(interrupt::enable(
Expand Down Expand Up @@ -42,8 +35,6 @@ pub fn setup_timer_isr(systimer: Alarm<Target, 0>) {
interrupt::Priority::Priority1
));
}

setup_multitasking();
}

#[cfg(feature = "wifi")]
Expand Down
15 changes: 3 additions & 12 deletions esp-wifi/src/timer/timer_esp32c6.rs
Original file line number Diff line number Diff line change
@@ -1,20 +1,13 @@
use crate::{
binary,
hal::{
interrupt::{self, TrapFrame},
interrupt,
macros::interrupt,
peripherals::{self, Interrupt},
prelude::*,
riscv,
systimer::{Alarm, Periodic, SystemTimer, Target},
},
};

pub use super::arch_specific::{get_systimer_count, yield_task, TICKS_PER_SECOND};
use super::arch_specific::{setup_multitasking, setup_timer};

pub fn setup_timer_isr(systimer: Alarm<Target, 0>) {
setup_timer(systimer);

pub fn setup_radio_isr() {
#[cfg(feature = "wifi")]
{
unwrap!(interrupt::enable(
Expand Down Expand Up @@ -48,8 +41,6 @@ pub fn setup_timer_isr(systimer: Alarm<Target, 0>) {
interrupt::Priority::Priority1
));
}

setup_multitasking();
}

#[cfg(feature = "wifi")]
Expand Down
21 changes: 3 additions & 18 deletions esp-wifi/src/timer/timer_esp32s2.rs
Original file line number Diff line number Diff line change
@@ -1,19 +1,6 @@
use crate::hal::{
interrupt,
macros::interrupt,
peripherals::{self, TIMG1},
timer::{Timer, Timer0},
};

pub use super::arch_specific::{get_systimer_count, yield_task, TICKS_PER_SECOND};
use super::arch_specific::{setup_multitasking, setup_timer};

pub fn setup_timer_isr(timg1_timer0: Timer<Timer0<TIMG1>>) {
unwrap!(interrupt::enable(
peripherals::Interrupt::TG1_T0_LEVEL,
interrupt::Priority::Priority2,
));
use crate::hal::{interrupt, macros::interrupt, peripherals};

pub fn setup_radio_isr() {
#[cfg(feature = "wifi")]
{
unwrap!(interrupt::enable(
Expand All @@ -26,9 +13,7 @@ pub fn setup_timer_isr(timg1_timer0: Timer<Timer0<TIMG1>>) {
));
}

setup_timer(timg1_timer0);

setup_multitasking();
// ble not supported
}

#[cfg(feature = "wifi")]
Expand Down
16 changes: 2 additions & 14 deletions esp-wifi/src/timer/timer_esp32s3.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,6 @@
use crate::hal::{
interrupt,
macros::interrupt,
peripherals::{self, TIMG1},
timer::{Timer, Timer0},
};
use crate::hal::{interrupt, macros::interrupt, peripherals};

pub use super::arch_specific::{get_systimer_count, yield_task, TICKS_PER_SECOND};
use super::arch_specific::{setup_multitasking, setup_timer};

pub fn setup_timer_isr(timg1_timer0: Timer<Timer0<TIMG1>>) {
pub fn setup_radio_isr() {
#[cfg(feature = "wifi")]
{
unwrap!(interrupt::enable(
Expand All @@ -32,10 +24,6 @@ pub fn setup_timer_isr(timg1_timer0: Timer<Timer0<TIMG1>>) {
interrupt::Priority::Priority1,
));
}

setup_timer(timg1_timer0);

setup_multitasking();
}

#[cfg(feature = "wifi")]
Expand Down
11 changes: 6 additions & 5 deletions esp-wifi/src/timer/xtensa.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
use core::cell::RefCell;

use critical_section::Mutex;

use crate::{
hal::{
interrupt,
Expand All @@ -13,9 +15,10 @@ use crate::{
preempt::preempt::task_switch,
};
use atomic_polyfill::{AtomicU32, Ordering};
use critical_section::Mutex;

static TIMER1: Mutex<RefCell<Option<Timer<Timer0<TIMG1>>>>> = Mutex::new(RefCell::new(None));
pub type TimeBase = Timer<Timer0<TIMG1>>;

static TIMER1: Mutex<RefCell<Option<TimeBase>>> = Mutex::new(RefCell::new(None));

static TIMER_OVERFLOWS: AtomicU32 = AtomicU32::new(0);

Expand All @@ -41,9 +44,7 @@ pub fn get_systimer_count() -> u64 {
(((overflow as u64) << 32) + counter_after as u64) * 40_000_000 / 240_000_000
}

pub fn setup_timer(timg1_timer0: Timer<Timer0<TIMG1>>) {
let mut timer1 = timg1_timer0;

pub fn setup_timer(mut timer1: TimeBase) {
unwrap!(interrupt::enable(
peripherals::Interrupt::TG1_T0_LEVEL,
interrupt::Priority::Priority2,
Expand Down

0 comments on commit efcb954

Please sign in to comment.