

# FT61F02X

# **TIMERO Application note**



#### Table of contents

| 1.timer (TIMERS)       |                                               | 3  |
|------------------------|-----------------------------------------------|----|
| 1.1. timer0 (T         | IMER0)                                        | 4  |
| 1.1.1. Timer(          | 0Summary of related registers                 | 5  |
| 1.1.2. exis            | stTimer0andWDTSwitch between divider circuits | 6  |
| 2.Application examples |                                               | 7  |
| Contact information    |                                               | 10 |



# FT61F02x TIMER0application

## 1.timer (TIMERS)

in total7timers, including the watchdog timer (WDT)inside.

|                   | WDT                 | Timer0                                                         | Timer1                                                  | Timer2                           | Timer3/4/5                                                                                           |
|-------------------|---------------------|----------------------------------------------------------------|---------------------------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------|
| Prescaler (bits)  | -                   | 8 (andWDTshared)                                               | 3 (1x, 2x, 4x, 8x)                                      | 4 (1x, 4x, 16x)                  | 7 (1x, 2x, 4x, 8x,<br>16x, 32x, 64x, 128x)                                                           |
| counter (bit)     | 16                  | 8                                                              | 16                                                      | 8                                | 12                                                                                                   |
| Postscaler (bits) | 7 (andTimer0shared) | -                                                              | -                                                       | 4 (1 – 16x)                      | -                                                                                                    |
| clock source      | - <u>LIRC</u>       | - instruction clock - PA2/TOCKI (transition edge count device) | - instruction clock - LP - PA7/T1CKI (rising edge count | - 2xcommand<br>bell<br>- 2x HIRC | - HIRC - 2xinstruction clock - PA2/TOCKI (transition edge counter) - PA7/T1CKI (rising edge counter) |

#### surface1-1timer resource

Note: If the clock source of the timer is not the instruction clock, after changingTMRxBefore setting the "TMRxON = 0".

When the timer is enabled, its selected clock source is automatically turned on. When the timer selectsLPWhen the oscillator is used as the clock source, theFOSCmust be configured accordinglyLPmode or choiceINTOSCIOmode, otherwiseLPThe oscillator will be off and will not generate counts.

WDTThe postscaler (postscaler) and Timer 0 The prescaler (prescaler) Share the same hardware frequency division circuit. The hardware circuit is assigned by instruction selection to WDT or Timer 0, but both cannot be used at the same time. For timers that are not assigned a divider, the divider ratio is "1".

existPORor system reset, exceptTimer0counter of (counter)The counters, prescalers, and postscalers of all other timers will be reset except. The following events will also reset the counter and divider of the corresponding timer:

|              | WDT                         | Timer0                        | Timer1                         | Timer2                                                       | Timer3/4/5                    |
|--------------|-----------------------------|-------------------------------|--------------------------------|--------------------------------------------------------------|-------------------------------|
| prescaler    | -                           | - WriteTMR0<br>- PSAto switch | - TMR1ON = 0<br>- WriteTMR1L/H | - LIRCandHIRC  Cross Calibration Start - WriteT2CON, TMR2L/H | - WriteTMRxL/H - WriteTxCKDIV |
|              |                             |                               |                                | - any reset action                                           |                               |
|              | - WDT, OSToverflow          | -Timer0overflow               | - TMR1 = PR1                   | - TMR2 = PR2                                                 | - TMRx = PRx                  |
|              | - enter/exitSLEEP           |                               | (match, special                | (match)                                                      | (BUZZERmode                   |
| counter      | - CLRWDT                    |                               | event trigger)                 |                                                              | match)                        |
|              | - WriteWDTCON               |                               | - ECCPtrigger special          |                                                              |                               |
|              |                             |                               | special event                  |                                                              |                               |
|              | except writeWDTCONoutside   |                               |                                | - WriteT2CON,                                                |                               |
| post divider | all of the above conditions |                               | -                              | TMR2L/H                                                      | -                             |
|              | - PSAto switch              |                               |                                | - any reset action                                           |                               |

surface1-2Timer counter and divider reset events



### 1.1. timer0 (TIMER0)



picture1-1Timer0Structure diagram

Timer0can be used asI/O "PA2-T0CKI"Rising edge/falling edge counters, or timing timers (the clock source is the instruction clock).

Timer0Count and timeout time = TMR0[7:0] \* Timer0\_prescaler

TimerOAn overflow will set the interrupt flag bit (TOIF), whether to triggerto interrupt depends on the corresponding enable control bit (TOIEandGIE).

#### Note:

1.rightTMR0after a write operation2In an instruction cycle,Timer0stop incrementing;

2.existSLEEPmode,Timer0It will stop counting and maintain the count value before going to sleep;

3.ifTimer0used to pairT0CKIis counted, then relative toTimer0,rightT0CKIThere are minimum period, high/low pulse width requirements. unlessT0CKIvery fast andTтоскVery slow, otherwise these constraints are usually met;

| T0CKI                | minimum value                       | unit | condition                          |  |  |
|----------------------|-------------------------------------|------|------------------------------------|--|--|
|                      | 0.5*Ттоск+ 20                       | ns   | no prescaler                       |  |  |
| High/Low Pulse Width | 10                                  | ns   | with prescaler                     |  |  |
| cycle                | 20and (Ττοςκ+40)/Nthe greater of    | ns   | N = 1, 2, 4,, 256 (with prescaler) |  |  |
|                      | 20and (110ck +40)/ Nulle greater of | 113  | N = 1 (no prescaler)               |  |  |

- 4 -

4.About "inTimer0andWDTswitching between divider circuits" seechapter1.1.1;



#### 1.1.1. Timer0Summary of related registers

| name      | state                                                                                                           |         |                                                             |                        |            | register    | address      | reset value |
|-----------|-----------------------------------------------------------------------------------------------------------------|---------|-------------------------------------------------------------|------------------------|------------|-------------|--------------|-------------|
| T0CS      | Timer0clock source                                                                                              |         | = <u>PA2/T0CKI</u> (counter) 0 =<br>struction clock (timer) |                        | OPTION[5]  |             | RW-1         |             |
| TOSE      | Counter trigger edge                                                                                            |         | =f <u>alling edge</u><br>=rising edge                       |                        | OPTON[4]   |             | RW-1         |             |
| PSA       | 1 = The divider circuit is assigned to WDT post divider 0 = The divider circuit is assigned to Timer Oprescaler |         |                                                             | OPTION[3]              |            | RW-1        |              |             |
|           | WDTPost divider ratio                                                                                           |         | TIMER0Prescaler                                             |                        |            |             |              |             |
|           | 000                                                                                                             |         | 1                                                           |                        | 2          |             | 0x81         |             |
|           | 001                                                                                                             |         | 2                                                           | (PSA=0) 16<br>32<br>64 | 4          | OPTION[2:0] |              | RW-111      |
|           | 010                                                                                                             |         | 4                                                           |                        | 8          |             |              |             |
| P.S.      | 011                                                                                                             | (PSA=1) | 18                                                          |                        | 16         |             |              |             |
| r.3.      | 100                                                                                                             |         | 16                                                          |                        | 32         |             |              |             |
|           | 101                                                                                                             |         | 32<br>64                                                    |                        | 64         |             |              |             |
|           | 110                                                                                                             |         |                                                             |                        | 128        |             |              |             |
|           | 111                                                                                                             |         | <u>128</u>                                                  |                        | <u>256</u> |             |              |             |
|           | XXX                                                                                                             | (PSA=0) | 1                                                           | (PSA=1)                | 1          |             |              |             |
| TMR0[7:0] | Timer0count value                                                                                               |         |                                                             |                        | TMR0[7:0]  | 0x01        | RW-xxxx xxxx |             |

surface1-3 Timer0Related User Control Registers

| name |                       | register                   | address                   | reset value  |               |        |
|------|-----------------------|----------------------------|---------------------------|--------------|---------------|--------|
| GIE  | global interrupt      | 1 =Enable                  | (TOIEBe applicable)       | INTCON[7]    |               | RW-0   |
| GIL  | global interrupt      | 0 = <u>qlobal shutdown</u> | (wake up is not affected) | 1111 CO11[7] |               | 1744 0 |
| TOIE | Timer0overflow        | 1 =Enable                  |                           | INTCON[5]    | 0x0B          | RW-0   |
| TOIE | interrupt control bit | 0 = <u>closure</u>         | (no wakeup)               | INTCON[5]    | 0x8B<br>0x10B | KVV-U  |
| TOIF | Timer0overflow        | 1 =has overflowed          | (Latch)                   | INITCONICAL  | UXTUD         | DW 0   |
| 1016 | interrupt flag        | 0 = <u>not overflow</u>    |                           | INTCON[2]    |               | RW-0   |

surface1-4 Timer0Interrupt Enable and Status Bits

- 5 -



#### 1.1.2.existTimer0andWDTSwitch between divider circuits

Shared hardware divider circuitry can be assigned to Timer 0 or WDT use when in Timer 0 and WDT Switching between frequency divider circuits may cause false reset of the system.

Assign the divider circuit from the Timer 0 switch to WDT, the following command sequence must be followed:

BANKSEL TMRO ; Can skip if already in TMRO bank ;

CLRWDT Clear WDT

CLRR TMR0 ; Clear TMR0 and scaler

**BANKSEL OPTION** 

BSR OPTION, PSA ;Select WDT

LDWI b'11111000'; Mask scaler bits (PS2-0)

ANDWR OPTION, W

IORWI b'00000101'; Set WDT scaler bits to 32 (or any value desired)

STR OPTION

Assign the divider circuit from the WDTs witch to Timer 0, the following command sequence must be followed:

CLRWDT ; Clear WDT and scaler

**BANKSEL OPTION** 

LDWI b'11110000'; Mask TMR0 select and scaler bits (PSA, PS2-0)

ANDWR OPTION, W

IORWI b'00000011'; Set Timer0 scale to 16 (or any value desired)

STR OPTION

- 6 -



#### 2.Application example

```
//**************
******* /*file name:TEST_61F02x_Timer0.c
* Features:
         FT61F02x-Timer0Demo
*IC:
         FT61F023 SOP16
* Crystal:
         16M/2T
* illustrate:
         Demo Port Outoutput60Hzduty cycle50%The waveform of -Timer0accomplish
            FT61F023 SOP16
             -----
* VDD------GND (VSS)16|-----GND
* NC----- | 2(PA7)
                  (PA0)15|----NC
* NC-----|3(PA6)
                    (PA1)14|----NC
* NC-----|4(PA5) (PA2)13|-----NC
* NC-----|5(PC3)
                   (PA3)12|--DemoPortOut
* NC------ | 6(PC2)
                     (PC0)11 | -----NC
* NC-----|7(PA4)
                    (PC1)10|----NC
* NC------18(PC5)
                    (PC4)09 | - ----NC
*/
# include "SYSCFG.h"
# define DemoPortOut PA3 /
*_____
  Function name:interrupt ISR
  Features: timer0interrupt handling
  enter:
         none
  output: none
----* / void interrupt ISR(void)
{
                                //8.16msFlip once ≈60Hz
   if(TOIE && TOIF)
   {
       TOIF = 0:
       DemoPortOut = ~DemoPortOut; //flip level
   }
}
  Function name:POWER_INITIAL
   Features: Power-on system initialization
   enter: none
   output: none
```

- 7 - 2021-11-02



```
void POWER_INITIAL (void) {
     OSCCON = 0B01110001;
                                              //IRCF=111=16MHz/2T=8MHz,0.125µs//Temporarily
    INTCON = 0;
                                              disable all interrupts
     PORTA = 0B00000000;
    TRISA = 0B00000000;
                                              //PAinput Output0-output1-enter //
                                              PA3->output
    PORTC = 0B00000000;
    TRISC = 0B00000000:
                                              //PCinput Output0-output1-enter //PAPort pull-
    WPUA = 0B00000000;
                                              up control1-pull up0-close pull //PCPort pull-up
     WPUC = 0B0000000;
                                              control1-pull up0-close pull
     OPTION = 0B00001000;
                                             //Bit3=1, WDT MODE, PS=000=WDT RATE 1:1
     MSCKCON = 0B00000000;
    //Bit6->0,prohibitPA4,PC5Regulated output
    //Bit5->0,TIMER2the clock isFosc //Bit4->0,
     prohibitLVR
     CMCON0 = 0B00000111;
                                           //turn off the comparator,Cxfor numbersIOmouth
}
    Function name:TIMER0_INITIAL
     Function: Initialize and set the timer0
     set upTMR0Timing duration =(1/System clock frequency)*instruction cycle*prescaler value*255
                             =(1/16000000)*2*256*255=8.16ms
----* / void TIMERO_INITIAL (void)
{
     OPTION = 0B00000111;
    //Bit5:
               TOCS TimerOClock Source Selection
    //
               1-External pin level changeT0CKI 0-internal clock (FOSC/2)
    //Bit4:
               TOCKIpin trigger mode1-falling edge PSAPnessgalegeAllocation
                                                     1-WDT
    //Bit3:
               Bits0-Timer0
    //Bit[2:0]: PS 8prescaler111-1:256
    TOIF = 0;
                                              //emptyT0software interrupt
}
    Function name:main
    Features: main function
    enter:
               none
    output: none
*/ void main()
```

2021-11-02

- 8 -



2021-11-02

- 9 -



Contact information

#### **Fremont Micro Devices Corporation**

# 5–8, 10/F, Changhong Building Ke-Ji Nan 12 Road, Nanshan District, Shenzhen, Guangdong, PRC 518057

Tel: (+86 755) 8611 7811 Fax: (+86 755) 8611 7810

#### Fremont Micro Devices (HK) Limited

# 16, 16/F, Block B, Veristong Industrial Centre, 34–36 Au Pui Wan Street, Fotan, Shatin, Hong Kong SAR

Tel: (+852) 2781 1186 Fax: (+852) 2781 1144

http://www.fremontmicro.com

- 10 -

2021-11-02

<sup>\*</sup> Information furnished is believed to be accurate and reliable. However, Fremont Micro Devices Corporation assumes no responsibility for the consequences of use of such information or for any infringement of patents of other rights of third parties, which may result from its use. No license is granted by implication or otherwise under any patent rights of Fremont Micro Devices Corporation. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. components in life support devices or systems without express written approval of Fremont Micro Devices Corporation. The FMD logo is a registered trademark of Fremont Micro Devices Corporation. All other names are the property of their respective owners.