## (0) HITACHI

4-BIT SINGLE-CHIP MICROCOMPUTER DATA BOOK



# 4-BIT SINGLE-CHIP MICROCOMPUTER DATABOOK 

This advance data has been preliminarily prepared based on manuscript translated in Japan. Use this information with caution, therefore, as the accuracy of the copy cannot be guaranteed. A revised, U.S. edition of this technical data is currently in preparation, and may be ordered by returning the Business Reply Card at the back of this publication.

When using this manual, the reader should keep the following in mind:

1. This manual may, wholly or partially, be subject to change without notice.
2. All rights reserved: No one is permitted to reproduce or duplicate, in any form, the whole or part of this manual without Hitachi's permission.
3. Hitachi will not be responsible for any damage to the user that may result from accidents or any other reasons during operation of his unit according to this manual.
4. This manual neither ensures the enforcement of any industrial properties or other rights, nor sanctions the enforcement right thereof.

## INDEX

GENERAL INFORMATION

- Quick Reference Guide ..... 7
- Introduction of Packages ..... 11
- Quality Assurance ..... 19
- Reliability Test Data ..... 25
- Design Procedure and Support Tools for 4-bit Single-chip Microcomputers ..... 31
DATA SHEETS
- 4-bit Single-chip Microcomputer HMCS40 Series HMCS44C (HD44801), HMCS44CL (HD44808) ..... 38
HMCS45C (HD44820), HMCS45CL (HD44828) ..... 60
HMCS46C (HD44840), HMCS46CL (HD44848) ..... 82
HMCS47C (HD44860), HMCS47CL (HD44868) ..... 108
- 4-bit Single-chip Microcomputer HMCS40 Series Liquid Crystal Display Driving Type LCD-III (HD44790, HD44795) ..... 137
LCD-IV (HD613901) ..... 174
- 4-bit Single-chip Microcomputer HMCS400 Series HMCS404C (HD614042) ..... 221
HD614P080S ..... 258
- Evaluation Chip for 4-bit Single-chip Microcomputers HD44850E ..... 292
HD44857E ..... 293
HD44797E ..... 294
NEW DEVICES
HMCS404AC (HD614048) ..... 297
HMCS404CL (HD614045) ..... 335
NOTE: No new designs for HMCS 42/43/44A/45A/47A/42C/42CL/43C/43CL accepted after April 1984.


## GENERAL INFORMATION

- Quick Reference Guide
- Introduction of Packages
- Quality Assurance
- Reliability Test Data
- Design Procedure and Support Tools for 8-bit Single-chip Microcomputers


## QUICK REFERENCE GUIDE

- CMOS 4-BIT SINGLE-CHIP MICROCOMPUTER HMCS40 SERIES

* 1 Wide Temperature Range $\left(-40\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ version is available, except LCD.IV
* 2 Pattern Memory
- 3 LCD DRIVE FUNCTION

| LCD <br> Drive | Common | 4 |
| :--- | :--- | :---: |
|  | Segment | 32 |
|  | Duty | Static, $1 / 2,1 / 3,1 / 4$ |
|  | Bias | $1 / 2,1 / 3$ |
| Display Capability |  | $\mathbf{4 \times 3 2}$ Matrix $(1 / 4$ Duty) |

Expandable using the LCD Driver HD44100H.

| HMCS46CL <br> (HD44848) <br> HMCS46C <br> (HD44840) | HMCS47CL (HD44868) HMCS47C (HD44860) | $\begin{aligned} & \text { LCD-II *3 } \\ & \text { (HD44795, } \\ & \text { HD44790) } \end{aligned}$ | $\begin{aligned} & \text { LCD-IV**3 } \\ & \text { (HD613901) } \end{aligned}$ |
| :---: | :---: | :---: | :---: |
| 3/5 | 3/5 | 3/5 | 3/5 |
| 0.4/9 | 0.4/9 | 0.4/6 | 0.8/13.5 |
| $\mathrm{V}_{\mathrm{cc}}+0.3$ | $\mathrm{Vcc}^{+0.3}$ | $\mathrm{V}_{\mathrm{cc}}+0.3$ | $\mathrm{V}_{\mathrm{cc}}+0.3$ |
| -20 to +75 | -20 to +75 | -20 to +75 | -20 to +75 |
| DP-42, DP-42S | FP-54, DP-64S | FP-80 | FP-80 |
| $4,096 \times 10$ | $4,096 \times 10$ | $\begin{aligned} & 2,048 \times 10 \\ & 128 \times 10^{* 2} \end{aligned}$ | 4,096 $\times 10$ |
| $256 \times 4$ | $256 \times 4$ | $160 \times 4$ | $256 \times 4$ |
| 8 | 6 | 6 | 6 |
| 4 | 4 | 4 | 4 |
| - | - | $4 \times 1$ | $4 \times 1$ |
| - | $4 \times 1$ | $4 \times 1$ | $4 \times 1$ |
| $32-$ | 44 | 32 | $32-$ |
| $4 \times 4$ | $4 \times 6$ | $4 \times 2$ | $4 \times 2$ |
| $1 \times 16$ | $1 \times 16$ | $1 \times 16$ | $1 \times 16$ |
| 2 | 2 | 2 | 2 |
| 1. | 1 | 1 | 1 |
| 71 | 71 | 71 | 71 |
| 20/5 | 20/5 | 20/10 | 20/5 |
| Yes |  |  |  |
| No/Yes | No/Yes | Yes | No |
| Halt | Halt | Halt | Halt |
| HD44857E | HD44857E | HD44797E | HD44797E |
| 218 | 244 | 273 | 310 |

## - CMOS 4-BIT SINGLE-CHIP MICROCOMPUTER HMCS400 SERIES

| Family Name (Type Name) |  |  |  |  | $\begin{aligned} & \text { HMCS404C } \\ & \text { (HD614042) } \end{aligned}$ | HMCS404AC* |  | HMÇS404CL* |  | HD614P080S $\dagger$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Supply Voltage (V) |  |  |  | 4 to 6 |  | 4.5 to 6.0 |  | 2.7 to 6.0 |  | 4.5 to 5.5 |
|  | Power Dissipation |  | (typ) (mW) |  | 9.0 |  | 13.5 |  | 4.5 |  | 9.0 |
|  | Max. I/O Terminal Voltage |  | (V) |  | $\mathrm{V}_{\text {CC }}-40$ |  | $\mathrm{V}_{\text {cC }}-40$ |  | $\mathrm{VCC}^{\text {- }} 40$ |  | $\mathrm{V}_{\text {cc- }} 40$ |
|  | Operating Temperature Range |  |  |  | -20 to +75 |  | -20 to +75 |  | -20 to +75 |  | 20 to +75 |
|  | Package |  |  | FP-64, DP-64S |  | FP-64, DP-64S |  | FP-64, DP-64S |  | DC-64SP |  |
|  | Memory | ROM | (bits) |  | $4096 \times 10$ |  | $4096 \times 10$ |  | $4096 \times 10$ | $\begin{array}{r} \cdot 4,05 \\ \text { witl } \\ \text { EPF } \\ 08,19 \\ \text { with } \\ \text { EPF } \end{array}$ | 6-word $\times 10$-bit standard OM 2764 <br> 2-word $\times 10$-bit standard OM 27128 |
|  |  | RAM | (bits) |  | $256 \times 4$ |  | $256 \times 4$ |  | $256 \times 4$ |  | $576 \times 4$ |
|  | Registers |  |  |  | 7 |  | 7 |  | 7 |  | 7 |
|  | Stack Registers |  |  |  | 16 |  | 16 |  | 16 |  | 16 |
|  | 1/O Ports | 4-Bit Input |  | 58 | $4 \times 1$ <br> $2 \times 1$ | 58 | $\begin{array}{r} 4 \times 1 \\ 2 \times 1 \\ \hline \end{array}$ | 58 | $\begin{array}{r} 4 \times 1 \\ 2 \times 1 \end{array}$ | 58 | $\begin{aligned} & 4 \times 1 \\ & 2 \times 1 \\ & \hline \end{aligned}$ |
|  |  | 4-Bit Output |  |  | $4 \times 4$ |  | $4 \times 4$ |  | $4 \times 4$ |  | $4 \times 4$ |
|  |  | 4-Bit Input/Output |  |  | $4 \times 5$ |  | $4 \times 5$ |  | $4 \times 5$ |  | $4 \times 5$ |
|  |  | 1-Bit Input/Output |  |  | $1 \times 16$ |  | $1 \times 16$ |  | $1 \times 16$ |  | $1 \times 16$ |
|  | Interrupts | External |  |  | 2 |  | 2 |  | 2 |  | 2 |
|  |  | Timer/Counter |  |  | 2 |  | 2 |  | 2 |  | 2 |
|  |  | Serial Interface |  |  | 1 |  | 1 |  | 1 |  | 1 |
|  | Instructions | Number of Instructions |  |  | 99 |  | 99 |  | 99 |  | 99 |
|  |  | Cycle Time | ( $\mu \mathrm{s}$ ) |  | 2 |  | 1.33 |  | 4 |  | 1.33 |
|  | Built-in Clock Pulse Generator |  |  | Yes (External drive is possible) |  |  |  |  |  |  |  |
|  | Others |  |  | Low Power Dissipation Mode (Stop mode, Stand-by mode) |  |  |  |  |  |  |  |
| Raference Page |  |  |  |  | 357 |  | 394 |  | 396 |  | 398 |

* Under Development
+ EPROM on the Package Type


## INTRODUCTION OF PACKAGES

Hitachi microcomputer devices are offered in a variety of packages, to meet various user requirements.

1. Package Classification

When selecting suitable packaging, please refer to the Package Classifications given in Fig. 1 for pin insertion, surface mount, and multi-function types, in plastic and ceramic.


Fig. 1 Package Classification according to Material and Printed Circuit Board Mounting Type

## INTRODUCTION OF PACKAGES

## 2. Type No. and Package Code Indication

The Hitachi type No. for 4-bit single-chip microcomputer devices is followed by package material and outline specifications, as shown below. The package type used for each device is identified by code as
follows, illustrated in the data sheet of each device
When ordering, please write the package code next to the type number.

Type No. Indication



Package Code Indication


## 3. Package Dimensional Outline

Hitachi 4-bit single-chip microcomputer devices employ the packages shown in Table 1 according to PCB mounting method.

Table 1 Package List

| Mounting method | Package classification |  | Package material | Package code |
| :---: | :---: | :---: | :---: | :---: |
| Pin insertion type | Standard outline (DIP) |  | Plastic | $\begin{aligned} & \hline \text { DP- } 28 \\ & \text { DP. } 42 \\ & \hline \end{aligned}$ |
|  | Shrink outline (S-DIP) |  | Plastic | DP-28S DP-42S DP-64S |
| Surface mounting type | Flat package | FPP | Plastic | $\begin{aligned} & \text { FP-54 } \\ & \text { FP-64 } \\ & \text { FP-80 } \\ & \text { FP-100 } \end{aligned}$ |
|  |  | FPC | Ceramic | FC-80 |
| Multi-function type | EPROM on the package type |  | Ceramic | DC-64SP |

Plastic DIP


Shrink Type Plastic DIP

- DP-28S

(Unit: mm)
- DP-42S

- DP-64S



## Flat Plastic Package




## Flat Package of Ceramic

- FC-80




## 4. Mounting Method

Package lead pins are surface treated with solder coating or plating to facilitate PCB mounting. The lead pins are connected to the package by eutectic solder. Common connecting method of leads and precautions are explained as follows:
4.1 Mounting Methods of Pin Insertion Type Package Insert lead pins into the PCB through-holes (usually about $\phi 0.8 \mathrm{~mm}$ ). Soak leads in a wave solder tub.

Lead pins held by the through-holes enable handling of the package through the soldering process, and facilitate automated soldering. When soldering leads in the wave solder tub, do not get solder on the package.

### 4.2 Mounting Method of Surface Mount Type Package

Apply the specified quantity of solder paste to the pattern on any printed board by the screen printing method, to temporarily fix the package to the board. The solder paste melts when heated in a reflowing furnace, and package leads and the pattern of the printed board are fixed by the surface tension of the melted solder and self alignment.

The size of the pattern where leads are attached should be 1.1 to 1.3 times the leads' width, depending on paste material or furnace adjustment.

The temperature of the reflowing furnace is dependent on packaging material and type. Fig. 2 lists the adjustment of the reflowing furnace for FPP. Pre-heat the furnace to $150^{\circ} \mathrm{C}$. Surface temperature of the resin should be kept at $235^{\circ} \mathrm{C}$ maximum for 10 minutes or less.
(1) The temperature of the leads should be kept at $260^{\circ}$ for 10 minutes or less.
(2) The temperature of the resin should be kept at $235^{\circ}$ for 10 minutes or less.
(3) Below is shown the temperature profile when soldering a package by the reflowing method.


Fig. 2 Reflowing Furnace Adjustment for FPP
Employ adequate heating or temperature control equipment to prevent damage to the plastic package epoxy-resin material. When using an infrared heater, avoid long exposure at temperatures higher than the glass transition point of epoxy-resin (about $150^{\circ} \mathrm{C}$ ), which may cause package damage and loss of reliability characteristics. Equalize the temperature inside and outside of packages by reducing the heat of the upper surface of the packages.

FPP leads may easily bend in shipment or during handling, and impact soldering onto the printed board. Heat the bent leads again with a soldering iron to reshape them.

Use a rosin flux when soldering. Do not use chloric flux because the chlorine in the flux has a tendency to remain on the leads and reduce reliability. Use alcohol, chlorothene or freon to wash away rosin flux from packages. These solvents should not remain on the packages for an excessive length of time, because the package markings may disappear.

## 1. VIEWS ON QUALITY AND RELIABILITY

Basic views on quality at Hitachi are to meet the individual uers' required quality level and maintain a general quality level equal to or above that of the general market. The quality required by the user may be specified by contract, or may be indefinite. In either case, efforts are made to assure reliable performance in actual operating circumstances. Quality control during the manufacturing process, and quality awareness from design through production lead to product quality and customer satisfaction. Our quality assurance technique consists basically of the following steps:
(1) Build in reliability at the design stage of new product development.
(2) Build in quality at all steps in the manufacturing process.
(3) Execute stringent inspection and reliability confirmation of final products.
(4) Enhance quality levels through field data feed back.
(5) Cooperate with research laboratories for higher quality and reliability.

With the views and methods mentioned above, utmost efforts are made to meet users' requirements.

## 2. RELIABILITY DESIGN OF SEMICONDUCTOR DEVICES

### 2.1 Reliability Targets

The reliability target is an important factor in sales, manufacturing, performance, and price. It is not adequate to set a reliability target based on a single set of common test conditions. The reliability target is set based on many factors:
(1) End use of semiconductor device.
(2) End use of equipment in which device is used.
(3) Device manufacturing process.
(4) End user manufacturing techniques.
(5) Quality control and screening test methods.
(6) Reliability target of system.

### 2.2 Reliability Design

The following steps are taken to meet the reliability targets:
(1) Design Standardization

As for design rules, critical items pertaining to quality and reliability are always studied at circuit
design, device design, layout design, etc. Therefore, as long as standardized processing and materials are used the reliability risk is extremely small even in the case of new development devices, with the exception of special requirements imposed by functional needs.
(2) Device Design

It is important for the device design to consider total balance of process, structure, circuit, and layout design, especially in the case where new processes and/or new materials are employed. Rigorous technical studies are conducted prior to device development.
(3) Reliability Evaluation by Functional Test Functional Testing is a useful method for design arid process reliability evaluation of IC's and LSI devices which have complicated functions.

The objectives of Functional Test are:

- Determining the fundamental failure mode.
- Analysis of relation between failure mode and manufacturing process.
- Analysis of failure mechanism.
- Establishment of QC points in manufacturing process.


### 2.3 Design Review

Design Review is an organized method to confirm that a design satisfies the performance required and meets design specifications. In addition, design review helps to insure quality and reliability of the finished products. At Hitachi, design review is performed from the planning stage to production for new products, and also for design changes on existing products. Items discussed and considered at design review are:
(1) Description of the products based on design documents.
(2) From the standpoint of each participant, design documents are studied, and for points needing clarification, further investigation will be carried out.
(3) Specify quality control and test methods based on design documents and drawings.
(4) Check process and ability of manufacturing line to achieve design goal.
(5) Preparation for production.
(6) Planning and execution of sub-programs for design changes proposed by individual specialists,
for test, experiments, and calculations to confirm the design changes.
(7) Analysis of past failures with similar devices, discussion of methods to prevent them, and planning and execution of test programs to confirm success.

## 3. QUALITY ASSURANCE SYSTEM

### 3.1 Activity of Quality Assurance

General views of overall quality assurance in Hitachi are as follows:
(1) Problems in each individual process should be solved in the process. Therefore, at the finished product stage the potential failure factors have been removed.
(2) Feedback of information is used to insure a satisfactory level of ability process.

### 3.2 Quality Approval

To insure quality and reliability, quality approval is carried out at the preproduction stage of device
design, as described in section 2. Our views on quality approval are:
(1) A third party executes approval objectively from the standpoint of the customer.
(2) Full consideration is given to past failures and information from the field.
(3) No design change or process change without $Q A$ approval.
(4) Parts, materials, and processes are closely monitored.
(5) Control points are established in mass production after studying the process abilities and variables.

### 3.3 Quality and Reliability Control at Mass

 ProductionQuality control is accomplished through division of functions in manufacturing, quality assurance, and other related departments. The total function flow is shown in Fig. 2. The main points are described below.


Production
Figure 1 Flow Chart of Quality Approval


Figure 2 Flow Chart of Quality Control in Manufacturing Process

### 3.3.1 Quality Control of Parts and Materials

As semiconductor devices tend towards higher performance and higher reliability, the importance of quality control of parts and materials becomes paramount. Items such as crystals, lead frames, fine wire for wire bonding, packages, and materials needed in manufacturing processes such as masks and chemicals, are all subject to rigorous inspection and control. Incoming inspection is performed based on the purchase specification and drawing. The sampling is executed based mainly on MIL-STD-105D.

The other activities of quality assurance are as follows:
(1) Outside vendor technical information meeting.
(2) Approval and guidance of outside vendors.
(3) Chemical analysis and test.

The typical check points of parts and materials are shown in Table 1.

| Material, Parts | Important Control Items | Point for Check |
| :---: | :---: | :---: |
| Wafer | Appearance <br> Dimension Sheet Resistance Defect Density Crystel Axis | Demege and Contamination on Surface Flatneas Resistence: Defect Numbers |
| Mask | Appearance Dimension Resistoration Gradation | Defect Numbers, Scratch Dimension Level <br> Uniformity of Gradation |
| Fine <br> Wire for <br> Wire <br> Bonding | Appearance <br> Dimension Purity Elongation Ratio | Contamination, Scratch, Bend, Twist <br> Purity Level Mechanical Strength |
| Frame | Appearance <br> Dimension <br> Processing <br> Accuracy <br> Plating Mounting Characteristics | Contamination, Scratch Dimension Level <br> Bondability, Soldarability Heat Resistance |
| Ceramic Package | Appearance <br> Dimension <br> Laak Resistance <br> Plating Mounting <br> Characteristics <br> Electrical <br> Characteristics <br> Mechanical <br> Strength | Contemination, Scratch <br> Dimension Level <br> Airtightness <br> Bondability, Solderability <br> Heat Resistance <br> Mechanical Strength |
| Plastic | Composition <br> Electrical <br> Characteristics <br> Thermal <br> Characteristics <br> Molding <br> Performance <br> Mounting <br> Characteristics | Characteristics of Plestic Material <br> Molding Performance <br> Mounting Characteristics |

### 3.3.2 Inner Process Quality Control

Inner Process Quality Control performs very important functions in quality assurance of semiconductor devices. The manufacturing Inner Process Quality Control is shown in Fig. 3.
(1) Quality Control of Semi-final Products and Final Products
Potential failure factors of semiconductor devices are removed in the manufacturing process. To achieve this, check points are set-up in each process and products which have potential failure factors are not moved to the next process step. Manufacturing lines are rigidly selected and tight inner process quality controls are executed-rigid checks in each process and each lot, 100\% inspection to remove failure factors caused by manufacturing variables and high temperature aging and temperature cycling. Elements of inner process quality control are as follows:

- Condition control of equipment and workers environment and random sampling of semifinal products.
- Suggestion system for improvement of work.
- Education of workers.
- Maintenance and improvement of yield.
- Determining quality problems, and implement. ing countermeasures.
- Transfer of quality information.
(2) Quality Control of Manufacturing Facilities and Measuring Equipment Manufacturing equipment is improving as higher performance devices are needed. At Hitachi, the automation of manufacturing equipment is encouraged. Maintenance Systems maintain operation of high performance equipment. There are daily inspections which are performed based on related specifications. Inspection points are listed in the specification and are checked one by one to prevent any omission. As for adjustment and maintenance of measuring equipment, specifications are checked one by one to maintain and improve quality.
(3) Quality Control of Manufacturing Circumstances and Sub-Materials
The quality and reliability of semiconductor devices are highly affected by the manufacturing process. Therefore, controls of manufacturing circum-
stances such as temperature, humidity and dust, and the control of submaterials, like gas, and pure water used in a manufacturing process, are intensively executed.

Dust control is essential to realize higher integration and higher reliability of devices. At Hitachi, maintenance and improvement of cleanliness at manufacturing sites is accomplished through
attention to buildings, facilities, air conditioning systems, delivered materials, clothes, work environment, and periodic inspection of floating dust concentration.

### 3.3.3 Final Product Inspection and Reliability Assurance

(1) Final Product Inspection

Lot inspection is done by the quality assurance


Figure 3 Example of Inner Process Quality Control
department for products which were judged good in $100 \%$ test . . . the final process in manufacturing. Though $100 \%$ yield is expected, sampling inspection is executed to prevent mixture of bad product by mistake. The inspection is executed not only to confirm that the products have met the users' requirements but also to consider potential
quality factors. Lot inspection is executed based on MIL-STD-105D.
(2) Reliability Assurance Tests

To assure the reliability of semiconductor devices, reliability tests and tests on individual manufacturing tots that are required by the user, are periodically performed.


Figure 4 Process Flow Chart of Field Failure

## RELIABILITY TEST DATA

## 1. INTRODUCTION

Microcomputers provide high reliability and quality to meet the demands of increased functions, enlarging scale, and widening application. Hitachi has improved the quality level of microcomputer products by evaluating reliability, building quality into the manufacturing process, strengthening inspection techniques, and analyzing field data.

The following reliability and quality assurance data for Hitachi 8-bit single-chip microcomputers indicates results from test and failure analysis.

## 2. PACKAGE AND CHIP STRUCTURE

2.1 Packaging

Production output and application of plastic packaging continues to increase, expanding to automobile measuring and control systems, and computer terminal equipment operating under severe conditions. To meet this demand, Hitachi has significantly improved moisture resistance and operational stability in the plastic manufacturing process.

Plastic and side-brazed ceramic package structures are shown in Figure 1 and Table 1.
(1) Plastic DIP

Figure 1 Package Structure

Table 1 Package Material and Properties

| Item | Plastic DIP | Plastic Flat Package |
| :--- | :--- | :--- |
| Package | Epoxy | Epoxy |
| Lead | Solder dipping Alloy 42 | Solder plating Alloy 42 |
| Die bond | Au-Si or Ag paste | Au-Si or Ag paste |
| Wire bond | Thermo compression | Thermo compression |
| Wire | Au | Au |

### 2.2 Chip Structure

The HMCS40 family is produced in low power CMOS technology. The Si-gate process is used because of high reliability and high
density.
Chip structure and basic circuitry are shown in Figure 2.


Figure 2 Chip Structure and Basic Circuit

## 3. QUALITY QUALIFICATION AND EVALUATION

### 3.1 Reliability Test Methods

Reliability test methods shown in Table 2 are used to qualify and evaluate the new products and new process.
Table 2 Reliability Test Methods

| Test Items | Test Condition | MIL-STD-883B Method No. |
| :---: | :---: | :---: |
| Operating Life Test | $125^{\circ} \mathrm{C}, 1000 \mathrm{hr}$ | 1005,2 |
| High Temp, Storage Low Temp, Storage Steady State Humidity Steady State Humidity Biased | Tstg max, 1000 hr Tstg min, 1000 hr $65^{\circ} \mathrm{C} 95 \% \mathrm{RH}, 1000 \mathrm{hr}$ $85^{\circ} \mathrm{C} 85 \% \mathrm{RH}, 1000 \mathrm{hr}$ | 1.008,1 |
| Temperature Cycling <br> Temperature Cycling <br> Thermal Shock <br> Soldering Heat <br> Mechanical Shock <br> Vibration Fatigue <br> Variable Frequency <br> Constant Acceleration <br> Lead Integrity (DIP) <br> Lead Integrity (FPP) | $\begin{aligned} & -55^{\circ} \mathrm{C} \sim 150^{\circ} \mathrm{C}, 10 \text { cycles } \\ & -20^{\circ} \mathrm{C} \sim 125^{\circ} \mathrm{C}, 200 \text { cycles } \\ & 0^{\circ} \mathrm{C} \sim 100^{\mathrm{C}}, 100 \text { cycles } \\ & 260^{\circ} \mathrm{C}, 10 \mathrm{sec} \\ & 1500 \mathrm{G} 0.5 \mathrm{msec}, 3 \text { times } / X, Y, Z \\ & 60 \mathrm{~Hz} 20 \mathrm{G}, 32 \mathrm{hrs} / X, Y, Z \\ & 20 \sim 2000 \mathrm{~Hz} 20 \mathrm{G}, 4 \mathrm{~min} / X, Y, Z \\ & 20000 \mathrm{G}, 1 \text { min } / X, Y, Z \\ & 225 \mathrm{gr}, 90^{\circ} 3 \text { times } \\ & 225 \mathrm{gr}, 90^{\circ} 1 \text { time } \end{aligned}$ | $\begin{aligned} & 1010,4 \\ & 1011,3 \\ & 2002,2 \\ & 2005,1 \\ & 2007,1 \\ & 2001,2 \\ & 2004,3 \\ & 2004 \end{aligned}$ |

### 3.2 Reliability Test Results

Reliability Test Results of 4-bit single-chip microcomputer devices is shown in Table 3 to Table 7

## Table 3 Dynamic Life Test

| Device | Package | Sample Size | Component Hours | Failure |
| :--- | :--- | :---: | :---: | :---: |
| HMCS47C | DP-64S | 90 | 90000 | 0 |
|  | FP-54 | 90 | 90000 | 0 |
| HMCS46C | DP-42 | 90 | 90000 | 0 |
|  | DP-42S | 45 | 45000 | 0 |
| HMCS45C | DP-64S | 45 | 45000 | 0 |
|  | FP-54 | 120 | 120000 | $1 * * *$ |
| HMCS44C | DP-42 | 162 | 162000 | 0 |
|  | DP-42S | 45 | 45000 | 0 |

*Surface contamination
** Aluminum metallization open

Table 4 High Temperature, High Humidity Test (Moisture Resistance Test)
(1) $85^{\circ} \mathrm{C} \mathbf{8 5 \% R H}$ Bias Test

| Package | 168 hrs | 500 hrs | 1000 hrs |
| :---: | :---: | :---: | :---: |
| DIP-type | $0 / 205$ | $0 / 205$ | $1^{*} / 205$ |
| FP-type | $0 / 185$ | $0 / 185$ | $1^{*} / 185$ |

*Aluminum corrosion
Condition; C MOS: VCC $=5.5 \mathrm{~V}$
(2) High Temperature High Humidity Storage Life Test
a) $65^{\circ} \mathrm{C} / 95 \% \mathrm{RH}$

| Package | 168 hrs | 500 hrs | 1000 hrs |
| :---: | :---: | :---: | :---: |
| DIP-type | $0 / 870$ | $0 / 870$ | $1^{*} / 870$ |
| FP-type | $0 / 545$ | $0 / 545$ | $1^{*} / 545$ |

RELIABILITY TEST DATA OF MICROCOMPUTER
b) $85^{\circ} \mathrm{C} / 95 \% \mathrm{RH}$

| Package | 168 hrs | 500 hrs | 1000 hrs |
| :---: | :---: | :---: | :---: |
| DIP-type | $0 / 220$ | $0 / 220$ | $1^{*} / 220$ |
| FP-type | $0 / 165$ | $0 / 165$ | $1^{*} / 165$ |

-Aluminum corrosion
(3) Pressure Cooker Test
$\left(121^{\circ} \mathrm{C}, 2 \mathrm{~atm}\right)$

| Package | 40 hrs | 60 hrs | 100 hrs | 200 hrs |
| :---: | :---: | :---: | :---: | :---: |
| DIP-type | $0 / 55$ | $0 / 55$ | $0 / 55$ | $0 / 55$ |
| FP-type | $0 / 55$ | $0 / 55$ | $0 / 55$ | $1{ }^{*} / 55$ |

(4) MIL-STD-883B Moisture Resistance Test
$\left(-65^{\circ} \mathrm{C} \sim-10^{\circ} \mathrm{C}, 90 \% \mathrm{RH}\right.$ or more)

| Package | 10 cycles | 20 cycles | 40 cycles |
| :---: | :---: | :---: | :---: |
| DIP-type | $0 / 50$ | $0 / 50$ | $0 / 50$ |
| FP-type | $0 / 22$ | $0 / 22$ | $0 / 22$ |

Table 5 Temperature Cycling Test
$\left(-55^{\circ} \mathrm{C} \sim 150^{\circ} \mathrm{C}\right.$ )

| Package | 10 cycles | 100 cycles | 200 cycles |
| :---: | :---: | :---: | :---: |
| DIP-type | $0 / 1637$ | $0 / 1637$ | $0 / 1637$ |
| FP-type | $0 / 1514$ | $0 / 1514$ | $0 / 1514$ |

Table 6 High Temperature, Low Temperature Storage Life Test

| Package | Temperature | 168 hrs | 500 hrs | 1000 hrs |
| :---: | :---: | :---: | :---: | :---: |
| DIP-type | $150^{\circ} \mathrm{C}$ | $0 / 43$ | $0 / 43$ | $0 / 43$ |
|  | $-55^{\circ} \mathrm{C}$ | $0 / 50$ | $0 / 50$ | $0 / 50$ |
| FP-type | $150^{\circ} \mathrm{C}$ | $0 / 53$ | $0 / 53$ | $0 / 53$ |
|  | $-55^{\circ} \mathrm{C}$ | $0 / 40$ | $0 / 40$ | $0 / 40$ |

Table 7 Mechanical and Environmental Test

| Test Item | Condition | Plastic DIP |  | Flat Plastic Package |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Sample Size | Failure | Sample Size | Failure |
| Thermal Shock | $\begin{aligned} & 0^{\circ} \mathrm{C} \sim 100^{\circ} \mathrm{C} \\ & 10 \text { cycles } \end{aligned}$ | 150 | 0 | 100 | 0 |
| Soldering Heat | $260^{\circ} \mathrm{C}, 10 \mathrm{sec}$. | 140 | 0 | 160 | 0 |
| Salt Water Spray | $\begin{aligned} & 35^{\circ} \mathrm{C}, \mathrm{NaCl} 5 \% \\ & 24 \mathrm{hrs} \end{aligned}$ | 40 | 0 | 40 | 0 |
| Solderability | $230^{\circ} \mathrm{C}$, 5 sec. <br> Rosin flux | 34 | 0 | 34 | 0 |
| Drop Test | 75 cm , maple board 3 times | 38 | 0 | 38 | 0 |
| Mechanical Shock | $\begin{aligned} & 1500 \mathrm{G}, 0.5 \mathrm{~ms} \\ & 3 \text { times } / X, Y, Z \end{aligned}$ | 45 | 0 | 45 | 0 |
| Vibration Fatigue | $\begin{aligned} & 60 \mathrm{~Hz}, 20 \mathrm{G} \\ & 32 \mathrm{hrs} / \mathrm{Y}, \mathrm{Y}, \mathrm{Z} \end{aligned}$ | 120 | 0 | 45 | 0 |
| Vibration Variable Freq. | $\begin{aligned} & 100 \sim 2000 \mathrm{~Hz} \\ & 20 \mathrm{G}, 4 \text { times } / X, Y, Z \end{aligned}$ | 45 | 0 | 45 | 0 |
| Lead Integrity | $\begin{aligned} & 225 \mathrm{~g}, 90^{\circ} \\ & \text { Bonding } 3 \text { times } \end{aligned}$ | 45 | 0 | - | - |
|  | $\begin{aligned} & \mathbf{2 2 5 g}, 90^{\circ} \\ & \text { Bonding } 1 \text { time } \\ & \hline \end{aligned}$ | - | - | 45 | 0 |

## 4. PRECAUTIONS

### 4.1 Storage

To prevent deterioration of electrical characteristics, solderability, appearance or structure, Hitachi recommends semiconductor devices be stored as follows:
(1) Store in ambient temperatures of 5 to $30^{\circ} \mathrm{C}$, with a relative humidity of 40 to $60 \%$.
(2) Store in a clean, dust- and active gas-free environment.
(3) Store in conductive containers to prevent static electricity.
(4) Store without any physical load.
(5) When storing devices for an extended period, store in an unfabricated form, to minimize corrosion of pre-formed lead wires.
(6) Unsealed chips should be stored in a cool, dry, dark and dust-free environment. Assembly should be performed within 5 days of unpacking. Devices can be stored for up to 20 days in dry nitrogen gas with a dew point at $-30^{\circ} \mathrm{C}$ or less.
(7) Prevent condensation during storage due to rapid temperature changes.

### 4.2 Transportation

General precautions for electronic components are applicable in transporting semiconductors, units incorporating semiconductors, and other similar systems. In addition, Hitachi recommends the following:
(1) When transporting semiconductor devices or printed circuit boards, minimize mechanical vibration and shock. Use containers or jigs which will not induce static electricity as a result of vibration. Use of an electrically conductive container or aluminum foil is recommended.
(2) To prevent device deterioration from clothing-induced static electricity, workers should be properly grounded while handling devices. Use of a 1 M ohm resistor is recommended to prevent electric shock.
(3) When transporting printed curcuit boards containing semiconductor devices, suitable preventive measures against static electricity must be taken. Voltage build-up can be avoided by shorting the card-edge terminals. When a belt conveyor is used, apply some surface treatment to prevent build-up of electrical charge.
(4) Minimize mechanical vibration and shock when transporting semiconductor devices or printed circuit boards.

### 4.3 Handling for Measurement

Avoid static electricity, noise and voltage surge when measuring or mounting devices. Precaution should be taken against current leakage through terminals and housings of curve tracers, synchroscopes, pulse generators, and DC power sources.

When testing devices, prevent voltage surges from the tester, attached clamping circuit, and any excessive voltage possible through accidental contact.

In inspecting a printed circuit board, power should not be applied if any solder bridges or foreign matter is present.

### 4.4 Soldering

Semiconductor devices should not be exposed to high temperatures for excessive periods. Soldering must be performed consistent with temperature conditions of $260^{\circ} \mathrm{C}$ for 10 seconds, $350^{\circ} \mathrm{C}$ for 3 seconds, and at a distance of 1 to 1.5 mm from the end of the device package.

A soldering iron with secondary voltage supplied through a grounded transformer is recommended to protect against leakage current. Use of alkali or acid flux, which may corrode the leads, is not recommended.

### 4.5 Removing Residual Flux

Detergent or ultrasonic removal of residual flux from circuit boards is necessary to ensure system reliability. Selection of detergent type and cleaning conditions are important factors.

When chloric detergent is used for plastic packaged devices, care must be taken against package corrosion. Extended cleaning periods and excessive temperature conditions can cause the chip coating to swell due to solvent permeation. Hitachi recommends use of Lotus and Dyfron solvents. Trichloroethylene solvent is not suitable.

The following conditions are advisable for uitrasonic cleaning:

- Frequency: 28 to 29 k Hz (to avoid device resonation)
- Ultrasonic output: $15 \mathrm{~W} / \ell$
- Keep devices from making direct contact with power generator
- Cleaning time: Less than 30 seconds.


## DESIGN PROCEDURE AND SUPPORT TOOLS FOR 4-BIT SINGLE-CHIP MICROCOMPUTER

The cross assembler and the hardware simulator using various types of computer are prepared by Hitachi as supporting systems to develop user's programs.

User's programs are mask programmed into the ROM and deliv-
ered as the LSI by the company.
Fig. 1 shows the typical program design procedure and Table 1 shows the system development support tools for 4-bit single-chip microcomputer family used in these processes.

(2) A flow chart is designed to achieve the predetermined functions and the flow chart is coded by using the mnemonic code.
(3) The coded flow chart is punched into the card or the paper tape or written into the floppy disk, to generate a source program.
(4) The source program is assembled by the evaluation kit or the H68SD5, to generate the object program. In this case, errors during the assembling are also detected.
(5) Hardware simulation is performed to confirm the program. The company provides four kinds of hardware, the H68SD5, the evaluation kit, the evaluation board and the EPROM on the package type microcomputer. The consumers are able to choose the best suitable tool.
(6) The completed program is sent to the company in the form of EPROM or the object tape.
(7) Options such as ROM is masked by the company. LSI is testatively produced and the sample is handed in to the user. After the user has evaluated the sample and confirmed that the program is correct, mass production is started.

Figure 1 Program Design Procedure

Table 1 System Development Support Tools

| Family No. | Resident System |  |  |  | Cross System |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Evaluation Kit ${ }^{\text {² }}$ | Evaluation Board | EPROM on the Packaga | H68SD5 +Emulator set*3(Hardware + Software) | 18M370 | Intel MDS220/230 |  | EXORciser-11 |
|  |  |  |  |  |  | ISIS-II | CP/M |  |
| HMCSA4C HMCS45C | H40EVKIT2 | H45CEV00 H47CEV00 | - | H68SD5+H40MIX1 | S40XAM 1-T | S40MDS1-F | - | S40EXR1-F |
| HMCSA6C HMCS47C | H40EVKIT2 | H47CEV00 | - | H68SD5+H40MIX 1 | - | S40MDS 1-F | - | S40EXR1-F |
| LCD-III | HAOEVKIT4* 1 | $\begin{aligned} & \text { H40LCEV00 } \\ & \text { H40LCEV04*1 } \end{aligned}$ | - | $\begin{aligned} & \text { H68SD5+H40M1X2 } \\ & \text { H68SD5+H40M1X4* } \end{aligned}$ | S40XAM1-T | S40MDS 1-F | - | S40EXR1-F |
| LCD-IV | H40EVKIT4* 1 | H40LCEV04* | - | H68SD5+H4OM1X4*1 | - | S40MDS 1-F | - | S40EXR1-F |
| HMCS404C | - | - | HD614P080S | H68SD5+H400CMIX1 | - | S400MDS1F | S400MDS2F | - |
| $\begin{aligned} & \text { HMCS404CL*" } \\ & \text { HMCS404AC* } \end{aligned}$ | - | - | ${ }^{*}$ | ${ }^{*}$ | - | S400MDS 1 F | S400MDS 2 F | - |

- 1 : Under Development
${ }^{*} 2$ : Cross Assembler is Supplied with Evaluation Kit.
${ }^{-3}$ : Cross Assembler is Supplied with Emulator.
* 4 : MDS is a registared trede mark of Mohorwk Data Science Corp. ISIS-II is a registered trade mark of Intel Corp.
CP/M is a registered trade mark of Digital Research Inc.
EXORciser is a registered trade mark of Motorola Inc.


## - SINGLE-CHIP MICROCOMPUTER DEVELOPMENT SYSTEM

The H68SD5 is a development system for Hitachi 4-bit and 8-bit single-chip microcomputers.

It is compact HD6800-based CRT/Key board microcomputer terminal, with two Floppy disk drivers, and has standard interface for the TTY (RS-232C or TTL level) and printer (Centronics parallel interface). An optional EPROM Writer is avaitable.

## Features

- Supports system development for 8-bit and 4-bit single chip microcomputers


## System Configuration



- Disk based low cost system
- Provides the CRT Editor, Assembler, Emulator and EPROM Writer controlled by FDOS-III
- 56k-byte RAM
- Allows linking between the H68SD5 and the I/O devices (TTY and Printer)
- Easy to debug user's prototype system using the Emulator Module


EPROM Writer


# DATA SHEETS 

4-BIT SINGLE-CHIP MICROCOMPUTER HMCS40 SERIES

Preliminary data sheets herein contain information on new products. Specifications and information are subject to change without notice.

Advance Information data sheets herein contain information on a product under development. Hitachi reserves the right to change or discontinue these products without notice.

## HMCS44C(HD44801) HMCS44CL(HD44808)

The HMCS44C is the CMOS 4-bit single chip microcomputer which contains ROM, RAM, I/O and Timer/Event Counter on single chip. The HMCS44C is designed to perform efficient controller function as well as arithmetic function for both binary and BCD data. The CMOS technology of the HMCS44C provides the flexibility of microcomputers for battery powered and battery back-up applications.

## - FEATURES

- 4-bit Architecture
- 2,048 Words of Program ROM (10 bits/Word) 128 Words of Pattern ROM (10 bits/Word)
- 160 Digits of Data RAM (4 bits/Digit)
- 32 I/O Lines and 2 External Interrupt Lines
- Timer/Event Counter
- Instruction Cycle Time: HMCS44C; $10 \mu \mathrm{~s}$

HMCS44CL; $20 \mu \mathrm{~s}$

- All Instructions except One Instruction; Single Word and Single Cycle
- BCD Arithmetic Instructions
- Pattern Generation Instruction
- Table Look Up Capability -
- Powerfül Interrupt Function 3 Interrupt Sources
- 2 External Interrupt Lines
$\boxed{-}$ Timer/Event Counter
Multiple Interrupt Capability
- Bit Manipulation Instructions for Both RAM and I/O
- Option of $1 / O$ Configuration Selectable on Each Pin; Pull Up MOS or CMOS or Open Drain
- Built-in Oscillator
- Built-in Power-on Reset Circuit (HMCS44C only)
- Low Operating Power Dissipation; 2mW typ.
- Stand-by Mode (Halt Mode); $50 \mu \mathrm{~W}$ max.
- CMOS Technology
- Single Power Supply: HMCS44C; 5V $\pm 10 \%$

HMCS44CL; 2.5 V to 5.5 V

HMCS44C,HMCS44CL

(DP.42)
HMCS44C,HMCS44CL

(DP-42S)
PIN ARRANGEMENT



HMCS44C, HMCS44CL

HMCS44C ELECTRICAL CHARACTERISTICS ( $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}+10 \%$ )

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $V_{T 1}$ | -0.3 to $V_{c c}+0.3$ | V | Except for terminals specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $\mathrm{V}_{12}$ | -0.3 to +10.0 | V | Applied to only open drain output pins, open drain $1 / O$ common pins. |
| Maximum Total Output Current (1) | - 5101 | 45 | mA | [NOTE 3 |
| Maximum Total Output Current (2) | צ102 | 45 | mA | \| NOTE 3 |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\text {c }}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | c |  |

|NOTE 1 | Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS-1, -2." If these conditions are exceeded, it could affect reliability of LSI.
|NOTE 2| All voltages are with respect to GND.
[NOTE 3| Maximum Total Output Current is total sum of output currents which can flow out (or flow in) simultaneously.

- ELECTRICAL CHARACTERISTICS- $1\left(\mathrm{~V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-20 \%\right.$ to $\left.+75 \mathrm{C}\right)$

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{\mathrm{IL}}$ |  |  | - | - | 1.0 | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathbf{H} 1}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | V cc | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{\mathrm{HH} 2}$ |  |  | $\mathrm{V}_{\text {cc }}-1.0$ | - | 10 | V | 3 |
| Output "Low" Voltage | VoL | $1 \mathrm{OL}=1.6 \mathrm{~mA}$ |  | - | - | 0.8 | V |  |
| Output "High" Voltage (1) | Vor 1 | $-\mathrm{IOH}_{\text {O }}=1.0$ |  | 2.4 | - | - | V | 4 |
| Output "High" Voltage (2) | Voh2 | $-\mathrm{loh}^{\text {H }}=0.0$ | mA | $V_{c c}-0.3$ | - | . | V | 5 |
| Interrupt Input Hold Time | tint |  |  | 2. $\mathrm{T}_{\text {inst }}$ | - | $\cdots$ | $\mu \mathrm{s}$ |  |
| Interrupt Input Fall Time | tfint |  |  | - | - | 50 | $\mu \mathrm{S}$ |  |
| Interrupt Input Rise Time | trint |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Output "High" Current | IOH | $\mathrm{V}_{\mathrm{OH}}=10 \mathrm{~V}$ |  | - | - | 3 | $\mu \mathrm{A}$ | 6 |
| Input Leakage Current | 11. | $\mathrm{V}_{\text {in }}=0$ to |  | - | - | 1.0 | $\mu \mathrm{A}$ | 2 |
|  |  | $\mathrm{V}_{\text {in }}=0$ to 1 |  | - | * | 3 |  | 3 |
| Pull up MOS Current | -lp | $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$ |  | 60 | - | 250 | $\mu \mathrm{A}$ |  |
| Supply Current (1) | Icc 1 | $V_{\text {in }}=V_{c c},$ <br> Ceramic $F$ Oscillation |  | $\cdots$ | $\cdots$ | 2 | mA | 7 |
| Supply Current (2) | Icc2 | $V_{\text {in }}=V_{c c},$ <br> $R_{f}$ Oscillat <br> External | ock Operation | - | - | 1.0 | mA | 7 |
| Standby I/O Leakage Current | ILs | $\overline{\mathrm{HLT}}=1.0 \mathrm{~V}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ | . | - | 1 | $\mu \mathrm{A}$ | 2, 8 |
|  |  |  | $V_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 3.8 |
| Standby Supply Current | Iccs | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{cc}}, \mathrm{H}$ | $\underline{L T}=0.2 \mathrm{~V}$ |  | - | 10 | $\mu \mathrm{A}$ | 9 |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $\mathrm{f}_{\mathrm{cp}}$ |  |  | 200 | 400 | 440 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | $\%$ |  |
| External Clock Rise Time | trep |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | tfcp |  |  | 0 | . | 0.2 | $\mu \mathrm{S}$ |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\mathrm{c}}$ |  | 9.1 | 10 | 20 | $\mu \mathrm{S}$ |  |
| Internal Clock Operation (R, Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | $\mathrm{R}_{\mathrm{f}}=91 \mathrm{k} \Omega \pm$ | 2\% | 300 | - | 500 | kHz |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{0}$ |  | 8.0 | - | 13.3 | $\mu \mathrm{s}$ |  |
| İternal Clock Operation (Ceramic Filter Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | Ceramic Fi | ter Circuit | 392 | - | 408 | kHz |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {o }}$ |  | 9.8 | - | 10.2 | $\mu \mathrm{s}$ |  |

[NOTE 1] All voltages are with respect to GND.
[NOTE 2] This is applied to RESET, $\overline{H L T}$, OSC ${ }_{1}$, INT $_{0}$, INT 1 and the With Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of I/O pins.
[NOTE 4] This is applied to the CMOS type of $1 / 0$ or Output pins.
[NOTE 5] This is applied to the With Pull up MOS or CMOS type of I/O or Output pins
[NOTE 6] This is applied to the Open Drain type of I/O or Output pins.
[NOTE 7] 1/O current is excluded.
[NOTE 8] The Standby I/O Leakage Current is the $1 / O$ leakage current in the Halt and Disable State.
[NOTE 9] I/O current is excluded.
The Standby Supply Current is the supply current at $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%$ in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration Voltage is called the Halt Current (loh), and it is shown in "ELECTRICAL CHARACTERISTICS-2."

HMCS44C, HMCS44CL

- ELECTRICAL CHARACTERISTICS-2 $\left(\mathrm{Ta}=-20\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Halt Duration Voltage | V DH | $\overline{\text { HLT }}=0.2 \mathrm{~V}$ | 2.3 | - | V |
| Halt Current | Ion | $\begin{aligned} & V_{\text {in }}=V_{C C} \\ & H L T=0.2 \mathrm{~V}, V_{O H}=2.3 \mathrm{~V} \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Halt Delay Time | thD |  | 100 | - | $\mu \mathrm{S}$ |
| Operation Recovery Time | tRC |  | 100 | - | $\mu \mathrm{s}$ |
| HLT Fall Time | tfith |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | trict |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT "Low" Hold Time | thLT |  | 400 | - | $\mu \mathrm{S}$ |
| HLT "High" Hold Time | tOPR | Rf Oscillation, External Clock Operation | 0.1 | - | ms |
|  |  | Ceramic Filter Oscillation | 4 | - |  |
| Power Supply Rise Time | $\mathrm{tr}_{\mathrm{r} C}$ | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | 0.1 | 10 | ms |
| Power Supply OFF Time | tOFF | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | 1 | - | ms |
| RESET Pulse Width (1) | tRST 1 | External Reset, <br> $\mathrm{V}_{\mathrm{Cc}}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{CC}}$ <br> (R, Oscillation, External <br> Clock Operation) | 1 | - | ms |
|  |  | External Reset $\mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ <br> (Ceramic Filter <br> Oscillation) | 4 | - |  |
| RESET Pulse Width (2) | tRST2 | External Reset $\mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}}$ | $\begin{aligned} & 2 \cdot \\ & T_{\text {inst }} \end{aligned}$ | - | $\mu \mathrm{S}$ |
| RESET Rise Time | trRST | External Reset $\mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V} . \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | - | 20 | ms |
| RESET Fall Time | tfRST | External Reset $\mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | - | 20 | ms |

[NOTE] All voltages are with respect to GND.

HMCS44CL ELECTRICAL CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=2.5$ to 5.5 V ) - ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | Vcc | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $\mathrm{V}_{\text {T1 }}$ | -0.3 to $\mathrm{V}_{\mathrm{cc}}+0.3$ | V | Except for terminals specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $\mathrm{V}_{\text {T2 }}$ | -0.3 to +10.0 | V | Applied to only open-drain output pins and open-drain 1/O common pins. |
| Maximum Total Output Current (1) | - El01 | 45 | mA | (Note 3) |
| Maximum Total Output Current (2) | Elo2 | 45 | mA | (Note 3) |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | C |  |

[NOTE 1] Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS-1, -2." If these conditions are exceeded, it could affect reliability of LSI.
[NOTE 2] All voltages are with respect to GND.
[NOTE 3] Maximum Total Output Current is total sum of output currents which can flow out (or flow in) simultaneously.

- ELECTRICAL CHARACTERISTICS-1 $\left(\mathrm{V}_{\mathrm{CC}}=2.5\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-20$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | VIL |  |  | - | - | $0.15 \cdot V_{c c}$ | V | , |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathrm{H} 1}$ |  |  | $0.85 \cdot V_{\text {cc }}$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{\mathrm{H} 2}$ |  |  | $0.85 \cdot \mathrm{~V}_{\text {cc }}$ | - | 10 | V | 3 |
| Output "Low" Voltage | VoL | $\mathrm{loL}=0.4 \mathrm{~mA}$ |  | - | - | 0.4 | V |  |
| Output "High" Voltage | Voh | $-\mathrm{l}_{\text {OH }}=0.08$ | mA | $\mathrm{V}_{\mathrm{cc}}-0.4$ | - | - | V | 4 |
| Interrupt Input Hold Time | tint |  |  | 2. Tinst | - | - | $\mu \mathrm{S}$ |  |
| Interrupt Input Fall Time | tfint |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Interrupt Input Rise Time | trint |  |  | - | - | 50 | $\mu \mathrm{S}$ |  |
| Output "High" Current | loH | $\mathrm{V}_{\mathrm{OH}}=10 \mathrm{~V}$ |  | - | - | 3 | $\mu \mathrm{A}$ | 5 |
| Input Leakage Current | IL. | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\mathrm{C}}$ |  | - | - | 1.0 | $\mu \mathrm{A}$ | 2 |
|  |  | $\mathrm{V}_{\text {in }}=0$ to 10 |  | - | - | 3 |  | 3 |
| Pull-up MOS Current | -Ip | $\mathrm{V}_{\mathrm{cc}}=3 \mathrm{~V}$ |  | 10 | - | 80 | $\mu \mathrm{A}$ |  |
| Supply Current | Icc | $V_{\text {in }}=V_{c c}, V$ <br> (fosc/fcp= <br> $\mathrm{R}_{\mathrm{f}}$ Oscillatio <br> Clock Oper | $\begin{aligned} & \hline c \mathrm{cc}=3 \mathrm{~V} \\ & 200 \mathrm{kHz}) \end{aligned}$ <br> External ation | - | - | 140 | $\mu \mathrm{A}$ | 6 |
| Standby 1/O Leakage Current | LLs | $\begin{aligned} & \overline{\mathrm{HLT}} \\ & =0.5 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{in}}=0$ to $\mathrm{V}_{\mathrm{cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 2, 7 |
|  |  |  | $V_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 3,7 |
| Standby Supply Current | Iccs | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{cc}}=2.5$ to 3.5 V | - | - | 6 | $\mu \mathrm{A}$ | 8 |
|  |  | HLT $=0.1 \mathrm{~V}$ | $\mathrm{V}_{\text {cc }}=2.5$ to 5.5 V | - | - | 10 | $\mu \mathrm{A}$ |  |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $\mathrm{f}_{\mathrm{cp}}$ |  |  | 130 | 200 | 240 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | trep |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | tfcp |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{fcp}$ |  | 16.8 | 20 | 30.8 | $\mu \mathrm{S}$ |  |
| Internal Clock Operation ( $\mathbf{f f}^{\text {Oscillation) }}$ |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | $\begin{aligned} & R_{f}=180 \mathrm{k} \Omega \\ & V_{c c}=2.5 \text { to } \end{aligned}$ | $\begin{aligned} & \pm 2 \% \\ & 3.5 \mathrm{~V} \end{aligned}$ | 130 | - | 250 | kHz |  |
|  |  | $\begin{aligned} & R_{\mathrm{f}}=180 \mathrm{k} \Omega \\ & \mathrm{~V}_{\mathrm{cc}}=2.5 \mathrm{to} \end{aligned}$ | $\begin{aligned} & \pm 2 \% \\ & 05.5 \mathrm{~V} \end{aligned}$ | 130 | - | 350 |  |  |
| Instruction Cycle Time | Tinst | $\begin{aligned} & \mathrm{T}_{\text {inst }}=4 / \mathrm{fos} \\ & \mathrm{~V}_{\mathrm{cc}}=2.5 \text { to } \end{aligned}$ | $03.5 \mathrm{~V}$ | 16 | - | 30.8 | $\mu \mathrm{S}$ |  |
|  |  | $\begin{aligned} & \mathrm{T}_{\text {inst }}=4 / \mathrm{fos} \\ & \mathrm{~V}_{\mathrm{cc}}=2.5 \text { to } \end{aligned}$ | $5.5 \mathrm{~V}$ | 11.4 | - | 30.8 |  |  |

|NOTE 11 All voltages are with respect to GND.
|NOTE 2] This is applied to RESET. HLT, OSC ${ }_{1}$, INT $_{0}$. INT ${ }_{1}$ and the With Pull up MOS or CMOS type of I/O pins.
[NOTE 3| This is applied to the Open Drain type of $1 / O$ pins.
[NOTE 4] This is applied to the CMOS type of $1 / O$ or Output pins.
[NOTE 5] This is applied to the Open Drain type of $1 / 0$ or Output pins.
[NOTE 6| 10 current is excluded.
[NOTE 7] The Standby 10 Leakage Current is the $1 / O$ leakage current in the Halt and Disable State.
[NOTE 8| 10 current is excluded.
The Standby Supply Current is the supply current at $\mathrm{V}_{\mathrm{cc}}=2.5 \mathrm{~V}$ to 5.5 V in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration Voltage is called the Halt Current (IDH), and it is shown in "ELECTRICAL CHARACTERISTICS-2."

- ELECTRICAL CHARACTERISTICS-2 ( $\mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$ )

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Halt Duration Voltage | VDH | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.0 | - | V |
| Halt Current | IdH | $\begin{aligned} & V_{\text {in }}=V_{c c}, \mathrm{HLT}=0.1 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Halt Delay Time | ${ }^{\text {thD }}$ |  | 200 | - | $\mu \mathrm{s}$ |
| Operation Recovery Time | tRC |  | 200 | - | $\mu \mathrm{S}$ |
| HLT Fall Time | tf HLT |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | trHLT |  | - | 1000 | $\mu \mathrm{S}$ |
| HLT "Low" Hold Time | thLT |  | 800 | - | $\mu \mathrm{s}$ |
| HLT "High" Hold Time | tOPR | Rf Oscillation, External Clock Operation $\mathrm{V}_{\mathrm{CC}}=2.5 \text { to } 5.5 \mathrm{~V}$ | 0.2 | - | ms |
| RESET Pulse Width (1) | tRST 1 | External Reset, <br> $\mathrm{V}_{\mathrm{cc}}=2.5$ to 5.5 V , $\mathrm{HLT}=\mathrm{V}_{\mathrm{cc}}$ <br> ( $\mathbf{R}_{\mathrm{f}}$ Oscillation, External <br> Clock Operation) | 2 | - | ms |
| RESET Pulse Width (2) | trST2 | External Reset, $\mathrm{V}_{\mathrm{cc}}=2.5$ to 5.5 V $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | $\begin{aligned} & 2 \cdot \\ & \mathrm{~T}_{\text {inst }} \end{aligned}$ | - | $\mu \mathrm{S}$ |
| RESET Fall Time | tfRST | $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | - | 20 | ms |
| RESET Rise Time | trRST | $\overline{\mathrm{HLT}}=\mathrm{V}_{\text {cc }}$ | - | 20 | ms |

[NOTE] All voltages are with respect to GND.

## - SIGNAL DESCRIPTION

The input and output signals for the HMCS44C, shown in PIN ARRANGEMENT, are described in the following paragraphs.

- Vcc and GND

Power is supplied to the HMCS44C using these two pins. $\mathrm{V}_{\mathrm{CC}}$ is power and GND is the ground connection.

## - Reset

This pin allows resetting of the HMCS44C at times other than the automatic resetting capability (ACL; Built-in Reset Circuit) already in the HMCS44C.

The HMCS44C can be reset by pulling RESET high. Refer to RESET FUNCTION for additional information.

## - OSC, and OSC ${ }_{2}$

These pins provide control input for the built-in oscillator circuit. Resistor and capacitor, ceramic filter circuit, or an external oscillator can be connecter to these pins to provide a system clock with various degrees of stability/cost tradeoffs.

Lead length and stray capacitance on these two pins should be minimized. Refer to OSCILLATOR for recommendations about these pins.

- HLT

This pin is used to place the HMCS44C in the Halt State.
Refer to HALT FUNCTION for details of the Halt Mode.

## - TEST

This pin is not for user application and must be connected to $\mathbf{V}_{\mathbf{C C}}$.

- INT $_{0}$ and INT ${ }_{1}$

These pins provide the capability for asynchronously applying external interrupts to the HMCS44C.

Refer to INTERRUPTS for additional information.

- $\mathbf{R}_{00}$ to $\mathbf{R}_{03}, \mathbf{R}_{10}$ to $\mathbf{R}_{13}, \mathbf{R}_{20}$ to $\mathbf{R}_{23}, \mathbf{R}_{30}$ to $\mathbf{R}_{33}$

These 16 lines are arranged into four 4-bit Data Input/Output Common Channels.

The 4-bit registers (Data I/O Register) are attached to these channels. Each channel is directly addressed by the operand of input/output instruction. Refer to INPUT/OUTPUT for additional information.

- $D_{0}$ to $D_{15}$

These lines are 16 1-bit Discrete Input/Output Common Pins. The 1-bit latches are attached to these pins. Each pin is addressed by the Y register. The $\mathrm{D}_{0}$ to $\mathrm{D}_{3}$ pins are also addressed directly by the operand of input/output instruction. Refer to INPUT/ OUTPUT for additional information.

## - ROM

- ROM Address Space

ROM is used as a memory for the instructions and the patterns (constants). The instruction used in the HMCS44C consists of 10 bits. These 10 bits are called "a word", which is a unit for writing into ROM.

The ROM address is composed of the program area ( 0 page to 31 page) and the pattern area ( 61,62 page) ( 64 words/page).

The ROM capacity is 2,176 words ( 1 word $=10$ bits) in all.
Only the program area can contain both the instructions and the patterns (constants).

The ROM address space is shown in Figure 1.


Figure 1 ROM Address Space

Program Counter (PC)
The program counter is used for addressing of ROM. It consists of the page part and the address part as shown in Figure 2.


Figure 2 Configuration of Program Counter

Once a certain value is loaded into a page part, the content is unchanged until other value is loaded by the program. The settable value of a page part is any number between 0 to 31 .

The address part is a 6 -bit polynomial counter and counts up for each instruction cycle time. The sequence in the decimal and hexa-decimal system is shown in Table 1. This sequence is circulating and has neither the starting nor ending point. It doesn't generate an overflow carry. Consequently, the program on a same page is executed in order unless the value of the page part is changed.

Table 1 Program Counter Address Part Sequence

| Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 63 | 3F | 5 | 05 | 9 | 09 |
| 62 | 3E | 11 | OB | 19 | 13 |
| 61 | 3D | 23 | 17 | 38 | 26 |
| 59 | 38 | 46 | 2E | 12 | OC |
| 55 | 37 | 28 | 1 C | 25 | 19 |
| 47 | 2 F | 56 | 38 | 50 | 32 |
| 30 | 1E | 49 | 31 | 37 | 25 |
| 60 | 3 C | 35 | 23 | 10 | OA |
| 57 | 39 | 6 | 06 | 21 | 15 |
| 51 | 33 | 13 | OD | 42 | 2A |
| 39 | 27 | 27 | 18 | 20 | 14 |
| 14 | OE | 54 | 36 | 40 | 28 |
| 29 | $1{ }^{10}$ | 45 | 2D | 16 | 10 |
| 58 | 3A | 26 | 1A | 32 | 20 |
| 53 | 35 | 52 | 34 | 0 | 00 |
| 43 | 2B | 41 | 29 | 1 | 01 |
| 22 | 16 | 18 | 12 | 3 | 03 |
| 44 | 2C | 36 | 24 | 7 | 07 |
| 24 | 18 | 8 | 08 | 15 | OF |
| 48 | 30 | 17 | 11 | 31 | 1F |
| 33 | 21 | 34 | 22 |  |  |
| 2 | 02 | 4 | 04 |  |  |

## - Designation of ROM Address and ROM Code

The page part of the ROM address is represented by decimal and the address part is divided into 2 parts ( 2 bits and 4 bits) and represented by hexa-decimal.

One word ( 10 bits) is divided into three parts ( 2 bits, 4 bits and 4 bits from the most significant bit $\mathrm{O}_{10}$ ) and represented by hexadecimal. The examples are shown in Figure 3.
(a) ROM Address

(b) ROM Code


Figure 3 Designation of ROM Address and ROM Code

## - PATtERN GENERATION

The pattern (constants) can be accessed by the pattern instruction (P). The pattern can be written in any address of the ROM address space.

- Reference

ROM addressing for reference of the patterns is achieved by modifying the program counter with the accumulator, the $\mathbf{B}$ register, the Carry F/F and the operand p. Figure 4 shows how to modify the program counter. The address part is replaced with the accumulator and the lower 2 bits of $B$ register, while the page part is ORed with the upper 2 bits of B register, the Carry F/F and the operand $\mathrm{p}\left(\mathrm{p}_{0}, \mathrm{p}_{1}\right)$. The upper bit ( $\mathrm{p}_{2}$ ) of the operand is for referring to the pattern area.

The value of the operand $p$ is 0 to 7 .
The content of the program counter is only modified apparently and is not changed. Then the address is counted up after the execution of the pattern instruction and the next instruction is executed.

The execution time of this instruction is 2 -cycle time.
Even when interrupt is enable, interrupt is disabled in the second cycle of the pattern instruction. However, the interrupt request is latched into the interrupt request $\mathrm{F} / \mathrm{F}$.

## - Generation

The pattern of referred ROM address is generated as the following two ways:
(i) The pattern is loaded into the accumulator and B register.
(ii) The pattern is loaded into the Data I/O registers R2 and R3.

Selection is determined by the command bits ( $\mathrm{O}_{9}, \mathrm{O}_{10}$ ) in the pattern.

Mode (i) is performed when $\mathrm{O}_{9}$ is " 1 " and mode (ii) is performed when $O_{10}$ is " 1 ".

Mode (i) and mode (ii) are simultaneously performed when both $\mathrm{O}_{9}$ and $\mathrm{O}_{10}$ are " 1 ".

The correspondence of each bit of the pattern is shown in Figure 5.

Examples of the pattern instruction usage is shown in Table 2.


Figure 4 ROM Addressing for Pattern Generation


Figure 5 Correspondence of Each Bit of Pattern

Table 2 Example of Pattern Instruction Usage

| Before Execution |  |  |  |  | ReferredROMAddress | Pattern | After Execution |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PC Value | p | C | B | A |  |  | B | A | R2 | R3 |
| 0.3F | 1 | 0 | A | 0 | 10-20 | 12D | 2 | B |  |  |
| 0.3F | 7 | 1 | 4 | 0 | 61-00 | 22D |  |  | 4 | B |
| 30-00 | 4 | 0/1 | 0 | 9 | 62-09 | 32D | 2 | B | 4 | B |
| 30-00 | 4 | 0/1 | F | 9 | 63-39 |  |  |  |  |  |

"-" means that the value is unchanged after the execution.
"0/1" means that either " 0 " or " 1 " will do.

## - BRANCH

ROM is accessed according to the program counter sequence and the program is executed. In order to jump to any address out of the sequence, there are four ways.

They are explained in the following paragraphs.

- BR

By BR instruction, the program branches to an address in the current page.

The lower 6 bits of ROM Object Code (operand $a, \mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) are transferred to the lower 6 bits of the program counter. This instruction is a conditional instruction and executed only when the Status $F / F$ is " 1 ". If it is " 0 ", the instruction is skipped and the Status F/F becomes " 1 ". The operation is shown in Figure 6.

- LPU

By LPU instruction, the jump of page is performed.
The lower 5 bits of the ROM Object Code (operand $u$ ) are transferred to the page part of the program counter with a delay of 1 instruction cycle time. Therefore, the cycle just after the issuing of this instruction is on the same page and the page jump is performed at the next cycle.

This instruction is a conditional instruction and performed only when the Status is " 1 ". But the Status is unchanged (remains " 0 ") even if it is skipped. The operation is shown in Figure 7.


Figure 6 BR Operation


Figure 7 LPU Operation

- BRL

By BRL instruction, the program branches to an address in any page.

This instruction is a macro instruction of LPU and BR instructions, which is divided into two instructions as follows.

$$
\begin{aligned}
& \text { BRL } a-b \rightarrow \text { LPU } a \\
& <\text { Jump to } b \text { address on a page }> \\
& \text { BR } b
\end{aligned}
$$

BRL instruction is a conditional instruction because of characteristics of LPU and BR instructions, and is executed only when the Status F/F is " 1 ". If the Status F/F is " 0 ", the instruction is skipped and the Status F/F becomes " 1 ".

- TBR (Table Branch)

By TBR instruction, the program branches by the table.
The program counter is modified with the accumulator, the B register, the Carry F/F, the operand $p$. The method for modification is shown in Figure 8.

The accumulator and the lower 2 bits of B register are assigned into the address part of the program counter. The upper 2 bits of $B$ register, Carry $F / F$, and the operand $p_{1}, p_{0}$ are ORed with the page part of the program counter.

TBR instruction is executed regardless of the Status $F / F$, and does not affect the Status F/F.


Figure 8 Modification of Program Counter by TBR Instruction

## SUBROUTINE JUMP

There are two types of subroutine jumps. They are explained in the following paragraphs.

- CAL

By CAL instruction, subroutine jump to an address in the Subroutine Page.

The Subroutine Page is 0 page.
The address next to CAL instruction address is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively as shown in Figure 9.


Figure 9 Subroutine Jump Stacking Order
The page part of the program counter is 0 . The lower 6 bits (operand $\mathrm{a}, \mathrm{O}_{6}$ to $\mathrm{O}_{6}$ ) of the ROM Object Code is transferred to the address part of the program counter.

The HMCS44C has 4 levels of stack (ST1, ST2, ST3 and ST4) which allows the programmer to use up to 4 levels of subroutine jumps (including interrupts).

CAL is a conditional instruction and executed only when the

Status F/F is " 1 ". If the Status $F / F$ is " 0 ", it is skipped and the Status F/F changes to " 1 ".

- CALL

By CALL instruction, subroutine jump to an address in any page.

Subroutine jump to any address can be implemented by the subroutine jump to the page specified by LPU instruction.

This instruction is a macro instruction of LPU and CAL instructions, which is divided into two instructions as follows.

$$
\text { CALL } a-b \rightarrow \text { LPU } a
$$

<Subroutine jump to $b$ address on a page> CAL $b$
CALL instruction is conditional because of characteristics of LPU and CAL instructions and is executed when the Status F/F is " 1 ". If the Status F/F is " 0 ", it is skipped and the Status F/F changes to " 1 ".

- RAM

RAM is a memory used for storing data and saving the contents of the registers. Its capacity is 160 digits ( 640 bits) where one digit consists of 4 bits.

Addressing of RAM is performed by a matrix of the file No. and the digit No.

The file No. is set in the $\mathbf{X}$ register and the digit No. in the $\mathbf{Y}$ register for reading, writing or testing. Specific digits in RAM can be addressed not via the $X$ register and $Y$ register. These digits are called "Memory Register (MR)", 0 to 15 ( 16 digits in all). The memory register can be exchanged with the accumulator by XAMR instruction.

The RAM address space is shown in Figure 10.
In an instruction in which reading from RAM and writing to RAM coexist (exchange between RAM and the register), reading precedes writing and the write data does not affect the read data.

The RAM bit manipulation instruction enables any addressed RAM bit to be set, reset or tested. The bit assignment is specified by the operand $n$ of the instruction.

The bit test makes the Status $\mathrm{F} / \mathrm{F}$ " 1 " and makes it " 0 " when the assigned bit is " 0 ".

Correspondence between the RAM bit and the operand $n$ is shown in Figure 11.


* The file 8 is selected when $X$ register has any value in 8 to 11 , and the file

9 is selected when 12 to 15.

Figure 10 RAM Address Space


Figure 11 RAM Bit and Operand n

## - REGISTER

The HMCS44C has six 4-bit registers and two 1-bit registers available to the programmer. The 1-bit registers are the Carry F/ $F$ and the Status $F / F$. They are explained in the following paragraphs.

## - Status F/F (S)

The Status F/F latches the result of logical or arithmetic operations (Not Zero, Overflow) and bit test operations. The Status F/F affects conditional instructions (LPU, BR and CAL instructions). These instructions are executed only when the Status F/F is " 1 ". If it is " 0 ", these instructions are skipped and the Status F/F becomes " 1 ".

- Accumulator (A; A Register) and Carry F/F (C)

The result of the Arithmetic Logic Unit (ALU) operation (4 bits) and the overflow of the ALU are loaded into the accumulator and the Carry F/F. The Carry F/F can be set, reset or tested. Combination of the accumulator and the Carry F/F can be right or left rotated. The accumulator is the main register for ALU operation and the Carry F/F is used to store the overflow generated by ALU operation when the calculation of two or more digits (4 bits/digit) is performed.

## - B Register (B)

The result of ALU operation (4 bits) is loaded into this register. The $\mathbf{B}$ register is used as a sub-accumulator to stack data temporarily and also used as a counter.

## - $X$ Register (X)

The result of ALU operation (4 bits) is loaded into this register. The $\mathbf{X}$ register has exchangeability for the SPX register. The $X$ register addresses the RAM file and is composed of 4-bit register.

- SPX Regişter (SPX)

The SPX register has exchangeability for the $X$ register.
The SPX register is used to stack the $X$ register and expand the addressing system of RAM in combination with the $X$ register. It is composed of 4-bit register.

## - Y Register ( $\mathbf{Y}$ )

The result of ALU operation ( 4 bits) is loaded into this register. The Y register has exchangeability for the SPY register. The $Y$ register can calculate itself simultaneously with transferring data by the bus lines, which is usable for the calculation of two or more digits ( 4 bits/digit). The $Y$ register addresses the RAM digit and 1-bit Discrete 1/O.

- SPY Register (SPY)

The SPY register has exchangeability for the $Y$ register. The SPY register is used to stack the $Y$ register and expand the addressing system of RAM and 1-bit Discrete I/O in combination with the Y register.

## - INPUT/OUTPUT

- 4-bit Data Input/Output Channel (R)

The HMCS44C has four 4-bit Data I/O Common Channels (R0, R1, R2, R3).

The 4-bit registers (Data I/O Register) are attached to R1, R2 and R3 channels.

Each channel is directly addressed by the operand p of input/ output instruction.

The data is transferred from the accumulator and the $B$ register to the Data I/O Registers R0 to R3 via the bus lines. Pattern instruction enables the patterns of ROM to be taken into the Data I/O Registers R2 and R3.

Input instruction enables the 4-bit data to be sent to the accumulator and the B register from R0 to R3. Note that, since the Data 1/O Register output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the Data I/O Register output and the pin input.

Therefore, the Data I/O Register should be set to 15 (all bits of the Data I/O Register is " 1 ") not to affect the pin input before execution of input instruction.

The block diagram is shown in Figure 12. The I/O timing is shown in Figure 13.


Figure 12 4-bit Data I/O Block Diagram


Figure 13 4-bit Data $1 / 0$ Timing

- 1-bit Discrete Input/Output Common Terminals (D)

The HMCS44C has 16 1-bit Discrete I/O Common Terminals.
The 1-bit Discrete I/O Common Terminal consists of a 1-bit latch and an I/O common pin.

The 1-bit Discrete I/O is addressed by the $Y$ register. The addressed latch can be set or reset by output instruction and " 0 "
and " 1 " a level can be tested with the addressed pin by input instruction.

Note that, since the latch output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the latch output and the pin input. Therefore, the latch should be set to " 1 " not to affect the pin input before ex-
ecution of input instruction.
The $D_{0}$ to $D_{3}$ terminals are also addressed directly by the operand $n$ of input/output instruction and can be set or reset.

The block diagram is shown in Figure 14 and the I/O timing is shown in Figure 15.


Figure 14 1-bit Discrete I/O Block Diagram


Figure 15 1-bit Discrete I/O Timing

## - I/O Configuration

The $1 / O$ configuration of each pin can be specified among

Open Drain and With Pull up MOS using a mask option as shown in Figure 16.

*When "Disable" is specified for the I/O State at the Halt State, the I/O Enable signal shown in the figure turns off the input circuit, Pull up MOS and NMOS output and sets CMOS output to high impedance (PMOS, NMOS; OFF).

Figure 16 I/O Configuration

## - TIMER/COUNTER

The timer/counter consists of the 4 -bit counter and the 6 -bit prescaler as shown in Figure 17. The 4-bit counter may be loaded under program control and is incremented toward 15 by the prescaler overflow output pulse or the input pulse of INT 1 pin (its leading edge is counted). The clock input to the counter is selected by the CF F/F. When the CF F/F is " 0 ", the clock input is the prescaler overflow output pulse (Timer Mode). When the CF F/F is " 1 ", the clock input is the input pulse of INT $_{1}$ pin (Counter Mode). When the counter reaches zero (returns from 15 to zero), the overflow output pulse is generated and the counter continues to count $(14 \rightarrow 15 \rightarrow 0 \rightarrow 1 \rightarrow 2$ ...).

The TF F/F is a flip-flop which masks interrupts from the timer/counter. It can be set and reset by interrupt instruction. If the overflow output pulse of the counter is generated when the TF F/F is reset (" 0 "), an interrupt request occurs and the TF F/
$F$ becomes " 1 ". If the overflow output pulse is generated when the TF F/F is set (" 1 "), no interrupt request occurs. The TTF instruction enables the TF F/F to be tested.

The prescaler is a 6-bit frequency divider. It divides a system clock (instruction frequency) by 64 into the overflow output pulses of "instruction frequency $\div 64$ ".

The prescaler is cleared when data is loaded into the counter (by LTA or LTI instruction). The frequency division is 0 when the prescaler is cleared. At the 64th clock, an overflow output pulse is generated from the prescaler. During operation of the LSI, the prescaler is operating and cannot be stopped. The relation between the specified value of the counter and specified time in the Timer Mode is shown in Table 3.

The pulse width of the $\mathrm{INT}_{1}$ pin in the Counter Mode must be at least 2-cycle time for both "High" and "Low" levels as shown in Figure 18.


Figure 17 Timer/Counter Block Diagram

Table 3 Timer Range

| Specified <br> Value | Number of <br> cycles | Time (ms) | Specified <br> Value | Number of <br> cycles | Time (ms) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1.024 | 10.24 | 8 | 512 | 5.12 |
| 1 | 960 | 9.60 | 9 | 448 | 4.48 |
| 2 | 896 | 8.96 | 10 | 384 | 3.84 |
| 3 | 832 | 8.32 | 11 | 320 | 3.20 |
| 4 | 768 | 7.68 | 12 | 256 | 2.56 |
| 5 | 704 | 7.04 | 13 | 192 | 1.92 |
| 6 | 640 | 6.40 | 14 | 128 | 1.28 |
| 7 | 576 | 5.76 | 15 | 64 | 0.64 |

[NOTE] Time is based on instruction frequency 100 kHz . (one instruction cycle $=10 \mu \mathrm{~s}$ )


Figure 18 The Pulse Width of the $\mathrm{INT}_{1}$ pin in the Counter Mode

## - INTERRUPT

The HMCS44C can be interrupted in two different ways: through the external interrupt input pins ( $\mathrm{INT}_{0}, \mathrm{INT}_{1}$ ) and the timer/counter interrupt request. When any interrupt occurs, processing is suspended, the Status F/F is unchanged, the present program counter is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively. At that time, the Interrupt Enable F/F (I/E) is set and the address jumps to a fixed destination (Interrupt Address), and then the interrupt routine is executed. Stacking the registers other than the program counter must be performed by the program. The interrupt routine must end with RTNI (Return Interrupt) instruction which sets the I/E F/F simultaneously with the RTN instruction.

The Interrupt Address:
Input Interrupt Address . . . . .
1 Page 3F Address
Timer/Counter Interrupt Address . . . . .
0 Page 3F Address
The input interrupt has priority over the timer/counter interrupt.

The $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ pin have an interrupt request function.

Each terminal consists of a circuit which generates leading pulse and the interrupt mask F/F (IF0, IF1). An interrupt is enabled (unmasked) when the IF0 F/F or IF1 F/F is reset. When the $\mathrm{INT}_{0}$ or $\mathrm{INT}_{1}$ pin changes from " 0 " to " 1 " (from "Low" level to "High" level), a leading pulse is generated to produce an interrupt request. At the same time, the IF0 F/F or IF1 F/F is set. When the IF0 F/F or IF1 F/F is set, the interrupt masking for the pin will result. (If a leading pulse is generated, no interrupt request occurs.)

An interrupt request generated by the leading pulse is latched into the input interrupt request $\mathrm{F} / \mathrm{F}$ (I/RI) on the input side. If the Interrupt Enable F/F (I/E) is " 1 " (Interrupt Enable State), an interrupt occurs immediately and the I/RI F/F and the I/E F/ F are reset. If the I/E F/F is " 0 " (Interrupt Disable State), the I/ RI F/F is held at " 1 " until the HMCS44C gets into the Interrupt Enable State.

The IF0 F/F, the IF1 F/F, the $\mathrm{INT}_{0}$ pin and the $\mathrm{INT}_{1}$ pin can be tested by interrupt instruction. Therefore, the $\mathrm{INT}_{0}$ and the INT $T_{1}$ can be used as additional input pins with latches.

The INT $_{0}$ pin and INT $_{1}$ pin can be provided with Pull up MOS using a mask option as shown in Figure 19.

An interrupt request from the timer/counter is latched into the timer interrupt request $\mathrm{F} / \mathrm{F}$ (I/RT). The succeeding operations are the same as an interrupt from the input. Only the exception is that, since an interrupt from the input precedes a timer/counter interrupt, the input interrupt occurs if both the I/ RI F/F and the 1/RT F/F are " 1 " (when the input interrupt and the timer/counter interrupts are generated simultaneously). During this processing, the I/RT F/F remains " 1 ". The timer/counter interrupt can be implemented after the input interrupt processing is achieved.

The interrupt circuit block diagram is shown in Figure 20.


Figure 19 Configuration of $I N T_{0}$ and $I N T_{1}$


Figure 20 Interrupt Circuit Block Diagram

## RESET FUNCTION

The reset is performed by setting the RESET pin to " 1 " ("High" level) and the HMCS44C gets into operation by setting it to " 0 " ("Low" level). Refer to Figure 21. Moreover, the HMCS44C has the automatic reset function (ACL; Built-in Reset Circuit). The Built-in Reset Circuit restricts the rise condition of the power supply. Refer to Figure 22. When the Built-in Reset Circuit is used, RESET should be connected to $\mathrm{V}_{\mathrm{SS}}$.

Internal state of the HMCS44C are specified as follows by the
reset function.

- Program Counter (PC) is set to 3 F address on 31 page (313F).
- I/RI, I/RT, I/E and CF are reset to " 0 ".
- IF0, IF1 and TF are set to " 1 ".
- Reset/Set of I/O latch and register ( $D_{0}$ to $D_{15}, R 0$ to R6) are set to " 1 ".
Note that other blocks (Status, Register, Timer/Counter, RAM, etc.) are not cleared.

- trST1 includes the time required from the power ON until the operation gets into the constant state.
- tRST2 is applied when the operation is in the constant state.

Figure 21 RESET Timing

${ }^{\text {t OFF }}$ specifies the period when the power supply is OFF in the case that a short break of the power supply occurs and the power supply ON/OFF is repeated.

Figure 22 Power Supply Timing for Built-in Reset Circuit

## HALT FUNCTION

When the HLT pin is set to " 0 " ("Low" level), the internal clock stops and all the internal statuses (RAM, the Registers, the Carry F/F, the Status F/F, the Program Counter, and all the internal statuses) are held. Because all internal logic operation stop, power consumption is reduced. There are two input/output statuses in the Halt State. The user should specify either "Enable" or "Disable" using a mask option at the time of ordering ROM.
"Enable"——Output........ The Status before the Halt State is held.
-Pull up MOS. . ON
Input........... No relation to "Halt"
Since Pull up MOS is ON, Pull up MOS current flows with output " 0 " ("Low" level) in the Halt State (NMOS;ON). When an input signal changes, transmission current flows into an input circuit. Also, current flows into Pull up MOS. These cur-
rents are added to the Stand-by Supply Current (or Halt Current).
"Disable"_Output . . . . . . . . High Impedance (NMOS, PMOS: OFF)

- Pull up MOS. . . OFF

Input. .......... Input Circuit: OFF
Both input and output are at high impedance state. Since an input circuit is OFF, any current other than the Stand-by Supply Current (or Halt Current) does not flow even if an input signal changes.
When the HLT pin is set to " 1 " ("High" level), the HMCS44C gets into operation from the status just before the Halt State. The halt timing is shown in Figure 23.

CAUTION
If, during the Halt State, the external reset input is applied (RESET = " 1 " ("High" level)), the internal status is not held.


Figure 23 Halt Timing

## OSCILLATOR

The HMCS44C contains its own oscillator and frequency divider (CPG). The user can obtain the desired timing for operation of the LSI by merely connecting an resistor $\mathbf{R}_{\mathrm{f}}$ or ceramic filter circuit (Internal Clock Operation).

The OSC $_{1}$ clock frequency is internally divided by four to produce the internal system clocks.

The user may exchange the external parts for the same LSI to select either of these two operational modes as shown in Figure 24. There is no need of specifying it by using the mask option.
(a) Internal Clock Operation Using Resistor $\mathbf{R}_{f}$


Wiring of OSC 1 and OSC 2 terminals should be as short as
possible because the oscillation frequency is
modified by capacitance of these terminals.
(b) Internal Clock Operation Using Ceramic Filter Circuit (Built-in CPG; Ceramic Filter Oscillator) (This is not applied to HMCS44CL.)


The ceramic filter oscillation does not apply when using "Halt" and not resetting at the time of "Halt" cancellation.
This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefully on your application.
(c) External Clock Operation (External CPG)


Figure 24 Clock Operation Mode

## HMCS44C, HMCS44CL

## - instruction list

The instructions of the HMCS44C are listed according to their functions, as shown in Table 4.

Table 4 Instruction List

| Group | Mnemonic | Function | Status |
| :---: | :---: | :---: | :---: |
| Register - Register Instruction | LAB <br> LBA <br> LAY <br> LASPX <br> LASPY <br> XAMR m | $\begin{aligned} & B \rightarrow A \\ & A \rightarrow B \\ & Y \rightarrow A \\ & S P X \rightarrow A \\ & S P Y \rightarrow A \\ & A \leftrightarrow M R(m) \end{aligned}$ |  |
| RAM Address Register Instruction | LXA <br> LYA <br> LXI i <br> LYI i <br> IY <br> DY <br> AYY <br> SYY <br> XSPX <br> XSPY <br> XSPXY | $\begin{aligned} & \mathrm{A} \rightarrow \mathrm{X} \\ & \mathrm{~A} \rightarrow \mathrm{Y} \\ & \mathrm{i} \rightarrow \mathrm{X} \\ & \mathrm{i} \rightarrow \mathrm{Y} \\ & \mathrm{Y}+1 \rightarrow \mathrm{Y} \\ & \mathrm{Y}-1 \rightarrow \mathrm{Y} \\ & \mathrm{Y}+\mathrm{A} \rightarrow \mathrm{Y} \\ & \mathrm{Y}-\mathrm{A} \rightarrow \mathrm{Y} \\ & \mathrm{X} \leftrightarrow \mathrm{SPX} \\ & \mathrm{Y} \leftrightarrow \mathrm{SPY} \\ & \mathrm{X} \leftrightarrow \mathrm{SPX}, \quad \mathrm{Y} \leftrightarrow \mathrm{SPY} \\ & \hline \end{aligned}$ | $\begin{gathered} \text { NZ } \\ \text { NB } \\ \text { C } \\ \text { NB } \end{gathered}$ |
| RAM - Register Instruction | LAM (XY) <br> LBM (XY) <br> XMA (XY) <br> XMB (XY) <br> LMAIY (X) <br> LMADY (X) | $\begin{aligned} & M \rightarrow A(X Y \leftrightarrow S P X Y) \\ & M \rightarrow B(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow A(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow B(X Y \leftrightarrow S P X Y) \\ & A \rightarrow M, Y+1 \rightarrow Y(X \leftrightarrow S P X) \\ & A \rightarrow M, Y \rightarrow 1 \rightarrow Y(X \leftrightarrow S P X) \end{aligned}$ | $\begin{aligned} & \text { NZ } \\ & \text { NB } \end{aligned}$ |
| Immediate Transfer Instruction | LMIIY <br> LAI i <br> LBI i | $\begin{aligned} & \mathrm{i} \rightarrow \mathrm{M}, \mathrm{Y}+1 \rightarrow \mathrm{Y} \\ & \mathrm{i} \rightarrow \mathrm{~A} \\ & \mathrm{i} \rightarrow B \end{aligned}$ | NZ |
| Arithmetic Instruction | Al i <br> IB <br> DB <br> AMC <br> SMC <br> AM <br> DAA <br> DAS <br> NEGA <br> COMB <br> SEC <br> REC <br> TC <br> ROTL <br> ROTR <br> OR | $\begin{aligned} & A+i \rightarrow A \\ & B+1 \rightarrow B \\ & B-1 \rightarrow B \\ & M+A+C(F / F) \rightarrow A \\ & M-A-C(F / F) \rightarrow A \\ & M+A \rightarrow A \end{aligned}$ <br> Decimal Adjustment (Addition) <br> Decimal Adjustment (Subtraction) <br> $\bar{A}+1 \rightarrow A$ <br> $\bar{B} \rightarrow B$ <br> $" 1 " \rightarrow C(F / F)$ <br> " 0 " $\rightarrow C$ (F/F) <br> Test C (F/F) <br> Rotation Left <br> Rotation Right <br> $A \cup B \rightarrow A$ | $\begin{gathered} \hline \text { C } \\ \text { NZ } \\ \text { NB } \\ \text { C } \\ \text { NB } \\ \text { C } \\ \\ \\ \\ \text { C (F/F) } \end{gathered}$ |


| Group | Mnemonic | Function | Status |
| :---: | :---: | :---: | :---: |
| Compare Instruction | MNEI i <br> YNEI i <br> ANEM <br> BNEM <br> ALEI i <br> ALEM <br> BLEM | $\begin{aligned} & M \neq i \\ & Y \neq i \\ & A \neq M \\ & B \neq M \\ & A \leqq i \\ & A \leqq M \\ & B \leqq M \end{aligned}$ | NZ NZ NZ NZ NB NB NB |
| RAM Bit Manipulation Instruction | SEM $n$ REM $n$ TM n | $\begin{aligned} & " 1 " \rightarrow M(n) \\ & " O " \rightarrow M(n) \\ & \text { Test } M(n) \end{aligned}$ | M(n) |
| ROM Address Instruction | BR a CAL a LPU u TBR p RTN | Branch on Status 1 <br> Subroutine Jump on Status 1 <br> Load Program Counter Upper on Status 1 <br> Table Branch <br> Return from Subroutine | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
| Interrupt Instruction | SEIE SEIFO SEIF1 SETF SECF REIE REIFO REIF1 RETF RECF TIO TI1 TIFO TIF1 TTF LTI i LTA LAT RTNI | $\begin{aligned} & " 1 " \rightarrow \text { I/E } \\ & " 1 " \rightarrow \text { IFO } \\ & " 1 " \rightarrow \text { IF1 } \\ & " 1 " \rightarrow \text { TF } \\ & " 1 " \rightarrow \text { CF } \\ & " O " \rightarrow I / E \\ & " O " \rightarrow \text { IFO } \\ & " 0 " \rightarrow \text { IF1 } \\ & " 0 " \rightarrow \text { TF } \\ & " 0 " \rightarrow \text { CF } \\ & \text { Test } \quad \text { INTo } \\ & \text { Test } \quad \text { INT1 } \\ & \text { Test } \quad \text { IFO } \\ & \text { Test } \quad \text { IF1 } \\ & \text { Test } \quad \text { TF } \\ & \mathrm{i} \rightarrow \text { Timer/Counter } \\ & \text { A } \rightarrow \text { Timer/Counter } \\ & \text { Timer/Counter } \rightarrow \text { A } \\ & \text { Return Interrupt } \end{aligned}$ | INTo <br> $\mathrm{INT}_{1}$ <br> IFO <br> IF1 <br> TF |
| Input/Output Instruction | SED RED TD SEDD $n$ REDD $n$ LAR $p$ LBR $p$ LRA $p$ LRB $p$ $P p$ | $\begin{aligned} & " 1 " \rightarrow D(Y) \\ & " 0 " \rightarrow D(Y) \\ & \text { Test } \quad D(Y) \\ & " 1 " \rightarrow D(n) \\ & " O " \rightarrow D(n) \\ & R(p) \rightarrow A \\ & R(p) \rightarrow B \\ & A \rightarrow R(p) \\ & B \rightarrow R(p) \\ & \text { Pattern Generation } \end{aligned}$ | $\mathrm{D}(\mathrm{Y})$ |
|  | NOP | No Operation |  |

HMCS44C, HMCS44CL
[NOTE] 1. (XY) after a mnemonic code has four meanings as follows.
Mnemonic only Instruction execution only
Mnemonic with $X \quad$ After instruction execution, $X \leftrightarrow S P X$
Mnemonic with $Y \quad$ After instruction execution, $Y \leftrightarrow$ SPY
Mnemonic with $X Y \quad$ After instruction execution, $X \mapsto S P X, Y \mapsto S P Y$

| [Example] | LAM | $M \rightarrow A$ |
| :--- | :--- | :--- |
|  | LAMX | $M \rightarrow A, X \mapsto S P X$ |
|  | LAMY | $M \rightarrow A, Y \mapsto S P Y$ |

LAMY $\quad M \rightarrow A, Y \rightarrow S P Y$
LAMXY $\quad M \rightarrow A, X \leftrightarrow S P X, Y \leftrightarrow S P Y$
2. Status column shows the factor which brings the Status $\mathbf{F} / \mathrm{F}^{\text {" } 1 \text { " under judgement instruction or instruction accompanying the judgement. }}$

NZ .........ALU Not Zero
C .........ALU Overflow in Addition, that is, Carry
NB ........ALU Overflow in Subtraction, that is, No Borrow
Except above .........Contents of the status column affects the Status F/F directly.
3. The Carry $\mathbf{F} / \mathbf{F}(\mathbf{C}(F / F)$ ) is not always affected by executing the instruction which affects the Status $\mathrm{F} / \mathrm{F}$. Instructions which affect the Carry $F / F$ are eight as follows.

| AMC | SEC |
| :--- | :--- |
| SMC | REC |
| DAA | ROTL |
| DAS | ROTR |

4. All instructions except the pattern instruction ( $P$ ) are executed in 1 instruction cycle. The pattern instruction ( $P$ ) is executed in 2 instruction cycles.

HMCS44C, HMCS44CL

| HMCS44C Mask Option List | Date  <br>  Customer's Name |
| :--- | :--- | :--- |
| ROM CODE ID |  |
| Hitachi $\mathrm{P} / \mathrm{N}$ |  |


|  | 1/0 | 1/O Option |  |  | Remarks | Pin <br> Name | 1/0 | 1/O Option |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A | B | C |  |  |  | A | B | C |  |
| Do | 1/0 |  |  |  |  | $\mathrm{R}_{00}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{1}$ | 1/0 |  |  |  |  | $\mathrm{R}_{01}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{2}$ | 1/0 |  |  |  |  | $\mathrm{R}_{02}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{3}$ | 1/0 |  |  |  |  | $\mathrm{R}_{03}$ | 1/0 |  |  |  |  |
| D4 | 1/0 |  |  |  |  | $\mathrm{R}_{10}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{5}$ | 1/0 |  |  |  |  | $\mathrm{R}_{11}$ | 1/0 |  |  |  |  |
| D ${ }^{\text {b }}$ | 1/0 |  |  |  |  | $\mathrm{R}_{12}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{7}$ | 1/0 |  |  |  |  | $\mathrm{R}_{13}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{8}$ | 1/0 |  |  |  |  | $\mathrm{R}_{20}$ | 1/0 |  |  |  |  |
| D9 | 1/0 |  |  |  |  | $\mathrm{R}_{21}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{10}$ | 1/0 |  |  |  |  | $\mathrm{R}_{22}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{11}$ | 1/0 |  |  |  |  | $\mathrm{R}_{23}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{12}$ | 1/0 |  |  |  |  | R30 | 1/0 |  |  |  |  |
| $\mathrm{D}_{13}$ | 1/0 |  |  |  |  | $\mathrm{R}_{31}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{14}$ | 1/0 |  |  |  |  | $\mathrm{R}_{32}$ | 1/0 |  |  |  |  |
| D15 | 1/0 |  |  |  |  | $\mathrm{R}_{33}$ | 1/0 |  |  |  |  |
| INTo | 1 |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{INT}_{1}$ | 1 |  |  |  |  |  |  |  |  |  |  |

\& Specify the $I / O$ composition with a mark of " $O$ " in the applicable composition column.
A : No pull up MOS B : With pull up MOS C: CMOS Output
(2) Oscillator \& Halt

| Halt | Not Used | Used (Reset is applied <br> when Halt release) | Used (Reset is not applied <br> when Halt release) |
| :--- | :--- | ---: | ---: |
| Oscillator |  |  |  |
| Resistor |  |  |  |
| Ceramic Resonator |  |  |  |
| External Clock |  |  |  |

\& Please check one section on the above chart.
(3) I/O State at "Halt" Mode

| 1/O State |  |
| :--- | :--- |
| $\square$ Enable |  |
| $\square$ | Disable |

$\hat{\star}$ Mark " $\checkmark$ " in " $\square$ " for the selected I/O state.
(4) Supply Voltage ( $\mathrm{V}_{\mathrm{cc}}$ )

| Supply Voltage $(\mathrm{Vcc})$ |  |
| :--- | :--- |
| $\square$ | $5 \pm 0.5 \mathrm{~V}$ |
| $\square$ | 2.5 V to 5.5 V |

[^0](5) Package

|  |
| :---: |
| Package |
| $\square$ |
| DP-42 |
| $\square$ |
| DP-42S |

\&. Mark $v$ " in " $\square$ " for the selected package.

## HMCS45C(HD44820) HMCS45CL(HD44828)

The HMCS45C is the CMOS 4-bit single chip microcomputer which contains ROM, RAM, I/O and Timer/Event Counter on single chip. The HMCS45C is designed to perform efficient controller function as well as arithmetic function for both binary and BCD data. The CMOS technology of the HMCS45C provides the flexibility of microcomputers for battery powered and battery back-up applications.

## - FEATURES

- 4-bit Architecture
- 2,048 Words of Program ROM (10 bits/Word)

128 Words of Pattern ROM (10 bits/Word)

- 160 Digits of Data RAM (4 bits/Digit)
- 44 I/O Lines and 2 External Interrupt Lines
- Timer/Event Counter
- Instruction Cycle Time: HMCS45C; $10 \mu \mathrm{~s}$

HMCS45CL; $20 \mu \mathrm{~s}$

- All Instructions except One Instruction; Single Word and Single Cycle
- BCD Arithmetic Instructions
- Pattern Generation Instruction - Table Look Up Capability -
- Powerful Interrupt Function 3 Interrupt Sources
- 2 External Interrupt Lines
- Timer/Event Counter

Multiple Interrupt Capability

- Bit Manipulation Instructions for Both RAM and I/O
- Option of I/O Configuration Selectable on Each Pin; Pull Up MOS or CMOS or Open Drain
- Built-in Oscillator
- Built-in Power-on Reset Circuit (HMCS45C only)
- Low Operating Power Dissipation; 2 mW typ.
- Stand-by Mode (Halt Mode); $50 \mu \mathrm{~W}$ max.
- CMOS Technology
- Single Power Supply: HMCS45C; 5V $\pm 10 \%$

HMCS45CL; 2.5 V to 5.5 V


- PIN ARRANGEMENT

(Top View)
- HMCS45C ELECTRICAL CHARACTERISTICS (Vcc=5V $\pm 10 \%$ )
- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $V_{\text {T1 }}$ | -0.3 to $\mathrm{V}_{\mathrm{cc}}+0.3$ | V | Except for terminals specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $\mathrm{V}_{\text {T2 }}$ | -0.3 to +10.0 | V | Applied to only open-drain output pins and open-drain $1 / 0$ common pihs. |
| Maximum Total Output Current (1). | - Elo1 | 45 | mA | [NOTE 3] |
| Maximum Total Output Current (2) | $\Sigma_{\text {Llo2 }}$ | 45 | mA | [NOTE 3] |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ}$ |  |

[NOTE 1] Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS $-1,-\mathbf{2 "}^{\prime \prime}$. If these conditions are exceeded, it could affect reliability of LSI.
NOTE 2] All voltages are with respect to GND
[NOTE 3] Maximum Total Output Current is total sum of output currents which can flow out (or flow in) simultaneously.

- ELECTRICAL CHARACTERISTICS-1 $\left(\mathrm{VCc}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-20^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $V_{1 L}$ |  |  | - | - | 1.0 | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathbf{H I}}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{\mathrm{H} 2}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | 10 | V | 3 |
| Output "Low" Voltage | Vot | $\mathrm{loL}=1.6 \mathrm{~mA}$ |  | - | - | 0.8 | V |  |
| Output "High" Voltage (1) | $\mathrm{V}_{\mathrm{OH} 1}$ | $-\mathrm{l}_{\text {OH }}=1.0 \mathrm{~m}$ |  | 2.4 | - | - | V | 4 |
| Output "High" Voltage (2) | Voh2 | $-\mathrm{l}_{\text {OH }}=0.01$ | mA | $\mathrm{V}_{\text {cc }}-0.3$ | - | - | V | 5 |
| Interrupt Input Hold Time | tint |  |  | 2. $\mathrm{T}_{\text {inst }}$ | - | - | $\mu \mathrm{s}$ |  |
| Interrupt Input Fall Time | tfin |  |  | - | - | 50 | $\mu \mathrm{S}$ |  |
| Interrupt Input Rise Time | trint |  |  | - | - | 50 | $\mu \mathrm{S}$ |  |
| Output "High" Current | IOH | $\mathrm{V}_{\mathrm{OH}}=10 \mathrm{~V}$ |  | - | - | 3 | $\mu \mathrm{A}$ | 6 |
| Input Leakage Current | $11 /$ | $V_{\text {in }}=0$ to $V_{\text {c }}$ |  | - | - | 1.0 | $\mu \mathrm{A}$ | 2 |
|  |  | $V_{\text {in }}=0$ to 1 |  | - | - | 3 |  | 3 |
| Pull up MOS Current | -lp | $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$ |  | 60 | - | 250 | $\mu \mathrm{A}$ |  |
| Supply Current (1) | Iccl | $V_{\mathrm{in}}=\mathrm{V}_{\mathrm{cc}},$ <br> Ceramic Fil Oscillation |  | - | - | 2 | mA | 7 |
| Supply Current (2) | 1 cc 2 | $V_{\text {in }}=V_{c c} .$ <br> $R_{f}$ Oscillatio <br> External | ock Operation | - | - | 1.0 | mA | 7 |
| Standby 1/O Leakage Current | LLs | $\overline{\mathrm{HLT}}=1.0 \mathrm{~V}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ | - | - | 1 | $\mu \mathrm{A}$ | 2, 8 |
|  |  |  | $V_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 3,8 |
| Standby Supply Current | Iccs | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{cc}}, \bar{H}$ | $\bar{T}=0.2 \mathrm{~V}$ | - | - | 10 | $\mu \mathrm{A}$ | 9 |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $f_{\text {cp }}$ |  |  | 200 | 400 | 440 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | trcp |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | tfep |  |  | 0 | - | 0.2 | $\mu \mathrm{S}$ |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\mathrm{cp}}$ |  | 9.1 | 10 | 20 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation ( $\mathrm{R}_{\mathrm{f}}$ Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | $\mathrm{R}_{\mathrm{f}}=91 \mathrm{k} \Omega \pm$ | 2\% | 300 | - | 500 | kHz |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {os }}$ |  | 8.0 | - | 13.3 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation (Ceramic Filter Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | Ceramic Fil | ter Circuit | 392 | - | 408 | kHz |  |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {os }}$ |  | 9.8 | - | 10.2 | $\mu \mathrm{s}$ |  |

[NOTE 1] All voltages are with respect to GND.
[NOTE 2] This is applied to RESET, HLT, OSC $1,{ }_{1} \mathrm{INT}_{0}, I N T_{1}$ and the With Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of I/O pins.
[NOTE 4] This is applied to the CMOS type of I/O or Output pins.
[NOTE 5] This is applied to the With Pull up MOS or CMOS type of $1 / 0$ or Output pins.
[NOTE 6] This is applied to the Open Drain type of I/O or Output pins.
[NOTE 7] 1/O current is excluded.
[NOTE 8] The Standby I/O Leakage Current is the I/O leakage current in the Halt and Disable State
[NOTE 9] 1/O current is excluded.
The Standby Supply Current is the supply current at $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%$ in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration Voltage is called the Halt Current (ldH), and it is shown in "ELECTRICAL CHARACTERISTICS-2."

HMCS45C, HMCS45CL

- ELECTRICAL CHARACTERISTICS-2 ( $\mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$ )

Reset and Halt

| Item | Symbol | Test Conditions | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | typ. | max. |  |
| Halt Duration Voltage | V ${ }_{\text {DH }}$ | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.3 | - | - | V |
| Halt Current | Ioh | $\begin{aligned} & V_{\text {in }}=V_{C C} \\ & H L T=0.2 V, V_{D H}=2.3 V \end{aligned}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Halt Delay Time | thD |  | 100 | - | - | $\mu \mathrm{S}$ |
| Operation Recovery Time | tRC |  | 100 | - | - | $\mu \mathrm{S}$ |
| HLT Fall Time | tfHLT |  | - | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | trict |  | - | - | 1000 | $\mu \mathrm{s}$ |
| HLT "Low" Hold Time | thLT |  | 400 | - | - | $\mu \mathrm{s}$ |
| HLT "High" Hold Time | tOPR | $\mathrm{R}_{\mathrm{f}}$ Oscillation, External Clock Operation | 0.1 | - | - | ms |
|  |  | Ceramic Filter Oscillation | 4 | - | - |  |
| Power Supply Rise Time | $\mathrm{trCC}^{\text {c }}$ | Built-in Reset. $\overline{H L T}=V_{c c}$ | 0.1 | - | 10 | ms |
| Power Supply OFF Time | tOFF | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | 1 | - | - | ms |
| RESET Pulse Width (1) | tRST1 | External Reset, <br> $\mathrm{V}_{\mathrm{cc}}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ <br> ( $R_{f}$ Oscillation, External <br> Clock Operation) | 1 | - | - | ms |
|  |  | External Reset $\mathrm{V}_{\mathrm{cc}}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ (Ceramic Filter Oscillation) | 4 | - | - |  |
| RESET Pulse Width (2) | tRST2 | External Reset $\mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | $\begin{aligned} & 2 \cdot \\ & T_{\text {inst }} \end{aligned}$ | - | - | $\mu \mathrm{S}$ |
| RESET Rise Time | trRST | External Reset $V_{c c}=4.5 \text { to } 5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | - | - | 20 | ms |
| RESET Fall Time | tfRST | $\begin{aligned} & \text { External Reset } \\ & \mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}} \end{aligned}$ | - | - | 20 | ms |

[NOTE] All voltages are with respect to GND.
HMCS45CL ELECTRICAL CHARACTERISTICS $\left(V_{C C}=2.5 \mathrm{~V}\right.$ to 5.5 V$)$

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :--- | :---: | :---: | :---: | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $\mathrm{V}_{\mathrm{T} 1}$ | -0.3 to $\mathrm{V}_{\mathrm{Cc}}+0.3$ | V | Except for terminais specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $\mathrm{V}_{\mathrm{T} 2}$ | -0.3 to +10.0 | V | Applied oo only open-drain output pins <br> and open-drain 1/O common pins. |
| Maximum Total Output Current (1) | $-\Sigma l_{01}$ | 45 | mA | (Note 3) |
| Maximum Total Output Current (2) | $\Sigma l_{02}$ | 45 | mA | (Note 3) |
| Operating Temperature | $\mathrm{T}_{\mathrm{opr}}$ | -20 to +75 | C |  |
| Storage Temperature | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +125 | C |  |

[NOTE 1] Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS-1, -2." If these conditions are exceeded, it could affect reliability of LSI.
[NOTE 2] All voltages are with respect to GND.
[NOTE 3] Maximum Total Output Current is total sum of output currents which can flow out (or flow in) simultaneously.

- ELECTRICAL CHARACTERISTICS-1 ( $\mathrm{V}_{\mathrm{CC}}=2.5$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{\mathrm{LL}}$ |  |  | - | - | $0.15 \cdot V_{c c}$ | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathbf{H} 1}$ |  |  | $0.85 \cdot \mathrm{~V}_{\text {cc }}$ | - | $\mathrm{V}_{\text {cc }}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{\mathrm{H} 2}$ |  |  | $0.85 \cdot V_{\text {cc }}$ | - | 10 | V | 3 |
| Output "Low" Voltage | Vot | $1 \mathrm{loL}=0.4 \mathrm{~mA}$ |  | - | - | 0.4 | V |  |
| Output "High" Voltage | Voh | $-\mathrm{l}_{\mathrm{OH}}=0.08$ | 8 mA | $\mathrm{V}_{\mathbf{c c}}-0.4$ | - | - | V | 4 |
| Interrupt Input Hold Time | tint |  |  | 2. Tinst | - | - | $\mu \mathrm{S}$ |  |
| Interrupt input Fall Time | tfint |  |  | - | - | 50 | $\mu \mathrm{S}$ |  |
| Interrupt Input Rise Time | triNT |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Output "High" Current | loh | $\mathrm{VOH}_{\text {O }}=10 \mathrm{~V}$ |  | - | - | 3 | $\mu \mathrm{A}$ | 5 |
| Input Leakage Current | IL | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\mathrm{C}}$ |  | - | - | 1.0 | $\mu \mathrm{A}$ | 2 |
|  |  | $\mathrm{V}_{\text {in }}=0$ to 10 |  | - | - | 3 |  | 3 |
| Pull-up MOS Current | -lp | $\mathrm{V}_{\mathrm{cc}}=3 \mathrm{~V}$ |  | 10 | - | 80 | $\mu \mathrm{A}$ |  |
| Supply Current | Icc | $\begin{aligned} & \mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{cc}}, \mathrm{~V} \\ & \text { (fosc/fcp }=2 \\ & \mathrm{R}_{\mathrm{f}} \text { Oscillatio } \\ & \text { Clock Opera } \end{aligned}$ | $\begin{aligned} & V_{c c}=3 V \\ & 200 \mathrm{kHz}) \end{aligned}$ <br> En, External ation | - | - | 140 | $\mu \mathrm{A}$ | 6 |
| Standby 1/O Leakage Current | Lis | $\overline{\mathrm{HLT}}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ | - | - | 1 | $\mu \mathrm{A}$ | 2,7 |
|  |  | $=0.5 \mathrm{~V}$ | $\mathrm{V}_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 3,7 |
| Standby Supply Current | Iccs | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{cc}}=2.5$ to 3.5 V | - | - | 6 | $\mu \mathrm{A}$ | 8 |
|  |  | $\overline{\mathrm{HLT}}=0.1 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{cc}}=2.5$ to 5.5 V | - | - | 10 | $\mu \mathrm{A}$ |  |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $f_{c p}$ |  |  | 130 | 200 | 240 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | trep |  |  | 0 | - | 0.2 | $\mu \mathrm{S}$ |  |
| External Clock Fall Time | tffp |  |  | 0 | - | 0.2 | $\mu \mathrm{S}$ |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}$ cp |  | 16.8 | 20 | 30.8 | $\mu \mathrm{S}$ |  |
| Internal Clock Operation (R $\mathbf{R}_{\text {f }}$ Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | $\begin{aligned} & R_{f}=180 \mathrm{k} \Omega \pm 2 \% \\ & \mathrm{~V}_{\mathrm{CC}}=2.5 \text { to } 3.5 \mathrm{~V} \\ & \hline \end{aligned}$ |  | 130 130 | - | 250 | kHz |  |
| Instruction Cycle Time | Tinst | $\begin{array}{\|l\|} \hline T_{\text {inst }}=4 / \mathrm{f} \\ \mathrm{~V}_{\mathrm{cc}}=2.5 \text { to } \\ \hline \mathrm{T}_{\text {inst }}=4 / \mathrm{f} \\ \mathrm{~V}_{\mathrm{cc}}=2.5 \text { to } \\ \hline \end{array}$ | $\frac{3.5 \mathrm{~V}}{\mathrm{c}}$ | 16 11.4 | - | 30.8 30.8 | $\mu \mathrm{S}$ |  |

INOTE 1| All voltages are with respect to GND.
INOTE 2] This is applied to RESET, HLT, OSC 1 , INTO, INT $_{1}$ and the With Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of $1 / O$ pins.
[NOTE 4] This is applied to the CMOS type of $1 / 0$ or Output pins.
|NOTE $\left.5\right|^{\circ}$ This is applied to the Open Drain type of I/O or Output pins.
|NOTE 6| I/O current is excluded.
[NOTE 7] The Standby I/O Leakage Current is the I/O leakage current in the Halt and Disable State.
[NOTE 8] 1/O current is excluded.
The Standby Supply Current is the supply current at $\mathrm{V}_{\mathrm{cc}}=2.5 \mathrm{~V}$ to 5.5 V in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration Voltage is called the Halt Current ( $\mathrm{I}_{\mathrm{DH}}$ ), and it is shown in "ELECTRICAL CHARACTERISTICS-2."

- ELECTRICAL CHARACTERISTICS-2 $(\mathrm{Ta}=-20$ to $+75 \mathrm{C})$

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Halt Duration Voltage | VoH | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.0 | - | V |
| Halt Current | Іон | $\begin{aligned} & \mathrm{V}_{\mathrm{in}}=\mathrm{V}_{\mathrm{cc}}, \mathrm{HLT}=0.1 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DH}}=2.0 \mathrm{~V} \end{aligned}$ | - | 10 | $\mu \mathrm{A}$ |
| Halt Delay Time | thD |  | 200 | - | $\mu \mathrm{S}$ |
| Operation Recovery Time | tre |  | 200 | - | $\mu \mathrm{S}$ |
| HLT Fall Time | tfHLT |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | tr HLT |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT "Low" Hold Time | tHLT |  | 800 | - | $\mu \mathrm{s}$ |
| HLT "High" Hold Time | tOPR | Rf Oscillation, External Clock Operation $V_{c c}=2.5 \text { to } 5.5 \mathrm{~V}$ | 0.2 | - | ms |
| RESET Pulse Width (1) | tRST 1 | External Reset, $\mathrm{V}_{\mathrm{cc}}=2.5 \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}}$ <br> ( $\mathrm{R}_{\mathrm{f}}$ Oscillation, External <br> Clock Operation) | 2 | - | ms |
| RESET Pulse Width (2) | tRST2 | External Reset, $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=2.5 \text { to } 5.5 \mathrm{~V} \\ & \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}} \end{aligned}$ | 2 . <br> Tinst | - | $\mu \mathrm{S}$ |
| RESET Fall Time | tfRST | HLT $=\mathrm{V}_{\text {cc }}$ | - | 20 | ms |
| RESET Rise Time | trRST | $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ | - | 20 | ms |

[NOTE] All voltages are with respect to GND.

## - SIGNAL DESCRIPTION

The input and output signals for the HMCS45C, shown in PIN ARRANGEMENT, are described in the following paragraphs.

- $V_{c c}$ and GND

Power is supplied to the HMCS45C using these two pins. $\mathrm{V}_{\mathrm{CC}}$ is power and GND is the ground connection.

## - RESET

This pin allows resetting of the HMCS45C at times other than the automatic resetting capability (ACL; Built-in Reset Circuit) already in the HMCS45C.

The HMCS45C can be reset by pulling RESET high. Refer to RESET FUNCTION for additional information.

- OSC 1 and OSC $_{2}$

These pins provide control input for the built-in oscillator circuit. Resistor and capacitor, ceramic filter circuit, or an external oscillator can be connected to these pins to provide a system clock with various degrees of stability/cost tradeoffs.

Lead length and stray capacitance on these two pins should be minimized. Refer to OSCILLATOR for recommendations about these pins.

## - HLT

This pin is used to place the HMCS45C in the Halt State.
Refer to HALT FUNCTION for details of the Halt Mode.

## - TEST

This pin is not for user application and must be connected to $V_{C C}$

- INT $_{0}$ and INT ${ }_{1}$

These pins provide the capability for asynchronously applying external interrupts to the HMCS45C.

Refer to INTERRUPTS for additional information.

- $\mathbf{R}_{00}$ to $\mathbf{R}_{03}, \mathbf{R}_{10}$ to $\mathbf{R}_{13}, \mathbf{R}_{20}$ to $\mathbf{R}_{23}, \mathbf{R}_{30}$ to $\mathbf{R}_{33}, \mathbf{R}_{40}$ to $\mathbf{R}_{43}$, $\mathbf{R}_{50}$ to $\mathbf{R}_{53}$
These 24 lines are arranged into six 4-bit Data Input/Output Common Channels.

The 4-bit registers (Data I/O Register) are attached to these channels. Each channel is directly addressed by the operand of input/output instruction. Refer to INPUT/OUTPUT for additional information.

## - $\mathbf{R}_{60}$ to $\mathbf{R}_{63}$

These 4 lines are the 4 bit Data Output Channel.
The 4-bit register (Data I/O Register) is attached to this channel. This channel is directly addressed by the operand of input/ output instruction. Refer to INPUT/OUTPUT for additional information.

- $D_{0}$ to $D_{15}$

These lines are 16 1-bit Discrete Input/Output Common Pins. The 1-bit latches are attached to these pins. Each pin is addressed by the $Y$ register. The $D_{0}$ to $D_{3}$ pins are also addressed directly by the operand of input/output instruction. Refer to INPUT/ OUTPUT for additional information.

## - ROM

## - ROM Address Space

ROM is used as a memory for the instructions and the patterns (constants). The instruction used in the HMCS45C consists of 10 bits. These 10 bits are called " $a$ word", which is a unit for writing into ROM.

The ROM address is composed of the program area ( 0 page to 31 page) and the pattern area ( 61,62 page) ( 64 words/page). The ROM capacity is 2,176 words ( 1 word $=10$ bits) in all. Only the program area can contain both the instructions and the patterns (constants).

The ROM address space is shown in Figure 1.


Figure 1 ROM Address Space

- Program Counter (PC)

The program counter is used for addressing of ROM. It consists of the page part and the address part as shown in Figure 2.


Figure 2 Configuration of Program Counter

Once a certain value is loaded into a page part, the content is unchanged until other value is loaded by the program. The settable value of a page part is any number between 0 to 31 .

The address part is a 6 -bit polynomial counter and counts up for each instruction cycle time. The sequence in the decimal and hexa-decimal system is shown in Table 1. This sequence is circulating and has neither the starting nor ending point. It doesn't generate an overflow carry. Consequently, the program on a same page is executed in order unless the value of the page part is changed.

Table 1 Program Counter Address Part Sequence

| Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 63 | 3F | 5 | 05 | 9 | 09 |
| 62 | 3E | 11 | OB | 19 | 13 |
| 61 | 3D | 23 | 17 | 38 | 26 |
| 59 | 3B | 46 | 2E | 12 | OC |
| 55 | 37 | 28 | 1 C | 25 | 19 |
| 47 | 2F | 56 | 38 | 50 | 32 |
| 30 | 1 E | 49 | 31 | 37 | 25 |
| 60 | 3 C | 35 | 23 | 10 | OA |
| 57 | 39 | 6 | 06 | 21 | 15 |
| 51 | 33 | 13 | OD | 42 | 2A |
| 39 | 27 | 27 | 1 B | 20 | 14 |
| 14 | OE | 54 | 36 | 40 | 28 |
| 29 | 1D | 45 | 2D | 16 | 10 |
| 58 | 3A | 26 | 1 A | 32 | 20 |
| 53 | 35 | 52 | 34 | 0 | 00 |
| 43 | 2B | 41 | 29 | 1 | 01 |
| 22 | 16 | 18 | 12 | 3 | 03 |
| 44 | 2 C | 36 | 24 | 7 | 07 |
| 24 | 18 | 8 | 08 | 15 | OF |
| 48 | 30 | 17 | 11 | 31 | 1F |
| 33 | 21 | 34 | 22 |  |  |
| 2 | 02 | 4 | 04 |  |  |

- Designation of ROM Address and ROM Code

The page part of the ROM address is represented by decimal and the address part is divided into 2 parts ( 2 bits and 4 bits) and represented by hexa-decimal.

One word ( 10 bits) is divided into three parts ( 2 bits, 4 bits and 4 bits from the most significant bit $\mathrm{O}_{10}$ ) and represented by hexadecimal. The examples are shown in Figure 3.
(a) ROM Address

(b) ROM Code


Figure 3 Designation of ROM Address and ROM Code

## - PATTERN GENERATION

The pattern (constants) can be accessed by the pattern instruction ( $P$ ). The pattern can be written in any address of the ROM address space.

- Reference

ROM addressing for reference of the patterns is achieved by modifying the program counter with the accumulator, the $B$ register, the Carry F/F and the operand p. Figure 4 shows how to modify the program counter. The address part is replaced with the accumulator and the lower 2 bits of $B$ register, while the page part is ORed with the upper 2 bits of B register, the Carry F/F and the operand $p\left(p_{0}, p_{1}\right)$. The upper bit ( $p_{2}$ ) of the operand is for referring to the pattern area.

The value of the operand $p$ is 0 to 7 .
The content of the program counter is only modified apparently and is not changed. Then the address is counted up after the execution of the pattern instruction and the next instruction is executed.

The execution time of this instruction is 2-cycle time.
Even when interrupt is enable, interrupt is disabled in the second cycle of the pattern instruction. However, the interrupt request is latched into the interrupt request $\mathrm{F} / \mathrm{F}$.

## - Generation

The pattern of referred ROM address is generated as the following two ways:
(i) The pattern is loaded into the accumulator and $B$ register.
(ii) The pattern is loaded into the Data I/O registers R2 and R3.

Selection is determined by the command bits $\left(\mathrm{O}_{9}, \mathrm{O}_{10}\right)$ in the pattern.

Mode (i) is performed when $\mathrm{O}_{9}$ is " 1 " and mode (ii) is performed when $\mathrm{O}_{10}$ is " 1 ".

Mode (i) and mode (ii) are simultaneously performed when both $\mathrm{O}_{9}$ and $\mathrm{O}_{10}$ are " 1 ".

The correspondence of each bit of the pattern is shown in Figure 5.

Examples of the pattern instruction usage is shown in Table 2.


Figure 4 ROM Addressing for Pattern Generation


Figure 5 Correspondence of Each Bit of Pattern

Table 2 Example of Pattern Instruction Usage

| Before Execution |  |  |  |  | Referred ROM Address | Pattern | After Execution |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PC Value | p | C | B | A |  |  | B | A | R2 | R3 |
| 0-3F | 1 | 0 | A | 0 | 10-20 | 12D | 2 | B | - | - |
| 0-3F | 7 | 1 | 4 | 0 | 61-00 | 22D | - | - | 4 | B |
| 30-00 | 4 | 0/1 | 0 | 9 | 62-09 | 32D | 2 | B | 4 | B |
| 30-00 | 4 | 0/1 | F | 9 | 63-39 |  |  |  |  |  |

"-" means that the value is unchanged after the execution. " $0 / 1$ " means that either " 0 " or " 1 " will do.

- BRANCH

ROM is accessed according to the program counter sequence and the program is executed. In order to jump to any address out of the sequence, there are four ways.

They are explained in the following paragraphs.

- BR

By BR instruction, the program branches to an address in the current page.

The lower 6 bits of ROM Object Code (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) are transferred to the lower 6 bits of the program counter. This instruction is a conditional instruction and executed only when the Status $F / F$ is " 1 ". If it is " 0 ", the instruction is skipped and the Status F/F becomes " 1 ". The operation is shown in Figure 6.


Figure 6 BR Operation

- LPU

By LPU instruction, the jump of page is performed.
The lower 5 bits of the ROM Object Code (operand u) are transferred to the page part of the program counter with a delay of 1 instruction cycle time. Therefore, the cycle just after the issuing of this instruction is on the same page and the page jump is performed at the next cycle.

This instruction is a conditional instruction and performed
only when the Status is " 1 ". But the Status is unchanged (remains " 0 ") even if it is skipped. The operation is shown in Figure 7.


Figure 7 LPU Operation

- BRL

By BRL instruction, the program branches to an address in any page.

This instruction is a macro instruction of LPU and BR instructions, which is divided into two instructions as follows.

$$
\begin{gathered}
\text { BRL } a-b \rightarrow \text { LPU } a \\
\text { <Jump to } b \text { address on a page> }>\text { BR } b
\end{gathered}
$$

BRL instruction is a conditional instruction because of characteristics of LPU and BR instructions, and is executed only when the Status $F / F$ is " 1 ". If the Status $F / F$ is " 0 ", the instruction is skipped and the Status $F / F$ becomes " 1 ".

## - TBR (Table Branch)

By TBR instruction, the program branches by the table.
The program counter is modified with the accumulator, the B register, the Carry $\mathrm{F} / \mathrm{F}$, the operand p . The method for modification is shown in Figure 8.


Figure 8 Modification of Program Counter by TBR Instruction

The accumulator and the lower 2 bits of $B$ register are assigned into the address part of the program counter. The upper 2 bits of $B$ register, Carry F/F, and the operand $p_{1}, p_{0}$ are ORed with the page part of the program counter.

TBR instruction is executed regardless of the Status F/F, and does not affect the Status F/F.

## - SUBROUTINE JUMP

There are two types of subroutine jumps. They are explained in the following paragraphs.

## - CAL

By CAL instruction, subroutine jump to an address in the Subroutine Page.

The Subroutine Page is 0 page.
The address next to CAL instruction address is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively as shown in Figure 9.


Figure 9 Subroutine Jump Stacking Order

The page part of the program counter is 0 . The lower 6 bits (operand $\mathrm{a}, \mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) of the ROM Object Code is transferred to the address part of the program counter.

The HMCS45C has 4 levels of stack (ST1, ST2, ST3 and

ST4) which allows the programmer to use up to 4 levels of subroutine jumps (including interrupts).

CAL is a conditional instruction and executed only when the Status F/F is " 1 ". If the Status F/F is " 0 ", it is skipped and the Status F/F changes to " 1 ".

- CALL

By CALL instruction, subroutine jump to an address in any page.

Subroutine jump to any address can be implemented by the subroutine jump to the page specified by LPU instruction.

This instruction is a macro instruction of LPU and CAL instructions, which is divided into two instructions as follows.

$$
\begin{gathered}
\text { CALL } a-b \rightarrow L P U a \\
\text { <Subroutine jump to } b \text { address on a page }>\quad \text { CAL } b
\end{gathered}
$$

CALL instruction is conditional because of characteristics of LPU and CAL instructions and is executed when the Status F/F is " 1 ". If the Status $F / F$ is " 0 ", it is skipped and the Status F/F changes to " 1 "

- RAM

RAM is a memory used for storing data and saving the contents of the registers. Its capacity is 160 digits ( 640 bits) where one digit consists of 4 bits.

Addressing of RAM is performed by a matrix of the file No. and the digit No.

The file No. is set in the $X$ register and the digit No. in the $Y$ register for reading, writing or testing. Specific digits in RAM can be addressed not via the $X$ register and $Y$ register. These digits are called "Memory Register (MR)", 0 to 15 ( 16 digits in all). The memory register can be exchanged with the accumulator by XAMR instruction.

The RAM address space is shown in Figure 10.
In an instruction in which reading from RAM and writing to RAM coexist (exchange between RAM and the register), reading precedes writing and the write data does not affect the read data.

The RAM bit manipulation instruction enables any addressed RAM bit to be set, reset or tested. The bit assignment is specified by the operand $n$ of the instruction.

The bit test makes the Status $\mathrm{F} / \mathrm{F}$ " 1 " and makes it " 0 " when the assigned bit is " 0 ".

Correspondence between the RAM bit and the operand $n$ is shown in Figure 11.

|  | $Y$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\leftarrow$ digit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ${ }_{+}^{\text {d }}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| - | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\sim$ | N |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| m | $\cdots$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| * | * |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 | 10 | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\omega$ | $\bullet$ | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $N$ | N | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\stackrel{\vdots}{\overline{1}}$ | $\infty$ | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| in | $\infty$ | $\frac{-n}{\dot{x}}$ | $\frac{J}{\frac{\alpha}{\Sigma}}$ | $\frac{m}{\underset{\Sigma}{\sim}}$ | $\frac{N}{\underset{\Sigma}{\Sigma}}$ | $\frac{\bar{x}}{\Sigma}$ | $\frac{0}{\frac{0}{\Sigma}}$ | $\begin{aligned} & 9 \\ & \frac{\square}{2} \\ & \hline \end{aligned}$ | $\begin{aligned} & \infty \\ & \stackrel{Y}{\Sigma} \end{aligned}$ | $\stackrel{\underset{N}{\mathbf{\Sigma}}}{\mathbf{\Sigma}}$ | $\begin{aligned} & 0 \\ & \frac{\tilde{x}}{\mathbf{\Sigma}} \end{aligned}$ | $\begin{array}{\|l\|l\|l\|} \substack{\boldsymbol{n} \\ \Sigma} \end{array}$ | $\underset{\Sigma}{\underset{\Sigma}{\mathbf{L}}}$ | $\underset{\Sigma}{\stackrel{y}{\Sigma}}$ | $\underset{\Sigma}{\underset{\Sigma}{x}}$ | $\underset{\underset{\Sigma}{\alpha}}{\bar{\alpha}}$ | $\left\lvert\, \frac{0}{\Sigma}\right.$ |  |

* The file 8 is selected when $X$ register has any value in 8 to 11 , and the file

9 is selected when 12 to 15
Figure 10 RAM Address Space


Figure 11 RAM Bit and Operand $n$

REGISTER
The HMCS45C has six 4-bit registers and two 1 -bit registers available to the programmer. The l-bit registers are the Carry F/ $F$ and the Status F/F. They are explained in the following paragraphs.

- Status F/F (S)

The Status F/F latches the result of logical or arithmetic operations (Not Zero, Overflow) and bit test operations. The Status F/F affects conditional instructions (LPU, BR and CAL instructions). These instructions are executed only when the Status F/F is " 1 ". If it is " 0 ", these instructions are skipped and the Status F/F becomes " 1 ".

## - Accumulator (A; A Register) and Carry F/F (C)

The result of the Arithmetic Logic Unit (ALU) operation (4 bits) and the overflow of the ALU are loaded into the accumulator and the Carry F/F. The Carry F/F can be set, reset or tested. Combination of the accumulator and the Carry F/F can be right or left rotated. The accumulator is the main register for ALU operation and the Carry F/F is used to store the overflow generated by ALU operation when the calculation of two or more digits (4 bits/digit) is performed.

## - B Register (B)

The result of ALU operation (4 bits) is loaded into this register. The B register is used as a sub-accumulator to stack data temporarily and also used as a counter.

## - X Register (X)

The result of ALU operation ( 4 bits) is loaded into this register. The X register has exchangeability for the SPX register. The $\mathbf{X}$ register addresses the RAM file and is composed of 4-bit register.

- SPX Registor (SPX)

The SPX register has exchangeability for the $\mathbf{X}$ register.
The SPX register is used to stack the X register and expand the addressing system of RAM in combination with the X register. It is composed of 4-bit register.

## - $\mathbf{Y}$ Register ( $\mathbf{Y}$ )

The result of ALU operation (4 bits) is loaded into this register. The Y register has exchangeability for the SPY register. The Y register can calculate itself simultaneously with transferring data by the bus lines, which is usable for the calculation of two or more digits ( 4 bits/digit). The Y register addresses the RAM digit and 1-bit Discrete I/O.

- SPY Register (SPY)

The SPY register has exchangeability for the Y register. The SPY register is used to stack the Y register and expand the addressing system of RAM and 1-bit Discrete I/O in combination with the Y register.

The HMCS45C has four 4-bit Data I/O Common Channels (R0, R1, R2, R3).

The 4-bit registers (Data I/O Register) are attached to R1, R2 and R3 channels.

Each channel is directly addressed by the operand $p$ of input/ output instruction.

The data is transferred from the accumulator and the B register to the Data I/O Registers R0 to R3 via the bus lines. Pattern instruction enables the patterns of ROM to be taken into the Data I/O Registers R2 and R3.

Input instruction enables the 4-bit data to be sent to the accumulator and the B register from R0 to R3. Note that, since the Data I/O Register output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the Data I/O Register output and the pin input.

Therefore, the Data I/O Register should be set to 15 (all bits of the Data I/O Register is " 1 ") not to affect the pin input before execution of input instruction.

The block diagram is shown in Figure 12. The I/O timing is shown in Figure 13.

## - 1-bit Discrete Input/Output Common Terminals (D)

The HMCS45C has 16 1-bit Discrete I/O Common Terminals.
The 1-bit Discrete I/O Common Terminal consists of a 1-bit latch and a I/O common pin.

The 1-bit Discrete I/O is addressed by the Y register. The addressed latch can be set or reset by output instruction and " 0 " and " 1 " a level can be tested with the addressed pin by input instruction.

Note that, since the latch output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the latch output and the pin input. Therefore, the latch should be set to " 1 " not to affect the pin input before execution of input instruction.

The $D_{0}$ to $D_{3}$ terminals are also addressed directly by the operand $n$ of input/output instruction and can be set or reset.

The block diagram is shown in Figure 14 and the I/O timing is shown in Figure 15.

## - I/O Configuration

The I/O configuration of each pin can be specified among Open Drain and With Pull up MOS using a mask option as shown in Figure 16.


Figure 12 4-bit Data I/O Block Diagram


Figure 13 4-bit Data $1 / O$ Timing


Figure 14 1-bit Discrete I/O Block Diagram


Figure 15 1-bit Discrete I/O Timing

HMCS45C, HMCS45CL
(a) Configuration of Output Pin

(b) Configuration of $1 / \mathrm{O}$ Pin

*When "Disable" is specified for the $1 / O$ State at the Halt State,
the $1 / O$ Enable signal shown in the figure turns off the input circuit, Pull up MOS and NMOS output and sets CMOS output to high impedance (PMOS, NMOS; OFF).

Figure 16 I/O Configuration

## TIMER/COUNTER

The timer/counter consists of the 4 -bit counter and the 6 -bit prescaler as shown in Figure 17. The 4 -bit counter may be loaded under program control and is incremented toward 15 by the prescaler overflow output pulse or the input pulse of $\mathrm{INT}_{1}$ pin (its leading edge is counted). The clock input to the counter is selected by the CF F/F. When the CF F/F is " 0 ", the clock input is the prescaler overflow output pulse (Timer Mode). When the CF F/F is " 1 ", the clock input is the input pulse of $\mathrm{INT}_{1}$ pin (Counter Mode). When the counter reaches zero (returns from 15 to zero), the overflow output pulse is generated and the counter continues to count $(14 \rightarrow 15 \rightarrow 0 \rightarrow 1 \rightarrow 2$ ...).

The TF F/F is a flip-flop which masks interrupts from the timer/counter. It can be set and reset by interrupt instruction. If the overflow output pulse of the counter is generated when the TF F/F is reset ("0"), an interrupt request occurs and the TF F/

F becomes " 1 ". If the overflow output pulse is generated when the TF F/F is set (" 1 "), no interrupt request occurs. The TTF instruction enables the TF F/F to be tested.

The prescaler is a 6 -bit frequency divider. It divides a system clock (instruction frequency) by 64 into the overflow output pulses of "instruction frequency $\div 64$ ".

The prescaler is cleared when data is loaded into the counter (by LTA or LTI instruction). The frequency division is 0 when the prescaler is cleared. At the 64th clock, an overflow output pulse is generated from the prescaler. During operation of the LSI, the prescaler is operating and cannot be stopped. The relation between the specified value of the counter and specified time in the Timer Mode is shown in Table 3.

The pulse width of the $\mathrm{INT}_{1}$ pin in the Counter Mode must be at least 2-cycle time for both "High" and "Low" levels as shown in Figure 18.


Figure 17 Timer/Counter Block Diagram

Table 3 Timer Range

| Specified <br> Value | Number of <br> cycles | Time (ms) | Specified <br> Value | Number of <br> cycles | Time (ms) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1,024 | 10.24 | 8 | 512 | 5.12 |
| 1 | 960 | 9.60 | 9 | 448 | 4.48 |
| 2 | 896 | 8.96 | 10 | 384 | 3.84 |
| 3 | 832 | 8.32 | 11 | 320 | 3.20 |
| 4 | 768 | 7.68 | 12 | 256 | 2.56 |
| 5 | 704 | 7.04 | 13 | 192 | 1.92 |
| 6 | 640 | 6.40 | 14 | 128 | 1.28 |
| 7 | 576 | 5.76 | 15 | 64 | 0.64 |

[NOTE] Time is based on instruction frequency 100 kHz . (one instruction cycle $=10 \mu \mathrm{~s}$ )


Figure 18 The Pulse Width of the $\operatorname{INT} T_{1}$ pin in the Counter Mode

## - INTERRUPT

The HMCS45C can be interrupted in two different ways: through the external interrupt input pins ( $\mathrm{INT}_{0}, \mathrm{INT}_{1}$ ) and the timer/counter interrupt request. When any interrupt occurs, processing is suspended, the Status $F / F$ is unchanged, the present program counter is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively. At that time, the Interrupt Enable F/F ( $\mathrm{I} / \mathrm{E}$ ) is set and the address jumps to a fixed destination (Interrupt Address), and then the interrupt routine is executed. Stacking the registers other than the program counter must be performed by the program. The interrupt routine must end with RTNI (Return Interrupt) instruction which sets the I/E F/F simultaneously with the RTN instruction.

The Interrupt Address:
Input Interrupt Address . . . . .
1 Page 3F Address
Timer/Counter Interrupt Address . . . . .
0 Page 3F Address
The input interrupt has priority over the timer/counter interrupt.

The $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ pin have an interrupt request function.
Each terminal consists of a circuit which generates leading pulse and the interrupt mask $\mathrm{F} / \mathrm{F}$ (IF0, IF1). An interrupt is enabled (unmasked) when the IFO F/F or IF1 F/F is reset. When the $\mathrm{INT}_{0}$ or $\mathrm{INT}_{1}$ pin changes from " 0 " to " 1 " (from "Low" level to "High" level), a leading pulse is generated to produce an interrupt request. At the same time, the IF0 F/F or IF1 F/F is set. When the IF0 F/F or IF1 F/F is set, the interrupt masking for the pin will result. (If a leading pulse is generated, no interrupt request occurs.)
An interrupt request generated by the leading pulse is latched into the input interrupt request $\mathrm{F} / \mathrm{F}$ (I/RI) on the input side. If the Interrupt Enable F/F (I/E) is "1" (Interrupt Enable State), an interrupt occurs immediately and the I/RI F/F and the I/E F/ F are reset. If the I/E F/F is " 0 " (Interrupt Disable State), the I/ RI F/F is held at " 1 " until the HMCS45C gets into the Interrupt Enable State.

The IF0 F/F, the IF1 F/F, the INT $_{0}$ pin and the INT $_{1}$ pin can be tested by interrupt instruction. Therefore, the $\mathrm{INT}_{0}$ and the $\mathrm{INT}_{1}$ can be used as additional input pins with latches.

The $\mathrm{INT}_{0}$ pin and $\mathrm{INT}_{1}$ pin can be provided with Pull up MOS using a mask option as shown in Figure 19.

An interrupt request from the timer/counter is latched into the timer interrupt request $\mathrm{F} / \mathrm{F}$ (I/RT). The succeeding operations are the same as an interrupt from the input. Only the exception is that, since an interrupt from the input precedes a timer/counter interrupt, the input interrupt occurs if both the I/ RI F/F and the I/RT F/F are " 1 " (when the input interrupt and the timer/counter interrupts are generated simultaneously). During this processing, the I/RT F/F remains " 1 ". The timer/counter interrupt can be implemented after the input interrupt processing is achieved.

The interrupt circuit block diagram is shown in Figure 20.


With Pull up MOS (PMOS)

*When "Disable" is specified for the I/O State at the Halt State,
the I/O Enable signal shown in the figure turns off the input circuit and
Pull up MOS.
Figure 19 Configuration of INTo and INT1


Figure 20 Interrupt Circuit Block Diagram

## - RESET FUNCTION

The reset is performed by setting the RESET pin to " 1 " ("High" level) and the HMCS45C gets into operation by setting it to "0" ("Low" level). Refer to Figure 21. Moreover, the HMCS45C has the automatic reset function (ACL; Built-in Reset Circuit). The Built-in Reset Circuit restricts the rise condition of the power supply. Refer to Figure 22. When the Built-in Reset Circuit is used, RESET should be connected to $V_{\text {Ss }}$.

Internal state of the HMCS4SC are specified as follows by the
reset function.

- Program Counter (PC) is set to 3 F address on 31 page (313F).
- I/RI, I/RT, I/E and CF are reset to " 0 ".
- IF0, IF1 and TF are set to " 1 ".

Reset/Set of I/O latch and register ( $D_{0}$ to $D_{15}, R 0$ to R6) are set to " 1 ".
Note that other blocks (Status, Register, Timer/Counter, RAM, etc.) are not cleared.
 into the constant state

- tRST2 is applied when the operation is in the constant state.

Figure 21 RESET Timing

tOFF specifies the period when the power supply is OFF in the case that a short break of the power supply occurs and the power supply ON/OFF is repeated.

Figure 22 Power Supply Timing for Built-in Reset Circuit

## - HALT FUNCTION

When the HLT pin is set to " 0 " ("Low" level), the internal clock stops and all the internal statuses (RAM, the Registers, the Carry F/F, the Status F/F, the Program Counter, and all the internal statuses) are held. Because all internal logic operation stop, power consumption is reduced. There are two input/output statuses in the Halt State. The user should specify either "Enable" or "Disable" using a mask option at the time of ordering ROM.
"Enable" $\left\{\begin{array}{l}\text { Output ........ The Status before the Halt State } \\ \text { is held. }\end{array}\right.$

LInput. $\qquad$ No relation to "Halt"
Since Pull up MOS is ON, Pull up MOS current flows with output " 0 " ("Low" level) in the Halt State ( $\mathrm{NMOS} ; \mathrm{ON}$ ). When an input signal changes, transmission current flows into an input circuit. Also, current flows into Pull up MOS. These currents are added to the Stand-by Supply Current (or Halt Current).
"Disable" $\left[\begin{array}{l}\text { Output ......... High Impedance } \\ \text { (NMOS, PMOS: OFF) } \\ \text { Pull up MOS. . OFF } \\ \text { OF }\end{array}\right.$
Input. .......... Input Circuit: OFF

Both input and output are at high impedance state. Since an input circuit is OFF, any current other than the Stand-by Supply Current (or Halt Current) does not flow even if an input signal changes.
When the HLT pin is set to " 1 " ("High" level), the HMCS-

45C gets into operation from the status just before the Halt State. The halt timing is shown in Figure 23.

CAUTION
If, during the Halt State, the external reset input is applied (RESET $=$ " 1 " ("High" level)), the internal status is not held.


Figure 23 Halt Timing

- OSCILLATOR

The HMCS45C contains its own oscillator and frequency divider (CPG). The user can obtain the desired timing for operation of the LSI by merely connecting an resistor $\mathrm{R}_{\mathrm{f}}$ or ceramic filter circuit (Internal Clock Operation).

The OSC $_{1}$ clock frequency is internally divided by four to produce the internal system clocks.

The user may exchange the external parts for the same LSI to select either of these two operational modes as shown in Figure 24. There is no need of specifying it by using the mask option.
(a) Internal Clock Operation Using Resistor Rf

(b) Internal Clock Operation Using Ceramic Filter Circuit (Built-in CPG; Ceramic Filter Oscillator) (This is not applied to HMCS45CL.)


The ceramic filter oscillation does not apply when using "Halt" and not resetting at the time of "Halt" cancellation.
This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefully on your application.
(c) External Clock Operation (External CPG)


Figure 24 Clock Operation Mode

INSTRUCTION LIST
The instructions of the HMCS45C are listed according to their functions, as shown in Table 4.

Table 4 Instruction List

| Group | Mnemonic | Function | Status |
| :---: | :---: | :---: | :---: |
| Register - Register Instruction | LAB <br> LBA <br> LAY <br> LASPX <br> LASPY <br> XAMR m | $\begin{aligned} & B \rightarrow A \\ & A \rightarrow B \\ & Y \rightarrow A \\ & S P X \rightarrow A \\ & S P Y \rightarrow A \\ & A \leftrightarrow M R(m) \end{aligned}$ |  |
| RAM Address Register Instruction | LXA <br> LYA <br> LXI i <br> LYII <br> IY <br> DY <br> AYY <br> SYY <br> XSPX <br> XSPY <br> XSPXY |  | $\begin{gathered} \text { NZ } \\ \text { NB } \\ \text { C } \\ \text { NB } \end{gathered}$ |
| RAM - Register Instruction | LAM (XY) <br> LBM (XY) <br> XMA (XY) <br> XMB (XY) <br> LMAIY (X) <br> LMADY (X) | $\begin{aligned} & M \rightarrow A(X Y \leftrightarrow S P X Y) \\ & M \rightarrow B(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow A(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow B(X Y \leftrightarrow S P X Y) \\ & A \rightarrow M, Y+1 \rightarrow Y(X \leftrightarrow S P X) \\ & A \rightarrow M, Y-1 \rightarrow Y(X \leftrightarrow S P X) \end{aligned}$ | $\begin{aligned} & \text { NZ } \\ & \text { NB } \end{aligned}$ |
| Immediate Transfer Instruction | LMIIY $i$ <br> LAI i <br> LBI i | $\begin{aligned} & i \rightarrow M, Y+1 \rightarrow Y \\ & i \rightarrow A \\ & i \rightarrow B \end{aligned}$ | NZ |
| Arithmetic Instruction | Ali <br> IB <br> DB <br> AMC <br> SMC <br> AM <br> DAA <br> DAS <br> NEGA <br> COMB <br> SEC <br> REC <br> TC <br> ROTL <br> ROTR <br> OR | $\begin{aligned} & A+i \rightarrow A \\ & B+1 \rightarrow B \\ & B-1 \rightarrow B \\ & M+A+C(F / F) \rightarrow A \\ & M-A-C(F / F) \rightarrow A \\ & M+A \rightarrow A \end{aligned}$ <br> Decimal Adjustment (Addition) Decimal Adjustment (Subtraction) $\bar{A}+1 \rightarrow A$ <br> $\bar{B} \rightarrow B$ <br> ${ }^{\prime \prime}{ }^{\prime \prime} \rightarrow C(F / F)$ <br> $" O " \rightarrow C(F / F)$ <br> Test $\quad C(F / F)$ <br> Rotation Left <br> Rotation Right <br> $A \cup B \rightarrow A$ | C <br> NZ <br> NB <br> C <br> NB <br> C <br> C (F/F) |


| Group | Mnemonic | Function | Status |
| :---: | :---: | :---: | :---: |
| Compare Instruction | MNEI i <br> YNEI i <br> ANEM <br> BNEM <br> ALEI i <br> ALEM <br> BLEM | $\begin{aligned} & M \neq i \\ & Y \neq i \\ & A \neq M \\ & B \neq M \\ & A \leqq i \\ & A \leqq M \\ & B \leqq M \end{aligned}$ | $\begin{aligned} & \text { NZ } \\ & \text { NZ } \\ & \text { NZ } \\ & \text { NZ } \\ & \text { NB } \\ & \text { NB } \\ & \text { NB } \end{aligned}$ |
| RAM Bit Manipulation Instruction | SEM $n$ REM $n$ <br> TM n | $\begin{aligned} & " 1 " \rightarrow M(n) \\ & " 0 " \rightarrow M(n) \\ & \text { Test } M(n) \end{aligned}$ | $\mathrm{M}(\mathrm{n})$ |
| ROM Address Instruction | BR a <br> CAL a <br> LPU u <br> TBR p <br> RTN | Branch on Status 1 <br> Subroutine Jump on Status 1 <br> Load Program Counter Upper on Status 1 <br> Table Branch <br> Return from Subroutine | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
| Interrupt Instruction | SEIE SEIFO SEIF1 SETF SECF REIE REIFO REIF1 RETF RECF TIO TI1 TIFO TIF1 TTF LTI i LTA LAT RTNI |  | INTo <br> INT $_{1}$ <br> IFO <br> IF1 <br> TF |
| Input/Output Instruction | SED <br> RED <br> TD <br> SEDD $n$ <br> REDD $n$ <br> LAR $p$ <br> LBR $p$ <br> LRA $p$ <br> LRB $p$ <br> $P_{p}$ | $\begin{aligned} & " 1 " \rightarrow D(Y) \\ & " O " \rightarrow D(Y) \\ & \text { Test } \quad D(Y) \\ & " 1 " \rightarrow D(n) \\ & " O " \rightarrow D(n) \\ & R(p) \rightarrow A \\ & R(p) \rightarrow B \\ & A \rightarrow R(p) \\ & B \rightarrow R(p) \\ & \text { Pattern Generation } \end{aligned}$ | D(Y) |
|  | NOP | No Operation |  |

## HMCS45C, HMCS45CL

[NOTE] 1. (XY) after a mnemonic code has four meanings as follows.
$\begin{array}{ll}\text { Mnemonic with } X & \text { After instruction execution, } X \leftrightarrow S P X \\ \text { Mnemonic with } Y & \text { After instruction execution, } Y \leftrightarrow S P Y\end{array}$
Mnemonic with XY After instruction execution, $X \leftrightarrow S P X, Y \leftrightarrow$ SPY
[Example] LAM $M \rightarrow A$
LAMX $\quad M \rightarrow A, X \leftrightarrow S P X$
LAMY $\quad M \rightarrow A, Y \leftrightarrow S P Y$
LAMXY $\quad M \rightarrow A, X \leftrightarrow S P X, Y \leftrightarrow S P Y$
2. Status column shows the factor which brings the Status $F / F$ "1" under judgement instruction or instruction accompanying the judgement

NZ .........ALU Not Zero
C ….....ALU Overflow in Addition, that is, Carry
NB .........ALU Overflow in Subtraction, that is, No Borrow
Except above .........Contents of the status column affects the Status $\mathrm{F} / \mathrm{F}$ directly.
3. The Carry $F / F(C / F / F)$ ) is not always affected by executing the instruction which affects the Status $F / F$. Instructions which affect the Carry F/F are eight as follows.

AMC
SEC
SMC REC
DAA ROTL
DAS ROTR
4. All instructions except the pattern instruction $(P)$ are executed in 1 instruction cycle. The pattern instruction $(P)$ is executed in 2 instruction cycles.

## HMCS45C Mask Option List

| Date |  |
| :--- | :--- |
| Customer's Name |  |
| ROM CODE ID |  |
| Hitachi P/N |  |

(1) $1 / 0$

| Pin <br> Name | 1/0 | I/O Option |  |  | Remarks | Pin <br> Name | 1/0 | 1/O Option |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A | B | C |  |  |  | A | B | C |  |
| Do | 1/0 |  |  |  |  | Roo | 1/0 |  |  |  |  |
| $\mathrm{D}_{1}$ | 1/0 |  |  |  |  | Ro1 | 1/0 |  |  |  |  |
| $\mathrm{D}_{2}$ | 1/0 |  |  |  |  | $\mathrm{R}_{02}$ | I/O |  |  |  |  |
| $\mathrm{D}_{3}$ | 1/0 |  |  |  |  | $\mathrm{R}_{03}$ | 1/0 |  |  |  |  |
| D4 | 1/0 |  |  |  |  | $\mathrm{R}_{10}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{5}$ | 1/0 |  |  |  |  | $\mathrm{R}_{11}$ | 1/0 |  |  |  |  |
| D6 | 1/0 |  |  |  |  | $\mathrm{R}_{12}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{7}$ | 1/0 |  |  |  |  | $\mathrm{R}_{13}$ | 1/0 |  |  |  |  |
| D8 | 1/0 |  |  | . |  | $\mathrm{R}_{20}$ | 1/0 |  |  |  |  |
| D9 | 1/0 |  |  |  |  | $\mathrm{R}_{21}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{10}$ | 1/0 |  |  |  |  | $\mathrm{R}_{22}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{11}$ | 1/0 |  |  |  |  | $\mathrm{R}_{23}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{12}$ | 1/0 |  |  |  |  | $\mathrm{R}_{30}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{13}$ | 1/0 |  |  |  |  | $\mathrm{R}_{31}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{14}$ | 1/0 |  |  |  |  | $\mathrm{R}_{32}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{15}$ | 1/0 |  |  |  |  | $\mathrm{R}_{3}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R40 | 1/0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{41}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{42}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{43}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{50}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{51}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R 52 | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R ${ }^{3}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R60 | 0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{61}$ | 0 |  |  |  |  |
| INTo | 1 |  |  | - |  | $\mathrm{R}_{62}$ | 0 |  |  |  |  |
| INT ${ }_{1}$ | 1 |  |  |  |  | $\mathrm{R}_{63}$ | 0 |  |  |  |  |

\& Specify the I/O composition with a mark of " O " in the applicable composition column.
A : No pull up MOS
B : With pull up MOS
C : CMOS Output
(2) Oscillator \& Halt

| Oscillator | Halt | Not Used | Used (Reset is applied <br> when Halt release) |
| :--- | :--- | ---: | ---: |
| Resistor |  | Used (Reset is not applied <br> when Halt release) |  |
| Ceramic Resonator |  |  |  |
| External Clock |  |  |  |

\& Please check one section on the above chart.
(3) I/O State at "Halt" Mode

| 1/O State |  |
| :--- | :--- |
| $\square$ | Enable |
| $\square$ | Disable |

$\therefore$ Mark " $v$ " in " $\square$ " for the selected $1 / 0$ state.
(4) Supply Voltage ( $\mathrm{V}_{\mathrm{cc}}$ )

i Mark " $v$ " in " $\square$ " for the selected supply voltage.
(5) Package

|  |
| :---: |
|  |
| Package |
| $\square$ |

i Mark " $v$ " in " $\square$ " for the selected package.

## HMCS46C(HD44840), HMCS46CL(HD44848)

The HMCS46C is the CMOS 4-bit single chip microcomputer which contains ROM, RAM, I/O and Timer/Counter on single chip. The HMCS46C is designed to perform efficient controller function as well as arithmetic function for both binary and BCD data. The CMOS technology of the HMCS46C provides the flexibility of microcomputers for battery powered and battery back-up applications.

- FEATURES
- 4-bit Architecture
- 4,096 Words of Program ROM and Pattern ROM (10 bits/ Word)
- 256 Digits of Data RAM (4 bits/Digit)
- 32 I/O Lines and 2 External Interrupt Lines
- Timer/Counter
- Instruction Cycle Time;

HMCS46C: $5 \mu \mathrm{~s}$
HMCS46CL: $20 \mu \mathrm{~s}$

- All Instructions except One Instruction; Single Word and Single Cycle
- BCD Arithmetic Instructions
- Pattern Generation Instruction
- Table Look Up Capability -
- Powerful Interrupt Function 3 Interrupt Sources
- 2 External Interrupt Lines
- Timer/Counter

Multiple Interrupt Capability

- Bit Manipulation Instructions for Both RAM and I/O
- Option of I/O Configuration Selectable on Each Pin; With Puil up MOS or CMOS or Open Drain
- Built-in Oscillator
- Built-in Power-on Reset Circuit (HMCS46C only)
- Low Operating Power Dissipation; 3.3mW typ.
- Stand-by Mode (Half Mode); $66 \mu \mathrm{~W}$ max.
- CMOS Technology
- Single Power Supply;

HMCS46C: 5V $\pm 10 \%$
HMCS46CL: 2.5 V to 5.5 V

HMCS46C, HMCS46CL

(DP-42)
HMCS46C, HMCS46CL

(DP-42S)

- PIN ARRANGEMENT



## - BLOCK DIAGRAM



HMCS46C, HMCS46CL

- HMCS46C ELECTRICAL CHARACTERISTICS (VCC $=5 \mathrm{~V} \pm 10 \%$ )
- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $\mathrm{V}_{\mathrm{T} 1}$ | -0.3 to $\mathrm{V}_{\mathbf{c c}}+0.3$ | V | Except for the terminals <br> specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $\mathrm{V}_{\mathrm{T} 2}$ | -0.3 to +10.0 | V | Applied to the Open Drain <br> type of Output pins and Open <br> Drain type of I/O pins. |
| Maximum Total Output Current (1) | $-\Sigma \mathrm{I}_{\mathrm{O} 1}$ | 45 | mA | [NOTE 3] |
| Maximum Total Output Current (2) | $\Sigma \mathrm{I}_{\mathrm{O} 2}$ | 45 | mA | [NOTE 3] |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\mathrm{sto}}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

[NOTE 1] Parmanent LSI damage may occur if "Maximum Ratings" are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS -1, -2." If these conditions are exceeded, it could be cause of malfunction of LSI and affects reliability of LSI.
[NOTE 2] All voltages are with respect to GND.
[NOTE 3] The Maximum Total Output Current is total sum of output currents which can flow out (or flow in) from or into the 1/O pins and Output pins simultaneously.

- ELECTRICAL CHARACTERISTICS-1 ( $\mathrm{V}_{\mathbf{c c}}=\mathbf{5 V} \pm \mathbf{1 0 \%}, \mathrm{Ta}=\mathbf{- 2 0} \mathrm{C}$ to $\left.+\mathbf{7 5}{ }^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\min$. | typ. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{\text {IL }}$ |  |  | - | - | 1.0 | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{1 \mathrm{H} 1}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{1 \mathrm{H} 2}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | 10 | V | 3 |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{IOL}^{\text {a }}$ - |  | - | - | 0.8 | V |  |
| Output "High" Voltage (1) | $\mathrm{V}_{\mathrm{OH} 1}$ | $-\mathrm{I}_{\mathrm{OH}}=$ | mA | 2.4 | - | - | V | 4 |
| Output "High" Voltage (2) | $\mathrm{V}_{\mathrm{OH} 2}$ | $-\mathrm{I}_{\mathrm{OH}}=$ | 1 mA | $\mathrm{V}_{\mathrm{cc}}-0.3$ | - | - | V | 5 |
| Interrupt Input Hold Time | $\mathrm{t}_{\text {INT }}$ |  |  | $2 \cdot \mathrm{~T}_{\text {inst }}$ | - | - | $\mu \mathrm{s}$ |  |
| Interrupt Input Fall Time | $\mathrm{t}_{\text {fint }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Interrupt Input Rise Time | $\mathrm{t}_{\text {rint }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Output "High" Current | $\mathrm{IOH}^{\text {O}}$ | $\mathrm{V}_{\mathrm{OH}}=$ |  | - | - | 3 | $\mu \mathrm{A}$ | 6 |
| Input Leakage Current | IIL | $\mathrm{V}_{\text {in }}=0$ | $\mathrm{V}_{\mathrm{cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 2 |
|  |  | $\mathrm{V}_{\text {in }}=0$ | 10 V | - | - | 3 |  | 3 |
| Pull up MOS Current | $-l_{p}$ | $\mathrm{V}_{\mathrm{CC}}=5$ |  | 60 | - | 250 | $\mu \mathrm{A}$ |  |
| Supply Current (1) | $\mathrm{I}_{\mathrm{cc} 1}$ | $V_{\text {in }}=V$ <br> Ceramic <br> Oscillat $\left\langle f_{o s c}=\right.$ | $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V},$ <br> ter <br> kHz) | - | - | 2.0 | mA |  |
| Supply Current (2) | $\mathrm{I}_{\mathrm{cc} 2}$ | $\begin{aligned} & V_{\text {in }}=V_{1} \\ & R_{f} \text { Oscil } \\ & \text { If } f_{\text {oxc }}=8 \\ & \text { Externa } \\ & \text { Operati } \end{aligned}$ | $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$ <br> on, <br> kHz ) <br> ock $\left(f_{c p}=800 \mathrm{kHz}\right)$ | - | - | 0.85 | mA | 7 |
| Standby I/O Leakage Current | $\mathrm{I}_{\text {LS }}$ | $\begin{aligned} & \overline{\text { HLT }} \\ & =1.0 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\mathrm{cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 5,8 |
|  |  |  | $\mathrm{V}_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 6,8 |
| Standby Supply Current | $I_{\text {ccs }}$ | $\mathrm{V}_{\text {in }}=\mathrm{V}^{\prime}$ | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | - | - | 12 | $\mu \mathrm{A}$ | 9 |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $\mathrm{f}_{\text {cp }}$ |  |  | 350 | - | 850 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | $\mathrm{t}_{\text {rcp }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | $\mathrm{t}_{\text {fop }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4$ |  | 4.7 | - | 11.4 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation ( $\mathrm{R}_{\mathrm{f}}$ Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {osc }}$ | $\mathrm{R}_{\mathrm{f}}=51$ | $\pm 2 \%$ | 540 | - | 900 | kHz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {osc }}$ |  | 4.4 | - | 7.4 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation (Ceramic Filter Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {osc }}$ | Ceramic Filter Circuit |  | 784 | - | 816 | kHz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {osc }}$ |  | 4.9 | - | 5.1 | $\mu \mathrm{s}$ |  |

[NOTE 1] All voltages are with respect to GND.
[NOTE 2] This is applied to RESET, $\overline{\text { HLT, OSC }}$, , INT ${ }_{0}$, INT, and the with Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of I/O pins.
[NOTE 4] This is applied to the CMOS type of I/O pins.
[NOTE 5] This is applied to the with Pull up MOS or CMOS type of I/O pins.
[NOTE 6] This is applied to the Open Drain type of I/O pins.
[NOTE 7] I/O current is excluded.
[NOTE 8] The Standby I/O Leakage Current is the I/O leakage current in the Halt and Disable State.
[NOTE 9] I/O current is excluded.
The Standby Supply Current is the supply current at $V_{C C}=5 \mathrm{~V} \pm 10 \%$ in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration voltage is called the Halt Current ( $I_{D H}$ ), and it is shown in "ELECTRICAL CHARACTERISTICS -2."

- ELECTRICAL CHARACTERISTICS-2 $\left(\mathbf{T a}=-20^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min . | max. |  |
| Halt Duration Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.3 | - | V |
| Halt Current | $\mathrm{I}_{\mathrm{DH}}$ | $\begin{aligned} & V_{\text {in }}=V_{c c} \\ & H L T=0.2 V, V_{D H}=2.3 V \end{aligned}$ | - | 12 | $\mu \mathrm{A}$ |
| Halt Delay Time | $t_{\text {HD }}$ |  | 100 | - | $\mu \mathrm{s}$ |
| Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}$ |  | 100 | - | $\mu \mathrm{s}$ |
| HLT Fall Time | $\mathrm{t}_{\mathrm{fHLT}}$ |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | $\mathrm{t}_{\text {r }}$ LTT |  | - | 1000 | $\mu \mathrm{s}$ |
| $\overline{\text { HLT "Low" Hold Time }}$ | $\mathrm{t}_{\mathrm{HLT}}$ |  | 400 | - | $\mu \mathrm{s}$ |
| HLT "High" Hold Time | $t_{\text {OPR }}$ | R $_{\mathrm{f}}$ Oscillation, External Clock Operation | 0.1 | - | ms |
|  |  | Ceramic Filter Oscillation | 4 | - |  |
| Power Supply Rise Time | $\mathrm{t}_{\mathrm{rcC}}$ | Built-in Reset, HLT $=\mathrm{V}_{\text {c }}$ | 0.1 | 10 | ms |
| Power Supply OFF Time | toff | Built-in Reset $\mathrm{HLT}=\mathrm{V}_{\mathrm{cc}}$ | 1 | - | ms |
| RESET Pulse Width (1) | $\mathrm{t}_{\text {RST } 1}$ | External Reset <br> $V_{C C}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{CC}}$ <br> ( $\mathrm{R}_{\mathrm{f}}$ Oscillation, External Clock Operation) | 1 | - | ms |
|  |  | $\begin{aligned} & \text { External Reset } \\ & \mathrm{V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}} \\ & \text { (Ceramic Filter Oscillation) } \end{aligned}$ | 4 | - |  |
| RESET Pulse Width (2) | $t_{\text {RST2 }}$ | $\begin{aligned} & \text { External Reset } \\ & V_{c c}=4.5 \text { to } 5.5 \mathrm{~V}, \\ & H L T=V_{c c} \end{aligned}$ | 2- $T_{\text {inst }}$ | - | $\mu \mathrm{s}$ |
| RESET Fall Time | ${ }^{t_{\text {fRST }}}$ |  | - | 20 | ms |
| RESET Rise Time | ${ }^{\text {t }}$ rRST |  | - | 20 | ms |

[NOTE] All voltages are with respect to GND.

- HMCS46CL ELECTRICAL CHARACTERISTICS (2.5V to 5.5V)

ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $V_{T 1}$ | -0.3 to $V_{c c}+0.3$ | V | Except for the terminals specified by $V_{T 2}$ |
| Terminal Voltage (2) | $V_{T 2}$ | -0.3 to +10.0 | V | Applied to the Open Drain type of Output pins and Open Drain type of I/O pins. |
| Maximum Total Output Current (1) | $-\Sigma \log ^{1}$ | 45 | mA | [NOTE 3] |
| Maximum Total Output Current (2) | $\Sigma l_{02}$ | 45 | mA | [NOTE 3] |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{10}$ | -65 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(NOTE 1] Permanent LSI damage may occur if "Maximum Ratings" are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS $\mathbf{- 1 , - 2 . " ~ I f ~ t h e s e ~ c o n d i t i o n s ~ a r e ~ e x c e e d e d , ~ i t ~ c o u l d ~ b e ~ c a u s e ~ o f ~ m a l f u n c t i o n ~ o f ~ L S I ~ a n d ~ a f f e c t s ~ r e l i a b i l i t y ~ o f ~}$ LSI.
[NOTE 2] All voltages are with respect to GND.
[NOTE 3] The Maximum Total Output Current is total sum of output currents which can flow out (or flow in) from or into the I/O pins and Output pins simultaneously.

- ELECTRICAL CHARACTERISTICS - $1\left(\mathrm{~V}_{\mathrm{CC}}=\mathbf{2 . 5}\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=\mathbf{- 2 0}$ to $\left.+\mathbf{7 5}{ }^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Condition |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{1 \mathrm{LL}}$ |  |  | - | - | $0.15 \cdot V_{c c}$ | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathrm{IH} 1}$ |  |  | $0.85 \cdot V_{\text {cc }}$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{1 \mathrm{H} 2}$ |  |  | $0.85 \cdot \mathrm{~V}_{\text {cc }}$ | - | 10 | V | 3 |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=0.4$ | 4 mA | - | - | 0.4 | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $-\mathrm{I}_{\mathrm{OH}}=$ | 0.08 mA | $\mathrm{V}_{\mathrm{cc}}-0.4$ | - | - | V | 4 |
| Interrupt Input Hold Time | tint |  |  | $2 \cdot{ }^{\text {inst }}$ | - | - | $\mu_{\text {s }}$ |  |
| Interrupt Input Fall Time | $\mathrm{t}_{\mathrm{f} \text { INT }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Interrupt Input Rise Time | trint |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Output "High" Level Current | IOH | $\mathrm{V}_{\mathrm{OH}}=$ | 10 V | - | - | 3 | $\mu \mathrm{A}$ | 6 |
| Input Leakage Current | IIL | $V_{\text {in }}=0$ | to $\mathrm{V}_{\mathrm{CC}}$ | - | - | 1.0 | $\mu \mathrm{A}$ | 2 |
|  |  | $V_{\text {in }}=0$ | to 10 V | - | - | 3 |  | 3 |
| Pull up MOS Current | -Ip | $\mathrm{V}_{\text {CC }}=3$ |  | 10 | - | 80 | $\mu \mathrm{A}$ |  |
| Supply Current | Icc | $\begin{aligned} & V_{\text {in }}=V_{c c} \\ & f_{\text {ossc }} / f_{c p} \\ & R_{f} \text { Oscill } \\ & \text { External } \\ & \text { Operatio } \end{aligned}$ | $\begin{aligned} & \hline, V_{c c}=3 \mathrm{~V} \\ & =200 \mathrm{kHz} \text { ) } \\ & \text { Ilation, } \\ & \text { I Clock } \\ & \text { on } \end{aligned}$ | - | - | 140 | $\mu \mathrm{A}$ | 7 |
| Standby I/O Leakage Current | ILS | $\begin{aligned} & \text { HLT } \\ & =0.5 \mathrm{~V} \end{aligned}$ | $V_{\text {in }}=0$ to $V_{\text {cc }}$ | - | - | 1 | $\mu \mathrm{A}$ | 5,8 |
|  |  |  | $\mathrm{V}_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 6,8 |
| Standby Supply Current | Iccs | $\begin{aligned} & \hline \mathrm{v}_{\text {in }}= \\ & \mathrm{v}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{V}_{\mathrm{cc}}=2.5 \mathrm{to} \\ 3.5 \mathrm{~V} \end{gathered}$ | - | - | 6 | $\mu \mathrm{A}$ | 9 |
|  |  | $\begin{aligned} & \mathrm{HLT}= \\ & 0.1 \mathrm{~V} \end{aligned}$ | $\begin{array}{r} \mathrm{V}_{\mathrm{CC}}=2.5 \text { to } \\ 5.5 \mathrm{~V} \end{array}$ | - | - | 10 | $\mu \mathrm{A}$ |  |

External Clock Operation


| Internal Clock Operation ( $\mathrm{Rf}_{\mathrm{f}}$ Oscillation) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {ox }}$ | $\begin{aligned} & R_{f}=200 \mathrm{k} \pm 2 \% \\ & \mathrm{~V}_{\mathrm{CC}}=2.5 \text { to } 3.5 \mathrm{~V} \end{aligned}$ | 130 | - | 250 | kHz |
|  | $\mathrm{f}_{\text {osc }}$ | $\begin{aligned} & R_{f}=200 k \Omega \pm 2 \% \\ & V_{c C}=2.5 \text { to } 5.5 \mathrm{~V} \end{aligned}$ | 130 | - | 350 | kHz |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\begin{aligned} & T_{\text {inst }}=4 / \mathrm{f}_{\text {osc }} \\ & \mathrm{VcC}=2.5 \text { to } 3.5 \mathrm{~V} \\ & \hline \end{aligned}$ | 16 | - | 30.8 | $\mu \mathrm{s}$ |
|  | $\mathrm{T}_{\text {inst }}$ | $\begin{aligned} & T_{\text {inss }}=4 / \mathrm{f}_{\text {osc }} \\ & \mathrm{V}_{\mathrm{CC}}=2.5 \text { to } 5.5 \mathrm{~V} \\ & \hline \end{aligned}$ | 11.4 | - | 30.8 | $\mu \mathrm{s}$ |

[NOTE 1] All voltages are with respect to GND.
[NOTE 2] This is applied to RESET, $\overline{\text { HLT, OSC }} 1$, INT, INT, and the with Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of I/O pins.
(NOTE 4] This is applied to the CMOS type of I/O pins.
[NOTE 5] This is applied to the with Pull up MOS or CMOS type of I/O pins.
[NOTE 6] This is applied to the Open Drain type of I/O pins.
[NOTE 7] 1/O current is excluded.
[NOTE 8] The Standby I/O Leakage Current is the I/O leakage current in the Halt and Disable State.
[NOTE 9] 1/O current is excluded.
The Standby Supply Current is the supply current at $V_{C C=}=2.5$ to 5.5 V in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration voltage is called the Halt Current (IDH), and it is shown in "ELECTRICAL CHARACTERISTICS-2."

- ELECTRICAL CHARACTERISTICS-2 (Ta $\mathbf{= - 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$ )

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Halt Duration Voltage | $V_{\text {DH }}$ | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.0 | - | V |
| Halt Current | $I_{\text {DH }}$ | $\begin{aligned} & V_{i n}=V_{c c}, V_{D H}=2.0 \mathrm{~V} \\ & H L T=0.1 \mathrm{~V} \end{aligned}$ | - | 12 | $\mu \mathrm{A}$ |
| Halt Delay Time | thD |  | 200 | - | $\mu \mathrm{s}$ |
| Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}$ |  | 200 | - | $\mu \mathrm{s}$ |
| HLT Fall Time | $\mathrm{t}_{\text {f } \mathrm{HLT}}$ |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | $\mathrm{t}_{\text {r }}$ LTT |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT "Low" Hold Time | thLT |  | 800 | - | $\mu \mathrm{s}$ |
| HLT "High" Hold Time | $t_{\text {OPR }}$ | Rf Oscillation, External Clock Operation, $V_{C C}=2.5 \text { to } 5.5 \mathrm{~V}$ | 0.2 | - | ms |
| RESET Pulse Width (1) | $\mathrm{t}_{\text {RST }} \mathbf{1}$ | External Reset <br> $V_{C C}=2.5$ to 5.5 V <br> HLT $=V_{\infty}$ <br> $\mathrm{R}_{\mathrm{f}}$ Oscillation, <br> External Clock <br> Operation | 2 | - | ms |
| RESET Pulse Width (2) | $\mathrm{t}_{\text {RST2 }}$ | $\begin{aligned} & \text { External Reset } \\ & V_{C C}=2.5 \text { to } 5.5 \mathrm{~V} \\ & \text { HLT }=V_{C C} \\ & \hline \end{aligned}$ | $2 \cdot \mathrm{~T}_{\text {inst }}$ | - | $\mu \mathrm{s}$ |
| RESET Fall Time | $\mathrm{t}_{\text {fRST }}$ | $\overline{H L T}=\mathrm{V}_{\text {cC }}$ | - | 20 | ms |
| RESET Rise Time | trRST | HLT $=\mathrm{V}_{\text {cc }}$ | - | 20 | ms |

(NOTE) All volteges are with respect to GND.

## - SIGNAL DESCRIPTION

The input and output signals for the HMCS46C, shown in PIN ARRANGEMENT, are described in the following paragraphs.

- VCC and GND

Power is supplied to the HMCS46C using these two pins. $\mathrm{V}_{\mathrm{CC}}$ is power and GND is the ground connection.

## - RESET

This pin allows resetting of the HMCS46C at times other than the automatic resetting capability (ACL; Built-in Reset Circuit) already in the HMCS46C. The HMCS46C can be reset by pulling RESET high. Refer to RESET FUNCTION for additional information.

## - OSC $_{1}$ and OSC $_{2}$

These pins provide control input for the built-in oscillator circuit. A resistor, ceramic filter circuit, or an external oscillator can be connected to these pins to provide a system clock with various degrees of stability/cost tradeoffs. Lead length and stray capacitance on these two pins should be minimized. Refer to OSCILLATOR for recommendations about these pins.

## - HLT

This pin is used to place the HMCS46C in the Halt State (Stand-by Mode).

The HMCS46C can be moved into the Halt State by pulling HLT low.

In the Halt State, the internal clock stops and all the internal statuses (the RAM, the registers, the Carry F/F, the Status F/F, the Program Counter, and all the internal statuses) are held.

Consequently, the power consumption is reduced. By pulling HLT high, the HMCS46C starts operation from the state just before the Halt State.

Refer to HALT FUNCTION for details of the Halt Mode.

- TEST

This pin is not for user application and must be connected to $\mathrm{V}_{\mathrm{cc}}$.

- $\mathbf{I N T}_{0}$ and $\mathbf{N N T}_{1}$

These pins provide the capability for asynchronously applying external interrupts to the HMCS46C.

Refer to INTERRUPTS for additional information.

- $\mathbf{R}_{00}-\mathbf{R}_{03}, \mathbf{R}_{10}-\mathbf{R}_{13}, \mathbf{R}_{20}-\mathbf{R}_{23}, \mathbf{R}_{30}-\mathbf{R}_{33}$

These 16 lines are arranged into four 4-bit Data Input/Output Common Channels.

The 4-bit registers (Data I/O Register) are attached to these channels. Each channel is directly addressed by the operand of input/output instruction. Refer to INPUT/OUTPUT for additional information.

- $D_{0}-D_{15}$

These lines are 16 1-bit Discrete Input/Outpat Common Terminals.

The 1-bit latches are attached to these terminals. Each terminal is addressed by the $Y$ register. The $D_{0}$ to $D_{3}$ terminals are also addressed directly by the operand of input/output instruction. Refer to INPUT/OUTPUT for additional information.

## - ROM

- ROM Address Space

ROM is used as a memory for the instructions and the patterns (constants). The instruction used in the HMCS46C consists
of 10 bits. These 10 bits are called "a word", which is a unit for writing into ROM.

The ROM address has been split into two banks.
Each bank is composed of 32 pages ( 64 words/page).
The ROM capacity is 4,096 words ( 1 word $=10$ bits) in all.
All addresses can contain both the instructions and the patterns (constants).

The ROM address space is shown in Figure 1.


Bank 131 Page 3F Address

(63 Page 3F Address)
*Bank 00 Page ( 0 Page) is the Subroutine Space.

Note: The parenthesized contents are expressions of the Page, combining the bank part with the page part.

Figure 1 ROM Address Space

- Program Counter (PC)


Note: The parenthesized contents are expressions of the Page, combining the bank part with the page part.

Figure 2 Configuration of Program Counter

The bank part is a 1 -bit register and the page part is a 5 -bit register.

Once a certain value is loaded into the bank part or the page part, the content is unchanged until other value is loaded by a program.

The settable value is " 0 " (the Bank 0 ) or " 1 " (the Bank 1) for the bank part, and 0 to 31 for the page part.

The address part is a 6 -bit polynomial counter and counts up for each instruction cycle time. The sequence in the decimal and hexa-decimal system is shown in Table 1. This sequence is circulating and has neither the starting nor ending point. It doesn't generate an overflow carry. Consequently, the program on a same page is executed in order unless the value of the bank part or the page part is changed.

Table 1 Program Counter Address Part Sequence

| Decimal | Hexa- <br> decimal | Decimal | Hexa- <br> decimal | Decimal | Hexa- <br> decimal |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 63 | $3 F$ | 5 | 05 | 9 | 09 |
| 62 | $3 E$ | 11 | $0 B$ | 19 | 13 |
| 61 | $3 D$ | 23 | 17 | 38 | 26 |
| 59 | $3 B$ | 46 | $2 E$ | 12 | $0 C$ |
| 55 | 37 | 28 | $1 C$ | 25 | 19 |
| 47 | $2 F$ | 56 | 38 | 50 | 32 |
| 30 | $1 E$ | 49 | 31 | 37 | 25 |
| 60 | $3 C$ | 35 | 23 | 10 | $0 A$ |
| 57 | 39 | 6 | 06 | 21 | 15 |
| 51 | 33 | 13 | $0 D$ | 42 | $2 A$ |
| 39 | 27 | 27 | $1 B$ | 20 | 14 |
| 14 | $0 E$ | 54 | 36 | 40 | 28 |
| 29 | $1 D$ | 45 | $2 D$ | 16 | 10 |
| 68 | $3 A$ | 26 | $1 A$ | 32 | 20 |
| 53 | 35 | 52 | 34 | 0 | 00 |
| 43 | $2 B$ | 41 | 29 | 1 | 01 |
| 22 | 16 | 18 | 12 | 3 | 03 |
| 44 | $2 C$ | 36 | 24 | 7 | 07 |
| 24 | 18 | 8 | 08 | 16 | $0 F$ |
| 48 | 30 | 17 | 11 | 31 | $1 F$ |
| 33 | 21 | 34 | 22 |  |  |
| 2 | 02 | 4 | 04 |  |  |

## - Designation of ROM Address and ROM Code

The bank part of the ROM address is shown in the binary system and the page part in the decimal system. The address part is divided into 2 bits and 4 bits, and shown in the hexadecimal system.

It is possible to combine the bank part and the page part and show the combined part as the Page (in the decimal system).

In this case, the 0 Page to the 31 Page in the Bank 1 are shown as the 32 Page to the 63 Page. The examples are shown in Figure 3.

One word ( 10 bits) of ROM is divided into three parts (2 bits, 4 bits and 4 bits from the most significant bit $\mathrm{O}_{10}$ in order) shown in the hexa-decimal system. The examples are shown in Figure 3.
(a) ROM Address

(b) ROM Code


Figure 3 Designation of ROM Address and ROM Code

## - PATTERN GENERATION

The pattern (constant) can be accessed by the pattern instruction (P). The pattern can be written in any address of the ROM address space.

## - Reference

ROM addressing for reference of the patterns is achieved by modifying the program counter with the accumulator, the $B$ register, the Carry F/F and the operand p. Figure 4 shows how to modify the program counter. The address part is replaced with the accumulator and the lower 2 bits of $B$ register, while the page part and the bank part are ORed with the upper 2 bits of $B$ register, the Carry $F / F$ and the operand $p$.

The value of the operand $p\left(p_{2}, p_{1}, p_{0}\right)$ is 0 to 7 (decimal).
The bank part of the ROM address to be referenced to is determined by the logical equation: $\mathrm{PC}_{11}+\mathrm{p}_{2}$ ( $\mathrm{p}_{2}=$ the MSB of the operand p ).

If the address where the pattern instruction exists is in the Bank 1, only the pattern of the Bank 1 can be referenced.

If the address where the pattern instruction exists is in the Bank 0, the pattern of the either Bank 1 or Bank 0 can be referenced depending on the value of $p_{2}$. The truth table of the bank part of the ROM address is shown in Table 2.

The value of the program counter is apparently modified and does not change actually. After execution of the pattern instruction, the program counter counts up and the next instruction is
executed.
The pattern instruction is executed in 2-cycle time.

- Generation

The pattern of referred ROM address is generated as the following two ways:
(i) The pattern is loaded into the accumulator and B register.
(ii) The pattern is loaded into the Data I/O Registers R2 and R3.
Selection is determined by the command bits $\left(\mathrm{O}_{9}, \mathrm{O}_{10}\right)$ in the pattern.

Mode (i) is performed when $\mathrm{O}_{9}$ is " 1 " and mode (ii) is performed when $\mathrm{O}_{10}$ is " 1 ".

Mode (i) and (ii) are simultaneously performed when both of $O_{9}$ and $O_{10}$ are " 1 ". The correspondence of each bit of the pattern is shown in Figure 5.

Examples of the pattern instruction usage is shown in Table 3.

## CAUTION

In the program execution, the pattern can not be distinguished from the instruction. When the program is executed at the addresses into which pattern is written, the instruction corres ponding to the pattern bit is executed. Take care that a pattern is not executed as an instruction.



Figure 4 ROM Addressing for Pattern Generation

Table 2 Bank Part Truth Table of Pattern Generation

| PC $_{11}$ | $p_{2}$ | Bank part of ROM address <br> to be referenced to |
| :---: | :---: | :---: |
| 1 (Bank 1) | 1 | 1 (Bank 1) |
|  | 0 | 1 (Bank 1) |
| 0 (Bank 0) | 1 | 1 (Bank 1) |
|  | 0 | $0($ Bank 0) |



Figure 5 Correspondence of Each Bit of Pattern

Table 3 Example of Pattern Instructions Usage

| Before Execution |  |  |  |  | Referred ROM Address | ROM Pattern | After Execution |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PC | p | C | B | A |  |  | B | A | R2 | R3 |
| $\begin{gathered} \text { Bank } 00.3 F \\ (0.3 F) \end{gathered}$ | 1 | 0 | A | 0 | $\begin{gathered} \text { Bank } 0 \text { 10-20 } \\ (10-20) \end{gathered}$ | 12D | 2 | B | - | -* |
| $\begin{gathered} \text { Bank } 00.3 F \\ (0-3 F) \end{gathered}$ | 7 | 1 | 4 | 0 | $\begin{gathered} \hline \text { Bank } 129-00 \\ (61-00) \\ \hline \end{gathered}$ | 22D | - | - | 4 | B |
| $\begin{gathered} \hline \text { Bank } 130.00 \\ (62-00) \end{gathered}$ | 4 | 0/1** | 0 | 9 | $\begin{gathered} \hline \text { Bank 1 30-09 } \\ (62.09) \end{gathered}$ | 32D | 2 | B | 4 | B |
| $\begin{gathered} \hline \text { Bank } 130.00 \\ (62.00) \\ \hline \end{gathered}$ | 1 | 0/1** | F | 9 | $\begin{gathered} \hline \text { Bank 1 31-39 } \\ (63-39) \end{gathered}$ | 223 | - | - | 4 | C |

[^1]"* " $0 / 1$ " means that either " 0 " or " 1 " may be selected.

## - BRANCH

ROM is accessed according to the program counter sequence and the program is executed. In order to jump to any address out of the sequence, there are four ways. They are explained in the following paragraphs.

- BR

By BR instruction, the program branches to an address in the current page.

The lower 6 bits of ROM Object Code (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) are transferred to the address part of the program counter. This instruction is a conditional instruction and executed only when the Status $F / F$ is " 1 ". If it is " 0 ", the instruction is skipped and the Status F/F becomes " 1 ". The operation is shown in Figure 6. - LPU

By LPU instruction, the jump of the bank and page is performed.

The lower 5 bits of the ROM Object Code (operand $u, \mathbf{O}_{5}$ to $\mathrm{O}_{1}$ ) are transferred to the page part of the program counter with a delay of 1 -cycle time. At the same time, the signal $\overline{R_{0}}$ (the reversed-phase signal of the Data $I / O$ Register $R_{7}$ ) is transferred to the bank part of the program counter with a delay of 1 -cycle time. The operation is shown in Figure 7.

Consequently, the bank and page will remain unchanged in the cycle immediately following this instruction. In the next cycle, a jump of the bank and page is achieved.

This instruction (LPU) is conditional, and is executed only when the Status F/F is " 1 ". Even after a skip, the Status F/F will remain unchanged ("0").

LPU instruction is used in combination with BR instruction or CAL instruction as the macro instruction of BRL or CALL instruction.

- BRL

By BRL instruction, the program branches to an address in any bank and page.

This instruction is a macro instruction of LPU and BR instructions, which is divided into two instructions as follows.

$$
\begin{gathered}
\text { BRL } \quad \text { BR } b-\operatorname{lPU} a \\
\text { < Jump to Bank " } \overline{R_{70}}{ }^{\prime \prime} \text {, a Page -b Address > }>
\end{gathered}
$$

BRL instruction is a conditional instruction because of characteristics of LPU and BR instructions, and is executed only when the Status $F / F$ is " 1 ". If the Status $F / F$ is " 0 ", the instruction is skipped and the Status $\mathrm{F} / \mathrm{F}$ becomes " 1 ". The examples of BRL instruction are shown in Figure 8.

- TBR (Table Branch)

By TBR instruction, the program branches by the table.
The program counter is modified with the accumulator, the $B$ register, the Carry F/F and the operand $p$.

The method for modification is shown in Figure 9.
The bank part is determined by the logical equation: $\mathrm{PC}_{11}+$ $\mathrm{p}_{2}$, as shown in Table 4.

If the address where TBR instruction exists is in the Bank 1, it is possible to jump to an address only in the Bank 1, not to an address in the Bank 0.

If the address where TBR instruction exists is in the Bank 0, it is possible to jump to an address in either the Bank 1 or the Bank 0 depending on the value of the operand $p_{2}$.
TBR instruction is executed regardless of the Status $F / F$, and does not affect the Status $\mathrm{F} / \mathrm{F}$.


Figure 6 BR Operation


Figure 7 LPU Operation


Figure 8 BRL Example

Table 4 Bank Part Truth Table of TBR Instruction

| $\mathrm{PC}_{11}$ | $p_{2}$ | Bank Part of PC after <br> TBR |
| :---: | :---: | :---: |
| 1 (Bank 1) | 1 | 1 (Bank 1) |
|  | 0 | $1($ Bank 1) |
| $0($ Bank 0) | 1 | $1($ Bank 1) |
|  | 0 | $0($ Bank 0) |

## - SUBROUTINE JUMP

There are two types of subroutine jumps. They are explained in the following paragraphs.

- CAL

By CAL instruction, subroutine jump to the Subroutine Space is performed.

The Subroutine Space is the Bank 00 Page ( 0 Page).
The address next to CAL instruction address is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively as shown in Figure 10.

The bank part of the program counter becomes the Bank 0 and the page part becomes the 0 Page. The lower 6 bits (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) of the ROM Object Code is transferred to the address part of the program counter.

The HMCS46C has 4 levels of stack (ST1, ST2, ST3 and ST4) which allows the programmer to use up to 4 levels of subroutine jumps (including interrupts).

CAL is a conditional instruction and executed only when the Status $F / F$ is " 1 ". If the Status $F / F$ is " 0 ", it is skipped and the Status F/F changes to " 1 ".

## - CALL

By CALL instruction, subroutine jump to an address in any bank and page is performed.

Subroutine jump to any address can be implemented by the subroutine jump to the page specified by LPU instruction in the bank designated by the reversed-phase signal $\overline{\mathbf{R}_{70}}$ of the Data I/O Register $\mathrm{R}_{70}$.

This instruction is a macro instruction of LPU and CAL instructions, which is divided into two instructions as follows.

< Subroutine Jump to Bank " $\overline{\mathbf{R}_{70}}$ ", a Page - b Address >
CALL instruction is conditional because of characteristics of LPU and CAL instructions, and is executed when the Status F/F is " 1 " If the Status $F / F$ is " 0 ", the instruction is skipped and the Status $\mathrm{F} / \mathrm{F}$ changes to " 1 ". The examples of CALL instruction are shown in Figure 11.


(PC after TBR Instruction)


Figure 9 Modification of Program Counter by TBR Instruction


Figure 10 Subroutine Jump Stacking Order

| Subroutine Jump to Bank 0 |  |  |
| :---: | :---: | :---: |
| LAI | 15 |  |
| -LRA | 7 | $\mathrm{R}_{70}={ }^{\prime} 1{ }^{\prime \prime}\left(\overline{R_{70}}={ }^{\prime} 0{ }^{\prime \prime}\right)$ |
| - LPU CAL | $\left.\begin{array}{l}5 \\ 3 F\end{array}\right\}$ | CALL 5-3F <br> (Subroutine Jump to Bank 05-3F (5-3F)) |
| $\cdot \begin{gathered} \text { LAI } \\ \text { LBA } \end{gathered}$ | 15 |  |
| LRA COMB | 7 | $R_{70}={ }^{\prime \prime}{ }^{\prime \prime}\left(\overline{R_{70}}={ }^{\prime} 0{ }^{\prime \prime}\right)$ |
| $\rightarrow$ LPU CAL | $\left.\begin{array}{l}31 \\ 3 F\end{array}\right\}$ | CALL 31-3F <br> (Subroutine Jump to Bank 0 31-3F (31-3F) |

Subroutine Jump to Bank 1

| LAI | 0 |  |
| :---: | :---: | :---: |
| -LRA | 7 | $\mathrm{R}_{70}={ }^{\prime \prime} 0^{\prime \prime}\left(\overline{\mathrm{R}_{70}}={ }^{\prime \prime 1}{ }^{\prime \prime}\right)$ |
| $\rightarrow$ LPU CAL | $\left.\begin{array}{l}15 \\ 3 F\end{array}\right\}$ | CALL 15-3F <br> (Subroutine Jump to Bank 1 15-3F (47-3F)) |
| LAI <br> LTA | 0 |  |
| - LRA | 7 | $\mathrm{R}_{70}={ }^{\prime \prime} 0^{\prime \prime}\left(\overline{R_{70}}={ }^{\prime \prime} 1{ }^{\prime \prime}\right)$ |
| $\begin{aligned} & \text { LYI } \\ & \text { XMA } \end{aligned}$ | 3 |  |
| $\therefore$ LPU | $10\}$ | CALL 10-2E |
| CAL | 2E | (Subroutine Jump to Bank 1 10-2E (42-2E) |

Figure 11 CALL Example

- RAM

RAM is a memory used for storing data and saving the contents of the registers. Its capacity is 256 digits ( 1,024 bits) where one digit consists of 4 bits.

Addressing of RAM is performed by a matrix of the file No. and the digit No.

The file No. is set in the X register and the digit No. in the Y register for reading, writing or testing. Specific digits in RAM can be addressed not via the X register and Y register. These digits are called "Memory Register (MR)", 0 to 15 ( 16 digits in all). The memory register can be exchanged with the accumulator by XAMR instruction.

The RAM address space is shown in Figure 12.
In an instruction in which reading from RAM and writing to RAM coexist (exchange between RAM and the register), reading precedes writing and the write data does not affect the read data.

The RAM bit manipulation instruction enables any addressed RAM bit to be set, reset or tested. The bit assignment is specified by the operand n of the instruction.

The bit test makes the Status $\mathrm{F} / \mathrm{F}$ " 1 " when the assigned bit is " 1 " and makes it " 0 " when the assigned bit is " 0 ".

Correspondence between the RAM bit and the operand n is shown in Figure 13.


Figure 12 RAM Address Space


Figure 13 RAM Bit and Operand $n$

## - REGISTER

The HMCS46C has eight 4-bit registers and two 1-bit registers available to the programmer. The 1 -bit registers are the Carry $\mathrm{F} / \mathrm{F}$ and the Status $\mathrm{F} / \mathrm{F}$. They are explained in the following paragraphs.

- Status F/F (S)

The Status F/F latches the result of logical or arithmetic operations (Not Zero, Overflow) and bit test operations. The Status F/F affects conditional instructions (LPU, BR and CAL instructions). These instructions are executed only when the Status F/F is " 1 ". If it is " 0 ", these instructions are skipped and the Status $\mathrm{F} / \mathrm{F}$ becomes " 1 ".

- Accumulator (A; A Register) and Carry F/F (C)

The result of the Arithmetic Logic Unit (ALU) operation (4 bits) and the overflow of the ALU are loaded into the accumulator and the Carry F/F. The Carry F/F can be set, reset or tested. Combination of the accumulator and the Carry F/F can be right or left rotated. The accumulator is the main register for ALU operation and the Carry F/F is used to store the overflow generated by ALU operation when the calculation of two or more digits ( 4 bits/digit) is performed.

## - B Register (B)

The result of ALU operation (4 bits) is loaded into this register. The B register is used as a sub-accumulator to stack data temporarily and also used as a counter.

## - X Register (X)

The result of ALU operation (4 bits) is loaded into this register. The $\mathbf{X}$ register has exchangeability for the SPX register. The X register addresses the RAM file.

## - SPX Register (SPX)

The SPX register has exchangeability for the X register.
The SPX register is used to stack the X register and expand the addressing system of RAM in combination with the X register.

- Y Register (Y)

The result of ALU operation (4 bits) is loaded into this register. The Y register has exchangeability for the SPY register. The Y register can calculate itself simultaneously with transferring data by the bus lines, which is usable for the calculation of two or more digits ( 4 bits/digit). The Y register addresses the RAM digit and 1-bit Discrete I/O.

## - SPY Register (SPY)

The SPY register has exchangeability for the Y register. The SPY register is used to stack the Y register and expand the addressing system of RAM and 1-bit Discrete I/O in combination with the Y register.

The Data I/O Registers R4 and R5, which are not connected to the LSI pin, can be used for general purpose registers.

## - R4 Register (R4)

The contents of the accumulator and the B register are transferred by LRA and LRB instructions, respectively. The contents of the R4 register are sent to the accumulator and the B
register by LAR and LBR instructions, respectively.

## - R5 Register (R5)

The contents of the accumulator and the B register are transferred by LRA and LRB instructions, respectively. The contents of the R5 register are sent to the accumulator and the B register, respectively.

## - INPUT/OUTPUT

- 4-bit Data Input/Output Common Channel (R)

The HMCS46C has four 4-bit Data I/O Common Channels (R0, R1, R2 and R3).

The 4-bit registers (Data I/O Register) are attached to these channels.

Each channel is directly addressed by the operand p of input/output instruction.

The data is transferred from the accumulator and the B register to the Data I/O Registers R0 to R3 via the bus lines. Pattern instruction enables the patterns of ROM to be loaded into the Data I/O Registers R2 and R3.

Input instruction enables the 4-bit data to be sent to the accumulator and the B register from R0 to R3. Note that, since the Data I/O Register's output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the Data I/O Register's output and the pin input. Therefore, the Data I/O Register should be set to 15 (all bits of the Data I/O Register is " 1 ") not to affect the pin input before execution of input instruction, and Open Drain or With Pull up MOS should be specified for the I/O configuration of these pins.

The block diagram is shown in Figure 14. The I/O timing is shown in Figure 15.

- 1-bit Discrete Input/Output Common Terminal (D)

The HMCS46C has 161 -bit Discrete I/O Common Terminals.
The 1 -bit Discrete I/O Common Terminal consists of a 1-bit latch and an I/O common pin.

The 1 -bit Discrete $\mathrm{I} / \mathrm{O}$ is addressed by the Y register. The addressed latch can be set or reset by output instruction and " 0 " and " 1 " level can be tested with the addressed pin by input instruction

Note that, since the latch output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the latch's output and the pin input. Therefore, the latch should be set to " 1 " not to affect the pin input before execution of input instruction and Open Drain or With Pull up MOS should be specified for the I/O configuration of this pin.

The $D_{0}$ to $D_{3}$ terminal are also addressed directly by the operand $n$ of input/output instruction and can be set or reset. The block diagram is shown in Figure 16 and the I/O timing is shown in Figure 17.

## - I/O Configuration

The I/O configuration of each pin can be specified among Open Drain, With Pull up MOS and CMOS using a mask option as shown in Figure 18.


Figure 14 4-bit Data I/O Block Diagram


Figure 15 4-bit Data I/O Timing


Figure 16 1-bit Discrete I/O Block Diagram


Figure 17 1-bit Discrete I/O Timing

Applied pins; $D_{0}$ to $D_{15}, R_{00}$ to $R_{03}, R_{10}$ to $R_{13}$,
$R_{20}$ to $R_{23}, R_{30}$ to $R_{33}$

*When "Disable" is specified for the I/O State at the Halt State, the I/O Enable signal shown in the figure turns off the input circuit, Pull up MOS, and NMOS output and sets CMOS output to high impedance (PMOS, NMOS; OFF).

Figure 18 I/O Configuration

## - TIMER/COUNTER

The timer/counter consists of the 4 -bit counter and the 6 -bit prescaler as shown in Figure 19. The 4-bit counter may be loaded under program control and is incremented toward 15 by the prescaler overflow output pulse or the input pulse of INT $_{1}$ pin (its leading edge is counted). The clock input to the counter is selected by the CF F/F. When the CF F/F is " 0 ", the clock input is the prescaler overflow output pulse (Timer Mode). When the CF F/F is " 1 ", the clock input is the input pulse of $\mathrm{INT}_{1}$ pin (Counter Mode). When the counter reaches zero (returns from 15 to zero), the overflow output pulse is generated and the counter continues to count ( $14 \rightarrow 15 \rightarrow 0 \rightarrow 1 \rightarrow 2$ ...).

The TF F/F is a flip-flop which masks interrupts from the timer/counter. It can be set and reset by interrupt instruction. If the overflow output pulse of the counter is generated when the TF F/F is reset (" 0 "), an interrupt request occurs and the TF F/F becomes " 1 ". If the overflow output pulse is generated when the TF F/F is set (" 1 "), no interrupt request occurs. The TTF instruction enables the TF F/F to be tested.

The prescaler is a 6-bit frequency divider. It divides a system clock (instruction frequency) by 64 into the overflow output pulses of "instruction frequency $\div 64$ ".

The prescaler is cleared when data is loaded into the counter (by LTA or LTI instruction). The frequency division is 0 when the prescaler is cleared. At the 64th clock, an overflow output
pulse is generated from the prescaler. During operation of the LSI, the prescaler is operating and cannot be stopped. (In the Halt state, it stops.) The relation between the specified value of the counter and specified time in the Timer Mode is shown in Table 5.

The pulse width of the $\mathrm{INT}_{1}$ pin in the Counter Mode must be at least 2-cycle time for both "High" and "Low" levels as shown in Figure 19.

## - INTERRUPT

The HMCS46C can be interrupted in two different ways: through the external interrupt input pins ( $\mathrm{INT}_{0}, \mathrm{INT}_{1}$ ) and the timer/counter interrupt request. When any interrupt occurs, processing is suspended, the Status $F / F$ is unchanged, the present program counter is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively. At that time, the Interrupt Enable $\mathbf{F} / \mathbf{F}(\mathbf{I} / E)$ is set and the address jumps to a fixed destination (Interrupt Address), and then the interrupt routine is executed. Stacking the registers other than the program counter must be performed by the program. The interrupt
routine must end with RTNI (Return Interrupt) instruction which sets the I/E F/F simultaneously with the RTN instruction.

The Interrupt Address:
Input Interrupt Address
Bank 01 Page 3F Address (1 Page 3F Address)
Timer/Counter Interrupt Address ...Bank 00 Page 3F Address (0 Page 3F Address)
The input interrupt has priority over the timer/counter interrupt.

The $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ pin have an interrupt request function. Each terminal consists of a circuit which generates leading pulse and the Interrupt mask F/F (IF0, IF1). An interrupt is enabled (unmasked) when the IFO F/F or IF1 F/F is reset. When the $\mathrm{INT}_{0}$ or $\mathrm{INT}_{1}$ pin changes from " 0 " to " 1 " (from "Low" level to "High" level), a leading pulse is generated to produce an interrupt request. At the same time, the IFO F/F or IF1 F/F is set. When the IF0 F/F or IF1 F/F is set, the interrupt masking for the pin will result. (If a leading pulse is generated, no interrupt request occurs.)

$\mathrm{t}_{\text {INT }} \geqq 2 \cdot \mathbf{T}_{\text {inst }}$
( $\mathrm{T}_{\text {inst }}$ =One Instruction Cycle Time)

Figure 19 Timer/Counter Block Diagram

Table 5 Timer Range

| Specified <br> Value | Number of <br> Cycles | ${ }^{*}$ Time (ms) | Specified <br> Value | Number of <br> Cycles | ${ }^{\text {"Time (ms) }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1024 | 5.12 | 8 | 512 | 2.56 |
| 1 | 960 | 4.80 | 9 | 448 | 2.24 |
| 2 | 896 | 4.48 | 10 | 384 | 1.92 |
| 3 | 832 | 4.16 | 11 | 320 | 1.60 |
| 4 | 768 | 3.84 | 12 | 256 | 1.28 |
| 5 | 704 | 3.52 | 13 | 192 | 0.96 |
| 6 | 640 | 3.20 | 14 | 128 | 0.64 |
| 7 | 576 | 2.88 | 15 | 64 | 0.32 |

*Time is based on instruction frequency 200 kHz . (One Instruction Cycle Time ( $T_{\text {inst }}$ ) $=5 \mu \mathrm{~s}$ )

An interrupt request generated by the leading pulse is latched into the input interrupt request $\mathrm{F} / \mathrm{F}$ (I/RI) on the input side. If the Interrupt Enable F/F (I/E) is " 1 " (Interrupt Enable State), an interrupt occurs immediately and the I/RI F/F and the I/E $\mathrm{F} / \mathrm{F}$ are reset. If the I/E F/F is " 0 " (Interrupt Disable State), the I/RI F/F is held at " 1 " until the HMCS46C gets into the Interrupt Enable State.

The IF0 F/F, the IF1 F/F, the $\mathrm{INT}_{0}$ pin and the $\mathrm{INT}_{1}$ pin can be tested by interrupt instruction. Therefore, the $\mathrm{INT}_{0}$ and the $\mathrm{INT}_{1}$ can be used as additional input pins with latches.

The $\mathrm{INT}_{0}$ pin and $\mathrm{INT}_{1}$ pin can be provided with Pull up MOS using a mask option as shown in Figure 20.

An interrupt request from the timer/counter is latched into the timer interrupt request $\mathrm{F} / \mathrm{F}$ (I/RT). The succeeding operations are the same as an interrupt from the input. Only the exception is that, since an interrupt from the input precedes a timer/counter interrupt, the input interrupt occurs if both the I/RI F/F and the I/RT F/F are "1" (when the input interrupt and the timer/counter interrupts are generated simultaneously). During this processing, the I/RT F/F remains " 1 ". The timer/ counter interrupt can be implemented after the input interrupt processing is achieved.

The interrupt circuit block diagram is shown in Figure 21.


> "When "Disable" is specified for the I/O State at the Halt State, the I/O Enable signal shown in the figure turns off the input circuit and Pull up MOS.

Figure 20 Configuration of $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$


Figure 21 Interrupt Circuit Block Diagram

## - RESET FUNCTION

The reset is performed by setting the RESET pin to " 1 " ("High" level) and the HMCS46C gets into operation by setting it to "0" ("Low" level); Refer to Figure 22. Moreover, the HMCS46C has the power-on reset function (ACL; Built-in Reset Circuit). The Built-in Reset Circuit restricts the rise condition of the power supply; Refer to Figure 23. When the Built-in Reset Circuit is used, RESET should be connected to GND.
HMCS46CL doesn't have the power-on reset function.
Internal state of the HMCS46C are specified as follows by the reset function.

- Program Counter (PC) is set to Bank 131 Page 3F Address (63 Page 3F Address).
- Data I/O Registers $\mathrm{R}_{70}$ is set to " 1 " (Jumps to Bank 0 by execution of LPU instruction after the reset).
- I/RI, I/RT, I/E and CF are reset to " 0 ".
- IFO, IF1, and TF are set to " 1 ".
- Data I/O Registers (R0 to R5) and Discrete I/O Latches ( $D_{0}$ to $D_{15}$ ) are all set to " 1 ".

Note that all the other logic blocks (the Stack Registers, the Status F/F, the accumulator, the Carry F/F, the registers, the Timer/Counter, RAM) are not cleared by the reset function. The user should initialize these blocks by software. Because the Status $\mathrm{F} / \mathrm{F}$ after the reset is not defined, set the Status $\mathrm{F} / \mathrm{F}$ to " 0 " or " 1 " before the first execution of the conditional instructions (LPU, CAL and BR instructions).

## - HALT FUNCTION

When the HLT pin is set to " 0 " ("Low" level), the internal clock stops and all the internal statuses (RAM, the Registers, the Carry F/F, the Status F/F, the Program Counter, and all the internal statuses) are held. Because all internal logic operation stop, power consumption is reduced. There are two input/ output statuses in the Halt State. The user should specify either "Enable" or "Disable" using a mask option at the time of ordering ROM.

"Enable"—— \begin{tabular}{l}

Output $\ldots \ldots .$| The status before the |
| :--- |
| Halt State is held | <br>

| Pull up MOS $\ldots$. ON |
| :--- | <br>

Input $\ldots \ldots . .$| Independent of the Halt |
| :--- |
| State or Operating State |
| (Input Circuit is ON) |

\end{tabular}

Since Pull up MOS is ON, Pull up MOS current flows with output "0" ("Low" level) in the Halt State (NMOS; ON). When an input signal changes, transition current flows into an input circuit. Also, current flows into Pull up MOS.


* $\mathbf{t}_{\text {RST1 }}$ includes the time required from the power ON until the operation gets into the constant state.
*     * ${ }^{\text {R RST2 }}$ is applied when the operation is in the constant state.

Figure 22 RESET Timing


- tOFF specifies the period when the power supply if OFF in the case that a short break of the power supply occurs and the power supply ON/OFF is repeated.

Figure 23 Power Supply Timing for Built-in Reset Circuit

These currents and added to the Standby Supply Current (or Halt Current).
"Disable" $\qquad$ Output $\qquad$
$\qquad$ NMOS Output: OFF CMOS Output:

High Impedance (NMOS, PMOS: OFF)
Pull up MOS ... OFF
Input . . . . . . . . . Input Circuit: OFF Both input and output are at high impedance state. Since an input circuit is OFF, any current other than the Standby Supply Current (or Halt Current) does not flow even if an input signal changes.
When the HLT pin is set to " 1 "("High" level), the HMCS46C gets into operation from the status just before the Halt State. The halt timing is shown in Figure 24.

## CAUTION

If, during the Halt State, the external reset input is applied (RESET = " 1 " ("High" level)), the internal status is not held.

## - OSCILLATOR

The HMCS46C contains its own oscillator and frequency divider (CPG). The user can obtain the desired timing for operation of the LSI by merely connecting an resistor $R_{f}$ or ceramic filter circuit (Internal Clock Operation). Also an external oscillator can supply a clock (External Clock Operation).

The $\mathbf{O S C}_{1}$ clock frequency is internally divided by four to produce the internal system clocks.

The user may exchange the external parts for the same LSI to select either of these two operational modes as shown in Figure 25 . There is no need of specifying it by using the mask option.

The typical value of clock oscillation frequency ( $f_{\text {osc }}$ ) varies with a oscillation resistor $\mathbf{R}_{\mathrm{f}}$ as shown in Figure 26.


Figure 24 Halt Timing
(a) Internal Clock Operation Using Resistor $\mathbf{R}_{\mathbf{f}}$


Wiring of OSC ${ }_{1}$ and OSC ${ }_{2}$ terminals should be as short as possible because the oscillation frequency is modified by capacitance of these terminals.
(b) Internal Clock Operation Using Ceramic Filter Circuit (This is not applied to HMCS46CL.)


Ceramic Filter; CSB800A (MURATA)
$R_{1} ; 1 M \Omega \pm 10 \%$
$C_{1}: 100 p F \pm 10 \%$ (Ceramic Capacitor)
$C_{2}: 100 \mathrm{pF} \pm 10 \%$ (Ceramic Capacitor)

The ceramic filter oscillation does not apply when using "Halt" and not resetting at the time of "Halt" cancellation.
This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefutly on your application.
Figure 25 Clock Operation Modes (to be continued)
(c) External Clock Operation


Figure 25 Clock Operation Modes


Figure 26 Typical Value of Oscillation Frequency vs. $\mathbf{R}_{\mathbf{f}}$

## - INSTRUCTION LIST

The instructions of the HMCS46C are listed according to their functions, as shown in Table 6.

Table 6 Instruction List

\begin{tabular}{|c|c|c|c|}
\hline Group \& Mnemonic \& Function \& Status \\
\hline Register - Register Instruction \& \begin{tabular}{l}
LAB \\
LBA \\
LAY \\
LASPX \\
LASPY \\
XAMR m
\end{tabular} \& \[
\begin{aligned}
\& B \rightarrow A \\
\& A \rightarrow B \\
\& Y \rightarrow A \\
\& S P X \rightarrow A \\
\& S P Y \rightarrow A \\
\& A \rightarrow M R(m)
\end{aligned}
\] \& \\
\hline RAM Address Register Instruction \& \begin{tabular}{l}
LXA \\
LYA \\
LXI i \\
LYI i \\
IY \\
DY \\
AYY \\
SYY \\
XSPX \\
XSPY \\
XSPXY
\end{tabular} \&  \& \[
\begin{aligned}
\& \text { NZ } \\
\& \text { NB } \\
\& \text { C } \\
\& \text { NB }
\end{aligned}
\] \\
\hline RAM - Register Instruction \& \begin{tabular}{l}
LAM (XY) \\
LBM (XY) \\
XMA (XY) \\
XMB (XY) \\
LMAIY (X) \\
LMADY (X)
\end{tabular} \& \[
\begin{array}{llllllll}
M \& \rightarrow \& A \& (X Y \& \leftrightarrow \& S P X Y) \& \& \\
M \& \rightarrow \& B \& (X Y \& \leftrightarrow \& S P X Y) \\
M \& \leftrightarrow \& A \& (X Y \& \leftrightarrow \& S P X Y) \\
M \& \leftrightarrow \& B \& (X Y \& \leftrightarrow \& S P X Y) \& \& \\
A \& \rightarrow \& M, Y+1 \& \rightarrow \& Y \& (X) \& S P X) \\
A \& \rightarrow \& M, Y-1 \& \rightarrow \& Y \& (X) \& S P X)
\end{array}
\] \& \[
\begin{aligned}
\& N Z \\
\& N B
\end{aligned}
\] \\
\hline Immediate Transfer Instruction \& \begin{tabular}{l}
LMIIY i \\
LAI i \\
LBI i
\end{tabular} \&  \& NZ \\
\hline Arithmetic Instruction \&  \& \begin{tabular}{l}
\[
\begin{array}{lllll}
A+i \& \rightarrow \& A \& \& \\
B+1 \& \rightarrow \& B \& \& \\
B-1 \& B \& \& \\
M+A+C \& (F / F) \& \rightarrow \& A \\
M-A-C \& (F / F) \& \rightarrow \& A \\
M+A \& A \& \&
\end{array}
\] \\
Decimal Adjustment (Addition) \\
Decimal Adjustment (Subtraction) \\
\(\bar{A}+1 \rightarrow A\) \\
\(\bar{B} \rightarrow B\) \\
\(" 1 " \rightarrow C(F / F)\) \\
" 0 " \(\rightarrow\) C (F/F) \\
Test C (F/F) \\
Rotation Left \\
Rotation Right \\
\(A \cup B \rightarrow A\)
\end{tabular} \& \(C\)
\(N Z\)
\(N B\)
\(C\)
\(N B\)
\(C\)

$C(F / F)$ <br>
\hline
\end{tabular}

(to be continued)

| Group | Mnemonic | Function | Status |
| :---: | :---: | :---: | :---: |
| Compare Instruction |  |  | $\begin{aligned} & \text { NZ } \\ & \text { NZ } \\ & \text { NZ } \\ & \text { NZ } \\ & \text { NB } \\ & \text { NB } \\ & \text { NB } \end{aligned}$ |
| RAM Bit Manipulation Instruction | SEM $n$ REM $n$ TM $n$ | $\begin{array}{ccc} " 1 " & \rightarrow & M(n) \\ " 0 " & \rightarrow & M(n) \\ \text { Test } & M(n) \end{array}$ | $\mathrm{M}(\mathrm{n})$ |
| ROM Address Instruction | BR a CAL a LPU u TBR p RTN | Branch on Status 1 <br> Subroutine Jump on Status 1 <br> Load Program Counter Upper on Status 1 <br> Table Branch <br> Return from Subroutine | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
| Interrupt Instruction | SEIE <br> SEIFO <br> SEIF 1 <br> SETF <br> SECF <br> REIE <br> REIFO <br> REIF1 <br> RETF <br> RECF <br> TIO <br> TII <br> TIFO <br> TIF1 <br> TTF <br> LTI i <br> LTA <br> LAT <br> RTNI |  | $\begin{aligned} & \text { INT }_{0} \\ & \text { INT } \\ & \text { IFO } \\ & \text { IF1 } \\ & \text { TF } \end{aligned}$ |
| Input/Output Instruction | SED <br> RED <br> TD <br> SEDD n <br> REDD $n$ <br> LAR $p$ <br> LBR p <br> LRA $p$ <br> LRB $p$ <br> P p |  | $D(Y)$ |
|  | NOP | No Operation |  |

[NOTE] 1. (XY) after a mnemonic code has four meanings as follows.
Mnemonic only Instruction execution only
Mnemonic with $X \quad$ After instruction execution, $X \leftrightarrow S P X$
Mnemonic with $Y \quad$ After instruction execution, $Y \leftrightarrow$ SPY
Mnemonic with $X Y \quad$ After instruction execution, $X \leftrightarrow S P X, Y \leftrightarrow S P Y$
[Example] LAM $M \rightarrow A$

| LAMX | $M \rightarrow A, X \leftrightarrow S P X$ |
| :--- | :--- |
| LAMY | $M \rightarrow A, Y \leftrightarrow S P Y$ |
| LAMXY | $M \rightarrow A, X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |

2. Status column shows the factor which brings the Status $F / F$ " 1 " under judgement instruction or instruction accompanying the judgement.

NZ . . . ALU Not Zero
C . . . . . ALU Overflow in Addition, that is, Carry
NB . . . . ALU Overflow in Subtraction, that is, No Borrow
Except above . . . . . . . Contents of the status column affects the Status F/F directly.
3. The Carry $F / F(C(F / F))$ is not always affected by executing the instruction which affects the Status $F / F$. Instructions which affect the Carry F/F are eight as follows.

| AMC | SEC |
| :--- | :--- |
| SMC | REC |
| DAA | ROTL |
| DAS | ROTR |

4. All instructions except the pattern instruction ( $P$ ) are executed in 1 -cycle. The pattern instruction ( $P$ ) is executed in 2-cycye.

## HMCS46C Mask Option Lis

| Date |  |
| :--- | :--- |
| Customer＇s Name |  |
| ROM CODE ID |  |
| Hitachi P／N |  |

（1）I／O Option

| Pin Name | 1／O | 1／O Option |  |  | Remarks | Pin Name | 1／0 | 1／O Option |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A | B | C |  |  |  | A | B | C |  |
| Do | 1／0 |  |  |  |  | Roo | 1／0 |  |  |  |  |
| D1 | I／O |  |  |  |  | $\mathrm{R}_{01}$ | 1／O |  |  |  |  |
| D2 | 1／0 |  |  |  |  | $\mathrm{R}_{02}$ | 1／0 |  |  |  |  |
| D3 | 1／O |  |  |  |  | $\mathrm{R}_{03}$ | 1／0 |  |  |  |  |
| D4 | 1／O |  |  |  |  | $\mathrm{R}_{10}$ | 1／0 |  |  |  |  |
| Ds | 1／0 |  |  |  |  | $\mathrm{R}_{11}$ | 1／O |  |  |  |  |
| D6 | I／O |  |  |  |  | $\mathrm{R}_{12}$ | 1／0 |  |  |  |  |
| D7 | I／O |  |  |  |  | $\mathrm{R}_{13}$ | 1／0 |  |  |  |  |
| Ds | 1／0 |  |  |  |  | $\mathrm{R}_{20}$ | 1／0 |  |  |  |  |
| D9 | 1／0 |  |  |  |  | $\mathrm{R}_{21}$ | 1／O |  |  |  |  |
| D10 | 1／0 |  |  |  |  | $\mathrm{R}_{22}$ | 1／0 |  |  |  |  |
| D11 | 1／0 |  |  |  |  | $\mathrm{R}_{23}$ | 1／0 |  |  |  |  |
| $D_{12}$ | 1／0 |  |  |  |  | $\mathrm{R}_{30}$ | 1／0 |  |  |  |  |
| D13 | I／O |  |  |  |  | $\mathrm{R}_{31}$ | 1／0 |  |  |  |  |
| Di4 | 1／O |  |  |  |  | $\mathrm{R}_{32}$ | 1／0 |  |  |  |  |
| Dis | 1／0 |  |  |  |  | $\mathrm{R}_{33}$ | 1／0 |  |  |  |  |
| INT0 | 1 |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{INT}_{1}$ | 1 |  |  |  |  |  |  |  |  |  |  |

＂Specify the $1 / O$ composition with a mark of＂$O$＂in the applicable composition column． A：No pull up MOS B：With pull up MOS C：CMOS Output

## （2）Oscillator \＆Halt

| Oscillator | Halt | Not used | Used（Reset is applied when Halt release） |
| :--- | :--- | :--- | :--- | Used（Reset is not applied when Halt release） | Resistor |  |
| :--- | :--- |
| Ceramic Resonator |  |
|  |  |
| External Clock |  |
|  |  |

＊Please check one section on the above chart．
（3）I／O State at＂Halt＂mode

| $1 / 0$ State |
| :---: |
| $\square$ Enable |
| $\square$ Disable |

＊Mark＂$V$＂in＂$口$＂for the selected $/ / O$ state．
（4）Supply Voltage（ $V_{C C}$ ）

| Supply Voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$ |
| :---: |
| $\square 5 \pm 0.5 \mathrm{~V}$ |
| $\square 2.5 \mathrm{~V}$ to 5.5 V |

＊Mark＂$\sqrt{ }$＂in＂口＂for the selected supply voltage．
（5）Package

| Package |
| :---: |
| $\square$ DP－42 |
| $\square$ DP－42S |

＊Mark＂$\sqrt{ }$＂in＂口＂for the selected package．
（6）Evchip used for Program Evaluation

| Evchip |
| :---: |
| $\square$ HD44855E |
| $\square$ HD44857E |

＊Mark＂$\sqrt{ }$＂in＂$口$＂for the evchip used for program evaluation．

## HMCS47C(HD44860), HMCS47CL(HD44868)

The HMCS47C is the CMOS 4-bit single chip microcomputer which contains ROM, RAM, I/O and Timer/Counter on single chip. The HMCS47C is designed to perform efficient controller function as well as arithmetic function for both binary and BCD data. The CMOS technology of the HMCS47C provides the flexibility of microcomputers for battery powered and battery back-up applications.

## - FEATURES

- 4-bit Architecture
- 4,096 Words of Program ROM and Pattern ROM (10 bits/Word)
- 256 Digits of Data RAM (4 bits/Digit)
- 44 I/O Lines and 2 External Interrupt Lines
- Timer/Counter
- Instruction Cycle Time;

HMCS47C : $5 \mu \mathrm{~s}$
HMCS47CL : $20 \mu \mathrm{~s}$

- All Instructions except One Instruction; Single Word and Single Cycle
- BCD Arithmetic Instructions
- Pattern Generation Instruction - Table Look Up Capability -
- Powerful Interrupt Function

3 Interrupt Sources
-2 External Interrupt Lines
-Timer/Counter
Multiple Interrupt Capability

- Bit Manipulation Instructions for Both RAM and I/O
- Option of I/O Configuration Selectable on Each Pin; With Pull up MOS or CMOS or Open Drain
- Built-in Oscillator
- Built-in Power-on Reset Circuit (HMCS47C only)
- Low Operating Power Dissipation; 3.3mW typ.
- Stand-by Mode (Halt Mode); $66 \mu \mathrm{~W}$ max.
- CMOS Technology
- Single Power Supply;

HMCS47C : 5V $\pm 10 \%$
HMCS47CL : 2.5 V to 5.5 V


HMCS47C, HMCS47CL

(DP-64S)

- PIN ARRANGEMENT



HMCS47C, HMCS47CL

- HMCS47C ELECTRICAL CHARACTERISTICS (Vcc ${ }^{2} 5 \mathrm{~V} \pm 10 \%$ )
- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $\mathrm{V}_{\mathrm{T} 1}$ | -0.3 to $\mathrm{V}_{\mathrm{cc}}+0.3$ | V | Except for the terminals specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $V_{T 2}$ | -0.3 to +10.0 | V | Applied to the Open Drain type of Output pins and Open Drain type of I/O pins. |
| Maximum Total Output Current (1) | $-\Sigma I_{01}$ | 45 | mA | [NOTE 3] |
| Maximum Total Output Current (2) | $\mathrm{\Sigma l}_{02}$ | 45 | mA | [NOTE 3] |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {sto }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

[NOTE 1] Permanent LSI damage may occur if "Maximum Ratings" are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS $-1,-2^{\prime \prime}$. If these conditions are exceeded, it could be cause of malfunction of LSI and affects reliability of LSI.
[NOTE 2] All voltages are with respect to GND.
[NOTE 3] The Maximum Total Output Current is total sum of output currents which can flow out (or flow in) from or into the I/O pins and Output pins simultaneously.

- ELECTRICAL CHARACTERISTICS-1 ( $\mathrm{VCC}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-20^{\circ} \mathrm{C}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{\text {IL }}$ |  |  | - | - | 1.0 | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{1 \mathrm{H}_{1}}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{1 \mathrm{H}_{2}}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | 10 | V | 3 |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{l}_{\mathrm{OL}}=1$ |  | - | - | 0.8 | V |  |
| Output "High" Voltage (1) | $\mathrm{V}_{\mathrm{OH} 1}$ | $-\mathrm{I}_{\mathrm{OH}}=$ | mA | 2.4 | - | - | V | 4 |
| Output "High" Voltage (2) | $\mathrm{V}_{\mathrm{OH} 2}$ | $-{ }^{-1 \mathrm{OH}}=$ | 1 mA | $\mathrm{V}_{\mathrm{cc}}-0.3$ | - | - | V | 5 |
| Interrupt Input Hold Time | $\mathrm{I}_{\text {INT }}$ |  |  | $2 \cdot T_{\text {inst }}$ | - | - | $\mu \mathrm{s}$ |  |
| Interrupt Input Fall Time | $\mathrm{t}_{\text {fint }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Interrupt Input Rise Time | $\mathrm{t}_{\text {rint }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Output "High" Current | IOH | $\mathrm{V}_{\mathrm{OH}}=$ |  | - | - | 3 | $\mu \mathrm{A}$ | 6 |
| Input Leakage Current | $I_{\text {IL }}$ | $\mathrm{V}_{\text {in }}=0$ | $V_{c c}$ | - | - | 1 | $\mu \mathrm{A}$ | 2 |
|  |  | $\mathrm{V}_{\text {in }}=0$ | 10 V | - | - | 3 |  | 3 |
| Pull up MOS Current | $-1 p$ | $\mathrm{V}_{\mathrm{CC}}=5$ |  | 60 | - | 250 | $\mu \mathrm{A}$ |  |
| Supply Current (1) | $\mathbf{I c c l}$ | $V_{\text {in }}=V$ <br> Ceramic <br> Oscillat $\left(f_{o x}=\right.$ | $V_{c c}=5 \mathrm{~V}$ <br> ler <br> kHz ) | - | - | 2.0 | mA | 7 |
| Supply Current (2) | $I_{\text {cc2 }}$ | $\begin{aligned} & V_{\text {in }}=V^{\prime} \\ & R_{f} \text { Oscil } \\ & \text { If } f_{\text {oxc }}=8 \\ & \text { Externa } \\ & \text { Operati } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \\ & \text { ion } \\ & \mathrm{kHz}) \\ & \text { lock } \\ & \left(f_{\mathrm{cp}}=800 \mathrm{kHz}\right) \end{aligned}$ | - | - | 0.85 | mA | 7 |
| Standby I/O Leakage Current | ILs | $\begin{aligned} & \overline{\mathrm{HLT}} \\ & =1.0 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ | - | - | 1 | $\mu \mathrm{A}$ | 5,8 |
|  |  |  | $\mathrm{V}_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 6,8 |
| Standby Supply Current | $I_{\text {ccs }}$ | $\mathrm{V}_{\text {in }}=\mathrm{V}^{\text {c }}$ | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | - | - | 12 | $\mu \mathrm{A}$ | 9 |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $\mathrm{f}_{\text {cp }}$ |  |  | 350 | - | 850 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | $\mathrm{t}_{\text {rcp }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | $\mathrm{t}_{\text {fip }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4$ |  | 4.7 | - | 11.4 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation ( $\mathrm{R}_{\mathrm{f}}$ Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\mathrm{oxc}}$ | $\mathrm{R}_{\mathrm{f}}=51$ | $\pm 2 \%$ | 540 | - | 900 | kHz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {oxc }}$ |  | 4.4 | - | 7.4 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation (Cersmic Filter Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\mathrm{osc}}$ | Ceramic Filter Circuit |  | 784 | - | 816 | kHz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {oxc }}$ |  | 4.9 | - | 5.1 | $\mu \mathrm{s}$ |  |

[NOTE 1] All voltages are with respect to GND.
[NOTE 2] This is applied to RESET, $\overline{\mathrm{HLT}}, \mathrm{OSC}_{1}, \mathrm{INT}_{0}$, INT $\mathrm{I}_{1}$ and the With Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of I/O pins.
[NOTE 4] This is applied to the CMOS type of I/O or Output pins.
[NOTE 5] This is applied to the With Pull up MOS or CMOS type of I/O or Output pins.
[NOTE 6] This is applied to the Open Drain type of I/O or Output pins.
[NOTE 7] I/O current is excluded.
[NOTE 8] The Standby I/O Leakage Current is the I/O leakage current in the Halt and Disable State.
[NOTE 9] I/O current is excluded.
The Standby Supply Current is the supply current at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration voltage is called the Halt Current (IDH), and it is shown in "ELECTRICAL CHARACTERISTICS -2."

## - ELECTRICAL CHARACTERISTICS-2 ( $\mathbf{T a}=-20^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ )

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Halt Duration Voltage | $\mathrm{V}_{\text {DH }}$ | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.3 | - | V |
| Halt Current | $\mathrm{I}_{\mathrm{DH}}$ | $\begin{aligned} & V_{\mathrm{in}}=V_{\mathrm{cc}} \\ & H L T=0.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{DH}}=2.3 \mathrm{~V} \end{aligned}$ | - | 12 | $\mu \mathrm{A}$ |
| Halt Delay Time | $t_{\text {HD }}$ |  | 100 | - | $\mu \mathrm{s}$ |
| Operation Recovery Time | $\mathrm{t}_{\mathrm{BC}}$ |  | 100 | - | $\mu \mathrm{s}$ |
| $\overline{\text { HLT }}$ Fall Time | $\mathrm{t}_{\text {f }} \mathrm{t}_{\text {LT }}$ |  | - | 1000 | $\mu \mathrm{s}$ |
| $\overline{\text { HLT }}$ Rise Time | $\mathrm{t}_{\text {rHLT }}$ |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT "Low" Hold Time | $\mathrm{t}_{\mathrm{HLT}}$ |  | 400 | - | $\mu \mathrm{s}$ |
| HLT "High" Hold Time | $\mathrm{t}_{\text {OPR }}$ | Rf Oscillation, External Clock Operation | 0.1 | - | ms |
|  |  | Ceramic Filter Oscillation | 4 | - |  |
| Power Supply Rise Time | $\mathrm{t}_{\mathrm{rcc}}$ | Built-in Reset, $\overline{H L T}=\mathrm{V}_{\mathrm{CC}}$ | 0.1 | 10 | ms |
| Power Supply OFF Time | $t_{\text {OFF }}$ | Built-in Reset $\mathrm{HLT}=\mathrm{V}_{\mathrm{CC}}$ | 1 | - | ms |
| RESET Pulse Width (1) | $\mathrm{t}_{\text {RST } 1}$ | External Reset <br> $V_{c c}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ <br> (R, Oscillation, External Clock <br> Operation) | 1 | - | ms |
|  |  | External Reset <br> $\mathrm{V}_{\mathrm{cc}}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ <br> (Ceramic Filter Oscillation) | 4 | - |  |
| RESET Pulse Width (2) | $\mathrm{t}_{\text {RST2 }}$ | $\begin{aligned} & \text { External Reset } \\ & V_{\mathrm{CC}}=4.5 \text { to } 5.5 \mathrm{~V}, \\ & \hline \mathrm{HLT}=V_{\mathrm{Cc}} \end{aligned}$ | $2 \cdot \mathrm{~T}_{\text {inst }}$ | - | $\mu \mathrm{s}$ |
| RESET Fall Time | $\mathrm{t}_{\text {fRST }}$ | $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{CC}}$ | - | 20 | ms |
| RESET Rise Time | $\mathrm{t}_{\mathrm{r} \text { RST }}$ | $\overline{\text { HLT }}=\mathrm{V}_{\mathrm{Cc}}$ | - | 20 | ms |

[NOTE] All voltages are with respect to GND.

- HMCS47CL ELECTRICAL CHARACTERISTICS (2.5V to 5.5V)
- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Remarks |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $\mathrm{V}_{\mathrm{T} 1}$ | -0.3 to $\mathrm{V}_{\mathrm{Cc}}+0.3$ | V | Except for the terminals <br> specified by $\mathrm{V}_{\mathrm{T} 2}$ |
| Terminal Voltage (2) | $\mathrm{V}_{\mathrm{T} 2}$ | -0.3 to +10.0 | V | Applied to the Open Drain <br> type of Output pins and Open <br> Drain type of $/ \mathrm{O}$ pins. |
| Maximum Total Output Current (1) | $-\Sigma \mathrm{I}_{\mathrm{O} 1}$ | 45 | mA | [NOTE 3] |
| Maximum Total Output Current (2) | $\Sigma \mathrm{I}_{\mathrm{O} 2}$ | 45 | mA | [NOTE 3] |
| Operating Temperature | $\mathrm{T}_{\mathrm{opr}}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\mathrm{sta}}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

[NOTE 1] Permanent LSI damage may occur if "Maximum Ratings" are exceeded. Normal operation should be under the conditions of "ELECTRICAL CHARACTERISTICS $-1,-2$." If these conditions are exceeded, it could be cause of malfunction of LSI and affects reliability of LSI.
[NOTE 2] All voltages are with respect to GND.
[NOTE 3] The Maximum Total Output Current is total sum of output currents which can flow out (or flow in) from or into the I/O pins and Output pins simultaneously.

- ELECTRICAL CHARACTERISTICS - $1\left(\mathrm{~V} \mathbf{C C}=2.5\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-20$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $V_{\text {IL }}$ |  |  | - | - | $0.15 \cdot V_{\text {c }}$ | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathrm{IH} 1}$ |  |  | $0.85 \cdot V_{\text {cC }}$ | - | $\mathrm{V}_{\mathrm{CC}}$ | V | 2 |
| Input "High" Voltage (2) | $\mathrm{V}_{1 \mathrm{H} 2}$ |  |  | $0.85 \cdot V_{\text {CC }}$ | - | 10 | V | 3 |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{IOL}^{\text {a }}=0$ | 4 mA | - | - | 0.4 | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $-\mathrm{IOH}^{\text {a }}=$ | 0.08 mA | $\mathrm{V}_{\mathrm{cc}}-0.4$ | - | - | V | 4 |
| Interrupt Input Hold Time | IINT |  |  | $2 \cdot T_{\text {in st }}$ | - | - | $\mu \mathrm{s}$ |  |
| Interrupt Input Fall Time | $\mathrm{t}_{\mathrm{fINT}}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Interrupt Input Rise Time | $\mathrm{tr}_{\text {INT }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ |  |
| Output "High" Level Current | IOH | $\mathrm{V}_{\mathrm{OH}}=$ | V | - | - | 3 | $\mu \mathrm{A}$ | 6 |
| Input Leakage Current | IIL | $V_{\text {in }}=$ | $V_{c c}$ | - | - | 1.0 | $\mu \mathrm{A}$ | 2 |
|  |  | $V_{\text {in }}=0$ | - 10 V | - | - | 3 |  | 3 |
| Pull up MOS Current | $-1 p$ | $V_{\text {cc }}=3$ |  | 10 | - | 80 | $\mu \mathrm{A}$ |  |
| Supply Current | ICC | $V_{\text {in }}=V_{\text {c }}$ <br> $1 \mathrm{f}_{\mathrm{osc}} / \mathrm{f}_{\mathrm{cp}}$ <br> $\mathrm{R}_{\mathrm{f}}$ Osci <br> Externa <br> Operati | $\begin{aligned} & c, V V_{C C}=3 V \\ & =200 \mathrm{kHz}) \\ & \text { lation, } \\ & \text { Clock } \end{aligned}$ on | - | - | 140 | $\mu \mathrm{A}$ | 7 |
| Standby I/O Leakage Current | ILS | $\begin{aligned} & \text { HLT } \\ & =0.5 \mathrm{~V} \end{aligned}$ | $V_{\text {in }}=0$ to $V_{c c}$ | - | - | 1 | $\mu \mathrm{A}$ | 5.8 |
|  |  |  | $\mathrm{V}_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | 6,8 |
| Standby Supply Current | Iccs | $\begin{aligned} & V_{\text {in }}= \\ & V_{c c} \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=2.5 \text { to } \\ 3.5 \mathrm{~V} \end{gathered}$ | - | - | 6 | $\mu \mathrm{A}$ | 9 |
|  |  | $\begin{aligned} & \text { HLT }= \\ & 0.1 \mathrm{~V} \end{aligned}$ | $\begin{array}{r} \mathrm{V}_{\mathrm{CC}}=2.5 \text { to } \\ 5.5 \mathrm{~V} \end{array}$ | - | - | 10 | $\mu \mathrm{A}$ |  |
| External Clock Operation |  |  |  |  |  |  |  |  |
| External Clock Frequency | $\mathrm{f}_{\mathrm{cp}}$ |  |  | 130 | 200 | 240 | $\overline{\mathrm{kHz}}$ |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | $\mathrm{t}_{\mathrm{rcp}}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | $\mathrm{t}_{\text {fcp }}$ |  |  | 0 | - | 0.2 | $\mu s$ |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inat }}$ | $\mathrm{T}_{\text {inst }}=$ | /fcp | 16.8 | 20 | 30.8 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation ( $\mathrm{R}_{\mathrm{f}}$ Oscillation) |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {osc }}$ | $\begin{aligned} & R_{f}=20 \\ & V_{C C}=2 . \end{aligned}$ | $\begin{aligned} & 0 k \Omega \pm 2 \% \\ & 5 \text { to } 3.5 \mathrm{~V} \end{aligned}$ | 130 | - | 250 | kHz |  |
|  | $f_{\text {ose }}$ | $\begin{aligned} & R_{f}=200 \\ & V_{C C}=2 . \end{aligned}$ | $\begin{aligned} & \Omega \Omega \pm 2 \% \\ & 5 \text { to } 5.5 \mathrm{~V} \end{aligned}$ | 130 | - | 350 | kHz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\begin{aligned} & T_{\text {inst }}=4 \\ & V_{c c}=2 . \end{aligned}$ | $\begin{aligned} & f_{\text {osc }} \\ & 5 \text { to } 3.5 \mathrm{~V} \end{aligned}$ | 16 | - | 30.8 | $\mu \mathrm{s}$ |  |
|  | $\mathrm{T}_{\text {inst }}$ | $\begin{aligned} & T_{\text {inst }}=4 \\ & V_{C C}=2 . \end{aligned}$ | $\begin{aligned} & \text { ose } \\ & 5 \text { to } \\ & 5.5 V \end{aligned}$ | 11.4 | - | 30.8 | $\mu \mathrm{s}$ |  |

[NOTE 1] All voltages are with respect to GND.
[NOTE 2] This is applied to RESET, $\overline{H L T}, \mathrm{OSC}_{1}, I N T_{0}, I N T_{1}$ and the With Pull up MOS or CMOS type of I/O pins.
[NOTE 3] This is applied to the Open Drain type of $1 / O$ pins.
[NOTE 4] This is applied to the CMOS type of 1/O or Output pins.
[NOTE 5] This is applied to the With Pull up MOS or CMOS type of I/O or Output pins
[NOTE 6] This is applied to the Open Drain type of I/O or Output pins.
[NOTE 7] I/O current is excluded.
[NOTE 8] The Standby I/O Leakage Current is the I/O leakage current in the Halt and Disable State.
[NOTE 9] I/O current is excluded.
The Standby Supply Current is the supply current at $\mathrm{V}_{\mathrm{CC}}=2.5$ to 5.5 V in the Halt State. The supply current in the case where the supply voltage falls to the Halt Duration voltage is called the Halt Current (IDH), and it is shown in "ELECTRICAL CHARACTERISTICS -2."

- ELECTRICAL CHARACTERISTICS - 2 ( $\mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$ )

Reset and Halt

| Item | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Halt Duration Voltage | V DH | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | 2.0 | - | V |
| Halt Current | 1 DH | $\begin{aligned} & V_{\mathrm{in}}=V_{\mathrm{Cc}}, V_{D H}=2.0 \mathrm{~V} \\ & \mathrm{HLT}=0.1 \mathrm{~V} \end{aligned}$ | - | 12 | $\mu \mathrm{A}$ |
| Halt Delay Time | thD |  | 200 | - | $\mu \mathrm{s}$ |
| Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}$ |  | 200 | - | $\mu \mathrm{s}$ |
| $\overline{\text { HLT Fall Time }}$ | $\mathrm{t}_{\mathrm{fHLT}}$ |  | - | 1000 | $\mu \mathrm{s}$ |
| HLT Rise Time | $\mathrm{trHLT}^{\text {r }}$ |  | - | 1000 | $\mu \mathrm{s}$ |
| $\overline{\text { HLT }}$ "Low" Hold Time | $\mathrm{t}_{\mathrm{HLT}}$ |  | 800 | - | $\mu \mathrm{s}$ |
| HLT 'High' Hold Time | topr | $\mathrm{R}_{\mathrm{f}}$ Oscillation, External Clock Operation, $V_{C C}=2.5$ to 5.5 V | 0.2 | - | ms |
| RESET Pulse Width (1) | $\mathrm{t}_{\text {RST }} 1$ | External Reset $\mathrm{V}_{\mathrm{CC}}=2.5$ to 5.5 V HLT $=V \propto$ Rf Oscillation, External Clock Operation | 2 | - | ms |
| RESET Pulse Width (2) | $t_{\text {RST2 }}$ | $\begin{aligned} & \text { External Reset } \\ & V_{C C}=2.5 \text { to } 5.5 \mathrm{~V} \\ & \mathrm{HLT}=\mathrm{V}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | $2 \cdot T_{\text {inst }}$ | - | $\mu \mathrm{s}$ |
| RESET Fall Time | $\mathrm{t}_{\text {fRST }}$ | HLT $=V_{\text {CC }}$ | - | 20 | ms |
| RESET Rise Time | trRST | $\mathrm{HLT}=\mathrm{V}_{\mathrm{Cc}}$ | - | 20 | ms |

(NOTE) All voltages are with respect to GND.

## - SIGNAL DESCRIPTION

The input and output signals for the HMCS47C, shown in PIN ARRANGEMENT, are described in the following paragraphs.

- VCC and GND

Power is supplied to the HMCS47C using these two pins. $\mathrm{V}_{\mathrm{CC}}$ is power and GND is the ground connection.

## - RESET

This pin allows resetting of the HMCS47C at times other than the automatic resetting capability (ACL; Built-in Reset Circuit) already in the HMCS47C. The HMCS47C can be reset by pulling RESET high. Refer to RESET FUNCTION for additional information.

- OSC $_{1}$ and OSC 2

These pins provide control input for the built-in oscillator circuit. A resistor, ceramic filter circuit, or an external oscillator can be connected to these pins to provide a system clock with various degrees of stability/cost tradeoffs. Lead length and stray capacitance on these two pins should be minimized. Refer to OSCILLATOR for recommendations about these pins.

## - HLT

This pin is used to place the HMCS47C in the Halt State (Stand-by Mode).

The HMCS47C can be moved into the Halt State by pulling $\overline{\text { HLT }}$ low.

In the Halt State, the internal clock stops and all the internal statuses (the RAM, the registers, the Carry F/F, the Status F/F, the Program Counter, and all the internal statuses) are held.

Consequently, the power consumption is reduced. By pulling $\overline{\text { HLT high, the HMCS47C starts operation from the state just }}$ before the Halt State.

Refer to HALT FUNCTION for details of the Halt Mode.

## - TEST

This pin is not for user application and must be connected to $\mathrm{V}_{\mathrm{Cc}}$.

- INT ${ }_{0}$ and INT $_{1}$

These pins provide the capability for asynchronously applying external interrupts to the HMCS47C.

Refer to INTERRUPTS for additional information.

- $\mathbf{R}_{\mathbf{0 0}}-\mathbf{R}_{\mathbf{0 3}}, \mathbf{R}_{10}-\mathbf{R}_{13}, \mathbf{R}_{\mathbf{2 0}}-\mathbf{R}_{23}, \mathbf{R}_{\mathbf{3 0}}-\mathbf{R}_{33}, \mathbf{R}_{40}-\mathbf{R}_{43}$,
$\mathbf{R}_{50}-\mathbf{R}_{53}$
These 24 lines are arranged into six 4-bit Data Input/Output Common Channels.

The 4-bit registers (Data I/O Register) are attached to these channels. Each channel is directly addressed by the operand of input/output instruction. Refer to INPUT/OUTPUT for additional information.

## - $\mathbf{R}_{60}-\mathbf{R}_{63}$

These 4 lines are the 4-bit Data Output Channel.

The 4-bit register (Data I/O Register) is attached to this channel.

The channel is directly addressed by the operand of output instruction.

Refer to INPUT/OUTPUT for additional information.

- $D_{0}-D_{15}$

These lines are 16 1-bit Discrete Input/Output Common Terminals.

The 1-bit latches are attached to these terminals. Each terminal is addressed by the $Y$ register. The $D_{0}$ to $D_{3}$ terminals are also addressed directly by the operand of input/output instruction. Refer to INPUT/OUTPUT for additional information.

- ROM
- ROM Address Space

ROM is used as a memory for the instructions and the patterns (constants). The instruction used in the HMCS47C consists of 10 bits. These 10 bits are called "a word", which is a unit for writing into ROM.

The ROM address has been split into two banks.
Each bank is composed of 32 pages ( 64 words/page).
The ROM capacity is 4,096 words ( 1 word $=10$ bits) in all.
All addresses can contain both the instructions and the patterns (constants).

The ROM address space is shown in Figure 1.


Reset Address
Bank 131 Page 3F Address
(63 Page 3F Address)
*Bank 00 Page ( 0 Page) is the Subroutine Space.
Note: The parenthesized contents are expressions of the Page, combining the bank part with the page part.

Figure 1 ROM Address Space

- Program Counter (PC)

The program counter is used for addressing of ROM. The


Note: The parenthesized contents are expressions of the Page,combining the bank part with the page part.

Figure 2 Configuration of Program Counter
program counter consists of the bank part, the page part, and the address part as shown in Figure 2.

The bank part is a 1 -bit register and the page part is a 5 -bit register.

Once a certain value is loaded into the bank part or the page part, the content is unchanged until other value is loaded by a program.

The settable value is " 0 " (the Bank 0) or " 1 " (the Bank 1) for the bank part, and 0 to 31 for the page part. The address part is a 6-bit polynomial counter and counts up for each instruction cycle time. The sequence in the decimal and
hexa-decimal system is shown in Table 1. This sequence is cirfor each instruction cycle time. The sequence in the decimal and
hexa-decimal system is shown in Table 1. This sequence is circulating and has neither the starting nor ending point. It doesn't culating and has neither the starting nor ending point. It doesn't
generate an overflow carry. Consequently, the program on a same page is executed in order unless the value of the bank part or the page part is changed.

Table 1 Program Counter Address Part Sequence

| Decimal | Hexa- <br> decimal | Decimal | Hexa- <br> decimal | Decimal | Hexa- <br> decimal |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 63 | $3 F$ | 5 | 05 | 9 | 09 |
| 62 | $3 E$ | 11 | $0 B$ | 19 | 13 |
| 61 | $3 D$ | 23 | 17 | 38 | 26 |
| 59 | $3 B$ | 46 | $2 E$ | 12 | $0 C$ |
| 55 | 37 | 28 | $1 C$ | 25 | 19 |
| 47 | $2 F$ | 56 | 38 | 50 | 32 |
| 30 | $1 E$ | 49 | 31 | 37 | 25 |
| 60 | $3 C$ | 35 | 23 | 10 | $0 A$ |
| 57 | 39 | 6 | 06 | 21 | 15 |
| 51 | 33 | 13 | $0 D$ | 42 | $2 A$ |
| 39 | 27 | 27 | $1 B$ | 20 | 14 |
| 14 | $0 E$ | 54 | 36 | 40 | 28 |
| 29 | $1 D$ | 45 | $2 D$ | 16 | 10 |
| 58 | $3 A$ | 26 | $1 A$ | 32 | 20 |
| 53 | 35 | 52 | 34 | 0 | 00 |
| 43 | $2 B$ | 41 | 29 | 1 | 01 |
| 22 | 16 | 18 | 12 | 3 | 03 |
| 44 | $2 C$ | 36 | 24 | 7 | 07 |
| 24 | 18 | 8 | 08 | 15 | $0 F$ |
| 48 | 30 | 17 | 11 | 31 | $1 F$ |
| 33 | 21 | 34 | 22 |  |  |
| 2 | 02 | 4 | 04 |  | 0 |

## - Designation of ROM Address and ROM Code

The bank part of the ROM address is shown in the binary system and the page part in the decimal system. The address part is divided into 2 bits and 4 bits, and shown in the hexadecimal system.

It is possible to combine the bank part and the page part and show the combined part as the Page (in the decimal system).

In this case, the 0 Page to the 31 Page in the Bank 1 are shown as the 32 Page to the 63 Page. The examples are shown in Figure 3.

One word ( 10 bits) of ROM is divided into three parts (2 bits, 4 bits and 4 bits from the most significant bit $\mathrm{O}_{10}$ in order) shown in the hexa-decimal system. The examples are shown in Figure 3.
(a) ROM Address

(b) ROM Code


Figure 3 Designation of ROM Address and ROM Code

## - PATTERN GENERATION

The pattern (constant) can be accessed by the pattern instruction ( $\mathbf{P}$ ). The pattern can be written in any address of the ROM address space.

## - Reference

ROM addressing for reference of the patterns is achieved by modifying the program counter with the accumulator, the B register, the Carry F/F and the operand p. Figure 4 shows how to modify the program counter. The address part is replaced with the accumulator and the lower 2 bits of $B$ register, while the page part and the bank part are ORed with the upper 2 bits of $B$ register, the Carry $F / F$ and the operand $p$.

The value of the operand $p\left(p_{2}, p_{1}, p_{n}\right)$ is 0 to 7 (decimal).
The bank part of the ROM address to be referenced to is determined by the logical equation: $\mathbf{P C}_{11}+\mathbf{P}_{\mathbf{2}}$ ( $\mathbf{p}_{\mathbf{2}}=$ the MSB of the operand p ).

If the address where the pattern instruction exists is in the Bank 1, only the pattern of the Bank 1 can be referenced.

If the address where the pattern instruction exists is in the Bank 0, the pattern of the either Bank 1 or Bank 0 can be referenced depending on the value of $p_{2}$. The truth table of the bank part of the ROM address is shown in Table 2.

The value of the program counter is apparently modified and does not change actually. After execution of the pattern instruction, the program counter counts up and the next instruction is
executed.
The pattern instruction is executed in 2-cycle time.

## - Generation

The pattern of referred ROM address is generated as the following two ways:
(i) The pattern is loaded into the accumulator and B register.
(ii) The pattern is loaded into the Data I/O Registers R2 and R3.
Selection is determined by the command bits $\left(\mathrm{O}_{9}, \mathrm{O}_{10}\right)$ in the pattern.

Mode (i) is performed when $O_{9}$ is " 1 " and mode (ii) is performed when $O_{10}$ is " 1 ".

Mode (i) and (ii) are simultaneously performed when both of $O_{9}$ and $\mathrm{O}_{10}$ are " 1 ". The correspondence of each bit of the pattern is shown in Figure 5.

Examples of the pattern instruction is shown in Table 3.

## CAUTION

In the program execution, the pattern can not be distinguished from the instruction. When the program is executed at the addresses into which pattern is written, the instruction corresponding to the pattern bit is executed. Take care that a pattern is not executed as an instruction.


Figure 4 ROM Addressing for Pattern Generation

Table 2 Bank Part Truth Table of Pattern Generation

| PC $_{11}$ | $p_{2}$ | Bank part of ROM address <br> to be referenced to |
| :---: | :---: | :---: |
| 1 (Bank 1) | 1 | 1 (Bank 1) |
|  | 0 | 1 (Bank 1) |
| 0 (Bank 0) | 1 | 1 (Bank 1) |
|  | 0 | $0($ Bank 0) |





Figure 5 Correspondence of Each Bit of Pattern

Table 3 Example of Pattern Instructions

| Before Execution |  |  |  |  | Referred ROM Address | ROM Pattern | After Execution |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PC | p | C | B | A |  |  | B | A | R2 | R3 |
| $\begin{gathered} \text { Bank 0 0.3F } \\ (0.3 F) \end{gathered}$ | 1 | 0 | A | 0 | $\begin{gathered} \text { Bank } 0 \text { 10-20 } \\ (10-20) \end{gathered}$ | 12D | 2 | B | - | -* |
| $\begin{gathered} \text { Bank } 000.3 F \\ (0.3 F) \end{gathered}$ | 7 | 1 | 4 | 0 | $\begin{gathered} \text { Bank } 129.00 \\ (61.00) \end{gathered}$ | 22D | - | - | 4 | B |
| $\begin{gathered} \hline \text { Bank } 130-00 \\ (62-00) \\ \hline \end{gathered}$ | 4 | 0/1** | 0 | 9 | $\begin{gathered} \text { Bank } 130-09 \\ (62.09) \\ \hline \end{gathered}$ | 32D | 2 | B | 4 | B |
| $\begin{gathered} \text { Bank } 130-00 \\ (62.00) \end{gathered}$ | 1 | 0/1** | F | 9 | $\begin{gathered} \text { Bank } 131-39 \\ (63-39) \end{gathered}$ | 223 | - | - | 4 | C |

[^2]
## - BRANCH

ROM is accessed according to the program counter sequence and the program is executed. In order to jump to any address out of the sequence, there are four ways. They are explained in the following paragraphs.

## - BR

By BR instruction, the program branches to an address in the current page.

The lower 6 bits of ROM Object Code (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) are transferred to the address part of the program counter. This instruction is a conditional instruction and executed only when the Status $\mathrm{F} / \mathrm{F}$ is " 1 ". If it is " 0 ", the instruction is skipped and the Status F/F becomes " 1 ". The operation is shown in Figure 6. - LPU

By LPU instruction, the jump of the bank and page is performed.

The lower 5 bits of the ROM Object Code (operand $u, \mathrm{O}_{5}$ to $\mathrm{O}_{1}$ ) are transferred to the page part of the program counter with a delay of 1 -cycle time. At the same time, the signal $\overline{R_{0}}$ (the reversed-phase signal of the Data I/O Register $\mathrm{R}_{0}$ ) is transferred to the bank part of the program counter with a delay of 1-cycle time. The operation is shown in Figure 7.

Consequently, the bank and page will remain unchanged in the cycle immediately following this instruction. In the next cycle, a jump of the bank and page is achieved.

This instruction (LPU) is conditional, and is executed only when the Status F/F is "1". Even after a skip, the Status F/F will remain unchanged (" 0 ").

LPU instruction is used in combination with BR instruction or CAL instruction as the macro instruction of BRL or CALL instruction.

- BRL

By BRL instruction, the program branches to an address in any bank and page.

This instruction is a macro instruction of LPU and BR instructions, which is divided into two instructions as follows.

$$
\begin{aligned}
& \text { BRL } \begin{array}{r}
a-b \longrightarrow \\
\quad \text { LPU } a \\
b
\end{array} \\
& \text { < Jump to Bank " } \overline{R_{70}}{ }^{\prime} \text {, a Page - b Address > }
\end{aligned}
$$

BRL instruction is a conditional instruction because of characteristics of LPU and BR instructions, and is executed only when the Status $F / F$ is " 1 ". If the Status $F / F$ is " 0 ", the instruction is skipped and the Status $\mathrm{F} / \mathrm{F}$ becomes " 1 ". The examples of BRL instruction are shown in Figure 8.

## - TBR (Table Branch)

By TBR instruction, the program branches by the table.
The program counter is modified with the accumulator, the $B$ register, the Carry $F / F$ and the operand $p$.

The method for modification is shown in Figure 9.
The bank part is determined by the logical equation: $\mathrm{PC}_{11}+$ $\mathrm{p}_{2}$, as shown in Table 4.

If the address where TBR instruction exists is in the Bank 1, it is possible to jump to an address only in the Bank 1, not to an address in the Bank 0.

If the address where TBR instruction exists is in the Bank 0 , it is possible to jump to an address in either the Bank 1 or the Bank 0 depending on the value of the operand $p_{2}$.

TBR instruction is executed regardless of the Status F/F, and does not affect the Status $\mathrm{F} / \mathrm{F}$.


Figure 6 BR Operation


Figure 7 LPU Operation

| Branch to | $\begin{gathered} \text { Bank } 0 \\ 15 \end{gathered}$ |  |
| :---: | :---: | :---: |
| $\cdots$ - LRA | 7 | $\mathrm{R}_{70}={ }^{\prime \prime} \mathbf{1}^{\prime \prime}\left(\overline{\mathrm{R}_{70}}={ }^{\prime} 0^{\prime \prime}\right)$ |
| LPU | 5 5 | BRL 5-3F |
| BR | 3F ? | (Branch to Bank 0 5-3F (5-3F)) |
| LAI | 15 |  |
| $\begin{array}{r} \text { LBA } \\ \cdots-\text { LRA } \end{array}$ |  |  |
| $\begin{aligned} & \text { F-LRA } \\ & \text { COMB } \end{aligned}$ | 7 | $\mathrm{R}_{70}={ }^{\prime \prime} \mathbf{1}^{\prime}\left(\mathrm{R}_{70}\right.$ |
| $\xrightarrow{-H P U}$ |  |  |
| BR | 3F 3 | BRL 31-3F <br> (Branch to Bank 0 31-3F (31-3F)) |

Branch to Bank 1

| $\begin{gathered} \text { LAI } \\ \hdashline \text { LRRA } \\ \rightarrow \text { LPR } \\ \text { BR } \end{gathered}$ | $\left.\begin{array}{l} 0 \\ 7 \\ 15 \\ 3 F \end{array}\right\}$ | $R_{70}={ }^{\prime} 0^{\prime \prime}\left(\overline{R_{70}}=" 1 "\right)$ <br> BRL 15-3F <br> (Branch to Bank 115-3F (47-3F) |
| :---: | :---: | :---: |
| $\text { - } \begin{gathered} \text { LAI } \\ \text { LTA } \end{gathered}$ | 0 |  |
| $\begin{gathered} \text { LRA } \\ \text { LYI } \end{gathered}$ | $\begin{aligned} & 7 \\ & 2 \end{aligned}$ | $\mathrm{R}_{70}={ }^{\prime \prime} 0^{\prime \prime}\left(\overline{R_{70}}={ }^{\prime \prime} 1{ }^{\prime \prime}\right)$ |
| XMA |  |  |
| $\begin{gathered} \text { BR } \\ \text { BR } \end{gathered}$ | $\left.\begin{array}{l} 10 \\ 2 E \end{array}\right\}$ | BRL 10-2E |

Figure 8 BRL Example

Table 4 Bank Part Truth Table of TBR Instruction

| PC $_{11}$ | $p_{2}$ | Bank Part of PC after <br> TBR |
| :---: | :---: | :---: |
| 1 (Bank 1) | 1 | $1($ Bank 1) |
|  | 0 | $1($ Bank 1) |
| $0($ Bank 0) | 1 | $1($ Bank 1) |
|  | 0 | $0($ Bank 0) |

SUBROUTINE JUMP
There are two types of subroutine jumps. They are explained in the following paragraphs.

## - CAL

By CAL instruction, subroutine jump to the Subroutine Space is performed.

The Subroutine Space is the Bank 00 Page ( 0 Page).
The address next to CAL instruction address is pushed onto the Stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively as shown in Figure 10.

The bank part of the program counter becomes the Bank 0 and the page part becomes the 0 Page. The lower 6 bits (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) of the ROM Object Code is transferred to the address part of the program counter.

The HMCS47C has 4 levels of stack (ST1, ST2, ST3 and ST4) which allows the programmer to use up to 4 levels of subroutine jumps (including interrupts).

CAL is a conditional instruction and executed only when the Status F/F is " 1 ". If the Status $F / F$ is " 0 ", it is skipped and the Status F/F changes to " 1 ".

- CALL

By CALL instruction, subroutine jump to an address in any bank and page is performed.

Subroutine jump to any address can be implemented by the subroutine jump to the page specified by LPU instruction in the bank designated by the reversed-phase signal $\overline{\mathbf{R}_{70}}$ of the Data I/O Register $\mathrm{R}_{70}$.

This instruction is a macro instruction of LPU and CAL instructions, which is divided into two instructions as follows.

<Subroutine Jump to Bank " $\overline{R_{70}}$ ", a Page - b Address >
CALL instruction is conditional because of characteristics of LPU and CAL instructions and is executed when the Status F/F is " 1 ". If the Status $F / F$ is " 0 ", the instruction is skipped and the Status F/F changes to " 1 ". The examples of CALL instruction are shown in Figure 11.


Figure 9 Modification of Program Counter by TBR Instruction


Figure 10 Subroutine Jump Stacking Order

| Subroutine | Jum |  |
| :---: | :---: | :---: |
| --LRA | 7 |  |
| -LPU CAL | $\left.\begin{array}{l} 5 \\ 3 F \end{array}\right\}$ | CALL 5-3F <br> (Subroutine Jump to Bank 05-3F (5-3F)) |
| LAI <br> LBA | 15 |  |
| LRA COMB | 7 | $\mathrm{R}_{70}={ }^{\prime \prime}{ }^{\prime \prime}\left(\overline{R_{90}}=\times 0 \times\right)$ |
| - LPU CAL | $\left.\begin{array}{l} 31 \\ 3 F \end{array}\right\}$ | CALL 3-3F |



Figure 11 CALL Example

## - RAM

RAM is a memory used for storing data and saving the contents of the registers. Its capacity is 256 digits ( 1,024 bits) where one digit consists of 4 bits.

Addressing of RAM is performed by a matrix of the file No. and the digit No.

The file No. is set in the $X$ register and the digit No. in the $Y$ register for reading, writing or testing. Specific digits in RAM can be addressed not via the X register and Y register. These digits are called "Memory Register (MR)", 0 to 15 ( 16 digits in all). The memory register can be exchanged with the accumulator by XAMR instruction.

The RAM address space is shown in Figure 12.
In an instruction in which reading from RAM and writing to RAM coexist (exchange between RAM and the register), reading precedes writing and the write data does not affect the read data.

The RAM bit manipulation instruction enables any addressed RAM bit to be set, reset or tested. The bit assignment is specified by the operand $n$ of the instruction.

The bit test makes the Status $\mathrm{F} / \mathrm{F}$ " 1 " when the assigned bit is " 1 " and makes it " 0 " when the assigned bit is " 0 ".

Correspondence between the RAM bit and the operand n is shown in Figure 13.


Figure 12 RAM Address Space


Figure 13 RAM Bit and Operand $n$

## - REGISTER

The HMCS47C has six 4-bit registers and two 1 -bit registers available to the programmer. The 1 -bit registers are the Carry F/F and the Status F/F. They are explained in the following paragraphs.

## - Status F/F (S)

The Status F/F latches the result of logical or arithmetic operations (Not Zero, Overflow) and bit test operations. The Status F/F affects conditional instructions (LPU, BR and CAL instructions). These instructions are executed only when the Status $F / F$ is " 1 ". If it is " 0 ", these instructions are skipped and the Status $\mathrm{F} / \mathrm{F}$ becomes " 1 ".

## - Accumulator (A; A Register) and Carry F/F (C)

The result of the Arithmetic Logic Unit (ALU) operation (4 bits) and the overflow of the ALU are loaded into the accumulator and the Carry F/F. The Carry F/F can be set, reset or tested. Combination of the accumulator and the Carry F/F can be right or left rotated. The accumulator is the main register for ALU operation and the Carry $\mathrm{F} / \mathrm{F}$ is used to store the overflow generated by ALU operation when the calculation of two or more digits ( 4 bits/digit) is performed.

## - B Register (B)

The result of ALU operation (4 bits) is loaded into this register. The B register is used as a sub-accumulator to stack data temporarily and also used as a counter.

## - X Register (X)

The result of ALU operation (4 bits) is loaded into this register. The $\mathbf{X}$ register has exchangeability for the SPX register. The X register addresses the RAM file.

## - SPX Register (SPX)

The SPX register has exchangeability for the $\mathbf{X}$ register.
The SPX register is used to stack the X register and expand the addressing system of RAM in combination with the X register.

## - Y Register (Y)

The result of ALU operation (4 bits) is loaded into this register. The Y register has exchangeability for the SPY register. The Y register can calculate itself simultaneously with transferring data by the bus lines, which is usable for the calculation of two or more digits ( 4 bits/digit). The Y register addresses the RAM digit and 1-bit Discrete I/O.

- SPY Register (SPY)

The SPY register has exchangeability for the Y register. The SPY register is used to stack the $Y$ register and expand the addressing system of RAM and 1-bit Discrete I/O in combination with the Y register.

## - INPUT/OUTPUT

- 4-bit Data Input/Output Common Channel (R)

The HMCS47C has five 4-bit Data I/O Common Channels (R0, R1, R2, R3, R4 and R5) and one 4-bit Data Output Channel (R6).

The 4-bit registers (Data I/O Register) are attached to these channels.

Each channel is directly addressed by the operand P of input/output instruction

The data is transferred from the accumulator and the B register to the Data I/O Registers R0 to R6 via the bus lines.
Pattern instruction enables the patterns of ROM to be loaded into the Data I/O Registers R2 and R3.

Input instruction enables the 4 -bit data to be sent to the accumulator and the B register from R0 to R5. Note that, since the Data I/O Register's output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the Data I/O Register's output and the pin input. Therefore, the Data I/O Register should be set to 15 (all bits of the Data I/O Register is " 1 ") not to affect the pin input before execution of input instruction, and Open Drain or With Pull up MOS should be specified for the I/O configuration of these pins.

The block diagram is shown in Figure 14. The I/O timing is shown in Figure

- 1-bit Discrete Input/Output Common Terminal (D)

The HMCS47C has 161 -bit Discrete I/O Common Terminals.
The 1-bit Discrete I/O Common Terminal consists of a 1-bit latch and an I/O common pin.

The 1 -bit Discrete $\mathrm{I} / \mathrm{O}$ is addressed by the Y register. The addressed latch can be set or reset by output instruction and " 0 " and " 1 " level can be tested with the addressed pin by input instruction.

Note that, since the latch output is directly connected to the pin even during execution of input instruction, the input data is wired logic of the latch's output and the pin input. Therefore, the latch should be set to " 1 " not to affect the pin input before execution of input instruction and Open Drain or With Pull up MOS should be specified for the I/O configuration of this pin.

The $\mathrm{D}_{0}$ to $\mathrm{D}_{3}$ terminals are also addressed directly by the operand n of input/output instruction and can be set or reset. The block diagram is shown in Figure 16 and the I/O timing is shown in Figure 17.

- I/O Configuration

The I/O configuration of each pin can be specified among Open Drain, With Pull up MOS and CMOS using a mask option as shown in Figure 18.
(a) RO to R5

(b) R6


Figure 14 4-bit Data I/O Block Diagram


Figure 15 4-bit Data I/O Timing


Figure 16 1-bit Discrete I/O Block Diagram


Figure 17 1-bit Discrete I/O Timing
(a) Configuration of Output Pin


Applied pins: $D_{0}$ to $D_{13}, R_{00}$ to $R_{63}, R_{10}$ to $R_{13}$.

*When "Disable" is specified for the I/O State at the Halt State,
the 1/O Enable signal shown in the figure turns off the input circuit,
Pull up MOS and NMOS output and sets CMOS output to high
inpedance (PMOS, NMOS: OFF).
Figure 18 I/O Configuration

## - TIMER/COUNTER

The timer/counter consists of the 4 -bit counter and the 6 -bit prescaler as shown in Figure 19. The 4-bit counter may be loaded under program control and is incremented toward 15 by the prescaler overflow output pulse or the input pulse of $\mathrm{INT}_{1}$ pin (its leading edge is counted). The clock input to the counter is selected by the CF F/F. When the CF F/F is " 0 ", the clock input is the prescaler overflow output pulse (Timer Mode). When the CF F/F is " 1 ", the clock input is the input pulse of $\mathrm{INT}_{1}$ pin (Counter Mode). When the counter reaches zero (returns from 15 to zero), the overflow output pulse is generated and the counter continues to count ( $14 \rightarrow 15 \rightarrow 0 \rightarrow 1 \rightarrow 2$ ...).

The TF F/F is a flip-flop which masks interrupts from the timer/counter. It can be set and reset by interrupt instruction. If the overflow output pulse of the counter is generated when the TF F/F is reset (" 0 "), an interrupt request occurs and the TF F/F becomes " 1 ". If the overflow output pulse is generated when the TF F/F is set (" 1 "), no interrupt request occurs. The TTF instruction enables the TF F/F to be tested.

The prescaler is a 6 -bit frequency divider. It divides a system clock (instruction frequency) by 64 into the overflow output pulses of "instruction frequency $\div 64$ ".

The prescaler is cleared when data is loaded into the counter (by LTA or LTI instruction). The frequency division is 0 when the prescaler is cleared. At the 64th clock, an overflow output
pulse is generated from the prescaler. During operation of the LSI, the prescaler is operating and cannot be stopped. (In the Halt state, it stops.) The relation between the specified value of the counter and specified time in the Timer Mode is shown in Table 5.

The pulse width of the INT $_{1}$ pin in the Counter Mode must be at least 2-cycle time for both "High" and "Low" levels as shown in Figure 19.

## - INTERRUPT

The HMCS47C can be interrupted in two different ways: through the external interrupt input pins ( $\mathrm{INT}_{0}, \mathrm{INT}_{1}$ ) and the timer/counter interrupt request. When any interrupt occurs, processing is suspended, the Status $\mathrm{F} / \mathrm{F}$ is unchanged, the present program counter is pushed onto the stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively. At that time, the Interrupt Enable F/F (I/E) is set and the address jumps to a fixed destination (Interrupt Address), and then the interrupt routine is executed. Stacking the registers other than the program counter must be performed by the program. The interrupt routine
must end with RTNI (Return Interrupt) instruction which sets the I/E F/F simultaneously with RTN instruction.

The Interrupt Address:
Input Interrupt Address
Bank 01 Page 3F Address
(1 Page 3F Address)
Timer/Counter Interrupt Address
. . . . . . . Bank 00 Page
3F Address
(0 Page 3F Address)
The input interrupt has priority over the timer/counter interrupt.

The INT $_{0}$ and INT $_{1}$ pin have an interrupt request function. Each terminal consists of a circuit which generates leading pulse and the Interrupt mask F/F (IFO, IF1). An interrupt is enabled (unmasked) when the IF0 F/F or IF1 F/F is reset. When the $\mathrm{INT}_{0}$ or $\mathrm{INT}_{1}$ pin changes from " 0 " to " 1 " (from "Low" level to "High" level), a leading pulse is generated to produce an interrupt request. At the same time, the IF0 F/F or IF1 F/F is set. When the IF0 F/F or IF1 F/F is set, the interrupt masking for the pin will result. (If a leading pulse is generated, no interrupt request occurs.)

iNT, Pulse

$\boldsymbol{t}_{\text {INT }} \geqq 2 \cdot$ Tinst
( $T_{\text {inst }}=$ One Instruction Cycle Time)
Figure 19 Timer/Counter Block Diagram

Table 5 Timer Range

| Specified <br> Value | Number of <br> Cycles | "Time (ms) | Specified <br> Value | Number of <br> Cycles | "Time (ms) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1024 | 5.12 | 8 | 512 | 2.56 |
| 1 | 960 | 4.80 | 9 | 448 | 2.24 |
| 2 | 896 | 4.48 | 10 | 384 | 1.92 |
| 3 | 832 | 4.16 | 11 | 320 | 1.60 |
| 4 | 768 | 3.84 | 12 | 256 | 1.28 |
| 5 | 704 | 3.52 | 13 | 192 | 0.96 |
| 6 | 640 | 3.20 | 14 | 128 | 0.64 |
| 7 | 576 | 2.88 | 15 | 64 | 0.32 |

[^3]An interrupt request generated by the leading pulse is latched into the input interrupt request $\mathrm{F} / \mathrm{F}$ (I/RI) on the input side. If the Interrupt Enable F/F (I/E) is " 1 " (Interrupt Enable State), an interrupt occurs immediately and the I/RI F/F and the I/E $\mathrm{F} / \mathrm{F}$ are reset. If the $\mathrm{I} / \mathrm{E} F / \mathrm{F}$ is " 0 " (Interrupt Disable State), the I/RI F/F is held at " 1 " until the HMCS47C gets into the Interrupt Enable State.

The IF0 F/F, the IF1 F/F, the $\mathrm{INT}_{0}$ pin and the $\mathrm{INT}_{1}$ pin can be tested by interrupt instruction. Therefore, the $\mathrm{INT}_{0}$ and the $\mathrm{INT}_{1}$ can be used as additional input pins with latches.

The $\mathrm{INT}_{0}$ pin and $\mathrm{INT}_{1}$ pin can be provided with Pull up MOS using a mask option as shown in Figure 20.

An interrupt request from the timer/counter is latched into the timer interrupt request $\mathrm{F} / \mathrm{F}$ (I/RT). The succeeding operations are same as an interrupt from the input. Only the exception is that, since an interrupt from the input precedes a timer/ counter interrupt, the input interrupt occurs if both the I/RI F/F and the I/RT F/F are " 1 " (when the input interrupt and the timer/counter interrupts are generated simultaneously). During this processing, the I/RT F/F remains " 1 ". The timer/ counter interrupt can be implemented after the input interrupt processing is achieved.

The interrupt circuit block diagram is shown in Figure 21.


Figure 20 Configuration of $I N T_{0}$ and $I N T_{1}$


## - RESET FUNCTION

The reset is performed by setting the RESET pin to " 1 " ("High" level) and the HMCS47C gets into operation by setting it to " 0 " ("Low" level); Refer to Figure 22. Moreover, the HMCS47C has the power-on reset function (ACL; Built-in Reset Circuit). The Built-in Reset Circuit restricts the rise condition of the power supply; Refer to Figure 23. When the Built-in Reset Circuit is used, RESET should be connected to GND.

HMCS47CL doesn't have the power-on reset function.
Internal state of the HMCS47C are specified as follows by the reset function.

- Program Counter (PC) is set to Bank 131 Page 3F Address (63 Page 3F Address).
- Data I/O Register $\mathrm{R}_{70}$ is set to " 1 "(Jumps to Bank 0 by execution of LPU instruction after the reset).
- I/RI, I/RT, I/E and CF are reset to " 0 "
- IF0, IF1, and TF are set to " 1 "
- Data I/O Registers (R0 to R6) and Discrete I/O Latches ( $\mathrm{D}_{0}$ to $\mathrm{D}_{15}$ ) are all set to " 1 "

Note that all the other logic blocks (the Stack Registers, the Status $F / F$, the accumulator, the Carry $F / F$, the registers, the Timer/Counter, RAM) are not cleared by the reset function. The user should initialize these blocks by software. Because the Status F/F after the reset is not defined, set the Status F/F to " 0 " or " 1 " before the first execution of the conditional instruc. tions (LPU, CAL and BR instructions).

## - HALT FUNCTION

When the HLT pin is set to " 0 " ("Low" level), the internal clock stops and all the internal statuses (RAM, the Registers, the Carry F/F, the Status F/F, the Program Counter, and all the internal statuses) are held. Becuase all internal logic operation stop, power consumption is reduced. There are two input/ output statuses in the Halt State. The user should specify either "Enable" or "Disable" using a mask option at the time of ordering ROM.


Since Pull up MOS current flows with output " 0 " ("Low" level) in the Halt State (NMOS; ON). When an input signal changes, transition current flows into an input circuit. Also, current flows into Pull


* $\mathbf{t}_{\text {RST } 1}$ includes the time required from the power ON until the operation gets into the constant state.
** ${ }^{t_{\text {RST2 }}}$ is applied when the operation is in the constant state.
Figure 22 RESET Timing

* tOFF specifies the period when the power supply is OFF in the case that a short break of the power supply occurs and the power supply ON/OFF is repeated.

Figure 23 Power Supply Timing for Built-in Reset Circuit
up MOS. These currents are added to the Stand-by Supply Current (or Halt Current).
"Disable"
 Output

NMOS Output: OFF CMOS Output:

High Impedance (NMOS, PMOS: OFF)

- Pull up MOS ... OFF

Input . . . . . . . . . Input Circuit: OFF Both input and output are at high impedance state. Since an input circuit is OFF, any current other than the Standby Supply Current (or Halt Current) does not flow even if an input signal changes.
When the HLT pin is set to " 1 "("High"level), the HMCS47C gets into operation from the status just before the Halt State.

The halt timing is shown in Figure 24.

## CAUTION

If, during the Halt State, the external reset input is applied (RESET = "l" ("High" level)), the internal status is not held.

## - OSCILLATOR

The HMCS47C contains its own oscillator and frequency divider (CPG). The user can obtain the desired timing for operation of the LSI by merely connecting an resistor $\mathbf{R}_{f}$ or ceramic filter circuit (Internal Clock Operation). Also an external oscillator can supply a clock (External Clock Operation).

The $\mathrm{OSC}_{1}$ clock frequency is internally divided by four to produce the internal system clocks.

The user may exchange the external parts for the same LSI to select either of these two operational modes as shown in Figure 25. There is no need of specifying it by using the mask option.

The typical value of clock oscillation frequency ( $\mathrm{f}_{\text {osc }}$ ) varies with a oscillation resistor $R_{f}$ as shown in Figure 26.


Figure 24 Halt Timing
(a) Internal Clock Operation Using Resistor $\mathbf{R}_{\mathbf{f}}$


Wiring of OSC 1 and OSC $_{2}$ terminals should be as short as possible because the oscillation frequency is modified by capacitance of these terminals.
(b) Internal Clock Operation Using Ceramic Filter Circuit (This is not applied to HMCS47CL.)


Ceramic Filter; CSB800A (MURATA)
$R_{1}$ : $1 M \Omega \pm 10 \%$
$C_{1}: 100 \mathrm{pF} \pm 10 \%$ (Ceramic Capacitor)
$C_{2} ; 100 \mathrm{pF} \pm 10 \%$ (Ceramic Capacitor)

The ceramic filter oscillation does not apply when using " Halt " and not resetting at the time of "Halt" cancellation.
This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefully on your application.

Figure 25 Clock Operation Mode (to be continued)
(c) External Clock Operation


$$
\text { Duty }=\frac{T_{1}}{T_{n}+T_{1}} \times 100 \%
$$

Figure $\mathbf{2 5}$ Clock Operation Mode


Figure 26 Typical Value of Oscillation Frequency vs. $\mathbf{R}_{\boldsymbol{f}}$

## - INSTRUCTION LIST

The instructions of the HMCS47C are listed according to their functions, as shown in Table 6.

Table 6 Instruction List

\begin{tabular}{|c|c|c|c|c|}
\hline Group \& Mnemonic \& \multicolumn{2}{|l|}{Function} \& Status \\
\hline Register - Register Instruction \& \begin{tabular}{l}
LAB \\
LBA \\
LAY \\
LASPX \\
LASPY \\
XAMR m
\end{tabular} \& \[
\begin{aligned}
\& B \rightarrow A \\
\& A \rightarrow B \\
\& Y \rightarrow A \\
\& S P X \rightarrow A \\
\& S P Y \rightarrow A \\
\& A \rightarrow M R(m)
\end{aligned}
\] \& \& \\
\hline RAM Address Register Instruction \& \begin{tabular}{l}
LXA \\
LYA \\
LXI i \\
LY1 i \\
IY \\
DY \\
AYY \\
SYY \\
XSPX \\
XSPY \\
XSPXY
\end{tabular} \&  \& \& \[
\begin{gathered}
\text { NZ } \\
\text { NB } \\
\text { C } \\
\text { NB }
\end{gathered}
\] \\
\hline RAM - Register Instruction \& \begin{tabular}{l}
LAM (XY) \\
LBM (XY) \\
XMA (XY) \\
XMB (XY) \\
LMAIY (X) \\
LMADY (X)
\end{tabular} \&  \& SPX)
SPX) \& \[
\begin{aligned}
\& \text { NZ } \\
\& \text { NB }
\end{aligned}
\] \\
\hline Immediate Transfer Instruction \& \[
\begin{aligned}
\& \text { LMIIY i } \\
\& \text { LAI i } \\
\& \text { LBI i }
\end{aligned}
\] \& \[
\begin{aligned}
\& \mathrm{i} \\
\& \mathrm{~B} \\
\& \mathrm{M}, \mathrm{Y}+1 \rightarrow \mathrm{Y} \\
\& \mathrm{i} \\
\& \rightarrow \mathrm{~B}
\end{aligned}
\] \& \& NZ \\
\hline Arithmetic Instruction \& AI i
IB
DB
AMC
SMC
AM
DAA
DAS
NEGA
COMB
SEC
REC
TC
ROTL
ROTR
OR \& ```
\(\mathrm{A}+\mathrm{i} \rightarrow \mathrm{A}\)
\(\mathrm{B}+1 \rightarrow \mathrm{~B}\)
\(\mathrm{B}-1 \rightarrow \mathrm{~B}\)
\(M+A+C(F / F) \rightarrow A\)
\(M-A-\bar{C}(F / F) \rightarrow A\)
\(\mathrm{M}+\mathrm{A} \rightarrow \mathrm{A}\)
Decimal Adjustment (Addition)
Decimal Adjustment (Subtraction)
\(\stackrel{\bar{A}+1}{B} \rightarrow B\)
\(" 1 " \rightarrow C(F / F)\)
'0" \({ }^{\prime \prime}\) C (F/F)
Test \(C(F / F)\)
Rotation Left
Rotation Right
\(A \cup B \rightarrow A\)
``` \& \& \(C\)
NZ
NB
C
NB
\(C\)

$C(F / F)$ <br>
\hline
\end{tabular}

(to be continued)

| Group | Mnemonic | Function | Status |
| :---: | :---: | :---: | :---: |
| Compare Instruction | MNEI i ANEM BNEM ALEI i ALEM BLEM | $\begin{array}{lll} M & \searrow & i \\ \mathbf{Y} & \searrow & i \\ \mathbf{A} & \searrow & M \\ B & \vdots & M \\ \mathbf{A} & \vdots & i \\ \mathbf{A} & \vdots & M \\ \mathbf{B} & \leqq & M \end{array}$ | $\begin{aligned} & \hline \text { NZ } \\ & \text { NZ } \\ & \text { NZ } \\ & \text { NZ } \\ & \text { NB } \\ & \text { NB } \\ & \hline \end{aligned}$ |
| RAM Bit Manipulation Instruction | SEM $n$ REM $n$ TM n | $\begin{array}{lll} " 1 " & \rightarrow & M(n) \\ " 0 \prime \prime & M(n) \\ \text { Test } & M(n) & M(n) \end{array}$ | M(n) |
| ROM Address Instruction | BR a CAL a LPU u TBR p RTN | Branch on Status 1 <br> Subroutine Jump on Status 1 <br> Load Program Counter Upper on Status 1 <br> Table Branch <br> Return from Subroutine | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
| Interrupt Instruction | SEIE SEIFO SEIF1 SETF SECF REIE REIFO REIF 1 RETF RECF <br> TIO <br> TII <br> TIFO <br> TIF1 <br> TTF <br> LTI i <br> LTA <br> LAT <br> RTNI |  | INT ${ }_{0}$ <br> INT $_{1}$ <br> IFO <br> IF1 <br> TF |
| Input/Output Instruction | SED <br> RED <br> TD <br> SEDD $n$ <br> REDD $n$ <br> LAR $p$ <br> LBR $p$ <br> LRA p <br> LRB $p$ <br> P p | $" 1 " \rightarrow D(Y)$ $" 0 " \rightarrow D(Y)$ Test $D D(Y)$ $" 1 " \rightarrow D(n)$ $" 0 " \rightarrow D(n)$ $R(p) \rightarrow A$ $R(p) \rightarrow B$ $A \rightarrow R(p)$ $B \rightarrow R(p)$ Pattern Generation | $D(Y)$ |
|  | NOP | No Operation |  |

[NOTE] 1. (XY) after a mnemonic code has four meanings as follows.
Mnemonic only Instruction execution only
Mnemonic with $X \quad$ After instruction execution, $X \leftrightarrow S P X$
Mnemonic with $Y \quad$ After instruction execution, $Y \leftrightarrow$ SPY
Mnemonic with $X Y \quad$ After instruction execution, $X \leftrightarrow S P X, Y \leftrightarrow S P Y$
Example] LAM
$M \rightarrow A$
LAMX $\quad M \rightarrow A, X \leftrightarrow S P X$
LAMY $\quad M \rightarrow A, Y \leftrightarrow S P Y$
LAMXY $\quad M \rightarrow A, X \leftrightarrow S P X, Y \leftrightarrow S P Y$
2. Status column shows the factor which brings the Status $F / F$ " 1 " under judgement instruction or instruction accompanying the judgement.

NZ .... ALU Not Zero
C .... ALU Overflow in Addition, that is, Carry
NB . . . . ALU Overflow in Subtraction, that is, No Borrow
Except above . . . . . . . Contents of the status column affects the Status F/F directly.
3. The Carry $F / F(C(F / F))$ is not always affected by executing the instruction which affects the Status $F / F$. Instructions which affect the Carry F/F are eight as follows.

| AMC | SEC |
| :--- | :--- |
| SMC | REC |
| DAA | ROTL |
| DAS | ROTR |

4. All instructions except the pattern instruction $(P)$ are executed in 1-cycle. The pattern instruction $(P)$ is executed in 2-cycle.

| Date |  |
| :--- | :--- |
| Customer's Name |  |
| ROM CODE ID |  |
| Hitachi P/N |  |

## (1) I/O Option

Hitachi P/N

| Pin Name | 1/0 | I/O Option |  |  | Remarks | Pin Name | 1/0 | 1/O Option |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A | B | C |  |  |  | A | B | C |  |
| Do | 1/0 |  |  |  |  | Roo | 1/0 |  |  |  |  |
| $\mathrm{D}_{1}$ | 1/0 |  |  |  |  | Ro1 | 1/0 |  |  |  |  |
| $\mathrm{D}_{2}$ | 1/0 |  |  |  |  | Roz | 1/0 |  |  |  |  |
| D3 | 1/0 |  |  |  |  | $\mathrm{R}_{03}$ | 1/0 |  |  |  |  |
| D4 | 1/0 |  |  |  |  | R10 | 1/0 |  |  |  |  |
| D5 | 1/0 |  |  |  |  | $\mathrm{R}_{11}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{6}$ | 1/0 |  |  |  |  | $\mathrm{R}_{12}$ | 1/0 |  |  |  |  |
| D7 | 1/0 |  |  |  |  | $\mathrm{R}_{13}$ | 1/0 |  |  |  |  |
| Ds | 1/0 |  |  |  |  | $\mathrm{R}_{20}$ | I/O |  |  |  |  |
| D9 | 1/0 |  |  |  |  | $\mathrm{R}_{21}$ | I/O |  |  |  |  |
| D10 | 1/0 |  |  |  |  | $\mathrm{R}_{22}$ | 1/0 |  |  |  |  |
| D11 | 1/0 |  |  |  |  | $\mathrm{R}_{23}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{12}$ | 1/0 |  |  |  |  | R30 | 1/0 |  |  |  |  |
| D13 | 1/0 |  |  |  |  | R31 | 1/0 |  |  |  |  |
| $D_{14}$ | 1/0 |  |  |  |  | R32 | 1/0 |  |  |  |  |
| D15 | 1/0 |  |  |  |  | R33 | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R40 | 1/O |  |  |  |  |
|  |  |  |  |  |  | R41 | I/O |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{42}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{R}_{43}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | Rs0 | 1/0 |  |  |  |  |
|  |  |  |  |  |  | Rs1 | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R ${ }_{5}$ | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R53 | 1/0 |  |  |  |  |
|  |  |  |  |  |  | R60 | 0 |  | $\bigcirc$ |  |  |
|  |  |  |  |  |  | R61 | 0 |  | - |  |  |
| INT 0 | 1 |  |  | - |  | R62 | 0 |  | - |  |  |
| INT ${ }_{1}$ | 1 |  |  | - |  | R63 | 0 |  | $\square$ |  |  |

"Specify the $I / O$ composition with a mark of " $O$ " in the applicable composition column.
A: No pull up MOS B: With pull up MOS C: CMOS Output
(2) Oscillator \& Halt

| Oscillator | Halt | Not used | Used (Reset is applied when Halt release) |
| :--- | :--- | :--- | :--- | Used (Reset is not applied when Halt release) | Resistor |  |  |
| :--- | :--- | :--- |
| Ceramic Resonator |  |  |
| External Clock |  |  |

* Please check one section on the above chart.
(3) I/O State at "Halt' mode

| I/O State |
| :---: |
| $\square \quad$ Enable |
| $\square$ Disable |

* Mark " $\sqrt{ }$ " in " $口$ " for the selected I/O state.
(4) Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ )

| Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |
| :---: |
| $\square \quad 5 \pm 0.5 \mathrm{~V}$ |
| $\square 2.5 \mathrm{~V}$ to 5.5 V |
| Mark " V " in" " " or the selected supoly voltage. |

(5) Package

| Package |  |
| :---: | :--- |
| $\square$ | FP.54 |
| $\square$ | DP-64S |

" Mark " $\sqrt{ }$ " in " $口$ " for the selected package.
(6) Evchip used for Program Evaluation

| Evchip |  |  |
| :---: | :--- | :---: |
| $\square$ | HD44855E |  |
| $\square$ | HD44857E |  |

*Mark " $\sqrt{ }$ " in " $\square$ " for the evchip used for program evaluation.

## LCD—III(HD44790,HD44795)

The LCD-III is the CMOS 4-bit single chip microcomputer which contains ROM, RAM, I/O, Timer/Event Counter and Control Circuit, Direct Drive Circuit for LCD on single chip. The LCD-III is designed to drive LCD directly and perform efficient controller function as well as arithmetic function for both binary and BCD data. With the on-chip crystal oscillator for timer, the clock function is easily realized. The CMOS technology of the LCD-III provides the flexibility of microcomputers for battery powered and battery back-up applications in combination with low power consuming LCD.

- FEATURES
- 4-bit Architecture
- 2,048 Words of Program ROM (10 bits/Word) 128 Words of Pattern ROM (10 bits/Word)
- 160 Digits of Data RAM and Display Data RAM $(4$ bits/ Digit)
- Control Circuit and Direct Drive Circuit for LCD 4 Commons (Duty Radio; Static, 1/2, 1/3, 1/4)
32 Segments (Externally expandable up to 96 Segments using external Drivers HD44100s)
- 32 I/O Lines and 2 External Interrupt Lines
- Timer/Event Counter
- All Instructions except One Instruction; Single Word and Single Cycle
- BCD Arithmetic Instructions
- Pattern Generation Instruction - Table Look Up Capability -
- Powerful Interrupt Function 3 Interrupt Sources
- 2 External Interrupt Lines
- Timer/Event Counter

Multiple Interrupt Capability

- Bit Manipulation Instructions for Both RAM and I/O
- Qption of I/O Configuration Selectable on Each Pin; Pull Up MOS or CMOS or Open Drain
- Built-in Oscillator for System Clock (Resistor or Ceramic Filter)
- Built-in Crystal Oscillator for Timer
- Built-in Power-on Reset Circuit
- Low Operating Power Dissipation; 2mW typ.
- Stand-by Mode (Halt Mode); $50 \mu \mathrm{~W}$ max.
- 2 Versions; HD44790 VCC $=5 \mathrm{~V} \pm 10 \%, 10 \mu \mathrm{~s}$ Instruction Cycle Time
HD44795 VCC $=2.7 \mathrm{~V}$ to $5.5 \mathrm{~V}, 20 \mu \mathrm{~s}$ Instruction Cycle Time


## LCD.III







## - BLOCK DIAGRAM



- HD44790 ELECTRICAL CHARACTERISTICS (VCC $=5 \mathrm{~V} \pm 10 \%$ )
- AbSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $V_{T 1}$ | -0.3 to $\mathrm{V}_{\mathbf{c c}}+0.3$ | V | Applied to all terminals except those specified in $\mathrm{V}_{\mathrm{T} 2}$. |
| Terminal Voltage (2) | $V_{\text {T2 }}$ | 0.3 to +10.0 | V | Applied to open-drain output pins and open-drain I/O common pins. |
| Maximum Total Output Current (1) | $-\Sigma \mathrm{I}_{01}$ | 45 | mA | (Note 3) |
| Maximum Total Output Current (2) | $\Sigma \mathrm{l}_{02}$ | 45 | mA | (Note 3) |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(NOTE) 1. Stresses above those listed under "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. Normal operation should be limited to those conditions specified under "ELECTRICAL CHARACTERISTICS -1" and "-2". The use beyond these conditions may cause LSI's malfunction and at the same time affects device reliability.
2. All voltages are with respect to GND.
3. Maximum Total Output Current is the total sum of output currents which can flow out or in simultaneously.
4. Power supply condition $\mathbf{V}_{\mathbf{C}} \geqq \mathrm{V} 1 \geqq \mathrm{~V} 2 \geqq \mathrm{~V} 3 \geqq G N D$ should be maintained.

ELECTRICAL CHARACTERISTICS - 1 ( $\mathbf{V C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}_{\mathrm{a}}=-\mathbf{- 2 0}$ to $\left.+\mathbf{7 5} 5^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{\text {IL }}$ |  |  | - | - | 1.0 | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\mathrm{iH} 1}$ |  |  | $\mathrm{V}_{\text {cc }}-1.0$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V | (9) |
| Input "High" Voltage (2) | $\mathrm{V}_{\mathbf{H} \mathbf{2}}$ |  |  | $\mathrm{V}_{\text {cc }}-1.0$ | - | 10 | V | (10) |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |  | - | - | 0.8 | V |  |
| Output "High" Voltage (1) | $\mathrm{V}_{\mathrm{OH} 1}$ | $-^{-1}{ }^{\text {H }}=1.0 \mathrm{~mA}$ |  | 2.4 | - | - | V | (1) |
| Output "High" Voltage (2) | $\mathrm{V}_{\mathrm{OH} 2}$ | $-\mathrm{I}_{\mathrm{OH}}=0.01 \mathrm{~mA}$ |  | $\mathrm{V}_{\text {cc }}-0.3$ | - | - | V | (2) |
| Driver Voltage Descending (COM) | $\mathrm{V}_{\mathrm{d}_{1}}$ | $1 \mathrm{~d}=0.05 \mathrm{~mA}$ |  | - | - | 0.4 | V | (13) |
| Driver Voltage Descending (SEG) | $\mathrm{V}_{\mathrm{d}_{2}}$ | $1 \mathrm{ld}=0.01 \mathrm{~mA}$ |  | - | - | 0.4 | V | (13) |
| Dividing Resistor of LCD Power Supply | Rwell | - |  | 25 | - | 300 | k $\Omega$ |  |
| Interrupt Input Hold Time | $\mathrm{t}_{\text {INT }}$ |  |  | $2 \cdot \mathrm{~T}_{\text {inst }}$ | - | - | $\mu \mathrm{s}$ | (15) |
| Interrupt Input Fall Time | $\mathrm{t}_{\text {fint }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ | (15) |
| Interrupt Input Rise Time | trint |  |  | - | - | 50 | $\mu \mathrm{s}$ | (15) |
| Output "High" Current | IOH | $\mathrm{V}_{\mathrm{OH}}=10 \mathrm{~V}$ |  | - | - | 3 | $\mu \mathrm{A}$ | (3) |
| Input Leakage Current | IIL | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ |  | - | - | 1.0 | $\mu \mathrm{A}$ | (3), (9) <br> (3), (10) |
|  |  | $\mathrm{V}_{\mathrm{in}}=0$ to 10 V |  | - | - | 3 |  |  |
| Pull up MOS Current | $-l_{p}$ | $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$ |  | 45 | - | 250 | $\mu \mathrm{A}$ |  |
| Supply Current (1) | 'ccı | $V_{i n}=V_{c c} V_{c c}=5 V$ <br> Ceramic Filter Oscillation $\left(f_{o x}=400 \mathrm{kHz}\right)$ |  | - | - | 1.3 | mA | (5) |
| Supply Current (2) | $I_{\text {cc2 }}$ | $\begin{aligned} & V_{\text {in }}=V_{c c}, V \\ & R_{f} \text { Oscillation } \\ & \text { (fosc }=400 \mathrm{k} \\ & \text { External Clo } \\ & \text { (fip }=400 \mathrm{kH} \end{aligned}$ | $c=5 \mathrm{~V}$ <br> 2) <br> Operation | - | - | 0.6 | mA | (5), (12) |
| Standby I/O Leakage Current | ILs | HLT $=1.0 \mathrm{~V}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ | - | - | 1.0 | $\mu \mathrm{A}$ | (6), (9) |
|  |  |  | $\mathrm{V}_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | (6), (10) |
| Standby Supply Current (1) | $l^{\text {ccs }} 1$ | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {cc }}, \overline{H L T}=0.2 \mathrm{~V}$ |  | - | - | 10 | $\mu \mathrm{A}$ | (11) |
| Standby Supply Current (2) | $I_{\text {ccs2 }}$ | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {cc }}, \overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ |  | - | - | 40 | $\mu \mathrm{A}$ | (7) |
| Frame Frequency of LCD Drive | $\mathrm{f}_{\mathrm{F}}$ | $\begin{aligned} & n=1 \text { (static) } \\ & n=2(1 / 2 \text { Duty) } \\ & n=3(1 / 3 \text { Duty }) \\ & n=4(1 / 4 \text { Duty) } \end{aligned}$ |  | $\frac{1}{256 \times n \times T_{\text {inst }}}$ |  |  | Hz |  |
| LCD Display Voltage | $\mathrm{V}_{\text {LCO }}$ | $\mathrm{V}_{\mathrm{cc}}-\mathrm{V}_{3}$ |  | 2.5 | - | $\mathrm{V}_{\mathrm{cc}}$ | V | (8) |
| External Clock Operation; System Clock |  |  |  |  |  |  |  |  |
| External Clock Frequency | $\mathrm{f}_{\text {cp }}$ |  |  | 40 | 400 | $440^{-1}$ | k $\overline{\mathrm{H}} \mathbf{z}$ |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | $\mathrm{t}_{\text {rcp }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | $\mathrm{t}_{\text {fop }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 /$ fep |  | 9.1 | 10 | 100 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation ( $\mathbf{R}_{\mathbf{f}}$ Oscillation); System Clock |  |  |  |  |  |  |  |  |
| C̄lock O-Osillation Frequency | ${ }_{\text {foxc }}$ | $\mathrm{R}_{\mathrm{f}}=82 \mathrm{k} \overline{\mathrm{I}} \mathrm{I} \mathbf{2}$ |  | 300 | - | $500{ }^{-1}$ | kïz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {oxc }}$ |  | 8.0 | - | 13.3 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation (Ceramic Filter Oscillation); System Clock |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {oxc }}$ | Ceramic Filter |  | 392 | - | 408 | kHz |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {oxic }}$ |  | 9.8 | - | 10.2 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation (Crystal Oscillation); Clock for Timer |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {OXCx }}$ | Crystal |  | 32.768 |  |  | kHz |  |

- ELECTRICAL CHARACTERISTICS - 2 ( $\mathrm{T}_{\mathrm{a}}=\mathbf{- 2 0}$ to $\left.+\mathbf{7 5}{ }^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions | Value |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |  |
| Halt Duration Voltage | $\mathrm{V}_{\mathrm{DH}}$ | HLT $=0.2 \mathrm{~V}$ | 2.3 | - | V |  |
| Halt Current | $\mathrm{I}_{\mathrm{DH}}$ | $\begin{aligned} & V_{\text {in }}=V_{C c}, \overline{H L T}=0.2 \mathrm{~V}, \\ & V_{D H}=2.3 V \end{aligned}$ | - | 4.0 | $\mu \mathrm{A}$ | (14) |
| Halt Delay Time | $\mathrm{t}_{\mathrm{HD}}$ |  | 100 | - | $\mu \mathrm{s}$ |  |
| Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}$ |  | 100 | - | $\mu \mathrm{s}$ |  |
| HLT Fall Time | $\mathrm{t}_{\text {f }} \mathrm{t}_{\text {LT }}$ |  | - | 1000 | $\mu \mathrm{s}$ |  |
| HLT Rise Time | $\mathrm{t}_{\text {r }}$ HLT |  | - | 1000 | $\mu \mathrm{s}$ |  |
| HLT "Low" Hold Time | $\mathrm{t}_{\mathrm{HLT}}$ |  | 400 | - | $\mu \mathrm{s}$ |  |
| $\overline{H L T}$ "High" Hold Time | $t_{\text {OPR }}$ | $R_{f}$ Oscillation, External Clock Operation | 100 | - | $\mu \mathrm{s}$ |  |
|  |  | Ceramic Filter Oscillation | 4000 | - |  |  |
| Power Supply Rise Time | $t_{\text {rcc }}$ | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathbf{c c}}$ | 0.1 | 10 | ms |  |
| Power Supply OFF Time | toff | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\text {cc }}$ | 1 | - | ms |  |
| RESET Pulse Width (1) | $\mathrm{t}_{\text {RST1 }}$ | $\begin{aligned} & \text { External Reset, } \mathrm{V}_{\mathrm{cc}}=4.5 \\ & \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}} \\ & \text { (Rfo Oscillation, External } \\ & \text { Clock Operation) } \end{aligned}$ | 1 | - | ms |  |
|  |  | External Reset, $\mathbf{V}_{\mathbf{c c}}=4.5$ to $5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$ (Ceramic Filter Oscillation) | 4 | - |  |  |
| RESET Pulse Width (2) | $\mathrm{t}_{\text {RST2 }}$ | $\begin{aligned} & \text { External Reset, } \mathrm{V}_{\mathrm{cc}}=4.5 \\ & \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V} \mathrm{cc}, \\ & \text { (Prescaler Clock }=\text { System } \\ & \text { Clock) } \end{aligned}$ | $\mathbf{2} \cdot \mathrm{T}_{\text {inst }}$ | - | $\mu \mathrm{s}$ |  |
|  |  | $\begin{aligned} & \text { External Reset, } \mathrm{V}_{\mathrm{cc}}=4.5 \\ & \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}}, \\ & \text { (Prescaler Clock }=\mathrm{Crystal} \\ & \text { Clock) } \end{aligned}$ | $\begin{gathered} 32 \times 10^{6} / \\ f_{\text {osex }} \end{gathered}$ | - |  |  |
| RESET Rise Time | $\mathrm{t}_{\text {r }}$ SST | External Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}$, $V_{c c}=4.5 \text { to } 5.5 \mathrm{~V}$ | - | 100 | $\mu s$ |  |
| RESET Fall Time | $\mathrm{t}_{\text {fRST }}$ | $\begin{aligned} & \text { External Reset, } \overline{\text { HLT }}=\mathrm{V}_{\mathrm{cc}}, \\ & \mathrm{~V}_{\mathrm{cc}}=4.5 \text { to } 5.5 \mathrm{~V} \end{aligned}$ | - | 100 | $\mu \mathrm{s}$ |  |

(NOTE) 1. Applied to PMOS load of CMOS output pins and CMOS I/O common pins among D and R terminals.
2. Applied to CMOS output pins, CMOS I/O common pins, input pins with pull up MOS, and I/O common pins with pull up MOS among D and R terminals.
3. Applied to open-drain output pins and open-drain I/O common pins among $D$ and $R$ terminals.
4. Pull up MOS current is excluded.
5. Applied to the supply current when the LCD-III is in the reset state and the crystal oscillation for timer doesn't operate. (Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded).

Test Condition: RESET, HLT, TEST $=\mathrm{V} C \mathrm{C}$ (Reset State)

$$
\begin{aligned}
& \begin{array}{l}
\text { INTo, } \text { INT }_{1}, R_{00} \text { to } R_{33}, D_{0} \text { to } D_{13}=V_{C C} \\
D_{14} / X O, D_{13} / X I-D_{14} / X O, D_{13} / X I=V_{C C} \text { (Crystal oscillation for timer is not selected). }
\end{array} \\
& \begin{array}{l}
D_{14} / X O, D_{1 s} / X I-\quad D_{14} / X O, D_{15} / X I=V_{C C} \text { (Crystal oscillation for timer is not selected). } \\
V_{1}, V_{2}, V_{3}=V_{C C} \\
D_{14} / X O=O p e n, D_{15} / X I=V_{C C} \text { (Crystal oscillation for timer is selected). }
\end{array} \\
& \mathrm{COM}_{1} \text { to } \mathrm{COM}_{4}, \mathrm{SEG}_{1} \text { to } \mathrm{SEG}_{32}=\text { Open }
\end{aligned}
$$

When the crystal oscillation for timer operates, the standby supply current (2) Iccs2 flows in addition to Icc1 or Icc2.
When the LCD-III is installed in the user's system, and in operation current increases according to the external circuitry and devices. Those are connected to the LCD-III. User should design the power supply in consideration of this point (The difference between the measured current in the above reset state and that measured in the operational state in the user's system is the increased part of the supply current).
6. Standby I/O leakage current is the leakage current of I/O pins in the "Halt" and "Disable" state.
7. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current (2) is the supply current at $V_{C C}=5 \mathrm{~V} \pm 10 \%$ in "Halt" state in the case that the crystal oscillation for timer is selected (only the crystal oscillator for timer, 5 -bit divider and $\mathbf{6}$-bit prescaler are in operation).

8. Power supply condition $\mathrm{V}_{\mathrm{CC}} \geqq \mathrm{V}_{1} \geqq \mathrm{~V}_{2} \geqq \mathrm{~V}_{3} \geqq \mathrm{GND}$ should be maintained.
9. Applied to the following terminals.
(1) Input pins, I/O common pins with pull up MOS, and CMOS I/O common pins among $D$ and $R$ terminals.
(2) RESET, HLT, OSC 1 , INT 0 and INT 1
10. Applied to open-drain $1 / O$ common pins among $D$ and $R$ terminals.
11. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current is the supply current at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ in "Halt" state in the cose that the crystal oscillation for timer is sefected. The supply current when supply voltage falls to the Halt Duration Voltage is called "Halt Current" (IDH).
12. The supply current changes as follows according to operating frequency.

13. The voltage that drops between the power supply terminals ( $\mathrm{V}_{\mathrm{cc}}, \mathrm{V}_{1}, \mathrm{~V}_{2}, \mathrm{~V}_{3}$ ) and each common or segment output terminal.
14. The supply current at $V_{c C}=V_{P H}=2.3 \mathrm{~V}$ in "Halt" state, in the case that the crystal oscillation for timer is not selected. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded.
15. Interrupt inputs must be retained for two or more instruction cycle times at both "High" and "Low"' levels.


HD44795 ELECTRICAL CHARACTERISTICS (VCc $=2.7$ to 5.5 V )
ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $V_{T 1}$ | -0.3 to $\mathrm{V}_{\text {cc }}+0.3$ | V | Applied to all terminals except those specified in $\mathrm{V}_{\mathrm{T} 2}$. |
| Terminal Voltage (2) | $V_{\text {T2 }}$ | 0.3 to +10.0 | V | Applied to open-drain output pins and open-drain I/O common pins. |
| Maximum Total Output Current (1) | $-\Sigma I_{01}$ | 45 | mA | (Note 3) |
| Maximum Total Output Current (2) | $\Sigma \mathrm{I}_{02}$ | 45 | mA | (Note 3) |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(NOTE) 1. Stresses above those listed under "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. Normal operation should be limited to those conditions specified under "ELECTRICAL CHARACTERISTICS -1 " and " -2 ". The use beyond these conditions may cause LSI's malfunction and at the same time affects device reliability.
2. All voltages are with respect to GND.
3. Maximum Total Output Current is the total sum of output currents which can flow out or in simultaneously.
4. Power supply condition $\mathrm{V}_{\mathrm{C}} \geqq \mathrm{V} 1 \geqq \mathrm{~V} 2 \geqq \mathrm{~V} 3 \geqq \mathrm{GND}$ should be maintained.

- ELECTRICAL CHARACTERISTICS - 1 (VCC $=2.7$ to 5.5V, $\mathrm{T}_{\mathrm{a}}=-20$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min. | typ. | max. |  |  |
| Input "Low" Voltage | $V_{\text {IL }}$ |  |  | - | - | 0.4 | V |  |
| Input "High" Voltage (1) | $\mathrm{V}_{\text {IH1 }}$ |  |  | $V_{\text {cc }}-0.4$ | - | V cc | V | (9) |
| Input "High" Voltage (2) | $\mathrm{V}_{\mathbf{1 H 2}}$ |  |  | $\mathrm{V}_{\mathbf{c c}}-0.4$ | - | 10 | V | (10) |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=0.4 \mathrm{~mA}$ |  | - | - | 0.4 | V |  |
| Output "High" Voltage (1) | $\mathrm{V}_{\mathrm{OH} 1}$ | $-\mathrm{I}^{\mathrm{OH}}=0.08 \mathrm{~m}$ |  | $\mathrm{V}_{\mathbf{c c}}-0.4$ | - | - | V | (1) |
| Output "High" Voltage (2) | $\mathrm{V}_{\mathrm{OH} 2}$ | $-1^{-1}{ }^{\text {OH }}=0.01 \mathrm{~m}$ |  | $\mathrm{V}_{\mathrm{cc}}-0.3$ | - | - | V | (2) |
| Driver Voltage Descending (COM) | $V_{d_{1}}$ | Id $=0.05 \mathrm{~mA}$ |  | - | - | 0.4 | V | (13) |
| Driver Voltage Descending (SEG) | $\mathrm{V}_{\mathrm{d}_{2}}$ | $1 \mathrm{~d}=0.01 \mathrm{~mA}$ |  | - | - | 0.4 | V | (13) |
| Dividing Resistor of LCD Power Supply | Rwell |  |  | 25 | - | 300 | $k \Omega$ |  |
| Interrupt Input Hold Time | $\mathrm{t}_{\text {INT }}$ |  |  | $\mathbf{2 \cdot} \mathrm{T}_{\text {inst }}$ | - | - | $\mu \mathrm{s}$ | (15) |
| Interrupt Input Fall Time | $\mathrm{t}_{\text {fint }}$ |  |  | - | - | 50 | $\mu \mathrm{s}$ | (15) |
| Interrupt Input Rise Time | trint |  |  | - | - | 50 | $\mu \mathrm{s}$ | (15) |
| Output " High" Current | IOH | $\mathrm{V}_{\text {OH }}=10 \mathrm{~V}$ |  | - | - | 3 | $\mu \mathrm{A}$ | (3) |
| Input Leakage Current | $I_{1 L}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\mathrm{c}}$ |  | - | - | 1.0 | $\mu \mathrm{A}$ | (3), (9) |
|  |  | $\mathrm{V}_{\text {in }}=0$ to 10 |  | - | - | 3 |  | (3), (10) |
| Pull up MOS Current | -Ip | $\mathrm{V}_{\text {cc }}=3 \mathrm{~V}$ |  | 15 | - | 80 | $\mu \mathrm{A}$ |  |
| Supply Current | $I_{\text {cc }}$ |  | $\mathrm{cc}=3 \mathrm{~V}$ <br> Hz) <br> Operation <br> z) | - | - | 0.15 | mA | (5), (12) |
| Standby I/O Leakage Current | ILs | $\begin{aligned} & \overline{\mathrm{HLT}} \\ & =1.0 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\text {cc }}$ | - | - | 1.0 | $\mu \mathrm{A}$ | (6), (9) |
|  |  |  | $V_{\text {in }}=0$ to 10 V | - | - | 3 | $\mu \mathrm{A}$ | (6), (10) |
| Standby Supply Current (1) | Iccs1 | $\begin{aligned} & V_{i n}=V_{c c}, \overline{H L T}=0.1 \mathrm{~V} \\ & V_{c c}=2.7 \text { to } 3.3 \mathrm{~V} \end{aligned}$ |  | - | - | 6 | $\mu \mathrm{A}$ | (11) |
| Standby Supply Current (2) | I ccse | $\begin{aligned} & V_{i n}=V_{c c}, \overline{H L T}=0.1 \mathrm{~V} \\ & V_{c c}=2.7 \text { to } 3.3 \mathrm{~V} \end{aligned}$ |  | - | - | 21 | $\mu \mathrm{A}$ | (7) |
| Frame Frequency of LCD Drive | $\mathrm{f}_{\mathrm{F}}$ | $\begin{aligned} & n=1 \text { (static) } \\ & n=2(1 / 2 \text { Duty) } \\ & n=3(1 / 3 \text { Duty) } \\ & n=4(1 / 4 \text { Duty }) \end{aligned}$ |  | $\frac{1}{128 \times n \times T_{\text {inst }}}$ |  |  | Hz |  |
| LCD Display Voltage | V LCD | $\mathrm{Vcc}^{-} \mathrm{V}_{3}$ |  | 2.5 | - | $\mathrm{V}_{\mathrm{cc}}$ | V | (8) |
| External Clock Operation; System Clock |  |  |  |  |  |  |  |  |
| External Clock Frequency | ${ }_{\text {f }}$ |  |  | 40 | 200 | 220 | kHz |  |
| External Clock Duty | Duty |  |  | 45 | 50 | 55 | \% |  |
| External Clock Rise Time | $\mathrm{t}_{\text {rcp }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| External Clock Fall Time | $\mathrm{t}_{\text {fop }}$ |  |  | 0 | - | 0.2 | $\mu \mathrm{s}$ |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\mathrm{T}_{\text {inst }}=4 / \mathrm{f}_{\text {cp }}$ |  | 16.6 | 20 | 100 | $\mu \mathrm{s}$ |  |
| Internal Clock Operation ( $\mathbf{R}_{\mathrm{f}}$ Oscillation); System Clock |  |  |  |  |  |  |  |  |
| Clock Oscillation Frequency | $\mathrm{f}_{\text {osc }}$ | $\begin{aligned} & R_{f}= \\ & 200 \mathrm{k} \Omega \pm 2 \% \end{aligned}$ | $\mathrm{V}_{\mathrm{cc}}=2.7$ to 3.3 V | 150 | $\square$ | 250 | kHz |  |
|  |  |  | $\mathrm{V}_{\mathrm{CC}}=2.7$ to 5.5 V | 150 | - | 350 |  |  |
| Instruction Cycle Time | $\mathrm{T}_{\text {inst }}$ | $\begin{aligned} & T_{\text {inst }}= \\ & 4 / f_{\text {osc }} \end{aligned}$ | $\mathrm{V}_{\mathrm{cc}}=2.7$ to 3.3 V | 16 | - | 26.6 | $\mu \mathrm{s}$ |  |
|  |  |  | $\mathrm{V}_{\mathrm{Cc}}=2.7$ to 5.5 V | 11.4 | - | 26.6 |  |  |


| Internal Clock Operation (Crystal Oscillation); Clock for Timer |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Clock Oscillation Frequency | fosex | Crystal | 32.768 | kHz |

- ELECTRICAL CHARACTERISTICS - 2 ( $\mathbf{T a}_{\mathbf{a}}=\mathbf{- 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions | Value |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |  |
| Halt Duration Voltage | $\mathrm{V}_{\mathrm{DH}}$ | $\overline{H L T}=0.1 \mathrm{~V}$ | 2.3 | - | V |  |
| Halt Current | $\mathrm{I}_{\mathrm{DH}}$ | $\begin{aligned} & V_{i n}=V_{c c}, \overline{H L T}=0.1 \mathrm{~V}, \\ & V_{D H}=2.3 V \end{aligned}$ | - | 4.0 | $\mu \mathrm{A}$ | (14) |
| Halt Delay Time | $\mathrm{t}_{\mathrm{HD}}$ |  | 100 | - | $\mu \mathrm{s}$ |  |
| Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}$ |  | 100 | - | $\mu \mathrm{s}$ |  |
| HLT Fall Time | $\mathrm{t}_{\text {fHLT }}$ |  | - | 1000 | $\mu \mathrm{s}$ |  |
| HLT Rise Time | $\mathrm{t}_{\text {rHLT }}$ |  | - | 1000 | $\mu \mathrm{s}$ |  |
| HLT "Low" Hold Time | $\mathrm{t}_{\mathrm{HLT}}$ |  | 400 | - | $\mu \mathrm{s}$ |  |
| HLT "High" Hold Time | topr | $\mathrm{R}_{\mathrm{f}}$ Oscillation, External Clock Operation | 100 | - | $\mu \mathrm{s}$ |  |
| Power Supply Rise Time | $t_{\text {rcc }}$ | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathbf{C c}}$ | 0.1 | 10 | ms |  |
| Power Supply OFF Time | toff | Built-in Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\text {cc }}$ | 1 | - | ms |  |
| RESET Pulse Width (1) | $\mathbf{t}_{\text {RSTI }}$ | External Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathbf{c c}}$ | 1 | - | ms |  |
| RESET Pulse Width (2) | $\mathrm{t}_{\text {RST2 }}$ | $\begin{aligned} & \text { External Reset, } \mathrm{V}_{\mathrm{cc}}=2.7 \\ & \text { to } 5.5 \mathrm{~V}, \overline{\mathrm{HLT}}=\mathrm{V}_{\mathrm{cc}}, \\ & \text { (Prescaler Clock }=\text { System } \\ & \text { Clock) } \end{aligned}$ | $2 \cdot T_{\text {inst }}$ | - | $\mu \mathrm{s}$ |  |
|  |  | $\begin{aligned} & \text { External Reset, } V_{c c}=2.7 \\ & \text { to } 5.5 \mathrm{~V}, \mathrm{HLT}=\mathrm{V}_{\mathrm{cc}} \\ & \text { (Prescaler Clock }=\text { Crystal } \\ & \text { Clock) } \end{aligned}$ | $\underset{f_{\text {oscx }}}{32 \times 10^{6} /}$ | - |  |  |
| RESET Rise Time | $\mathrm{t}_{\text {rest }}$ | $\begin{aligned} & \text { External Reset, } \overline{H L T}=V_{c c} \\ & V_{c c}=2.7 \text { to } 5.5 \mathrm{~V} \end{aligned}$ | - | 100 | $\mu \mathrm{s}$ |  |
| RESET Fall Time | $\mathrm{t}_{\text {frst }}$ | External Reset, $\overline{\mathrm{HLT}}=\mathrm{V}_{\mathbf{c c}}$, $V_{C C}=2.7$ to 5.5 V | - | 100 | $\mu \mathrm{s}$ |  |

(NOTE) 1. Applied to PMOS load of CMOS output pins and CMOS I/O common pins among $D$ and $R$ terminals.
2. Applied to CMOS output pins, CMOS I/O common pins, input pins with pull up MOS, and I/O common pins with pull up MOS among $D$ and $R$ terminals.
3. Applied to open-drain output pins and open-drain I/O common pins among $D$ and $R$ terminals.
4. Pull up MOS current is excluded.
5. Applied to the supply current when the LCD-III is in the reset state and the crystal oscillation for timer doesn't operate (Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded).

Test Condition: RESET, HLT, FEST $=\mathrm{V}_{\mathrm{CC}}$ (Reset State)

$$
\begin{aligned}
& \begin{array}{l}
\text { RESET, HLT, } \\
\text { INTO }{ }^{\prime} \text { INT }, R_{00} \text { to } R_{33}, D_{0} \text { to } D_{13}=V_{C C}
\end{array} \\
& D_{14} / X O, D_{15} / X 1 D_{14} / X O, D_{15} / X I=V_{C C} \text { (Crystal oscillation for timer is not selected) } \\
& V_{14} V_{2} V_{3}=V_{C} D_{14} / X O=O_{\text {pen, }} D_{1 s} I X 1=V_{C C} \text { (Crystal oscilation for timer is selected). } \\
& \begin{array}{l}
V_{1}, V_{2}, V_{3}=V_{C C} \\
\text { COM }_{1} \text { to COM }
\end{array}
\end{aligned}
$$

When the crystal oscillation for timer operates, the standby supply current (2) I CCS2 flows in addition to ICC.
When the LCD-III is instalied in the user's system, and in operation current increases according to the external circuitry and devices. Those are connected to the LCD-III. User should design the power supply in consideration of this point (The difference between the measured current in the above reset state and that measured in the operational state in the user's system is the increased part of the supply current).
6. Standby I/O leakage current is the leakage current of I/O pins in the "Halt" and "Disable"' state.
7. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current (2) is the supply current at $\mathrm{V} \mathrm{CC}=3 \mathrm{~V} \pm 10 \%$ in "Halt" state in the case that the crystal oscillation for timer is selected (only the crystal oscillator for timer, 5 -bit divider and 6 -bit prescaler are in operation).

8. Power supply condition $V_{c c} \geqq V_{1} \geqq V_{2} \geqq V_{3} \geq$ GND should be maintained.
9. Applied to the following terminals.
(1) Input pins, I/O common pins with pull up MOS, and CMOS I/O common pins among D and R terminals.
(2) RESET, HLT, OSC 1 , INT, and INT $T_{1}$
10. Applied to open-drain I/O common pins among $D$ and $R$ terminals.
11. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current is the supply current at $V_{C C}=3 \mathrm{~V} \pm 10 \%$ in "Halt" state in the case that the crystal oscillation for timer is selected. The supply current when supply voltage falls to the Halt Duration Voltage is called "Halt Current" (IDH).
12. The supply current changes as follows according to operating frequency.

13. The voltage that drops between the power supply terminals ( $\mathrm{V}_{\mathrm{cc}}, \mathrm{V}_{1}, \mathrm{~V}_{2}, \mathrm{~V}_{3}$ ) and each common or segment output terminal.
14. The supply current at $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DH}}=2.3 \mathrm{~V}$ in "Halt" state, in the case that the crystal oscillation for timer is not selected.

Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded.
15. Interrupt inputs must be retained for two or more instruction cycle time at both "High" and "Low" levels.


## - SIGNAL DESCRIPTION

The input and output signals for the LCD-III shown in PIN ARRANGEMENT are described in the following paragraphs.

## - VCC and GND

Power is supplied to the LCD-III using these two pins. VCC is power and GND is the ground connection.

- RESET

This pin allows resetting of the LCD-III at times other than the automatic resetting capability (ACL; Built-in Reset Circuit) already in the LCD-III. The LCD-III can be reset by pulling RESET High.

Refer to RESET FUNCTION for additional information.

- OSC $_{1}$ and OSC $_{2}$

These pins provide control input for the on-chip clock oscillator circuit. A resistor, a ceramic filter circuit, or an external oscillator can be connected to these pins to provide a system clock with various degrees of stability/cost tradeoffs. Lead length and stray capacitance on these two pins should be minimized.

Refer to OSCILLATOR for recommendations about these pins.

- HLT

This pin is used to place the LCD-III in the HALT state (Stand-by Mode). The LCD-III can be moved into the halt state by pulling HLT Low.

In the halt state the internal clock stops and all the internal status (RAM, Registers, Carry, Status, Program Counter, and all the internal statuses) are maintained. Consequently power consumption is greatly reduced. By pulling FLT high, the LCD-III starts operation from the status just before the halt state.

Refer to HALT FUNCTION for details of halt mode.

- TEST

This pin is not for user application and must be connected to $\mathrm{V}_{\mathrm{CC}}$.

## - INTO and INTI

These pins provide the capability for asynchronously applying an external interrupt to the LCD-III.

Refer to INTERRUPTS for additional information.

- $V_{1}, V_{2}$ and $V_{3}$

Power for liquid crystal display are supplied to the LCD-III using these pins ( $\left.V_{C C} \geqq V_{1} \geqq V_{2} \geqq V_{3} \geqq G N D\right)$.

- Roo to Ro3

These four lines are a 4-bit input channel.
Refer to INPUT/OUTPUT for additional information.

- $\mathbf{R}_{10}$ to $\mathrm{R}_{13}, \mathrm{R}_{20}$ to $\mathbf{R}_{23}$

These 8 lines are arranged into two 4-bit Input/Output common channels.

4-bit registers (data I/O register) are attached to these channels. Each channel is directly addressed by the operand of an instruction. I/O configuration of each pin can be specified among Open Drain, With Pull Up MOS, and CMOS using a mask option.

Refer to INPUT/OUTPUT for additional information.

## - R30 to R33

These four lines are a 4-bit output channel.
4-bit register is attached to this channel. This channel is directly addressed by the operand of an instruction. I/O configuration of each pin can be specified among Open Drain and CMOS using a mask option.

Refer to INPUT/OUTPUT for additional information.

- $\mathrm{D}_{0}$ to $\mathrm{D}_{13}$

These are 14 discrete signals which can be configured as Input/Output lines.

Refer to INPUT/OUTPUT for additional information.

- D14/XO, D15/XI
$\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ require a mask option in the following 3 types.
- Discrete I/O (common terminal)
- Crystal circuit connecting terminals (with internal halt)
- Crystal circuit connecting terminals (no internal halt)

Refer to INPUT/OUTPUT for additional information.

- COM1 to COM4

These pins are common terminals for liquid crystal display.
Refer to LIQUID CRYSTAL DISPLAY for additional information.

- SEG $_{1}$ to SEG $_{32}$

These pins are segment terminals for liquid crystal display.

Refer to LIQUID CRYSTAL DISPLAY for additional information.

- OSCILLATOR

A resistor, a ceramic filter circuit or an external oscillator
can be connected to $\mathrm{OSC}_{1}$ and $\mathrm{OSC}_{2}$. However, a ceramic filter circuit cannot be used on the HD44795. The oscillator frequency is initially divided by four to produce the initial system clock. The different connection methods are shown in Figure 1.
(1) External Clock



$$
\text { Duty }=\frac{T_{1}}{T_{h}+T_{1}} \times 100 \%
$$

Length of the wirings for OSC $_{1}$ and OSC 2
terminals should be minimized because the oscillation frequency varies depending on the capecitance of these terminals.



Figure 1 Connection Methods for Oscillator (to be continued)
(3) Ceramic Filter (This is not applied to HD44795.)


Figure 1 Connection Methods for Oscillator

- ROM

ROM is used as program and pattern (constants) memory. The instruction used in the LCD-III consists of 10 bits.

The pattern area is in pages 61 and 62 . No program can be
stored in this area. The area is only used to store patterns (constants) that are referred in programs by user.

The program area (instructions can be programmed) consists of 2,048 words $(64 \times 32)$ of pages 0 through 31 . In this area, either of programs or patterns can be stored.

Table 1 ROM Capacity

| Program Area | 32 peges |
| :--- | :--- |
| Pattern Area | 2 pages |
| Total Number <br> of the words | 2,176 words |

(NOTE) 1 page = 64 words


|  |  |
| :--- | :--- | :--- |
|  |  |


| Pattern Area |
| :---: |
| Pattern Area | | page 61 |
| :--- |
| page 62 |

Figure 2 ROM Address Space

## - PROGRAM COUNTER (PC)

PC is the counter for addressing the program area of ROM. It consists of the page part and the address part as shown in Figure 3.


Figure 3 PC Structure

## Page Part (5-bit register)

Once a certain value is loaded into a page part, the content is unchanged until other value is loaded by the program. The settable value of a page part is any number from 0 through 31.

## - Address Part (6-bit counter)

The address part consists of a random sequential counter and this counter counts up for each word, that is, one instruc-

Table 2 Sequence of the PC Address Part

| Decimal | Hex- <br> decimal | Decimal | Hex- <br> decimal | Decimal | Hex- <br> decimal |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 63 | $3 F$ | 5 | 05 | 9 | 09 |
| 62 | $3 E$ | 11 | $0 B$ | 19 | 13 |
| 61 | $3 D$ | 23 | 17 | 38 | 26 |
| 59 | $3 B$ | 46 | $2 E$ | 12 | $0 C$ |
| 55 | 37 | 28 | $1 C$ | 25 | 19 |
| 47 | $2 F$ | 56 | 38 | 50 | 32 |
| 30 | $1 E$ | 49 | 31 | 37 | 25 |
| 60 | $3 C$ | 35 | 23 | 10 | $0 A$ |
| 57 | 39 | 6 | 06 | 21 | 15 |
| 51 | 33 | 13 | $0 D$ | 42 | $2 A$ |
| 39 | 27 | 27 | $1 B$ | 20 | 14 |
| 14 | $0 E$ | 54 | 36 | 40 | 28 |
| 29 | $1 D$ | 45 | $2 D$ | 16 | 10 |
| 58 | $3 A$ | 26 | $1 A$ | 32 | 20 |
| 53 | 35 | 52 | 34 | 0 | 00 |
| 43 | $2 B$ | 41 | 29 | 1 | 01 |
| 22 | 16 | 18 | 12 | 3 | 03 |
| 44 | $2 C$ | 36 | 24 | 7 | 07 |
| 24 | 18 | 8 | 08 | 15 | $0 F$ |
| 48 | 30 | 17 | 11 | 31 | $1 F$ |
| 33 | 21 | 34 | 22 |  |  |
| 2 | 02 | 4 | 04 |  |  |

tion cycle. All instructions except the pattern instruction are executed in one instruction cycle. (While the pattern instruction is executed in two cycles.)

The sequence indicated in decimal and hexa-decimal is shown in Table 2. This sequence forms a loop and has neither the starting nor ending points. It generates no overflow carry. Therefore, instructions on a same page are executed step by step unless the content of the page part of PC is unchanged.

## - PATTERN GENERATION

The pattern (constants) can be assigned into ROM for user's reference in program. It can be written both in the program area and the pattern area.

Pattern reference is performed by the instruction of pattern $(\mathrm{P})$ in the program.

ROM Addressing for the pattern reference is performed by modifying PC with A, B, C (F/F), and the operand p . The modifying scheme is shown in Figure 4. The address part is replaced by the contents of A (Accumulator) and the lower bits of B. The page part is logically ORed with the PC, the upper 2 bits of the operand is for referring to the pattern area. When the upper bit is preset to 1 , the pattern area is referred, and it is preset to 0 , the program area is referred. Non-existing ROM area can not be referred.

The value of PC is only modified apparently and is not changed. Then the address is counted up after the execution of $P$ instruction and the next instruction is executed. The execution time of this instruction is 2 -cycle time. Moreover, an instruction just after this instruction is masked.

The bit pattern of referred ROM address is generated by two ways.
(i) The pattern is taken into $A$ and $B$.
(ii) The pattern is taken into the output ports R2 and R3.

The difference is determined by the command bits $\left(\mathrm{O}_{9}, \mathrm{O}_{10}\right)$ in the pattern. Mode (i) is performed when $O_{9}$ is " 1 " and mode (ii) is performed when $\mathrm{O}_{10}$ is " 1 ". Mode (i) and (ii) are simultaneously performed when both $\mathrm{O}_{9}$ and $\mathrm{O}_{10}$ are " 1 ". The correspondence of each bit of the pattern is shown in Figure 5.

In the program run, the pattern can not be distinguished from the instruction. When the program is running at the address written as a pattern by user, the instruction corresponding to the pattern bit is executed.

Therefore, when the pattern is written in the pattern area, the instruction must not be executed.


Figure 4 ROM Addressing for Pattern Reference

(Note) A's significance is inverted.

(Note) The significance of R2 and R3 is inverted.
Figure 5 Correspondence of Each Bit of the Pattern

## - RAM (RANDOM ACCESS MEMORY)

RAM is the memory used for data storage and register save (data RAM) and storage of segment data for liquid crystal display (display data RAM). One unit (digit) consists of 4 bits and there is a total of 160 digits ( 640 bits).
(NOTE) Capacity of display data RAM varies by contents of display, and capacity of data RAM changes corresponding to the former.

Addressing of RAM is performed by the matrix of the file number and the digit number. There are 10 files and 16 digits in the matrix. Normally the file No. is set to X and the digit No. is set to Y , then the matrix of $\mathbf{X}$ and Y addresses RAM and performs the Read/Write operation.

Special digits in RAM can be addressed without the use of $X$ and $Y$. These digits are called as memory register (MR) and the number is 16 (MR0 to MR15). Memory register can be exchanged for A register By XAMR instruction. RAM address space is shown in Figure 6.

file No.
Figure 6 RAM Address Space

In case of the instructions which consist of a simultaneous Read/Write operations of RAM (exchange of RAM and a register), the writing data doesn't affect the reading data because the read operation is followed by the write operation.

RAM bit manipulation is usable, which performs any bit set, reset or test of the addressed RAM. Bit assignment is made by the program as shown below.


The bit test makes the status " 1 " when the assigned bit is " 1 " and makes it " 0 " when the assigned bit is " 0 ".

## - REGISTERS

The LCD-III has six 4-bit registers and two 1-bit registers available to the programmer. 1-bit registers are Carry F/F and Status $F / F$. They are explained in the following paragraphs.

- Accumulator (A; A Register) and Carry F/F (C)

The result of ALU operation (4 bits) and the overflow of the ALU are put into the accumulator and Carry F/F. Carry F/F can be set, reset or tested. Combination of the accumulator and Carry F/F can be right or left rotated. The accumulator is the main register for ALU operation and Carry F/F is used to store the overflow generated by ALU operation when the calculation of two or more digits ( 4 bits/digit) is performed.

- B Register (B)

The result of ALU operation (4 bits) is put into this register. B register is used as a sub-accumulator to stack the data temporarily and also used as a counter.

- $X$ Register ( $X$ )

The result of ALU operation ( 4 bits) is put into this register. $\mathbf{X}$ register has exchangeability for SPX register. $\mathbf{X}$ register addresses the RAM file.

- SPX Register (SPX)

SPX register has exchangeability for $X$ register.
SPX register is used to stack X register and expand the addressing system of RAM in combination with X register.

- $\mathbf{Y}$ Register ( $\mathbf{Y}$ )

The result of ALU operation (4 bits) is put into this register.

Y register has exchangeability for SPY register. Y register can calculate itself simultaneously with transferring the data by bus lines, which is usable for the calculation of two or more digits ( 4 bits/digit).' Y register addresses the RAM digit and 1-bit discrete input/output common terminals.

## - SPY Register (SPY)

SPY register has exchangeability for Y register. SPY register is used to stack $Y$ register and expand the addressing system of RAM and 1-bit discrete input/output common terminals in combination with Y register.

## - Status F/F (S)

Status F/F latches the result of logical or arithmetic operations (Not Zero, Overflow) and bit test operations. Status F/F affects conditional instructions (LPU, BR and CAL). These instructions are executed only when Status $F / F$ is " 1 ". If it is " 0 ", these instructions are skipped and Status F/F becomes " 1 ".

## - INPUT/OUTPUT

## - Discrete I/O (D Terminal)

The discrete $I / O$ is composed of 1 -bit latch and $I / O$ pin. Figure 7 shows the basic block diagram.


Figure 7 Discrete I/O Block Diagram


Figure 8 Mask Option of $D_{14}$ and $D_{15}$ Terminals
$D_{0}$ to $D_{13}$ are discrete I/O's of common for input and output, $D_{14}$ and $D_{15}$ require a mask option in 3 types. When the crystal oscillation for timer is selected and the latches of $D_{14}$ and $D_{15}$ are not connected to the terminals, $D_{14}$ and $D_{15}$ can be used as 1 -bit general purpose registers that can be set, reset and tested. Furthermore, if there is internal halt mode, latch of $D_{15}$ is used as a register for internal halt mode specially.

In such case, since $D_{15}$ means internal halt state and $D_{15}=$ " 1 " means operating state, LSI can be in internal halt state by resetting $D_{15}$ using an instruction. The prescaler keeps its operation in internal halt state. Therefore, $\mathrm{D}_{15}$ may be set by overflow output pulse from the prescaler to return to operating state. Refer to HALT FUNCTION for details of internal halt mode.

Table 3 Mask Option of $D_{14} / X O$ and $D_{15} / X I$ Terminals

| Mask Option |  |  | a | $b$ | c | d | Function of $\mathrm{D}_{14} / \mathrm{XO} \text { and } \mathrm{D}_{15} / \mathrm{XI}$ | Function of $\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ latch |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Unselectable crystal oscillation for timer (no internal halt) |  | short | open | open | short | discrete I/O (common terminal) | Output Latch |
| 2 | Selectable crystal oscillation for timer | with internal halt | open | short |  |  | Crystal Circuit Connecting Terminal | 1-bit register |
| 3 |  | no internal halt |  |  |  |  |  | $\mathrm{D}_{14}$; 1-bit register <br> $D_{15}$; register for internal halt |

(NOTE) Users can specify this mask option in "The format of I/O channels" at ROM order.

Discrete I/O is addressed by $Y$ register, and the set/reset instruction is executed for the addressed latch. " 0 " and " 1 " level can be tested with the addressed terminal and 1 -bit register against the $I / O$ common pins and 1 -bit register. The test is performed with the wired logic of the output latch and the pin
input. Therefore, in the case of the $I / O$ common pins, the output latch should be in the high impedance state when the test instruction is executed. In order to test the pin input, it is necessary the state that the output latch should not affect the pin input.


Figure 9 Timing Chart of Discrete I/O

## - Data I/O (R Terminal)

Table 4 Data I/O for the LCD-III

| I/O common channel | R1, R2 (2 channels) |
| :--- | :--- |
| Input channel | RO (1 channel) |
| Output channel | R3 $\quad$ (1 channel) |
| Total | 4 channels |

(NOTE) In addition to the above, R4, R5 and R6 are provided as register setting liquid crystal display mode. In these registers, there is no terminal and exists only data I/O register each, which controls liquid crystal display mode. Data is transferred to R4, R5 and R6 by LRA or LRB instruction, same as data transfer to data 1/O registers of R1, R2 and R3. For details of R4, R5 and R6, refer to LIQUID CRYSTAL DISPLAY.

4-bit register (data I/O register) each is attached to an I/O common channel and output channel. No register is attached to input channel. Addressing to all channels is performed by programs (addressed by operands in instructions).

Figure 10 shows the block diagram of each channel.


Figure 10 Data I/O Block Diagram

When expansion of segment signal for liquid crystal display is designated by a program (Register $\mathrm{R}_{42}=$ " 0 "), R1 is used as a display data output terminal. This prohibits R1 to be used as an I/O common channel by users (Refer to Figure 10, R1 channel).

If LRA or LRB instruction is executed at the time, data is transferred to data I/O register, but the content of data I/O register is not output from R1. If LAR or LBR instruction is executed, display data is inputted to accumulator (A register) or B register.

Data is transferred from the accumulator (A register) and B
register to data I/O registers R1, R2, and R3 through the bus line. In addition, ROM bit patterns can be transferred to R2 and R3 by pattern generation instructions.

4-bit data can be inputted to the accumulator (A register) and B register from R0, R1 and R2 channels by input instructions. However, in the case of I/O common channels R2 and R3, since data I/O register outputs are connected to terminals, inputs are done to wired logic of register output and terminal input information. For this reason, to input terminal input signal, registers must be set to a state that would not affect the terminal input.


Figure 11 Data I/O Timing Chart

Pay attention: When executing an input instruction to output channel, the microcomputer reads unstabilized value causing malfunction of the program.

When executing an input instruction (LAR and LBR) from the data $1 / 0$, pay attention to time allowance after executing an output instruction. At the time, the input sampling pulse is generated during the first half of the instruction cycle.


Applied Pins: $\mathrm{INT}_{0}, \mathrm{INT}_{1}, \mathrm{R}_{00}$ to $\mathrm{R}_{03}$


With Pull up MOS (PMOS)


Figure 12 Configuration of Input Pins
Applied Pins: $\mathbf{R}_{\mathbf{3 0}}$ to $\mathbf{R}_{\mathbf{3 3}}$

> No Pull up MOS

CMOS Output


Figure 13 Configuration of Output Pins
Applied Pins: $D_{0}$ to $D_{13}, D_{14} / X O, D_{15} / X I, R_{10}$ to $R_{13}, R_{20}$ to $R_{23}$


## - TIMER/COUNTER



Figure 15 Timer/Counter Block Diagram

Timer/Counter Block Diagram is shown in Figure 15. 5-bit divider divides the crystal oscillation $(32.768 \mathrm{kHz})$ by 32 and generates clocks of $1,024 \mathrm{~Hz}$ in the crystal oscillation mode. It does not stop in the halt state. Prescaler divides the system clock (instruction frequency) or $1,024 \mathrm{~Hz}$ clock by 64 and generates overflow output pulse of "Instruction frequency/ 64 Hz " or 16 Hz . In the crystal oscillation mode, it does not stop during halt state. The input of the 4 -bit counter is overflow output pulse of the prescaler or a pulse of INT 1 terminal. Input selection is determined by CF state. Data can be exchanged between the counter and bus by LTI, LTA or LAT instruction. TF is a flip-flop which masks the interrupt of timer/counter.

The timer is operable in 2 modes (timer mode and counter mode) depending on what to count, and the mode is selected by programs.

- Timer Mode

The 4-bit counter counts prescaler overflow output pulses. One of the following two can be selected as the prescaler count clock by the mask option.

1. System clock (Instruction frequency)

2 . $1,024 \mathrm{~Hz}$ clock (Crystal oscillation for timer is selected.) . . . Clock obtained by dividing the crystal oscillation $(32.768 \mathrm{kHz})$ for timer by 32. Crystal oscillator is constructed between D
terminals of $D_{14}$ and $D_{15}$ :
Note 1) In this case, the overflow output pulses from the prescaler are 16 Hz . These pulses are counted by the 4 bit counter to generate an interrupt from 16 Hz to 1 Hz .
Note 2) In this case, the part marked with WIITS in Figure 15 Timer/Counter does not stop even in halt state. When using "internal halt mode" among the halt function, internal halt state is generated by resetting the register for internal halt mode ( D latch: $\mathrm{D}_{15}$ ) by an instruction $\left(D_{15}=\right.$ " 0 ": internal halt state, $D_{15}=$ " 1 ": operating state), and all the operation stop. In this case, overflow output pulses from the prescaler work as the signals releasing the internal halt state and set the $D_{15}$ output latch. Therefore, if an overflow output pulse from the prescaler is generated, internal halt state is released, and the LSI starts to operate.
By utilizing this function, intermittent operation is possible, that is, program execution for necessary processing (for example, counting for clock function) starts after every $62.5 \mathrm{msec}(16 \mathrm{~Hz})$ and the LSI stops after execution of this program by an instruction which makes the LSI into internal halt state. This reduces the time in which the LSI operates, resulting in power consumption in substance.


Figure 16 Set/Reset Operation Using Crystal Oscillator for Timer

- Counter Mode

Counts pulses of INT $_{1}$ terminal.
(Note) The width of INT $_{1}$ pulse in the counter mode must be at least 2 -cycle time for both the "High" and "Low" levels.
Each block of timer/counter and the specified time of timer mode are explained in the followings.
inputs. Each interrupt cause has the interrupt request $F / F$ and the request is latched into this flip-flop when it is generated. If an interrupt request can be accepted, the interrupt is generated.

It is controlled by Interrupt Enable F/F (I/E F/F) whether an interrupt can be accepted or not.

Figure 17 shows the interrupt block diagram and Figure 18 shows the interrupt timing chart.

## - INTERRUPT

There are interrupt caused by the timer/counter or the


Figure 17 Interrupt Block Diagram

The status is unchanged. (The interrupt is different from general CAL in regard to this matter.)

Stacking of registers is performed by the program. Returning from the interrupt routine is performed in the same way as that from normal subroutine. But it is convenient to use RTNI (Return Interrupt) which sets the I/E simultaneously with RTN.

An interrupt is generated irrespectively of the condition of stack registers, so enough stack registers are needed.

TF, IF0, or IF1 is flip-flop where the set has priority over the reset. It is not reset when the reset instruction is issued simultaneously with OVF of the timer/counter or the leading edge of the input, though the interrupt request is generateo and latched into I/RI or I/RT.

The interrupt processing caused by the interrupt generation is basically the subroutine jump and the jumping location in memory is fixed as:
$\begin{array}{ll}\text { Interrupt of the timer/counter } & \begin{array}{l}0 \text { page } 3 \mathrm{~F} \text { address }(00-3 F) \\ \text { Interrupt of the inputs } \\ \text { In addition, }\end{array} \\ \begin{array}{l}\text { The saving operation of } \mathrm{PC} \rightarrow \text { ST1 } \rightarrow \text { ST2 } \rightarrow \text { ST3 } \rightarrow \text { ST4. }\end{array}\end{array}$

## 1/E reset

## - Interrupt of the inputs

Two pins $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ have the interrupt request functions. They have the leading pulse generation circuit and the
interrupt mask F/F (IF0, IF1). When IF0 or IF1 is reset, the interrupt request is able to generate interrupt mask release. When $\mathrm{INT}_{0}$ or $\mathrm{INT}_{1}$ changes from " 0 " to " 1 " ("Low" level $\rightarrow$ "High" level), the leading pulse is generated and generates the interrupt request. Then IFO or IF1 is set, the interrupt is masked.

The interrupt request generated by the leading pulse is latched in the interrupt request $F / F$ on the input side (I/RI). If interrupt Enable $F / F(I / E)$ is " 1 ", the interrupt is generated immediately and I/RI is reset. But if Interrupt Enable F/F ( $\mathrm{I} / \mathrm{E}$ ) is " 0 ", $\mathrm{I} / \mathrm{RI}$ is held at " 1 " level until it gets into the Interrupt Enable state.

IF0, IF1, $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ can be tested by the program. Therefore, they can also be used as normal input terminals or latch terminals of momentary pulse input.

The interrupt pulse width (at both "High" and "Low" levels) should be more than two-cycle.

## - Interrupt of the Timer/Counter

The interrupt request of the timer/counter is latched into the interrupt request $\mathrm{F} / \mathrm{F}$ of the timer (I/RT). Then I/RT operates in the same way as I/RI, but the interrupt of the input has priority over that of the timer. Therefore, the input interrupt is processed when both of I/RI and I/RT are at " 1 " level (interrupt requests are simultaneously generated). During the input interrupt, I/RT remains set. Thus, after the input interrupt, the timer/counter interrupt can be processed.


Figure 18 Interrupt Timing Chart

## - LIOUID CRYSTAL DISPLAY

- Liquid Crystal Display Circuit

The LCD-III can directly drive the liquid crystal display panel of static, $1 / 2$ duty factor, $1 / 3$ duty factor and $1 / 4$ duty factor.

The LCD-III has 4 common signal terminals and 32 segment signal terminals. Further, if liquid crystal driver LSI(HD44100H) is connected to the LCD-III, up to 96 segment signal terminals can be extended externally. Thus, in addition to the internal 32 terminals, total 128 segment signal terminals can be driven.


Figure 19 Liquid Crystal Display Circuit Block Diagram

Display is automatically executed by writing segment data into RAM for LCD. The RAM reads segment data bit by bit sequentially every one instruction cycle upon receiving address signal from the display counter and the control circuit. Every time common signal is scanned, the RAM reads 128 -segment data ( SEG $_{1}$ to SEG $_{128}$ ), which is correspond to common signal selected at the next time. In the HD44790, scan of common signal is executed every 256 -instruction cycle. Therefore, the data which is correspond to 128 -segment is read twice at the same time. And in the HD44795, scan of common signal is executed every 128 -instruction cycle. Therefore, 128 -segment data is read. The serial data read is converted to parallel data by the
shift register and latch, converted to LCD drive signal by the liquid crystal driver and the outputted from a segment terminal. 32 -segment ( $\mathrm{SEG}_{1}$ to $\mathrm{SEG}_{32}$ ) out of 128 -segment serial data is used within the LCD-III, and the rest ( 96 -segment) is outputted to the liquid crystal driver LSI HD44100H which is connected to the LCD-III and is converted to the LCD drive signal in the HD44100H at the time of designation of with liquid crystal segment output extension. Cycle of the latch clock is 256 instruction cycle in the HD44790 and 128 instruction cycle in the HD44795. In the case of dynamic drive, data at the common side changes synchronously with the latch clock. These display operations are all executed regardless of program.


Figure 20 Liquid Crystal Display Circuit Time Chart (To be continued)


Figure 20 Liquid Crystal Display Circuit Time Chart

- Liquid Crystal Display Mode Setting Registers

For selection of the liquid crystal display mode, data I/O registers of R4, R5 and R6 are used.
Table 5 Function of Liquid Crystal Display Mode Setting Registers

| Selection of liquid crystal display duty factor ( $\mathbf{R}_{40}, \mathbf{R}_{41}$ ) | $\mathrm{R}_{41}$ | $\mathrm{R}_{40}$ | Function |
| :---: | :---: | :---: | :---: |
|  | 0 | 0 | Static |
|  | 0 | 1 | 1/2 duty |
|  | 1 | 0 | 1/3 duty |
|  | 1 | 1 | 1/4 duty |
| Designation of with or without liquid crystal segment output extension ( $\mathbf{R}_{42}$ ) | $\mathbf{R}_{42}$ |  | Function |
|  | 0 |  | To be extended (Outputs display data from Channel R1) |
|  | 1 |  | Not to be extended (Channel R1. becomes an ordinary 4-bit data 1/0.) |
| Liquid crystal display blanking signal ( $\mathbf{R}_{60}$ ) | $\mathrm{R}_{60}$ |  | Function |
|  | 0 |  | Outputs RAM data for liquid crystal display as segment signals. |
|  | 1 |  | Segment signals become non-selection status (blanking) regardless of RAM data for liquid crystal display. |


| RAM designation for liquid <br> crystal display $\left(\mathbf{R}_{\mathbf{s o}}, \mathbf{R}_{\mathbf{5 1}}\right)$ | $\mathbf{R}_{\mathbf{5 1}}$ | $\mathbf{R}_{\mathbf{5 0}}$ |  |
| :--- | :--- | :--- | :--- |
|  | Function varies with liquid crystal display duty factor. |  |  |

(NOTE) Liquid crystal display mode at resetting
Since all bits of registers R4, R5 and R6 are set to " 1 " by the reset function, display mode after resetting becomes as shown below:
Liquid crystal display duty factor: $1 / 4$ duty $\left(R_{40}=\right.$ " 1 ", $\left.R_{41}=" 1 "\right)$
Liquid crystal segment output extension: Not extended ( $R_{42}={ }^{\prime \prime} 1$ ")
Defignation of liquid crystal display blanking: Display blanking ( $\mathrm{R}_{60}={ }^{\prime \prime} 1$ ")

## - Relation between Display RAM and Segment Data

In the LCD-III, 4 types of display duty factor (static, $1 / 2$ duty, $1 / 3$ duty, and $1 / 4$ duty) can be selected by programs, and correspondence between RAM bits and segment data changes according to these duty factors.


Figure 21 Relation between RAM for LCD \& Segment Data (Static)

(NOTE) The SEG ${ }_{33}$ to SEG $_{12}$ are extended segments.
Figure 22 Relation between RAM for LCD \& Segment Data (1/2 Duty, 1/2 Bias)


|  | RAM Address |  |  |  |  | RAM |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | X |  |  |  | $Y$ | $2^{3}$ | $2^{2}$ | $2{ }^{\prime}$ | $2^{\circ}$ |
|  | 2 | 0 | 6 | 4 | 0 |  | SEG ${ }_{85}$ | SEG65 | SEG ${ }_{85}$ |
|  |  |  |  |  | 1 |  | SEG68 | SEG68 | SEG86 |
|  |  |  |  |  | 2 |  | SEG 87 | SEG 87 | SEG67 |
|  |  |  |  |  | 3 |  | SEG ${ }_{\text {d }}$ | SEG ${ }_{\text {B8 }}$ | SEG68 |
|  |  |  |  |  | 4 |  | SEG ${ }^{\text {b }}$ | SEG69 | SEG69 |
|  |  |  |  |  | 5 |  | SEG70 | SEG70 | SEG70 |
|  |  |  |  |  | 6 |  | SEG71 | SEG71 | SEG71 |
|  |  |  |  |  | 7 |  | SEG72 | SEG 72 | SEG72 |
|  |  |  |  |  | 8 |  | SEG73 | SEG73 | SEG73 |
|  |  |  |  |  | 9 |  | SEG74 | SEG74 | SEG74 |
|  |  |  |  |  | 10 |  | SEG75 | SEG75 | SEG75 |
|  |  |  |  |  | 11 |  | SEG76 | SEG76 | SEG76 |
|  |  |  |  |  | 12 |  | SEG77 | SEG77 | SEG77 |
|  |  |  |  |  | 13 |  | SEG78 | SEG78 | SEG78 |
|  |  |  |  |  | 14 |  | SEG79 | SEG79 | SEG79 |
|  |  |  |  |  | 15 |  | SEG30 | SEG80 | SEG ${ }_{80}$ |
|  | 3 | 1 | 7 | 5 | 0 |  | $\mathbf{S E G}_{81}$ | SEG ${ }_{81}$ | $\mathrm{SEG}_{\mathbf{8 1}}$ |
|  |  |  |  |  | 1 |  | SEG ${ }^{\text {d }}$ | SEG ${ }_{\text {82 }}$ | $\mathrm{SEG}_{82}$ |
|  |  |  |  |  | 2 |  | SEG $_{83}$ | SEG ${ }^{\text {e }}$ | SEG ${ }_{\text {83 }}$ |
|  |  |  |  |  | 3 |  | SEG ${ }^{4}$ | SEG84 | SEG ${ }^{4}$ |
|  |  |  |  |  | 4 |  | SEG95 | SEG85 | SEG ${ }_{\text {B5 }}$ |
|  |  |  |  |  | 5 |  | SEG88 | SEG86 | SEG ${ }_{\text {88 }}$ |
|  |  |  |  |  | 6 |  | SEG87 | SEG ${ }_{87}$ | SEG ${ }_{87}$ |
|  |  |  |  |  | 7 |  | SEG ${ }_{\text {88 }}$ | SEGB8 | SEGE8 |
|  |  |  |  |  | 8 |  | SEG89 | SEG89 | SEG ${ }_{\text {89 }}$ |
|  |  |  |  |  | 9 |  | SEG90 | SEG ${ }_{\text {PO }}$ | SEG90 |
|  |  |  |  |  | 10 |  | SEG91 | SEG91 | SEG ${ }_{91}$ |
|  |  |  |  |  | 11 |  | SEG92 | SEG92 | SEG92 |
|  |  |  |  |  | 12 |  | SEG93 | SEG93 | SEG ${ }^{\text {93 }}$ |
|  |  |  |  |  | 13 |  | SEG ${ }_{94}$ | SEG94 | SEG94 |
|  |  |  |  |  | 14 |  | SEG95 | SEG95 | SEG95 |
|  |  |  |  |  | 15 |  | SEG ${ }_{96}$ | SEG96 | SEG98 |
|  | 0 | 2 | 4 | 6 | 0 |  | SEG97 | SEG97 | SEG97 |
|  |  |  |  |  | 1 |  | SEG98 | SEG98 | SEG98 |
|  |  |  |  |  | 2 |  | SEG99 | SEG99 | SEG99 |
|  |  |  |  |  | 3 |  | SEG 100 | SEG ${ }_{100}$ | SEG 100 |
|  |  |  |  |  | 4 |  | SEG ${ }_{101}$ | SEG ${ }_{101}$ | SEG 101 |
|  |  |  |  |  | 5 |  | SEG ${ }_{102}$ | SEG ${ }^{102}$ | SEG ${ }_{102}$ |
|  |  |  |  |  | 6 |  | SEG ${ }_{103}$ | SEG ${ }_{103}$ | SEG ${ }_{103}$ |
|  |  |  |  |  | 7 |  | SEG104 | SEG ${ }_{104}$ | SEG ${ }^{104}$ |
|  |  |  |  |  | 8 |  | SEG ${ }_{105}$ | SEG 105 | SEG ${ }^{105}$ |
|  |  |  |  |  | 9 |  | SEG106 | SEG 108 | SEG ${ }^{108}$ |
|  |  |  |  |  | 10 |  | SEG ${ }_{107}$ | SEG 107 | SEG 107 |
|  |  |  |  |  | 11 |  | SEG ${ }_{108}$ | SEG108 | SEG108 |
|  |  |  |  |  | 12 |  | SEG ${ }_{109}$ | SEG 108 | SEG 109 |
|  |  |  |  |  | 13 |  | SEG ${ }_{110}$ | SEG ${ }_{110}$ | SEG 110 |
|  |  |  |  |  | 14 |  | SEG ${ }_{111}$ | $\mathbf{S E G}_{111}$ | SEG ${ }_{111}$ |
|  |  |  |  |  | 15 |  | SEG ${ }_{112}$ | SEG ${ }_{112}$ | SEGG12 |
|  |  | 3 | 5 | 7 | 0 |  | SEG $_{113}$ | SEG ${ }_{113}$ | $\mathrm{SEG}_{113}$ |
|  |  |  |  |  | 1 |  | SEG114 | SEG 114 | SEG 114 |
|  |  |  |  |  | 2 |  | SEG115 | SEG 115 | SEG 115 |
|  |  |  |  |  | 3 |  | SEG ${ }_{116}$ | SEG ${ }_{116}$ | SEG ${ }_{118}$ |
|  |  |  |  |  | 4 |  | SEG ${ }_{11}$ | SEG ${ }_{117}$ | SEG ${ }_{117}$ |
|  |  |  |  |  | 5 |  | SEG ${ }_{118}$ | SEG ${ }_{11}$ | SEG $_{118}$ |
|  |  |  |  |  | 6 |  | SEG ${ }_{119}$ | SEG ${ }_{119}$ | $\mathrm{SEG}_{118}$ |
|  | 1 |  |  |  | 7 |  | SEG ${ }_{120}$ | SEG ${ }_{120}$ | $\mathrm{SEG}_{120}$ |
|  | 1 |  |  |  | 8 |  | SEG $_{121}$ | SEG ${ }_{121}$ | $\mathrm{SEG}_{121}$ |
|  |  |  |  |  | 9 |  | SEG $_{122}$ | SEG $_{122}$ | $\mathrm{SEG}_{122}$ |
|  |  |  |  |  | 10 |  | SEG ${ }_{123}$ | $\mathrm{SEG}_{123}$ | SEG $_{123}$ |
|  |  |  |  |  | 11 |  | SEG ${ }_{124}$ | SEG ${ }_{124}$ | SEG124 |
|  |  |  |  |  | 12 |  | SEG ${ }_{125}$ | SEG ${ }_{125}$ | SEG ${ }_{125}$ |
|  |  |  |  |  | 13 |  | SEG ${ }_{126}$ | SEG 128 | SEG128 |
|  |  |  |  |  | 14 |  | SEG ${ }_{127}$ | SEG 127 | SEG ${ }_{127}$ |
|  |  |  |  |  | 15 |  | SEG ${ }_{128}$ | $\mathrm{SEG}_{128}$ | $\mathrm{SEG}_{128}$ |
| R 50 | 0 | 0 | 1 | 1 |  |  |  |  |  |
| $\mathrm{R}_{51}$ | 0 | 1 | 0 | 1 |  |  | $\mathrm{COM}_{3}$ | $\mathrm{COM}_{2}$ | COM ${ }_{1}$ |

(NOTE) The SEG St $_{3 s}$ to SEG $_{128}$ are extended segments.
Figure 23 Relation between RAM for Liquid Crystal Display and Segment Data (1/3 Duty, 1/3 Bias Drive)


|  | RAM Address |  |  |  |  | RAM |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | X |  |  |  | $Y$ | 23 | $2^{2}$ | 21 | $2^{\circ}$ |
|  | 2 | 0 | 6 | 4 | 0 | SEG ${ }^{\text {bs }}$ | SEG85 | SEGas | SEG85 |
|  |  |  |  |  | 1 | SEG68 | SEG86 | SEGe | SEG80 |
|  |  |  |  |  | 2 | SEG $_{87}$ | SEG97 | SEG67 | SEG67 |
|  |  |  |  |  | 3 | SEG ${ }^{\text {es }}$ | SEGa | SEG* | SEGee |
|  |  |  |  |  | 4 | SEG60 | SEG69 | SEG69 | SEG80 |
|  |  |  |  |  | 5 | SEG70 | SEG70 | SEG70 | SEG70 |
|  |  |  |  |  | 6 | SEG71 | SEG71 | SEG71 | SEG71 |
|  |  |  |  |  | 7 | SEG72 | SEG72 | SEG72 | SEG72 |
|  |  |  |  |  | 8 | SEG73 | SEG73 | SEG73 | SEG73 |
|  |  |  |  |  | 9 | SEG74 | SEG74 | SEG74 | SEG74 |
|  |  |  |  |  | 10 | SEG78 | SEG75 | SEG78 | SEG75 |
|  |  |  |  |  | 11 | SEG76 | SEG78 | SEG76 | SEG76 |
|  |  |  |  |  | 12 | SEG77 | SEG79 | SEG77 | SEG71 |
|  |  |  |  |  | 13 | SEG78 | SEG79 | SEG7: | SEG7\% |
|  |  |  |  |  | 14 | SEG79 | SEG79 | SEG76 | SEG78 |
|  |  |  |  |  | 15 | SEG80 | SEG*0 | SEGeo | SEGso |
|  | 3 | 1 | 7 | 5 | 0 | SEG ${ }_{10}$ | SEGat | SEGE1 | SEG ${ }^{\text {S }}$ |
|  |  |  |  |  | 1 | $\mathrm{SEG}_{82}$ | SEG ${ }^{2}$ | SEGE2 | SEG ${ }^{\text {2 }}$ |
|  |  |  |  |  | 2 | SEG ${ }^{\text {a }}$ | SEGas | SEGa3 | SEG ${ }^{\text {S }}$ |
|  |  |  |  |  | 3 | SEG ${ }^{4}$ | SEGs | SEG94 | SEG ${ }_{\text {s }}$ |
|  |  |  |  |  | 4 | SEGEs | SEGs | SEGas | SEGes |
|  |  |  |  |  | 5 | SEGeo | SEGe | SEGs | SEGe8 |
|  |  |  |  |  | 6 | SEG ${ }_{87}$ | SEG47 | SEGa7 | SEGay |
|  |  |  |  |  | 7 | SEGss | SEGe: | SEGea | SEGe9 |
|  |  |  |  |  | 8 | SEG99 | SEGas | SEGen | SEGes |
|  |  |  |  |  | 8 | SEG00 | SEG90 | SEG80 | SEG90 |
|  |  |  |  |  | 10 | SEG91 | SEG91 | SEG91 | SEG ${ }^{\text {Pt }}$ |
|  |  |  |  |  | 11 | SEG $^{29}$ | SEG ${ }^{\text {ch }}$ | SEG $_{62}$ | SEG62 |
|  |  |  |  |  | 12 | SEG93 | SEG03 | SEG ${ }^{\text {a }}$ | SEG93 |
|  |  |  |  |  | 13 | SEG94 | SEGa | SEG94 | SEG94 |
|  |  |  |  |  | 14 | SEG95 | SEG98 | SEGes | SEGgs |
|  |  |  |  |  | 15 | SEG98 | SEGse | SEG6 | SEG\% |
|  | 0 | 2 | 4 | 6 | 0 | SEG97 | SEG97 | SEG97 | SEG97 |
|  |  |  |  |  | 1 | SEG98 | SEGes | SEG0 | 8EG90 |
|  |  |  |  |  | 2 | SEG90 | SEG98 | SEG90 | SEG9 |
|  |  |  |  |  | 3 | SEG100 | SEG100 | SEG100 | SEG100 |
|  |  |  |  |  | 4 | SEG 101 | SEG 101 | SEG ${ }_{101}$ | 8EG109 |
|  |  |  |  |  | 5 | SEG102 | SEG102 | SEG102 | SEG102 |
|  |  |  |  |  | 6 | SEG109 | SEG 109 | SEG102 | 8EG109 |
|  |  |  |  |  | 7 | SEG100 | SEGioa | SEG ${ }_{104}$ | 8EG104 |
|  |  |  |  |  | 8 | SEG106 | SEG10\% | 8EG ${ }^{\text {S }}$ | SEG ${ }_{106}$ |
|  |  |  |  |  | 8 | SEG 100 | SEG100 | SEG 106 | SEG 100 |
|  |  |  |  |  | 10 | SEG109 | SEG 107 | SEG107 | 8EG ${ }_{107}$ |
|  |  |  |  |  | 11 | SEG 100 | SEG100 | SEG 100 | SEG100 |
|  |  |  |  |  | 12 | SEG 109 | SEG100 | SEG 100 | SEG100 |
|  |  |  |  |  | 13 | SEG110 | SEG110 | SEG ${ }_{110}$ | SEG 110 |
|  |  |  |  |  | 14 | SEG111 | SEG111 | SEG 111 | SEG 111 |
|  |  |  |  |  | 15 | SEG ${ }_{112}$ | SEG1+2 | SEG ${ }_{112}$ | SEG 112 |
|  |  | 3 | 5 | 7 | 0 | SEG 113 | SEG113 | SEG 113 | SEG113 |
|  | 1 |  |  |  | 1 | SEG 114 | SEG ${ }_{14}$ | SEG ${ }_{114}$ | SEG 114 |
|  |  |  |  |  | 2 | SEG 118 | SEG $_{118}$ | SEG118 | SEG 116 |
|  |  |  |  |  | 3 | SEG110 | SEG ${ }_{11}$ | SEG:16 | SEG116 |
|  |  |  |  |  | 4 | SEG117 | SEG117 | SEG 117 | SEG 117 |
|  |  |  |  |  | 5 | SEG110 | SEG11 | SEG $_{118}$ | SEG118 |
|  |  |  |  |  | 6 | SEG119 | SEG118 | SEG $_{118}$ | SEG ${ }_{110}$ |
|  |  |  |  |  | 7 | SEG 120 | SEG 120 | SEG ${ }^{120}$ | SEG ${ }_{120}$ |
|  |  |  |  |  | 8 | SEG 121 | SEG 121 | SEG ${ }^{21}$ | SEG121 |
|  |  |  |  |  | 9 | SEG $_{122}$ | SEG $_{122}$ | SEG 122 | SEG 122 |
|  |  |  |  |  | 10 | $\mathrm{SEG}_{123}$ | SEG123 | SEG $_{123}$ | SEG $_{123}$ |
|  |  |  |  |  | 11 | SEG ${ }_{124}$ | SEG124 | SEG 124 | $\mathrm{SEG}_{124}$ |
|  |  |  |  |  | 12 | SEG 128 | SEG ${ }^{28}$ | SEG 128 | SEG ${ }_{128}$ |
|  |  |  |  |  | 13 | SEG 120 | SEG126 | SEG120 | SEG 120 |
|  |  |  |  |  | 14 | SEG ${ }^{127}$ | SEG 127 | SEG 127 | SEG 127 |
|  |  |  |  |  | 15 | SEG $_{128}$ | SEG ${ }^{28}$ | SEG $_{128}$ | SEG ${ }^{128}$ |
| Rso | 0 | 0 | 1 | 1 | $\mathrm{COM}_{4}$ |  |  |  |  |
| R ${ }_{51}$ | 0 | 1 | 0 | 1 |  |  | $\mathrm{COM}_{3}$ | $\mathrm{COM}_{2}$ | COM, |

(NOTE) The SEG Sis $^{2}$ to SEG $_{13}$ are extended segments.
Figure 24 Relation between RAM for Liquid Crystal Display and Segment Data ( $1 / 4$ Duty, $1 / 3$ Bias Drive)

(1/2 duty, $1 / 2$ bias)

(1/3 duty, $1 / 3$ bias)

(1/4 duty, $1 / 3$ bias)
Figure 25 LCD Wiring Samples

## - Extension of Display Function

Number of display digits can be increased by externally connecting an LCD driver LSI HD44100H to the LCD-III.

The HD44100H consists of shift registers and latch and liquid crystal drive circuit. When connected with the LCD-III, the HD44100H is used as a circuit for segment. In the LCD-III, display data for 128 segments is sent to the 32-bit shift register from RAM constantly. When R42 is set to " 0 ", the R1 channel outputs the 32 nd stage output $D$ of the shift register, shift clock $\mathrm{CL}_{2}$, latch clock $\mathrm{CL}_{1}$ and AC signal M . Therefore, up to 96 segment terminals from SEG 33 to SEG i28 can be added by directly connecting the HD44100H.

## - RESET FUNCTION

The LCD-III can be reset by setting the reset terminal to " 1 "
(High) and its operation starts when the terminal is set to " 0 " (Low). Also an automatic reset function (internal reset circuit) that operates when power is turned on is provided.

However, note that in the case of internal reset circuit the rise time of a power supply has a restriction. The LCD-III internal state is set as follows by the reset function:

The program counter is set to Address 3 F of Page 31.
IR/I, IR/T, I/E and CF are reset to " 0 ".
IF0, IF1 and TF are preset to " 1 ".
All bits of data I/O register, discrete I/O output latches (R1, R2, R3 and $D_{0}$ to $D_{15}$ ) are preset to " 1 ".
Liquid crystal display . . All bits of display mode setting registers (data I/O registers) R4, R5 and R6 are preset to " 1 ".
RAM data is not retained after reset.


Figure 26 Power Supply Condition Using the Built-in Reset Circuit


Figure 27 Reset Input Condition Using an External Reset Circuit

## - HALT FUNCTION

The LCD-III is provided with half function. The halt function reduces power consumption in the halt state by temporarily stopping all status including RAM. When halt is released, operation restarts from the state immediately before the halt.

## (Caution at the halt time)

When the LCD.III goes into halt state, segment terminals ( $\mathrm{SEG}_{1}$ to $\mathrm{SEG}_{32}$ ) and common terminals ( $\mathrm{COM}_{1}$ to $\mathrm{COM}_{4}$ ) become the same potential and display goes out. However, in order to reduce power consumption during halt, disconnect the voltage applied to liquid crystal power supply $\mathrm{V}_{3}$. Since there are dividing resistors among $\mathrm{V}_{1}, \mathrm{~V}_{2}$, and $\mathrm{V}_{3}$, current of up to $50 \mu \mathrm{~A}$ flows if voltage is applied between VCC and $V_{3}$ in the same way as normal operation.

The user can select one of the following I/O status at the time of halt based on the "MASK OPTION LIST" when ordering ROM:
i) All $1 / 0$ status is kept as the state immediately before the halt.
ii) All I/O status is held in the high impedance state (both PMOS and NMOS are off, and pull-up MOS is off).
There are the following two types of halt:

1) External Halt (Halt state generated by using $\overline{\mathrm{HLT}}$ terminal) All operations stop when the HLT terminal is set to the " 0 " level (Low). When the HLT terminal is set to the " 1 " level (High), operation restarts from the state immediately before the halt.
2) Internal Halt (Halt state generated by programs)

The user can select availability of internal halt at the time of ROM order based on the "MASK OPTION LIST". When internal halt is selected, timer crystal must be at-
tached externally. Therefore, the $\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ terminals should not be used as general I/O's, but as XO and XI terminals for connecting cyrstal oscillator.
Resetting of the $\mathrm{D}_{15}$ latch by RED instruction generates internal halt state. Return from internal halt is effected by overflow signals of the prescaler. 16 Hz overflow signals are output from the prescaler if a crystal oscillator of 32.768 kHz is connected to the $\mathrm{D}_{14} / \mathrm{XO}$ and
$\mathrm{D}_{15} / \mathrm{XI}$ terminals. When an overflow signal is issued, the Dis latch is set to " 1 " from " 0 ", the LCD-III returns from halt state, adds 1 to the timer register, and execution restarts from the instruction next to the RED instruction.
Note that external halt caused by the $\overline{\text { HLT }}$ terminal cannot be released by prescaler overflow signals.


Figure 28 Program example in the Internal Halt Mode


Figure 29 Internal Halt Timing Chart


Figure 30 External Halt Timing Chart

- CRYSTAL OSCILLATION CIRCUIT FOR TIMER

The user can specify by the "MASK OPTION LIST" whether or not the timer crystal should be externally attached. By externally attaching a crystal oscillator of 32.768
kHz to the $\mathrm{D}_{14} / \mathrm{XO}$ and D15/XI terminals, maximum 1 second of timer interruption cycle is possible setting the prescaler clock to $1,024 \mathrm{~Hz}$.

This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefully on your application.


$$
C_{1}=C_{2}=20 p F \pm 10 \%
$$

$R=10 \mathrm{M} \Omega \pm 10 \%$
$R d=200 k \Omega \pm 10 \%$
(NOTE)
The crystal oscillator, resistor R, Rd and load capacitor $C_{1}$ and $C_{2}$ should be placed as close as possible to the LCD-III. Induction of ex-
ternal noise to $D_{14} / X O$ and $D_{15} / X I$ may disturb normal oscillation.

Figure 31 Crystal Oscillator Circuit

| No. | Halt state | With or without timer crystal | $\underset{\text { terminals }}{\mathrm{D}_{14}, \mathrm{D}_{15}(\mathrm{XO}, \mathrm{XI})}$ | Function |
| :---: | :---: | :---: | :---: | :---: |
| 1 | External halt | Externally attached crystal ( 32.768 kHz ) | Terminals for attaching crystal. Cannot be used as general I/O. | Prescaler clock is set to $1,024 \mathrm{~Hz}$ and the overflow signal to 16 Hz . Up to 1 second can be set as the timer interruption cycle. |
| 2 | External halt | (Without crystal) <br> Internal clock of LSI | Used as general I/O | The prescaler clock becomes 100 kHz type, and the timer interruption cycle can be set to maximum 97.66 Hz . |
| 3 | Internal and external halt | Externally attached crystal ( 32.768 kHz ) | Terminals for attaching crystal. Cannot be used as general I/O. | Prescaler clock is set to $1,024 \mathrm{~Hz}$ and the overflow signal to 16 Hz . This signal performs the LCD-III return from internal halt. (Return from external halt is not possible by the prescaler overflow signal.) |

## - MASK OPTION

The following type mask option is available.

- I/O Terminal Format

Select one of A, B or C
A: Without pull-up MOS
B: With pull-up MOS
C: CMOS output
(Note) External input is not permitted if CMOS output is selected in the case of $\mathrm{I} / \mathrm{O}$ common terminals.

- I/O Status in the Halt State . . . . . Select Enable or Disable Enable - Output . . . Maintained in the status before halt. - Pull-up MOS . . . ON

Input . . . Unrelated to halt state
(Since Pull-up MOS is ON, if halt state occurs when output is " 0 " (Low) level (NMOS; ON), pullup MOS current always flows. If input changes, transient current flows through the input circuit. Also, current flows through the input pull-up MOS. These currents are added to standby power supply current (or halt current).)
Disable $T^{\text {Output }} \ldots$. NMOS output; OFF CMOS output; High impedance (NMOS, PMOS; OFF)

- Pull-up MOS . . OFF

Input . . . Input circuit; OFF
(Both input and output become high impedance
state. Since the input circuit is turned off, input change does not cause current other than the standby power supply current or halt current.)

- With or without Externally Attached Timer Crystal

Without timer crystal...
The $D_{14}$ and $D_{15}$ can be used as general I/O terminals.
Select one of $A, B$ or $C$ in the $D_{14} / D_{15}$ column of the I/O format specifications.
With timer crystal...
The $D_{14}$ and $D_{15}$ cannot be used as general $I / 0$ terminals.
Therefore, leave the $\mathrm{D}_{14} / \mathrm{D}_{15}$ column in blank.
Since the $\mathrm{D}_{14}$ latch can be set, reset or tested, it can be used as a flag.
If no internal halt exists, the $D_{15}$ latch can be used as a flag same as the $D_{14}$ latch. If internal halt exists, it cannot be used as a general flag.

- With or without Internal Halt

With internal halt ..
When internal halt is specified, the timer crystal must also be specified.
Without internal halt . . .
The $\mathrm{D}_{15}$ can be used as a general I/O terminal (when no timer crystal is used) or as a flag (when timer crystal is used).

## - INSTRUCTION

Instructions are listed according to their functions.
Each mnemonic code and function are shown in this table.

| Group | Mnemonic code | Function | Status |
| :---: | :---: | :---: | :---: |
| Register to Register | LAB <br> LBA <br> LAY <br> LASPX <br> LASPY <br> XAMR m | $\begin{aligned} & B \rightarrow A \\ & A \rightarrow B \\ & Y \rightarrow A \\ & S P X \rightarrow A \\ & S P Y \rightarrow A \\ & A \leftrightarrow M R(m) \end{aligned}$ |  |
| R A M Address | LXA <br> LYA <br> LXI i <br> LYI i <br> IY <br> D $Y$ <br> AYY <br> SYY <br> XSPX <br> XSPY <br> XSPXY | $\begin{aligned} & A \rightarrow X \\ & A \rightarrow Y \\ & i \rightarrow X \\ & i \rightarrow Y \\ & Y+1 \rightarrow Y \\ & Y-1 \rightarrow Y \\ & Y+A \rightarrow Y \\ & Y-A \rightarrow Y \\ & X \leftrightarrow S P X \\ & Y \leftrightarrow S P Y \\ & X \leftrightarrow S P X, Y \leftrightarrow S P Y \end{aligned}$ | $\begin{gathered} \text { N Z } \\ \text { NB } \\ \text { C } \\ \text { NB } \end{gathered}$ |
| Register RAM | $\begin{aligned} & \text { LAM (XY) } \\ & \text { LBM }(X Y) \\ & \text { XMA }(X Y) \\ & X M B(X Y) \\ & \text { LMAIY(X) } \\ & \text { LMADY }(X) \end{aligned}$ | $\begin{aligned} & M \rightarrow A(X Y \leftrightarrow S P X Y) \\ & M \rightarrow B(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow A(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow B(X Y \leftrightarrow S P X Y) \\ & A \rightarrow M, Y+1 \rightarrow Y(X \leftrightarrow S P X) \\ & A \rightarrow M, Y-1 \rightarrow Y(X \leftrightarrow S P X) \end{aligned}$ | $\begin{aligned} & \text { N Z } \\ & \text { NB } \end{aligned}$ |
| Immediate | LMIIY i LAI i LBI i | $\begin{aligned} & i \rightarrow M, Y+1 \rightarrow Y \\ & i \rightarrow A \\ & i \rightarrow B \end{aligned}$ | N Z |
| Arithmetic | Al i <br> IB <br> D B <br> AMC <br> SMC <br> AM <br> DAA <br> DAS <br> NEGA <br> COMB <br> SEC <br> REC <br> TC <br> ROTL <br> ROTR <br> OR | $\begin{array}{lll} A+i \rightarrow A \\ B+1 \rightarrow B & \\ B-1 \rightarrow B & \\ M+A+C(F / F) \rightarrow A \\ M-A-\bar{C}(F / F) \rightarrow A \\ M+A \rightarrow A \end{array}$ <br> Decimal Adjustment (Addition) <br> Decimal Adjustment (Subtraction) $\bar{A}+1 \rightarrow A$ $\bar{B} \rightarrow B$ $1 \rightarrow C(F / F)$ $0 \rightarrow C(F / F)$ <br> Test C (F/F) <br> Rotation Left <br> Rotation Right <br> $A \cup B \rightarrow A$ | C <br> NZ <br> NB <br> C <br> NB <br> C <br> $C(F / F)$ |


| Group | Mnemonic code |  | Function | Status |
| :---: | :---: | :---: | :---: | :---: |
| Compare | MNEI | i | M キ i | N Z |
|  | YNEI | i | Y $\neq \mathrm{i}$ | N Z |
|  | ANEM |  | $A \neq M$ | N Z |
|  | BNEM |  | $B \neq M$ | N Z |
|  | ALEI | i | $A \leqq i$ | N B |
|  | ALEM |  | $A \leqq M$ | N B |
|  | BLEM |  | $\mathrm{B} \leqq \mathrm{M}$ | NB |
| RAM bit Manipulation | SEM n |  | $1 \rightarrow M(n)$ |  |
|  | REM | n | $0 \rightarrow M(n)$ |  |
|  | TM | n | Test M ( n ) | M ( n ) |
| ROM Address | $\begin{aligned} & \text { BR } \\ & C A L \\ & L P U \end{aligned}$ | a | Branch on Status 1 | 1 |
|  |  | a | Subroutine Jump on Status 1 | 1 |
|  |  | $u$ | Load Program Counter Upper on Status 1 |  |
|  | $\begin{aligned} & \text { TBR } \\ & \text { RTN } \end{aligned}$ | $p$ | Table Branch |  |
|  |  |  | Return from Subroutine |  |
| Interrupt | SEIE |  | $1 \rightarrow$ I/E |  |
|  | SEIFO |  | $1 \rightarrow$ IF 0 |  |
|  | SEIF1 |  | $1 \rightarrow \mid F 1$ |  |
|  | SETF |  | $1 \rightarrow$ T F |  |
|  | SECF |  | $1 \rightarrow$ C F |  |
|  | REIE |  | $0 \rightarrow I / E$ |  |
|  | REIFO |  | $0 \rightarrow 1 \mathrm{~F} 0$ |  |
|  | REIF1 |  | $0 \rightarrow I F 1$ |  |
|  | RETF |  | $0 \rightarrow T F$ |  |
|  | RECF |  | $0 \rightarrow C F$ |  |
|  | TIO |  | Test $\quad 1 N T_{0}$ | $\mathrm{INT}_{0}$ |
|  | TII |  | Test $\quad 1 N T_{1}$ | $\mathrm{INT}_{1}$ |
|  | TIFO |  | Test IFO | $1 \mathrm{~F}_{0}$ |
|  | TIF1 |  | Test IF 1 | I $\mathrm{F}_{1}$ |
|  | TTF |  | Test TF | T F |
|  | LTI |  | i $\rightarrow$ Timer/Counter |  |
|  | LTA |  | A $\rightarrow$ Timer/Counter |  |
|  | LAT |  | Timer/Counter $\rightarrow$ A |  |
|  | RTNI |  | Return Interrupt |  |
| Input/Output (Display Control) | SED |  | $1 \rightarrow \mathrm{D}$ (Y) | D (Y) |
|  | RED |  | $0 \rightarrow \mathrm{D}$ (Y) |  |
|  | T D |  | Test $\mathrm{D}(\mathrm{Y})$ |  |
|  | SEDD | $n$ | $1 \rightarrow \mathrm{D}$ ( n ) |  |
|  | REDD | $n$ | $0 \rightarrow D \quad(n)$ |  |
|  | LAR | $p$ | $R(p) \rightarrow A$ |  |
|  | LBR | p | $R(p) \rightarrow B$ |  |
|  | LRA | p | $A \rightarrow R(p)$ |  |
|  | LRB | $p$ | $B \rightarrow R(p)$ |  |
|  | Pp |  | Pattern Generation |  |
|  | NOP |  | No Operation |  |

## LCD-III

(NOTE) 1. (XY) after a mnemonic code has four meanings as follows.
Mnemonic only
nstruction execution only
Mnemonic with $Y$ Instruction execution, $Y \leftrightarrow S P Y$
Mnemonic with $X Y \quad$ Instruction execution, $X \leftrightarrow S P X, Y \leftrightarrow$ SPY [Example] LAM

## $M \rightarrow A$

LAMX
LAMXY
$M \rightarrow A, X \leftrightarrow S P X$
$M \rightarrow A, Y \leftrightarrow S P Y$
$M \rightarrow A, X \leftrightarrow S P X, Y \leftrightarrow S P Y$
2. Status column shows the factor which affects status by the instruction of status change. NZ .......... ALU Not Zeto
C ............ ALU Overflow in Addition/Carry
NB .......... ALU Overflow in Subtraction/No Borrow
except above .... Content of status column affects status directly.
3. Carry flip-flop is not always affected by executing the instruction which affects the Status.

Instructions which affect Carry flip-flop are eight as follows.
AMC
SMC
DAA REC
DAS ROTR
4. All instructions except for $P$ are executed in single cycle. $\mathbf{P}$ is executed in 2-cycle.

## LCD-III Mask Option List

| Date |  |
| :--- | :--- |
| Customer's Name |  |
| ROM CODE ID |  |
| Hitachi P/N |  |

(1) I/O Option

| Pin Name | 1/0 | 1/O Option |  |  | Remarks | Pin Name | 1/0 | I/O Option |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A | B | C |  |  |  | A | B | C |  |
| Do | 1/O |  |  |  |  | Roo | 1 |  |  |  |  |
| $\mathrm{D}_{1}$ | 1/0 |  |  |  |  | Ro1 | 1 |  |  | , |  |
| $D_{2}$ | 1/0 |  |  |  |  | Ro2 | 1 |  |  |  |  |
| $\mathrm{D}_{3}$ | 1/0 |  |  |  |  | Ros | 1 |  |  | , |  |
| D4 | 1/0 |  |  |  |  | $\mathrm{R}_{10}$ | 1/0 |  |  |  |  |
| Ds | 1/0 |  |  |  |  | $\mathrm{R}_{11}$ | I/O |  |  |  |  |
| D6 | I/O |  |  |  |  | $\mathrm{R}_{12}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{7}$ | 1/0 |  |  |  |  | R13 | I/O |  |  |  |  |
| Di | 1/0 |  |  |  |  | $\mathrm{R}_{20}$ | 1/0 |  |  |  |  |
| D9 | 1/0 |  |  |  |  | $\mathrm{R}_{21}$ | I/O |  |  |  |  |
| D10 | 1/0 |  |  |  |  | $\mathrm{R}_{22}$ | 1/0 |  |  |  |  |
| D11 | 1/0 |  |  |  |  | $\mathrm{R}_{23}$ | 1/0 |  |  |  |  |
| D12 | 1/0 |  |  |  |  | R30 | 0 |  | , |  |  |
| D13 | 1/0 |  |  |  |  | R31 | 0 |  | - |  |  |
| D14 | 1/0 |  |  |  |  | R32 | 0 |  | , |  |  |
| D15 | 1/0 |  |  |  |  | R33 | 0 |  | 7 |  |  |
| INT0 | 1 |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{INT}_{1}$ | 1 |  |  |  |  |  |  |  |  |  |  |

"Specify the I/O composition with a mark of " $O$ " in the applicable composition column.
A: No pull up MOS
B: With pull up MOS
C: CMOS Output
(2) Oscillator \& External Halt

| Oscillator External Halt | Not used | Used (Reset is applied when Halt release) | Used (Reset is not applied when Halt release) |
| :--- | :--- | :--- | :--- |
| Resistor |  |  |  |
| Ceramic Resonator |  |  |  |
| External Clock |  |  |  |

*Please check one section on the above chart.
(3) Oscillator \& Intemal Halt

|  | Internal <br> Halt | No (RAM contents are <br> not kept by reset) | No (RAM contents are <br> kept by reset) |
| :--- | :--- | :--- | :--- |
| Oscillator |  |  | Yes (It is provided only <br> when the crystal for timer exists.) |
| Resistor |  |  |  |
| Ceramic Resonator |  |  |  |
| External Clock |  |  |  |

* Please check one section on the above chart.
(4) Other Options

| I/O State at Halt Mode | $\square$ Enable | $\square$ Disable |  |
| :---: | :---: | :---: | :---: |
| External Crystal for Timer | - Yes | - No | If "Yes", $D_{14}$ and $D_{15}$ become XO and XI for connection of Crystal. Therefore, no I/O option can be selectable. |
| Supply Voltage | - $5 \pm 0.5 \mathrm{~V}$ | - 2.7 to 5.5 V |  |

*Mark " $\sqrt{ }$ " in "口" for the selected I/O state.

## LCD-IV(HD613901)

The LCD-IV is the CMOS 4-bit single chip microcomputer which contains ROM, RAM, I/O, Timer/Event Counter and Control Circuit, Direct Drive Circuit for LCD on single chip. The LCD-IV is designed to drive LCD directly and perform efficient controller function as well as arithmetic function for both binary and BCD data. With the on-chip crystal oscillator for timer, the clock function is easily realized. The CMOS technology of the LCD.IV provides the flexibility of microcomputers for battery powered and battery back-up applications in combination with low power consuming LCD.

- FEATURES
- 4-bit Architecture
- 4,096 Words of Program ROM ( 10 bits/Word)
- 256 Digits of Data RAM and Display Data RAM $(4$ bits/ Digit)
- Control Circuit and Direct Drive Circuit for LCD

4 Commons (Duty Ratio; Static, $1 / 2,1 / 3,1 / 4$ )
32 Segments (Externally expandable up to 96 Segments using external Drivers HD44100Hs)

- 32 I/O Lines and 2 External Interrupt Lines
- Timer/Event Counter
- All Instructions except One Instruction; Single Word and Single Cycle
- BCD Arithmetic Instructions
- Pattern Generation Instruction
- Table Look Up Capability -
- Powerful Interrupt Function

3 Interrupt Sources

- 2 External Interrupt Lines

Timer/Event Counter
Multiple Interrupt Capability

- Bit Manipulation Instructions for Both RAM and I/O
- Option of I/O Configuration Selectable on Each Pin; Pull Up MOS or CMOS or Open Drain
- Built-in Oscillator for System Clock (Resistor or Ceramic Filter)
- Built-in Crystal Oscillator for Timer
- Low Operating Power Dissipation
- Stand-by Mode (Halt Mode)
- 2 Versions; - $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, 5 \mu$ s Instruction Cycle Time
- $V_{C C}=2.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, 20 \mu \mathrm{~s}$ Instruction Cycle Time

LCD-IV

(FP-80)

## - PIN ARRANGEMENT



(Top View)

- BLOCK DIAGRAM



## LCD-IV

- ELECTRICAL CHARACTERISTICS (Vcc $=\mathbf{5 V} \pm 10 \%$ )
- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{Vcc}_{\mathrm{cc}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage (1) | $\mathrm{V}_{\mathrm{T} 1}$ | -0.3 to $\mathrm{Vcc}+0.3$ | V |  |
| Maximum Total Output Current (1) | $-\Sigma \mathrm{I}_{\mathrm{o} 1}$ | 25 | mA | (Note 3) |
| Maximum Total Output Current (2) | $\Sigma \mathrm{I}_{\mathrm{O} 2}$ | 25 | mA | (Note 3) |
| Operating Temperature | $\mathrm{T}_{\mathrm{opr}}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(NOTE) 1. Stresses above those listed under "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. Normal operation should be limited to those conditions specified under "ELECTRICAL CHARACTERISTICS -1 " and " -2 ". The use beyond these conditions may cause LSI's malfunction and at the same time affects device reliability.
2. All voltages are with respect to GND.
3. Maximum Total Output Current is the total sum of output currents which can flow out or in simultaneously.
4. Power supply condition $\mathrm{V}_{\mathrm{CC}} \geqq \mathrm{V} 1 \geqq \mathrm{~V} 2 \geqq \mathrm{~V} 3 \geqq$ GND should be maintained.

- ELECTRICAL CHARACTERISTICS $\mathbf{- 1}\left(\mathrm{V}_{\mathrm{CC}}=\mathbf{5 V} \pm \mathbf{1 0} \%, \mathrm{Ta}=\mathbf{- 2 0}\right.$ to $\left.+\mathbf{7 5}{ }^{\circ} \mathrm{C}\right)$

| Item | Symbol | Test Conditions | Value |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |  |
| Input "Low" Voltage | $\mathrm{V}_{\text {IL }}$ |  | - | 1.0 | V |  |
| Input "High" Voltage | $\mathrm{V}_{\text {IH }}$ |  | V cc-1.0 | Vcc | V | (12) |
| Output "Low" Voltage | VOL | $\mathrm{IOL}=1.6 \mathrm{~mA}$ | - | 0.8 | V |  |
| Output "High" Voltage (1) | $\mathrm{VOH}^{\prime}$ | $-1 \mathrm{OH}=1.0 \mathrm{~mA}$ | 2.4 | - | V | (1) |
| Output "High" Voltage (2) | Voh2 | $-\mathrm{IOH}=0.01 \mathrm{~mA}$ | Vcc-0.3 | - | V | (2) |
| Driver Voltage Descending (COM) | V d1 | $1 \mathrm{~d}=0.05 \mathrm{~mA}, \mathrm{~V}_{\mathrm{LCD}}=5 \mathrm{~V}$ | - | 0.4 | V | (16) |
| Driver Voltage Descending (SEG) | V d2 | $\mathrm{Id}=0.01 \mathrm{~mA}, \mathrm{~V}_{\mathrm{LCD}}=5 \mathrm{~V}$ | - | 0.4 | V | (16) |
| Dividing Resistor of LCD Power Supply | Rwell |  | 25 | 300 | $k \Omega$ |  |
| Interrupt Input Hold Time | tint |  | $2 \cdot \mathrm{~T}_{\text {inst }}$ | - | $\mu \mathrm{s}$ | (14) |
| Output "High" Current | IOH | $\mathrm{VOH}=10 \mathrm{~V}$ | - | 4 | $\mu \mathrm{A}$ | (3) |
| Input Leakage Current | IIL | $\mathrm{V}_{\text {in }}=0$ to V cc | - | 2 | $\mu \mathrm{A}$ | (4), (12) |
| Pull up MOS Current | -Ip | $\mathrm{Vcc}=5 \mathrm{~V}$ | 45 | 250 | $\mu \mathrm{A}$ |  |
| Supply Current (1) | Icc1 | $\begin{aligned} & V_{\text {in }}=V_{c c}, V_{c c}=5 \mathrm{~V} \\ & \text { Ceramic Filter Oscillation } \\ & \text { (fosc }=800 \mathrm{kHz} \text { ) } \end{aligned}$ | - | 3 | mA | (5) |
| Supply Current (2) | Icc2 | $\begin{aligned} & V_{\text {in }}=V_{c c}, V_{c c}=5 \mathrm{~V} \\ & R_{f} \text { Oscillation } \\ & \text { (fosc }=800 \mathrm{kHz} \text { ) } \\ & \text { External Clock Operation } \\ & \text { (fcp }=800 \mathrm{kHz} \text { ) } \end{aligned}$ | - | 2 | mA | (5) |
| Standby I/O Leakage Current | ILS | $\overline{\mathrm{HLT}}=1.0 \mathrm{~V}, \mathrm{~V}_{\text {in }}=0$ to $\mathrm{V}_{\mathrm{CC}}$ | - | 1.0 | $\mu \mathrm{A}$ | (6),(12) |
| Standby Supply Current (1) | Iccs1 | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{cc}}, \overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | - | 10 | $\mu \mathrm{A}$ | (15) |
| Standby Supply Current (2) | Iccs2 | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{cc}}, \overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ | - | 120 | $\mu \mathrm{A}$ | (7) |
| LCD Display Voltage | VLCD | $\mathrm{VCC} \mathrm{V}_{3}$ | 2.5 | Vcc | V | (11) |
| Frame Frequency of LCD Drive | ${ }^{\text {f }}$ | $\begin{aligned} & n=1 \text { (static) } \\ & n=2(1 / 2 \text { Duty) } \\ & n=3(1 / 3 \text { Duty) } \\ & n=4(1 / 4 \text { Duty }) \end{aligned}$ | $\overline{256 \times n}$ | Tinst | Hz | (13) |

External Clock Operation; System Clock

| External Clock Frequency | $\mathrm{fcp}^{\text {c }}$ |  | 130 | 1,000 | kHz | (8), (13) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| External Clock Duty | Duty |  | 45 | 55 | \% | (8) |
| External Clock Rise Time | trep |  | 0 | 0.2 | $\mu \mathrm{s}$ | (8) |
| External Clock Fall Time | tfpp |  | 0 | 0.2 | $\mu \mathrm{s}$ | (8) |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{fcp}$ | 4.0 | 31.3 | $\mu \mathrm{s}$ | (8) |

Internal Clock Operation (Rf Oscillation); System Clock

| Clock Oscillation Frequency | fosc | $\mathrm{R}_{\mathrm{f}}=62 \mathrm{k} \Omega \pm 2 \%$ | 600 | 1,000 | kHz | (9) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{fosc}$ | 4.0 | 6.7 | $\mu \mathrm{s}$ | (9) |
| Internal Clock Operation (Ceramic Filter Oscillation); System Clock |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | Ceramic Filter | 784 | $8 \overline{16}{ }^{-}$ | $\overline{\mathrm{k}} \overline{\mathrm{Hz}}$ | (10) |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{fosc}$ | 4.9 | 5.1 | $\mu \mathrm{s}$ | (10) |

(NOTE) All voltages are with respect to GND.

- ELECTRICAL CHARACTERISTICS - $\mathbf{2}$ ( $\mathbf{T a}=\mathbf{- 2 0}$ to $\mathbf{+ 7 5}{ }^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions |  |  | Value |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | min. | max. |  |  |
| Halt Duration Voltage | VDH | $\overline{\mathrm{HLT}}=0.2 \mathrm{~V}$ |  |  | 2.3 | - | V | (17) |
| Halt Current | IDH | $\begin{aligned} & V_{\text {in }}=V_{c c}, \overline{H L T}=0.2 \mathrm{~V}, \\ & V_{D H}=2.3 \mathrm{~V} \end{aligned}$ |  |  | - | 4.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \hline(17), \\ & (19) \\ & \hline \end{aligned}$ |
| Halt Delay Time | thD |  |  |  | 100 | - | $\mu \mathrm{s}$ | (17) |
| Operation Recovery Time | trc |  |  |  | 100 | - | $\mu \mathrm{s}$ | (17) |
| HLT Fall Time | tfhlt |  |  |  | - | 1000 | $\mu \mathrm{s}$ | (17) |
| HLT Rise Time | trict |  |  |  | - | 1000 | $\mu \mathrm{s}$ | (17) |
| HLT "Low' Hold Time | thit |  |  |  | 400 | - | $\mu \mathrm{s}$ | (17) |
| HLT "High" Hold Time | topr | $\mathbf{R f}_{\mathrm{f}}$ Oscillation, External Clock Operation |  |  | 100 | - | $\mu \mathrm{s}$ | (17) |
|  |  | Ceramic Filter Oscillation |  |  | 4000 | - |  |  |
| RESET Pulse Width (1) | trst1 | $\mathrm{R}_{\mathrm{f}}$ Oscillation, External Clock Operation |  |  | 5 | - | ms | (18) |
|  |  | Ceramic Filter Oscillation |  |  | 20 | - |  |  |
| RESET Pulse Width (2) | trst2 | External Reset, <br> $\overline{\mathrm{HLT}}=\mathrm{Vcc}$ <br> $V_{C C}=4.5$ <br> to 5.5 V | Prescaler Clock = System Clock |  | 2. Tinst |  | $\mu \mathrm{s}$ | (18) |
|  |  |  | Prescaler clock $=\mathrm{D}_{15} /$ XI clock | Not clear Prescaler with Reset signal | $2 \cdot T_{\text {inst }}$ | - |  |  |
|  |  |  | $\begin{aligned} & \left(32 \times 10^{6} /\right. \\ & \left.f_{\text {osce }}\right) \end{aligned}$ | Clear Prescaler with Reset signal | $\begin{gathered} 32 \times 10^{6} / \\ \text { foscx } \end{gathered}$ | - |  |  |
| RESET Rise Time | trRST | External Reset, $\overline{\mathrm{HLT}}=\mathrm{Vcc}$, $\mathrm{VCC}=4.5$ to 5.5 V |  |  | - | 100 | $\mu \mathrm{s}$ | (18) |
| RESET Fall Time | tfrst | External Reset, $\overline{\mathrm{HLT}}=\mathrm{Vcc}$,$\mathrm{VCC}=4.5 \text { to } 5.5 \mathrm{~V}$ |  |  | - | 100 | $\mu \mathrm{s}$ | (18) |

(NOTE) 1. Applied to PMOS load of CMOS output pins and CMOS I/O common pins among D and R terminals.
2. Applied to CMOS output pins, CMOS I/O common pins, input pins with pull up MOS, and I/O common pins with pull up MOS among $D$ and $R$ terminals.
3. Applied to open-drain output pins and open-drain I/O common pins among $D$ and $R$ terminals.
4. Pull up MOS current is excluded.
5. Applied to the supply current when the LCD-IV is in the reset state and the crystal oscillation for timer doesn't operate. (Current that flows in the input/output circuit and in the power supply circuit for LCD-is excluded).

Test Condition: RESET, HLT, TEST $=\mathrm{VCC}_{\mathrm{Cl}}$ (Reset State)

$$
\begin{aligned}
& \text { RESET, HLT, TEST }=V_{C C} \text { (Reset State) } \\
& \text { INT }, \text { INT }, R_{00} \text { to } R_{33}, D_{9} \text { to } D_{13}=V_{C C} \\
& D_{14} / X O, D_{15} / X I-\quad-D_{14} / X O, D_{15} / X I=V_{C C}(C r y s t a l \\
& V_{1}, V_{2}, V_{3}=V_{C C}
\end{aligned} D_{14} / \times O=\text { Open, } D_{15} / X I=V_{C C} \text { (Crystal oscillation for timer is selecte } .
$$

$$
\mathrm{COM}_{1} \text { to } \mathrm{COM}_{4}, \text { SEG } 1 \text { to } \mathrm{SEG}_{32}=\text { Open }
$$

When the crystal oscillation for timer operates, the standby supply current (2) ICCS2 flows in addition to ICC1 or ICC2. When the LCD-IV is installed in the user's system, and in operation current increases according to the external circuitry and devices. Those are connected to the LCD-IV. User should design the power supply in consideration of this point (The difference between the measured current in the above reset state and that measured in the operational state in the user's system is the increased part of the supply current).
6. Standby I/O leakage current is the leakage current of I/O pins in the "Halt" and "Disable" state.
7. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current (2) is the supply current at $\mathrm{VCC}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ in "Halt" state in the case that the crystal osciflation for timer is selected (only the crystal oscillator for timer, 5 -bit divider and 6 -bit prescaler are in operation).
8. Applied to external clock operation (system clock).


$$
\text { Duty }=\frac{T_{1}}{T_{h}+T_{1}} \times 100 \%
$$

9. Applied to internal clock operation using resistor $\boldsymbol{R}_{\mathrm{f}}$. (system clock)


Wiring of OSC ${ }_{1}$ and OSC $_{2}$ terminals should be as short as possible because the oscillation frequency is modified by capacitance of these terminals.
10. Applied to internal clock operation using ceramic filter. (system clock)
11. Power supply condition $V C C \geq V_{1} \geq V_{2} \geq V_{3} \geq$ GND should be maintained
12. Applied to input pins, I/O common pins among $D$ and $R$ terminals, and RESET, HLT, OSC 1, INT $0, I N T$, pins.
13. Lower limit of operation frequency is determined by liquid crystal display duty. Flutter occurs on liquid crystal display if frame frequency is under 32 Hz . Therefore operation frequency should be determined to prevent that frame frequency becomes under 32 Hz .
The following shows the relation between liquid crystal display frame frequency and operation frequency.

14. INT $T_{0}$ and $\mathrm{INT}_{1}$ inputs must be retained for two or more instruction cycle time at both "High" and "Low" levels.

15. Power supply circuit for LCD is excluded. The standby supply current (1) is the supply at Vcc $=5 \mathrm{~V} \pm 10 \%$ in "Halt" state in the case that the crystal oscillation for timer is not selected. The supply current when supply voltage falls to the Halt Duration Voltage is called "Halt Current" (IDH). (shown in ELECTRICAL CHARACTERISTICS-2)
16. The voltage that drops between the power supply terminals $\left(\mathbf{V c c}, \mathrm{V}_{1}, \mathrm{~V}_{2}, \mathrm{~V}_{3}\right)$ and each common or segment output terminal. 17. External Halt Timing Chart

18. RESET Input Condition


- RRST $_{1}$ includes the time that required from the power ON until the operation gets into the constant state.
- tRST $_{2}$ is applied when the operation is in the constant state.

Reset circuit at power on is not installed. Simple reset circuit at power on is the following.

19. The supply current at $V_{C C}=V_{D H}=2.3 V$ in "Halt" state, in the case that the crystal oscillation for timer is not selected. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded.

- ELECTRICAL CHARACTERISTICS (VcC = $\mathbf{2 . 5}$ to 5.5V)
- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | Vcc | -0.3 to +7.0 | V |  |
| Terminal Voltage | $V_{T 1}$ | -0.3 to Vcc +0.3 | $\checkmark$ |  |
| Maximum Total Output Current (1) | - 5101 | 25 | mA | (Note 3) |
| Maximum Total Output Current (2) | Slo2 | 25 | mA | (Note 3) |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(NOTE) 1. Stresses above those listed under "ABSOLUTE MAXIMUM RATINGS" may cause permanent damage to the device. Normal operation should be limited to those conditions specified under "ELECTRICAL CHARACTERISTICS -1 " and " -2 ". The use beyond these conditions may cause LSI's malfunction and at the same time affects device reliability.
2. All voltages are with respect to GND.
3. Maximum Total Output Current is the total sum of output currents which can flow out or in simultaneously.
4. Power supply condition $\mathrm{V}_{\mathrm{CC}} \geqq \mathrm{V} 1 \geqq \mathrm{~V} 2 \geqq \mathrm{~V} 3 \geqq \mathrm{GND}$ should be maintained.

## - ELECTRICAL CHARACTERISTICS - 1 ( $\mathrm{VCC}=\mathbf{2 . 5}$ to $5.5 \mathrm{~V}, \mathrm{Ta}_{\mathrm{a}}=\mathbf{- 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions | Value |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |  |
| Input "Low" Voltage | $V_{\text {IL }}$ |  | - | 0.15.Vcc | V |  |
| Input "High" Voltage | $\mathrm{V}_{\mathrm{IH}}$ |  | $0.85 . \mathrm{Vcc}$ | Vcc | V | (11) |
| Output "Low" Voltage | VOL | $\mathrm{IOL}=0.4 \mathrm{~mA}$ | - | 0.4 | V |  |
| Output "High" Voltage (1) | VOH 9 | $-1 \mathrm{OH}=0.08 \mathrm{~mA}$ | $\mathrm{Vcc}-0.5$ | - | V | (1) |
| Output "High" Voltage (2) | VOH2 | $-\mathrm{IOH}=0.01 \mathrm{~mA}$ | $\mathrm{Vcc}-0.4$ | - | V | (2) |
| Driver Voltage Descending (COM) | Vd1 | $1 \mathrm{~d}=0.05 \mathrm{~mA}$ | - | 0.5 | V | (15) |
| Driver Voltage Descending (SEG) | Vd2 | $1 \mathrm{~d}=0.01 \mathrm{~mA}$ | - | 0.5 | V | (15) |
| Dividing Resistor of LCD Power Supply | Rwell |  | 25 | 300 | $\mathrm{k} \Omega$ |  |
| Interrupt Input Hold Time | tint |  | 2• $\mathrm{T}_{\text {inst }}$ | - | $\mu \mathrm{s}$ | (13) |
| Output "High" Current | IOH | $\mathrm{VOH}_{\text {c }}=\mathrm{V}_{\text {cc }}$ | - | 4 | $\mu \mathrm{A}$ | (3) |
| Input Leakage Current | IIL | $\mathrm{V}_{\text {in }}=0$ to Vcc | - | 2 | $\mu \mathrm{A}$ | (4), (11) |
| Pull up MOS Current | -IP | $\mathrm{Vcc}=3 \mathrm{~V}$ | 10 | 100 | $\mu \mathrm{A}$ |  |
| Supply Current | Icc | $V_{\text {in }}=V c c, V c c=3 V$ <br> $\mathrm{R}_{\mathrm{f}}$ Oscillation $\text { (fosc }=200 \mathrm{kHz} \text { ) }$ <br> External Clock Operation $\left(f_{c p}=200 \mathrm{kHz}\right)$ | - | 0.3 | mA | (5) |
| Standby I/O Leakage Current | ILS | $\overline{\mathrm{HLT}}=0.5 \mathrm{~V}, \mathrm{~V}$ in $=0$ to Vcc | - | 1 | $\mu \mathrm{A}$ | (6), (11) |
| Standby Supply Current (1) | Iccs1 | $\begin{aligned} & V_{\text {in }}=V_{c c}, \overline{\mathrm{HLT}}=0.1 \mathrm{~V}, \\ & V_{c c}=2.5 \text { to } 3.3 V \end{aligned}$ | - | 6 | $\mu \mathrm{A}$ | (14) |
| Standby Supply Current (2) | ICcs2 | $\begin{aligned} & \mathrm{Vin}_{\mathrm{V}}=\mathrm{Vcc}, \overline{\mathrm{HLT}}=0.1 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{cc}}=2.5 \text { to } 3.3 \mathrm{~V} \end{aligned}$ | - | 50 | $\mu \mathrm{A}$ | (7) |
| LCD Display Voltage | V LCD | $\mathrm{Vcc}-\mathrm{V}_{3}$ | 2.5 | Vcc | V | (10) |
| Frame Frequency of LCD Drive | ${ }^{\text {f }}$ | $\begin{aligned} & n=1 \text { (static) } \\ & n=2(1 / 2 \text { Duty) } \\ & n=3(1 / 3 \text { Duty) } \\ & n=4(1 / 4 \text { Duty }) \end{aligned}$ | $\overline{256 x}$ | Tinst | Hz | (12) |
| External Clock Operation; System Clock |  |  |  |  |  |  |
| External Colock $\overline{\text { Frequency }}$ - | ${ }^{-} \overline{f r p}^{-}{ }^{-}$ |  | 130 | 300 | k Hz | (8). $)^{-12)^{-}}$ |
| External Clock Duty | Duty |  | 45 | 55 | \% | (8) |
| External Clock Rise Time | trep |  | 0 | 0.2 | $\mu \mathrm{s}$ | (8) |
| External Clock Fall Time | tfep |  | 0 | 0.2 | $\mu \mathrm{s}$ | (8) |
| Instruction Cycle Time | Tinst | $\mathrm{T}_{\text {inst }}=4 / \mathrm{fcp}$ | 13.3 | 31.3 | $\mu \mathrm{s}$ | (8) |
| Internal Clock Operation (Rf Oscillation); System Clock |  |  |  |  |  |  |
| Clock Oscillation Frequency | fosc | $R_{f}=270 \mathrm{k} \Omega \pm 2 \% \quad \mathrm{VCC}^{2}=2.5 \text { to } 3.5 \mathrm{~V} \mid$ | 130 | 270 | kHz | (9) |
| Instruction Cycle Time | Tinst | ${ }_{\text {inst }}=4 / \mathrm{fosc}$  <br>  $V_{\mathrm{CC}}=2.5$ to 3.5 V <br> $=2.5$ to 5.5 V  | 14.8 13.3 | 30.8 | kHz | (9) |

(NOTE) Alt voltages are with respect to GND.

- ELECTRICAL CHARACTERISTICS-2 ( $\mathbf{T a}=\mathbf{- 2 0}$ to $\mathbf{+ 7 5}{ }^{\circ} \mathrm{C}$ )

| Item | Symbol | Test Conditions |  |  | Value |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | min. | max. |  |  |
| Halt Duration Voltage | V DH | $\overline{\text { HLT }}=0.2 \mathrm{~V}$ |  |  | 2.3 | - | V | (16) |
| Halt Current | IDH | $\mathrm{V}_{\text {in }}=\mathrm{V}_{C c}, \overline{\mathrm{HLT}}=0.2 \mathrm{~V}, \mathrm{~V}_{\text {DH }}=2.3 \mathrm{~V}$ |  |  | - | 4.0 | $\mu \mathrm{A}$ | (16), (18) |
| Halt Delay Time | tho |  |  |  | 100 | - | $\mu \mathrm{s}$ | (16) |
| Operation Recovery Time | tric |  |  |  | 100 | - | $\mu \mathrm{s}$ | (16) |
| HLT Fall Time | $\mathrm{t}_{\mathrm{fHLT}}$ |  |  |  | - | 1000 | $\mu \mathrm{s}$ | (16) |
| HLT Rise Time | trict |  |  |  | - | 1000 | $\mu \mathrm{s}$ | (16) |
| HLT "Low" Hold Time | thLT |  |  |  | 400 | - | $\mu \mathrm{s}$ | (16) |
| HLT ''High" Hold Time | topr |  |  |  | 100 | - | $\mu \mathrm{s}$ | (16) |
| RESET Pulse Width (1) | trst 1 | External Reset, $\overline{\mathrm{HLT}}=\mathrm{Vcc}$ |  |  | 10 | - | ms | (17) |
| RESET Pulse Width (2) | trST2 | Prescaler Clock <br> = System Clock |  |  | 2.Tinst | - | $\mu \mathrm{s}$ | (17) |
|  |  | External Reset, <br> HLT=VCC <br> VCC=2.5V <br> to 5.5 V | Prescaler Clock $=D_{15}$ /XI Clock | Not Clear Prescaler with Reset Signal | 2.Tinst |  |  |  |
|  |  |  | $\left(\frac{32 \times 10^{\circ}}{\operatorname{foscx}}\right)$ | Clear <br> Prescaler with Reset Signal | $\frac{32 \times 10^{6}}{\text { foscx }}$ |  |  |  |
| RESET Rise Time | trRST | External Reset, $\mathrm{HLT}=\mathrm{VCC}$$\mathrm{VCC}=2.5 \text { to } 5.5 \mathrm{~V}$ |  |  | - | 100 | $\mu \mathrm{s}$ | (17) |
| RESET Fall Time | tfRST | $\begin{aligned} & \text { External Reset, } \overline{\text { HLT }}=\mathrm{Vcc} \\ & \mathrm{VCC}=2.5 \text { to } 5.5 \mathrm{~V} \end{aligned}$ |  |  | - | 100 | $\mu \mathrm{s}$ | (17) |

(NOTE) 1. Applied to PMOS load of CMOS output pins and CMOS I/O common pins among D and R terminals.
2. Applied to CMOS output pins, CMOS I/O common pins, input pins with pull up MOS, and I/O common pins with pull up MOS among D and $R$ terminals.
3. Applied to open-drain output pins and open-drain I/O common pins among $D$ and $R$ terminals.
4. Pull up MOS current is excluded.
5. Applied to the supply current when the LCD-IV is in the reset state and the crystal oscillation for timer doesn't operate. (Current that flows in input/output circuit and in the power supply circuit for LCD is excluded).

Test Condition: RESET, HLT $=$ VCC (Reset State)

$$
\begin{aligned}
& D_{14} / X O, D_{15} / X 1 \quad D_{14} / X O, D_{15} / X 1=V_{C C} \text { (Crystal oscillation for timer is not selected.) } \\
& V_{1}, V_{2}, V_{3}=V_{C C} \quad D_{14} / X O=\text { Open, } D_{15} / X I=V_{C C} \text { (Crystal oscillation for timer is selected.) }
\end{aligned}
$$

$\mathrm{COM}_{1}$ to $\mathrm{COM}_{4}, \mathrm{SEG}_{1}$ to $\mathrm{SEG}_{32}=$ Open
When the crvstal oscillation for timer operates, the standby supply current (2) ICCS2 flows in addition to ICC.
When the LCD-IV is installed in the user's system, and in operation current increases according to the external circuitry and devices. Those are connected to the LCD-IV. User should design the power supply in consideration of this point. (The difference between the measured current in the above reset state and that measured in the operational state in the user's system is the increased part of the supply current).
6. Standby I/O leakage current is the leakage current of I/O pins in the "Halt" and "Disable" state.
7. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current (2) is the supply current at $\mathrm{VCC}=2.5$ to 3.3 V in "Halt" state in the case that the crystal oscillation for timer is selected (only the crystal oscillator for timer, 5 -bit divider and 6 -bit prescaler are in operation).
8. Applied to external clock operation. (system clock)

9. Applied to internal clock operation using resistor $\mathbf{R}_{\mathbf{f}}$. (System Clock)


Wiring of $\mathrm{OSC}_{1}$ and $\mathrm{OSC}_{2}$ terminals should be as short as possible because the oscillation frequency is modified by capacitance of these terminals.
10. Power supply condition $V_{C C} \geq V_{1} \geq V_{2} \geq V_{3} \geq G N D$ should be maintained.
11. Applied to input pins, I/O common pins among $\bar{D}$ and $R$ terminals, and RESET, $\overline{H L T}, O_{1} C_{1}, I N T_{0}, I N T_{1}$ pins.
12. Lower limit of operation frequency is determined by liquid crystal display duty. Flutter occurs on liquid crystal display if frame frequency is under 32 Hz . Therefore operation frequency should be determined to prevent that frame frequency becomes under 32 Hz .
The following shows the relation between liquid crystal display frame frequency and operation frequency.

13. INT $T_{0}$ and $I N T_{1}$ inputs must be retained for two or more instruction cycle time at both "High" and "Low" levels:

14. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded. The standby supply current (1) is the supply at $\mathrm{V}_{\mathrm{CC}}=\mathbf{2 . 5}$ to $\mathbf{3 . 3 V}$ in "Halt" state in the case that the crystal oscillation for timer is not selected. The supply current when supply voltage fails to the Halt Duration Voltage is called."Halt Current" (IDH). (shown in ELECTRICAL CHARACTERISTICS -2).
15. The voltage that drops between the power supply terminals ( $\mathrm{V}_{\mathrm{Cc}}, \mathrm{V}_{1}, \mathrm{~V}_{2}, \mathrm{~V}_{3}$ ) and each common or segment output terminal.
16. External Hait Timing Chart

17. RESET Input Condition


- RRST $_{1}$ includes the time required from the power ON until the operation gets into the constant state.
- tRST ${ }_{2}$ is applied when the operation is in the constant state.

Reset circuit at power on is not installed. Simple reset circuit at power on is the following.

18. The supply current at $V C C=V D H=2.3 V$ in "Hait" state, in the case that the crystal oscillation for timer is not selected. Current that flows in the input/output circuit and in the power supply circuit for LCD is excluded.

## - SIGNAL DESCRIPTION

The input and output signals for the LCD-IV shown in PIN ARRANGEMENT are described in the following paragraphs.

Vcc and GND
Power is supplied to the LCD-IV using these two pins. $\mathrm{V}_{\mathrm{CC}}$ is power and GND is the ground connection.

## - RESET

The LCD-IV can be reset by pulling RESET High.
Refer to RESET FUNCTION for additional information.

## - OSC $_{1}$ and OSC $_{2}$

These pins provide control input for the on-chip clock oscillator circuit. A resistor, a ceramic filter circuit, or an external oscillator can be connected to these pins to provide a system clock with various degreeds of stability/cost trade-offs. Lead length and stray capacitance on these two pins should be minimized.

Refer to OSCILLATOR for recommendations about these
pins.

- $\overline{\mathrm{HLT}}$

This pin is used to place the LCD-IV in the HALT state (Stand-by Mode). The LCD-IV can be moved into the halt state by pulling HLT low.

In the halt state the internal clock stops and all the internal status (RAM, Registers, Carry, Status, Program Counter, and all the internal statuses) are maintained. Consequently power consumption is greatly reduced. By pulling HLT high, the LCD-IV starts operation from the status just before the halt state.

Refer to HALT FUNCTION for details of halt mode.

- TEST

This pin is not for user application and must be connected to $\mathrm{V}_{\mathrm{CC}}$.

- INT $_{0}$ and INT $_{1}$

These pins provide the capability for asynchronously apply.
ing an external interrupt to the LCD-IV.
Refer to INTERRUPTS for additional information.

- $V_{1}, V_{2}$ and $V_{3}$

Power for liquid crystal display are supplied to the LCD-IV using these pins ( $\mathrm{V}_{\mathrm{CC}} \geqq \mathrm{V}_{1} \geqq \mathrm{~V}_{2} \geqq \mathrm{~V}_{3} \geqq \mathrm{GND}$ ).

## - Roo to Ros

These 4 lines are a 4-bit input channel.
Refer to INPUT/OUTPUT for additional information.

## - $\mathbf{R}_{10}$ to $\mathbf{R}_{13}, \mathbf{R}_{20}$ to $\mathbf{R}_{23}$

These 8 lines are arranged into two 4 -bit Input/Output common channels.

The 4-bit register is attached to this channel. This channel is directly addressed by the operand of an instruction. I/O configuration of each pin can be specified among Open Drain and CMOS using a mask option.

Refer to INPUT/OUTPUT for additional information.

## - R30 to R33

These 4 lines are a 4 -bit output channel.
4-bit register is attached to this channel. This channel is directly addressed by the operand of an instruction. I/O configuration of each pin can be specified among Open Drain and CMOS using a mask option.

Refer to INPUT/OUTPUT for additional information.

## - Do to $D_{13}$

These are 14 discrete signals which can be configured as Input/Output lines.

Refer to INPUT/OUTPUT for additional information.

- $D_{14} / X O, D_{15} / X I$
$\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ require a mask option in the following 3 types.
- Discrete I/O (common terminal)
- Crystal circuit connecting terminals (with internal halt)
- Crystal circuit connecting terminals (no internal halt)

Refer to INPUT/OUTPUT for additional information.

- $\mathrm{COM}_{1}$ to COM4

These pins are common terminals for liquid crystal display.
Refer to LIQUID CRYSTAL DISPLAY for additional information.

## - $\mathbf{S E G}_{1}$ to $\mathbf{S E G}_{32}$

These pins are segment terminals for liquid crystal display.

## - OSCILLATOR

The user can specify a resistor, or a ceramic filter circuit or an external oscillator by "MASK OPTION LIST".
(1) External Clock

(2) Resistor

(3) Ceramic Filter (This is not applied to Low Voltage Operation Version.)

(NOTE) Configuration and constant of external parts are depend upon each applied ceramic filter.

The ceramic filter oscillation does not apply when using "Halt" and not resetting at time of "Halt" cancellation.
This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefully on your application.

## - ROM

- ROM Address Space

ROM is used as a memory for the instructions and the patterns (constants). The instruction used in the LCD-IV consists of 10 bits. These 10 bits are called "a word", which is a unit for writing into ROM

The ROM address has been split into two banks.
Each bank is composed of 32 pages ( 64 words/page).
The ROM capacity is 4,096 words ( 1 word $=10$ bits) in all.
All addresses can contain both the instructions and the patterns (constants).

The ROM address space is shown in Figure 1.

*Bank 00 Page ( 0 Page) is the Subroutine Space.
Note: The parenthesized contents are expressions of the Page, combining the bank part with the page part.

Figure 1 ROM Address Space

Program Counter (PC)
The program counter is used for addressing of ROM. The


Note: The parenthesized contents are expressions of the Page, combining the bank part with the page part.

Figure 2 Configuration of Program Counter

The bank part is a 1 -bit register and the page part is a 5 -bit register.

Once a certain value is loaded into the bank part or the page part, the content is unchanged until other value is loaded by a program.

The settable value is " 0 " (the Bank 0) or " 1 " (the Bank 1) for the bank part, and 0 to 31 for the page part.

The address part is a 6-bit polynomial counter and counts up for each instruction cycle time. The sequence in the decimal and hexa-decimal system is shown in Table 1. This sequence is circulating and has neither the starting nor ending point. It doesn't generate an overflow carry. Consequently, the program on a same page is executed in order unless the value of the bank part or the page part is changed.

Table 1 Program Counter Address Part Sequence

| Decimal | Hexa- <br> decimal | Decimal | Hexa- <br> decimal | Decimal | Hexa- <br> decimal |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 63 | $3 F$ | 5 | 05 | 9 | 09 |
| 62 | $3 E$ | 11 | $0 B$ | 19 | 13 |
| 61 | $3 D$ | 23 | 17 | 38 | 26 |
| 59 | $3 B$ | 46 | $2 E$ | 12 | $0 C$ |
| 55 | 37 | 28 | $1 C$ | 25 | 19 |
| 47 | $2 F$ | 56 | 38 | 50 | 32 |
| 30 | $1 E$ | 49 | 31 | 37 | 25 |
| 60 | $3 C$ | 35 | 23 | 10 | $0 A$ |
| 57 | 39 | 6 | 06 | 21 | 15 |
| 51 | 33 | 13 | $0 D$ | 42 | $2 A$ |
| 39 | 27 | 27 | $1 B$ | 20 | 14 |
| 14 | $0 E$ | 54 | 36 | 40 | 28 |
| 29 | $1 D$ | 45 | $2 D$ | 16 | 10 |
| 58 | $3 A$ | 26 | $1 A$ | 32 | 20 |
| 53 | 35 | 52 | 34 | 0 | 00 |
| 43 | $2 B$ | 41 | 29 | 1 | 01 |
| 22 | 16 | 18 | 12 | 3 | 03 |
| 44 | $2 C$ | 36 | 24 | 7 | 07 |
| 24 | 18 | 8 | 08 | 15 | $0 F$ |
| 48 | 30 | 17 | 11 | 31 | $1 F$ |
| 33 | 21 | 34 | 22 |  |  |
| 2 | 02 | 4 | 04 |  |  |

## - Designation of ROM Address and ROM Code

The bank part of the ROM address is shown in the binary system and the page part in the decimal system. The address part is divided into 2 bits and 4 bits, and shown in the hexadecimal system.

It is possible to combine the bank part and the page part and show the combined part as the Page (in the decimal system).

In this case, the 0 Page to the 31 Page in the Bank 1 are shown as the 32 Page to the 63 Page. The examples are shown in Figure 3.

One word ( 10 bits) of ROM is divided into three parts ( 2 bits, 4 bits and 4 bits from the most significant bit $\mathrm{O}_{10}$ in order) shown in the hexa-decimal system. The examples are shown in Figure 3.
(a) ROM Address
(Example 1)

(Example 2)

(b) ROM Code
(Example 1)

(Example 2)


Figure 3 Designation of ROM Address and ROM Code

## - PATTERN GENERATION

The pattern (constant) can be accessed by the pattern instruction ( $\mathbf{P}$ ). The pattern can be written in any address of the ROM address space.

## - Reference

ROM addressing for reference of the patterns is achieved by modifying the program counter with the accumulator, the B register, the Carry F/F and the operand p. Figure 4 shows how to modify the program counter. The address part is replaced with the accumulator and the lower 2 bits of $B$ register, while the page part and the bank part are ORed with the upper 2 bits of B register, the Carry F/F and the operand $p$.

The value of the operand $p\left(p_{2}, p_{1}, p_{0}\right)$ is 0 to 7 (decimal).
The bank part of the ROM address to be referenced to is determined by the logical equation: $\mathrm{PC}_{11}+\mathrm{P}_{\mathbf{2}}$ ( $\mathrm{p}_{\mathbf{2}}=$ the MSB of the operand p ).

If the address where the pattern instruction exists is in the Bank 1, only the pattern of the Bank 1 can be referenced.

If the address where the pattern instruction exists is in the Bank 0, the pattern of the either Bank 1 or Bank 0 can be referenced depending on the value of $p_{2}$. The truth table of the bank part of the ROM address is shown in Table 2.

The value of the program counter is apparently modified and does not change actually. After execution of the pattern instruction, the program counter counts up and the next instruction is
executed.
The pattern instruction is executed in 2-cycle time.

## - Generation

The pattern of referred ROM address is generated as the following two ways:
(i) The pattern is loaded into the accumulator and B register.
(ii) The pattern is loaded into the Data I/O Registers R2 and R3.
Selection is determined by the command bits $\left(\mathrm{O}_{9}, \mathrm{O}_{10}\right)$ in the pattern.

Mode (i) is performed when $\mathrm{O}_{9}$ is " 1 " and mode (ii) is performed when $O_{10}$ is " 1 ".

Mode (i) and (ii) are simultaneously performed when both $\mathrm{O}_{9}$ and $\mathrm{O}_{10}$ are " 1 ". The correspondence of each bit of the pattern is shown in Figure 5.

Examples of the pattern instruction is shown in Table 3.

## CAUTION

In the program execution, the pattern can not be distinguished from the instruction. When the program is executed at the addresses into which pattern is written, the instruction corresponding to the pattern bit is executed. Take care that a pattern is not executed as an instruction.


Figure 4 ROM Addressing for Pattern Generation

Table 2 Bank Part Truth Table of Pattern Generation

| PC $_{11}$ | $P_{2}$ | Bank part of ROM address <br> to be referenced to |
| :---: | :---: | :---: |
| 1 (Bank 1) | 1 | 1 (Bank 1) |
|  | 0 | 1 (Bank 1) |
| 0 (Bank 0) | 1 | 1 (Bank 1) |
|  | 0 | $0($ Bank 0) |



Figure 5 Correspondence of Each Bit of Pattern

Table 3 Example of Pattern Instructions

| Before Execution |  |  |  |  | Referred ROM Address | ROM Pattern | After Execution |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PC | p | C | B | A |  |  | B | A | R2 | R3 |
| $\begin{gathered} \text { Bank } 00.3 F \\ (0.3 F) \end{gathered}$ | 1 | 0 | A | 0 | $\begin{gathered} \text { Bank } 0 \text { 10-20 } \\ (10-20) \end{gathered}$ | 12D | 2 | B | - | -* |
| $\begin{gathered} \text { Bank } 00.3 F \\ (0-3 F) \end{gathered}$ | 7 | 1 | 4 | 0 | $\begin{gathered} \text { Bank } 129.00 \\ (61.00) \end{gathered}$ | 22D | - | - | 4 | B |
| $\begin{gathered} \hline \text { Bank } 130.00 \\ (62.00) \end{gathered}$ | 4 | 0/1** | 0 | 9 | $\begin{gathered} \hline \text { Bank } 130-09 \\ (62.09) \\ \hline \end{gathered}$ | 32D | 2 | B | 4 | B |
| $\begin{gathered} \text { Bank } 130-00 \\ (62-00) \\ \hline \end{gathered}$ | 1 | 0/1** | F | 9 | $\begin{gathered} \hline \text { Bank } 131-39 \\ (63-39) \\ \hline \end{gathered}$ | 223 | - | - | 4 | C |

[^4]
## - BRANCH

ROM is accessed according to the program counter sequence and the program is executed. In order to jump to any address out of the sequence, there are four ways. They are explained in the following paragraphs.

## - BR

By BR instruction, the program branches to an address in the current page.

The lower 6 bits of ROM Object Code (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) are transferred to the address part of the program counter. This instruction is a conditional instruction and executed only when the Status $F / F$ is " 1 ". If it is " 0 ", the instruction is skipped and the Status $\mathrm{F} / \mathrm{F}$ becomes " 1 ". The operation is shown in Figure 6. - LPU

By LPU instruction, the jump of the bank and page is performed.

The lower 5 bits of the ROM Object Code (operand $u, \mathrm{O}_{5}$ to $\mathrm{O}_{1}$ ) are transferred to the page part of the program counter with a delay of 1 instruction cycle time. At the same time, the signal $\overline{\mathbf{R}_{\mathbf{7}}}$ (the reversed-phase signal of the Data I/O Register $\mathrm{R}_{70}$ ) is transferred to the bank part of the program counter with a delay of 1 instruction cycle time. The operation is shown in Figure 7.

Consequently, the bank and page will remain unchanged in the cycle immediately following this instruction. In the next cycle, a jump of the bank and page is achieved.

This instruction (LPU) is conditional, and is executed only when the Status F/F is " 1 ". Even after a skip, the Status $\mathrm{F} / \mathrm{F}$
will remain unchanged (" 0 ").
LPU instruction is used in combination with BR instruction or CAL instruction as the macro instruction of BRL or CALL instruction.

- BRL

By BRL instruction, the program branches to an address in any bank and page.

This instruction is a macro instruction of LPU and BR instructions, which is divided into two instructions as follows.

$$
\begin{aligned}
& \text { BRL } \quad \mathrm{a}-\mathrm{b}-\text { LPU } \mathrm{BR} \\
& \text { < Jump to Bank " } \overline{R_{70}}{ }^{\prime \prime} \text {, a Page - b Address > }
\end{aligned}
$$

BRL instruction is a conditional instruction because of characteristics of LPU and BR instructions, and is executed only when the Status $F / F$ is " 1 ". If the Status $F / F$ is " 0 ", the instruction is skipped and the Status $\mathrm{F} / \mathrm{F}$ becomes " 1 ". The examples of BRL instruction are shown in Figure 8.

## - TBR (Table Branch)

By TBR instruction, the program branches by the table.
The program counter is modified with the accumulator, the $B$ register, the Carry $F / F$ and the operand $p$.

The method for modification is shown in Figure 9.
The bank part is determined by the logical equation: $\mathrm{PC}_{11}+$ $\mathrm{p}_{2}$, as shown in Table 4.

If the address where TBR instruction exists is in the Bank 1,
it is possible to jump to an address only in the Bank 1, not to an address in the Bank 0.

If the address where TBR instruction exists is in the Bank 0, it is possible to jump to an address in either the Bank 1 or the

Bank 0 depending on the value of the operand $p_{2}$.
TBR instruction is executed regardless of the Status $F / F$, and does not affect the Status $F / F$.


Figure 6 BR Operation


Figure 7 LPU Operation


Figure 8 BRL Example

Table 4 Bank Part Truth Table of TBR Instruction

| PC $_{11}$ | $\rho_{2}$ | Bank Part of PC after <br> TBR |
| :---: | :---: | :---: |
| 1 (Bank 1) | 1 | 1 (Bank 1) |
|  | 0 | 1 (Bank 1) |
| 0 (Bank 0) | 1 | 1 (Bank 1) |
|  | 0 | $0($ Bank 0) |

## SUBROUTINE JUMP

There are two types of subroutine jumps. They are explained in the following paragraphs.

## - CAL

By CAL instruction, subroutine jump to the Subroutine Space is performed.

The Subroutine Space is the Bank 00 Page ( 0 Page).
The address next to CAL instruction address is pushed onto the Stack ST1 and the contents of the stacks ST1, ST2 and ST3 are pushed onto the stacks ST2, ST3 and ST4 respectively as shown in Figure 10.

The bank part of the program counter becomes the Bank 0 and the page part becomes the 0 Page. The lower 6 bits (operand a, $\mathrm{O}_{6}$ to $\mathrm{O}_{1}$ ) of the ROM Object Code is transferred to the address part of the program counter.

The LCD-IV has 4 levels of stack (ST1, ST2, ST3 and ST4) which allows the programmer to use up to 4 levels of subroutine
jumps (including interrupts).
CAL is a conditional instruction and executed only when the Status $F / F$ is " 1 ". If the Status $F / F$ is " 0 ", it is skipped and the Status F/F changes to " 1 ".

## - CALL

By CALL instruction, subroutine jump to an address in any bank and page is performed.

Subroutine jump to any address can be implemented by the subroutine jump to the page specified by LPU instruction in the bank designated by the reversed-phase signal $\overline{R_{70}}$.

This instruction is a macro instruction of LPU and CAL instructions, which is divided into two instructions as follows.

$$
\text { CALL } \quad a-b \longrightarrow \text { CPU } a
$$

<Subroutine Jump to Bank " $\overline{R_{70}}$ ", a Page - b Address >
CALL instruction is conditional because of characteristics of LPU and CAL instructions and is executed when the Status F/F is " 1 ". If the Status $F / F$ is " 0 ", the instruction is skipped and the Status F/F changes to " 1 ". The examples of CALL instruction are shown in Figure 11.


Figure 9 Modification of Program Counter by TBR Instruction


Figure 10 Subroutine Jump Stacking Order

Subroutine Jump to Bank 0


Subroutine Jump to Bank 1

| LAI | 0 |  |
| :---: | :---: | :---: |
| r-LRA | 7 | $\mathrm{R}_{70}=$ " 0 " $\left(\overline{R_{70}}={ }^{\prime \prime} 1{ }^{\prime \prime}\right)$ |
| - LPU CAL | $\left.\begin{array}{l} 15 \\ 3 F \end{array}\right\}$ | CALL 15-3F <br> (Subroutine Jump to Bank 1 15-3F (47-3F)) |
| LAI <br> LTA | 0 |  |
| -LRA | 7 | $R_{70}={ }^{\prime \prime} 0^{\prime \prime}\left(\overline{R_{70}}={ }^{\prime \prime} 1{ }^{\prime \prime}\right)$ |
| $\begin{aligned} & \text { LYI } \\ & \text { XMA } \end{aligned}$ | 3 |  |
| $\cdots$ | 10 $\}$ | CALL 10-2E |
| CAL | 2E, | (Subroutine Jump to Bank 1 10-2E (42-2E)) |

Figure 11 CALL Example

(NOTE) The area marked as $\square$ is usable only for data.
The area marked as is usable for both tiquid crystal display and data.

In case of the instructions which consists of a simultaneous Read/Write operations of RAM (exchange of RAM and a register), the writing data doesn't affect the reading data because the read operation is followed by the write operation.

RAM bit manipulation is usable, which performs any bit set (SEM), reset (REM) or test (TM) of the addressed RAM. Bit assignment is made by the program as shown below.


The bit test makes the status " 1 " when the assigned bit is " 1 " and makes it " 0 " when the assigned bit is " 0 "

## - REGISTERS

The LCD-IV has six 4-bit registers and two 1 -bit registers available to the programmer. 1-bit registers are Carry F/F and Status $F / F$. They are explained in the following paragraphs.

- Accumulator (A; A Register) and Carry F/F (C)

The result of ALU operation (4 bits) and the overflow of the ALU are put into the accumulator and Carry F/F. Carry F/F can be set, reset or tested. Combination of the accumulator and Carry F/F can be right or left rotated. The accumulator is the main register for ALU operation and Carry F/F is used to store the overflow generated by ALU operation when the calculation of two or more digits ( 4 bits/digit) is performed.

## - B Register (B)

The result of ALU operation (4 bits) is put into this register. B register is used as a sub-accumulator to stack the data temporarily and also used as a counter.

## - $\mathbf{X}$ Register ( $\mathbf{X}$ )

The result of ALU operation ( 4 bits) is put into this register. $X$ register has exchangeability for SPX register. $X$ register addresses the RAM file.

- SPX Register (SPX)

SPX register has exchangeability for X register.
SPX register is used to stack X register and expand the addressing system of RAM in combination with $\mathbf{X}$ register.

- Y Register (Y)

The result of ALU operation (4 bits) is put into this register. Y register has exchangeability for SPY register. Y register can calculate itself simultaneously with transferring the data by bus lines, which is usable for the calculation of two or more digits ( 4 bits/digit). Y register addresses the RAM digit and 1 -bit discrete input/output common terminals.

- SPY Register (SPY)

SPY register has exchangeability for Y register. SPY register is used to stack Y register and expand the addressing system of RAM and 1 -bit discrete input/output common terminals in combination with Y register.

## - Status F/F (S)

Status F/F latches the result of logical or arithmetic operations (Not Zero, Overflow) and bit test operations. Status F/F affects conditional instructions (LPU, BR and CAL). These instructions are executed only when Status $F / F$ is " 1 ". If it is " 0 ", these instructions are skipped and Status F/F becomes " 1 ".

## - INPUT/OUTPUT

- Discrete I/O (D Terminal)

The discrete $I / O$ is composed of 1 -bit latch and $I / O$ pin. Figure 13 shows the basic block diagram.


Figure 13 Discrete I/O Block Diagram


Figure 14 Mask Option of $D_{14}$ and $D_{15}$ Terminals
$D_{0}$ to $D_{13}$ are discrete $1 / O$ 's of common for input and output, $D_{14}$ and $D_{15}$ require a mask option in 3 types. When the crystal oscillation for timer is selected and the latches of $D_{14}$ and $D_{15}$ are not connected to the terminals, $D_{14}$ and $D_{15}$ can be used as 1 -bit general purpose registers that can be set, reset and tested. Furthermore, if there is internal halt mode, latch of $D_{15}$ is used as a register for internal halt mode specially.

In such case, since $D_{15}$ means internal halt state and $D_{15}=$ " 1 " means operating state, LSI can be in internal halt state by resetting $D_{15}$ using an instruction. The prescaler keeps its operation in internal halt state. Therefore, D ${ }_{15}$ may be set by overflow output pulse from the prescaler to return to operating state. For details of internal halt mode, refer to HALT FUNCTION.

Table 5 Mask Option of $D_{14} / X O$ and $D_{15} / X 1$ Terminals

| Mask Option |  |  | a | b | c | d | Function of $D_{14} / X O \text { and } D_{15} / X I$ | Function of $D_{14} / X O$ and $\mathrm{D}_{15} / \mathrm{XI}$ latch |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Unselectable crystal oscillation for timer (no internal halt) |  | short | open | open | short | discrete I/O (common terminal) | Output Latch |
| 2 | Selectable crystal oscillation for timer | with internal halt | open | short |  |  | Crystal Circuit Connecting Terminal | 1-bit register |
| 3 |  | no internal halt |  |  | short | open |  | $\mathrm{D}_{14}$; 1-bit register <br> $\mathrm{D}_{15}$; register for internal halt |

(NOTE) Users can specify this mask option in "The format of I/O channels" at ROM order.

Discrete $\mathrm{I} / \mathrm{O}$ is addressed by Y register, and the set/reset instruction is executed for the addressed latch. " 0 " and " 1 " level can be tested with the addressed terminal and 1 -bit register against the $I / O$ common pins and 1 -bit register. The test is performed with the wired logic of the output latch and the pin
input. Therefore, in the case of the I/O common pins, the output latch should be in the high impedance state when the test instruction is executed. In order to test the pin input, it is necessary the state that the output latch should not affect the pin input.


Figure 15 Timing Chart of Discrete I/O

## - Data I/O (R Terminal)

Table 6 Data I/O for the LCD-IV

| 1/O common channel | R1, R2 (2 channels) |  |
| :--- | :--- | :---: |
| Input channel | RO $\quad$ (1 channel) |  |
| Output channel | R3 (1 channe!) |  |
| Total | 4 channels |  |

(NOTE) In addition to the above, R4, R5 and R6 are provided as register setting liquid crystal display mode. In these registers, there is no terminal and exists only data I/O register each. which controls liquid crystal display mode. Data is transferred to R4, R5 and R6 by LRA or LRB instruction, same as data transfer to data 1/O registers of R1, R2 and R3. For details of R4, R5 and R6, refer to LIQUID CRYSTAL DISPLAY.


4-bit register (data $1 / \mathrm{O}$ register) each is attached to an I/O common channel and output channel. No register is attached to input channel. Addressing to all channels is performed by programs (addressed by operands in instructions).

Figure 16 shows the block diagram of each channel.


Figure 16 Data I/O Block Diagram

When expansion of segment signal for liquid crystal display is designated by a program (Register $\mathrm{R}_{42}=$ " 0 "), R1 is used as a display data output terminal. This prohibits R1 to be used as an I/O common channel by users (Refer to Figure 16, R1 channel).

If LRA or LRB instruction is executed at the time, data is transferred to data I/O register, but the content of data I/O register is not output from R1. If LAR or LBR instruction is executed, display data is inputted to accumulator (A register) or $B$ register.

Data is transferred from the accumulator (A register) and B
register to data I/O registers $\mathrm{R} 1, \mathrm{R} 2$, and R 3 through the bus line. In addition, ROM bit patterns can be transferred to R2 and R3 by pattern generation instructions.

4-bit data can be inputted to the accumulator (A register) and B register from R0, R1 and R2 channels by input instructions. However, in the case of I/O common channels R2 and R3, since data I/O register outputs are connected to terminals, inputs are done to wired logic of register output and terminal input information. For this reason, to input terminal input signal, registers must be set to a state that would not affect the terminal input.


Figure 17 Data I/O Timing Chart

Pay attention: When executing an input instruction to output channel, the microcomputer reads unstabilized value causing malfunction of the program.

When executing an input instruction (LAR and LBR) from the data $1 / 0$, pay attention to time allowance after executing an output instruction. At the time, the input sampling pulse is generated during the first half of the instruction cycle.


Applied Pins: INTO, INT,$R_{00}$ to $R_{03}$


Figure 18 Configuration of Input Pins
Applied Pins: $\mathbf{R}_{\mathbf{3 0}}$ to $\mathbf{R}_{\mathbf{3 3}}$
No Pull up MOS
CMOS output


Figure 19 Configuration of Output Pins


Figure 20 Configuration of Input/Output Pins

- TIMER/COUNTER


Figure 21 Timer/Counter Block Diagram

Timer/Counter Block Diagram is shown in Figure 21. 5 -bit divider divides the crystal oscillation ( 32.768 kHz ) by 32 and generates clocks of $1,024 \mathrm{~Hz}$ in the crystal oscillation mode. It does not stop in the halt state. Prescaler divides the system clock (instruction frequency) or $1,024 \mathrm{~Hz}$ clock by 64 and generates overflow output pulse of "Instruction frequency/ 64 Hz " or 16 Hz . In the crystal oscillation mode, it does not stop during halt state. The input of the 4 -bit counter is overflow output pulse of the prescaler or a pulse of INT $_{1}$ terminal. Input selection is determined by CF state. Data can be exchanged between the counter and bus by LTI, LTA or LAT instruction. TF is a flip-flop which masks the interrupt of timer/counter.

The timer is operable in 2 modes (timer mode and counter mode) depending on what to count, and the mode is selected by programs.

## - Timer Mode

The 4-bit counter counts prescaler overflow output pulses. One of the following two can be selected as the prescaler count clock by the mask option.

1. System clock (Instruction frequency)
2. $1,024 \mathrm{~Hz}$ clock (Crystal oscillation for timer is selected.) . . Clock obtained by dividing the crystal oscillation ( 32.768 kHz ) for timer by 32. Crystal oscillator is constructed between D
terminals of $D_{14}$ and $D_{15}$ :
Note 1) In this case, the overflow output pulses form the prescaler are 16 Hz . These pulses are counted by the 4 bit counter to generate an interrupt from 16 Hz to 1 Hz .
Note 2) In this case, the part marked with प्ITIX in Figure 21 Timer/Counter does not stop even in halt state. When using "internal halt mode" among the halt function, internal halt state is generated by resetting the register for internal halt mode ( $D$ latch: $D_{15}$ ) by an instruction ( $D_{15}=$ " 0 ": internal halt state, $D_{15}=$ " 1 ": operating state), and all the operation stop. In this case, overflow output pulses from the prescaler work as the signals releasing the internal halt state and set the $D_{15}$ output latch. Therefore, if an overflow output pulse from the prescaler is generated, internal halt state is released, and the LSI starts to operate.
By utilizing this function, intermittent operation is possible, that is, program execution for necessary processing (for example, counting for clock function) starts after every $62.5 \mathrm{msec}(16 \mathrm{~Hz})$ and the LSI stops after execution of this program by an instruction which makes the LSI into internal halt state. This reduces the time in which the LSI operates, resulting in power consumption in substance.


Figue 22 Set/Reset Operation Using Crystal Oscillator for Timer

## - Counter Mode

Counts pulse of $\mathrm{INT}_{1}$ terminal.
(Note) The width of $\mathrm{INT}_{1}$ pulse in the counter mode must be at least 2-cycle time for both the "High" and "Low"
levels.
The relation between the specified value of the counter and specified time in the Timer Mode are shown in Table 7 and 8.

Table 7 Timer Range (Prescaler clock: system clock)

| Specified <br> Value | Number of <br> Cycles | ${ }^{*}$ Time (ms) | Specified <br> Value | Number of <br> Cycles | ${ }^{\text {"Time (ms) }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1,024 | 5.12 | 8 | 512 | 2.56 |
| 1 | 960 | 4.80 | 9 | 448 | 2.24 |
| 2 | 896 | 4.48 | 10 | 384 | 1.92 |
| 3 | 832 | 4.16 | 11 | 320 | 1.60 |
| 4 | 768 | 3.84 | 12 | 256 | 1.28 |
| 5 | 704 | 3.52 | 13 | 192 | 0.96 |
| 6 | 640 | 3.20 | 14 | 128 | 0.64 |
| 7 | 576 | 2.88 | 15 | 64 | 0.32 |

*Time is based on instruction frequency 200 kHz . (One Instruction Cycle Time ( $T_{i n s t}$ ) $=5 \mu \mathrm{~s}$ )

Table 8 Timer Range (Prescaler clock: $1,024 \mathrm{~Hz}$ )

| Specified Value | * Time (ms) | Frequency ( Hz ) | Specified Value | * Time (ms) | Frequency |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1,000 | 1 | 8 | 500 | 2 |
| 1 | 937.5 | 1.07 | 9 | 437.5 | 2.29 |
| 2 | 875 | 1.04 | 10 | 375 | 2.67 |
| 3 | 812.5 | 1.23 | 11 | 312.5 | 3.20 |
| 4 | 750 | 1.33 | 12 | 250 | 4 |
| 5 | 687.5 | 1.45 | 13 | 187.5 | 5.33 |
| 6 | 625 | 1.60 | 14 | 125 | 8 |
| 7 | 562.5 | 1.78 | 15 | 62.5 | 16 |

* Time is based on crystal oscillation for timer 32.768 kHz .


## - INTERRUPT

There are interrupt caused by the timer/counter or the inputs. Each interrupt cause has the interrupt request $F / F$ and the request is latched into this flip-flop when it is generated. If an interrupt can be accepted, the interrupt is generated.

It is controlled by Interrupt Enable F/F (I/E F/F) whether an interrupt can be accepted or not.

Figure 23 shows the interrupt block diagram and Figure 24 shows the interrupt timing chart.


D O: D F/F (Delayed by One Instruction Cycle)

Figure 23 Interrupt Circuit Block Diagram

The status is unchanged. (The interrupt is different from general CAL in regard to this matter.)

Stacking of registers is performed by the program. Returning from the interrupt routine is performed in the same way as that from normal subroutine. But it is convenient to use RTNI (Return Interrupt) which sets the I/E simultaneously with RTN.

An interrupt is generated irrespectively of the condition of stack registers, so enough stack registers are needed.

TF, IF0, or IF1 is flip-flop where the set has priority over the reset. It is not reset when the reset instruction is issued simultaneously with OVF of the timer/counter or the leading
edge of the input, though the interrupt request is generated and latched into I/RI or I/RT.

The interrupt processing caused by the interrupt generation is basically the subroutine jump and the jumping location in memory is fixed as:

Interrupt of the timer/counter
Bank 00 page 3 F address ( $00-3 \mathrm{~F}$ )
Interrupt of the inputs
Bank 01 page 3 F address $(01-3 \mathrm{~F}$ )
In addition,
The saving operation of $\mathrm{PC} \rightarrow \mathrm{ST} 1 \rightarrow \mathrm{ST} 2 \rightarrow \mathrm{ST} 3 \rightarrow \mathbf{S T} 4$.

## I/E reset

- Interrupt of the Inputs

Two pins $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ have the interrupt request functions. They have the leading pulse generation circuit and the interrupt mask F/F (IF0, IF1). When IF0 or IF1 is reset, the interrupt request is able to generate interrupt mask release. When INT $\mathrm{IN}_{0}$ or $\mathrm{INT}_{1}$ changes from " 0 " to " 1 " ("Low" level $\rightarrow$ "High" level), the leading pulse is generated and generates the interrupt request. Then IFO or IF1 is set, the interrupt is masked.

The interrupt request generated by the leading pulse is latched in the interrupt request $\mathrm{F} / \mathrm{F}$ on the input side (I/RI). If interrupt Enable $\mathrm{F} / \mathrm{F}(\mathrm{I} / \mathrm{E}$ ) is " 1 ", the interrupt is generated immediately and I/RI is reset. But if Interrupt Enable F/F $(I / E)$ is " 0 ", $I / R I$ is held at " 1 " level until it gets into the

Interrupt Enable state.
IF0, IF1, $\mathrm{INT}_{0}$ and $\mathrm{INT}_{1}$ can be tested by the program. Therefore, they can also be used as normal input terminals or latch terminals of momentary pulse input.

The interrupt pulse width (at both "High" and "Low" levels) should be more than two-cycle.

## - Interrupt of the Timer/Counter

The interrupt request of the timer/counter is latched into the interrupt request $\mathrm{F} / \mathrm{F}$ of the timer (I/RT). Then I/RT operates in the same way as I/RI, but the interrupt of the input has priority over that of the timer. Therefore, the input interrupt is processed when both of I/RI and I/RT are at " 1 " level (interrupt requests are simultaneously generated). During the input interrupt, I/RT remains set. Thus, after the input interrupt, the timer/counter interrupt can be processed.


Figure 24 Interrupt Timing Chart

## LIQUID CRYSTAL DISPLAY

- Liquid Crystal Display Circuit

The LCD-IV can directly drive the liquid crystal display panel of static, $1 / 2$ duty factor, $1 / 3$ duty factor and $1 / 4$ duty factor.

The LCD-IV has 4 common signal terminals and 32 seg. ment signal terminals. Further, if liquid crystal driver LSI (HD44100H) is connected to the LCD-IV, up to 96 segment signal terminals can be extended externally. Thus, in addition to the internal 32 terminals, total 128 segment signal terminals can be driven.


Figure 25 Liquid Crystal Display Circuit Block Diagram

Display is automatically executed by writing segment data into RAM for LCD. The RAM reads segment data bit by bit sequentially every one instruction cycle upon receiving address signal from the display counter and the control circuit. Every time common signal is scanned, the RAM reads 128 -segment data ( $\mathrm{SEG}_{1}$ to $\mathrm{SEG}_{128}$ ), which is correspond to common signal selected at the next time. Scan of common signal is executed every 256 -instruction cycle. Therefore, the data which is correspond to 128 -segment is read twice at the same time. The serial data read is converted to parallel data by the shift register and latch, converted to LCD drive signal by the liquid crystal
driver and the outputted from a segment terminal. 32 -segment (SEG1 to SEG $_{32}$ ) out of 128 -segment serial data is used within the LCD-IV, and the rest ( 96 -segment) is outputted to liquid crystal driver LSI HD44100H which is connected to the LCDIV and is converted to LCD drive signal in the HD44100H at the time of designation of with liquid crystal segment output extension. Cycle of the latch clock is 256 -instruction cycle in the LCD-IV. In the case of dynamic drive, data at the common side changes synchronously with the latch clock. These display operations are all executed regardless of program.


Figure 26 Display Data Timing Chart


Figure 27 Liquid Crystal Display Circuit Timing Chart

Liquid Crystal Display Mode Setting Registers
For selection of the liquid crystal display mode, data I/O registers of R4, R5 and R6 are used.
Table 9 Function of Liquid Crystal Display Mode Setting Registers

|  | $\mathbf{R}_{41}$ | $\mathbf{R}_{40}$ |  |
| :--- | :---: | :---: | :--- |
|  | 0 | 0 | Static |
| Selection of liquid crystal <br> display duty factor $\left(R_{40}, R_{41}\right)$ | 0 | 1 | $1 / 2$ duty |
|  | 1 | 0 | $1 / 3$ duty |
|  | 1 | 1 | $1 / 4$ duty |


|  |  |  |
| :--- | :---: | :---: |
| Designation of with or without <br> liquid crystal segment output <br> extension $\left(\mathbf{R}_{42}\right)$ | $\mathbf{R}_{\mathbf{4 2}}$ | Function |
|  | 0 | To be extended (Outputs display data from Channel R1) |
|  | 1 | Not to be extended (Channel R1 becomes an ordinary 4-bit data 1/O.) |


| Liquid crystal display blanking <br> signal $\left(R_{60}\right)$ | $\mathbf{R}_{60}$ | Function |
| :--- | :---: | :--- |
|  | $\mathbf{0}$ | Outputs RAM data for liquid crystal display as segment signals. |
|  | 1 | Segment signals become non-selection status (blanking) regardless of RAM <br> data for liquid crystal display. |


| RAM designation for liquid <br> crystal display $\left(\mathbf{R}_{50}, \mathbf{R}_{51}\right)$ | $\mathbf{R}_{51}$ | $\mathbf{R}_{50}$ | Function |
| :--- | :---: | :---: | :---: |
|  | Function varies with liquid crystal display duty factor. |  |  |


| Selection of <br> halt function <br> and oscillation <br> circuit for <br> timer | $\mathbf{R}_{63}$ | $\mathbf{R}_{62}$ | $\mathbf{R}_{61}$ | $\mathbf{R}_{60}$ | Function |
| :--- | :---: | :---: | :---: | :---: | :--- |
|  |  | 0 | 0 |  | Do not set in this state. |
|  |  | 0 | 1 |  | With crystal for timer, with internal halt, XI, XO |
|  |  | 1 | 0 |  | Without crystal for timer, $\mathrm{D}_{14}$ and $\mathrm{D}_{15}$ are general I/O. |

(NOTE) Liquid crystal display mode at resetting.
Since all bits of registers R4, R5 and R6 are set to " 1 " by the reset function, display mode after resetting becomes as shown below:
Liquid crystal display duty factor: $1 / 4$ duty ( $\left.\mathbf{R a c}_{40}=" 1 ", R_{44}=" 1^{\prime \prime}\right)$
Liquid crystal segment output extension: Not extended ( $\mathrm{R}_{\mathrm{A}_{2}}=" 1$ ")
Designation of liquid crystal display blanking: Display blanking ( $\mathrm{R}_{60}=$ " 1 ")
Designation of RAM for liquid crystal display: Varies correspond to each liquid crystal display duty factor. ( $\left.\mathbf{R}_{50}="{ }^{\prime \prime}{ }^{\prime \prime}, \mathbf{R}_{51}=" 1 "\right)$
Designation of crystal for timer and internal halt: With crystal for timer, without internal halt ( $\mathrm{R}_{61}=" 1 ", \mathrm{R}_{62}=" 1 "$ ).
1/O state at halt: I/O state at halt becomes disable ( $\mathrm{R}_{63}={ }^{\prime \prime} 1$ ").

## - Relation between Display RAM and Segment Data

In the LCD-IV, 4 types of display duty factor (static, $1 / 2$ duty, $1 / 3$ duty, and $1 / 4$ duty) can be selected by programs, and correspondence between RAM bits and segment data changes according to these duty factors.
shows segment signal output from the LCD-IV.


Figure 28 Relation between RAM for LCD \& Segment Data (Static)


Figure 29 Relation between RAM for LCD \& Segment Data (1/2 Duty, 1/2 Bias)


|  | RAM Address |  |  |  |  | RAM |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | X |  |  |  | Y | $2^{3}$ | $2{ }^{2}$ | 2' | $2^{\circ}$ |
|  | 2 | 0 | 6 | 4 | 0 |  | $\mathrm{SEG}_{65}$ | SEG $_{65}$ | SEG65 |
|  |  |  |  |  | 1 |  | SEG66 | $\mathrm{SEG}_{66}$ | SEG66 |
|  |  |  |  |  | 2 |  | $\mathrm{SEG}_{67}$ | SEG 67 | SEG $_{67}$ |
|  |  |  |  |  | 3 |  | SEG68 | $\mathrm{SEG}_{68}$ | SEG68 |
|  |  |  |  |  | 4 |  | SEG ${ }^{69}$ | SEG69 | SEG69 |
|  |  |  |  |  | 5 |  | SEG70 | SEG70 | SEG70 |
|  |  |  |  |  | 6 |  | SEG71 | SEG71 | SEG71 |
|  |  |  |  |  | 7 |  | SEG72 | SEG72 | SEG72 |
|  |  |  |  |  | 8 |  | SEG73 | SEG73 | SEG73 |
|  |  |  |  |  | 9 |  | SEG74 | SEG74 | SEG74 |
|  |  |  |  |  | 10 |  | SEG75 | SEG75 | SEG $_{75}$ |
|  |  |  |  |  | 11 |  | SEG76 | SEG76 | SEG76 |
|  |  |  |  |  | 12 |  | SEG77 | SEG 77 | SEG77 |
|  |  |  |  |  | 13 |  | SEG78 | SEG78 | SEG78 |
|  |  |  |  |  | 14 |  | SEG79 | SEG79 | SEG79 |
|  |  |  |  |  | 15 |  | SEG80 | SEG80 | SEG $_{80}$ |
|  | 3 | 1 | 7 | 5 | 0 |  | SEG81 | SEG81 | SEG $_{81}$ |
|  |  |  |  |  | 1 |  | SEG $_{82}$ | SEG $_{82}$ | SEG $_{82}$ |
|  |  |  |  |  | 2 |  | SEG $_{83}$ | SEG $_{83}$ | $\mathrm{SEG}_{83}$ |
|  |  |  |  |  | 3 |  | SEG84 | $\mathrm{SEG}_{84}$ | SEG84 |
|  |  |  |  |  | 4 |  | SEG85 | SEG85 | SEG $_{85}$ |
|  |  |  |  |  | 5 |  | SEG86 | SEG $_{86}$ | SEG $_{86}$ |
|  |  |  |  |  | 6 |  | SEG $_{87}$ | SEG $_{87}$ | $\mathrm{SEG}_{87}$ |
|  |  |  |  |  | 7 |  | SEG88 | SEG $_{88}$ | SEG88 |
|  |  |  |  |  | 8 |  | SEG89 | SEG89 | SEG89 |
|  |  |  |  |  | 9 |  | SEG90 | SEG 90 | SEG90 |
|  |  |  |  |  | 10 |  | SEG $_{91}$ | SEG ${ }_{91}$ | SEG ${ }_{91}$ |
|  |  |  |  |  | 11 |  | SEG92 | SEG92 | SEG92 |
|  |  |  |  |  | 12 |  | SEG93 | SEG93 | SEG93 |
|  |  |  |  |  | 13 |  | SEG94 | SEG94 | SEG94 |
|  |  |  |  |  | 14 |  | SEG95 | SEG95 | SEG95 |
|  |  |  |  |  | 15 |  | SEG96 | SEG96 | SEG96 |
|  | 0 | 2 | 4 | 6 | 0 |  | SEG97 | SEG97 | SEG97 |
|  |  |  |  |  | 1 |  | SEG98 | SEG98 | SEG98 |
|  |  |  |  |  | 2 |  | SEG99 | SEG99 | SEG99 |
|  |  |  |  |  | 3 |  | SEG 100 | SEG ${ }_{100}$ | SEG 100 |
|  |  |  |  |  | 4 |  | SEG 101 | SEG 101 | SEG ${ }_{101}$ |
|  |  |  |  |  | 5 |  | SEG ${ }_{102}$ | SEG 102 | SEG ${ }_{102}$ |
|  |  |  |  |  | 6 |  | SEG $_{103}$ | SEG $_{103}$ | SEG $_{103}$ |
|  |  |  |  |  | 7 |  | $\mathrm{SEG}_{104}$ | SEG 104 | SEG $_{104}$ |
|  |  |  |  |  | 8 |  | $\mathrm{SEG}_{105}$ | SEG ${ }_{105}$ | SEG $_{105}$ |
|  |  |  |  |  | 9 |  | SEG 106 | SEG 106 | SEG 106 |
|  |  |  |  |  | 10 |  | SEG ${ }_{107}$ | SEG 107 | SEG $_{107}$ |
|  |  |  |  |  | 11 |  | SEG 108 | SEG ${ }_{108}$ | SEG 108 |
|  |  |  |  |  | 12 |  | SEG109 | SEG 109 | SEG109 |
|  |  |  |  |  | 13 |  | $\mathrm{SEG}_{110}$ | SEG $_{110}$ | SEG $_{110}$ |
|  |  |  |  |  | 14 |  | SEG111 | SEG ${ }_{11}$ | SEG 111 |
|  |  |  |  |  | 15 |  | $\mathrm{SEG}_{112}$ | SEG:12 | SEG $_{112}$ |
|  | 1 | 3 | 5 | 7 | 0 |  | SEG $_{113}$ | SEG 113 | SEG $_{113}$ |
|  |  |  |  |  | 1 |  | $\mathrm{SEG}_{114}$ | SEG 114 | SEG 114 |
|  |  |  |  |  | 2 |  | $\mathrm{SEG}_{115}$ | SEG $_{115}$ | SEG $_{115}$ |
|  |  |  |  |  | 3 |  | SEG $_{116}$ | SEG $_{116}$ | SEG $_{116}$ |
|  |  |  |  |  | 4 |  | $\mathrm{SEG}_{117}$ | SEG ${ }_{117}$ | SEG $_{117}$ |
|  |  |  |  |  | 5 |  | $\mathrm{SEG}_{118}$ | $\mathrm{SEG}_{118}$ | SEG $_{118}$ |
|  |  |  |  |  | 6 |  | SEG119 | SEG119 | SEG 119 |
|  |  |  |  |  | 7 |  | SEG $_{120}$. | SEG ${ }_{120}$ | SEG $_{120}$ |
|  |  |  |  |  | 8 |  | $\mathrm{SEG}_{121}$ | SEG 121 | SEG ${ }_{121}$ |
|  |  |  |  |  | 9 |  | SEG $_{122}$ | SEG 122 | SEG ${ }_{122}$ |
|  |  |  |  |  | 10 |  | SEG $_{123}$ | SEG $_{123}$ | SEG $_{123}$ |
|  |  |  |  |  | 11 |  | SEG $_{124}$ | SEG ${ }_{124}$ | SEG 124 |
|  |  |  |  |  | 12 |  | SEG $_{125}$ | SEG ${ }_{125}$ | SEG $_{125}$ |
|  |  |  |  |  | 13 |  | SEG $_{126}$ | SEG $_{126}$ | SEG $_{126}$ |
|  |  |  |  |  | 14 |  | SEG ${ }_{127}$ | SEG ${ }_{127}$ | SEG $_{127}$ |
|  |  |  |  |  | 15 |  | SEG $_{128}$ | SEG $_{128}$. | SEG $_{128}$ |
| $\mathbf{R}_{50}$ | 0 | 1 | 0 | 1 |  |  |  |  |  |
| $\mathrm{R}_{51}$ | 0 | 0 | 1 | 1 |  |  | $\mathrm{COM}_{3}$ | $\mathrm{COM}_{2}$ | $\mathrm{COM}_{1}$ |

Figure 30 Relation between RAM for LCD \& Segment Data ( $1 / 3$ Duty, $1 / 3$ Bias)



Figure 31 Relation between RAM for LCD \& Segment Data (1/4 Duty, $1 / 3$ Bias)

(1/2 duty, $1 / 2$ bias)

(1/3 duty, $1 / 3$ bias)

(1/4 duty, $1 / 3$ bias)

Figure 32 LCD Wiring Samples

## - Extension of Display Function

Number of display digits can be increased by externally connecting an LCD driver LSI HD44100H to the LCD-IV.

The HD44100H consists of shift registers and latch and liquid crystal drive circuit. When connected with the LCD-IV, the HD 44100 H is used as a circuit for segment. In the LCD-

IV, display data for 128 segments is sent to the 32 -bit shift register from RAM constantly. When R42 is set to " 0 ", the R1 channel outputs the 32nd stage output D of the shift register, shift clock CL2, latch clock $\mathrm{CL}_{1}$ and AC signal M . Therefore, up to 96 segment terminals from $\mathrm{SEG}_{33}$ to $\mathrm{SEG}_{128}$ can be added by directly connecting the HD44100H.


## - RESET FUNCTION

The reset is performed by setting the RESET pin to " 1 " ("High" level) and the LCD-IV gets into operation by setting it to "0" ("Low" level).

Internal state of the LCD-IV are specified as follows by the reset function.

- Program Counter (PC) is set to Bank 163 Page 3F Address.
- $\mathrm{IR} / \mathrm{I}, \mathrm{IR} / \mathrm{T}, \mathrm{I} / \mathrm{E}$ and CF are reset to " 0 ".
- IFO, IF1 and TF are set to " 1 ".
- Data I/O Registers and Discrete I/O Latches (R1, R2, R3, $D_{0}$ to $D_{15}$ ) are all set to " 1 ".
- Bank Register $\mathrm{R}_{70}$ is set to "l" (Jumps to Bank 0 by execution of LPU instruction after the reset).
- Liquid Crystal Display ..... all bits of display mode setting register (Data I/O Register) R4, R5, R6 are set to " 1 ".
(Note) All the other logic blocks (the Stack Registers, the Status F/F, the accumulator, the Carry F/F, the registers, the Timer/Counter, RAM) are not cleared by the reset function.


## - HALT FUNCTION

The LCD-IV is provided with halt function. The halt function reduces power consumption in the halt state by temporarily stopping all status including RAM. When halt is released, operation restarts from the state before the halt.

HALT state is kept 16 -instruction after receiving halt releasing signal. (Internal, External)

The user can select one of the following I/O status at the time of halt based on the "MASK OPTION LIST" when ordering ROM:
i) All I/O status is kept as the state immediately before the halt.
ii) All I/O status is held in the high impedance state (both PMOS and NMOS are off, and pull-up MOS is off).
There are the following two types of halt:

1) External Halt (Halt state generated by using $\overline{\text { HLT }}$ terminal)

All operations stop when the $\overline{\text { HLT }}$ terminal is set to the " 0 " level (Low). When the HLT terminal is set to the " 1 " level (High), operation restarts from the state immediately before the halt.
2) Internal Halt (Halt state generated by programs)

The user can select availability of internal halt at the time of ROM order based on the "MASK OPTION LIST". When internal halt is selected, timer crystal must be attached externally. Therefore, the $\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ terminals should not be used as general I/O's, but as XO and XI terminals for connecting crystal oscillator.
Resetting of the $D_{15}$ latch by RED instruction generates internal halt state. Return from internal halt is effected by overflow signals of the prescaler. 16 Hz overflow signals are output from the prescaler if a crystal oscillator of 32.768 kHz is connected to the $\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ terminals. When an overflow signal is issued, the $D_{15}$ latch is set to " 1 " from " 0 ", the LCD-IV returns from halt state, adds 1 to the timer register, and execution restarts from the instruction next to the RED instruction.
Note that external halt caused by the $\overline{\text { HLT }}$ terminal cannot be released by prescaler overflow signals.

[^5]

Figure 33 Program example in the Internal Halt Mode


Figure 34 Internal Halt Timing Chart

## - CRYSTAL OSCILLATION CIRCUIT FOR TIMER

The user can specify by the "MASK OPTION LIST" whether or not the timer crystal should be externally attached. By externally attaching a crystal oscillator of
32.768 kHz to the $\mathrm{D}_{14} / \mathrm{XO}$ and $\mathrm{D}_{15} / \mathrm{XI}$ terminals, maximum 1 second of timer interruption cycle is possible setting the prescaler clock to $1,024 \mathrm{~Hz}$.

(NOTE)
The crystal oscillator, resistor R, Rd and load capacitor $C_{1}$ and $C_{2}$ should be placed as close as possible to the LCD-IV. Induction of external noise to $D_{14} / X O$ and $D_{15} / X 1$ may disturb normal oscillation.
This circuit is the example of the typical use. As the oscillation characteristics is not guaranteed, please consider and examine the circuit constants carefully on your application.
Figure 35 Crystal Oscillator Circuit

| No. | Halt state | With or without timer crystal | $\mathrm{D}_{14}, \mathrm{D}_{\text {terminais }}(\mathrm{XO}, \mathrm{XI})$ | Function |
| :---: | :---: | :---: | :---: | :---: |
| 1 | External halt | Externally attached crystal ( 32.768 kHz ) | Terminals for attaching crystal. Cannot be used as general $1 / 0$. | Prescaler clock is set to $1,024 \mathrm{~Hz}$ and the overflow signal to 16 Hz . Up to 1 second can be set as the timer interruption cycle. |
| 2 | External halt | (Without crystal) Internal clock of LSI | Used as general 1/O | The prescaler clock becomes 100 kHz type, and the timer interruption cycle can be set to maximum 97.66 Hz . |
| 3 | Internal and external halt | Externally attached crystal ( 32.768 kHz ) | Terminals for attaching crystal. Cannot be used as general I/O. | Prescaler clock is set to $1,024 \mathrm{~Hz}$ and the overflow signal to 16 Hz . This signal performs the LCD-IV return from internal halt. (Return from external halt is not possible by the prescaler overflow signal.) |

## LCD-IV

## - MASK OPTION

The following type mask option is available.

- I/O Terminal Format . . . . . . . . Select one of A, B or C.

A: Without pull-up MOS
B: With pull-up MOS
C: CMOS output
(Note) External input is not permitted if CMOS output is selected in the case of I/O common terminals.

- $1 / 0$ Status in the Halt State . . . . Select Enable or Disable.

Enable - Output . . . . Maintained in the status before halt. - Pull-up MOS . . . ON
$L_{\text {Input . . . Unrelated to halt state }}$
(Since Pull-up MOS is ON, if halt state occurs when output is " 0 " (Low) level (NMOS; ON), pullup MOS current always flows. If input changes, transient current flows through the input circuit. Also, current flows through the input pull-up MOS. These currents are added to standby power supply current (or halt current).)
Disable $T^{\text {Output }} .$. NMOS output; OFF CMOS output; High impedance (NMOS, PMOS; OFF)
Pull-up MOS . . OFF
Input . . . Input circuit; OFF
(Both input and output become high impedance state. Since the input circuit is turned off, input change does not cause current other than the standby power supply current or halt current.)

- With or without externally attached Timer Crystal

Without timer crystal ...
The $D_{14}$ and $D_{15}$ can be used as general I/O terminals. Select one of $A, B$ or $C$ in the $D_{14} / D_{15}$ column of the I/O format specifications.
With timer crystal . . .
The $\mathrm{D}_{14}$ and $\mathrm{D}_{15}$ cannot be used as general I/O terminals.
Therefore, leave the $D_{14} / D_{15}$ column in blank.
Since the $D_{14}$ latch can be set, reset or tested, it can be used as a flag.
If no internal halt exists, the $D_{15}$ latch can be used as a flag same as the $D_{14}$ latch. If internal halt exists, it cannot be used as a general flag.

- With or without Internal Halt

With internal halt
When internal halt is specified, the timer crystal must also be specified.
Without internal halt ...
The $\mathrm{D}_{15}$ can be used as a general I/O terminal (when no timer crystal is used) or as a flag (when timer crystal is used).

- OSCILLATION CIRCUIT

The user can specify a resistor, or a ceramic filter or an external oscillator.

| LSI Type Number | HD | (To be filled <br> by Hitachi) |
| :--- | :--- | ---: |
| Customer's ROM <br> Code Name |  |  |
| Customer |  |  |

- MASK OPTION LIST
(1) I/O Option

| Pin Name | 1/O | 1/O Option |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A | B | C |  |
| $\mathrm{D}_{0}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{1}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{2}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{3}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{4}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{5}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{6}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{7}$ | I/O |  |  |  |  |
| $\mathrm{D}_{8}$ | I/O |  |  |  |  |
| $\mathrm{D}_{9}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{10}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{11}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{12}$ | I/O |  |  |  |  |
| $\mathrm{D}_{13}$ | I/O |  |  |  |  |
| $\mathrm{D}_{14}$ | 1/0 |  |  |  |  |
| $\mathrm{D}_{15}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{00}$ | 1 |  |  |  |  |
| $\mathrm{R}_{01}$ | 1 |  |  |  |  |
| $\mathrm{R}_{02}$ | 1 |  |  |  |  |
| $\mathrm{R}_{03}$ | 1 |  |  |  |  |
| $\mathrm{R}_{10}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{11}$ | I/O |  |  |  |  |
| $\mathrm{R}_{12}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{13}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{20}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{21}$ | I/O |  |  |  |  |
| $\mathrm{R}_{22}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{23}$ | 1/0 |  |  |  |  |
| $\mathrm{R}_{30}$ | 0 |  |  |  |  |
| $\mathbf{R}_{31}$ | 0 |  |  |  |  |
| $\mathrm{R}_{32}$ | 0 |  |  |  |  |
| $\mathrm{R}_{33}$ | 0 |  |  |  |  |
| INTo | 1 |  |  |  |  |
| $\mathrm{INT}_{1}$ | 1 |  |  |  |  |

(NOTE) Mark a selected composition with a circle (o).
C. CMOS Output
(2) I/O State at "Halt" State and Others

| 1/O State | - Enable | - Disable |  |
| :---: | :---: | :---: | :---: |
| With or without externally attached crystal for timer | - With | - Without | With ....... $\mathrm{D}_{14}$ and $\mathrm{D}_{15}$ become XO, XI. Do not write any- |
| With or without internal halt | - With | - Without | Internal halt is specified only when crystal for timer is specified. |
| Power-supply voltage | $\square 5 \pm 0.5 \mathrm{~V}$ | - 2.5 to 5.5 V |  |
| Oscillation circuit (system clock) | - $R_{f}$ Oscilla <br> - Ceramic fil <br> - External |  | Ceramic filter is specified only when power supply is $\mathrm{V}_{\mathrm{CC}}=5 \pm 0.5 \mathrm{~V}$. |
| Halt function | - Not use <br> - Use (Retur <br> - Use (Retu | by Reset) by no Reset) |  |

(NOTE) Mark a selected I/O State or another with a check mark ( $\sqrt{ }$ ).

## - INSTRUCTION

Instructions are listed according to their functions.
Each mnemonic code and function are shown in this table.

| Group | Mnemonic code | Function | Status |
| :---: | :---: | :---: | :---: |
| Register to Register | LAB <br> LBA <br> LAY <br> LASPX <br> LASPY <br> XAMR m | $\begin{aligned} & B \rightarrow A \\ & A \rightarrow B \\ & Y \rightarrow A \\ & S P X \rightarrow A \\ & S P Y \rightarrow A \\ & A \leftrightarrow M R(m) \end{aligned}$ |  |
| RAM Address | LXA <br> LYA <br> LXI i <br> LYI i <br> IY <br> DY <br> AYY <br> SYY <br> XSPX <br> $X S P Y$ <br> XSPXY | $\begin{aligned} & A \rightarrow X \\ & A \rightarrow Y \\ & i \rightarrow X \\ & i \rightarrow Y \\ & Y+1 \rightarrow Y \\ & Y-1 \rightarrow Y \\ & Y+A \rightarrow Y \\ & Y-A \rightarrow Y \\ & X \leftrightarrow S P X \\ & Y \leftrightarrow S P Y \\ & X \leftrightarrow S P X, Y \leftrightarrow S P Y \end{aligned}$ | $\begin{gathered} N Z \\ N B \\ C \\ N B \end{gathered}$ |
| Register RAM | $\begin{aligned} & \text { LAM }(X Y) \\ & \text { LBM }(X Y) \\ & X M A(X Y) \\ & \text { XMB }(X Y) \\ & \text { LMAIY } X) \\ & \text { LMADY(X) } \end{aligned}$ | $\begin{aligned} & M \rightarrow A(X Y \leftrightarrow S P X Y) \\ & M \rightarrow B(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow A(X Y \leftrightarrow S P X Y) \\ & M \leftrightarrow B(X Y \leftrightarrow S P X Y) \\ & A \rightarrow M, Y+1 \rightarrow Y(X \leftrightarrow S P X) \\ & A \rightarrow M, Y-1 \rightarrow Y(X \leftrightarrow S P X) \end{aligned}$ | $\begin{aligned} & \text { N Z } \\ & \text { NB } \end{aligned}$ |
| Immediate | $\begin{aligned} & \text { LMIIY i } \\ & \text { LAI i } \\ & \text { LBI i } \end{aligned}$ | $\begin{aligned} & i \rightarrow M, Y+1 \rightarrow Y \\ & i \rightarrow A \\ & i \rightarrow B \end{aligned}$ | N |
| Arithmetic | AI <br> i <br> IB <br> D B <br> AMC <br> SMC <br> AM <br> DAA <br> DAS <br> NEGA <br> COMB <br> SEC <br> REC <br> TC <br> ROTL <br> ROTR <br> 0 R | $\begin{array}{lll} A+i \rightarrow A & \\ B+1 \rightarrow B & \\ B-1 \rightarrow B & \\ M+A+C(F / F) \rightarrow A \\ M-A-\bar{C}(F / F) \rightarrow A \\ M+A \rightarrow A & & \\ M+A \end{array}$ <br> Decimal Adjustment (Addition) <br> Decimal Adjustment (Subtruction) $\bar{A}+1 \rightarrow A$ <br> $\bar{B} \rightarrow B$ <br> $1 \rightarrow C(F / F)$ <br> $0 \rightarrow C(F / F)$ <br> Test C (F/F) <br> Rotation Left <br> Rotation Right <br> $A \cup B \rightarrow A$ | C <br> N Z <br> NB <br> C <br> NB <br> C $C(F / F)$ |


| Group | Mnemonic code |  | Function | Status |
| :---: | :---: | :---: | :---: | :---: |
| Compare | MNEI | i | M $\ddagger$ | N Z |
|  | YNEI | i | $Y \neq i$ | N Z |
|  | ANEM |  | $\mathrm{A} \neq \mathrm{M}$ | N Z |
|  | BNEM |  | $B \neq M$ | NZ |
|  | ALEI | i | $A \leqq i$ | NB |
|  | ALEM |  | $A \leqq M$ | NB |
|  | BLEM |  | $B \leqq M$ | N B |
| RAM bit Manipulation | SEM | n | $1 \rightarrow M(n)$ |  |
|  | REM | n | $0 \rightarrow M(n)$ |  |
|  | TM | $n$ | Test M ( n ) | M ( n ) |
| R OM Address | BR | a | Branch on Status 1 | 1 |
|  | CAL | a | Subroutine Jump on Status 1 | 1 |
|  | LP U | $u$ | Load Program Counter Upper on |  |
|  |  |  | Status 1 |  |
|  | TBR | p | Table Branch |  |
|  | RTN |  | Return from Subroutine |  |
| Interrupt | SEIE |  | $1 \rightarrow$ I/E |  |
|  | SEIFO |  | $1 \rightarrow$ IF 0 |  |
|  | SEIF1 |  | $1 \rightarrow$ IF 1 |  |
|  | SETF |  | $1 \rightarrow T F$ |  |
|  | SECF |  | $1 \rightarrow C F$ |  |
|  | REIE |  | $0 \rightarrow$ I/E |  |
|  | REIFO |  | $0 \rightarrow$ IF 0 |  |
|  | REIF1 |  | $0 \rightarrow$ IFI |  |
|  | RETF |  | $0 \rightarrow T F$ |  |
|  | RECF |  | $0 \rightarrow C F$ |  |
|  | TIO |  | Test INT0 | INT ${ }_{0}$ |
|  | TII |  | Test INT | $\mathrm{INT}_{1}$ |
|  | TIFO |  | Test IFO | $1 \mathrm{~F}_{0}$ |
|  | TIFI |  | Test IF1 | $1 F_{1}$ |
|  | TTF |  | Test TF | T F |
|  | LTA |  | i $\rightarrow$ Timer/Counter |  |
|  |  |  | A $\rightarrow$ Timer/Counter |  |
|  | LAT |  | Timer/Counter $\rightarrow$ A |  |
|  | RTNI |  | Return Interrupt |  |
| Input/Output (Display Control) | SED |  | $1 \rightarrow \mathrm{D}(\mathrm{Y})$ |  |
|  | RED |  | $0 \rightarrow \mathrm{D}$ (Y) |  |
|  | T D |  | Test $\mathrm{D}(\mathrm{Y})$ | D (Y) |
|  | SEDD | $n$ | $1 \rightarrow \mathrm{D}$ ( n ) |  |
|  | REDD | n | $0 \rightarrow \mathrm{D}$ ( n ) |  |
|  | LAR | p | $R(p) \rightarrow A$ |  |
|  | LBR | p | $R(p) \rightarrow B$ |  |
|  | LRA |  | $A \rightarrow R(p)$ |  |
|  | LRB | $p$ | $B \rightarrow R(p)$ |  |
|  | Pp |  | Pattern Generation |  |
|  | NOP |  | No Operation |  |

(NOTE) 1. (XY) after a mnemonic code has four meanings as follows.
Mnemonic only Instruction execution only
Mnemonic with $X \quad$ Instruction execution, $X \leftrightarrow S P X$
Mnemonic with $Y \quad$ Instruction execution, $Y \leftrightarrow$ SPY
Mnemonic with $X Y \quad$ Instruction execution, $X \leftrightarrow S P X, Y \leftrightarrow$ SPY
[Example] LAM $M \rightarrow A$
LAMX
$\begin{array}{ll}\text { LAMX } & M \rightarrow A, X \leftrightarrow S P X \\ M \rightarrow A, Y \leftrightarrow S P Y\end{array}$
$\begin{array}{ll}\text { LAMXY } & M \rightarrow A, Y \leftrightarrow S P Y \\ M \rightarrow A, X \leftrightarrow S P X . Y & \rightarrow \text { SPY }\end{array}$
2. Status column shows the factor which affects status by the instruction of status change.
NZ ........... ALU

NB ............ ALU
Not Zeto
Overflow in Addition/Carry
Overflow in Subtraction/No Borrow
3. Carry flip-flop is not always affected by executing the instruction which affects the Status. Instructions which affect Carry flip-flop are eight as follows.

| AMC | SEC |
| :--- | :--- |
| SMC | REC |
| DAA | ROTL |
| DAS | ROTR |

4. All instructions except for $P$ are executed in single cycle. $\mathbf{P}$ is executed in 2 cycles.

The Difference between LCD.III and LCD.IV

| No. | Difference | LCD-III | LCD-IV |
| :---: | :---: | :---: | :---: |
| 1 | ROM | (Program Memory) 2,048 words <br> (Pattern Memory) 128 words | (Program Memory) 4,096 words (Includes Pattern Memory) |
| 2 | RAM | 160 digits | 256 digits |
| 3 | Cycle Time $\left(V_{C C}=5 V \pm 10 \%\right)$ | $\begin{aligned} & 10 \mu \mathrm{~s} / \mathrm{cycle} \\ & \left(\mathrm{f}_{\mathrm{cp}}=400 \mathrm{kHz}\right) \end{aligned}$ | $\begin{aligned} & 5 \mu \mathrm{~s} / \mathrm{cycle} \\ & \left(\mathrm{f}_{\mathrm{cp}}=800 \mathrm{kHz}\right) \end{aligned}$ |
| 4 | Stored Reset Circuit (Poweron Reset) | Yes | No |
| 5 | Select Option | Selected by Mask Option List <br> (Note) But when program evaluation with HD44797E, set up the option with the register as LCD-IV. | When ordering ROM, selected by Mask Option List or by program using internal register R6. <br> (Mask Option List + Program) |
|  | Crystal for Timer |  | $\mathbf{R}_{61}=0$ (No crystal for timer) <br> $\mathbf{R}_{61}=1$ (With crystal for timer) |
|  | Internal Halt | ] | $R_{62}=0$ (With internal halt) <br> $R_{62}=1$ (No internal halt). |
|  | I/O Condition at "Halt" state |  | $R_{63}=0$ (Enable) <br> $R_{63}=1$ (Disable) |
| 6 | Oscillator | Refer to the manual as for circuit constant of resistor oscillation and ceramic oscillation. | Circuit constants of resistor oscillation and ceramic oscillation are undecided. (As for low voltage operation board ( V cc $=2.5$ to 5.5 V ), undecided that seramic filter can be used or not.) |
| 7 | Reset Address | 31-3F | 63-3F (Bank 1) |
| 8 | Bank Register (ROM Addressing) | No Bank Register | ROM is divided in 2 Banks. |
| 9 | Absolute Maximum Rating VT2 for Terminal Voltage of Open Drain Configuration Output Pins and I/O Common Pins | -0.3 to +10.0V | $\begin{gathered} -0.3 \text { to } V C C+0.3 V \\ \text { (same as } V T_{1} \text { ) } \end{gathered}$ |

LCD-IV


## HMCS404C (HD614042)

The HMCS404C is a CMOS 4-bit single-chip microcomputer which is a member of the HMCS400 series.

The HMCS404C has efficient and powerful architecture and its software is very similar to the HMCS40 series.

This microcomputer provides variety of on-chip resources such as ROM, RAM, I/O, two timer/counters and a serial interface to perform in wide users' applications.

The HMCS404C also has the characteristics of high speed and low power dissipation and which $1 / O$ pins are able to drive fluorescent display tube directly.

- HARDWARE FEATURES
- 4-bit Architecture
- 4,096 Words x 10-bit ROM
- 256 Digits $\times 4$-bit RAM
- 58 I/O Pins, Including 26 High Voltage I/O Pins (40V Max)
- Two Timer/Counters

11-bit Prescaler
8-bit Free Running Timer
8-bit Auto-Reload Timer/Event Counter

- Clock Synchronous 8 -bit Serial Interface
- Five Interrupts

$$
\begin{array}{ll}
\text { External } & 2 \\
\text { Timer/Counter } & 2 \\
\text { Serial Interface } & 1
\end{array}
$$

- Subroutine Stack

Up to 16 Levels Including Interrupt

- Minimum Instruction Execution Time - $2 \mu \mathrm{~s}$
- Two Low Power Dissipation Modes

Standby - Stops instruction execution while keeping clock oscillation and interrupt functions in operation
Stop - Stops instruction execution and clock oscillation while retaining RAM data

- On-Chip Oscillator

External Connection of Crystal, Ceramic Filter or Resistor (externally drivable)

## - SOFTWARE FEATURES

- Instruction Set Similar to and More Powerful than HMCS40 Series; 99 Instructions
- High Programming Efficiency with 10-bit ROM/Word; 79 instructions are single-word instructions
- Direct Branch to All ROM Area
- Direct or Indirect Addressing to All RAM Area
- Subroutine Nesting Up to 16 Levels Including Interrupts
- Binary and BCD Arithmetic Operation
- Powerful Logical Arithmetic Operation
- Pattern Generation - Table Look Up Capability -
- Bit Manipulation for Both RAM and I/O


[^6]- PIN ARRANGEMENT

(Top View)

(Top View)
- BLOCK DIAGRAM

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage | $V_{T}$ | -0.3 to $\mathrm{V}_{\text {cc }}+0.3$ | V | 3 |
|  |  | $\mathrm{V}_{\mathrm{CC}}-45$ to $\mathrm{V}_{\mathrm{CC}}+0.3$ | V | 4 |
| Total Allowance of Input Currents | $\mathrm{\Sigma l}_{0}$ | 50 | mA | 5 |
| Total Allowance of Output Currents | $-\Sigma \mathrm{l}_{0}$ | 150 | mA | 6 |
| Maximum Input Current | 10 | 15 | mA | 7.8 |
| Maximum Output Current | -10 | 4 | mA | 9,10 |
|  |  | 6 | mA | 9, 11 |
|  |  | 30 | mA | 9,12 |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(Note 1) Permanent damage may occur if "Absolute Maximum Ratings" are exceeded. Normal operation should be under the conditions of "Electrical Characteristics". If these conditions are exceeded, it may cause the malfunction and affect the reliability of LSI.
(Note 2) All voltages are with respect to GND.
(Note 3) Applied to standard pins.
(Note 4) Applied to high voltage pins.
(Note 5) Total allowance of input current is the total sum of input current which flow in from all I/O pins to GND simultaneously.
(Note 6) Total allowance of output current is the total sum of the output current which flow out from $\mathrm{V}_{\mathbf{C C}}$ to all I/O pins simultaneously.
(Note 7) Maximum input current is the maximum amount of input current from each I/O pin to GND.
(Note 8) Applied to $D_{0} \sim D_{3}$ and R3 ~R8.
(Note 9) Maximum output current is the maximum amount of output current from VCC to each I/O pin.
(Note 10) Applied to $D_{0} \sim D_{3}$ and R3 ~ R8.
(Note 11) Applied to RO ~R2.
(Note 12) Applied to $\mathrm{D}_{4} \sim \mathrm{D}_{15}$.

- ELECTRICAL CHARACTERISTICS
- DC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{Cc}}=\mathbf{4 V}$ to $\mathbf{6 V}$, $\mathrm{GND}=\mathbf{0 V}, \mathrm{V}_{\text {disp }}=\mathrm{V}_{\mathrm{Cc}} \mathbf{- 4 0 \mathrm { V }}$ to $\mathrm{V}_{\mathrm{cc}}, \mathrm{Ta}=\mathbf{- 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | min | typ | max |  |  |
| Input "High" Voltage | $V_{\text {IH }}$ | $\begin{aligned} & \hline \text { RESET, SCK, } \\ & \text { INT }_{0}, \text { NNT }_{1} \\ & \hline \end{aligned}$ |  |  | $0.7 V_{\text {cc }}$ | - | $V_{c c}+0.3$ | V |  |
|  |  | SI |  |  | $0.7 V_{\text {cc }}$ | - | $V_{c c}+0.3$ | V |  |
|  |  | $\mathrm{OSC}_{1}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-0.5$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & \text { RESET, SCK } \\ & \text { INT }_{0}, \frac{I^{N T}}{1} \end{aligned}$ |  |  | -0.3 | - | $0.22 V_{\text {cc }}$ | V |  |
|  |  | SI |  |  | -0.3 | - | $0.22 \mathrm{~V}_{\text {cc }}$ | V |  |
|  |  | OSC 1 |  |  | -0.3 | - | 0.5 | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | SCK, SO | $-\mathrm{l}_{\mathrm{OH}}=1.0 \mathrm{~mA}$ |  | $\mathrm{V}_{\text {cc }}-1.0$ | - | - | V |  |
|  |  |  | $-I_{\text {OH }}=0.01 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{cc}}-0.3$ | - | - | V |  |
| $\begin{aligned} & \text { Output "Low" } \\ & \text { Voltage } \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | SCK, SO | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | - | - | 0.4 | V |  |
| Input/Output Leakage Current | $\left\|I_{\text {IL }}\right\|$ | $\begin{aligned} & \text { RESET, SCK, }^{\text {INT }_{0}, \text { INT }_{1}} \\ & \text { SI, SO, OSC }_{1} \end{aligned}$ | $V_{\text {in }}=O \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ |  | - | - | 1 | $\mu \mathrm{A}$ | 1 |
| Current Dissipation in Active Mode | Icc | $V_{\text {cc }}$ | $V_{c c}=5 \mathrm{~V}$ | Crystal or Ceramic Filter Oscillator Option $f_{\text {oxc }}=4 \mathrm{MHz}$ | - | - | 2.0 | mA | 2, 6 |
|  |  |  |  | Resistor Oscillator Option $f_{\text {oce }}=4 \mathrm{MH}_{2}$ | - | - | 2.4 | mA | 2, 6 |
| Current Dissipation in Standby Mode | $\mathbf{I S B Y Y}^{\text {S }}$ | $V_{\text {cc }}$ | Maximum <br> Logic Operation $V_{c c}=5 \mathrm{~V}$ | Crystal or Ceramic Filter Oscillator Option $f_{\text {oxe }}=4 \mathrm{MHz}$ | - | - | 1.2 | mA | 3, 6 |
|  |  |  |  | Resistor Oscillator Option $\mathrm{f}_{\text {orc }}=4 \mathrm{MHz}$ | - | - | 1.6 | mA | 3, 6 |
|  | ISBY2 | $V_{\text {cc }}$ | Minimum <br> Logic Operation $V_{c c}=5 V$ | Crystal or Ceramic Filter Oscillator Option $f_{\text {oxc }}=4 \mathrm{MHz}$ | - | - | 0.9 | mA | 4, 6 |
|  |  |  |  | Resistor Oscillator Option $f_{\text {osc }}=4 \mathrm{MHz}$ | - | - | 1.3 | mA | 4,6 |
| Current Dissipation in Stop Mode | $\mathrm{I}_{\text {stop }}$ | $V_{\text {cc }}$ | $\begin{aligned} & V_{\text {in }}(\overline{T E S T})=V_{c c}-0.3 V \text { to } V_{c c} \\ & V_{\text {in }}(\text { RESET })=0 V \text { to } 0.3 \mathrm{~V} \end{aligned}$ |  | - | - | 10 | $\mu \mathrm{A}$ | 5 |
| Stop Mode Retain Voltage | $V_{\text {stop }}$ | V cc |  |  | 2 | - | - | V |  |

(Note 1) Pull-up MOS current and output buffer current are excluded.
(Note 2) The MCU is in the reset state. The input/output current does not flow.
Test Conditions: MCU state; - Reset state in Operation Mode
Pin state; - RESET, TEST ... $V_{\text {cc }}$ voltage

- $D_{0} \sim D_{3}, R 3 \sim R 9 \cdots V_{C}$ voltage
$-D_{4} \sim D_{15}, R 0 \sim R 2, R_{A 0}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 3) The timer/counter operate with the fastest clock and input/output current does not flow. Test Conditions: MCU state; - Standby Mode
- Input/Output; Reset state
- TIMER-A; $\div 2$ prescaler divide ratio
- TIMER-B; $\div 2$ prescaler divide ratio
- SERIAL Interface ; Stop

Pin state: - RESET ... GND voltage

- TEST ... $V_{\propto}$ voltage
- $D_{0} \sim D_{3}, R 3 \sim R 9 \cdots V_{C C}$ voltage
$-D_{4} \sim D_{15}, R O \sim R 2, R_{A 0}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 4) The timer/counter operate with the slowest clock and input/output current does not flow. Test Conditions: MCU state; •Standby Mode
- Input/Output; Reset state
- TIMER-A; $\div \mathbf{2 0 4 8}$ prescaler divide ratio
- TIMER-B; $\div 2048$ prescaler divide ratio
- SERIAL Interface ; Stop

Pin state: - RESET.... GND voltage

- TEST ... $V_{\text {Cc }}$ voltage
- $D_{0} \sim D_{3}, R 3 \sim R 9 \ldots V \propto$ voltage
$-D_{4} \sim D_{15}, R 0 \sim R 2, R_{A 0}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 5) Pull-down MOS current is excluded.
(Note 6) When $\mathrm{f}_{\mathrm{osc}}=x[\mathrm{MHz}$, the Current Dissipation in Operation mode and Standby mode are estimated as follows:

$$
\text { max. value }\left(f_{\text {osc }}=x[M H z]\right)=\frac{x}{4} \times \text { max. value }\left(f_{\text {osc }}=4[M H z]\right)
$$

- INPUT/OUTPUT CHARACTERISTICS FOR STANDARD PIN

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| $\begin{aligned} & \text { Inout "High" } \\ & \text { Voltage } \end{aligned}$ | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim \text { R5, R9 } \end{aligned}$ |  | $0.7 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| $\begin{aligned} & \text { Input "Low" } \\ & \text { Voltage } \end{aligned}$ | $V_{\text {IL }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 5, R 9 \end{aligned}$ |  | -0.3 | - | 0.22 V cc | V |  |
| Output "High" Voltage | $\mathrm{V}_{\text {OH }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 8 \end{aligned}$ | $-_{\text {OH }}=1.0 \mathrm{~mA}$ | $V_{c c}-1.0$ | - | - | V | 1 |
|  |  | $\begin{aligned} & D_{0} \sim D_{3}, \\ & \text { R3 } \sim \text { R8 } \end{aligned}$ | $-\mathrm{IOH}=0.01 \mathrm{~mA}$ | $V_{c c}-0.3$ | - | - | V | 1 |
| Output "Low" Voltage | Vol | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 8 \end{aligned}$ | $\mathrm{IOL}^{\text {a }}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |  |
| Input/Output Leakage Current | IIILI | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 9 \end{aligned}$ | $\mathrm{V}_{\text {in }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 2 |
| Pull-Up MOS Current | $-l_{p}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 9 \end{aligned}$ | $\begin{aligned} & V_{\mathrm{cc}}=5 \mathrm{~V} \\ & V_{\mathrm{in}}=0 \mathrm{~V} \end{aligned}$ | 30 | 60 | 120 | $\mu \mathrm{A}$ | 3 |

(Note 1) Applied to I/O pins with "CMOS" Output selected by mask option.
(Note 2) Pull-up MOS current and output buffer current are excluded.
(Note 3) Applied to I/O pins with "with Pull-up MOS" selected by mask option.

- INPUT/OUTPUT CHARACTERISTICS FOR HIGH VOLTAGE PIN
$\mathrm{V}_{\mathrm{CC}}=4 \mathrm{~V}$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathbf{C C}}-40 \mathrm{~V}$ to $\mathrm{V}_{\text {cc }}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| $\begin{aligned} & \hline \text { Input "High" } \\ & \text { Voltage } \\ & \hline \end{aligned}$ | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15}, \mathrm{R}_{1} \\ & \mathrm{R2}, \mathrm{R}_{\mathrm{AO}}, \mathrm{R}_{\mathrm{A} 1} \end{aligned}$ |  | $0.7 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & \mathrm{D} 4 \sim \mathrm{D}_{15}, \mathrm{R}_{1} \\ & \mathrm{R} 2, \mathrm{R}_{\mathrm{A} 0}, \mathrm{R}_{\mathrm{A} 1} \end{aligned}$ |  | $\mathrm{V}_{\mathrm{Cc}}-40$ | - | $0.22 V_{\text {cc }}$ | V |  |
| Output "High" Voltage | $\mathrm{V}_{\text {OH }}$ | $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ | $-\mathrm{I}_{\mathrm{OH}}=15 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | $\mathrm{V}_{\mathrm{cc}}-3.0$ | - | - | V |  |
|  |  |  | $-1 \mathrm{OH}=9 \mathrm{~mA}$ | $\mathrm{V}_{\text {CC }}-2.0$ | - | - | V |  |
|  |  | $\mathrm{RO} \sim \mathrm{R} 2$ | $-\mathrm{O}_{\mathrm{OH}}=3 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | $V_{c c}-3.0$ | - | - | V |  |
|  |  |  | $-\mathrm{I}_{\mathrm{OH}}=1.8 \mathrm{~mA}$ | $V_{c c}-2.0$ | - | - | V |  |
| Output "Low" <br> Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & \text { RO~R2 } \end{aligned}$ | $\mathrm{V}_{\text {disp }}=\mathrm{V}_{\text {cc }}-40 \mathrm{~V}$ | - | - | $\mathrm{V}_{\mathrm{cc}}-37$ | V | 1 |
|  |  | $\begin{aligned} & D_{4} \sim D_{15} \\ & R 0 \sim R 2 \end{aligned}$ | $150 \mathrm{k} \Omega$ to $\mathrm{V}_{\mathrm{cc}}-40 \mathrm{~V}$ | - | - | $\mathrm{V}_{\mathrm{cc}}-37$ | V | 2 |
| Input/Output Leakage Current | $\\|_{\text {IL }} \mathrm{l}$ | $\begin{aligned} & \hline \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & \mathrm{RO} \sim \mathrm{R}_{2} \\ & \mathrm{R}_{\mathrm{AO}}, \mathrm{R}_{\mathrm{A} 1} \end{aligned}$ | $V_{\text {in }}=V_{c c}-40 \mathrm{~V}$ to $V_{c c}$ | - | - | 20 | $\mu \mathrm{A}$ | 3 |
| Pull Down MOS Current | $l_{d}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & \mathrm{RO}_{2} \sim \mathrm{R}_{2} \\ & \mathrm{R}_{\mathrm{AO}}, \mathrm{R}_{\mathrm{A} 1} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\text {disp }}=\mathrm{V}_{\mathrm{cc}}-35 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{in}}=\mathrm{V}_{\mathrm{cc}} \end{aligned}$ | 125 | 250 | 500 | $\mu \mathrm{A}$ | 4 |

(Note 1) Applied to I/O pins with "with Pull-down MOS" selected by mask option.
(Note 2) Applied to I/O pins with "without Pull-down MOS (PMOS Open Drain)" selected by mask option.
(Note 3) Pull-down MOS current and output buffer current are excluded.
(Note 4) Applied to $1 / O$ pins with "with Pull-down MOS" selected by mask option.


| Item |  | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  |  | typ | max |  |  |
|  | Oscillation Frequency |  | $\mathrm{f}_{\mathrm{ox}}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ |  | 0.4 | 4 | 4.5 | MHz |  |
|  | Instruction Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  |  | 1.78 | 2 | 20 | $\mu \mathrm{s}$ |  |
|  | Oscillator Stabilization Time | $t_{\text {R }}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ |  | - | - | 20 | ms | 1 |
|  | Oscillation Frequency | $\mathrm{f}_{\mathrm{os}}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ | $\mathrm{R}_{\mathrm{f}}=20 \mathrm{k} \Omega \pm 2 \%$ | 1.8 | 3.0 | 4.2 | MHz |  |
|  | Instruction Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  | $\mathrm{R}_{\mathrm{f}}=20 \mathrm{k} \Omega \pm 2 \%$ | 1.9 | 2.66 | 4.44 | $\mu \mathrm{s}$ |  |
|  | Oscillator Stabilization Time | $\mathrm{t}_{\mathrm{RC}}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ | $\mathrm{R}_{\mathrm{f}}=20 \mathrm{k} \Omega \pm 2 \%$ | - | - | 0.5 | ms | 1 |
|  | External Clock Frequency | ${ }^{\text {f }}$ PP | $\mathrm{OSC}_{1}$ |  | 0.4 | - | 4.5 | MHz | 2 |
|  | External Clock "High" Level Width | ${ }_{\text {t }}^{\text {CPH }}$ | OSC ${ }_{1}$ |  | 100 | - | - | ns | 2 |
|  | External Clock "Low" Level Width | ${ }^{\text {t }}$ CPL | $\mathrm{OSC}_{1}$ |  | 100 | - | - | ns | 2 |
|  | External Clock Rise Time | ${ }^{\text {tepr }}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
|  | External Clock Fall Time | ${ }^{\text {t }}{ }_{\text {cPf }}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
|  | Instruction Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  |  | 1.78 | - | 20 | $\mu \mathrm{s}$ | 2 |
| INTo "High" Level Width |  | $\mathrm{t}_{\mathrm{IOH}}$ | INTo |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 3 |
| INTo "'Low" Level Width |  | $\mathrm{t}_{10 \mathrm{~L}}$ | into |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 3 |
| $\overline{\mathrm{NT}} \mathrm{T}^{\text {' }}$ "High" Level Width |  | $\mathrm{t}_{11 \mathrm{H}}$ | $\overline{\mathrm{INT}_{1}}$ |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 3 |
| $\overline{\mathrm{INT}_{1}}$ "Low" Level Width |  | $\mathrm{t}_{11 \mathrm{~L}}$ | $\overline{\text { INT }} 1$ |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 3 |
| RESET "High" Level Width |  | $\mathrm{t}_{\text {RSTH }}$ | RESET |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 4 |
| Input Capacitance |  | $\mathrm{C}_{\text {in }}$ | all pins | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V_{\text {in }}=0 \mathrm{~V} \end{aligned}$ | - | - | 15 | pF |  |
| RESET Fall Time |  | $\mathrm{t}_{\text {RSTf }}$ |  |  | - | - | 20 | ms | 4 |

(Note 1) Oscillator stabilization time is the time until the oscillator stabilizes after $V_{C C}$ reaches 4.0 V at "Power-on", or after RESET input level goes to "High" by resetting to quit the stop mode by MCU reset on the circuits below. When using crystal or ceramic filter oscillator, please ask a crystal oscillator maker's or ceramic filter maker's advice because oscillator stabilization time depends on the circuit constant and stray capacity.


Crystal: 4.194304MHz NC-18C(Nihon Denpa Kogyo)
Rf: $\mathbf{1 M} \Omega \pm \mathbf{2 \%}$
$C_{1}: 22 \mathrm{pF} \pm 20 \%$
$\mathrm{C}_{2}$ : $22 \mathrm{pF} \pm 20 \%$
(Note 2)
(Note 4)

RESET

OSC

Resistor oscillator


Rf: $20 k \Omega \pm 2 \%$

GND
Ceramic filter: CSA4.00M G (Murata)
Rf: $\mathbf{1 M H z} \pm \mathbf{2 \%}$
$C_{1}: 30 \mathrm{pF} \pm 20 \%$
$\mathrm{C}_{2}: 30 \mathrm{pF} \pm 20 \%$
(Note 3)
$\overline{\mathbf{N T}_{0}} \cdot \overline{\mathrm{NT}}$


- SERIAL INTERFACE TIMING CHARACTERISTICS
( $\mathrm{V}_{\mathrm{CC}}=4 \mathrm{~V}$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)
- At Transfer Clock Output

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | ${ }^{\text {t Seye }}$ | $\overline{\text { SCK }}$ | (Note 2) | 1 | - | - | $\mathrm{t}_{\text {cyc }}$ | 1,2 |
| Transfer Clock "High" Level Width | $\mathrm{t}_{\text {SCKH }}$ | $\overline{\text { SCK }}$ | (Note 2) | 0.5 | - | - | ${ }^{\text {tseyc }}$ | 1,2 |
| Transfer Clock "Low" Level Width | ${ }^{\text {tscki }}$ | $\overline{\text { SCK }}$ | (Note 2) | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1, 2 |
| Transfer Clock Rise Time | tsckr | $\overline{\text { SCK }}$ | (Note 2) | - | - | 100 | ns | 1,2 |
| Transfer Clock Fall Time | ${ }^{\text {tscki }}$ | SCK | (Note 2) | - | - | 100 | ns | 1,2 |
| Serial Output Data Delay Time | toso | SO | (Note 2) | - | - | 300 | ns | 1, 2 |
| Serial Input Data Set-up Time | ${ }^{\text {tss }}$ | SI |  | 500 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HSI}}$ | SI |  | 150 | - | - | ns | 1 |

- At Transfer Clock Input

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | $\mathrm{t}_{\text {Scyc }}$ | $\overline{\text { SCK }}$ |  | 1 | - | - | $\mathrm{t}_{\mathrm{cvc}}$ | 1 |
| Transfer Clock "High" Level Width | $\mathrm{t}_{\text {SCKH }}$ | $\overline{\text { SCK }}$ |  | 0.5 | - | - | ${ }^{\text {tsayc }}$ | 1 |
| Transfer Clock "Low" Level Width | $\mathrm{t}_{\text {sckL }}$ | $\overline{\text { SCK }}$ |  | 0.5 | - | - | ${ }^{\text {t }}$ Scyc | 1 |
| Transfer Clock Rise Time | $\mathrm{t}_{\text {sckr }}$ | $\overline{\text { SCK }}$ |  | - | - | 100 | ns | 1 |
| Transfer Clock Fall Time | $\mathrm{t}_{\text {sckf }}$ | $\overline{\text { SCK }}$ |  | - | - | 100 | ns | 1 |
| Serial Output Data Delay Time | $t_{\text {dso }}$ | SO | (Note 2) | - | - | 300 | ns | 1,2 |
| Serial Input Data Set-up Time | $\mathrm{t}_{\mathrm{ss}}$ | SI |  | 500 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HSI}}$ | SI |  | 150 | - | - | ns | 1 |

(Note 1) Timing Diagram of Serial Interface


* $V_{C C}-2.0 \mathrm{~V}$ and 0.8 V are the threshold voltage for transfer clock output. $0.7 \mathrm{~V}_{\mathrm{CC}}$ and $0.22 \mathrm{~V}_{\mathrm{CC}}$ are the threshold voltage for transfer clock input.
(Note 2) Timing Load Circuit

- CHARACTERISTICS CURVE (REFERENCE DATA)


Icc vs. $\mathrm{f}_{\text {osc }}$ Characteristics (Crystal, Ceramic Filter Oscillator Option)


Icc vs. fosc Characteristics (Resistor Oscillator Option)


ISBY vs. fosc Characteristics (Crystal, Ceramic Filter Oscillator Option)


Icc vs. Vcc Characteristics
(Crystal, Ceramic Filter Oscillator Option)

${ }^{\prime} \mathrm{cc}$ vs. $\mathrm{V}_{\mathrm{cc}}$ Characteristics (Resistor Oscillator Option)

$I_{\text {SBY }}$ vs. $V_{C C}$ Characteristics
(Crystal, Ceramic Filter Oscillator Option)


ISBY vs. fosc Characteristics (Resistor Oscillator Option)

-Ip (Pull-up MOS Current) vs.
$V_{\text {CC }}$ Characteristics


IOL min. vs. VOL Characteristics (Standard Pin)

$I_{\text {SBY }}$ vs. $V_{\text {CC }}$ Characteristics (Resistor Oscillator Option)

$I_{d}$ (Pull-down MOS Current) vs. ( $\mathrm{V}_{\mathrm{cc}}-\mathrm{V}_{\text {disp }}$ ) Characteristics

$-I_{\mathrm{OH}}$ min vs. $\left(\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{OH}}\right)$ Characteristics (Standard Pin "CMOS")


- DESCRIPTION OF PIN FUNCTIONS

Input and output signals of MCU are described below.

- GND, $V_{C c}, V_{\text {disp }}$

These are Power Supply Pins. Connect GND pin to Earth ( 0 V ) and apply $\mathrm{V}_{\mathrm{CC}}$ power supply voltage to $\mathrm{V}_{\mathrm{CC}}$ pin. $\mathrm{V}_{\text {disp }}$ is an power supply for high voltage Input/Output pins with maximum voltage of $\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$. $\mathrm{V}_{\text {disp }}$ pin can be also used as R $_{\mathrm{A} 1}$ pin by mask option. For details, see "INPUT/OUTPUT".

- TEST

TEST pin is not for user's application. TEST must be connected to $V_{C C}$.

- RESET

RESET pin is used to reset MCU. For details, see "RESET".

- OSC $_{1}$, OSC $_{2}$

These are Input pins to the internal oscillator circuit. They can be connected to crystal resonator, ceramic filter resonator, $\mathrm{R}_{\mathrm{f}}$ oscillator, or external oscillator circuit. Select the circuit of MCU by mask option corresponding to the oscillator type. For details, see "INTERNAL OSCILLATOR CIRCUIT."

## - D-port ( $\mathrm{D}_{0}$ to $\mathrm{D}_{15}$ )

D-port is a 1-bit Input/Output common port. $D_{0}$ to $D_{3}$ are standard type, $D_{4}$ to $D_{15}$ are for high voltage. Each pin has the mask option to select its circuit type. For details, See "INPUT/ OUTPUT".

## - R-port (R0 to RA)

R-port is a 4-bit Input/Output port. (only RA is 2-bit construction.) R0 and R6 to R8 are output ports, R9 to RA are input ports, and R1 to R5 are Input/Output common ports. R0 to R2 and RA are the high voltage ports, R3 to R9 are the standard ports. Each pin has the mask option to select its circuit type. $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ are also available as

$\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}, \overline{\mathrm{SCK}}$, SI and SO respectively. For details, see "INPUT/OUTPUT".

- $\overline{\mathbf{I N T}_{0}}, \overline{\text { INT }_{1}}$

These are the input pins to interrupt MCU operation externally. $\overline{\mathrm{INT}_{1}}$ can be used as an external event input pin for TIMER-B. $\overline{\overline{I N T}_{0}}$ and $\overline{\text { INT }_{1}}$ are also available as $\mathrm{R}_{32}$, and $\mathrm{R}_{33}$ respectively. For details, See "INTERRUPT".

- $\overline{\mathbf{S C K}}, \mathbf{S I}, \mathbf{S O}$

These are Transfer clock I/O pin ( $\overline{\mathrm{SCK}}$ ), serial data input pin (SI) and serial data output pin (SO) used for serial interface. SCK, SI, and SO are also available as $\mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ respectively. For details, see "SERIAL INTERFACE".

## - ROM MEMORY MAP

MCU includes 4096 words $\times 10$ bits ROM. ROM memory map is illustrated in Fig. 1 and described in the following paragraph.

- Vector Address Area ..... \$0000 to \$000F

When MCU is reset or an interrupt is serviced, the program is executed from the vector address. Program the JMPL instructions branching to the starting addresses of reset routine or of interrupt routines.

## - Zero-Page Subroutine Area ..... \$0000 to \$003F

CAL instruction allows to branch to the subroutines in $\$ 0000$ to $\$ 003 \mathrm{~F}$.

- Pattern Area ..... \$0000 to \$0FFF

P instruction allows referring to the ROM data in $\$ 0000$ to \$OFFF as a pattern.

[^7]

Fig. 1 ROM Memory Map

- RAM MEMORY MAP

MCU includes 256 digits $\times 4$ bits RAM as the data area and stack area. In addition to these areas, interrupt control bits
and special registers are also mapped on the RAM memory space. RAM memory map is illustrated in Fig. 2 and described in the following paragraph.


* Two registers are mapped on same address.

R :Read Only
W :Write Only
R/W:Read/Write


Fig. 2 RAM Memory Map


Fig. 3 Configuration of Interrupt Control Bit Area

- Interrupt Control Bit Area ..... \$000 to \$003

This area is used for interrupt controls, and is illustrated in Fig.3. It is accessable only by RAM bit manipulation instruction. However, the interrupt request flag cannot be set by software.

- Special Register Area ..... $\mathbf{\$ 0 0 4}$ to $\mathbf{\$ 0 0 B}$

Special Register is a mode or a data register for the external interrupt, the serial interface, and the timer/counter. These registers are classified into 3 types: Write-only, Read-only, and Read/Write as shown in Fig. 2. These registers cannot be accessed by RAM bit manipulation instruction.

- Data Area ..... \$020 to \$0DF

16 digits of $\$ 020$ to $\$ 02 \mathrm{~F}$ are called memory register (MR) and accessable by LAMR and XMRA instructions.

- Stack Area .... \$3C0 to \$3FF

Stack Area is used for LIFO stacks with the contents of the program counter (PC), status (ST) and carry (CA) when processing subroutine call and interrupt. As 1 level requires 4 digits, this stack area is nested to 16 level-stack max. The data pushed in the stack and LIFO stack state are provided in Fig. 4. The program counter is restored by RTN and RTNI instructions. Status and Carry are restored only by RTNI instruction. The area, not used for stacking, is available as a data area.

| Memory Regist |  |  |
| :---: | :---: | :---: |
| 32 | MR(0) | \$ 020 |
| 33 | MR(1) | \$ 021 |
| 34 | MR(2) | \$ 022 |
| 35 | MR(3) | \$ 023 |
| 36 | MR(4) | \$ 024 |
| 37 | MR(5) | \$ 025 |
| 38 | MR(6) | \$ 026 |
| 39 | MR(7) | \$ 027 |
| 0 | MR(8) | \$ 028 |
| 1 | MR(9) | 029 |
| 42 | MR(10) | \$ 02A |
| 43 | MR(11) | \$ 02B |
| 44 | MR(12) | \$ 02C |
| 45 | MR(13) | \$ 02D |
| 46 | MR(14) | \$ 02E |
| 47 | MR(15) | \$ 02F |



$\mathrm{PC}_{13}$ to $\mathrm{PC}_{0}$; Program Counter
ST; Status
CA; Carry
Fig. 4 Configuration of Memory Register, Stack Area and Stack Position

## - REGISTER AND FLAG

The MCU has nine registers and two flags for the CPU operations. They are illustrated in Fig. 5 and described in the following paragraphs.

## - Accumulator (A), B Register (B)

Accumulator and B Register are 4-bit registers used to hold the results of Arithmetic Logic Unit (ALU), and to transfer data to/from memories, $\mathrm{I} / \mathrm{O}$ and other registers.

- W Register (W), X Register (X), Y Register (Y)

W Register is 2-bit, and $\mathbf{X}$ and $Y$ Register are 4-bit registers used for indirect addressing of RAM. Y register is also used for $\mathbf{D}$-port addressing.

## - SPX Register (SPX), SPY Register (SPY)

SPX and SPY Register are 4-bit registers used to assist X and Y Register respectively.

- Carry (CA)

Carry (CA) stores the overflow of ALU generated by the arithmetic operation. It is also affected by SEC, REC, ROTL and ROTR instructions.

During interrupt servicing, Carry is pushed onto the stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Status (ST)

Status (ST) holds the ALU overflow, ALU non-zero and the results of bit test instruction for the arithmetic or compare instruction. It is used for a branch condition of BR, BRL, CAL or CALL instructions. The value of the Status remains unchanged until the next arithmetic, compare or bit test instruction is executed. Status becomes " 1 " after the BR, BRL, CAL or CALL instruction has been executed (irrespective of its execution/ skip). During the interrupt servicing, Status is pushed onto the


Fig. 5 Register and Flags
stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Program Counter (PC)

Program Counter is a 14 -bit binary counter for ROM addressing.

## - Stack Pointer (SP)

Stack Pointer is used to point the address of the next stacking area up to 16 levels.

The Stack Pointer is initialized to locate \$3FF on the RAM address, and is decremented by 4 as data pushed into the stack, and incremented by 4 as data restored back from the stack.

## - INTERRUPT

The MCU can be interrupted by five different sources: the external signals ( $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}$ ), timer/counter (TIMER-A, TIMER-B), and serial interface (SERIAL). In each sources, the Interrupt Request Flag, Interrupt Mask and interrupt vector address will be used to control and maintain the interrupt request. The Interrupt Enable Flag is also used to control the total interrupt operations.

## - Interrupt Control Bit and Interrupt Service

The interrupt control bit is mapped on $\$ 000$ to $\$ 003$ of the RAM address and accessable by RAM bit manipulation instruction. (The Interrupt Request Flag (IF) cannot be set by software.) The Interrupt Enable Flag (I/E) and Interrupt Request Flag (IF) are set to " 0 ", and the Interrupt Mask (IM) is set to " 1 " at the initialization by MCU reset.

Fig. 6 shows the interrupt block diagram. Table 1 shows the interrupt priority and vector addresses, and Table 2 shows the conditions that the interrupt service is executed by any one of the five interrupt sources.

The interrupt request is generated when the Interrupt Re quest Flag is set to " 1 " and the Interrupt Mask is " 0 ". If the Interrupt Enable Flag is " 1 ", then the interrupt will be activated and vector addresses will be generated from the priority PLA corresponding to the five interrupt sources.

Fig. 7 shows the interrupt services sequence, and Fig. 8 shows the interrupt flowchart. If the interrupt is requested, the instruction finishes its execution in the first cycle. The Interrupt Enable Flag is reset in the second cycle. In the second and third cycles, the Carry, Status and Program Counter are pushed onto the stack. In the third cycle, the instruction is executed again after jumping to the vector address.

In each vector address, program JMPL instruction to branch to a starting address of the interrupt routine. The Interrupt Request Flag which caused the interrupt service has to be reset by software in the interrupt routine.


Fig. 6 Interrupt Circuit Block Diagram

Table 1. Vector Addresses and Interrupt Priority

| Reset, Interrupt | Priority | Vector addresses |
| :---: | :---: | :---: |
| RESET | - | $\$ 0000$ |
| $\overline{I_{N} T_{0}}$ | 1 | $\$ 0002$ |
| $\overline{\text { INT }_{1}}$ | 2 | $\$ 0004$ |
| TIMER-A | 3 | $\$ 0006$ |
| TIMER-B | 4 | $\$ 0008$ |
| SERIAL | 5 | $\$ 000 \mathrm{C}$ |

Table 2. Conditions of Interrupt Service

| Interrupt <br> control bitsInterrupt <br> source | $\overline{\mathbb{I N T}_{0}}$ | $\overline{\overline{I N T}_{1}}$ | TIMER-A | TIMER-B | SERIAL |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/E | 1 | 1 | 1 | 1 | 1 |
| IFO $\overline{\mathrm{IMO}}$ | 1 | 0 | 0 | 0 | 0 |
| IF1 $\cdot \overline{\mathrm{IM} 1}$ | $*$ | 1 | 0 | 0 | 0 |
| IFTA $\cdot \overline{\mathrm{IMTA}}$ | $*$ | $*$ | 1 | 0 | 0 |
| IFTB $\overline{\mathrm{IMTB}}$ | $*$ | $*$ | $*$ | 1 | 0 |
| IFS $\cdot \overline{\mathrm{MSS}}$ | $*$ | $*$ | $*$ | $*$ | 1 |

## HMCS404C



JMPL instruction execution on the
vector address

Fig. 7 Interrupt Servicing Sequence


- Interrupt Enable Flag (I/E: $\mathbf{\$ 0 0 0 , 0}$ )

The Interrupt Enable Flag controls enable/disable of all interrupt requests as shown in Table 3. The Interrupt Enable Flag is reset by the interrupt servicing and set by RTNI instruction.

Table 3. Interrupt Enable Flag

| Interrupt Enable Flag | Interrupt Enable/Disable |
| :---: | :---: |
| 0 | Disable |
| 1 | Enable | - External Interrupt ( $\overline{\mathbf{I N T}}, \overline{\mathbf{I N T}_{1}}$ )

To use external interrupt, select $\mathrm{R}_{32} / \overline{\mathrm{INT}}, \mathrm{R}_{33} / \overline{\mathrm{INT}_{1}}$ port for $\overline{\mathrm{INT}}{ }_{0}, \overline{\mathrm{INT}} \mathrm{I}_{1}$ mode by setting the Port Mode Register (PMR: \$004).

The External Interrupt Request Flags (IF0, IF1) are set at the falling edge of $\overline{\mathrm{INT}} \mathrm{T}_{0}, \overline{\mathrm{INT}}_{1}$ inputs.
$\overline{\mathrm{INT}}_{1}$ input can be used as a clock signal input of TIMER-B. Then, TIMER-B counts up at each falling edge of input. When using $\overline{\text { INT }_{1}}$ as TIMER-B external event, an External Interrupt Mask (IM1) has to be set so that the interrupt request by $\overline{\mathrm{INT}_{1}}$ will not be accepted.

- External Interrupt Request Flag (IF0: $\mathbf{\$ 0 0 0 , 2 ,}$ IF1: $\mathbf{\$ 0 0 1 , 0}$

The External Interrupt Request Flags (IF0, IF1) are set at the falling edges of $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}}_{1}$ inputs respectively.

- External Interrupt Mask (IM0: $\mathbf{\$ 0 0 0 , 3}$, IM1: $\mathbf{\$ 0 0 1 , 1 )}$

The External Interrupt Mask is used to mask the external interrupt requests.

Table 4. External Interrupt Request Flag

| External Interrupt Request Flags | Interrupt Requests |
| :---: | :---: |
| 0 | No |
| $\mathbf{1}$ | Yes |

Table 5. External Interrupt Mask

| External Interrupt Masks | Interrupt Requests |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (masks) |

## - Port Mode Register (PMR: \$004)

The Port Mode Register is a 4 -bit write-only register which controls the $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}}$ pin, $\mathrm{R}_{33} / \overline{\mathrm{INT}_{1}}$ pin, $\mathrm{R}_{41} / \mathrm{SI}$ pin and $\mathrm{R}_{42} / \mathrm{SO}$ pin as shown in Table 6. The Port Mode Register will be initialized to $\$ 0$ by MCU reset, so that all these pins are set to a port mode.

Table 6. Port Mode Register

| PMR | $\mathrm{R}_{33} / \overline{\mathrm{INT}}_{1} \mathrm{pin}$ |
| :---: | :---: |
| bit 3 |  |
| 0 | Used as $\mathrm{R}_{33}$ port input/output pin |
| 1 | Used as $\mathrm{INT}_{1}$ input pin |
| PMR | $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}} \mathrm{pin}$ |
| bit 2 |  |
| 0 | Used as R32 port input/output pin |
| 1 | Used as $\mathrm{INT}_{0}$ input pin |
| PMR | $\mathrm{R}_{41} / \mathrm{SI}$ pin |
| bit 1 |  |
| 0 | Used as $\mathrm{R}_{41}$ port input/output pin |
| 1 | Used as SI input pin |
| PMR | $\mathrm{R}_{42} / \mathrm{SO}$ pin |
| bit 0 |  |
| 0 | Used as $\mathrm{R}_{42}$ port input/output pin |
| 1 | Used as SO output pin |



Fig. 8 Interrupt Servicing Flowchart

## - SERIAL INTERFACE

The serial interface is used to transmit/receive 8 -bit data serially. This consists of the Serial Data Register, the Serial Mode Register, the Octal Counter and the multiplexer, as illustrated in Fig. 9. Pin $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the transfer clock signal are controlled by the Serial Mode Register. Contents of the Serial Data Register can be written into or read out by the software. The data in the Serial Data Register can be shifted synchronous-
ly with the transfer clock signal.
The serial interface operation is initiated with STS instruction. The Octal Counter is reset to $\$ 0$ by STS instruction. It starts to count at the falling edge of the transfer clock ( $\overline{\mathrm{SCK}}$ ) signal and increments by one at the rising edge of the SCK. When the Octal Counter is reset to $\$ 0$ after eight transfer clock signals, or discontinued transmit/receive operation by resetting the Octal Counter, the SERIAL Interrupt Request Flag will be set.


Fig. 9 Serial Interface Block Diagram

- Serial Mode Register (SMR: \$005)

The Serial Mode Register is a 4 -bit write-only register. This register controls the $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the prescaler divide ratio as the transfer clock source as shown in Table 7.

The Write Signal to the Serial Mode Register controls the operating state of serial interface.

The Write Signal to the Serial Mode Register stops the transfer clock applied to the Serial Data Register and the Octal Counter. And it also reset the Octal Counter to $\$ 0$ simultaneously.

When the Serial Interface is in the "Transfer State", the Write Signal to the Serial Mode Register causes to quit the data transfer and to set the SERIAL Interrupt Request Flag.

Contents of the Serial Mode Register will be changed on the second instruction cycle after writing into the Serial Mode Register. Therefore, it will be necessary to execute the STS instruction after the data in the Serial Mode Register has been changed completely. The Serial Mode Register will be reset to $\$ 0$ by MCU reset.

- Serial Data Register (SRL: \$006, SRU: \$007)

The Serial Data Register is an 8 -bit read/write register. It consists of a low-order digit (SRL:\$006) and a high-order digit (SRU: \$007).

The data in the Serial Data Register will be output from the LSB side at SO pin synchronously with the falling edge of the transfer clock signal. At the same time, external data will be input from the LSB side at SI pin to the Serial Data Register synchronously with the rising edge of the transfer clock. Fig. 10 shows the I/O timing chart for the transfer clock signal and the data.

The writing into/reading from the Serial Data Register during its shifting causes the validity of the data.

Therefore complete data transmit/receive before writing into/reading from the serial data register.

Table 7. Serial Mode Register

| SMR | R $_{40} /$ SCK |
| :---: | :---: |
| Bit 3 |  |
| 0 | Used as R40 port input/output pin |
| 1 | Used as $\overline{\text { SCK }}$ input/output pin |


| SMR |  |  | Transfer Clock |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 | R40/位 Port | Clock Source | Prescaler <br> Divide <br> Ratio | System Clock <br> Divide <br> Ratio |
| 0 | 0 | 0 | SCK <br> Output | Prescaler | $\div 2048$ | $\div 4096$ |
| 0 | 0 | 1 | SCK <br> Output | Prescaler | $\div 512$ | $\div 1024$ |
| 0 | 1 | 0 | $\overline{\text { SCK }}$ <br> Output | Prescaler | $\div 128$ | $\div 256$ |
| 0 | 1 | 1 | $\overline{\text { SCK }}$ <br> Output | Prescaler | $\div 32$ | $\div 64$ |
| 1 | 0 | 0 | SCK <br> Output | Prescaler | $\div$ | 8 |
| 1 | 0 | 1 | SCK <br> Output | Prescaler | $\div$ | 2 |
| 1 | 1 | 0 | $\overline{\text { SCK }}$ <br> Output | System <br> Clock | - | $\div$ |
| 1 | 1 | 1 | $\overline{\text { SCK }}$ <br> Input | External <br> Clock | - | $\div$ |



Fig. 10 Serial Interface I/O Timing Chart

SERIAL Interrupt Request Flag (IFS: \$003, 0)
The SERIAL Interrupt Request Flag will be set after the eight transfer clock signals or transmit/receive discontinued operation by resetting the Octal Counter.

- SERIAL Interrupt Mask (IMS: \$003, 1)

The SERIAL Interrupt Mask masks the interrupt request.
Table 8. SERIAL Interrupt Request Flag

| SERIAL Interrupt Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 9. SERIAL Interrupt Mask

| SERIAL Interrupt Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (mask) |

- Selection of the Operation Mode

Table 10 shows the operation mode of the serial interface. Select a combination of the value in the Port Mode Register and the Serial Mode Register according to Table 10.

Initialize the serial interface by the Write Signal to the Serial Mode Register, when the Operation Mode is changed.

## - Operating State of Serial Interface

The serial interface has 3 operating states as shown in Fig. 11.
The serial interface gets into "STS waiting state" by 2 ways: one way is to change the operation mode by changing the data
in the Port Mode Register, the other is to write data into the Serial Mode Register. In this state, the serial interface does not operate although the transfer clock is applied. If STS instruction is executed, the serial interface changes its state to "SCK waiting state".

In the "SCK waiting state", the falling edge of first transfer clock affects the serial interface to get into "transfer state", while the Octal Counter counts-up and the Serial Data Register shifts simultaneously. As an exception, if the clock continuous output mode is selected, the serial interface stays in "SCK waiting state" while the transfer clock outputs continuously.

The Octal Counter becomes "000" again by 8 transfer clocks or execution of STS instruction, so that the serial interface gets back into the "SCK waiting state", and SERIAL Interrupt Request Flag is set simultaneously.

When the internal transfer clock is selected, the transfer clock output are triggered by the execution of STS instruction, and it stops after 8 clocks.

## - Example of Transfer Clock Error Detection

The serial interface functions abnormally when the transfer clock was disturbed by external noises. In this case, the transfer
clock error can be detected in the procedure shown in Fig. 12.
If more than 9 transfer clocks are applied by the external noises in the "SCK waiting state", the state of the serial interface shifts as the following sequence: first "transfer state" (while 1 to 7 transfer clocks), second "SCK waiting state" (at 8th transfer clock) and third "transfer state" again. Then reset the SERIAL Interrupt Request Flag, and make "STS waiting state" by writing to the Serial Mode Register. SERIAL Interrupt Request Flag is set again in this procedure, and it shows that the transfer clock was invalid and that the transmit/receive data were also invalid.

Table 10. Serial Interface Operation Mode

| SMR | PMR |  | Serial Interface Operating Mode |
| :---: | :---: | :---: | :--- |
| Bit 3 | Bit $\mathbf{1}$ | Bit 0 |  |
| 1 | 0 | 0 | Clock Continuous Output Mode |
| 1 | 0 | 1 | Transmit Mode |
| 1 | 1 | 0 | Receive Mode |
| 1 | 1 | 1 | Transmit/Receive Mode |




Fig. 12 Example of Transfer Clock Error Detection

## - TIMER

The MCU contains a prescaler and two timer/counters (TIMER-A, TIMER-B), Fig. 13 shows the block diagram. The prescaler is an 11 -bit binary counter. TIMER-A is an 8 -bit free-running timer. TIMER-B is an 8 -bit auto-reload timer/ event counter.

## - Prescaler

The input to the prescaler is a system clock signal. The prescaler is initialized to $\$ 000$ by MCU reset, and the prescaler starts to count up the system clock signal as soon as RESET input goes to logic " 0 ". The prescaler keeps counting up except MCU reset and stop mode. The prescaler provides clock signals to TIMER-A, TIMER-B and serial interface. The prescaler devide ratio of the clock signals are selected according to the content of the mode registers such as - Timer Mode Register A (TMA), Timer Mode Register B (TMB), Serial Mode Register (SMR).


Fig. 13 Timer/Counter Block Diagram

- TIMER-A Operation

After TIMER-A is initialized to $\$ 00$ by MCU reset, it counts up at every clock input signal. When the next clock signal is applied after TIMER-A is counted up to \$FF, TIMER-A is set to $\$ 00$ again, and generating overflow output. This leads to setting TIMER-A Interrupt Request Flag (IFTA: \$001, 2) to " 1 ". Therefore, this timer can function as an interval timer periodically generating overflow output at every 256th clock signal input.

The clock input signals to TIMER-A are selected by the Timer Mode Register A (TMA: \$008).

## - TIMER-B Operation

Timer Mode Register B (TMB: \$009) is used to select the auto-reload function and the prescaler divide ratio of TIMER-B as the input clock source. When the external event input is used as an input clock signal to TIMER-B, select the $\mathrm{R}_{33} / / \overline{\mathrm{INT}_{1}}$ as INT $_{1}$ and set the External Interrupt Mask (IM1) to " 1 " to prevent the external interrupt request from occurring.

TIMER-B is initialized according to the value written into the Timer Load Register by software. TIMER-B counts up at every clock input signal. When the next clock signal is applied to TIMER-B after TIMER-B is set to \$FF, TIMER-B will be initialized again and generate overflow output. In this case if the auto-reload function is selected. TIMER-B is initialized according to the value of the Timer Load Register. Else if the autoreload function is not selected, TIMER-B goes to \$00. TIMERB Interrupt Request Flag (IFTB: $\$ 002,0$ ) will be set at this overflow output.

- Timer Mode Register A (TMA: \$008)

The Timer Mode Register A is a 3-bit write-only register. The TMA controls the prescaler divide ratio of TIMER-A clock input, as shown in Table 11.

The Timer Mode Register A is initialized to $\$ 0$ by MCU reset.

## - Timer Mode Register B (TMB: \$009)

The Timer Mode Register B is a 4-bit write-only register. The Timer Mode Register B controls the selection for the autoreload function of TIMER-B and the prescaler divide ratio, and the source of the clock input signal, as shown in Table 12.

The Timer Mode Register B is initialized to $\$ 0$ by MCU reset.
The operation mode of TIMER-B is changed at the second instruction cycle after writing into the Timer Mode Register B.

Therefore, it is necessary to program the write instruction to TLRU after the content of TMB is changed.

Table 11. Timer Mode Register A

| TMA |  |  | Prescaler Divide Ratio |
| :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 |  |
| 0 | 0 | 0 | $\div 2048$ |
| 0 | 0 | 1 | $\div 1024$ |
| 0 | 1 | 0 | $\div 512$ |
| 0 | 1 | 1 | $\div 128$ |
| 1 | 0 | 0 | $\div 32$ |
| 1 | 0 | 1 | $\div 8$ |
| 1 | 1 | 0 | $\div 4$ |
| 1 | 1 | 1 | $\div 2$ |

Table 12. Timer Mode Register B

|  | MB | Auto-reload Function |  |
| :---: | :---: | :---: | :---: |
| Bit 3 |  |  |  |
| 0 |  |  | No |
| 1 |  |  | Yes |
| TMB |  |  | Prescaler Divide Ratio, Clock Input Source |
| Bit 2 | Bit 1 | Bit 0 |  |
| 0 | 0 | 0 | $\div 2048$ |
| 0 | 0 | 1 | $\div 512$ |
| 0 | 1 | 0 | $\div 128$ |
| 0 | 1 | 1 | $\div 32$ |
| 1 | 0 | 0 | $\div 8$ |
| 1 | 0 | 1 | $\div 4$ |
| 1 | 1 | 0 | $\div 2$ |
| 1 | 1 | 1 | $\overline{\mathrm{NT}} \mathrm{T}_{1}$ (External Event Input) |

- TIMER-B ( $\left.\begin{array}{l}\text { TCBL: } \$ 00 A, \text { TCBU: } \$ 00 B \\ \text { TLRL: } \$ 00 A, ~ T L R U: ~ \\ \text { TOOB }\end{array}\right)$

TIMER-B consists of an 8 -bit write-only Timer Load Register, and an 8 -bit read-only Timer/Event Counter. Each of them has a low-order digit (TCBL: \$00A, TLRL: \$00A) and a highorder digit (TCBU: \$00B, TLRU: \$00B).

The Timer/Event Counter can be initialized by writing data into the Timer Load Register. In this case, write the low-order digit first, and then the high-order digit. The Timer/Event Counter is initialized at the time when the high-order digit is written. The Timer Load Register will be initialized to $\$ 00$ by the MCU reset.

The counter value of TIMER-B can be obtained by reading
the Timer/Event Counter. In this case, read the high-order digit first, and then the low-order digit. The count value of low-order digit is latched at the time when the high-order digit is read.

- TIMER-A Interrupt Request Flag (IFTA: \$001, 2)

The TIMER-A Interrupt Request Flag is set by the overflow output of TIMER-A.

- TIMER-A Interrupt Mask (IMTA: \$001, 3)

TIMER-A Interrupt Mask prevents an interrupt request generated by TIMER-A Interrupt Request Flag.

Table 13. TIMER-A Interrupt Request Flag

| TIMERR-A Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 14. TIMER-A Interrupt Mask

| TIMER-A Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

- TIMER-B Interrupt Request Flag (IFTB: $\mathbf{\$ 0 0 2 , 0}$ )

The TIMER-B Interrupt Request Flag is set by the overflow output of TIMER-B.

- TIMER-B Interrupt Mask (IMTB: \$002, 1)

TIMER-B Interrupt Mask prevents an interrupt request generated by TIMER-B Interrupt Request Flag.


Fig. 14 Mode Register Configuration and Function

Table 15. TIMER-B Interrupt Request Flag

| TIMER-B Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 16. TIMER-B Interrupt Mask

| TIMER-B Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

## - INPUT/OUTPUT

The MCU provides 58 Input/Output pins, and they are consist of 32 standard pins and 26 high voltage pins. Each standard pin may have one of three mask options: (A) "Without pullup MOS (NMOS open drain)", (B) "With pull-up MOS", or (C) "CMOS". And also each high voltage pin may have one of two mask options: (D) "Without pull-down MOS (PMOS
open drain)", or (E) "With pull-down MOS". As pull-down MOS is connected to internal $V_{\text {disp }}$ line, select $R_{A 1} / V_{\text {disp }}$ pin as $\mathrm{V}_{\text {disp }}$ with mask option when at least one high voltage pin is selected as "With pull-down MOS" option.

When any Input/Output common pin is used as input pin, it is necessary to select the mask option and output data as shown in Table 18.

- Output Circuit Operation of Standard Pins with 'With pull--up MOS" Option
Fig. 15 shows the circuit used in the standard pins with "with pull-up MOS"option.

By execution of the output instruction, the write pulse will be generated, and be applied to the addressed port. This pulse will turn "ON" the PMOS (B) to make the transient time shorten to obtain "High level", if the output data is changed from " 0 " to " 1 ". In this case, the "write pulse" allows the PMOS (B) to turn "ON" as long as $1 / 8$ instruction cycle. While "write pulse" is " 0 ", pull-up MOS (C) may retain the output in high level.

The $\overline{\mathrm{HLT}}$ signal becomes " 0 " in stop mode, so that MOS (A) (B) (C) turn "OFF".


Output instruction execution

Fig. 15 Output Circuit Operation of Standard Pins with "with Pull-up MOS" Option

HMCS404C

Table 17 I/O Pin Circuit Type

|  |  | Without pull-up MOS (NMOS open drain) (A) | With pull-up MOS <br> (B) | CMOS (C) | Applied pins |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1/O common pins |  |  |  | $D_{0} \sim D_{3}$, <br> $R_{30} \sim R_{33}$, <br> $R_{40} \sim R_{43}$, <br> $R_{50} \sim R_{53}$ |
|  | Output pins |  |  |  | $\begin{aligned} & \mathbf{R}_{60} \sim \mathbf{R}_{63}, \\ & \mathbf{R}_{70} \sim \mathbf{R}_{733}, \\ & \mathbf{R}_{\mathbf{8 0}} \sim \mathbf{R}_{\mathbf{8 3}} \end{aligned}$ |
|  | Input pins |  |  |  | $\mathrm{R}_{90} \sim \mathrm{R}_{93}$ |


|  |  | Without pull-down MOS (PMOS open drain) (D) | With pull-down MOS (E) | Applied pins |
| :---: | :---: | :---: | :---: | :---: |
|  | 1/0 common pins |  |  | $\begin{aligned} & D_{4} \sim D_{15}, \\ & R_{10} \sim R_{13}, \\ & R_{20} \sim R_{23} \end{aligned}$ |
|  | Output pins |  |  | $\mathrm{R}_{00} \sim \mathrm{R}_{03}$ |
|  | Input pins | $\bigcirc-\frac{\overline{H L T}--\underbrace{\text { data }}_{\text {input }} \text { int }}{}$ |  | $\begin{aligned} & \mathrm{R}_{A O}, \\ & \mathrm{R}_{\mathrm{A} 1} / V_{\text {disp }} \end{aligned}$ |
| (Note) In the stop mode, HLT signal is " 0 " and $\mathrm{t} / 0$ pins are in high impedance state. $\quad$ (to be continued) |  |  |  |  |


(Note) In the stop mode, $\overline{H L T}$ signal is " 0 ", HLT signal is " 1 " and I/O pins are in high impedance state.

Table 18 Data Input from Input/Output Common Pins

| I/O pin circuit type |  | Possibility <br> of Input | Available pin condition <br> for input |
| :--- | :--- | :---: | :---: |
| Standard <br> pins | CMOS | No | - |
|  | Without pull-up <br> MOS <br> (NMOS open drain) | Yes | "1" |
|  | With pull-up MOS | Yes | "1" |
|  | Without pull-down <br> MOS <br> (PMOS open drain) | Yes | "0" |
|  | With pull-down <br> MOS | Yes | "0" |

- D-port

D-port is 1-bit I/O port, and it has 16 Input/Output common pins. It can be set/reset by the SED/RED and SEDD/REDD instructions, and can be tested by the TD and TDD instructions. Table 17 shows the classification of standard pins, high voltage pins and the Input/Output pins circuit types.

## - R-port

R-port is 4 -bit $\mathrm{I} / \mathrm{O}$ port. It provides 20 input/output common pins, 16 output-only pins, and 6 input-only pins. Data input is processed using the LAR and LBR instructions and data output is processed using the LRA and LRB instructions. The MCU will not be affected by writing into the input-only and/or non-existing ports, invalid data will be read by reading from the
output-only and/or non-existing ports.
The $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ pins are also used as the $\overline{\mathrm{INT}}{ }^{2}$, $\overline{I_{N T}}, \overline{\text { SCK }}$, SI and SO pins respectively. Table 17 shows the classification of standard pins, high voltage pins and Input/ Output pins circuit types.

## - RESET

The MCU is reset by setting RESET pin to " 1 ". At power ON or recovering from stop mode, apply RESET input more than $t_{R C}$ to obtain the necessary time for oscillator stabilization. In other cases, the MCU reset requires at least two instructions cycle time of RESET input.

Table 19 shows initialized items by MCU reset and each status after reset.

Table 19 Initial Value by MCU Reset

| Items |  |  | Initial value by MCU reset | Contents |
| :---: | :---: | :---: | :---: | :---: |
| Program counter (PC) |  |  | \$0000 | Execute program from the top of ROM address. |
| Status (ST) |  |  | "1" | Enable to branch with conditional branch instructions. |
| Stack pointer (SP) |  |  | \$3FF | Stack level is 0. |
| I/O pin output register | Standard pin | (A) Without pullup MOS | "1" | Enable to input. |
|  |  | (B) With pull-up MOS | "1" | Enable to input |
|  |  | (C) CMOS | "1" | - |
|  | High voltage pin | (D) Without pulldown MOS | "0" | Enable to input. |
|  |  | (E) With pulldown MOS | "0" | Enable to input. |
| Interrupt flag | Interrupt Enable Flag (I/E) |  | '0" | Inhibit all interrupts. |
|  | Interrupt Request Flag (IF) |  | " 0 " | No interrupt request. |
|  | Interrupt Mask (IM) |  | "1" | Mask interrupt request. |
| Mode register | Port Mode Register (PMR) |  | "0000" | See Item "Port Mode Register". |
|  | Serial Mode Register (SMR) |  | "0000" | See Item "Serial Mode Register". |
|  | Timer Mode Register A (TMA) |  | '000" | See Item "Timer Mode Register A". |
|  | Timer Mode Register B (TMB) |  | "0000" | See Item "Timer Mode Register B". |
| Timer/Counter, Serial interface | Prescaler |  | \$000 | - |
|  | Timer/Counter A (TCA) |  | \$00 | - |
|  | Timer/Event Counter B (TCB) |  | \$00 | - |
|  | Timer Load Register (TLR) |  | \$00 | - |
|  | Octal Counter |  | "000" | - |

(Note) MCU reset affects to the rest of registers as follows:

| Item | After recovering from STOP mode by MCU reset | After MCU reset except for the left condition |
| :---: | :---: | :---: |
| Carry (CA) | The contents of the items before MCU reset are not retained. It is necessary to intialize them by software again. | The contents of the items before MCU reset are not retained. It is necessary to initialize them by software again. |
| Accumulator (A) |  |  |
| B Register (B) |  |  |
| W Register $\quad$ (W) |  |  |
| X/SPX Registers (X/SPX) |  |  |
| Y/SPY Registers (Y/SPY) |  |  |
| Serial Data Register (SR) | Same as above | Same as above |
| RAM | The contents of RAM before MCU reset (just before STOP instruction) are retained. | Same as above |

- INTERNAL OSCILLATOR CIRCUIT

Fig. 16 gives internal oscillator circuit. The oscillator type can be selected from the followings; crystal oscillator, ceramic
filter oscillator, or resistor oscillator as shown in Table 20. In any cases, external clock operation is available.


Fig. 16 Internal Oscillator Circuit

- Oscillator Circuit

Table 20 Examples of Oscillator Circuit

|  | Circuit configuration | Remarks |
| :---: | :---: | :---: |
| External clock operation |  |  |
| Resistor oscillator |  | $\mathrm{Rf}_{\mathrm{f}} \mathbf{2 0 k} \Omega \pm 2 \%$ |
| Ceramic filter oscillator |  | Ceramic filter CSA4.00MG (Murata) <br> Rf : $\mathbf{1 M} \Omega \pm \mathbf{2 \%}$ <br> $\mathrm{C}_{1}$ : 30pF $\pm 20 \%$ <br> $C_{2}: 30 \mathrm{pF} \pm 20 \%$ <br> - Wiring between these pins and elements should be as short as possible, and never cross the other wirings. (Refer to Fig. 17) |
| Crystal oscillator |  | $\begin{aligned} & R f: 1 M \Omega \pm 2 \% \\ & C_{1}: 10 \sim 22 p F \pm 20 \% \\ & C_{2}: 10 \sim 22 p F \pm 20 \% \end{aligned}$ <br> Crystal: ATcut parallel resonance crystal <br> $C_{0}$ : 7pF max. $\mathrm{R}_{\mathbf{s}}: 60 \Omega \text { max. }$ $f: 2.0 \sim 4.5 \mathrm{MHz}$ <br> - Wiring between these pins should be as short as possible, and never cross the other wirings. (Refer to Fig. 17) |

Note) Please consult with the engineers of crystal or ceramic filter maker to determine the value of $\mathrm{R}_{\mathrm{f}}, \mathrm{C}_{1}$ and $\mathrm{C}_{\mathbf{2}}$.


## - LOW POWER DISSIPATION MODE

The MCU provides two low power dissipation modes, that is, a Standby mode and a Stop mode. Table 21 shows the function of the low power dissipation mode, and Fig. 18 shows the diagram of the mode transition.

Fig. 17 Recommendable Layout of Crystal and Ceramic Filter
Table 21 Low Power Dissipation Mode Function

| Low Power Dissipation Mode | Instruction | Condition |  |  |  |  |  |  | Recovering method |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Oscillator circuit | Instruction execution | Register, Flag | Interrupt function | RAM | Input/ Output pin | Timer/ Counter, Serial Interface |  |
| Standby mode | SBY instruction | Active | Stop | Retained | Active | Retained | Retained ${ }^{\text {31 }}$ | Active | RESET Input, Interrupt request |
| Stop mode | $\begin{aligned} & \text { STOP } \\ & \text { instruction } \end{aligned}$ | Stop | Stop | RESET ${ }^{\text {¹) }}$ | Stop | Retained | High*2) impedance | Stop | RESET Input |

*1) As the MCU recovers from STOP mode by RESET input, the contents of the flags and registers are initialized according to Table 19.
${ }^{\text {-2) }}$ A high voltage pin with a pull-down MOS option is pulled down to the $V_{\text {disp }}$ power supply by the pull-down MOS. As the MOS is ON, a pulldown MOS current flows when a voltage difference between the pin and the $\mathrm{V}_{\text {disp }}$ voltage exists. This is the additional current to the current dissipation in Stop Mode (Istop).
*3) As a I/O circuit is active, a I/O current possibly flows according the state of I/O pin. This is the additional current to the current dissipation in Standby Mode (ISBY1, ISBY2).


Fig. 18 MCU Operation Mode Transition

## Standby Mode

The SBY instruction puts the MCU into the Standby mode. In the Standby mode, the oscillator circuit is active and timer/
counter and serial interface continue working. On the other hand, the CPU stops since the clock related to the instruction execution stops. Registers, RAM and Input/Output pins retain the state they had just before going into the Standby mode.

The Standby mode is canceled by the MCU reset or interrupt request. When canceled by the interrupt request, the MCU becomes an active mode and executes the instruction next to the SBY instruction. At this time, if the Interrupt Enable Flag is " 1 ", the interrupt is executed. If the Interrupt Enable Flag is " 0 ", the interrupt request is held on and the normal instruction execution continues.

Fig. 19 shows the flowchart of the Standby Mode.

## - Stop Mode

The STOP instruction brings the MCU into the Stop mode. In this mode the oscillator circuit and every function of the MCU stop.

The Stop mode is canceled by the MCU reset. At this time, as shown in Fig. 20, apply the RESET input for more than $\mathrm{t}_{\mathrm{RC}}$ to get enough oscillator stabilization time. (Refer to the "AC CHARACTERISTICS".) After the Stop mode is canceled, RAM retains the state it had just before going into the Stop mode. The other hand, Accumulator, B Register, W Register, X/SPX Registers, Y/SPY Registers, Carry and Serial Data Register don't retain the contents.


Fig. 19 MCU Operating Flowchart


Fig. 20 Timing Chart of Recovering from Stop Mode

- RAM ADDRESSING MODE

As shown in Fig. 21, the MCU provides three RAM addressing modes; Register Indirect Addressing, Direct Addressing and Memory Register Addressing.

- Register Indirect Addressing

The combined 10 -bit contents of W Register, X Register and Y Register is used as the RAM address in this mode.

## - Direct Addressing

The direct addressing instruction consists of two words and the second word ( 10 bits) following Op-code (the first word) is used as the RAM address.

## - Memory Register Addressing

The Memory Register Addressing can access 16 digits (Memory Register: MR) from $\$ 020$ to $\$ 02 \mathrm{~F}$ by using the LAMR and XMRA instruction.

RAM Address

(a) Register Indirect Addressing

(b) Direct Addressing

(c) Memory Register Addressing

Fig. 21 RAM Addressing Mode

- ROM ADDRESSING MODE AND P INSTRUCTION The MCU has four kinds of ROM addressing modes as shown in Fig. 22.


## - Direct Addressing Mode

The program can branch to any addresses in the ROM memory space by using JMPL, BRL or CALL instruction. These instruction replace 14 -bit program counter ( $\mathrm{PC}_{13}$ to $\mathrm{PC}_{0}$ ) with 14-bit immediate data.

## - Current Page Addressing Mode

MCU has 8 pages of ROM( 256 words in each page). The program branches to the address in the same page using BR instruction. This instruction replace the low-order eight bits of pro-
gram counter $\left(\mathrm{PC}_{7}\right.$ to $\left.\mathrm{PC}_{\mathbf{0}}\right)$ with 8 -bit immediate data.

## - Zero Page Addressing Mode

The program branches to the zero page subroutine area, which is located on the address from $\$ 0000$ to $\$ 003 \mathrm{~F}$, using CAL instruction. When CAL instruction is executed, 6 -bit immediate data is placed in low-order six bits of program counter ( $\mathrm{PC}_{5}$ to $\mathrm{PC}_{0}$ ) and "0's" are placed in high-order eigit bits ( $\mathrm{PC}_{13}$ to $\mathrm{PC}_{6}$ ). The branch destination by BR instruction on the broundary between pages is given in Fig. 24.

## - Table Data Addressing

The program branches to the address determined by the contents of the 4 -bit immediate data, accumulator and $B$ register, using TBR instruction.

(a) Direct Addressing

(b) Current Page Addressing

(c) Zero Page Addressing

(d) Table Data Addressing

Fig. 22 ROM Addressing Mode

(a) Address Designation

(b) Pattern Output

Fig. 23 P Instruction

- P Instruction

The $P$ instruction refers ROM data addressed by Table Data Addressing. ROM data addressed also determine its destination. When bit 8 in referred ROM data is " 1 ", 8 bits of referred


Fig. 24 The Branch Destination by BR Instruction on the Boundary between Pages

ROM data are written into the accumulator and B Register. When bit 9 is " 1 ", 8 bits of referred ROM data are written into the R1 and R2 port output register. When both bit 8 and 9 are " 1 ", ROM data are written into the accumulator and B Register and also to the R1 and R2 port output register at a same time.

The $\mathbf{P}$ instruction has no effect on the program counter.

- INSTRUCTION SET

The HMCS400 series provide 99 instructions. These instructions are classified into 10 groups as follows;
(1) Immediate Instruction
(2) Register-to-Register Instruction
(3) RAM Address Instruction
(4) RAM Register Instruction
(5) Arithmetic Instruction
(6) Compare Instruction
(7) RAM Bit Manipulation Instruction
(8) ROM Address Instruction
(9) Input/Output Instruction
(10) Control Instruction

Table 22. Immediate Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD CYCLE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Immediate | LAI i | $100011 i_{3} i_{2} i_{1} i_{0}$ | $\longrightarrow A$ |  | 1/1 |
| Load B from Immediate | LBI i | $100000 i_{3} i_{2} i_{1} i_{0}$ | $\square B$ |  | 1/1 |
| Load Memory from Immediate | LMID i,d | $011010 i_{3} i_{1} i_{0}$ | $\longmapsto \mathrm{M}$ |  | 2/2 |
| Load Memory from Immediate, Increment Y | LMIIY i | $101001 i_{3} i_{2} i_{1} i_{0}$ | $i \rightarrow M, Y+1 \rightarrow Y$ | NZ | 1/1 |

Table 23. Register-to-Register Instruction


Table 24. RAM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD CYCLE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load W from Immediate | LWI i | $001111 i_{3} i_{2} i_{1} i_{0}$ | $\xrightarrow{\longrightarrow} \mathrm{W}$ |  | 1,1 |
| Load $X$ from Immediate | LXI i | $100010 i_{3} i_{2} i_{1} i_{0}$ | $\underline{\longrightarrow} \mathrm{X}$ |  | 1/1 |
| Load $Y$ from Immediate | LYI i | $100001 i_{3} i_{2} i_{1} i_{0}$ | $\boldsymbol{H} \longrightarrow Y$ |  | 1/1 |
| Load $X$ from $A$ | LXA | 0011101000 | $A \longrightarrow X$ |  | 1,11 |
| Load $Y$ from $A$ | LYA | 0011011000 | $A \longrightarrow Y$ |  | 1/1 |
| Increment $Y$ | IY | 0001011100 | $Y+1 \rightarrow Y$ | NZ | 1/1 |
| Decrement $Y$ | DY | 0011011111 | $Y-1 \rightarrow Y$ | NB | 1/1 |
| Add $A$ to $Y$ | AYY | 0001010100 | $Y+A \rightarrow Y$ | OVF | 1/1 |
| Subtract $A$ from $Y$ | SYY | 0011010100 | $Y-A \rightarrow Y$ | NB | $1 / 1$ |
| Exchange $X$ and SPX | XSPX | 0000000001 | $X \leftrightarrow S P X$ |  | $1 / 1$ |
| Exchange $Y$ and SPY | XSPY | 0000000010 | $Y \leftrightarrow S P Y$ |  | 1/1 |
| Exchange $X$ and SPX,Y and SPY | XSPXY | 0000000011 | $X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |  | 1/1 |

Table 25. RAM Register Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CyCle |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Memory | LAM (XY) | 00100100 yx | $\mathrm{M} \rightarrow \mathrm{A},\left(\begin{array}{l}\binom{\text { ( }}{\mathrm{Y}+\mathrm{SPP} \mathrm{SP}}\end{array}\right.$ |  | 1/1 |
| Load A from Memory | LAMD d |  | $\mathrm{M} \rightarrow \mathrm{A}$ |  | 2/2 |
| Load B from Memory | LBM (XY) | $00010000 y x$ |  |  | $1 / 1$ |
| Load Memory from A | LMA(XY) | 00100101 yx | $A \rightarrow M,\left(\begin{array}{l}\left(\begin{array}{l}X \\ Y\end{array} \text { SPPY }\right.\end{array}\right.$ |  | 1/1 |
| Load Memory from A | LMAD d | $\begin{array}{\|l\|l\|lllllllllll} \hline 0 & 1 & 1 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\ d_{9} & d_{8} & d_{7} & d_{6} & d_{5} & d_{4} & d_{3} & d_{2} & d_{1} & d_{0} \\ \hline \end{array}$ | $\mathrm{A} \rightarrow \mathrm{M}$ |  | 2/2 |
| Load Memory from A, Increment Y | LMAIY(X) | $000101000 \times$ | $A \rightarrow M, \overline{Y+1} \rightarrow \bar{Y}(X \cdots s P X)$ | NZ | 1/1 |
| Load Memory from A, Decrement $Y$ | LMADY(X) | $001101000 \times$ | $A \rightarrow M, Y-1 \rightarrow Y(X \cdots S P X)$ | NB | 1/1 |
| Exchange Memory and A | XMA(XY) | 00100000 yx | $M \mapsto A,\left(\begin{array}{l}\left(\begin{array}{l}x \\ Y\end{array} \mathrm{SPX} \mathrm{SPY}\right.\end{array}\right)$ |  | 1/1 |
| Exchange Memory and A | XMAD d |  | $M \mapsto A$ |  | 2/2 |
| Exchange Memory and B | XMB(XY) | 00110000 yx | $\mathrm{M} \rightarrow \mathrm{B},\binom{$ ( }{$\mathrm{Y} \rightarrow \mathrm{SPP} \times \mathrm{SPY}}$ |  | 1/1 |

Note) ( $X Y$ ) and ( $X$ ) have the meaning as follows:
(1) The instructions with (XY) have 4 mnemonics and 4 object codes for each. (example of LAM (XY) is given below.)

| MNEMONIC | $y$ | $x$ | FUNCTION |
| :--- | :---: | :---: | :---: |
| LAM | 0 | 0 |  |
| LAMX | 0 | 1 | $X \leftrightarrow S P X$ |
| LAMY | 1 | 0 | $Y \leftrightarrow S P Y$ |
| LAMXY | 1 | 1 | $X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |

(2) The instructions with $(X)$ have 2 mnemonics and 2 object codes for each. (example of LMAIY $(X)$ is given below.)

| MNEMONIC | $x$ | FUNCTION |
| :---: | :---: | :---: |
| LMAIY | 0 |  |
| LMAIYX | 1 | $x \leftrightarrow$ SPX |

Table 26. Arithmetic Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CYCLE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Add Immediate to A | Al i | $101000 i_{3} i_{2} i_{1}$ io | $A+i \rightarrow A$ | OVF | 1/1 |
| Increment B | IB | 0001001100 | $B+1 \rightarrow B$ | NZ | 1/1 |
| Decrement B | DB | 0011001111 | $B-1 \rightarrow B$ | NB | 1/1 |
| Decimal Adjust for Addition | DAA | 0010100110 |  |  | 1/1 |
| Decimal Adjust for Subtraction | DAS | 0010101010 |  |  | 1/1 |
| Negate A | NEGA | 0001100000 | $\bar{A}+1 \rightarrow A$ |  | 1/1 |
| Complement B | COMB | 0101000000 | $\bar{B} \rightarrow B$ |  | 1/1 |
| Rotate Right A with Carry | ROTR | 0010100000 |  |  | 1/1 |
| Rotate Left A with Carry | ROTL | 0010100001 |  |  | 1/1 |
| Set Carry | SEC | 0011101111 | $1 \rightarrow$ CA |  | 1/1 |
| Reset Carry | REC | 0011101100 | $0 \rightarrow$ CA |  | 1/1 |
| Test Carry | TC | 0001101111 |  | CA | 1/1 |
| Add A to Memory | AM | 0000001000 | $M+A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory | AMD d | $\begin{array}{ll} \mathrm{g}_{9} \mathrm{~d}_{9} \mathrm{O}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~g}_{4} d_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0} \\ \hline \end{array}$ | $M+A \rightarrow A$ | OVF | 2/2 |
| Add A to Memory with Carry | AMC | 0000011000 | $M+A+C A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory with Carry | AMCD d |  | $M+A+C A \rightarrow A$ | OVF | 2/2 |
| Subtract A from Memory with Carry | SMC | 0010011000 | $\bar{M}-\mathbf{A}-\overline{\mathbf{C A}} \rightarrow \mathrm{A}$ | NB | 1/1 |
| Subtract A from Memory with Carry | SMCD d |  | $M-A-\overline{C A} \rightarrow A$ | NB | 2/2 |
| OR A and B | OR | 0101000100 | $A \cup B \rightarrow A$ |  | 1/1 |
| AND Memory with A | ANM | 0010011100 | $A \cap M \rightarrow A$ | NZ | 1/1 |
| AND Memory with A | ANMD d |  | $\mathbf{A} \cap \mathrm{M} \rightarrow \mathrm{A}$ | NZ | 2/2 |
| OR Memory with A | ORM | 0000001100 | $A \cup M \rightarrow A$ | NZ | 1/1 |
| OR Memory with A | ORMD d |  | $A \cup M \rightarrow A$ | NZ | 2/2 |
| EOR Memory with A | EORM | 0000011100 | $A \oplus M \rightarrow A$ | NZ | 1/1 |
| EOR Memory with A | EORMD d |  | $\mathbf{A} \oplus \mathbf{M} \rightarrow \mathbf{A}$ | NZ | 2/2 |

Table 27. Compare Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | StATUS | WORD <br> trcle |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Immediate Not Equal to Memory | INEM ; | $000010 i_{3} i_{2} i_{1} i_{0}$ | $i \neq M$ | NZ | 1/1 |
| Immediate Not Equal to Memory | INEMD i,d |  | $i \neq M$ | NZ | 2/2 |
| A Not Equal to Memory | ANEM | 0000000100 | $A \neq M$ | NZ | 1/1 |
| A Not Equal to Memory | ANEMD d | $\begin{aligned} & 0 \\ & d_{9} \mathrm{~d}_{8} \mathrm{O}_{7} 0 \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{C}_{1} \mathrm{~d}_{0} \end{aligned}$ | $A \neq M$ | NZ | 2/2 |
| B Not Equal to Memory | BNEM | 0001000100 | $B \neq M$ | NZ | 1/1 |
| Y Not Equal to Immediate | YNEI i | $000111 i_{3} i_{2} i_{1} i_{0}$ | $Y \neq i$ | NZ | 1/1 |
| Immediate Less or Equal to Memory | ILEM i | $000011 i_{3} i_{2} i_{1} i_{0}$ | $i \leqq M$ | NB | 1/1 |
| Immediate Less or Equal to Memory | ILEMD i,d |  | $i \leqq M$ | NB | 2/2 |
| A Less or Equal to Memory | ALEM | 0000010100 | $A \leqq M$ | NB | 1/1 |
| A Less or Equal to Memiory | ALEMD d |  | $A \leqq M$ | NB | 2/2 |
| B Less or Equal to Memory | BLEM | 0011000100 | $B \leqq M$ | NB | 1/1 |
| A Less or Equal to Immediate | ALEI i | $101011 i_{3} i_{2} i_{1} i_{0}$ | A | NB | 1/1 |

Table 28. RAM Bit Manipulation Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Memory Bit | SEM $n$ | 00100001 nino | $1 \rightarrow M(n)$ |  | 1/1 |
| Set Memory Bit | SEMD n,d |  | $1 \rightarrow M(n)$ |  | 2/2 |
| Reset Memory Bit | REM n | $00100010 n_{1} n_{0}$ | $0 \rightarrow M(n)$ |  | 1/1 |
| Reset Memory Bit | REMD n,d |  | $0 \rightarrow M(n)$ |  | 2/2 |
| Test Memory Bit | TM $n$ | $00100011 n^{\prime} n_{0}$ |  | $M(\mathrm{n})$ | 1/1 |
| Test Memory Bit | TMD n,d |  |  | $M(\mathrm{n})$ | 2/2 |

Table 29. ROM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD CrCle |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Branch on Status 1 | BR b | $11 \mathrm{~b}_{7} \mathrm{~b}_{6} \mathrm{~b}_{5} \mathrm{~b}_{4} \mathrm{~b}_{3} \mathrm{~b}_{2} \mathrm{~b}_{1} \mathrm{~b}_{0}$ |  | 1 | 1/1 |
| Long Branch on Status 1 | BRL u |  |  | 1 | 2/2 |
| Long Jump Unconditionally | JMPL u |  |  |  | 2/2 |
| Subroutine Jump on Status 1 | CAL a | $0111 a_{5} a_{4} a_{3} a_{2} a_{1} a_{0}$ |  | 1 | 1/2 |
| Long Subroutine Jump on Status 1 | CALL u | $\mathrm{g}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{Pd}_{3} \mathrm{P}_{3} \mathrm{~d}_{2} \mathrm{P}_{1} \mathrm{~d}_{1} \mathrm{po}_{0}$ |  | 1 | 2/2 |
| Table Branch | TBR p | $001011 p_{3} p_{2} p_{1} p_{0}$ |  |  | 1/1 |
| Return from Subroutine | RTN | 0000010000 |  |  | 1/3 |
| Return from Interrupt | RTNI | 0000010001 | $1 \rightarrow 1 / E$ |  | 1/3 |

Table 30. Input/Output Instruction


Table 31. Control Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CYCLE |
| :--- | :---: | :---: | :---: | :---: | :---: |
| No Operation | NOP | 0000000000 |  |  | $1 / 1$ |
| Start Serial | STS | 0101001000 |  |  | $1 / 1$ |
| Stand-by Mode | SBY | 0101001100 |  | $1 / 1$ |  |
| Stop Mode | STOP | 0101001101 |  |  | $1 / 1$ |

Table 32. Op-Code Map
1-word/3-cycle Instruction

RAM Direct Address
Instruction
(2-word/2-cycle)


2-word/2-cycle Instruction

- MASK OPTION LIST

| - Family Name $\quad$ HMCS404C |  |
| :--- | :--- |
| $\bullet$ Package |  |
| - I/O Circuit Type | DP-64S Without Pull-up MOS (NMOS Open Drain) |
|  |  |
|  | B; With Pull-up MOS |
|  | C; CMOS |
|  | D; Without Pull-down MOS (PMOS Open Drain) |
|  | E; With Pull-down MOS |


| Date of Order |  |
| :--- | :--- |
| Customer |  |
| Dept. |  |
| Name |  |
| ROM Code Name |  |
| LSI Trpe Number <br> (Hitachi's entry) |  |

E; With Pull-down MOS


[^8]Note 2) $\mathbf{R}_{\mathbf{A} 1} / \mathrm{V}_{\text {disp }}$ has to be selected as $\mathrm{V}_{\text {disp }}$ pin exept the case that all High Voltage Pins are option D.

## HD614P080S

The HD6 14P080S is a 4-bit single chip microcomputer which has mounted a standard EPROM 2764/27128 for program memory.

The HD614P080S is pin-compatible with the mask ROM type HMCS404C/404AC, but has some differences with them as shown in Table 33. By modifying the program in the EPROM, it can be used for the evaluation of the HMCS404C/404AC, or for small-scale production.

## - HARDWARE FEATURES

- 4-bit Architecture
- Applicable to $4 k$ or $8 k$ words $\times 10$ bits of EPROM 4096 words $\times 10$ bits . . . . . HN482764, HN27C64 8192 words $\times 10$ bits . . . . . HN4827 128
- Data Memory (RAM) Capacity . . . . . . . . 576 digits $\times 4$ bits
- 58 I/O Pins - 26 I/O pins are high voltage up to $\mathbf{4 0 V}$ (max).
- 2 Timer/Counters

11-bit Prescaler
8 -bit Free Running Counter
8-bit Auto-reload Timer/Event Counter

- Clocked Synchronous 8-bit Serial Interface
- 5 Interrupts

External 2
Timer/Counter 2
Serial Interface 1

- Subroutine Stack

Up to 16 levels including interrupts

- Minimum Instruction Execution Time; $1.33 \mu \mathrm{~s}$
- 2 Low Power Modes

Standby - Stops instruction execution while keeping clock generator and interrupt functions included Timer/Counter and Serial Interface in operation
Stop - Stops instruction execution and clock generation while retaining RAM data

- Clock Generator

External Connection of Crystal Resonator or Ceramic Filter Resonator (externally drivable)

- Power Voltage Range; $5 \mathrm{~V} \pm 10 \%$
- I/O Pin Circuit Form

All standard pins are "without pull-up MOS".
All high voltage pins are "without pull-down MOS".

- Shrink Type 64 Pin EPROM On-package
- SOFTWARE FEATURES
- Software Compatible with HMCS404C/404AC
- Instruction Set Similar to and More Powerful than HMCS40 Series; 99 Instructions
- High Programming Efficiency with 10-bit ROM/Word; 79 instructions are single word instructions.
- Direct Branch to All ROM Area
- Direct or Indirect Addressing to All RAM Area
- Subroutine Nesting Up to 16 Levels Including Interrupts

HD614P080S

(DC-64SP)

- PIN ARRANGEMENT

(Top View)
- Binary and BCD Arithmetic Operation
- Powerful Logic Arithmetic Operation
- Pattern Generation - Table Look Up Capability -
- Bit Manipulation for Both RAM and I/O
- VERSATILE PROGRAM DEVELOPMENT SUPPORT TOOLS
- H68SD Series Macro Assembler
- H68SD5-use Emulator (With Real Time Trace Function)

[---] High Voltage Pins

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voitage | $V_{\text {cc }}$ | -0.3 to +7.0 | V |  |
| Pin Voltage | $\mathrm{V}_{\mathrm{T}}$ | -0.3 to $\mathrm{V}_{\text {CC }}+0.3$ | V | 3 |
|  |  | $\mathrm{V}_{\text {CC }}-45$ to $\mathrm{V}_{\text {cC }}+0.3$ | V | 4 |
| Total Allowance of Input Currents | $\Sigma 1_{0}$ | 50 | mA | 5 |
| Total Allowance of Output Currents | $-\Sigma 1_{0}$ | 150 | mA | 6 |
| Maximum Input Current | 10 | 15 | mA | 7,8 |
| Maximum Output Current | -10 | 4 | mA | 9,10 |
|  |  | 6 | mA | 9, 11 |
|  |  | 30 | mA | 9,12 |
| Operating Temperature | Topr | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(Note 1) Permanent damage may occur if "Absolute Maximum Ratings" of the LSI or the EPROM are exceeded. Normal operation should be under the conditions of "Electrical Characteristics". If these conditions are exceeded, it may cause the malfunction and affect the relisbility of LSI.
(Note 2) All voltages are with respect to GND.
(Note 3) Applied to standard pins.
(Note 4) Applied to high voltage I/O pins.
(Note 5) Total allowance of input current is the total sum of input current which flow in from all I/O pins to GND simultaneously.
(Note 6) Total allowance of output current is the total sum of the output current which flow out from VCC to all I/O pins simultaneously.
(Note 7) Maximum input current is the maximum amount of input current from each I/O pin to GND.
(Note 8) Applied to $D_{0} \sim D_{3}$ and R3 $\sim R 8$.
(Note 9) Maximum output current is the maximum amount of output current from $V_{C C}$ to each I/O pin.
(Note 10) Applied to $D_{0} \sim D_{3}$ and $R 3 \sim R 8$
(Note 11) Applied to $R 0 \sim \mathbf{R 2}_{3}$.
(Note 12) Applied to $D_{4} \sim D_{1 s}$.

- RECOMMENDED APPLICABLE EPROM

| Type No. | Program Memory Capacity | $\mathrm{f}_{\text {ose }}(\mathrm{MHz})$ | EPROM Type No. |
| :---: | :---: | :---: | :---: |
| HD614P080S | 4096 words | 4 | $\begin{aligned} & \text { HN27C64-30 } \\ & \text { HN482764-3 } \end{aligned}$ |
|  |  | 6 | HN27C64-25 HN482764 |
|  | 8192 words | 4 | HN4827128-45 |
|  |  | 6 | HN4827 128-25 |

## ELECTRICAL CHARACTERISTICS

- DC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{cc}}=\mathbf{4 . 5 \mathrm { V }}$ to $5.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{Ta}=\mathbf{- 2 0}$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions |  | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | min | typ | max |  |  |
| Input "High"Voltage | $\mathrm{V}_{\mathrm{IH}}$ | RESET, SCK, $\overline{\mathrm{N} T \mathrm{O}}, \overline{\mathrm{INT}} \mathrm{I}_{1}$ |  |  | $0.7 \mathrm{~V}_{\text {cc }}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
|  |  | SI |  |  | $0.7 \mathrm{~V}_{\mathrm{CC}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
|  |  | $\mathrm{OSC}_{1}$ |  |  | $\mathrm{V}_{\mathrm{cc}}-0.5$ | - | $\mathrm{v}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low"Voltage | $V_{\text {IL }}$ | $\frac{\text { RESET }}{\frac{\text { STCK }}{}}$ |  |  | -0.3 | - | 0.22 V cc | V |  |
|  |  | SI |  |  | -0.3 | - | 0.22 V cc | V |  |
|  |  | OSC ${ }_{1}$ |  |  | -0.3 | - | 0.5 | V |  |
| Output "High" <br> Voltage | VOH | SCK, SO | $-\mathrm{I}_{\mathrm{OH}}=1.0 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | - | V |  |
|  |  |  | $-\mathrm{IOH}=0.01 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{cc}}-0.3$ | - | - | V |  |
| $\begin{aligned} & \text { Output "Low" } \\ & \text { Voltage } \end{aligned}$ | $\mathrm{V}_{\text {OL }}$ | SCK, SO | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | - | - | 0.4 | V |  |
| Input/Output <br> Leakage Current | IIILI | $\begin{aligned} & \overline{\text { RESET, } \overline{\text { SCK }}} \\ & \frac{\text { NTTO, }}{\text { INT }}, \\ & \text { SI, SO, OSC } \end{aligned}$ | $\mathrm{V}_{\text {in }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}$ |  | - | - | 1 | $\mu \mathrm{A}$ | 1 |
| Current <br> Dissipation in Operation Mode | ${ }^{\text {I cc }}$ | V cc | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | Crystal or Ceramic Filter Resonator $f_{\text {osc }}=4 \mathrm{MHz}$ | - | - | 2.0 | mA | 2, 5 |
| Current Dissipation in Standby Mode | $I_{\text {SBY1 }}$ | $\mathrm{V}_{\mathrm{cc}}$ | Maximum Logic Operation $V_{C C}=5 V$ | Crystal or Ceramic Filter Resonator $f_{\text {osc }}=4 \mathrm{MHz}$ | - | - | 1.2 | mA | 3,5 |
|  | ISBY2 | V cc | Minimum Logic Operation $V_{c C}=5 V$ | Crystal or Ceramic Filter Resonator $\mathrm{f}_{\mathrm{osc}}=4 \mathrm{MHz}$ | - | - | 0.9 | mA | 4.5 |
| Current Dissipation in Stop Mode | $1_{\text {stop }}$ | $V_{\text {cc }}$ | $\begin{aligned} & \mathrm{V}_{\text {in }} \text { (TEST) } \\ & \mathrm{V}_{\text {in }} \text { (RESE } \end{aligned}$ | $\begin{aligned} = & V_{c c} \\ \sim & V_{c c}-0.3 V \\ T & =0 \sim 0.3 \mathrm{~V} \end{aligned}$ | - | - | 10 | $\mu \mathrm{A}$ |  |
| Stop Mode Retain Voltage | $\mathrm{V}_{\text {stop }}$ | V cc |  |  | 2.0 | - | - | V |  |

(Note 1) Output buffer current are excluded.
(Note 2) The MCU is in the reset state. The input/output current does not flow.
Test Conditions: MCU state; Reset state in Operation Mode
Pin state; RESET, TEST - V ${ }_{\text {Cc }}$ voltage

- $D_{0} \sim D_{3}, R 3 \sim R 9-V_{C c}$ voltage
$-D_{4} \sim D_{15}, R 0 \sim R 2, R_{A 0}, R_{A 1}-V_{C C} \sim V_{C C}-40 V$
(Note 3) The timer/counter with the fastest clock and input/output current does not flow.
Test Conditions: MCU state: Standby Mode
- Input/Output; Reset state
- TIMER-A; $\div 2$ prescaler divide ratio
- TIMER-B; $\div 2$ prescaler divide ratio
- SERIAL; Stop

Pinstate: RESET - GND voltage

- TEST - $V_{C C}$ voltage
- $D_{0} \sim D_{3}, R 3 \sim R 9-V_{C c}$ voltage
$-D_{4} \sim D_{15}, R O \sim R 2, R_{A 0}, R_{A 1}-V_{C C} \sim V_{C C}-40 \mathrm{~V}$
(Note 4) The timer/counter with the slowest clock and input/output current does not flow. Test Conditions: MCU state;
- Standby Mode
- Input/Output; Reset state
- TIMER-A; $\div 2048$ prescaler divide ratio
- TIMER-B; $\div 2048$ prescaler divide ratio
- SERIAL; Stop

Pin state; - RESET - GND voltage

- TEST $-V_{C C}$ voltage
- $D_{0} \sim D_{3}, R 3 \sim R 9-V_{C C}$ voltage
- $D_{4} \sim D_{15}, R 0 \sim R 2, R_{A O}, R_{A 1}-V_{C C} \sim V_{C C}-40 V$
(Note 5) The consumption of current in operation and standby mode is proportional to fosc. When fosc $=x$ [ MHz ], the value of each current is calculated as follows.
max. value $\left(f_{\text {OsC }}=x\right)=\frac{x}{4} \times \max$. value $\left(f_{\text {osc }}=4[M H z]\right)$.
- INPUT/OUTPUT CHARACTERISTICS FOR STANDARD PIN
( $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{GND}=\mathrm{OV}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| $\begin{aligned} & \text { Input "High" } \\ & \text { Voltage } \end{aligned}$ | $\mathrm{V}_{1 \mathrm{H}}$ | $\begin{aligned} & \hline D_{0} \sim D_{3}, \\ & R 3 \sim R 5, R 9 \end{aligned}$ |  | 0.7 V cc | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 5, \text { R9 } \end{aligned}$ |  | -0.3 | - | $0.22 V_{\text {cc }}$ | V |  |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{D}_{0} \sim \mathrm{D}_{3}, \\ & \mathrm{R} 3 \sim \mathrm{R} 8 \end{aligned}$ | $\mathrm{I}_{\text {OL }}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |  |
| Input/Output Leakage Current | $\left\|I_{\text {IL }}\right\|$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 9 \end{aligned}$ | $V_{\text {in }}=0 V-V_{c c}$ | - | - | 1 | $\mu \mathrm{A}$ | 1 |

(Note 1) Output buffer current are excluded.

- INPUT/OUTPUT CHARACTERISTICS FOR HIGH VOLTAGE PIN $\left(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}\right.$ to $5.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" Voltage | $V_{\text {IH }}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15}, \mathrm{R}_{1} \\ & \mathrm{R2}, \mathrm{R}_{\mathrm{AO}}, \mathrm{R}_{\mathrm{A} 1} \end{aligned}$ |  | $0.7 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & D_{4} \sim D_{15}, R_{1} \\ & R 2, R_{A 0}, R_{A 1} \end{aligned}$ |  | $\mathrm{V}_{\text {cc }}-40$ | - | $0.22 V_{\text {cc }}$ | V |  |
| Output "High" <br> Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ | $-I_{\mathrm{OH}}=15 \mathrm{~mA}$ $-I_{\mathrm{OH}}=9 \mathrm{~mA}$ | $\frac{V_{\mathrm{cc}}-3.0}{\mathrm{~V}_{\mathrm{cc}}-2.0}$ | - | - | V |  |
|  |  | $\mathrm{RO} \sim \mathrm{R} 2$ | $\begin{aligned} & -I_{\mathrm{OH}}=3 \mathrm{~mA} \\ & -\mathrm{I}_{\mathrm{OH}}=1.8 \mathrm{~mA} \end{aligned}$ | $\frac{V_{c c}-3.0}{V_{c c}-2.0}$ | - | - | V |  |
| $\begin{aligned} & \text { Output "Low" } \\ & \text { Voltage } \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & \mathrm{RO} \sim \mathrm{R} 2 \end{aligned}$ | $150 \mathrm{k} \Omega$ to $\mathrm{V}_{\mathrm{cc}}-40 \mathrm{~V}$ | - | - | $V_{c c-37}$ | V |  |
| Input/Output Leakage Current | HILI | $\begin{aligned} & D_{4} \sim D_{15} \\ & R 0 \sim R_{2} \\ & R_{A O}, R_{A 1} \end{aligned}$ | $V_{\text {in }}=V_{c c}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ | - | - | 20 | $\mu \mathrm{A}$ | 1 |

(Note 1) Output buffer current are excluded.

- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item |  | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  |  | typ | max |  |  |
|  | Oscillation Frequency |  | $\mathrm{f}_{\text {osc }}$ | OSC ${ }_{1}, \mathrm{OSC}_{2}$ |  | 0.4 | - | 6.2 | MHz |  |
|  | Instruction Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  |  | 1.29 | - | 20 | $\mu \mathrm{s}$ |  |
|  | Oscillator Stabilization Time | $t_{\text {RC }}$ | OSC ${ }_{1}, \mathrm{OSC}_{2}$ |  | - | - | 20 | ms | 1 |
|  | Oscillation Frequency | $\mathrm{f}_{\mathrm{osc}}$ | OSC $_{1}$, OSC $_{2}$ |  | 0.4 | - | 6.2 | MHz |  |
|  | Instruction Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  |  | 1.29 | - | 20 | $\mu \mathrm{s}$ |  |
|  | Oscillator Stabilization Time | $t_{\text {RC }}$ | OSC ${ }_{1}$, OSC $_{2}$ |  | - | - | 20 | ms | 1 |
|  | External Clock Frequency | ${ }^{\prime}{ }_{C P}$ | OSC ${ }_{1}$ |  | 0.4 | - | 6.2 | MHz | 2 |
|  | External Clock "High" Level Width | ${ }^{\text {t }}$ CPH | $\mathrm{OSC}_{1}$ |  | 70 | - | - | ns | 2 |
|  | External Clock "Low" Level Width | ${ }^{\text {c }}$ CPL | $\mathrm{OSC}_{1}$ |  | 70 | - | - | ns | 2 |
|  | External Clock Rise Time | ${ }^{\text {t }} \mathrm{CPr}_{\mathrm{r}}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
|  | External Clock Fall Time | ${ }_{\text {t }}^{\text {cpf }}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
|  | Instruction Cycle Time | $\mathrm{t}_{\mathrm{cvc}}$ |  |  | 1.29 | - | 20 | $\mu \mathrm{s}$ | 2 |
| INTo "High" Level Width |  | $\mathrm{t}_{10 \mathrm{H}}$ | TNTo |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 3 |
| INTo "Low" Level Width |  | ${ }_{1} 10 \mathrm{~L}$ | TNT0 |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 3 |
| $\overline{\mathrm{NT}} \mathrm{T}_{1}$ "High" Level Width |  | $\mathrm{t}_{11 \mathrm{H}}$ | TNTi |  | 2 | - | - | ${ }_{\text {cyc }}$ | 3 |
| INT1 "Low" Level Width |  | $t_{112}$ | TNT: |  | 2 | - | - | $\mathrm{tcrc}_{\mathrm{crc}}$ | 3 |
| RESET "High" Level Width |  | $\mathrm{t}_{\text {RSTH }}$ | RESET |  | 2 | - | - | $\mathrm{tcyc}^{\text {cre }}$ | 4 |
| Input Capacitance |  | $\mathrm{C}_{\text {in }}$ | all pins | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V_{\text {in }}=0 \mathrm{~V} \end{aligned}$ | - | - | 15 | pF |  |
| Reset Fall Time |  | $\mathrm{t}_{\text {RSTf }}$ |  |  | - | - | 20 | ms | 4 |

(Note 1) Oscillator stabilization time is the time until the oscillator stabilizes after $V_{C C}$ reaches 4.5 V at "Power-on", or after RESET input level goes to "High" by resetting to quit the stop mode by MCU reset on the circuits below. When using crystal or ceramic filter oscillator, please ask a crystal oscillator maker's or ceramic filter maker's advice because oscillator stabilization time depends on the circuit constant and stray capacity.


Crystal: $6.0[\mathrm{MHz}]$
NC-18C (Nihon Denpa Kogyo)
$R_{f}=1[M \Omega] \pm 2 \%, C_{1}=C_{2}=20[p F] \pm 20 \%$


Ceramic filter: CSA6.00MG (Murata)
$R_{f}=1[M \Omega] \pm 2 \%, C_{1}=C_{2}=30[p F] \pm 20 \%$
(Note 2)

OSC

(Note 3)
$\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}}$,

(Note 4) RESET

- SERIAL INTERFACE TIMING CHARACTERISTICS
$\left(\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}\right.$ to $5.5 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{Ta}_{\mathrm{a}}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)
- At Transfer Clock Output

| Item | Symbol | Pin Name | Test <br> Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | $\mathrm{t}_{\text {Scyc }}$ | $\overline{\text { SCK }}$ | (Note 2) | 1 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 1,2 |
| Transfer Clock "High" Level Width | ${ }^{\text {tsCKH }}$ | $\overline{\text { SCK }}$ | (Note 2) | 0.5 | - | - | ${ }^{\text {tsayc }}$ | 1, 2 |
| Transfer Clock "Low" Level Width | ${ }^{\text {tsCKL }}$ | SCK | (Note 2) | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1,2 |
| Transfer Clock Rise Time | ${ }_{\text {tsckr }}$ | SCK | (Note 2) | - | - | 100 | ns | 1,2 |
| Transfer Clock Fall Time | $\mathrm{t}_{\text {SCKf }}$ | SCK | (Note 2) | - | - | 100 | ns | 1,2 |
| Serial Output Data Delay Time | $t_{\text {dso }}$ | SO | (Note 2) | - | - | 250 | ns | 1, 2 |
| Serial Input Data Set-up Time | ${ }_{\text {tssI }}$ | SI |  | 300 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HSI}}$ | SI |  | 150 | - | - | ns | 1 |

- At Transfer Clock Input

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | $\mathrm{t}_{\text {scyc }}$ | SCK |  | 1 | - | - | $\mathrm{t}_{\text {cyc }}$ | 1 |
| Transfer Clock "High" Level Width | ${ }^{\text {tsCKH }}$ | $\overline{\text { SCK }}$ |  | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1 |
| Transfer Clock "Low" Level Width | ${ }^{\text {tsCKL }}$ | SCK |  | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1 |
| Transfer Clock Rise Time | $\mathrm{t}_{\text {sckr }}$ | $\overline{\text { SCK }}$ |  | - | - | 100 | ns | 1 |
| Transfer Clock Fall Time | ${ }^{\text {tsckf }}$ | $\overline{\text { SCK }}$ |  | - | - | 100 | ns | 1 |
| Serial Output Data Delay Time | $t_{\text {dso }}$ | SO | (Note 2) | - | - | 250 | ns | 1, 2 |
| Serial Input Data Set-up Time | $\mathrm{t}_{\text {ss }}$ | SI |  | 300 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HSI}}$ | SI |  | 150 | - | - | ns | 1 |

(Note 1) Timing Diegram of Serial Interface


- $\mathrm{V}_{\mathrm{cc}}-2.0 \mathrm{~V}$ and 0.8 V are the threshold voltage for transfer clock output.
$0.7 \mathrm{~V}_{\mathrm{CC}}$ and $0.22 \mathrm{~V}_{\mathrm{CC}}$ are the threshold voltage for transfer clock input.
(Note 2) Timing Load Circuit

- CHARACTERISTICS CURVE (REFERENCE DATA)

${ }^{\text {Icc }} \mathbf{v s .} \mathrm{f}_{\text {osc }}$ characteristic (crystal, ceramic resonator)


ISBY $^{\text {vs. }} \mathrm{f}_{\text {osc }}$ characteristics (crystal, ceramic resonator)


IOL min. vs. $V_{\text {OL }}$ characteristics
(Standard Pin)


Icc vs. $V_{\text {cc }}$ characteristic (crystal, ceramic resonator)

$I_{\text {SBY }}$ vs. $V_{\text {CC }}$ characteristics (crystal, ceramic resonator)

$-\mathrm{l}_{\mathrm{OH}} \mathrm{min}$. vs. ( $\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{OH}}$ ) characteristics ( $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ pins)


- DESCRIPTION OF PIN FUNCTIONS

Input and output signals of MCU are described below.

- GND, Vcc, $\mathbf{V}_{\text {diep }}$

These are power supply pins. Connect GND pin to Earth ( $O V$ ) and apply $\mathrm{V}_{\mathrm{CC}}$ power supply voltage to $\mathrm{V}_{\mathrm{CC}}$ pin. $\mathrm{R}_{\mathrm{A} 1} /$ $\mathbf{V}_{\text {dip }}$ pins are used for $\mathrm{R}_{\mathbf{A 1}}$ as all high voltage pins are "without pull-down MOS" (PMOS open drain).

- TEST

TEST pin is not for users application. Connect it to $\mathrm{V}_{\mathrm{CC}}$.

- RESET

RESET pin is used to reset MCU. For details, see "RESET".

- OSC $_{1}$, OSC $_{2}$

These are input pins to the internal clock generator circuit. They can be connected to crystal resonator, ceramic filter resonator, or external oscillator circuit. For details, see "INTERNAL OSCILLATOR CIRCUIT."

## - D-port (Do to D15)

D-port is a 1-bit Input/Output common port. $D_{0}$ to $D_{3}$ are
standard type, D4 to Dis are for high voltage. For details, see "INPUT/OUTPUT".

## - R-port (R0 to RA)

R-port is a 4-bit Input/Output port. (only RA is 2-bit construction.) R0 and R6 to R8 are output ports, R9 to RA are input ports, and R1 to R5 are Input/Output common ports. R0 to R2 and RA are the high voltage ports, R3 to R9 are the standard ports. $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$, and $\mathrm{R}_{42}$ are also available as $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}} \mathbf{1}_{1}, \overline{\text { SCK }}$, SI and SO respectively. For details, see "INPUT/OUTPUT".

- INTO. $\overline{\text { INT }}$

These are the input pins to interrupt MCU operation externally. $\overline{\mathrm{INT}_{1}}$ can be used as an external event input pin for TIMER-B. INTo and INT1 are also available as $\mathrm{R}_{32}$, and $\mathrm{R}_{33}$ respectively. For details, see "INTERRUPT".

- $\overline{\mathbf{S C K}}, \mathbf{S I}, \mathbf{S O}$

These are transfer clock I/O pin ( $\overline{\mathbf{S C K}}$ ), serial data input pin (SI) and serial data output pin (SO) used for serial interface. SCK, SI and SO are also available as $\mathrm{R}_{40}, \mathrm{R}_{41}$, and $\mathrm{R}_{42}$ respectively. For details, see "SERIAL INTERFACE".

## ROM MEMORY MAP

ROM memory map is illustrated in Fig. 1 and described in the following paragraph.

- Vector Address Area ..... \$0000 to \$000F

When MCU reset or an interrupt is serviced, the program is executed from the vector address. Program the JMPL instructions branching to the starting addresses of reset routine or of interrupt routines.

- Zero-Page Subroutine Area ..... \$0000 to \$003F

CAL instruction allows to branch to the subroutines in $\$ 0000$ to $\$ 003 \mathrm{~F}$.

- Pattern Area ..... \$0000 to \$0FFF

P instruction allows referring to the ROM data in $\$ 0000$ to \$OFFF as a pattern.

- Program Area ..... \$0000 to \$1FFF


Fig. 1 ROM Memory Map


* Two registers are mapped on same address.
$\begin{array}{l:l}\text { R } \quad \text { : Read Only } \\ \text { W } & \text { Write Only } \\ \text { R/W: Read/Write }\end{array}$

| Timer/Event Counter B Lower (TCBL) | R | Timer Load Reg. Lower (TLRL) | $W$ |  |
| :--- | :---: | :---: | :---: | :---: |
| Timer/Event Counter B Upper (TCBU) | R | Timer Load Reg. Upper (TLRU) | $w$ | $\$ 000$ |

Fig. 2 RAM Memory Map

## - RAM MEMORY MAP

The MCU includes 576 digits $\times 4$ bits RAM as the data area and stack area. In addition to these areas, interrupt control bits
and special registers are also mapped on the RAM memory space. RAM memory map is illustrated in Fig. 2 and described in the following paragraph.

| 0 | bit 3 | bit 2 | bit 1 | bit 0 | \$000 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | (IMO of $\overline{\mathrm{INT}_{0}}$ ) | $\begin{aligned} & \text { IFO } \\ & \text { (IF of } \overline{\mathrm{INT} T_{0}} \text { ) } \end{aligned}$ | RSP (Reset SP Bit) | I/E (Interrupt Enable Flag) |  |
| 1 | IMTA <br> (IM of TIMER-A) | IFTA (IF of TIMER-A) | IM 1 <br> (IM of $\overline{\mathrm{NT}_{1}}$ ) | $\frac{\text { IF1 }}{\text { (IF of } \overline{\mathrm{INT}_{1}} \text { ) }}$ | \$001 |
| 2 | Not Used | Not Used | IMTB <br> (IM of TIMER-B) | $\begin{gathered} \text { IFTB } \\ \text { (IF of TIMER-B) } \end{gathered}$ | \$002 |
| 3 | Not Used | Not Used | IMS <br> (IM of SERIAL) | $\begin{gathered} \text { IFS } \\ \text { (IF of SERIAL) } \end{gathered}$ | \$003 |
| IF : | Interrupt Request Flag Interrupt Mask |  |  |  |  |
| I/E | Interrupt Enable Flag |  |  |  |  |
| (Note) | Each bit in Interrupt Control Bits Area is set by SEM/SEMD instruction, is reset by REM/REMD instruction and is tested by TM/TMD instruction. It is not affected by other instructions. Furthermore, Interrupt Request Flag is not affected by SEM/SEMD instruction. The content of Status becomes invarid when "RSP" bit and "Not Used" bit is tested. |  |  |  |  |

Fig. 3 Configuration of Interrupt Control Bit Area

- Interrupt Control Bit Area ..... \$000 to \$003

This area is used for interrupt controls, and is illustrated in Fig. 3. It is accessable only by RAM bit manipulation instruction. However, the interrupt request flag cannot be set by software. The RSP bit is only used to reset the SP.

## - Special Register Area ..... \$004 to \$00B

Special Register is a mode or a data register for the external interrupt, the serial interface, and the timer/counter. These registers are classified into 3 types: Write-only, Read-only, and Read/Write as shown in Fig. 2. These registers cannot be accessed by RAM bit manipulation instruction.

16 digits of $\$ 020$ to $\$ 02 \mathrm{~F}$ are called memory register (MR) and accessable by LAMR and XMRA instructions.

## - Stack Area .... \$3C0 to \$3FF

Stack Area is used for LIFO stacks with the contents of the program counter (PC), status (ST) and carry (CA) when processing subroutine call and interrupt. As 1 level requires 4 digits, this stack area is nested to 16 level-stack max. The data pushed in the stack and LIFO stack state are provided in Fig. 4. The program counter is restored by RTN and RTNI instructions. Status and Carry are restored only by RTNI instruction, and not affected by RTN instruction. The area, not used for stacking, is available as a data area.

- Data Area ..... \$020 to \$21F

| Memory Registers |  |  |
| :---: | :---: | :---: |
| 32 | MR(0) | \$ 020 |
| 33 | MR(1) | \$ 021 |
| 34 | MR(2) | \$ 022 |
| 35 | MR(3) | \$ 023 |
| 36 | MR(4) | \$ 024 |
| 37 | MR(5) | \$ 025 |
| 38 | MR(6) | \$ 026 |
| 39 | MR(7) | \$ 027 |
| 40 | MR(8) | \$ 028 |
| 41 | MR(9) | \$ 029 |
| 42 | MR(10) | \$ 02A |
| 43 | MR(11) | \$ 02B |
| 44 | MR(12) | 02C |
| 45 | MR(13) | \$ 02D |
| 46 | MR(14) | \$ 02E |
| 47 | MR(15) | \$ 02F |



[^9]Fig. 4 Configuration of Memory Register, Stack Area and Stack Position

## - REGISTER AND FLAG

The MCU has nine registers and two flags for the CPU operations. They are illustrated in Fig. 5 and described in the following paragraphs.

- Accumulator (A), B Register (B)

Accumulator and B Register are 4-bit registers used to hold the results of Arithmetic Logic Unit (ALU), and to transfer data to/from memories, I/O and other registers.

- W Register (W), X Register (X), Y Register (Y)

W Register is 2 -bit, and X and Y Register are 4 -bit registers used for indirect addressing of RAM. Y register is also used for D-port addressing.

## - SPX Register (SPX), SPY Register (SPY)

SPX and SPY Register are 4-bit registers used to assist X and Y Register respectively.

## - Carry (CA)

Carry (CA) stores the overflow of ALU generated by the arithmetic operation. It is also affected by SEC, REC, ROTL and ROTR instructions.

During interrupt servicing, Carry is pushed onto the stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Status (ST)

Status (ST) holds the ALU overflow, ALU non-zero and the results of bit test instruction for the arithmetic or compare instruction. It is used for a branch condition of BR, BRL, CAL or CALL instructions. The value of the Status remains unchanged until the next arithmetic, compare or bit test instruction is executed. Status becomes " 1 " after the BR, BRL, CAL or CALL instruction has been executed (irrespective of its execution/ skip). During the interrupt servicing, Status is pushed onto the
stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

- Program Counter (PC)

Program Counter is a 14 -bit binary counter for ROM addressing.

- Stack Pointer (SP)

Stack Pointer is used to point the address of the next stacking area up to 16 levels.

The Stack Pointer is initialized to locate \$3FF on the RAM address, and is decremented by 4 as data pushed into the stack, and incremented by 4 as data restored back from the stack.

## - INTERRUPT

The MCU can be interrupted by five different sources: the external signals ( $\overline{\mathrm{INT}}_{0}, \overline{\mathrm{INT}}_{1}$ ), timer/counter (TIMER-A, TIMER-B), and serial interface (SERIAL). In each sources, the Interrupt Request Flag, Interrupt Mask and interrupt vector address will be used to control and maintain the interrupt request. The Interrupt Enable Flag is also used to control the total interrupt operations.

## - Interrupt Control Bit and Interrupt Service

The interrupt control bit is mapped on $\$ 000$ to $\$ 003$ of the RAM address and accessable by RAM bit manipulation instruction. (The Interrupt Request Flag (IF) cannot be set by software.) The Interrupt Enable Flag (I/E) and Interrupt Request Flag (IF) are set to " 0 ", and the Interrupt Mask (IM) is set to " 1 " at the initialization by MCU reset.

Fig. 6 shows the interrupt block diagram. Table 1 shows the interrupt priority and vector addresses, and Table 2 shows the conditions that the interrupt service is executed by any one of the five interrupt sources.

The interrupt request is generated when the Interrupt Request Flag is set to " 1 " and the Interrupt Mask is " 0 ". If the Interrupt Enable Flag is "1", then the interrupt will be activated and vector addresses will be generated from the priority PLA corresponding to the five interrupt sources.

Fig. 7 shows the interrupt services sequence, and Fig. 8 shows the interrupt flowchart. If the interrupt is requested, the instruction finishes its execution in the first cycle. The Interrupt Enable Flag is reset in the second cycle. In the second and third cycles, the Carry, Status and Program Counter are pushed onto the stack. In the third cycle, the instruction is executed again after jumping to the vector address.

In each vector address, program JMPL instruction to branch to a starting address of the interrupt routine. The Interrupt Request Flag which caused the interrupt service has to be reset by software in the interrupt routine.


Fig. 6 Interrupt Circuit Block Diagram

Table 1. Vector Addresses and Interrupt Priority

| Reset . Interrupt | Priority | Vector addresses |
| :---: | :---: | :---: |
| RESET | - | $\$ 0000$ |
| $\overline{\text { INT }}_{0}$ | 1 | $\$ 0002$ |
| $\overline{\text { INT }} 1$ | 2 | $\$ 0004$ |
| TIMER-A | 3 | $\$ 0006$ |
| TIMER-B | 4 | $\$ 0008$ |
| SERIAL | 5 | $\$ 000 C$ |

Table 2. Conditions of Interrupt Service

| Interrupt control bits | INTo | $\overline{\text { INT }}$ | TIMER-A | TIMER-B | SERIAL |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/E | 1 | 1 | 1 | 1 | 1 |
| IFO.IMO | 1 | 0 | 0 | 0 | 0 |
| IF1. $\overline{\text { IM1 }}$ | * | 1 | 0 | 0 | 0 |
| IFTA - $\overline{\text { MTA }}$ | * | * | 1 | 0 | 0 |
| IFTB • $\overline{\text { MTTB }}$ | * | * | * | 1 | 0 |
| IFS • $\overline{\mathrm{MSS}}$ | * | * | * | * | 1 |



- Interrupt Enable Flag (I/E: \$000,0)

The Interrupt Enable Flag controls enable/disable of all interrupt requests as shown in Table 3. The Interrupt Enable Flag is reset by the interrupt servicing and set by RTNI instruction.

Table 3. Interrupt Enable Flag

| Interrupt Enable Flag | Interrupt Enable/Disable |
| :---: | :---: |
| 0 | Disable |
| 1 | Enable |

## - External Interrupt ( $\overline{\mathbf{N N T}} \mathbf{N}_{0}, \overline{\mathrm{INT}_{1}}$ )

To use external interrupt, select $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}}, \mathrm{R}_{33} / \overline{\mathrm{INT}}$ port for $\overline{\mathrm{IN}} \mathrm{T}_{\mathbf{0}}, \overline{\mathrm{INT}}_{1}$ mode by setting the Port Mode Register (PMR: \$004).

The External Interrupt Request Flags (IF0, IF1) are set at the falling edge of $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}$ inputs.
$\overline{\mathrm{INT}} \mathbf{1}_{1}$ input can be used as a clock signal input of TIMER-B. Then, TIMER-B counts up at each falling edge of input. When using $\overline{I N T}_{1}$ as TIMER-B external event, an External Interrupt Mask (IM1) has to be set so that the interrupt request by $\overline{\mathrm{INT}} 1$ will not be accepted.

- External Interrupt Request Flag (IF0: $\mathbf{\$ 0 0 0 , 2 , ~ I F 1 : ~ \$ 0 0 1 , 0 )}$

The External Interrupt Request Flags (IF0, IF1) are set at the falling edges of $\overline{\mathrm{INT}}_{0}, \overline{\mathrm{INT}}_{1}$ inputs respectively.

- External Interrupt Mask (IM0: \$000,3, IM1: \$001,1)

The External Interrupt Mask is used to mask the external interrupt requests.

Table 4. External Interrupt Request Flag

| External Interrupt Request Flags | Interrupt Requests |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 5. External Interrupt Mask

| External Interrupt Masks | Interrupt Requests |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (masks) |

## - Port Mode Register (PMR: \$004)

The Port Mode Register is a 4-bit write-only register which controls the $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}} \mathrm{pin}, \mathrm{R}_{33} / \overline{\mathrm{INT}_{1}}$ pin, $\mathrm{R}_{41} / \mathrm{SI}$ pin and $\mathrm{R}_{42}$ / SO pin as shown in Table 6. The Port Mode Register will be initialized to $\$ 0$ by MCU reset, so that all these pins are set to a port mode.

Table 6. Port Mode Register

| PMR | $\mathrm{R}_{33} / \overline{\mathrm{NT}_{1}}$ pin |
| :---: | :---: |
| bit 3 |  |
| 0 | Used as $\mathrm{R}_{33}$ port input/output pin |
| 1 | Used as $\overline{\mathrm{INT}_{1}}$ input pin |
| PMR | $\mathrm{R}_{32} / \overline{\mathrm{NT}}{ }_{0} \mathrm{pin}$ |
| bit 2 |  |
| 0 | Used as R 32 port input/output pin |
| 1 | Used as $\overline{\text { NT }}_{0}$ input pin |
| PMR | $\mathrm{R}_{41} / \mathrm{SI}$ pin |
| bit 1 |  |
| 0 | Used as $\mathrm{R}_{41}$ port input/output pin |
| 1 | Used as SI input pin |
| PMR | $\mathrm{R}_{42} / \mathrm{SO}$ pin |
| bit 0 |  |
| 0 | Used as $\mathrm{R}_{42}$ port input/output pin |
| 1 | Used as SO output pin |



Fig. 8 Interrupt Servicing Flowchart

## - SERIAL INTERFACE

The serial interface is used to transmit/receive 8 -bit data serially. This consists of the Serial Data Register, the Serial Mode Register, the Octal Counter and the multiplexer, as illustrated in Fig. 9. Pin $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the transfer clock signal are controlled by the Serial Mode Register. Contents of the Serial Data Register can be written into or read out by the software. The data in the Serial Data Register can be shifted synchronous-
ly with the transfer clock signal.
The serial interface operation is initiated with STS instruction. The Octal Counter is reset to $\$ 0$ by STS instruction. It starts to count at the falling edge of the transfer clock ( $\overline{\mathrm{SCK}}$ ) signal and increments by one at the rising edge of the SCK. When the Octal Counter is reset to $\$ 0$ after eight transfer clock signals, or discontinued transmit/receive operation by resetting the Octal Counter, the SERIAL Interrupt Request Flag will be set.


Fig. 9 Serial Interface Block Diagram

- Serial Mode Register (SMR: \$005)

The Serial Mode Register is a 4 -bit write-only register. This register controls the $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the prescaler divide ratio as the transfer clock source as shown in Table 7.

The Write Signal to the Serial Mode Register controls the operating state of serial interface.

The Write Signal to the Serial Mode Register stops the transfer clock applied to the Serial Data Register and the Octal Counter. And it also reset the Octal Counter to $\$ 0$ simultaneously.

When the Serial Interface is in the "Transfer State", the Write Signal to the Serial Mode Register causes to quit the data transfer and to set the SERIAL Interrupt Request Flag.

Contents of the Serial Mode Register will be changed on the second instruction cycle after writing into the Serial Mode Register. Therefore, it will be necessary to execute the STS instruction after the data in the Serial Mode Register has been changed completely. The Serial Mode Register will be reset to
$\$ 0$ by MCU reset.

- Serial Data Register (SRL: \$006, SRU: \$007)

The Serial Data Register is an 8 -bit read/write register. It consists of a low-order digit (SRL:\$006) and a high-order digit (SRU: \$007).

The data in the Serial Data Register will be output from the LSB side at SO pin synchronously with the falling edge of the transfer clock signal. At the same time, external data will be input from the LSB side at SI pin to the Serial Data Register synchronously with the rising edge of the transfer clock. Fig. 10 shows the I/O timing chart for the transfer clock signal and the data.

The writing into/reading from the Serial Data Register during its shifting causes the validity of the data.

Therefore complete data transmit/receive before writing into/reading from the serial data register.

Table 7. Serial Mode Register

| SMR | R $_{\mathbf{4 0}} / \overline{\text { SCK }}$ |
| :---: | :---: |
| Bit 3 |  |
| $\mathbf{0}$ | Used as R40 port input/output pin |
| $\mathbf{1}$ | Used as $\overline{\text { SCK input/output pin }}$ |


| SMR |  |  | Transfer Clock |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 | R40/ $\overline{\text { SCK }}$ Port | Clock Source | Prescaler Divide Ratio | System Clock Divide Ratio |
| 0 | 0 | 0 | $\begin{aligned} & \text { SCK } \\ & \text { Output } \end{aligned}$ | Prescaler | $\div 2048$ | $\div 4096$ |
| 0 | 0 | 1 | SCK Output | Prescaler | $\div 512$ | $\div 1024$ |
| 0 | 1 | 0 | SCK Output | Prescaler | $\div 128$ | $\div 256$ |
| 0 | 1 | 1 | $\begin{aligned} & \overline{\text { SCK }} \\ & \text { Output } \end{aligned}$ | Prescaler | $\div 32$ | $\div 64$ |
| 1 | 0 | 0 | SCK Output | Prescaler | $\div 8$ | $\div 16$ |
| 1 | 0 | 1 | $\begin{aligned} & \overline{\text { SCK }} \\ & \text { Output } \end{aligned}$ | Prescaler | $\div 2$ | $\div 4$ |
| 1 | 1 | 0 | SCK Output | System Clock | - | $\div 1$ |
| 1 | 1 | 1 | $\begin{aligned} & \hline \overline{\text { SCK }} \\ & \text { Input } \end{aligned}$ | External Clock | - | - |

(In the case of SMR Bit $\mathbf{3}=1$ )


Fig. 10 Serial Interface I/O Timing Chart

- SERIAL Interrupt Request Flag (IFS: \$003, 0)

The SERIAL Interrupt Request Flag will be set after the eight transfer clock signals or transmit/receive discontinued operation by resetting the Octal Counter.

- SERIAL Interrupt Mask (IMS: \$003, 1)

The SERIAL Interrupt Mask masks the interrupt request.
Table 8. SERIAL Interrupt Request Flag

| SERIAL Interrupt Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| $\mathbf{1}$ | Yes |

Table 9. SERIAL Interrupt Mask

| SERIAL Interrupt Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| $\mathbf{1}$ | Disable (masks) |

- Selection of the Operation Mode

Table 10 shows the operation mode of the serial interface. Select a combination of the value in the Port Mode Register and the Serial Mode Register according to Table 10.

Initialize the serial interface by the Write Signal to the Serial Mode Register, when the Operation Mode is changed.

- Operating State of Serial Interface

The serial interface has 3 operating states as shown in Fig. 11. The serial interface gets into "STS waiting state" by 2 ways: one way is to change the operation mode by changing the data
in the Port Mode Register, the other is to write data into the Serial Mode Register. In this state, the serial interface does not operate although the transfer clock is applied. If STS instruction is executed, the serial interface changes its state to "SCK waiting state".

In the "SCK waiting state", the falling edge of first transfer clock affects the serial interface to get into "transfer state", while the Octal Counter counts-up and the Serial Data Register shifts simultaneously. As an exception, if the clock continuous output mode is selected, the serial interface stays in "SCK waiting state" while the transfer clock outputs continuously.

The Octal Counter becomes " 000 " again by 8 transfer clocks or execution of STS instruction, so that the serial interface gets back into the "SCK waiting state", and SERIAL Interrupt Request Flag is set simultaneously.

When the internal transfer clock is selected, the transfer clock output are triggered by the execution of STS instruction, and it stops after 8 clocks.

## - Example of Transfer Clock Error Detection

The serial interface functions abnormally when the transfer clock was disturbed by external noises. In this case, the transfer
clock error can be detected in the procedure shown in Fig. 12.
If more than 9 transfer clocks are applied by the external noises in the "SCK waiting state", the state of the serial interface shifts as the following sequence: first "transfer state" (while 1 to 7 transfer clocks), second "SCK waiting state" (at 8th transfer clock) and third "transfer state" again. Then reset the SERIAL Interrupt Request Flag, and make "STS waiting state" by writing to the Serial Mode Register. SERIAL Interrupt Request Flag is set again in this procedure, and it shows that the transfer clock was invalid and that the transmit/receive data were also invalid.

Table 10. Serial Interface Operation Mode

| SMR | PMR |  | Serial Interface Operating Mode |
| :---: | :---: | :---: | :--- |
| Bit 3 | Bit 1 | Bit 0 |  |
| 1 | 0 | 0 | Clock Continuous Output Mode |
| 1 | 0 | 1 | Transmit Mode |
| 1 | 1 | 0 | Receive Mode |
| 1 | 1 | 1 | Transmit/Receive Mode |




Fig. 12 Example of Transfer Clock Error Detection

- TIMER

The MCU contains a prescaler and two timer/counters (TIMER-A, TIMER-B), Fig. 13 shows the block diagram. The prescaler is an 11 -bit binary counter. TIMER-A is an 8 -bit free-run timer. TIMER-B is an 8 -bit auto-reload timer/event counter.

## - Prescaler

The input to the prescaler is a system clock signal. The prescaler is initialized to $\$ 000$ by MCU reset, and the prescaler starts to count up the system clock signal as soon as RESET input goes to logic " 0 ". The prescaler keeps counting up except MCU reset and stop mode. The prescaler provides clock signals to TIMER-A, TIMER-B and serial interface. The prescaler divide ratio of the clock signals are selected according to the content of the mode registers such as - Timer Mode Register A (TMA), Timer Mode Register B (TMB), Serial Mode Register (SMR).


Fig. 13 Timer/Counter Block Diagram

## - TIMER-A Operation

After TIMER-A is initialized to $\$ 00$ by MCU reset, it counts up at every clock input signal. When the next clock signal is applied after TIMER-A is counted up to \$FF, TIMER-A is set to $\$ 00$ again, and generating overflow output. This leads to setting TIMER-A Interrupt Request Flag (IFTA: \$001, 2) to " 1 ". Therefore, this timer can function as an interval timer periodically generating overflow output at every 256th clock signal input.

The clock input signals to TIMER-A are selected by the Timer Mode Register A (TMA: \$008).

## - TIMER-B Operation

Timer Mode Register B (TMB: \$009) is used to select the auto-reload function and the prescaler divide ratio of TIMER-B as the input clock source. When the external event input is used as an input clock signal to TIMER-B, select the $\mathrm{R}_{33} / \mathrm{INT}_{1}$ as $\overline{I N T_{1}}$ and set the External Interrupt Mask (IM1) to " 1 " to prevent the external interrupt request from occurring.

TIMER-B is initialized according to the value written into the Timer Load Register by software. TIMER-B counts up at every clock input signal. When the next clock signal is applied to TIMER-B after TIMER-B is set to \$FF, TIMER-B will be initialized again and generate overflow output. In this case if the auto-reload function is selected. TIMER-B is initialized according to the value of the Timer Load Register. Else if the autoreload function is not selected, TIMER-B goes to \$00. TIMERB Interrupt Request Flag (IFTB: $\$ 002,0$ ) will be set at this overflow output.

- Timer Mode Register A (TMA: \$008)

The Timer Mode Register A is a 3-bit write-only register. The TMA controls the prescaler divide ratio of TIMER-A clock input, as shown in Table 11.

The Timer Mode Register A is initialized to $\$ 0$ by MCU reset.

- Timer Mode Register B (TMB: \$009)

The Timer Mode Register B is a 4 -bit write-only register. The Timer Mode Register B controls the selection for the autoreload function of TIMER-B and the prescaler divide ratio, and the source of the clock input signal, as shown in Table 12.

The Timer Mode Register B is initialized to $\$ 00$ by MCU reset.

The operation mode of TIMER-B is changed at the second instruction cycle after writing into the Timer Mode Register B.

Therefore, it is necessary to program the write instruction to TLRU after the content of TMB is changed.

Table 11. Timer Mode Register A

| TMA |  |  | Prescaler Divide Ratio |
| :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 |  |
| 0 | 0 | 0 | $\div 2048$ |
| 0 | 0 | 1 | $\div 1024$ |
| 0 | 1 | 0 | $\div 512$ |
| 0 | 1 | 1 | $\div 128$ |
| 1 | 0 | 0 | $\div 32$ |
| 1 | 0 | 1 | $\div$ |
| 1 | 1 | 0 | $\div$ |
| 1 | 1 | 1 | $\div$ |

Table 12. Timer Mode Register B

| TMB |  | Auto-reload Function |  |
| :---: | :---: | :---: | :---: |
| Bit 3 | No |  |  |
| 0 |  | Yes |  |
| 1 |  | Prescaler Divide Ratio, <br> Clock Input Source |  |
| TMB |  |  | $\div 2048$ |
| Bit 2 | Bit 1 | Bit 0 | $\div 512$ |
| 0 | 0 | 0 | $\div 128$ |
| 0 | 0 | 1 | $\div 32$ |
| 0 | 1 | 0 | $\div 3$ |
| 0 | 1 | 1 | $\div 4$ |
| 1 | 0 | 0 | $\div$ |
| 1 | 0 | 1 | 2 |
| 1 | 1 | 0 | $\div$ |
| 1 | 1 | 1 | INT $_{1}$ (External Event Input) |

- TIMER-B (TCBL: \$00A, TCBU : \$00B

TLRL: \$00A, TLRU: \$00B
TIMER-B consists of an 8 -bit write-only Timer Load Register, and an 8 -bit read-only Timer/Event Counter. Each of them has a low-order digit (TCBL: \$00A, TLRL: \$00A) and a highorder digit (TCBU: \$00B, TLRU: \$00B).

The Timer/Event Counter can be initialized by writing data into the Timer Load Register. In this case, write the low-order digit first, and then the high-order digit. The Timer/Event Counter is initialized at the time when the high-order digit is written. The Timer Load Register will be initialized to $\$ 00$ by the MCU reset.

The counter value of TIMER-B can be obtained by reading
the Timer/Event Counter. In this case, read the high-order digit first, and then the low-order digit. The count value of low-order digit is latched at the time when the high-order digit is read.

- TIMER-A Interrupt Request Flag (IFTA: \$001, 2)

The TIMER-A Interrupt Request Flag is set by the overflow output of TIMER-A.

- TIMER-A Interrupt Mask (IMTA: \$001, 3)

TIMER-A Interrupt Mask prevents an interrupt request generated by TIMER-A Interrupt Request Flag.

Table 13. TIMER-A Interrupt Request Flag

| TIMER-A Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 14. TIMER.A Interrupt Mask

| TIMER-A Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

TIMER-B Interrupt Request Flag (IFTB: \$002, 0)
The TIMER-B Interrupt Request Flag is set by the overflow output of TIMER-B.

- TIMER-B Interrupt Mask (IMTB: \$002, 1)

TIMER-B Interrupt Mask prevents an interrupt request generated by TIMER-B Interrupt Request Flag.

SMR:\$005

$\mathbf{R}_{\mathbf{4 2}}$ /SO pin mode selection
R $_{41} /$ SI pin mode selection

- $\mathrm{R}_{32} / \overline{\mathrm{NT}}{ }_{0}^{-}$pin mode selection
$-\mathrm{R}_{33} / \overline{\mathrm{NT}} \mathbf{1}_{1}$ pin mode selection
TMA:\$008
TMB:\$009


TIMER-A input clock selection
Fig. 14 Mode Register Configuration and Function

Table 15. TIMER-B Interrupt Request Flag

| TIMER-B Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 16. TIMER•B Interrupt Mask

| TIMER-B Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

## - INPUT/OUTPUT

The MCU provides 58 Input/Output pins, and they are consist of 32 standard pins of "Without pull-up MOS (NMOS open drain)" and 26 high voltage pins of "Without pull-down MOS (PMOS open drain)".

When any input/output common pin is used as input pin, it is necessary to set the output data as shown in Table 18.

Table 17 I/O Pin Circuit Forms

(Continued)

|  |  | Applied pins |
| :--- | :--- | :--- | :--- | :--- |

(Note) In the stop mode, HLT signal is " 0 ", HLT signal is " 1 " and I/O pins are in high impedance.

Table 18 Data Input from Input/Output Common Pins

| 1/O circuit type | Available pin condition for input |
| :---: | :---: |
| For Standard pins |  |
| "Without pull-up MOS |  |
| (NMOS open drain)" | "1"' |
| For High voltage pins |  |
| "Without pull-down MOS |  |
| (PMOS open drain)" |  |

- D-port

D-port is 1 -bit $\mathrm{I} / \mathrm{O}$ port, and it has 16 Input/Output common pins. It can be set/reset by the SED/RED and SEDD/REDD instructions, and can be tested by the TD and TDD instructions. Table 17 shows the classification of standard pins, high voltage pins and the Input/Output pins circuit types.

## - R-port

R-port is 4-bit I/O port. It provides 20 input/output common pins, 16 output-only pins, and 6 input-only pins. Data input is processed using the LAR and LBR instructions and data
output is processed using the LRA and LRB instructions. The MCU will not be affected by writing into the input-only and/or non-existing ports, invalid data will be read by reading from the output-only and/or non-existing ports.

The $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ pins are also used as the $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}} \mathbf{1}, \overline{\mathrm{SCK}}, \mathrm{SI}$ and SO pins respectively. Table 17 shows the classification of standard pins, high voltage pins and Input/ Output pins circuit types.

## - RESET

The MCU is reset by setting RESET pin to " 1 ". At power

Table 19 MCU Initial Value by Reset

| Items |  |  | Initial value by MCU reset | Contents |
| :---: | :---: | :---: | :---: | :---: |
| Program counter (PC) |  |  | \$0000 | Execute program from the top of ROM address. |
| Status (ST) |  |  | "1" | Enable to branch with conditional branch instructions. |
| Stack pointer (SP) |  |  | \$3FF | Stack level is 0 . |
| I/O output register | Standard pin | Without pull-up MOS | "1" | Enable to input. |
|  | High voltage pin | Without pull-down MOS | "0" | Enable to input. |
| Interrupt flag | Interrupt Enable Flag (I/E) |  | "0" | Inhibit all interrupts. |
|  | Interrupt Request Flag (IF) |  | "0" | No interrupt request. |
|  | Interrupt Mask (IM) |  | "1" | Mask interrupt request. |
| Mode register | Port Mode Register (PMR) |  | "0000" | See Item "Port Mode Register". |
|  | Serial Mode Register (SMR) |  | "0000" | See Item 'Serial Mode Register". |
|  | Timer Mode Register A (TMA) |  | "000" | See Item "Timer Mode Register A". |
|  | Timer Mode Register B (TMB) |  | "0000" | See Item "Timer Mode Register B". |
| Timer/Counter, Serial Interface | Prescaler |  | \$000 | - |
|  | Timer/Counter A (TCA) |  | \$00 | - |
|  | Timer/Event Counter B (TCB) |  | \$00 | - |
|  | Timer Load Register (TLR) |  | \$00 | - |
|  | Octal Counter |  | "000" | - |

(Note) The values of registers and flags which are not described on above table will become as follows.

| Item | After releasing stop mode by MCU Reset | After MCU Reset except the left |
| :---: | :---: | :---: |
| Carry (CA) | The value immediately before MCU reset is not guaranteed. <br> Initialization by the program should be required. | The value immediately before MCU Reset is not guaranteed. <br> Initialization by the program should be required. |
| Accumulator (A) |  |  |
| B register (B) |  |  |
| W register (W) |  |  |
| X/SPX register (X/SPX) |  |  |
| Y/SPY register (Y/SPY) |  |  |
| Serial data register (SR) | - ditto - | - ditto - |
| RAM | The value immediately before MCU reset (the value immediately before executing stop instruction) is retained. | - ditto - |

ON or recovering from stop mode, apply RESET input more than $t_{R C}$ to obtain the necessary time for oscillator stabilization. In other cases, the MCU reset requires at least two instructions cycle time of RESET input.

Table 19 shows initialized items by MCU reset and each status after reset.

## - INTERNAL OSCILLATOR CIRCUIT

Fig. 15 gives internal oscillator circuit. The oscillator type can be selected from the followings; crystal resonator, or ceramic filter resonator as shown in Table 20. In any cases, external clock operation is available.


Fig. 15 Internal Oscillator Circuit
Table 20 Oscillator Circuit Example

|  | Circuit configuration | Remarks |
| :---: | :---: | :---: |
| External clock operation |  |  |
| Ceramic filter resonator |  | Ceramic filter: CSA 4.00MG (Murata) <br> $R_{f}: 1 M \Omega \pm 2 \%$ <br> $\mathrm{C}_{1}: \quad 33 \mathrm{pF} \pm 20 \%$ <br> $\mathrm{C}_{2}: \quad 33 \mathrm{pF} \pm 20 \%$ <br> Ceramic filter: CSA 6.00MG (Murata) <br> $R_{f}: \quad 1 \mathrm{M} \Omega \pm 2 \%$ <br> C1: $30 \mathrm{pF} \pm 20 \%$ <br> $C_{2}: \quad 30 \mathrm{pF} \pm 20 \%$ <br> - Wiring between these pins and elements should be as short as possible, and never cross the other wirings. (Refer to Fig. 16) |
| Crystal resonator |  | Crystal: $\mathbf{4 . 1 9 4 3 0 4}$ (MHz) <br> NC-18C (Nihon Denpa Kogyo) <br> $R_{f}$ : $\quad 1 \mathrm{M} \Omega \pm 2 \%$ <br> $\mathrm{C}_{1}$ : $\quad 22 \mathrm{pF} \pm 20 \%$ <br> $C_{2}$ : $\quad 22 \mathrm{pF} \pm 20 \%$ <br> Crystal: 6.0 (MHz) <br> NC-18C (Nihon Denpa Kogyo) <br> $R_{f}$ : $\quad 1 \mathrm{M} \Omega \pm 2 \%$ <br> $\mathrm{C}_{1}$ : $\quad 20 \mathrm{pF} \pm 20 \%$ <br> $\mathrm{C}_{2}$ : $\quad 20 \mathrm{pF} \pm 20 \%$ |

Crystal: ATcut parallel resonance crystal
Co: 7pF max.
$R_{\mathbf{s}}$ : $100 \Omega$ max.
f: $2.0 \sim 6.2 \mathrm{MHz}$

- Wiring between these pins and elements should be as short as possible, and never cross the other wirings. (Refer to Fig. 16)

[^10]

- LOW POWER DISSIPATION MODE

The MCU provides two low power dissipation modes, that is, a Standby mode and a Stop mode. Table 21 shows the function of the low power dissipation mode, and Fig. 17 shows the diagram of the mode transition.

Fig. 16 Recommendable Layout of Crystal and Ceramic Filter
Table 21 Low Power Dissipation Mode Function

| Low Power Dissipation Mode | Instruction | Condition |  |  |  |  |  |  | Recovering method |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Oscillator circuit | Instruction execution | Register Flag | Interrupt function | RAM | Input/ Output pin | Timer Counter, Serial Interface |  |
| Standby mode | SBY instruction | Active | Stop | Retained | Active | Retained | Retained ${ }^{\text {* }}$ 2 | Active | RESET Input, Interrupt request |
| Stop mode | $\begin{aligned} & \text { STOP } \\ & \text { instruction } \end{aligned}$ | Stop | Stop | RESET ${ }^{*} 1$ | Stop | Retained | High impedance | Stop | RESET Input |

*1) STOP mode is released only by MCU Reset. Refer to Table 19 as for the values of the registers and flags after releasing stop mode.
*2) Current flows in $1 / O$ Circuit by $1 / O$ pin state at stand-by mode, because $1 / O$ circuit is active. This current is an addition to stand-by mode power dissipation.


Fig. 17 MCU Operation Mode Transition

## - Standby Mode

The SBY instruction puts the MCU into the Standby mode. In the Standby mode, the oscillator circuit is active and timer/
counter and serial interface continue working. On the other hand, the CPU stops since the clock related to the instruction execution stops. Registers, RAM and Input/Output pins retain the state they had just before going into the Standby mode.

The Standby mode is canceled by the MCU reset or interrupt request. When canceled by the interrupt request, the MCU becomes an active mode and executes the instruction next to the SBY instruction. At this time, if the Interrupt Enable Flag is " 1 ", the interrupt is executed. If the Interrupt Enable Flag is " 0 ", the interrupt request is held on and the normal instruction execution continues.

Fig. 18 shows the flowchart of the Standby Mode.

## - Stop Mode

The STOP instruction brings the MCU into the Stop mode. In this mode the oscillator circuit and every function of the MCU stop.

The Stop mode is canceled by the MCU reset. At this time, as shown in Fig. 19, apply the RESET input for more than $t_{R C}$ to get enough oscillator stabilization time. (Refer to the "AC CHARACTERISTICS".) After the Stop mode is canceled, RAM retains the state it had just before going into the Stop mode after releasing stop mode by MCU reset, the values of the B register, W register, X/SPX register, Y/SPY register, carry and serial data register are not guaranteed.


Fig. 18 MCU Operating Flowchart


Fig. 19 Stop Mode Cancel Timing Chart

- RAM ADDRESSING MODE

As shown in Fig. 20, the MCU provides three RAM addressing modes; Register Indirect Addressing, Direct Addressing and Memory Register Addressing.

- Register Indirect Addressing

The combined 10-bit contents of W Register, X Register and Y Register is used as the RAM address in this mode.

## - Direct Addressing

The direct addressing instruction consists of two words and the second word ( 10 bits) following Op-code (the first word) is used ás the RAM address.

## - Memory Register Addressing

The Memory Register Addressing can access 16 digits (Memory Register: MR) from $\$ 020$ to $\$ 02 \mathrm{~F}$ by using the LAMR and XMRA instruction.

(a) Register Indirect Addressing

(b) Direct Addressing

(c) Memory Register Addressing

Fig. 20 RAM Addressing Mode

## - ROM ADDRESSING MODE AND P INSTRUCTION

The MCU has four kinds of ROM addressing modes as shown in Fig. 21.

## - Direct Addressing Mode

The program can branch to any addresses in the ROM memory space by using JMPL, BRL or CALL instruction. These instructions replace 14 -bit program counter (PCl3 to PCO) with 14 -bit immediate data.

## - Current Page Addressing Mode

ROM memory space is divided into 256 words in each page starting from $\$ 0000$. The program branches to the address in the same page using BR instruction. This instruction replace the low-order eight bits of program counter (PC7 to PC0) with

8-bit immediate data.

## - Zero Page Addressing Mode

The program branches to the zero page subroutine area, which is located on the address from $\$ 0000$ to $\$ 003 \mathrm{~F}$, using CAL instruction. When CAL instruction is executed, 6 -bit immediate data is placed in low-order six bits of program counter (PC5 to PC0) and " 0 's" are placed in high-order eight bits (PC13 to PC6). The branch destination by BR instruction on the boundary between pages is given in Fig. 23.

## - Table Data Addressing

The program branches to the address determined by thr contents of the 4 -bit immediate data, accumulator and B regis ter, using TBR instruction.

(a) Direct Addressing

(b) Current Page Addressing

(c) Zero Page Addressing

Instruction
(TBR)

(d) Table Data Addressing

Fig. 21 ROM Addressing Mode

(a) Address Designation

(b) Pattern Output

Fig. 22 P Instruction

- P Instruction (Pattern Instruction)

By P instruction, the ROM data determined by Table Data addressing is referred. When bit 8 in referred ROM data is " 1 ", 8 bits of referred ROM data are written into the accumu-


Fig. 23 The Branch Destination by BR Instruction on the Boundary between Pages
lator and B Register. When bit 9 is " 1 ", 8 bits of referred ROM data are written into the R1 and R2 port output register. When both bit 8 and 9 are " 1 ", ROM data are written into the accumulator and B register and also to the R1 and R2 port output register at a same time.

The $P$ instruction has no effect on the program counter.

- INSTRUCTION SET

The HMCS400 series provide 99 instructions. These instructions are classified into 10 groups as follows;
(1) Immediate Instruction
(2) Register-to-Register Instruction
(3) RAM Address Instruction
(4) RAM Register Instruction
(5) Arithmetic Instruction
(6) Compare Instruction
(7) RAM Bit Manipulation Instruction
(8) ROM Address Instruction
(9) Input/Output Instruction
(10) Control Instruction

Table 22. Immediate Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CyCLE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Immediate | LAI i | $100011 \mathrm{i}_{3} \mathrm{i}_{2} \mathrm{i} \mathrm{i}_{0}$ | $\longrightarrow$ - |  | 1/1 |
| Load B from Immediate | LBI i | $100000 \mathrm{i}_{3} \mathrm{i}_{2} \mathrm{i}$, io | $\longmapsto \mathrm{B}$ |  | 1/1 |
| Load Memory from Immediate | LMID i,d |  | $\longmapsto \mathrm{M}$ |  | 2/2 |
| Load Memory from Immediate, Increment $Y$ | LMIIY i | $101001 i_{3} i_{2} \mathrm{i}_{1} \mathrm{i}_{0}$ | $i \rightarrow M, Y+1 \rightarrow Y$ | NZ | 1/1 |

Table 23. Register-to-Register Instruction

| OPERATION | MNEMONIC | OPERATION CODE |  |  |  |  |  |  |  | FUNCTION | STATUS | worg <br> trces |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from B | LAB |  | 000 | 01 | 0 | 0 | 10 | 0 | 0 | $B \rightarrow A$ |  | 1/1 |
| Load B from A | LBA |  | 00 | 11 | 0 | 0 | 10 | 0 | 0 | $A \rightarrow B$ |  | 1/1 |
| Load A from $Y$ | LAY |  | 00 | 10 | 1 | 0 | 11 | 1 | 1 | $Y \rightarrow A$ |  | 1/1 |
| Load A from SPX | LASPX |  | 00 | 01 | 1 | 0 | 10 | 0 | 0 | SPX $\rightarrow$ A |  | 1/1 |
| Load A from SPY | LASPY |  | 000 | 01 | 0 | 1 | 10 | 0 | 0 | SPY $\rightarrow$ A |  | 1/1 |
| Load A from MR | LAMR m |  | 100 | 01 | 1 | 1 | $\mathrm{m}_{3} \mathrm{~m}_{2}$ | m |  | $\mathrm{MR}(\mathrm{m}) \rightarrow \mathrm{A}$ |  | 1/1 |
| Exchange MR and $A$ | XMRA m |  | 10 | 11 | 1 | 1 | $\mathrm{m}_{3} \mathrm{~m}_{2}$ | $\mathrm{m}_{1}$ |  | $M R(m) \leftarrow A$ |  | 1/1 |

Table 24. RAM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD CYCLE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load W from Immediate | LWI i | $001111 i_{3} i_{2} i_{1} i_{0}$ | $\xrightarrow{\longrightarrow} \mathrm{W}$ |  | 1/1 |
| Load X from Immediate | LXI i | $100010 i_{3} i_{2} i_{1}$ io | $\longrightarrow X$ |  | 1/1 |
| Load $Y$ from Immediate | LYI i | $100001 i_{3} i_{2} i_{1}$ io | $\underline{\longrightarrow} \mathrm{Y}$ |  | 1/1 |
| Load $X$ from $A$ | LXA | 0011101000 | $\boldsymbol{A} \longrightarrow X$ |  | 1/1 |
| Load $Y$ from $A$ | LYA | 0011011000 | $\mathbf{A} \longrightarrow Y$ |  | 1/1 |
| Increment $Y$ | IY | 0001011100 | $Y+1 \rightarrow Y$ | NZ | 1/1 |
| Decrement $Y$ | DY | 0011011111 | $Y-1 \rightarrow Y$ | NB | 1/1 |
| Add $A$ to $Y$ | AYY | 0001010100 | $Y+A \rightarrow Y$ | OVF | 1/1 |
| Subtract $A$ from $Y$ | SYY | 0011010100 | $Y-A \rightarrow Y$ | NB | 1/1 |
| Exchange $X$ and SPX | XSPX | 0000000001 | $X \leftrightarrow S P X$ |  | 1/1 |
| Exchange $Y$ and SPY | XSPY | 0000000010 | $\mathrm{Y} \leftrightarrow \mathrm{SPY}$ |  | 1/1 |
| Exchange $X$ and SPX,Y and SPY | XSPXY | 0000000011 | X↔SPX,Y*SPY |  | 1/1 |

Table 25. RAM Register Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Memory | LAM (XY) | 00100100 yx | $\mathbf{M} \rightarrow \mathrm{A},\binom{x+\cdots$ SPX }{$\mathrm{r} \cdot \mathrm{SPY}}$ |  | 1/1 |
| Load A from Memory | LAMD d |  | $\mathbf{M} \rightarrow \mathrm{A}$ |  | 2/2 |
| Load B from Memory | LBM (XY) | $00010000 y x$ | $\mathrm{M} \rightarrow \mathrm{B},\binom{$ ( }{$\mathrm{Y} \rightarrow \mathrm{SPP} \mathrm{SP}}$ |  | 1/1 |
| Load Memory from A | LMA(XY) | 00100101 yx | $\mathrm{A} \rightarrow \mathrm{M},\left(\begin{array}{c}\binom{\text { ¢ }}{\mathrm{Y} \rightarrow \text { SPX }}\end{array}\right.$ |  | 1/1 |
| Load Memory from A | LMAD d |  | $A \rightarrow M$ |  | 2/2 |
| Load Memory from A, Increment Y | LMAIY(X) | $000101000 \times$ | $A \rightarrow M, Y+1 \rightarrow Y(X \rightarrow S P X)$ | NZ | 1/1 |
| Load Memory from A, Decrement Y | LMADY(X) | $001101000 \times$ | $A \rightarrow M, Y-1 \rightarrow Y(X \sim S P X)$ | NB | 1/1 |
| Exchange Memory and A | XMA(XY) | 00100000 yx |  |  | 1/1 |
| Exchange Memory and $A$ | XMAD d |  | $\mathbf{M} \leftrightarrow A$ |  | 2/2 |
| Exchange Memory and B | XMB(XY) | 00110000 yx |  |  | 1/1 |

Note) ( $X Y$ ) and ( $X$ ) have the meaning as follows:
(1) The instructions with ( $X Y$ ) have 4 mnemonics and 4 object codes for each. (example of LAM ( $X Y$ ) is given below.)

| MNEMONIC | $y$ | $x$ | FUNCTION |
| :---: | :---: | :---: | :---: |
| LAM | 0 | 0 |  |
| LAMX | 0 | 1 | $X \leftrightarrow$ SPX |
| LAMY | 1 | 0 | $Y \leftrightarrow S P Y$ |
| LAMXY | 1 | 1 | $X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |

(2) The instructions with $(x)$ have 2 mnemonics and 2 object codes for each. (example of LMAIY $(X)$ is given below.)

| MNEMONIC | $x$ | FUNCTION |
| :---: | :---: | :---: |
| LMAIY | 0 |  |
| LMAIYX | 1 | $\mathrm{X} \leftrightarrow S P X$ |

Table 26. Arithmetic Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD/ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Add Immediate to A | Al i | $101000 i_{3} i_{2} i_{1}$ io | $A+i \rightarrow A$ | OVF | 1/1 |
| Increment B | IB | 0001001100 | $B+1 \rightarrow B$ | NZ | 1/1 |
| Decrement B | DB | 0011001111 | $B-1 \rightarrow B$ | NB | 1/1 |
| Decimal Adjust for Addition | DAA | 0010100110 |  |  | 1/1 |
| Decimal Adjust for Subtraction | DAS | 0010101010 |  |  | 1/1 |
| Negate A | NEGA | 0001100000 | $\bar{A}+1 \rightarrow A$ |  | 1/1 |
| Complement B | COMB | 0101000000 | $\bar{B} \rightarrow B$ |  | 1/1 |
| Rotate Right A with Carry | ROTR | 0010100000 |  |  | 1/1 |
| Rotate Left A with Carry | ROTL | 0010100001 |  |  | 1/1 |
| Set Carry | SEC | 0011101111 | $1 \rightarrow \mathrm{CA}$ |  | 1/1 |
| Reset Carry | REC | 0011101100 | $0 \rightarrow C A$ |  | 1/1 |
| Test Carry | TC | 0001101111 |  | CA | 1/1 |
| Add A to Memory | AM | 0000001000 | $M+A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory | AMD d | $\mathrm{Cd}_{9} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $M+A \rightarrow A$ | OVF | 2/2 |
| Add A to Memory with Carry | AMC | 0000011000 | $M+A+C A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory with Carry | AMCD d |  | $M+A+C A \rightarrow A$ | OVF | 2/2 |
| Subtract A from Memory with Carry | SMC | 0010011000 | $\mathbf{M}-\mathbf{A}-\overline{\mathbf{C A}} \rightarrow \mathbf{A}$ | NB | 1/1 |
| Subtract A from Memory with Carry | SMCD d |  | $M-A-\overline{C A} \rightarrow A$ | NB | 2/2 |
| OR A and B | OR | 0101000100 | $\mathbf{A} \cup \mathbf{B} \rightarrow \mathbf{A}$ |  | 1/1 |
| AND Memory with A | ANM | 0010011100 | $A \cap M \rightarrow A$ | NZ | 1/1 |
| AND Memory with A | ANMD d |  | $A \cap M \rightarrow A$ | NZ | 2/2 |
| OR Memory with A | ORM | 0000001100 | $A \cup M \rightarrow A$ | NZ | 1/1 |
| OR Memory with A | ORMD d | $\begin{array}{ll} \mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~g}_{1} \mathrm{~d}_{0} \end{array}$ | $A \cup M \rightarrow A$ | NZ | 2/2 |
| EOR Memory with A | EORM | 0000011100 | $A( \pm M \rightarrow A$ | NZ | 1/1 |
| EOR Memory with A | EORMD d |  | $A+M \rightarrow A$ | NZ | 2/2 |

Table 27. Compare Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Immediate Not Equal to Memory | INEM i | $000010 i_{3} i_{2} i_{1} i_{0}$ | $i \neq M$ | NZ | 1/1 |
| Immediate Not Equal to Memory | INEMD i,d |  | $i \neq M$ | NZ | 2/2 |
| A Not Equal to Memory | ANEM | 0000000100 | $A \neq M$ | NZ | 1/1 |
| A Not Equal to Memory | ANEMD d | $0_{9} \mathrm{dog}_{5} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{3} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $A \neq M$ | NZ | 2/2 |
| B Not Equal to Memory | BNEM | 0001000100 | $B \neq M$ | NZ | 1/1 |
| Y Not Equal to Immediate | YNEI i | $000111 i_{3} i_{2} i_{1} i_{0}$ | $\mathrm{Y}_{\neq 1} \mathrm{i}$ | NZ | 1/1 |
| Immediate Less or Equal to Memory | ILEM i | $000011 i_{3} i_{2} i_{1} i_{0}$ | $i \leqq M$ | NB | 1/1 |
| Immediate Less or Equal to Memory | ILEMD i,d |  | $i \leqq M$ | NB | 2/2 |
| A Less or Equal to Memory | ALEM | 0000010100 | $A \leq M$ | NB | 1/1 |
| A Less or Equal to Memory | ALEMD d |  | $A \leq M$ | NB | 2/2 |
| B Less or Equal to Memory | BLEM | 0011000100 | $B \leqq M$ | NB | 1/1 |
| A Less or Equal to Immediate | ALEI i | $101011 i_{3} i_{2} i_{1} i_{0}$ | $A \leqq i$ | NB | 1/1 |

Table 28. RAM Bit Manipulation Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | $\frac{\text { WORD }}{\text { CYCLE }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Memory Bit | SEM $n$ | $00100001 n^{1} n_{0}$ | $1 \rightarrow M(n)$ |  | 1/1 |
| Set Memory Bit | SEMD n,d |  | $1 \rightarrow M(n)$ |  | 2/2 |
| Reset Memory Bit | REM $n$ | 00100010 nino | $0 \rightarrow M(n)$ |  | 1/1 |
| Reset Memory Bit | REMD n,d |  | $0 \rightarrow M(n)$ |  | 2/2 |
| Test Memory Bit | TM $n$ | $00100011 n_{1} n_{0}$ |  | $M(n)$ | 1/1 |
| Test Memory Bit | TMD n,d | $\begin{array}{\|l\|lllll} \hline 0 & 1 & 1 & 0 & 0 & 0 \end{array} 1_{1} n_{1} n_{0}$ |  | M(n) | 2/2 |

Table 29. ROM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Branch on Status 1 | BR b | $11 \mathrm{~b}_{7} \mathrm{~b}_{6} b_{5} b_{4} b_{3} b_{2} b_{1} b_{0}$ |  | 1 | 1/1 |
| Long Branch on Status 1 | BRL u |  |  | 1 | 2/2 |
| Long Jump Unconditionally | JMPL u | $\begin{array}{llll} 010 & 10 & 1 & 0 \end{array}$ |  |  | 2/2 |
| Subroutine Jump on Status 1 | CAL a | $0111 a_{5} a_{4} a_{3} a_{2} a_{1} a_{0}$ |  | 1 | 1/2 |
| Long Subroutine Jump on Status 1 | CALL u | $g_{9} d_{3} d_{7} d_{6} d_{5} d_{4} d_{3} d_{3} d_{3} d_{2} p_{2} d_{1} p_{1} d_{0}$ |  | 1 | 2/2 |
| Table Branch | TBR p | $001011 p_{3} p_{2} p_{1} p_{0}$ |  |  | 1/1 |
| Return from Subroutine | RTN | 0000010000 |  |  | 1/3 |
| Return from Interrupt | RTNI | 0000010001 | $1 \rightarrow 1 / E$ |  | 1/3 |

Table 30. Input/Output Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Discrete I/O Latch | SED | 0011100100 | $1 \rightarrow \mathrm{D}(\mathrm{Y})$ |  | 1/1 |
| Set Discrete 1/O Latch Direct | SEDD m |  | $1 \rightarrow \mathrm{D}(\mathrm{m})$ |  | 1/1 |
| Reset Discrete 1/O Latch | RED | 0001100100 | $0 \rightarrow D(Y)$ |  | 1/1 |
| Reset Discrete 1/O Latch Direct | REDD m |  | $0 \rightarrow \mathrm{D}(\mathrm{m})$ |  | 1/1 |
| Test Discrete 1/O Latch | TD | 00111100000 |  | D(Y) | 1/1 |
| Test Discrete 1/O Latch Direct | TDD m | $10010100 m_{3} m_{2} m_{1} m_{0}$ |  | D(m) | 1/1 |
| Load A from R-Port Register | LAR m | $100011001 m_{3} m_{2} m_{1} m_{0}$ | $R(\mathrm{~m}) \rightarrow \mathrm{A}$ |  | 1/1 |
| Load B from R-Port Register | LBR m | $10001000 m_{3} m_{2} m_{1} m_{0}$ | $R(m) \rightarrow B$ |  | 1/1 |
| Load R-Port Register from A | LRA m |  | $A \rightarrow R(m)$ |  | 1/1 |
| Load R-Port Register from B | LRB m |  | $B \rightarrow R(m)$ |  | 1/1 |
| Pattern Generation | P p | $\left\lvert\, \begin{array}{lllllll}0 & 1 & 1 & 0 & 1 & 1 & p_{3} p_{2} p_{1} p_{0}\end{array}\right.$ |  |  | 1/2 |

Table 31. Control Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD |
| :--- | :---: | :---: | :---: | :---: | :---: |
| CYCLE |  |  |  |  |  |

Table 32. Op-Code Map

.... 1 word/2 cycle Instruction. 1 word/3 cycle Instruction

RAM Direct Address Instruction (2 word/2 cycle) instruction

PRECAUTION TO USE THE EPROM ON-PACKAGE 4 BIT SINGLE CHIP MICROCOMPUTER
Please pay attention to the followings, since this MCU has special structure with pin socket on the package.
(1) Don't apply high static voltage or surge voltage over MAXIMUM RATINGS to the socket pins as well as the LSI pins.
If not, that may cause permanent damage to the device.
(2) When using this in production like mask ROM type single chip microcomputer, pay attention to the followings to keep the good contact between the EPROM pins and socket pins.
(a) When soldering the LSI on a print circuit board, the recommended condition is

Temperature: lower than $250^{\circ} \mathrm{C}$
Time : within 10 sec .
Over time/temperature may cause the bonding solder of socket pin to melt and the socket pin may drop.
(b) Note that the detergent or coating will not get in the socket during flux washing or board coating after soldering, because that may cause bad effect on socket contact.
(c) Avoid permanent application of this under the condition of vibratory place and system.
(d) The socket, inserted and pulled repeatedly loses its contactability. It is recommended to use new one when applied in production.

Table 33 Difference between the HD614P080S and HMCS404C/HMCS404AC

| Type name <br> Item |  | HD614P080S | HMCS404C |  | HMCS404AC |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Minimum instruction execution time |  | $1.33 \mu \mathrm{~s}$ | $2 \mu \mathrm{~s}$ |  | $1.33 \mu \mathrm{~s}$ |  |
| Power supply voltage |  | 4.5 to 5.5 V | 4 to 6 V |  | 4.5 to 6 V |  |
| ROM |  | - 4,096 words $\times 10$ bits (using standard EPROM 2764) <br> - 8,192 words x 10 bits (using standard EPROM 27128) | 4,096 words $\times 10$ bits Mask ROM |  |  |  |
| RAM |  | 576 digits $\times 4$ bits | 256 digits $\times 4$ bits |  |  |  |
| 1/0 pin circuit | Standard pins | All pins are "without pull-up MOS (NMOS open drain)". | $\begin{aligned} & \text { Each pin selects "without pull-up MOS (NMOS open drain)", } \\ & \text { "with pull-up MOS", or "CMOS". } \end{aligned}$ |  |  |  |
|  | High voltage pins | All pins are "without pull-down MOS (PMOS open drain)" | Each pin selects "without pull-down MOS (PMOS open drain)" or "with pull-down MOS." |  |  |  |
| Clock generator |  | Crystal resonator or ceramic filter resonator | Crystal resonator, ceramic filter resonator, or resistance oscillator |  |  |  |
| Package |  | Shrink type 64-pin EPROM on package (DC-64SP). <br> The base chip pins are compatible with those of the HMCS404C/HMCS404AC. | Shrink type 64-pin dual-in-line plastic package (DP-64S) or 64-pin flat plastic package (FP-64). |  |  |  |
|  | Type | DC-64SP | DP-64S | FP-64 | DP-64S | FP-64 |
|  | Occupied area ( mm ) | $23 \times 57.3$ | $17 \times 58$ | $19.6 \times 25.6$ | $17 \times 58$ | $19.6 \times 25.6$ |
|  | High from stand-off | $\begin{gathered} 7.5 \text { (max.) } \\ \text { EPROM on package } \end{gathered}$ | 5.1 (max) | 2.9 (max) | 5.1 (max.) | 2.9 (max.) |

EVALUATION CHIP FOR 4-BIT SINGLE-CHIP MICROCOMPUTERS

## HD44850E

The HD44850E is an evaluation chip for 4 -bit single-chip microcomputer, HMCS40 series. Its function is equivalent to HMCS45C except that it doesn't contain ROM. Instead, it has the function to address external memory (ROM or RAM). User can handle this evaluation chip by writing program into external program memory as well as the HMCS40 series chip in which program has been written. User program and system can be debugged by connecting this evaluation chip with external program memory in which user program is written to user systems.

The HD44850E provides 12 -bit address outputs ( $\mathrm{A}_{0}$ to $\mathrm{A}_{11}$ terminals) and 10 -bit instruction input pins ( $\mathrm{O}_{1}$ to $\mathrm{O}_{10}$ terminals) for the external program memory. $\phi$ and TSTP pins are required for debugging programs, and H43, CMOS and D/E pins for selecting applicable chips.

- APPLICABLE CHIPS

HMCS42C, 43C, 44C, 45C

## - FUNCTION

- Instruction Characteristics etc.; Same as the HMCS45C
- Address External ROM (2k)
- Address Output; Direct interface with EPROM ( $A_{0}$ to $\left.A_{1}\right)$
- Instruction input; EPROM or CMOS RAM or NMOS RAM 10, to 0, )
Direct interface with TTL
- CMOS/PMOS Selecting Input Pin
- Timer Halt Input
- I/O Enable/Disable Selecting Pin at Halt
- Output Pins except Address Output and Clock Open Drain Output
- Address Output, Clock; CMOS Output
- Input Pins; Inputs with no Pull up MOS

- PIN ARRANGEMENT

(Top View)
- PIN NAME

| $A_{0}$ to $A_{11}$ | : Address Output |
| :---: | :---: |
| $\mathrm{O}_{1}$ to $\mathrm{O}_{10}$ | : Instruction Input |
| ¢ | : Word Timing |
| TSTP | : Timer Stop Input |
| H43 | : HMCS43/45A Selection |
| CMOS | : CMOS/PMOS Selection |
| D/E | I/O Enable/Disable Selection Input in the $\mathrm{H}_{\text {alt }}$ Mode |
| $\mathrm{R}_{00}$ to $\mathrm{R}_{53}$ | : I/O Common Port |
| $\mathbf{R}_{\text {bo }}$ to $\mathrm{R}_{\text {b3 }}$ | : Output Port |
| $\mathrm{D}_{0}$ to $\mathrm{D}_{15}$ | : 1/O Common Port |
| $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ | Oscillator |
| $\mathrm{INT}_{0}$, INT, $^{\text {c }}$ | : Interrupt |
| RESET | : External Reset |
| HLT | : Halt Pin |
| $\mathrm{V}_{\text {cc }}$ | : Power Supply |
| GND | : Ground |

## HD44857E

The HD44857E is an evaluation chip for 4 -bit single-chip microcomputer, HMCS40 series. Its function is equivalent to HMCS47C except that it doesn't contain ROM and RAM. Instead, it has the function to address external memory, program memory (ROM or RAM) and data memory (RAM).

User can handle this evaluation chip by writing program into external program memory as well as the HMCS 40 series chip in which program has been written.

The HD44857E provides address/instruction pins ( $\mathrm{A}_{0} / \mathrm{O}_{1}$ to $A_{9} / \mathrm{O}_{10}, \mathrm{~A}_{10} / \mathrm{A}_{11}$ terminals) for the external program memory, and address/bus pins ( $Y_{1} / S_{11}$ to $Y_{4} / S_{14}, X_{1} / S_{21}$ to $X_{4} / S_{24}$ ), timing signal $\phi_{1}, \phi_{2}$ pins for accessing data RAM.
$\phi$ and TSTP pins are required for debugging programs, and CMOS and D/E pins for selecting applicable chips.

- APPLICABLE CHIPS

HMCS42C, 43C, 44C, 45C, 46C, 47C

## - FUNCTION

- Instruction Characteristics etc.; Same as the HMCS47C
- Address External ROM (max; 4k words)
- Access External Data RAM (max; 256 digits)
- CMOS/PMOS Selecting Input Pin for evaluating PMOS
- Timer Stop Input
- I/O Enable/Disable Selecting Input Pin at Halt
- External ROM/RAM Access Pin; CMOS Pin

All Output Pins except these are Open Drain Output.

- Input Pin; Input with no Pull up MOS
- PIN NAME
(1) $A_{0} / O_{1}$ to $A_{8} / O_{10}$ : Access pins for user program external memory. Divide 1 instruction cycle by two. The first half is the address from $A_{0}$ to $A_{9}$ and the latter nalf is instruction inputs from $\mathrm{O}_{1}$ to $\mathrm{O}_{10}$.
(2) $A_{10} / A_{11}$
(3) $A_{1} \cdot{ }^{\circ}$

Access pins for external user program memory. Divide 1 instruction cycle by two. The first half is $A_{10}$ and the latter half is $A_{1 .}$.
: Unusable. Be "open" always.
(4) $X, / S_{21}$ to $X_{4} / S_{24}$ : Access pins for data RAM. Divide 1 instruction cycle by two. The first half ( X , to $X_{4}$ ) is for selecting RAM file and the latter half $\left(S_{21}\right.$ to $\left.S_{24}\right)$ is bus signal for writing data into RAM.
(5) $Y_{1} / S_{11}$ to $Y_{4} / S_{14}$ : Access pins for data RAM. Divide 1 instruction cycle by two. The first half $(Y$, to $Y_{4}$ ) is for selecting RAM digit and the latter half $\left(\mathbf{S}_{11}\right.$ to $\mathbf{S}_{14}$ ) is bus signal for reading data from RAM to evaluation chip.
(6) $\phi, \phi_{1}, \phi_{2}$
(7) TSTP
: Clock signal
(8) CMOS
: Timer stops with timer stop input or " $H$ " level, and operates with " $L$ " level.
(9) $\mathrm{D} / \mathrm{E}$
(10) $R_{00}$ to $R_{53}$
: CMOS/PMOS selecting pin
: Selecting I/O state at halt
(11) $\mathrm{R}_{80}$ to $\mathrm{R}_{83}$
: $1 / 0$ common pins ( $1 / 0$ pins)
(12) $D_{0}$ to $D_{18}$
: Output pins ( $1 / 0$ pins)
: I/O common pins (I/O pins)
(13) OSC, : Oscillator (input)
(14) $\mathrm{OSC}_{2} \quad$ Oscillator (output)
(15) $\mid \mathbb{N} T_{0}{ }_{0} \mathbb{N} T_{1} \quad$ : Interrupt input pin
(16) RESET : External reset input
(17) HLT : Halt pin
(18) TEST : "H" level always


PIN ARRANGEMENT


## HD44797E

The HD44797E is an evaluation chip for 4-bit single-chip microcomputer LCD-III/IV. The HD44797E has the same logical functions as LCD-III/IV except that its ROM is external. All I/O pins are open drain.

The HD44797E provides 12 -bit address outputs ( $\mathrm{A}_{0}$ to $\mathrm{A}_{11}$ terminals) and 5 -bit instruction input pins ( $\mathrm{O}_{1} / \mathrm{O}_{5}$ to $\mathrm{O}_{6} / \mathrm{O}_{10}$ pins) for the external program memory. $\phi$ and TSTP pins are required for debugging programs, and SELECT pin for selecting applicable chips.

## - APPLICABLE CHIPS

LCD-III, LCD-IV

- FUNCTION
- Instruction Characteristics etc.; Same as LCD-III, LCD-IV
- Address External ROM (4k)
- I/O Pins (D, R, $\mathbb{N} T_{0}, \mathbb{N T}_{1}$ ); Open Drain
- PIN NAME
: Power Supply for LCD
OSC $1 \quad:$ External Clock Input Pin
HLT
$\mathrm{R}_{00}$ to $\mathrm{R}_{\mathbf{0 3}}$
$\mathrm{R}_{10}$ to $\mathrm{R}_{23}$
$\mathbf{R}_{30}$ to $\mathbf{R}_{33}$
$D_{0}$ to $D_{13}$
$\mathrm{D}_{14} / \mathrm{XO}, \mathrm{D}_{15} / \mathrm{XI}$
$\mathrm{INT}_{0,}$ INT ${ }_{1}$
Halt Pin
: Input Port
: I/O Port
: Output Port
I/O Port
$\mathrm{COM}_{1}$ to $\mathrm{COM}_{4}$ : Common Signal Pin
SEG $_{1}$ to SEG $_{32}$ : Segment Signal Pin
$A_{0}$ to $A_{11}$ : Program Memory Access Pin
$\mathrm{O}_{1} / \mathrm{O}_{6}$ to $\mathrm{O}_{5} / \mathrm{O}_{10}$ : Instruction Input Pin
$\phi, \phi_{1}, \phi_{2} \quad$ Clock Signal
TSTP : Timer/Prescaler Stop Signal Pin
SELECT: Applicable Chips Selecting Pin

- PIN ARRANGEMENT

(Note) *: Additional pin for evaluation chip.
(Top View)

NEW DEVICES

## HMCS404AC (HD614048)

The HMCS404AC is a CMOS 4-bit single-chip microcomputer which is a member of the HMCS400 series.

The HMCS404AC is a high speed version of the HMCS404C.
The HMCS404AC has efficient and powerful architecture and its software is very similar to the HMCS40 series.

This microcomputer provides variety of on-chip resources such as ROM, RAM, I/O, two timer/counters and a serial interface to perform in wide users' applications.

The HMCS404AC also has the characteristics of high speed and low power dissipation and which I/O pins are able to drive fluorescent display tube directly.

- HARDWARE FEATURES
- 4-bit Architecture
- 4,096 Words x 10 -bit ROM
- 256 Digits $\times 4$-bit RAM
- 58 I/O Pins, including 26 high voltage I/O pins (40V Max)
- Two Timer/Counters

11 -bit Prescaler
8 -bit Free Running Timer
8 -bit Auto-Reload Timer/Event Counter

- Clock Synchronous 8-bit Serial Interface
- Five Interrupt Sources

External 2
Timer/Counter 2
Serial Interface 1

- Subroutine Stack

Up to 16 levels including interrupts

- High Speed Operation

Minimum Instruction Execution Time - $1.33 \mu \mathrm{~s}$

- Two Low Power Dissipation Modes

Standby - Stops instruction execution while keeping clock oscillation and interrupt functions in operation.
Stop - Stops instruction execution and clock oscillation while retaining RAM data

- On-Chip Oscillator

External Connection of Crystal or Ceramic Filter (externally drivable)

## - SOFTWARE FEATURES

- Instruction Set Similar to and More Powerful than HMCS40 Series; 99 Instructions
- High Programming Efficiency with 10-bit ROM/Word; 79 instructions are single word instructions
- Direct Branch to All ROM Area
- Direct or Indirect Addressing to All RAM Area
- Subroutine Nesting Up to 16 Levels Including Interrupts
- Binary and BCD Arithmetic Operation
- Powerful Logical Arithmetic Operation
- Pattern Generation - Table Look Up Capability -
- Bit Manipulation for Both RAM and I/O


## HMCS 404AC


(DP-64S)
HMCS404AC

(FP-64)

## - VERSATILE PROGRAM DEVELOPMENT SUPPORT TOOLS

- H68SD Series Macro Assembler
- H68SD5-use Emulator (With Real Time Trace Function)
- EPROM On Package Microcomputer

Mask options are fixed as follows:

- I/O pin : Open drain
- Oscillator : Crystal Oscillator or Ceramic Filter Oscillator (externally drivable)
- Divider : Divided-by-8
- PIN ARRANGEMENT (Top View)

- BLOCK DIAGRAM


ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage | $V_{T}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | V | 3 |
|  |  | $\mathrm{V}_{C C}-45$ to $\mathrm{V}_{\text {CC }}+0.3$ | V | 4 |
| Total Allowance of Input Currents | $\Sigma 1_{0}$ | 50 | mA | 5 |
| Total Allowance of Output Currents | $-\Sigma 1_{0}$ | 150 | mA | 6 |
| Maximum Input Current | Io | 15 | mA | 7, 8 |
| Maximum Output Current | $-10$ | 4 | mA | 9,10 |
|  |  | 6 | mA | 9, 11 |
|  |  | 30 | mA | 9,12 |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |  |

(Note 1) Permanent damage may occur if "Absolute Maximum Ratings" are exceeded. Normal operation should be under the conditions of "Electrical Characteristics". If these conditions are exceeded, it may cause the malfunction and affect the reliability of LSI.
(Note 2) All voltages are with respect to GND.
(Note 3) Applied to standard pins.
(Note 4) Applied to high voltage pins.
(Note 5) Total allowance of input current is the total sum of input current which flow in from all I/O pins to GND simultaneously.
(Note 6) Total allowance of output current is the total sum of the output current which flow out from $\mathrm{V}_{\mathrm{CC}}$ to atl I/O pins simultaneously.
(Note 7) Maximum input current is the maximum amount of input current from each I/O pin to GND.
(Note 8) Applied to $D_{0} \sim D_{3}$ and R3~R8.
(Note 9) Maximum output current is the maximum amount of output current from $V_{C C}$ to each I/O pin.
(Note 10) Applied to $\mathrm{D}_{0} \sim \mathrm{D}_{3}$ and R3 $\sim \mathrm{R} 8$.
(Note 11) Applied to RO~R2.
(Note 12) Applied to $D_{4} \sim D_{15}$

- ELECTRICAL CHARACTERISTICS


| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" <br> Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\frac{\mathrm{RESET}, \overline{\mathrm{SCK}}}{\mathrm{INT}_{0}, \mathrm{INT}_{1}}$ |  | $0.7 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
|  |  | SI |  | $0.7 \mathrm{~V}_{\mathrm{Cc}}$ | - | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
|  |  | $\mathrm{OSC}_{1}$ |  | $\mathrm{V}_{\text {cc }}-0.5$ | - | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| Input "Low" <br> Voltage | $V_{\text {IL }}$ | $\frac{\text { RESET, } \overline{\text { SCK }}}{\mathrm{INT}_{0}},$ |  | -0.3 | - | $0.22 V_{c c}$ | V |  |
|  |  | SI |  | -0.3 | - | $0.22 V_{\text {cc }}$ | V |  |
|  |  | $\mathrm{OSC}_{1}$ |  | -0.3 | - | 0.5 | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | SCK, SO | $-\mathrm{I}_{\mathrm{OH}}=1.0 \mathrm{~mA}$ | $\mathrm{V}_{\text {cc- }} 1.0$ | - | - | V |  |
|  |  |  | $-\mathrm{I}_{\mathrm{OH}}=0.01 \mathrm{~mA}$ | $\mathrm{V}_{\text {cc }}-0.3$ | - | - | V |  |
| $\begin{aligned} & \text { Output "Low" } \\ & \text { Voltage } \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\overline{\text { SCK, SO }}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |  |
| Input/Output Leakage Current | $H_{\text {IL }}$ | $\begin{aligned} & \text { RESET, SCK, } \\ & \overline{\text { INT}}_{0}, \overline{N T T}_{1} \\ & \text { SI, SO, OSC }_{1} \end{aligned}$ | $\mathrm{V}_{\text {in }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 1 |
| Current Dissipation in Active Mode | ICC | $\mathrm{V}_{\text {cc }}$ | $\begin{aligned} & V_{c \mathrm{cc}}=5 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{osc}}=6 \mathrm{MHz} \end{aligned}$ | - | - | 3.0 | mA | 2, 6 |
| Current <br> Dissipation in Standby Mode | $\mathrm{I}_{\text {SBY1 }}$ | $\mathrm{V}_{\text {cc }}$ | Maximum Logic Operation $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{osc}}=6 \mathrm{MHz} \end{aligned}$ | - | - | 1.8 | mA | 3,6 |
|  | $\mathrm{I}_{\mathrm{SBY} 2}$ | $\mathrm{V}_{C C}$ | Minimum Logic Operation $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{osc}}=6 \mathrm{MHz} \end{aligned}$ | - | - | 1.35 | mA | 4, 6 |
| Current <br> Dissipation in <br> Stop Mode | $\mathrm{I}_{\text {stop }}$ | $V_{C C}$ | $\begin{aligned} & V_{\text {in }}(\overline{\mathrm{TEST}})=\mathrm{V}_{\text {CC }}-0.3 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & V_{\text {in }}(\text { RESET })=0 \mathrm{~V} \text { to } 0.3 \mathrm{~V} \end{aligned}$ | - | - | 10 | $\mu \mathrm{A}$ | 5 |
| Stop Mode Retain Voltage | $V_{\text {stop }}$ | $\mathrm{V}_{\text {cc }}$ |  | 2 | - | - | V |  |

(Note 1) Pull-up MOS current and output buffer current are excluded.
(Note 2) The MCU is in the reset state. The input/output current does not flow. Test Conditions: MCU state; - Reset state in Operation Mode Pin state; - RESET, TEST ... $V_{\text {cc }}$ voltage - $D_{0} \sim D_{3}, R 3 \sim R 9 \cdots V_{C C}$ voltage

- $D_{4} \sim D_{15}, R 0 \sim R 2, R_{A 0}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 3) The timer/counter operate with the fastest clock and input/output current does not flow. Test Conditions: MCU state; - Standby Mode
- Input/Output; Reset state
- TIMER-A; $\div 2$ prescaler divide ratio
- TIMER-B; $\div 2$ prescaler divide ratio
- SERIAL Interface ; Stop

Pin state; - RESET ... GND voltage

- TEST $\cdots V_{\text {cc }}$ voltage
- $D_{0} \sim D_{3}, R 3 \sim R 9 \cdots V_{C C}$ voltage
$\bullet_{D_{4}} \sim D_{15}, R 0 \sim R 2, R_{A 0}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 4) The timer/counter operate with the slowest clock and input/output current does not flow. Test Conditions: MCU state: • Standby Mode
- Input/Output; Reset state
- TIMER-A: $\div 2048$ prescaler divide ratio
- TIMER-B; $\div 2048$ prescaler divide ratio
- SERIAL Interface ; Stop

Pin state; - RESET... GND voitage

- TEST ... V $\mathrm{VCC}_{\text {voltage }}$
- $D_{0} \sim D_{3}, R 3 \sim R 9 \ldots V_{c c}$ voltage
$-D_{4} \sim D_{15}, R 0 \sim R 2, R_{A 0} . R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 5) Pull-down MOS current is excluded.
(Note 6) When $\mathrm{f}_{\mathrm{osc}}=x[\mathrm{MHz}]$, the Current Dissipation in Operation mode and Standby mode are estimated as follows:

$$
\text { max. value }\left(\mathrm{f}_{\mathrm{osc}}=x[\mathrm{MHz}]\right)=\frac{x}{6} \times \max \text {. value }\left(\mathrm{f}_{\mathrm{osc}}=6[\mathrm{MHz}]\right)
$$

- INPUT/OUTPUT CHARACTERISTICS FOR STANDARD PIN
$\left(\mathrm{V}_{\mathrm{Cc}}=4.5 \mathrm{~V}\right.$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathrm{Cc}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}, \mathrm{Ta}=-\mathbf{2 0}$ to $+75^{\circ} \mathrm{C}$, if not specified. $)$

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" Voltage | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 5, R 9 \end{aligned}$ |  | $0.7 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & \text { R3 } \sim \text { R5, R9 } \end{aligned}$ |  | -0.3 | - | 0.22 V cc | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & \text { R3 } \sim \text { R8 } \end{aligned}$ | $-\mathrm{I}_{\mathrm{OH}}=1.0 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | - | V | 1 |
|  |  | $\begin{aligned} & \mathrm{D}_{0} \sim \mathrm{D}_{3}, \\ & \mathrm{R} 3 \sim \mathrm{R} 8 \\ & \hline \end{aligned}$ | $-\mathrm{l}_{\mathrm{OH}}=0.01 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{cc}}-0.3$ | - | - | V | 1 |
| Output "Low" Voltage | $V_{\text {OL }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 8 \end{aligned}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |  |
| Input/Output Leakage Current | IILI | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 9 \end{aligned}$ | $V_{\text {in }}=O V$ to $V_{c c}$ | - | - | 1 | $\mu \mathrm{A}$ | 2 |
| Pull-Up MOS Current | $-I_{p}$ | $\begin{aligned} & \hline D_{0} \sim D_{3}, \\ & R 3 \sim R 9 \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{c c}=5 \mathrm{~V} \\ & V_{\text {in }}=0 \mathrm{~V} \end{aligned}$ | 30 | 60 | 120 | $\mu \mathrm{A}$ | 3 |

(Note 1) Applied to I/O pins with "CMOS" Output selected by mask option.
(Note 2) Pull-up MOS current and output buffer current are excluded.
(Note 3) Applied to I/O pins "with Pull-up MOS" selected by mask option.

- INPUT/OUTPUT CHARACTERISTICS FOR HIGH VOLTAGE PIN
$\left(\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}\right.$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathrm{cc}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}, \mathrm{Ta}=\mathbf{- 2 0}$ to $+\mathbf{7 5} 5^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" Voltage | $\mathrm{V}_{1+}$ | $\begin{aligned} & D_{4} \sim D_{15}, R_{1} \\ & R 2, R_{A 0}, R_{A 1} \end{aligned}$ |  | $0.7 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & D_{4} \sim D_{15}, R_{1} \\ & R 2, R_{A 0}, R_{A 1} \end{aligned}$ |  | $V_{c c}-40$ | - | 0.22 V cc | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ | $-\mathrm{I}_{\mathrm{OH}}=15 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | $\mathrm{V}_{\text {cc }}-3.0$ | - | - | V |  |
|  |  |  | $-\mathrm{IOH}^{2}=9 \mathrm{~mA}$ | $V_{C C}-2.0$ | - | - | V |  |
|  |  | $\mathrm{R} 0 \sim \mathrm{R} 2$ | $-\mathrm{IOH}=3 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | $\mathrm{V}_{\text {cc }}-3.0$ | - | - | V |  |
|  |  |  | $-\mathrm{IOH}=1.8 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{cc}}-2.0$ | - | - | V |  |
| Output "Low" Voltage | $V_{\text {OL }}$ | $\begin{aligned} & D_{4} \sim D_{15} \\ & R O \sim R 2 \end{aligned}$ | $\mathrm{V}_{\text {diap }}=\mathrm{V}_{\mathrm{cc}}-40 \mathrm{~V}$ | - | - | $V_{c c}-37$ | V | 1 |
|  |  | $\begin{aligned} & D_{4} \sim D_{15} \\ & R O \sim R 2 \end{aligned}$ | $150 \mathrm{k} \Omega$ to $\mathrm{V}_{\mathrm{cc}}-40 \mathrm{~V}$ | - | - | $V_{c c}-37$ | V | 2 |
| Input/Output <br> Leakage <br> Current | $\mid I I I L$ | $\begin{aligned} & D_{4} \sim D_{15} \\ & R 0 \sim R_{2} \\ & R_{A 0}, R_{A 1} \\ & \hline \end{aligned}$ | $V_{\text {in }}=V_{c c}-40 \mathrm{~V}$ to $V_{c c}$ | - | - | 20 | $\mu \mathrm{A}$ | 3 |
| Pull Down MOS Current | $\mathrm{I}_{\mathrm{d}}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & R_{0} \sim \mathrm{R}_{2} \\ & \mathrm{R}_{\mathrm{AO}}, \mathrm{R}_{\mathrm{A} 1} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\text {dipp }}=\mathrm{V}_{\mathrm{cc}}-35 \mathrm{~V} \\ & \mathrm{~V}_{\text {in }}=\mathrm{V}_{\mathrm{cc}} \end{aligned}$ | 125 | 250 | 500 | $\mu \mathrm{A}$ | 4 |

(Note 1) Applied to I/O pins "with Pull-down MOS" selected by mask option.
(Note 2) Applied to I/O pins "without Pull-down MOS (PMOS Open Drain)" selected by mask option.
(Note 3) Pull-down MOS current and output buffer current are excluded.
(Note 4) Applied to I/O pins "with Pull-down MOS" selected by mask option.

AC CHARACTERISTICS ( $\mathrm{V}_{\mathbf{C C}}=4.5 \mathrm{~V}$ to $\mathbf{6 V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathbf{C C}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathbf{C C}}, \mathbf{T a}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified. )

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Oscillation Frequency | $f_{\text {osc }}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ |  | 0.4 | 6 | 6.2 | MHz |  |
| Instruction Cycle Time | $\mathrm{t}_{\mathrm{cyc}}$ |  |  | 1.29 | 1.33 | 20 | $\mu \mathrm{s}$ |  |
| Oscillator Stabilization Time | $t_{\text {RC }}$ | OSC ${ }_{1}$, OSC $_{2}$ |  | - | - | 20 | ms | 1 |
| External Clock "High" Level Width | ${ }^{\text {t CPH }}$ | $\mathrm{OSC}_{1}$ |  | 70 | - | - | ns | 2 |
| External Clock "Low" Level Width | ${ }^{\text {t }} \mathrm{CPL}$ | $\mathrm{OSC}_{1}$ |  | 70 | - | - | ns | 2 |
| External Clock Rise Time | ${ }^{\text {t }} \mathrm{CPr}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
| External Clock Fall Time | ${ }^{\text {t }}$ CPf | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
| $\overline{\text { INTo }}$ 'High'' Level Width | ${ }^{\text {tor }}$ | INT0 |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 3 |
| $\overline{\text { INTo " }}$ Low" Level Width | $\mathrm{t}_{10 \mathrm{~L}}$ | $\overline{\text { INTo }}$ |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 3 |
| $\overline{\text { INT }}{ }^{\text {' }}$ 'High" Level Width | $\mathrm{t}_{11 \mathrm{H}}$ | $\overline{\mathrm{NT}} \mathrm{T}_{1}$ |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 3 |
| $\overline{\mathrm{NT}}{ }^{\text {" }}$ "Low" Level Width | $\mathrm{t}_{11 \mathrm{~L}}$ | $\overline{\mathrm{INT}_{1}}$ |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 3 |
| RESET "High" Level Width | $\mathrm{t}_{\text {RSTH }}$ | RESET |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 4 |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ | all pins | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V_{\text {in }}=0 \mathrm{~V} \end{aligned}$ | - | - | 15 | pF |  |
| RESET Fall Time | $\mathrm{t}_{\text {RST }}$ |  |  | - | - | 20 | ms | 4 |

(Note 1) Oscillator stabilization time is the time until the oscillator stabilizes after $\mathrm{V}_{\mathrm{CC}}$ reaches 4.5 V at "Power-on", or after RESET input level goes "High" by resetting to quit the stop mode by MCU reset. The circuits used to measure the value are described below. When using crystal or ceramic filter oscillator, please ask a crystal oscillator maker's or ceramic filter maker's advice because oscillator stabilization time depends on the circuit constant and stray capacity.

Crystal oscillator


Ceramic filter oscillator


Ceramic filter: CSA6.00MG (Murata)

$$
\begin{aligned}
& \text { Rf }: 1 \mathrm{M} \Omega \pm 2 \% \\
& \mathrm{C}_{1}: 30 \mathrm{pF} \pm 20 \% \\
& \mathrm{C}_{2}: 30 \mathrm{pF} \pm 20 \%
\end{aligned}
$$

(Note 2)
Rf : $1 \mathrm{M} \Omega \pm \mathbf{2 \%}$
$C_{1}: 20 \mathrm{pF} \pm 20 \%$
$\mathrm{C}_{2}$ : 20pF $\pm 20 \%$
(Note 3)

(Note 4)


RESET


- SERIAL INTERFACE TIMING CHARACTERISTICS
( $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{disp}}=\mathrm{V}_{\mathrm{Cc}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)
- At Transfer Clock Output

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | ${ }^{\text {t Scyc }}$ | SCK | (Note 2) | 1 | - | - | $\mathrm{t}_{\text {cyc }}$ | 1,2 |
| Transfer Clock "High" Level Width | ${ }^{\text {tscku }}$ | $\overline{\text { SCK }}$ | (Note 2) | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1, 2 |
| Transfer Clock "Low" Level Width | ${ }_{\text {tsckl }}$ | SCK | (Note 2) | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1, 2 |
| Transfer Clock Rise Time | $\mathrm{t}_{\text {sckr }}$ | SCK | (Note 2) | - | - | 100 | ns | 1,2 |
| Transfer Clock Fall Time | ${ }_{\text {tsckf }}$ | SCK | (Note 2) | - | - | 100 | ns | 1,2 |
| Serial Output Data Delay Time | toso | SO | (Note 2) | - | - | 250 | ns | 1,2 |
| Serial Input Data Set-up Time | ${ }_{\text {tss }}$ | SI |  | 300 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HSI}}$ | SI |  | 150 | - | - | ns | 1 |

- At Transfer Clock Input

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | $\mathrm{t}_{\text {Scyc }}$ | SCK |  | 1 | - | - | $\mathrm{t}_{\text {cyc }}$ | 1 |
| Transfer Clock "High" Level Width | ${ }^{\text {tsCKH }}$ | $\overline{\text { SCK }}$ |  | 0.5 | - | - | ${ }^{\text {tsayc }}$ | 1 |
| Transfer Clock "Low" Level Width | $\mathrm{t}_{\text {SCKL }}$ | $\overline{\text { SCK }}$ |  | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1 |
| Transfer Clock Rise Time | $\mathrm{tsckr}^{\text {r }}$ | $\overline{\text { SCK }}$ |  | - | - | 100 | ns | 1 |
| Transfer Clock Fall Time | $\mathrm{t}_{\text {SCK }}{ }^{\text {f }}$ | $\overline{\text { SCK }}$ |  | - | - | 100 | ns | 1 |
| Serial Output Data Delay Time | toso | SO | (Note 2) | - | - | 250 | ns | 1, 2 |
| Serial Input Data Set-up Time | $\mathrm{t}_{\text {ss }}$ | SI |  | 300 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HS} 1}$ | SI |  | 150 | - | - | ns | 1 |

(Note 1) Timing Diagram of Serial Interface


* $V_{C C}-2.0 \mathrm{~V}$ and 0.8 V are the threshold voltage for transfer clock output. $0.7 \mathrm{~V}_{\mathrm{CC}}$ and $0.22 \mathrm{~V}_{\mathrm{CC}}$ are the threshold voltage for transfer clock input.
(Note 2) Timing Load Circuit

- CHARACTERISTICS CURVE (REFERENCE DATA)

$I_{\text {cc }}$ vs. $V_{\text {CC }}$ Characteristics
(Crystal, Ceramic Filter Oscillator)

$-I_{p}$ (Pull-up MOS Current) vs.
$V_{C C}$ Characteristics


$-\mathrm{IOH}_{\mathrm{OH}} \mathrm{min}$. vs. ( $\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{OH}}$ ) Characteristics ( $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ Pins)


## - DESCRIPTION OF PIN FUNCTIONS

Input and output signals of MCU are described below.

- GND, $\mathbf{V}_{\mathbf{C c}}, \mathrm{V}_{\mathrm{disp}}$

These are Power Supply Pins. Connect GND pin to Earth (0V) and apply $\mathrm{V}_{\mathrm{CC}}$ power supply voltage to $\mathrm{V}_{\mathrm{CC}}$ pin. $\mathrm{V}_{\mathrm{disp}}$ is an power supply for high voltage Input/Output pins with maximum voltage of $\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$. $\mathrm{V}_{\text {disp }}$ pin can be also used as $\mathrm{R}_{\mathrm{A} 1}$ pin by mask option. For details, see "INPUT/OUTPUT".

## - TEST

TEST pin is not for user's application. TEST must be connected to $\mathrm{V}_{\mathrm{CC}}$.

- RESET

RESET pin is used to reset MCU. For details, see "RESET".

- OSC $_{1}$, OSC $_{2}$

These are Input pins to the internal oscillator circuit. They can be connected to crystal, or ceramic filter resonator. For details, see "INTERNAL OSCILLATOR CIRCUIT."

- D-port ( $D_{0}$ to $D_{15}$ )

D-port is a 1-bit Input/Output common port. $\mathrm{D}_{0}$ to $\mathrm{D}_{3}$ are standard type, $D_{4}$ to $D_{1 s}$ are for high voltage. Each pin has the mask option to select its circuit type. For details, See "INPUT/ OUTPUT".

## - R-port (R0 to RA)

R-port is a 4-bit Input/Output port. (only RA is 2-bit construction.) R0 and R6 to R8 are output ports, R9 to RA are input ports, and R1 to R5 are Input/Output common ports. R0 to R2 and RA are the high voltage ports, R3 to R9 are the standard ports. Each pin has the mask option to select its circuit type. $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ are also available as

$\overline{\mathrm{INT}}, \overline{\mathrm{INT}}{ }_{1}, \overline{\text { SCK }}$, SI and SO respectively. For details, see "INPUT/OUTPUT".

- $\overline{\mathbf{N T}_{0}}, \overline{\mathbf{I N T}_{1}}$

These are the input pins to interrupt MCU operation externally. $\overline{\mathrm{INT}_{1}}$ can be used as an external event input pin for TIMER-B. $\overline{\mathrm{INT}}{ }_{0}$ and $\overline{\mathrm{INT}}{ }_{1}$ are also available as $\mathrm{R}_{32}$, and $\mathrm{R}_{33}$ respectively. For details, See "INTERRUPT".

## - $\overline{\mathbf{S C K}}, \mathbf{S I}, \mathbf{S O}$

These are Transfer clock I/O pin ( $\overline{\mathrm{SCK}}$ ), serial data input pin (SI) and serial data output pin (SO) used for serial interface. $\overline{\mathrm{SCK}}, \mathrm{SI}$, and SO are also available as $\mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ respectively. For details, see "SERIAL INTERFACE".

## - ROM MEMORY MAP

MCU includes 4096 words $\times 10$ bits ROM. ROM memory map is illustrated in Fig. 1 and described in the following paragraph.

## - Vector Address Area ..... \$0000 to \$000F

When MCU is reset or an interrupt is serviced, the program is executed from the vector address. Program the JMPL instructions branching to the starting addresses of reset routine or of interrupt routines.

## - Zero-Page Subroutine Area ..... \$0000 to \$003F

CAL instruction allows to branch to the subroutines in $\$ 0000$ to $\$ 003 \mathrm{~F}$.

## - Pattern Area ..... \$0000 to \$0FFF

$\mathbf{P}$ instruction allows referring to the ROM data in $\$ 0000$ to $\$ 0 \mathrm{FFF}$ as a pattern.

- Program Area ...... \$0000 to \$0FFF


Fig. 1 ROM Memory Map

- RAM MEMORY MAP

MCU includes 256 digits $\times 4$ bits RAM as the data area and stack area. In addition to these areas, interrupt control bits
and special registers are also mapped on the RAM memory space. RAM memory map is illustrated in Fig. 2 and described in the following paragraph.


Fig. 2 RAM Memory Map

|  | bit 3 | bit 2 | bit 1 | bit 0 | \$000 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\frac{\operatorname{IMO}}{\left(\mathrm{IM} \text { of } \overline{\mathrm{INT}} \mathrm{~T}_{0}\right)}$ | IFO (IF of $\overline{\mathrm{INT}_{0}}$ ) | RSP (Reset SP Bit) | I/E (Interrupt Enable Flag) |  |
| 1 | IMTA <br> (IM of TIMER-A) | $\begin{gathered} \text { IFTA } \\ \text { (IF of TIMER-A) } \end{gathered}$ | $\begin{gathered} \mathrm{IM} 1 \\ \left(\mathrm{IM} \text { of } \overline{\left.\mathrm{INT} T_{1}\right)}\right. \end{gathered}$ | $\begin{gathered} \text { IF1 } \\ \left(\mathrm{IF} \text { of } \overline{\mathrm{INT} \mathrm{~T}_{1}}\right) \end{gathered}$ | \$001 |
| 2 | Not Used | Not Used | IMTB <br> (IM of TIMER-B) | $\begin{gathered} \text { IFTB } \\ \text { (IF of TIMER-B) } \end{gathered}$ | \$002 |
| 3 | Not Used | Not Used | IMS (IM of SERIAL) | $\begin{gathered} \text { IFS } \\ \text { (IF of SERIAL) } \end{gathered}$ | \$003 |


| IF | : |
| :--- | :--- |
| Interrupt Request Flag |  |
| IM | Interrupt Mask |
| I/E | Interrupt Enable Flag |
| SP | : |
| Stack Pointer |  |

LP : Interrupt Enable Flag
(Note) Each bit in Interrupt Control Bits Area is set by SEM/SEMD instruction, is reset by REM/REMD instruction and is tested by TM/TMD instruction. It is not affected by other instructions. Furthermore, Interrupt Request Flag is not affected by SEM/SEMD instruction. The content of Status becomes invarid when "Not Used" bit is tested.

Fig. 3 Configuration of Interrupt Control Bit Area

- Interrupt Control Bit Area ..... \$000 to \$003

This area is used for interrupt controls, and is illustrated in Fig.3. It is accessable only by RAM bit manipulation instruction. However, the interrupt request flag cannot be set by software.

## - Special Register Area ..... \$004 to \$00B

Special Register is a mode or a data register for the external interrupt, the serial interface, and the timer/counter. These registers are classified into 3 types: Write-only, Read-only, and Read/Write as shown in Fig. 2. These registers cannot be accessed by RAM bit manipulation instruction.

- Data Area ..... \$020 to \$0DF

16 digits of $\$ 020$ to $\$ 02 \mathrm{~F}$ are called memory register (MR) and accessable by LAMR and XMRA instructions.

- Stack Area .... \$3C0 to \$3FF

Stack Area is used for LIFO stacks with the contents of the program counter (PC), status (ST) and carry (CA) when processing subroutine call and interrupt. As 1 level requires 4 digits, this stack area is nested to 16 level-stack max. The data pushed in the stack and LIFO stack state are provided in Fig. 4. The program counter is restored by RTN and RTNI instructions. Status and Carry are restored only by RTNI instruction. The area, not used for stacking, is available as a data area.


Fig. 4 Configuration of Memory Register, Stack Area and Stack Position

## - REGISTER AND FLAG

The MCU has nine registers and two flags for the CPU operations. They are illustrated in Fig. 5 and described in the following paragraphs.

- Accumulator (A), B Register (B)

Accumulator and B Register are 4-bit registers used to hold the results of Arithmetic Logic Unit (ALU), and to transfer data to/from memories, $\mathrm{I} / \mathrm{O}$ and other registers.

- W Register (W), X Register (X), Y Register (Y)

W Register is 2-bit, and $X$ and $Y$ Register are 4-bit registers used for indirect addressing of RAM. Y register is also used for D -port addressing.

- SPX Register (SPX), SPY Register (SPY)

SPX and SPY Register are 4-bit registers used to assist $X$ and Y Register respectively.

## - Carry (CA)

Carry (CA) stores the overflow of ALU generated by the arithmetic operation. It is also affected by SEC, REC, ROTL and ROTR instructions.

During interrupt servicing, Carry is pushed onto the stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Status (ST)

Status (ST) holds the ALU overflow, ALU non-zero and the results of bit test instruction for the arithmetic or compare instruction. It is used for a branch condition of BR, BRL, CAL or CALL instructions. The value of the Status remains unchanged until the next arithmetic, compare or bit test instruction is executed. Status becomes " 1 " after the BR, BRL, CAL or CALL instruction has been executed (irrespective of its execution/ skip). During the interrupt servicing, Status is pushed onto the


Fig. 5 Register and Flags
stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Program Counter (PC)

Program Counter is a 14 -bit binary counter for ROM addressing.

## - Stack Pointer (SP)

Stack Pointer is used to point the address of the next stacking area up to 16 levels.

The Stack Pointer is initialized to locate $\$ 3$ FF on the RAM address, and is decremented by 4 as data pushed into the stack, and incremented by 4 as data restored back from the stack.

## - INTERRUPT

The MCU can be interrupted by five different sources: the external signals ( $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}$ ), timer/counter (TIMER-A, TIMER-B), and serial interface (SERIAL). In each sources, the Interrupt Request Flag, Interrupt Mask and interrupt vector address will be used to control and maintain the interrupt request. The Interrupt Enable Flag is also used to control the total interrupt operations.

## - Interrupt Control Bit and Interrupt Service

The interrupt control bit is mapped on $\$ 000$ to $\$ 003$ of the RAM address and accessable by RAM bit manipulation instruction. (The Interrupt Request Flag (IF) cannot be set by software.) The Interrupt Enable Flag (I/E) and Interrupt Request Flag (IF) are set to " 0 ", and the Interrupt Mask (IM) is set to " 1 " at the initialization by MCU reset.

Fig. 6 shows the interrupt block diagram. Table 1 shows the interrupt priority and vector addresses, and Table 2 shows the conditions that the interrupt service is executed by any one of the five interrupt sources.

The interrupt request is generated when the Interrupt Request Flag is set to " 1 " and the Interrupt Mask is " 0 ". If the Interrupt Enable Flag is " 1 ", then the interrupt will be activated and vector addresses will be generated from the priority PLA corresponding to the five interrupt sources.

Fig. 7 shows the interrupt services sequence, and Fig. 8 shows the interrupt flowchart. If the interrupt is requested, the instruction finishes its execution in the first cycle. The Interrupt Enable Flag is reset in the second cycle. In the second and third cycles, the Carry, Status and Program Counter are pushed onto the stack. In the third cycle, the instruction is executed again after jumping to the vector address.

In each vector address, program JMPL instruction to branch to a starting address of the interrupt routine. The Interrupt Request Flag which caused the interrupt service has to be reset by software in the interrupt routine.


Fig. 6 Interrupt Circuit Block Diagram

Table 1. Vector Addresses and Interrupt Priority

| Reset $\cdot$ Interrupt | Priority | Vector addresses |
| :---: | :---: | :---: |
| RESET | - | $\$ 0000$ |
| $\overline{\text { NTN }_{0}}$ | 1 | $\$ 0002$ |
| $\overline{\overline{I N T}_{1}}$ | 2 | $\$ 0004$ |
| TIMER-A | 3 | $\$ 0006$ |
| TIMER-B | 4 | $\$ 0008$ |
| SERIAL | 5 | $\$ 000 \mathrm{C}$ |

Table 2. Conditions of Interrupt Service

| InterruptInterrupt <br> control bits <br> source | $\overline{\text { INT }_{0}}$ | $\overline{\text { INT }}_{1}$ | TIMER-A | TIMER-B | SERIAL |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/E | 1 | 1 | 1 | 1 | 1 |
| IFO. $\overline{\mathrm{MO}}$ | 1 | 0 | 0 | 0 | 0 |
| IF1 $\cdot \overline{\mathrm{IM1}}$ | $*$ | 1 | 0 | 0 | 0 |
| IFTA $\cdot \overline{\mathrm{IMTA}}$ | $*$ | $*$ | 1 | 0 | 0 |
| IFTB $\overline{\mathrm{IMTB}}$ | $*$ | $*$ | $*$ | 1 | 0 |
| IFS $\cdot \overline{\mathrm{IMS}}$ | $*$ | $*$ | $*$ | $*$ | 1 |



- Interrupt Enable Flag (I/E: \$000,0)

The Interrupt Enable Flag controls enable/disable of all interrupt requests as shown in Table 3. The Interrupt Enable Flag is reset by the interrupt servicing and set by RTNI instruction.

Table 3. Interrupt Enable Flag

| Interrupt Enable Flag | Interrupt Enable/Disable |
| :---: | :---: |
| 0 | Disable |
| 1 | Enable |

- External Interrupt ( $\overline{\mathbf{N T}}, \overline{\mathbf{I N T}_{1}}$ )

To use external interrupt, select $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}}, \mathrm{R}_{33} / \overline{\mathrm{INT}}{ }_{1}$ port for $\overline{\mathrm{INT}} \mathrm{T}_{0}, \overline{\mathrm{INT}_{1}}$ mode by setting the Port Mode Register (PMR: \$004).

The External Interrupt Request Flags (IF0, IF1) are set at the falling edge of $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}}_{1}$ inputs.
$\overline{\mathrm{INT}}_{1}$ input can be used as a clock signal input of TIMER-B. Then, TIMER-B counts up at each falling edge of input. When using $\overline{\mathrm{INT}}{ }_{1}$ as TIMER-B external event, an External Interrupt Mask (IM 1) has to be set so that the interrupt request by $\overline{\overline{I N T}_{1}}$ will not be accepted.

- External Interrupt Request Flag (IFO: \$000,2, IF1: \$001,0)

The External Interrupt Request Flags (IF0, IF1) are set at the falling edges of $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}$ inputs respectively.

- External Interrupt Mask (IM0: \$000,3, IM1: \$001,1)

The External Interrupt Mask is used to mask the external interrupt requests.

Table 4. External Interrupt Request Flag

| External Interrupt Request Flags | Interrupt Requests |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 5. External Interrupt Mask

| External Interrupt Masks | Interrupt Requests |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (masks) |

- Port Mode Register (PMR: \$004)

The Port Mode Register is a 4-bit write-only register which controls the $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}}$ pin, $\mathrm{R}_{33} / \overline{\mathrm{INT}_{1}}$ pin, $\mathrm{R}_{41} / \mathrm{SI}$ pin and $\mathrm{R}_{42}$ / SO pin as shown in Table 6. The Port Mode Register will be initialized to $\$ 0$ by MCU reset, so that all these pins are set to a port mode.

Table 6. Port Mode Register

| PMR | $\mathrm{R}_{33} / /_{\mathrm{NT}}^{1} 10$ pin |
| :---: | :---: |
| bit 3 |  |
| 0 | Used as $\mathrm{R}_{33}$ port input/output pin |
| 1 | Used as $\mathrm{INT}_{1}$ input pin |
| PMR | $\mathrm{R}_{32} / \overline{\mathrm{NT}_{0}} \mathrm{pin}$ |
| bit 2 |  |
| 0 | Used as $\mathrm{R}_{32}$ port input/output pin |
| 1 | Used as $\overline{\mathrm{INT}_{0}}$ input pin |
| PMR | $\mathrm{R}_{41} / \mathrm{St}$ pin |
| bit 1 |  |
| 0 | Used as $\mathrm{R}_{41}$ port input/output pin |
| 1 | Used as SI input pin |
| PMR | $\mathrm{R}_{42} / \mathrm{SO} \mathrm{pin}$ |
| bit 0 |  |
| 0 | Used as $\mathrm{R}_{42}$ port input/output pin |
| 1 | Used as SO output pin |



Fig. 8 Interrupt Servicing Flowchart

## - SERIAL INTERFACE

The serial interface is used to transmit/receive 8 -bit data serially. This consists of the Serial Data Register, the Serial Mode Register, the Octal Counter and the multiplexer, as illustrated in Fig. 9. Pin $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the transfer clock signal are controlled by the Serial Mode Register. Contents of the Serial Data Register can be written into or read out by the software. The data in the Serial Data Register can be shifted synchronous-
ly with the transfer clock signal.
The serial interface operation is initiated with STS instruction. The Octal Counter is reset to $\$ 0$ by STS instruction. It starts to count at the falling edge of the transfer clock ( $\overline{\mathrm{SCK}}$ ) signal and increments by one at the rising edge of the SCK. When the Octal Counter is reset to $\$ 0$ after eight transfer clock signals, or discontinued transmit/receive operation by resetting the Octal Counter, the SERIAL Interrupt Request Flag will be set.


Fig. 9 Serial Interface Block Diagram

- Serial Mode Register (SMR: \$005)

The Serial Mode Register is a 4 -bit write-only register. This register controls the $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the prescaler divide ratio as the transfer clock source as shown in Table 7.

The Write Signal to the Serial Mode Register controls the operating state of serial interface.

The Write Signal to the Serial Mode Register stops the transfer clock applied to the Serial Data Register and the Octal Counter. And it also reset the Octal Counter to $\$ 0$ simultaneously.

When the Serial Interface is in the "Transfer State", the Write Signal to the Serial Mode Register causes to quit the data transfer and to set the SERIAL Interrupt Request Flag.

Contents of the Serial Mode Register will be changed on the second instruction cycle after writing into the Serial Mode Register. Therefore, it will be necessary to execute the STS instruction after the data in the Serial Mode Register has been changed completely. The Serial Mode Register will be reset to $\$ 0$ by MCU reset.

- Serial Data Register (SRL: \$006, SRU: \$007)

The Serial Data Register is an 8 -bit read/write register. It consists of a low-order digit (SRL:\$006) and a high-order digit (SRU: \$007).

The data in the Serial Data Register will be output from the LSB side at SO pin synchronously with the falling edge of the transfer clock signal. At the same time, external data will be input from the LSB side at SI pin to the Serial Data Register synchronously with the rising edge of the transfer clock. Fig. 10 shows the I/O timing chart for the transfer clock signal and the data.

The writing into/reading from the Serial Data Register during its shifting causes the validity of the data.

Therefore complete data transmit/receive before writing into/reading from the serial data register.

Table 7. Serial Mode Register



Fig. 10 Serial Interface I/O Timing Chart

- SERIAL Intarrupt Request Flag (IFS: \$003, 0)

The SERIAL Interrupt Request Flag will be set after the eight transfer clock signals or transmit/receive discontinued operation by resetting the Octal Counter.

- SERIAL Interrupt Mask (IMS: \$003, 1)

The SERIAL Interrupt Mask masks the interrupt request.
Table 8. SERIAL Interrupt Request Flag

| SERIAL Interrupt Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 9. SERIAL Interrupt Mask

| SERIAL Interrupt Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (mask) |

## - Selection of the Operation Mode

Table 10 shows the operation mode of the serial interface. Select a combination of the value in the Port Mode Register and the Serial Mode Register according to Table 10.

Initialize the serial interface by the Write Signal to the Serial Mode Register, when the Operation Mode is changed.

## - Operating State of Serial Interface

The serial interface has 3 operating states as shown in Fig. 11.
The serial interface gets into "STS waiting state" by 2 ways: one way is to change the operation mode by changing the data
in the Port Mode Register, the other is to write data into the Serial Mode Register. In this state, the serial interface does not operate although the transfer clock is applied. If STS instruction is executed, the serial interface changes its state to "SCK waiting state".

In the "SCK waiting state", the falling edge of first transfer clock affects the serial interface to get into "transfer state", while the Octal Counter counts-up and the Serial Data Register shifts simultaneously. As an exception, if the clock continuous output mode is selected, the serial interface stays in "SCK waiting state" while the transfer clock outputs continuously.

The Octal Counter becomes " 000 " again by 8 transfer clocks or execution of STS instruction, so that the serial interface gets back into the "SCK waiting state", and SERIAL Interrupt Request Flag is set simultaneously.

When the internal transfer clock is selected, the transfer clock output are triggered by the execution of STS instruction, and it stops after 8 clocks.

## - Example of Transfer Clock Error Detection

The serial interface functions abnormally when the transfer clock was disturbed by external noises. In this case, the transfer
clock error can be detected in the procedure shown in Fig. 12.
If more than 9 transfer clocks are applied by the external noises in the "SCK waiting state", the state of the serial interface shifts as the following sequence: first "transfer state" (while 1 to 7 transfer clocks), second "SCK waiting state" (at 8th transfer clock) and third "transfer state" again. Then reset the SERIAL Interrupt Request Flag, and make "STS waiting state" by writing to the Serial Mode Register. SERIAL Interrupt Request Flag is set again in this procedure, and it shows that the transfer clock was invalid and that the transmit/receive data were also invalid.

Table 10. Serial Interface Operation Mode

| SMR | PMR |  | Serial Interface Operating Mode |
| :---: | :---: | :---: | :--- |
| Bit 3 | Bit 1 | Bit 0 |  |
| 1 | 0 | 0 | Clock Continuous Output Mode |
| 1 | 0 | 1 | Transmit Mode |
| 1 | 1 | 0 | Receive Mode |
| 1 | 1 | 1 | Transmit/Receive Mode |




Fig. 12 Example of Transfer Clock Error Detection

## - TIMER

The MCU contains a prescaler and two timer/counters (TIMER-A, TIMER-B), Fig. 13 shows the block diagram. The prescaler is an 11 -bit binary counter. TIMER-A is an 8 -bit free-running timer. TIMER-B is an 8-bit auto-reload timer/ event counter.

## - Prescaler

The input to the prescaler is a system clock signal. The prescaler is initialized to $\$ 000$ by MCU reset, and the prescaler starts to count up the system clock signal as soon as RESET input goes to logic " 0 ". The prescaler keeps counting up except MCU reset and stop mode. The prescaler provides clock signals to TIMER-A, TIMER-B and serial interface. The prescaler devide ratio of the clock signals are selected according to the content of the mode registers such as - Timer Mode Register A (TMA), Timer Mode Register B (TMB), Serial Mode Register (SMR).


Fig. 13 Timer/Counter Block Diagram

- TIMER-A Operation

After TIMER-A is initialized to $\$ 00$ by MCU reset, it counts up at every clock input signal. When the next clock signal is applied after TIMER-A is counted up to \$FF, TIMER-A is set to $\$ 00$ again, and generating overflow output. This leads to setting TIMER-A Interrupt Request Flag (IFTA: \$001, 2) to " 1 ". Therefore, this timer can function as an interval timer periodically generating overflow output at every 256th clock signal input.

The clock input signals to TIMER-A are selected by the Timer Mode Register A (TMA: \$008).

## - TIMER-B Operation

Timer Mode Register B (TMB: \$009) is used to select the auto-reload function and the prescaler divide ratio of TIMER-B as the input clock source. When the external event input is used as an input clock signal to TIMER-B, select the $\mathrm{R}_{33} / \mathrm{INT}_{1}$ as $\overline{\mathrm{INT}} 1_{1}$ and set the External Interrupt Mask (IM1) to " 1 " to prevent the external interrupt request from occurring.

TIMER-B is initialized according to the value written into the Timer Load Register by software. TIMER-B counts up at every clock input signal. When the next clock signal is applied to TIMER-B after TIMER-B is set to \$FF, TIMER-B will be initialized again and generate overflow output. In this case if the auto-reload function is selected. TIMER-B is initialized according to the value of the Timer Load Register. Else if the autoreload function is not selected, TIMER-B goes to \$00. TIMERB Interrupt Request Flag (IFTB: $\$ 002,0$ ) will be set at this overflow output.

- Timer Mode Register A (TMA: \$008)

The Timer Mode Register A is a 3-bit write-only register. The TMA controls the prescaler divide ratio of TIMER-A clock input, as shown in Table 11.

The Timer Mode Register A is initialized to $\$ 0$ by MCU reset.

- Timer Mode Register B (TMB: \$009)

The Timer Mode Register B is a 4 -bit write-only register. The Timer Mode Register B controls the selection for the autoreload function of TIMER-B and the prescaler divide ratio, and the source of the clock input signal, as shown in Table 12.

The Timer Mode Register B is initialized to $\$ 0$ by MCU reset.
The operation mode of TIMER-B is changed at the second instruction cycle after writing into the Timer Mode Register B.

Therefore, it is necessary to program the write instruction to TLRU after the content of TMB is changed.

Table 11. Timer Mode Register A

| TMA |  |  | Prescaler Divide Ratio |
| :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 |  |
| 0 | 0 | 0 | $\div 2048$ |
| 0 | 0 | 1 | $\div 1024$ |
| 0 | 1 | 0 | $\div 512$ |
| 0 | 1 | 1 | $\div 128$ |
| 1 | 0 | 0 | $\div 32$ |
| 1 | 0 | 1 | $\div 8$ |
| 1 | 1 | 0 | $\div 4$ |
| 1 | 1 | 1 | $\div 2$ |

Table 12. Timer Mode Register B

| TMB |  | Auto-reload Function |  |
| :---: | :---: | :---: | :---: |
| Bit 3 |  | No |  |
| 0 |  | Yes |  |
| 1 |  | Prescaler Divide Ratio, <br> Clock Input Source |  |
| TMB |  |  | $\div 2048$ |
|  |  |  |  |
| Bit 2 | Bit 1 | Bit 0 | $\div 512$ |
| 0 | 0 | 0 | $\div 128$ |
| 0 | 0 | 1 | $\div 32$ |
| 0 | 1 | 0 | $\div$ |
| 0 | 1 | 1 | $\div$ |
| 1 | 0 | 0 | $\div$ |
| 1 | 0 | 1 | $\div$ |
| 1 | 1 | 0 | 2 |
| 1 | 1 | 1 | INT $_{1}$ (External Event Input) |

- TIMER-B ( $\left.\begin{array}{l}\text { TCBL: } \$ 00 A, \text { TCBU: } \$ 00 B \\ \text { TLRL: } \$ 00 A, ~ T L R U: ~ \$ 00 B\end{array}\right)$

TIMER-B consists of an 8 -bit write-only Timer Load Register, and an 8-bit read-only Timer/Event Counter. Each of them has a low-order digit (TCBL: \$00A, TLRL: \$00A) and a highorder digit (TCBU: \$00B, TLRU: \$00B).

The Timer/Event Counter can be initialized by writing data into the Timer Load Register. In this case, write the low-order digit first, and then the high-order digit. The Timer/Event Counter is initialized at the time when the high-order digit is written. The Timer Load Register will be initialized to $\$ 00$ by the MCU reset.

The counter value of TIMER-B can be obtained by reading
the Timer/Event Counter. In this case, read the high-order digit first, and then the low-order digit. The count value of low-order digit is latched at the time when the high-order digit is read.

- TIMER-A Interrupt Request Flag (IFTA: \$001, 2)

The TIMER-A Interrupt Request Flag is set by the overflow output of TIMER-A.

TIMER-A Interrupt Mask (IMTA: \$001, 3)
TIMER-A Interrupt Mask prevents an interrupt request generated by TIMER-A Interrupt Request Flag.

Table 13. TIMER-A Interrupt Request Flag

| TIMER-A Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 14. TIMER-A Interrupt Mask

| TIMER-A Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

- TIMER-B Interrupt Request Flag (IFTB: $\mathbf{\$ 0 0 2 , 0}$ )

The TIMER-B Interrupt Request Flag is set by the overflow output of TIMER-B.

- TIMER-B Interrupt Mask (IMTB: \$002, 1)

TIMER-B Interrupt Mask prevents an interrupt request generated by TIMER-B Interrupt Request Flag.

PMR:\$ 004


SMR:\$005


TMA:\$008


TMB:\$009


Fig. 14 Mode Register Configuration and Function

Table 15. TIMER-B Interrupt Request Flag

| TIMER-B Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 16. TIMER-B Interrupt Mask

| TIMER-B Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

## - INPUT/OUTPUT

The MCU provides 58 Input/Output pins, and they are consist of 32 standard pins and 26 high voltage pins. Each standard pin may have one of three mask options: (A) "Without pullup MOS (NMOS open drain)", (B) "With pull-up MOS", or (C) "CMOS". And also each high voltage pin may have one of two mask options: (D) "Without pull-down MOS (PMOS
open drain)", or (E) "With pull-down MOS". As pull-down MOS is connected to internal $V_{\text {disp }}$ line, select $R_{A 1} / V_{\text {disp }}$ pin as $\mathrm{V}_{\text {disp }}$ with mask option when at least one high voltage pin is selected as "With pull-down MOS" option.

When any Input/Output common pin is used as input pin, it is necessary to select the mask option and output data as shown in Table 18.

- Output Circuit Operation of Standard Pins with 'With pull-- up MOS" Option

Fig. 15 shows the circuit used in the standard pins with "with pull-up MOS"option.

By execution of the output instruction, the write pulse will be generated, and be applied to the addressed port. This pulse will turn "ON" the PMOS (B) to make the transient time shorten to obtain "High level", if the output data is changed from " 0 " to " 1 ". In this case, the "write pulse" allows the PMOS (B) to turn "ON" as long as $1 / 8$ instruction cycle. While "write pulse" is " 0 ", pull-up MOS (C) may retain the output in high level.

The $\overline{\text { HLT }}$ signal becomes " 0 " in stop mode, so that MOS (A) (B) (C) turn "OFF".


Write pulse

Fig. 15 Output Circuit Operation of Standard Pins with "with Pull-up MOS" Option

Table 17 I/O Pin Circuit Type


|  |  | Without pull-up MOS (NMOS open drain) or CMOS ( A or C ) | With pull-up MOS (B) | Applied pins |
| :---: | :---: | :---: | :---: | :---: |
|  | I/O common pins |  |  | $\overline{\text { SCK }}$ |
|  | Output pins |  |  | SO |
|  | Input pins |  |  | $\overline{\mathrm{NT}}{ }^{2}$, $\mathrm{INT}_{1}$, SI |

(Note) In the stop mode, $\overline{\mathrm{HLT}}$ signal is " 0 ", HLT signal is " 1 " and $\mathrm{I} / \mathrm{O}$ pins are in high impedance state.

Table 18 Data Input from Input/Output Common Pins

| I/O pin circuit type |  | Possibility <br> of Input | Available pin condition <br> for input |
| :--- | :--- | :---: | :---: |
| Standard <br> pins | CMOS | No | - |
|  | Without pull-up <br> MOS <br> (NMOS open drain) | Yes | "1" |
|  | With pull-up MOS | Yes | "1" |
| High <br> voltage <br> pins | Without pull-down <br> MOS <br> (PMOS open drain) | Yes | "0" |
|  | With pull-down <br> MOS | Yes | "0" |

## D-port

D-port is 1 -bit I/O port, and it has 16 Input/Output common pins. It can be set/reset by the SED/RED and SEDD/REDD instructions, and can be tested by the TD and TDD instructions. Table 17 shows the classification of standard pins, high voltage pins and the Input/Output pins circuit types.

## - R-port

R-port is 4 -bit I/O port. It provides 20 input/output common pins, 16 output-only pins, and 6 input-only pins. Data input is processed using the LAR and LBR instructions and data output is processed using the LRA and LRB instructions. The MCU will not be affected by writing into the input-only and/or non-existing ports, invalid data will be read by reading from the
output-only and/or non-existing ports.
The $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ pins are also used as the $\overline{\mathrm{INT}}{ }_{0}$, $\overline{\mathrm{INT}_{1}}, \overline{\mathrm{SCK}}, \mathrm{SI}$ and SO pins respectively. Table 17 shows the classification of standard pins, high voltage pins and Input/ Output pins circuit types.

## - RESET

The MCU is reset by setting RESET pin to " 1 ". At power ON or recovering from stop mode, apply RESET input more than $t_{R C}$ to obtain the necessary time for oscillator stabilization. In other cases, the MCU reset requires at least two instructions cycle time of RESET input.

Table 19 shows initialized items by MCU reset and each status after reset.

Table 19 Initial Value by MCU Reset

| Items |  |  | Initial value by MCU reset | Contents |
| :---: | :---: | :---: | :---: | :---: |
| Program counter (PC) |  |  | \$0000 | Execute program from the top of ROM address. |
| Status (ST) |  |  | "1" | Enable to branch with conditional branch instructions. |
| Stack pointer (SP) |  |  | \$3FF | Stack level is 0 . |
| I/O pin output register | Standard pin | (A) Without pullup MOS | "1" | Enable to input. |
|  |  | (B) With pull-up MOS | "1" | Enable to input |
|  |  | (C) CMOS | "1" | - |
|  | High voltage pin | (D) Without pulldown MOS | "0" | Enable to input. |
|  |  | (E) With pulldown MOS | "0" | Enable to input. |
| Interrupt flag | Interrupt Enable Flag (1/E) |  | "0" | Inhibit all interrupts. |
|  | Interrupt Request Flag (IF) |  | "0" | No interrupt request. |
|  | Interrupt Mask (IM) |  | "1" | Mask interrupt request. |
| Mode register | Port Mode Register (PMR) |  | "0000" | See Item "Port Mode Register". |
|  | Serial Mode Register (SMR) |  | "0000" | See Item "Serial Mode Register". |
|  | Timer Mode Register A (TMA) |  | "000" | See Item "Timer Mode Register A". |
|  | Timer Mode Register B (TMB) |  | "0000" | See Item "Timer Mode Register B". |
| Timer/Counter, Serial interface | Prescaler |  | \$000 | - |
|  | Timer/Counter A (TCA) |  | \$00 | - |
|  | Timer/Event Counter B (TCB) |  | \$00 | - |
|  | Timer Load Register (TLR) |  | \$00 | - |
|  | Octal Counter |  | "000" | - |

(Note) MCU reset affects to the rest of registers as follows:

| Item |  | After recovering from STOP mode by MCU reset | After MCU reset except for the left condition |
| :---: | :---: | :---: | :---: |
| Carry | (CA) | The contents of the items before MCU reset are not retained. <br> It is necessary to intialize them by software again. | The contents of the items before MCU reset are not retained. <br> It is necessary to initialize them by software again. |
| Accumulator | (A) |  |  |
| B Register | (B) |  |  |
| W Register | (W) |  |  |
| X/SPX Registers | (X/SPX) |  |  |
| Y/SPY Registers | (Y/SPY) |  |  |
| Serial Data Register | (SR) | Same as above | Same as above |
| RAM |  | The contents of RAM before MCU reset (just before STOP instruction) are retained. | Same as above |

- INTERNAL OSCILLATOR CIRCUIT

Fig. 16 gives internal oscillator circuit. The oscillator type can be selected from a crystal oscillator or a ceramic filter
oscillator without mask option. In any cases, external clock operation is available.


Fig. 16 Internal Oscillator Circuit

- Oscillator Circuit

Table 20 Examples of Oscillator Circuit

|  | Circuit configuration | Remarks |
| :---: | :---: | :---: |
| External clock operation | Oscillator |  |
| Ceramic filter oscillator |  | Ceramic filter CSA6.00MG (Murata) $\begin{aligned} & \text { Rf: } 1 \mathrm{M} \Omega \pm 2 \% \\ & \mathrm{C}_{1}: 30 \mathrm{pF} \pm 20 \% \\ & \mathrm{C}_{2}: 30 \mathrm{pF} \pm 20 \% \end{aligned}$ <br> - Wiring between these pins and elements should be as short as possible, and never cross the other wirings. (Refer to Fig. 17) |
| Crystal oscillator | AT cut parallel resonance crystal | $\begin{aligned} & R f: 1 \mathrm{M} \Omega \pm 2 \% \\ & C_{1}: 10 \sim 22 p F \pm 20 \% \\ & C_{2}: 10 \sim 22 p F \pm 20 \% \end{aligned}$ <br> Crystal: ATcut parallel resonance crystal <br> $C_{0}$ : 7pF max. $\begin{aligned} & \mathrm{R}_{\mathrm{s}}: 100 \Omega \text { max. } \\ & \mathrm{f} \quad: 2.0 \sim 6.2 \mathrm{MHz} \end{aligned}$ <br> - Wiring between these pins should be as short as possible, and never cross the other wirings. (Refer to Fig. 17) |

[^11]

## - LOW POWER DISSIPATION MODE

The MCU provides two low power dissipation modes, that is, a Standby mode and a Stop mode. Table 21 shows the function of the low power dissipation mode, and Fig. 18 shows the diagram of the mode transition.

Fig. 17 Recommendable Layout of Crystal and Ceramic Filter
Table 21 Low Power Dissipation Mode Function

| Low Power Dissipation Mode | Instruction | Condition |  |  |  |  |  |  | Recovering method |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Oscillator circuit | Instruction execution | Register, Flag | Interrupt function | RAM | Input/ Output pin | Timer/ Counter, Serial Interface |  |
| Standby mode | SBY instruction | Active | Stop | Retained | Active | Retained | Retained ${ }^{3}$ | Active | RESET input, Interrupt request |
| Stop mode | STOP instruction | Stop | Stop | RESET ${ }^{\text {+ }}$ | Stop | Retained | High ${ }^{2!}$ impedance | Stop | RESET Input |

*1) As the MCU recovers from STOP mode by RESET input, the contents of the flags and registers are initialized according to Table 19.
*2) A high voltage pin with a pull-down MOS option is pulled down to the $V_{\text {disp }}$ power supply by the pull-down MOS. As the MOS is ON, a pulldown MOS current flows when a voltage difference between the pin and the $V_{\text {disp }}$ voltage exists. This is the additional current to the current dissipation in Stop Mode (1 stop).
*3) As a $1 / O$ circuit is active, a $1 / O$ current possibly flows according the state of $1 / O$ pin. This is the additional current to the current dissipation in Standby Mode ('SBY1, ISBY2).


Fig. 18 MCU Operation Mode Transition

## - Standby Mode

The SBY instruction puts the MCU into the Standby mode. In the Standby mode, the oscillator circuit is active and timer/
counter and serial interface continue working. On the other hand, the CPU stops since the clock related to the instruction execution stops. Registers, RAM and Input/Output pins retain the state they had just before going into the Standby mode.

The Standby mode is canceled by the MCU reset or interrupt request. When canceled by the interrupt request, the MCU becomes an active mode and executes the instruction next to the SBY instruction. At this time, if the Interrupt Enable Flag is " 1 ", the interrupt is executed. If the Interrupt Enable Flag is " 0 ", the interrupt request is held on and the normal instruction execution continues.

Fig. 19 shows the flowchart of the Standby Mode.

## - Stop Mode

The STOP instruction brings the MCU into the Stop mode. In this mode the oscillator circuit and every function of the MCU stop.

The Stop mode is canceled by the MCU reset. At this time, as shown in Fig. 20, apply the RESET input for more than $t_{\text {RC }}$ to get enough oscillator stabilization time. (Refer to the "AC CHARACTERISTICS".) After the Stop mode is canceled, RAM retains the state it had just before going into the Stop mode. The other hand, Accumulator, B Register, W Register, X/SPX Registers, Y/SPY Registers, Carry and Serial Data Register don't retain the contents.


Fig. 19 MCU Operating Flowchart


Fig. 20 Timing Chart of Recovering from Stop Mode

- RAM ADDRESSING MODE

As shown in Fig. 21, the MCU provides three RAM addressing modes; Register Indirect Addressing, Direct Addressing and Memory Register Addressing.

- Register Indirect Addressing

The combined 10 -bit contents of W Register, X Register and Y Register is used as the RAM address in this mode.

- Direct Addressing

The direct addressing instruction consists of two words and the second word ( 10 bits) following Op-code (the first word) is used as the RAM address.

- Memory Register Addressing

The Memory Register Addressing can access 16 digits (Memory Register: MR) from $\$ 020$ to $\$ 02 \mathrm{~F}$ by using the LAMR and XMRA instruction.

RAM Address

(a) Register Indirect Addressing

(b) Direct Addressing


Fig. 21 RAM Addressing Mode

## - ROM ADDRESSING MODE AND P INSTRUCTION

The MCU has four kinds of ROM addressing modes as shown in Fig. 22.

## - Direct Addressing Mode

The program can branch to any addresses in the ROM memory space by using JMPL, BRL or CALL instruction. These instruction replace 14 -bit program counter ( $\mathrm{PC}_{13}$ to $\mathrm{PC}_{0}$ ) with 14 -bit immediate data.

## - Current Page Addressing Mode

ROM memory space is divided into 256 words in each page starting from $\$ 0000$. The program branches to the address in the same page using BR instruction. This instruction replace the lower-order eight bits of program counter ( $\mathrm{PC}_{7}$ to $\mathrm{PCo}_{0}$ ) with 8 -bit immediate data. The branch destination by BR
instruction on the boundary between pages is in the next page. Refer to Fig. 24.

## - Zero Page Addressing Mode

The program branches to the zero page subroutine area, which is located on the address from $\$ 0000$ to $\$ 003 \mathrm{~F}$, using CAL instruction. When CAL instruction is executed, 6 -bit immediate data is placed in low-order six bits of program counter ( $\mathrm{PC}_{5}$ to $\mathrm{PC}_{0}$ ) and "0's" are placed in high-order eight bits ( $\mathrm{PC}_{13}$ to $\mathrm{PC}_{6}$ ).

## - Table Data Addressing

The program branches to the address determined by the contents of the 4 -bit immediate data, accumulator and B register, using TBR instruction.
(JMPL)
(BRL)
(CALL)

(a) Direct Addressing

(b) Current Page Addressing

(c) Zero Page Addressing

(d) Table Data Addressing

Fig. 22 ROM Addressing Mode

(a) Address Designation

(b) Pattern Output

Fig. 23 P Instruction

- P Instruction

The $\mathbf{P}$ instruction refers ROM data addressed by Table Data Addressing. ROM data addressed also determine its destination. When bit 8 in referred ROM data is " 1 ", 8 bits of referred


Fig. 24 The Branch Destination by BR Instruction on the Boundary between Pages

ROM data are written into the accumulator and B Register. When bit 9 is " 1 ", 8 bits of referred ROM data are written into the R1 and R2 port output register. When both bit 8 and 9 are " 1 ", ROM data are written into the accumulator and B Register and also to the R1 and R2 port output register at a same time.

The P instruction has no effect on the program counter.

- INSTRUCTION SET

The HMCS400 series provide 99 instructions. These instructions are classified into 10 groups as follows;
(1) Immediate Instruction
(2) Register-to-Register Instruction
(3) RAM Address Instruction
(4) RAM Register Instruction
(5) Arithmetic Instruction
(6) Compare Instruction
(7) RAM Bit Manipulation Instruction
(8) ROM Address Instruction
(9) Input/Output Instruction
(10) Control Instruction

Table 22. Immediate Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | StATUS | $\begin{aligned} & \text { WORD } \\ & \text { CYCLE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Immediate | LAI i | $100011 \mathrm{i}_{3} \mathrm{i}_{2} \mathrm{i}_{1} \mathrm{i}_{0}$ | $\longrightarrow$ - |  | 1/1 |
| Load B from Immediate | LBI i | $100000 i_{3} \mathrm{i}_{2} \mathrm{i}_{1} \mathrm{io}$ | $\longmapsto B$ |  | 1/1 |
| Load Memory from Immediate | LMID i,d | $011010 i_{3} \mathrm{i}_{2}$ io $\mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $\longmapsto \mathrm{M}$ |  | 2/2 |
| Load Memory from Immediate, Increment $Y$ | LMIIY i | $101001 i_{3} i_{2} \mathrm{i}$, io | $\underset{i \rightarrow M, Y+1 \rightarrow Y}{ }$ | NZ | 1/1 |

Table 23. Register-to-Register Instruction


Table 24. RAM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CYCLE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load W from Immediate | LWI ; | $00111100 i_{1} i_{0}$ | $\longmapsto W$ |  | 1,1 |
| Load $X$ from Immediate | LXI i | $100010 i_{3} i_{2} i_{1} i_{0}$ | $\mathfrak{i} \longrightarrow X$ |  | 1/1 |
| Load $Y$ from Immediate | LYI i | $100001 i_{3} i_{2} i_{1} i_{0}$ | $i \longrightarrow Y$ |  | 1/1 |
| Load $X$ from $A$ | LXA | 0011101000 | $A \longrightarrow X$ |  | 1/1 |
| Load $Y$ from $A$ | LYA | 0011011000 | $A \longrightarrow Y$ |  | 1/1 |
| Increment $Y$ | IY | 0001011100 | $Y+1 \rightarrow Y$ | NZ | 1/1 |
| Decrement $Y$ | DY | 0011011111 | $Y-1 \rightarrow Y$ | NB | 1/1 |
| Add A to Y | AYY | 0001010100 | $Y+A \rightarrow Y$ | OVF | 1/1 |
| Subtract $A$ from $Y$ | SYY | 0011010100 | $Y-A \rightarrow Y$ | NB | 1/1 |
| Exchange $X$ and SPX | XSPX | 0000000001 | $X \leftrightarrow S P X$ |  | 1/1 |
| Exchange $Y$ and SPY | XSPY | 0000000010 | Y↔SPY |  | 1/1 |
| Exchange $X$ and SPX,Y and SPY | XSPXY | 0000000011 | $\mathbf{X} \leftrightarrow$ SPX, Y $\rightarrow$ SPY |  | 1/1 |

Table 25. RAM Register Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | $\begin{aligned} & \text { WORD } \\ & \text { CYCLE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Memory | LAM (XY) | 00100100 yx |  |  | 1/1 |
| Load A from Memory | LAMD d | 0110010000 $\mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $\mathrm{M} \rightarrow \mathrm{A}$ |  | 2/2 |
| Load B from Memory | LBM (XY) | 00010000 yx | $\mathrm{M} \rightarrow \mathrm{B},\binom{\mathrm{X} \times \mathrm{SPX}}{\mathrm{Y} \sim \mathrm{SPY}}$ |  | 1/1 |
| Load Memory from A | LMA (XY) | 00100101 yx | $\mathrm{A} \rightarrow \mathrm{M},\left(\begin{array}{l}\binom{\mathrm{X} \rightarrow \text { SPX }}{\mathrm{Y} \rightarrow \text { SPY }}\end{array}\right.$ |  | 1/1 |
| Load Memory from A | LMAD d |  | $A \rightarrow M$ |  | 2/2 |
| Load Memory from A, Increment Y | LMAIY(X) | $000101000 x$ | $A \rightarrow M, Y+1 \rightarrow Y(X-S P X)$ | NZ | 1/1 |
| Load Memory from A, Decrement Y | LMADY(X) | $001101000 x$ | $A \rightarrow M, Y-1 \rightarrow Y(X \cdot S P X)$ | NB | 1/1 |
| Exchange Memory and $\mathbf{A}$ | XMA(XY) | 00100000 yx | $M \mapsto A,\binom{X \rightarrow S P X}{Y}$ |  | 1/1 |
| Exchange Memory and A | XMAD d |  | $\mathbf{M} \leftrightarrow A$ |  | 2/2 |
| Exchange Memory and B | XMB(XY) | 00110000 yx | $M \leftrightarrow B,\binom{\mathrm{X} \leftrightarrow \mathrm{S}$ SPX }{$\mathrm{Y} \rightarrow \mathrm{SPY}}$ |  | 1/1 |

Note) ( $X Y$ ) and $(X)$ have the meaning as follows:
(1) The instructions with ( $X Y$ ) have 4 mnemonics and 4 object codes for each. (example of LAM ( $X Y$ ) is given below.)

| MNEMONIC | $y$ | $x$ | FUNCTION |
| :--- | :---: | :---: | :---: |
| LAM | 0 | 0 |  |
| LAMX | 0 | 1 | $X \leftrightarrow S P X$ |
| LAMY | 1 | 0 | $Y \leftrightarrow S P Y$ |
| LAMXY | 1 | 1 | $X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |

(2) The instructions with $(x)$ have 2 mnemonics and 2 object codes for each. (example of LMAIY $(X)$ is given below.)

| MNEMONIC | $x$ | FUNCTION |
| :---: | :---: | :---: |
| LMAIY | 0 |  |
| LMAIYX | 1 | $x \leftrightarrow$ SPX |

Table 26. Arithmetic Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> Cycle |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Add Immediate to A | Al i | $101000 i_{3} i_{2} i_{1} i_{0}$ | $A+i \rightarrow A$ | OVF | 1/1 |
| Increment B | IB | 0001001100 | $B+1 \rightarrow B$ | NZ | 1/1 |
| Decrement B | DB | 0011001111 | $B-1 \rightarrow B$ | NB | 1/1 |
| Decimal Adjust for Addition | DAA | 0010100110 |  |  | 1/1 |
| Decimal Adjust for Subtraction | DAS | 0010101010 |  |  | 1/1 |
| Negate A | NEGA | 0001100000 | $\overline{\mathrm{A}}+1 \rightarrow \mathrm{~A}$ |  | 1/1 |
| Complement B | COMB | 0101000000 | $\bar{B} \rightarrow B$ |  | 1/1 |
| Rotate Right A with Carry | ROTR | 0010100000 |  |  | 1/1 |
| Rotate Left A with Carry | ROTL | 0010100001 |  |  | 1/1 |
| Set Carry | SEC | 0011101111 | $1 \rightarrow C A$ |  | 1/1 |
| Reset Carry | REC | 0011101100 | $0 \rightarrow C A$ |  | 1/1 |
| Test Carry | TC | 0001101111 |  | CA | 1/1 |
| Add A to Memory | AM | 0000001000 | $M+A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory | AMD d | $\mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $\mathbf{M}+\mathrm{A} \rightarrow \mathrm{A}$ | OVF | 2/2 |
| Add A to Memory with Carry | AMC | 0000011000 | $M+A+C A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory with Carry | AMCD d |  | $M+A+C A \rightarrow A$ | OVF | 2/2 |
| Subtract A from Memory with Carry | SMC | 0010011000 | $M-A-\overline{C A} \rightarrow A$ | NB | 1/1 |
| Subtract A from Memory with Carry | SMCD d |  | $M-A-\overline{C A} \rightarrow A$ | NB | 2/2 |
| OR A and B | OR | 0101000100 | $A \cup B \rightarrow A$ |  | 1/1 |
| AND Memory with A | ANM | 0010011100 | $A \cap M \rightarrow A$ | NZ | 1/1 |
| AND Memory with A | ANMD d |  | $A \cap M \rightarrow A$ | NZ | 2/2 |
| OR Memory with A | ORM | 0000001100 | $A \cup M \rightarrow A$ | NZ | 1/1 |
| OR Memory with A | ORMD d |  | $A \cup M \rightarrow A$ | NZ | 2/2 |
| EOR Memory with A | EORM | 0000011100 | $A \oplus M \rightarrow A$ | NZ | 1/1 |
| EOR Memory with A | EORMD d | $\begin{array}{llll} 0100011 & 000 \\ \mathrm{~d}_{9} \mathrm{~d}_{3} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0} \\ \hline \end{array}$ | $\mathbf{A} \oplus \mathbf{M} \rightarrow \mathrm{A}$ | NZ | 2/2 |

Table 27. Compare Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> tycle |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Immediate Not Equal to Memory | INEM i | $000010 i_{3} i_{2} i_{1} i_{0}$ | $i \neq M$ | NZ | 1/1 |
| Immediate Not Equal to Memory | INEMD i,d |  | $i \neq M$ | NZ | 2/2 |
| A Not Equal to Memory | ANEM | 0000000100 | $A \neq M$ | NZ | 1/1 |
| A Not Equal to Memory | ANEMD d |  | $A \neq M$ | NZ | 2/2 |
| B Not Equal to Memory | BNEM | 0001000100 | $B \neq M$ | NZ | 1/1 |
| Y Not Equal to Immediate | YNEI i | $000111 i_{3} i_{2} i_{1} i_{0}$ | $Y \neq 1$ | NZ | 1/1 |
| Immediate Less or Equal to Memory | ILEM i | $000011 i_{3} i_{2} i_{1} i_{0}$ | $i \leq M$ | NB | 1/1 |
| Immediate Less or Equal to Memory | ILEMD i,d | $010011 i_{3} i_{2} i_{1} i_{0}$ $\mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $i \leqq M$ | NB | 2/2 |
| A Less or Equal to Memory | ALEM | 0000010100 | $A \leqq M$ | NB | 1/1 |
| A Less or Equal to Memory | ALEMD d |  | $A \leqq M$ | NB | 2/2 |
| B Less or Equal to Memory | BLEM | 0011000100 | $B \leq M$ | NB | 1/1 |
| A Less or Equal to Immediate | ALEI i | $101011 i_{3} i_{2} i_{1} i_{0}$ | $\mathrm{A} \leqq \mathrm{i}$ | NB | 1/1 |

Table 28. RAM Bit Manipulation Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Memory Bit | SEM $n$ | $00100001 n_{1} n_{0}$ | $1 \rightarrow \mathrm{M}(\mathrm{n})$ |  | 1/1 |
| Set Memory Bit | SEMD n,d |  | $1 \rightarrow M(n)$ |  | 2/2 |
| Reset Memory Bit | REM n | $00100010 n_{1} n_{0}$ | $0 \rightarrow M(n)$ |  | 1/1 |
| Reset Memory Bit | REMD n,d |  | $0 \rightarrow M(n)$ |  | 2/2 |
| Test Memory Bit | TM $n$ | 00100011 nino |  | $M(n)$ | 1/1 |
| Test Memory Bit | TMD n,d | $01100011 n_{1} n_{0}$ $\mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ |  | M(n) | 2/2 |

Table 29. ROM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | $\underset{\text { CYCLE }}{\text { WORD }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Branch on Status 1 | BR b | $11 b_{7} b_{6} b_{5} b_{4} b_{3} b_{2} b_{1} b_{0}$ |  | 1 | 1/1 |
| Long Branch on Status 1 | BRL u |  |  | 1 | 2/2 |
| Long Jump Unconditionally | JMPL u |  |  |  | 2/2 |
| Subroutine Jump on Status 1 | CAL a | 0111 asa $_{4} a_{3} a_{2} a_{1} a_{0}$ |  | 1 | 1/2 |
| Long Subroutine Jump on Status 1 | CALL u | $\mathrm{O}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{4} \mathbf{p}_{3} \mathrm{~d}_{2} \mathrm{p}_{2} \mathrm{~d}_{1} \mathrm{~d}_{1} \mathrm{do}_{0}$ |  | 1 | 2/2 |
| Table Branch | TBR p | $001011 p_{3} p_{2} p_{1} p_{0}$ |  |  | 1/1 |
| Return from Subroutine | RTN | 0000010000 |  |  | 1/3 |
| Return from Interrupt | RTNI | 0000010001 | $1 \rightarrow 1 / E$ |  | 1/3 |

Table 30. Input/Output Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | $\begin{aligned} & \text { WORD } \\ & \text { CYCLE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Discrete 1/O Latch | SED | 00011110001000 | $1 \rightarrow \mathrm{D}(\mathrm{Y})$ |  | 1/1 |
| Set Discrete 1/O Latch Direct | SEDD m |  | $1 \rightarrow \mathrm{D}(\mathrm{m})$ |  | 1/1 |
| Reset Discrete I/O Latch | RED | 000011000100 | $0 \rightarrow D(Y)$ |  | 1/1 |
| Reset Discrete 1/O Latch Direct | REDD $m$ |  | $0 \rightarrow D(m)$ |  | 1/1 |
| Test Discrete 1/O Latch | TD | 000111100000 |  | D(Y) | 1/1 |
| Test Discrete 1/O Latch Direct | TDD m | $\begin{array}{lllllllllllllllllllll}1 & 0 & 1 & 0 & 1 & 0\end{array} m_{3} m_{2} m_{1} m_{0}$ |  | D(m) | 1/1 |
| Load A from R-Port Register | LAR m | $\begin{array}{llllllllllllllllllllll}1 & 0 & 0 & 1 & 0 & 1 & m_{2} m_{1} m_{0}\end{array}$ | $R(\mathrm{~m}) \rightarrow \mathrm{A}$ |  | 1/1 |
| Load B from R-Port Register | LBR m |  | $R(m) \rightarrow B$ |  | 1/1 |
| Load R-Port Register from A | LRA m |  | $A \rightarrow R(m)$ |  | 1/1 |
| Load R-Port Register from B | LRB m |  | $B \rightarrow R(m)$ |  | 1/1 |
| Pattern Generation | $\mathrm{P} \quad \mathrm{p}$ |  |  |  | 1/2 |

Table 31. Control Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUSWORD <br> CYCLE |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| No Operation | NOP | 0000000000 |  |  | $1 / 1$ |
| Start Serial | STS | 0101001000 |  |  | $1 / 1$ |
| Stand-by Mode | SBY | 0101001100 |  | $1 / 1$ |  |
| Stop Mode | STOP | 0101001101 |  |  | $1 / 1$ |

Table 32. Op-Code Map


1-word/3-cycle Instruction Instruction

- MASK OPTION LIST
- Family Name $\quad$ HMCS404AC
- Package $\square$ DP-64S $\quad$ FP-64
- I/O Circuit Type

A; Without Pull-up MOS (NMOS Open Drain)
B; With Pull-up MOS
C; CMOS
D; Without Pull-down MOS (PMOS Open Drain)

| Date of Order |  |
| :--- | :--- |
| Customer |  |
| Dept. |  |
| Name |  |
| ROM Code Name |  |
| LSI Type Number <br> (Hitachi's entry) |  |

E; With Pull-down MOS

$\bullet^{-} R_{A 1} / V_{\text {disp }}(R A 1) \quad \square R_{A 1}$ : Without Pull-down MOS (D) $\square V_{\text {disp }}$ (VDISP)

- Oscillator (OSC) - Crystal or Ceramic Filter Oscillator (XTAL)
- Divider (DIV)
- Divide-by- 8 (D-8)
$\bullet$ ROM Code Media $\quad$ EPROM: Emulator Type $\square$ EPROM: EPROM On-Package Microcomputer Type
Note 1) I/O Options masked by $\square$ are not available.
Note 2) $R_{A 1} / V_{\text {disp }}$ has to be selected as $V_{\text {disp }}$ pin exept the case that all High Voltage Pins are option D.
- PACKAGE DIMENSIONS (Unit: mm)



## HMCS404CL (HD614045)

The HMCS404CL is a CMOS 4-bit single-chip microcomputer which is a member of the HMCS 400 series.

The HMCS404CL is a 3 V operation version of the HMCS404C.

The HMCS404CL has efficient and powerful architecture and its software is very similar to the HMCS40 series.

This microcomputer provides variety of on-chip resources such as ROM, RAM, I/O, two timer/counters and a serial interface to perform in wide users' applications.

The HMCS404CL also has the characteristics of high speed and low power dissipation and which I/O pins are able to drive fluorescent display tube directly.

- HARDWARE FEATURES
- 4-bit Architecture
- 4,096 Words x 10-bit ROM
- 256 Digits $\times 4$-bit RAM
- 58 I/O Pins, including 26 high voltage I/O pins (40V Max)
- Two Timer/Counters

11-bit Prescaler
8 -bit Free Running Timer
8-bit Auto-Reload Timer/Event Counter

- Clock Synchronous 8-bit Serial Interface
- Five Interrupt Sources

External 2
Timer/Counter 2
Serial Interface 1

- Subroutine Stack

Up to 16 levels including interrupts

- Wide $\mathrm{V}_{\mathrm{cc}}$ Supply Voltage Range -2.7 V to 6 V
- Minimum Instruction Execution Time - $4 \mu \mathrm{~s}$
- Two Low Power Dissipation Modes

Standby - Stops instruction execution while keeping clock oscillation and interrupt functions in operation.
Stop - Stops instruction execution and clock oscillation while retaining RAM data

- On-Chip Oscillator

External Connection of Crystal or Ceramic Filter (externally drivable)

## - SOFTWARE FEATURES

- Instruction Set Similar to and More Powerful than HMCS40 Series; 99 Instructions
- High Programming Efficiency with 10-bit ROM/Word; 79 instructions are single word instructions
- Direct Branch to All ROM Area
- Direct or Indirect Addressing to All RAM Area
- Subroutine Nesting Up to 16 Levels Including Interrupts
- Binary and BCD Arithmetic Operation
- Powerful Logical Arithmetic Operation
- Pattern Generation - Table Look Up Capability -
- Bit Manipulation for Both RAM and I/O


## HMCS404CL


(DP-64S)

## HMCS404CL


(FP-64)

- VERSATILE PROGRAM DEVELOPMENT SUPPORT TOOLS
- H68SD Series Macro Assembler
- H68SD5-use Emulator (With Real Time Trace Function)
- EPROM On Package Microcomputer

Mask options are fixed as follows:

- l/O pin : Open drain
- Oscillator: Crystal Oscillator or Ceramic Filter Oscillator
(externally drivable)
- Divider : Divided-by-8


## - PIN ARRANGEMENT (Top View)



- BLOCK DIAGRAM

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit | Note |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}$ | -0.3 to +7.0 | V |  |
| Terminal Voltage | $V_{T}$ | -0.3 to $V_{\text {CC }}+0.3$ | V | 3 |
|  |  | $\mathrm{V}_{\mathrm{CC}}-45$ to $\mathrm{V}_{\mathrm{CC}}+0.3$ | V | 4 |
| Total Allowance of Input Currents | $\mathrm{ElO}_{0}$ | 50 | mA | 5 |
| Total Allowance of Output Currents | $-\Sigma \mathrm{I}_{0}$ | 150 | mA | 6 |
| Maximum Input Current | 10 | 15 | mA | 7.8 |
| Maximum Output Current | -10 | 4 | mA | 9,10 |
|  |  | 6 | mA | 9,11 |
|  |  | 30 | mA | 9,12 |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ}$ |  |

(Note 1) Permanent damage may occur if "Absolute Maximum Ratings" are exceeded. Normal operation should be under the conditions of "Electrical Characteristics". If these conditions are exceeded, it may cause the malfunction and affect the reliability of LSI.
(Note 2) All voltages are with respect to GND.
(Note 3) Applied to standard pins.
(Note 4) Applied to high voltage pins.
(Note 5) Total allowance of input current is the total sum of input current which flow in from all 1/O pins to GND simultaneously.
(Note 6) Total allowance of output current is the total sum of the output current which flow out from $V_{\mathrm{CC}}$ to all $1 / O$ pins simultaneously.
(Note 7) Maximum input current is the maximum amount of input current from each I/O pin to GND.
(Note 8) Applied to $D_{0} \sim D_{3}$ and $R 3 \sim R 8$.
(Note 9) Maximum output current is the maximum amount of output current from $V_{C C}$ to each I/O pin.
(Note 10) Applied to $D_{0} \sim D_{3}$ and $R 3 \sim R 8$.
(Note 11) Applied to R0~R2.
(Note 12) Applied to $D_{4} \sim D_{15}$.

## - ELECTRICAL CHARACTERISTICS

- DC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=2.7 \mathrm{~V}$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{disp}}=\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}, \mathrm{Ta}=\mathbf{- 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" <br> Voltage | $\mathrm{V}_{\text {IH }}$ | $\text { RESET, } \overline{\text { SCK }}$ $\overline{N_{10}}, \hat{I N T}_{1}$ |  | 0.85 V CC | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
|  |  | SI |  | $0.85 \mathrm{~V}_{\mathrm{CC}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
|  |  | $\mathrm{OSC}_{1}$ |  | $V_{\text {CC }}-0.3$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" <br> Voltage | $V_{\text {IL }}$ | RESET, $\overline{\text { SCK }}$, INTo, INT1 |  | -0.3 | - | $0.15 V_{c c}$ | V |  |
|  |  | SI |  | -0.3 | - | $0.15 \mathrm{~V}_{\text {cc }}$ | V |  |
|  |  | $\mathrm{OSC}_{1}$ |  | -0.3 | - | 0.3 | V |  |
| Output "High" Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\overline{\text { SCK, SO }}$ | $-\mathrm{IOH}=0.1 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{Cc}}-0.5$ | - | - | V |  |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | SCK, SO | $\mathrm{IOLL}=0.4 \mathrm{~mA}$ | - | - | 0.4 | V |  |
| Input/Output Leakage Current | HILI |  | $V_{\text {in }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 1 |
| Current <br> Dissipation in Active Mode | ${ }^{\text {I cc }}$ | $V_{\text {cc }}$ | $\begin{aligned} & V_{\mathrm{CC}}=3 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{osc}}=2 \mathrm{MHz} \end{aligned}$ | - | - | 0.6 | mA | 2,6 |
| Current Dissipation in Standby Mode | $\mathrm{I}_{\text {SBY } 1}$ | $V_{c c}$ | Maximum Logic Operation $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=3 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{sc}}=2 \mathrm{MHz} \\ & \hline \end{aligned}$ | - | - | 0.5 | mA | 3,6 |
|  | ${ }^{\text {S SBY2 }}$ | $\mathrm{V}_{\text {cc }}$ | Minimum Logic Operation $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=3 \mathrm{~V} \\ & \mathrm{f}_{\mathrm{osC}}=2 \mathrm{MHz} \end{aligned}$ | - | - | 0.4 | mA | 4,6 |
| Current Dissipation in Stop Mode | $\mathrm{I}_{\text {stop }}$ | $V_{C c}$ | $\begin{aligned} & V_{\text {in }}(\overline{T E S T})=V_{C C}-0.2 \mathrm{~V} \text { to } V_{C C} \\ & V_{\text {in }}(R E S E T)=0 \mathrm{~V} \text { to } 0.2 \mathrm{~V} \end{aligned}$ | - | - | 10 | $\mu \mathrm{A}$ | 5 |
| Stop Mode Retain Voltage | $V_{\text {stop }}$ | $V_{\text {cc }}$ |  | 2 | - | - | V |  |

(Note 1) Pull-up MOS current and output buffer current are excluded.
(Note 2) The MCU is in the reset state. The input/output current does not flow.
Test Conditions: MCU state; Reset state in Operation Mode Pin state; - RESET, TEST... $V_{c c}$ voltage - $D_{0} \sim D_{3}, R 3 \sim R 9 \cdots V_{C C}$ voltage $-D_{4} \sim D_{15}, R O \sim R 2, R_{A O}, R_{A 1} \ldots V_{\text {disp }}$ voltage
(Note 3) The timer/counter operate with the fastest clock and input/output current does not flow.
Test Conditions: MCU state; - Standby Mode

- Input/Output; Reset state
- TIMER-A; $\div 2$ prescaler divide ratio
- TIMER-B; $\div 2$ prescaler divide ratio - SERIAL Interface ; Stop

Pin state; - RESET ... GND voltage - TEST ... $V_{\text {Cc }}$ voltage - $D_{0} \sim D_{3}, R 3 \sim R 9 \cdots V_{c c}$ voltage - $D_{4} \sim D_{15}, R 0 \sim R 2, R_{A 0}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 4) The timer/counter operate with the slowest clock and input/output current does not flow.
Test Conditions: MCU state; - Standby Mode

- Input/Output; Reset state
- TIMER-A; $\div 2048$ prescaler divide ratio
- TIMER-B; - 2048 prescaler divide ratio - SERIAL Interface ; Stop

Pin state; - RESET ... GND voltage

- TEST ... $V_{\text {CC }}$ voltage
- $D_{0} \sim D_{3}, R 3 \sim R 9 \ldots V_{C}$ voltage
$-D_{4} \sim D_{15}, R 0 \sim R 2, R_{A O}, R_{A 1} \cdots V_{\text {disp }}$ voltage
(Note 5) Pull-down MOS current is excluded.
(Note 6) When $\mathrm{f}_{\mathrm{osc}}=x[\mathrm{MHz}]$, the Current Dissipation in Operation mode and Standby mode are estimated as follows:
[When Divide-by-8 (D-8) option is selected.] max. value ( $\mathrm{f}_{\mathrm{osc}}=x[\mathrm{MHz}]$ ) $=\frac{x}{2} \times \max$. value ( $\mathrm{f}_{\mathrm{Osc}}=2[\mathrm{MHz]}$ )
- INPUT/OUTPUT CHARACTERISTICS FOR STANDARD PIN
$\left(V_{C C}=2.7 \mathrm{~V}\right.$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" Voltage | $\mathrm{V}_{1 \mathrm{H}}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & \text { R3 } \sim \text { R5, R9 } \end{aligned}$ |  | $0.85 V_{\text {cc }}$ | - | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| Input "Low" Voltage | $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 5, R 9 \\ & \hline \end{aligned}$ |  | -0.3 | - | 0.15 V cc | V |  |
| Output "High" <br> Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & \text { R3 } \sim \text { R8 } \end{aligned}$ | $-\mathrm{l}_{\mathrm{OH}}=0.1 \mathrm{~mA}$ | $V_{c c}-0.5$ | - | - | V | 1 |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 8 \end{aligned}$ | $\mathrm{I}_{\mathrm{OL}}=0.4 \mathrm{~mA}$ | - | - | 0.4 | V |  |
| Input/Output Leakage Current | \|ILI | $\begin{aligned} & \mathrm{D}_{0} \sim \mathrm{D}_{3}, \\ & \mathrm{R} 3 \sim \mathrm{R}, \end{aligned}$ | $V_{\text {in }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ | - | - | 1 | $\mu \mathrm{A}$ | 2 |
| Pull-Up MOS Current | $-l_{p}$ | $\begin{aligned} & \mathrm{Do}_{0} \sim \mathrm{D}_{3}, \\ & \mathrm{R} 3 \sim \mathrm{R9} \\ & \hline \end{aligned}$ | $\begin{aligned} & v_{c c}=3 \mathrm{~V} \\ & v_{\text {in }}=0 \mathrm{~V} \end{aligned}$ | 3 | 15 | 40 | $\mu \mathrm{A}$ | 3 |
|  |  | $\begin{aligned} & D_{0} \sim D_{3}, \\ & R 3 \sim R 9 \end{aligned}$ | $\begin{aligned} & V_{\mathrm{cc}}=5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{in}}=0 \mathrm{~V} \end{aligned}$ | 30 | 60 | 120 | $\mu \mathrm{A}$ | 3 |

(Note 1) Applied to I/O pins with "CMOS" output selected by mask option.
(Note 2) Pull-up MOS current and output buffer current are excluded.
(Note 3) Applied to $1 / O$ pins "with Pull-up MOS" selected by mask option.

- INPUT/OUTPUT CHARACTERISTICS FOR HIGH VOLTAGE PIN
( $\mathrm{V}_{\mathrm{Cc}}=2.7 \mathrm{~V}$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathrm{Cc}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}, \mathrm{Ta}_{\mathrm{a}}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Input "High" Voltage | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & D_{4} \sim D_{15}, R_{1} \\ & R 2, R_{A 0}, R_{A 1} \end{aligned}$ |  | $0.85 \mathrm{~V}_{\mathrm{cc}}$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Input "Low" Voltage | $V_{\text {IL }}$ | $\begin{aligned} & D_{4} \sim D_{15}, R 1 \\ & R 2, R_{A 0}, R_{A 1} \end{aligned}$ |  | $V_{c c}-40$ | - | $0.15 \mathrm{~V}_{\mathrm{cc}}$ | V |  |
| Output "High" <br> Voltage | V OH | $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ | $-\mathrm{IOH}=15 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | $V_{\text {cc }}-3.0$ | - | - | V |  |
|  |  |  | $-1 \mathrm{OH}=2.5 \mathrm{~mA}$ | $V_{C C}-1.0$ | - | - | V |  |
|  |  | R0 ~ R2 | $-\mathrm{l}_{\mathrm{OH}}=3 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | $\mathrm{V}_{C C}-3.0$ | - | - | V |  |
|  |  |  | $-1 \mathrm{OH}=0.5 \mathrm{~mA}$ | $V_{c c}-1.0$ | - | - | V |  |
| Output "Low" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & \mathrm{RO} \sim \mathrm{R} 2 \end{aligned}$ | $\mathrm{V}_{\text {dizp }}=\mathrm{V}_{\text {cc }}-40 \mathrm{~V}$ | - | - | $V_{c c}-37$ | V | 1 |
|  |  | $\begin{aligned} & \mathrm{D}_{4} \sim \mathrm{D}_{15} \\ & \mathrm{RO} \sim \mathrm{R2} \end{aligned}$ | $150 \mathrm{k} \Omega$ to $\mathrm{V}_{\mathrm{cc}}-40 \mathrm{~V}$ | - | - | $V_{c c}-37$ | V | 2 |
| Input/Output Leakage Current | $\mathrm{H}_{12} \mathrm{l}$ | $\begin{aligned} & D_{4} \sim D_{15} \\ & R_{0} \sim R_{2} \\ & R_{A O}, R_{A 1} \end{aligned}$ | $V_{\text {in }}=V_{c c}-40 \mathrm{~V}$ to $V_{c c}$ | - | - | 20 | $\mu \mathrm{A}$ | 3 |
| Pull Down MOS Current | $I_{d}$ | $\begin{aligned} & D_{4} \sim D_{15} \\ & R O \sim R_{2} \\ & R_{A 0}, R_{A 1} \end{aligned}$ | $\begin{aligned} & V_{\text {disp }}=V_{c c}-35 V \\ & V_{\text {in }}=V_{c c} \end{aligned}$ | 125 | 250 | 500 | $\mu \mathrm{A}$ | 4 |

(Note 1) Applied to I/O pins "with Pull-down MOS" selected by mask option.
(Note 2) Applied to I/O pins "without Pull-down MOS (PMOS Open Drain)" selected by mask option.
(Note 3) Pull-down MOS current and output buffer current are excluded.
(Note 4) Applied to I/O pins "with Pull-down MOS" selected by mask option.

- AC CHARACTERISTICS $\left(V_{C C}=2.7 \mathrm{~V}\right.$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\text {disp }}=\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{Cc}}, \mathrm{Ta}_{\mathrm{a}}=-\mathbf{2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}$, if not specified.)

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Oscillation Frequency | $f_{\text {osc }}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ |  | 0.4 | 2 | 2.25 | MHz |  |
| Instruction Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  |  | 3.55 | 4 | 20 | $\mu \mathrm{s}$ |  |
| Oscillator Stabilization Time | $\mathrm{t}_{\mathrm{RC}}$ | $\mathrm{OSC}_{1}, \mathrm{OSC}_{2}$ |  | - | - | 60 | ms | 1 |
| External Clock "High" Level Width | ${ }^{\text {t }}$ CPH | $\mathrm{OSC}_{1}$ |  | 205 | - | - | ns | 2 |
| External Clock "Low" Level Width | ${ }^{\text {t CPL }}$ | OSC ${ }_{1}$ |  | 205 | - | - | ns | 2 |
| External Clock Rise Time | ${ }^{t}{ }_{C P r}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
| External Clock Fall Time | ${ }^{\text {t }}$ ¢ ${ }^{\text {fa }}$ | $\mathrm{OSC}_{1}$ |  | - | - | 20 | ns | 2 |
| $\overline{\text { INTo }}$ "High" Level Width | ${ }_{10} \mathrm{OH}$ | INTo |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 3 |
| $\overline{\text { INT0 }}$ "Low" Level Width | $\mathrm{t}_{10 \mathrm{~L}}$ | $\overline{\text { INTo }}$ |  | 2 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 3 |
| $\overline{\text { INT }{ }_{1}}$ "High" Level Width | $\mathrm{t}_{11 \mathrm{H}}$ | $\overline{\mathrm{INT}_{1}}$ |  | 2 | - | - | ${ }^{\text {t }} \mathrm{cyc}$ | 3 |
| $\overline{\text { INT1 }}$ "Low" Level Width | $\mathrm{t}_{11 \mathrm{~L}}$ | $\overline{\mathrm{INT}_{1}}$ |  | 2 | - | - | ${ }_{\text {teyc }}$ | 3 |
| RESET "High" Level Width | $\mathrm{t}_{\text {RSTH }}$ | RESET |  | 2 | - | - | $\mathrm{t}_{\text {cyc }}$ | 4 |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ | all pins | $\begin{aligned} & f=1 \mathrm{MHz} \\ & V_{\text {in }}=0 \mathrm{~V} \end{aligned}$ | - | - | 15 | pF |  |
| RESET Fall Time | $t_{\text {RST }}$ |  |  | - | - | 15 | ms | 4 |

(Note 1) Oscillator stabilization time is the time until the oscillator stabilizes after $V_{C C}$ reaches 2.7 V at "Power-on", or after RESET input level goes "High" by resetting to quit the stop mode by MCU reset. The circuits used to measure the value are described below. When using crystal or ceramic filter oscillator, please ask a crystal oscillator maker's or ceramic filter maker's advice because oscillator stabilization time depends on the circuit constant and stray capacity.


> Ceramic filter oscillator


Crystal: 2.097152 MHz DS-MGQ308 (Seiko Denshi)
Ceramic filter: CSA2.000MK (Murata)

$$
\begin{aligned}
& R f=2 M \Omega \pm 2 \%, R d=2.2 \mathrm{k} \Omega \pm 2 \% \\
& C_{1}=10 \mathrm{pF} \pm 20 \% \\
& C_{2}=10 \mathrm{pF} \pm 20 \%
\end{aligned}
$$


(Note 4)
RESET
(Note 3)


- SERIAL INTERFACE TIMING CHARACTERISTICS
$\left(\mathrm{V}_{\mathrm{cc}}=2.7 \mathrm{~V}\right.$ to $6 \mathrm{~V}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{disp}}=\mathrm{V}_{\mathrm{Cc}}-\mathbf{4 0 V}$ to $\mathrm{V}_{\mathrm{cc}}, \mathrm{Ta}=-20$ to $+75^{\circ} \mathrm{C}$, if not specified.)
- At Transfer Clock Output

| ftem | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | ${ }^{\text {t }}$ Scyc | SCK | (Note 2) | 1 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ | 1,2 |
| Transfer Clock "High" Level Width | $\mathrm{t}_{\text {SCKH }}$ | $\overline{\text { SCK }}$ | (Note 2) | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1.2 |
| Transfer Clock "Low" Level Width | $\mathrm{t}_{\text {SCKL }}$ | SCK | (Note 2) | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1,2 |
| Transfer Clock Rise Time | $\mathrm{t}_{\text {SCK } \mathrm{r}}$ | SCK | (Note 2) | - | - | 300 | ns | 1,2 |
| Transfer Clock Fall Time | $\mathrm{t}_{\text {SCK }}$ | SCK | (Note 2) | - | - | 300 | ns | 1,2 |
| Serial Output Data Delay Time | $t_{\text {dso }}$ | SO | (Note 2) | - | - | 600 | ns | 1.2 |
| Serial Input Data Set-up Time | ${ }_{\text {tss }}$ | SI |  | 1000 | - | - | ns | 1 |
| Serial Input Data Hold Time | ${ }^{\text {thSI }}$ | SI |  | 500 | - | - | ns | 1 |

- At Transfer Clock Input

| Item | Symbol | Pin Name | Test Conditions | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | typ | max |  |  |
| Transfer Clock Cycle Time | $\mathrm{t}_{\text {Scyc }}$ | SCK |  | 1 | - | - | $\mathrm{t}_{\text {cyc }}$ | 1 |
| Transfer Clock "High" Level Width | ${ }^{\text {tsCKH }}$ | SCK |  | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1 |
| Transfer Clock "Low" Level Width | ${ }^{\text {tsckL }}$ | $\overline{\text { SCK }}$ |  | 0.5 | - | - | ${ }^{\text {tscyc }}$ | 1 |
| Transfer Clock Rise Time | $\mathrm{t}_{\text {sckr }}$ | $\overline{\text { SCK }}$ |  | - | - | 300 | ns | 1 |
| Transfer Clock Fall Time | $\mathrm{t}_{\text {Sck }}$ | SCK |  | - | - | 300 | ns | 1 |
| Serial Output Data Delay Time | $t_{\text {dso }}$ | SO | (Note 2) | - | - | 600 | ns | 1, 2 |
| Serial Input Data Set-up Time | ${ }_{\text {tssi }}$ | SI |  | 1000 | - | - | ns | 1 |
| Serial Input Data Hold Time | $\mathrm{t}_{\mathrm{HSI}}$ | SI |  | 500 | - | - | ns | 1 |

(Note 1) Timing Diagram of Serial Interface


* $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$ and 0.4 V are the threshold voltage for transfer clock output. $0.85 \mathrm{~V}_{\mathrm{CC}}$ and $0.15 \mathrm{~V}_{\mathrm{CC}}$ are the threshold voltage for transfer clock input.
(Note 2) Timing Load Circuit



Icc vs. V ${ }_{\text {cc }}$ Characteristics
(Crystal, Ceramic Filter Oscillator)

-Ip (Pull-up MOS Current) vs. $V_{\text {cC }}$ Characteristics


IOL min. vs. VOL Characteristics (Standard Pin)

$I_{\text {SBY }}$ vs. $V_{\text {CC }}$ Characteristics (Crystal, Ceramic Filter Oscillator)

$I_{d}$ (Pull-down MOS Current) vs. ( $\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\text {disp }}$ ) Characteristics

$-\mathrm{l}_{\mathrm{OH}}$ min. vs. $\left(\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{OH}}\right)$ Characteristics (Standard Pin "CMOS")

$-\mathrm{IOH}_{\mathrm{OH}}$ min. vs. $\left(\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{OH}}\right)$ Characteristics ( $\mathrm{D}_{4} \sim \mathrm{D}_{15}$ Pins)

## - DESCRIPTION OF PIN FUNCTIONS

Input and output signals of MCU are described below.

- GND, $V_{c c}, V_{\text {disp }}$

These are Power Supply Pins. Connect GND pin to Earth $(0 \mathrm{~V})$ and apply $\mathrm{V}_{\mathrm{CC}}$ power supply voltage to $\mathrm{V}_{\mathrm{CC}}$ pin. $\mathrm{V}_{\mathrm{disp}}$ is an power supply for high voltage Input/Output pins with maximum voltage of $\mathrm{V}_{\mathrm{CC}}-40 \mathrm{~V}$. $\mathrm{V}_{\mathrm{disp}}$ pin can be also used as $\mathrm{R}_{\mathrm{A} 1}$ pin by mask option. For details, see "INPUT/OUTPUT".

- TEST

TEST pin is not for user's application. $\overline{\text { TEST }}$ must be connected to $\mathrm{V}_{\mathrm{CC}}$.

## - RESET

RESET pin is used to reset MCU. For details, see "RESET".

- OSC $_{1}$, OSC $_{2}$

These are Input pins to the internal oscillator circuit. They can be connected to crystal, or ceramic filter resonator. For details, see "INTERNAL OSCILLATOR CIRCUIT."

## - D-port ( $\mathrm{D}_{0}$ to $\mathrm{D}_{15}$ )

D-port is a 1-bit Input/Output common port. $\mathrm{D}_{0}$ to $\mathrm{D}_{3}$ are standard type, $D_{4}$ to $D_{1 s}$ are for high voltage. Each pin has the mask option to select its circuit type. For details, See "INPUT/ OUTPUT".

## - R-port (R0 to RA)

R-port is a 4 -bit Input/Output port. (only RA is 2 -bit construction.) R0 and R6 to R8 are output ports, R9 to RA are input ports, and R1 to R5 are Input/Output common ports. R0 to R2 and RA are the high voltage ports, R3 to R9 are the standard ports. Each pin has the mask option to select its circuit type. $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ are also available as $\overline{\mathrm{INT}}, \overline{\mathrm{INT}_{1}}, \overline{\mathrm{SCK}}, \mathrm{SI}$ and SO respectively. For details, see


## "INPUT/OUTPUT".

- $\overline{\mathbf{I N T}_{0}}, \overline{\mathrm{INT}_{1}}$

These are the input pins to interrupt MCU operation externally. $\overline{I_{N T}}{ }_{1}$ can be used as an external event input pin for TIMER-B. $\overline{\mathrm{INT}} \mathrm{T}_{0}$ and $\overline{\mathrm{INT}_{1}}$ are also available as $\mathrm{R}_{32}$, and $\mathrm{R}_{33}$ respectively. For details, See "INTERRUPT".

- $\overline{\mathbf{S C K}}, \mathbf{S I}, \mathbf{S O}$

These are Transfer clock I/O pin ( $\overline{\mathrm{SCK}}$ ), serial data input pin (SI) and serial data output pin (SO) used for serial interface. SCK, SI, and SO are also available as $\mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ respectively. For details, see "SERIAL INTERFACE".

## - ROM MEMORY MAP

MCU includes 4096 words $\times 10$ bits ROM. ROM memory map is illustrated in Fig. 1 and described in the following paragraph.

## - Vector Address Area ..... \$0000 to \$000F

When MCU is reset or an interrupt is serviced, the program is executed from the vector address. Program the JMPL instructions branching to the starting addresses of reset routine or of interrupt routines.

## - Zero-Page Subroutine Area ..... \$0000 to \$003F

CAL instruction allows to branch to the subroutines in $\$ 0000$ to $\$ 003 \mathrm{~F}$.

## - Pattern Area ..... \$0000 to \$0FFF

P instruction allows referring to the ROM data in $\$ 0000$ to $\$ 0 \mathrm{FFF}$ as a pattern.

- Program Area ...... \$0000 to \$0FFF


Fig. 1 ROM Memory Map

- RAM MEMORY MAP

MCU includes 256 digits $\times 4$ bits RAM as the data area and stack area. In addition to these areas, interrupt control bits
and special registers are also mapped on the RAM memory space. RAM memory map is illustrated in Fig. 2 and described in the following paragraph.


Fig. 2 RAM Memory Map

| 0 | bit 3 | bit 2 | bit 1 | bit 0 | \$000 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | IMO (IM of $\overline{\mathrm{INT}} \mathrm{T}_{0}$ ) | $\begin{gathered} \text { IFO } \\ (\mathrm{IF} \text { of } \overline{\mathrm{INT}}) \end{gathered}$ | RSP (Reset SP Bit) | (Interrupt Enable Flag) |  |
| 1 | IMTA <br> (iM of TIMER-A) | $\begin{gathered} \text { IFTA } \\ \text { (IF of TIMER-A) } \end{gathered}$ | IM1 (IM of $\left.\overline{\mathrm{INT}} \mathrm{T}_{1}\right)$ | $\begin{gathered} \text { IF1 } \\ \left(\mathrm{IF} \text { of } \overline{\left.\mathrm{INT} \mathrm{~T}_{1}\right)}\right. \end{gathered}$ | \$001 |
| 2 | Not Used | Not Used | IMTB <br> (IM of TIMER-B) | $\begin{gathered} \text { IFTB } \\ \text { (IF of TIMER-B) } \end{gathered}$ | \$002 |
| 3 | Not Used | Not Used | $\begin{gathered} \text { IMS } \\ \text { (IM of SERIAL) } \end{gathered}$ | $\begin{gathered} \text { IFS } \\ \text { (IF of SERIAL) } \end{gathered}$ | \$003 |
| $\begin{array}{c:} \text { IF } \\ \text { IM } \\ \text { I/E } \\ \text { SP } \end{array}$ | Interrupt Request Flag <br> Interrupt Mask <br> Interrupt Enable Flag <br> Stack Pointer |  |  |  |  |
| (Note) | Each bit in Interrupt Control Bits Area is set by SEM/SEMD instruction, is reset by REM/REMD instruction and is tested by TM/TMD instruction. It is not affected by other instructions. Furthermore, Interrupt Request Flag is not affected by SEM/SEMD instruction. The content of Status becomes invarid when "Not Used" bit is tested. |  |  |  |  |

Fig. 3 Configuration of Interrupt Control Bit Area

- Interrupt Control Bit Area ..... \$000 to $\mathbf{\$ 0 0 3}$

This area is used for interrupt controls, and is illustrated in Fig.3. It is accessable only by RAM bit manipulation instruction. However, the interrupt request flag cannot be set by software.

## - Special Register Area ..... \$004 to \$00B

Special Register is a mode or a data register for the external interrupt, the serial interface, and the timer/counter. These registers are classified into 3 types: Write-only, Read-only, and Read/Write as shown in Fig. 2. These registers cannot be accessed by RAM bit manipulation instruction.

- Data Area ..... \$020 to \$0DF

16 digits of $\$ 020$ to $\$ 02 \mathrm{~F}$ are called memory register (MR) and accessable by LAMR and XMRA instructions.

## - Stack Area .... \$3C0 to \$3FF

Stack Area is used for LIFO stacks with the contents of the program counter (PC), status (ST) and carry (CA) when processing subroutine call and interrupt. As 1 level requires 4 digits, this stack area is nested to 16 level-stack max. The data pushed in the stack and LIFO stack state are provided in Fig. 4. The program counter is restored by RTN and RTNI instructions. Status and Carry are restored only by RTNI instruction. The area, not used for stacking, is available as a data area.


|  | Stack Area |  |
| :---: | :---: | :---: |
| 960 | Level 16 | \$3C0 |
|  | Level 15 |  |
|  | Level 14 |  |
|  | Level 13 |  |
|  | Level 12 |  |
|  | Level 11 |  |
|  | Level 10 |  |
|  | Level 9 |  |
|  | Level 8 |  |
|  | Level 7 |  |
|  | Level 6 |  |
|  | Level 5 |  |
|  | Level 4 |  |
|  | Level 3 |  |
|  | Level 2 |  |
|  | Level 1 | \$ 3FF |


$\mathrm{PC}_{13}$ to $\mathrm{PC}_{0}$; Program Counter
ST; Status
CA; Carry
Fig. 4 Configuration of Memory Register, Stack Area and Stack Position

## - REGISTER AND FLAG

The MCU has nine registers and two flags for the CPU operations. They are illustrated in Fig. 5 and described in the following paragraphs.

## - Accumulator (A), B Register (B)

Accumulator and B Register are 4-bit registers used to hold the results of Arithmetic Logic Unit (ALU), and to transfer data to/from memories, I/O and other registers.

- W Register (W), X Register (X), Y Register (Y)

W Register is 2 -bit, and $X$ and $Y$ Register are 4 -bit registers used for indirect addressing of RAM. Y register is also used for $D$-port addressing.

- SPX Register (SPX), SPY Register (SPY)

SPX and SPY Register are 4-bit registers used to assist $X$ and Y Register respectively.

## - Carry (CA)

Carry (CA) stores the overflow of ALU generated by the arithmetic operation. It is also affected by SEC, REC, ROTL and ROTR instructions.

During interrupt servicing, Carry is pushed onto the stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Status (ST)

Status (ST) holds the ALU overflow, ALU non-zero and the results of bit test instruction for the arithmetic or compare instruction. It is used for a branch condition of BR, BRL, CAL or CALL instructions. The value of the Status remains unchanged until the next arithmetic, compare or bit test instruction is executed. Status becomes " 1 " after the BR, BRL, CAL or CALL instruction has been executed (irrespective of its execution/ skip). During the interrupt servicing, Status is pushed onto the


Fig. 5 Register and Flags
stack and restored back from the stack by RTNI instruction. (It's not affected by RTN instruction.)

## - Program Counter (PC)

Program Counter is a 14 -bit binary counter for ROM addressing.

## - Stack Pointer (SP)

Stack Pointer is used to point the address of the next stacking area up to 16 levels.

The Stack Pointer is initialized to locate $\$ 3$ FF on the RAM address, and is decremented by 4 as data pushed into the stack, and incremented by 4 as data restored back from the stack.

## - INTERRUPT

The MCU can be interrupted by five different sources: the external signals ( $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}$ ), timer/counter (TIMER-A, TIMER-B), and serial interface (SERIAL). In each sources, the Interrupt Request Flag, Interrupt Mask and interrupt vector address will be used to control and maintain the interrupt request. The Interrupt Enable Flag is also used to control the total interrupt operations.

## - Interrupt Control Bit and Interrupt Service

The interrupt control bit is mapped on $\$ 000$ to $\$ 003$ of the RAM address and accessable by RAM bit manipulation instruction. (The Interrupt Request Flag (IF) cannot be set by software.) The Interrupt Enable Flag (I/E) and Interrupt Request Flag (IF) are set to " 0 ", and the Interrupt Mask (IM) is set to "1" at the initialization by MCU reset.

Fig. 6 shows the interrupt block diagram. Table 1 shows the interrupt priority and vector addresses, and Table 2 shows the conditions that the interrupt service is executed by any one of the five interrupt sources.

The interrupt request is generated when the Interrupt Request Flag is set to " 1 " and the Interrupt Mask is " 0 ". If the Interrupt Enable Flag is " 1 ", then the interrupt will be activated and vector addresses will be generated from the priority PLA corresponding to the five interrupt sources.

Fig. 7 shows the interrupt services sequence, and Fig. 8 shows the interrupt flowchart. If the interrupt is requested, the instruction finishes its execution in the first cycle. The Interrupt Enable Flag is reset in the second cycle. In the second and third cycles, the Carry, Status and Program Counter are pushed onto the stack. In the third cycle, the instruction is executed again after jumping to the vector address.

In each vector address, program JMPL instruction to branch to a starting address of the interrupt routine. The Interrupt Request Flag which caused the interrupt service has to be reset by software in the interrupt routine.


Fig. 6 Interrupt Circuit Block Diagram

Table 1. Vector Addresses and Interrupt Priority

| Reset . Interrupt | Priority | Vector addresses |
| :--- | :---: | :---: |
| RESET | - | $\$ 0000$ |
| $\overline{\text { NT }_{0}}$ | 1 | $\$ 0002$ |
| $\overline{\text { INT }}_{1}$ | 2 | $\$ 0004$ |
| TIMER-A | 3 | $\$ 0006$ |
| TIMER-B | 4 | $\$ 0008$ |
| SERIAL | 5 | $\$ 000 \mathrm{C}$ |

Table 2. Conditions of Interrupt Service

| $\underbrace{\text { Interrupt }}_{\substack{\text { Interrupt } \\ \text { control bits }}}$ source | $\overline{\text { NTo }}$ | $\overline{\text { INT, }}$ | TIMER-A | TIMER-B | SERIAL |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I/E | 1 | 1 | 1 | 1 | 1 |
| IFO. $\overline{\text { M }}$ | 1 | 0 | 0 | 0 | 0 |
| IF1. $\overline{\mathrm{M} 1}$ | * | 1 | 0 | 0 | 0 |
| IFTA $\cdot \overline{\text { IMTA }}$ | * | * | 1 | 0 | 0 |
| IFTB • IMTB | * | * | * | 1 | 0 |
| IFS $\cdot \overline{\text { MS }}$ | * | * | * | * | 1 |



## JMPL instruction execution on the vector address

Fig. 7 Interrupt Servicing Sequence
instruction Execution at starting address of the interrupt routine

- Interrupt Enable Flag (I/E: $\mathbf{\$ 0 0 0}, \mathbf{0})$

The Interrupt Enable Flag controls enable/disable of all interrupt requests as shown in Table 3. The Interrupt Enable Flag is reset by the interrupt servicing and set by RTNI instruction.

Table 3. Interrupt Enable Flag

| Interrupt Enable Flag | Interrupt Enable/Disable |
| :---: | :---: |
| $\mathbf{0}$ | Disable |
| $\mathbf{1}$ | Enable |

- External Interrupt ( $\overline{\mathbf{N T}} \mathbf{T}_{0}, \overline{\mathbf{I N T}_{1}}$ )

To use external interrupt, select $\mathrm{R}_{32} / \overline{\mathrm{INT}_{0}}, \mathrm{R}_{33} / \overline{\mathrm{INT}_{1}}$ port for $\overline{\mathrm{INT}}{ }_{0}, \overline{\mathrm{INT}_{1}}$ mode by setting the Port Mode Register (PMR: \$004).

The External Interrupt Request Flags (IF0, IF1) are set at the falling edge of $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}_{1}}$ inputs.
$\overline{I N T}_{1}$ input can be used as a clock signal input of TIMER-B. Then, TIMER-B counts up at each falling edge of input. When using $\overline{\mathrm{INT}_{1}}$ as TIMER-B external event, an External Interrupt Mask (IM1) has to be set so that the interrupt request by $\overline{\mathrm{INT}_{1}}$ will not be accepted.

- External Interrupt Request Flag (IF0: \$000,2, IF1: \$001,0) The External Interrupt Request Flags (IF0, IF1) are set at the falling edges of $\overline{\mathrm{INT}}_{0}, \overline{\mathrm{INT}}_{1}$ inputs respectively
- External Interrupt Mask (IM0: \$000,3, IM1: \$001,1)

The External Interrupt Mask is used to mask the external interrupt requests.

Table 4. External Interrupt Request Flag

| External Interrupt Request Flags | Interrupt Requests |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 5. External Interrupt Mask

| External Interrupt Masks | Interrupt Requests |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (masks) |

Port Mode Register (PMR: \$004)
The Port Mode Register is a 4 -bit write-only register which controls the $\mathrm{R}_{32} / \overline{\mathrm{INT}} \mathrm{N}_{0}$ pin, $\mathrm{R}_{33} / \overline{\mathrm{INT}_{1}}$ pin, $\mathrm{R}_{4} / \mathrm{SI}$ pin and $\mathrm{R}_{42}$ /SO pin as shown in Table 6. The Port Mode Register will be initialized to $\$ 0$ by MCU reset, so that all these pins are set to a port mode.

Table 6. Port Mode Register

| PMR | $\mathrm{R}_{33} / / \overline{\mathrm{NT}}_{1}$ pin |
| :---: | :---: |
| bit 3 |  |
| 0 | Used as $\mathrm{R}_{33}$ port input/output pin |
| 1 | Used as $\overline{\mathrm{INT}_{1}}$ input pin |
| PMR | $\mathrm{R}_{32} / \overline{\mathrm{NT}_{0}} \mathrm{pin}$ |
| bit 2 |  |
| 0 | Used as R32 port input/output pin |
| 1 | Used as $\overline{I N T}_{0}$ input pin |
| PMR | $\mathrm{R}_{41} / \mathrm{SI}$ pin |
| bit 1 |  |
| 0 | Used as $\mathrm{R}_{41}$ port input/output pin |
| 1 | Used as SI input pin |
| PMR | $\mathrm{R}_{42} / \mathrm{SO}$ pin |
| bit 0 |  |
| 0 | Used as $\mathrm{R}_{42}$ port input/output pin |
| 1 | Used as SO output pin |



Fig. 8 Interrupt Servicing Flowchart

## - SERIAL INTERFACE

The serial interface is used to transmit/receive 8 -bit data serially. This consists of the Serial Data Register, the Serial Mode Register, the Octal Counter and the multiplexer, as illustrated in Fig. 9. Pin $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the transfer clock signal are controlled by the Serial Mode Register. Contents of the Serial Data Register can be written into or read out by the software. The data in the Serial Data Register can be shifted synchronous-
ly with the transfer clock signal.
The serial interface operation is initiated with STS instruction. The Octal Counter is reset to $\$ 0$ by STS instruction. It starts to count at the falling edge of the transfer clock ( $\overline{\mathrm{SCK}}$ ) signal and increments by one at the rising edge of the SCK. When the Octal Counter is reset to $\$ 0$ after eight transfer clock signals, or discontinued transmit/receive operation by resetting the Octal Counter, the SERIAL Interrupt Request Flag will be set.


Fig. 9 Serial Interface Block Diagram

## - Serial Mode Register (SMR: \$005)

The Serial Mode Register is a 4 -bit write-only register. This register controls the $\mathrm{R}_{40} / \overline{\mathrm{SCK}}$ and the prescaler divide ratio as the transfer clock source as shown in Table 7.

The Write Signal to the Serial Mode Register controls the operating state of serial interface.

The Write Signal to the Serial Mode Register stops the transfer clock applied to the Serial Data Register and the Octal Counter. And it also reset the Octal Counter to $\$ 0$ simultaneously.

When the Serial Interface is in the "Transfer State", the Write Signal to the Serial Mode Register causes to quit the data transfer and to set the SERIAL Interrupt Request Flag.

Contents of the Serial Mode Register will be changed on the second instruction cycle after writing into the Serial Mode Register. Therefore, it will be necessary to execute the STS instruction after the data in the Serial Mode Register has been changed completely. The Serial Mode Register will be reset to $\$ 0$ by MCU reset.

- Serial Data Register (SRL: \$006, SRU: \$007)

The Serial Data Register is an 8 -bit read/write register. It consists of a low-order digit (SRL:\$006) and a high-order digit (SRU: \$007).

The data in the Serial Data Register will be output from the LSB side at SO pin synchronously with the falling edge of the transfer clock signal. At the same time, external data will be input from the LSB side at SI pin to the Serial Data Register synchronously with the rising edge of the transfer clock. Fig. 10 shows the I/O timing chart for the transfer clock signal and the data.

The writing into/reading from the Serial Data Register during its shifting causes the validity of the data.

Therefore complete data transmit/receive before writing into/reading from the serial data register.

Table 7. Serial Mode Register

| SMR | $R_{40} / \overline{\text { SCK }}$ |
| :---: | :---: |
| Bit 3 |  |
| 0 | Used as R40 port input/output pin |
| 1 | Used as $\overline{\text { SCK }}$ input/output pin |


| SMR |  |  | Transfer Clock |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 | R40/ $\overline{\text { SCK }}$ Port | Clock Source | Prescaler Divide Ratio | System Clock Divide Ratio |
| 0 | 0 | 0 | $\begin{aligned} & \overline{\text { SCK }} \\ & \text { Output } \end{aligned}$ | Prescaler | $\div 2048$ | $\div 4096$ |
| 0 | 0 | 1 | $\overline{\text { SCK }}$ Output | Prescaler | $\div 512$ | $\div 1024$ |
| 0 | 1 | 0 | SCK Output | Prescaler | $\div 128$ | $\div 256$ |
| 0 | 1 | 1 | SCK Output | Prescaler | $\div 32$ | $\div 64$ |
| 1 | 0 | 0 | SCK Output | Prescaler | $\div 8$ | $\div 16$ |
| 1 | 0 | 1 | $\overline{\text { SCK }}$ Output | Prescaler | $\div 2$ | $\div 4$ |
| 1 | 1 | 0 | $\overline{\text { SCK }}$ Output | System Clock | - | $\div 1$ |
| 1 | 1 | 1 | SCK Input | External Clock | - | - |



Fig. 10 Serial Interface I/O Timing Chart

- SERIAL Interrupt Request Flag (IFS: \$003, 0)

The SERIAL Interrupt Request Flag will be set after the eight transfer clock signals or transmit/receive discontinued operation by resetting the Octal Counter.

- SERIAL Interrupt Mask (IMS: \$003, 1)

The SERIAL Interrupt Mask masks the interrupt request.
Table 8. SERIAL Interrupt Request Flag

| SERIAL Interrupt Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 9. SERIAL Interrupt Mask

| SERIAL Interrupt Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (mask) |

## - Selection of the Operation Mode

Table 10 shows the operation mode of the serial interface. Select a combination of the value in the Port Mode Register and the Serial Mode Register according to Table 10.

Initialize the serial interface by the Write Signal to the Serial Mode Register, when the Operation Mode is changed.

## - Operating State of Serial Interface

The serial interface has 3 operating states as shown in Fig. 11.
The serial interface gets into "STS waiting state" by 2 ways: one way is to change the operation mode by changing the data
in the Port Mode Register, the other is to write data into the Serial Mode Register. In this state, the serial interface does not operate although the transfer clock is applied. If STS instruction is executed, the serial interface changes its state to "SCK waiting state".

In the "SCK waiting state", the falling edge of first transfer clock affects the serial interface to get into "transfer state", while the Octal Counter counts-up and the Serial Data Register shifts simultaneously. As an exception, if the clock continuous output mode is selected, the serial interface stays in "SCK waiting state" while the transfer clock outputs continuously.

The Octal Counter becomes " 000 " again by 8 transfer clocks or execution of STS instruction, so that the serial interface gets back into the "SCK waiting state", and SERIAL Interrupt Request Flag is set simultaneously.

When the internal transfer clock is selected, the transfer clock output are triggered by the execution of STS instruction, and it stops after 8 clocks.

## - Example of Transfer Clock Error Detection

The serial interface functions abnormally when the transfer clock was disturbed by external noises. In this case, the transfer
clock error can be detected in the procedure shown in Fig. 12.
If more than 9 transfer clocks are applied by the external noises in the "SCK waiting state", the state of the serial interface shifts as the following sequence: first "transfer state" (while 1 to 7 transfer clocks), second "SCK waiting state" (at 8th transfer clock) and third "transfer state" again. Then reset the SERIAL Interrupt Request Flag, and make "STS waiting state" by writing to the Serial Mode Register. SERIAL Interrupt Request Flag is set again in this procedure, and it shows that the transfer clock was invalid and that the transmit/receive data were also invalid.

Table 10. Serial Interface Operation Mode

| SMR | PMR |  | Serial Interface Operating Mode |
| :---: | :---: | :---: | :--- |
| Bit 3 | Bit 1 | Bit 0 |  |
| 1 | 0 | 0 | Clock Continuous Output Mode |
| 1 | 0 | 1 | Transmit Mode |
| 1 | 1 | 0 | Receive Mode |
| 1 | 1 | 1 | Transmit/Receive Mode |




Fig. 12 Example of Transfer Clock Error Detection

- TIMER

The MCU contains a prescaler and two timer/counters (TIMER-A, TIMER-B), Fig. 13 shows the block diagram. The prescaler is an 11-bit binary counter. TIMER-A is an 8 -bit free-running timer. TIMER-B is an 8 -bit auto-reload timer/ event counter.

## - Prescaler

The input to the prescaler is a system clock signal. The prescaler is initialized to $\$ 000$ by MCU reset, and the prescaler starts to count up the system clock signal as soon as RESET input goes to logic " 0 ". The prescaler keeps counting up except MCU reset and stop mode. The prescaler provides clock signals to TIMER-A, TIMER-B and serial interface. The prescaler devide ratio of the clock signals are selected according to the content of the mode registers such as - Timer Mode Register A (TMA), Timer Mode Register B (TMB), Serial Mode Register (SMR).


Fig. 13 Timer/Counter Block Diagram

## - TIMER-A Operation

After TIMER-A is initialized to $\$ 00$ by MCU reset, it counts up at every clock input signal. When the next clock signal is applied after TIMER-A is counted up to \$FF, TIMER-A is set to $\$ 00$ again, and generating overflow output. This leads to setting TIMER-A Interrupt Request Flag (IFTA: \$001, 2) to " 1 ". Therefore, this timer can function as an interval timer periodically generating overflow output at every 256th clock signal input.

The clock input signals to TIMER-A are selected by the Timer Mode Register A (TMA: \$008).

## - TIMER-B Operation

Timer Mode Register B (TMB: \$009) is used to select the auto-reload function and the prescaler divide ratio of TIMER-B as the input clock source. When the external event input is used as an input clock signal to TIMER-B, select the $\mathrm{R}_{33} /$ INT $_{1}$ as $\overline{\mathrm{INT}}_{1}$ and set the External Interrupt Mask (IM1) to " 1 " to prevent the external interrupt request from occurring.

TIMER-B is initialized according to the value written into the Timer Load Register by software. TIMER-B counts up at every clock input signal. When the next clock signal is applied to TIMER-B after TIMER-B is set to \$FF, TIMER-B will be initialized again and generate overflow output. In this case if the auto-reload function is selected. TIMER-B is initialized according to the value of the Timer Load Register. Else if the autoreload function is not selected, TIMER-B goes to $\$ 00$. TIMERB Interrupt Request Flag (IFTB: $\$ 002,0$ ) will be set at this overflow output.

- Timer Mode Register A (TMA: \$008)

The Timer Mode Register A is a 3-bit write-only register. The TMA controls the prescaler divide ratio of TIMER-A clock input, as shown in Table 11.

The Timer Mode Register A is initialized to $\$ 0$ by MCU reset.

## - Timer Mode Register B (TMB: \$009)

The Timer Mode Register B is a 4 -bit write-only register. The Timer Mode Register B controls the selection for the autoreload function of TIMER-B and the prescaler divide ratio, and the source of the clock input signal, as shown in Table 12.

The Timer Mode Register B is initialized to $\$ 0$ by MCU reset.
The operation mode of TIMER-B is changed at the second instruction cycle after writing into the Timer Mode Register B.

Therefore, it is necessary to program the write instruction to TLRU after the content of TMB is changed.

Table 11. Timer Mode Register $\mathbf{A}$

| TMA |  |  | Prescaler Divide Ratio |
| :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 |  |
| 0 | 0 | 0 | $\div 2048$ |
| 0 | 0 | 1 | $\div 1024$ |
| 0 | 1 | 0 | $\div 512$ |
| 0 | 1 | 1 | $\div 128$ |
| 1 | 0 | 0 | $\div 32$ |
| 1 | 0 | 1 | $\div 8$ |
| 1 | 1 | 0 | $\div 4$ |
| 1 | 1 | 1 | $\div$ |

Table 12. Timer Mode Register B

| TMB |  | Auto-reload Function |  |
| :---: | :---: | :---: | :---: |
| Bit 3 |  | No |  |
| 0 |  | Yes |  |
| 1 |  | Prescaler Divide Ratio, <br> Clock Input Source |  |
| TMB |  |  |  |
| Bit 2 | Bit 1 | Bit 0 | $\div 2048$ |
| 0 | 0 | 0 | $\div 512$ |
| 0 | 0 | 1 | $\div 128$ |
| 0 | 1 | 0 | $\div 32$ |
| 0 | 1 | 1 | $\div$ |
| 1 | 0 | 0 | $\div$ |
| 1 | 0 | 1 | 4 |
| 1 | 1 | 0 | $\div$ |
| 1 | 1 | 1 | INT $_{1}$ |

- TIMER-B (TCBL: \$00A, TCBU: \$00B)
(TLRL: \$00A, TLRU: \$00B)
TIMER-B consists of an 8 -bit write-only Timer Load Regisier, and an 8 -bit read-only Timer/Event Counter. Each of them has a low-order digit (TCBL: \$00A, TLRL: \$00A) and a highorder digit (TCBU: \$00B, TLRU: \$00B).

The Timer/Event Counter can be initialized by writing data into the Timer Load Register. In this case, write the low-order digit first, and then the high-order digit. The Timer/Event Counter is initialized at the time when the high-order digit is written. The Timer Load Register will be initialized to $\$ 00$ by the MCU reset.

The counter value of TIMER-B can be obtained by reading
the Timer/Event Counter. In this case, read the high-order digit first, and then the low-order digit. The count value of low-order digit is latched at the time when the high-order digit is read.

- TIMER-A Interrupt Request Flag (IFTA: \$001, 2)

The TIMER-A Interrupt Request Flag is set by the overflow output of TIMER-A.

- TIMER-A Interrupt Mask (IMTA: \$001, 3)

TIMER-A Interrupt Mask prevents an interrupt request generated by TIMER-A Interrupt Request Flag.

Table 13. TIMER-A Interrupt Request Flag

| TIMER-A Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 14. TIMER-A Interrupt Mask

| TIMER-A Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

- TIMER-B Interrupt Request Flag (IFTB: \$002, 0)

The TIMER-B Interrupt Request Flag is set by the overflow output of TIMER-B.

- TIMER-B Interrupt Mask (IMTB: \$002, 1)

TIMER-B Interrupt Mask prevents an interrupt request generated by TIMER-B Interrupt Request Flag.


Fig. 14 Mode Register Configuration and Function

Table 15. TIMER-B Interrupt Request Flag

| TiMER-B Interrupt <br> Request Flag | Interrupt Request |
| :---: | :---: |
| 0 | No |
| 1 | Yes |

Table 16. TIMER-B Interrupt Mask

| TIMER-B Interrupt <br> Mask | Interrupt Request |
| :---: | :---: |
| 0 | Enable |
| 1 | Disable (Mask) |

## - INPUT/OUTPUT

The MCU provides 58 Input/Output pins, and they are consist of 32 standard pins and 26 high voltage pins. Each standard pin may have one of three mask options: (A) "Without pullup MOS (NMOS open drain)", (B) "With pull-up MOS", or (C) "CMOS". And also each high voltage pin may have one of two mask options: (D) "Without pull-down MOS (PMOS
open drain)", or (E) "With pull-down MOS". As pull-down MOS is connected to internal $V_{\text {disp }}$ line, select $\mathrm{R}_{\mathrm{Al}} / \mathrm{V}_{\text {disp }}$ pin as $\mathrm{V}_{\text {disp }}$ with mask option when at least one high voltage pin is selected as "With pull-down MOS" option.

When any Input/Output common pin is used as input pin, it is necessary to select the mask option and output data as shown in Table 18.

## - Output Circuit Operation of Standard Pins with 'With pull-

 - up MOS" OptionFig. 15 shows the circuit used in the standard pins with "with pull-up MOS"option.

By execution of the output instruction, the write pulse will be generated, and be applied to the addressed port. This pulse will turn "ON" the PMOS (B) to make the transient time shorten to obtain "High level", if the output data is changed from " 0 " to " 1 ". In this case, the "write pulse" allows the PMOS (B) to turn "ON" as long as $1 / 8$ instruction cycle. While "write pulse" is " 0 ", pull-up MOS (C) may retain the output in high level.

The $\overline{H L T}$ signal becomes " 0 " in stop mode, so that MOS (A) (B) (C) turn "OFF".


Output instruction execution


Fig. 15 Output Circuit Operation of Standard Pins with "with Pull-up MOS" Option

Table 17 I/O Pin Circuit Type


|  |  | Without pull-up MOS (NMOS open drain) or CMOS (A or C) | With pull-up MOS (B) | Applied pins |
| :---: | :---: | :---: | :---: | :---: |
|  | I/O common pins |  |  | $\overline{\text { SCK }}$ |
|  | Output pins |  |  | SO |
|  | Input pins |  |  | $\overline{\mathrm{NT}} \mathrm{N}_{0}$ $\overline{\mathrm{INT}}{ }_{1}$, SI |

(Note) In the stop mode, $\overline{\mathrm{HLT}}$ signal is " 0 ", HLT signal is " 1 " and I/O pins are in high impedance state.

Table 18 Data Input from Input/Output Common Pins

| I/O pin circuit type |  | Possibility <br> of Input | Available pin condition <br> for input |
| :--- | :--- | :---: | :---: |
| Standard <br> pins | CMOS | No | - |
|  | Without pull-up <br> MOS <br> (NMOS open drain) | Yes | $" 1 "$ |
|  | With pull-up MOS | Yes | " 1 " |
| High <br> voltage <br> pins | Without pull-down <br> MOS <br> (PMOS open drain) | Yes | "0" |
|  | With pull-down <br> MOS | Yes | "0" |

## - D-port

D-port is 1 -bit I/O port, and it has 16 Input/Output common pins. It can be set/reset by the SED/RED and SEDD/REDD instructions, and can be tested by the TD and TDD instructions. Table 17 shows the classification of standard pins, high voltage pins and the Input/Output pins circuit types.

## - R-port

R-port is 4-bit I/O port. It provides 20 input/output common pins, 16 output-only pins, and 6 input-only pins. Data input is processed using the LAR and LBR instructions and data output is processed using the LRA and LRB instructions. The MCU will not be affected by writing into the input-only and/or non-existing ports, invalid data will be read by reading from the
output-only and/or non-existing ports.
The $\mathrm{R}_{32}, \mathrm{R}_{33}, \mathrm{R}_{40}, \mathrm{R}_{41}$ and $\mathrm{R}_{42}$ pins are also used as the $\overline{\mathrm{INT}}{ }_{0}$, $\overline{\mathrm{INT}_{1}}, \overline{\mathrm{SCK}}, \mathrm{SI}$ and SO pins respectively. Table 17 shows the classification of standard pins, high voltage pins and Input/ Output pins circuit types.

## - RESET

The MCU is reset by setting RESET pin to " 1 ". At power ON or recovering from stop mode, apply RESET input more than $t_{R C}$ to obtain the necessary time for oscillator stabilization. In other cases, the MCU reset requires at least two instructions cycle time of RESET input.

Table 19 shows initialized items by MCU reset and each status after reset.

Table 19 Initial Value by MCU Reset

| Items |  |  | Initial value by MCU reset | Contents |
| :---: | :---: | :---: | :---: | :---: |
| Program counter (PC) |  |  | \$0000 | Execute program from the top of ROM address. |
| Status (ST) |  |  | "1" | Enable to branch with conditional branch instructions. |
| Stack pointer (SP) |  |  | \$3FF | Stack level is 0. |
| I/O pin output register | Standard pin | (A) Without pullup MOS | "1" | Enable to input. |
|  |  | (B) With pull-up MOS | "1" | Enable to input |
|  |  | (C) CMOS | "1" | - |
|  | High voltage pin | (D) Without pulldown MOS | "0" | Enable to input. |
|  |  | (E) With pulldown MOS | "0" | Enable to input. |
| Interrupt flag | Interrupt Enable Flag (1/E) |  | "0" | Inhibit all interrupts. |
|  | Interrupt Request Flag (IF) |  | " 0 " | No interrupt request. |
|  | Interrupt Mask (IM) |  | "1" | Mask interrupt request. |
| Mode register | Port Mode Register (PMR) |  | "0000" | See Item "Port Mode Register". |
|  | Serial Mode Register (SMR) |  | "0000" | See Item "Serial Mode Register". |
|  | Timer Mode Register A (TMA) |  | '000" | See Item "Timer Mode Register $\mathrm{A}^{\prime \prime}$. |
|  | Timer Mode Register B (TMB) |  | "0000" | See Item "Timer Mode Register B". |
| Timer/Counter, Serial interface | Prescaler |  | \$000 | - |
|  | Timer/Counter A (TCA) |  | \$00 | - |
|  | Timer/Event Counter B (TCB) |  | \$00 | - |
|  | Timer Load Register (TLR) |  | \$00 | - |
|  | Octal Counter |  | '000" | - |

(Note) MCU reset affects to the rest of registers as follows:

| Item | After recovering from STOP mode by MCU reset | After MCU reset except for the left condition |
| :---: | :---: | :---: |
| Carry (CA) | The contents of the items before MCU reset are not retained. It is necessary to intialize them by software again. | The contents of the items before MCU reset are not retained. <br> It is necessary to initialize them by software again. |
| Accumulator (A) |  |  |
| B Register (B) |  |  |
| W Register (W) |  |  |
| X/SPX Registers (X/SPX) |  |  |
| Y/SPY Registers (Y/SPY) |  |  |
| Serial Data Register (SR) | Same as above | Same as above |
| RAM | The contents of RAM before MCU reset (just before STOP instruction) are retained. | Same as above |

- INTERNAL OSCILLATOR CIRCUIT

Fig. 16 gives internal oscillator circuit. The oscillator type
can be selected from a crystal oscillator or a ceramic filter oscillator. In any cases, external clock operation is available.


Fig. 16 Internal Oscillator Circuit

- Oscillator Circuit

Table 20 Examples of Oscillator Circuit

|  | Circuit configuration | Remarks |
| :---: | :---: | :---: |
| External clock operation | Oscillator |  |
| Ceramic filter oscillator |  | Ceramic filter CSA2.000MK (Murata) <br> Rf: $1 \mathrm{M} \Omega \pm 2 \%$ <br> C1: 30pF $\pm 20 \%$ <br> $\mathrm{C}_{2}: \mathbf{3 0 p F} \pm \mathbf{2 0 \%}$ <br> - Wiring between these pins and elements should be as short as possible and never cross the other wirings. (Refer to Fig. 17) |
| Crystal oscillator | GND <br> GT cut parallel resonance crystal | $\begin{aligned} & R f: 2 M \Omega \pm 2 \% \\ & C_{1}: 10 \sim 22 p F \pm 20 \% \\ & C_{2}: 10 \sim 22 p F \pm 20 \% \end{aligned}$ <br> Crystal: GT cut parallel resonance crystal <br> $\mathrm{C}_{\mathrm{o}}$ : 7pF max. <br> $R_{s}: 100 \Omega$ max. $f: 2.0 \sim 2.25 \mathrm{MHz}$ <br> - Wiring between these pins should be as short as possible, and never cross the other wirings. (Refer to Fig. 17) |

Note) Please consult with the engineers of erystal or ceramic filter maker to determine the value of $\mathbf{R}_{\mathrm{f}}, \mathrm{C}_{\mathbf{1}}$ and $\mathrm{C}_{\mathbf{2}}$.


- LOW POWER DISSIPATION MODE

The MCU provides two low power dissipation modes, that is, a Standby mode and a Stop mode. Table 21 shows the function of the low power dissipation mode, and Fig. 18 shows the diagram of the mode transition.

Fig. 17 Recommendable Layout of Crystal and Ceramic Filter
Table 21 Low Power Dissipation Mode Function

| Low Power Dissipation Mode | Instruction | Condition |  |  |  |  |  |  | Recovering method |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Oscillator circuit | Instruction execution | Register, Flag | Interrupt function | RAM | Input/ Output pin | Timer Counter, Serial Interface |  |
| Standby mode | $\begin{aligned} & \hline \text { SBY } \\ & \text { instruction } \end{aligned}$ | Active | Stop | Retained | Active | Retained | Retained ${ }^{\text {3) }}$ | Active | RESET Input, Interrupt request |
| Stop mode | STOP instruction | Stop | Stop | RESET ${ }^{\text {® }}$ | Stop | Retained | $\begin{gathered} \text { High }{ }^{21} \\ \text { impedance } \end{gathered}$ | Stop | RESET Input |

*1) As the MCU recovers from STOP mode by RESET input, the contents of the flags and registers are initialized according to Table 19.
*2) A high voltage pin with a pull-down MOS option is pulled down to the $V_{\text {disp }}$ power supply by the pull-down MOS. As the MOS is ON, a pulldown MOS current flows when a voltage difference between the pin and the $V_{\text {disp }}$ voltage exists. This is the additional current to the current dissipation in Stop Mode (1stop).
*3) As a $1 / O$ circuit is active, a $1 / O$ current possibly flows according the state of $1 / O$ pin. This is the additional current to the current dissipation in Standby Mode (ISBY1, ISBY2).


Fig. 18 MCU Operation Mode Transition

## - Standby Mode

The SBY instruction puts the MCU into the Standby mode. In the Standby mode, the oscillator circuit is active and timer/
counter and serial interface continue working. On the other hand, the CPU stops since the clock related to the instruction execution stops. Registers, RAM and Input/Output pins retain the state they had just before going into the Standby mode.

The Standby mode is canceled by the MCU reset or interrupt request. When canceled by the interrupt request, the MCU becomes an active mode and executes the instruction next to the SBY instruction. At this time, if the Interrupt Enable Flag is " 1 ", the interrupt is executed. If the Interrupt Enable Flag is " 0 ", the interrupt request is held on and the normal instruction execution continues.

Fig. 19 shows the flowchart of the Standby Mode.

## - Stop Mode

The STOP instruction brings the MCU into the Stop mode. In this mode the oscillator circuit and every function of the MCU stop.

The Stop mode is canceled by the MCU reset. At this time, as shown in Fig. 20, apply the RESET input for more than $\mathrm{t}_{\mathrm{RC}}$ to get enough oscillator stabilization time. (Refer to the "AC CHARACTERISTICS".) After the Stop mode is canceled, RAM retains the state it had just before going into the Stop mode. The other hand, Accumulator, B Register, W Register, X/SPX Registers, Y/SPY Registers, Carry and Serial Data Register don't retain the contents.


Fig. 19 MCU Operating Flowchart


Fig. 20 Timing Chart of Recovering from Stop Mode

## RAM ADDRESSING MODE

As shown in Fig. 21, the MCU provides three RAM addressing modes; Register Indirect Addressing, Direct Addressing and Memory Register Addressing.

- Register Indirect Addressing

The combined 10-bit contents of W Register, X Register and Y Register is used as the RAM address in this mode.

## - Direct Addressing

The direct addressing instruction consists of two words and the second word ( 10 bits) following Op-code (the first word) is used as the RAM address.

## - Memory Register Addressing

The Memory Register Addressing can access 16 digits (Memory Register: MR) from $\$ 020$ to $\$ 02 \mathrm{~F}$ by using the LAMR and XMRA instruction.

RAM Address

(a) Register Indirect Addressing

(b) Direct Addressing

(c) Memory Register Addressing

Fig. 21 RAM Addressing Mode

## - ROM ADDRESSING MODE AND P INSTRUCTION

The MCU has four kinds of ROM addressing modes as shown in Fig. 22.

## - Direct Addressing Mode

The program can branch to any addresses in the ROM memory space by using JMPL, BRL or CALL instruction. These instruction replace 14 -bit program counter ( $\mathrm{PC}_{13}$ to $\mathrm{PC}_{0}$ ) with 14 -bit immediate data.

## - Current Page Addressing Mode

ROM memory space is divided into 256 words in each page starting from $\$ 0000$. The program branches to the address in the same page using BR instruction. This instruction replace the low-order eight bits of program counter ( $\mathrm{PC}_{7}$ to $\mathrm{PC}_{0}$ ) with 8 -bit immediate data. The branch destination by BR
instruction on the boundary between pages is in the next page. Refer to Fig. 24.

## - Zero Page Addressing Mode

The program branches to the zero page subroutine area, which is located on the address from $\$ 0000$ to $\$ 003 \mathrm{~F}$, using CAL instruction. When CAL instruction is executed, 6-bit immediate data is placed in low-order six bits of program counter ( $\mathrm{PC}_{5}$ to $\mathrm{PC}_{0}$ ) and " 0 's" are placed in high-order eight bits $\left(\mathrm{PC}_{13}\right.$ to $\left.\mathrm{PC}_{6}\right)$.

## - Table Data Addressing

The program branches to the address determined by the contents of the 4 -bit immediate data, accumulator and $B$ register, using TBR instruction.

(a) Direct Addressing

(b) Current Page Addressing

(c) Zero Page Addressing

(d) Table Data Addressing

Fig. 22 ROM Addressing Mode

(a) Address Designation

(b) Pattern Output

Fig. 23 P Instruction

## - P Instruction

The P instruction refers ROM data addressed by Table Data Addressing. ROM data addressed also determine its destination. When bit 8 in referred ROM data is " 1 ", 8 bits of referred


Fig. 24 The Branch Destination by BR Instruction on the Boundary between Pages

Table 22. Immediate Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | $\begin{aligned} & \text { WORD } \\ & \text { CYCLE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Immediate | LAI i | $100011 i_{3} i_{2} i_{1} i_{0}$ | $\boldsymbol{\longrightarrow} \longrightarrow \mathrm{A}$ |  | 1/1 |
| Load B from Immediate | LBI i | $100000 i_{3} i_{2} i_{1} i_{0}$ | $\longrightarrow B$ |  | 1/1 |
| Load Memory from Immediate | LMID i,d |  | $\longmapsto \mathrm{M}$ |  | 2/2 |
| Load Memory from Immediate, Increment $Y$ | LMIIY i | $101001 i_{3} i_{2} i_{1} i_{0}$ | $i \rightarrow M, Y+1 \rightarrow Y$ | NZ | 1/1 |

Table 23. Register-to-Register Instruction


Table 24. RAM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | $\begin{aligned} & \text { WORD } \\ & \text { TYCLE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load W from Immediate | LWI i | $00111100 i_{1} i_{0}$ | $\longmapsto W$ |  | 1/1 |
| Load $X$ from Immediate | LXI i | $100010 i_{3} i_{2} i_{1}$ io | $\xrightarrow{\longrightarrow} \mathrm{X}$ |  | 1/1 |
| Load $Y$ from Immediate | LYI i | $100001 i_{3} i_{2} i_{1} i_{0}$ | $\xrightarrow{\longrightarrow} \mathrm{Y}$ |  | 1/1 |
| Load $X$ from $A$ | LXA | 0011101000 | $A \longrightarrow X$ |  | 1/1 |
| Load $Y$ from $A$ | LYA | 0011011000 | $A \longrightarrow Y$ |  | 1/1 |
| Increment $Y$ | IY | 0001011100 | $Y+1 \rightarrow Y$ | NZ | 1/1 |
| Decrement $Y$ | DY | 0011011111 | $Y-1 \rightarrow Y$ | NB | 1/1 |
| Add A to Y | AYY | 0001010100 | $Y+A \rightarrow Y$ | OVF | 1/1 |
| Subtract $A$ from $Y$ | SYY | 0011010100 | $Y-A \rightarrow Y$ | NB | 1/1 |
| Exchange $X$ and SPX | XSPX | 0000000001 | $X \leftrightarrow S P X$ |  | 1/1 |
| Exchange $Y$ and SPY | XSPY | 0000000010 | $Y \leftrightarrow S P Y$ |  | 1/1 |
| Exchange $X$ and SPX,Y and SPY | XSPXY | 0000000011 | $X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |  | 1/1 |

Table 25. RAM Register Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CyCle |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load A from Memory | LAM (XY) | 00100100 yx |  |  | 1/1 |
| Load A from Memory | LAMD d |  | $M \rightarrow A$ |  | 2/2 |
| Load B from Memory | LBM(XY) | $00010000 y x$ | $M \rightarrow B,\left(\begin{array}{l}X \\ X \sim S P X \\ Y \sim S P Y\end{array}\right)$ |  | 1/1 |
| Load Memory from A | LMA(XY) | 00100101 yx | $\mathrm{A} \rightarrow \mathrm{M},\left(\begin{array}{l}\mathrm{X} \\ \mathrm{X} \times \mathrm{SPX} \\ \mathrm{y} \rightarrow \mathrm{SPY}\end{array}\right)$ |  | 1/1 |
| Load Memory from A | LMAD d |  | $\mathrm{A} \rightarrow \mathrm{M}$ |  | 2/2 |
| Load Memory from $A$, Increment $Y$ | LMAIY(X) | $000101000 \times$ | $A \rightarrow M, Y+1 \rightarrow Y(X \cdot \sim S P X)$ | NZ | 1/1 |
| Load Memory from A, Decrement $Y$ | LMADY(X) | $001101000 x$ | $A \rightarrow M, Y-1 \rightarrow Y(X \sim S P X)$ | NB | 1/1 |
| Exchange Memory and $\mathbf{A}$ | XMA(XY) | 00100000 yx | $M \mapsto A,\left(\begin{array}{l}\text { ( } \\ Y \rightarrow S P X \\ Y\end{array}\right.$ |  | 1/1 |
| Exchange Memory and $\mathbf{A}$ | XMAD d |  | $\mathbf{M} \leftrightarrow \mathbf{A}$ |  | 2/2 |
| Exchange Memory and B | XMB(XY) | 00110000 yx | $\bar{M} \leftrightarrow \mathrm{~B},\binom{\mathrm{X}}{\mathrm{Y} \leftrightarrow \mathrm{SPPY} \mathrm{S}}$ |  | 1/1 |

Note) ( $X Y$ ) and $(X)$ have the meaning as follows:
(1) The instructions with ( $X Y$ ) have 4 mnemonics and 4 object codes for each. (example of LAM ( $X Y$ ) is given below.)

| MNEMONIC | $y$ | $x$ | FUNCTION |
| :--- | :---: | :---: | :---: |
| LAM | 0 | 0 |  |
| LAMX | 0 | 1 | $X \leftrightarrow S P X$ |
| LAMY | 1 | 0 | $Y \leftrightarrow S P Y$ |
| LAMXY | 1 | 1 | $X \leftrightarrow S P X, Y \leftrightarrow S P Y$ |

(2) The instructions with $(x)$ have 2 mnemonics and 2 object codes for each. (example of LMAIY $(X)$ is given below.)

| MNEMONIC | $x$ | FUNCTION |
| :---: | :---: | :---: |
| LMAIY | 0 |  |
| LMAIYX | 1 | $X \leftrightarrow S P X$ |

Table 26. Arithmetic Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Add Immediate to A | Al i | $101000 i_{3} i_{2} i_{1} i_{0}$ | A $+i \rightarrow A$ | OVF | 1/1 |
| Increment B | IB | 0001001100 | $B+1 \rightarrow B$ | NZ | 1/1 |
| Decrement B | DB | 0011001111 | $B-1 \rightarrow B$ | NB | 1/1 |
| Decimal Adjust for Addition | DAA | 0010100110 |  |  | 1/1 |
| Decimal Adjust for Subtraction | DAS | 0010101010 |  |  | 1/1 |
| Negate A | NEGA | 0001100000 | $\bar{A}+1 \rightarrow A$ |  | 1/1 |
| Complement B | COMB | 0101000000 | $\bar{B} \rightarrow B$ |  | 1/1 |
| Rotate Right A with Carry | ROTR | 0010100000 |  |  | 1/1 |
| Rotate Left A with Carry | ROTL | 0010100001 |  |  | 1/1 |
| Set Carry | SEC | 0011101111 | $1 \rightarrow \mathrm{CA}$ |  | 1/1 |
| Reset Carry | REC | 0011101100 | $0 \rightarrow$ CA |  | $1 / 1$ |
| Test Carry | TC | 0001101111 |  | CA | $1 / 1$ |
| Add A to Memory | AM | 0000001000 | $M+A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory | AMD d | $\mathrm{d}_{9} \mathrm{~d}_{8} \mathrm{~d}_{7} \mathrm{~d}_{6} \mathrm{~d}_{5} \mathrm{~d}_{4} \mathrm{~d}_{3} \mathrm{~d}_{2} \mathrm{~d}_{1} \mathrm{~d}_{0}$ | $\mathrm{M}+\mathrm{A} \rightarrow \mathrm{A}$ | OVF | 2/2 |
| Add A to Memory with Carry | AMC | 0000011000 | $M+A+C A \rightarrow A$ | OVF | 1/1 |
| Add A to Memory with Carry | AMCD d |  | $M+A+C A \rightarrow A$ | OVF | 2/2 |
| Subtract A from Memory with Carry | SMC | 0010011000 | $M-A-\overline{C A} \rightarrow A$ | NB | 1/1 |
| Subtract A from Memory with Carry | SMCD d |  | $\mathrm{M}-\mathrm{A}-\overline{\mathrm{CA}} \rightarrow \mathrm{A}$ | NB | 2/2 |
| OR A and B | OR | 0101000100 | $A \cup B \rightarrow A$ |  | 1/1 |
| AND Memory with A | ANM | 0010011100 | $A \cap M \rightarrow A$ | NZ | 1/1 |
| AND Memory with A | ANMD d |  | $\mathbf{A} \cap \mathbf{M} \rightarrow \mathrm{A}$ | NZ | 2/2 |
| OR Memory with A | ORM | 0000001100 | $A \cup M \rightarrow A$ | NZ | 1/1 |
| OR Memory with A | ORMD d |  | $A \cup M \rightarrow A$ | NZ | 2/2 |
| EOR Memory with A | EORM | 0000011100 | $A \oplus M \rightarrow A$ | NZ | 1/1 |
| EOR Memory with A | EORMD d |  | $\mathrm{A} \oplus \mathrm{M} \rightarrow \mathrm{A}$ | NZ | 2/2 |

Table 27. Compare Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Immediate Not Equal to Memory | INEM i | $0000010 i_{3} i_{2} i_{1} i_{0}$ | $\mathrm{i} \neq \mathrm{M}$ | NZ | $1 / 1$ |
| CYCLE |  |  |  |  |  |

Table 28. RAM Bit Manipulation Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Memory Bit | SEM $n$ | 00100001 nino | $1 \rightarrow \mathrm{M}(\mathrm{n})$ |  | 1/1 |
| Set Memory Bit | SEMD n,d |  | $1 \rightarrow M(n)$ |  | 2/2 |
| Reset Memory Bit | REM n | $00100010 n^{\prime} n_{0}$ | $0 \rightarrow M(n)$ |  | 1/1 |
| Reset Memory Bit | REMD n,d | $\begin{array}{lllllll} \hline 0 & 11 & 0 & 0 & 0 & 1 & 0 \end{array} n_{1} n_{0}$ | $0 \rightarrow M(n)$ |  | 2/2 |
| Test Memory Bit | TM $n$ | $00100011 n^{\prime} n_{0}$ |  | $M(n)$ | 1/1 |
| Test Memory Bit | TMD n,d |  |  | $M(\mathrm{n})$ | 2/2 |

Table 29. ROM Address Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> S |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| CYCLE |  |  |  |  |  |

Table 30. Input/Output Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set Discrete 1/O Latch | SED | 0011100100 | $1 \rightarrow \mathrm{D}(\mathrm{Y})$ |  | 1/1 |
| Set Discrete 1/O Latch Direct | SEDD m |  | $1 \rightarrow \mathrm{D}(\mathrm{m})$ |  | 1/1 |
| Reset Discrete 1/O Latch | RED | 00001110001000 | $\mathrm{O} \rightarrow \mathrm{D}(\mathrm{Y})$ |  | 1/1 |
| Reset Discrete 1/O Latch Direct | REDD m | $10001110 m_{3} m_{2} m_{1} m_{0}$ | $0 \rightarrow \mathrm{D}(\mathrm{m})$ |  | 1/1 |
| Test Discrete 1/O Latch | TD | 00111100000 |  | O(Y) | 1/1 |
| Test Discrete 1/O Latch Direct | TDD m |  |  | $D(\mathrm{~m})$ | 1/1 |
| Load A from R-Port Register | LAR m |  | $R(m) \rightarrow A$ |  | 1/1 |
| Load B from R-Port Register | LBR m | $10001000 m_{3} m_{2} m_{1} m_{0}$ | $R(m) \rightarrow B$ |  | 1/1 |
| Load R-Port Register from A | LRA m |  | $A \rightarrow R(m)$ |  | 1/1 |
| Load R-Port Register from B | LRB m |  | $B \rightarrow R(m)$ |  | 1/1 |
| Pattern Generation | P p |  |  |  | 1/2 |

Table 31. Control Instruction

| OPERATION | MNEMONIC | OPERATION CODE | FUNCTION | STATUS | WORD <br> CYCLE |
| :--- | :---: | :---: | :---: | :---: | :---: |
| No Operation | NOP | 0000000000 |  |  | $1 / 1$ |

Table 32. Op-Code Map


## HMCS404CL

## - MASK OPTION LIST

- Family Name

HMCS404CL

- Package

OP-64S $\square$ FP-64
A; Without Pull-up MOS (NMOS Open Drain)
B; With Pull-up MOS
C; CMOS
D; Without Pull-down MOS (PMOS Open Drain)

| Date of Order |  |
| :--- | :--- |
| Customer |  |
| Dept. |  |
| Name |  |
| ROM Code Name |  |
| LSI TYpe Number <br> (Hitachi's entry) |  |

E; With Pull-down MOS


- $R_{A 1} / V_{\text {disp }}$ (RA1) $\square R_{A 1}$ : Without Pull-down MOS (D) $\square V_{\text {disp }}$ (VDISP)
- Oscillator (OSC) Crystal or Ceramic Filter Oscillator (XTAL)
- Divider (DIV)
- Divide-by 8 (D-8)
$\bullet$ ROM Code Media $\square$ EPROM: Emulator Type $\square$ EPROM: EPROM On-Package Microcomputer Type
Note 1) I/O Options masked by $\square$ are not available.
Note 2) $R_{A 1} / V_{\text {disp }}$ has to be selected as $V_{\text {disp }}$ pin exept the case that all High Voltage Pins are option D.
- PACKAGE DIMENSIONS (Unit: mm)



## COMING SOON...REVISED U.S. EDITION

This publication is an advance copy of technical information prepared in Japan on 4-Bit Single-Chip Microcomputers. A revised U.S. edition is now in production, scheduled for publication in May, 1985.
If you would like to reserve a copy of the U.S. edition, please complete the postage-paid reply card below and mail foday.

## Please Print

## Name

Title

Company

Address
City State
( ${ }^{\text {( }}$,
Telephone
\#U76

## Please Print

Name
Mail/Stop

Title

Company

Address
City
(elephone $\quad$ State


Hitachi America, Ltd.
Semiconductor and IC Sales and Service Division 2210 O’Toole Avenue, Sán Jose, CA 95131
1-408-942-1500


[^0]:    is Mark " $v$ " in " $\square$ " for the selected supply voltage.

[^1]:    " "-" means that the value does not change after execution of the instruction

[^2]:    *"-" means that the value does not change after execution of the instruction.
    *" " $0 / 1$ " means that either " 0 " or " 1 " may be selected.

[^3]:    - Time is based on instruction frequency 200kHz. (One Instruction Cycle Time ( $T_{\text {inst }}$ ) $=\mathbf{5 \mu s}$ )

[^4]:    * "-" means that the value does not change after execution of the instruction.
    * " $0 / 1$ " means that either " 0 " or " 1 " may be selected.

[^5]:    (Caution at the halt time)
    When the LCD-IV goes into halt state, segment terminals $\left(\mathrm{SEG}_{1}\right.$ to $\mathrm{SEG}_{32}$ ) and common terminals ( $\mathrm{COM}_{1}$ to $\mathrm{COM}_{4}$ ) become the same potential and display goes out. However, in order to reduce power consumption during halt, disconnect the voltage applied to liquid crystal power supply $\mathrm{V}_{3}$. Since there are dividing resistors among $\mathrm{V}_{1}, \mathrm{~V}_{2}$, and $\mathrm{V}_{3}$, current of up to $50 \mu \mathrm{~A}$ flows if voltage is applied between VCC and $\mathrm{V}_{3}$ in the same way as normal operation.

[^6]:    - VERSATILE PROGRAM DEVELOPMENT SUPPORT TOOLS
    - H68SD Series Macro Assembler
    - H68SD5-use Emulator (With Real Time Trace Function)
    - EPROM On Package Microcomputer

    Mask options àre fixed as follows:

    - I/O pin : Open Drain
    - Oscillator: Crystal Oscillator or Ceramic Filter Oscillator (externally drivable)
    - Divider : Divide-by-8

[^7]:    - Program Area ...... \$0000 to \$0FFF

[^8]:    - $R_{A 1} / V_{\text {disp }}$ (RA1) $\square R_{A 1}$ : Without Pull-down MOS (D)
    - Oscillator (OSC)
    - Crystal or Ceramic Filter

    Oscillator (XTAL)

    - Divider (DIV)
    - Divide-by 8 (D-8)
    -ROM Code Media $\square$ EPROM: Emulator Type
    ㅁ $V_{\text {disp }}$ (VDISP)
    - Resistor Oscillator (RF)
    [ EPROM: EPROM On-Package Microcomputer Type
    Note 1) 1/O Options masked by $\ldots$, are not available.

[^9]:    $\mathrm{PC}_{13}$ to $\mathrm{PC}_{0}$; Program Counter
    ST; Status
    CA; Carry

[^10]:    * Please consult with the engineers of crystal or ceramic filter resonator maker to determine the value of $\mathbf{R}_{\mathrm{f}}, \mathrm{C}_{1}$ and $\mathrm{C}_{\mathbf{2}}$.

[^11]:    Note) Please consult with the engineers of crystal or ceramic filter maker to determine the value of $R_{f}, C_{1}$ and $C_{2}$.

