Skip to content

Commit

Permalink
timer: Check the timer's source is ref_clk ÷ watchdog tick.
Browse files Browse the repository at this point in the history
  • Loading branch information
ithinuel committed Aug 16, 2023
1 parent 4b9722c commit f933b0c
Show file tree
Hide file tree
Showing 7 changed files with 48 additions and 11 deletions.
7 changes: 6 additions & 1 deletion rp2040-hal/examples/adc_fifo_dma.rs
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,12 @@ fn main() -> ! {
adc_fifo.resume();

// initialize a timer, to measure the total sampling time (printed below)
let timer = hal::Timer::new(pac.TIMER, &mut pac.RESETS, &clocks.reference_clock);
let timer = hal::Timer::new(
pac.TIMER,
&mut pac.RESETS,
&watchdog,
&clocks.reference_clock,
);

// NOTE: in a real-world program, instead of calling `wait` now, you would probably:
// 1. Enable one of the DMA interrupts for the channel (e.g. `dma.ch0.enable_irq0()`)
Expand Down
7 changes: 6 additions & 1 deletion rp2040-hal/examples/adc_fifo_poll.rs
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,12 @@ fn main() -> ! {
let mut i = 0;

// initialize a timer, to measure the total sampling time (printed below)
let timer = hal::Timer::new(pac.TIMER, &mut pac.RESETS, &clocks.reference_clock);
let timer = hal::Timer::new(
pac.TIMER,
&mut pac.RESETS,
&watchdog,
&clocks.reference_clock,
);

loop {
// busy-wait until the FIFO contains at least two samples:
Expand Down
7 changes: 6 additions & 1 deletion rp2040-hal/examples/blinky.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,12 @@ fn main() -> ! {
.ok()
.unwrap();

let mut timer = rp2040_hal::Timer::new(pac.TIMER, &mut pac.RESETS, &clocks.reference_clock);
let mut timer = rp2040_hal::Timer::new(
pac.TIMER,
&mut pac.RESETS,
&watchdog,
&clocks.reference_clock,
);

// The single-cycle I/O block controls our GPIO pins
let sio = hal::Sio::new(pac.SIO);
Expand Down
7 changes: 6 additions & 1 deletion rp2040-hal/examples/vector_table.rs
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,12 @@ fn main() -> ! {
// Configure GPIO25 as an output
let led_pin = pins.gpio25.into_push_pull_output();

let mut timer = hal::Timer::new(pac.TIMER, &mut pac.RESETS, &clocks.reference_clock);
let mut timer = hal::Timer::new(
pac.TIMER,
&mut pac.RESETS,
&watchdog,
&clocks.reference_clock,
);
critical_section::with(|cs| {
let mut alarm = timer.alarm_0().unwrap();
// Schedule an alarm in 1 second
Expand Down
4 changes: 2 additions & 2 deletions rp2040-hal/src/clocks/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
//! let xosc = setup_xosc_blocking(peripherals.XOSC, XOSC_CRYSTAL_FREQ.Hz()).map_err(InitError::XoscErr)?;
//!
//! // Start tick in watchdog
//! watchdog.enable_tick_generation((XOSC_CRYSTAL_FREQ / 1_000_000) as u8);
//! watchdog.enable_tick_generation((XOSC_CRYSTAL_FREQ / 1_000_000) as u16);
//!
//! let mut clocks = ClocksManager::new(peripherals.CLOCKS);
//!
Expand Down Expand Up @@ -330,7 +330,7 @@ pub fn init_clocks_and_plls(
let xosc = setup_xosc_blocking(xosc_dev, xosc_crystal_freq.Hz()).map_err(InitError::XoscErr)?;

// Configure watchdog tick generation to tick over every microsecond
watchdog.enable_tick_generation((xosc_crystal_freq / 1_000_000) as u8);
watchdog.enable_tick_generation((xosc_crystal_freq / 1_000_000) as u16);

let mut clocks = ClocksManager::new(clocks_dev);

Expand Down
18 changes: 14 additions & 4 deletions rp2040-hal/src/timer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,8 @@ use crate::{
clocks::ReferenceClock,
pac::{self, RESETS, TIMER},
resets::SubsystemReset,
typelevel::Sealed, Clock,
typelevel::Sealed,
Clock, Watchdog,
};

/// Instant type used by the Timer & Alarm methods.
Expand Down Expand Up @@ -59,8 +60,16 @@ impl Timer {
/// Make sure that clocks and watchdog are configured, so
/// that timer ticks happen at a frequency of 1MHz.
/// Otherwise, `Timer` won't work as expected.
pub fn new(timer: TIMER, resets: &mut RESETS, clocks: &ReferenceClock) -> Self {
assert_eq!(clocks.freq().to_Hz(), 1_000_000);
pub fn new(
timer: TIMER,
resets: &mut RESETS,
watchdog: &Watchdog,
clocks: &ReferenceClock,
) -> Self {
assert_eq!(
clocks.freq().to_Hz() / u32::from(watchdog.cycles_per_ticks()),
1_000_000
);
timer.reset_bring_down(resets);
timer.reset_bring_up(resets);
Self { _private: () }
Expand Down Expand Up @@ -185,8 +194,9 @@ impl eh1_0_alpha::delay::DelayUs for Timer {
/// // Make sure to initialize clocks, otherwise the timer wouldn't work
/// // properly. Omitted here for terseness.
/// let clocks: rp2040_hal::clocks::ClocksManager = todo!();
/// let watchdog: rp2040_hal::Watchdog = todo!();
/// // Configure the Timer peripheral in count-down mode
/// let timer = rp2040_hal::Timer::new(pac.TIMER, &mut pac.RESETS, &clocks);
/// let timer = rp2040_hal::Timer::new(pac.TIMER, &mut pac.RESETS, &watchdog, &clocks.reference_clock);
/// let mut count_down = timer.count_down();
/// // Create a count_down timer for 500 milliseconds
/// count_down.start(500.millis());
Expand Down
9 changes: 8 additions & 1 deletion rp2040-hal/src/watchdog.rs
Original file line number Diff line number Diff line change
Expand Up @@ -60,14 +60,21 @@ impl Watchdog {
///
/// * `cycles` - Total number of tick cycles before the next tick is generated.
/// It is expected to be the frequency in MHz of clk_ref.
pub fn enable_tick_generation(&mut self, cycles: u8) {
pub fn enable_tick_generation(&mut self, cycles: u16) {
const WATCHDOG_TICK_ENABLE_BITS: u32 = 0x200;

assert_eq!(cycles & !0x1FF, 0);

self.watchdog
.tick
.write(|w| unsafe { w.bits(WATCHDOG_TICK_ENABLE_BITS | cycles as u32) })
}

/// Returns the number of `clk_ref` cycles between each watchdog (and Timer) ticks.
pub fn cycles_per_ticks(&self) -> u16 {
self.watchdog.tick.read().cycles().bits()
}

/// Defines whether or not the watchdog timer should be paused when processor(s) are in debug mode
/// or when JTAG is accessing bus fabric
///
Expand Down

0 comments on commit f933b0c

Please sign in to comment.