

# **APPLICATION NOTE**

# PLL Generation using ST62 Auto-reload Timer

J.NICOLAI

# INTRODUCTION

This note describes how to generate a digital signal locked in phase and frequency (PLL) with a calibrated delay starting from an active edge on the Auto-reload timer input pin.

#### Auto-reload timer description

This timer is an 8 bit timer/counter with prescaler. It includes auto-reload PWM, capture and compare capability with one input and one output pins. It can be controlled by thefollowing registers (8 bit):

- Mode Control Register (MC)
- Status registers (SC0, SC1)
- Load register (LR)
- Incremental counter register (TC)
- Compare register (CP)
- Reload/Capture register (RC)

It can also wake-up the MCU from wait mode and exit from stop mode if an external event is present on the input pin. The prescaler ratio can be programmed to choose the timer input frequency  $F_{N}$  (see Table 1).

### Figure 1. Auto-reload Timer Block Diagram



# Example:

The TIMIN input receives a 15 kHz digital signal. We want to generate a phase-locked 15 kHz digital signal with a falling edge delayed 19us from the input rising edge, and a duty cycle of 75%. The CPU quartz frequency is 8 MHz.

The Figure 2 shows the TIMOUT signal generated in "load on external edge" mode, given the above TIMIN signal: on TIMIN rising edge, the TC count register is loaded with the value contained in RC register (160 in this example). The timer will re-sume counting from value 160. When the compare value (210 in this example) is reached, the TI-MOUT signal goes down. The timer keeps counting until the overflow (255) is reached. At this point, signal TIMOUT rises again. The timer keeps counting from 0 until next active edge on TIMIN. At this time, TC is loaded again with the RC value (160) and so on...

The delay from TIMIN edge to TIMOUT falling edge is given by CP-RC (multiplied by the TC register clock period Fin). The low level duration on TI-MOUT is given by 255 - CP. The remaining of the TIMOUT period is variable, and will adjust to the TIMIN period: small variations of TIMIN period will be absorbed by a variation of TVAR. The following rule must be respected in order to get the proper output signal:

The variable time Tvar must stay smaller than CP, (otherwise the falling edge on TIMOUT occurs berore rising edge on TIMIN) and larger than 0 (otherwise the rising edge on TIMOUT never occurs).

In other words, the period of input TIMIN (TOT in terms of TC clock cycles) must meet the following requirement:

255 - RC < TOT < 255 - RC + CP

Coming back to our example, let's calculate the timer settings:

The input period is Tin =  $1/15 \text{ kHz} = 66.7 \mu \text{s}$ 





Note: All numbers are decimal

2/4

| Bit 0<br>Reg. SC1 | PS2 | PS1 | PS0 | PRESCALER<br>Ratio |
|-------------------|-----|-----|-----|--------------------|
| 0                 | 0   | 0   | 0   | 1                  |
| 0                 | 0   | 0   | 1   | 2                  |
| 0                 | 0   | 1   | 0   | 4                  |
| 0                 | 0   | 1   | 1   | 8                  |
| 0                 | 1   | 0   | 0   | 16                 |
| 0                 | 1   | 0   | 1   | 32                 |
| 0                 | 1   | 1   | 0   | 64                 |
| 0                 | 1   | 1   | 1   | 128                |
| 1                 | 0   | 0   | 0   | 3                  |
| 1                 | 0   | 0   | 1   | 6                  |
| 1                 | 0   | 1   | 0   | 12                 |
| 1                 | 0   | 1   | 1   | 24                 |
| 1                 | 1   | 0   | 0   | 48                 |
| 1                 | 1   | 0   | 1   | 96                 |
| 1                 | 1   | 1   | 0   | 192                |
| 1                 | 1   | 1   | 1   | 384                |

**Table 1. Prescaler Programming Ratio** 



#### Calculation of the prescaler ratio:

We want the best possible resolution, e.g. the smaller possible prescaler ratio: we would like the TC counter to count up to the highest number: 255 (for best resolution). In this case  $66.7\mu s / 255 = 0.26\mu s$  is the smallest TC clock period that we can use. With a prescaler ratio of 1, the TC clock period is  $1/8MHz = 0.125\mu s$ . So we need a prescaler ratio of 3, giving a TC clock period of 3/8 MHz =  $0.375\mu s$ . This is the elementary incrementing time of the TC counter, which gives the resolution of the phase shift and of the bw level on TIMOUT (the TC counter is incremented with a clock  $F_{IN} = 1/0.375\mu s = 2667kHz$ ).

The desired delay is  $19\mu$ s: CP - RC =  $19\mu$ s /0.375 $\mu$ s = 50.67.

The TIMIN period is:

TOT = 66.7μs / 0.375 μs = 177.78.

The duty cycle is: 0.25 = (255 - CP)/TOT

Rounding the decimals, this gives:

RC = 160; CP = 210; TOT = 178

The variable time  $T_{VAR}$  is:  $T_{VAR} = TOT - 255 + RC = 83$ 

The condition is met: Tvar is positive and smaller than CP: (255 - 160) < 178 < (255 - 160 + 210)

The TIMOUT signal will remain correct and stable as long as this condition is met, even if the input frequency varies:

The input frequency limits for output correctness are:

(255 - 160) x 0.375µs < T<sub>IN <</sub> (255 - 160 + 210) x 0.375µs

The output signal will remain locked in phase and frequency as long as the input signal TIMIN is in the range:

8.7kHz < TIMIN frequency < 28kHz

Of course, it is also possible to modify by software the  $19\mu$ s delay and the 75% duty cycle, for example by measuring repetitively an error voltage with the A/D converter and calculating the modified delay or duty cycle.

#### **Program example**

| ;************** A-R Timer Register Set ********************* |                                                                                                                                        |                                                                                                                                                                     |  |  |
|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RC<br>CP<br>MC<br>SC0<br>SC1<br>LR<br>;=======               | .def 0D9h,0FFh,0FFh<br>.def 0DAh,0FFh,0FFh<br>.def 0D5h,0FFh,0FFh<br>.def 0D6h,0FFh,0FFh<br>.def 0D7h,0FFh,0FFh<br>.def 0DBh,0FFh,0FFh | <pre>;reload/capture register ;compare register ;mode control register ;status/control register 0 ;status/control register 1 ;load register</pre>                   |  |  |
|                                                              | ldi CP, 210<br>ldi RC, 160<br>ldi SC1,00000101b                                                                                        | ;compare register = 210d<br>;reload register = 160d<br>;clock source= CPU clock divided by 3<br>;rising TIMIN edge active<br>;pull-up disabled, prescaler ratio = 1 |  |  |
|                                                              | ldi MC, 11100011b                                                                                                                      | ;load on TIMIN mode,interrupts disabled<br>;PWMOUT enabled, start timer                                                                                             |  |  |



THE SOFTWARE INCLUDED IN THIS NOTE IS FOR GUIDANCE ONLY. SGS-THOMSON SHALL NOT BE HELD LIABLE FOR ANY DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM USE OF THE SOFTWARE.

Information furnished is believed to be accurate and reliable. However, SGS-THOMSON Microelectronics assumes no responsability for the consequences of use of such information nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of SGS-THOMSON Microelectronics. Specificationsmentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied.

SGS-THOMSON Microelectronics products are not authorized for use as critical components in life support devices or systems without the express written approval of SGS-THOMSON Microelectronics.

© 1994 SGS-THOMSON Microelectronics - All rights reserved.

Purchase of I<sup>2</sup>C Components by SGS-THOMSON Microelectronics conveys a license under the Philips I<sup>2</sup>C Patent. Rights to use these components in an I<sup>2</sup>C system is granted provided that the system conforms to the I<sup>2</sup>C Standard Specification as defined by Philips.

SGS-THOMSON Microelectronics Group of Companies

Australia - Brazil - France - Germany - Hong Kong - Italy - Japan - Korea - Malaysia - Malta - Morocco - The Netherlands Singapore - Spain - Sweden - Switzerland - Taiwan - Thailand - United Kingdom - U.S.A.

