Clock monitor HIL test (#1425)

* tests: Add clock_monitor HIL test

* feat: Adjust accepted freq ranges

* fix: Get the estimate a second time if its very off

* test: Update ranges and check
This commit is contained in:
Sergio Gasquez Arcos 2024-04-15 11:54:55 +02:00 committed by GitHub
parent 634191203f
commit 381ce9530c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 60 additions and 0 deletions

View File

@ -1821,6 +1821,10 @@ impl RtcClock {
.rtc_cali_start()
.set_bit()
});
timg0
.rtccalicfg()
.modify(|_, w| w.rtc_cali_start().set_bit());
while timg0.rtccalicfg().read().rtc_cali_rdy().bit_is_clear() {}
(timg0.rtccalicfg1().read().rtc_cali_value().bits()

View File

@ -628,6 +628,11 @@ impl RtcClock {
.rtc_cali_start()
.set_bit()
});
timg0
.rtccalicfg()
.modify(|_, w| w.rtc_cali_start().set_bit());
while timg0.rtccalicfg().read().rtc_cali_rdy().bit_is_clear() {}
(timg0.rtccalicfg1().read().rtc_cali_value().bits()

View File

@ -12,6 +12,10 @@ harness = false
name = "aes_dma"
harness = false
[[test]]
name = "clock_monitor"
harness = false
[[test]]
name = "crc"
harness = false

View File

@ -0,0 +1,47 @@
//! Clock Monitor Test
//% CHIPS: esp32 esp32c2 esp32c3 esp32c6 esp32h2 esp32s2 esp32s3
#![no_std]
#![no_main]
use defmt_rtt as _;
use esp_backtrace as _;
use esp_hal::{clock::ClockControl, peripherals::Peripherals, prelude::*, rtc_cntl::Rtc};
struct Context<'a> {
rtc: Rtc<'a>,
}
impl Context<'_> {
pub fn init() -> Self {
let peripherals = Peripherals::take();
let system = peripherals.SYSTEM.split();
ClockControl::boot_defaults(system.clock_control).freeze();
let rtc = Rtc::new(peripherals.LPWR, None);
Context { rtc }
}
}
#[cfg(test)]
#[embedded_test::tests]
mod tests {
use super::*;
#[init]
fn init() -> Context<'static> {
Context::init()
}
#[test]
fn test_estimated_clock(mut ctx: Context<'static>) {
#[cfg(feature = "esp32c2")] // 26 MHz
defmt::assert!((23..=29).contains(&ctx.rtc.estimate_xtal_frequency()));
#[cfg(feature = "esp32h2")] // 32 MHz
defmt::assert!((29..=35).contains(&ctx.rtc.estimate_xtal_frequency()));
#[cfg(not(any(feature = "esp32h2", feature = "esp32c2")))] // 40 MHz
defmt::assert!((35..=45).contains(&ctx.rtc.estimate_xtal_frequency()));
}
}