Function
CLASSB_TEST_STATUS CLASSB_ClockTest(uint32_t cpu_clock_freq, uint8_t error_limit, uint16_t clock_test_tmr1_cycles, bool running_context);
Summary
This self-test checks whether the CPU clock frequency is within the permissible limit.
Description
This self-test uses TMR1 and SysTick to measure the CPU clock frequency. The TMR1 is clocked at 32768 Hz from the external crystal and CPU clock can be from any other high frequency oscillator. If the CPU clock frequency is within specified error limit, it returns PASS. The test duration is defined by the value of tmr1_cycles. The TMR1 is configured to take clock from an external 32.768 kHz accurate crystal.
Precondition
None.
Parameters
cpu_clock_freq - Expected CPU clock frequency.
error_limit - Permissible error limit (eg; 5 means +-5 percent).
clock_test_tmr1_cycles - The test duration in terms of TMR1 cycles.
running_context - False for startup test. True for run-time test.
Returns
CLASSB_TEST_STATUS - Status of the test.
Example
CLASSB_TEST_STATUS classb_test_status = CLASSB_TEST_NOT_EXECUTED;
// Perform run-time test of the CPU clock
classb_test_status = CLASSB_ClockTest(120000000, 5, 500, true);
Remarks
This self-test can be used during startup as well as run-time. This self-test shall be used only if there is an external 32.768 kHz accurate crystal connected to the XOSC32K of the microcontroller.