Internal Clock Generator (ICG) Module)
MC68HC908GT16 MC68HC908GT8 Data Sheet, Rev. 3
88
Freescale Semiconductor
;* Clock Monitor Enable Code Example
;* This code turns on both clocks, selects the desired one,
;* then turns on the Clock Monitor and CM Interrupt
;* ICG Clock Monitor Enable
CMEnable:
bset ECGON,ICGCR ; turn on external oscillator
; (assumes internal osc is on)
brclr ECGS,ICGCR,* ; wait until external clock engaged
bset CS,ICGCR ; select external clock for bus
bset CMON,ICGCR ; enable Clock Monitor
bset CMIE,ICGCR ; enable CM interrupt
Figure 7-10. Code Example for Enabling the Clock Monitor
7.4.3 Using Clock Monitor Interrupts
The clock monitor circuit can be used to recover from perilous situations such as crystal loss. To use the
clock monitor effectively, these points should be observed:
Enable the clock monitor and clock monitor interrupts.
The first statement in the clock monitor interrupt service routine (CMISR) should be a read to the
ICG control register (ICGCR) to verify that the clock monitor flag (CMF) is set. This is also the first
step in clearing the CMF bit.
The second statement in the CMISR should be a write to the ICGCR to clear the CMF bit (write the
bit low). Writing the bit high will not affect it. This statement does not need to immediately follow
the first, but must be contained in the CMISR.
The third statement in the CMISR should be to clear the CMON bit. This is required to ensure
proper reconfiguration of the reference dividers. This statement also must be contained in the
CMISR.
Although the clock monitor can be enabled only when both clocks are stable (ICGS is set or ECGS
is set), it will remain set if one of the clocks goes unstable.
The clock monitor only works if the external slow (EXTSLOW) bit in the CONFIG2 register is set to
the correct value.
The internal and external clocks must both be enabled and running to use the clock monitor.
When the clock monitor detects inactivity, the inactive clock is automatically deselected and the
active clock selected as the source for CGMXCLK and TBMCLK. The CMISR can use the state of
the CS bit to check which clock is inactive.
When the clock monitor detects inactivity, the application may have been subjected to extreme
conditions which may have affected other circuits. The CMISR should take any appropriate
precautions.
7.4.4 Quantization Error in DCO Output
The digitally controlled oscillator (DCO) is comprised of three major sub-blocks:
1.
Binary weighted divider
2.
Variable-delay ring oscillator
3.
Ring oscillator fine-adjust circuit
Each of these blocks affects the clock period of the internal clock (ICLK). Since these blocks are controlled
by the digital loop filter (DLF) outputs DDIV and DSTG, the output of the DCO can change only in