## 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.



# H8SX Family

Using the 32K Timer to Drive a 24-Hour Clock (Updated at 1-Minute Intervals)

### Introduction

A 24-hour clock (which is updated at 1-minute intervals) is created by using the 32K timer.

## Target Device

H8SX/1668R

### Preface

Although the writing of this application note is in accord with the hardware manual for the H8SX/1668 Group, the program covered in this application note can be run on the target device indicated above. However, since some functional modules may be changed for the addition of functionality etc., be sure to perform a thorough evaluation by confirming the details with the hardware manual for the target device.

### Contents

| 1. | Specification                        | . 2 |
|----|--------------------------------------|-----|
| 2. | Applicable Conditions                | . 3 |
| 3. | Description of Modules Used          | . 4 |
| 4. | Principles of Operation              | 10  |
| 5. | Description of Software              | 11  |
| 6. | Documents and Programs for Reference | 28  |



### 1. Specification

A 24-hour clock is created by using the 32K timer.

- The configuration of this clock is shown in figure 1.
- An LCD module is used to display the time.
- The clock starts operating after the current time has been set.
- The overflow period of the 32K timer is set to 60 s. The clock counts up at the end of each overflow period.
- The time data to be displayed on the LCD is stored in the on-chip RAM.
- If data in the on-chip RAM are erroneous, the LCD displays "error."
- The deep software standby mode is entered except when the clock counts up.
- If the IRQ0, IRQ1 or the NMI is generated while the clock is running, the clock continues to operate normally.

The operations of this clock are as follows.

- (1) The LCD displays "00:00" after power has been applied.
- (2) Set the "hours" by using the IRQ0 switch. Each time you press this switch, the "hours" data is incremented. "Hours" data from "00:00" to "23:00" is displayed.
- (3) After setting the "hours" to the desired value, press the IRQ1 switch. This establishes the "hours" setting.
- (4) Set the "minutes" by using the IRQ0 switch. Each time you press this switch, the "minutes" data is incremented. "Minutes" data from "00:00" to "00:59" is displayed.
- (5) After setting the "minutes" to the desired value, press the IRQ1 switch. This completes initialization of the time and starts operation of the clock.
- (6) The clock display is updated at 1-minute intervals. Note that the display on the LCD display ranges from "00:00" to "23:59."



Figure 1 Configuration of the 24-Hour Clock



### 2. Applicable Conditions

### Table 1 Applicable Conditions

| ltem                | Setting                      |                                           |
|---------------------|------------------------------|-------------------------------------------|
| Operating frequency | Input clock                  | 12.5 MHz                                  |
|                     | System clock (Iø)            | 50 MHz (input clock frequency $\times$ 4) |
|                     | Peripheral module clock (Pø) | 25 MHz (input clock frequency $\times$ 2) |
|                     | External bus clock (Bø)      | 50 MHz (input clock frequency $\times$ 4) |
| Operating mode      | Mode 7 (MD3 = 0, MD2 = 1, M  | D1 = 1, MD0 = 1, MD_CLK = 0)              |

#### Table 2Section Settings

| Address    | Section Name | Description                 |
|------------|--------------|-----------------------------|
| H'00000400 | P, C         | Program area, constant area |
| H'00FF4000 | BCLOCK, D    | RAM area                    |

#### Table 3 Vector Table

| Exception Handling<br>Source | Vector No. | Address in Vector Table | Function to interrupt destination |
|------------------------------|------------|-------------------------|-----------------------------------|
| Reset                        | 0          | H'000000                | main                              |



### 3. Description of Modules Used

#### 3.1 32K Timer

#### 3.1.1 Overview

Operation with 8- or 24-bit can be selected for the timer counting. Setting of the TME bit in TCR32K to 1 initiates counting up by the counter (TCNT32K). A 32K-timer interrupt is generated at the end of each interrupt cycle. Timer counting operations according to settings of the CKS0 bit and interrupt cycles are shown in table 4.

| Setting |      |      | Dividing<br>Ratio         | Counter in Use |              |              | Interrupt Cycles           |                      |
|---------|------|------|---------------------------|----------------|--------------|--------------|----------------------------|----------------------|
| EXCKSN  | CKS1 | CKS2 | Internally<br>Divided CLK | TCNT32K1       | TCNT32K2     | TCNT32K3     | Counter Value              | 32KOVI<br>Cycle      |
| 1       | 0    | 0    | SUBCK/32                  | $\checkmark$   | _            | -            | TCNT32K1 =                 | 250 ms               |
| 1       | 0    | 1    | SUBCK/64                  | $\checkmark$   | _            | _            | H'FF                       | 500 ms               |
| 1       | 1    | 0    | SUBCK/128                 | $\checkmark$   | _            | _            | -                          | 1 s                  |
| 1       | 1    | 1    | SUBCK/256                 | $\checkmark$   | _            | _            | -                          | 2 s                  |
| 0       | 0    | 0    | SUBCK/16384               | $\checkmark$   | $\checkmark$ | $\checkmark$ | TCNT32K3 =                 | 30 s                 |
| 0       | 0    | 1    | SUBCK/32768               | $\checkmark$   | $\checkmark$ | $\checkmark$ | H'3B                       | 60 s                 |
| 0       | 1    | 0    | SUBCK/16384               | √              | $\checkmark$ | $\checkmark$ | TCNT32K1 to3<br>= H'FFFF3B | Approx.<br>22.7 days |
| 0       | 1    | 1    | SUBCK/32768               | ✓              | ✓            | $\checkmark$ | -                          | Approx.<br>45.5 days |

#### Table 4 Counter Settings and OVI Cycles

✓: In use —: Not in use



### 3.1.2 Description of Operations

The counter (TCNT32K) starts counting up when the TME bit in the timer control register (TCR32K) is set to 1. A 32-K timer interrupt (32KOVI) is generated each time the counter overflows. The interrupt cycle can be changed by using the extended clock select bit and clock select bits 0 and 1 of the timer control register (TCR32K). If, for example, the extended clock select bit is 1, the 32K timer operates as shown in figure 2.



Figure 2 Operation of the 32K Timer



### 3.2 Deep Software Standby Mode

#### 3.2.1 Overview

In deep software standby mode, the CPU, on-chip peripheral functions (except for the USB and 32K timer), on-chip RAM areas 6 to 4, and oscillator functionality are all halted. In addition, the internal power supply to these modules stops, resulting in a significant reduction in power consumption. The states of operation are described in table 5.

#### Table 5 States of Operation

| State of<br>Operation                                    | Sleep Mode                           | All-Module-<br>Clock-Stop<br>Mode    | Software<br>Standby Mode          | Deep Software<br>Standby Mode                 | Hardware<br>Standby<br>Mode         |
|----------------------------------------------------------|--------------------------------------|--------------------------------------|-----------------------------------|-----------------------------------------------|-------------------------------------|
| Transition condition                                     | Control<br>register +<br>instruction | Control<br>register +<br>instruction | Control register<br>+ instruction | Control register +<br>instruction             |                                     |
| Cancellation method                                      | Interrupt                            | Interrupt <sup>*2</sup>              | Interrupt <sup>*8</sup>           | Interrupt <sup>*8</sup>                       | _                                   |
| Oscillator                                               | Operating                            | Operating                            | Halted                            | Halted                                        | Halted                              |
| Subclock<br>oscillator                                   | Operating <sup>*9</sup>              | Operating <sup>*9</sup>              | Operating <sup>*9</sup>           | Operating <sup>*9</sup>                       | Halted                              |
| CPU                                                      | Halted<br>(retained)                 | Halted<br>(retained)                 | Halted (retained)                 | Halted (undefined)                            | Halted<br>(undefined)               |
| On-chip RAM<br>areas 6 to 4<br>(H'FEE000 to<br>H'FF3FFF) | Operating<br>(retained)              | Halted<br>(retained)                 | Halted (retained)                 | Halted (undefined)                            | Halted<br>(undefined)               |
| On-chip RAM<br>areas 3 to 0<br>(H'FF4000 to<br>H'FFBFFF) | Operating<br>(retained)              | Halted<br>(retained)                 | Halted (retained)                 | Halted (retained/<br>undefined) <sup>*5</sup> | Halted<br>(undefined)               |
| Universal<br>Serial Bus<br>interface                     | Operating                            | Halted<br>(retained)                 | Halted (retained)                 | Halted (retained/<br>undefined) <sup>*5</sup> | Halted<br>(undefined)               |
| Watchdog<br>timer                                        | Operating                            | Operating                            | Halted (retained)                 | Halted (undefined)                            | Halted<br>(undefined)               |
| 8-bit timer<br>(unit 0/1)                                | Operating                            | Operating <sup>*4</sup>              | Halted (retained)                 | Halted (undefined)                            | Halted<br>(undefined)               |
| 32K timer                                                | Operating                            | Operating                            | Operating                         | Operating                                     | Halted                              |
| Other<br>peripheral<br>modules                           | Operating                            | Halted <sup>*1</sup>                 | Halted <sup>*1</sup>              | Halted <sup>*7</sup><br>(undefined)           | Halted <sup>*3</sup><br>(undefined) |
| I/O ports                                                | Operating                            | Retained                             | Retained <sup>*6</sup>            | Halted <sup>*6</sup><br>(undefined)           | Hi-Z                                |

Notes: "Halted (retained)" in the table means that the internal values are retained and internal operations are suspended.

"Halted (undefined)" in the table means that the internal values are undefined and the power supply for internal operations is turned off.



- 1. SCI enters the reset state, and other peripheral modules retain their states.
- 2. External interrupt and some internal interrupts (8-bit timer, watchdog timer, and 32K timer).
- 3. All peripheral modules enter the reset state.
- 4. "Functioning" or "Halted" is selectable through the setting of bits MSTPA9 and MSTPA8 in MSTPCRA.
- 5. "Retained" or "undefined" for the contents of RAM is selected by the setting of the bits RAMCUT2 to RAMCUT0 in DPSBYCR.
- 6. Retention or high-impedance for the address bus and bus-control signals ( $\overline{CS0}$  to  $\overline{CS7}$ ,  $\overline{AS}$ ,  $\overline{RD}$ ,  $\overline{HWR}$ , and  $\overline{LWR}$ ) is selected by the setting of the OPE bit in SBYCR.
- 7. Some peripheral modules enter a state where the register values are retained.
- 8. An external interrupt, 32-K timer interrupt, or USB suspend/resume interrupt.
- 9. Start/stop can be selected by setting the OSC32STP bit in TCR32K.

#### 3.2.2 Transition to the Deep Software Standby Mode

When both of the SSBY bit in the standby control register (SBYCR) and the DPSBY bit in the deep standby control register (DPSBYCR) are set to 1 and the SLEEP instruction is executed, a transition to deep software standby mode will be made. The mode transitions are described in figure 3.



#### H8SX Family Using the 32K Timer to Drive a 24-Hour Clock (Updated at 1-Minute Intervals)



From any state except hardware standby mode, a transition to the reset state oc curs when RES is driven low.

Figure 3 Mode Transitions



### 3.2.3 Cancellation of the Deep Software Standby Mode

Exit from deep software standby mode is initiated by signals on the external interrupt pins (the NMI and  $\overline{IRQ0}$ -A to  $\overline{IRQ3}$ -A), internal interrupt signals (32K timer and USB suspend/resume),  $\overline{RES}$  pin, or  $\overline{STBY}$  pin.

When deep software standby mode clearing source is generated, internal power supply starts simultaneously with the start of clock oscillation, and internal reset signal is generated for the entire LSI. Once the time specified by the WTSTS5 to WTSTS0 bits in a deep standby control register (DPSWCR) has elapsed, a stable clock signal is being supplied throughout the LSI and the internal reset is cleared.

Deep software standby mode is canceled on clearing of the internal reset, and then the reset exception handling starts. When deep software standby mode is canceled by an external interrupt pin or internal interrupt signal, the DPSRSTF bit in a reset status register (RSTSR) is set to 1.



### 4. Principles of Operation

The timing of operations of this sample task is shown in figure 4. In this figure, note that the clock operation starts after the initial time has been set to 0101 hours.



#### Figure 4 Timing of Operations



#### 5. Description of Software

### 5.1 **Operating Environment**

### Table 6 Operating Environment

| Item                                                         | Details                                            |
|--------------------------------------------------------------|----------------------------------------------------|
| Development tool                                             | High-performance Embedded Workshop Ver.4.02.00.022 |
| C/C++ compiler H8S, H8/300 Series C/C++ Compiler Ver.6.01.03 |                                                    |
|                                                              | (manufactured by Renesas Technology)               |
| Compiler options                                             | -cpu = h8sxa:24:md, -optimize = 1                  |
| Linker options                                               | -start = P, C/400, BCLOCK, D/OFF4000               |

### 5.2 List of Functions

The functions of this sample task are listed in table 7.

#### Table 7 List of Functions

| Function Name              | Description                                                                                                                                   |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| main                       | <ul> <li>Main function<br/>Calls the init, refresh, timeupdate and lcd functions, judges the mode and sets the<br/>mode variables.</li> </ul> |
| init                       | <ul> <li>Initialization function<br/>Makes initial settings for various registers and in RAM.</li> </ul>                                      |
| set                        | <ul> <li>Time set function<br/>Makes initial settings for the time, judges the mode and sets the mode variables.</li> </ul>                   |
| mode                       | <ul> <li>Mode set function<br/>Judges the mode and sets the mode variables.</li> </ul>                                                        |
| refresh                    | Reset function     Resets the registers.                                                                                                      |
| timeupdate                 | <ul> <li>Time update function<br/>Increments the time, judges the mode and sets the mode variables.</li> </ul>                                |
| lcd                        | <ul> <li>LCD display function<br/>Calls the InitializeDisplay and DisplayString functions and judges the mode.</li> </ul>                     |
| InitialiseDisplay*         | LCD initialization function     Initializes the LCD.                                                                                          |
| DisplayString <sup>*</sup> | Display function     Updates the LCD display.                                                                                                 |

Note: \* See section 6, Documents and Programs for Reference.



### 5.3 Symbolic Constants

## Table 8 Symbolic Constants

| Setting    | Description                                                       |  |
|------------|-------------------------------------------------------------------|--|
| _          | Tag for mode variables                                            |  |
| 0          | Enumeration constant for enumeration RAM_mode                     |  |
|            | "Hours" setting mode                                              |  |
| 1          | Enumeration constant for enumeration RAM_mode                     |  |
|            | "Minutes" setting mode                                            |  |
| 2          | Enumeration constant for enumeration RAM_mode                     |  |
|            | Clock operation mode                                              |  |
| 3          | <ul> <li>Enumeration constant for enumeration RAM_mode</li> </ul> |  |
|            | Abnormal-operation mode                                           |  |
| "( )"*     | Character strings to be set in the second row of the LCD          |  |
| "set hour" |                                                                   |  |
| "set min " |                                                                   |  |
| "error"    |                                                                   |  |
|            |                                                                   |  |

Note: \* Eight half-width spaces are displayed.



### 5.4 RAM Usage

#### Table 9 RAM Usage

| Туре          | Variable Name     | Description                                                  | Used in                          |
|---------------|-------------------|--------------------------------------------------------------|----------------------------------|
| unsigned char | RAMmin1           | First digit of minutes data (:-X)                            | init, set, timeupdate, lcd       |
| unsigned char | RAMmin2           | Second digit of minutes data (:X-)                           |                                  |
| unsigned char | RAMhr1            | First digit of hours data (-X:)                              | -                                |
| unsigned char | RAMhr2            | Second digit of hours data (X-:)                             | -                                |
| unsigned char | RAMflg            | Flag for causing a branch from the setting mode.             | init, set, mode, timeupdate, lcd |
| char          | RAMIcd_data[9]    | Data to be passed to the LCD function for display on the LCD | lcd, DisplayString               |
| enum          | RAM_mode_variable | Variable for storing the mode                                | init, set, mode, timeupdate      |



### 5.5 Description of Functions

#### 5.5.1 main Function

#### 1. Functional overview

Calls the init, refresh, timeupdate and lcd functions, judges the mode and sets the mode variable.

- 2. Arguments None
- 3. Return value None

#### 4. Description of internal registers used

The internal registers used in this sample task are described below. The settings shown in these tables are the values used in this sample task and differ from the initial values.

| Bit | Bit Name | Setting | R/W  | Description                                                                                                     |
|-----|----------|---------|------|-----------------------------------------------------------------------------------------------------------------|
| 10  | ICK2     | 0       | R/W  | System Clock (I                                                                                                 |
| 9   | ICK1     | 0       |      | Select the frequency of the system clock provided to the                                                        |
| 8   | ICK0     | 0       |      | CPU, EXDMAC, DMAC, and DTC. The ratio to the input                                                              |
|     |          |         |      | clock is as follows:                                                                                            |
|     |          |         |      | ICK (2:0)                                                                                                       |
|     |          |         |      | 000: Input clock × 4                                                                                            |
|     |          |         |      | The frequencies of the peripheral module clock and                                                              |
|     |          |         |      | external bus clock change to the same frequency as the                                                          |
|     |          |         |      | system clock if the frequency of the system clock is lower                                                      |
| -   |          |         |      | than that of the two clocks.                                                                                    |
| 6   | PCK2     | 0       | R/W  | Peripheral Module Clock (Ρφ) Select                                                                             |
| 5   | PCK1     | 0       |      | Select the frequency of the peripheral module clock. The                                                        |
| 4   | PCK0     | 1       |      | ratio to the input clock is as follows:                                                                         |
|     |          |         |      | PCK (2:0)                                                                                                       |
|     |          |         |      | 001: Input clock × 2                                                                                            |
|     |          |         |      | The frequency of the peripheral module clock should be                                                          |
|     |          |         |      | lower than that of the system clock. Though these bits can be set so as to make the frequency of the peripheral |
|     |          |         |      | module clock higher than that of the system clock, the                                                          |
|     |          |         |      | clocks will have the same frequency in reality.                                                                 |
| 2   | BCK2     | 0       | R/W  | External-Bus Clock (Bø) Select                                                                                  |
| 1   | BCK1     | 0       | 1011 | Select the frequency of the external bus clock. The ratio to                                                    |
| 0   | BCK0     | 0       |      | the input clock is as follows:                                                                                  |
| -   |          | -       |      | BCK (2:0)                                                                                                       |
|     |          |         |      | 000: Input clock × 4                                                                                            |
|     |          |         |      | The frequency of the external bus clock should be lower                                                         |
|     |          |         |      | than that of the system clock. Though these bits can be set                                                     |
|     |          |         |      | so as to make the frequency of the external bus clock                                                           |
|     |          |         |      | higher than that of the system clock, the clocks will have                                                      |
|     |          |         |      | the same frequency in reality.                                                                                  |

• System clock control register (SCKCR) Number of bits: 16 Address: H'FFFDC4



5. Flowchart





#### 5.5.2 init Function

- 1. Functional overview Makes initial settings for registers and in RAM.
- 2. Arguments None
- 3. Return value None
- 4. Description of internal registers used

The internal registers used in this sample task are described below. The settings shown in these tables are the values used in this sample task and differ from the initial values.

| • | Deep | standby wait co | ontrol register | (DPS WC | (R) Number of bits: 8 Address: HFFFE/1                          |
|---|------|-----------------|-----------------|---------|-----------------------------------------------------------------|
| _ | Bit  | Bit Name        | Setting         | R/W     | Description                                                     |
|   | 5    | WTSTS5          | 0               | R/W     | Deep Software Standby Wait Time Setting                         |
|   | 4    | WTSTS4          | 0               | R/W     | Select the time for which the MCU waits until the clock settles |
|   | 3    | WTSTS3          | 1               | R/W     | W when deep software standby mode is canceled by an interrup    |
|   | 2    | WTSTS2          | 1               | R/W     | 001101: Wait time = 131072 states (CPU cycles)                  |
|   | 1    | WTSTS1          | 0               | R/W     |                                                                 |
|   | 0    | WTSTS0          | 1               | R/W     |                                                                 |
|   |      |                 |                 |         |                                                                 |

| • Stan | dby control reg | ister (SBYCR) | Numb | er of bits: 16 Address: H'FFFDC6                                                                                                                                                                                                                                                                                                                      |
|--------|-----------------|---------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | Bit Name        | Setting       | R/W  | Description                                                                                                                                                                                                                                                                                                                                           |
| 15     | SSBY            | 1             | R/W  | Software Standby<br>Specifies the transition mode after executing the SLEEP<br>instruction.<br>1: Enter software standby mode after execution of the SLEEP<br>instruction is executed.<br>This bit does not change when clearing software standby mode<br>by using interrupts and shifting to normal operation. For<br>clearing, write 0 to this bit. |
| 12     | STS4            | 0             | R/W  | Standby Timer Select 4 to 0                                                                                                                                                                                                                                                                                                                           |
| 11     | STS3            | 1             | R/W  | Select the time the MCU waits for the clock to settle when                                                                                                                                                                                                                                                                                            |
| 10     | STS2            | 1             | R/W  | software standby mode is cleared by an interrupt or when a                                                                                                                                                                                                                                                                                            |
| 9      | STS1            | 1             | R/W  | transition is made from subclock operation to main clock                                                                                                                                                                                                                                                                                              |
| 8      | STS0            | 0             | R/W  | operation.<br>01110: Wait time = 262144 states (CPU cycles)                                                                                                                                                                                                                                                                                           |

Deep standby wait control register (DPSWCR) Number of hits: 8 Address: H'FFFE71



| • Deep st | andby control r | egister (Dl | PSBYC | R) Numbe                                             | r of bits: 8                                                                                                                                                                                                                                                                                                      | Address: H'FFFE70                                                          |  |
|-----------|-----------------|-------------|-------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|
| Bit       | Bit Name        | Setting     | R/W   | Description                                          | า                                                                                                                                                                                                                                                                                                                 |                                                                            |  |
| 7         | DPSBY           | 1           | R/W   | When the<br>SLEEP ins<br>At this time<br>and this bi | Deep Software Standby<br>When the SSBY bit in SBYCR has been set to 1, executing the<br>SLEEP instruction causes a transition to software standby mode.<br>At this time, if there is no source to clear software standby mode<br>and this bit is set to 1, a transition to deep software standby mode<br>is made. |                                                                            |  |
|           |                 |             |       | SSBY DPSBY Entry to                                  |                                                                                                                                                                                                                                                                                                                   |                                                                            |  |
|           |                 |             |       | 1                                                    | 1                                                                                                                                                                                                                                                                                                                 | Enters deep software standby mode after execution of a SLEEP instruction.  |  |
|           |                 |             |       |                                                      |                                                                                                                                                                                                                                                                                                                   | tandby mode is canceled due to an interrupt,<br>rite a 0 here to clear it. |  |

• Deep standby interrupt edge register (DPSIEGR) Number of bits: 8 Address: H'FFFE74

| Bit | Bit Name | Setting | R/W | Description                                              |
|-----|----------|---------|-----|----------------------------------------------------------|
| 7   | DNMIEG   | 0       | R/W | NMI Edge Select                                          |
|     |          |         |     | Selects the active edge for NMI pin input.               |
|     |          |         |     | 0: The interrupt request is generated by a falling edge. |
| 3   | DIRQ3EG  | 0       | R/W | IRQ3 Interrupt Edge Select                               |
|     |          |         |     | Selects the active edge for IRQ3 pin input.              |
|     |          |         |     | 0: The interrupt request is generated by a falling edge. |
| 2   | DIRQ2EG  | 0       | R/W | IRQ2 Interrupt Edge Select                               |
|     |          |         |     | Selects the active edge for IRQ2 pin input.              |
|     |          |         |     | 0: The interrupt request is generated by a falling edge. |
| 1   | DIRQ1EG  | 0       | R/W | IRQ1 Interrupt Edge Select                               |
|     |          |         |     | Selects the active edge for IRQ1 pin input.              |
|     |          |         |     | 0: The interrupt request is generated by a falling edge. |
| 0   | DIRQ0EG  | 0       | R/W | IRQ0 Interrupt Edge Select                               |
|     |          |         |     | Selects the active edge for IRQ0 pin input.              |
|     |          |         |     | 0: The interrupt request is generated by a falling edge. |
|     |          |         |     |                                                          |

• Deep standby interrupt enable register (DPSIER) Number of bits: 8 Address: H'FFFE72

| Bit | Bit Name | Setting | R/W | Description                                                 |
|-----|----------|---------|-----|-------------------------------------------------------------|
| 5   | DT32KIE  | 1       | R/W | 32-K Timer Interrupt Enable                                 |
|     |          |         |     | Enables/disables exit from deep software standby mode by    |
|     |          |         |     | the 32-K timer interrupt signal.                            |
|     |          |         |     | 1: Enables exit from deep software standby mode by the 32-K |
|     |          |         |     | timer interrupt signal.                                     |



| • Deep | standby interrup | ot flag registe | er (DPSII | FR) Number of bits: 8 Address: H'FFFE73                                                                                                                               |
|--------|------------------|-----------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | Bit Name         | Setting         | R/W       | Description                                                                                                                                                           |
| 5      | DT32KIF          | 0               | R/W       | 32-K Timer Interrupt Flag<br>[Setting condition]<br>Generation of a 32-K timer interrupt<br>[Clearing condition]<br>Writing of 0 to this bit after reading it as 1    |
| 1      | DIRQ1F           | 0               | R/W       | IRQ1 Interrupt Flag<br>[Setting condition]<br>Generation of IRQ1 input specified in DPSIEGR<br>[Clearing conditio]<br>Writing of 0 to this bit after reading it as 1  |
| 0      | DIRQ0F           | 0               | R/W       | IRQ0 Interrupt Flag<br>[Setting condition]<br>Generation of IRQ0 input specified in DPSIEGR<br>[Clearing condition]<br>Writing of 0 to this bit after reading it as 1 |

• Timer control register (TCR32K) Number of bits: 8 Address: H'FFFABC

| Bit | Bit Name | Setting | R/W | Description                                                                                                          |
|-----|----------|---------|-----|----------------------------------------------------------------------------------------------------------------------|
| 7   | EXCKSN   | 0       | R/W | Extended Clock Select and Clock Select 1, 0                                                                          |
| 1   | CKS1     | 0       | R/W | Select the clock source to be input to TCNT32K. The overflow                                                         |
| 0   | CKS0     | 1       | R/W | cycle for SUBCK = 32.768 kHz is indicated in parentheses.<br>When EXCKSN = 0:<br>01: Clock SUBCK/32768 (cycle: 60 s) |

• Data direction register (P2DDR) Number of bits: 8 Address: H'FFFB81

| Bit | Bit Name | Setting | R/W | Description                                                          |
|-----|----------|---------|-----|----------------------------------------------------------------------|
| 7   | P27DDR   | 1       | W   | DDR is an 8-bit write-only register that specifies the port input or |
| 6   | P26DDR   | 1       | W   | output for each bit. A read from the DDR is invalid and DDR is       |
| 5   | P25DDR   | 1       | W   | always read as an undefined value.                                   |
| 4   | P24DDR   | 1       | W   | When the general I/O port function is selected, the corresponding    |
| 3   | P23DDR   | 1       | W   | pin functions as an output port by setting the corresponding DDR     |
| 2   | P22DDR   | 1       | W   | bit to 1; the corresponding pin functions as an input port by        |
| 1   | P21DDR   | 1       | W   | clearing the corresponding DDR bit to 0.                             |
| 0   | P20DDR   | 1       | W   |                                                                      |
|     |          |         |     |                                                                      |



#### 5. Flowchart





### 5.5.3 mode Function

- Functional overview Judges the mode and sets the mode variables.
- 2. Arguments None
- 3. Return value None
- 4. Description of internal registers used

The internal register used in this sample task is described below. The setting shown in the table is the value used in this sample task and differs from the initial values.

|  | ٠ | Timer control register (TCR32) | K) Number of bits: 8 | Address: H'FFFABC |
|--|---|--------------------------------|----------------------|-------------------|
|--|---|--------------------------------|----------------------|-------------------|

| Bit | Bit Name | Setting | R/W | Description                                                                                                                                                 |
|-----|----------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | TME      | 1       | R/W | Timer Enable<br>When this bit is set to 1, TCNT32K starts counting. When it is<br>cleared to 0, TCNT32K stops counting and is initialized to<br>H'00_00_00. |

5. Flowchart





### 5.5.4 set Function

 Functional overview Makes initial settings for the time, judges the mode and sets the mode variables.

2. Arguments None

- 3. Return value None
- 4. Description of internal registers used

The internal register used in this sample task is described below. The setting below is the value used in this sample task and differs from the initial values.

• Port register (PORT1) Number of bits: 8 Address: H'FFFF40

Function: PORT is an 8-bit read-only register that reflects the port pin state. A write to PORT is invalid. When PORT is read, the DR bits that correspond to the respective DDR bits set to 1 are read and the status of each pin whose corresponding DDR bit is cleared to 0 is also read regardless of the ICR value. The initial value of PORT is undefined and is determined based on the port pin state.



#### 5. Flowchart





#### 5.5.5 refresh Function

- 1. Functional overview Resets the registers.
- 2. Arguments None
- 3. Return value None
- 4. Description of internal registers used

The internal registers used in this sample task are described below. The settings shown in these tables are the values used in this sample task and differ from the initial values.

| • | Data direction register  | (P2DDR) | Number of bits: 8   | Address: H'FFFB81 |
|---|--------------------------|---------|---------------------|-------------------|
|   | 2 and an eetion register | (       | rianicer or creat o | 1100100011111001  |

| Bit | Bit Name | Setting | R/W | Description                                                       |
|-----|----------|---------|-----|-------------------------------------------------------------------|
| 7   | P27DDR   | 1       | W   | DDR is an 8-bit write-only register that specifies the port input |
| 6   | P26DDR   | 1       | W   | or output for each bit. A read from the DDR is invalid and DDR    |
| 5   | P25DDR   | 1       | W   | is always read as an undefined value.                             |
| 4   | P24DDR   | 1       | W   | When the general I/O port function is selected, the               |
| 3   | P23DDR   | 1       | W   | corresponding pin functions as an output port by setting the      |
| 2   | P22DDR   | 1       | W   | corresponding DDR bit to 1; the corresponding pin functions as    |
| 1   | P21DDR   | 1       | W   | an input port by clearing the corresponding DDR bit to 0.         |
| 0   | P20DDR   | 1       | W   |                                                                   |
|     |          |         |     |                                                                   |

| ٠ | Standby control register (SBYCR) | Number of bits: 16 | Address: H'FFFDC6 |
|---|----------------------------------|--------------------|-------------------|
|---|----------------------------------|--------------------|-------------------|

| Bit | Bit Name | Setting | R/W | Description                                                                                  |
|-----|----------|---------|-----|----------------------------------------------------------------------------------------------|
| 15  | SSBY     | 1       | R/W | Software Standby                                                                             |
|     |          |         |     | Specifies the transition mode after executing the SLEEP instruction.                         |
|     |          |         |     | <ol> <li>Enters software standby mode after the SLEEP<br/>instruction is executed</li> </ol> |
| 12  | STS4     | 0       | R/W | Standby Timer Select 4 to 0                                                                  |
| 11  | STS3     | 1       | R/W | Select the time the MCU waits for the clock to settle when                                   |
| 10  | STS2     | 1       | R/W | software standby mode is cleared by an interrupt or when a                                   |
| 9   | STS1     | 1       | R/W | transition is made from subclock operation to main clock                                     |
| 8   | STS0     | 0       | R/W | operation.<br>01110: Wait time = 262144 states (CPU cycles)                                  |



#### 5. Flowchart

| ( | refresh ()                                                                                                                                                                                                                                                                                   |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | P2DDR = 0xFF<br>Set PL2 to the output pin for LCD.                                                                                                                                                                                                                                           |
|   | <ul> <li>SBYCR = 0xCE00</li> <li>Make settings so that the SLEEP instruction initiates the transition to deep software standby mode.</li> <li>Set the stabilization following release from the deep software standby mode to the recommended value of 262144 states (CPU cycles).</li> </ul> |
| ( | End                                                                                                                                                                                                                                                                                          |



#### 5.5.6 timeupdate Function

- 1. Functional overview Increments the time, judges the mode and sets the mode variables.
- 2. Arguments None
- 3. Return value None
- 4. Flowchart





### 5.5.7 Icd Function

1. Functional overview

Calls the InitialiseDisplay and DisplayString functions and judges the mode.

- 2. Arguments None
- 3. Return value None
- 4. Flowchart





#### 5.5.8 InitialiseDisplay Function\*

- 1. Functional overview Initializes the LCD.
- 2. Arguments None
- 3. Return value None

Note: \* See section 6, Documents and Programs for Reference.

### 5.5.9 DisplayString Function\*

- 1. Functional overview Displays character strings on the LCD.
- 2. Arguments LCD display contents and display position (which is either the first or second row)
- 3. Return value None

Note: \* See section 6, Documents and Programs for Reference.

#### 5.6 Notes

- If an IRQ interrupt request causes the system to return from deep software standby mode to the program execution state using the input buffer control register (ICR) to enable the input buffer is unnecessary.
- If an IRQ interrupt flag is to cause the system to return from deep software standby mode to the program execution state, use pins IRQ0-A to IRQ3-A. If you use pins IRQ0-B to IRQ3-B, the system will not be capable of returning to the program execution state.
- Some registers are initialized while others are not when the system is returned to the program execution state from deep software standby mode.
- When the system is returned to the program execution state from deep software standby mode, the amount of current consumption is increased during the period of waiting for stable oscillation by the MCU.



### 6. Documents and Programs for Reference

#### 6.1 Documents for Reference

- Hardware Manual H8SX/1668R Group Hardware Manual The most up-to-date version of this document is available on the Renesas Technology Website.
- Technical News/Technical Update The most up-to-date information is available on the Renesas Technology Website.

### 6.2 **Programs for Reference**

- InitialiseDisplay Function This LCD display function is included in a sample program for Renesas Starter Kit (RSK). The most up-to-date version of information is available on the Renesas Technology Website.
- DisplayString Function This LCD display function is included in a sample program for Renesas Starter Kit (RSK). The most up-to-date version of information is available on the Renesas Technology Website.



## Website and Support

Renesas Technology Website <u>http://www.renesas.com/</u>

Inquiries

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

### **Revision Record**

| Rev. |           | Description |                      |  |  |  |
|------|-----------|-------------|----------------------|--|--|--|
|      | Date      | Page        | Summary              |  |  |  |
| 1.00 | Jan.18.08 | _           | First edition issued |  |  |  |
|      |           |             |                      |  |  |  |
|      |           |             |                      |  |  |  |
|      |           |             |                      |  |  |  |
|      |           |             |                      |  |  |  |



#### Notes regarding these materials

- 1. This document is provided for reference purposes only so that Renesas customers may select the appropriate Renesas products for their use. Renesas neither makes warranties or representations with respect to the accuracy or completeness of the information contained in this document nor grants any license to any intellectual property rights or any other rights of Renesas or any third party with respect to the information in this document.
- 2. Renesas shall have no liability for damages or infringement of any intellectual property or other rights arising out of the use of any information in this document, including, but not limited to, product data, diagrams, charts, programs, algorithms, and application circuit examples.
- 3. You should not use the products or the technology described in this document for the purpose of military applications such as the development of weapons of mass destruction or for the purpose of any other military use. When exporting the products or technology described herein, you should follow the applicable export control laws and regulations, and procedures required by such laws and regulations.
- 4. All information included in this document such as product data, diagrams, charts, programs, algorithms, and application circuit examples, 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 products listed in this document, please confirm the latest product information with a Renesas sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas such as that disclosed through our website. (http://www.renesas.com)
- 5. Renesas has used reasonable care in compiling the information included in this document, but Renesas assumes no liability whatsoever for any damages incurred as a result of errors or omissions in the information included in this document.
- 6. When using or otherwise relying on the information in this document, you should evaluate the information in light of the total system before deciding about the applicability of such information to the intended application. Renesas makes no representations, warranties or guaranties regarding the suitability of its products for any particular application and specifically disclaims any liability arising out of the application and use of the information in this document or Renesas products.
- 7. With the exception of products specified by Renesas as suitable for automobile applications, Renesas products are not designed, manufactured or tested for applications or otherwise in systems the failure or malfunction of which may cause a direct threat to human life or create a risk of human injury or which require especially high quality and reliability such as safety systems, or equipment or systems for transportation and traffic, healthcare, combustion control, aerospace and aeronautics, nuclear power, or undersea communication transmission. If you are considering the use of our products for such purposes, please contact a Renesas sales office beforehand. Renesas shall have no liability for damages arising out of the uses set forth above.
- 8. Notwithstanding the preceding paragraph, you should not use Renesas products for the purposes listed below: (1) artificial life support devices or systems
  - (2) surgical implantations
  - (3) healthcare intervention (e.g., excision, administration of medication, etc.)
  - (4) any other purposes that pose a direct threat to human life

Renesas shall have no liability for damages arising out of the uses set forth in the above and purchasers who elect to use Renesas products in any of the foregoing applications shall indemnify and hold harmless Renesas Technology Corp., its affiliated companies and their officers, directors, and employees against any and all damages arising out of such applications.

- 9. You should use the products described herein within the range specified by Renesas, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas shall have no liability for malfunctions or damages arising out of the use of Renesas products beyond such specified ranges.
- 10. Although Renesas endeavors to improve the quality and reliability of its products, IC products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Please be sure to implement safety measures to guard against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas 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 applicable measures. Among others, since the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 11. In case Renesas products listed in this document are detached from the products to which the Renesas products are attached or affixed, the risk of accident such as swallowing by infants and small children is very high. You should implement safety measures so that Renesas products may not be easily detached from your products. Renesas shall have no liability for damages arising out of such detachment.
- 12. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written approval from Renesas.
- 13. Please contact a Renesas sales office if you have any questions regarding the information contained in this document, Renesas semiconductor products, or if you have any other inquiries.

© 2008. Renesas Technology Corp., All rights reserved.