The Clock Monitor Unit (CMU)

Initializing the CMU on MPC56xx & MPC57xx Devices

by: NXP Semiconductors

1 Introduction

A part's clocks are critical to its safe operation. They need to be accurate and correctly programmed and if there is any variation in their frequency then the application should be notified. Because of this, most NXP safety critical parts contain several Clock Monitor Units (CMU).

The main CMU of each device serves three purposes:

- Measures the frequency of the internal oscillator (IRCOSC)
- Monitors the external oscillator (XOSC) clock
- Monitors a selected clock

2 Overview

Main features of a CMU:

- Frequency meter: measure the IRCOSC frequency using the XOSC as a reference.
- XOSC clock monitoring: monitor the existence of the XOSC by comparing it to the IRCOSC clock.
- Selected clock monitoring: monitor the frequency of a selected clock against a user programmed upper and lower frequency boundary using IRCOSC clock ÷ 4 as a reference.
- Event generation for various failures detected.

The majority of the MPC56xx and MPC57xx parts have more than one CMU unit. The device has a CMU_0 that is capable of measuring the IRCOSC, XOSC monitoring, and monitoring one of the other system clocks. The device then contains other CMU_n blocks that are capable of monitoring other important system clocks. See the following table for examples of the CMU use for the MPC5643L and MPC5744P devices:

<table>
<thead>
<tr>
<th>Device</th>
<th>Module</th>
<th>Monitored clocks</th>
</tr>
</thead>
<tbody>
<tr>
<td>MPC5643L</td>
<td>CMU_0</td>
<td>• System clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• XOSC</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• IRCOSC</td>
</tr>
<tr>
<td></td>
<td>CMU_1</td>
<td>• Motor control clock</td>
</tr>
<tr>
<td></td>
<td>CMU_2</td>
<td>• FlexRay Clock</td>
</tr>
</tbody>
</table>

Table continues on the next page...
The user can use the CMU_0 to verify the exact frequency of the IRCOSC clock. Since this clock can be used as the reference for other system clocks or protocol clocks it could be critical to know the exact frequency to ensure proper protocol timing. The CMU_0 can also be used to monitor the XOSC. This feature only checks that the XOSC > (IRCOSC clock) ÷ 2^{RCDIV} where the RCDIV is a user selectable value of 0, 1, 2, or 3 in the CMU’s Control Status Register (CMU_CSR). This feature does not measure the frequency of the XOSC. Assuming an IRCOSC clock of 16 MHz, the CMU only checks that the XOSC is greater than either 16 MHz, 8 MHz, 4 MHz, or 2 MHz.

The user can closely monitor any of the selected system clocks that are hooked up to one of the part's many CMU's. With this feature the user can set an upper and lower limit for the CMU to compare the selected clock’s frequency.

When a failure is detected in a CMU, by either the selected clock monitor or the XOSC monitor, the CMU can notify different modules in the system depending on the device's configuration. For some devices, this could be the Reset Generation Module (MC_RGM), the Mode Entry (MC_ME) module, and the Fault Control and Collection Unit (FCCU) module. The user has the option to program the system's reaction to a CMU fault through the modules that get notified. Some of the options available depending on what modules are available in the device are generating a reset, entering SAFE mode, or generating an interrupt.

In the Figure 1. CMU_0 Block Diagram on page 3 below, the clock selection signal, controlled by the clock selection (CKSEL1) bits of the CMU_CSR, allows the user to select from several different reference sources. In truth the only option that is ever implemented is the IRCOSC. In some devices, it is hooked up to one of the inputs making the other ones invalid and in others it is hooked up to all of them.
In the Figure 2. CMU_n Block Diagram on page 3 below, the blocks for the frequency meter and the blocks for monitoring the XOSC are absent. The CMU_n modules do not support these functions.

Different device manuals might refer to the CMU signals differently. MPC56xx manuals usually reference the IRCOSC and the XOSC signals directly while it is more common in the MPC57xx devices to use the more formal signal names such as CLKMN0_RMT and CLKMNMT0_RMN. The Table 2. Signal Description on page 4 table below describes which clock sources are connected to which CMU signals.
Table 2. Signal Description

<table>
<thead>
<tr>
<th>Signal</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKMN0_RMT</td>
<td>I</td>
<td>Monitored Clock Signal 0/Metered Clock Signal Reference — Receives a clock signal that the CMU compares to a specified low-limit frequency to determine whether the frequency of the clock signal is greater than the specified limit. Also provides a reference clock signal for all metered clock signals.</td>
</tr>
<tr>
<td>(Always XOSC)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKMN1</td>
<td>I</td>
<td>Monitored Clock Signal 1 — Receives a clock signal that the CMU compares to specified low limit and high limit frequencies to determine whether the frequency of the clock signal is between the specified limits.</td>
</tr>
<tr>
<td>CLKMT0_RMN</td>
<td>I</td>
<td>Metered Clock Signal 0/Monitored Clock Signal Reference — Receives a clock signal that the CMU measures against a reference clock frequency. Also provides a reference clock signal for all monitored clock signals.</td>
</tr>
<tr>
<td>(Always IRCOSC)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

3 Procedure

3.1 Measuring the IRCOSC, also called frequency metering

The frequency meter, which is part of CMU_0, measures the IRCOSC (CLKMT0_RMN) using a known frequency, the XOSC (CLKMN0_RMT). Knowing the exact frequency of the IRCOSC allows the user to make other timing corrections if necessary. The measurement starts when the start frequency measurement (SFM) bit of the Control Status Register (CMU_CSR) is set. The measurement duration is given by the measurement duration (MD) bits of the Measurement Duration Register (CMU_MDR) in terms of IRCOSC clock cycles with a width of 20 bits. The SFM bit is cleared by the hardware after the frequency measurement is done and the count is loaded in the measured frequency (FD) bits of the Frequency Display Register (CMU_FDR). The IRCOSC measurement be can derived as follows:

\[ f_{sel} = f_{CLKMN0_RMT} \times \frac{CMU_MDR[MD]}{CMU_FDR[FD]} \]

Steps:
1. Program the CMU_MDR[MD] value.
2. Program the CMU_CSR[CKSEL1] bit to the CLKMT0_RMN you wish to measure.
3. Enable the monitor by setting the CMU_CSR[SMF] bit.
4. When the CMU_CSR[SMF] bit is clear read the CMD_FDR[FD] value and calculate the IRCOSC frequency.

3.2 Monitoring the XOSC clock

The XOSC (CLKMN0_RMT) clock is automatically monitored by CMU_0. If the XOSC is determined on and stable, signaled by CLKMN0_RMT_ACTIVE signal, and the frequency of the XOSC meets the following condition:

\[ f_{XOSC_CLK} < f_{IRCOSC_CLK} \times 2^{CSR[RCDIV]} \]

then an oscillator less than (OLR) error event has occurred and the CMU_0 takes the following steps:
1. The oscillator less than interrupt bit (OLRI) gets set in the CMU Interrupt Status Register (CMU_ISR[OLRI]).
2. A failure event is signaled to the system which can react as programmed by the user. In many devices the MC_RGM, MC_ME, and FCCU are notified, which in turn can generate a 'functional' reset, a SAFE mode request, or an interrupt.
For the MPC56xx devices the XOSC monitor may produce a false event when
\[ f_{\text{XOSC,CLK}} < 2 \times \frac{f_{\text{IRCOSC,CLK}}}{2^{\text{CSR[RCDIV]}}} \]
due to an accuracy limitation of the compare circuitry.

**NOTE**

For the MPC57xx devices the \( f_{\text{XOSC,CLK}} \) (CLKMN0_RMT) must be greater than \( f_{\text{IRCOSC,CLK}} / 2^{\text{CSR[RCDIV]}} \) (CLKMT0_RMN) by at least 0.5 MHz in order to guarantee correct XOSC (CLKMN0_RMT) monitoring.

### 3.3 Monitoring the system clock or any other CMU\textsubscript{n} clock

This section applies to the device’s main system clock, usually monitored by CMU\textsubscript{0}, and all monitored clocks (CLKMN1) monitored by the other CMU\textsubscript{n}s on the device.

The monitored clock (CLKMN1) frequency can be monitored by setting the Clock Monitor Enable (CME) bit in the CMU_CSR. The clock monitoring starts as soon as CMU_CSR[CME] = 1. This monitor can be disabled at any time by writing CMU_SCR[CME] = 0.

If the monitored clock is greater than the High Frequency Reference (HFREF) value programmed into the High Frequency Reference Register (CMU_HFREFR) and the monitored clock is enabled, then:

- A frequency higher than high reference (FHH) event is detected and CMU_ISR[FHHI] is set
- A failure event is signaled to the system which can react as programmed by the user. In many devices the MC_RGM, MC_ME, and FCCU are notified, which in turn can generate a ‘functional’ reset, a SAFE mode request, or an interrupt.

If the monitored clock is less than the Low Frequency Reference (LFREF) value programmed into the Low Frequency Reference Register (CMU_LFREFR) and the monitored clock is enabled, then:

- A frequency lower than low reference (FLL) event is detected and CMU_ISR[FLLI] is set
- A failure event is signaled to the system which can react as programmed by the user. In many devices the MC_RGM, MC_ME, and FCCU are notified, which in turn can generate a ‘functional’ reset, a SAFE mode request, or an interrupt.

On the MPC56xx devices only, if the monitored clock is less than the reference clock frequency (FIRCOSC,CLK ÷ 4) and the monitored clock is enabled, then:

- a frequency lower than reference clock (FLC) event is detected and CMU_ISR[FLCI] is set
- A failure event is signaled to the system which can react as programmed by the user. In many devices the MC_RGM, MC_ME, and FCCU are notified, which in turn can generate a ‘functional’ reset, a SAFE mode request, or an interrupt.

**NOTE**

For the MPC56xx devices the system clock monitor may produce a false event when the monitored clock is less than \( 2 \times \frac{f_{\text{IRCOSC,CLK}}}{2^{\text{CSR[RCDIV]}}} \) due to an accuracy limitation of the compare circuitry.

The following equations are used to calculate HFREF and LFREF:

\[
\text{HFREF} = \frac{f_{\text{CLKMN1}}}{(f_{\text{IRCOSC}} ÷ 4)} \times 16
\]

\[
\text{LFREF} = \frac{f_{\text{CLKMN1}}}{(f_{\text{IRCOSC}} ÷ 4)} \times 16
\]
Steps:

1. Program the CMU_HFREFR[HFREF] and CMU_LFREFR[LFREF] values.
2. Enable the monitor by setting the CMU_CSR[CME] bit.

3.4 Requirements

A key point that always needs to be considered is that the user should check a device’s data sheet for its IRCOSC variation. For any device, there are specifications for IRCOSC variation. It is necessary to take this into account when calculating the HFREF and LFREF values. Failure to adhere to the allowable variation detailed in a device's data sheet could result in false failures. The two tables below have excerpts from the MPC5643L and the MPC5744P data sheet.

Table 3. MPC5643L 16 MHz RC oscillator electrical characteristics

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>$\Delta_{\text{RCMVAR}}$</td>
<td>Fast internal RC oscillator variation over temperature and supply with respect to $f_{\text{RC}}$ at $T_A = 25$ °C in high-frequency configuration</td>
<td>-</td>
<td>-6</td>
<td>-</td>
<td>6</td>
<td>%</td>
</tr>
</tbody>
</table>

Table 4. MPC5744P Internal RC Oscillator electrical specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>$\delta F_{\text{var_noT}}$</td>
<td>IRC frequency variation without temperature compensation</td>
<td>$T_J &lt; 150$ °C</td>
<td>-8</td>
<td>-</td>
<td>8</td>
<td>%</td>
</tr>
<tr>
<td></td>
<td></td>
<td>$T_J &lt; 165$ °C</td>
<td>-10</td>
<td>-</td>
<td>10</td>
<td>%</td>
</tr>
</tbody>
</table>

An example of determining the $HFREF_{\text{Actual}}$ and $LFREF_{\text{Actual}}$ for the MPC5744P device is as follows. The $f_{\text{IRCOSC,CLK}} = 16$ MHz with an accuracy of +/- 8%. In order to monitor a $f_{\text{CLKMN1}} = 200$ MHz the ideal reference value is:

$HFREF_{\text{Ideal}} = (200 / (16 / 4)) * 16$
$HFREF_{\text{Ideal}} = (200 / 4) * 16$
$HFREF_{\text{Ideal}} = 50 * 16$
$HFREF_{\text{Ideal}} = 800.$

The $HFREF_{\text{Ideal}}$ and $LFREF_{\text{Ideal}}$ are the same. The $HFREF_{\text{Actual}}$ and $LFREF_{\text{Actual}}$ are:

$HFREF_{\text{Actual}} = HFREF_{\text{Ideal}} + (HFREF_{\text{Ideal}} * 0.08)$
$HFREF_{\text{Actual}} = 800 + (800 * 0.08)$
$HFREF_{\text{Actual}} = 800 + 64$
$HFREF_{\text{Actual}} = 864$ $LFREF_{\text{Actual}} = LFREF_{\text{Ideal}} - (LFREF_{\text{Ideal}} * 0.08)$
$LFREF_{\text{Actual}} = 800 - (800 * 0.08)$
$LFREF_{\text{Actual}} = 800 - 64$
$LFREF_{\text{Actual}} = 736$
4 Code Example

See the attached Green Hills project for MPC5744P example code.