# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

Renesas Electronics website: <a href="http://www.renesas.com">http://www.renesas.com</a>

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (<a href="http://www.renesas.com">http://www.renesas.com</a>)

Send any inquiries to http://www.renesas.com/inquiry.



#### Notice

- 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights
  of third parties by or arising from the use of Renesas Electronics products or technical information described in this document.
  No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights
  of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application for which it is not intended without the prior written consent of Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

# Regarding the change of names mentioned in the document, such as Hitachi Electric and Hitachi XX, to Renesas Technology Corp.

The semiconductor operations of Mitsubishi Electric and Hitachi were transferred to Renesas Technology Corporation on April 1st 2003. These operations include microcomputer, logic, analog and discrete devices, and memory chips other than DRAMs (flash memory, SRAMs etc.) Accordingly, although Hitachi, Hitachi, Ltd., Hitachi Semiconductors, and other Hitachi brand names are mentioned in the document, these names have in fact all been changed to Renesas Technology Corp. Thank you for your understanding. Except for our corporate trademark, logo and corporate statement, no changes whatsoever have been made to the contents of the document, and these changes do not constitute any alteration to the contents of the document itself.

Renesas Technology Home Page: http://www.renesas.com

Renesas Technology Corp. Customer Support Dept. April 1, 2003



#### **Cautions**

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 or an authorized 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 country of destination is prohibited.
- 8. Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.

# **APPLICATION NOTE**

# **Pulse Frequency Measurements Using Event Counter Function**

## Introduction

Measurement of the frequency of the applied pulse stream input from Timer B1 event input pin (TMIB) using the 8-bit event counter function of Timer B1.

# **Target Device**

H8/300H Tiny Series H8/3687

# **Contents**

| 1.  | Specification                                | .3 |
|-----|----------------------------------------------|----|
| 2.  | Description of Functions Used                | .3 |
| 3.  | Operational Description                      | .5 |
|     | Software Description                         |    |
| 4.1 | Module Description                           | .6 |
| 4.2 | Argument Description                         | .6 |
| 4.3 | Description of Applicable Internal Registers | .6 |
| 4.4 | Description of RAM Used                      | .7 |
| 5.  | Flowcharts                                   | .8 |
| 6   | Program Listing                              | 11 |

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

#### **Cautions**

Feb. 2003

1. Hitachi neither warrants nor grants licenses of any rights of Hitachi's or any third party's patent, copyright, trademark, or other intellectual property rights for information contained in this document. Hitachi bears no responsibility for problems that may arise with third party's rights, including intellectual property rights, in connection with use of the information contained in this document.

- 2. Products and product specifications may be subject to change without notice. Confirm that you have received the latest product standards or specifications before final design, purchase or use.
- 3. Hitachi makes every attempt to ensure that its products are of high quality and reliability. However, contact Hitachi's sales office before using the product in an application that demands especially high quality and reliability or where its failure or malfunction may directly threaten human life or cause risk of bodily injury, such as aerospace, aeronautics, nuclear power, combustion control, transportation, traffic, safety equipment or medical equipment for life support.
- 4. Design your application so that the product is used within the ranges guaranteed by Hitachi particularly for maximum rating, operating supply voltage range, heat radiation characteristics, installation conditions and other characteristics. Hitachi bears no responsibility for failure or damage when used beyond the guaranteed ranges. Even within the guaranteed ranges, consider normally foreseeable failure rates or failure modes in semiconductor devices and employ systemic measures such as fail-safes, so that the equipment incorporating Hitachi product does not cause bodily injury, fire or other consequential damage due to operation of the Hitachi product.
- 5. This product is not designed to be radiation resistant.
- 6. No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without written approval from Hitachi.
- 7. Contact Hitachi's sales office for any questions regarding this document or Hitachi semiconductor products.

Copyright © Hitachi, Ltd., 2003. All rights reserved.

ADE-502-134 16-bit / H8/300H Tiny

## 1. Specification

1. Measurement of the frequency of the applied pulse stream input from Timer B1 event input pin (TMIB) using the 8-bit event counter function of Timer B1.

- 2. The number of rising-edge events of the pulse stream applied from the TMIB input pin is counted during one-second, and the event count for the one-second time-interval is stored in RAM.
- 3. Measurement of the one-second time-interval is performed using the timebase function of Timer A time clock.

## 2. Description of Functions Used

- 1. In this task example, the frequency of the pulse stream input at the TMIB input pin is measured using the Timer B1 event counter function.
  - A. Figure 2.1 shows the block diagram of the Timer B1 event counter function which is described as follows:
    - Timer Mode Register B1 (TMB1) is an 8-bit read/write register used to select the interval function and select the input clock.
    - Timer Counter B1 (TCB1) is an 8-bit readable up counter that is incremented by means of the applied internal clock and/or external events. The applied input clock can be selected from a total of eight clocks, seven of which are derived from the system clock divided by 8192, 2048, 512, 256, 64, 16 and 4, and one external clock. In this task example, the edge detection of the TMIB input pin is selected as the TCB1 input clock.
    - Timer B1 Interrupt Request Flag (IRRTB1) is set to 1 by a TCB1 overflow event. If, on the provision that IRRTB1 has been set to 1, Timer B1 Interrupt Enable (IENTB1) of the Interrupt Enable Register (IENR1) is set to 1, and the I bit of the Condition Code register (CCR) is cleared to 0, the Timer B1 interrupt sequence will start on reception of the Timer B1 interrupt.
    - Timer B1 Event Input pin (TMIB) functions as the input pin for the pulse stream that will be subject to the frequency measurements. In this task example, a Timer B1 interrupt will be generated every 160 μs using the Timer B1 auto reload function.



Figure 2.1 Timer B1 Event Counter Function Block Diagram

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 3 of 16 http://www.renesas.com/

- B. The following is brief description of the method of frequency measurement.
  - When 256 rising-edge input pulse events have been applied to the TMIB input pin, TCB1 overflows and a Timer B1 interrupt is generated.
  - The 8-bit counter set by cnt 1 is incremented during the Timer B1 interrupt sequence,
  - The count value in TCB1 is read out and stored in cnt\_2 after an interval of one second has elapsed, at which point the TCB1 increment sequence by the signal applied from the TMIB input pin is stopped.
  - The frequency of the pulse stream applied to the TMIB input pin can be found using the following expression:

```
Input Pulse Frequency (Hz) = (Timer B1 Interrupt Event Count) x 256 + (Count Value in TCB1 after a one-second time lapse)
= (Value in cnt) x 256 + (Value in cnt_1)
```

- Since counter (cnt), used to count the Timer B1 interrupt events, is an 8-bit counter, the maximum frequency of the input pulse stream that can be measured is 65.535 kHz.
- When the 8-bit counter (cnt) that counts the number of Timer B1 interrupt events overflows, frequency measurements are stopped at that instant and the sequence finishes by writing H'00 to cnt and the register (cnt\_1) that stores the TCB1 count value after the 1 sec time lapse.
- 2. Table 2.1 lists the function assignments applicable to this task example. The functions are assigned as indicated in table 1. Frequency measurement is performed by timer B1 event counter function.

**Table 2.1 Function Assignment** 

| Function                                                                                                                        | Function Assignment                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| TCB1 This is an 8-bit counter to which edge detection for the TMIB input pin is input                                           |                                                                                                                 |
| TMB1                                                                                                                            | This register sets the interval function and sets the TCB1 input clock to edge detection for the TMIB input pin |
| IRRTB1                                                                                                                          | This reflects the presence/absence of a Timer B1 interrupt request                                              |
| TMIB This is the input pin of the pulse stream subject to frequency measurements                                                |                                                                                                                 |
| IEG1 This sets the input sense of the TMIB pin for rising edge detection                                                        |                                                                                                                 |
| TCNTV This is an 8-bit counter to which an input clock, derived by dividing the 16 MHz internative frequency by 128, is applied |                                                                                                                 |
| TCRV0 This sets selection of TCNTV input clock, and clears the counter by Compare Match A                                       |                                                                                                                 |
| TCSRV This selects PSW and sets the TCA overflow period                                                                         |                                                                                                                 |
| TCORA This sets the compare match value for TCNTV                                                                               |                                                                                                                 |
| TCRV1                                                                                                                           | This selects the TGRV input edge, starts the TCNV input count up, and selects the TCNTV input clock             |

Feb. 2003 ADE-502-134 16-bit / H8/300H Tiny

Page 4 of 16 http://www.renesas.com/

# 3. Operational Description

1. Figure 3.1 illustrates the principle of operation described by way of waveform diagrams. As shown in figure 3.1, pulse stream frequency measurements by means of the Timer B1 event counter function are facilitated by both hardware and software operations.



Figure 3.1 Operating Principle of Frequency Measurement by Timer B1 Event Counter Function

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 5 of 16 <a href="http://www.renesas.com/">http://www.renesas.com/</a>

# 4. Software Description

## **4.1 Module Description**

The modules applicable to this task example are listed in table 4.1.

Table 4.1 Module Description

| Module Name      | Label Name | Function                                                                                                                                                                                                             |
|------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Main Routine     | main       | The main routine initializes the stack pointer, sets the event counter function, sets the timebase function, sets the 8-bit counter, enables the interrupts, and initializes Timer B1 on completion of measurements. |
|                  |            | In the Timer B1 interrupt sequence, increments the 8-bit counter and performs the process operations when cnt overflows.                                                                                             |
| 1 Sec Time Lapse | TVCMA      | In the Timer A interrupt sequence, disables the interrupts by a time lapse of 1 sec and stores the TCB1 count value in cnt_1                                                                                         |

## **4.2 Argument Description**

Table 4.2 lists the arguments applicable to this task example.

**Table 4.2** Argument Description

| Argument Name    | Function                                                              | Used in          | Data Size | I/O    |
|------------------|-----------------------------------------------------------------------|------------------|-----------|--------|
| cnt              | Stores the 8-bit counter count value after 1-sec time lapse           | 8-bit counter    | 1 byte    | Output |
| 8-bit counter    | Stores TCB1 counter value after 1-sec time lapse                      | 1-sec time lapse | 1 byte    | Output |
| 1 sec time lapse | Stores counter value that discriminates whether one second has lapsed | 1-sec time lapse | 2 bytes   | Output |

## 4.3 Description of Applicable Internal Registers

Table 4.3 lists the internal registers used in this task example.

**Table 4.3** Description of Applicable Internal Registers

| Register Name                                                                                                                                                                             |        | Functional Description                                                                                                                                                                          | Address | Setting |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|
| IRR2                                                                                                                                                                                      | IRRTB1 | Interrupt Request Register 1 (Timer B1 Interrupt Request Flag) H'Fl<br>: When IRRTB1 is 0, a Timer B1 interrupt is not requested Bit 5<br>: When IRRTB1 is 1, a Timer B1 interrupt is requested |         | 0       |
| IENR2 IENTB1 Interrupt Enable Register 1 (Timer B1 Interrupt Enable) : When IENTB1 is 0, Timer B1 interrupt request is disabled : When IENTB1 is 1, Timer B1 interrupt request is enabled |        | H'FFF5<br>Bit 5                                                                                                                                                                                 | 1       |         |

Feb. 2003 ADE-502-134 16-bit / H8/300H Tiny

Page 6 of 16 http://www.renesas.com /

Table 4.3 Description of Applicable Internal Registers (cont)

| Register Name                                                                                                                                                                                       |                                                                                                                                                                                   | Functional Description                                                                                                                                                                           | Address                          | Setting |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|---------|--|
| IEGR2                                                                                                                                                                                               | EGR2 IEG1 Interrupt Enable Edge Select Register 2 (INT1 Edge Select) : When IEG1 is 1, TMIB input pin edge detection is set for rising-edge detection                             |                                                                                                                                                                                                  | H'FFF2<br>Bit 1                  | 1       |  |
| TCRV0                                                                                                                                                                                               | TCRV0 CMIEA Timer Control Register V0 (Timer V Interrupt Enable) : When CMIEA is 0, Timer V interrupt request is disabled : When CMIEA is 1, Timer V interrupt request is enabled |                                                                                                                                                                                                  | H'FFA0<br>Bit 6                  | 1       |  |
| TCRV0 CKS0 to Timer Control Register V0 (Clock Select) TCRV1 CKS2 Timer Control Register V1 (clock Select) ICSK1 : Sets the clock to 1/128 of the internal clock and counts up on the falling edge. |                                                                                                                                                                                   | H'FFA0<br>H'FFA5                                                                                                                                                                                 | CKS0 to CKS2 = 1, 1, 0 ICSK1 = 1 |         |  |
| TCSRV                                                                                                                                                                                               | CMFA                                                                                                                                                                              | Timer Control Status Register V (Timer V Interrupt Request Flag) : When CMFA = 0, Timer V compare match interrupt is not requested : When CMFA = 1, Timer V compare match interrupt is requested | H'FFA1<br>Bit 6                  | 1       |  |
| TMB1                                                                                                                                                                                                |                                                                                                                                                                                   | Timer Mode Register B1 : When TMB1 is H'7F, the Timer B1 function is set as the interval function and the TCB1 input clock is set for edge detection of TMIB input clock                         | H'F760                           | H'7F    |  |
| TCB1                                                                                                                                                                                                |                                                                                                                                                                                   | Timer Counter B1 : This is an 8-bit up counter to which the input edge detection for the TMIB1 pin is applied                                                                                    | H'F761                           | H'00    |  |
| TCNTV                                                                                                                                                                                               |                                                                                                                                                                                   | Timer Counter V : This is an 8-bit up counter to which the input clock, derived by dividing the 16 MHz clock by 128, is applied                                                                  | H'FFA4                           | H'00    |  |
| TC0RA                                                                                                                                                                                               |                                                                                                                                                                                   | Time Constant Register A : When the setting value of TCORA and the count value in TCNTV match, a compare match V is generated                                                                    | H'FFA2                           | H'20    |  |

# 4.4 Description of RAM Used

Table 4.4 lists and describes the RAM used in this task example.

**Table 4.4 Description of Applicable RAM** 

| Label Name |      | Function                                                                              | Address         | Used in                                           |
|------------|------|---------------------------------------------------------------------------------------|-----------------|---------------------------------------------------|
| USRF       | ENDF | Flag that determines whether or not the input pulse frequency measurements have ended | H'FB80<br>Bit 0 | Main routine<br>8-bit counter<br>1-sec time lapse |

Feb. 2003 ADE-502-134 16-bit / H8/300H Tiny

Page 7 of 16 http://www.renesas.com/

## 5. Flowcharts



Figure 5.1 Main Routine

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 8 of 16 http://www.renesas.com/



Figure 5.2 Timer B1 Interrupt Service Routine

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 9 of 16 http://www.renesas.com/



Figure 5.3 Timer V Interrupt Service Routine

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 10 of 16 http://www.renesas.com/

# 6. Program Listing

INIT.SRC (Program List)

#include

Feb. 2003

```
.EXPORT _INIT
.IMPORT _main
;
.SECTION P,CODE
_INIT:

MOV.W #H'FF80,R7

LDC.B #B'10000000,CCR

JMP @_main
;
.END
```

<C:\ch38\include\machine.h>

ADE-502-134 16-bit / H8/300H Tiny

Page 11 of 16 http://www.renesas.com/

```
Symbol Definition
struct BIT {
                                /* bit7 */
   unsigned char
                    b7:1;
                    b6:1;
                                /* bit6 */
    unsigned char
    unsigned char
                    b5:1;
                                /* bit5 */
    unsigned char
                    h4:1;
                                /* bit4 */
                                /* bit3 */
    unsigned char
                    b3:1;
    unsigned char
                    b2:1;
                                /* bit2 */
                                /* bit1 */
    unsigned char
                    h1:1;
                                /* bit0 */
    unsigned char
                    b0:1;
};
#define
               TMB1
                         *(volatile unsigned char *)0xF760 /* Timer B1 Mode register
                                                                                                        * /
#define
               TCB1
                         *(volatile unsigned char *)0xF761 /* Timer B1 Counter Register
#define
               TCRV0
                         *(volatile unsigned char *)0xFFA0 /* Timer Control Rgister V
#define
               TCRV0_BIT (*(struct BIT *)0xFFA0)
                                                          /* Timer Control Rgister V
#define
                        TCRV0_BIT.b7
                                                          /* Compare Match Interrupt Enable B
               CMIEB
                                                                                                        * /
#define
               CMIEA
                         TCRV0_BIT.b6
                                                          /* Compare Match Interrupt Enable A
#define
               OVIE
                         TCRV0_BIT.b5
                                                           /* Timer Over Flow Interrupt Enable
                         TCRV0_BIT.b4
                                                           /* Counter Clear Bit 1
#define
               CCLR1
#define
               CCLR0
                         TCRV0_BIT.b3
                                                           /* Counter Clear Bit 0
#define
               CKS2
                         TCRV0_BIT.b2
                                                           /* Clock Select 2
                        TCRV0_BIT.b1
                                                           /* Clock Select 1
#define
               CKS1
                        TCRV0_BIT.b0
#define
               CKS0
                                                          /* Clock Select 0
#define
                          *(volatile unsigned char *)0xFFA1/* Timer Control/Status Register
               TCSRV
#define
               TCSRV_BIT (*(struct BIT *)0xFFA1)
                                                          /* Timer Control Rgister V
#define
               CMFB
                        TCSRV_BIT.b7
                                                          /* Compare Match Interrupt Flag B
                         TCSRV_BIT.b6
#define
               CMFA
                                                          /* Compare Match Interrupt Flag A
#define
               OVFTCSRV_BIT.b5
                                                           /* Timer Over Flow Interrupt Enable
#define
               OS3TCSRV_BIT.b3
                                                           /* Output Select3
               OS2TCSRV_BIT.b2
#define
                                                           /* Output Select2
#define
               OS1TCSRV_BIT.b1
                                                           /* Output Select1
#define
               OS0TCSRV_BIT.b0
                                                          /* Output Select0
#define
               TCORA
                         *(volatile unsigned char *)0xFFA2 /* Time Constant Register A
#define
               TCORB
                         *(volatile unsigned char *)0xFFA3 /* Time Constant Register B
                         *(volatile unsigned char *)0xFFA4 /* Timer Counter V1
#define
               TCNTV
                                                                                                        * /
```

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 12 of 16 http://www.renesas.com/

| #define | TCRV1 *(volatile                 | unsigned char *)0xFFA  | /* : | Timer Control Register V1             | * / |
|---------|----------------------------------|------------------------|------|---------------------------------------|-----|
| #define | TCRV1_BIT (*(struct              | BIT *)0xFFA5)          | /*   | Timer Control Rgister V               | */  |
| #define | TVEG1 TCRV1_BIT.L                | 04                     | /*   | TRGV Input Edge Select 1              | */  |
| #define | TVEGO TCRV1_BIT.L                | 53                     | /*   | TRGV Input Edge Select 0              | */  |
| #define | TRGE TCRV1_BIT.k                 | 52                     | /*   | TCNTV Count Up TCNTV Count Up Disable | */  |
| #define | ICKS0 TCRV1_BIT.k                | 00                     | /*   | Internal Clock Select                 | */  |
|         |                                  |                        |      |                                       |     |
| #define | IEGR1 *(volatile                 | unsigned char *)0xFFF2 | /*   | Interrupt Edge Select Register 1      | */  |
| #define | IEGR1_BIT (*(struct E            | BIT *)0xFFF2)          | /*   | Interrupt Edge Select Register 1      | * / |
| #define | IEG3 IEGR1_BIT.b                 | 53                     | /*   | IRQ3 Edge Select                      | * / |
| #define | IEG2 IEGR1_BIT.b                 | 52                     | /*   | IRQ2 Edge Select                      | */  |
| #define | IEG1 IEGR1_BIT.b                 | 01                     | /*   | IRQ1 Edge Select                      | */  |
| #define | IEGO IEGR1_BIT.b                 | 00                     | /*   | IRQ0 Edge Select                      | */  |
| #define | IENR1 *(volatile                 | unsigned char *)0xFFF4 | /*   | Interrupt Enable Register 1           | */  |
| #define | <pre>IENR1_BIT (*(struct B</pre> | BIT *)0xFFF4)          | /*   | Interrupt Enable Register 1           | */  |
| #define | IEN3 IENR1_BIT.                  | 03                     | /*   | IRQ3 Interrupt Enable                 | */  |
| #define | IEN2 IENR1_BIT.                  | 02                     | /*   | IRQ2 Interrupt Enable                 | */  |
| #define | IEN1 IENR1_BIT.                  | 01                     | /*   | IRQ1 Interrupt Enable                 | */  |
| #define | IEN0 IENR1_BIT.b                 | 00                     | /*   | IRQ0 Interrupt Enable                 | */  |
| #define | IENR2 *(volatile                 | unsigned char *)0xFFF5 | /*   | Interrupt Enable Register 2           | */  |
| #define | IENR2_BIT (*(struct B            | BIT *)0xFFF5)          | /*   | Interrupt Enable Register 2           | */  |
| #define | IENTB1 IENR2_BIT.b               | 5                      | /*   | Timer Bl Interrupt Enable             | */  |
| #define | IRR1 *(volatile                  | unsigned char *)0xFFF6 | /*   | Interrupt Flag Register 1             | */  |
| #define | IRR1_BIT (*(struct B             | BIT *)0xFFF6)          | /*   | Interrupt Flag Register 1             | */  |
| #define | IRRI3 IRR1_BIT.b3                | 3                      | /*   | IRQ3 Interrupt Request Flag           | */  |
| #define | IRRI2 IRR1_BIT.b2                | 2                      | /*   | IRQ2 Interrupt Request Flag           | */  |
| #define | IRRI1 IRR1_BIT.b1                | L                      | /*   | IRQ1 Interrupt Request Flag           | */  |
| #define | IRRIO IRR1_BIT.b0                | )                      | /*   | IRQ0 Interrupt Request Flag           | */  |
| #define | IRR2 *(volatile                  | unsigned char *)0xFFF7 | /*   | Interrupt Flag Register 2             | */  |
| #define | IRR2_BIT (*(struct B             | BIT *)0xFFF7)          | /*   | Interrupt Flag Register 2             | */  |
| #define | IRRTB1 IRR2_BIT.b5               | 5                      | /*   | Timer Bl Interrupt Request Flag       | */  |
|         |                                  |                        |      |                                       |     |
| #define | PMR1 *(volatile                  | unsigned char *)0xFFE0 | /*   | Port Mode Register 1                  | */  |
| #define | PMR1_BIT (*(struct B             | BIT *)0xFFE0)          | /*   | Port Mode Register 1                  | */  |
| #define | IRQ1 PMR1_BIT.b5                 | 5                      | /*   | TMIB1 Input Pin                       | * / |
|         |                                  |                        |      |                                       |     |
| #pragma | interrupt (TB1INT)               | )                      |      |                                       |     |
| #pragma | interrupt (TVCMA)                |                        |      |                                       |     |

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 13 of 16 <a href="http://www.renesas.com/">http://www.renesas.com/</a>

```
/* Function Definitions
void INIT ( void );
                                   /* SP Set
extern
     main ( void );
void
     TVCMA ( void );
void
void
     TB1INT
          ( void );
/* RAM define
unsigned char USRF;
                                    /* User Flag Area
                                                                * /
unsigned char cnt;
                                    /* 8 Bit Counter
                                    /* TCB1 Value
unsigned char cnt_1;
                                                                */
                                    /* 1 Sec Counter
                                                                * /
unsigned int
        cnt_2;
extern void _INITSCT();
/* Timer Bl Interrupt
void TB1INT ( void )
  IRRTB1 = 0;
                                     /* Clear IRRTB1
                                                                */
  set_imask_ccr(0);
                                     /* Interrupt Enable
                                                                */
  if(cnt == 0xFF)
     cnt = 0x00;
                                                                * /
                                     /* 8 Bit Counter Clear
     cnt_1 = 0x00;
                                     /* TCB1 Store Counter Initialize
                                                                * /
     USRF = 0 \times 01;
  }
  else
                                                                * /
     cnt = cnt+1;
                                     /* 8 Bit Counter Increment
  }
```

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 14 of 16 http://www.renesas.com/

```
/* Timer V Interrupt
void TVCMA( void )
   CMFA = 0;
                                           /* Clear IMIFA_0 to 0
                                                                              * /
   if(cnt_2 == 0x1F4)
                                            /* 1 Sec Passed ?
      cnt_2 = 0x0000;
                                            /* 1 Sec Couter Clear
     cnt_1 = TCB1;
                                            /* Store TCB1
     USRF = 0x01;
                                            /* Program End
                                                                              * /
     IENTB1 = 0;
                                            /* Timer Bl Interrupt Disable
                                                                              */
      CMIEA = 0;
                                            /* Timer V Compaire Match A Interrupt Disable */
   }
   else
     cnt_2 = cnt_2 + 1;
                                           /* 1 Sec Counter Count Up
}
```

#### Link Address Designation

Feb. 2003

| Section Name | Address |
|--------------|---------|
| CV1          | H'0000  |
| Р            | H'0100  |
| V            | H'FB80  |

ADE-502-134 16-bit / H8/300H Tiny

Page 15 of 16 http://www.renesas.com/

Feb. 2003

ADE-502-134 16-bit / H8/300H Tiny

Page 16 of 16 http://www.renesas.com/