# 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: http://www.renesas.com

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

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

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. 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; anticrime 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 majorityowned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



# H8/300L SLP Series

# Using the Asynchronous Event Counter for Control

### Introduction

Using an asynchronous event counter, a series of operation is repeated periodically: a transition from subactive mode to high-speed active mode, reversal of the port output in high-speed active mode, and a transition back to subactive mode.

## Target Device

H8/38024

#### Contents

| 1. | Specifications           | . 2 |
|----|--------------------------|-----|
| 2. | Description of Functions | . 2 |
| 3. | Principle of Operation   | . 7 |
| 4. | Description of Software  | . 8 |
| 5. | Flowchart                | 13  |
| 6. | Program Listing          | 16  |

#### 1. Specifications

- 1. Using an asynchronous event counter (AEC), a series of operation is repeated once every 524.288 ms: a transition from subactive mode to high-speed active mode, reversal of the port output in high-speed active mode, and a transition back to subactive mode.
- 2. The 2-MHz event input is applied to the asynchronous event input L pin (AEVL).
- 3. In this sample task, the AEC is used as a 16-bit asynchronous event counter.

### 2. Description of Functions

- 1. In this sample task, an asynchronous event counter (AEC) is used to induce transitions between subactive and active modes and to invert the port output. The features of the AEC are as follows.
  - External events input asynchronously are counted without regard to the basic clock operation.
  - The counter has a 16-bit configuration, and can count up to 65,536 events.
  - The circuit can also be used as two independent 8-bit event counters on different channels.
  - The counter can be reset and its counting-up operation can be halted under software control.
  - Event counter overflow can be detected to automatically generate an interrupt.
  - When not in use, the AEC alone can be placed in a standby state by the module standby mode.
- 2. Figure 2.1 is a block diagram of the 16-bit asynchronous event counter used in this sample task.



Figure 2.1 Block Diagram of Asynchronous Event Counter

3. Functions of the 16-bit asynchronous event counter are described in table 2.1 below.

|                                                           | -                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register                                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Input pin edge selection register (AEGSR)                 | AEGSR is an 8-bit read/write register which selects the edge sensing of rising edge, falling edge, or both edges for AEVH, AEVL and IRQAEC pins.                                                                                                                                                                                                                                                                                                                |
| Event counter control register<br>(ECCR)                  | ECCR is an 8-bit read-only up-counter which controls the input clock of the counter and IRQAEC/IECPWM                                                                                                                                                                                                                                                                                                                                                           |
| Event counter control/<br>status register (ECCSR)         | ECCSR is an 8-bit read/write register which is used to control counter overflow detection, the counter resetting, and halting of counting-up function. Upon a reset, ECCSR is initialized to H'00.                                                                                                                                                                                                                                                              |
| Event counter H (ECH)                                     | ECH is an 8-bit read-only up-counter which operates either as an independent 8-bit event counter or, in combination with ECL, as the counter for the upper eight bits of a 16-bit event counter. As the input clock signal, either the external asynchronous event AEVH pin, or the overflow signal from the lower 8-bit counter ECH can be selected by the CH2 bit in ECCSR. ECH can be cleared to H'00 by software. Upon a reset, ECH is initialized to H'00. |
| Event counter L (ECL)                                     | ECL is an 8-bit read-only up-counter which operates either as an independent 8-bit event counter or, in combination with ECH, as the counter for the lower eight bits of a 16-bit event counter. As the input clock signal, the event clock from the external asynchronous event AEVL pin is used. ECL can be cleared to H'00 by software. Upon a reset, ECL is initialized to H'00.                                                                            |
| Asynchronous event input H<br>(AEVH)                      | AEVH is the event input pin for input to event counter H (ECH).                                                                                                                                                                                                                                                                                                                                                                                                 |
| Asynchronous event input L<br>(AEVL)                      | AEVL is the event input pin for input to event counter L (ECL).                                                                                                                                                                                                                                                                                                                                                                                                 |
| Asynchronous event counter interrupt request flag (IRREC) | When an asynchronous event counter interrupt request is generated, IRREC is set to 1. It is not automatically cleared even after the interrupt is accepted. To clear IRREC, write 0 by software.                                                                                                                                                                                                                                                                |
| Asynchronous event counter interrupt enable (IENEC)       | IENEC enables or disables asynchronous event counter interrupt requests.                                                                                                                                                                                                                                                                                                                                                                                        |

#### Table 2.1 Functions of the 16-bit Asynchronous Event Counter



| 4. | Figure 2.2 shows an | example of settings | when using the AEC as | a 16-bit asynchronous event counter. |
|----|---------------------|---------------------|-----------------------|--------------------------------------|
|    |                     |                     |                       |                                      |

#### Figure 2.2 Example of Settings for 16-bit Asynchronous Event Counter

Since CH2 is cleared to 0 upon a reset, ECH and ECL operate as a 16-bit event counter after a reset. The AEC also operate as a 16-bit event counter by the settings shown in figure 2.2. The operating clock source is the asynchronous event input from the AEVL pin. When the next clock pulse is input after the count values for both ECH and ECL reach H'FF, ECH and ECL overflow, the OVH flag in ECCSR is set to 1, the count values of ECH and ECL are both reset to H'00, and counting-up is restarted. Upon occurrence of overflow, the IRREC bit in IRR2 is set to 1. At this time, if the IENEC bit in IENR2 is 1, an interrupt request is issued to the CPU.

5. Asynchronous event counter operating modes are shown in table 2.2.

#### Table 2.2 Asynchronous Event Counter Operating Modes

| Operating |       |           |           |                            |                         |                         |                            | Module  |
|-----------|-------|-----------|-----------|----------------------------|-------------------------|-------------------------|----------------------------|---------|
| Mode      | Reset | Active    | Sleep     | Watch                      | Subactive               | Subsleep                | Standby                    | Standby |
| AEGSR     | Reset | Functions | Functions | Held* <sup>1</sup>         | Functions               | Functions               | Held* <sup>1</sup>         | Held    |
| ECCR      | Reset | Functions | Functions | Held* <sup>1</sup>         | Functions               | Functions               | Held* <sup>1</sup>         | Held    |
| ECCSR     | Reset | Functions | Functions | Held* <sup>1</sup>         | Functions               | Functions               | Held* <sup>1</sup>         | Held    |
| ECH       | Reset | Functions | Functions | Functions* <sup>1,*2</sup> | Functions* <sup>2</sup> | Functions* <sup>2</sup> | Functions* <sup>1,*2</sup> | Halted  |
| ECL       | Reset | Functions | Functions | Functions* <sup>1,*2</sup> | Functions* <sup>2</sup> | Functions* <sup>2</sup> | Functions* <sup>1,*2</sup> | Halted  |

Notes: 1. When an asynchronous external event signal is input, the counter is incremented, but the count overflow H/L flags are not affected.

2 In these modes, ECH and ECL operate when "asynchronous external event" is selected, otherwise the AEC is halted and held pending.



- 6. Notes on the 16-bit asynchronous event counter
  - A. Before reading the values of ECH and ECL, the CUEH and CUEL bits in ECCSR must be cleared to 0 to prevent asynchronous event input to the counter. If the event counter is incremented while being read, the correct value cannot be read.
  - B. Use a clock with a frequency of up to 16 MHz for input to the AEVH and AEVL pins, and ensure that the highand low-level widths of the clock are at least 30 ns. There is no constraint on the duty cycle.
  - C. In the case of the AEC used in 16-bit mode, before the clock is input to it, ECCSR setting should be made such that the CUEH bit is first set to 1 and then the CRCH bit to 1 or both CUEH and CRCH are set simultaneously. Thereafter, do not change the value of CUEH during AEC operation in 16-bit mode. If CUEH is changed while in 16-bit mode, ECH will not be incremented correctly.
  - D. When ECPWME in AEGSR is 1, event counter PWM is operating and therefore ECPWCRH, ECPWCRL, ECPWDRH, ECPWDRL should not be modified. When changing the data in them, event counter PWM must be stopped by clearing ECPWME to 0 before writing to these registers.
  - E The value of Event Counter PWM Data Register and the value of Event Counter PWM Compare Register must be set so that Event Counter PWM Data Register < Event Counter PWM Compare Register. If the settings do not satisfy this condition, do not set ECPWME in AEGSR to 1.
  - F. As synchronization is established internally when an IRQAEC interrupt is generated, a maximum error of 1 tcyc will arise between clock halting and interrupt acceptance.
  - G. Table 2.3 shows operating modes and event input frequencies.

#### Table 2.3 Relation between Operating Modes and AEVH/AEVL Pin Event Input Frequencies

| Mode                                      |                     | Maximum AEVH/AEVL Pin Input<br>Clock Frequency |
|-------------------------------------------|---------------------|------------------------------------------------|
| Active (high-speed), Sleep (high-speed)   |                     | 16 MHz                                         |
| Medium-speed active, Sleep (medium-speed) | (¢/16)              | 2 · f <sub>osc</sub>                           |
|                                           | (¢/32)              | f <sub>osc</sub>                               |
|                                           | (¢/64)              | 1/2 · f <sub>osc</sub>                         |
| f <sub>osc</sub> = 1 MHz to 4 MHz         | (¢/128)             | $1/4 \cdot f_{osc}$                            |
| Watch, Subactive, Subsleep,               | (¢ <sub>w</sub> /2) | 1000 KHz                                       |
| Standby                                   | (¢ <sub>w</sub> /4) | 500 KHz                                        |
| φ <sub>w</sub> = 32.768 kHz or 38.4 kHz   | (¢ <sub>w</sub> /8) | 250 KHz                                        |

7. Table 2.4 shows the assignment of functions in this sample task.

#### Table 2.4Function Assignment

| Function | Assignment                                                                                                                                          |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| AEGSR    | Selects the edge sensing of rising, falling, or both edges for AEVL.                                                                                |
| ECCR     | Controls AEVL counter input clock.                                                                                                                  |
| ECCSR    | Sets 16-bit asynchronous event counter function, detects counter overflow, enables/disables the event clock input to ECH and ECL.                   |
| ECH      | Functions as the upper 8-bit up-counter of a 16-bit event counter, taking the ECL overflow signal as the input clock.                               |
| ECL      | Functions as the lower 8-bit up-counter of a 16-bit event counter, taking the external asynchronous event input on the AEVL pin as the input clock. |
| СОМ      | Sets P40/SCK32 pin function.                                                                                                                        |
| SCR3     | Sets P40/SCK32 pin function.                                                                                                                        |
| TMA3     | Used to set transition to subactive mode.                                                                                                           |
| AEVL     | Functions as the input pin for 2-MHz external asynchronous event input.                                                                             |
| P40      | Inverts P40 output, triggered by 10 times of ECH and ECL overflows.                                                                                 |
| PCR40    | Sets P40 pin to output pin function.                                                                                                                |
| SYSCR1   | Controls power down modes.                                                                                                                          |
| SYSCR2   | Controls power down modes.                                                                                                                          |
| IENDT    | Enables/disables direct transition interrupt requests                                                                                               |
| IENEC    | Enables/disables asynchronous event counter interrupt requests.                                                                                     |
| IRRDT    | Indicates whether or not a direct transition interrupt has been requested                                                                           |
| IRREC    | Indicates whether or not an asynchronous event counter interrupt has been requested.                                                                |

### 3. **Principle of Operation**

1. Figure 3.1 illustrates the operation of this sample task. Asynchronous event counter operation is implemented through hardware and software processing as shown in the figure.



Figure 3.1 Operation Principle of Asynchronous Event Counter



#### 4. Description of Software

#### 4.1 Modules

The modules used in this sample task are shown in table 4.1.

#### Table 4.1 Description of Modules

| Module                                                         | Label  | Function                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Main routine                                                   | main   | Initializes RAM area for use, port 40, asynchronous event counter and system control register; enables interrupts; executes direct transition to subactive mode; after 524.288 ms, controls port output and executes direct transitions to high-speed active mode or subactive mode. |
| Asynchronous<br>event counter<br>interrupt handling<br>routine | aecint | An asynchronous event counter interrupt handling routine which clears an interrupt request flag, increments and initializes an 8-bit counter, and after 524.288 ms, sets the flag in RAM.                                                                                            |
| Direct transition<br>interrupt handling<br>routine             | dtint  | A direct transition interrupt handling routine which clears the interrupt request flag.                                                                                                                                                                                              |

#### 4.2 Arguments

In this sample task, no arguments are used.

#### 4.3 Internal Registers

Table 4.2 shows the internal registers used in this sample task.

#### Table 4.2Description of Internal Registers

| Register |        | Function                                                   | Address | Setting    |
|----------|--------|------------------------------------------------------------|---------|------------|
| AEGSR    | ALEGS1 | Input Pin Edge Selection Register(AEC Edge Select L)       | H'FF92  | ALEGS1 = 0 |
|          | ALEGS0 | If ALEGS1 = 0 and ALEGS0 = 0, falling edge of AEVL pin     | Bit 5   | ALEGS0 = 0 |
|          |        | input is detected.                                         | Bit 4   |            |
| ECCR     | ACKL1  | Event Counter Control Register (AEC Clock Select L)        | H'FF94  | ACKL1 = 0  |
|          | ACKL0  | If ACKL1 = 0 and ACKL0 = 0, the clock used by ECL is input | Bit 5   | ACKL0 = 0  |
|          |        | from AEVL pin.                                             | Bit 4   |            |
| ECCSR    | OVH    | Event Counter Control/Status Register (Counter Overflow H) | H'FF95  | 0          |
|          |        | A status flag indicating overflow of ECH.                  | Bit 7   |            |
|          |        | If OVH = 0, indicates no overflow of ECH.                  |         |            |
|          |        | If OVH = 1, indicates ECH overflow.                        |         |            |
|          | OVL    | Event Counter Control/Status Register (Counter Overflow L) | H'FF95  | 0          |
|          |        | A status flag indicating overflow of ECL.                  | Bit 6   |            |
|          |        | If OVL = 0, indicates no overflow of ECL.                  |         |            |
|          |        | If OVL = 1, indicates ECL overflow.                        |         |            |

| Register |              | Function                                                                                                                                                                                                                                                                                                                                                                                                                              | Address                  | Setting              |
|----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------|
| ECCSR    | CH2          | <ul> <li>Event Counter Control/Status Register (Channel Selection)</li> <li>Selects whether to use ECH and ECL as a single-channel</li> <li>16-bit event counter, or as independent 8-bit event counters on two channels.</li> <li>If CH2 = 0, ECH and ECL function as a single concatenated</li> <li>16-bit event counter.</li> <li>If CH2 = 1, ECH and ECL function as independent 8-bit event counters on two channels.</li> </ul> | H'FF95<br>Bit 4          | 0                    |
|          | CUEH         | Event Counters on two channels.<br>Event Counter Control/Status Register<br>(Count-Up Enable H)<br>Enables or disables the event clock input to ECH.<br>If CUEH = 0, disables the event clock input to ECH.<br>If CUEH = 1, enables the event clock input to ECH.                                                                                                                                                                     | H'FF95<br>Bit 3          | 0                    |
|          | CUEL         | Event Counter Control/Status Register<br>(Count-Up Enable L)<br>Enables or disables the event clock input to ECL.<br>If CUEL = 0, disables the event clock input to ECL.<br>If CUEL = 1, enables the event clock input to ECL.                                                                                                                                                                                                        | H'FF95<br>Bit 2          | 0                    |
|          | CRCH         | Event Counter Control/Status Register<br>(Counter Reset Control H)<br>Controls ECH reset.<br>If CRCH = 0, ECH is reset.<br>If CRCH = 1, ECH reset is cancelled and count-up function<br>is enabled.                                                                                                                                                                                                                                   | H'FF95<br>Bit 1          | 0                    |
|          | CRCL         | Event Counter Control/Status Register<br>(Counter Reset Control L)<br>Controls ECL reset.<br>If CRCL = 0, ECL is reset.<br>If CRCL = 1, ECL reset is cancelled and count-up function is<br>enabled.                                                                                                                                                                                                                                   | H'FF95<br>Bit 0          | 0                    |
| ECH      |              | Event Counter H<br>An 8-bit read-only up-counter; in combination with ECL, it<br>operates as the upper 8 bits of a 16-bit event counter.                                                                                                                                                                                                                                                                                              | H'FF96                   | H'00                 |
| ECL      |              | Event Counter L<br>An 8-bit read-only up-counter; in combination with ECH, it<br>operates as the lower 8 bits of a 16-bit event counter.                                                                                                                                                                                                                                                                                              | H'FF97                   | H'00                 |
| SMR      | СОМ          | Serial mode Register (Communication Mode)<br>If COM = 0, P40/SCK32 pin functions as the P40 pin.<br>If COM = 1, P40/SCK32 pin functions as the SCK32 output<br>pin.                                                                                                                                                                                                                                                                   | H'FFA8<br>Bit 7          | 0                    |
| SCR3     | CKE1<br>CKE0 | Serial Control Register 3 (Clock Enable1,0)<br>If CKE1 = 0, CKE0 = 0, COM = 0 and PCR40 = 0,<br>P40/SCK32 pin functions as the P40 input pin.                                                                                                                                                                                                                                                                                         | H'FFAA<br>Bit 1<br>Bit 0 | CKE1 = 0<br>CKE0 = 0 |
| ТМА      | TMA3         | Timer Mode Register A (Internal Clock Selector 3)<br>Selects the clock source input to TCA.<br>If TMA3 = 0, PSS is selected as the TCA input clock source,<br>and an interval timer function is selected for timer A<br>If TMA3 = 1, PSW is selected as the TCA input clock source,<br>and a clock time base function is selected for timer A                                                                                         | H'FFB0<br>Bit 3          | 1                    |

| Register |                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Address                           | Setting                          |
|----------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------|
| PMR3     | AEVL                 | Port Mode Register 3(P37/AEVL Pin Function Switch)<br>Sets the P37/AEVL pin function.<br>If AEVL = 0, the P37/AEVL pin functions as the P37<br>input/output pin<br>If AEVL = 1, the P37/AEVL pin functions as the AEVL input<br>pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | H'FFCA<br>Bit 7                   | 1                                |
| PDR4     | P40                  | Port Data Register 4 (P40)<br>Stores the P40 pin data.<br>If P40 = 0, the P40 pin output level is low<br>If P40 = 1, the P40 pin output level is high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | H'FFD7<br>Bit 0                   | 0                                |
| PCR4     | PCR40                | Port Control Register 4 (Port Control Register 40)<br>Controls the P40 pin input/output.<br>If PCR40 = 0, the P40 pin functions as an input pin<br>If PCR40 = 1, the P40 pin functions as an output pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | H'FFE7<br>Bit 0                   | 1                                |
| SYSCR1   | SSBY                 | System Control Register 1 (Software Standby)<br>Specifies transition to standby mode or watch mode.<br>If SSBY = 0, after a SLEEP instruction is executed in active<br>mode, a transition is made to sleep mode, or after a SLEEP<br>instruction is executed in subactive mode, a transition is<br>made to subsleep mode<br>If SSBY = 1, after a SLEEP instruction is executed in active<br>mode, a transition is made to standby mode or to watch<br>mode, or after a SLEEP instruction is executed in subactive<br>mode, a transition is made to watch mode, a transition is made to watch                                                                                                                                                                                                                     | H'FFF0<br>Bit 7                   | 1                                |
|          | STS2<br>STS1<br>STS0 | System Control Register 1 (Standby Timer Select 2 to 0)<br>Specifies the time for the CPU and peripheral functions to<br>wait until the clock stabilizes when, triggered by a specific<br>interrupt, the standby mode or watch mode is terminated and<br>a transition is made to active mode.<br>When STS2 to STS1 = 000, standby time is 8,192 states<br>When STS2 to STS1 = 001, standby time is 16,384 states<br>When STS2 to STS1 = 010, standby time is 1,024 states<br>When STS2 to STS1 = 011, standby time is 2,048 states<br>When STS2 to STS1 = 100, standby time is 4,096 states<br>When STS2 to STS1 = 101, standby time is 2 states<br>When STS2 to STS1 = 101, standby time is 8 states<br>When STS2 to STS1 = 110, standby time is 8 states<br>When STS2 to STS1 = 111, standby time is 16 states | H'FFF0<br>Bit 6<br>Bit 5<br>Bit 4 | STS2 = 0<br>STS1 = 0<br>STS0 = 0 |
|          | LSON                 | System Control Register 1 (Low Speed On Flag)<br>When watch mode is terminated, selects either the system<br>clock ( $\phi$ ) or the subclock ( $\phi_{sub}$ ) as the CPU operating clock.<br>If LSON = 0, selects the system clock ( $\phi$ ) as the CPU<br>operating clock<br>If LSON = 1, selects the subclock ( $\phi_{sub}$ ) as the CPU<br>operating clock                                                                                                                                                                                                                                                                                                                                                                                                                                                 | H'FFF0<br>Bit 3                   | 1                                |

# H8/300L SLP Series Using the Asynchronous Event Counter for Control

| Register     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Address                  | Setting            |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------|
| SYSCR2 NESEL | System Control Register 2<br>(Noise Elimination Sampling Frequency Selection)<br>Selects the frequency at which the watch clock signal ( $\phi_w$ )<br>output by the subclock pulse generator is sampled using the<br>oscillator clock ( $\phi_{osc}$ ) output by the system clock pulse<br>generator.<br>If NESEL = 0, sampling frequency is $\phi_{osc}$ /16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | H'FFF1<br>Bit 4          | 1                  |
| DTON         | If NESEL = 1, sampling frequency is $\phi_{osc}$ /4.<br>System Control Register 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | H'FFF1                   | 1                  |
| DION         | <ul> <li>System Control Register 2</li> <li>(Direct Transfer On Flag)</li> <li>Specifies whether or not to make direct transitions among high-speed active mode, medium-speed active mode, and subactive mode when a SLEEP instruction is executed.</li> <li>When DTON = 0, if a SLEEP instruction is executed in active mode, a transition is made to standby mode, watch mode or sleep mode; if a SLEEP instruction is executed in subactive mode, a transition is made to watch mode or subsleep mode.</li> <li>When DTON = 1, if a SLEEP instruction is executed in high-speed active mode, a direct transition is made to medium-speed active mode (when SSBY = 1, MSON = 1, LSON = 0) or to subactive mode (when SSBY = 1, TMA3 = 1, LSON = 1); if a SLEEP instruction is made to high-speed active mode, a direct transition is made to high-speed active mode (when SSBY = 1, TMA3 = 1, LSON = 1); and if a SLEEP instruction is executed in subactive mode, a direct transition is made to high-speed active mode, a direct transition is executed in subactive mode, a direct transition is made to high-speed active mode, a direct transition is executed in subactive mode (when SSBY = 1, TMA3 = 1, LSON = 0) or to medium-speed active mode (when SSBY = 1, TMA3 = 1, LSON = 0, MSON = 0) or to medium-speed active mode (when SSBY = 1, TMA3 = 1, LSON = 0, MSON = 1).</li> </ul> | Bit 3                    |                    |
| MSON         | System Control Register 2<br>(Medium Speed On Flag)<br>Selects whether to operate in high-speed active mode or in<br>medium-speed active mode after the standby mode, watch<br>mode, or sleep mode is terminated,.<br>If MSON = 0, operates in high-speed active mode.<br>If MSON = 1, operates in medium-speed active mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | H'FFF1<br>Bit 2          | 0                  |
| SA1<br>SA0   | System Control Register 2<br>(Subactive Mode Clock Select 1, 0)<br>Selects the CPU operating clock ( $\phi_w/8$ , $\phi_w/4$ , $\phi_w/2$ ) in<br>subactive mode.<br>If SA1 = 0 and SA0 = 0, $\phi_w/8$ is selected<br>If SA1 = 0 and SA0 = 1, $\phi_w/4$ is selected<br>If SA1 = 1 and SA0 = *, $\phi_w/2$ is selected<br>Note: * Don't care                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | H'FFF1<br>Bit 1<br>Bit 0 | SA1 = 0<br>SA0 = 0 |

| Register |       | Function                                                                                                                                                                                                                                                                                                                                                               | Address         | Setting |  |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|--|
| IRR2     | IRRDT | Interrupt Request Register 2<br>(Direct Transition Interrupt Request Flag)<br>Indicates whether there is any direct transition interrupt<br>requested.<br>If IRRDT = 0, indicates that no direct transition interrupt has<br>been requested.<br>If IRRDT = 1, indicates that a direct transition interrupt has<br>been requested.                                      | H'FFF7<br>Bit 7 | 0       |  |
|          | IRREC | Interrupt Request Register 2<br>(Asynchronous Event Counter Interrupt Request Flag)<br>Indicates whether there is any asynchronous event counter<br>interrupt requested.<br>If IRREC = 0, indicates that no asynchronous event counter<br>interrupt has been requested.<br>If IRREC = 1, indicates that an asynchronous event counter<br>interrupt has been requested. | H'FFF7<br>Bit 0 | 0       |  |
| IENR2    | IENDT | Interrupt Enable Register 2<br>(Direct Transition Interrupt Enable)<br>Enables or disables direct transition interrupt requests.<br>If IENDT = 0, disables direct transition interrupt requests.<br>If IENDT = 1, enables direct transition interrupt requests.                                                                                                        | H'FFF4<br>Bit 7 | 1       |  |
|          | IENEC | Interrupt Enable Register 2<br>(Asynchronous Event Counter Interrupt Enable)<br>Enables or disables asynchronous event counter interrupt<br>requests.<br>If IENEC = 0, disables asynchronous event counter interrupt<br>requests<br>If IENEC = 1, enables asynchronous event counter interrupt<br>request                                                              | H'FFF4<br>Bit 0 | 1       |  |

## 4.4 Description of RAM

Table 4.3 describes the RAM area used in this sample task.

#### Table 4.3 Description of RAM

| Label | Function                                                         | Address | Used in      |
|-------|------------------------------------------------------------------|---------|--------------|
| FLAG  | Flag indicating 524.288 ms have elapsed.                         | H'FB80  | main, aecint |
| CNT   | 8-bit counter to count the number of timer F interrupt requests. | H'FB81  | main, aecint |



### 5. Flowchart

#### 1. Main routine

|                                                         | *                  |                                                                                                   |
|---------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------|
| "1" → CCR I-bit                                         |                    | Mask I-bit in CCR to disable interrupts.                                                          |
| $H'00 \rightarrow CNT$ $H'00 \rightarrow FLAG$          |                    | Initialize the RAM.                                                                               |
| H'00 → SCR3                                             |                    |                                                                                                   |
| $0 \rightarrow \text{COM}$ $1 \rightarrow \text{PCR40}$ |                    | Initialize P40 pin: set PDR to 0 and PCR to 1 for P40 pin to set the initial output to low level. |
| H'F8 → PDR4                                             |                    |                                                                                                   |
| $1 \rightarrow AEVL$                                    |                    | Initialize AEVL pin; set P37/AEVL pin as the AEVL input pin.                                      |
| H'00 → AEGSR                                            |                    | Set falling edge of AEVL to be detected.                                                          |
| H'00 → ECCR                                             |                    | Select AEVL pin input for the ECL input clock.                                                    |
| H'00 → ECCSR                                            |                    | Reset 16-bit event counter.                                                                       |
| H'8F → SYSCR1                                           |                    | Set SSBY = 1, LSON = 1, DTON = 1 and                                                              |
| $H'F8 \rightarrow SYSCR2$ $H'18 \rightarrow TMA$        |                    | TMA3 = 1 to make a direct transition from active mode (high-speed) to subactive mode.             |
| $0 \rightarrow \text{IRRDT}$                            |                    | Clear direct transition interrupt request flag to 0.                                              |
| $H'80 \rightarrow IENR2$                                |                    | Set IENDT to 1 to enable direct transition interrupt request.                                     |
| $0 \rightarrow CCR I$ -bit                              |                    | Clear I-bit in CCR to 0 to enables interrupts.                                                    |
| SLEEP                                                   |                    | Execute a SLEEP instruction to make a direct transition to subactive mode.                        |
|                                                         |                    |                                                                                                   |
| Note: * In this sample task, the sta                    | ack pointer is set | in INIT.SRC (assembly language).                                                                  |







2. Asynchronous event count interrupt handling routine.



3. Direct transition interrupt handling routine.





### 6. Program Listing

INIT.SRC (Program listing)

```
.EXPORT _INIT
.IMPORT _main
;
.SECTION P,CODE
_INIT:
MOV.W #H'FF80,R7
LDC.B #B'10000000,CCR
JMP @_main
;
.END
```

```
/*
                                                                            */
/* H8/300L Super Low Power Series
                                                                            */
/*
   -H8/38024 Series-
                                                                            */
/* Application Note
                                                                            */
/*
                                                                            */
/* 'Asynchronous Event Counter Control'
                                                                            */
/*
                                                                            */
/* Function
                                                                            */
/* : AEC(Asynvhronous Event Counter)
                                                                            */
/*
                                                                            */
/* External Clock : 10MHz
                                                                            */
/* Internal Clock : 5MHz
                                                                            */
/* Sub Clock : 32.768kHz
                                                                            */
/*
                                                                            */
  /**
#include <machine.h>
/* Symbol Definition
                                                                            */
struct BIT {
                    /* bit7 */
  unsigned char b7:1;
  unsigned char b6:1;
                    /* bit6 */
  unsigned char b5:1;
                    /* bit5 */
  unsigned char b4:1;
                    /* bit4 */
  unsigned char b3:1;
                    /* bit3 */
  unsigned char b2:1;
                    /* bit2 */
  unsigned char b1:1;
                     /* bit1 */
  unsigned char b0:1;
                      /* bit0 */
};
                                         /* Input Edge Select Register
              *(volatile unsigned char *)0xFF92
                                                                            */
#define AEGSR
                                           /* Event Counter Control Register
                                                                            */
#define ECCR
                *(volatile unsigned char *)0xFF94
#define ECCSR
               *(volatile unsigned char *)0xFF95
                                           /*Event Counter Control Status Register
                                                                            */
#define ECCSR BIT (*(struct BIT *)0xFF95)
                                            /*Event Counter Control Status Register
                                                                            */
                                                                            */
#define OVH
               ECCSR BIT.b7
                                            /* Counter Over Flow H
#define OVL
               ECCSR BIT.b6
                                            /* Counter Over Flow L
                                                                            */
#define ECH
               *(volatile unsigned char *)0xFF96
                                            /* Event Counter H
                                                                            */
                                            /* Event Counter L
                                                                            */
#define ECL
               *(volatile unsigned char *)0xFF97
       SMR
                                                                            */
#define
                *(volatile unsigned char *)0xFFA8
                                             /* Serial Mode Register
      SMR BIT
                                                                            */
#define
                (*(struct BIT *)0xFFA8)
                                             /* Serial Mode Register
#define
               SMR BIT.b7
                                                                            */
      COM
                                             /* Communication Mode
```

### H8/300L SLP Series Using the Asynchronous Event Counter for Control

| #define | CHR        | SMR_BIT.b6                                     |
|---------|------------|------------------------------------------------|
| #define | PE         | SMR_BIT.b5                                     |
| #define | PM         | SMR_BIT.b4                                     |
| #define | STOP       | SMR_BIT.b3                                     |
| #define | MP         | SMR_BIT.b2                                     |
| #define | CKS1       | SMR_BIT.b1                                     |
| #define | CKS0       | SMR_BIT.b0                                     |
| #define | SCR3       | *(volatile unsigned char *)0xFFAA              |
| #define | SCR3_BIT   | (*(struct BIT *)0xFFAA)                        |
| #define | TIE        | SCR3_BIT.b7                                    |
| #define | RIE        | SCR3_BIT.b6                                    |
| #define | TE         | SCR3 BIT.b5                                    |
| #define | RE         | SCR3_BIT.b4                                    |
| #define | MPIE       | SCR3_BIT.b3                                    |
| #define | TEIE       | SCR3 BIT.b2                                    |
| #define | CKE1       | SCR3 BIT.b1                                    |
| #define | CKE0       | SCR3 BIT.b0                                    |
| #define | TMA        | <pre>- *(volatile unsigned char *)0xFFB0</pre> |
| #define | PMR3 BIT   | (*(struct BIT *)0xFFCA)                        |
| #define | AEVL       | PMR3 BIT.b7                                    |
| #define | PDR4       | -<br>*(volatile unsigned char *)0xFFD7         |
| #define | PDR4 BIT   | (*(struct BIT *)0xFFD7)                        |
| #define | -<br>P40   | PDR4 BIT.b0                                    |
| #define | PCR4       | -<br>*(volatile unsigned char *)0xFFE7         |
| #define | PCR4 BIT   | (*(struct BIT *)0xFFE7)                        |
| #define | PCR40      | PCR4 BIT.b0                                    |
| #define | SYSCR1     | -<br>*(volatile unsigned char *)0xFFF0         |
| #define | SYSCR1 BIT | (*(struct BIT *)0xFFF0)                        |
| #define |            | SYSCR1 BIT.b7                                  |
| #define | STS2       | SYSCR1 BIT.b6                                  |
| #define | STS1       | SYSCR1 BIT.b5                                  |
| #define | STSO       | SYSCR1 BIT.b4                                  |
| #define | LSON       | SYSCR1 BIT.b3                                  |
| #define | MA1        | SYSCR1 BIT.bl                                  |
| #define | MAO        | SYSCR1 BIT.b0                                  |
| #define | SYSCR2     | *(volatile unsigned char *)0xFFF1              |
| #define | SYSCR2_BIT | (*(struct BIT *)0xFFF1)                        |
| #define | NESEL      | SYSCR2 BIT.b4                                  |
|         |            |                                                |
| #define | DTON       | SYSCR2 BIT.b3                                  |
| #define | MSON       | SYSCR2 BIT.b2                                  |
| #define | SA1        | SYSCR2 BIT.bl                                  |
| #define | SA0        | SYSCR2 BIT.b0                                  |
| #define | IENR2      | *(volatile unsigned char *)0xFFF4              |
| #define | IENR2 BIT  | (*(struct BIT *)0xFFF4)                        |
|         | IENDT      | IENR2_BIT.b7                                   |
|         | IENEC      | _<br>IENR2_BIT.b0                              |
| #define | IRR2_BIT   | (*(struct BIT *)0xFFF7)                        |
|         | IRRDT      | IRR2_BIT.b7                                    |
| #define |            | <br>IRR2_BIT.b0                                |
|         |            |                                                |
|         |            |                                                |

/\* Character Length \*/ /\* Parity Enable \*/ /\* Parity Mode \*/ /\* Stop Bit Length \*/ /\* Multiprocessor Mode \*/ \*/ /\* Clock Select 1 /\* Clock Select 0 \*/ /\* Serial Control Register 3 /\* Serial Control Register 3 \*/ \*/ /\* Transmit Interrupt Enable /\* Receive Interrupt Enable \*/ \*/ /\* Transmit Enable \*/ /\* Receive Enable \*/ /\* Multiprocessor Interrupt Enable \*/ /\* Transmit End Interrupt Enable \*/ /\* Clock Enable 1 \*/ /\* Clock Enable 0 \*/ /\* Timer Mode Register A \*/ /\* Port Mode Register 3 \*/ /\* P37/AEVL Select \*/ /\* Port Data Register 4 /\* Port Data Register 4 /\* Port 40 \*/ \*/ /\* Port 40 \*/ /\* Port Control Register4 \*/ /\* Port Control Register4 \*/ /\* Port Control Register40 \*/ /\* System Control Register 1 \*/ /\* System Control Register 1 \*/ /\* Software Standby \*/ /\* Standby Timer Select 2 \*/ \*/ \*/ /\* Low Speed On Flag \*/ /\* Active Mode Clock Select 1 /\* Active Mode Clock Select 0 \*/ \*/ /\* System Control Register 2 \*/ /\* System Control Register 2 \*/
/\* Noise Elimination Sampling \*/ Frequency Select \*/ /\* /\* Direct Transfer On Flag \*/ /\* Middle Speed On Flag \*/ /\* Subactive Mode Clock Select 1 \*/ /\* Subactive Mode Clock Select 0 \*/ /\* Interrupt Enable Register 2 \*/ /\* Interrupt Enable Register 2 \*/ /\* Timer FH Interrupt Enable \*/ /\* Timer FH Interrupt Enable \*/ /\* Interrupt Request Register 2 \*/ /\* Timer FH Interrupt Request Flag /\* Timer FH Interrupt Request Flag \*/ \*/

#pragma interrupt (aecint)
#pragma interrupt (dtint)



| /**************************************                          | ***************************************                                                                                                                                                                                                    | ***/                                 |
|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| /* Function define                                               |                                                                                                                                                                                                                                            | */                                   |
| /*********                                                       | *****                                                                                                                                                                                                                                      | ***/                                 |
| extern void INIT ( void );                                       | /* SP Set                                                                                                                                                                                                                                  | */                                   |
| <pre>void main ( void );</pre>                                   |                                                                                                                                                                                                                                            |                                      |
| <pre>void aecint ( void );</pre>                                 |                                                                                                                                                                                                                                            |                                      |
| <pre>void dtint ( void );</pre>                                  |                                                                                                                                                                                                                                            |                                      |
|                                                                  |                                                                                                                                                                                                                                            |                                      |
| /******                                                          | ******                                                                                                                                                                                                                                     | ***/                                 |
| /* RAM define                                                    |                                                                                                                                                                                                                                            | */                                   |
| /**************************************                          | ******                                                                                                                                                                                                                                     | ***/                                 |
| unsigned char FLAG;                                              | /* User Flag Area                                                                                                                                                                                                                          | */                                   |
| unsigned char CNT;                                               | /* User Flag Area                                                                                                                                                                                                                          | */                                   |
|                                                                  | -                                                                                                                                                                                                                                          |                                      |
| /********                                                        | *****                                                                                                                                                                                                                                      | ***/                                 |
| /* Vector Address                                                |                                                                                                                                                                                                                                            | */                                   |
| /*******                                                         | *****                                                                                                                                                                                                                                      | ***/                                 |
| #pragma section V1                                               | /* Vector Section Set                                                                                                                                                                                                                      | */                                   |
| void (*const VEC TBL1[])(void) = {                               |                                                                                                                                                                                                                                            |                                      |
| INIT                                                             | /* 0x0000 Reset Vector                                                                                                                                                                                                                     | */                                   |
| };                                                               |                                                                                                                                                                                                                                            |                                      |
| #pragma section V2                                               | /* Vector Section Set                                                                                                                                                                                                                      | */                                   |
| void (*const VEC TBL2[])(void) = {                               | ,                                                                                                                                                                                                                                          | ,                                    |
| aecint                                                           | /* 0x0018 Timer F Interrupt Vector                                                                                                                                                                                                         | */                                   |
| };                                                               | , oxoolo limer i incertape veccoi                                                                                                                                                                                                          | ,                                    |
| #pragma section V3                                               | /* Vector Section Set                                                                                                                                                                                                                      | */                                   |
| void (*const VEC TBL3[])(void) = {                               | , , ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                                                                                                                                                                                                    | ,                                    |
| dtint                                                            | /* 0x0028 Timer F Interrupt Vector                                                                                                                                                                                                         | */                                   |
| };                                                               | / 0x0020 limer r interrupt vector                                                                                                                                                                                                          | /                                    |
| ,                                                                |                                                                                                                                                                                                                                            |                                      |
|                                                                  |                                                                                                                                                                                                                                            |                                      |
| #pragma section                                                  | /* P                                                                                                                                                                                                                                       | */                                   |
| <pre>#pragma section /************************************</pre> | /* P                                                                                                                                                                                                                                       | ,                                    |
| /*****                                                           |                                                                                                                                                                                                                                            | ,                                    |
|                                                                  | *****                                                                                                                                                                                                                                      | ***/<br>*/                           |
| /*************************************                           | *****                                                                                                                                                                                                                                      | ***/<br>*/                           |
| /*************************************                           | *****                                                                                                                                                                                                                                      | ***/<br>*/                           |
| /*************************************                           | ****                                                                                                                                                                                                                                       | ***/<br>*/<br>***/                   |
| /*************************************                           | *****                                                                                                                                                                                                                                      | ***/<br>*/                           |
| <pre>/************************************</pre>                 | /* Interrupt Disable                                                                                                                                                                                                                       | ***/<br>*/<br>***/<br>*/             |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter                                                                                                                                                                                        | ***/<br>*/<br>*/<br>*/               |
| <pre>/************************************</pre>                 | /* Interrupt Disable                                                                                                                                                                                                                       | ***/<br>*/<br>***/<br>*/             |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter                                                                                                                                                                                        | ***/<br>*/<br>*/<br>*/               |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter                                                                                                                                                                                        | ***/<br>*/<br>*/<br>*/               |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag                                                                                                                                                            | * * * /<br>* /<br>* /<br>* /<br>* /  |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag<br>/* Initialize P40 Terminal Function                                                                                                                     | ***/<br>**/<br>*/<br>*/              |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag                                                                                                                                                            | * * * /<br>* /<br>* /<br>* /<br>* /  |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag<br>/* Initialize P40 Terminal Function                                                                                                                     | ***/<br>**/<br>*/<br>*/              |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag<br>/* Initialize P40 Terminal Function                                                                                                                     | ***/<br>**/<br>*/<br>*/              |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag<br>/* Initialize P40 Terminal Function                                                                                                                     | ***/<br>**/<br>*/<br>*/              |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR</pre>                                                                                             | ***/<br>**/<br>*/<br>*/<br>*/        |
| <pre>/************************************</pre>                 | /* Interrupt Disable<br>/* Initialize 8-bit Counter<br>/* Initialize Event Flag<br>/* Initialize P40 Terminal Function                                                                                                                     | ***/<br>**/<br>*/<br>*/              |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter</pre>                                                               | ***/<br>**/<br>*/<br>*/<br>*/        |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1</pre>                                                 | ***/<br>**/<br>*/<br>*/<br>*/<br>*/  |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1 /* Set SYSCR2</pre>                                   | ***/<br>**/<br>*/<br>*/<br>*/<br>*/  |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1</pre>                                                 | ***/<br>**/<br>*/<br>*/<br>*/<br>*/  |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1 /* Set SYSCR2</pre>                                   | ***/<br>**/<br>*/<br>*/<br>*/<br>*/  |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1 /* Set SYSCR2 /* Initialize TCA Overflow Period</pre> | ***/<br>***/<br>*/<br>*/<br>*/<br>*/ |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1 /* Set SYSCR2</pre>                                   | ***/<br>**/<br>*/<br>*/<br>*/<br>*/  |
| <pre>/************************************</pre>                 | <pre>/* Interrupt Disable /* Initialize 8-bit Counter /* Initialize Event Flag /* Initialize P40 Terminal Function /* Initialize P40 PDR /* Reset 16-bit Event Counter /* Set SYSCR1 /* Set SYSCR2 /* Initialize TCA Overflow Period</pre> | ***/<br>***/<br>*/<br>*/<br>*/<br>*/ |



| <pre>sleep();</pre>                                                             | /* Transition to Sleep Mode                      | */             |
|---------------------------------------------------------------------------------|--------------------------------------------------|----------------|
| <pre>set_imask_ccr(1);</pre>                                                    | /* Interrupt Disable                             | */             |
| <pre>IRREC = 0;<br/>IENR2 = 0x81;<br/>ECCSR = 0x0F;</pre>                       | /* Timer A Interrupt Enable                      | */             |
| <pre>set_imask_ccr(0);</pre>                                                    | /* Interrupt Enable                              | */             |
| <pre>while(1){     while (!FLAG);</pre>                                         |                                                  |                |
| <pre>FLAG = 0;<br/>SYSCR1 = 0xE7;<br/>SYSCR2 = 0xF8;<br/>TMA = 0x18;</pre>      | /* TMA3 = "1"                                    | */             |
| <pre>sleep(); P40 = ~P40;</pre>                                                 | /* Transition to Sleep Mode                      | */             |
| <pre>SYSCR1 = 0x8F;<br/>SYSCR2 = 0xF8;<br/>TMA = 0x18;<br/>sleep();<br/>}</pre> | /* Set SYSCR1<br>/* Set SYSCR2<br>/* TMA3 = "1"  | */<br>*/<br>*/ |
| /* AEC Interrupt                                                                | ***************************************          | */             |
| <pre>IRREC = 0;</pre>                                                           | /* Clear IRREC                                   | */             |
| OVH = 0;<br>OVL = 0;<br>CNT++;                                                  | /* Clear OVH<br>/* Clear OVL<br>/* Increment CNT | */<br>*/<br>*/ |
| <pre>if ( CNT &gt; 0x0F ) {     FLAG = 1;     CNT = 0; }</pre>                  | /* Set Event Flag<br>/* Initialize 8-bit Counter | */<br>*/       |



| /************************************** | **************** | / |
|-----------------------------------------|------------------|---|
| /* Direct Transfer Interrupt            | *                | / |
| /************************************** | **************** | / |
| void dtint ( void )                     |                  |   |
| {                                       |                  |   |
| <pre>IRRDT = 0;</pre>                   | /* Clear IRRDT * | / |
| }                                       |                  |   |

#### Link address specifications

| Section Name | Address |
|--------------|---------|
| CV1          | H'0000  |
| CV2          | H'0018  |
| CV3          | H'0028  |
| Р            | H'0100  |
| В            | H'FB80  |



# **Revision Record**

|      |           | Descript | ion                  |  |
|------|-----------|----------|----------------------|--|
| Rev. | Date Page | Summary  |                      |  |
| 1.00 | Dec.19.03 | _        | First edition issued |  |
|      |           |          |                      |  |
|      |           |          |                      |  |
|      |           |          |                      |  |
|      |           |          |                      |  |



Keep safety first in your circuit designs!

1. Renesas Technology Corp. 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 Corp. 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 Corp. or a third party.
- 2. Renesas Technology Corp. assumes no responsibility for any damage, or infringement of any thirdparty'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 Corp. without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corp. or an authorized Renesas Technology Corp. 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 Corp. 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 Corp. by various means, including the Renesas Technology Corp. 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 Corp. assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- 5. Renesas Technology Corp. 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 Corp. or an authorized Renesas Technology Corp. 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 Corp. 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 Corp. for further details on these materials or the products contained therein.