# M16C/62P Group

# Operation of Timer B (pulse width measurement mode)

## 1. Abstract

In pulse period/pulse width measurement mode, choose functions from those listed in Table 1. Operations of the circled items are described below. Figure 1 shows the operation timing, and Figure 2 shows the set-up procedure. A reference program is an example when using the Timer B0 interrupt based on the setting procedure of Figure 2.

#### 2. Introduction

This application note is applied to the M16C/62P group Microcomputers.

This program can be operated under the condition of M16C family products with the same SFR(Special Function Register) as M16C/62P Group products. Because some functions may be modified of the M16C family products, see the user's manual. When using the functions shown in this application note, evaluate them carefully for an operation



# 3. Choosed functions

#### Table 1. Choosed functions

| Item                                                                                                                                                                        |   | Set-up                                                                                                                               |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Count source                                                                                                                                                                | 0 | Internal count source (f1 / f8 / f32 / fc32)                                                                                         |  |  |
| Measurement<br>mode         Pulse period measurement (interval between measurement pulse falli           Pulse period measurement (interval between measurement pulse risin |   | Pulse period measurement (interval between measurement pulse falling edge to falling edge)                                           |  |  |
|                                                                                                                                                                             |   | Pulse period measurement (interval between measurement pulse rising edge to rising edge)                                             |  |  |
|                                                                                                                                                                             | 0 | Pulse width measurement (interval between measurement pulse falling edge to rising edge,<br>and between rising edge to falling edge) |  |  |

#### 4. Operation

- (1) Setting the count start flag to "1" causes the counter to start counting the count source.
- (2) If an effective edge of a pulse to be measured is input, the value of the counter goes to "000016", and measurement is started. In this instance, an indeterminate value is transferred to the reload register. The timer Bi interrupt request does not generate.
- (3) If an effective edge of a pulse to be measured is input again, the value of the counter is transferred to the reload register, and the timer Bi interrupt request bit goes to "1". Then the value of the counter becomes "000016", and measurement is started again.

#### Note

- The timer Bi interrupt request bit goes to "1" when an effective edge of a pulse to be measured is input or timer Bi is overflows. The factor of interrupt request can be determined by use of the timer Bi overflow flag within the interrupt routine.
- The value of the counter at the beginning of a count is indeterminate. Therefore, the timer Bi overflow flag may go to "1" and timer Bi interrupt request may be generated during the interval between a count start and an effective edge input.
- The timer Bi overflow flag is indeterminate after reset. The timer Bi overflow flag goes to "0" if timer Bi mode register is written to when the count start flag is "1". This flag cannot be set to "1" by software.



Figure 1. Operation timing of pulse width measurement mode





Figure 2. Set-up procedure of pulse width measurement mode



| . The example                              | e of referenc   | e program       |                                                    |  |
|--------------------------------------------|-----------------|-----------------|----------------------------------------------------|--|
| .*************************************     | ******          | *******         | *************************                          |  |
| ; M16C/62P Pro                             | ogram Collectic | on              |                                                    |  |
| ;<br>;                                     | rjj05b0705_src  | .a30            |                                                    |  |
| CPU : M16C/62P Group                       |                 |                 |                                                    |  |
| ; FUNCTION :                               | Operation of Ti | mer B (pulse w  | idth measurement)                                  |  |
| ; HISTORY : 2004.12.24 Ver 1.00            |                 |                 |                                                    |  |
| · ·                                        | 2000.1.25 Ve    | 11.10           |                                                    |  |
| ,<br>; Copyright(C)2                       | 006, Renesas    | Technology Cor  | ۳۵.                                                |  |
| ; Copyright(C)2                            | 006, Renesas    | Solutions Corp. |                                                    |  |
| ; All rights reser                         | ved.            |                 |                                                    |  |
| ,<br>.**********************************   | *****           | *****           | *****                                              |  |
| ************************************       | *****           | ******          | ******                                             |  |
| ; Include                                  |                 |                 |                                                    |  |
| . * * * * * * * * * * * * * * * * * * *    | *****           | *****           | *********************                              |  |
| ,<br>.LIST                                 | off             | ;               | Stops outputting lines to the assembler list file  |  |
| .INCLUD                                    | E sfr62p.inc    | -               | Reads the file that defined SFR                    |  |
| .LIST                                      | on              | ;               | Starts outputting lines to the assembler list file |  |
| •                                          |                 |                 |                                                    |  |
| ;<br>Symbol d                              | ofinition       | *****           | **********************                             |  |
| , Oymbol a                                 | ******          | *****           | *****                                              |  |
| •                                          |                 |                 |                                                    |  |
| RAM_TOP                                    | .equ            | 00400h          | ;Start address of RAM                              |  |
| RAM_END                                    | .equ            | 013ffh          | ;End address of RAM                                |  |
| ROM_TOP                                    | .equ            | 0f4000h         | ;Start address of ROM                              |  |
| VECT_TOP                                   | .equ            | 0ffe00h         | ;Start address of vect_top                         |  |
| FIXED_VECT_TC                              | P .equ          | Offfdch         | ;Start address of fixed_vect_top                   |  |
| SB_BASE                                    | .equ            | 00380h          | ;Base address of sb                                |  |
| '<br>•************************************ | *****           | *****           | *****                                              |  |
| ; Program                                  | area            |                 |                                                    |  |
| •*************************************     | *****           | **************  | ******                                             |  |
| ;=====================================     |                 |                 |                                                    |  |
| ;=================                         | =============   |                 |                                                    |  |
| •                                          |                 |                 | Declares so the new solution to                    |  |
| .5                                         | section progra  | m,code          | ;Declares section name and section type            |  |
| .0                                         | org             | ROM_TOP         | ;Declares start address                            |  |
| .9                                         | sb              | SB_BASE         | •                                                  |  |

;



| Idc#RAM_END+1,isp ;Sets interrupt stack pointerIdc#SB_BASE,sb;Sets sb register;mov.b#03h,prcr;Removes protect<br>;Set processor mode registers 0 and 1mov.w#0800h,pm0;Single-chip mode<br>;No expansion, No waitmov.w#2008h,cm0;Xcin-Xcout High | START:            |                                        |                 |                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------|-----------------|-------------------------------------------------------------|
| <pre>idc #SB_BASE,sb ;Sets sb register ; mov.b #03h,prcr ;Removes protect ;Set processor mode registers 0 and 1 mov.w #0800h,pm0 ;Single-chip mode ;No expansion, No wait mov.w #2008h,cm0 ;Xcin-Xcout High</pre>                               |                   | ldc                                    | #RAM_END+1,is   | sp ;Sets interrupt stack pointer                            |
| ;<br>mov.b #03h,prcr ;Removes protect<br>;Set processor mode registers 0 and 1<br>mov.w #0800h,pm0 ;Single-chip mode<br>;No expansion, No wait<br>mov.w #2008h,cm0 ;Xcin-Xcout High                                                             |                   | ldc                                    | #SB_BASE,sb     | ;Sets sb register                                           |
| mov.b#03h,prcr;Removes protect<br>;Set processor mode registers 0 and 1mov.w#0800h,pm0;Single-chip mode<br>;No expansion, No waitmov.w#2008h,cm0;Xcin-Xcout High                                                                                | ;                 |                                        |                 |                                                             |
| ;Set processor mode registers 0 and 1<br>mov.w #0800h,pm0 ;Single-chip mode<br>;No expansion, No wait<br>mov.w #2008h,cm0 ;Xcin-Xcout High                                                                                                      |                   | mov.b                                  | #03h,prcr       | ;Removes protect                                            |
| mov.w #0800h,pm0 ;Single-chip mode<br>;No expansion, No wait<br>mov.w #2008h,cm0 ;Xcin-Xcout High                                                                                                                                               |                   |                                        | "               | ;Set processor mode registers 0 and 1                       |
| ;No expansion, No wait<br>mov.w #2008h,cm0 ;Xcin-Xcout High                                                                                                                                                                                     |                   | mov.w                                  | #0800h,pm0      | ;Single-chip mode                                           |
| mov.w #2008n,cm0 ;Xcin-Xcout High                                                                                                                                                                                                               |                   |                                        | #2000h am0      | No expansion, No wait                                       |
| Vin Yout High, Main clock is No divisor                                                                                                                                                                                                         |                   | mov.w                                  | #2008N,CM0      | Xin-Xout High<br>Xin Xout High, Main clock is No divison    |
| mov b #0 pror Protects all registers                                                                                                                                                                                                            |                   | movh                                   | #0 prcr         | Protects all registers                                      |
|                                                                                                                                                                                                                                                 | :                 | mov.b                                  | #0,pici         |                                                             |
| Idintb #VECT TOP ;Sets interrupt table register                                                                                                                                                                                                 | 3                 | ldintb                                 | #VECT TOP       | ;Sets interrupt table register                              |
|                                                                                                                                                                                                                                                 |                   |                                        | -               |                                                             |
| mov.w #0,r0 ;Clears WORKRAM area                                                                                                                                                                                                                |                   | mov.w                                  | #0,r0           | ;Clears WORKRAM area                                        |
| mov.w #((RAM_END+1)-RAM_TOP)/2,r3                                                                                                                                                                                                               |                   | mov.w                                  | #((RAM_END+1)   | )-RAM_TOP)/2,r3                                             |
| mov.w #RAM_TOP,a1                                                                                                                                                                                                                               |                   | mov.w                                  | #RAM_TOP,a1     |                                                             |
| sstr.w                                                                                                                                                                                                                                          |                   | sstr.w                                 |                 |                                                             |
| ;<br>;                                                                                                                                                                                                                                          |                   |                                        |                 |                                                             |
| ;=====================================                                                                                                                                                                                                          | ;=======<br>; Mai | ====================================== |                 |                                                             |
| ;======================================                                                                                                                                                                                                         | ;========         | =============                          |                 |                                                             |
| mov.b #01001010b,tb0mr ;Timer B0 mode register                                                                                                                                                                                                  |                   | mov.b                                  | #01001010b,tb0n | nr ;Timer B0 mode register                                  |
| ;                                                                                                                                                                                                                                               | ;                 |                                        | ++              | ;Pulse period/pulsewidgh measurement mode                   |
| ;     ++;Pulse width measurement(measurement between                                                                                                                                                                                            | •                 |                                        | ++              | ;Pulse width measurement(measurement between                |
| ; [11]; ;a falling edge and the next rising edge of measured                                                                                                                                                                                    | ;                 |                                        |                 | ;a falling edge and the next rising edge of measured        |
| ;      ;pulse and between a rising edge and the next                                                                                                                                                                                            | ,                 |                                        |                 | ;pulse and between a rising edge and the next               |
| ;      ;talling edge)                                                                                                                                                                                                                           | •                 |                                        |                 | ;talling edge)                                              |
| ;    +;Set to 0 in pulse period and pulse widge                                                                                                                                                                                                 | ;                 |                                        | +               | ;Set to "0" in pulse period and pulse widge                 |
| ; []] ,Theasurement mode                                                                                                                                                                                                                        | ,                 |                                        |                 | Timer has not everflowed                                    |
| ,   +, finder has not overhowed                                                                                                                                                                                                                 | ,                 |                                        | ++              |                                                             |
| mov b #00000011b tb0ic :Interrupt control register                                                                                                                                                                                              | 3                 | moy b                                  | #00000011b tb0i | c :Interrupt control register                               |
| : I+++:Interrupt priority level select bit                                                                                                                                                                                                      | :                 | mov.b                                  | +++             | :Interrupt priority level select bit                        |
| : (011:Level 3. interrupt disabled)                                                                                                                                                                                                             | ;                 |                                        |                 | :(011:Level 3. interrupt disabled)                          |
| ; +;Interrupt request bit (0:interrupt not requested)                                                                                                                                                                                           | -                 |                                        | +               | ;Interrupt request bit (0:interrupt not requested)          |
| mov.b #0010000b,tabsr ;Count start flag                                                                                                                                                                                                         |                   | mov.b                                  | #00100000b,tabs | sr ;Count start flag                                        |
| ; +;Starts counting                                                                                                                                                                                                                             | •<br>?            |                                        | +               | ;Starts counting                                            |
| nop ;To set the MR3 bit to "0" (no overflow), set TBiMR                                                                                                                                                                                         |                   | nop                                    |                 | ;To set the MR3 bit to "0" (no overflow), set TBiMR         |
| nop ;register with setting the TBiS bit to "1" and counting the                                                                                                                                                                                 |                   | nop                                    |                 | register with setting the TBiS bit to "1" and counting the; |
| nop ;next count source after setting the MR3 bit to "1"                                                                                                                                                                                         |                   | nop                                    |                 | ;next count source after setting the MR3 bit to "1"         |
| nop ;(overflow). Newly added in the Ver 1.10                                                                                                                                                                                                    |                   | nop                                    |                 | ;(overflow). Newly added in the Ver 1.10                    |
| nop ;                                                                                                                                                                                                                                           |                   | nop                                    |                 | ;                                                           |
| nop                                                                                                                                                                                                                                             |                   | nop                                    |                 | ;                                                           |
| nop                                                                                                                                                                                                                                             |                   | nop                                    |                 |                                                             |



|                                | nop                                    |                                        | ;                                               |
|--------------------------------|----------------------------------------|----------------------------------------|-------------------------------------------------|
|                                | fset                                   | i                                      | ;Set interrupt enable flag                      |
|                                | mov.b                                  | #01001010b,t                           | b0mr ;Timer B0 mode register                    |
| ;                              |                                        | +                                      | ;Timer did not overflowed                       |
| MAIN:                          |                                        |                                        |                                                 |
|                                |                                        |                                        |                                                 |
|                                | jmp                                    | MAIN                                   |                                                 |
| ; <b>=====</b> ;               | Interrupt program                      |                                        |                                                 |
| ;======<br>TR0 IN <sup>-</sup> | ·===================================== | ==============                         |                                                 |
| :                              |                                        |                                        |                                                 |
| •                              | ;/ TB0 interru                         | pt routine /                           |                                                 |
| •                              |                                        |                                        |                                                 |
|                                | reit                                   |                                        |                                                 |
| ;======<br>;                   | Dummy interrupt proc                   | ====================================== |                                                 |
| ;=====                         |                                        | ==============                         |                                                 |
| DUMMY                          | ·                                      |                                        |                                                 |
| ***                            | reit                                   | ****                                   |                                                 |
| ,                              | Sotting of variable vo                 | ctor tabla                             |                                                 |
| ,<br>.*******                  |                                        | CIOI IADIE                             | *****                                           |
| ,                              |                                        |                                        |                                                 |
| ,                              | section vec                            | t romdata                              |                                                 |
|                                | .org                                   | VECT TOP +                             | (4 * 4)                                         |
| ;                              |                                        | _                                      |                                                 |
|                                | .lword                                 | DUMMY                                  | ;INT3 interrupt vector                          |
|                                | .lword                                 | DUMMY                                  | ;TB5 interrupt vector                           |
|                                | .lword                                 | DUMMY                                  | ;TB4 interrupt vector                           |
|                                |                                        |                                        | ;UART1 bus collision detection interrupt vector |
|                                | .lword                                 | DUMMY                                  | ;TB3 interrupt vector                           |
|                                |                                        |                                        | ;UART0 bus collision detection interrupt vector |
|                                | .lword                                 | DUMMY                                  | ;SI/04/INT5 interrupt vector                    |
|                                | .lword                                 | DUMMY                                  | ;SI/03/INT4 interrupt vector                    |
|                                | .lword                                 | DUMMY                                  | ;UART2 bus collision detection interrupt vector |
|                                | .lword                                 | DUMMY                                  | ;DMA0 interrupt vector                          |
|                                | .lword                                 | DUMMY                                  | ;DMA1 interrupt vector                          |
|                                | .lword                                 | DUMMY                                  | ;KEY interrupt vector                           |
|                                | .lword                                 | DUMMY                                  | ;A-D interrupt vector                           |
|                                | .lword                                 | DUMMY                                  | ;UAR12 transmit/NACK interrupt vector           |
|                                | .lword                                 | DUMMY                                  | ;UAR12 receive/ACK interrupt vector             |
|                                | .Iword                                 |                                        | UAR I U transmit/NACK Interrupt vector          |
|                                | .lword                                 | DUMMY                                  |                                                 |
|                                | .lword                                 | DUMMY                                  | ;UAR I 1 transmit/NACK interrupt vector         |
|                                | .lword                                 | DUMMY                                  | ;UARI 1 receive/ACK interrupt vector            |
|                                | .Iword                                 | DUMMY                                  | ; I AU Interrupt vector                         |



|               | .lword                 | DUMMY                                   | ;TA1 interrupt vector                                    |
|---------------|------------------------|-----------------------------------------|----------------------------------------------------------|
|               | .lword                 | DUMMY                                   | ;TA2 interrupt vector                                    |
|               | .lword                 | DUMMY                                   | ;TA3 interrupt vector                                    |
|               | .lword                 | DUMMY                                   | ;TA4 interrupt vector                                    |
|               | .lword                 | TB0_INT                                 | ;TB0 interrupt vector                                    |
|               | .lword                 | DUMMY                                   | ;TB1 interrupt vector                                    |
|               | .lword                 | DUMMY                                   | ;TB2 interrupt vector                                    |
|               | .lword                 | DUMMY                                   | ;INT0 interrupt vector                                   |
|               | .lword                 | DUMMY                                   | ;INT1 interrupt vector                                   |
|               | .lword                 | DUMMY                                   | ;INT2 interrupt vector                                   |
| ;             |                        |                                         |                                                          |
| ·********     | Sotting of fixed vocto | *************************************** | *********************                                    |
| ,<br>.******* | *****                  | //<br>****************************      | ******                                                   |
| ,             |                        |                                         |                                                          |
| ,             | .section f v           | ect.romdata                             |                                                          |
|               | .org                   | FIXED_VECT                              | _TOP                                                     |
| ;             |                        |                                         |                                                          |
|               | .lword                 | DUMMY                                   | ;Undefined instruction interrupt vector                  |
|               | .lword                 | DUMMY                                   | ;Overflow (INTO instruction) interrupt vector            |
|               | .lword                 | DUMMY                                   | ;BRK instruction interrupt vector                        |
|               | .lword                 | DUMMY                                   | ;Address match interrupt vector                          |
|               | .lword                 | DUMMY                                   | ;Single-step interrupt vector                            |
|               | .lword                 | DUMMY                                   | ;Watchdog timer interrupt vector                         |
|               |                        |                                         | ;Oscillation stop and Re-oscillation detection interrupt |
|               |                        |                                         | ;vector                                                  |
|               |                        |                                         | ;Voltage down detection interrupt vector                 |
|               | .lword                 | DUMMY                                   | ;DBC interrupt vector                                    |
|               | .lword                 | DUMMY                                   | ;NMI interrupt vector                                    |
|               | .lword                 | START                                   | ;Sets start vector                                       |
| ;             |                        |                                         |                                                          |
|               | .end                   |                                         |                                                          |



### 6. Referense

Hardware manual M16C/62P Group Hardware Manual (Use the most recent version of the document on the Renesas Technology Web site.)

Technical news/Technical update

(Use the most recent version of the document on the Renesas Technology Web site.)



# Web-site and contact for support

Renesas Technology Web site http://www.renesas.com/en/m16c

Inquiries http://www.renesas.com/inquiry csc@renesas.com

#### Revision

| Rev. | Issue data | Revised |                              |  |  |
|------|------------|---------|------------------------------|--|--|
|      |            | Page    | Point                        |  |  |
| 1.00 | 2004.12    | -       | First edition issued         |  |  |
| 1.10 | 2006.01    | 5       | 5 Reference program modified |  |  |



Keep safety first in your circuit designs!

 Renesas Technology Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of nonflammable material or (iii) prevention against any malfunction or mishap.

Notes regarding these materials

- 1. These materials are intended as a reference to assist our customers in the selection of the Renesas Technology Corporation product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Renesas Technology Corporation or a third party.
- 2. Renesas Technology Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.

3. All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Renesas Technology Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corporation product distributor for the latest product information before purchasing a product listed herein.

The information described here may contain technical inaccuracies or typographical errors. Renesas Technology Corporation assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors.

Please also pay attention to information published by Renesas Technology Corporation by various means, including the Renesas Technology Corporation Semiconductor home page (http://www.renesas.com).

- 4. When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Renesas Technology Corporation assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- 5. Renesas Technology Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Renesas Technology Corporation or an authorized Renesas Technology Corporation product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- 6. The prior written approval of Renesas Technology Corporation is necessary to reprint or reproduce in whole or in part these materials.
- 7. If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination. Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the
- Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.
- 8. Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.

**(ENESAS**