# 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

- 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.
- 2. 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 for written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application for which it is not intended without the prior written consent of Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics atta abooks, 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.
- 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.

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

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

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

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



#### Cautions

Keep safety first in your circuit designs!

 Renesas Technology Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate

measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of nonflammable material or (iii) prevention against any malfunction or mishap.

Notes regarding these materials

- 1. These materials are intended as a reference to assist our customers in the selection of the Renesas Technology Corporation product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Renesas Technology Corporation or a third party.
- 2. Renesas Technology Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.
- 3. All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Renesas Technology Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corporation or an authorized Renesas Technology Corporation product distributor for the latest product information before purchasing a product listed herein.

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

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

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

Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.

8. Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.



8

# H8/3867 Series

# **Application Note**

Renesas Electronics

Rev.1.0 1999.08

# Cautions

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

# Preface

The H8/300L Series of single-chip microcomputers are based on the high-speed H8/300L CPU, and integrate all peripheral functions necessary for system configuration.

The H8/300L CPU uses an instruction set which is compatible with the H8/300 CPU.

The H8/3867 Series and H8/3827 Series are provided with such peripheral functions for system configuration as an LCD controller/driver, six different timers, a 14-bit pulse width modulator (PWM), a two-channel serial communication interface, and an A/D converter. These models can be used as microcomputers for embedded systems where LCD display is required.

The H8/3867 Series models are equipped with a booster constant-voltage (5 V) power supply as an LCD driver power supply, providing a constant 5 V regardless of  $V_{cc}$ .

These H8/3867 Series application notes include a "Basic Operation" section with operation examples when using the built-in peripheral functions of the H8/3867 Series independently. They are provided in the hope that they will be of use for software and hardware design.

Operation of the programs and circuits described in these application notes has been verified, but their operation should be confirmed by the user as well before actually being used.

# Contents

| Section | on 1 Guide to Using the H8/3867 Series Application Notes | 1   |
|---------|----------------------------------------------------------|-----|
| 1.1     | Contents of Basic Operation                              | 2   |
| Section | on 2 Basic Operation                                     | 5   |
| 2.1     | Internal Power Supply Step-Down Circuit Settings         | 5   |
| 2.2     | Asynchronous Event Counter Operation                     | 10  |
| 2.3     | LCD Display with Static Duty                             | 35  |
| 2.4     | LCD Display with 1/4 Duty                                | 58  |
| 2.5     | LCD Display with Segment External Expansion              | 83  |
| 2.6     | Oscillation Stabilization Time Settings                  | 108 |
| 2.7     | Module Standby Mode Settings                             | 117 |
| 2.8     | Clock Operation Using Timer F                            | 124 |

# Section 1 Guide to Using the H8/3867 Series Application Notes

These application notes consist of two sections, as follows.

Application Notes -----

 Guide to Using the H8/3867 Series Application Notes

- Basic Operation

#### Figure 1 Contents of these Application Notes

#### Guide to Using the H8/3867 Series Application Notes

Explains how to use the H8/3867 Series application notes.

#### **Basic Operation**

Explains how to use the built-in peripheral functions of the H8/3867 Series through simple task examples.

# 1.1 Contents of Basic Operation

Basic Operation includes the sections shown below, explaining use of the built-in peripheral functions.



Figure 2 Contents of Basic Operation

#### Specifications

Explains system specifications for task examples.

#### **Explanation of Functions Used**

Explains the features of peripheral functions used in task examples, and allocation of the peripheral functions.

#### **Explanation of Operation**

Explains operation of task examples using timing charts.

#### **Explanation of Software**

- Explanation of Modules
   Explains the software modules used for operation in task examples.
- 2. Explanation of Arguments

Explains input arguments necessary for module execution, and arguments output following execution.

3. Explanation of Internal Registers Used

Explains internal registers such as a timer control register and serial mode register of peripheral functions used in modules.

 Explanation of RAM Usage Explains RAM label names and functions used in modules.

#### Flowcharts

Uses flowcharts to explain the software executed in task examples.

#### **Program Lists**

Gives program lists for software executed in task examples.

#### RENESAS

# Section 2 Basic Operation

# 2.1 Internal Power Supply Step-Down Circuit Settings

| Internal Power Supply Step-Down | MCU:           | Functions Used:                 |
|---------------------------------|----------------|---------------------------------|
| Circuit Settings                | H8/3867 Series | Internal Power Supply Step-Down |
|                                 |                | Circuit                         |

#### Usage

The H8/3867 Series incorporates an internal power supply step-down circuit. Below the features and usage of the internal power supply step-down circuit are explained, together with important notes and the power supply voltage and operating range.

#### Features of the internal power supply step-down circuit

- 1. By using the internal power supply step-down circuit, the internal power supply voltage can be held constant at approximately 1.5 V without depending on the voltage of the power supply connected to the external V<sub>cc</sub> pin.
- 2. Current consumed when an external power supply at 1.8 V or higher is used can be held to approximately the same low current as at 1.5 V.
- 3. It is also possible to use the same level of an external power supply voltage and internal power supply voltage, without using the internal power supply step-down circuit.

#### Power supply connection when using the internal power supply step-down circuit

An external power supply is connected to the  $V_{cc}$  pin as shown in figure 1, and a capacitance of approximately 1  $\mu$ F is inserted between  $CV_{cc}$  and  $V_{ss}$ . By adding this external circuit, the internal step-down circuit becomes operative.



Figure 1 Power Supply Connection When Using the Internal Power Supply Step-down Circuit

#### Notes on operation using the internal power supply step-down circuit

- 1. The interface to the external circuit uses as reference levels the voltage of the power supply connected to the  $V_{cc}$  pin and the level of the ground connected to the  $V_{ss}$  pin. For example, the high and low port input/output levels become the  $V_{cc}$  level and the  $V_{ss}$  level, respectively.
- 2. When the internal power supply step-down circuit is used, the operating frequency  $f_{osc}$  range is, for a  $V_{cc}$  of 2.2 to 5.5 V,  $f_{osc} = 0.4$  MHz to 2 MHz; otherwise, it is  $f_{osc} = 0.4$  MHz to 1 MHz.
- 3. The LCD power supply and A/D converter analog power supply are not affected by internal step-down processing.

#### Power supply connection when not using the internal power supply step-down circuit

The external power supply is connected across the  $V_{cc}$  and  $CV_{cc}$  pins, as shown in figure 2. The external power supply is input directly to the internal power supply circuit.



Figure 2 Power Supply Connection When Not Using the Internal Power Supply Step-down Circuit

#### Note on operation not using the internal power supply step-down circuit

Power supply voltages between 1.8 V and 5.5 V can be used. Operation cannot be guaranteed if a voltage outside this range (less than 1.8 V or more than 5.5 V) is input.

#### Power supply voltage and oscillator frequency ranges

Figure 3 shows the ranges of the power supply voltage and the oscillator frequency (shaded regions).





#### Power supply voltage and operating frequency ranges

Figure 4 shows the ranges of the power supply voltage and operating frequency (shaded regions).



Figure 4 Power Supply Voltage and Operating Frequency Ranges

# 2.2 Asynchronous Event Counter Operation

| Asynchronous Event Counter | MCU:           | Functions Used:                  |
|----------------------------|----------------|----------------------------------|
| Operation                  | H8/3867 Series | Asynchronous Event Counter (AEC) |

#### **Specifications**

- 1. Using an asynchronous event counter, once every 524.288 ms there is a transition from subactive mode to active (high-speed) mode, reversal of the port output in active (high-speed) 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 task example, the circuit is used as a 16-bit asynchronous event counter.

#### **Explanation of Functions Used**

- 1. In this task example, 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.
  - Input external events can be counted asynchronously, independently of 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 counter channels.
  - The counter can be reset or halted under software control.
  - Event counter overflow can be detected to automatically generate an interrupt.
  - A module standby mode can be employed to set standby mode in module units when not in use.
- 2. Figure 1 is a block diagram of the 16-bit asynchronous event counter used in this task example.



Figure 1 Block Diagram of Asynchronous Event Counter

#### Renesas

3. Functions of the 16-bit asynchronous event counter are explained in table 1 below.

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

#### Event counter control/status register (ECCSR)

Function ECCSR is an 8-bit read/write register which is used to detect counter overflow, reset the counter, and halt counting-up operation. Upon reset, ECCSR is initialized to H'00.

#### Event counter H (ECH)

Function ECH is an 8-bit readable 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 of ECCSR. ECH can be cleared to H'00 by software. Upon reset, ECH is initialized to H'00.

#### Event counter L (ECL)

Function ECL is an 8-bit readable 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 by the CH2 bit of ECCSR. ECL can be cleared to H'00 by software. Upon reset, ECL is initialized to H'00.

#### Asynchronous event input H (AEVH)

Function AEVH is the event input pin for input to the event counter H (ECH).

#### Asynchronous event input L (AEVL)

Function AEVL is the event input pin for input to the event counter L (ECL).

#### Asynchronous event counter interrupt request flag (IRREC)

Function When an asynchronous event counter interrupt request occurs, IRREC is set to 1. Even when the interrupt is accepted, IRREC is not automatically cleared. To clear IRREC, use software to write 0.

#### Asynchronous event counter interrupt enable (IENEC)

Function Enables or disables asynchronous event counter interrupt requests.

4. Figure 2 shows an example of settings when using the circuit as a 16-bit asynchronous event counter.



Figure 2 Example of Settings for 16-bit Asynchronous Event Counter

Upon reset, CH2 is cleared to 0, so that after reset ECH and ECL operate as a 16-bit event counter. In addition, the circuit will also operate as a 16-bit event counter by using the settings shown in figure 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 of ESSSR is set to 1, the count values of ECH and ECL are both returned to H'00, and counting-up is restarted. Upon occurrence of overflow, the IRREC bit of IRR2 is set to 1. At this time, if the IENEC bit of IENR2 is 1, an interrupt request is sent to the CPU.

#### RENESAS

5. Asynchronous event counter operating modes are indicated in table 2.

#### Table 2 Asynchronous Event Counter Operating Modes

| Operating<br>Mode | Reset | Active    | Sleep      | Watch      | Subactive | Subsleep  | Standby    | Module<br>Standby |
|-------------------|-------|-----------|------------|------------|-----------|-----------|------------|-------------------|
| ECCSR             | Reset | Functions | Functions  | Held*      | Functions | Functions | Held*      | Held              |
| ECH               | Reset | Functions | Functions* | Functions* | Functions | Functions | Functions* | Halted            |
| ECL               | Reset | Functions | Functions* | Functions* | Functions | Functions | Functions* | Halted            |

Note: \* When an asynchronous external event is input, the counter is incremented, but the count overflow H/L flags are not affected.

- 6. Notes on the 16-bit asynchronous event counter
  - a. Before reading the values of ECH and ECL, the CUEH and CUEL bits of ECCSR are cleared to 0, to prevent asynchronous events from being input to the counter. If the counter is incremented during reading, the correct value cannot be read. When clearing the CUEH and CUEL bits of ECCSR to 0, ECH and ECL may each be incremented by one.
  - b. When the internal power supply step-down circuit is not being used, the maximum clock frequency for input to the AEVH and AEVL pins is 6 MHz when  $V_{cc}$  is 4.5 to 5.5 V, is 4 MHz when  $V_{cc}$  is 3.0 to 5.5 V, and is 3.2 MHz when  $V_{cc}$  is 2.6 to 5.5 V. When the internal power supply step-down circuit is being used or not being used, the maximum clock frequency is 2 MHz when  $V_{cc}$  is 2.2 to 5.5 V, and otherwise is 1 MHz. In addition, the clock high and low widths should be a minimum of 83 ns.
  - c. When the AEC is used in 16-bit mode, either the CUEH bit in ECCSR should be set to 1 and then CRCH set to 1, or else after CUEH and CRCH are set simultaneously the clock pulse should be input. Thereafter, the value of CUEH should not be modified during use in 16-bit mode. If, while in 16-bit mode, CUEH is changed, ECH may be erroneously incremented.
  - d. Table 3 shows operating modes and event input frequencies.

| Mode                                                                 |                                                       | Clock Frequency                                                                                                                                                                                       |  |  |
|----------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 16-bit mode<br>8-bit mode<br>Active (high-speed), Sleep (high-speed) |                                                       | Internal step-down circuit not used:<br>$V_{cc} = 4.5$ to 5.5 V/6 MHz<br>$V_{cc} = 3.0$ to 5.5 V/8 MHz<br>$V_{cc} = 2.6$ to 5.5 V/3.2 MHz<br>$V_{cc} = 2.2$ to 5.5 V/2 MHz<br>Other then shows (4 MHz |  |  |
|                                                                      |                                                       | Internal step-down circuit used:<br>$V_{cc} = 2.2$ to 5.5 V/2 MHz<br>Other than above/1 MHz                                                                                                           |  |  |
| 8-bit mode                                                           |                                                       |                                                                                                                                                                                                       |  |  |
| Active (medium-speed), Sleep (medium-speed)                          | ( <i>ф</i> /16)<br>( <i>ф</i> /32)<br>( <i>ф</i> /64) | $\begin{array}{c} 2 \cdot f_{osc} \\ f_{osc} \\ 1/2 \cdot f_{osc} \end{array}$                                                                                                                        |  |  |
| $f_{osc} = 400 \text{ KHz to 4 MHz}$                                 | ( <i>ø</i> /128)                                      | $1/4 \cdot f_{osc}$                                                                                                                                                                                   |  |  |
| 8-bit mode<br>Watch, Subactive, Subsleep, Standby                    | $(\phi_{\rm w}/2)$<br>$(\phi_{\rm v}/4)$              | 1000 kHz<br>500 kHz                                                                                                                                                                                   |  |  |
| f <sub>osc</sub> = 32.768 kHz or 38.4 kHz                            | ( $\phi_{\rm w}/8)$                                   | 250 kHz                                                                                                                                                                                               |  |  |

# Table 3Relation between Operating Modes and AEVH/AEVL Pin Event Input<br/>Frequencies

7. Table 4 indicates function allocation in this task example.

| Function | Function Allocation                                                                                                                    |
|----------|----------------------------------------------------------------------------------------------------------------------------------------|
| ECCSR    | Sets 16-bit asynchronous event counter functions, detects counter overflow, enables/disables input to ECH, ECL of the event clock.     |
| 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 AEVL pin as the input clock. |
| AVEL     | Functions as the input pin for 2-MHz external asynchronous event input.                                                                |
| IRREC    | Indicates whether there has been an asynchronous event counter interrupt request.                                                      |
| IENEC    | Enables/disables asynchronous event counter interrupt requests.                                                                        |

#### Table 4Function Allocation

Maximum AEVH/AEVL Pin Input

# **Explanation of Operation**

1. Figure 3 illustrates the principle of operation. Asynchronous event counter operation is based on the hardware and software processing indicated in the figure.



Figure 3 Principle of Operation of Asynchronous Event Counter

#### RENESAS

# **Explanation of Software**

1. Explanation of Modules

Table 5 explains the modules in this task example.

# Table 5Explanation of Modules

| Module Name                                                   | Label Name | Function                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Main routine                                                  | MAIN       | Initializes the stack pointer, RAM, port 4 <sub>o</sub> ,<br>asynchronous event counter, and system control<br>register; enables interrupts; executes direct<br>transitions to subactive mode; after 524.288 ms,<br>controls port output and executes direct transitions<br>to active (high-speed) mode and to subactive mode. |
| Asynchronous event<br>counter interrupt<br>processing routine | AECINT     | By routine for processing asynchronous event<br>counter interrupts, clears an interrupt request flag,<br>increments and initializes an 8-bit counter, and after<br>524.288 ms, sets a flag in RAM.                                                                                                                             |
| Direct transition interrupt processing routine                | DTINT      | By routine for processing direct transition interrupts, clears the interrupt request flag                                                                                                                                                                                                                                      |

2. Explanation of Arguments

In this task example, no arguments are used.

#### RENESAS

3. Explanation of Internal Registers Used

Table 6 gives explanations of the internal registers used in this task example.

|            |                  |                                                                                                                                         | RAM             |         |
|------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| Register N | lame             | Description                                                                                                                             | Address         | Setting |
| ECCSR      | OVH              | Event counter control/status register<br>(Counter overflow H)                                                                           | H'FF95<br>Bit 7 | 0       |
|            |                  | A status flag indicating overflow of ECH.                                                                                               | BRT             |         |
|            |                  | • When OVH = 0, indicates no overflow of ECH                                                                                            |                 |         |
|            |                  | • When OVH = 1, indicates ECH overflow                                                                                                  |                 |         |
| ECCSR      | OVL              | Event counter control/status register<br>(Counter overflow L)                                                                           | H'FF95<br>Bit 6 | 0       |
|            |                  | A status flag indicating overflow of ECL.                                                                                               | Bito            |         |
|            |                  | • When OVL = 0, indicates no overflow of ECL                                                                                            |                 |         |
|            |                  | • When OVL = 1, indicates ECL overflow                                                                                                  |                 |         |
| ECCSR      | CH2              | Event counter control/status register<br>(Channel selection)                                                                            | H'FF95<br>Bit 4 | 0       |
|            |                  | Selects whether to use ECH and ECL as a single-<br>channel 16-bit event counter, or as two<br>independent 8-bit event counter channels. |                 |         |
|            |                  | • When CH2 = 0, ECH and ECL function as a single concatenated 16-bit event counter                                                      |                 |         |
|            |                  | • When CH2 = 1, ECH and ECL function as two independent 8-bit event counter channels                                                    |                 |         |
| ECCSR      | CUEH             | Event counter control/status register                                                                                                   | H'FF95          | 0       |
|            | (Count-up enable | (Count-up enable H)                                                                                                                     | Bit 3           |         |
|            |                  | Enables or disables the event clock input to ECH.                                                                                       |                 |         |
|            |                  | <ul> <li>When CUEH = 0, disables the event clock input<br/>to ECH</li> </ul>                                                            |                 |         |
|            |                  | • When CUEH = 1, enables the event clock input to ECH                                                                                   |                 |         |

| Register I | Name | Description                                                                                                           | RAM<br>Address            | Setting |  |
|------------|------|-----------------------------------------------------------------------------------------------------------------------|---------------------------|---------|--|
| ECCSR      | CUEL | Event counter control/status register<br>(Count-up enable I)                                                          | H'FF95                    | 0       |  |
|            |      | Enables or disables the event clock input to ECL.                                                                     | Bit 2                     |         |  |
|            |      | • When CUEL = 0, disables the event clock input to ECL                                                                |                           |         |  |
|            |      | • When CUEL = 1, enables the event clock input to ECL                                                                 |                           |         |  |
| ECCSR      | CRCH | Event counter control/status register                                                                                 | H'FF95                    | 0       |  |
|            |      | (Counter reset control H)                                                                                             | Bit 1                     |         |  |
|            |      | Controls ECH reset.                                                                                                   |                           |         |  |
|            |      | <ul> <li>When CRCH = 0, ECH is reset</li> </ul>                                                                       |                           |         |  |
|            |      | <ul> <li>When CRCH = 1, ECH reset is canceled and<br/>count-up function is enabled</li> </ul>                         |                           |         |  |
| ECCSR      | CRCL | Event counter control/status register                                                                                 | H'FF95                    | 0       |  |
|            |      | (Counter reset contro                                                                                                 | (Counter reset control L) | Bit 0   |  |
|            |      | Controls ECL reset.                                                                                                   |                           |         |  |
|            |      | <ul> <li>When CRCL = 0, ECL is reset</li> </ul>                                                                       |                           |         |  |
|            |      | • When CRCL = 1, ECL reset is canceled and count-up function is enabled                                               |                           |         |  |
| ECH        |      | Event counter H                                                                                                       | H'FF96                    | H'00    |  |
|            |      | An 8-bit readable up-counter; by combining it with ECL, it can operate as the upper 8 bits of a 16-bit event counter. |                           |         |  |
| ECL        |      | Event counter L                                                                                                       | H'FF97                    | H'00    |  |
|            |      | An 8-bit readable up-counter; by combining it with ECH, it can operate as the lower 8 bits of a 16-bit event counter. |                           |         |  |

| Register | Name              | Description                                                                                                                                      | RAM<br>Address  | Setting |
|----------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| TMA      | TMA3              | Timer mode register A<br>(Internal clock selector 3)<br>Selects the clock input to TCA.                                                          | H'FFB0<br>Bit 3 | 1       |
|          |                   | <ul> <li>When TMA3 = 0, PSS is selected as the TCA<br/>input clock source, and an interval timer<br/>function is selected for timer A</li> </ul> |                 |         |
|          |                   | • When TMA3 = 1, PSW is selected as the TCA input clock source, and a clock time base function is selected for timer A                           |                 |         |
| PMR3     | AVEL              | Port mode register 3<br>(P3,/AEVL pin function switch)                                                                                           | H'FFCA<br>Bit 7 | 1       |
|          |                   | Determines whether the P3/AEVL pin is to be used as the P3, pin, or as the AEVL pin.                                                             |                 |         |
|          |                   | <ul> <li>When AEVL = 0, the P3,/AEVL pin functions<br/>as the P3, pin</li> </ul>                                                                 |                 |         |
|          |                   | <ul> <li>When AEVL = 1, the P3,/AEVL pin functions<br/>as the AEVL pin</li> </ul>                                                                |                 |         |
| PDR4     | P4 <sub>0</sub>   | Port data register 4<br>(P4 <sub>o</sub> )                                                                                                       | H'FFD7<br>Bit 0 | 0       |
|          |                   | Stores the $P4_0$ pin data.                                                                                                                      | DILU            |         |
|          |                   | • When $P4_0 = 0$ , the $P4_0$ pin output level is low                                                                                           |                 |         |
|          |                   | • When $P4_0 = 1$ , the $P4_0$ pin output level is high                                                                                          |                 |         |
| PCR4     | PCR4 <sub>0</sub> | Port control register 4                                                                                                                          | H'FFE7          | 1       |
|          |                   | (Port control register $4_{0}$ )                                                                                                                 | Bit 0           |         |
|          |                   | Controls the $P4_0$ pin input/output.                                                                                                            |                 |         |
|          |                   | <ul> <li>When PCR4<sub>0</sub> = 0, the P4<sub>0</sub> pin functions as<br/>an input pin</li> </ul>                                              |                 |         |
|          |                   | <ul> <li>When PCR4<sub>0</sub> = 1, the P4<sub>0</sub> pin functions as<br/>an output pin</li> </ul>                                             |                 |         |

| Register I | Name                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RAM<br>Address           | Setting                          |
|------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------------|
| SYSCR1     | SSBY                 | <ul> <li>System control register 1<br/>(Software standby)</li> <li>Carries out transition to standby mode or watch<br/>mode.</li> <li>When SSBY = 0, after executing a SLEEP<br/>instruction in active mode, causes a transition<br/>to sleep mode, or after executing a SLEEP<br/>instruction in subactive mode, causes a<br/>transition to subsleep mode</li> <li>When SSBY = 1, after executing a SLEEP<br/>instruction in active mode, causes a transition<br/>to standby mode or to watch mode, or after<br/>executing a SLEEP instruction in subactive<br/>mode, causes a transition to watch mode</li> </ul>                                                                                                                                                                                                   | H'FFF0<br>Bit 7          | 1                                |
| SYSCR1     | STS2<br>STS1<br>STS0 | <ul> <li>System control register 1 (Standby timer select 2 to 0)</li> <li>Specify the time for the CPU and peripheral functions to wait until the clock stabilizes when standby mode or watch mode is canceled and a transition is made to active mode due to a specific interrupt.</li> <li>When STS2 to STS1 = 000, standby time is 8,192 states</li> <li>When STS2 to STS1 = 001, standby time is 16,384 states</li> <li>When STS2 to STS1 = 010, standby time is 32,768 states</li> <li>When STS2 to STS1 = 011, standby time is 65,536 states</li> <li>When STS2 to STS1 = 100, standby time is 131,072 states</li> <li>When STS2 to STS1 = 101, standby time is 2 states</li> <li>When STS2 to STS1 = 101, standby time is 131,072 states</li> <li>When STS2 to STS1 = 111, standby time is 8 states</li> </ul> | H'FFF0<br>Bit 6 to bit 4 | STS2 = 0<br>STS1 = 0<br>STS0 = 0 |

# RENESAS

| Register I | Name  | Description                                                                                                                                                                                                    | RAM<br>Address | Setting |
|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|
| SYSCR1     | LSON  | System control register 1                                                                                                                                                                                      | H'FFF0         | 1       |
|            |       | (Low speed on flag)                                                                                                                                                                                            | Bit 3          |         |
|            |       | When watch mode is canceled, selects either the system clock ( $\phi$ ) or the subclock ( $\phi_{sub}$ ) as the CPU operating clock.                                                                           |                |         |
|            |       | <ul> <li>When LSON = 0, selects the system clock (φ)<br/>as the CPU operating clock</li> </ul>                                                                                                                 |                |         |
|            |       | • When LSON = 1, selects the subclock ( $\phi_{sub}$ ) as the CPU operating clock                                                                                                                              |                |         |
| SYSCR2     | NESEL | System control register 2                                                                                                                                                                                      | H'FFF1         | 1       |
|            |       | (Noise elimination sampling frequency selection)                                                                                                                                                               | Bit 4          |         |
|            |       | Selects the frequency at which the watch clock signal ( $\phi_w$ ) generated by the subclock oscillator is sampled relative to the oscillator clock ( $\phi_{osc}$ ) generated by the system clock oscillator. |                |         |
|            |       | • When NESEL = 0, sampling rate is $\phi_{\text{osc}}$ /16                                                                                                                                                     |                |         |
|            |       | • When NESEL = 1, sampling rate is $\phi_{osc}$ /4                                                                                                                                                             |                |         |

| Register Name |      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RAM<br>Address  | Setting |
|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| SYSCR2        | DTON | System control register 2<br>(Direct transfer on flag)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | H'FFF1<br>Bit 3 | 1       |
|               |      | Specifies whether or not to make direct transitions<br>among active (high-speed) mode, active (medium-<br>speed) mode, and subactive mode when a SLEEP<br>instruction is executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |         |
|               |      | <ul> <li>When DTON = 0, if a SLEEP instruction is<br/>executed in active mode, a transition to<br/>standby mode, watch mode or sleep mode<br/>occurs; if a SLEEP instruction is executed in<br/>subactive mode, a transition to watch mode or<br/>subsleep mode occurs</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |         |
|               |      | <ul> <li>When DTON = 1, if a SLEEP instruction is executed in active (high-speed) mode, a direct transition occurs to active (medium-speed) mode (when SSBY = 1, MSON = 1, LSON = 0) or to subactive mode (when SSBY = 1, TMA3 = 1, LSON = 1); if a SLEEP instruction is executed in active (medium-speed) mode, a direct transition occurs to active (high-speed) mode (when SSBY = 0, MSON = 0, LSON = 0) or to subactive mode (when SSBY = 1, TMA3 = 1, LSON = 1); and if a SLEEP instruction is executed in subactive mode, a direct transition occurs to active (high-speed) mode (when SSBY = 1, TMA3 = 1, LSON = 1); and if a SLEEP instruction is executed in subactive mode, a direct transition occurs to active (high-speed) mode (when SSBY = 1, TMA3 = 1, LSON = 0, MSON = 0) or to active (medium-speed) mode (when SSBY = 1, TMA3 = 1, LSON = 0, MSON = 1)</li> </ul> |                 |         |

| Register Name |            | Description                                                                                                                                                     | RAM<br>Address         | Setting |
|---------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------|
| SYSCR2        | MSON       | System control register 2<br>(Medium speed on flag)                                                                                                             | H'FFF1<br>Bit 2        | 0       |
|               |            | Selects whether to operate in active (high-speed)<br>mode or in active (medium-speed) mode after<br>cancellation of standby mode, watch mode, or<br>sleep mode. |                        |         |
|               |            | <ul> <li>When MSON = 0, operates in active<br/>(high-speed) mode</li> </ul>                                                                                     |                        |         |
|               |            | <ul> <li>When MSON = 1, operates in active<br/>(medium- speed) mode</li> </ul>                                                                                  |                        |         |
| SYSCR2        | SA1<br>SA0 | System control register 1                                                                                                                                       | H'FFF0<br>Bit 1, bit 0 | 1       |
|               |            | (Subactive mode clock select 1, 0)<br>Select the CPU clock rate ( $\phi_w/8$ , $\phi_w/4$ , $\phi_w/2$ ) in subactive mode.                                     |                        |         |
|               |            | • When SA1 = 0 and SA0 = 0, $\phi_{\rm w}/8$ is selected                                                                                                        |                        |         |
|               |            | • When SA1 = 0 and SA0 = 1, $\phi_w/4$ is selected                                                                                                              |                        |         |
|               |            | • When SA1 = 1 and SA0 = *, $\phi_{\rm w}/2$ is selected                                                                                                        |                        |         |
|               |            | *: Don't care                                                                                                                                                   |                        |         |
| IRR2          | IRRDT      | Interrupt request register 2                                                                                                                                    | H'FFF7                 | 0       |
|               |            | (Direct transition interrupt request flag)                                                                                                                      | Bit 7                  |         |
|               |            | Indicates whether there has been a direct transition interrupt request.                                                                                         | )                      |         |
|               |            | <ul> <li>When IRRDT = 0, indicates that no direct<br/>transition interrupt has been requested</li> </ul>                                                        |                        |         |
|               |            | • When IRRDT = 1, indicates that a direct transition interrupt has been requested                                                                               |                        |         |

| Register Name |       | Description                                                                                                                                                                                                                                                                                                                                                                                  | RAM<br>Address  | Setting |
|---------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| IRR2          | IRREC | <ul> <li>Interrupt request register 2 (Asynchronous event counter interrupt request flag) Indicates whether there has been an asynchronous event counter interrupt request.</li> <li>When IRREC = 0, indicates that no asynchronous event counter interrupt has been requested</li> <li>When IRREC = 1, indicates that an asynchronous event counter interrupt has been requested</li> </ul> | H'FFF7<br>Bit 0 | 0       |
| IENR2         | IENDT | <ul> <li>Interrupt enable register 2<br/>(Direct transition interrupt enable)</li> <li>Enables or disables direct transition interrupt<br/>requests.</li> <li>When IENDT = 0, disables direct transition<br/>interrupt requests</li> <li>When IENDT = 1, enables direct transition<br/>interrupt requests</li> </ul>                                                                         | H'FFF4<br>Bit 7 | 1       |
| IENR2         | IENEC | <ul> <li>Interrupt enable register 2 (Asynchronous event counter interrupt enable)</li> <li>Enables or disables asynchronous event counter interrupt requests.</li> <li>When IENEC = 0, disables asynchronous event counter interrupt requests</li> <li>When IENEC = 1, enables asynchronous event counter interrupt request</li> </ul>                                                      | H'FFF4<br>Bit 0 | 1       |

# 4. Explanation of RAM Usage

Table 7 explains RAM usage for this task example.

# Table 7Explanation of RAM Usage

| Label Name | Function                                                                         | RAM Address | Modules Used |
|------------|----------------------------------------------------------------------------------|-------------|--------------|
| FLAG       | Flag indicating 524.288 ms have elapsed.                                         | H'F780      | MAIN, AECINT |
| CNT        | 8-bit counter to count the number of occurrences of a timer F interrupt request. | H'F781      | MAIN, AECINT |

### Flowchart

1. Main routine



#### Renesas

#### 1. Main routine (cont)



#### RENESAS

2. Asynchronous event counter interrupt processing routine



3. Direct transition interrupt processing routine



#### RENESAS
### **Program Lists**

```
;*
  H8/3867 Application Note
;*
;*
    'Asynchronous Event Counter Control'
;*
;*
        Function : AEC(Asynvhronous Event Counter) *
;*
;*
        External Clock : 6MHz
;*
        Internal Clock : 3MHz
;*
        Sub Clock
               : 32.768kHz
;
      .cpu 3001
;
;*
      Symbol Defnition
;
ECCSR .equ h'ff95 ;Event Counter Control/Status Register
          h'ff96 ;Event Counter H
ECH
     .equ
ECL
          h'ff97 ;Event Counter L
      .equ
           h'ffb0
                   ;Timer Mode Register A
TMA
      .equ
           h'ffca
                   ;Port Mode Register 3
PMR3
      .equ
           h'ffd7
PDR4
                   ;Port Data Register 4
      .equ
           h'ffe7
                   ;Port Control Register 4
PCR4
      .equ
     .equ h'fff0
SYSCR1
                    ;System Control Register 1
SYSCR2 .equ h'fff1
                    ;System Control Register 2
   .equ h'fff4
IENR2
                    ;Interrupt Enable Register 2
IRR2
     .equ h'fff7
                    ;Interrupt Request Register 2
;
;*
      RAM Allocation
;
FLAG .equ h'f780 ;Bit0 : Event Flag
CNT
          h'f781
                   ;8-bit Counter
      .equ
```

Rev. 1.0, 08/99, page 30 of 151

; ; \* Vector Address ; .org h'0000 ;No.0 Reset Interrupt(H'0000-H'0001) .data.w MAIN ; h'0008 .orq ;No.4 \_IRQ0 Interrupt(H'0008-H'0009) .data.w MAIN .data.w MAIN ;No.5 \_IRQ1 Interrupt(H'000A-H'000B) ;No.6 \_IRQ2 Interrupt(H'000C-H'000D) .data.w MAIN .data.w MAIN ;No.7 \_IRQ3 Interrupt(H'000E-H'000F) ;No.8 \_IRQ4 Interrupt(H'0010-H'0011) .data.w MAIN ;No.9 \_WKP0-\_WKP7 Interrupt(H'0012-H'0013) .data.w MAIN ; h'0016 .org ;No.11 Timer A Interrupt(H'0016-H'0017) .data.w MAIN .data.w AECINT ;No.12 AEC Interrupt(H'0018-H'0019) ;No.13 Timer C Interrupt(H'001A-H'001B) .data.w MAIN MAIN ;No.14 Timer FL Interrupt(H'001C-H'001D) .data.w ;No.15 Timer FH Interrupt(H'001E-H'001F) .data.w MAIN .data.w MAIN ;No.16 Timer G Interrupt(H'0020-H'0021) ;No.17 SCI31 Interrupt(H'0022-H'0023) .data.w MAIN .data.w MAIN ;No.18 SCI32 Interrupt(H'0024-H'0025) ;No.19 A/D Converter Interrupt(H'0026-H'0028) .data.w MAIN ;No.20 Direct Transfer Interrupt(H'0028-H'0029) .data.w DTINT ; ;\* MAIN : Main Routine ; h'1000 .org ; MAIN: \$ .equ mov.w #h'ff80,sp ;Initialize Stack Pointer #h'80,ccr ;Interrupt Disable orc

#### RENESAS

Rev. 1.0, 08/99, page 31 of 151

```
mov.b
                   #h'00,r01
                                ;Initialize 8-bit Counter
          mov.b
                   r01,@CNT
          mov.b
                   r01,@FLAG
                                ;Initialize Event Flag
;
                   #h'f8f9,r0
          mov.w
                                ;Initialize P40 PDR
          mov.b
                   r0h,@PDR4
                                ;Initialize P40 Terminall Function
          mov.b
                   r01,@PCR4
;
          mov.b
                   #h'00,r01
                               ;Reset 16-bit Event Counter
          mov.b
                   r01,@ECCSR
          mov.b
                   #h'84,r01
                                ;Initialize AEVL Terminal Function
          mov.b
                   r01,@PMR3
;
                                ;SSBY="1", LSON="1"
          mov.b
                   #h'8f,r0l
                   r01,@SYSCR1 ;DTON="1", TMA3="1"
          mov.b
                   #h'F8,r01
          mov.b
          mov.b
                   r01,@SYSCR2
          mov.b
                   #H'18,r01
          mov.b
                   r01,@TMA
;
          bclr
                    #7,@IRR2
                                ;Clear IRRDT
          mov.b
                   #h'80,r01
          mov.b
                   r01,@IENR2 ;Direct Transfer Interrupt Enable
;
          andc
                    #h'7f,ccr
                                ;Interrupt Enable
;
                                ;Direct Transfer to Subactive Mode
          sleep
          nop
;
          bclr
                   #0,@IRR2
                                ;Clear IRREC
                   #h'81,r01
          mov.b
          mov.b
                   r01,@IENR2 ;Asynchronous Event Counter Interrupt Enable
;
                   #h'0f,r01
          mov.b
          mov.b
                   r01,@ECCSR ;16-bit Event counter count-up start
;
```

;

```
EVTMN:
        mov.b
               @FLAG,r01
                #0,r01
                         ;Event Flag = "1" ?
        btst
        beq
                EVTMN
                          ;No.
;
                #h'00,r01
        mov.b
        mov.b
               r01,@FLAG ;Clear Event Flag
;
                #h'e7f8,r0 ;SSBY="1", LSON="0"
        mov.w
               r0h,@SYSCR1 ;MSON="0", DTON="1"
        mov.b
        mov.b
              r01,@SYSCR2 ;TMA3="1"
              #h'18,r01 ;STS2-0="000"
        mov.b
        mov.b
                r01,@TMA
;
                          ;Direct Transfer to Active Mode
        sleep
        nop
;
                @PDR4,r01 ;Load PDR4
        mov.b
                      ;Invert P40 PDR
                #0,r01
        bnot
        mov.b
                r01,@PDR4 ;Store PDR4
;
               #h'8ff8,r0 ;SSBY="1", LSON="1"
        mov.w
               r0h,@SYSCR1 ;DTON="1", TMA3="1"
        mov.b
               r01,@SYSCR2
        mov.b
        mov.b
               #h'18,r0l
               r01,@TMA
        mov.b
;
                          ;Direct Transfer to Subavtive Mode
        sleep
        nop
;
        bra
                EVTMN
;
;*
        AECINT : AEC Interrupt Routine
;
AECINT:
        .equ
                $
        push r0
                          ;Store r0
```

| ;        |           |                           |                           |
|----------|-----------|---------------------------|---------------------------|
|          | bclr      | #0,@IRR2                  | ;Clear IRREC              |
|          | bclr      | #7,@ECCSR                 | ;Clear OVH                |
|          | bclr      | #6,@ECCSR                 | ;Clear OVL                |
| i        |           |                           |                           |
|          | mov.b     | @CNT,r0l                  | ;Load CNT                 |
|          | inc       | rOl                       | ;Increment CNT            |
|          | cmp.b     | #h'10,r01                 | ;CNT = h'10 ?             |
|          | beq       | EVNT                      | ;Yes. CNT Initialize      |
|          | mov.b     | r01,@CNT                  | ;Store CNT                |
|          | bra       | RNFI                      |                           |
| ;        |           |                           |                           |
| EVNT:    | mov.b     | #h'01,r01                 |                           |
|          | mov.b     | r01,@FLAG                 | ;Set Event Flag           |
|          | mov.b     | #h'00,r01                 |                           |
|          | mov.b     | r01,@CNT                  | ;Initialize 8-bit Counter |
| ;        |           |                           |                           |
| RNFI     | рор       | rO                        | ;Restore r0               |
|          | rte       |                           |                           |
| ;        |           |                           |                           |
| ;******* | ******    | * * * * * * * * * * * * * | ******                    |
| ;*       | DTINT : I | Direct Transf             | er Interrupt Routine      |
| ;******* | ******    | * * * * * * * * * * * * * | ******                    |
| ;        |           |                           |                           |
| DTINT:   | .equ      | \$                        |                           |
|          | bclr      | #7,@IRR2                  | ;Clear IRRDT              |
|          | rte       |                           |                           |
| ;        |           |                           |                           |
|          | .end      |                           |                           |

# 2.3 LCD Display with Static Duty

| LCD Display with Static Duty | MCU:           | Functions Used:       |  |
|------------------------------|----------------|-----------------------|--|
|                              | H8/3867 Series | LCD Controller/Driver |  |

# **Specifications**

- 1. LCD display is performed using the segment-type LCD controller circuit, LCD driver, and power supply circuit of the H8/3867 Series.
- 2. A single common signal and 32 segment signals are used for LCD display with static duty.
- 3. As the power supply driving the LCD, a step-up constant-voltage power supply (5 V) is used.
- 4. An example of LCD module connection and an LCD display example for this task example appear in figure 1.



Figure 1 LCD Display Example

## Renesas

# **Explanation of Functions Used**

- 1. In this task example, the LCD controller/driver is used for LCD display. The features of the LCD controller/driver are described below.
  - Display capacity
    - a. Duty cycle: static
       Internal driver: 32 segments
       Segment external-expansion driver: 256 segments
    - b. Duty cycle: 1/2 Internal driver: 32 segment
       Segment external-expansion driver: 128 segments
    - c. Duty cycle: 1/3 Internal driver: 32 segment
       Segment external-expansion driver: 64 segments
    - d. Duty cycle: 1/4 Internal driver: 32 segment
       Segment external-expansion driver: 64 segments
  - LCD RAM capacity: 8 bits × 32 bytes (256 bits)
  - LCD RAM is word-accessible.
  - All segment output pins can be used as port pins in eight-pin units.
  - Depending on the duty cycle, the common output pins not used can be used for a common double-buffer (parallel connection).
  - Display is possible in all operating modes other than standby mode.
  - Frame frequency can be selected from among 11 values.
  - A power supply split-resistance is built-in, for supply of LCD driver power.
  - Use of module standby mode enables a module to be placed in standby mode independently when not used.
  - An internal step-up constant-voltage (5 V) power supply enables LCD display even at low voltages.
  - A or B waveform can be selected by software.





Figure 2 Block Diagram of LCD Controller/Driver (LCD Display with Static Duty)

3. Functions of the LCD controller/driver are explained in table 1.

## Table 1 LCD Controller/Driver Functions

## LCD port control register (LPCR)

Function LPCR is an 8-bit read/write register which selects the duty cycle, the LCD driver and pin functions. LPCR is initialized to H'00 upon reset.

### LCD control register (LCR)

Function LCR is an 8-bit read/write register which turns the LCD drive power supply on and off, controls display data, and selects the frame frequency. LCR is initialized to H'80 upon reset.

## LCD control register 2 (LCR2)

Function LCR2 is an 8-bit read/write register which controls switching between A and B waveforms, selects the driver power supply, controls the step-up constant-voltage (5 V) power supply, and selects the duty cycle for charge/discharge pulses controlling disconnection of the power supply split-resistance from power supply circuit. LCR2 is initialized to H'60 upon reset.

## Segment output pins (SEG<sub>32</sub> to SEG<sub>1</sub>)

Function These are pins used for LCD segment driving; all these pins are multiplexed as port pins, and their functions can be selected programmably.

## Common output pins ( $COM_4$ to $COM_1$ )

Function These are LCD common driving output pins; under static or 1/2-duty driving, they can be configured in parallel.

## Segment external expansion signal pin (CL<sub>1</sub>)

Function This is a display data latch clock pin which is multiplexed as  $SEG_{y}$ .

## Segment external expansion signal pin (CL<sub>2</sub>)

Function This is a display data shift clock pin which is multiplexed as SEG<sub>31</sub>.

### Segment external expansion signal pin (M)

Function This is an LCD alternation signal pin which is multiplexed as SEG<sub>29</sub>.

### Segment external expansion signal pin (DO)

Function This is a serial display data signal pin which is multiplexed as SEG<sub>30</sub>.

## LCD power supply pins ( $V_0$ to $V_3$ )

Function These pins are used when connecting an external bypass capacitor or when using an external power supply circuit.

## LCD RAM

Function Sets the display data. The relation between the LCD RAM and the display segments differs depending on the duty cycle. After the registers necessary for display have been set, instructions similar to the instructions for normal RAM are used to write data corresponding to the duty, and when the display is turned on, display is started automatically. Word/byte access instructions can be used to set data in the LCD RAM.

4. In this task example, a 16-line 8-character segment LCD is used for display under static driving. Figure 3 is a diagram showing connections for segment signals and common signals of 16-line 8-character segment LCD used in this task example.



Figure 3 Connections of Segment Signals and Common Signals of the 16-Line 8-Character Segment LCD Used in this Task Example



5. Figure 4 shows the LCD RAM mapping under static driving without segment external expansion.

Figure 4 LCD RAM Mapping under Static Driving without Segment External Expansion

6. Figure 5 shows the relation between the 16-line 8-character segment LCD display and LCD RAM settings used in this task example. In this example, the LCD display is cycled through the series pattern 1 → pattern 2 → pattern 3 → pattern 1 →.

| 1. Pattern 1 | 00000 V<br>000 <b>0</b> 0 | 00000          | (1000) (100<br>1000) (100                                                                                    | 000 0000             | 00 00000<br>00 00000000000000000000000000 | V<br>00000<br>00000 | 0000  |       |  |
|--------------|---------------------------|----------------|--------------------------------------------------------------------------------------------------------------|----------------------|-------------------------------------------|---------------------|-------|-------|--|
|              | Bit 7                     | Bit 6          | Bit 5                                                                                                        | Bit 4                | Bit 3                                     | Bit 2               | Bit 1 | Bit 0 |  |
| H'F740       | 0                         | 0              | 0                                                                                                            | 1                    | 0                                         | 0                   | 0     | 1     |  |
| H'F741       | 0                         | 0              | 0                                                                                                            | 1                    | 0                                         | 0                   | 0     | 1     |  |
| H'F742       | 0                         | 0              | 0                                                                                                            | 1                    | 0                                         | 0                   | 0     | 1     |  |
| H'F743       | 0                         | 0              | 0                                                                                                            | 1                    | 0                                         | 0                   | 0     | 1     |  |
| 2. Pattern 2 | V<br>00000<br>00000       | 00000          | ( <u>) () () () () () () () () () () () () ()</u>                                                            |                      | 00000<br>00000                            |                     |       |       |  |
|              | Bit 7                     | Bit 6          | Bit 5                                                                                                        | Bit 4                | Bit 3                                     | Bit 2               | Bit 1 | Bit 0 |  |
| H'F740       | 0                         | 0              | 1                                                                                                            | 0                    | 0                                         | 0                   | 1     | 0     |  |
| H'F741       | 0                         | 0              | 1                                                                                                            | 0                    | 0                                         | 0                   | 1     | 0     |  |
| H'F742       | 0                         | 0              | 1                                                                                                            | 0                    | 0                                         | 0                   | 1     | 0     |  |
| H'F743       | 0                         | 0              | 1                                                                                                            | 0                    | 0                                         | 0                   | 1     | 0     |  |
| 3. Pattern 3 | 00000<br>00000            | 00000          | (1000) (100<br>1000) (100<br>1000) (100                                                                      | 000 0000             |                                           | V<br>00000<br>00000 | 0000  |       |  |
|              | Bit 7                     | Bit 6          | Bit 5                                                                                                        | Bit 4                | Bit 3                                     | Bit 2               | Bit 1 | Bit 0 |  |
| H'F740       | 0                         | 1              | 0                                                                                                            | 0                    | 0                                         | 1                   | 0     | 0     |  |
| H'F741       | 0                         | 1              | 0                                                                                                            | 0                    | 0                                         | 1                   | 0     | 0     |  |
| H'F742       | 0                         | 1              | 0                                                                                                            | 0                    | 0                                         | 1                   | 0     | 0     |  |
| H'F743       | 0                         | 1              | 0                                                                                                            | 0                    | 0                                         | 1                   | 0     | 0     |  |
| 4. Pattern 4 | V<br>00000<br>000000      | 00000<br>00000 | ( <u>)</u><br>( <u>)</u><br>( <u>)</u><br>( <u>)</u><br>( <u>)</u><br>( <u>)</u><br>( <u>)</u><br>( <u>)</u> | 000 0000<br>000 0000 | 00 00000<br>00 00000000000000000000000000 | 00000<br>00000      | 0000  |       |  |
|              | Bit 7                     | Bit 6          | Bit 5                                                                                                        | Bit 4                | Bit 3                                     | Bit 2               | Bit 1 | Bit 0 |  |
| H'F740       | 1                         | 0              | 0                                                                                                            | 0                    | 1                                         | 0                   | 0     | 0     |  |
| H'F741       | 1                         | 0              | 0                                                                                                            | 0                    | 1                                         | 0                   | 0     | 0     |  |
| H'F742       | 1                         | 0              | 0                                                                                                            | 0                    | 1                                         | 0                   | 0     | 0     |  |
| H'F743       | 1                         | 0              | 0                                                                                                            | 0                    | 1                                         | 0                   | 0     | 0     |  |

Figure 5 Relation between LCD Display and LCD RAM Settings

### Rev. 1.0, 08/99, page 41 of 151

7. Figure 6 shows the relation between the LCD RAM addresses and the segments SEG<sub>1</sub> through SEG<sub>8</sub> of the 16-line 8-character segment LCD. As the figure indicates, when the LCD RAM bits corresponding to 0 through 7 are set to 1 the corresponding LCD areas are lit, and when cleared to 0 the corresponding areas are unlit.



Figure 6 Relation between LCD Lit/Unlit States and LCD RAM Settings

8. Table 2 indicates function allocations in this task example.

## Table 2Function Allocations

| Function                              | Function Allocation                                                                                                                                                                                                                                       |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPCR                                  | Selects duty cycle, LCD driver, and pin functions.                                                                                                                                                                                                        |
| LCR                                   | Turns LCD drive power supply on and off, controls display data, and selects frame frequency.                                                                                                                                                              |
| LCR2                                  | Switches between A and B waveforms, selects drive power supply, controls step-up constant-voltage (5 V) power supply, selects duty cycle for charge/discharge pulses to control disconnection of power supply split-resistance from power supply circuit. |
| SEG <sub>32</sub> to SEG <sub>1</sub> | Used as segment drivers.                                                                                                                                                                                                                                  |
| COM                                   | Used as a common driver.                                                                                                                                                                                                                                  |
| V <sub>0</sub> , V <sub>1</sub>       | The V <sub>0</sub> and V <sub>1</sub> pins are shorted in order to use the step-up constant-voltage (5 V) power supply as the LCD drive power supply.                                                                                                     |
| LCD RAM                               | Sets the LCD display data.                                                                                                                                                                                                                                |

# **Explanation of Functions Used**

- 1. Hardware settings for LCD display are explained below.
  - a. LCD drive power supply settings

The H8/3867 Series can use either the internal power supply circuit or an external power supply circuit as the LCD drive power supply. In addition, either the power supply voltage  $(V_{cc})$  or the step-up constant-voltage (5 V) can be selected for the internal power supply circuit.

When using the internal power supply circuit to drive the LCD, the  $V_0$  and  $V_1$  pins are connected externally, as illustrated in figure 7.

In this task example, the step-up constant-voltage power supply is used as the LCD drive power supply.



Figure 7 Example of Connection of LCD Power Supply Pins When Using Internal Power Supply Circuit

## b. Contrast control function

A block diagram of the LCD drive power supply circuit appears in figure 8. Either  $V_{cc}$  or a 5 V output from the step-up constant-voltage power supply circuit is output to pin  $V_0$ . When these voltages are used directly to drive the LCD, the  $V_0$  and  $V_1$  pins should be shorted. By inserting a variable resistance R between the  $V_0$  and  $V_1$  pins, the voltage applied to the  $V_1$  pin can be adjusted, and the LCD panel contrast can be controlled.



Figure 8 Block Diagram of LCD Drive Power Supply Circuit

c. Step-up constant-voltage (5 V) power supply

The H8/3867 Series has an internal step-up constant-voltage (5 V) power supply, supplying a constant 5 V independent of  $V_{\rm cc}$ .

By setting SUPS of the LCD control register 2 (LCR2) to 1, the step-up constant-voltage (5 V) power supply is activated, and a constant 5 V is output to the  $V_0$  pin. This can be used either with pins  $V_0$  and  $V_1$  short-circuited, or with a resistance inserted to divide the voltage.

Note: The step-up constant-voltage (5 V) power supply must not be used for purposes other than to drive the LCD. In addition, when driving a large panel, the power supply capacity may be insufficient. In such cases, either  $V_{cc}$  or an external power supply circuit can be used as the power supply.

Rev. 1.0, 08/99, page 44 of 151

- 2. Software settings for LCD display are explained below.
  - a. Duty selection
     DTS1 and DTS0 are used to select from among static, 1/2 duty, 1/3 duty, and 1/4 duty.
  - b. Segment driver selection
     SGS3 to SGS0 are used to select the segment drivers to be used.
  - c. Frame frequency selection
     By setting CKS3 to CKS0, the frame frequency can be selected. The frame frequency should be selected according to the LCD panel.
  - d. Selection of A and B waveforms
     LCDAB can be used to select either the A or the B waveform for use as the LCD waveform.
  - e. Selection of LCD drive power supply

When using the internal power supply circuit, SUPS can be used to select the power supply to be used. When using an external power supply circuit, SUPS is used to select  $V_{cc}$ , and PSW should be used to turn off the LCD drive power supply.



3. Figure 9 shows the operation principle of this task example.



# **Explanation of Software**

1. Explanation of Modules

Table 3 explains the modules in this task example.

# Table 3Module Explanation

| Module Name  | Label Name | Function                                                                                                        |
|--------------|------------|-----------------------------------------------------------------------------------------------------------------|
| Main routine | MAIN       | Initializes the stack pointer, LCD RAM and LCD controller/driver, enables interrupts, and controls LCD display. |

2. Explanation of Arguments

In this task example, no arguments are used.

3. Explanation of Internal Registers Used

Table 4 gives explanation of the internal registers used in this task example.

| Register Name |               | Description                                                                                                                                                                                                                                                                                                                                                                                        | RAM<br>Address         | Settings             |
|---------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------|
| LPCR          | DTS1,<br>DTS0 | <ul> <li>LCD port control register<br/>(Duty cycle selection 1, 0)</li> <li>Select duty from among static, 1/2 duty, 1/3 duty, and 1/4 duty.</li> <li>When DTS1 = 0 and DTS0 = 0, static duty is selected</li> <li>When DTS1 = 0 and DTS0 = 1, 1/2 duty is selected</li> <li>When DTS1 = 1 and DTS0 = 0, 1/3 duty is selected</li> <li>When DTS1 = 1 and DTS0 = 1, 1/4 duty is selected</li> </ul> | H'FFC0<br>Bit 7, bit 6 | DTS1 = 0<br>DTS0 = 0 |
|               |               |                                                                                                                                                                                                                                                                                                                                                                                                    |                        |                      |

| Register Name |     | Description                                                                                                                                                                                                                                                                                                                    | RAM<br>Address | Settings |
|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|
| LPCR          | CMX | LCD port control register                                                                                                                                                                                                                                                                                                      | H'FFC0         | 0        |
|               |     | (Common function selection)                                                                                                                                                                                                                                                                                                    | Bit 5          |          |
|               |     | Selects whether the same waveform is output from<br>several pins in order to increase the common<br>driving capacity, when common pins are not<br>selected for a given duty cycle.                                                                                                                                             |                |          |
|               |     | <ul> <li>When CMX = 0, the same waveform is not<br/>output from multiple common pins not used at<br/>that duty cycle</li> </ul>                                                                                                                                                                                                |                |          |
|               |     | • When CMX = 1, the same waveform is output from multiple common pins not used at that duty cycle                                                                                                                                                                                                                              |                |          |
| LPCR          | SGX | LCD port control register                                                                                                                                                                                                                                                                                                      | H'FFC0         | 0        |
|               |     | (Expansion signal select)                                                                                                                                                                                                                                                                                                      | Bit 4          |          |
|               |     | Selects whether the SEG <sub>32</sub> /CL <sub>1</sub> , SEG <sub>31</sub> /CL <sub>2</sub> ,<br>SEG <sub>30</sub> /D0, and SEG <sub>29</sub> /M pins are used as segment<br>pins (SEG <sub>32</sub> through SEG <sub>29</sub> ), or as segment<br>external expansion signal pins (CL <sub>1</sub> , CL <sub>2</sub> , D0, M). |                |          |
|               |     | <ul> <li>When SGX = 0, they are used as segment pins<br/>(SEG<sub>32</sub> through SEG<sub>29</sub>)</li> </ul>                                                                                                                                                                                                                |                |          |
|               |     | <ul> <li>When SGX = 1, they are used as segment<br/>external expansion signal pins (CL<sub>1</sub>, CL<sub>2</sub>, D0,<br/>M)</li> </ul>                                                                                                                                                                                      |                |          |

| Register Name |                    | Description                                                                                                                                                                                                                                     | RAM<br>Address           | Settings                         |
|---------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------------|
| LPCR          | SGS3<br>to<br>SGS0 | LCD port control register<br>(Segment driver selection)<br>Select the segment driver to be used.                                                                                                                                                | H'FFC0<br>Bit 3 to bit 0 | SGS3 = 1<br>SGS2 = 0<br>SGS1 = 0 |
|               |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 0, pins SEG<sub>32</sub> through<br/>SEG, function as ports</li> </ul>                                                                                                       |                          | SGS0 = 0                         |
|               |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 1, pins SEG<sub>32</sub> through<br/>SEG, function as ports</li> </ul>                                                                                                       |                          |                                  |
|               |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 1 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>25</sub> function as segment drivers and pins<br/>SEG<sub>24</sub> through SEG<sub>1</sub> function as ports</li> </ul>         |                          |                                  |
|               |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 1,<br/>SGS1 = 0 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>17</sub> function as segment drivers and pins<br/>SEG<sub>16</sub> through SEG<sub>1</sub> function as ports</li> </ul>         |                          |                                  |
|               |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 1,<br/>SGS1 = 1 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>9</sub> function as segment drivers and pins<br/>SEG<sub>8</sub> through SEG<sub>1</sub> function as ports</li> </ul>           |                          |                                  |
|               |                    | <ul> <li>When SGX = 0, SGS3 = 1, SGS2 = *,<br/>SGS1 = * and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>1</sub> function as segment drivers</li> </ul>                                                                                  |                          |                                  |
|               |                    | <ul> <li>When SGX = 1, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 0, pins SEG<sub>32</sub> through<br/>SEG<sub>29</sub> function as external expansion pins and<br/>pins SEG<sub>28</sub> through SEG<sub>1</sub> function as ports</li> </ul> |                          |                                  |
|               |                    | • SGX = 1, SGS3 = *, SGS2 = *, SGS1 = * and<br>SGS0 = * cannot be specified                                                                                                                                                                     |                          |                                  |
|               |                    | *: Don't care                                                                                                                                                                                                                                   |                          |                                  |

| Register | Name | Description                                                                                                                                                                                                                                                         | RAM<br>Address  | Settings |
|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|
| LCR      | PSW  | LCD control register<br>(LCD drive power supply on/off control)                                                                                                                                                                                                     | H'FFC1<br>Bit 6 | 1        |
|          |      | Turns the LCD drive power supply off when LCD display is not used in power-down mode, or when an external power supply is used. When the ACT bit is cleared to 0, or when in standby mode, the LCD drive power supply is turned off regardless of this bit setting. |                 |          |
|          |      | • When PSW = 0, the LCD drive power supply is turned off                                                                                                                                                                                                            |                 |          |
|          |      | • When PSW = 1, the LCD drive power supply is turned on                                                                                                                                                                                                             |                 |          |
| LCR      | ACT  | LCD control register<br>(Display function activate)                                                                                                                                                                                                                 | H'FFC1          | 1        |
|          |      | Selects whether the LCD controller/driver is to be<br>used or not. By clearing this bit to 0, LCD<br>controller/driver operation is halted. Also,<br>regardless of the value of PSW, the LCD drive<br>power supply is turned off.                                   | Bit 5           |          |
|          |      | However, the register contents are maintained.                                                                                                                                                                                                                      |                 |          |
|          |      | • When ACT = 0, LCD controller/driver operation<br>is halted                                                                                                                                                                                                        |                 |          |
|          |      | • When ACT = 1, LCD controller/driver operations                                                                                                                                                                                                                    |                 |          |
| LCR      | DISP | <ul> <li>LCD control register<br/>(Display data control)</li> <li>DISP selects whether the LCD RAM contents or<br/>blank data are to be displayed.</li> <li>When DISP = 0, blank data is displayed</li> </ul>                                                       | H'FFC1<br>Bit 4 | 1        |
|          |      | <ul> <li>vvnen DISP = 1, LCD RAM data is displayed</li> </ul>                                                                                                                                                                                                       |                 |          |

| Registe | er Name    | Description                                                                                                            | RAM<br>Address | Settings                         |
|---------|------------|------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------|
| LCR     | CKS3       | LCD control register                                                                                                   | H'FFC1         | CKS3 = 1                         |
|         | to<br>CKS0 | (Frame frequency select 3 to 0)<br>Select the operating clock and the frame<br>frequency.                              | Bit 3 to bit 0 | CKS2 = 1<br>CKS1 = 1<br>CKS0 = 0 |
|         |            | • When CKS3 = 0, CKS2 = *, CKS1 = 0 and CKS0 = 0, $\phi_w$ is selected as operating clock                              |                |                                  |
|         |            | • When CKS3 = 0, CKS2 = *, CKS1 = 0 and CKS0 = 1, $\phi_{\rm w}/2$ is selected as operating clock                      |                |                                  |
|         |            | <ul> <li>When CKS3 = 0, CKS2 = *, CKS1 = 1 and<br/>CKS0 = *, φ<sub>w</sub>/4 is selected as operating clock</li> </ul> |                |                                  |
|         |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 0 and<br/>CKS0 = 0, φ/2 is selected as operating clock</li> </ul>             |                |                                  |
|         |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 0 and<br/>CKS0 = 1, φ/4 is selected as operating clock</li> </ul>             |                |                                  |
|         |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 1 and<br/>CKS0 = 0, φ/8 is selected as operating clock</li> </ul>             |                |                                  |
|         |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 1 and<br/>CKS0 = 1, φ/16 is selected as operating clock</li> </ul>            |                |                                  |
|         |            | • When CKS3 = 1, CKS2 = 1, CKS1 = 0 and CKS0 = 0, $\phi$ /32 is selected as operating clock                            |                |                                  |
|         |            | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 0 and<br/>CKS0 = 1, φ/64 is selected as operating clock</li> </ul>            |                |                                  |
|         |            | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 1 and<br/>CKS0 = 0, φ/128 is selected as operating clock</li> </ul>           | ζ.             |                                  |
|         |            | • When CKS3 = 1, CKS2 = 1, CKS1 = 1 and CKS0 = 1, $\phi$ /256 is selected as operating clock                           | (              |                                  |
|         |            | *: Don't care                                                                                                          |                |                                  |

| Register | Name  | Description                                                                                                                                                                                                                                     | RAM<br>Address | Settings |
|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|
| LCR2 LC  | LCDAB | LCD control register 2                                                                                                                                                                                                                          | H'FFC2         | 0        |
|          |       | (A waveform/B waveform switching control)                                                                                                                                                                                                       | Bit 7          |          |
|          |       | Selects whether the A or B waveform is to be used for LCD driving.                                                                                                                                                                              |                |          |
|          |       | • When LCDAB = 0, the LCD is driven using the<br>A waveform                                                                                                                                                                                     |                |          |
|          |       | • When LCDAB = 1, the LCD is driven using the<br>B waveform                                                                                                                                                                                     |                |          |
| LCR2     | SUPS  | LCD control register 2                                                                                                                                                                                                                          | H'FFC2         | 1        |
|          |       | (Drive power supply select, step-up constant-<br>voltage (5 V) power supply control)                                                                                                                                                            | Bit 4          |          |
|          |       | When $V_{cc}$ is selected as the drive power supply,<br>the step-up constant-voltage (5 V) power supply<br>operation is halted; when 5 V is selected as the<br>drive power supply, the step-up constant-voltage<br>(5 V) power supply operates. |                |          |
|          |       | • When SUPS = 0, the drive power supply is V <sub>cc</sub> ,<br>and the step-up constant-voltage (5 V) power<br>supply operation is halted                                                                                                      |                |          |
|          |       | <ul> <li>When SUPS = 1, the drive power supply is 5 V,<br/>and the step-up constant-voltage (5 V) power<br/>supply operates</li> </ul>                                                                                                          |                |          |

| Register Name       |                    | Description                                                                                                                                                                                                                                                           | RAM<br>Address           | Settings                                     |
|---------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------------------------|
| LCR2 CE<br>to<br>CE | CDS3<br>to<br>CDS0 | LCD control register 2<br>(Charge/discharge pulse duty cycle select 3 to 0)<br>Select the duty cycle while the power supply split-<br>resistance is connected to the power supply circuit.<br>When CDS3 = 0, CDS2 = 0, CDS1 = 0 and CDS0<br>= 0, the duty cycle is 1. | H'FFC2<br>Bit 3 to bit 0 | CDS3 = 0<br>CDS2 = 0<br>CDS1 = 0<br>CDS0 = 0 |
|                     |                    | <ul> <li>When CDS3 = 0, CDS2 = 0, CDS1 = 0 and<br/>CDS0 = 1, the duty cycle is 1/8</li> <li>When CDS3 = 0, CDS2 = 0, CDS1 = 1 and</li> </ul>                                                                                                                          |                          |                                              |
|                     |                    | <ul> <li>CDS0 = 0, the duty cycle is 2/8</li> <li>When CDS3 = 0, CDS2 = 0, CDS1 = 1 and CDS0 = 1, the duty cycle is 3/8</li> </ul>                                                                                                                                    |                          |                                              |
|                     |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 0 and<br>CDS0 = 0, the duty cycle is 4/8                                                                                                                                                                                            |                          |                                              |
|                     |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 0 and CDS0 = 1, the duty cycle is 5/8                                                                                                                                                                                               |                          |                                              |
|                     |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 1 and<br>CDS0 = 0, the duty cycle is 6/8                                                                                                                                                                                            |                          |                                              |
|                     |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 1 and<br>CDS0 = 1, the duty cycle is 0                                                                                                                                                                                              |                          |                                              |
|                     |                    | <ul> <li>When CDS3 = 1, CDS2 = 0, CDS1 = * and<br/>CDS0 = *, the duty cycle is 1/16</li> </ul>                                                                                                                                                                        |                          |                                              |
|                     |                    | • When CDS3 = 1, CDS2 = 1, CDS1 = * and<br>CDS0 = *, the duty cycle is 1/32                                                                                                                                                                                           |                          |                                              |
|                     |                    | *: Don't care                                                                                                                                                                                                                                                         |                          |                                              |

# 4. Explanation of RAM Usage

In this task example, RAM is not used.

# Flowchart

1. Main routine



### **Program Lists**

```
;*
   H8/3867 Application Note
;*
; *
    'Liquid Crystal Display
    -Static Drive, Internal Driver-'
;*
;*
        Function : LCD Controller / Driver
;*
;*
        External Clock : 6MHz
;*
        Internal Clock : 3MHz
;*
        Sub Clock : 32.768kHz
;*
;
    .cpu 3001
;
;*
     Symbol Defnition
;
LPCR .equ h'ffc0 ;LCD Port Control Register
LCR .equ h'ffc1 ;LCD Control Register
LCR2 .equ h'ffc2 ;LCD Control Register 2
;
; *
    Vector Address
;
     .org h'0000
     .data.w MAIN ;No.0 Reset Interrupt(H'0000-H'0001)
;
          h'0008
     .org
                   ;No.4 _IRQ0 Interrupt(H'0008-H'0009)
     .data.w
          MAIN
     .data.w MAIN
                   ;No.5 _IRQ1 Interrupt(H'000A-H'000B)
                   ;No.6 _IRQ2 Interrupt(H'000C-H'000D)
     .data.w MAIN
                   ;No.7 _IRQ3 Interrupt(H'000E-H'000F)
     .data.w MAIN
                   ;No.8 _IRQ4 Interrupt(H'0010-H'0011)
     .data.w
          MAIN
```

Rev. 1.0, 08/99, page 55 of 151

|        | .data.w    | MAIN                      | ;No.9 _WKP0WKP7 Interrupt(H'0012-H'0013)        |
|--------|------------|---------------------------|-------------------------------------------------|
| ;      |            |                           |                                                 |
|        | .org       | h'0016                    |                                                 |
|        | .data.w    | MAIN                      | ;No.11 Timer A Interrupt(H'0016-H'0017)         |
|        | .data.w    | MAIN                      | ;No.12 AEC Interrupt(H'0018-H'0019)             |
|        | .data.w    | MAIN                      | ;No.13 Timer C Interrupt(H'001A-H'001B)         |
|        | .data.w    | MAIN                      | ;No.14 Timer FL Interrupt(H'001C-H'001D)        |
|        | .data.w    | MAIN                      | ;No.15 Timer FH Interrupt(H'001E-H'001F)        |
|        | .data.w    | MAIN                      | ;No.16 Timer G Interrupt(H'0020-H'0021)         |
|        | .data.w    | MAIN                      | ;No.17 SCI31 Interrupt(H'0022-H'0023)           |
|        | .data.w    | MAIN                      | ;No.18 SCI32 Interrupt(H'0024-H'0025)           |
|        | .data.w    | MAIN                      | ;No.19 A/D Converter Interrupt(H'0026-H'0028)   |
|        | .data.w    | MAIN                      | ;No.20 Direct Transfer Interrupt(H'0028-H'0029) |
| ;      |            |                           |                                                 |
| ;***** | *******    | * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * *         |
| ;*     | MAIN : Mai | in Routine                |                                                 |
| ;***** | *******    | * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * *         |
| ;      |            |                           |                                                 |
|        | .org       | h'1000                    |                                                 |
| ;      |            |                           |                                                 |
| MAIN:  | .equ       | \$                        |                                                 |
|        | mov.w      | #h'ff80,sp                | ;Initialize Stack Pointer                       |
|        | orc        | #h'80,ccr                 | ;Interrupt Disable                              |
| ;      |            |                           |                                                 |
|        | mov.w      | #h'0000,r0                | ;Initialize LCD RAM                             |
|        | mov.w      | r0,@(h'f740)              |                                                 |
|        | mov.w      | r0,@(h'f742)              |                                                 |
| ;      |            |                           |                                                 |
|        | mov.b      | #h'08,r01                 | ;Initialize LCD Controller/Driver               |
|        | mov.b      | r01,@LPCR                 |                                                 |
|        | mov.b      | <pre>#h'fe,r01</pre>      |                                                 |
|        | mov.b      | r01,@LCR                  |                                                 |
|        | mov.b      | #h'70,r01                 |                                                 |
|        | mov.b      | r0l,@LCR2                 |                                                 |
| ;      |            |                           |                                                 |
|        | andc       | #h'7f,ccr                 | ;Interrupt REnable                              |
| ;      |            |                           |                                                 |

|         | mov.w | #h'1111,r0   | ;Set | LCD  | RAM   |        |      |
|---------|-------|--------------|------|------|-------|--------|------|
| MAIN99: | mov.w | r0,@(h'f740) |      |      |       |        |      |
|         | mov.w | r0,@(h'f742) |      |      |       |        |      |
| ;       |       |              |      |      |       |        |      |
|         | sub.w | r1,r1        | ;Set | Soft | tware | Timer  |      |
|         | sub.w | r2,r2        |      |      |       |        |      |
|         | mov.w | #h'0005,r3   |      |      |       |        |      |
| INC:    | adds  | #1,r1        |      |      |       |        |      |
|         | mov.w | r1,r1        |      |      |       |        |      |
|         | bne   | INC          |      |      |       |        |      |
| ;       |       |              |      |      |       |        |      |
|         | adds  | #1,r2        |      |      |       |        |      |
|         | cmp.w | r2,r3        |      |      |       |        |      |
|         | bne   | INC          |      |      |       |        |      |
| ;       |       |              |      |      |       |        |      |
|         | rotl  | r0h          | ;Dis | play | Data  | Rotate | Left |
|         | rotl  | rOl          |      |      |       |        |      |
| ;       |       |              |      |      |       |        |      |
|         | bra   | MAIN99       |      |      |       |        |      |
| ;       |       |              |      |      |       |        |      |
|         | ,     |              |      |      |       |        |      |

.end

# 2.4 LCD Display with 1/4 Duty

| LCD Display with 1/4 Duty | MCU:           | Functions Used:       |
|---------------------------|----------------|-----------------------|
|                           | H8/3867 Series | LCD Controller/Driver |

# Specifications

- 1. LCD display is performed using the segment-type LCD controller circuit, LCD driver, and power supply circuit of the H8/3867 Series.
- 2. Four common signals and 32 segment signals are used for LCD display with 1/4 duty.
- 3. As the power supply driving the LCD, a step-up constant-voltage power supply (5 V) is used.
- 4. An example of LCD module connection and an LCD display example for this task example appear in figure 1.



Figure 1 LCD Display Example

# **Explanation of Functions Used**

- 1. In this task example, the LCD controller/driver is used for LCD display. The features of the LCD controller/driver are described below.
  - Display capacity
    - a. Duty cycle: static Internal driver: 32 segments Segment external-expansion driver: 256 segments
    - b. Duty cycle: 1/2 Internal driver: 32 segment
       Segment external-expansion driver: 128 segments
    - c. Duty cycle: 1/3 Internal driver: 32 segment
       Segment external-expansion driver: 64 segments
    - d. Duty cycle: 1/4 Internal driver: 32 segment
       Segment external-expansion driver: 64 segments
  - LCD RAM capacity: 8 bits × 32 bytes (256 bits)
  - LCD RAM is word-accessible.
  - All segment output pins can be used as port pins in eight-pin units.
  - Depending on the duty cycle, the common output pins not used can be used for a common double-buffer (parallel connection).
  - Display is possible in all operating modes other than standby mode.
  - Frame frequency can be selected from among 11 values.
  - A power supply split-resistance is built-in, for supply of LCD driver power.
  - Use of module standby mode enables a module to be placed in standby mode independently when not used.
  - An internal step-up constant-voltage (5 V) power supply enables LCD display even at low voltages.
  - A or B waveform can be selected by software.

2. Figure 2 is a block diagram of the LCD controller/driver used in this task examples.



Figure 2 Block Diagram of LCD Controller/Driver (LCD Display with 1/4 Duty)

3. Functions of the LCD controller/driver are explained in table 1.

## Table 1 LCD Controller/Driver Functions

## LCD port control register (LPCR)

Function LPCR is an 8-bit read/write register which selects the duty cycle, the LCD driver and pin functions. LPCR is initialized to H'00 upon reset.

### LCD control register (LCR)

Function LCR is an 8-bit read/write register which turns the LCD drive power supply on and off, controls display data, and selects the frame frequency. LCR is initialized to H'80 upon reset.

### LCD control register 2 (LCR2)

Function LCR2 is an 8-bit read/write register which controls switching between A and B waveforms, selects the driver power supply, controls the step-up constant-voltage (5 V) power supply, and selects the duty cycle for charge/discharge pulses controlling disconnection of the power supply split-resistance from power supply circuit. LCR2 is initialized to H'60 upon reset.

### Segment output pins (SEG<sub>32</sub> to SEG<sub>1</sub>)

Function These are pins used for LCD segment driving; all these pins are multiplexed as port pins, and their functions can be selected programmably.

### Common output pins (COM<sub>4</sub> to COM<sub>1</sub>)

Function These are LCD common driving output pins; under static or 1/2-duty driving, they can be configured in parallel.

### Segment external expansion signal pin (CL,)

Function This is a display data latch clock pin which is multiplexed as SEG<sub>32</sub>.

### Segment external expansion signal pin (CL<sub>2</sub>)

Function This is a display data shift clock pin which is multiplexed as SEG<sub>31</sub>.

### Segment external expansion signal pin (M)

Function This is an LCD alternation signal pin which is multiplexed as SEG<sub>20</sub>.

#### Segment external expansion signal pin (DO)

Function This is a serial display data signal pin which is multiplexed as SEG<sub>30</sub>.

### LCD power supply pins ( $V_0$ to $V_3$ )

Function These pins are used when connecting an external bypass capacitor or when using an external power supply circuit.

## LCD RAM

Function Sets the display data. The relation between the LCD RAM and the display segments differs depending on the duty cycle. After the registers necessary for display have been set, instructions similar to the instructions for normal RAM are used to write data corresponding to the duty, and when the display is turned on, display is started automatically. Word/byte access instructions can be used to set data in the LCD RAM.

4. In this task example, a 16-line 8-character segment LCD is used for display with 1/4 duty driving. Figure 3 is a diagram showing connections for segment signals and common signals of the 16-line 8-character segment LCD used in this task example.



Figure 3 Connections of Segment Signals and Common Signals of the 16-Line 8-Character Segment LCD Used in this Task Example

5. Figure 4 shows the LCD RAM mapping under 1/4 duty driving without segment external expansion.

| H'F740<br>H'F741 | SEG₂<br>SEG₄      | SEG₂<br>SEG₄      | SEG₂<br>SEG₄      | SEG₂<br>SEG₄      | SEG <sub>1</sub><br>SEG <sub>2</sub> | SEG <sub>1</sub><br>SEG <sub>2</sub> | SEG <sub>1</sub><br>SEG <sub>2</sub> | SEG <sub>1</sub><br>SEG₂ |
|------------------|-------------------|-------------------|-------------------|-------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------|
| H'F742           | SEG <sub>6</sub>  | SEG <sub>6</sub>  | SEG <sub>6</sub>  | SEG <sub>6</sub>  | SEG <sub>5</sub>                     | SEG <sub>5</sub>                     | SEG <sub>5</sub>                     | SEG <sub>5</sub>         |
| H'F743           | SEG <sub>8</sub>  | SEG <sub>8</sub>  | SEG <sub>8</sub>  | SEG <sub>8</sub>  | SEG7                                 | SEG7                                 | SEG7                                 | SEG7                     |
| H'F745           | SEG <sub>10</sub> | SEG <sub>10</sub> | SEG <sub>10</sub> | SEG <sub>10</sub> | SEG <sub>11</sub>                    | SEG <sub>11</sub>                    | SEG <sub>11</sub>                    | SEG <sub>11</sub>        |
| H'F746           | SEG <sub>14</sub> | SEG <sub>14</sub> | SEG <sub>14</sub> | SEG <sub>14</sub> | SEG <sub>13</sub>                    | SEG <sub>13</sub>                    | SEG <sub>13</sub>                    | SEG <sub>13</sub>        |
| H'F747           | SEG <sub>16</sub> | SEG <sub>16</sub> | SEG <sub>16</sub> | SEG <sub>16</sub> | SEG <sub>15</sub>                    | SEG <sub>15</sub>                    | SEG <sub>15</sub>                    | SEG <sub>15</sub>        |
| H'F748           | SEG <sub>18</sub> | SEG <sub>18</sub> | SEG <sub>18</sub> | SEG <sub>18</sub> | SEG <sub>17</sub>                    | SEG <sub>17</sub>                    | SEG <sub>17</sub>                    | SEG <sub>17</sub>        |
| H'F749           | SEG <sub>20</sub> | SEG <sub>20</sub> | SEG <sub>20</sub> | SEG <sub>20</sub> | SEG <sub>19</sub>                    | SEG <sub>19</sub>                    | SEG <sub>19</sub>                    | SEG <sub>19</sub>        |
| H'F74A           | SEG <sub>22</sub> | SEG <sub>22</sub> | SEG <sub>22</sub> | SEG <sub>22</sub> | SEG <sub>21</sub>                    | SEG <sub>21</sub>                    | SEG <sub>21</sub>                    | SEG <sub>21</sub>        |
| H'F74B           | SEG <sub>24</sub> | SEG <sub>24</sub> | SEG <sub>24</sub> | SEG <sub>24</sub> | SEG <sub>23</sub>                    | SEG <sub>23</sub>                    | SEG <sub>23</sub>                    | SEG <sub>23</sub>        |
| H'F74C           | SEG <sub>26</sub> | SEG <sub>26</sub> | SEG <sub>26</sub> | SEG <sub>26</sub> | SEG <sub>25</sub>                    | SEG <sub>25</sub>                    | SEG <sub>25</sub>                    | SEG <sub>25</sub>        |
| H'F74D           | SEG <sub>28</sub> | SEG <sub>28</sub> | SEG <sub>28</sub> | SEG <sub>28</sub> | SEG <sub>27</sub>                    | SEG <sub>27</sub>                    | SEG <sub>27</sub>                    | SEG <sub>27</sub>        |
| H'F74E           | SEG <sub>30</sub> | SEG <sub>30</sub> | SEG <sub>30</sub> | SEG <sub>30</sub> | SEG <sub>29</sub>                    | SEG <sub>29</sub>                    | SEG <sub>29</sub>                    | SEG <sub>29</sub>        |
| H'F74F           | SEG <sub>32</sub> | SEG <sub>32</sub> | SEG <sub>32</sub> | SEG <sub>32</sub> | SEG <sub>31</sub>                    | SEG <sub>31</sub>                    | SEG <sub>31</sub>                    | SEG <sub>31</sub>        |
|                  | ↓ I               | ↓                 | ↓<br>↓            | ↓<br>↓            | ↓ I                                  | ↓                                    | ↓<br>↓                               | ↓<br>↓                   |
|                  | $COM_4$           | COM <sub>3</sub>  | $COM_2$           | COM <sub>1</sub>  | $COM_4$                              | COM <sub>3</sub>                     | $COM_2$                              | COM <sub>1</sub>         |

Figure 4 LCD RAM Mapping under 1/4 Duty Driving without Segment External Expansion

6. Figure 5 shows the relation between the 16-line 8-character segment LCD display and LCD RAM settings used in this task example. As shown in the figure, by setting the LCD RAM appropriately, "H8/3867" is displayed on the 16-line 8-character segment LCD.

|                                                  |       |       |       | ) 0000 |       |       | V     | ▼<br>()0000<br>()0000<br>()0000 |              |
|--------------------------------------------------|-------|-------|-------|--------|-------|-------|-------|---------------------------------|--------------|
|                                                  | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0                           |              |
| H'F740                                           | 0     | 1     | 1     | 0      | 0     | 0     | 1     | 0                               | Display data |
| H'F741                                           | 0     | 1     | 0     | 0      | 0     | 1     | 1     | 0                               | for "H"      |
| H'F742                                           | 0     | 1     | 1     | 1      | 0     | 0     | 1     | 0                               | Display data |
| H'F743                                           | 0     | 1     | 0     | 0      | 1     | 1     | 1     | 0                               | for "8"      |
| H'F744                                           | 0     | 0     | 0     | 0      | 0     | 1     | 0     | 0                               | Display data |
| H'F745                                           | 0     | 0     | 1     | 0      | 0     | 0     | 0     | 0                               | for "/"      |
| H'F746                                           | 0     | 0     | 0     | 1      | 0     | 0     | 1     | 0                               | Display data |
| H'F747                                           | 0     | 1     | 0     | 0      | 1     | 1     | 1     | 0                               | for "3"      |
| H'F748                                           | 0     | 1     | 1     | 1      | 0     | 0     | 1     | 0                               | Display data |
| H'F749                                           | 0     | 1     | 0     | 0      | 1     | 1     | 1     | 0                               | for "8"      |
| H'F74A                                           | 0     | 1     | 1     | 1      | 0     | 0     | 1     | 0                               | Display data |
| H'F74B                                           | 0     | 1     | 0     | 0      | 1     | 0     | 1     | 0                               | for "6"      |
| H'F74C                                           | 0     | 1     | 0     | 0      | 0     | 0     | 0     | 0                               | Display data |
| H'F74D                                           | 0     | 0     | 0     | 0      | 1     | 1     | 1     | 0                               | for "7"      |
| H'F74E                                           | 0     | 0     | 0     | 0      | 0     | 0     | 0     | 0                               | Display data |
| H'F74F                                           | 0     | 0     | 0     | 0      | 0     | 0     | 0     | 0                               | for ""*      |
| Note: *: " " denotes a blank (nothing displayed) |       |       |       |        |       |       |       |                                 |              |

Figure 5 Relation between LCD Display and LCD RAM Settings

7. Figure 6 shows the relation between the display of the eighth column from the right in the 16-line 8-character segment LCD and the LCD RAM corresponding to SEG<sub>1</sub> through SEG<sub>4</sub>. As indicated in figure 6, when the LCD RAM bits corresponding to 0 through f are set to 1, the LCD regions are lit; when they are cleared to 0, the LCD regions are unlit.



Figure 6 Relation between LCD Lit/Unlit States and Corresponding LCD RAM Settings
8. Table 2 shows examples of SEG<sub>1</sub> through SEG<sub>4</sub> display and display data for a 16-line 8-character segment LCD.

| Symbol | Display        | Address | Display Data |   |   | Symbol | Display | Address |   | Display Data |      |                                          |        |   |   |   |   |   |   |   |   |
|--------|----------------|---------|--------------|---|---|--------|---------|---------|---|--------------|------|------------------------------------------|--------|---|---|---|---|---|---|---|---|
|        | 00000          | H'F740  | 0            | 0 | 0 | 0      | 0       | 0       | 0 | 0            | 0    | V <u>000</u> 0                           | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|        | 0200.          | H'F741  | 0            | 0 | 0 | 0      | 0       | 0       | 0 | 0            | G    | 1 <u>000</u>                             | H'F741 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| *      | VONO           | H'F740  | 0            | 0 | 0 | 0      | 1       | 1       | 1 | 1            | ц    | V NOZ                                    | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |
|        | 0200.          | H'F741  | 1            | 1 | 1 | 1      | 0       | 0       | 0 | 0            |      |                                          | H'F741 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 |
| _      | V0000          | H'F740  | 0            | 0 | 0 | 0      | 0       | 0       | 1 | 0            |      | 0000                                     | H'F740 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
|        | 0 <u>000</u> 0 | H'F741  | 0            | 1 | 0 | 0      | 0       | 0       | 0 | 0            | I    | 0200                                     | H'F741 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| /      | 00000          | H'F740  | 0            | 0 | 0 | 0      | 0       | 1       | 0 | 0            |      | 0000                                     | H'F740 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 |
| /      | 0000.          | H'F741  | 0            | 0 | 1 | 0      | 0       | 0       | 0 | 0            | 5    |                                          | H'F741 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| 0      | <b>V</b>       | H'F740  | 0            | 1 | 1 | 1      | 0       | 1       | 0 | 0            | ĸ    |                                          | H'F740 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 |
| Ū      |                | H'F741  | 0            | 0 | 1 | 0      | 1       | 1       | 1 | 0            | L L  |                                          | H'F741 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1      | 0000           | H'F740  | 0            | 0 | 0 | 0      | 0       | 0       | 0 | 0            |      | 10000                                    | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
|        | 0200           | H'F741  | 0            | 0 | 0 | 0      | 0       | 1       | 1 | 0            |      | <u>000</u> 0                             | H'F741 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 2      | 0000           | H'F740  | 0            | 0 | 1 | 1      | 0       | 0       | 1 | 0            | 5.4  | Ĭ                                        | H'F740 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |
| 2      |                | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 0 | 0            | IVI  | <u>200</u>                               | H'F741 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 3      | 0000           | H'F740  | 0            | 0 | 0 | 1      | 0       | 0       | 1 | 0            | NI   | V NO2                                    | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
|        | 0200           | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 0 | 0            |      | <u>200</u>                               | H'F741 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 1      | V NOZ          | H'F740  | 0            | 1 | 0 | 0      | 0       | 0       | 1 | 0            | 0    | V 102                                    | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
|        | 0200           | H'F741  | 0            | 1 | 0 | 0      | 0       | 1       | 1 | 0            |      | <u>1000</u>                              | H'F741 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
| 5      | V <u>000</u> 0 | H'F740  | 0            | 1 | 0 | 1      | 0       | 0       | 1 | 0            | Б    | V 1000                                   | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |
|        | 0200           | H'F741  | 0            | 1 | 0 | 0      | 1       | 0       | 1 | 0            |      | <u>200</u> 0                             | H'F741 | 0 | 1 | 0 | 0 | 1 | 1 | 9 | 0 |
| 6      | V <u>000</u> 0 | H'F740  | 0            | 1 | 1 | 1      | 0       | 0       | 1 | 0            | 0    | V NOZI                                   | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 9 | 1 |
|        |                | H'F741  | 0            | 1 | 0 | 0      | 0       | 0       | 1 | 0            |      | <u>100</u>                               | H'F741 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
| 7      | V 002          | H'F740  | 0            | 1 | 0 | 0      | 0       | 0       | 0 | 0            | Б    | V NOZ                                    | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 |
| '      | 000            | H'F741  | 0            | 0 | 0 | 0      | 1       | 1       | 1 | 0            | R    | <u>201</u> 0                             | H'F741 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| ß      | V 1000         | H'F740  | 0            | 1 | 1 | 1      | 0       | 0       | 1 | 0            |      | 0000                                     | H'F740 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|        |                | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 1 | 0            | 3    | 02000                                    | H'F741 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| ٥      | V NOZ          | H'F740  | 0            | 1 | 0 | 0      | 0       | 0       | 1 | 0            | - T  | 00000                                    | H'F740 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 5      | 0200           | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 1 | 0            |      | 0200                                     | H'F741 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| Δ      | V NOZ          | H'F740  | 0            | 1 | 1 | 0      | 0       | 0       | 1 | 0            |      | V NOZI                                   | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
|        | 200            | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 1 | 0            |      | <u>1000</u>                              | H'F741 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| в      | V 0000         | H'F740  | 0            | 0 | 0 | 1      | 1       | 1       | 0 | 0            | V    | V NOLO                                   | H'F740 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |
|        | <u> </u>       | H'F741  | 0            | 0 | 0 | 1      | 1       | 1       | 1 | 0            |      | ĬŌ.                                      | H'F741 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| C      | V <u>00</u> 0  | H'F740  | 0            | 1 | 1 | 1      | 0       | 0       | 0 | 0            | 14/  | V NOZ                                    | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
|        | <u>indi</u>    | H'F741  | 0            | 0 | 0 | 0      | 1       | 0       | 0 | 0            | l vv | <u>M</u>                                 | H'F741 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 |
|        | V0000          | H'F740  | 0            | 0 | 0 | 1      | 1       | 0       | 0 | 0            | v    | VONOLO                                   | H'F740 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |
|        | <u>M</u>       | H'F741  | 0            | 0 | 0 | 1      | 1       | 1       | 1 | 0            |      | <u>M</u>                                 | H'F741 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
|        | V 0000         | H'F740  | 0            | 1 | 1 | 1      | 0       | 0       | 1 | 0            | V    | V () () () () () () () () () () () () () | H'F740 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
|        |                | H'F741  | 0            | 1 | 0 | 0      | 1       | 0       | 0 | 0            | Y    | ĬŽÍŠÍ.                                   | H'F741 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| F      | V 0000         | H'F740  | 0            | 1 | 1 | 0      | 0       | 0       | 1 | 0            | _    | 00000                                    | H'F740 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 |
|        |                | H'F741  | 0            | 1 | 0 | 0      | 1       | 0       | 0 | 0            |      | <u>ČČČČ</u>                              | H'F741 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 |

## Table 2Display Data Examples

9. Table 3 indicates function allocations in this task example.

| Function                              | Function Allocation                                                                                                                                                                                                                                       |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPCR                                  | Selects duty cycle, LCD driver, and pin functions.                                                                                                                                                                                                        |
| LCR                                   | Turns LCD drive power supply on and off, controls display data, and selects frame frequency.                                                                                                                                                              |
| LCR2                                  | Switches between A and B waveforms, selects drive power supply, controls step-up constant-voltage (5 V) power supply, selects duty cycle for charge/discharge pulses to control disconnection of power supply split-resistance from power supply circuit. |
| SEG <sub>32</sub> to SEG <sub>1</sub> | Used as segment drivers.                                                                                                                                                                                                                                  |
| COM <sub>4</sub> to COM <sub>1</sub>  | Used as common drivers.                                                                                                                                                                                                                                   |
| V <sub>0</sub> , V <sub>1</sub>       | The V <sub>0</sub> and V <sub>1</sub> pins are shorted in order to use the step-up constant-voltage (5 V) power supply as the LCD drive power supply.                                                                                                     |
| LCD RAM                               | Sets the LCD display data.                                                                                                                                                                                                                                |

Table 3Function Allocations

## **Explanation of Functions Used**

- 1. Hardware settings for LCD display are explained below.
  - a. LCD drive power supply settings

The H8/3867 Series can use either the internal power supply circuit or can use an external power supply circuit as the LCD drive power supply. In addition, either the power supply voltage ( $V_{cc}$ ) or the step-up constant-voltage (5 V) can be selected for the internal power supply circuit.

When using the internal power supply circuit to drive the LCD, the  $V_0$  and  $V_1$  pins are connected externally, as illustrated in figure 7.

In this task example, the step-up constant-voltage power supply is used as the LCD drive power supply.



Figure 7 Example of Connection of LCD Power Supply Pins When Using Internal Power Supply Circuit

### b. Contrast control function

A block diagram of the LCD drive power supply circuit appears in figure 8. Either  $V_{cc}$  or a 5 V output from the step-up constant-voltage power supply circuit is output to pin  $V_0$ . When these voltages are used directly to drive the LCD, the  $V_0$  and  $V_1$  pins should be shorted. By inserting a variable resistance R between the  $V_0$  and  $V_1$  pins, the voltage applied to the  $V_1$  pin can be adjusted, and the LCD panel contrast can be controlled.



Figure 8 Block Diagram of LCD Drive Power Supply Circuit

c. Step-up constant-voltage (5 V) power supply

The H8/3867 Series has an internal step-up constant-voltage (5 V) power supply, supplying a constant 5 V independent of  $V_{\rm cc}$ .

By setting SUPS of the LCD control register 2 (LCR2) to 1, the step-up constant-voltage (5 V) power supply is activated, and a constant 5 V is output to the  $V_0$  pin. This can be used either with pins  $V_0$  and  $V_1$  short-circuited, or with a resistance inserted to divide the voltage.

Note: The step-up constant-voltage (5 V) power supply must not be used for purposes other than to drive the LCD. In addition, when driving a large panel, the power supply capacity may be insufficient. In such cases, either  $V_{cc}$  or an external power supply circuit can be used as the power supply.

Rev. 1.0, 08/99, page 69 of 151

### RENESAS

- 2. Software settings for LCD display are explained below.
  - a. Duty selection
     DTS1 and DTS0 are used to select from among static, 1/2 duty, 1/3 duty, and 1/4 duty.
  - b. Segment driver selection
     SGS3 to SGS0 are used to select the segment drivers to be used.
  - c. Frame frequency selection
     By setting CKS3 to CKS0, the frame frequency can be selected. The frame frequency should be selected according to the LCD panel.
  - d. Selection of A and B waveforms
     LCDAB can be used to select either the A or the B waveform for use as the LCD waveform.
  - e. Selection of LCD drive power supply

When using the internal power supply circuit, SUPS can be used to select the power supply to be used. When using an external power supply circuit, SUPS is used to select  $V_{cc}$ , and PSW should be used to turn off the LCD drive power supply.



3. Figure 9 shows the operation principle of this task example.



Rev. 1.0, 08/99, page 71 of 151

#### RENESAS

## **Explanation of Software**

1. Explanation of Modules

Table 4 explains the modules in this task example.

### Table 4Module Explanation

| Module Name  | Label Name | Function                                                                                   |
|--------------|------------|--------------------------------------------------------------------------------------------|
| Main routine | MAIN       | Initializes the stack pointer, LCD RAM, and LCD controller/driver, and enables interrupts. |

### 2. Explanation of Arguments

In this task example, no arguments are used.

3. Explanation of Internal Registers Used

Table 5 gives explanation of the internal registers used in this task example.

### Table 5Explanation of Internal Registers Used

| Register Name |      | Description                                                      | RAM<br>Address     | Settings |
|---------------|------|------------------------------------------------------------------|--------------------|----------|
| LPCR DTS1,    |      | LCD port control register                                        | H'FFC0             | DTS1 = 1 |
|               | D130 | Select duty from among static, 1/2 duty, 1/3 duty, and 1/4 duty. | Bit 7 and<br>bit 6 | D130 = 1 |
|               |      | • When DTS1 = 0 and DTS0 = 0, static duty is selected            |                    |          |
|               |      | • When DTS1 = 0 and DTS0 = 1, 1/2 duty is selected               |                    |          |
|               |      | • When DTS1 = 1 and DTS0 = 0, 1/3 duty is selected               |                    |          |
|               |      | • When DTS1 = 1 and DTS0 = 1, 1/4 duty is selected               |                    |          |

| Register | Name | Description                                                                                                                                                                                                                                                                                                                    | RAM<br>Address | Settings |
|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|
| LPCR CMX |      | LCD port control register                                                                                                                                                                                                                                                                                                      | H'FFC0         | 0        |
|          |      | (Common function selection)                                                                                                                                                                                                                                                                                                    | Bit 5          |          |
|          |      | Selects whether the same waveform is output from<br>several pins in order to increase the common<br>driving capacity, when common pins are not<br>selected for a given duty cycle.                                                                                                                                             |                |          |
|          |      | <ul> <li>When CMX = 0, the same waveform is not<br/>output from multiple common pins not used at<br/>that duty cycle</li> </ul>                                                                                                                                                                                                |                |          |
|          |      | <ul> <li>When CMX = 1, the same waveform is output<br/>from multiple common pins not used at that<br/>duty cycle</li> </ul>                                                                                                                                                                                                    |                |          |
| LPCR     | SGX  | LCD port control register                                                                                                                                                                                                                                                                                                      | H'FFC0         | 0        |
|          |      | (Expansion signal select)                                                                                                                                                                                                                                                                                                      | Bit 4          |          |
|          |      | Selects whether the SEG <sub>32</sub> /CL <sub>1</sub> , SEG <sub>31</sub> /CL <sub>2</sub> ,<br>SEG <sub>30</sub> /D0, and SEG <sub>29</sub> /M pins are used as segment<br>pins (SEG <sub>32</sub> through SEG <sub>29</sub> ), or as segment<br>external expansion signal pins (CL <sub>1</sub> , CL <sub>2</sub> , D0, M). |                |          |
|          |      | <ul> <li>When SGX = 0, they are used as segment pins<br/>(SEG<sub>32</sub> through SEG<sub>29</sub>)</li> </ul>                                                                                                                                                                                                                |                |          |
|          |      | <ul> <li>When SGX = 1, they are used as segment<br/>external expansion signal pins (CL<sub>1</sub>, CL<sub>2</sub>,<br/>D0, M)</li> </ul>                                                                                                                                                                                      |                |          |

| Register | Name               | Description                                                                                                                                                                                                                                                | RAM<br>Address           | Settings                                     |
|----------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------------------------|
| LPCR     | SGS3<br>to<br>SGS0 | <ul> <li>LCD port control register<br/>(Segment driver selection)</li> <li>Select the segment driver to be used.</li> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 0, pins SEG<sub>32</sub> through<br/>SEG, function as ports</li> </ul> | H'FFC0<br>Bit 3 to bit 0 | SGS3 = 1<br>SGS2 = 0<br>SGS1 = 0<br>SGS0 = 0 |
|          |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 1, pins SEG<sub>32</sub> through<br/>SEG, function as ports</li> </ul>                                                                                                                  |                          |                                              |
|          |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 1 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>25</sub> function as segment drivers and pins<br/>SEG<sub>24</sub> through SEG<sub>1</sub> function as ports</li> </ul>                    |                          |                                              |
|          |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 1,<br/>SGS1 = 0 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>17</sub> function as segment drivers and pins<br/>SEG<sub>16</sub> through SEG<sub>1</sub> function as ports</li> </ul>                    |                          |                                              |
|          |                    | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 1,<br/>SGS1 = 1 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>9</sub> function as segment drivers and pins<br/>SEG<sub>8</sub> through SEG<sub>1</sub> function as ports</li> </ul>                      |                          |                                              |
|          |                    | <ul> <li>When SGX = 0, SGS3 = 1, SGS2 = *,<br/>SGS1 = * and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>1</sub> function as segment drivers</li> </ul>                                                                                             |                          |                                              |
|          |                    | <ul> <li>When SGX = 1, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 0, pins SEG<sub>32</sub> through<br/>SEG<sub>29</sub> function as external expansion pins and<br/>pins SEG<sub>28</sub> through SEG<sub>1</sub> function as ports</li> </ul>            |                          |                                              |
|          |                    | <ul> <li>SGX = 1, SGS3 = *, SGS2 = *, SGS1 = * and<br/>SGS0 = * cannot be specified</li> </ul>                                                                                                                                                             |                          |                                              |
|          |                    | *: Don't care                                                                                                                                                                                                                                              |                          |                                              |

| Register Name |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RAM<br>Address  | Settings |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|--|
| LCR           | <ul> <li>CR PSW LCD control register<br/>(LCD drive power supply on/off control)<br/>Turns the LCD drive power supply off when LCD<br/>display is not used in power-down mode, or when<br/>an external power supply is used. When the ACT<br/>bit is cleared to 0, or when in standby mode, the<br/>LCD drive power supply is turned off regardless of<br/>this bit setting.</li> <li>When PSW = 0, the LCD drive power supply is<br/>turned off</li> <li>When PSW = 1, the LCD drive power supply is<br/>turned on</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | H'FFC1<br>Bit 6 | 1        |  |
| LCR           | ACT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <ul> <li>LCD control register <ul> <li>(Display function activate)</li> </ul> </li> <li>Selects whether the LCD controller/driver is to be used or not. By clearing this bit to 0, LCD controller/driver operation is halted. Also, regardless of the value of PSW, the LCD drive power supply is turned off.</li> <li>However, the register contents are maintained.</li> <li>When ACT = 0, LCD controller/driver operation is halted</li> <li>When ACT = 1, LCD controller/driver operations</li> </ul> | H'FFC1<br>Bit 5 | 1        |  |
| LCR           | DISP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <ul> <li>LCD control register<br/>(Display data control)</li> <li>DISP selects whether the LCD RAM contents or<br/>blank data are to be displayed.</li> <li>When DISP = 0, blank data is displayed</li> <li>When DISP = 1, LCD RAM data is displayed</li> </ul>                                                                                                                                                                                                                                           | H'FFC1<br>Bit 4 | 1        |  |

| Register | Name               | Description                                                                                                        | RAM<br>Address           | Settings                                     |
|----------|--------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------------------------|
| LCR      | CKS3<br>to<br>CKS0 | LCD control register<br>(Frame frequency select 3 to 0)<br>Select the operating clock and the frame<br>frequency.  | H'FFC1<br>Bit 3 to bit 0 | CKS3 = 1<br>CKS2 = 1<br>CKS1 = 1<br>CKS0 = 0 |
|          |                    | • When CKS3 = 0, CKS2 = *, CKS1 = 0 and CKS0 = 0, $\phi_w$ is selected as operating clock                          |                          |                                              |
|          |                    | • When CKS3 = 0, CKS2 = *, CKS1 = 0 and CKS0 = 1, $\phi_{\rm w}/2$ is selected as operating clock                  |                          |                                              |
|          |                    | • When CKS3 = 0, CKS2 = *, CKS1 = 1 and CKS0 = *, $\phi_{\rm w}/4$ is selected as operating clock                  |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 0 and<br/>CKS0 = 0, \u03c6/2 is selected as operating clock</li> </ul>    |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 0 and<br/>CKS0 = 1, \u03c6/4 is selected as operating clock</li> </ul>    |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 1 and<br/>CKS0 = 0, \u03c6/8 is selected as operating clock</li> </ul>    |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 1 and<br/>CKS0 = 1, \u03c6/16 is selected as operating clock</li> </ul>   |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 0 and<br/>CKS0 = 0, \$\phi\32\$ is selected as operating clock</li> </ul> |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 0 and<br/>CKS0 = 1, #64 is selected as operating clock</li> </ul>         |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 1 and<br/>CKS0 = 0, \$\phi\$128 is selected as operating clock</li> </ul> |                          |                                              |
|          |                    | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 1 and<br/>CKS0 = 1, φ/256 is selected as operating clock</li> </ul>       |                          |                                              |
|          |                    | *: Don't care                                                                                                      |                          |                                              |

| Register   | Name | Description                                                                                                                                                                                                                                     | RAM<br>Address | Settings |
|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|
| LCR2 LCDAB |      | LCD control register 2                                                                                                                                                                                                                          | H'FFC2         | 0        |
|            |      | (A waveform/B waveform switching control)                                                                                                                                                                                                       | Bit 7          |          |
|            |      | Selects whether the A or B waveform is to be used for LCD driving.                                                                                                                                                                              |                |          |
|            |      | • When LCDAB = 0, the LCD is driven using the<br>A waveform                                                                                                                                                                                     |                |          |
|            |      | • When LCDAB = 1, the LCD is driven using the B waveform                                                                                                                                                                                        |                |          |
| LCR2       | SUPS | LCD control register 2                                                                                                                                                                                                                          | H'FFC2         | 1        |
|            |      | (Drive power supply select, step-up constant-<br>voltage (5 V) power supply control)                                                                                                                                                            | Bit 4          |          |
|            |      | When $V_{cc}$ is selected as the drive power supply,<br>the step-up constant-voltage (5 V) power supply<br>operation is halted; when 5 V is selected as the<br>drive power supply, the step-up constant-voltage<br>(5 V) power supply operates. |                |          |
|            |      | • When SUPS = 0, the drive power supply is V <sub>cc</sub> ,<br>and the step-up constant-voltage (5 V) power<br>supply operation is halted                                                                                                      |                |          |
|            |      | • When SUPS = 1, the drive power supply is 5 V,<br>and the step-up constant-voltage (5 V) power<br>supply operates.                                                                                                                             |                |          |

| Register | Name               | Description                                                                                                                              | RAM<br>Address           | Settings                                     |
|----------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------------------------|
| LCR2     | CDS3<br>to<br>CDS0 | LCD control register 2<br>(Charge/discharge pulse duty cycle selection 3<br>to 0)<br>Select the duty cycle while the power supply split- | H'FFC2<br>Bit 3 to bit 0 | CDS3 = 0<br>CDS2 = 0<br>CDS1 = 0<br>CDS0 = 0 |
|          |                    | <ul> <li>When CDS3 = 0, CDS2 = 0, CDS1 = 0 and<br/>CDS0 = 0, the duty cycle is 1</li> </ul>                                              |                          |                                              |
|          |                    | • When CDS3 = 0, CDS2 = 0, CDS1 = 0 and CDS0 = 1, the duty cycle is 1/8                                                                  |                          |                                              |
|          |                    | • When CDS3 = 0, CDS2 = 0, CDS1 = 1 and<br>CDS0 = 0, the duty cycle is 2/8                                                               |                          |                                              |
|          |                    | • When CDS3 = 0, CDS2 = 0, CDS1 = 1 and CDS0 = 1, the duty cycle is 3/8                                                                  |                          |                                              |
|          |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 0 and CDS0 = 0, the duty cycle is 4/8                                                                  |                          |                                              |
|          |                    | <ul> <li>When CDS3 = 0, CDS2 = 1, CDS1 = 0 and<br/>CDS0 = 1, the duty cycle is 5/8</li> </ul>                                            |                          |                                              |
|          |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 1 and CDS0 = 0, the duty cycle is 6/8                                                                  |                          |                                              |
|          |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 1 and<br>CDS0 = 1, the duty cycle is 0                                                                 |                          |                                              |
|          |                    | <ul> <li>When CDS3 = 1, CDS2 = 0, CDS1 = * and<br/>CDS0 = *, the duty cycle is 1/16</li> </ul>                                           |                          |                                              |
|          |                    | • When CDS3 = 1, CDS2 = 1, CDS1 = * and<br>CDS0 = *, the duty cycle is 1/32                                                              |                          |                                              |
|          |                    | *: Don't care                                                                                                                            |                          |                                              |

4. Explanation of RAM Usage

In this task example, RAM is not used.

## Flowchart

1. Main routine



#### Renesas

#### **Program Lists**

```
;*
    H8/3867 Application Note
 ; *
      'Liquid Crystal Display
 ;*
       -1/4 Duty Drive, Internal Driver-'
 ;*
 ;*
           Function : LCD Controller / Driver
 ;*
 ;*
          External Clock : 6MHz
 ;*
 ;*
           Internal Clock : 3MHz
           Sub Clock : 32.768kHz
 ;*
 ;
      .cpu 3001
 ;
 ;*
      Symbol Defnition
 ;
 LPCR .equ h'ffc0 ;LCD Port Control Register
 LCR .equ h'ffc1 ;LCD Control Register
 LCR2 .equ
          h'ffc2 ;LCD Control Register 2
 ;
 ;*
      Vector Address
 ;
      .org h'0000
      .data.w MAIN
                  ;No.0 Reset Interrupt(H'0000-H'0001)
 ;
             h'0008
      .org
      .data.w
                     ;No.4 _IRQ0 Interrupt(H'0008-H'0009)
             MAIN
                     ;No.5 _IRQ1 Interrupt(H'000A-H'000B)
      .data.w
             MAIN
      .data.w
                      ;No.6 _IRQ2 Interrupt(H'000C-H'000D)
             MAIN
                      ;No.7 _IRQ3 Interrupt(H'000E-H'000F)
      .data.w
             MAIN
                      ;No.8 _IRQ4 Interrupt(H'0010-H'0011)
      .data.w
             MAIN
Rev. 1.0, 08/99, page 80 of 151
```

#### RENESAS

|        | .data.w               | MAIN                          | ;No.9 _WKP0WKP7 Interrupt(H'0012-H'0013)        |
|--------|-----------------------|-------------------------------|-------------------------------------------------|
| ;      |                       |                               |                                                 |
|        | .org                  | h'0016                        |                                                 |
|        | .data.w               | MAIN                          | ;No.11 Timer A Interrupt(H'0016-H'0017)         |
|        | .data.w               | MAIN                          | ;No.12 AEC Interrupt(H'0018-H'0019)             |
|        | .data.w               | MAIN                          | ;No.13 Timer C Interrupt(H'001A-H'001B)         |
|        | .data.w               | MAIN                          | ;No.14 Timer FL Interrupt(H'001C-H'001D)        |
|        | .data.w               | MAIN                          | ;No.15 Timer FH Interrupt(H'001E-H'001F)        |
|        | .data.w               | MAIN                          | ;No.16 Timer G Interrupt(H'0020-H'0021)         |
|        | .data.w               | MAIN                          | ;No.17 SCI31 Interrupt(H'0022-H'0023)           |
|        | .data.w               | MAIN                          | ;No.18 SCI32 Interrupt(H'0024-H'0025)           |
|        | .data.w               | MAIN                          | ;No.19 A/D Converter Interrupt(H'0026-H'0028)   |
|        | .data.w               | MAIN                          | ;No.20 Direct Transfer Interrupt(H'0028-H'0029) |
| ;      |                       |                               |                                                 |
| ;***** | *******               | * * * * * * * * * * * * * * * | *****                                           |
| ;*     | MAIN : Ma             | in Routine                    |                                                 |
| ;***** | * * * * * * * * * * * | * * * * * * * * * * * * * * * | *****                                           |
| ;      |                       |                               |                                                 |
|        | .org                  | h'1000                        |                                                 |
| ;      |                       |                               |                                                 |
| MAIN:  | .equ                  | \$                            |                                                 |
|        | mov.w                 | #h'ff80,sp                    | ;Initialize Stack Pointer                       |
|        | orc                   | #h'80,ccr                     | ;Interrupt Disable                              |
| ;      |                       |                               |                                                 |
|        | sub.b                 | r01,r01                       | ;Initialize LCD RAM                             |
|        | mov.w                 | #h'f740,r1                    |                                                 |
|        | mov.w                 | #h'f750,r2                    |                                                 |
| INIT:  | mov.b                 | r0l,@r1                       |                                                 |
|        | adds                  | #1,r1                         |                                                 |
|        | cmp.w                 | r2,r1                         |                                                 |
|        | bne                   | INIT                          |                                                 |
| ;      |                       |                               |                                                 |
|        | mov.b                 | #h'c8,r0l                     |                                                 |
|        | mov.b                 | r01,@LPCR                     | ;Initialize LCD Port Control                    |
|        | mov.b                 | <pre>#h'fe,r01</pre>          |                                                 |
|        | mov.b                 | r01,@LCR                      | ;Initialize LCD Control                         |
|        | mov.b                 | #h'70,r01                     |                                                 |
|        |                       |                               |                                                 |

RENESAS

Rev. 1.0, 08/99, page 81 of 151

```
r01,@LCR2 ;Initialize LCD Control 2
      mov.b
;
               #h'f740,r1 ;Set LCD RAM Start Address
      mov.w
               #h'f750,r2 ;Set LCD RAM End Address
      mov.w
               #h'1500,r3 ;Set LCD Data Address
      mov.w
DISP:
               @r3,r0
                        ;Load LCD Data
      mov.w
                         ;Store LCD Data to LCD RAM
      mov.w
               r0,@r1
                         ;Increment LCD Data Address
      adds
               #2,r3
      adds
                         ;Increment LCD RAM Address
               #2,r1
                         ;LCD RAM Address = LCD RAM End Address ?
      cmp.w
               r2,r1
               DISP
      bne
                         ;No.
;
      andc
               #h'7f,ccr ;Interrupt Enable
EXIT:
      bra
               EXIT
                         ;Yes.
;
;*
      LCD Data Table
;
               h'1500
       .org
;
              h'6246
                         ;"H"
       .data.w
       .data.w
             h'724e
                         ;"8"
             h'0420
                         ;"/"
       .data.w
       .data.w
             h'124e
                         ;"3"
                         ;"8"
       .data.w h'724e
              h'724a
                         ;"6"
       .data.w
                         ;"7"
       .data.w
              h'400e
                         ;""
       .data.w h'0000
;
```

.end

# 2.5 LCD Display with Segment External Expansion

| LCD Display with Segment External | MCU:           | Functions Used:       |
|-----------------------------------|----------------|-----------------------|
| Expansion                         | H8/3867 Series | LCD Controller/Driver |

## **Specifications**

- 1. LCD display is performed using the segment-type LCD controller circuit, LCD driver, and power supply circuit of the H8/3867 Series.
- 2. By connecting an HD66100 to an H8/3867 Series for segment external expansion, data is displayed on the LCD.
- 3. Data is displayed on the 16-line 8-character segment LCD with 1/4 duty.
- 4. As the power supply driving the LCD, Vcc is used.
- 5. An example of LCD module to the HD66100 connection and an LCD display example for this task example appear in figure 1.



Figure 1 LCD Module to HD66100 Connection and LCD Display Example

## **Explanation of Functions Used**

- 1. In this task example, the LCD controller/driver is used for LCD display. The features of the LCD controller/driver are described below.
  - Display capacity
    - a. Duty cycle: static
       Internal driver: 32 segments
       Segment external-expansion driver: 256 segments
    - b. Duty cycle: 1/2 Internal driver: 32 segment
       Segment external-expansion driver: 128 segments
    - c. Duty cycle: 1/3 Internal driver: 32 segment
       Segment external-expansion driver: 64 segments
    - d. Duty cycle: 1/4 Internal driver: 32 segment
       Segment external-expansion driver: 64 segments
  - LCD RAM capacity: 8 bits × 32 bytes (256 bits)
  - LCD RAM is word-accessible.
  - All segment output pins can be used as port pins in eight-pin units.
  - Depending on the duty cycle, the common output pins not used can be used for a common double-buffer (parallel connection).
  - Display is possible in all operating modes other than standby mode.
  - Frame frequency can be selected from among 11 values.
  - A power supply split-resistance is built-in, for supply of LCD driver power.
  - Use of module standby mode enables a module to be placed in standby mode independently when not used.
  - An internal step-up constant-voltage (5 V) power supply enables LCD display even at low voltages.
  - A or B waveform can be selected by software.





Figure 2 Block Diagram of LCD Controller/Driver (LCD Display with Segment External Expansion)

#### RENESAS

3. Functions of the LCD controller/driver are explained in table 1.

### Table 1 LCD Controller/Driver Functions

### LCD port control register (LPCR)

Function LPCR is an 8-bit read/write register which selects the duty cycle, the LCD driver and pin functions. LPCR is initialized to H'00 upon reset.

#### LCD control register (LCR)

Function LCR is an 8-bit read/write register which turns the LCD drive power supply on and off, controls display data, and selects the frame frequency. LCR is initialized to H'80 upon reset.

#### LCD control register 2 (LCR2)

Function LCR2 is an 8-bit read/write register which controls switching between A and B waveforms, selects the driver power supply, controls the step-up constant-voltage (5 V) power supply, and selects the duty cycle for charge/discharge pulses controlling disconnection of the power supply split-resistance from power supply circuit. LCR2 is initialized to H'60 upon reset.

#### Common output pins (COM<sub>4</sub> to COM<sub>1</sub>)

Function These are LCD common driving output pins; under static or 1/2-duty driving, they can be configured in parallel.

#### Segment external expansion signal pin (CL,)

Function This is a display data latch clock pin which is multiplexed as SEG<sub>32</sub>.

#### Segment external expansion signal pin (CL<sub>2</sub>)

Function This is a display data shift clock pin which is multiplexed as SEG<sub>31</sub>.

#### Segment external expansion signal pin (M)

Function This is an LCD alternation signal pin which is multiplexed as SEG<sub>29</sub>.

#### Segment external expansion signal pin (DO)

Function This is a serial display data signal pin which is multiplexed as SEG<sub>30</sub>.

### LCD power supply pins ( $V_0$ to $V_3$ )

Function These pins are used when connecting an external bypass capacitor or when using an external power supply circuit.

#### LCD RAM

Function Sets the display data. The relation between the LCD RAM and the display segments differs depending on the duty cycle. After the registers necessary for display have been set, instructions similar to the instructions for normal RAM are used to write data corresponding to the duty, and when the display is turned on, display is started automatically. Word/byte access instructions can be used to set data in RAM.

4. In this task example, a 16-line 8-character segment LCD is used for display with segment external expansion with 1/4 duty. Figure 3 is a diagram showing connections for segment signals and common signals of the 16-line 8-character segment LCD used in this task example.



Figure 3 Connections of Segment Signals and Common Signals of the 16-Line 8-Character Segment LCD Used in this Task Example

#### RENESAS

5. Figure 4 shows the LCD RAM mapping under 1/4 duty driving when using segment external expansion.

|        | Bit 7             | Bit 6             | Bit 5             | Bit 4             | Bit 3             | Bit 2             | Bit 1             | Bit 0             |
|--------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| H'F740 | SEG <sub>2</sub>  | SEG <sub>2</sub>  | SEG <sub>2</sub>  | SEG <sub>2</sub>  | SEG <sub>1</sub>  | SEG <sub>1</sub>  | SEG <sub>1</sub>  | SEG <sub>1</sub>  |
| H'F741 | SEG <sub>4</sub>  | SEG <sub>4</sub>  | SEG <sub>4</sub>  | SEG <sub>4</sub>  | SEG <sub>3</sub>  | SEG <sub>3</sub>  | SEG <sub>3</sub>  | SEG <sub>3</sub>  |
| H'F742 | SEG <sub>6</sub>  | SEG <sub>6</sub>  | SEG <sub>6</sub>  | SEG <sub>6</sub>  | SEG <sub>5</sub>  | SEG <sub>5</sub>  | $SEG_5$           | SEG <sub>5</sub>  |
| H'F743 | SEG <sub>8</sub>  | SEG <sub>8</sub>  | SEG <sub>8</sub>  | SEG <sub>8</sub>  | SEG <sub>7</sub>  | SEG <sub>7</sub>  | SEG <sub>7</sub>  | SEG <sub>7</sub>  |
| H'F744 | SEG <sub>10</sub> | SEG <sub>10</sub> | SEG <sub>10</sub> | SEG <sub>10</sub> | SEG <sub>9</sub>  | SEG <sub>9</sub>  | SEG <sub>9</sub>  | SEG <sub>9</sub>  |
| H'F745 | SEG <sub>12</sub> | SEG <sub>12</sub> | SEG <sub>12</sub> | SEG <sub>12</sub> | SEG <sub>11</sub> | SEG <sub>11</sub> | SEG <sub>11</sub> | SEG <sub>11</sub> |
| H'F746 | SEG <sub>14</sub> | SEG <sub>14</sub> | SEG <sub>14</sub> | SEG <sub>14</sub> | SEG <sub>13</sub> | SEG <sub>13</sub> | SEG <sub>13</sub> | SEG <sub>13</sub> |
| H'F747 | SEG <sub>16</sub> | SEG <sub>16</sub> | SEG <sub>16</sub> | SEG <sub>16</sub> | SEG <sub>15</sub> | SEG <sub>15</sub> | SEG <sub>15</sub> | SEG <sub>15</sub> |
| H'F748 | SEG <sub>18</sub> | SEG <sub>18</sub> | SEG <sub>18</sub> | SEG <sub>18</sub> | SEG <sub>17</sub> | SEG <sub>17</sub> | SEG <sub>17</sub> | SEG <sub>17</sub> |
| H'F749 | SEG <sub>20</sub> | SEG <sub>20</sub> | SEG <sub>20</sub> | SEG <sub>20</sub> | SEG <sub>19</sub> | SEG <sub>19</sub> | SEG <sub>19</sub> | SEG <sub>19</sub> |
| H'F74A | SEG <sub>22</sub> | SEG <sub>22</sub> | SEG <sub>22</sub> | SEG <sub>22</sub> | SEG <sub>21</sub> | SEG <sub>21</sub> | SEG <sub>21</sub> | SEG <sub>21</sub> |
| H'F74B | SEG <sub>24</sub> | SEG <sub>24</sub> | SEG <sub>24</sub> | SEG <sub>24</sub> | SEG <sub>23</sub> | SEG <sub>23</sub> | SEG <sub>23</sub> | SEG <sub>23</sub> |
| H'F74C | SEG <sub>26</sub> | SEG <sub>26</sub> | SEG <sub>26</sub> | SEG <sub>26</sub> | SEG <sub>25</sub> | SEG <sub>25</sub> | SEG <sub>25</sub> | SEG <sub>25</sub> |
| H'F74D | SEG <sub>28</sub> | SEG <sub>28</sub> | SEG <sub>28</sub> | SEG <sub>28</sub> | SEG <sub>27</sub> | SEG <sub>27</sub> | SEG <sub>27</sub> | SEG <sub>27</sub> |
| H'F74E | SEG <sub>30</sub> | SEG <sub>30</sub> | SEG <sub>30</sub> | SEG <sub>30</sub> | SEG <sub>29</sub> | SEG <sub>29</sub> | SEG <sub>29</sub> | SEG <sub>29</sub> |
| H'F74F | SEG <sub>32</sub> | SEG <sub>32</sub> | SEG <sub>32</sub> | SEG <sub>32</sub> | SEG <sub>31</sub> | SEG <sub>31</sub> | SEG <sub>31</sub> | SEG <sub>31</sub> |
| :      |                   |                   |                   |                   |                   |                   |                   |                   |
| H'F75F | SEG <sub>64</sub> | SEG <sub>64</sub> | SEG <sub>64</sub> | SEG <sub>64</sub> | SEG <sub>63</sub> | SEG <sub>63</sub> | SEG <sub>63</sub> | SEG <sub>63</sub> |
|        |                   | •                 | •                 | •                 | ↓<br>↓            | •                 | •                 | •                 |
|        | COM <sub>4</sub>  | COM <sub>3</sub>  | COM <sub>2</sub>  | COM <sub>1</sub>  | COM <sub>4</sub>  | COM <sub>3</sub>  | COM <sub>2</sub>  | COM <sub>1</sub>  |

Figure 4 LCD RAM Mapping under 1/4 Duty Driving with Segment External Expansion

6. Figure 5 shows the relation between the 16-line 8-character segment LCD display and LCD RAM settings used in this task example. As shown in the figure, by setting the LCD RAM appropriately, "H8/3867" is displayed on the 16-line 8-character segment LCD.

|        | V 000                                            |       | ▼<br>0000(<br>0000( | ) 0000<br>) 0000 | V 000 |       | V 0000<br>00000 | ▼<br>00000<br>00000 |              |  |
|--------|--------------------------------------------------|-------|---------------------|------------------|-------|-------|-----------------|---------------------|--------------|--|
|        | Bit 7                                            | Bit 6 | Bit 5               | Bit 4            | Bit 3 | Bit 2 | Bit 1           | Bit 0               |              |  |
| H'F740 | 0                                                | 1     | 1                   | 0                | 0     | 0     | 1               | 0                   | Display data |  |
| H'F741 | 0                                                | 1     | 0                   | 0                | 0     | 1     | 1               | 0                   | for "H"      |  |
| H'F742 | 0                                                | 1     | 1                   | 1                | 0     | 0     | 1               | 0                   | Display data |  |
| H'F743 | 0                                                | 1     | 0                   | 0                | 1     | 1     | 1               | 0                   | for "8"      |  |
| H'F744 | 0                                                | 0     | 0                   | 0                | 0     | 1     | 0               | 0                   | Display data |  |
| H'F745 | 0                                                | 0     | 1                   | 0                | 0     | 0     | 0               | 0                   | for "/"      |  |
| H'F746 | 0                                                | 0     | 0                   | 1                | 0     | 0     | 1               | 0                   | Display data |  |
| H'F747 | 0                                                | 1     | 0                   | 0                | 1     | 1     | 1               | 0                   | for "3"      |  |
| H'F748 | 0                                                | 1     | 1                   | 1                | 0     | 0     | 1               | 0                   | Display data |  |
| H'F749 | 0                                                | 1     | 0                   | 0                | 1     | 1     | 1               | 0                   | for "8"      |  |
| H'F74A | 0                                                | 1     | 1                   | 1                | 0     | 0     | 1               | 0                   | Display data |  |
| H'F74B | 0                                                | 1     | 0                   | 0                | 1     | 0     | 1               | 0                   | for "6"      |  |
| H'F74C | 0                                                | 1     | 0                   | 0                | 0     | 0     | 0               | 0                   | Display data |  |
| H'F74D | 0                                                | 0     | 0                   | 0                | 1     | 1     | 1               | 0                   | for "7"      |  |
| H'F74E | 0                                                | 0     | 0                   | 0                | 0     | 0     | 0               | 0                   | Display data |  |
| H'F74F | 0                                                | 0     | 0                   | 0                | 0     | 0     | 0               | 0                   | for ""*      |  |
|        | Note: *: " " denotes a blank (nothing displayed) |       |                     |                  |       |       |                 |                     |              |  |

Figure 5 Relation between LCD Display and LCD RAM Settings

7. Figure 6 shows the relation between the display of the eighth column from the right in the 16-line 8-character segment LCD and the LCD RAM corresponding to SEG<sub>1</sub> through SEG<sub>4</sub>. As indicated in figure 6, when the LCD RAM bits corresponding to 0 through f are set to 1, the LCD regions are lit; when they are cleared to 0, the LCD regions are unlit.



Figure 6 Relation between LCD Lit/Unlit States and Corresponding LCD RAM Settings

8. Table 2 shows examples of SEG<sub>1</sub> through SEG<sub>4</sub> display and display data for a 16-line 8-character segment LCD.

| Symbol | Display      | Address | Display Data |   |   | Symbol | Display | Address | Display Data |   |   |                 |        |   |   |   |   |   |   |   |   |
|--------|--------------|---------|--------------|---|---|--------|---------|---------|--------------|---|---|-----------------|--------|---|---|---|---|---|---|---|---|
|        | V 0000       | H'F740  | 0            | 0 | 0 | 0      | 0       | 0       | 0            | 0 | 0 | V <b>1</b> 0000 | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|        | iziki.       | H'F741  | 0            | 0 | 0 | 0      | 0       | 0       | 0            | 0 | G | ĬM.             | H'F741 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| *      | V NICO       | H'F740  | 0            | 0 | 0 | 0      | 1       | 1       | 1            | 1 |   | V NOD           | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |
|        | 0200.        | H'F741  | 1            | 1 | 1 | 1      | 0       | 0       | 0            | 0 |   |                 | H'F741 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 |
| _      | V 0000       | H'F740  | 0            | 0 | 0 | 0      | 0       | 0       | 1            | 0 | 1 |                 | H'F740 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
|        | 02000.       | H'F741  | 0            | 1 | 0 | 0      | 0       | 0       | 0            | 0 | I |                 | H'F741 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| /      | 0000         | H'F740  | 0            | 0 | 0 | 0      | 0       | 1       | 0            | 0 |   | 0000            | H'F740 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 |
| /      | 0000.        | H'F741  | 0            | 0 | 1 | 0      | 0       | 0       | 0            | 0 | J |                 | H'F741 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| 0      | V NOON       | H'F740  | 0            | 1 | 1 | 1      | 0       | 1       | 0            | 0 | ĸ |                 | H'F740 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 |
|        |              | H'F741  | 0            | 0 | 1 | 0      | 1       | 1       | 1            | 0 |   |                 | H'F741 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1      | 0002         | H'F740  | 0            | 0 | 0 | 0      | 0       | 0       | 0            | 0 | 1 | ¥0020           | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
|        | 0200         | H'F741  | 0            | 0 | 0 | 0      | 0       | 1       | 1            | 0 |   | <b>000</b> 0    | H'F741 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 2      | V0002        | H'F740  | 0            | 0 | 1 | 1      | 0       | 0       | 1            | 0 | м | Ĭ <u>M</u>      | H'F740 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |
| _      | <u>,0000</u> | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 0            | 0 |   | 200             | H'F741 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 3      | V0002        | H'F740  | 0            | 0 | 0 | 1      | 0       | 0       | 1            | 0 | N |                 | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
|        | 0200         | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 0            | 0 |   |                 | H'F741 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 4      | Y NOZ        | H'F740  | 0            | 1 | 0 | 0      | 0       | 0       | 1            | 0 | 0 | Y NOV           | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| · ·    | 0200         | H'F741  | 0            | 1 | 0 | 0      | 0       | 1       | 1            | 0 |   | <u>1200</u>     | H'F741 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
| 5      | 5            | H'F740  | 0            | 1 | 0 | 1      | 0       | 0       | 1            | 0 | P | Y NOZ           | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |
|        |              | H'F741  | 0            | 1 | 0 | 0      | 1       | 0       | 1            | 0 |   |                 | H'F741 | 0 | 1 | 0 | 0 | 1 | 1 | 9 | 0 |
| 6      | 0020         | H'F740  | 0            | 1 | 1 | 1      | 0       | 0       | 1            | 0 | 0 | <u>No</u> 2     | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 9 | 1 |
|        |              | H'F741  | 0            | 1 | 0 | 0      | 0       | 0       | 1            | 0 | ~ |                 | H'F741 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
| 7      |              | H'F740  | 0            | 1 | 0 | 0      | 0       | 0       | 0            | 0 | R | R               | H'F740 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 |
|        |              | H'F741  | 0            | 0 | 0 | 0      | 1       | 1       | 1            | 0 |   |                 | H'F741 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 8      | 002          | H'F740  | 0            | 1 | 1 | 1      | 0       | 0       | 1            | 0 | s | 0000            | H'F740 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|        |              | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 1            | 0 |   |                 | H'F741 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 9      | 002          | H'F740  | 0            | 1 | 0 | 0      | 0       | 0       | 1            | 0 | т | 0000            | H'F740 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
|        |              | H'F741  | 0            | 1 | 0 | 0      | 1       | 1       | 1            | 0 |   |                 | H'F741 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| Α      | 002          | H'F740  | 0            | 1 | 1 | 0      | 0       | 0       | 1            | 0 | U |                 | H'F740 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
|        |              |         | 0            | 1 | 0 | 0      | 1       | 1       | 1            | 0 |   |                 | H'F741 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| В      |              | H'F740  | 0            | 0 | 0 | 1      | 1       | 1       | 0            | 0 | V |                 | H'F740 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |
|        |              |         | 0            | 0 | 0 | 1      | 1       | 1       | 1            | 0 |   |                 |        | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| С      |              |         | 0            | 1 | 1 | 1      | 0       | 0       | 0            | 0 | W |                 |        | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
|        |              |         | 0            | 0 | 0 | 0      | 1       | 0       | 0            | 0 |   |                 |        | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 |
| D      |              |         | 0            | 0 | 0 | 1      | 1       | 0       | 0            | 0 | Х |                 |        | 0 | 0 | 0 | 0 | 0 | 1 | 0 |   |
|        |              |         | 0            | 0 | 0 | 1      | 1       | 1       | 1            | 0 |   |                 |        | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| E      |              |         | 0            | 1 | 1 |        | 1       | 0       | 0            | 0 | Y |                 |        | 1 | 0 | 0 | 1 |   |   | 0 |   |
|        |              |         | 0            | 1 | 1 | 0      |         | 0       | 1            | 0 |   | v               |        | 0 | 0 | 0 | 1 | 0 | 1 | 0 |   |
| F      |              |         | 0            | 1 | 1 | 0      | 1       | 0       | 0            | 0 | Z |                 |        | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
|        |              | FIF/41  | 0            |   | U | 0      |         | U       | U            | U |   | <b>4</b>        | FIF/41 | U | U |   |   |   | U | U | U |

## Table 2Display Data Examples

# RENESAS

9. Table 3 indicates function allocations in this task example.

| Function                             | Function Allocation                                                                                                                                                                                                                                       |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPCR                                 | Selects duty cycle, LCD driver, and pin functions.                                                                                                                                                                                                        |
| LCR                                  | Turns LCD drive power supply on and off, controls display data, and selects frame frequency.                                                                                                                                                              |
| LCR2                                 | Switches between A and B waveforms, selects drive power supply, controls step-up constant-voltage (5 V) power supply, selects duty cycle for charge/discharge pulses to control disconnection of power supply split-resistance from power supply circuit. |
| COM <sub>4</sub> to COM <sub>1</sub> | Used as common drivers.                                                                                                                                                                                                                                   |
| $V_{_0}$ to $V_{_3}$                 | Used as the LCD drive power supply pins to be connected to the HD66100.                                                                                                                                                                                   |
| CL <sub>1</sub>                      | Functions as a display data latch clock output to be connected to the HD66100.                                                                                                                                                                            |
|                                      | Functions as a display data latch clock output to be connected to the HD66100.                                                                                                                                                                            |
| Μ                                    | Functions as an LCD alternation signal output to be connected to the HD66100.                                                                                                                                                                             |
| DO                                   | Functions as a serial display data output to be connected to the HD66100.                                                                                                                                                                                 |
| LCD RAM                              | Sets the LCD display data.                                                                                                                                                                                                                                |

Table 3Function Allocations

## **Explanation of Functions Used**

- 1. Hardware settings for LCD display are explained below.
  - a. LCD drive power supply settings

The H8/3867 Series can use either the internal power supply circuit or an external power supply circuit as the LCD drive power supply. In addition, either the power supply voltage  $(V_{cc})$  or the step-up constant-voltage (5 V) can be selected for the internal power supply circuit.

When using the internal power supply circuit to drive the LCD, the  $V_0$  and  $V_1$  pins are connected externally, as illustrated in figure 7.

In this task example, the step-up constant-voltage power supply is used as the LCD drive power supply.



Figure 7 Example of Connection of LCD Power Supply Pins When Using Internal Power Supply Circuit

### b. Contrast control function

A block diagram of the LCD drive power supply circuit appears in figure 8. Either  $V_{cc}$  or a 5 V output from the step-up constant-voltage power supply circuit is output to pin  $V_0$ . When these voltages are used directly to drive the LCD, the  $V_0$  and  $V_1$  pins should be shorted. By inserting a variable resistance R between the  $V_0$  and  $V_1$  pins, the voltage applied to the  $V_1$  pin can be adjusted, and the LCD panel contrast can be controlled.



Figure 8 Block Diagram of LCD Drive Power Supply Circuit

- 2. Software settings for LCD display are explained below.
  - a. Duty selection
     DTS1 and DTS0 are used to select from among static, 1/2 duty, 1/3 duty, and 1/4 duty.
  - b. Segment driver selection
     SGS3 to SGS0 are used to select the segment drivers to be used.
  - c. Frame frequency selection
     By setting CKS3 to CKS0, the frame frequency can be selected. The frame frequency should be selected according to the LCD panel.
  - d. Selection of A and B waveforms
     LCDAB can be used to select either the A or the B waveform for use as the LCD waveform.
  - e. Selection of LCD drive power supply

When using the internal power supply circuit, SUPS can be used to select the power supply to be used. When using an external power supply circuit, SUPS is used to select  $V_{cc}$ , and PSW should be used to turn off the LCD drive power supply.



3. Figure 9 shows the operation principle of this task example.

**Figure 9** Operation Principle

## **Explanation of Software**

1. Explanation of Modules

Table 4 explains the modules in this task example.

## Table 4Module Explanation

| Module Name  | Label Name | Function                                                                                   |
|--------------|------------|--------------------------------------------------------------------------------------------|
| Main routine | MAIN       | Initializes the stack pointer, LCD RAM, and LCD controller/driver, and enables interrupts. |

### 2. Explanation of Arguments

In this task example, no arguments are used.

3. Explanation of Internal Registers Used

Table 5 gives explanation of the internal registers used in this task example.

| Register Name |               | Description                                                                                                                                                                                                                                                                                                                                                                                        | RAM<br>Address               | Settings             |
|---------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|----------------------|
| LPCR          | DTS1,<br>DTS0 | <ul> <li>LCD port control register<br/>(Duty cycle selection 1, 0)</li> <li>Select duty from among static, 1/2 duty, 1/3 duty, and 1/4 duty.</li> <li>When DTS1 = 0 and DTS0 = 0, static duty is selected</li> <li>When DTS1 = 0 and DTS0 = 1, 1/2 duty is selected</li> <li>When DTS1 = 1 and DTS0 = 0, 1/3 duty is selected</li> <li>When DTS1 = 1 and DTS0 = 1, 1/4 duty is selected</li> </ul> | H'FFC0<br>Bit 7 and<br>bit 6 | DTS1 = 1<br>DTS0 = 1 |
|               |               |                                                                                                                                                                                                                                                                                                                                                                                                    |                              |                      |

| Register Name |     | Description                                                                                                                                                                                                                                                                                                                    | RAM<br>Address | Settings |
|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|
| LPCR          | CMX | LCD port control register                                                                                                                                                                                                                                                                                                      | H'FFC0         | 0        |
|               |     | (Common function selection)                                                                                                                                                                                                                                                                                                    | Bit 5          |          |
|               |     | Selects whether the same waveform is output from<br>several pins in order to increase the common<br>driving capacity, when common pins are not<br>selected for a given duty cycle.                                                                                                                                             |                |          |
|               |     | <ul> <li>When CMX = 0, the same waveform is not<br/>output from multiple common pins not used at<br/>that duty cycle</li> </ul>                                                                                                                                                                                                |                |          |
|               |     | • When CMX = 1, the same waveform is output from multiple common pins not used at that duty cycle                                                                                                                                                                                                                              |                |          |
| LPCR          | SGX | LCD port control register                                                                                                                                                                                                                                                                                                      | H'FFC0         | 1        |
|               |     | (Expansion signal select)                                                                                                                                                                                                                                                                                                      | Bit 4          |          |
|               |     | Selects whether the SEG <sub>32</sub> /CL <sub>1</sub> , SEG <sub>31</sub> /CL <sub>2</sub> ,<br>SEG <sub>30</sub> /D0, and SEG <sub>29</sub> /M pins are used as segment<br>pins (SEG <sub>32</sub> through SEG <sub>29</sub> ), or as segment<br>external expansion signal pins (CL <sub>1</sub> , CL <sub>2</sub> , D0, M). |                |          |
|               |     | <ul> <li>When SGX = 0, they are used as segment pins<br/>(SEG<sub>32</sub> through SEG<sub>29</sub>)</li> </ul>                                                                                                                                                                                                                |                |          |
|               |     | <ul> <li>When SGX = 1, they are used as segment<br/>external expansion signal pins (CL<sub>1</sub>, CL<sub>2</sub>, D0,<br/>M)</li> </ul>                                                                                                                                                                                      |                |          |

| Register Name |            | Description                                                                                                                                                                                                                                     | RAM<br>Address           | Settings                       |  |  |
|---------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------|--|--|
| LPCR          | SGS3<br>to | LCD port control register<br>(Segment driver selection)                                                                                                                                                                                         | H'FFC0<br>Bit 3 to bit 0 | SGS3 = 0 $SGS2 = 0$ $SGS1 = 0$ |  |  |
|               | 3630       | Select the segment driver to be used.                                                                                                                                                                                                           |                          | SGS1 = 0<br>SGS0 = 0           |  |  |
|               |            | • When $SGX = 0$ , $SGS3 = 0$ , $SGS2 = 0$ ,<br>$SGS1 = 0$ and $SGS0 = 0$ , pins $SEG_{32}$ through<br>$SEG_1$ function as ports                                                                                                                |                          |                                |  |  |
|               |            | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 1, pins SEG<sub>32</sub> through<br/>SEG<sub>1</sub> function as ports</li> </ul>                                                                                            |                          |                                |  |  |
|               |            | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 1 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>25</sub> function as segment drivers and pins<br/>SEG<sub>24</sub> through SEG<sub>1</sub> function as ports</li> </ul>         |                          |                                |  |  |
|               |            | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 1,<br/>SGS1 = 0 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>17</sub> function as segment drivers and pins<br/>SEG<sub>16</sub> through SEG<sub>1</sub> function as ports</li> </ul>         |                          |                                |  |  |
|               |            | <ul> <li>When SGX = 0, SGS3 = 0, SGS2 = 1,<br/>SGS1 = 1 and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>9</sub> function as segment drivers and pins<br/>SEG<sub>8</sub> through SEG<sub>1</sub> function as ports</li> </ul>           |                          |                                |  |  |
|               |            | <ul> <li>When SGX = 0, SGS3 = 1, SGS2 = *,<br/>SGS1 = * and SGS0 = *, pins SEG<sub>32</sub> through<br/>SEG<sub>1</sub> function as segment drivers</li> </ul>                                                                                  |                          |                                |  |  |
|               |            | <ul> <li>When SGX = 1, SGS3 = 0, SGS2 = 0,<br/>SGS1 = 0 and SGS0 = 0, pins SEG<sub>32</sub> through<br/>SEG<sub>29</sub> function as external expansion pins and<br/>pins SEG<sub>28</sub> through SEG<sub>1</sub> function as ports</li> </ul> |                          |                                |  |  |
|               |            | • SGX = 1, SGS3 = *, SGS2 = *, SGS1 = * and<br>SGS0 = * cannot be specified                                                                                                                                                                     |                          |                                |  |  |
|               |            | *: Don't care                                                                                                                                                                                                                                   |                          |                                |  |  |

| Register | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RAM<br>Address  | Settings |
|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------|
| LCR      | PSW  | <ul> <li>LCD control register<br/>(LCD drive power supply on/off control)</li> <li>Turns the LCD drive power supply off when LCD<br/>display is not used in power-down mode, or when<br/>an external power supply is used. When the ACT<br/>bit is cleared to 0, or when in standby mode, the<br/>LCD drive power supply is turned off regardless<br/>of this bit setting.</li> <li>When PSW = 0, the LCD drive power supply is<br/>turned off</li> <li>When PSW = 1, the LCD drive power supply is<br/>turned on</li> </ul> | H'FFC1<br>Bit 6 | 1        |
| LCR      | ACT  | <ul> <li>LCD control register <ul> <li>(Display function activate)</li> </ul> </li> <li>Selects whether the LCD controller/driver is to be used or not. By clearing this bit to 0, LCD controller/driver operation is halted. Also, regardless of the value of PSW, the LCD drive power supply is turned off.</li> <li>However, the register contents are maintained.</li> <li>When ACT = 0, LCD controller/driver operation is halted</li> <li>When ACT = 1, LCD controller/driver operations</li> </ul>                    | H'FFC1<br>Bit 5 | 1        |
| LCR      | DISP | <ul> <li>LCD control register<br/>(Display data control)</li> <li>DISP selects whether the LCD RAM contents or<br/>blank data are to be displayed.</li> <li>When DISP = 0, blank data is displayed</li> <li>When DISP = 1, LCD RAM data is displayed</li> </ul>                                                                                                                                                                                                                                                              | H'FFC1<br>Bit 4 | 1        |

| Register Name |            | Description                                                                                                            | RAM<br>Address | Settings                         |
|---------------|------------|------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------|
| LCR           | CKS3       | LCD control register                                                                                                   | H'FFC1         | CKS3 = 1                         |
|               | to<br>CKS0 | (Frame frequency select 3 to 0)<br>Select the operating clock and the frame<br>frequency.                              | Bit 3 to bit 0 | CKS2 = 1<br>CKS1 = 1<br>CKS0 = 0 |
|               |            | <ul> <li>When CKS3 = 0, CKS2 = *, CKS1 = 0 and<br/>CKS0 = 0, φ<sub>w</sub> is selected as operating clock</li> </ul>   |                |                                  |
|               |            | • When CKS3 = 0, CKS2 = *, CKS1 = 0 and CKS0 = 1, $\phi_{\rm w}/2$ is selected as operating clock                      |                |                                  |
|               |            | <ul> <li>When CKS3 = 0, CKS2 = *, CKS1 = 1 and<br/>CKS0 = *, φ<sub>w</sub>/4 is selected as operating clock</li> </ul> |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 0 and<br/>CKS0 = 0, \u03c6/2 is selected as operating clock</li> </ul>        |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 0 and<br/>CKS0 = 1, \u03c6/4 is selected as operating clock</li> </ul>        |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 1 and<br/>CKS0 = 0, \u03c6/8 is selected as operating clock</li> </ul>        |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 0, CKS1 = 1 and<br/>CKS0 = 1, \u03c6/16 is selected as operating clock</li> </ul>       |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 0 and<br/>CKS0 = 0, \u03c6/32 is selected as operating clock</li> </ul>       |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 0 and<br/>CKS0 = 1, \u03c6/64 is selected as operating clock</li> </ul>       |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 1 and<br/>CKS0 = 0, \u03c6/128 is selected as operating clock</li> </ul>      |                |                                  |
|               |            | <ul> <li>When CKS3 = 1, CKS2 = 1, CKS1 = 1 and<br/>CKS0 = 1, φ/256 is selected as operating clock</li> </ul>           |                |                                  |
|               |            | *: Don't care                                                                                                          |                |                                  |
# Table 5 Explanation of Internal Registers Used (cont)

| Register Name |       | Description                                                                                                                                                                                                                                     | RAM<br>Address | Settings |
|---------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|
| LCR2          | LCDAB | LCD control register 2                                                                                                                                                                                                                          | H'FFC2         | 0        |
|               |       | (A waveform/B waveform switching control)                                                                                                                                                                                                       | Bit 7          |          |
|               |       | Selects whether the A or B waveform is to be used for LCD driving.                                                                                                                                                                              |                |          |
|               |       | • When LCDAB = 0, the LCD is driven using the<br>A waveform                                                                                                                                                                                     |                |          |
|               |       | • When LCDAB = 1, the LCD is driven using the<br>B waveform                                                                                                                                                                                     |                |          |
| LCR2          | SUPS  | LCD control register 2                                                                                                                                                                                                                          | H'FFC2         | 0        |
|               |       | (Drive power supply select, step-up constant-<br>voltage (5 V) power supply control)                                                                                                                                                            | Bit 4          |          |
|               |       | When $V_{cc}$ is selected as the drive power supply,<br>the step-up constant-voltage (5 V) power supply<br>operation is halted; when 5 V is selected as the<br>drive power supply, the step-up constant-voltage<br>(5 V) power supply operates. |                |          |
|               |       | • When SUPS = 0, the drive power supply is V <sub>cc</sub> ,<br>and the step-up constant-voltage (5 V) power<br>supply operation is halted                                                                                                      |                |          |
|               |       | <ul> <li>When SUPS = 1, the drive power supply is 5 V,<br/>and the step-up constant-voltage (5 V) power<br/>supply operates</li> </ul>                                                                                                          |                |          |

# Table 5 Explanation of Internal Registers Used (cont)

| Register Name |                    | Description                                                                                    | RAM<br>Address           | Settings                                  |
|---------------|--------------------|------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------------|
| LCR2          | CDS3<br>to<br>CDS0 | LCD control register 2<br>(Charge/discharge pulse duty cycle selection 3<br>to 0)              | H'FFC2<br>Bit 3 to bit 0 | CDS3 = 0 $CDS2 = 0$ $CDS1 = 0$ $CDS0 = 0$ |
|               |                    | resistance is connected to the power supply spin-                                              |                          |                                           |
|               |                    | <ul> <li>When CDS3 = 0, CDS2 = 0, CDS1 = 0 and<br/>CDS0 = 0, the duty cycle is 1</li> </ul>    |                          |                                           |
|               |                    | <ul> <li>When CDS3 = 0, CDS2 = 0, CDS1 = 0 and<br/>CDS0 = 1, the duty cycle is 1/8</li> </ul>  |                          |                                           |
|               |                    | • When CDS3 = 0, CDS2 = 0, CDS1 = 1 and<br>CDS0 = 0, the duty cycle is 2/8                     |                          |                                           |
|               |                    | • When CDS3 = 0, CDS2 = 0, CDS1 = 1 and<br>CDS0 = 1, the duty cycle is 3/8                     |                          |                                           |
|               |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 0 and CDS0 = 0, the duty cycle is 4/8                        |                          |                                           |
|               |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 0 and CDS0 = 1, the duty cycle is 5/8                        |                          |                                           |
|               |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 1 and CDS0 = 0, the duty cycle is 6/8                        |                          |                                           |
|               |                    | • When CDS3 = 0, CDS2 = 1, CDS1 = 1 and<br>CDS0 = 1, the duty cycle is 0                       |                          |                                           |
|               |                    | <ul> <li>When CDS3 = 1, CDS2 = 0, CDS1 = * and<br/>CDS0 = *, the duty cycle is 1/16</li> </ul> |                          |                                           |
|               |                    | • When CDS3 = 1, CDS2 = 1, CDS1 = * and<br>CDS0 = *, the duty cycle is 1/32                    |                          |                                           |
|               |                    | *: Don't care                                                                                  |                          |                                           |

# 4. Explanation of RAM Usage

In this task example, RAM is not used.

# Flowchart

1. Main routine



## **Program Lists**

```
;*
   H8/3867 Application Note
;*
; *
    'Liquid Crystal Display
;*
    -Using Segment External Expansion,
    Using HD66100, 1/4 Duty Drive'
;*
;*
        Function : LCD Controller / Driver
;*
;*
        External Clock : 6MHz
;*
        Internal Clock : 3MHz
;*
; *
        Sub Clock : 32.768kHz
;
     .cpu 3001
;
;*
     Symbol Defnition
;
LPCR .equ h'ffc0 ;LCD Port Control Register
         h'ffc1
                   ;LCD Control Register
LCR
    .equ
          h'ffc2
LCR2
                  ;LCD Control Register 2
    .equ
;
;*
    Vector Address
;
     .org h'0000
                 ;No.0 Reset Interrupt(H'0000-H'0001)
     .data.w MAIN
;
           h'0008
     .org
     .data.w
          MAIN
                   ;No.4 _IRQ0 Interrupt(H'0008-H'0009)
                   ;No.5 _IRQ1 Interrupt(H'000A-H'000B)
     .data.w MAIN
                   ;No.6 _IRQ2 Interrupt(H'000C-H'000D)
     .data.w MAIN
                    ;No.7 _IRQ3 Interrupt(H'000E-H'000F)
     .data.w
           MAIN
```

RENESAS

Rev. 1.0, 08/99, page 105 of 151

|        | .data.w               | MAIN                      | ;No.8 _IRQ4 Interrupt(H'0010-H'0011)            |
|--------|-----------------------|---------------------------|-------------------------------------------------|
|        | .data.w               | MAIN                      | ;No.9 _WKP0WKP7 Interrupt(H'0012-H'0013)        |
| ;      |                       |                           |                                                 |
|        | .org                  | h'0016                    |                                                 |
|        | .data.w               | MAIN                      | ;No.11 Timer A Interrupt(H'0016-H'0017)         |
|        | .data.w               | MAIN                      | ;No.12 AEC Interrupt(H'0018-H'0019)             |
|        | .data.w               | MAIN                      | ;No.13 Timer C Interrupt(H'001A-H'001B)         |
|        | .data.w               | MAIN                      | ;No.14 Timer FL Interrupt(H'001C-H'001D)        |
|        | .data.w               | MAIN                      | ;No.15 Timer FH Interrupt(H'001E-H'001F)        |
|        | .data.w               | MAIN                      | ;No.16 Timer G Interrupt(H'0020-H'0021)         |
|        | .data.w               | MAIN                      | ;No.17 SCI31 Interrupt(H'0022-H'0023)           |
|        | .data.w               | MAIN                      | ;No.18 SCI32 Interrupt(H'0024-H'0025)           |
|        | .data.w               | MAIN                      | ;No.19 A/D Converter Interrupt(H'0026-H'0028)   |
|        | .data.w               | MAIN                      | ;No.20 Direct Transfer Interrupt(H'0028-H'0029) |
| ;      |                       |                           |                                                 |
| ;***** | *******               | * * * * * * * * * * * * * | ******                                          |
| ;*     | MAIN : Ma             | in Routine                |                                                 |
| ;***** | * * * * * * * * * * * | * * * * * * * * * * * * * | *****                                           |
|        | .org                  | h'1000                    |                                                 |
| ;      |                       |                           |                                                 |
| MAIN:  | .equ                  | \$                        |                                                 |
|        | mov.w                 | #h'ff80,sp                | ;Initialize Stack Pointer                       |
|        | orc                   | #h'80,ccr                 | ;Interrupt Disable                              |
| ;      |                       |                           |                                                 |
|        | sub.b                 | r01,r01                   | ;Initialize LCD RAM                             |
|        | mov.w                 | #h'f740,rl                |                                                 |
|        | mov.w                 | #h'f750,r2                |                                                 |
| INIT:  | mov.b                 | r0l,@r1                   |                                                 |
|        | adds                  | #1,r1                     |                                                 |
|        | cmp.w                 | r2,r1                     |                                                 |
|        | bne                   | INIT                      |                                                 |
| ;      |                       |                           |                                                 |
|        | mov.b                 | #h'd0,r01                 | ;Initialize LCD Port Control                    |
|        | mov.b                 | r01,@LPCR                 |                                                 |
|        | mov.b                 | <pre>#h'fe,r01</pre>      | ;Initialize LCD Control                         |
|        | mov.b                 | r01,@LCR                  |                                                 |
|        | mov.b                 | #h'60,r01                 | ;Initialize LCD Control 2                       |
|        |                       |                           |                                                 |

## Rev. 1.0, 08/99, page 106 of 151

mov.b r01,@LCR2

; #h'f740,r1 ;Set LCD RAM Start Address mov.w #h'f750,r2 ;Set LCD RAM End Address mov.w #h'1500,r3 ;Set LCD Data Address mov.w ;Load LCD Data DISP: @r3,r0 mov.w r0,@r1 ;Store LCD Data to LCD RAM mov.w ;Increment LCD Data Address adds #2,r3 adds ;Increment LCD RAM Address #2,r1 cmp.w r2,r1 ;LCD RAM Address = LCD RAM End Address ? ;No. bne DISP ; EXIT: bra EXIT ;Yes. ; ;\* LCD Data Table h'1500 .org ; .data.w h'6246 ;"H" .data.w h'724e ;"8" .data.w h'0420 ;"/" .data.w h'124e ;"3" .data.w h'724e ;"8" .data.w h'724a ;"6" ;"7" .data.w h'400e .data.w h'0000 ;""

.end

;

# 2.6 Oscillation Stabilization Time Settings

| Oscillation Stabilization Time Settings | MCU:           | Functions Used: |
|-----------------------------------------|----------------|-----------------|
|                                         | H8/3867 Series | Power-Down Mode |

# Settings

The time for which the CPU and peripheral functions must wait until the clock stabilizes when, by means of specific interrupts, standby or watch mode is canceled and there is a transition to active mode, is set. This standby time must be set to be longer than the time for oscillation stabilization, in accordance with the operating frequency.

# Setting the standby time

The standby time is set by setting the standby timer selects 2 to 0 bits (STS2 to STS0) of the system control register 1 (SYSCR1).

## Explanation of the STS2 to STS0 bits

Table 1 explains the STS2 to STS0 bits of the SYSCR1 register.

## Table 1 STS2 to STS0 Settings and Standby Time

|       | SYSCF | R1    |                               |                       |
|-------|-------|-------|-------------------------------|-----------------------|
| Bit 6 | Bit 5 | Bit 4 |                               |                       |
| STS2  | STS1  | STS0  | Description                   |                       |
| 0     | 0     | 0     | Standby time = 8,192 states   | (Initial value)       |
|       |       | 1     | Standby time = 16,384 states  |                       |
|       | 1     | 0     | Standby time = 32,768 states  |                       |
|       |       | 1     | Standby time = 65,536 states  |                       |
| 1     | 0     | 0     | Standby time = 131,072 states |                       |
|       |       | 1     | Standby time = 2 states       | (External clock mode) |
|       | 1     | 0     | Standby time = 8 states       |                       |
|       |       | 1     | Standby time = 16 states      |                       |

Note: When an external clock signal is to be input, the standby timer select pins should be set to external clock mode prior to execution of the mode transition. When an external clock is not used, the external clock input mode should not be set.

## Operating frequency and oscillation stabilization time when a crystal oscillator is used

Table 2 shows the standby times resulting for different operating frequencies and STS2 to STS0 settings when a crystal oscillator is used. STS2 to STS0 are set so that the standby time is longer than the time required for oscillation stabilization.

# Table 2Operating Frequency and Oscillation Stabilization Times for Crystal<br/>Oscillators

| Standby Timer<br>Select Bit Settings |      |      |                      | <b>Operating Frequency</b>     |       |       |         |
|--------------------------------------|------|------|----------------------|--------------------------------|-------|-------|---------|
| STS2                                 | STS1 | STS0 | Standby <sup>-</sup> | Гime                           | 2 MHz | 1 MHz | 0.5 MHz |
| 0                                    | 0    | 0    | 8,192 stat           | es                             | 4.1   | 8.2   | 16.4    |
|                                      |      | 1    | 16,384 sta           | ites                           | 8.2   | 16.4  | 32.8    |
|                                      | 1    | 0    | 32,768 sta           | 32,768 states<br>65,536 states |       | 32.8  | 65.5    |
|                                      |      | 1    | 65,536 sta           |                                |       | 65.5  | 131.1   |
| 1                                    | 0    | 0    | 131,072 s            | tates                          | 65.5  | 131.1 | 262.1   |
|                                      |      | 1    | 2 states             | (Use prohibited)               | 0.001 | 0.002 | 0.004   |
|                                      | 1    | 0    | 8 states             |                                | 0.004 | 0.008 | 0.016   |
|                                      |      | 1    | 16 states            |                                | 0.008 | 0.016 | 0.032   |

Unit: ms

## When an external clock is used

It is recommended that the circuit be used with STS2 = 1, STS1 = 0, and STS0 = 1. Use at other settings is also possible, but operation may begin before the standby time has completed.

#### Oscillation stabilization times

Table 3 shows the AC characteristics of oscillation stabilization times.

|                                      |                                                                                                                                                                                                                            | Applicable                             | Test                                                      | Values |     |     |      | Reference |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------|--------|-----|-----|------|-----------|
| Item                                 | Symbol                                                                                                                                                                                                                     | Pins                                   | Conditions                                                | Min    | Тур | Max | Unit | Figure    |
| Oscillation<br>stabilization<br>time | t <sub>rc</sub>                                                                                                                                                                                                            | OSC <sub>1</sub> ,<br>OSC <sub>2</sub> | $V_{cc}$ = 2.2 V to<br>5.5 V<br>(as shown in<br>figure 1) | _      | 20  | 45  | us   | Figure 1* |
|                                      |                                                                                                                                                                                                                            |                                        | $V_{cc}$ = 2.2 V to<br>5.5 V<br>(as shown in<br>figure 1) |        | 0.1 | 8   | ms   | Figure 1  |
|                                      |                                                                                                                                                                                                                            |                                        | Other than the above                                      |        | _   | 50  | ms   | Figure 1  |
| Oscillation<br>stabilization<br>time | t <sub>rc</sub>                                                                                                                                                                                                            | X <sub>1</sub> , X <sub>2</sub>        | _                                                         | _      | _   | 2.0 | S    | _         |
| $(V_{cc} = 1.8 \text{ to})$          | $(V_{cc} = 1.8 \text{ to } 5.5 \text{ V}, \text{AV}_{cc} = 1.8 \text{ to } 5.5 \text{ V}, \text{V}_{SS} = \text{AV}_{SS} = 0.0 \text{ V}, \text{T}_{a} = -20 \text{ to } +75^{\circ}\text{C}, \text{ including subactive}$ |                                        |                                                           |        |     |     |      |           |

## Table 3 AC Characteristics of Oscillation Stabilization Time

(v<sub>cc</sub> = mode)

Note: \*: Internal power supply step-down circuit not used.



# Figure 1 Oscillator Equivalent Circuit

## Example of oscillation stabilization time settings

## 1. Functions

A transition from active (high-speed) to watch mode is induced, and after 250 ms watch mode is canceled by a timer A interrupt, with a transition back to active (high-speed) mode. In making the transition from watch mode to active (high-speed) mode, the time for the CPU and peripheral functions to wait until the clock stabilizes is set to eight states.

## 2. Notes

In these settings, when the watch mode is canceled by a timer A interrupt, part of the timer A interrupt processing includes prohibition of timer A interrupt requests. Hence when there is a transition from active (high-speed) mode to watch mode, and watch mode is then canceled by a timer A interrupt with a transition to active (high-speed) mode, processing is completed.

## 3. Watch mode

a. Transition to watch mode

When, in active mode or subactive mode, the software standby bit (SSBY) of the system control register 1 (SYSCR1) is 1 and the internal clock selector 3 bit (TMA3) of the timer mode register A (TMA) is 1, if a sleep instruction is executed, there is a transition to watch mode. In watch mode, operation of all built-in peripheral functions other than timer A, timer F, timer G, the asynchronous event counter, and the LCD (operation/halted selectable), is halted. So long as the standard voltage is supplied, the CPU, the internal registers for part of the built-in peripheral functions, and internal RAM are maintained, and the I/O ports are held at their states prior to transition.

b. Watch mode cancellation

Watch mode is canceled by an interrupt ( $IRQ_0$ ,  $WKP_7$  to  $WKP_0$ , timer A, timer F, timer G) or by RES pin input.

In cancellation by an interrupt, when the interrupt occurs the watch mode is canceled, and if the low-speed on-flag (LSON) of SYSCR1 is 0 and the medium-speed on-flag (MSON) of the system control register 2 (SYSCR2) is 0, there is a transition to active (high-speed) mode. If LSON = 0 and MSON = 1, there is a transition to active (medium-speed) mode, and if LSON = 1 there is a transition to subactive mode. On transitions to active modes, after the time set by the STS2 to STS0 bits of SYSCR1 has elapsed, the stabilized clock pulse is supplied to the entire LSI, and interrupt exception processing begins. When the I bit of CCR is 1 or when acceptance of the relevant interrupt by the interrupt enable register is disabled, watch mode is not canceled.

In cancellation by input to the RES pin, if the RES pin is forced low, system clock oscillation is started. After the time for oscillation stabilization has elapsed, if the RES pin is forced high, the CPU initiates reset exception processing. The system clock is supplied to the entire LSI at the time, system clock oscillation is started. The RES pin should always be held low until the system clock oscillation stabilizes.

#### Rev. 1.0, 08/99, page 111 of 151

## Renesas

## Flowchart

1. Main routine



# 2. Timer A interrupt processing routine



#### **Program Lists**

```
;*
    H8/3867 Application Note
 ;*
    'Oscillator Settling Time -8 States'
 ;*
 ;*
 ;*
         Function : Oscillator Settling Time
 ;*
         External Clock : 6MHz
 ;*
 ;*
         Internal Clock : 3MHz
 ;*
         Sub Clock : 32.768kHz
 ;
      .cpu 3001
 ;
 ;*
      Symbol Defnition
 ;
 TMA .equ h'ffb0 ;Timer Mode Register A
 SYSCR1 .equ h'fff0 ;System Control Register 1
 SYSCR2 .equ h'fff1
                    ;System Control Register 2
            h'fff3
                     ;Interrupt Enable Register 1
 IENR1 .equ
 IRR1
      .equ
           h'fff6
                     ;Interrupt Request Register 1
 ;
 ;*
      Vector Address
 ;
      .org h'0000
                  ;No.0 Reset Interrupt(H'0000-H'0001)
      .data.w MAIN
 ;
            h'0008
      .org
      .data.w
           MAIN
                     ;No.4 _IRQ0 Interrupt(H'0008-H'0009)
      .data.w
                     ;No.5 _IRQ1 Interrupt(H'000A-H'000B)
             MAIN
      .data.w
                     ;No.6 _IRQ2 Interrupt(H'000C-H'000D)
             MAIN
                     ;No.7 _IRQ3 Interrupt(H'000E-H'000F)
      .data.w
             MAIN
Rev. 1.0, 08/99, page 114 of 151
```

|         | .data.w    | MAIN                      | ;No.8 _IRQ4 Interrupt(H'0010-H'0011)            |
|---------|------------|---------------------------|-------------------------------------------------|
|         | .data.w    | MAIN                      | ;No.9 _WKP0WKP7 Interrupt(H'0012-H'0013)        |
| ;       |            |                           |                                                 |
|         | .org       | h'0016                    |                                                 |
|         | .data.w    | TAINT                     | ;No.11 Timer A Interrupt(H'0016-H'0017)         |
|         | .data.w    | MAIN                      | ;No.12 AEC Interrupt(H'0018-H'0019)             |
|         | .data.w    | MAIN                      | ;No.13 Timer C Interrupt(H'001A-H'001B)         |
|         | .data.w    | MAIN                      | ;No.14 Timer FL Interrupt(H'001C-H'001D)        |
|         | .data.w    | MAIN                      | ;No.15 Timer FH Interrupt(H'001E-H'001F)        |
|         | .data.w    | MAIN                      | ;No.16 Timer G Interrupt(H'0020-H'0021)         |
|         | .data.w    | MAIN                      | ;No.17 SCI31 Interrupt(H'0022-H'0023)           |
|         | .data.w    | MAIN                      | ;No.18 SCI32 Interrupt(H'0024-H'0025)           |
|         | .data.w    | MAIN                      | ;No.19 A/D Converter Interrupt(H'0026-H'0028)   |
|         | .data.w    | MAIN                      | ;No.20 Direct Transfer Interrupt(H'0028-H'0029) |
| ;       |            |                           |                                                 |
| ;****** | ******     | * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * *         |
| ;*      | MAIN : Ma: | in Routine                |                                                 |
| ;****** | ******     | * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * *         |
| ;       |            |                           |                                                 |
|         | .org       | h'1000                    |                                                 |
| ;       |            |                           |                                                 |
| MAIN:   | .equ       | \$                        |                                                 |
|         | mov.w      | #h'ff80,sp                | ;Initialize Stack Pointer                       |
|         | orc        | #h'80,ccr                 | ;Interrupt Disable                              |
| ;       |            |                           |                                                 |
|         | mov.b      | #h'e7,r01                 | ;Initialize System Control Regsiter             |
|         | mov.b      | r01,@SYSCR1               |                                                 |
|         | mov.b      | #h'f0,r01                 |                                                 |
|         | mov.b      | r01,@SYSCR2               |                                                 |
| ;       |            |                           |                                                 |
|         | bclr       | #7,@IRR1                  |                                                 |
|         | mov.b      | #h'80,r01                 |                                                 |
|         | mov.b      | r01,@IENR1                |                                                 |
|         |            |                           |                                                 |
| ;       |            |                           |                                                 |
|         | mov.b      | <pre>#h'ff,r01</pre>      |                                                 |
|         | mov.b      | r0l,@TMA                  |                                                 |
|         |            |                           |                                                 |

```
mov.b
          #h'1a,r01
     mov.b
          r0l,@TMA
;
     andc
          #h'7f,ccr
;
     sleep
;
     nop
;
EXIT:
    bra
          EXIT
;
;*
    TMAINT : Timer A Interrupt Routine
;
TAINT: .equ
           $
    bclr
          #7,@IRR1
;
    mov.b
          #h'00,r01
    mov.b
          r01,@IENR1
;
    rte
;
```

.end

# 2.7 Module Standby Mode Settings

| Module Standby Mode Settings | MCU:           | Functions Used:     |
|------------------------------|----------------|---------------------|
|                              | H8/3867 Series | Module Standby Mode |

# Settings

Module standby halts the supply of the system clock to the module and stops module functions. Module standby can be set for individual peripheral functions. All built-in peripheral modules can be set to module standby mode.

## Setting module standby mode

Module standby mode can be set for a particular module by clearing the corresponding bits of the clock stop register 1 (CKSTPR1) and clock stop register 2 (CKSTPR2) to 0.

## Canceling module standby mode

Module standby mode can be cancelled for a particular module by setting the corresponding bits of the clock stop register 1 (CKSTPR1) and clock stop register 2 (CKSTPR2) to 1.

After reset, CKSTPR1 and CKSTPR2 are both initialized to H'FF.

# Explanation of CKSTPR1 and CKSTPR2 registers

Table 1 gives explanations of the CKSTPR1 and CKSTPR2 registers.

# Table 1 Explanations of CKSTPR1 and CKSTPR2 Registers

| Register<br>Name | Bit<br>Number | Bit<br>Name   | Set<br>Value | Description                               |
|------------------|---------------|---------------|--------------|-------------------------------------------|
| CKSTPR1          | Bit 6         | S31CKSTP      | 0            | Sets SCI3-1 to module standby mode        |
|                  |               |               | 1            | Cancels SCI3-1 module standby mode        |
|                  | Bit 5         | S32CKSTP      | 0            | Sets SCI3-2 to module standby mode        |
|                  |               |               | 1            | Cancels SCI3-2 module standby mode        |
|                  | Bit 4         | ADCKSTP       | 0            | Sets A/D converter to module standby mode |
|                  |               |               | 1            | Cancels A/D converter module standby mode |
|                  | Bit 3         | TGCKSTP       | 0            | Sets timer G to module standby mode       |
|                  |               |               | 1            | Cancels timer G module standby mode       |
|                  | Bit 2         | TFCKSTP       | 0            | Sets timer F to module standby mode       |
|                  |               |               | 1            | Cancels timer F module standby mode       |
|                  | Bit 1         | Bit 1 TCCKSTP |              | Sets timer C to module standby mode       |
|                  |               |               | 1            | Cancels timer C module standby mode       |
|                  | Bit 0         | TACCKSTP      | 0            | Sets timer A to module standby mode       |
|                  |               |               | 1            | Cancels timer A module standby mode       |
| CKSTPR2          | Bit 3         | AECKSTP       | 0            | Sets AEC to module standby mode           |
|                  |               |               | 1            | Cancels AEC module standby mode           |
|                  | Bit 2         | WDCKSTP       | 0            | Sets WDT to module standby mode           |
|                  |               |               | 1            | Cancels WDT module standby mode           |
|                  | Bit 1         | PWCKSTP       | 0            | Sets PWM to module standby mode           |
|                  |               |               | 1            | Cancels PWM module standby mode           |
|                  | Bit 0         | LDCKSTP       | 0            | Sets LCD to module standby mode           |
|                  |               |               | 1            | Cancels LCD module standby mode           |

## Example of module standby mode settings

1. Function

In this example, while in active (high-speed) mode, timer F and timer G are set to module standby mode, and then make a transition to watch mode.

- 2. Notes
  - a. Operation continues in watch mode only when an external clock is input as the timer F and timer G input clock, or when  $\phi_w/4$  is selected as the internal clock. If any other clock is selected, operation is stopped while in watch mode. Hence under these settings, after setting the timer F, timer G input clock to  $\phi_w/4$ , timer F and timer G should be set to module standby mode before the transition to watch mode.
  - b. For the settings of this example, all interrupt requests are disabled, so that if there is a transition to watch mode, watch mode can only be canceled by input from the RES pin.

## Flowchart



#### **Program Lists**

```
;*
   H8/3867 Application Note
;*
; *
    'Module Standby Mode
;*
     -In Watch Mode, Timer F&G Module Stsndby Mode Set
;*
;*
        Function : Module Standby Mode
; *
        External Clock : 6MHz
;*
        Internal Clock : 3MHz
;*
        Sub Clock : 32.768kHz
;*
;
     .cpu 3001
;
;*
     Symbol Defnition
;
TMA
  .equ h'ffb0
                    ;Timer Mode Register A
         h'ffb6 ;Timer Control Register F
TCRF
    .equ
    .equ
           h'ffb7
                   ;Timer Control/Status Register F
TCSRF
OCRFH
           h'ffba
                   ;Output Compare Register FH
    .equ
OCRFL
           h'ffbb
                    ;Output Compare Register FL
     .equ
TMG
           h'ffbc
                    ;Timer Mode Register G
     .equ
SYSCR1 .equ
           h'fff0
                    ;System Control Register 1
    .equ h'fff1
                    ;System Control Register 2
SYSCR2
IENR2
    .equ h'fff4
                    ;Interrupt Enable Register 2
IRR2
           h'fff7
                    ;Interrupt Request Register 2
    .equ
           h'fffa
                   ;Clock Stop Register 1
CKSTPR1 .equ
CKSTPR2 .equ
           h'fffb
                   ;Clock Stop Register 2
;
;*
     Vector Address
;
```

```
h'0000
        .org
        .data.w
                 MAIN
                            ;No.0 Reset Interrupt(H'0000-H'0001)
;
                 h'0008
        .org
                            ;No.4 _IRQ0 Interrupt(H'0008-H'0009)
        .data.w
                 MAIN
                 MAIN
                             ;No.5 _IRQ1 Interrupt(H'000A-H'000B)
        .data.w
                 MAIN
                             ;No.6 _IRQ2 Interrupt(H'000C-H'000D)
        .data.w
                             ;No.7 _IRQ3 Interrupt(H'000E-H'000F)
        .data.w
                 MAIN
        .data.w
                             ;No.8 _IRQ4 Interrupt(H'0010-H'0011)
                 MAIN
                             ;No.9 _WKP0-_WKP7 Interrupt(H'0012-H'0013)
        .data.w
                 MAIN
;
        .org
                 h'0016
                            ;No.11 Timer A Interrupt(H'0016-H'0017)
        .data.w
                 MAIN
                             ;No.12 AEC Interrupt(H'0018-H'0019)
        .data.w
                 MAIN
                             ;No.13 Timer C Interrupt(H'001A-H'001B)
        .data.w
                 MAIN
                             ;No.14 Timer FL Interrupt(H'001C-H'001D)
        .data.w
                 MAIN
                             ;No.15 Timer FH Interrupt(H'001E-H'001F)
        .data.w
                 MAIN
                             ;No.16 Timer G Interrupt(H'0020-H'0021)
        .data.w
                 MAIN
                             ;No.17 SCI31 Interrupt(H'0022-H'0023)
        .data.w
                 MAIN
                             ;No.18 SCI32 Interrupt(H'0024-H'0025)
        .data.w
                 MAIN
                            ;No.19 A/D Converter Interrupt(H'0026-H'0028)
        .data.w
                 MAIN
                            ;No.20 Direct Transfer Interrupt(H'0028-H'0029)
        .data.w
                 MAIN
;
;*
       MAIN : Main Routine
;
        .org
                 h'1000
;
MAIN:
       .equ
                 $
                 #h'ff80,sp ;Initialize Stack Pointer
       mov.w
       orc
                 #h'80,ccr
                             ;Interrupt Disable
;
       mov.w
                 #h'8ff0,r0
                            ;Initialize System Control Regsiter
                 r0h,@SYSCR1
       mov.b
       mov.b
                 r01,@SYSCR2
                 #h'18,r0l ;Initialize Timer Mode Register
       mov.b
```

```
Rev. 1.0, 08/99, page 122 of 151
```

mov.b r01,@TMA

;

```
sub.b
                   r01,r01
                                ;Initialize Timer F
                   r01,@IRR2
        mov.b
        mov.b
                   r01,@IENR2
                   #h'ff,r01
        mov.b
        mov.b
                  r01,@OCRFH
                  r01,@OCRFL
        mov.b
        mov.b
                  #h'10,r01
                  r01,@TCSRF
        mov.b
        mov.b
                   #h'07,r01
                   r01,@TCRF
        mov.b
;
                               ;Initialize Timer G
        mov.b
                   #h'03,r01
                   r01,@TMG
        mov.b
;
                   #h'f3ff,r0 ;Timer F & G Module Standby Mode ON
        mov.w
        mov.b
                   r0h,@CKSTPR1
                   r01,@CKSTPR2
        mov.b
;
        andc
                   #h'7f,ccr ;Interrupt Enable
;
                                ;Transfer to Watch Mode
        sleep
        nop
;
EXIT:
                   EXIT
        bra
;
        .end
```

# 2.8 Clock Operation Using Timer F

| Clock Operation Using Timer F | MCU:           | Functions Used: |
|-------------------------------|----------------|-----------------|
|                               | H8/3867 Series | Timer F         |

# **Specifications**

- 1. A 38.4-kHz subclock is used for clock operation employing timer F.
- 2. Timer F interrupts are issued every 1 sec, and a counter provided for clock use in RAM is incremented.
- 3. The clock counter provided in RAM has eight bits for counting seconds and eight bits for counting minutes; it begins counting from 00 min, 00 sec, and after counting up to 59 min, 59 sec, in the next cycle it is initialized to 00 min, 00 sec and continues counting.
- 4. After completion of initialization, there is a transition from active (high-speed) mode to watch mode, a timer F interrupt request causes a transition to subactive mode, the counter provided in RAM is incremented, and there is another transition to watch mode.
- 5. The mode transition diagram for this task example is shown in figure 1.



Figure 1 Diagram of Mode Transitions for this Task Example

# **Explanation of Functions Used**

- 1. In this task example, clock operation is performed in which timer F is used to increment a counter provided in RAM every second. The features of timer F are as follows.
  - Four different internal clocks ( $\phi/32$ ,  $\phi/16$ ,  $\phi/4$ ,  $\phi_w/4$ ) or an external clock can be selected (external event counting is possible).
  - A single compare-match signal can be used for a toggle output to the TMOFH pin (the initial value of the toggle output can be set).
  - The counter can be reset by a compare-match signal.
  - There are a total of two interrupt factors: one compare-match, and one overflow.
  - Operation as two independent 8-bit timers (timer FH and timer FL) is also possible (in 8-bit mode).
  - When  $\phi_w/4$  is selected as the internal clock, operation in watch mode, subactive mode, and sleep mode is possible.
  - Using the module standby mode, it is possible to set standby mode in module units when not in use.



2. Figure 2 shows a block diagram of the timer F 16-bit compare match function used in this task example.

Figure 2 Block Diagram of Timer F 16-Bit Compare Match Function

#### 3. Table 1 explains timer F functions.

#### Table 1Timer F Functions

#### Timer control register F (TCRF)

Functions TCRF is an 8-bit write-only register. It switches between 16-bit mode and 8-bit mode, selects between four types of internal clocks and an external event, and sets the output levels of the TMOFH and TMOFL pins. On reset, TCRF is initialized to H'00.

#### Timer control status register F (TCSRF)

Functions TCSRF is an 8-bit read/write register. It selects counter clear, sets the overflow flag, sets the compare match flag, and enables interrupt requests due to overflows.

#### 16-bit timer counter F (TCF)

Functions TCF is a 16-bit read/write up-counter. It consists of cascade connections of the 8-bit timer counters (TCFH and TCFL). In addition to use as a 16-bit counter employing TCFH for the upper eight bits and TCFL for the lower eight bits, TCFH and TCFL can also be used as independent 8-bit counters. TCFH and TCFL can be read and written from the CPU, but when used in 16-bit mode, data transfer with the CPU is via a temporary register (TEMP). On reset, TCFH and TCFL are both initialized to H'00.

If the CKSH2 bit of TCRF is clear to 0, then TCF functions as a 16-bit counter. The TCF input clock can be selected using the CKSL2 to CKSL0 bits of TCRF. The CCLRH bit of TCSRF can be used to clear TCF on compare match. When TCF overflows, the OVFH bit of TCSRF is set to 1, and if the IENTFH bit of IENR2 is 1, an interrupt request is sent to the CPU.

#### 8-bit timer counter FH (TCFH)

Functions TCFH can be made to operate as an independent 8-bit counter by setting the CKSH2 bit of TCRF to 1. The TCFH input clock is selected using the CKSH2 to CKSH0 bits of TCRF. The CCLRH bit of TCSRF can be used to clear TCFH on a compare match. When there is an overflow of TCFH, the OVFH bit of TCSRF is set to 1. At this time, if the OVIEH bit of TCSRF is 1, the IRRTFH bit of IRR2 is set to 1, and if the IENTFH bit of IENR2 is 1, an interrupt request is sent to the CPU.

#### 8-bit timer counter FL (TCFL)

Functions TCFL can be made to operate as an independent 8-bit counter by setting the CKSH2 bit of TCRF to 1. The TCFL input clock is selected using the CKSL2 to CKSL0 bits of TCRF. The CCLRL bit of TCSRF can be used to clear TCFL on a compare match. When there is an overflow of TCFL, the OVFL bit of TCSRF is set to 1. At this time, if the OVIEL bit of TCSRF is 1, the IRRTFL bit of IRR2 is set to 1, and if the IENTFL bit of IENR2 is 1, an interrupt request is sent to the CPU.

#### Table 1Timer F Functions (cont)

## 16-bit output compare register F (OCRF)

Functions OCRF consists of two 8-bit read/write registers (OCRFH and OCRFL). In addition to being used as a 16-bit register of which OCRFH is the upper eight bits and OCRFL is the lower eight bits, OCRFH and OCRFL can also be used as independent 8-bit registers. OCRFH and OCRFL can be read and written from the CPU, but when used in 16-bit mode, data transfer with the CPU is via TEMP. On reset, OCRFH and OCRFL are both initialized to H'FF.

On clearing the CKSH2 bit of TCRF to 0, OCRF operates as a 16-bit register. The contents of OCRF are constantly compared with TCF, and if the values of the two match, the CMFH bit of TCSRF is set to 1. At the same time, the IRRTFH bit of IRR2 is also set to 1. At this time if the IENTFH bit of IENR2 is 1, an interrupt request is sent to the CPU. The toggle output of a compare match can be output from the TMOFH pin. In addition, the TOLH bit of TCRF can be used to select the output level (high/low).

#### 8-bit output compare register FH (OCRFH)

Functions When the CKSH2 bit of TCRF is set to 1, OCRF operates as two 8-bit registers (OCRFH and OCRFL). The contents of OCRFH are compared with TCFH, and the contents of OCRFL are compared with TCFL. If the values of OCRFH and TCFH match, the CMFH bit of TCSRF is set to 1. At the same time, the IRRTFH bit of IRR2 is also set to 1. At this time if the IENTFH bit of IENR2 is 1, an interrupt request is sent to the CPU. The toggle output of a compare match can be output from the TMOFH pin. In addition, the TOLH pin of TCRF can be used to select the output level (high/low).

## 8-bit output compare register FL (OCRFL)

Functions When the CKSH2 bit of TCRF is set to 1, OCRF operates as two 8-bit registers (OCRFH and OCRFL). The contents of OCRFH are compared with TCFH, and the contents of OCRFL are compared with TCFL. If the values of OCRFL and TCFL match, the CMFL bit of TCSRF is set to 1. At the same time, the IRRTFL bit of IRR2 is also set to 1. At this time if the IENTFL bit of IENR2 is 1, an interrupt request is sent to the CPU. The toggle output of a compare match can be output from the TMOFL pin. In addition, the TOLL pin of TCRF can be used to select the output level (high/low).

#### Timer FH interrupt request flag (IRRTFH)

Functions IRRTFH of the OCRFH register is set to 1, if TCF matches OCRF in 16-bit mode, if TCFH matches OCRFH in 8-bit mode, or if TCF and TCFH overflow when IENTFH is set to 1. IRRTFH is cleared to 0, if IRRTFH is written to 1 when IRRTFH is set to 1.

## Timer FL interrupt request flag (IRRTFL)

Functions IRRTFL of the OCRFL register is set to 1, if TCFL matches OCRFL in 8-bit mode or if TCFL overflows when IENTFL is set to 1. IRRTFL is cleared to 0, if IRRTFL is written to 1 when IRRTFL is set to 1.

#### Table 1Timer F Functions (cont)

| Timer FH i  | nterrupt enable (IENTFH)                                                                          |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Functions   | IENTFH enables or disables interrupt requests caused by timer FH compare matches<br>or overflows. |  |  |  |  |  |
| Timer FL ir | nterrupt enable (IENTFL)                                                                          |  |  |  |  |  |
| Functions   | IENTFL enables or disables interrupt requests caused by timer FL compare matches or overflows.    |  |  |  |  |  |
| Timer F ev  | ent input (TMIF)                                                                                  |  |  |  |  |  |
| Functions   | TIMF is used as an event input pin to be input to the TCFL.                                       |  |  |  |  |  |
| Timer FH o  | utput (TMOFH)                                                                                     |  |  |  |  |  |
| Functions   | TMOFH is a timer FH toggle output pin.                                                            |  |  |  |  |  |
| Timer FL o  | utput (TMOFL)                                                                                     |  |  |  |  |  |
| Functions   | TMOFL is a timer FL toggle output pin.                                                            |  |  |  |  |  |
|             |                                                                                                   |  |  |  |  |  |

4. The method for setting the timer FH interrupt cycle is explained below.

In this task example, 38.4 kHz is used as the subclock, and the timer F operates as a clock time base.

By setting TCRF CKSL2 to 1, CKSL1 to 1 and CKSL0 to 1, the TCF input clock is set to  $\phi_w/4$ . Here  $\phi_w/4$  is given by

 $\phi_{\rm w}/4 = 38.4 \text{ kHz}/4 = 9.6 \text{ kHz}$ 

Hence the TCF input clock cycle is

 $1/9.6 \text{ kHz} \cong 104.167 \ \mu s$ 

Here if OCRF is set to H'2580, then the time until the values of TCF and OCRF match is calculated as

 $H'2580 \times (1/9.6 \text{ kHz}) = 9600 \times 104.167 \ \mu s = 1 \text{ sec}$ 

Hence the settings for OCRF used to set the timer FH interrupt cycle  $T_{_{FH}}$  are calculated by the following equation.

OCRF setting =  $T_{FH}/(1/9.6 \text{ kHz}) = T_{FH} \times 9.6 \text{ kHz}$ 

Table 2 shows timer FH interrupt cycle  $T_{_{FH}}$  values and OCRA setting examples.

Rev. 1.0, 08/99, page 129 of 151

| T <sub>FH</sub> (sec) | Calculation                | OCRA Setting |
|-----------------------|----------------------------|--------------|
| 0.125                 | 0.125 sec × 9.6 kHz = 1200 | H'04B0       |
| 0.25                  | 0.25 sec × 9.6 kHz = 2400  | H'0960       |
| 0.5                   | 0.5 sec × 9.6 kHz = 4800   | H'12C0       |
| 1                     | 1 sec × 9.6 kHz = 9600     | H'2580       |
| 0.125                 | 2 sec × 9.6 kHz = 19200    | H'4B00       |

Table 2 Examples of Timer FH Interrupt Cycles and OCRF Settings

5. The interface with the CPU is explained below.

TCF and OCRF are 16-bit read/write registers. On the other hand, the data bus between the CPU and internal peripheral modules has an 8-bit data width. Hence when the CPU accesses TCF or OCRF, it must do so via the 8-bit temporary register (TEMP).

When reading or writing TCF or writing OCRF in 16-bit mode, operations must always be performed in 16-bit units (with byte-size MOV instructions executed twice in succession), in the order of the upper byte and lower byte. If only the upper byte or only the lower byte is accessed, the data is not transferred correctly.

In 8-bit mode, there are no restraints on access order.

a. Write operation

By writing the upper byte, the upper byte data is transferred to TEMP. Next the lower byte is written; the data in TEMP is written to the upper byte register, and the lower-byte data is written directly to the lower byte register.

The TCF write operation when H'AA55 is written to TCF is illustrated in figure 3.



Figure 3 TCF Write Operation

b. Read operation

In the case of TCF, when the upper byte is read, the upper byte data is transferred directly to the CPU, and the lower byte data is transferred to TEMP. Next the lower byte data is read; the lower byte data in TEMP is transferred to the CPU.

In the case of OCRF, in upper byte reading the upper byte data is transferred directly to the CPU. In lower byte reading the lower byte data is also transferred directly to the CPU. Figure 4 shows a TCF read operation when TCF contains H'AAFF.



Figure 4 TCF Read Operation

6. Notes on use of the timer F

While the timer F is operating in 16-bit timer mode, the following conflicts and operations may occur.

- a. When all bits match and a compare match signal is generated, the TMOFH pin output is toggled. When TCRF writing by a MOV instruction and a compare match signal occur simultaneously, TOLH data resulting from TCRF writing is output to pin TMOFH. In 16-bit mode, the TMOFL pin output is undefined, and should not be used. Use it as a port instead.
- b. When OCRFL writing and compare match signal generation occur simultaneously, the compare match signal is invalid. However, when the data to be written matches the counter value, at that point a compare match signal is generated. The compare match signal is output in synchronization with the TCFL clock, so that if the clock is stopped, no compare match signal is generated even if a compare match occurs.
- c. When all 16 bits match and a compare match signal is generated, the compare match flag CMFH is set. Similarly, if conditions for the lower 8 bits are satisfied, CMFL is set.
- d. When there is a TCF overflow, OVFH is set; but when the lower 8 bits of OVFL overflow, if set conditions are satisfied, OVFL is set. If TCFL writing and overflow signal output occur simultaneously, the overflow signal is not output.
- e. When, in active mode and sleep mode,  $\phi_w/4$  is selected as the TCF internal clock, the system clock and internal clock are out of synchronization, and so synchronization is secured by an internal synchronization circuit. This results in a maximum count cycle error of  $1/\phi$  (sec). In order to prevent this error from occurring, the system must be operated in subactive mode, subsleep mode, or watch mode.

7. Table 3 indicates function allocation in this task example.

| Function         | Function Allocation                                                                                                                                                                                             |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| TCRF             | Sets 16-bit mode and selects TCFL input clock.                                                                                                                                                                  |  |  |
| TCSRF            | Selects counter clear, sets the overflow flag, sets the compare match flag, and enables/disables interrupt requests due to overflows.                                                                           |  |  |
| TCF              | Functions as a 16-bit up-counter configured by the connection of 8-bit timer counters TCFH and TCFL. TCF counts internal clock ( $\phi_w/4$ ), and sets the IRTFH and CMFH bits to 1 if a compare match occurs. |  |  |
| OCRF             | 16-bit register configured by the connection of 8-bit registers OCRFH and OCRFL. If OCRF matches TCF, a compare match signal is generated.                                                                      |  |  |
| IRRTFH           | Indicates if a timer FH interrupt is requested or not.                                                                                                                                                          |  |  |
| IENTFH           | Enables or disables timer FH interrupt requests.                                                                                                                                                                |  |  |
| $\phi_{_{ m w}}$ | Subclock frequency, 38.4 kHz in this task example.                                                                                                                                                              |  |  |

# Table 3Function Allocation

# **Explanation of Operation**

1. Operation of the timer F 16-bit timer mode is explained below.

Timer F is a 16-bit counter which is incremented each time a clock pulse is input. The value of the timer counter F is continuously compared with the value set in the output compare register F; when they match, the counter is cleared, an interrupt request is issued, and port toggle output is possible. The timer can also operate as two independent 8-bit timers.

When the CKSH2 bit of the timer control register F (TCRF) is set to 0, timer F operates as a 16-bit timer.

Immediately after reset, the timer counter F (TCF) is set to H'0000, the output compare register F (OCRF) is set to H'FFFF, and the timer control register F (TCRF) and timer control status register F (TCSRF) are both initialized to H'00. The counter begins to be incremented by input from an external event (TMIF). The external event edge is selected through the IEG3 bit of the IRQ edge select register (IEGR).

As the operating clock for timer F, the CKSL2 through CKSL0 bits of TCRF can be used to select from three kinds of internal clock output by prescaler S, an internal clock which is 1/4 the subclock, or an external clock.

The contents of TCF and OCRF are continuously compared; when the two match, the CMFH bit of TCSRF is set to 1. At this time if the IENTFH bit of IENR2 is 1 an interrupt request is sent to the CPU, and at the same time the TMOFH pin output is toggled. Also, if the CCLRH bit of TCSRF is 1, TCF is cleared. The output from pin TMOFH can be set by the TOLH bit of TCRF.

When TCF overflows (H'FFFF  $\rightarrow$  H'0000), the OVFH bit of TCSRF is set to 1. At the time, if both the OVIEH bit of TCSRF and the IENTFH bit of IENR2 are 1, an interrupt request is sent to the CPU.

2. Timer F operating modes are indicated in table 4.

| Operating Mode | TCF                   | OCRF      | TCRF      | TCSRF     |
|----------------|-----------------------|-----------|-----------|-----------|
| Reset          | Reset                 | Reset     | Reset     | Reset     |
| Active         | Functions             | Functions | Functions | Functions |
| Sleep          | Functions             | Held      | Held      | Held      |
| Watch          | Functions/<br>Halted* | Held      | Held      | Held      |
| Subactive      | Functions/<br>Halted* | Functions | Functions | Functions |
| Subsleep       | Functions/<br>Halted* | Held      | Held      | Held      |
| Standby        | Halted                | Held      | Held      | Held      |
| Module standby | Halted                | Held      | Held      | Held      |

# Table 4Timer F Operating Modes

Note: \* If  $\phi_w/4$  is selected as the TCF's internal clock in active mode or sleep mode, the system clock and internal clock are mutually asynchronous, and so synchronization is established by a synchronization circuit. This results in a maximum error of  $1/\phi(s)$  in the count period. When the counter is operated in subactive mode, watch mode, or subsleep mode,  $\phi_w/4$  must always be selected as the internal clock. The counter will not operate if any other internal clock is selected.



3. Figure 5 illustrates the principle of operation in this task example.

## Figure 5 Operation Principle
## **Explanation of Software**

1. Explanation of Modules

Table 5 explains the modules in this task example.

#### Table 5Explanation of Modules

| Module Name                          | Label Name | Function                                                                                                                       |
|--------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------|
| Main routine                         | MAIN       | Initializes the stack pointer, RAM and timer F, enables interrupts, and executes a transition to watch mode.                   |
| Timer F interrupt processing routine | TFINT      | Clears IRRTFH and CMFH to 0, save register data,<br>increment and clear SEC and MIN defined in RAM,<br>restores register data. |

#### 2. Explanation of Arguments

In this task example, no arguments are used.

3. Explanation of Internal Registers Used

Table 6 gives explanations of the internal registers used in this task example.

|               |                                                                                                 |                                                                                                         | RAM            |           |
|---------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------|-----------|
| Register Name |                                                                                                 | Description                                                                                             | Address        | Setting   |
| TCRF CKSH     | CKSH2                                                                                           | Timer control register F                                                                                | H'FFB6         | CKSH2 = 0 |
|               | to                                                                                              | (Clock select H 2 to 0)                                                                                 | Bit 6 to bit 4 | CKSH1 = 0 |
| CKSH0         | Select the clock input to TCFH from among four internal clock source or TCFL overflow.          |                                                                                                         | CKSH0 = 0      |           |
|               | <ul> <li>When CKSH2 = 0, CKSH1 = 0 and<br/>CKSH0 = 0, TCFL overflow is selected</li> </ul>      |                                                                                                         |                |           |
|               | <ul> <li>When CKSH2 = 0, CKSH1 = 0 and<br/>CKSH0 = 1, TCFL overflow is selected</li> </ul>      |                                                                                                         |                |           |
|               | <ul> <li>When CKSH2 = 0, CKSH1 = 1 and<br/>CKSH0 = 0, TCFL overflow is selected</li> </ul>      |                                                                                                         |                |           |
|               |                                                                                                 | <ul> <li>When CKSH2 = 1, CKSH1 = 0 and<br/>CKSH0 = 0, internal clock φ/32 is selected</li> </ul>        |                |           |
|               |                                                                                                 | <ul> <li>When CKSH2 = 1, CKSH1 = 0 and<br/>CKSH0 = 1, internal clock \u00f6/16 is selected</li> </ul>   |                |           |
|               | <ul> <li>When CKSH2 = 1, CKSH1 = 1 and<br/>CKSH0 = 0, internal clock φ/4 is selected</li> </ul> |                                                                                                         |                |           |
|               |                                                                                                 | <ul> <li>When CKSH2 = 1, CKSH1 = 1 and<br/>CKSH0 = 1, internal clock <i>φ</i>w/4 is selected</li> </ul> |                |           |
|               |                                                                                                 | <ul> <li>Note that CKSH2 = 0, CKSH1 = 1 and<br/>CKSH0 = 1 cannot be specified</li> </ul>                |                |           |
|               |                                                                                                 |                                                                                                         |                |           |

## Table 6Explanation of Internal Registers Used

| Register Name    |             | Description                                                                                      | RAM<br>Address           | Setting                |
|------------------|-------------|--------------------------------------------------------------------------------------------------|--------------------------|------------------------|
| TCRF CKSL2<br>to | CKSL2<br>to | Timer control register F<br>(Clock select L 2 to 0)                                              | H'FFB6<br>Bit 2 to bit 0 | CKSL2 = 1<br>CKSL1 = 1 |
|                  | CKSL0       | Select the clock input to TCFL from among four internal clock source or an external event.       |                          | CKSL0 = 1              |
|                  |             | <ul> <li>When CKSL2 = 0, CKSL1 = 0 and<br/>CKSL0 = 0, an external event is selected</li> </ul>   |                          |                        |
|                  |             | <ul> <li>When CKSL2 = 0, CKSL1 = 0 and<br/>CKSL0 = 1, an external event is selected</li> </ul>   |                          |                        |
|                  |             | <ul> <li>When CKSL2 = 0, CKSL1 = 1 and<br/>CKSL0 = 0, an external event is selected</li> </ul>   |                          |                        |
|                  |             | <ul> <li>When CKSL2 = 1, CKSL1 = 0 and<br/>CKSL0 = 0, internal clock φ/32 is selected</li> </ul> |                          |                        |
|                  |             | <ul> <li>When CKSL2 = 1, CKSL1 = 0 and<br/>CKSL0 = 1, internal clock φ/16 is selected</li> </ul> |                          |                        |
|                  |             | <ul> <li>When CKSL2 = 1, CKSL1 = 1 and<br/>CKSL0 = 0, internal clock φ/4 is selected</li> </ul>  |                          |                        |
|                  |             | <ul> <li>When CKSL2 = 1, CKSL1 = 1 and<br/>CKSL0 = 1, internal clock φw/4 is selected</li> </ul> |                          |                        |
|                  |             | • Note that CKSL2 = 0, CKSL1 = 1 and CKSL0 = 1 cannot be specified                               |                          |                        |
| TCSRF            | OVFH        | Timer control/status register F<br>(Timer overflow flag H)                                       | H'FFB7<br>Bit 7          | 0                      |
|                  |             | A status flag indicating overflow of TCF.                                                        | 2                        |                        |
|                  |             | • When OVFH = 0, indicates no overflow of TCF                                                    |                          |                        |
|                  |             | • When OVFH = 1, indicates TCF overflow                                                          |                          |                        |
| TCSRF            | CMFH        | Timer control/status register F<br>(Compare match flag H)                                        | H'FFB7<br>Bit 6          | 0                      |
|                  |             | A status flag indicating that TCF has matched OCRF.                                              |                          |                        |
|                  |             | <ul> <li>When CMFH = 0, indicates no compare<br/>match between TCF and OCRF</li> </ul>           |                          |                        |
|                  |             | <ul> <li>When CMFH = 1, indicates TCF has<br/>matched OCRF</li> </ul>                            |                          |                        |

| Register Name | Description                                                                                                                                | RAM<br>Address  | Setting |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| TCSRF OVIEH   | Timer control/status register F<br>(Timer overflow interrupt enable H)                                                                     | H'FFB7<br>Bit 5 | 1       |
|               | Enables or disables interrupt generation when TCF overflows.                                                                               |                 |         |
|               | <ul> <li>When OVIEH = 0, disables TCF overflow<br/>interrupt requests</li> </ul>                                                           |                 |         |
|               | • When OVIEH = 1, enables TCF overflow<br>interrupt requests                                                                               |                 |         |
| TCSRF CCLRH   | Timer control/status register F<br>(Counter clear H)                                                                                       | H'FFB7<br>Bit 4 | 1       |
|               | Selects whether or not TCF is cleared when TCF has matched OCRF.                                                                           |                 |         |
|               | • When CCLRH = 0, disables TCF clear by compare match                                                                                      |                 |         |
|               | • When CCLRH = 1, enables TCF clear by compare match                                                                                       |                 |         |
| TCFH          | Timer counter FH                                                                                                                           | H'FFB8          | H'00    |
|               | Upper 8 bits of 16-bit timer counter F (TCF);<br>functions as an 8-bit up-counter using a TCFL<br>overflow signal as an input clock.       |                 |         |
| TCFL          | Timer counter FL                                                                                                                           | H'FFB9          | H'00    |
|               | Lower 8 bits of 16-bit timer counter F (TCF);<br>functions as an 8-bit up-counter using $\phi$ w/4 of<br>internal clock as an input clock. |                 |         |
| OCRFH         | Output compare register FH                                                                                                                 | H'FFBA          | H'25    |
|               | Upper 8 bits of 16-bit output compare register (OCRF); generates a compare match signal when OCRF has matched TCF.                         |                 |         |
| OCRFL         | Output compare register FL                                                                                                                 | H'FFBB          | H'80    |
|               | Lower 8 bits of 16-bit output compare register (OCRF); generates a compare match signal when OCRF has matched TCF.                         |                 |         |

| Register I | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RAM<br>Address  | Setting |
|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| IENR2      | IENTFH | <ul> <li>Interrupt enable register 2<br/>(Timer FH interrupt enable)</li> <li>Enables or disables timer FH interrupt requests.</li> <li>When IENTFH = 0, disables timer FH<br/>interrupt requests</li> <li>When IENTFH = 1, enables timer FH<br/>interrupt requests</li> </ul>                                                                                                                                                                                                                                                                                                                                         | H'FFF4<br>Bit 3 | 1       |
| IRR2       | IRRTFH | <ul> <li>Interrupt request register 2<br/>(Timer FH interrupt request flag)</li> <li>Indicates whether there has been a timer FH<br/>interrupt request.</li> <li>When IRRTFH = 0, indicates that no timer<br/>FH interrupt has been requested</li> <li>When IRRTFH = 1, indicates that a timer<br/>FH interrupt has been requested</li> </ul>                                                                                                                                                                                                                                                                          | H'FFF7<br>Bit 3 | 0       |
| SYSCR1     | SSBY   | <ul> <li>System control register 1<br/>(Software standby)</li> <li>Carries out transitions to standby mode or<br/>watch mode.</li> <li>When SSBY = 0, after executing a SLEEP<br/>instruction in active mode, causes a transition<br/>to sleep mode, or after executing a SLEEP<br/>instruction in subactive mode, causes a<br/>transition to subsleep mode.</li> <li>When SSBY = 1, after executing a SLEEP<br/>instruction in active mode, causes a transition<br/>to standby mode or to watch mode, or after<br/>executing a SLEEP instruction in subactive<br/>mode, causes a transition to watch mode.</li> </ul> | H'FFF0<br>Bit 7 | 1       |

| Register                    | Name         | Description                                                                                                                                                                                                                                                                                                                                                                        | RAM<br>Address           | Setting              |
|-----------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------|
| SYSCR1 STS2<br>STS1<br>STS0 | STS2<br>STS1 | System control register 1<br>(Standby timer select 2 to 0)                                                                                                                                                                                                                                                                                                                         | H'FFF0<br>Bit 6 to bit 4 | STS2 = 0<br>STS1 = 0 |
|                             | STS0         | Specify the time for the CPU and peripheral<br>functions to wait until the clock stabilizes when<br>standby mode or watch mode is canceled and a<br>transition is made to active mode due to a<br>specific interrupt. Note that the standby time<br>must be specified to be equal to or longer than<br>the oscillation stabilization time according to the<br>operating frequency. | STSO                     | STS0 = 0             |
|                             |              | • When STS2 to STS1 = 000, standby time is 8,192 states                                                                                                                                                                                                                                                                                                                            |                          |                      |
|                             |              | • When STS2 to STS1 = 001, standby time is 16,384 states                                                                                                                                                                                                                                                                                                                           |                          |                      |
|                             |              | • When STS2 to STS1 = 010, standby time is 32,768 states                                                                                                                                                                                                                                                                                                                           |                          |                      |
|                             |              | • When STS2 to STS1 = 011, standby time is 65,536 states                                                                                                                                                                                                                                                                                                                           |                          |                      |
|                             |              | • When STS2 to STS1 = 100, standby time is 131,072 states                                                                                                                                                                                                                                                                                                                          |                          |                      |
|                             |              | • When STS2 to STS1 = 101, standby time is 2 states                                                                                                                                                                                                                                                                                                                                |                          |                      |
|                             |              | • When STS2 to STS1 = 110, standby time is 8 states                                                                                                                                                                                                                                                                                                                                |                          |                      |
|                             |              | • When STS2 to STS1 = 111, standby time is 16 states                                                                                                                                                                                                                                                                                                                               |                          |                      |
| SYSCR1                      | LSON         | System control register 1<br>(Low speed on flag)                                                                                                                                                                                                                                                                                                                                   | H'FFF0                   | 1                    |
|                             |              | When watch mode is canceled, selects either the system clock ( $\phi$ ) or the subclock ( $\phi_{sub}$ ) as the CPU operating clock.                                                                                                                                                                                                                                               | Bit 3                    |                      |
|                             |              | <ul> <li>When LSON = 0, selects the system clock (φ) as the CPU operating clock</li> </ul>                                                                                                                                                                                                                                                                                         |                          |                      |
|                             |              | • When LSON = 1, selects the subclock $(\phi_{sub})$ as the CPU operating clock                                                                                                                                                                                                                                                                                                    |                          |                      |

| Register Name Description |                                                                                                                                                                                   | Description                                                                                                                                                                                                                                                                  | RAM<br>Address  | Setting |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|
| SYSCR2                    | DTON                                                                                                                                                                              | System control register 2<br>(Direct transfer on flag)                                                                                                                                                                                                                       | H'FFF1<br>Bit 3 | 0       |
|                           | Specifies whether or not to make direct<br>transitions among active (high-speed) mode,<br>active (medium-speed) mode, and subactive<br>mode when a SLEEP instruction is executed. |                                                                                                                                                                                                                                                                              |                 |         |
|                           |                                                                                                                                                                                   | <ul> <li>When DTON = 0, if a SLEEP instruction is<br/>executed in active mode, a transition to<br/>standby mode, watch mode or sleep mode<br/>occurs</li> </ul>                                                                                                              |                 |         |
|                           |                                                                                                                                                                                   | <ul> <li>When DTON = 1, if a SLEEP instruction is<br/>executed in active (high-speed) mode, a<br/>direct transition occurs to active (medium-<br/>speed) mode (when SSBY = 1, MSON = 1,<br/>LSON = 0) or to subactive mode (when<br/>SSBY = 1, TMA = 1, LSON = 1)</li> </ul> |                 |         |
| SYSCR2                    | MSON                                                                                                                                                                              | System control register 2<br>(Medium speed on flag)                                                                                                                                                                                                                          | H'FFF1<br>Bit 2 | 0       |
|                           |                                                                                                                                                                                   | Selects whether to operate in active (high-speed)<br>mode or in active (medium-speed) mode after<br>cancellation of standby mode, watch mode, or<br>sleep mode.                                                                                                              |                 |         |
|                           |                                                                                                                                                                                   | • When MSON = 0, operates in active (high-<br>speed) mode                                                                                                                                                                                                                    |                 |         |
|                           |                                                                                                                                                                                   | <ul> <li>When MSON = 1, operates in active<br/>(medium- speed) mode</li> </ul>                                                                                                                                                                                               |                 |         |
| ΤΜΑ                       | TMA3                                                                                                                                                                              | <ul> <li>Timer mode register A (Internal clock select 3)</li> <li>Selects the clock input to TCA.</li> <li>When TMA3 = 0, PSS is selected as the TCA input clock source</li> <li>When TMA3 = 1, PSW is selected as the TCA input clock source</li> </ul>                     | H'FFB0<br>Bit 3 | 1       |
|                           |                                                                                                                                                                                   |                                                                                                                                                                                                                                                                              |                 |         |

## 4. Explanation of RAM Usage

Table 7 explains RAM usage for this task example.

| Label Name | Function                                      | RAM Address | Modules Used |
|------------|-----------------------------------------------|-------------|--------------|
| SEC        | Counter used as a clock, counting the minutes | H'F780      | MAIN, TFINT  |
| MIN        | Counter used as a clock, counting the seconds | H'F781      | MAIN, TFINT  |

Table 7Explanation of RAM Usage

## Flowchart

1. Main routine



#### 2. Timer F interrupt processing routine



#### RENESAS

#### **Program Lists**

```
;*
   H8/3867 Application Note
 ;*
 ;*
   'Timer F -Clock Time Base-'
 ;*
 ;*
          Function : Timer F
 ;*
 ;*
          External Clock : 6MHz
 ;*
          Internal Clock : 3MHz
 ;*
          Sub Clock : 38.4kHz
 ;
      .cpu 3001
 ;
 ;*
      Symbol Defnition
 ;
 TMA .equ h'ffb0 ;Timer Mode Register A
                    ;Timer Control Register F
TCRF
      .equ h'ffb6
      .equ h'ffb7
                    ;Timer Control/Status Register F
TCSRF
                    ;8-bit Timer Counter FH
TCFH
            h'ffb8
      .equ
                    ;8-bit Timer Counter FL
            h'ffb9
TCFL
      .equ
OCRFH
      .equ
            h'ffba
                    ;Output Compare Register FH
            h'ffbb
                    ;Output Compare Register FL
 OCRFL
      .equ
 SYSCR1 .equ
            h'fff0
                    ;System Control Register 1
      .equ
                    ;System Control Register 2
 SYSCR2
            h'fffl
 IENR2
            h'fff4
                    ;Interrupt Enable Register 2
      .equ
 IRR2
      .equ
            h'fff7
                    ;Interrupt Request Register 2
 ;
 ;*
     RAM Allocation
 ;
 SEC .equ h'f780
                    ;Second Counter
MIN .equ
            h'f781
                     ;Minute Counter
Rev. 1.0, 08/99, page 148 of 151
```

#### RENESAS

Vector Address ;\* ; h'0000 .org MAIN ;No.0 Reset Interrupt(H'0000-H'0001) .data.w ; h'0008 .org ;No.4 \_IRQ0 Interrupt(H'0008-H'0009) .data.w MAIN .data.w MAIN ;No.5 \_IRQ1 Interrupt(H'000A-H'000B) ;No.6 \_IRQ2 Interrupt(H'000C-H'000D) .data.w MAIN ;No.7 \_IRQ3 Interrupt(H'000E-H'000F) .data.w MAIN ;No.8 \_IRQ4 Interrupt(H'0010-H'0011) .data.w MAIN ;No.9 \_WKP0-\_WKP7 Interrupt(H'0012-H'0013) .data.w MAIN ; h'0016 .org ;No.11 Timer A Interrupt(H'0016-H'0017) .data.w MAIN .data.w MAIN ;No.12 AEC Interrupt(H'0018-H'0019) ;No.13 Timer C Interrupt(H'001A-H'001B) .data.w MAIN .data.w ;No.14 Timer FL Interrupt(H'001C-H'001D) MAIN ;No.15 Timer FH Interrupt(H'001E-H'001F) .data.w TFINT .data.w ;No.16 Timer G Interrupt(H'0020-H'0021) MAIN .data.w MAIN ;No.17 SCI31 Interrupt(H'0022-H'0023) ;No.18 SCI32 Interrupt(H'0024-H'0025) .data.w MAIN .data.w MAIN ;No.19 A/D Converter Interrupt(H'0026-H'0028) .data.w MAIN ;No.20 Direct Transfer Interrupt(H'0028-H'0029) ; ;\* MAIN : Main Routine ; h'1000 .org ; MAIN: \$ .equ #H'ff80,sp ;Initialize Stack Pointer mov.w

;

#### RENESAS

#h'80,ccr ;Interrupt Disable

orc

;

|        | sub.b                 | r0l,r0l                     | ;Initialize RAM                         |
|--------|-----------------------|-----------------------------|-----------------------------------------|
|        | mov.b                 | r0l,@SEC                    |                                         |
|        | mov.b                 | r0l,@MIN                    |                                         |
| ;      |                       |                             |                                         |
|        | mov.b                 | #h'8c,r0l                   | ;Initialize System Control              |
|        | mov.b                 | r01,@SYSCR1                 |                                         |
|        | mov.b                 | #h'f0,r01                   |                                         |
|        | mov.b                 | r01,@SYSCR2                 |                                         |
|        | mov.b                 | #h'08,r01                   |                                         |
|        | mov.b                 | r0l.@TMA                    |                                         |
| ;      |                       | ,                           |                                         |
|        | mov b                 | #b'08 r01                   | Timer F Interrupt Enable                |
|        | mov b                 | r0l @TENR2                  | , i moi i moori apo imoro               |
| ;      |                       | 101/8111112                 |                                         |
| ,      | mov b                 | #b:25 r0b                   | :Initialize Timer F                     |
|        | mov b                 | #h 25,1011                  |                                         |
|        | mov b                 | rob @OCPFH                  |                                         |
|        | mov.b                 | rol cocpet                  |                                         |
|        | morr b                | 101,@OCRFL                  |                                         |
|        |                       | #11'30, POI                 |                                         |
|        | mov.b                 | rul,@TCSRF                  |                                         |
| i      |                       |                             |                                         |
|        | andc                  | #h'71,ccr                   | ;Interrupt Enable                       |
| ;      |                       |                             |                                         |
|        | mov.b                 | #h'07,r01                   | ;Initialize TCFL Input Clock            |
|        | mov.b                 | r01,@TCRF                   |                                         |
| ;      |                       |                             |                                         |
| LOOP:  | sleep                 |                             | ;Transfer to Watch Mode                 |
|        | nop                   |                             |                                         |
|        | bra                   | LOOP                        |                                         |
| ;      |                       |                             |                                         |
| ;***** | * * * * * * * * * * * | * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * * |
| ;*     | TFINT : T             | imer F Interr               | upt Routine                             |
| ;***** | * * * * * * * * * * * | ***********                 | ***********                             |
| ;      |                       |                             |                                         |
| TFINT: | .equ                  | \$                          |                                         |
|        | bclr                  | #3,@IRR2                    | ;Clear Timer F Interrupt Request Flag   |

## RENESAS

|         | bclr  | #6,@TCSRF | ;Clear Compare Match Flag H     |
|---------|-------|-----------|---------------------------------|
| ;       |       |           |                                 |
|         | push  | rO        | ;Store r0                       |
| ;       |       |           |                                 |
|         | mov.b | @SEC,r01  | ;Load Second Counter            |
|         | mov.b | @MIN,r0h  | ;Load Minute Counter            |
|         | inc   | rOl       | ;Increment Second Counter       |
|         | cmp.b | #h'3c,r01 | ;@SEC = d'60 ?                  |
|         | bne   | INTEXT    | ;No. Exit                       |
|         | mov.b | #h'00,r01 | ;Yes. Initialize Second Counter |
|         | inc   | r0h       | ;Increment Minute Counter       |
|         | cmp.b | #h'3c,r0h | ;@MIN = d'60 ?                  |
|         | bne   | INTEXT    | ;No. Exit                       |
|         | mov.b | #h'00,r0h | ;Yes. Initialize Minute Counter |
| ;       |       |           |                                 |
| INTEXT: | mov.b | r0h,@MIN  | ;Store Minute Counter           |
|         | mov.b | r01,@SEC  | ;Store Second Counter           |
| ;       |       |           |                                 |
|         | рор   | r0        | ;Restore r0                     |
| ;       |       |           |                                 |
|         | rte   |           |                                 |
| ;       |       |           |                                 |
|         | .end  |           |                                 |

## Renesas

# H8/3867 Series Application Note

| Publication Date: | 1st Edition, August 1999                                |
|-------------------|---------------------------------------------------------|
| Published by:     | Electronic Devices Sales & Marketing Group              |
|                   | Semiconductor & Integrated Circuits                     |
|                   | Hitachi, Ltd.                                           |
| Edited by:        | Technical Documentation Group                           |
|                   | UL Media Co., Ltd.                                      |
| Copyright © Hitad | chi, Ltd., 1999. All rights reserved. Printed in Japan. |