## (0) HITACHI ${ }^{\circ}$ <br> 8/16-BIT MICROPROCESSOR DATA BOOK



## 8/16-BIT MICROPROCESSOR DATA BOOK

## MEDICAL APPLICATIONS

Hitachi's products are not authorized for use in MEDICAL APPLICATIONS, including, but not limited to, use in life support devices without the written consent of the appropriate officer of Hitachi's sales company. Buyers of Hitachi's products are requested to notify Hitachi's sales offices when planning to use the products in MEDICAL APPLICATIONS.

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.
5. Circuitry and other examples described herein are meant merely to indicate characteristics and performance of Hitachi semiconductorapplied products. Hitachi assumes no responsibility for any patent infringements or other problems resulting from applications based on the examples described herein.
6. No license is granted by implication or otherwise under any patents or other rights of any third party or Hitachi, Ltd.

## CONTENTS

GENERAL INFORMATION

- Quick Reference Guide ..... VIII
- Introduction of Packages ..... 1
- Reliability and Quality Assurance ..... 11
- Reliability Test Data of Microcomputer ..... 17
- Program Development and Support System ..... 23
DATA SHEETS
- NMOS 8-Bit Microprocessor HD6802 Microprocessor with Clock and RAM ..... 30
HD6802W Microprocessor with Clock and RAM ..... 43
HD6803 Micro Processing Unit ..... 56
HD6809 Micro Processing Unit ..... 83
HD6809E Micro Processing Unit ..... 115
- CMOS 8-Bit Microprocessor
HD6303R Micro Processing Unit ..... 151
HD6303X Micro Processing Unit ..... 185
HD6303Y Micro Processing Unit ..... 224
HD6305X2 Micro Processing Unit ..... 268
HD63B09 Micro Processing Unit ..... 302
HD63B09E Micro Processing Unit ..... 348
HD64180R Micro Processing Unit ..... 385
- 16-Bit Microprocessor
HD68000 Micro Processing Unit (NMOS) ..... 519
HD68HC000 Micro Processing Unit (CMOS) ..... 519
- Hitachi Sales Offices ..... 606


## GENERAL <br> INFORMATION

- Quick Reference Guide
- Introduction of Packages
- Reliability and Quality Assurance
- Reliability Test Data of Microcomputer
- Program Development and Support System


## QUICK REFERENCE GUIDE

- NMOS 8-BIT MICROPROCESSOR

| Type No. | HD6802 | HD6802W | $\begin{aligned} & \text { HD6803 } \\ & \text { HD6803-1 } \end{aligned}$ | $\begin{aligned} & \text { HD6809 } \\ & \text { HD68A09 } \\ & \text { HD68B09 } \end{aligned}$ | HD6809E <br> HD68A09E <br> HD68B09E |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Frequency (MHz) | 1.0 | 1.0 | $\begin{aligned} & 1.0 \text { (HD6803) } \\ & 1.25 \text { (HD6803.1) } \end{aligned}$ | 1.0 (HD6809) 1.5 (HD68A09) 2.0 (HD68B09) | 1.0 (HD6809E) <br> 1.5 (HD68A09E) <br> 2.0 (HD68B09E) |
| Supply Voltage (V) | 5.0 | 5.0 | 5.0 | 5.0 | 5.0 |
| Operating Temperature* <br> ( ${ }^{\circ} \mathrm{C}$ ) | -20~+75 | -20~+75 | 0~+70 | $-20 \sim+75$ | $-20 \sim+75$ |
| RAM (byte) | 128 | 256 | 128 | - | - |
| Oscillator | Yes | Yes | Yes | Yes | - |
| Package | DP-40 | DP-40 | DP-40 | DP-40 | DP-40 |
| Features | - Internal oscillator and RAM added to the HD6800 <br> - 32 byte RAM Battery backed up possible |  | - Upward instruction compatibil ity with the HD6800 <br> - On-chip SCI and timer | - The highest version of the HMCS6800 family <br> - Powerful addressing modes <br> - Easy relocatable/reentrant programming | - Full software compatibility with the HD6809 <br> - Bus employment on time sharing basis <br> - External clock |
| Compatibility | MC6802 | - | MC6803 <br> MC6803-1 | $\begin{aligned} & \text { MC6809 } \\ & \text { MC68A09 } \\ & \text { MC68B09 } \end{aligned}$ | MC6809E <br> MC68A09E <br> MC68B09E |
| Reference Page | 30 | 43 | 56 | 83 | 115 |



- CMOS 8-BIT MICROPROCESSOR

| Type No. | HD6303R HD63A03R HD63B03R | $\begin{aligned} & \text { HD6303X } \\ & \text { HD63A03X } \\ & \text { HD63B03X } \end{aligned}$ | HD6303Y HD63A03Y HD63B03Y HD63C03Y |
| :---: | :---: | :---: | :---: |
| Clock Frequency (MHz) | 1.0 (HD6303R) <br> 1.5 (HD63A03R) <br> 2.0 (HD63B03R) | 1.0 (HD6303X) <br> 1.5 (HD63A03X) <br> 2.0 (HD63B03X) | 1.0 (HD6303Y) 1.5 (HD63A03Y) 2.0 (HD63B03Y) 3.0 (HD63C03Y) |
| Supply Voltage (V) | 5.0 | 5.0 | 5.0 |
| Operating Temperature* ( ${ }^{\circ} \mathrm{C}$ ) | $0 \sim+70$ | $0 \sim+70$ | $0 \sim+70$ |
| RAM (byte) | 128 | 192 | 256 |
| External Memory Expansion (byte) | 65k | 65k | 65k |
| Package | $\begin{aligned} & \text { DP-40, FP-54, } \\ & \text { CG-40, CP-52 } \end{aligned}$ | $\begin{aligned} & \text { DP-64S, FP-80, } \\ & \text { CP-68 } \end{aligned}$ | $\begin{aligned} & \text { DP-64S, FP-64, } \\ & \text { CP-68 } \end{aligned}$ |
| Features | - On-chip timer and synchronous/asynchronous SCI <br> - Upward instruction compatibility with the HD6800 <br> - Low power consumption modes (sleep and standby) |  |  |
| Reference Page | 151 | 185 | 224 |

*Wide Temperature Range ( $-40 \sim+85^{\circ} \mathrm{C}$ ) version is available. $C P / M^{\circledR}$ is the registered trade mark of Digital Research Inc.

| HD6305X2 HD63A05X2 HD63B05X2 | HD6305Y2 HD63A05Y2 HD63B05Y2 | HD63B09/E HD63C09/E | HD64180R | HD64180R |
| :---: | :---: | :---: | :---: | :---: |
| 1.0 (HD6305X2) <br> 1.5 (HD63A05X2) <br> 2.0 (HD63B05X2) | 1.0 (HD6305Y2) <br> 1.5 (HD63A05Y2) <br> 2.0 (HD63B05Y2) | $\begin{aligned} & 2.0 \text { (HD63B09/E) } \\ & 3.0 \text { (HD63C09/E) } \end{aligned}$ | 6.0 (HD64180RP-6) <br> 8.0 (HD64180RP-8) | 6.0 (HD64180RCP-6X) <br> 8.0 (HD64180RCP-8X) |
| 5.0 | 5.0 | 5.0 | 5.0 | 5.0 |
| $0 \sim+70$ | $0 \sim+70$ | $-20 \sim+75$ | $0 \sim+70$ | $0 \sim+70$ |
| 128 | 256 | - | - | - |
| 16k | 16k | 65k | 512k | 1M |
| DP-64S, FP-64 | DP-64S, FP-64 | DP-40 | DP-64S | CP-68 |
| - On-chip timer and <br> - Powerful bit manip <br> - Low power consum (wait, stop and sta | hronous SCl on instruction modes ) | - Software compatibility with the HD6809/E <br> - Easy relocatable/ reentrant programming <br> - Flexible system expansion capabilities | - On-chip MMU, DMAC, synchronous/ asynchronous SCI and timer <br> - Software compatibility with Z80/8080 |  |
| 268 | 268 | 302/348 | 385 | 385 |

## QUICK REFERENCE GUIDE

- NMOS 16-BIT MICROPROCESSOR

| Type No. | HD68000-8 HD68000-10 HD68000-12 | HD68000Y8 HD68000Y10 HD68000Y12 | HD68000P8 | HD68000PS8 | HD68000CP8 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Frequency (MHz) | $\begin{array}{c\|} \hline \text { 8.0(HD68000-8) } \\ 10.0(H D 68000-10) \\ 12.5(\text { HD68000-12) } \end{array}$ | 8.0(HD68000Y8) $10.0(\mathrm{HD} 68000 \mathrm{Y}-10)$ $12.5(\mathrm{HD} 68000 \mathrm{Y}-12)$ | 8.0(HD68000R8) | 8.0(HD68000PS8) | 8.0(HD68000CR8) |
| Supply Voltage (V) | 5.0 |  |  |  |  |
| Operating Temperature ( ${ }^{\circ} \mathrm{C}$ ) | $0 \sim+70$ |  |  |  |  |
| Power Dissipation (W) | $\begin{gathered} 1.5(f=6 \mathrm{MHz}, 8 \mathrm{MHz}, 10 \mathrm{MHz}), \\ 1.75(f=12.5 \mathrm{MHz}) \end{gathered}$ |  | $0.9(f=8 \mathrm{MHz})$ |  |  |
| Package | DC-64 | PGA-68 | DP-64 | DP-64S | CP-68 |
| Feature | High performance MPU featuring 32-bit data processing function |  |  |  |  |
| Compatibility | MC68000L6 <br> MC68000L8 <br> MC68000L 10 <br> MC68000L12 | MC68000R6 MC68000R8 MC68000R10 MC68000R12 | MC68000P6 MC68000P8 |  | MC68000FN6 MC68000FN8 |
| Reference Page | 519 | 519 | 519 | 519 | 519 |

- CMOS 16-BIT MICROPROCESSOR

| Type No. | HD68HC000-8 HD68HC000-10 HD68HCOOO-12 | HD68HC000Y8 HD68HC000K-10 HD68HCOOOY-12 | HD68HC000P8 HD68HC000P10 HD68HCOOOR12 | HD68HC000PS8 HD68HCOOOPS10 HD68HC000PST2 | HD68HCOOOCR8 HD68HCOOOCP10 HD68HCOOOCP12 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Frequency (MHz) | 8.0(HD68HCOOO-8) $10.0(\mathrm{HD} 68 \mathrm{HCOOO-10})$ $12.5(\mathrm{HD} 68 \mathrm{HCOOO}-12)$ | 8.0(HD68HC000K8) 10.0(HD68HC000Y10) 12.5(HD68HCOOOY12) | 8.0(HD68HC000R8) 10.0(HD68HC000P10) 12.5(HD68HC000R12) | 8.0(HD68HC000PS8) 10.0(HD68HC000PS90) 12.5(HD68HC000PS12) | 8.0(HD68HC000CR8) 10.0(HD68HCOOOCP40) 12.5(HD68HCOOOCP12) |
| Supply <br> Voltage <br> (V) | 5.0 |  |  |  |  |
| Operating Temperature ( ${ }^{\circ} \mathrm{C}$ ) | $0 \sim+70$ |  |  |  |  |
| Current <br> Dissipa- <br> tion (mA) | $\left.\begin{array}{l} 25(f=8 \\ 30(f=10 \end{array} \mathrm{MHz}\right)$ |  |  |  |  |
| Package | DC-64 | PGA-68 | DP-64 | DP-64S | CP-68 |
| Feature | High performance MPU featuring 32-bit data processing function |  |  |  |  |
| Compatibility | MC68HCOOOL8 <br> MC68HC000L10 <br> MC68HC000L12 | MC68HCOOOR8 MC68HC000R10 MC68HC000R12 | MC68HC000G8 MC68HC000G10 MC68HC000G12 |  | MC68HC000FN8 MC68HCOOOFN10 MC68HCOOOFN12 |
| Reference Page | 519 | 519 | 519 | 519 | 519 |

Hitachi microcomputer devices include various types of package which meet a lot of requirements such as ever smaller, thinner and more versatile electric appliances. When selecting a package suitable for the customers' use, please refer to the following for Hitachi microcomputer packages.

## 1. Package Classification

There are pin insertion types, surface mounting types and
multi-function types, applicable to each kind of mounting method. Also, plastic and ceramic materials are offered according to use.

Fig. 1 shows the package classification according to the mounting types on the Printed Circuit Board (PCB) and the materials.


Fig. 1 Package Classification according to the Mounting Type on the Printed Circuit Board and the Materials.

## 2. Type No. and Package Code Indication

Type No. of Hitachi microprocessor is followed by package material and outline specifications, as shown below. The package type used for each device is identified by code as follows, illus-
trated in the data sheet of each device.
When ordering, please write the package code beside the type number.

Type No. Indication

$$
\mathrm{HD} \times \times \times \times \mathrm{P}
$$

(Note) The HD68000 with shrink type plastic DIP (DP-64S) has a different type No. from other devices.

Troono: HD68000 $\frac{\text { PS }}{4}$
Package designation

Package Code Indication

(Note) PGA packages of 16-bit microcomputer devices have a different indication.

3. Package Dimensional Outline

Hitachi microprocessor employs the packages shown in

Table 1 according to the mounting method on the PCB.

Table 1 Package List

| Method of Mounting | Package Classification |  | Package Material | Package Code |
| :---: | :---: | :---: | :---: | :---: |
| Pin Insertion Type | Standard Outline (DIP) |  | Plastic | $\begin{aligned} & \text { DP- } 40 \\ & \text { DP- } 64 \end{aligned}$ |
|  |  |  | Ceramic | DC-64 |
|  | Shrink Outline | S-DIP | Plastic | DP-64S |
|  |  | PGA | Glass Sealed Ceramic | PGA-68 |
| Surface Mounting Type | Flat Package | FLAT-QUIP (FPP) | Plastic | $\begin{aligned} & \text { FP- } 54 \\ & \text { FP. } 64 \\ & \text { FP-80 } \end{aligned}$ |
|  | Chip Carrier | PLCC | Plastic | $\begin{aligned} & \text { CP-52 } \\ & \text { CP-68 } \end{aligned}$ |
|  |  | LCC | Glass Sealed Ceramic | CG-40 |

## Plastic DIP

- DP-40

- DP-64


Ceramic DIP
Unit : mm(inch)


Shrink Type Plastic DIP
Unit: mm(inch)


Hitachi America Ltd. • 2210 O'Toole Avenue • San Jose, CA 95131 • (408) 435-8300

## Pin Grid Array

Unit : mm(inch)


Flat Package Unit : mm(inch)


Unit : mm(inch)

- FP-80


Plastic Leaded Chip Carrier
Unit : mm(inch)

- CP-52

- CP-68


Leadless Chip Carrier

- CG-40




## 4. Mounting Method on Board

Lead pins of the package have surface treatment, such as solder coating or solder plating, to make them easy to mount on the PCB. The lead pins are connected to the package by eutectic solder. The following explains the common connecting method of leads and precautions.

### 4.1 Mounting Method of Pin Insertion Type Package

Insert lead pins of the package into through-holes (usually about $\phi 0.8 \mathrm{~mm}$ ) on the PCB. Soak the lead part of the package in a wave solder tub.

Lead pins of the package are held by the through-holes. Therefore, it is easy to handle the package through the process up to soldering, and easy to automate the soldering process. When soldering the lead part of the package in the wave solder tub, be careful not to get the solder on the package, because the wave solder will damage it.

### 4.2 Mounting Method of Surface Mounting Type Package

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

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

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


Figure 2 Reflowing Furnace Adjustment for FPP

Ensure good heater or temperature controls because the material of a plastic package is black epoxy-resin which damages easily. When an infrared heater is used, if the temperature is higher than the glass transition point of epoxy-resin (about $150^{\circ} \mathrm{C}$ ), for a long time, the package may be damaged and the reliability lowered. Equalize the temperature inside and outside the packages by lessening the heat of the upper surface of the packages.

Leads of FPP may be easily bent under shipment or during handling and cannot be soldered onto the printed board. If they are, heat the bent leads again with a soldering iron to reshape them.

Use a rosin flux when soldering. Don't use a chloric flux because the chlorine in the flux tends to remain on the leads and lower the reliability of the product.

Even if you use a rosin flux, remaining flux can cause the leads to deteriorate. Wash away flux from packages with alcohol, chlorothene or freon. But don't leave these solvents on the packages for a long time because the marking may disappear.

## 5. Marking

Hitachi trademark, product type No., etc. are printed on packages. Case I and Case II give examples of marks and Nos. Case I applies to products which have only a standard type No. Case II applies to products which have an old type No. and a standard type No.

Case I; Includes a standard type No.

Case II; Includes an old type No. and a standard type No.
(a)

 (d) $A \mathbb{A} B \mathbb{A}$
(c)日D6800D
Meaning of Each Mark

| (a) | Hitachi Trademark |
| :--- | :---: |
| (b) | Lot Code |
| (c) | Standard Type No. |
| (d) | Japan Mark |
| (e) | Old Type No. |

## 1. VIEWS ON QUALITY AND RELIABILITY

Basic views on quality in Hitachi are to meet individual user's purchase purpose and quality required, and to be at the satisfied quality level considering general marketability. Quality required by users is specifically clear if the contract specification is provided. If not, quality required is not always definite. In both cases, efforts are made to assure the reliability so that semiconductor devices delivered can perform their ability in actual operating circumstances. To realize such quality in manufacturing process, the key points should be to establish quality control system in the process and to enhance morale for quality.

In addition, quality required by users on semiconductor devices is going toward higher level as performance of electronic system in the market is going toward higher one and is expanding size and application fields. To cover the situation, actual bases Hitachi is performing is as follows;
(1) Build the reliability in design at the stage of new product development.
(2) Build the quality at the sources of manufacturing process.
(3) Execute the harder inspection and reliability confirmation of final products.
(4) Make quality level higher with 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 for users' requirements.

## 2. RELIABILITY DESIGN OF SEMICONDUCTOR DEVICES

### 2.1 Reliability Targets

Reliability target is the important factor in manufacture and sales as well as performance and price. It is not practical to rate reliability target with failure rate at the certain common test condition. The reliability target is determined corresponding to character of equipments taking design, manufacture, inner process quality control, screening and test method, etc. into consideration, and considering operating circumstances of equipments the semiconductor device used in, reliability target of system, derating applied in design, operating condition, maintenance, etc.

### 2.2 Reliability Design

To achieve the reliability required based on reliability targets, timely sude and execution of design standardization, device design (including process design, structure design), design review, reliability test are essential.
(1) Design Standardization

Establishment of design rule, and standardization of parts, material and process are necessary. As for design rule, critical items on quality and reliability are always studied at circuit design, device design, layout design, etc. Therefore, as long as standardized process, material, etc. are used, reliability risk is extremely small even in new development devices, only except for in the case special requirements in function needed.
(2) Device Design

It is important for device design to consider total balance of process design, structure design, circuit and layout design. Especially in the case new process, and new material are employed, technical study is deeply executed prior to device
development.
(3) Reliability Evaluation by Test Site

Test site is sometimes called Test Pattern. It is useful method for design and process reliability evaluation of IC and LSI which have complicated functions.

1. Purposes of Test Site are as follows;

- Making clear about fundamental failure mode
- Analysis of relation between failure mode and manufacturing process condition
- Search for failure mechanism analysis
- Establishment of QC point in manufacturing

2. Effectiveness of evaluation by Test Site are as follows;

- Common fundamental failure mode and failure mechanism in devices can be evaluated.
- Factors dominating failure mode can be picked up, and comparison can be made with process having been experienced in field.
- Able to analyze relation between failure causes and manufacturing factors.
- Easy to rin tests.
etc.


### 2.3 Design Review

Design review is organized method to confirm that design satisfies the performance required including users' and design work follows the specified ways, and whether or not technical improved items accumulated in test data of individual major fields and field data are effectively built in. In addition, from the standpoint of enhancement of competitive power of products, the major purpose of design review is to ensure quality and reliability of the products. In Hitachi, design review is performed from the planning stage for new products and even for design changed products. Items discussed and determined at design review are as follows;
(1) Description of the products based on specified design documents.
(2) From the standpoint of specialty of individual participants, design documents are studied, and if unclear matter is found, sub-program of calculation, experiments, investigation, etc. will be carried out.
(3) Determine contents of reliability and methods, etc. based on design document and drawing.
(4) Check process ability of manufacturing line to achieve design goal.
(5) Discussion about preparation for production.
(6) Planning and execution of sub-programs for design change proposed by individual specialist, and for tests, experiments and calculation to confirm the design change.
(7) Reference of past failure experiences with similar devices, confirmation of method to prevent them, and planning and execution of test program for confirmation of them. These studies and decisions are made using check lists made individually depending on the objects.

## 3. QUALITY ASSURANCE SYSTEM OF SEMICONDUCTOR DEVICES

### 3.1 Activity of Quality Assurance

General views of overall quality assurance in Hitachi are as follows;
(1) Problems in individual process should be solved in the
process. Therefore, at final product stage, the potential failure factors have been already removed.
(2) Feedback of information should be made to ensure satisfied level of process ability.
(3) To assure reliability required as an result of the things mentioned above is the purpose of quality assurance.
The followings are regarding device design, quality approval at mass production, inner process quality control, product inspection and reliability tests.

### 3.2 Quality Approval

To ensure quality and reliability required, quality approval is carried out at trial production stage of device design and mass production stage based on reliability design described at section 2.

The views on quality approval are as follows;
(1) The third party performs approval objectively from the standpoint of customers.
(2) Fully consider past failure experiences and information from field.
(3) Approval is needed for design change and work change.
(4) Intensive approval is executed on parts material and process.
(5) Study process ability and fluctuation factor, and set up control points at mass production stage.
Considering the views mentioned above, quality approval shown in Fig. 1 is performed.

### 3.3 Quality and Reliability Control at Mass Production

For quality assurance of products in mass production, quality control is executed with organic division of functions
in manufacturing department, quality assurance department, which are major, and other departments related. The total function flow is shown in Fig. 2. The main points are described below.

### 3.3.1 Quality Control of Parts and Material

As the performance and the reliability of semiconductor devices are getting higher, importance is increasing in quality control of material and parts, which are crystal, lead frame, fine wire for wire bonding, package, to build products, and materials needed in manufacturing process, which are mask pattern and chemicals. Besides quality approval on parts and materials stated in section 3.2, the incoming inspection is, also, key in quality control of parts and materials. The incoming inspection is performed based on incoming inspection specification following purchase specification and drawing, and sampling inspection is executed based on MIL-STD-105D mainly.

The other activities of quality assurance are as follows:
(1) Outside Vendor Technical Information Meeting
(2) Approval on outside vendors, and guidance of outside vendors
(3) Physical chemical analysis and test

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

### 3.3.2 Inner Process Quality Control

Inner process quality control is performing very important function in quality assurance of semiconductor devices. The following is description about control of semi-final products, final products, manufacturing facilities, measuring equipments,


Figure 1 Flow Chart of Quality Approval
circumstances and sub-materials. The quality control in the manufacturing process is shown in Fig. 3 corresponding to the manufacturing process.
(1) Quality Control of Semi-final Products and Final Products

Potential failure factors of semiconductor devices should be removed preventively in manufacturing process. To achieve it, check points are set-up in each process, and products which have potential failure factor are not transfer to the next process. Especially, for high reliability semiconductor devices, manufacturing line is rigidly selected, and the quality control in the manufacturing process is tightly executed - rigid check in each process and each lot, $100 \%$ inspection in appropriate ways to remove failure factor caused by manufacturing fluctuation, and execution of screening needed, such as high temperature aging and temperature cycling. Contents of inner process quality control are as follows;

- Condition control on individual equipments and workers, and sampling check of semifinal products.
- Proposal and carrying-out improvement of work
- Education of workers
- Maintenance and improvement of yield
- Picking-up of quality problems, and execution of counter-


## measures

- Transmission of information about quality
(2) Quality Control of Manufacturing Facilities and Measuring Equipment
Equipments for manufacturing semiconductor devices have been developing extraordinarily with necessary high performance devices and improvement of production, and are important factors to determine quality and reliability. In Hitachi, automatization of manufacturing equipments are promoted to improve manufacturing fluctuation, and controls are made to maintain proper operation of high performance equipments and perform the proper function. As for maintenance inspection for quality control, there are daily inspection which is performed daily based on specification related, and periodical inspection which is performed periodically. At the inspection, inspection points listed in the specification are checked one by one not to make any omission. As for adjustment and maintenance of measuring equipments, maintenance number, specification are checked one by one to maintain and improve quality.
(3) Quality Control of Manufacturing Circumstances and Submaterials
Quality and reliability of semiconductor device is highly


Figure 2 Flow Chart of Quality Control in Manufacturing Process
affected by manufacturing process. Therefore, the controls of manufacturing circumstances - temperature, humidity, dust and the control of submaterials - gas, pure water - used in manufacturing process are intensively executed. Dust control is described in more detail below.

Dust control is essential to realize higher integration and higher reliability of devices. In Hitachi, maintenance and improvement of cleanness in manufacturing site are executed with paying intensive attention on buildings, facilities, airconditioning systems, materials delivered-in, clothes, work, etc., and periodical inspection on floating dust in room, falling dusts and dirtiness of floor.

### 3.3.3 Final Product Inspection and Reliability Assurance

(1) Final Product Inspection

Lot inspection is done by quality assurance department for products which were judged as good products in $100 \%$ test, which is final process in manufacturing department. Though $100 \%$ of good products is expected, sampling inspection is executed to prevent mixture of failed products by mistake of work, etc. The inspection is executed not only to confirm that the products meet users' requirement, but to consider potential factors. Lot inspection is executed based on MIL-STD-105D.
(2) Reliability Assurance Tests

To assure reliability of semiconductor devices, periodical reliability tests and reliability tests on individual manufacturing lot required by user are performed.

Table 1 Quality Control Check Points of Material and Parts (Example)

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



Figure 3 Example of Inner Process Quality Control


Figure 4 Process Flow Chart of Field Failure

## RELIABILITY TEST DATA OF MICROCOMPUTER

## 1. INTRODUCTION

Microcomputer is required to provide higher reliability and quality with increasing function, enlarging scale and widening application. To meet this demand, Hitachi is improving the quality by evaluating reliability, building up quality in process, strengthening inspection and analyzing field data etc..

This chapter describes reliability and quality assurance data for Hitachi 8 -bit and 16 -bit multi-chip microcomputer based on test and failure analysis results. More detail data and new information will be reported in another reliability data sheet.

## 2. PACKAGE AND CHIP STRUCTURE

### 2.1 Package

The reliability of plastic molded type has been greatly improved, recently their applications have been expanded to automobiles measuring and control systems, and computer terminal equipment operated under relatively severe conditions and production output and application of plastic molded type will continue to increase.

To meet such requirements, Hitachi has considerably improved moisture resistance, operation stability, and chip and plastic manufacturing process.

Plastic and ceramic package type structure are shown in Figure 1 and Table 1.
(1) Ceramic DIP

Figure 1 Package Structure

Table 1 Package Material and Properties

| Item | Ceramic DIP | Plastic DIP | Plastic Flat Package |
| :--- | :--- | :--- | :--- |
| Package | Alumina | Epoxy | Epoxy |
| Lead | Tin plating Brazed Alloy 42 | Solder dipping Alloy 42 or Cu | Solder plating Alloy 42 |
| Seal | Au-Sn Alloy | N.A | N.A |
| Die bond | Au-Si | Au-Si or Ag paste | Au-Si or Ag paste |
| Wire bond | Ultrasonic | Thermo compression | Thermo compression |
| Wire | Al | Au | Au |

### 2.2 Chip Structure

Hitachi microcomputers are produced in NMOS E/D technology or low power CMOS technology. Si-gate process is used
in both types because of high reliability and high density. Chip structure and basic circuit 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}, 100 \mathrm{hr}$ | 1005,2 |
| High Temp, Storage <br> Low Temp, Storage <br> Steady State Humidity <br> Steady State Humidity Biased | Tstg max, 1000hr Tstg min, 1000hr $65^{\circ} \mathrm{C} 95 \% \mathrm{RH}, 1000 \mathrm{hr}$ $85^{\circ} \mathrm{C} 85 \% \mathrm{RH}, 1000 \mathrm{hr}$ | 1008,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 | $\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^{\circ} \mathrm{C}, 100 \text { cycles } \\ & 260^{\circ} \mathrm{C}, 10 \text { 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 \mathrm{~min} / X, Y, Z \\ & 225 \mathrm{gr}, 90^{\circ} 3 \text { times } \end{aligned}$ | $\begin{aligned} & 1010,4 \\ & 1011,3 \\ & 2002,2 \\ & 2005,1 \\ & 2007,1 \\ & 2001,2 \\ & 2004,3 \end{aligned}$ |

### 3.2 Reliability Test Result

Reliability test result of 8 -bit microprocessors is shown in Table 3 to Table 7, that of 16 -bit microprocessors in Table 8,

Table 9. There is little difference according to device series, as the design and production process, etc. are standardized.

Table 3 Dynamic Life Test (8-bit microprocessor)

| Device Type | Sample Size | Component Hours | Failures |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| HD6800 | 248 pcs | 248000 | 0 |  |  |
| HD6802 | 452 | 153712 | $1^{\star}$ |  |  |
| HD6809 | 85 | 85000 | 0 |  |  |
| Total | 785 | 486712 | 1 |  |  |
|  |  |  |  |  | ${ }^{\star}$ leakage current |

Estimated Field Failure Rate
$=0.01 \% / 1000 \mathrm{hrs}$ at $\mathrm{Ta}=75^{\circ} \mathrm{C}$
(Activation Energy $=0.7 \mathrm{eV}$, Confidence Level 60\%)

Table 4 High Temperature, High Humidity Test (8-bit microprocessor) (Moisture Resistance Test)
(1) $85^{\circ} \mathrm{C} 85 \% \mathrm{RH}$ Bias Test

| Device Type | Vcc Bias | 168 hrs | 500 hrs | 1000 hrs |
| :--- | :---: | :---: | :---: | :---: |
| HD6800P | 5.5 V | $0 / 45$ | $0 / 45$ | $0 / 45$ |
| HD6802P | 5.5 V | $0 / 38$ | $0 / 38$ | $0 / 38$ |
| HD6809P | 5.5 V | $0 / 22$ | $0 / 22$ | $0 / 22$ |
| Total |  | $0 / 105$ | $0 / 105$ | $0 / 105$ |

(2) High Temperature-High Humidity Storage Life Test

| Device Type | Condition | 168 hrs | 500 hrs | 1000 hrs |
| :--- | :---: | :---: | :---: | :---: |
| HD6800P | $65^{\circ} \mathrm{C} 95 \%$ RH | $0 / 22$ | $0 / 22$ | $0 / 22$ |
| HD6802P | $80^{\circ} \mathrm{C} 90 \%$ RH | $0 / 22$ | $0 / 22$ | $0 / 22$ |
| HD6802P | $65^{\circ} \mathrm{C} 95 \%$ RH | $0 / 38$ | $0 / 38$ | $0 / 38$ |
| HD6809P | $65^{\circ} \mathrm{C} 95 \%$ RH | $0 / 45$ | $0 / 45$ | $0 / 45$ |

(3) Pressure Cooker Test
(Condition ; 2atm $121^{\circ} \mathrm{C}$ )

| Device Type | 40 hrs | 60 hrs | 100 hrs |
| :---: | :---: | :---: | :---: |
| HD6800P | $0 / 42$ | $0 / 42$ | $0 / 42$ |
| HD6802P | $0 / 22$ | $0 / 22$ | $0 / 22$ |

(4) MIL-STD-883B Moisture Resistance Test
(Condition; $65^{\circ} \mathrm{C} \sim-10^{\circ} \mathrm{C}$, over $90 \% \mathrm{RH}, \mathrm{Vcc}=5.5 \mathrm{~V}$ )

| Device Type | 10 cycles | 20 cycles | 40 cycles |
| :---: | :---: | :---: | :---: |
| HD6800P | $0 / 25$ | $0 / 25$ | $0 / 25$ |
| HD6802P | $0 / 25$ | $0 / 25$ | $0 / 25$ |

Table 5 Temperature Cycling Test (8-bit microprocessor) ( $\mathbf{- 5 5}{ }^{\circ} \mathrm{C} \sim 25^{\circ} \mathrm{C} \sim 150^{\circ} \mathrm{C}$ )

| Device Type | 10 cycles | 100 cycles | 200 cycles |
| :---: | :---: | :---: | :---: |
| HD6800P | $0 / 453$ | $0 / 44$ | $0 / 44$ |
| HD6802P | $0 / 502$ | $0 / 77$ | $0 / 77$ |
| HD6809P | $0 / 202$ | $0 / 45$ | $0 / 45$ |

Table 6 High Temperature, Low Temperature Storage Life Test (8-bit microprocessor)

| Device | Temperature | 168 hrs | 500 hrs | 1000 hrs |
| :--- | :---: | :---: | :---: | :---: |
| MPU total | $150^{\circ} \mathrm{C}$ | $0 / 88$ | $0 / 88$ | $0 / 88$ |

Table 7 Mechanical and Environmental Test (8-bit microprocessor)

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

Table 8 Dynamic Life Test (16-bit microprocessor)

| Device Type | Condition |  | 168 hrs | 500 hrs | 1000 hrs |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Ta | Vcc |  |  |  |
| HD 68000 | $125^{\circ} \mathrm{C}$ | 5.5 V | $0 / 62$ | $0 / 52$ | $0 / 52$ |

Estimated Field Failure Rate
$=0.013 \% / 1000 \mathrm{hrs}$ at $\mathrm{Ta}=75^{\circ} \mathrm{C}$
(Activation Energy 0.7eV, Confidence Level 60\%)

Table 9 Mechanical and Environmental Test (16-bit microprocessor)

| Test Item | Condition | Device Type |  |
| :---: | :---: | :---: | :---: |
|  |  | Sample Size | Failure |
| High Temperature Storage | $\mathrm{Ta}=295^{\circ} \mathrm{C}, 1000 \mathrm{hrs}$ | 42 | 0 |
| Low Temperature Storage | $\mathrm{Ta}=-55^{\circ} \mathrm{C}, 1000 \mathrm{hrs}$ | 42 | 0 |
| Temperature Cycling (1) | $\begin{aligned} & -55^{\circ} \mathrm{C} \sim 25^{\circ} \mathrm{C} \sim 150^{\circ} \mathrm{C} \\ & 10 \text { cycles } \end{aligned}$ | 189 | 0 |
| Temperature Cycling (2) | $\begin{aligned} & -20^{\circ} \mathrm{C} \sim 25^{\circ} \mathrm{C} \sim 125^{\circ} \mathrm{C} \\ & 500 \text { cycles } \end{aligned}$ | 44 | 0 |
| Thermal Shock | $\begin{aligned} & -55^{\circ} \mathrm{C} \sim 125^{\circ} \mathrm{C} \\ & 15 \text { cycles } \end{aligned}$ | 44 | 0 |
| Soldering heat | $260^{\circ} \mathrm{C}, 10 \mathrm{sec}$ | 44 | 0 |
| Solderability | $230^{\circ} \mathrm{C}, 5 \mathrm{sec}$ | 44 | 0 |
| Mechanical Shock | $1500 \mathrm{G}, 0.5 \mathrm{msec}$ <br> 3 times/X, Y, Z | 44 | 0 |
| Vibration Variable Freq. | $\begin{aligned} & 20 \sim 2000 \mathrm{~Hz}, 20 \mathrm{G} \\ & 3 \text { times } / X, Y, Z \end{aligned}$ | 44 | 0 |
| Constant <br> Acceleration | $\begin{aligned} & 20000 \mathrm{G} \\ & 1 \mathrm{~min} / X, Y, Z \end{aligned}$ | 44 | 0 |

## 4. PRECAUTION

### 4.1 Storage

It is preferable to store semiconductor devices in the following ways to prevent detrioration in their electrical characteristics, solderability, and appearance, or breakage.
(1) Store in an ambient temperature of 5 to $30^{\circ} \mathrm{C}$, and in a relative humidity of 40 to $60 \%$.
(2) Store in a clean air environment, free from dust and active gas.
(3) Store in a container which does not induce static electricity.
(4) Store without any physical load.
(5) If semiconductor devices are stored for a long time, store them in the unfabricated form. If their lead wires are formed beforehand, bent parts may corrode during storage.
(6) If the chips are unsealed, store them in a cool, dry, dark, and dustless place. Assemble them within 5 days after unpacking. Storage in nitrogen gas is desirable. They can be stored for 20 days or less in dry nitrogen gas with a dew point at $-30^{\circ} \mathrm{C}$ or lower. Unpacked devices must not be stored for over 3 months.
(7) Take care not to allow condensation during storage due to rapid temperature changes.

### 4.2 Transportation

As with storage methods, general precautions for other electronic component parts are applicable to the transportation of semiconductors, semiconductor-incorporating units and other similar systems. In addition, the following considerations must be given, too:
(1) Use containers or jigs which will not induce static electricity as the result of vibration during transportation. It is desirable to use an electrically conductive container or aluminium foil.
(2) In order to prevent device breakage from clothes-induced static eiectricity, workers snouid be properiy grounded with a resistor while handling devices. The resistor of about 1 M ohm must be provided near the worker to protect from electric shock.
(3) When transporting the printed circuit boards on which semiconductor devices are mounted, suitable preventive measures against static electricity induction must be taken; for example, voltage built-up is prevented by shorting terminal circuit. When a belt conveyor is used, prevent the conveyor belt from being electrically charged by applying some surface treatment.
(4) When transporting semiconductor devices or printed circuit boards, minimize mechanical vibration and shock.

### 4.3 Handling for Measurement

Avoid static electricity, noise and surge-voltage when semiconductor devices are measured. It is possible to prevent breakage by shorting their terminal circuits to equalize electrical potential during transportation. However, when the devices are to be measured or mounted, their terminals are left open to provide the possibility that they may be accidentally touched by a worker, measuring instrument, work bench, soldering iron, belt conveyor, etc. The device will fail if it touches something which leaks current or has a static charge. Take care not toallow curve tracers, synchroscopes, pulse generators, D.C. stabilizing power supply units etc. to leak current through their terminals or housings.

Especially, while the devices are being tested, take care not
to apply surge voltage from the tester, to attach a clamping circuit to the tester, or not to apply any abnormal voltage through a bad contact from a current source.

During measurement, avoid miswiring and short-circuiting. When inspecting a printed circuit board, make sure that no soldering bridge or foreign matter exists before turning on the power switch.

Since these precautions depend upon the types of semiconductor devices, contact Hitachi for further details.

### 4.4 Soldering

Semiconductor devices should not be left at high temperatures for a long time. Regardless of the soldering method, soldering must be done in a short time and at the lowest possible temperature. Soldering work must meet soldering heat test conditions, namely, $260^{\circ} \mathrm{C}$ for 10 seconds and $350^{\circ} \mathrm{C}$ for 3 seconds at a point 1 to 1.5 mm away from the end of the device package.

Use of a strong alkali or acid flux may corrode the leads, deteriorating device characteristics. The recommended soldering iron is the type that is operated with a secondary voltage supplied by a transformer and grounded to protect from lead current. Solder the leads at the farthest point from the device package.

### 4.5 Removing Residual Flux

To ensure the reliability of electronic systems, residual flux must be removed from circuit boards. Detergent or ultrasonic cleaning is usually applied. If chloric detergent is used for the plastic molded devices, package corrosion may occur. Since cleaning over extended periods or at high temperatures will cause swollen chip coating due to solvent permeation, select the type of detergent and cleaning condition carefully. Lotus Solvent and Dyfron Solvent are recommended as a detergent. Do not use any trichloroethylene solvent. For ultrasonic cleaning, the foilowing conditions are adivisabie:

- Frequency: 28 to 29 kHz (to avoid device resonation)
- Ultrasonic output: $15 \mathrm{~W} / \mathrm{l}$
- Keep the devices out of direct contact with the power generator.
- Cleaning time: Less than 30 seconds
- PROGRAM DEVELOPMENT AND SUPPORT SYSTEM OF 8-BIT/16-BIT MICROPROCESSOR
H680SD200 is prepared as system development device to develop software and hardware of various types of microcomputer system.

Fig. 1 shows the program development procedure using this system development device.

H680SD200 loads a universal OS, CP/M-68K ${ }^{\circledR}$ developed jointly with Digital Research Inc. and operates with the existing $C P / M^{\circledR}$.
${ }^{*} C P / M^{\circledR}$ and $C P / M-68 K{ }^{\circledR}{ }^{\circledR}$ are registered trademarks of Digital Research Inc.


Fig. 1 Program Development Procedure

Table 1 System Development Equipment SD200

| MPU | Product Name | Product Code | Function | Note |
| :---: | :---: | :---: | :---: | :---: |
| - | CP/M-68K | S680CPM3F | - Single user Operating System. <br> - 68000 Assembler, C compiler, Screen editor and Linker are included. |  |
| - | VAX-11 <br> Interface Program | S680CLC3F | - Interface Program between the SD200 and the VAX-11. <br> - File transfer function. <br> - VT52 Terminal Emulation. | Option |
|  | DATA I/O EPROM Programmer Interface Program | S680CDI1F | - Interface Program between the SD200 and the DATA I/O EPROM Programmer model 22/29. |  |
|  | PKW-1000/7000 EPROM Programmer Interface Program | S680CPK2F | - Interface Program between the SD200 and the PKW-1000/7000 EPROM Programmer (Aval Corp. Japan). |  |
| 16-bit MPU HD68000 | FORTRAN | S680CFR1F | - FORTRAN Compiler. (Subset of FORTRAN77) | Option |
|  | Super PL/H | S680CPL1F | - Super PL/H Compiler. | Option |
|  | Symbolic Debugger | S680CSD2F | - Symbolic Debugger for programs written in 68000 Assembler or Super PL/H. | Option |
| 8 bit MPU/MCU | 64180ASE | S180CAS1F | - Realtime In-circuit Emulator for 64180. | Supplied with H180AS01E |
|  | 6305/63L05/6805 Macro Assembler | S35XAS6-F | - 6305Z/63L05/6805 Macro Assembler. <br> - Linkage editor is included. | Option |
|  | 6301/6801/6800 <br> Macro Assembler | S31XAS6-F | - 6301/6801/6800 Macro Assembler. <br> - Linkage editor is included. | Option |
|  | $6301$ <br> C Compiler | S31CCLN-F | - C Compiler for 6301(6303). | Option |

Table 2 Cross System

| MPU | Machine | OS | Product Name | Product Code | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 8 -bit MCU | Intel MDS | ISIS-II | 6305/63L05/6805 Assembler | S35MDS1-F | - 6305/63L05/6805 Assembler. <br> - Object code is absolute address format. <br> - Conditional assemble function. |
|  |  | CP/M | 6305/63L05/6805 Assembler | S35MDS2-F | - 6305/63L05/6805 Assembler. <br> - Object code is absolute address format. <br> - Conditional assemble function. |
|  |  | ISIS-II | 6301 Assembler | S31MDS1-F | - 6301/6801 Assembler. <br> - Object code is absolute address format. <br> - Conditional Assemble function. |
|  |  | CP/M | 6301 Assembler | S31MDS2-F | - 6301/6801 Assembler. <br> - Object code is absolute address format. <br> - Conditional Assemble function. |
|  | IBM-PC | PC-DOS | $6301$ <br> Macro Assembler | S311AS1-F* | - 6301 Macro Assembler. <br> - Linkage Editor is included. |
|  |  |  | 6305 <br> Macro Assembler | S35IAS1-F* | - 6305 Macro Assembler. <br> - Linkage Editor is included. |

Table 3 Third Parties' Products

Assemblers for HITACHI's microcomputers are provided by the other companies. Hitachi introduce some venders and their
products listed below. Please contact those venders directly if you have questions or requests to purchase these products.

| Vender Name | Product Name | OS/System | Product Code |
| :---: | :---: | :---: | :---: |
| MICROTEC <br> 505W Olive, Suite 325 Sunnyvale, CA94086 (408)733-2919 U.S.A. | 6301 Assembler | VAX11 | ASM68 |
|  | 6305 Assembler |  | ASM05 |
|  | 6809 Assembler |  | ASM69 |
|  | 68000 Assembler |  | ASM68K |
|  | 64180 Assembler |  | ASM180 |
|  | 64180 Simulator |  | INT180 |
|  | 64180 C |  | MCC180 |
|  | 64180 Pascal |  | PAS180 |
|  | 6301 Assembler | IBM-PC | ASM68 |
|  | 6305 Assembler |  | ASM05 |
|  | 64180 Assembler |  | ASM180 |
|  | 64180 C |  | MCC180 |
|  | 64180 Pascal |  | PAS180 |
| CAMELOT <br> 79 London Road Knebworth Herts, SG3 6HG, England Stevenage (0438) 812215 | 6301 Assembler | IBM-PC |  |
|  |  |  |  |
|  | 6305 Assembler |  | * |
| AVOCET SYSTEMS, INC. <br> 804 South State St. <br> Dover, DE19901 (302) 734-0151 U.S.A. | $\begin{aligned} & \text { 6800/6801/6301 } \\ & \text { Assembler } \end{aligned}$ | $\text { MS-DOS, } \frac{C P / M}{C P / M-86}$ | XASM-68 |
|  | 6805 Assembler | $\text { MS-DOS, }{ }_{C P}^{C P / M} / 86$ | XASM-05 |
|  | 6309/6809 Assembler | $\text { MS-DOS, } \begin{aligned} & \text { CP/M } \\ & \text { CP/M-86 } \end{aligned}$ | XASM-09 |
|  | 64180 Assembler | $\text { MS-DOS, } \begin{gathered} \text { CP/M } \\ \text { CP/86 } \end{gathered}$ | XASM-180 |
| MICROWARE SYSTEMS CORPORA- <br> TION <br> 5835 Grand Avenue <br> Dos Moines, IA50312 <br> (512) 279-8844 U.S.A. | $\begin{aligned} & \text { 6309/6809 } \\ & \text { Assembler } \end{aligned}$ | OS-9 | - |
|  | $\begin{aligned} & \text { 68000/68HC000 } \\ & \text { Assembler } \end{aligned}$ | OS-9 | KCRS |

*Under development

Development System for 4-Bit, 8-Bit, and 16-Bit Microcomputers <H680SD200>
The H680SD200 is a development system for Hitachi 4-bit, 8 -bit and 16 -bit microcomputers. It is a desktop system in which a 16 -bit microprocessor HD68000 is loaded as the CPU. Its standard system configuration includes a CRT, a keyboard, and two floppy disk drives. An assembler, compiler, and incircuit emulator (ASE) associated with the user's MCU are available as options.

## APPLICABLE DEVICES

- HMCS400 series
- HD6305U, HD6305V
- HD6301V, HD6301X, HD6301Y
- HD64180
- HD68000, HD68HC000
(Other 4 -bit and 8 -bit microcomputers will be supported in the future.)
- FEATURES
- Adopts general CP/M-68K ${ }^{\circledR}$ operating system
- Two internal 8 inch floppy disk drives (double-sided, doubledensity) and a 40M byte hard disk (available as an option)
make it possible to provide substantial external memory.
- Since CRT editor (screen editor) is included in the standard system, efficient programming, editing, and debugging of source programs are possible.
- C compiler for HD68000 is included. FORTRAN and Super PL/H for HD68000 and C Compiler for HD6301 (HD6303) are available as options.
- User prototype system can easily be debugged using incircuit emulator (ASE) associated with the user's MCU.
- With connection of VAX-11 ${ }^{\circledR}$ to RS-232C interface, H680SD 200 operates as VAX-11 ${ }^{\circledR}$ (OS, VMS) work station.
- When 2M byte memory board is connected, high-speed operation can be realized.
- Following interface are included
(1) EPROM programmer
(2) Printer (Centronics specification)
(3) Serial interface emulator for 4 -bit and 8 -bit single chip microcomputers
${ }^{*} \mathrm{CP} / \mathrm{M}^{\circledR}$ is a registered trade mark of Digital Research Inc.
**VAX-11 ${ }^{\circledR}$ is a registered trade mark of Digital Equipment Corp.


H680SD200

## HD64180 THIRD-PARTY DEVELOPMENT TOOLS

| Company | ASM | S/W SIM | C COMP | PASCAL | BASIC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| American Automation (714-731-1661) | V/I | V/I | V/I |  |  |
| Microtec Research (408-733-2919) | V/I | V/I | V/I | V/I |  |
| $\begin{aligned} & \text { Avocet Systems } \\ & (800-448-8500) \end{aligned}$ | C/I | C/I |  |  |  |
| 2500AD Software (303-369-5001) | C/I |  |  |  |  |
| ```BS0``` | V | V | V | V |  |
| $\begin{aligned} & \text { Sumitronics } \\ & (408-737-7683) \end{aligned}$ | V |  |  |  |  |
| $\begin{aligned} & \text { SLR Systems } \\ & (800-833-3061) \end{aligned}$ | C |  |  |  |  |
| Uniware/SDS (312-971-8170) | V |  |  |  |  |
| $\begin{aligned} & \text { Softaid } \\ & (800-433-8812) \end{aligned}$ |  |  |  |  | C |
| $\begin{aligned} & \text { Allen Ashley } \\ & (818-793-5748) \end{aligned}$ |  |  |  |  |  |
| $[1=I B M-P C, V=V A X, C=C P / M]$ |  |  |  |  |  |

## Product: Support Tools

| Company | Product Description |
| :--- | :--- |
| Electronic Molding | Shrink-DIP Adapter for Breadboarding |
| (401-769-3800) | P/N 28764-72-341 |
| Robinson Nugent | Shrink-DIP Socket |
| (812-945-0211) | P/N TSS-6475-TNG |
| Yamaiche/Nepenthe | Shrink-DIP Socket P/N IC 38-64075-G4 |
| (415-856-9332) | S-D Test Socket P/N IC 76-64075-G4 |
| Methode Electronics | PLCC Adapter for Hitachi's ASE |
| (312-392-3500) |  |
| TSI, Inc |  |
| (800-874-2288) | 64180 IBM-PC Card with DSD80 Remote |
| Micromint | Software Debugger |
| (800-635-3355) | 64180 Evaluation Board |
|  | P/N SB180 |

Product: Operating Systems

| Company | Type of Operating System |
| :--- | :--- |
| Echelon <br> (415-948-3820) | ZCPR3 (CP/M) |
| JMI Software <br> (215-628-0840) | C Executive/80 Multi-Tasking Kernel |
| Decmation <br> (408-980-1678) | Quick-Task Realtime Executive |
| Hunter \& Ready <br> $(415-326-2950)$ | VRTX/80 Multi-Tasking Kernel (Z80) |
| IP$(516-938-6600)$ | MTOS/80 Multi-Tasking Kernel (Z80) |

## HITACHI ORDERING INFORMATION

| Part Number | Description |
| :--- | :--- |
| H180ASE02 | Adaptive System Evaluator, ASE-II |
| H680SM01S | 256K Byte Emulation Memory Board (Option) |
| H180ABX | 8 MHz Buffer Box for ASE-I User, <br> Includes V2.0 System Software |
|  | PLCC-68 MPU Adapter for 1 Mbyte <br> H180CP01 |
|  | Addressing (Option) |

# DATA SHEETS 

## NMOS 8-BIT MICROPROCESSOR

## HD6802 <br> MPU (Microprocessor with Clock and RAM)

The HD6802 is a monolithic 8 -bit microprocessor that contains all the registers and accumulators of the present HD6800 plus an internal clock oscillator and driver on the same chip. In addition, the HD6802 has 128 bytes of RAM on the chip located at hex addresses 0000 to 007F. The first 32 bytes of RAM, at hex addresses 0000 to 001 F , may be retained in a low power mode by utilizing $\mathrm{V}_{\mathrm{CC}}$ standby, thus facilitating memory retention during a power-down situation.

The HD6802 is completely software compatible with the HD6800 as well as the entire HMCS6800 family of parts. Hence, the HD6802 is expandable to 65 k words.

## - FEATURES

- On-Chip Clock Circuit
- $128 \times 8$ Bit On-Chip RAM
- 32 Bytes of RAM are Retainable
- Software-Compatible with the HD6800
- Expandable to 65 k words
- Standard TTL-Compatible Inputs and Outputs
- 8 Bit Word Size
- 16 Bit Memory Addressing
- Interrupt Capability
- Compatible with MC6802
- BLOCK DIAGRAM


- PIN ARRANGEMENT

(Top View)

ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}{ }^{*}{ }^{*} \mathrm{~V}_{\mathrm{CC}}$ Standby $^{*}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $-20 \sim+75$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

* With respect to $V_{S S}$ (SYSTEM GND)
(NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.
- RECOMMENDED OPERATING CONDITIONS

| Item | Symbol |  | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\begin{gathered} \mathrm{V}_{\mathrm{cc}}^{*} \\ \mathrm{~V}_{\mathrm{cc}} \mathrm{Standby}^{*} \end{gathered}$ |  | 4.75 | 5.0 | 5.25 | V |
| Input Voltage | $\mathrm{V}_{\text {IL }}{ }^{*}$ |  | -0.3 | - | 0.8 | V |
|  | $\mathrm{V}_{1 \mathrm{H}}{ }^{*}$ | Except $\overline{\mathrm{RES}}$ | 2.0 | - | Vcc | V |
|  |  | $\overline{\text { RES }}$ | 4.25 | - | $\mathrm{V}_{\mathrm{Cc}}$ | V |
| Operation Temperature | Topr |  | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

* With respect to $\mathrm{V}_{\mathrm{SS}}$ (SYSTEM GND)


## - ELECTRICAL CHARACTERISTICS

- DC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}} \operatorname{Standby}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ** | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input "High" Voltage | Except RES | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | V |
|  | $\overline{\text { RES }}$ |  |  | 4.25 | - | $V_{c c}$ |  |
| Input "Low" Voltage | Except $\overline{\text { RES }}$ | $\stackrel{*}{V}_{\text {VIL }}$ |  | -0.3 | - | 0.8 | V |
|  | $\overline{\text { RES }}$ |  |  | -0.3 | - | 0.8 |  |
| Output "High" Voltage | $D_{0} \sim D_{7}, E$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}=-205 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  | $A_{0} \sim A_{15}, R / \bar{W}, V M A$ |  | $\mathrm{IOH}=-145 \mu \mathrm{~A}$ | 2.4 | - | - |  |
|  | BA |  | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ | 2.4 | - | - |  |
| Output "Low" Voltage |  | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |
| Three State (Off State) Input Current | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | $I_{\text {TSI }}$ | $\mathrm{V}_{\text {in }}=0.4 \sim 2.4 \mathrm{~V}$ | -10 | - | 10 | $\mu \mathrm{A}$ |
| Input Leakage Current | Except $\mathrm{D}_{0} \sim \mathrm{D}_{7}{ }^{* * * *}$ | lin | $\mathrm{V}_{\text {in }}=0 \sim 5.25 \mathrm{~V}$ | -2.5 | - | 2.5 | $\mu \mathrm{A}$ |
| Power Dissipation |  | $\mathrm{PD}^{*}$ |  | - | 0.6 | 1.2 | W |
| Input Capacitance | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | $\mathrm{C}_{\text {n }}$ | $\begin{aligned} & \mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=25^{\circ} \mathrm{C}, \\ & \mathrm{f}, 1.0 \mathrm{MHz}, \end{aligned}$ | - | 10 | 12.5 | pF |
|  | Except $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ |  |  | - | 6.5 | 10 |  |
| Output Capacitance | $A_{0} \sim A_{15}, R / \bar{W}, B A,$ VMA, E | $\mathrm{C}_{\text {out }}$ | $\begin{aligned} & \mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=25^{\circ} \mathrm{C}, \\ & \mathrm{f}=1.0 \mathrm{MHz} \end{aligned}$ | - | - | 12 | pF |

[^0]- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}} \mathrm{Standby}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.)

1. CLOCK TIMING CHARACTERISTICS

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Frequency of Operation | Input Clock $\div 4$ | $f$ |  | 0.1 | - | 1.0 | MHz |
|  | Crystal Frequency | ${ }_{\text {fxtal }}$ |  | 1.0 | - | 4.0 |  |
| Cycle Time |  | $\mathrm{t}_{\text {cyc }}$ | Fig. 2, Fig. 3 | 1.0 | - | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width | "High" Level | $\mathrm{PW}_{\phi H}$ | at 2.4V (Fig. 2, Fig. 3) | 450 | - | 4500 | ns |
|  | "Low" Level | $\mathrm{PW}_{\phi} \mathrm{L}$ | at 0.8V (Fig. 2, Fig. 3) |  |  |  |  |
| Clock Fall Time |  | ${ }_{6}$ | 0.8V ~ 2.4V(Fig.2,Fig.3) | - | - | 25 | ns |

2. READ/WRITE TIMING

| Item | Symbol | Test Condition | min | typ* | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Delay | $t_{\text {AD }}$ | Fig. 2, Fig. 3, Fig. 6 | - | - | 270 | ns |
| Peripheral Read Access Time | tacc | Fig. 2 | 530 | - | - | ns |
| Data Setup Time (Read) | $\mathrm{t}_{\text {DSR }}$ | Fig. 2 | 100 | - | - | ns |
| Input Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | Fig. 2 | 10 | - | - | ns |
| Output Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | Fig. 3 | 20 | - | - | ns |
| Address Hold Time (Address, R $\overline{\mathbf{W}}$, VMA) | $\mathrm{t}_{\text {AH }}$ | Fig. 2, Fig. 3 | 10 | - | - | ns |
| Data Delay Time (Write) | todw | Fig. 3 | - | - | 225 | ns |
| Bus Available Delay | $\mathrm{t}_{\mathrm{BA}}$ | Fig. 4, Fig. 5, Fig. 7, Fig. 8 | - | - | 250 | ns |
| Processor Controls Processor Control Setup Time | tpcs | Fig. 4~Fig. 7, Fig. 12 | 200 | - | - | ns |
| Processor Control Rise and Fall Time (Measured at 0.8 V and 2.0 V ) | $\begin{aligned} & \mathrm{t}_{\mathrm{PCO}} \\ & \mathrm{t}_{\mathrm{PCf}} \\ & \hline \end{aligned}$ | Fig. 4~Fig. 7, Fig. 12, Fig. 13, Fig. 16 | - | - | 100 | ns |

* $\mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$

3. POWER DOWN SEQUENCE TIMING, POWER UP RESET TIMING AND MEMORY READY TIMING

| Item | Symbol | Test Condition | $\min$ | typ | max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| RAM Enable Reset Time (1) | $\mathrm{t}_{\text {RE1 }}$ | Fig. 13 | 150 | - | - | ns |
| RAM Enable Reset Time (2) | $\mathrm{t}_{\text {RE2 }}$ | Fig. 13 | E-3 cycles | - | - |  |
| Reset Release Time | $\mathrm{t}_{\text {LRES }}$ | Fig. 12 | $20^{*}$ | - | - | ms |
| RAM Enable Reset Time (3) | $\mathrm{t}_{\text {RE3 }}$ | Fig. 12 | 0 | - | - | ns |
| Memory Ready Setup Time | $\mathrm{t}_{\text {SMR }}$ | Fig. 16 | $\mathbf{3 0 0}$ | - | - | ns |
| Memory Ready Hold Time | $\mathrm{t}_{\text {HMR }}$ | Fig. 16 | 0 | - | 200 | ns |

[^1]
$C=130 \mathrm{pF}$ for $D_{0} \sim D_{7}, E$
$=90 p F$ for $A_{0} \sim A_{15}, R / \bar{W}$, and VMA
$=30 \mathrm{pF}$ for BA
$R=11 \mathrm{k} \Omega$ for $D_{0} \sim D_{7}, E$
$=16 \mathrm{k} \Omega$ for $A_{0}^{0} \sim A_{15}, R / \bar{W}$, and VMA $=24 \mathrm{k} \Omega$ for $\mathrm{BA}^{\circ}$
C includes stray Capacitance.
All diodes are 1S2074 or equivalent.
Figure 1 Bus Timing Test Load


Figure 2 Read Data from Memory or Peripherals


Figure 3 Write Data in Memory or Peripherals


Figure 4 Timing of $\overline{\text { HALT }}$ and BA


Figure 5 Timing of $\overline{\text { HALT }}$ and BA


Figure $6 \overline{R E S}$ and MPU Restart Sequence


Figure $7 \overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ Interrupt Timing


Figure 8 WAI Instruction and BA Timing

## - MPU REGISTERS

A general block diagram of the HD6802 is shown in Fig. 9. As shown; the number and configuration of the registers are the same as for the HD6800. The $128 \times 8$ bit RAM has been added to the basic MPU. The first 32 bytes may be operated in a low power mode via a $\mathrm{V}_{\mathrm{CC}}$ standby. These 32 bytes can be retained during power-up and power-down conditions via the RE signal.

The MPU has three 16 -bit registers and three 8 -bit registers available for use by the programmer (Fig. 10).

## - Program Counter (PC)

The program counter is a two byte (16-bit) register that points to the current program address.

## - Stack Pointer (SP)

The stack pointer is a two byte ( 16 -bit) register that contains the address of the next available location in an external push-down/pop-up stack. This stack is normally a random access Read/Write memory that may have any location (address) that is convenient. In those applications that require storage of information in the stack when power is lost, the stack must be non-volatile.

- Index Register (IX)

The index register is a two byte register that is used to store data or a sixteen bit memory address for the Indexed mode of memory addressing.

- Accumulators (ACCA, ACCB)

The MPU contains two 8 -bit accumulators that are used to hold operands and results from an arithmetic logic unit(ALU).

## - Condition Code Register (CCR)

The condition code register indicates the results of an Arithmetic Logic Unit operation: Negative(N), Zero(Z), Overflow(V), Carry from bit7(C), and half carry from bit3(H). These bits of the Condition Code Register are used as testable conditions for the conditional branch instructions. Bit 4 is the interrupt mask bit(I). The used bits of the Condition Code Register (B6 and B7) are ones.

Fig. 11 shows the order of saving the microprocessor status within the stack.


Figure 9 Expanded Block Diagram


Figure 10 Programming Model of The Microprocessing Unit


Figure 11 Saving The Status of The Microprocessor in The Stack

## - HD6802 MPU SIGNAL DESCRIPTION

Proper operation of the MPU requires that certain control and timing signals be provided to accomplish specific functions and that other signal lines be monitored to determine the state of the processor. These control and timing signals for the HD6802 are similar to those of the HD6800 except that TSC, DBE, $\phi_{1}, \phi_{2}$ input, and two unused pins have been eliminated, and the following signal and timing lines have been added.

RAM Enable (RE)
Crystal Connections EXTAL and XTAL
Memory Ready(MR)
$\mathrm{V}_{\mathrm{CC}}$ Standby
Enable $\phi_{2}$ Output(E)
The following is a summary of the HD6802 MPU signals:

- Address Bus ( $\mathrm{A}_{0} \sim \mathrm{~A}_{15}$ )

Sixteen pins are used for the address bus. The outputs are capable of driving one standard TTL load and 90 pF .

## - Data Bus ( $D_{0} \sim D_{7}$ )

Eight pins are used for the data bus. It is bidirectional, transferring data to and from the memory and peripheral devices. It also has three-state output buffers capable of driving one standard TTL load and 130 pF .

Data Bus will be in the output mode when the internal RAM is accessed. This prohibits external data entering the MPU. It should be noted that the internal RAM is fully decoded from $\$ 0000$ to $\$ 007 \mathrm{~F}$. External RAM at $\$ 0000$ to $\$ 007 \mathrm{~F}$ must be disabled when internal RAM is accessed.

## - HALT

When this input is in the "Low" state, all activity in the machine will be halted: This input is level sensitive.

In the halt mode, the machine will stop at the end of an instruction. Bus Available will be at a "High" state. Valid Memory Address will be at a "Low" state. The address bus will display the address of the next instruction.

To insure single instruction operation, transition of the HALT line must not occur during the last 250 ns of E and the HALT line must go "High" for one Clock cycle.

HALT should be tied "High" if not used. This is good engineering design practice in general and necessary to insure proper operation of the part.

## - Read/Write (R/W)

This TTL compatible output signals the peripherals and memory devices whether the MPU is in a Read ("High") or Write ("Low") state. The normal standby state of this signal is Read ("High"). When the processor is halted, it will be in the logical one state ("High").

This output is capable of driving one standard TTL load and 90 pF .

## - Valid Memory Address (VMA)

This output indicates to peripheral devices that there is a valid address on the address bus. In normal operation, this signal should be utilized for enabling peripheral interfaces such as the PIA and ACIA. This signal is not three-state. One standard TTL load and 90 pF may be directly driven by this active high signal.

## - Bus Available (BA)

The Bus Available signal will normally be in the "Low" state. When activated, it will go to the "High" state indicating that the microprocessor has stopped and that the address bus is available (but not in a three-state condition). This will occur if the HALT line is in the "Low" state or the processor is in the wait state as a result of the execution of a WAI instruction. At such time, all three-state output drivers will go to their off state and other
outputs to their normally inactive level.
The processor is removed from the wait state by the occurrence of a maskable (mask bit $\mathrm{I}=0$ ) or nonmaskable interrupt. This output is capable of driving one standard TTL load and 30 pF .

## - Interrupt Request (IRO)

This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will wait, until it completes the current instruction that is being executed before it recognizes the request. At that time, if the interrupt mask bit in the Condition Code Register is not set, the machine will begin an interrupt sequence. The index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. Next the MPU will respond to the interrupt request by setting the interrupt mask bit high so that no further interrupts may occur. At the end of the cycle, a 16 -bit address will be loaded that points to a vectoring address which is located in memory locations FFF8 and FFF9. An address loaded at these locations causes the MPU to branch to an interrupt routine in memory.

The HALT line must be in the "High" state for interrupts to be serviced. Interrupts will be latched internally while $\overline{\text { HALT }}$ is "Low".

A $3 \mathrm{k} \Omega$ external register to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts.

## - Reset ( $\overline{\mathrm{RES}}$ )

This input is used to reset and start the MPU from a power-down condition, resulting from a power failure or an initial start-up of the processor. When this line is "Low", the MPU is inactive and the information in the registers will be lost. If a "High" level is detected on the input, this will signal the MPU to begin the restart sequence. This will start execution of a routine to initialize the processor from its reset condition. All the higher order address lines will be forced "High". For the restart, the last two(FFFE, FFFF) locations in memory will be used to load the program that is addressed by the program counter. During the restart routine, the interrupt mask bit is set and must be reset before the MPU can be interrupted by IRQ. Power-up and reset timing and power-down sequences are shown in Fig. 12 and Fig. 13 respectively.

## - Non-Maskable Interrupt (NMI)

A low-going edge on this input requests that a non-maskinterrupt sequence be generated within the processor. As with the $\overline{\mathrm{IRQ}}$ signal, the processor will complete the current instruction that is being executed before it recognizes the $\overline{\text { NMI }}$ signal. The interrupt mask bit in the Condition Code Register has no effect on NMI.

The Index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. At the end of the cycle, a 16-bit address will be loaded that points to a vectoring address which is located in memory locations FFFC and FFFD. An address loaded at these locations causes the MPU to branch to a non-maskable interrupt routine in memory. A $3 \mathrm{k} \Omega$ external resistor to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts.

Inputs $\overline{\text { IRQ }}$ and $\overline{\text { NMI }}$ are hardware interrupt lines that are sampled when E is "High" and will start the interrupt routine on a "Low" E following the completion of an instruction. $\overline{\mathrm{IRQ}}$ and NMI should be tied "High" if not used. This is good engineering design practice in general and necessary to insure proper operation of the part. Fig. 14 is a flowchart describing the major decision paths and interrupt vectors of the microprocessor. Table 1 gives the memory map for interrupt vectors.


VMA
(NOTE) If option 1 is chosen, $\overline{\text { RES }}$ and RE pins can be tied together.
Figure 12 Power-up and Reset Timing


Figure 13 Power-down Sequence


Figure 14 MPU Flow Chart

Table 1 Memory Map for Interrupt Vectors

| Vector |  | Description |  |
| :---: | :---: | :---: | :---: |
| MS | LS |  |  |
| FFFE | FFFF | Restart | ( $\overline{\mathrm{RES}}$ ) |
| FFFC | FFFD | Non-Maskable Inter | (NMI) |
| FFFA | FFFB | Software Interrupt | (SWI) |
| FFF8 | FFF9 | Interrupt Request | ( $\overline{\mathrm{RO}}$ ) |

- RAM Enable (RE)

A TTL-compatible RAM enable input controls the on-chip RAM of the HD6802. When placed in the "High" state, the on-chip memory is enabled to respond to the MPU controls. In the "Low" state, RAM is disabled. This pin may also be utilized to disable reading and writing the on-chip RAM during a power-down situation. RAM enable must be "Low" three cycles before $\mathrm{V}_{\mathrm{CC}}$ goes below 4.75 V during power-down.

RE should be tied to the correct "High" or "Low" state if not used. This is good engineering design practice in general and necessary to insure proper operation of the part.

## - EXTAL and XTAL

The HD6802 has an internal oscillator that may be crystal controlled. These connections are for a parallel resonant fundamental crystal (AT cut). A divide-by-four circuit has been added to the HD6802 so that a 4 MHz crystal may be used in lieu of a 1 MHz crystal for a more cost-effective system. Pin39 of the HD6802 may be driven externally by a TTL input signal if a separate clock is required. Pin38 is to be left open in this mode.

An RC network is not directly usable as a frequency source on pins 38 and 39. An RC network type TTL or CMOS oscillator will work well as long as the TTL or CMOS output drives the HD6802.

If an external clock is used, it may not be halted for more than $4.5 \mu \mathrm{~s}$. The HD6802 is a dynamic part except for the internal RAM, and requires the external clock to retain information.

Conditions for Crystal ( 4 MHz )

- AT Cut Parallel resonant
- $\mathrm{C}_{0}=7 \mathrm{pF}$ max.
- $\mathrm{R}_{1}=80 \Omega$ max.


Crystal Equivalent Circuit

Recommended Oscillator (4MHz)


Figure 15 Crystal Oscillator

When using the crystal, see the note for Board Design of the Oscillation Circuit in HD6802.

## - Memory Ready (MR)

MR is a TTL compatible input control signal which allows stretching of E . When MR is "High", E will be in normal operation. When MR is "Low", E may be stretched integral multiples of half periods, thus allowing interface to slow memories. Memory Ready timing is shown in Fig. 16.

MR should be tied "High" if not used. This is good engineering design practice in general and necessary to insure proper operation of the part. A maximum stretch is $4.5 \mu \mathrm{~s}$.


Figure 16 Memory Ready Control Function

- Enable (E)

This pin supplies the clock for the MPU and the rest of the system. This is a single phase, TTL compatible clock. This clock may be conditioned by a Memory Ready Signal. This is equivalent to $\phi_{2}$ on the HD6800.

- $\mathbf{V C C}_{\mathbf{C t}}$ Standby

This pin supplies the dc voltage to the first 32 bytes of RAM as well as the RAM Enable (RE) control logic. Thus retention of data in this portion of the RAM on a power up, power-down, or standby condition is guaranteed at the range of 4.0 V to 5.25 V .

Maximum current drain at 5.25 V is 8 mA .

## - MPU INSTRUCTION SET

The HD6802 has a set of 72 different instructions. Included are binary and decimal arithmetic, logical, shift, rotate, load, store, conditional or unconditional branch, interrupt and stack manipulation instructions.

This instruction set is the same as that for the 6800MPU(HD6800 etc.) and is not explained again in this data sheet.

- NOTE FOR BOARD DESIGN OF THE OSCILLATION CIRCUIT IN HD6802
In designing the board, the following notes should be taken when the crystal oscillator is used.


Crystal oscillator and load capacity $\mathbf{C}_{\mathbf{L}}$ must be placed near the LSI as much as possible.
Normal oscillation may be disturbed when external noise is induced to pin 38 and 39.

Pin 38 signal line should be wired apart from pin 37 signal line as much as possible. Don't wire them in parallel, or normal oscillation may be disturbed when E signal is feedbacked to XTAL.

The following design must be avoided.


A signal line or a power source line must not cross or go near the oscillation circuit line as shown in the left figure to prevent the induction from these lines and perform the correct oscillation. The resistance among XTAL, EXTAL and other pins should be over $10 \mathrm{M} \Omega$.

Figure 17 Note for Board Design of the Oscillation Circuit


Figure 18 Example of Board Design Using the Crystal Oscillator

## - NOTE FOR THE RELATION BETWEEN WAI INSTRUCTION AND HALT OPERATION OF HD6802

When HALT input signal is asserted to "Low" level, the MPU will be halted after the execution of the current instruction except WAI instruction.

The "Halt" signal is not accepted after the fetch cycle of the WAI instruction (See (1) in Fig. 19). In the case of the "WAI" instruction, the MPU enters the "WAIT" cycle after stacking the internal registers and
outputs the "High" level on the BA line.
When an interrupt request signal is input to the MPU, the MPU accepts the interrupt regardless the "Halt" signal and releases the "WAIT" state and outputs the interrupt's vector address. If the "Halt" signal is "Low" level, the MPU halts after the fetch of new PC contents. The sequense is shown below.


Figure 19 HD6802 WAIT CYCLE \& HALT Request

## HD6802W MPU (Microprocessor with Clock and RAM)

HD6802W is the enhanced version of HD6802 which contains MPU, clock and 256 bytes RAM. Internal RAM has been extended from 128 to 256 bytes to increase the capacity of system read/write memory for handling temporary data and manipulating the stack.

The internal RAM is located at hex addresses 0000 to 00 FF . The first 32 bytes of RAM, at hex addresses 0000 to 001 F , may be retained in a low power mode by utilizing $\mathrm{V}_{\mathrm{CC}}$ standby, thus facilitating memory retention during a power-down situation.

The HD6802W is completely software compatible with the HD6800 as well as the entire HMCS6800 family of parts. Hence, the HD6802W is expandable to 65 k words.


- features
- On-Chip Clock Circuit
- $256 \times 8$ Bit On-Chip RAM - PIN ARRANGEMENT
- 32 Bytes of RAM are Retainable
- Software-Compatible with the HD6800, HD6802
- Expandable to 65 k words
- Standard TTL-Compatible Inputs and Outputs
- 8 Bit Word Size
- 16 Bit Memory Addressing
- Interrupt Capability


(Top View)

A expanded block diagram of the HD6802W is shown in Fig. 1. As shown, the number and configuration of the registers are
the same as the HD6802 except that the internal RAM has been extended to 256 bytes.


Figure 1 Expanded Block Diagram

Address Map of RAM is shown is Fig. 2.
The HD6802W has 256 bytes of RAM on the chip located at hex addresses 0000 to 00 FF . The first 32 bytes of RAM, at hex addresses 0000 to 001 F , may be retained in a low power
mode by utilizing $\mathrm{V}_{\mathrm{CC}}$ standby and setting RAM Enable Signal "Low" level, thus facilitating memory retention during a power-down situation.


Figure 2 Address Map of HD6802W

## ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\begin{aligned} & \hline \mathrm{V}_{\mathrm{cc}}^{*}{ }^{*} \\ & \mathrm{~V}_{\mathrm{cc}} \text { Standby* } \end{aligned}$ | -0.3~+7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20~+75 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {sto }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

* With respect to $V_{S S}$ (SYSTEM GND)
(NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.


## - RECOMMENDED OPERATING CONDITIONS

| Item |  | mbol | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}^{*} \\ & \mathrm{~V}_{\mathrm{CC}} \text { Standby* } \end{aligned}$ |  | 4.75 | 5.0 | 5.25 | V |
|  |  |  | 4.0 |  |  |  |
| Input Voltage |  | L* | -0.3 | - | 0.8 | V |
|  | $\mathrm{V}_{\mathrm{IH}}{ }^{*}$ | Except $\overline{\text { RES }}$ | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | V |
|  |  | $\overline{\text { RES }}$ | $\mathrm{V}_{\text {cc }}-0.75$ | - | $\mathrm{V}_{\mathrm{cc}}$ |  |
| Operation Temperature | $\mathrm{T}_{\text {opr }}$ |  | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

* With respect to $\mathrm{V}_{\mathbf{S S}}$ (SYSTEM GND)
- ELECTRICAL CHARACTERISTICS
- DC CHARACTERISTICS ( $\mathrm{V}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathbf{C C}} \operatorname{Standby}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.)


[^2]- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}$ Standby $=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}, \mathrm{Ta}=-\mathbf{2 0} \sim+\mathbf{7 5}{ }^{\circ} \mathrm{C}$, unless otherwise noted.)

1. CLOCK TIMING CHARACTERISTICS

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Frequency of Operation | Input Clock $\div 4$ | $f$ |  | 0.1 | - | 1.0 | MHz |
|  | Crystal Frequency | ${ }^{\text {fxtal }}$ |  | 1.0 | - | 4.0 |  |
| Cycle Time |  | teyc | Fig. 4, Fig. 5 | 1.0 | - | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width | "High" Level | $\mathrm{PW}_{\phi H}$ | at 2.4V (Fig. 4, Fig. 5) | 450 | - | 4500 | ns |
|  | "Low" Level | $\mathrm{PW}_{\phi L}$ | at 0.8 V (Fig. 4, Fig. 5) |  |  |  |  |
| Clock Fall Time |  | $\dagger_{\phi}$ | 0.8V ~ 2.4V (Fig.4,Fig.5) | - | - | 25 | ns |

## 2. READ/WRITE TIMING

| Item | Symbol | Test Condition | min | typ* | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Delay | $t_{A D}$ | Fig. 4, Fig. 5, Fig. 8 | - | - | 270 | ns |
| Peripheral Read Access Time | $\mathrm{t}_{\text {acc }}$ | Fig. 4 | 530 | - | - | ns |
| Data Setup Time (Read) | $\mathrm{t}_{\text {dSR }}$ | Fig. 4 | 100 | - | - | ns |
| Input Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | Fig. 4 | 10 | - | - | ns |
| Output Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | Fig. 5 | 20 | - | - | ns |
| Address Hold Time (Address, $\mathrm{R} / \overline{\mathrm{W}}$, VMA) | ${ }^{\text {t }}{ }_{\text {AH }}$ | Fig. 4, Fig. 5 | 10 | - | - | ns |
| Data Delay Time (Write) | todw | Fig. 5 | - | - | 225 | ns |
| Bus Available Delay | $t_{\text {BA }}$ | Fig. 6, Fig. 7, Fig. 9, Fig. 10 | - | - | 250 | ns |
| Processor Controls <br> Processor Control Setup Time | ${ }_{\text {tpCs }}$ | Fig. $6 \sim$ Fig. 9, Fig. 11 | 200 | - | - | ns |
| Processor Control Rise and Fall Time (Measured at 0.8 V and 2.0 V ) | ${ }^{\text {tpCr }}$, tpCf | Fig. $6 \sim$ Fig. 9, Fig. 11, Fig. 12, Fig. 14 | - | - | 100 | ns |

* $\mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$

3. POWER DOWN SEQUENCE TIMING, POWER UP RESET TIMING AND MEMORY READY TIMING

| Item | Symbol | Test Condition | $\min$ | typ | $\max$ | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| RAM Enable Reset Time (1) | $\mathrm{t}_{\text {RE1 }}$ | Fig. 12 | 150 | - | - | ns |
| RAM Enable Reset Time (2) | $\mathrm{t}_{\text {RE2 }}$ | Fig. 12 | E-3 cycles | - | - |  |
| Reset Release Time | $\mathrm{t}_{\text {LRES }}$ | Fig. 11 | 20 | - | - | ms |
| RAM Enable Reset Time (3) | $\mathrm{t}_{\text {RE3 }}$ | Fig. 11 | 0 | - | - | ns |
| Memory Ready Setup Time | $\mathrm{t}_{\text {SMR }}$ | Fig. 14 | 300 | - | - | ns |
| Memory Ready Hold Time | $\mathrm{t}_{\text {HMR }}$ | Fig. 14 | 0 | - | 200 | ns |


$C=130 \mathrm{pF}$ for $D_{0} \sim D_{7}, E$
$=90 \mathrm{pF}$ for $A_{0} \sim A_{15}, R / \bar{W}$, and VMA
$=30 \mathrm{pF}$ for BA
$R=11 \mathrm{k} \Omega$ for $D_{0} \sim D_{\eta}, E$
$=16 \mathrm{k} \Omega$ for $A_{0} \sim A_{15}^{7}, R / \bar{W}$, and VMA
$=24 \mathrm{k} \Omega$ for $B A$
C includes stray Capacitance.
All diodes are 1S2074(H) or equivalent
Figure 3 Bus Timing Test Load


Figure 4 Read Data from Memory or Peripherals


Figure 5 Write Data in Memory or Peripherals


Figure 6 Timing of $\overline{\text { HALT }}$ and BA


Figure 7 Timing of $\overline{\text { HALT }}$ and BA


Figure $8 \overline{\text { RES }}$ and MPU Restart Sequence


Figure $9 \overline{\mathrm{RO}}$ and $\overline{\mathrm{NMI}}$ Interrupt Timing


Figure 10 WAI Instruction and BA Timing

## - HD6802W MPU SIGNAL DESCRIPTION

- Address Bus ( $\mathrm{A}_{0} \sim \mathrm{~A}_{15}$ )

Sixteen pins are used for the address bus. The outputs are capable of driving one standard TTL load and 90 pF .

- Data Bus ( $D_{0} \sim D_{7}$ )

Eight pins are used for the data bus. It is bidirectional, transferring data to and from the memory and peripheral devices. It also has three-state output buffers capable of driving one standard TTL load and 130 pF .

Data Bus will be in the output mode when the internal RAM is accessed. This prohibits external data entering the MPU. It should be noted that the internal RAM is fully decoded from $\$ 0000$ to $\$ 00 \mathrm{FF}$. External RAM at $\$ 0000$ to $\$ 00 \mathrm{FF}$ must be disabled when internal RAM is accessed.

## - HALT

When this input is in the "Low" state, all activity in the machine will be halted: This input is level sensitive.

In the halt mode, the machine will stop at the end of an instruction. Bus Available will be at a "High" state. Valid Memory Address will be at a "Low" state. The address bus will display the address of the next instruction.

To insure single instruction operation, transition of the HALT line must not occur during the last $t_{\text {PCS }}$ of $E$ and the HALT line must go "High" for one Clock cycle.

HALT should be tied "High" if not used. This is good engineering design practice in general and necessary to insure proper operation of the part.

## - Read/Write (R/W)

This TTL compatible output signals the peripherals and memory devices whether the MPU is in a Read ("High") or Write ("Low") state. The normal standby state of this signal is Read ("High"). When the processor is halted, it will be in the logical one state ("High").

This output is capable of driving one standard TTL load and 90 pF .

## - Valid Memory Address (VMA)

This output indicates to peripheral devices that there is a valid address on the address bus. In normal operation, this signal should be utilized for enabling peripheral interfaces such as the PIA and ACIA. This signal is not three-state. One standard TTL load and 90 pF may be directly driven by this active high signal.

## - Bus Available (BA)

The Bus Available signal will normally be in the "Low" state. When activated, it will go to the "High" state indicating that the microprocessor has stopped and that the address bus is available (but not in a three-state condition). This will occur if the HALT line is in the "Low" state or the processor is in the wait state as a result of the execution of a WAI instruction. At such time, all three-state output drivers will go to their off state and other outputs to their normally inactive level.

The processor is removed from the wait state by the occurrence of a maskable (mask bit $\mathrm{I}=0$ ) or nonmaskable interrupt. This output is capable of driving one standard TTL load and 30 pF .

## - Interrupt Request (IRQ)

This level sensitive input requests that an interrupt sequence
be generated within the machine. The processor will wait, until it completes the current instruction that is being executed before it recognizes the request. At that time, if the interrupt mask bit in the Condition Code Register is not set, the machine will begin an interrupt sequence. The index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. Next the MPU will respond to the interrupt request by setting the interrupt mask bit high so that no further interrupts may occur. At the end of the cycle, a 16 -bit address will be loaded that points to a vectoring address which is located in memory locations FFF8 and FFF9. An address loaded at these locations causes the MPU to branch to an interrupt routine in memory.

The HALT line must be in the "High" state for interrupts to be serviced. Interrupts will be latched internally while HALT is "Low".

A $3 \mathrm{k} \Omega$ external register to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts.

## - Reset ( $\overline{\mathrm{RES}}$ )

This input is used to reset and start the MPU from a power-down condition, resulting from a power failure or an initial start-up of the processor. When this line is "Low", the MPU is inactive and the information in the registers will be lost. If a "High" level is detected on the input, this will signal the MPU to begin the restart sequence. This will start execution of a routine to initialize the processor from its reset condition. All the higher order address lines will be forced "High". For the restart, the last two(FFFE, FFFF) locations in memory will be used to load the program that is addressed by the program counter. During the restart routine, the interrupt mask bit is set and must be reset before the MPU can be interrupted by IRQ. Power-up and reset timing and power-down sequences are shown in Fig. 11 and Fig. 12 respectively.

## - Non-Maskable Interrupt (NMI)

A low-going edge on this input requests that a non-maskinterrupt sequence be generated within the processor. As with the IRQ signal, the processor will complete the current instruction that is being executed before it recognizes the $\overline{\text { NMI }}$ signal. The interrupt mask bit in the Condition Code Register has no effect on NMI.

The Index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. At the end of the cycle, a 16-bit address will be loaded that points to a vectoring address which is located in memory locations FFFC and FFFD. An address loaded at these locations causes the MPU to branch to a non-maskable interrupt routine in memory. A $3 \mathrm{k} \Omega$ external resistor to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts.

Inputs $\overline{\text { IRQ }}$ and $\overline{\text { NMI }}$ are hardware interrupt lines that are sampled when E is "High" and will start the interrupt routine on a "Low" E following the completion of an instruction. $\overline{\mathrm{IRQ}}$ and NMI should be tied "High" if not used. This is good engineering design practice in general and necessary to insure proper operation of the part. Fig. 13 is a flowchart describing the major decision paths and interrupt vectors of the microprocessor. Table 1 gives the memory map for interrupt vectors.

(NOTE) If option 1 is chosen, $\overline{R E S}$ and RE pins can be tied together.
Figure 11 Power-up and Reset Timing


Figure 12 Power-down Sequence


Figure 13 MPU Flow Chart

Table 1 Memory Map for Interrupt Vectors

| Vector |  | Description |  |
| :---: | :---: | :---: | :---: |
| MS | LS |  |  |
| FFFE | FFFF | Restart | ( $\overline{\mathrm{RES}})$ |
| FFFC | FFFD | Non-Maskable Inter | (NMI) |
| FFFA | FFFB | Software Interrupt | (SWI) |
| FFF8 | FFF9 | Interrupt Request | ( $\overline{\mathrm{RO}}$ ) |

- RAM Enable (RE)

A TTL-compatible RAM enable input controls the on-chip RAM of the HD6802W. When placed in the "High" state, the on-chip memory is enabled to respond to the MPU controls. In the "Low" state, RAM is disabled. This pin may also be utilized to disable reading and writing the on-chip RAM during a power-down situation. RAM enable must be "Low" three cycles before $\mathrm{V}_{\mathrm{CC}}$ goes below 4.75 V during power-down.

RE should be tied to the correct "High" or "Low" state if not used. This is good engineering design practice in general and necessary to insure proper operation of the part.

## - EXTAL and XTAL

The HD6802W has an internal oscillator that may be crystal controlled. These connections are for a parallel resonant fundamental crystal (AT cut). A divide-by-four circuit has been added to the HD6802W so that a 4 MHz crystal may be used in lieu of a 1 MHz crystal for a more cost-effective system. Pin39 of the HD6802W may be driven externally by a TTL input signal if a separate clock is required. Pin 38 is to be left open in this mode.

An RC network is not directly usable as a frequency source on pins 38 and 39. An RC network type TTL or CMOS oscillator will work well as long as the TTL or CMOS output drives the HD6802W.

If an external clock is used, it may not be halted for more than $4.5 \mu \mathrm{~s}$. The HD6802W is a dynamic part except for the internal RAM, and requires the external clock to retain information.

Conditions for Crystal ( 4 MHz )

- AT Cut Parallel resonant
- $\mathrm{C}_{0}=7 \mathrm{pF}$ max.
- $\mathrm{R}_{1}=80 \Omega$ max.


Crystal Equivalent Circuit


When using the crystal, see the note for Board Design of the Oscillation Circuit in HD6802W.

## - Memory Ready (MR)

MR is a TTL compatible input control signal which allows stretching of $E$. When MR is "High", E will be in normal operation. When MR is "Low", E may be stretched integral multiples of half periods, thus allowing interface to slow memories. Memory Ready timing is shown in Fig. 14.

MR should be tied "High" if not used. This is good engineering design practice in general and necessary to insure proper operation of the part. A maximum stretch is $4.5 \mu \mathrm{~s}$.


Figure 14 Memory Ready Control Function

## - Enable (E)

This pin supplies the clock for the MPU and the rest of the system. This is a single phase, TTL compatible clock. This clock may be conditioned by a Memory Ready Signal. This is equivalent to $\phi_{2}$ on the HD6800.

- $\mathbf{V c c}^{\text {Standby }}$

This pin supplies the dc voltage to the first 32 bytes of RAM as well as the RAM Enable (RE) control logic. Thus retention of data in this portion of the RAM on a power-up, power-down, or standby condition is guaranteed at the range of 4.0 V to 5.25 V .

Maximum current drain at 5.25 V is 8 mA .

## - MPU INSTRUCTION SET

The HD6802W has a set of 72 different instructions. Included are binary and decimal arithmetic, logical, shift, rotate, load, store, conditional or unconditional branch, interrupt and stack manipulation instructions.

This instruction set is the same as that for the 6800 MPU (HD6800 etc.) and is not explained again in this data sheet.

- NOTE FOR BOARD DESIGN OF THE OSCILLATION CIRCUIT IN HD6802W
In designing the board, the following notes should be taken when the crystal oscillator is used.


Crystal oscillator and load capacity $\mathbf{C}_{\mathbf{L}}$ must be placed near the LSI as much as possible.

Normal oscillation may be disturbed when external noise is] induced to pin 38 and 39.

Pin 38 signal line should be wired apart from pin 37 signal line as much as possible. Don't wire them in parallel, or normal oscillation may be disturbed when E signal is feedbacked to XTAL.

The following design must be avoided.


A signal line or a power source line must not cross or go near the oscillation circuit line as shown in the left figure to prevent the induction from these lines and perform the correct oscillation. The resistance among XTAL, EXTAL and other pins should be over $10 \mathrm{M} \Omega$.

Figure 15 Note for Board Design of the Oscillation Circuit


Figure 16 Example of Board Design Using the Crystal Oscillator

- NOTE FOR THE RELATION BETWEEN WAI INSTRUCTION AND HALT OPERATION OF HD6802W

When HALT input signal is asserted to "Low" level, the MPU will be halted after the execution of the current instruction except WAI instruction.

The "Halt" signal is not accepted after the fetch cycle of the WAI instruction (See(1) in Fig. 17). In the case of the "WAI" instruction, the MPU enters the "WAIT" cycle after stacking the internal registers and
outputs the "High" level on the BA line.
When an interrupt request signal is input to the MPU, the MPU accepts the interrupt regardless the "Halt" signal and releases the "WAIT" state and outputs the interrupt's vector address. If the "Halt" signal is "Low" level, the MPU halts after the fetch of new PC contents. The sequense is shown below.


Figure 17 HD6802W WAIT CYCLE \& $\overline{\text { HALT }}$ Request

# HD6803, HD6803-1 MPU (Micro Processing Unit) 

The HD6803 MPU is an 8 -bit micro processing unit which is compatible with the HMCS6800 family of parts. The HD6803 MPU is object code compatible with the HD6800 with improved execution times of key instructions plus several new 16 -bit and 8 -bit instruction including an $8 \times 8$ unsigned multiply with 16 -bit result. The HD6803 MPU can be expanded to 65 k bytes. The HD6803 MPU is TTL compatible and requires one +0.5 volt power supply. The HD6803 MPU has 128 bytes of RAM, Serial Communications Interface (S.C.I.), and parallel I/O as well as a three function 16 -bit timer. Features and Block Diagram of the HD6803 include the following:

## - FEATURES

- Expanded HMCS6800 Instruction Set
- $8 \times 8$ Multiply
- On-Chip Serial Communications Interface (S.C.I.)
- Object Code Compatible with The HD6800 MPU
- 16-Bit Timer
- Expandable to 65 k Bytes
- Multiplexed Address and Data
- 128 Bytes of RAM (64 Bytes Retainable On Power Down)
- 13 Parallel I/O Lines
- Internal Clock/Divided-By-Four
- TTL Compatible Inputs and Outputs
- Interrupt Capability
- Compatible with MC6803 and MC6803-1
- BLOCK DIAGRAM


- PIN ARRANGEMENT

\begin{tabular}{|c|c|c|}
\hline $$
\begin{array}{r}
v_{\text {SS }}^{1} \\
\times T A L \sqrt{2}
\end{array}
$$ \& \multirow[t]{19}{*}{O

HD6803} \& 30 Ea <br>
\hline Extal 3 \& \& 38 RN <br>
\hline तला 4 \& \& $3 \mathrm{D}_{0} / \mathrm{A}_{0}$ <br>
\hline $\overline{\mathrm{IRO}, 5}$ \& \& $3 \mathrm{D}_{1} / \mathrm{A}_{1}$ <br>
\hline RES 6 \& \& $3 \mathrm{D}_{2} / \mathrm{A}_{2}$ <br>
\hline $\mathrm{vcc}^{7}$ \& \& (3) $\mathrm{D}_{3} / \mathrm{A}_{3}$ <br>
\hline $P^{210} 8$ \& \& $3 \mathrm{D}_{4} / A_{4}$ <br>
\hline $P_{21} 9$ \& \& (32) $\mathrm{D}_{5} / \mathrm{A}_{5}$ <br>
\hline $P_{2} 10$ \& \& 31 $\mathrm{D}_{6} / A_{6}$ <br>
\hline $P_{2}$, 11 \& \& $3 \mathrm{~S}_{7} / \mathrm{A}_{7}$ <br>
\hline $P_{24} 12$ \& \& $29 A_{*}$ <br>
\hline $P_{10} 113$ \& \& $28 A_{9}$ <br>
\hline $P_{1} 114$ \& \& $27 A_{10}$ <br>
\hline $P_{12} 15$ \& \& $26 A_{11}$ <br>
\hline $P_{1}, 16$ \& \& 25 $A_{12}$ <br>
\hline P. 17 \& \& (44) $A_{13}$ <br>
\hline $P_{15} 18$ \& \& $23 A_{14}$ <br>
\hline $P_{16} 19$ \& \& (2) $A_{15}$ <br>
\hline $P_{1}, 20$ \& \& 21 $\mathrm{v}_{\text {cc }}$ Standbv <br>
\hline
\end{tabular}

(Top View)

- TYPE OF PRODUCTS

| Type No. | Bus Timing |
| :--- | :--- |
| HD6803 | 1.0 MHz |
| HD6803-1 | 1.25 MHz |

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {xa }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

- With respect to $V_{\text {SS }}$ (SYSTEM GND)
[NOTE] Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.


## - electrical characteristics

- DC CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\text {ss }}=\mathbf{0 V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input "High" Voltage | $\overline{\text { RES }}$ | $\mathrm{V}_{\mathrm{iH}}$ |  | 4.0 | - | $\mathrm{V}_{\text {cc }}$ | V |
|  | Other Inputs* |  |  | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ |  |
| Input "Low" Voltage | All Inputs* | $V_{\text {IL }}$ |  | -0.3 | - | 0.8 | V |
| Input Load Current | EXTAL | $\left\|1 i_{\text {in }}\right\|$ | $\mathrm{V}_{\text {in }}=0 \sim \mathrm{~V}_{\mathrm{cc}}$ | - | - | 0.8 | mA |
| Input Leakage Current | $\overline{\mathrm{NMI}}, \overline{\mathrm{R} \mathrm{R}_{1}}, \overline{\mathrm{RES}}$ | $\|\mathrm{lin}\|$ | $V_{\text {in }}=0 \sim 5.25 \mathrm{~V}$ | - | - | 2.5 | $\mu \mathrm{A}$ |
| Three State (Offset) Leakage Current | $P_{10} \sim P_{17}, D_{0} / A_{0} \sim D_{7} / A_{7}$ | $\\|_{\text {ts }}{ }^{\text {I }}$ | $\mathrm{V}_{\text {in }}=0.5 \sim 2.4 \mathrm{~V}$ | - | - | 10 | $\mu \mathrm{A}$ |
|  | $\mathrm{P}_{20} \sim \mathrm{P}_{24}$ |  |  | - | - | 100 |  |
| Output "High" Voltage | $\mathrm{D}_{0} / A_{0} \sim D_{7} / A_{7}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\text {LOAD }}=-205 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  | $A_{8} \sim A_{15}, E, R \bar{W}, A S$ |  | $\mathrm{I}_{\text {LOAD }}=-145 \mu \mathrm{~A}$ | 2.4 | - | - |  |
|  | Other Outputs |  | $\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}$ | 2.4 | - | - |  |
| Output "Low" Voltage | All Outputs | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}$ | - | - | 0.5 | V |
| Darlington Drive Current | $\mathrm{P}_{10} \sim \mathrm{P}_{17}$ | $-^{-1}$ | $\mathrm{V}_{\text {out }}=1.5 \mathrm{~V}$ | 1.0 | - | 10.0 | mA |
| Power Dissipation |  | $\mathrm{P}_{\mathrm{D}}$ |  | - | - | 1200 | mW |
| Input Capacitance | $\mathrm{D}_{0} / \mathrm{A}_{0} \sim \mathrm{D}_{7} / \mathrm{A}_{7}$ | $\mathrm{C}_{\text {in }}$ | $\begin{aligned} & V_{\text {in }}=0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}, \\ & f=1.0 \mathrm{MHz} \end{aligned}$ | - | - | 12.5 | pF |
|  | Other Inputs |  |  | - | - | 10.0 |  |
| $V_{\text {cc }}$ Standby | Powerdown | $\mathrm{V}_{\text {SBB }}$ |  | 4.0 | - | 5.25 | V |
|  | Operating | $\mathrm{V}_{\text {SB }}$ |  | 4.75 | - | 5.25 |  |
| Standby Current | Powerdown | $\mathrm{I}_{\text {SBB }}$ | $\mathrm{V}_{\text {SBB }}=4.0 \mathrm{~V}$ | - | - | 8.0 | mA |

*Except Mode Programming Levels.

## - AC CHARACTERISTICS

BUS TIMING ( $\mathrm{VCC}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\text {SS }}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

*These timings change in approximate proportion to $t_{c y c}$. The figures in this characteristics represent those when $t_{c y c}$ is minimum (= in the highest speed operation).

PERIPHERAL PORT TIMING $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Peripheral Data Setup Time | Port 1, 2 | tposu | Fig. 2 | 200 | - | - | ns |
| Peripheral Data Hold Time | Port 1, 2 | $\mathrm{t}_{\text {PDH }}$ | Fig. 2 | 200 | - | - | ns |
| Delay Time, Enable Negative Transition to Peripheral Data Valid | Port 1, 2* | $t_{\text {Pwo }}$ | Fig. 3 | - | - | 400 | ns |

[^3]TIMER, SCI TIMING ( $\mathbf{V}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\text {SS }}=\mathbf{O V}, \mathbf{T a}=\mathbf{0} \sim+70^{\circ} \mathrm{C}$, unless otherwise noted. $)$

| Item | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Timer Input Pulse Width | $\mathrm{t}_{\text {PWT }}$ |  | $2 \mathrm{t}_{\mathrm{cyc}}+200$ | - | - | ns |
| Delay Time, Enable Positive Transition to Timer Out | ${ }^{\text {tod }}$ | Fig. 4 | - | - | 600 | ns |
| SCI Input Clock Cycle | $\mathrm{t}_{\text {scyc }}$ |  | 1 | - | - | $\mathrm{t}_{\text {cre }}$ |
| SCI Input Clock Pulse Width | $\mathrm{t}_{\text {Pwsck }}$ |  | 0.4 | - | 0.6 | ${ }^{\text {Scerc }}$ |

MODE PROGRAMMING ( $\mathbf{V C C}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathbf{S S}}=\mathbf{0 V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode Programming Input "Low" Voltage |  | $V_{\text {MPL }}$ | Fig. 5 | - | - | 1.7 | V |
| Mode Programming Input "High" Voltage |  | $V_{\text {MPH }}$ |  | 4.0 | - | - | V |
| $\overline{\text { RES }}$ "Low" Pulse Width |  | PW ${ }_{\text {RSTL }}$ |  | 3.0 | - | - | $t_{\text {cyc }}$ |
| Mode Programming Set-up Time |  | $t_{\text {MPS }}$ |  | 2.0 | - | - | $t_{\text {cyc }}$ |
| Mode Programming Hold Time | RES Rise Time $\geqq \mathbf{1} \boldsymbol{\mu} \mathrm{s}$ | $\mathbf{t M P H}^{\text {M }}$ |  | 0 | - | - | ns |
|  | RES Rise Time $<1 \mu \mathrm{~s}$ |  |  | 100 | - | - | ns |



Figure 1 Expanded Multiplexed Bus Timing
 (MPU Read)

Figure 3 Port Data Delay Timing (MPU Write)


Figure 5 Mode Programming Timing


Figure 4 Timer Output Timing

$C=90 p F$ for $D_{0} / A_{0} \sim D_{7} / A_{7}, A_{8} \sim A_{15}, E, A S, R / W$
$=30 \mathrm{pF}$ for $P_{10} \sim P_{17}, P_{20} \sim P_{24}$
$R=12 \mathrm{k} \Omega$ for $D_{0} / A_{0} \sim D_{7} / A_{7}, A_{8} \sim A_{15}, E, A S, R / \bar{W}$
$=24 \mathrm{k} \Omega$ for $P_{10} \sim P_{17}, P_{20} \sim P_{24}$
TTL Load

Figure 6 Bus Timing Test Load


- IRO: ; Internal interrupt

Figure 7 Interrupt Sequence


Figure 8 Reset Timing

## - SIGNAL DESCRIPTIONS

- Vcc and Vss

These two pins are used to supply power and ground to the chip. The voltage supplied will be +5 volts $\pm 5 \%$.

- XTAL and EXTAL

These connections are for a parallel resonant fundamental crystal, AT cut. Devide-by-4 circuitry is included with the internal clock, so a 4 MHz crystal may be used to run the system at 1 MHz . The devide-by- 4 circuitry allows for use of the inexpensive 3.58 MHz Color TV crystal for non-time critical applications. Two 22 pF capacitors are needed from the two crystal pins to ground to insure reliable operation. An example of the crystal interface is shown in Fig. 9. EXTAL may be driven by an external TTL compatible source with a $45 \%$ to $55 \%$ duty cycle. It will devided by 4 any frequency less than or equal to 5 MHz . XTAL must be grounded if an external clock is used.

Nominal Crystal Parameter

| Crystal | 4 MHz | 5 MHz |
| :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{O}}$ | 7 PFF max. | 4.7 pF max. |
| $\mathrm{R}_{\mathrm{S}}$ | $60 \Omega$ max. | $30 \Omega$ typ. |



Figure 9 Crystal Interface

## - Vcc Standby

This pin will supply +5 volts $\pm 5 \%$ to the standby RAM on the chip. The first 64 bytes of RAM will be maintained in the power down mode with 8 mA current max. The circuit of figure 13 can be utilized to assure that $\mathrm{V}_{\mathrm{Cc}}$ Standby does not go below $\mathbf{V}_{\text {SBB }}$ during power down.

To retain information in the RAM during power down the following procedure is necessary:

1) Write " 0 " into the RAM enable bit, RAME. RAME is bit 6 of the RAM Control Register at location \$0014. This disables the standby RAM, thereby protecting it at power down.
2) Keep $V_{C C}$ Standby greater than $V_{S B B}$.


Figure 10 Battery Backup for $\mathrm{V}_{\mathrm{cc}}$ Standby

## - Reset ( $\overline{R E S}$ )

This input is used to reset and start the MPU from a power down condition, resulting from a power failure or an initial startup of the processor. On power up, the reset must be held "Low" for at least 100 ms . When reset during operation, $\overline{\text { RES }}$ must be held "Low" at least 3 clock cycles.

When a "High" level is detected, the CPU does the following;

1) All the higher order address lines will be forced "High".
2) I/O Port 2 bits, 2, 1, and 0 are latched into programmed control bits PC2, PC1 and PC0.
3) The last two (\$FFFE, \$FFFF) locations in memory will be used to load the program addressed by the program counter.
4) The interrupt mask bit is set. Clear before the CPU can recognize maskable interrupts.

- Enable (E)

This supplies the external clock for the rest of the system when the internal oscillator is used. It is a single phase, TTL compatible clock, and will be the divide-by- 4 result of the crystal oscillator frequency. It will drive one TTL load and 90 pF capacitance.

## - Non-Maskable Interrupt (NMI)

When the falling edge of the input signal is detected at this pin, the CPU begins non-maskable interrupt sequence internally. As with interrupt Request signal, the processor will complete the current instruction that is being executed before it recognizes the NMI signal. The interrupt mask bit in the Condition Code Register has no effect on NMI.

In response to an NMI interrupt, the Index Register, Program Counter, Accumulators, and Condition Code Register are stored on the stack. At the end of the sequence, a 16 -bit address will be loaded that points to a vectoring address located in memory locations \$FFFC and \$FFFD. An address loaded at these locations causes the CPU to branch to a non-maskable interrupt service routine in memory.

A $3.3 \mathrm{k} \Omega$ external resistor to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts.

Inputs $\mathrm{IRQ}_{1}$ and $\overline{\mathrm{NMI}}$ are hardware interrupt lines that are sampled during $E$ and will start the interrupt routine on the
$\overline{\mathrm{E}}$ following the completion of an instruction.

## - Interrupt Request ( $\overline{\mathbf{R O}} \mathbf{Q}_{1}$ )

This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will complete the current instruction before it recognizes the request. At that time, if the interrupt mask bit in the Condition Code Register is not set, the machine will begin an interrupt sequence. The Index Register, Program Counter, Accumulators, and Condition Code Register are stored on the stack. Next the CPU will respond to the interrupt request by setting the interrupt mask bit "High" so that no further maskable interrupts may occur. At the end of the cycle, a 16 -bit address will be loaded that points to a vectoring address which is located in memory locations \$FFF8 and \$FFF9. An address loaded at these locations causes the CPU to branch to an interrupt routine in memory.

The $\overline{\mathrm{IRQ}}{ }_{1}$ requires a $3.3 \mathrm{k} \Omega$ external resistor to $\mathrm{V}_{\mathrm{CC}}$ which should be used for wire-OR and optimum control of interrupts. Internal Interrupts will use an internal interrupt line ( $\overline{\mathrm{IRQ}}_{2}$ ). This interrupt will operate the same as $\overline{I R Q}_{1}$ except that it will use the vector address of \$FFF0 through \$FFF7. $\overline{\mathrm{IRQ}}{ }_{1}$ will have priority to $\overline{\mathrm{IRQ}_{2}}$ if both occur at the same time. The Interrupt Mask Bit in the condition code register masks both interrupts (See Table 1).

Table 1 Interrupt Vector Location

| Vector |  | Interrupt |
| :--- | :---: | :---: |
| MSB | LSB |  |
| FFFE | FFFF | $\overline{\text { RES }}$ |
| FFFC | FFFD | $\overline{\text { NMI }}$ |
| FFFA | FFFB | Software Interrupt (SWI) |
| FFF8 | FFF9 | $\overline{\text { IRQ }} 1$ |
| FFF6 | FFF7 | ICF (Input Capture) |
| FFF4 | FFF5 | OCF (Output Compare) |
| FFF2 | FFF3 | TOF (Timer Overflow) |
| FFFO | FFF1 | SCI (RDRF + ORFE + TDRE) |

## - Read/Write (R/W)

This TTL compatible output signals the peripherals and memory devices whether the CPU is in a Read ("High") or a Write ("Low") state. The normal standby state of this signal is Read ("High"). This output can drive one TTL load and 90 pF capacitance.

## - Address Strobe (AS)

In the expanded multiplexed mode of operation, address strobe is output on this pin. This signal is used to latch the 8 LSB's of address which are multiplexed with data on $D_{0} / A_{0}$ to $\mathrm{D}_{7} / \mathrm{A}_{7}$. An 8-bit latch is utilized in conjunction with Address Strobe, as shown in figure 11. So $D_{0} / A_{0}$ to $D_{7} / A_{7}$ can become data bus during the E pulse. The timing for this signal is shown in Figure 1 of Bus Timing. This signal is also used to disable the address from the multiplexed bus allowing a deselect time, $\mathrm{t}_{\text {ASD }}$ before the data is enabled to the bus.

## - PORTS

There are two I/O ports on the HD6803 MPU; one 8 -bit port and one 5 -bit port. Each port has an associated write
only Data Direction Register which allows each I/O line to be programmed to act as an input or an output*. A " 1 " in the corresponding Data Direction Register bit will cause that I/O line to be an output. A " 0 " in the corresponding Data Direction Register bit will cause that I/O line to be an input. There are two ports: Port 1, Port 2. Their addresses and the addresses of their Data Direction registers are given in Table 2.

* The only exception is bit 1 of Port 2 , which can either be data input or Timer output.

Table 2 Port and Data Direction Register Addresses

| Ports | Port Address | Data Direction <br> Register Address |
| :---: | :---: | :---: |
| 1/O Port 1 | $\$ 0002$ | $\$ 0000$ |
| 1/O Port 2 | $\$ 0003$ | $\$ 0001$ |

- 1/O Port 1

This is an 8 -bit port whose individual bits may be defined as inputs or outputs by the corresponding bit in its data direction register. The 8 output buffers have three-state capability, allowing them to enter a high impedance state when the peripheral data lines are used as inputs. In order to be read properly, the voltage on the input lines must be greater than 2.0 V for a logic " 1 " and less than 0.8 V for a logic " 0 ". As outputs, these lines are TTL compatible and may also be used as a source of up to 1 mA at 1.5 V to directly drive a Darlington base. After reset, the $\mathrm{I} / \mathrm{O}$ lines are configured as inputs.

## - I/O Port 2

This port has five lines that may be defined as inputs or outputs by its data direction register. The 5 output buffers have three-state capability, allowing them to enter a high impedance

state when used as an input. In order to be read properly, the voltage on the input lines must be greater than 2.0 V for a logic " 1 " and less than 0.8 V for a logic "0". As outputs, this port has no internal pullup resistors but will drive TTL inputs directly. For driving CMOS inputs, external pullup resistors are required. After reset, the I/O lines are configured as inputs. Three pins on Port 2 (pin 8,9 and 10 of the chip) are requested to set following values (Table 3) during reset. The values of above three pins during reset are latched into the three MSBs (Bit 5,6 and 7) of Port 2 which are read only.

Port 2 can be configured as I/O and provides access to the Serial Communications Interface and the Timer. Bit 1 is the only pin restricted to data input or Timer output.

Table 3 The Values of three pins

| Pin Number | Value |
| :---: | :---: |
| 8 | L |
| 9 | H |
| 10 | L |

[NOTES] L; Logical " 0 "'
H; Logical "1"

- BUS
- Data/Address Lines ( $D_{0} / A_{0} \sim D_{7} / A_{7}$ )

Since the data bus is multiplexed with the lower order address bus in Data/Address, latches are required to latch those address bits. The 74LS373 Transparent Octal D-type latch can be used with the HD6803 to latch the least significant address byte. Figure 11 shows how to connect the latch to the HD6803. The output control to the 74LS373 may be connected to ground.

- Address Lines ( $A_{8} \sim A_{15}$ )

Each line is TTL compatible and can drive one TTL load and 90 pF . After reset, these pins become output for upper order address lines (As to A15).

## - INTERRUPT FLOWCHART

The Interrupt flowchart is depicted in Figure 16 and is common to every interrupt excluding reset.

Address: $A_{0} \sim A_{\text {, }}$
Function Table

| Output <br> Control | Enable |  | Output |
| :---: | :---: | :---: | :---: |
| L | $H$ | D | Q |
| L | $H$ | L | H |
| L | L | $X$ | $Q_{0}$ |
| $H$ | $X$ | $X$ | $Z$ |

Figure 11 Latch Connection

## - MEMORY MAP

The MPU can provide up to 65 k byte address space. A memory map is shown in Figure 12. The first 32 locations are reserved for the MPU's internal register area, as shown in Table 4 with exceptions as indicated.

Table 4 Internal Register Area

| Register | Address |
| :--- | :---: |
| Port 1 Data Direction Register*** | 00 |
| Port 2 Data Direction Register** | 01 |
| Port 1 Data Register | 02 |
| Port 2 Data Register | 03 |
| Not Used | $04^{*}$ |
| Not Used | $05^{*}$ |
| Not Used | $06^{*}$ |
| Not Used | $07^{*}$ |
| Timer Control and Status Register | 08 |
| Counter (High Byte) | 09 |
| Counter (Low Byte) | $0 A$ |
| Output Compare Register (High Byte) | $0 B$ |
| Output Compare Register (Low Byte) | $0 C$ |
| Input Capture Register (High Byte) | 00 |
| Input Capture Register (Low Byte) | $0 E$ |
| Not Used | $0 F^{*}$ |
| Rate and Mode Control Register | 10 |
| Transmit/Receive Control and Status Register | 11 |
| Receive Data Register | 12 |
| Transmit Data Register | 13 |
| RAM Control Register | 14 |
| Reserved | $15-1 F$ |

- External Address
* 1; Output, 0; Input



## [NOTE]

Excludes the following addresses which may be used externally: $\$ 04, \$ 05, \$ 06, \$ 07$, and \$0F.

Figure 12 HD6803 Memory Map

## PROGRAMMABLE TIMER

The HD6803 contains an on-chip 16-bit programmable timer which may be used to measure an input waveform while independently generating an output waveform. Pulse widths for both input and output signals may vary from a few microseconds to many seconds. The timer hardware consists of

- an 8 -bit control and status register,
- a 16 -bit free running counter,
- a 16-bit output compare register,
- a 16 -bit input capture register

A block diagram of the timer registers is shown in Figure 13.

- Free Running Counter ( $\$ 0009: \$ 000 \mathrm{~A})$

The key element in the programmable timer is a 16 -bit free running counter which is driven to increasing values by E (Enable). The counter value may be read by the CPU software at any time. The counter is cleared to zero by reset and may be considered a read-only register with one exception. Any CPU write to the counter's address (\$09) will always result in preset value of \$FFF8 being loaded into the counter regardless of the value involved in the write. This preset figure is intended for testing operation of the part, but may be of value in some applications.

## - Output Compare Register ( $\$ \mathbf{0 0 0 B} \mathbf{\$ 0 0 0 C}$ )

The Output Compare Register is a 16 -bit read/write register which is used to control an output waveform. The contents of this register are constantly compared with the current value of the free running counter. When a match is found, a flag is set (OCF) in the Timer Control and Status Register (TCSR) and the current value of the Output Level bit (OLVL) in the TCSR is clocked to the Output Level Register. Providing the Data Direction Register for Port 2, Bit 1 contains a "l" (Output), the output level register value will appear on the pin for Port 2 Bit 1. The values in the Output Compare Register and Output Level bit may then be changed to control the output level on the next compare value. The Output Compare Register is set to SFFFF during reset. The Compare function is inhibited for one cycle following a write to the high byte of the Output Compare Register to insure a valid 16 -bit value is in the register before a compare is made.

## - Input Capture Register (\$000D: $\mathbf{\$ 0 0 0 E}$ )

The Input Capture Register is a 16 -bit read-only register used to store the current value of the free running counter when the proper transition of an external input signal occurs. The input transition change required to trigger the counter transfer is controlled by the input Edge bit (IEDG) in the TCSR. The Data Direction Register bit for Port 2 Bit 0, should* be clear (zero) in order to gate in the external input signal to the edge detect unit in the timer.

The input pulse width must be at least two E-cycles to ensure an input capture under all conditions.

* With Port 2 Bit 0 configured as an output and set to " 1 ", the external input will still be seen by the edge detect unit.


Figure 13 Block Diagram of Programmable Timer

Timer Control and Status Register

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICF | OCF | TOF | EICI | EOCI | ETOI | IEDG | OLVL |

- Timer Control and Status Register (TCSR) (\$0008)

The Timer Control and Status Register consists of an 8 -bit register of which all 8 bits are readable but only the low order 5 bits may be written. The upper three bits contain read-only timer status information and indicate the followings:

- a proper transition has taken place on the input pin with a subsequent transfer of the current counter value to the input capture register.
- a match has been found between the value in the free running counter and the output compare register, and when $\$ 0000$ is in the free running counter.
Each of the flags may be enabled onto the HD6803 internal bus ( $\overline{\mathrm{RQ}_{2}}$ ) with an individual Enable bit in the TCSR. If the I-bit in the HD6803 Condition Code register has been cleared, a prior vectored interrupt will occur corresponding to the flag bit(s) set. A description for each bit follows:
Bit 0 OLVL Output Level - This value is clocked to the output level register on a successful output compare. If the DDR for Port 2 bit 1 is set. the value will appear on the output pin.
Bit 1 IEDG Input Edge - This bit controls which transition of an input will trigger a transfer of the counter to the input capture register. The DDR for Port 2 Bit 0 must be clear for this function to operate. IEDG $=0$ Transfer takes place on a negative edge ("High"-to-"Low" transition).
IEDG $=1$ Transfer takes place on a positive edge
("Low"-to-"High" transition).
Bit 2 ETOI Enable Timer Overflow Interrupt - When set, this bit enables $\overline{\mathrm{RQ}_{2}}$ to occur on the internal bus for a TOF interrupt; when clear the interrupt is inhibited.
Bit 3 EOCI Enable Output Compare Interrupt - When set, this bit enables $\overline{\mathrm{IRQ}_{2}}$ to appear on the internal bus for an output compare interrupt; when clear the interrupt is inhibited.
Bit 4 EICI Enable input Capture Interrupt - When set, this bit enables $\overline{\mathrm{IRQ}_{2}}$ to occur on the internal bus for an input capture interrupt; when clear the interrupt is inhibited.
Bit 5 TOF Timer Overflow Flag - This read-only bit is set when the counter contains \$FFFF. It is cleared by a read of the TCSR (with TOF set) followed by an CPU read of the Counter (\$09).
Bit 6 OCF Output Compare Flag - This read-only bit is set when a match is found between the output compare register and the free running counter. It is cleared by a read of the TCSR (with OCF set) followed by an CPU write to the output compare register (SOB or SOC).
Bit 7 ICF Input Capture Flag - This read-only status bit is set by a proper transition on the input; it is cleared by a read of the TCSR (with ICF set) followed by an CPU read of the Input Capture Register (\$0D).


## - SERIAL COMMUNICATIONS INTERFACE

The HD6803 contains a full-duplex asynchronous serial communications interface (SCI) on chip. The controller comprises a transmitter and a receiver which operate independently or each other but in the same data format and at the same data rate. Both transmitter and receiver communicate with the CPU via the data bus and with the outside world via pins 2, 3, and 4 of Port 2. The hardware, software, and registers are explained in the following paragraphs.

## - Wake-Up Feature

In a typical multi-processor application, the software protocol will usually contain a destination address in the initial byte(s) of the message. In order to permit non-selected MPU's to ignore the remainder of the message, a wake-up feature is included whereby all further interrupt processing may be optionally inhibited until the beginning of the next message. When the next message appears, the hardware re-enables (or "wakes-up") for the next message. The "wake-up" is automatically triggered by a string of ten consecutive l's which indicates an idle transmit line. The software protocol must provide for the short idle period between any two consecutive messages.

## - Programmable Options

The following features of the HD6803 serial I/O section are programmable:

- format - standard mark/space (NRZ)
- Clock - external or internal
- baud rate - one of 4 per given CPU $\phi_{2}$ clock frequency or external clock $\times 8$ input
- wake-up feature - enabled or disabled
- Interrupt requests - enabled or masked individually for transmitter and receiver data registers
- clock output - internal clock enabled or disabled to Port 2 (Bit 2)
- Port 2 (bits 3 and 4) - dedicated or not dedicated to serial I/O individually for transmitter and receiver.


## - Serial Communications Hardware

The serial communications hardware is controlled by 4 registers as shown in Figure 14. The registers include:

- an 8 -bit control and status register
- a 4-bit rate and mode control register (write only)
- an 8 -bit read only receive data register and
- an 8 -bit write only transmit data register.

In addition to the four registers, the serial I/O section utilizes bit 3 (serial input) and bit 4 (serial output) of Port 2. Bit 2 of Port 2 is utilized if the internal-clock-out or external-clock-in options are selected.

## Transmit/Receive Control and Status (TRCS) Register

The TRCS register consists of an 8 -bit register of which all 8 bits may be read while only bits $0 \sim 4$ may be written. The register is initialized to $\$ 20$ by reset. The bits in the TRCS register are defined as follows:


Figure 14 Serial I/O Registers
Bit 0 WU "Wake-up" on Next Message - set by HD6803 software and cleared by hardware on receipt of ten consecutive 1's or reset of RE flag. It should be noted that RE flag should be set in advance of CPU set of WU flag.
Bit 1 TE Transmit Enable - set by HD6803 to produce preamble of nine consecutive 1's and to enable gating of transmitter output to Port 2, bit 4 regardless of the DDR value corresponding to this bit; when clear, serial I/O has no effect on Port 2 bit 4.
TE set should be after at least one bit time of data transmit rate from the set-up of transmit data rate and mode.
Bit 2 TIE Transmit Interrupt Enable - when set, will permit an IRQ 2 interrupt to occur when bit 5 (TDRE) is set; when clear, the TDRE value is masked from the bus.
Bit 3 RE Receiver Enable - when set, gates Port 2 bit 3 to input of receiver regardless of DDR value for this bit; when clear, serial I/O has no effect on Port 2 bit 3.
Bit 4 RIE Receiver Interrupt Enable - when set, will permit an $\overline{\mathrm{IRQ}_{2}}$ interrupt to occur when bit 7 (RDRF) or bit 6 (ORFE) is set; when clear, the interrupt is masked.

Transmit/Receive Control and Status Register


Bit 5 TDRE Transmit Data Register Empty - set by hardware when a transfer is made from the transmit data register to the output shift register. The TDRE bit is cleared by reading the status register, then
writing a new byte into the transmit data register, TDRE is initialized to 1 by reset.
Bit 6 ORFE Over-Run-Framing Error - set by hardware when an overrun or framing error occurs (receive only).

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\times$ | $\times$ | $\times$ | $\times$ | $\mathrm{CC1}$ | CCO | SS 1 | SSO |

An overrun is defined as a new byte received with last byte still in Data Register/Buffer. A framing error has occured when the byte boundaries in bit stream are not synchronized to bit counter. If WU-flag is set, the ORFE bit will not be set. The ORFE bit is cleard by reading the status register, then reading the Receive Data Register, or by reset.
Bit 7 RDRF Receiver Data Register Full-set by hardware when a transfer from the input shift register to the receiver data register is made. If WU-flag is set, the RDRF bit will not be set. The RDRF bit is cleared by reading the status register, then reading the Receive Data Register, or by reset.

## Rate and Mode Control Register (RMCR)

The Rate and Mode Control register controls the following serial I/O variables:

- Baud rate
- format
- clocking source.
- Port 2 bit 2 configuration

The register consists of 4 bits all of which are write-only and cleared by reset. The 4 bits in the register may be considered as a pair of 2 -bit fields. The two low order bits control the bit rate for internal clocking and the remaining twq bits control the format and clock select logic. The register definition is as follows:
Bit 0 SSO 7 Speed Select - These bits select the Baud rate for Bit 1 SS1 $\}$ the internal clock. The four rates which may be selected are a function of the CPU $\phi_{2}$ clock frequency. Table 5 lists the available Baud rates.
Bit 2 CCO $\}$ Clock Control and Format Select - this 2-bit field Bit 3 CC1 $\}$ controls the format and clock select logic. Table 6 defines the bit field.

Table 5 SCI Bit Times and Rates

|  | XTAL | 2.4576 MHz | 4.0 MHz | 4.9152 MHz* |
| :---: | :---: | :---: | :---: | :---: |
| SS1 : SS0 | E | 614.4 kHz | 1.0 MHz | 1.2288 MHz |
| 00 | $E \div 16$ | $26 \mu \mathrm{~s} / 38,400$ Baud | $16 \mu \mathrm{~s} / 62,500$ Baud | $13.0 \mu \mathrm{~s} / 76,800$ Baud |
| 01 | $E \div 128$ | $208 \mu \mathrm{~s} / 4,800$ Baud | $128 \mu \mathrm{~s} / 7812.5$ Baud | $104.2 \mu \mathrm{~s} / 9,600$ Baud |
| 10 | $E \div 1024$ | 1.67 ms/600 Baud | 1.024 ms/976.6 Baud | $833.3 \mu \mathrm{~s} / 1,200$ Baud |
| 11 | $E \div 4096$ | $6.67 \mathrm{~ms} / 150$ Baud | 4.096 ms/244.1 Baud | 3.33 ms/300 Baud |

- HD6803.1 Only

Table 6 SCI Format and Clock Source Control

| CC1: CCO | Format | Clock Source | Port 2 Bit 2 | Port 2 Bit 3 | Port 2 Bit 4 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | - | - | - |
| 0 | 1 | NRZ | Internal | Not Used | $\ldots$ |
| 1 | 0 | NRZ | Internal | Output* | $\ldots$ |
| 1 | 1 | NRZ | External | Input | $\ldots$ |

- Clock output is available regardless of values for bits RE and TE.
* Bit 3 is used for serial input if RE = "1" in TRCS; bit 4 is used for serial output if TE = "1" in TRCS.


## Internally Generated Clock

If the user wishes for the serial I/O to furnish a clock, the following requirements are applicable:

- the values of RE and TE are immaterial.
- CC1. CC0 must be set to 10
- the maximum clock rate will be $E \div 16$.
- the clock will be at 1 x the bit rate and will have a rising edge at mid-bit.


## Externally Generated Clock

If the user wishes to provide an external clock for the serial $\mathrm{I} / \mathrm{O}$, the following requirements are applicable:

- the CC1, CC0, field in the Rate and Mode Control Register must be set to 11 ,
- the external clock must be set to 8 times $(\times 8)$ the desired baud rate and
- the maximum external clock frequency is 1.0 MHz .


## - Serial Operations

The serial I/O hardware should be initialized by the HD6803 software prior to operation. This sequence will normally consist of;

- writing the desired operation control bits to the Rate and Mode Control Register and
- writing the desired operational control bits in the Transmit/ Receive Control and Status Register.
The Transmitter Enable (TE) and Receiver Enable (RE) bits may be left set for dedicated operations.


## Transmit Operations

The transmit operation is enabled by the TE bit in the Transmit/Receive Control and Status Register. This bit when set, gates the output of the serial transmit shift register to Port 2 Bit 4 and takes unconditional control over the Data Direction Register value for Port 2, Bit 4.

Following a $\overline{\text { RES }}$ the user should configure both the Rate and Mode Control Register and the Transmit/Receive Control and Status Register for desired operation. Setting the TE bit during this procedure initiates the serial output by first transmitting a nine-bit preamble of l's. Following the preamble, internal synchronization is established and the transmitter section is ready for operation.

At this point one of two situation exist:

1) if the Transmit Data Register is empty (TDRE = 1), a continuous string of ones will be sent indicating an idle line, or,
2) if data has been loaded into the Transmit Data Register (TDRE $=0$ ), the word is transferred to the output shift register and transmission of the data word will begin.
During the data transmit, the 0 start bit is first transmitted. Then the 8 data bits (beginning with bit 0 ) followed by the stop bit, are transmitted. When the Transmitter Data Register has been emptied, the hardware sets the TDRE flag bit.

If the HD6803 fails to respond to the flag within the proper time, (TDRE is still set when the next normal transfer from the parallel data register to the serial output register should occur) then a 1 will be sent (instead of a 0 ) at "Start" bit time, followed by more l's until more data is supplied to the data register. No 0's will be sent while TDRE remains a 1 .

## Receive Operation

The receive operation is enabled by the RE bit which gates in the serial input through Port 2. Bit 3. The receiver section operation is conditioned by the contents of the Transmit/ Receive Control and Status Register and the Rate and Mode Control Register.

The receiver bit interval is divided into 8 sub-intervals for internal synchronization. In the NRZ Mode, the received bit stream is synchronized by the first 0 (space) encountered.

The approximate center of each bit time is strobed during the next 10 bits. If the tenth bit is not a 1 (stop bit) a framing error is assumed, and bit ORFE is set. If the tenth bit as a 1 , the data is transferred to the Receive Data Register, and interrupt flag RDRF is set. If RDRF is still set at the next tenth bit time, ORFE will be set. indicating an overrun has occurred. When the HD6803 responds to either flag (RDRF or ORFE) by reading the status register followed by reading the Data Register. RDRF (or ORFE) will be cleared.

## - RAM CONTROL REGISTER

This register. which is addressed at S0014. gives status information about the standby RAM. A 0 in the RAM enable bit (RAME) will disable the standby RAM, thereby protecting
it at power down if $\mathrm{V}_{\mathrm{CC}}$ Standby is held greater than $\mathrm{V}_{\text {SBB }}$ volts, as explained previously in the signal description for $\mathrm{V}_{\mathrm{CC}}$ Standby.


Bit 0 Not used.
Bit 1 Not used.
Bit 2 Not used.
Bit 3 Not used.
Bit 4 Not used.
Bit 5 Not used.
Bit 6 RAME The RAM Enable control bit allows the user the ability to disable the standby RAM. This bit is set to a logic " 1 " by $\overline{\mathrm{RES}}$ which enables the standby RAM and can be written to one or zero under program control. When the RAM is disabled. data is read from external memory.
Bit 7 STBY The Standby Power bit is cleared when the stand-
PWR by voltage is removed. This bit is a read/write status flag that the user can read which indicates that the standby RAM voltage has been applied, and the data in the standby RAM is valid.

## - GENERAL DESCRIPTION OF INSTRUCTION SET

The HD6803 is upward object code compatible with the HD6800 as it implements the full HMCS6800 instruction set.
The execution times of key instructions have been reduced to increase throughout. In addition, new instructions have been added; these include 16 -bit operations and a hardware multiply. Included in the instruction set section are the following:

- CPU Programming Model-Figure 15.
- Addressing modes
- Accumulator and memory instructions - Table 7
- New instructions
- Index register and stack manipulations instructions - Table 8
- Jump and branch instructions - Table 9
- Condition code register manipulation instructions - Table 10
- Instructions Execution times in machine cycles - Table 11
- Summary of cycle by cycle operation - Table 12
- Summary of undefined instructions - Table 13


## - CPU Programming Model

The programming model for the HD6803 is shown in Figure 15. The double (D) accumulator is physically the same as the Accumulator A concatenated with the Accumulator B so that any operation using accumulator $D$ will destroy information in A and B.


Figure 15 CPU Programming Model

## - CPU Addressing Modes

The HD6803 8 -bit micro processing unit has seven address modes that can be used by a programmer, with the addressing mode a function of both the type of instruction and the coding within the instruction. A summary of the addressing modes for a particular instruction can be found in Table 11 along with the associated instruction execution time that is given in machine cycles. With a clock frequency of 4 MHz , these times would be microseconds.

## Accumulator (ACCX) Addressing

In accumulator only addressing, either accumulator A or accumulator B is specified. These are one-byte instructions. Immediate Addressing

In immediate addressing, the operand is contained in the second byte of the instruction except LDS and LDX which have the operand in the second and third bytes of the instruction. The CPU addresses this location when it fetches the immediate instruction for execution. These are two or three-byte instructions.

Table 7 Accumulator \& Memory Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED. |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | = | OP | $\sim$ | * |  |  | H | 1 | N | $z$ | $v$ | C |
| Add | ADDA | 8B | 2 | 2 | 9B | 3 | 2 | AB | 4 | 2 | BB | 4 | 3 |  |  |  |  | $A+M \rightarrow A$ | 1 | $\bullet$ | 1 | 1 | $t$ | $t$ |
|  | ADDB | CB | 2 | 2 | DB | 3 | 2 | EB | 4 | 2 | FB | 4 | 3 |  |  |  |  | $B+M \rightarrow B$ | $t$ | - | 1 | 1 | $t$ | $t$ |
| Add Double | ADDD | C3 | 4 | 3 | D3 | 5 | 2 | E3 | 6 | 2 | F3 | 6 | 3 |  |  |  |  | $A: B+M: M+1 \rightarrow A: B$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
| Add Accumulators | ABA |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 2 | 1 |  | $A+B \rightarrow A$ | 1 | $\bullet$ | 1 | 1 | 1 | 1 |
| Add With Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | B9 | 4 | 3 |  |  |  |  | $A+M+C \rightarrow A$ | $t$ | $\bullet$ | 1 | $\pm$ | $t$ | $\pm$ |
|  | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 |  |  |  |  | $B+M+C-B$ | 1 | $\bullet$ | 1 | 1 | $t$ | 1 |
| AND | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A4 | 4 | 2 | B4 | 4 | 3 |  |  |  |  | $A \cdot M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | 1 | R | - |
|  | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 |  |  |  |  | $B \cdot M \rightarrow B$ | $\bullet$ | $\bullet$ | $!$ | $t$ | R | $\bullet$ |
| Bit Test | BIT A | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | B5 | 4 | 3 |  |  |  |  | A.M | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
|  | BIT B | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 |  |  |  |  | B.M | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Clear | CLR |  |  |  |  |  |  | 6 F | 6 | 2 | 7 F | 6 | 3 |  |  |  |  | OO $\rightarrow$ M | $\bullet$ | - | R | S | $R$ | R |
|  | CLRA |  |  |  |  |  |  |  |  |  |  |  |  | 4F | 2 | 1 |  | $00 \rightarrow A$ | $\bullet$ | $\bullet$ | R | S | R | R |
|  | CLRB |  |  |  |  |  |  |  |  |  |  |  |  | 5 F | 2 | 1 |  | $00 \rightarrow B$ | $\bullet$ | - | R | S | R | R |
| Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | B1 | 4 | 3 |  |  |  |  | A - M | $\bullet$ | - | 1 | 1 | $!$ | 1 |
|  | CMPB | C1 | 2 | 2 | D1 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 |  |  |  |  | $B-M$ | $\bullet$ | $\bullet$ | $!$ | 1 | $!$ | 1 |
| Compare Accumulators | CBA |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 2 | 1 |  | A-B | $\bullet$ | - | 1 | $t$ | : | 1 |
| Complement, 1's | COM |  |  |  |  |  |  | 63 | 6 | 2 | 73 | 6 | 3 |  |  |  |  | $\overline{\mathrm{M}} \rightarrow \mathrm{M}$ | $\bullet$ | $\bullet$ | 1 | 1 | R | S |
|  | COMA |  |  |  |  |  |  |  |  |  |  |  |  | 43 | 2 | 1 |  | $\bar{A} \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | 1 | R | S |
|  | COMB |  |  |  |  |  |  |  |  |  |  |  |  | 53 | 2 | 1 |  | $\bar{B} \rightarrow B$ | - | $\bullet$ | 1 | 1 | R | S |
| Complement, 2's (Negate) | NEG |  |  |  |  |  |  | 60 | 6 | 2 | 70 | 6 | 3 |  |  |  |  | OO-M -M | $\bullet$ | - | 1 | 1 | (1) | (2) |
|  | NEGA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 2 | 1 |  | $00-A \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | 1 | (1) | (2) |
|  | NEGB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 |  | $00-B \rightarrow B$ | $\bullet$ | $\bullet$ | $t$ | 1 | (1) | (2) |
| Decimal Adjust. A | DAA |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 |  | Converts binary add of BCD characters into BCD format | $\bullet$ | - | 1 | $t$ | 1 | (3) |
| Decrement | DEC |  |  |  |  |  |  | 6A | 6 | 2 | 7 A | 6 | 3 |  |  |  |  | $\mathrm{M}-1 \rightarrow \mathrm{M}$ | $\bullet$ | - | 1 | 1 | (4) | $\bullet$ |
|  | DECA |  |  |  |  |  |  |  |  |  |  |  |  | 4A | 2 | 1 |  | $A-1 \rightarrow A$ | $\bullet$ | - | 1 | 1 | (4) | $\bullet$ |
|  | DECB |  |  |  |  |  |  |  |  |  |  |  |  | 5 A | 2 | 1 |  | $B-1 \rightarrow B$ | $\bullet$ | - | 1 | 1 | (4) | $\bullet$ |
| Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | B8 | 4 | 3 |  |  |  |  | $A \oplus M \rightarrow A$ | $\bullet$ | - | $t$ | $!$ | R | $\bullet$ |
|  | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 |  |  |  |  |  | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
| Increment | INC |  |  |  |  |  |  | 6 C | 6 | 2 | 7C | 6 | 3 |  |  |  |  | $M+1 \rightarrow M$ | $\bullet$ | - | 1 | $t$ | (5) | $\cdots$ |
|  | INCA |  |  |  |  |  |  |  |  |  |  |  |  | 4C | 2 | 1 |  | $A+1 \rightarrow A$ | $\bullet$ | - | $t$ | $!$ | (5) | $\bullet$ |
|  | INCB |  |  |  |  |  |  |  |  |  |  |  |  | 5 C | 2 | 1 |  | $B+1 \cdots B$ | $\bullet$ | $\bullet$ | 1 | $!$ | (5) | $\bullet$ |
| Load Accumulator | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | B6 | 4 | 3 |  |  |  |  | M $\rightarrow$ A | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
|  | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 |  |  |  |  | $M \rightarrow B$ | $\bullet$ | $\bullet$ | 1 | $!$ | R | $\bullet$ |
| Load Double Accumulator | LDD | CC | 3 | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 |  |  |  |  | $M+1 \rightarrow B, M \cdot A$ | $\bullet$ | - | $t$ | 1 | R | - |
| Multiply Unsigned | MUL |  |  |  |  |  |  |  |  |  |  |  |  | 3D | 10 | 1 |  | $A \times B \cdot A: B$ | - | - | - | - | - | (11) |
| OR, Inclusive | ORAA | 8A | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 |  |  |  |  | $A+M \rightarrow A$ | $\bullet$ | $\bullet$ | : | : | R | $\bullet$ |
|  | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 |  |  |  |  | $B+M \rightarrow B$ | $\bullet$ | $\bullet$ | : | 1 | R | $\bullet$ |
| Push Data | PSHA |  |  |  |  |  |  |  |  |  |  |  |  | 36 | 3 | 1 |  | A $\rightarrow$ Msp, SP - $1 \cdot$ SP | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
|  | PSHB |  |  |  |  |  |  |  |  |  |  |  |  | 37 | 3 | 1 |  | $B \rightarrow$ Msp. SP - $1 \cdot$ SP | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Pull Data | PULA |  |  |  |  |  |  |  |  |  |  |  |  | 32 | 4 | 1 |  | SP + $1 \rightarrow$ SP, Msp $\rightarrow$ A | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
|  | PULB |  |  |  |  |  |  |  |  |  |  |  |  | 33 | 4 | 1 |  | SP + $1 \rightarrow$ SP. Msp $\rightarrow B$ | $\bullet$ | - | - | - | - | - |
| Rotate Left | ROL |  |  |  |  |  |  | 69 | 6 | 2 | 79 | 6 | 3 |  |  |  |  |  | $\bullet$ | - | 1 | 1 | (6) | 1 |
|  | ROLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 2 | 1 |  |  | - | - | $!$ | $!$ | (6) | 1 |
|  | ROLB |  |  |  |  |  |  |  |  |  |  |  |  | 59 | 2 | 1 |  |  | - | $\bullet$ | 1 | 1 | (6) | 1 |
| Rotate Right | ROR |  |  |  |  |  |  | 66 | 6 | 2 | 76 | 6 | 3 |  |  |  |  |  | $\bullet$ | $\bullet$ | $!$ | ! | (6) | 1 |
|  | RORA |  |  |  |  |  |  |  |  |  |  |  |  | 46 | 2 | 1 |  |  | $\bullet$ | - | : | : | (6) | 1 |
|  | RORB |  |  |  |  |  |  |  |  |  |  |  |  | 56 | 2 | 1 |  |  | $\bullet$ | $\bullet$ | : | $!$ | (6) | : |

## (0) HITACHI

Table 7 Accumulator \& Memory Instructions (Continued)

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Bcolean/ <br> Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED. |  |  | DIREC |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | $\pm$ | OP | $\sim$ | = | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | $z$ | $v$ | C |
| Shift l.eft Arithmetic | ASL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | 1 | $\pm$ | (6) | 1 |
|  | ASLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 2 | 1 |  | $\bullet$ | - | 1 | $\pm$ | 6, | 1 |
|  | ASLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 2 | 1 |  | $\bullet$ | $\bullet$ | 1 | $\pm$ | (6) | 1 |
| Double Shift Left, Arithmetic | ASLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 3 | 1 | $\square=\frac{A C C A T A C C B}{A T} B$ | - | $\bullet$ | 1 | $\pm$ | (6) | $\pm$ |
| Shift Right Arithmetic | ASR |  |  |  |  |  |  | 67 | 6 | 2 | 77 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | $\pm$ | $\pm$ | (6) | $\ddagger$ |
|  | ASRA |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 2 | 1 |  | $\bullet$ | $\bullet$ | 1 | $t$ | (6) | 1 |
|  | ASRB |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 2 | 1 |  | $\bullet$ | - | $\ddagger$ | $\pm$ | (6) | 1 |
| Shift Right Logical | LSR |  |  |  |  |  |  | 64 | 6 | 2 | 74 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | R | $\pm$ | (6) | 1 |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 2 | 1 |  | $\bullet$ | - | R | $\pm$ | (6) | 1 |
|  | LSRB |  |  |  |  |  |  |  |  |  |  |  |  | 54 | 2 | 1 |  | - | $\bullet$ | R | $\pm$ | (6) | 1 |
| Double Shift Right Logical | LSRD |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 3 | 1 |  | - | - | R | $\pm$ | (6) | $\pm$ |
| Store Accumulator | STAA |  |  |  | 97 | 3 | 2 | A7 | 4 | 2 | B7 | 4 | 3 |  |  |  | $A \rightarrow M$ | $\bullet$ | $\bullet$ | 1 | $\pm$ | R | $\bullet$ |
|  | STAB |  |  |  | D7 | 3 | 2 | E7 | 4 | 2 | F7 | 4 | 3 |  |  |  | $B \rightarrow M$ | $\bullet$ | - | $\pm$ | $t$ | R | $\bullet$ |
| Store Double Accumulator | STO |  |  |  | DD | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 |  |  |  | $\begin{aligned} & A \rightarrow M \\ & B \rightarrow M+1 \end{aligned}$ | $\bullet$ | $\bullet$ | $\pm$ | $\ddagger$ | R | $\bullet$ |
| Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | BO | 4 | 3 |  |  |  | $A-M \rightarrow A$ | - | $\bullet$ | $\pm$ | $t$ | $\ddagger$ | $\pm$ |
|  | SUBE | CO | 2 | 2 | D0 | 3 | 2 | EO | 4 | 2 | FO | 4 | 3 |  |  |  | $B-M \rightarrow B$ | $\bullet$ | $\bullet$ | $\pm$ | 1 | $\ddagger$ | 1 |
| Double Subtract | SUBD | 83 | 4 | 3 | 93 | 5 | 2 | A3 | 6 | 2 | B3 | 6 | 3 |  |  |  | $A: B-M: M+1 \rightarrow A: B$ | $\bullet$ | $\bullet$ | 1 | $t$ | $\pm$ | $t$ |
| Subtract <br> Arcumulators | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 2 | 1 | $A-B \rightarrow A$ | - | - | $\pm$ | $t$ | $\ddagger$ | $\pm$ |
| Subtract With Carry | SBC.A | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | B2 | 4 | 3 |  |  |  | $A-M-C \rightarrow A$ | $\bullet$ | $\bullet$ | $\pm$ | $t$ | $\pm$ | $\pm$ |
|  | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C \rightarrow B$ | $\bullet$ | $\bullet$ | 1 | $t$ | $\pm$ | $\pm$ |
| Transfer Accumulators | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 2 | 1 | $A \rightarrow B$ | $\bullet$ | $\bullet$ | $\ddagger$ | 1 | R | $\bullet$ |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 2 | 1 | $B \rightarrow A$ | $\bullet$ | $\bullet$ | $\pm$ | 1 | R | $\bullet$ |
| Test Zero or Minus | TST |  |  |  |  |  |  | 60 | 6 | 2 | 70 | 6 | 3 |  |  |  | M-00 | $\bullet$ | $\bullet$ | $t$ | $\pm$ | R | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 2 | 1 | A - 00 | $\bullet$ | $\bullet$ | 1 | 1 | R | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 | B - 00 | - | $\bullet$ | 1 | 1 | R | R |

The Condition Code Regıster notes are listed after Table 10.

## Direct Addressing

In direct addressing, the address of the operand is contained in the second byte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes in the machine i.e., locations zero through 255. Enhanced execution times are achieved by storing data in these locations. In most configurations, it should be a random access memory. These are two-byte instructions.

## Extended Addressing

In extended addressing. the address contained in the second byte of the instruction is used as the higher 8 -bits of the address of the operand. The third byte of the instruction is used as the lower 8 -bits of the address for the operand. This is an absolute address in memory. These are three-byte instructions.

## Indexed Addressing

In indexed addressing, the address contained in the second byte of the instruction is added to the index register's lowest

8 -bits in the CPU. The carry is then added to the higher order 8 -bits of the index register. This result is then used to address memory. The modified address is held in a temporary address register so there is no change to the index register. These are two-byte instructions.

## Implied Addressing

In the implied addressing mode the instruction gives the address (i.e., stack pointer, index register, etc.). These are one-byte instructions.

## Relative Addressing

In relative addressing, the address contained in the second byte of the instruction is added to the program counter's lowest 8 -bits plus two. The carry or borrow is then added to the high 8 -bits. This allows the user to address data within a range of -126 to +129 bytes of the present instruction. These are twobyte instructions.

## - New Instructions

In addition to the existing 6800 Instruction Set, the following new instructions are incorporated in the HD6803 Microcomputer.

ABX Adds the 8-bit unsigned accumulator $B$ to the 16 -bit $X$-Register taking into account the possible carry out of the low order byte of the X-Register.
ADDD Adds the double precision ACCD * to the double precision value $\mathrm{M}: \mathrm{M}+1$ and places the results in ACCD.
ASLD Shifts all bits of ACCD one place to the left. Bit 0 is loaded with zero. The C bit is loaded from the most significant bit of ACCD.
LDD Loads the contents of double precision memory location into the double accumulator $\mathbf{A}: B$. The condition codes are set according to the data.
LSRD Shifts all bits of ACCD one place to the right. Bit 15 is loaded with zero. The C bit is loaded from the least significant bit to ACCD.
MUL Multiplies the 8 bits in accumulator A with the 8 bits in accumulator B to obtain a 16 -bit unsigned number in $\mathrm{A}: \mathrm{B}, \mathrm{ACCA}$ contains MSB of result.
PSHX The contents of the index register is pushed onto the stack at the address contained in the stack pointer. The stack pointer is decremented by 2.
PULX The index register is pulled from the stack beginning at the current address contained in the stack pointer +1 . The stack pointer is incremented by 2 in total.
STD Stores the contents of double accumulator A:B in memory. The contents of ACCD remain unchanged.
SUBD Subtracts the contents of $M: M+1$ from the contents of double accumulator $A B$ and places the result in ACCD.
BRN Never branches. If effect, this instruction can be considered a two byte NOP (No operation) requiring three cycles for execution.
CPX Internal processing modified to permit its use with any conditional branch instruction.
*ACCD' is the 16 bit register ( $A: B$ ) formed by concatenating the $A$ and $B$ accumulators. The $A$-accumulator is the most significant byte.

Table 8 Index Register and Stack Manipulation Instructions

| Pointer Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ <br> Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED. |  |  | DIRECT |  |  | INDEX |  |  | EXTND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | z | V | C |
| Compare Index Reg | CPX | 8C | 4 | 3 | 9C | 5 | 2 | AC | 6 | 2 | BC | 6 | 3 |  |  |  | $X-M: M+1$ | - | - | 1 | 1 | $\pm$ | 1 |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 3 | 1 | $\mathrm{X}-1 \rightarrow \mathrm{X}$ | $\bullet$ | - | $\bullet$ | $\pm$ | $\bullet$ | $\bullet$ |
| Decrement Stack Pntr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 3 | 1 | SP-1 $\rightarrow$ SP | $\bullet$ | - | $\bullet$ | - | - | - |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 3 | 1 | $x+1 \rightarrow X$ | $\bullet$ | $\bullet$ | - | 1 | - | $\bullet$ |
| Increment Stack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 3 | 1 | SP + $1 \rightarrow$ SP | $\bullet$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Load Index Reg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 |  |  |  | $M \rightarrow X_{H},(M+1) \rightarrow X_{L}$ | $\bullet$ | $\bullet$ | (7) | 1 | R | $\bullet$ |
| Load Stack Pntr | LDS | 8 E | 3 | 3 | 9 E | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{SP}_{\mathrm{H}} .(\mathrm{M}+1) \rightarrow$ SP | $\bullet$ | - | 7 | 1 | R | $\bullet$ |
| Store Index Reg | STX |  |  |  | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 |  |  |  | $X_{H} \rightarrow M, X_{L} \rightarrow(M+1)$ | $\bullet$ | - | (7) | 1 | R | - |
| Store Stack Pntr | STS |  |  |  | 9F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 |  |  |  | $\mathrm{SP}_{H} \rightarrow \mathrm{M}_{\text {, }} \mathrm{SP}_{L} \rightarrow(M+1)$ | $\bullet$ | $\bullet$ | (7) | $\pm$ | R | $\bullet$ |
| Index Reg $\rightarrow$ Stack Pntr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 3 | 1 | $\mathrm{X}-1 \rightarrow \mathrm{SP}$ | $\bullet$ | - | - | - | - | - |
| Stack Pntr $\rightarrow$ Index Reg | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 3 | 1 | SP + $1 \rightarrow X$ | $\bullet$ | - | $\bullet$ | - | $\bullet$ | - |
| Add | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3A | 3 | 1 | $\mathrm{B}+\mathrm{X} \rightarrow \mathrm{X}$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | - |
| Push Data | PSHX |  |  |  |  |  |  |  |  |  |  |  |  | 3C | 4 | 1 | $\begin{aligned} & X_{L} \rightarrow M_{\text {sp }}, S P-1 \rightarrow S P \\ & X_{H} \rightarrow M_{\text {sp }}, S P-1 \rightarrow S P \end{aligned}$ | $\bullet$ | - | - | - | - | $\bullet$ |
| Pull Data | PULX |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 5 | 1 | $\begin{aligned} & S P+1 \rightarrow S P, M_{S p} \rightarrow X_{H} \\ & S P+1 \rightarrow S P, M_{s p} \rightarrow X_{L} \end{aligned}$ | $\bullet$ | - | - | - | - | - |

The Condition Code Register notes are listed after Table 10.

Table 9 Jump and Branch Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Branch Test | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | RELATIVE |  |  | DIRECT |  |  | INDEX |  |  | EXTND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | 2 | v | C |
| Branch Always | BRA | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | None | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch Never | BRN | 21 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | None | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Carry Clear | BCC | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{C}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Carry Set | BCS | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If = Zero | BEO | 27 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $Z=1$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If $>$ Zero | BGE | 2 C | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N \oplus \sim=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If $>$ Zero | BGT | 2 E | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Higher | BHI | 22 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C+Z=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch if < Zero | BLE | 2F | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N \oplus)=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Lower Or Same | BLS | 23 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C+Z=1$ | - | - | - | - | - | - |
| Branch if < Zero | BLT | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N \oplus \mathrm{~V}=1$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Minus | BMI | 2B | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Not Equal Zero | BNE | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $z=0$ | - | - | - | - | $\bullet$ | $\bullet$ |
| Branch If Overflow Clear | BVC | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $V=0$ | - | - | $\bullet$ | $\bullet$ | - | - |
| Branch If Overflow Set | BVS | 29 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $V=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Plus | BPL | 2A | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | - | - | $\bullet$ | - | - | $\bullet$ |
| Branch To Subroutine | BSR | 80 | 6 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $\bullet$ | - | - | - | $\bullet$ | - |
| Jump | JMP |  |  |  |  |  |  | 6 E | 3 | 2 | 7 F | 3 | 3 |  |  |  |  | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | - |
| Jump To Subroutine | JSR |  |  |  | 90 | 5 | 2 | AD | 6 | 2 | BD | 6 | 3 |  |  |  |  | $\bullet$ | - | - | $\bullet$ | $\bullet$ | - |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 | Advances Prog. Cntr. Only | $\bullet$ | - | - | $\bullet$ | $\bullet$ | - |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  |  |  |  | 3 B | 10 | 1 |  |  |  |  |  |  |  |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  | - | - | - | - | $\bullet$ | - |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  |  |  |  | 3 F | 12 | 1 |  | $\bullet$ | S | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Wait for Interrupt | WAI |  |  |  |  |  |  |  |  |  |  |  |  | 3 E | 9 | 1 |  | - | (9) | $\bullet$ | $\bullet$ | $\bullet$ | - |

Table 10 Condition Code Register Manipulation Instructions

| Operations | Mnemonic | AddressingModes <br> IMPLIED |  |  | Boolean Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# |  | H | 1 | N | 2 | V | C |
| Clear Carry | CLC | OC | 2 | 1 |  | $0 \rightarrow C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | R |
| Clear Interrupt Mask | CLI | OE | 2 | 1 | $0 \rightarrow 1$ | $\bullet$ | R | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Clear Overflow | CLV | OA | 2 | 1 | $0 \rightarrow V$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | R | $\bullet$ |
| Set Carry | SEC | OD | 2 | 1 | $1 \rightarrow C$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | S |
| Set Interrupt Mask | SEI | OF | 2 | 1 | $1 \rightarrow 1$ | $\bullet$ | S | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Set Overflow | SEV | OB | 2 | 1 | $1 \rightarrow V$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | S | $\bullet$ |
| Accumulator $A \rightarrow$ CCR | TAP | 06 | 2 | 1 | $A \rightarrow C C R$ |  |  |  |  |  |  |
| CCR $\rightarrow$ Accumulator $A$ | TPA | 07 | 2 | 1 | $\mathrm{CCR} \rightarrow \mathrm{A}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

\footnotetext{
Condition Code Register Notes: (Bit set it test is true and cleared otherwise)

| (1) (Bit V) | Test: Result $=10000000$ ? |
| :---: | :---: |
| (2) (Bit C) | Test: Result $* 00000000$ ? |
| (3) (Bit C) | Test: Decimal value of most significant BCD Character greater than nine? (Not cleared if previously set) |
| (4) (Bit V) | Test: Operand $=10000000$ prior to execution? |
| (5) (Bit V) | Test: Operand =01111111 prior to execution? |
| (6) (Bit V) | Test: Set equal to result of $\mathrm{N} \oplus \mathrm{C}$ after shift has occurred. |
| (7) (Bit N) | Test: Result less than zero? (Bit $15=1$ ) |
| 8 (All) | Load Condition Code Register from Stack. (See Special Operations) |
| 5 (Bit 1) | Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state. |
| 40 (All) | Set according to the contents of Accumulator A . |
| (1) (Bit C) | Set equal to result of Bit 7 (ACCB) |

Table 11 Instruction Execution Times in Machine Cycle

|  | ACCX | Immediate | Direct | Extended | $\begin{aligned} & \text { In- } \\ & \text { dexed } \end{aligned}$ | $\underset{\text { plied }}{\text { Im- }}$ | Relative |  | ACCX | Immediate | Direct | Extended | $\begin{gathered} \ln . \\ \text { dexed } \end{gathered}$ | $\underset{\text { plied }}{\text { Im. }}$ | Relative |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ABA | - | $\bullet$ | - | $\bullet$ | - | 2 | - | INX | - | - | - | - | $\bullet$ | 3 | $\bullet$ |
| ABX | - | - | $\bullet$ | $\bullet$ | - | 3 | - | JMP | - | - | - | 3 | 3 | $\bullet$ | - |
| ADC | - | 2 | 3 | 4 | 4 | - | - | JSR | - | - | 5 | 6 | 6 | - | - |
| ADD | - | 2 | 3 | 4 | 4 | - | $\bullet$ | LDA | - | 2 | 3 | 4 | 4 | - | - |
| ADDD | $\bullet$ | 4 | 5 | 6 | 6 | $\bullet$ | - | LDD | - | 3 | 4 | 5 | 5 | - | - |
| AND | - | 2 | 3 | 4 | 4 | $\bullet$ | - | LDS | - | 3 | 4 | 5 | 5 | - | - |
| ASL | 2 | $\bullet$ | - | 6 | 6 | $\bullet$ | $\bullet$ | LDX | $\bullet$ | 3 | 4 | 5 | 5 | - | - |
| ASLD | $\bullet$ | - | $\bullet$ | - | $\bullet$ | 3 | - | LSR | 2 | - | - | 6 | 6 | $\bullet$ | - |
| ASR | 2 | - | $\bullet$ | 6 | 6 | - | $\bullet$ | LSRD | - | - | - | - | - | 3 | $\bullet$ |
| BCC | - | - | $\bullet$ | $\bullet$ | - | - | 3 | MUL | - | - | - | - | $\bullet$ | 10 | $\bullet$ |
| BCS | - | $\bullet$ | - | - | - | - | 3 | NEG | 2 | - | - | 6 | 6 | - | - |
| BEQ | : | - | - | - | - | - | 3 | NOP | - | - | - | $\bullet$ | - | 2 | $\bullet$ |
| BGE | - | - | - | - | - | - | 3 | ORA | - | 2 | 3 | 4 | 4 | - | $\bullet$ |
| BGT | - | - | - | - | - | - | 3 | PSH | 3 | - | - | - | - | - | $\bullet$ |
| BHI | $\bullet$ | - | - | - | - | - | 3 | PSHX | $\bullet$ | - | - | $\bullet$ | - | 4 | - |
| BIT | - | 2 | 3 | 4 | 4 | - | - | PUL | 4 | - | - | - | $\bullet$ | - | - |
| BLE | - | - | - | - | - | $\bullet$ | 3 | PULX | $\bullet$ | - | - | - | $\bullet$ | 5 | - |
| BLS | - | $\bullet$ | - | - | - | - | 3 | ROL | 2 | - | - | 6 | 6 | - | - |
| BLT | $\bullet$ | $\bullet$ | - | - | - | - | 3 | ROR | 2 | - | - | 6 | 6 | - | $\bullet$ |
| BMI | - | $\bullet$ | - | - | - | - | 3 | RTI | - | - | - | - | - | 10 | - |
| BNE | - | - | - | - | - | - | 3 | RTS | - | - | - | - | - | 5 | $\bullet$ |
| BPL | - | - | - | - | - | - | 3 | SBA | $\bullet$ | - | $\bullet$ | - | - | 2 | - |
| BRA | $\bullet$ | $\bullet$ | - | - | - | - | 3 | SBC | - | 2 | 3 | 4 | 4 | - | - |
| BRN | $\bullet$ | $\bullet$ | - | - | $\bullet$ | $\bullet$ | 3 | SEC | - | $\bullet$ | - | $\bullet$ | $\bullet$ | 2 | $\bullet$ |
| BSR | - | - | - | $\bullet$ | - | - | 6 | SEI | $\bullet$ | - | $\bullet$ | - | - | 2 | $\bullet$ |
| BVC | - | - | - | $\bullet$ | - | - | 3 | SEV | - | - | - | - | - | 2 | - |
| BVS | - | - | - | - | - | - | 3 | STA | - | - | 3 | 4 | 4 | $\bullet$ | $\bullet$ |
| CBA | - | - | - | - | - | 2 | - | STD | - | - | 4 | 5 | 5 | - | - |
| CLC | - | - | - | - | $\bullet$ | 2 | - | STS | - | - | 4 | 5 | 5 | - | $\bullet$ |
| CLI | - | $\bullet$ | - | - | - | 2 | - | STX | - | - | 4 | 5 | 5 | - | $\bullet$ |
| CLR | 2 | - | - | 6 | 6 | $\bullet$ | - | SUB | - | 2 | 3 | 4 | 4 | - |  |
| CLV | - | - | - | - | - | 2 | - | SUBD | - | 4 | 5 | 6 | 6 | $\stackrel{\square}{-}$ | - |
| CMP | - | 2 | 3 | 4 | 4 | - | - | SWI | - | - | - | - | $\bullet$ | 12 | - |
| COM | 2 | - | - | 6 | 6 | - | - | TAB | $\bullet$ | - | - | - | - | 2 | - |
| CPX | - | 4 | 5 | 6 | 6 | $\bullet$ | - | TAP | - | - | - | - | - | 2 | - |
| DAA | - | - | - | - | - | 2 | - | TBA | - | - | - | - | - | 2 | $\bullet$ |
| DEC | 2 | - | - | 6 | 6 | - | - | TPA | - | - | - | - | - | 2 | - |
| DES | - | - | - | - | - | 3 | - | TST | 2 | - | - | 6 | 6 | $\bullet$ | - |
| DEX | - | - | - | - | $\bullet$ | 3 | - | TSX | $\bullet$ | - | - | - | - | 3 | - |
| EOR | - | 2 | 3 | 4 | 4 | - | - | TXS | - | - | - | - | - | 3 | - |
| INC | 2 | - | - | 6 | 6 | $\bullet$ | - | WAI | $\bullet$ | - | - | - | - | 9 | - |
| INS | - | - | - | - | - | 3 | - |  |  |  |  |  |  |  |  |

## - Summary of Cycle by Cycle Operation

Table 12 provides a detailed description of the information present on the Address Bus, Data Bus, and the Read/Write line $(R / \bar{W})$ during each cycle for each instruction.

This information is useful in comparing actual with expected results during debug of both software and hardware as the
control program is executed. The information is categorized in groups according to addressing mode and number of cycles per instruction. (In general. instructions with the same addressing mode and number of cycles execute in the same manner: exceptions are indicated in the table).

Table 12 Cycle by Cycle Operation

|  <br> Instructions | Cycles | Cycle <br> $\#$ | Address Bus | R $\bar{W}$ <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |

IMMEDIATE

| ADC EOR | 2 | 1 | Op Code Address | 1 | Op Code |
| :--- | :---: | :---: | :--- | :--- | :--- |
| ADD LDA |  |  |  |  |  |
| AND ORA |  | 2 | Op Code Address +1 | 1 | Operand Data |
| BIT SBC |  |  |  |  |  |
| CMP SUB |  |  |  |  |  |
| LDS | 3 | 1 | Op Code Address | 1 | Op Code |
| LDX |  | 2 | Op Code Address + 1 | 1 | Operand Data (High Order Byte) |
| LDD | 3 | Op Code Address + 2 | 1 | Operand Data (Low Order Byte) |  |
| CPX | 4 | 1 | Op Code Address | 1 | Op Code |
| SUBD |  | 2 | Op Code Address + 1 | 1 | Operand Data (High Order Byte) |
| ADDD | 3 | Op Code Address + 2 | 1 | Operand Data (Low Order Byte) |  |
|  |  | 4 | Address Bus FFFF | 1 | Low Byte of Restart Vector |

## DIRECT

| ADC EOR | 3 | 1 | Op Code Address | 1 | Op Code |
| :--- | :--- | :--- | :--- | :--- | :--- |
| ADD LDA |  | 2 | Op Code Address + 1 | 1 | Address of Operand |
| AND ORA |  | 3 | Address of Operand | 1 | Operand Data |
| BIT SBC |  |  |  |  |  |
| CMP SUB |  |  |  |  |  |
| STA | 3 | 1 | Op Code Address | 1 | Op Code |
|  |  | 2 | Op Code Address + 1 | 1 | Destination Address |
|  |  | 3 | Destination Address | 0 | Data from Accumulator |
| LDS | 4 | 1 | Op Code Address | 1 | Op Code |
| LDX |  | 2 | Op Code Address + 1 | 1 | Address of Operand |
| LDD |  | 3 | Address of Operand | 1 | Operand Data (High Order Byte) |
|  |  | 4 | Operand Address + 1 | 1 | Operand Data (Low Order Byte) |
| STS | 4 | 1 | Op Code Address | 1 | Op Code |
| STX |  | 2 | Op Code Address +1 | 1 | Address of Operand |
| STD | 3 | Address of Operand | 0 | Register Data (High Order Byte) |  |
|  |  | 4 | Address of Operand +1 | 0 | Register Data (Low Crder Byte) |
| CPX | 5 | 1 | Op Code Address | 1 | Op Code |
| SUBD | 2 | Op Code Address + 1 | 1 | Address of Operand |  |
| ADDD |  | 3 | Operand Address | 1 | Operand Data (High Order Byte) |
|  |  | 4 | Operand Address + 1 | 1 | Operand Data (Low Order Byte) |
|  |  | 5 | Address Bus FFFF | 1 | Low Byte of Restart Vector |
| JSR |  | 1 | Op Code Address | 1 | Op Code |
|  |  | 2 | Op Code Address + 1 | 1 | Irrelevant Data |
|  |  | 3 | Subroutine Address | 1 | First Subroutine Op Code |
|  |  | 4 | Stack Pointer | 0 | Return Address (Low Order Byte) |
|  |  | 5 | Stack Pointer + 1 | 0 | Return Address (High Order Byte) |

Table 12 Cycle by Cycle Operation (Continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | $\mathrm{R} / \bar{W}$ Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INDEXED |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector Operand Data |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector Operand Data |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \\ & \text { LDD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Index Register Plus Offset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| STS <br> STX <br> STD | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset Index Register Plus Offset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| ASL LSR ASR NEG CLR ROL COM ROR DEC TST* INC | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF Index Register Plus Offset Address Bus FFFF Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector Current Operand Data Low Byte of Restart Vector New Operand Data |
| CPX SUBD ADDD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF <br> Index Register + Offset <br> Index Register + Offset + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Offset Low Byte of Restart Vector Operand Data (High Order Byte) Operand Data (Low Order Byte) Low Byte of Restart Vector |
| JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF <br> Index Register + Offset <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Low Byte of Restart Vector <br> First Subroutine Op Code <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

- In the TST instruction, R/W line of the sixth cycle is " 1 " level, and AB = FFFF, DB = Low Byte of Reset Vector.
(Continued)

Table 12 Cycle by Cycle Operation (Continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \overline{\mathrm{R} / \bar{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EXTENDED |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Jump Address (High Order Byte) Jump Address (Low Order Byte) |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address of Operand (High Order Byte) Address of Operand (Low Order Byte) Operand Data |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Operand Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Destination Address (High Order Byte) <br> Destination Address (Low Order Byte) <br> Data from Accumulator |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| STS <br> STX <br> STD | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Address of Operand <br> Address of Operand + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| ASL LSR ASR NEG CLR ROL COM ROR DEC TST* INC | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Address of Operand <br> Address Bus FFFF <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Current Operand Data <br> Low Byte of Restart Vector <br> New Operand Data |
| CPX <br> SUBD <br> ADDD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Operand Address <br> Operand Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Operand Address (High Order Byte) Operand Address (Low Order Byte) Operand Data (High Order Byte) Operand Data (Low Order Byte) Low Byte of Restart Vector |
| JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Subroutine Starting Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Address of Subroutine (High Order Byte) <br> Address of Subroutine (Low Order Byte) <br> Op Code of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

- In the TST instruction, $R / \bar{W}$ line of the sixth cycle is " 1 " level, and $A B=F F F F$, DB = Low Byte of Reset Vector.
(Continued)

Table 12 Cycle by Cycle Operation (Continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \mathrm{W} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IMPLIED |  |  |  |  |  |
| ABA DAA SEC ASL DEC SEI ASR INC SEV CBA LSR TAB CLC NEG TAP CLI NOP TBA CLR ROL TPA CLV ROR TST COM SBA | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction |
| ABX | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address Op Code Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code Irrelevant Data Low Byte of Restart Vector |
| $\begin{aligned} & \text { ASLD } \\ & \text { LSRD } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code Irrelevant Data Low Byte of Restart Vector |
| $\begin{aligned} & \text { DES } \\ & \text { INS } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Previous Register Contents | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Op Code of Next Instruction Irrelevant Data |
| $\begin{aligned} & \operatorname{INX} \\ & \text { DEX } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address Op Code Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Op Code of Next Instruction Low Byte of Restart Vector |
| $\begin{aligned} & \text { PSHA } \\ & \text { PSHB } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & \hline \end{aligned}$ | Op Code <br> Op Code of Next Instruction Accumulator Data |
| TSX | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Op Code of Next Instruction Irrelevant Data |
| TXS | 3 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Op Code Address Op Code Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Op Code of Next Instruction Low Byte of Restart Vector |
| PULA PULB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Op Code of Next Instruction Irrelevant Data Operand Data from Stack |
| PSHX | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Irrelevant Data <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) |
| PULX | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & \hline \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 <br> Stack Pointer +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Irrelevant Data <br> Irrelevant Dáa <br> Index Register (High Order Byte) <br> Index Register (Low Order Byte) |
| RTS | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 <br> Stack Pointer + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Irrelevant Data <br> Irrelevant Data <br> Address of Next Instruction <br> (High Order Byte) <br> Address of Next Instruction <br> (Low Order Byte) |
| WAI** | 9 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Op Code of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

Table 12 Cycle by Cycle Operation (Continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \bar{W} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| WAI** |  | $\begin{aligned} & 5 \\ & 6 \\ & 7 \\ & 8 \\ & 9 \end{aligned}$ | Stack Pointer - 2 <br> Stack Pointer - 3 <br> Stack Pointer - 4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Index Register (Low Order Byte) Index Register (High Order Byte) Contents of Accumulator $A$ Contents of Accumulator B Contents of Cond. Code Register |
| MUL | 10 | $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \end{array}$ | Op Code Address Op Code Address + 1 Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Irrelevant Data Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector |
| RTI | 10 | 1 2 3 4 5 6 7 7 8 9 10 | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 <br> Stack Pointer +2 <br> Stack Pointer +3 <br> Stack Pointer +4 <br> Stack Pointer +5 <br> Stack Pointer +6 <br> Stack Pointer +7 |  | Op Cade <br> Irrelevant Data <br> Irrelevant Data <br> Contents of Cond. Code Reg. <br> from Stack <br> Contents of Accumulator B <br> from Stack <br> Contents of Accumulator A <br> from Stack <br> Index Register from Stack <br> (High Order Byte) <br> Index Register from Stack <br> (Low Order Byte) <br> Next Instruction Address from <br> Stack (High Order Byte) <br> Next Instruction Address from <br> Stack (Low Order Byte) |
| SWI | 12 | $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \\ 12 \end{array}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Stack Pointer - 3 <br> Stack Pointer - 4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 <br> Stack Pointer - 7 <br> Vector Address FFFA (Hex) <br> Vector Address FFFB (Hex) | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Irrelevant Data <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) <br> Contents of Accumulator $A$ <br> Contents of Accumulator B <br> Contents of Cond. Code Register <br> Irrelevant Data <br> Address of Subroutine <br> (High Order Byte) <br> Address of Subroutine <br> (Low Order Byte) |

(Continued)

- While the MPU is in the "Wait" state, its bus state will appear as a series of MPU reads of an address which is seven locations less than the original contents of the Stack Pointer. Contrary to the HD6800, none of the ports are driven to the high impedance state by a WAl instruction.

Table 12 Cycle by Cycle Operation (Continued)
Relative

|  <br> Instructions | Cycles | Cycle <br> $\#$ | Address Bus | R/ $\bar{W}$ <br> Line | Data Bus |
| :--- | :---: | :---: | :--- | :---: | :--- |
| BCC BHT BNE | 3 | 1 | Op Code Address | 1 | Op Code |
| BCS BLE BPL |  | 2 | Op Code Address + 1 | 1 | Branch Offset |
| BEQ BLS BRA |  | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector |
| BGE BLT BVC |  |  |  |  |  |
| BGT BMT BVS |  |  |  |  |  |
| BRN |  |  |  | 1 | Op Code |
| BSR | 6 | 1 | Op Code Address | 1 | Branch Offset |
|  |  | 2 | Op Code Address + 1 | 1 | Low Byte of Restart Vector |
|  |  | 3 | Address Bus FFFF | 1 | Op Code of Next Instruction |
|  |  | 4 | Subroutine Starting Address | 1 | 0 |
|  |  | 5 | Stack Pointer | Return Address (Low Order Byte) |  |
|  |  | 6 | Stack Pointer -1 | 0 | Return Address (High Order Byte) |

- Summary of Undefined Instruction Operations

The HD6803 has 36 underfined instructions. When these are carried out, the contents of Register and Memory in MPU change at random.

When the op codes ( $4 \mathrm{E}, 5 \mathrm{E}$ ) are used to execute. the MPU continues to increase the program counter and it will not stop until the Reset signal enters. These op codes are used to test the LSI.

Table 13 Op codes Map

[NOTES] 1) Undefined Op codes are marked with $\square$.
2) $1 \quad$ I indicate that the number in parenthesis must be added to the cycle count for that instruction.
3) The instructions shown below are all 3 bytes and are marked with ".".

Immediate addressing mode of SUBD, CPX, LDS, ADDD, LDD and LDX instructions, and undefined op codes (8F, CD, CF).
4) The Op codes (4E, 5E) are 1 byte/ $/ \infty$ cycles instructions, and are marked with ....."
Figure 16 Interrupt Flowchart



Figure 17 HD6803 MPंU Expanded Multiplexed Bus

- Caution for the HD6803 Family SCI, TIMER Status Flag

The flags shown in Table 14 are cleared by reading/writing (flag reset condition 2) the data register corresponding to each flag after reading the status register (flag reset condition 1).

To clear the flag correctly, take the following procedure:

1. Read the status register.
2. Test the flag.
3. Read the data register.

Table 14 Status Flag Reset Conditions

|  | Status Flag | Flag Reset Condition 1 (Status Register) | Flag Reset Condition 2 (Data Register) |
| :---: | :---: | :---: | :---: |
| TIMER | ICF | When each flag is " 1 ", <br> TRCSR/Read | ICR/Read |
|  | OCF |  | OCR/Write |
|  | TOF |  | TC/Read |
| SCI | RDRF | When each flag is " 1 ", <br> TRCSR/Read | RDR/Read |
|  | ORFE |  |  |
|  | TDRE |  | TDR/Write |

# HD6809，HD68A09，HD68B09 MPU（Micro Processing Unit） 

The HD6809 is a revolutionary high performance 8 －bit microprocessor which supports modern programming tech－ niques such as position independence，reentrancy，and modular programming．

This third－generation addition to the HMCS6800 family has major architectural improvements which include additional registers，instructions and addressing modes．

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes．The HD6809 has the most complete set of addressing modes available on any 8 －bit microprocessor today．

The HD6809 has hardware and software features which make it an ideal processor for higher level language execution or standard controller applications．

## HD6800 COMPATIBLE

－Hardware－Interfaces with All HMCS6800 Peripherals
－Software－Upward Source Code Compatible Instruc－ tion Set and Addressing Modes
－ARCHITECTURAL FEATURES
－Two 16－bit Index Registers
－Two 16－bit Indexable Stack Pointers
－Two 8－bit Accumulators can be Concatenated to Form One 16－Bit Accumulator
－Direct Page Register Allows Direct Addressing Through－ out Memory
－HARDWARE FEATURES
－On Chip Oscillator
－DMA／BREQ Allows DMA Operation or Memory Refresh
－Fast Interrupt Request Input Stacks Only Condition Code Register and Program Counter
－MRDY Input Extends Data Access Times for Use With Slow Memory
－Interrupt Acknowledge Output Allows Vectoring By Devices
－SYNC Acknowledge Output Allows for Synchronization to External Event
－Single Bus－Cycle RESET
－Single 5－Volt Supply Operation
－NMI Blocked After RESET Until After First Load of Stack Pointer
－Early Address Valid Allows Use With Slower Memories
－Early Write－Data for Dynamic Memories
－Compatible with MC6809，MC68A09 and MC68B09

## －SOFTWARE FEATURES

－ 10 Addressing Modes
－HMCS6800 Upward Compatible Addressing Modes
－Direct Addressing Anywhere in Memory Map
－Long Relative Branches
－Program Çounter Relative
－True Indirect Addressing
－Expanded Indexed Addressing：


PIN ARRANGEMENT

| $\mathrm{v}_{\text {ss }}$－ | HD6809 | Eat halt |
| :---: | :---: | :---: |
| NM1 2 |  | 3 STAL |
| 1 RO |  | 38 extal |
| FIRO 4 |  | 37］${ }^{\text {res }}$ |
| BS 5 |  | 36 mrdr |
| ${ }^{\text {BA }} 6$ |  | 陣。 |
| $\mathrm{Vcc}^{7}$ |  | 3 E |
| $A_{0} 8$ |  | 3 OMA／BREO |
| A， 9 |  | 32 ram |
| $A_{2}$ ， 10 |  | 31 D 。 |
| A， 11 |  | 30 D |
| A， 12 |  | $2 \mathrm{D}_{2}$ |
| As 113 |  | $22^{2}$ |
| A， 114 |  | 27 D ， |
| A， 115 |  | 26 D ， |
| A． 16 |  | 25 D 。 |
| A， 17 |  | 24 D |
| $A_{10} 118$ |  | $23 \mathrm{~A}_{15}$ |
| $A_{1}$ ， 19 |  | $2 \mathrm{~A}_{1}$ |
| $A_{12} \times$ |  | $2{ }^{2} 13$ |

（Top View）

0,5,8, or 16-bit Constant Offsets
8, or 16-bit Accumulator Offsets
Auto-Increment/Decrement by 1 or 2

- Improved Stack Manipulation
- 1464 Instructions with Unique Addressing Modes
- $8 \times 8$ Unsigned Multiply
- 16-bit Arithmetic
- TransferfExchange All Registers
- Push/Pull Any Registers or Any Set of Registers
- Load Effective Address


## - BLOCK DIAGRAM



- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $-20 \sim+75$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

* With respect to $\mathrm{V}_{\text {SS }}$ (SYSTEM GND)
(NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.
- RECOMMENDED OPERATING CONDITIONS

| Item | Symbol |  | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}{ }^{*}$ |  | 4.75 | 5.0 | 5.25 | V |
| Input Voltage | $\mathrm{V}_{12}{ }^{*}$ |  | -0.3 | - | 0.8 | V |
|  | $\mathrm{V}_{\mathrm{H}}{ }^{*}$ | $(\mathrm{Ta}=0 \text { Logic }$ | 2.0 | - | $\mathrm{V}_{\text {cc }}$ | v |
|  |  | $\left(\mathrm{Tagic}=-20 \sim 0^{\circ} \mathrm{C}\right)$ | 2.2 | - | $\mathrm{V}_{\text {cc }}$ |  |
|  |  | $\overline{\mathrm{RES}}$ | 4.0 | - | $\mathrm{V}_{\mathrm{cc}}$ |  |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ |  | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

* With respect to $\mathrm{V}_{\text {SS }}$ (SYSTEM GND)


## - ELECTRICAL CHARACTERISTICS

- DC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | HD6809 |  |  | HD68A09 |  |  | HD68B09 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ* | max | min | typ* | max | min | typ* | max |  |
| Input "High" Voltage |  |  | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{Ta}=0 \sim+75^{\circ} \mathrm{C}$ | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | V |
|  | Except RES | $\mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C}$ |  | 2.2 | - | $\mathrm{V}_{\mathrm{cc}}$ | 2.2 | - | $\mathrm{V}_{\text {cc }}$ | 2.2 | - | $\mathrm{V}_{\text {cc }}$ |  |  |
|  | $\overline{\text { RES }}$ |  |  | 4.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | 4.0 | - | $\mathrm{V}_{\text {cc }}$ | 4.0 | - | $\mathrm{V}_{\text {cc }}$ |  |  |
| Input "Low" Voltage |  | $V_{\text {IL }}$ |  | -0.3 | - | 0.8 | -0.3 | - | 0.8 | -0.3 | - | 0.8 | V |  |
| Input Leakage Current | $\begin{aligned} & \text { Except EXTAL, } \\ & \text { XTAL } \end{aligned}$ | lin | $\begin{aligned} & \mathrm{V}_{\mathrm{in}=0 \sim 5.25 \mathrm{~V}} \\ & \mathrm{~V}_{\mathrm{CC}}=\max \\ & \hline \end{aligned}$ | -2.5 | - | 2.5 | -2.5 | - | 2.5 | -2.5 | - | 2.5 | $\mu \mathrm{A}$ |  |
| Three State (Off State) Input Current | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | 'tsi | $\begin{aligned} & \mathrm{Vin}=0.4 \sim 2.4 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{cc}}=\max \end{aligned}$ | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |  |
|  | $A_{0} \sim A_{15}, R / \bar{W}$ |  |  | -100 | - | 100 | -100 | - | 100 | -100 | - | 100 |  |  |
| Output "High" Voltage | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | $\mathrm{V}_{\mathrm{OH}}$ | $I_{\text {LOAD }}=-205 \mu$, $\mathrm{V}_{\mathrm{CC}}=\mathrm{min}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | $v$ |  |
|  | $\begin{aligned} & A_{0} \sim A_{1 S}, R / \bar{W}, \\ & Q, E \end{aligned}$ |  | $I_{\text {LOAD }}=-145 \mu \mathrm{~A}$, $V_{C C}=$ min | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - |  |  |
|  | BA, BS |  | $I_{\text {LOAD }}=-100 \mu \mathrm{~A}$, $V_{C C}=$ min | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - |  |  |
| Output "Low" Voltage |  | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\text {LOAD }}=2 \mathrm{~mA}$ | - | - | 0.5 | - | - | 0.5 | - | - | 0.5 | V |  |
| Power Dissipation |  | $P_{\text {D }}$ |  | - | - | 1.0 | - | - | 1.0 | - | - | 1.0 | W |  |
| Input Capacitance | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | Cin | $\begin{aligned} & \text { Vin=0V, } \\ & \mathrm{Ta}=25^{\circ} \mathrm{C}, \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ | - | 10 | 15 | - | 10 | 15 | - | 10 | 15 | pF |  |
|  | Except $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ |  |  | - | 7 | 10 | - | 7 | 10 | - | 7 | 10 |  |  |
| Output Capacitance | $\begin{aligned} & A_{0} \sim A_{15}, R / \bar{W} \\ & B A, B S \end{aligned}$ | Cout |  | - | - | 12 | - | - | 12 | - | - | 12 | pF |  |

[^4]- AC CHARACTERISTICS ( $\mathrm{VCC}_{\mathrm{CC}}=5 \mathrm{~V} \pm \mathbf{5 \%}, \mathrm{V}_{\text {SS }}=0 \mathrm{~V}, \mathrm{Ta}=\mathbf{- 2 0 \sim + 7 5}{ }^{\circ} \mathrm{C}$, unless otherwise noted.)

1. ClOCK timing

| Item | Symbol | Test Condition | HD6809 |  |  | HD68A09 |  |  | HD68B09 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| Frequency of Operation (Crystal or External Input) | ${ }^{\text {f }}$ TAAL | Fig. 2, Fig. 3 | 0.4 | - | 4 | 0.4 | - | 6 | 0.4 | - | 8 | MHz |
| Cycle Time | $\mathrm{t}_{\text {cyc }}$ |  | 1000 | - | 10000 | 667 | - | 10000 | 500 | - | 10000 | ns |
| Total Up Time | ${ }_{\text {tut }}$ |  | 975 | - | - | 640 | - | - | 480 | - | - | ns |
| Processor Clock "High" | tPWEH |  | 450 | - | 15500 | 280 | - | 15700 | 220 | - | 15700 | ns |
| Processor Clock "Low" | $t_{\text {PWEL }}$ |  | 430 | - | 5000 | 280 | - | 5000 | 210 | - | 5000 | ns |
| $E$ Rise and Fall Time | $\mathrm{t}_{\mathrm{Er}, \mathrm{t}} \mathrm{t}_{\mathrm{Ef}}$ |  | - | - | 25 | - | - | 25 | - | - | 20 | ns |
| $E_{\text {Low }}$ to $\mathrm{Q}_{\text {High }}$ Time | ${ }^{\text {tavs }}$ |  | 200 | - | 250 | 130 | - | 165 | 80 | - | 125 | ns |
| Q Clock 'High" | ${ }^{\text {tPWOH }}$ |  | 450 | - | 5000 | 280 | - | 5000 | 220 | - | 5000 | ns |
| Q Clock "Low" | $t_{\text {PWOL }}$ |  | 450 | - | 15500 | 280 | - | 15700 | 220 | - | 15700 | ns |
| Q Rise and Fall Time | $t_{\text {Qr, }} \mathrm{t}_{\mathrm{Qf}}$ |  | - | - | 25 | - | - | 25 | - | - | 20 | ns |
| Q Low to E Falling | ${ }^{\text {toE }}$ |  | 200 | - | - | 133 | - | - | 100 | - | - | ns |

## 2. BUS TIMING

| Item |  | Symbol | Test Condition | HD6809 |  |  | HD68A09 |  |  | H068809 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Address Delay |  |  | $\mathrm{t}_{\text {AD }}$ | Fig. 2, Fig. 3 | - | - | 200 | - | - | 140 | - | - | 110 | ns |
| Address Valid to $\mathbf{Q}_{\text {High }}$ |  | ${ }^{t} A Q$ | 50 |  | - | - | 25 | - | - | 15 | - | - | ns |
| Peripheral Read Access Time ( $t_{U T}{ }^{-t_{A D}}{ }^{-t_{D S R}}{ }^{-t_{A C C}}$ ) |  | ${ }^{\text {taCC }}$ | 695 |  | - | - | 440 | - | - | 330 | - | - | ns |
| Data Set Up Time (Read) |  | ${ }^{\text {t DSR }}$ | 80 |  | - | - | 60 | - | - | 40 | - | - | ns |
| Input Data Hold Time |  | ${ }^{\text {t }}$ DHR | 10 |  | - | - | 10 | - | - | 10 | - | - | ns |
| Address Hold Time | $A_{0} \sim A_{15}, R / \bar{W}$ | ${ }^{\prime}$ AH | $\begin{aligned} & \text { Fig. 2, Fig. }{ }^{3} \\ & \mathrm{Ta}=0 \sim+75^{\circ} \mathrm{C} \end{aligned}$ | 20 | - | - | 20 | - | - | 20 | - | - | ns |
|  |  |  | $\begin{aligned} & \text { Fig. 2, Fig. }{ }^{3} \\ & \mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C} \end{aligned}$ | 10 | - | - | 10 | - | - | 10 | - | - | ns |
| Data Delay Time (Write) |  | t DDW | Fig. 3 | - | - | 200 | - | - | 140 | - | - | 110 | ns |
| Output Hold Time |  | tohw | $\begin{aligned} & \text { Fig. } 3 \\ & \mathrm{Ta}=0 \sim+75^{\circ} \mathrm{C} \end{aligned}$ | 30 | - | - | 30 | - | - | 30 | - | - | ns |
|  |  | $\begin{aligned} & \text { Fig. } 3 \\ & \mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C} \end{aligned}$ | 20 | - | - | 20 | - | - | 20 | - | - | ns |  |

## 3. PROCESSOR CONTROL TIMING

| Item | Symbol | Test Condition | HD6809 |  |  | HD68A09 |  |  | HD68809 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| MRDY Set Up Time | ${ }_{\text {tPCSM }}$ | Fig. 6~Fig. 10 Fig. 14, Fig. 15 | 125 | - | - | 125 | - | - | 110 | - | - | ns |
| Interrupts Set Up Time | tpcs |  | 200 | - | - | 140 | - | - | 110 | - | - | ns |
| HALT Set Up Time | $t_{\text {PCSH }}$ |  | 200 | - | - | 140 | - | - | 110 | - | - | ns |
| RES Set Up Time | $t_{\text {PCSR }}$ |  | 200 | - | - | 140 | - | - | 110 | - | - | ns |
| DMA/BREQ Set Up Time | ${ }^{\text {tPCSD }}$ |  | 125 | - | - | 125 | - | - | 110 | - | - | ns |
| Processor Control Rise and Fall Time | ${ }^{{ }^{1} \mathrm{PCr}}$, $t_{\text {PCf }}$ |  | - | - | 100 | - | - | 100 | - | - | 100 | ns |
| Crystal Oscillator Start Time | ${ }^{\text {t }} \mathrm{RC}$ |  | - | - | 50 | - | - | 30 | - | - | 30 | ms |



Figure 1 Bus Timing Test Load


Figure 2 Read Data from Memory or Peripherals


Figure 3 Write Data to Memory or Peripherals

## - PROGRAMMING MODEL

As shown in Figure 4, the HD6809 adds three registers to the set available in the HD6800. The added registers include a Direct Page Register, the User Stack pointer and a second Index Register.

## - Accumulators (A, B, D)

The $A$ and $B$ registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data.

Certain instructions concatenate the $\mathbf{A}$ and B registers to form a single 16 -bit accumulator. This is referred to as the D
register, and is formed with the A register as the most significant byte.

- Direct Page Register (DP)

The Direct Page Register of the HD6809 serves to enhance the Direct Addressing Mode. The content of this register appears at the higher address outputs ( $\mathrm{A}_{8} \sim \mathrm{~A}_{15}$ ) during Direct Addressing Instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure HD6800 compatibility, all bits of this register are cleared during Processor Reset.

## - Index Rogisters (X, Y)

The Index Registers are used in indexed mode of addressing. The 16 -bit address in this register takes part in the calculation of effective addresses. This address may be used to point to data directly or may be modified by an optional constant or register
offset. During some indexed modes, the contents of the index register are incremented or decremented to point to the next item of tabular type data. All four pointer registers (X, Y, U, S) may be used as index registers.


Figure 4 Programming Model of The Microprocessing Unit

## - Stack Pointer (U, S)

The Hardware Stack Pointer (S) is used automatically by the processor during subroutine calls and interrupts. The stack pointers of the HD6809 point to the top of the stack, in contrast to the HD6800 stack pointer, which pointed to the next free location on the stack. The User Stack Pointer (U) is controlled exclusively by the programmer thus allowing arguments to be passed to and from subroutines with ease. Both Stack Pointers have the same indexed mode addressing capabilities as the X and Y registers, but also support Push and Pull instructions. This allows the HD6809 to be used efficiently as a stack processor, greatly enhancing its ability to support higher level languages and modular programming.

## - Program Counter

The Program Counter is used by the processor to point to the address of the next instruction to be executed by the processor. Relative Addressing is provided allowing the Program Counter to be used like an index register in some situations.

## - Condition Code Register

The Condition Code Register defines the State of the Processor at any given time. See Fig. 5.


Figure 5 Condition Code Register Format

## - CONDITION CODE REGISTER DESCRIPTION

- Bit 0 (C)

Bit 0 is the carry flag, and is usually the carry from the binary ALU. C is also used to represent a 'borrow' from subtract like instructions (CMP, NEG, SUB, SBC) and is the complement of the carry from the binary ALU.

## - Bit 1 (V)

Bit 1 is the overflow flag, and is set to a one by an operation which causes a signed two's complement arithmetic overflow. This overflow is detected in an operation in which the carry from the MSB in the ALU does not match the carry from the MSB-1.

- Bit $2(Z)$

Bit 2 is the zero flag, and is set to a one if the result of the previous operation was identically zero.

## - Bit 3 (N)

Bit 3 is the negative flag, which contains exactly the value of the MSB of the result of the preceding operation. Thus, a negative two's-complement result will leave N set to a one.

## - Bit 4 (I)

Bit 4 is the IRQ mask bit. The processor will not recognize interrupts from the IRQ line if this bit is set to a one. NMI, $\overline{F I R Q}, \overline{I R Q}, \overline{R E S}$, and SWI all are set I to a one; SWI2 and SWI3 do not affect I.

## - Bit 5 (H)

Bit 5 is the half-carry bit, and is used to indicate a carry•from bit 3 in the ALU as a result of an 8 -bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is
undefined in all subtract-like instructions.

- Bit 6 (F)

Bit 6 is the $\overline{\text { FIRQ }}$ mask bit. The processor will not recognize interrupts from the FIRQ line if this bit is a one. $\overline{\text { NMI, }}$, FIRQ, SWI, and $\overline{\text { RES }}$ all set $F$ to a one. IRQ, SWI2 and SWI3 do not affect $F$.

- Bit 7 (E)

Bit 7 is the entire flag, and when set to a one indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current E left in the Condition Code Register represents past action.

## - SIGNAL DESCRIPTION

## - Power ( $\mathrm{V}_{\mathbf{s s}}, \mathrm{V}_{\mathbf{c c}}$ )

Two pins are used to supply power to the part: $\mathrm{V}_{\mathrm{SS}}$ is ground or 0 volts, while $V_{\text {CC }}$ is $+5.0 \mathrm{~V} \pm 5 \%$.

## - Address Bus $\left(A_{0} \sim A_{15}\right)$

Sixteen pins are used to output address information from the MPU onto the Address Bus. When the processor does not require the bus for a data transfer, it will output address $\mathrm{FFFF}_{16}, \mathrm{R} / \overline{\mathrm{W}}=$ "High", and BS = "Low"; this is a "dummy access" or VMA cycle. Addresses are valid on the rising edge of Q (see Figs. 2 and 3). All address bus drivers are made high impedance when output Bus Availalbe (BA) is "High". Each pin will drive one Schottky TTL load or four LS TTL loads, and typically 90 pF .

## - Data Bus ( $D_{0} \sim D_{7}$ )

These eight pins provide communication with the system bi-directional data bus. Each pin will drive one Schottky TTL load or four LS TTL loads, and typically 130 pF .

## - Read/Write (R/W)

This signal indicates the direction of data transfer on the data bus. A "Low" indicates that the MPU is writing data onto the data bus. $\mathrm{R} / \overline{\mathrm{W}}$ is made high impedance when BA is "High". $\mathrm{R} / \overline{\mathrm{W}}$ is valid on the rising edge of $\mathbf{Q}$. Refer to Figs. 2 and 3.

## - Reset ( $\overline{\mathrm{RES}}$ )

A "Low" level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in Fig. 6. The Reset vectors are fetched from locations FFFE $_{16}$ and FFFF $_{16}$ (Table 1) when Interrupt Acknowledge is true, ( $\overline{\mathrm{BA}} \cdot \mathrm{BS}=1$ ). During initial power-on, the Reset line should be held "Low" until the clock oscillator is fully operational. See Fig. 7.

Because the HD6809 Reset pin has a Schmitt-trigger input with a threshold voltage higher than that of standard peripherals, a simple R/C network may be used to reset the entire system. This higher threshold voltage ensures that all peripherals are out of the reset state before the Processor.

Table 1 Memory Map for Interrupt Vectors

| Memory Map For <br> Vector Locations |  | Interrupt Vector <br> Description |
| :---: | :---: | :---: |
| MS | LS |  |
| FFFE | FFFF | $\overline{\text { NMI }}$ |
| FFFC | FFFD | $\frac{\text { SWI }}{\text { FFFA }}$ |
| FFF8 | FFFB | $\overline{\text { FIQ }}$ |
| FFF6 | FFF9 | $\overline{\text { FIRO }}$ |
| FFF4 | FFF5 | SWI2 |
| FFF2 | FFF3 | SWI3 |
| FFF0 | FFF1 | Reserved |

- HALT

A "Low" level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven "High" indicating the buses are high impedance. BS is also "High" which indicates the processor is in the Halt or Bus Grant state. While halted, the MPU will not respond to external real-time requests ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) although $\overline{\mathrm{DMA} / \mathrm{BREQ}}$ will always be accepted, and $\overline{\text { NMI }}$ or RES will be latched for later response. During the Halt state $\mathbf{Q}$ and E continue to run normally. If the MPU is not running ( $\overline{\mathrm{RES}}, \overline{\mathrm{DMA} / \mathrm{BREQ}}$ ), a halted state ( $\mathrm{BA} \cdot \mathrm{BS}=1$ ) can be achieved by pulling HALT "Low" while RES is still "Low". If $\overline{\text { DAM/BREQ and } \overline{H A L T}}$ are both pulled "Low", the processor will reach the last cycle of the instruction (by reverse cycle stealing) where the machine will then become halted. See Figs. 8 and 16.

## - Bus Available, Bus Status (BA, BS)

The BA output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. This signal does not imply that the bus will be available for more than one cycle. When BA goes "Low", an additional dead cycle will elapse before the MPU acquires the bus.

The BS output signal, when decoded with BA, represents the MPU state (valid with leading edge of $\mathbf{Q}$ ).

Table 2 MPU State Definition

| BA | BS | MPU State |
| :--- | :---: | :--- |
| 0 | 0 | Normal (Running) |
| 0 | 1 | Interrupt or RESET Acknowledge |
| 1 | 0 | SYNC Acknowledge |
| 1 | 1 | HALT or Bus Grant |

Interrupt Acknowledge is indicated during both cycles of a hardware-vector-fetch (RES, NMI, $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$, SWI, SWI2, SWI3). This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 1.

Sync Acknowledge is indicated while the MPU is waiting for external synchronization on an interrupt line.

Halt/Bus Grant is true when the HD6809 is in a Halt or Bus Grant condition.


## - Non Maskable Interrupt (NMI)*

A negative edge on this input requests that a non-maskable interrupt sequence be generated. A non-maskable interrupt cannot be inhibited by the program, and also has a higher priority than FIRQ, $\overline{\text { IRQ }}$ or software interrupts. During recognition of an NMI, the entire machine state is saved on the
hardware stack. After reset, an NMI will not be recognized until the first program load of the Hardware Stack Pointer (S). The pulse width of NMI "Low" must be at least one E cycle. If the NMI input does not meet the minimum set up with respect to Q, the interrupt will not be recognized until the next cycle. See Fig. 9.


Figure $8 \overline{\text { HALT }}$ and Single Instruction Execution for System Debug


Figure $9 \overline{\mathrm{IRO}}$ and $\overline{\text { NMI }}$ Interrupt Timing


Figure $10 \overline{\mathrm{FIRO}}$ interrupt Timing

## - Fast-Interrupt Request ( $\overline{\mathrm{FIRO}})^{*}$

A "Low" level on this input pin will initiate a fast interrupt sequence provided its mask bit (F) in the CC is clear. This sequence has priority over the standard Interrupt Request (IRQ), and is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See Fig. 10.

## - Interrupt Request ( $\overline{\mathbf{R} \mathbf{Q}})^{*}$

A "Low" level input on this pin will initiate an interrupt Request sequence provided the mask bit (I) in the CC is clear. Since IRQ stacks the entire machine state it provides a slower response to interrupts than FIRQ. IRQ also has a lower priority than FIRQ. Again, the interrupt service routine should clear the source of the interrupt before doing an RTI. See Fig. 9.

* $\overline{\text { NMI }}, \overline{\text { FIRQ, }}$, and $\overline{\text { IRQ }}$ requests are sampled on the falling edge of Q . One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. If IRQ and $\overline{F I R Q}$ do not remain "Low" until completion of the current instruction they may not be recognized. However, NMI is latched and need only remain "Low" for one cycle.
- XTAL, EXTAL

These inputs are used to connect the on-chip oscillator to an external parallel-resonant crystal. Alternately, the pin EXTAL may be used as a TTL level input for external timing by grounding XTAL. The crystal or external frequency is four times the bus frequency. See Fig. 7. Proper RF layout techniques should be observed in the layout of printed circuit boards.

## <NOTE FOR BOARD DESIGN OF THE OSCILLATION CIRCUIT $>$

In designing the board, the following notes should be taken when the crystal oscillator is used.

1) Crystal oscillator and load capacity Cin, Cout must be placed
near the LSI as much as possible.
(Normal oscillation may be disturbed when external noise is induced to pin 38 and 39.
2) Pin 38 and 39 signal line should be wired apart from other signal line as much as possible. Don't wire them in parallel.
[Normal oscillation may be disturbed when E or Q signal is] feedbacked to pin 38 and 39.


Figure 11 Board Design of the Oscillation Circuit.

## <THE FOLLOWING DESIGN MUST BE AVOIDED >

A signal line or a power sóurce line must not cross or go near the oscillation circuit line as shown in Fig. 12 to prevent the induction from these lines and perform the correct oscillation. The resistance among XTAL, EXTAL and other pins should be over $10 \mathrm{M} \Omega$.


- E, $\mathbf{O}$

E is similar to the HD6800 bus timing signal $\phi_{2} ; \mathrm{Q}$ is a quadrature clock signal which leads E . Q has no parallel on the HD6800. Addresses from the MPU will be valid with the leading edge of Q . Data is latched on the falling edge of E . Timing for E and Q is shown in Fig. 13.

- MRDY

This input control signal allows stretching of $E$ and $Q$ to extend data-access time. E and Q operate normally while MRDY is "High". When MRDY is "Low", E and Q may be stretched in integral multiples of quarter ( $1 / 4$ ) bus cycles, thus allowing interface to slow memories, as shown in Fig. 14. A maximum

Figure 12 Example of Normal Oscillation may be Disturbed.


Figure 13 E/Q Relationship


Figure 14 MRDY Timing
stretch is 10 microseconds. During nonvalid memory access (VMA cycles) MRDY has no effect on stretching E and Q; this, inhibits slowing the processor during "don't care" bus accesses. MRDY may also be used to stretch clocks (for slow memory) when bus control has been transferred to an external device (through the use of HALT and DMA/BREQ).
Also MRDY has effect on stretching E and Qduring Dead Cycle.

## - DMA/BREQ

The $\overline{\text { DMA/BREQ }}$ input provides a method of suspending execution and acquiring the MPU bus for another use, as shown in Fig. 15. Typical uses include DMA and dynamic memory refresh.

Transition of DMA/BREQ should occur during Q. A "Low" level on this pin will stcp instruction execution at the end of the current cycle. The MPU will acknowledge DMA/BREQ by setting BA and BS to "High" level. The requesting device will now have up to 15 bus cycles before the MPU retrieves the bus for self-refresh. Self-refresh requires one bus cycle with a lead-
ing and trailing dead cycle. See Fig. 16.
Typically, the DMA controller will request to use the bus by asserting DMA/BREQ pin "Low" on the leading edge of E . When the MPU replies by setting BA and BS to a one, that cycle will be a dead cycle used to transfer bus mastership to the DMA controller.

False memory accesses may be prevented during and dead cycles by developing a system DMAVMA signal which is "Low" in any cycle when BA has changed.

When BA goes "Low" (either as a result of DMA/BREQ $=$ "High" or MPU self-refresh), the DMA device should be taken off the bus. Another dead cycle will elapse before the MPU accesses memory, to allow transfer of bus mastership without contention.

## - MPU OPERATION

During normal operation, the MPU fetches an instruction from memory and then executes the requested function. This


ADDR
(DMAC)

* $\overline{\text { DMAVMA }}$ is a signal which is developed externally, but is a system requirement for DMA.

Figure 15 Typical DMA Timing (<14 Cycles)


* $\overline{\text { DMAVMA }}$ is a signal which is developed externally, but is a system requirement for DMA.

Figure 16 Auto - Refresh DMA Timing (Reverse Cycle Stealing)
sequence begins at RES and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Software instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI and SYNC. An interrupt, $\overline{\text { HALT }}$ or DMA/BREQ can also alter the normal execution of instructions. Fig. 17 illustrates the flow chart for the HD6809.

## - ADDRESSING MODES

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The HD6809 has the most complete set of addressing modes available on any microcomputer today. For example, the HD6809 has 59 basic instructions; however, it recognizes 1464 different variations of instructions and addressing modes. The addressing modes support modern programming techniques. The following addressing modes are available on the HD6809:
(1) Implied (Includes Accumulator)
(2) Immediate
(3) Extended
(4) Extended Indirect
(5) Direct
(6) Register
(7) Indexed

## Zero-Offset

Constant Offset
Accumulator Offset
Auto Increment/Decrement
(8) Indexed Indirect
(9) Relative
(10) Program Counter Relative

## - Implied (Includes Accumulator)

In this addressing mode, the opcode of the instruction contains all the address information necessary. Examples of Implied Addressing are: ABX, DAA, SWI, ASRA, and CLRB.

## - Immediate Addressing

In Immediate Addressing, the effective address of the data is the location immediately following the opcode (i.e., the data to be used in the instruction immediately follows the opcode of the instruction). The HD6809 uses both 8 and 16 -bit immediate values depending on the size of argument specified oy the opcode. Examples of instructions with Immediate Addressing are:

## LDA \#\$20

LDX \#\$F000
LDY \#CAT
(NOTE) \# signifies Immediate addressing, \$ signifies hexadecimal value.

## - Extended Addressing

In Extended Addressing, the contents of the two bytes immediately following the opcode fully specify the 16 -bit effective address used by the instruction. Note that the address generated by an extended instruction defines an absolute address and is not position independent. Examples of Extended Addressing include:

| LDA | CAT |
| :--- | :--- |
| STX | MOUSE |
| LDD | $\$ 2000$ |

## - Extended Indirect

As a special case of indexed addressing (discussed below), " 1 " level of indirection may be added to Extended Addressing. In Extended Indirect, the two bytes following the postbyte of an Indexed instruction contain the address of the data.

| LDA | $[\mathrm{CAT}]$ |
| :--- | :--- |
| LDX | $[\$ F F F E]$ |
| STU | $[\mathrm{DOG}]$ |

## - Direct Addressing

Direct addressing is similar to extended addressing except that only one byte of address follows the opcode. This byte specifies the lower 8 -bit of the address to be used. The upper 8 -bit of the address are supplied by the direct page register. Since only one byte of address is required in direct addressing, this mode requires less memory and executes faster than extended addressing. Of course, only 256 locations (one page) can be

(NOTE) Asserting $\overline{\operatorname{RES}}$ will result in entering the reset sequence from any point in the flow chart.
Figure 17 Flowchart for HD6809 Instruction
accessed without redefining the contents of the DP register. Since the DP register is set to $\$ 00$ on Reset, direct addressing on the HD6809 is compatible with direct addressing on the HD6800. Indirection is not allowed in direct addressing. Some examples of direct addressing are:

| LDA | $\$ 30$ |
| :--- | :--- |
| SETDP | $\$ 10$ (Assembler directive) |
| LDB | $\$ 1030$ |
| LDD | <CAT |

(NOTE) $<$ is an assembler directive which forces direct addressing.

## - Register Addressing

Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction. This is called a postbyte. Some examples of register addressing are:

| TFR | X, Y | Transfers X into Y |
| :--- | :--- | :--- |
| EXG | A, B | Exchanges A with B |
| PSHS | A, B, X, Y | Push Y, X, B and A onto S |
| PULU | X, Y, D | Pull D, X, and Y from U |

## - Indexed Addressing

In all indexed addressing, one of the pointer registers ( $\mathrm{X}, \mathrm{Y}$, $\mathrm{U}, \mathrm{S}$, and sometimes PC) is used in a calculation of the effective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode as well as the pointer register to be used. Fig. 18 lists the legal formats for the postbyte. Table 3 gives the assembler form and the number of cycles and bytes

| Post-Byte Register Bit |  |  |  |  |  |  |  | Indexed Addressing Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0 | R | R | $\times$ | $\times$ | $\times$ | $\times$ | $\times$ | $E A=, R+5$ Bit Offset |
| 1 | R | R | 0 | 0 | 0 | 0 | 0 | , $\mathrm{R}+$ |
| 1 | R | R | 0/1 | 0 | 0 | 0 | 1 | , $\mathrm{R}++$ |
| 1 | R | R | 0 | 0 | 0 | 1 | 0 | , -R |
| 1 | R | R | 0/1 | 0 | 0 | 1 | 1 | , --R |
| 1 | R | R | 0/1 | 0 | 1 | 0 | 0 | $E A=, R+0$ Offset |
| 1 | $R$ | R | 0/1 | 0 | 1 | 0 | 1 | $E A=, R+A C C B$ Offset |
| 1 | R | R | 0/1 | 0 | 1 | 1 | 0 | $E A=, R+A C C A ~ O f f$ set |
| 1 | R | R | 0/1 | 1 | 0 | 0 | 0 | $E A=, R+8$ Bit Offset |
| 1 | R | R | 0/1 | 1 | 0 | 0 | 1 | $E A=, R+16$ Bit Offset |
| 1 | R | R | 0/1 | 1 | 0 | 1 | 1 | $E A=, R+D$ Offset |
| 1 | $\times$ | $\times$ | 0/1 | 1 | 1 | 0 | 0 | $E A=, P C+8$ Bit Offset |
| 1 | $\times$ | $\times$ | 0/1 | 1 | 1 | 0 | 1 | $E A=, P C+16$ Bit Offset |
| 1 | R | R | 1 | 1 | 1 | 1 | 1 | $\mathrm{EA}=$ [,Address] |
|  |  |  |  |  |  |  |  | Addressing Mode Field <br> Indirect Field (Sigh bit when b7 $=0$ ) $\left\{\begin{array}{lll}0 & \ldots . . . . & \text { Non Indirect } \\ 1 \ldots \ldots . . & \text { Indirect }\end{array}\right.$ Register Field : RR $\begin{aligned} & 00=X \\ & 01=Y \\ & 10=U \\ & 11=S \end{aligned}$ |

Figure 18 Index Addressing Postbyte Register Bit Assignments

Table 3 Indexed Addressing Mode

| Type | Forms | Non Indirect |  |  |  | Indirect |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Assembler Form | Postbyte OP Code | $\underset{\sim}{+}$ | $\stackrel{+}{+}$ | Assembler Form | Postbyte OP Code | $\pm$ | + |
| Constant Offset From R (2's Complement Offsets) | No Offset | ,R | 1RR00100 | 0 | 0 | [,R] | 1RR10100 | 3 | 0 |
|  | 5 Bit Offset | n, R | ORRnnnnn | 1 | 0 | defaults to 8-bit |  |  |  |
|  | 8 Bit Offset | $n, R$ | 1RR01000 | 1 | 1 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11000 | 4 | 1 |
|  | 16 Bit Offset | $\mathrm{n}, \mathrm{R}$ | 1RR01001 | 4 | 2 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11001 | 7 | 2 |
| Accumulator Offset From R (2's Complement Offsets) | A Register Offset | A, R | 1RR00110 | 1 | 0 | [A, R] | 1RR10110 | 4 | 0 |
|  | B Register Offset | B, R | 1RR00101 | 1 | 0 | [ $\mathrm{B}, \mathrm{R}$ ] | 1RR10101 | 4 | 0 |
|  | D Register Offset | D, R | 1RR01011 | 4 | 0 | [D, R] | 1RR11011 | 7 | 0 |
| Auto Increment/Decrement R | Increment By 1 | . $\mathrm{R}+$ | 1RR00000 | 2 | 0 | not allowed |  |  |  |
|  | Increment By 2 | , R + + | 1RR00001 | 3 | 0 | [, R + + ] | 1RR10001 | 6 | 0 |
|  | Decrement By 1 | , -R | 1RR00010 | 2 | 0 | not allowed |  |  |  |
|  | Decrement By 2 | , - - R | 1RR00011 | 3 | 0 | [, - - R ] | 1RR10011 | 6 | 0 |
| Constant Offset From PC (2's Complement Offsets) | 8 Bit Offset | $n$, PCR | $1 \times \times 01100$ | 1 | 1 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11100$ | 4 | 1 |
|  | 16 Bit Offset | $n$, PCR | $1 \times \times 01101$ | 5 | 2 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11101$ | 8 | 2 |
| Extended Indirect | 16 Bit Address | - | - | - | - | [ n ] | 10011111 | 5 | 2 |

$R=X, Y, U$ or $S \quad R R:$

| $X=$ Don't Care | $00=X$ |
| :--- | :--- |
|  | $01=Y$ |
|  | $10=U$ |
|  | $11=S$ |

$\stackrel{\sim}{\sim}$ and $_{\#}^{+}$indicate the number of additional cycles and bytes for the particular variation.
added to the basic values for indexed addressing for each variation.

## Zero-Offset Indexed

In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode.

Examples are:

## LDD $\mathbf{0 , X}$ <br> LDA S

## Constant Offset Indexed

In this mode, a two's-complement offset and the contents of one of the pointer registers are added to form the effective address of the operand. The pointer register's initial content is unchanged by the addition.

Three sizes of offsets are available:
5 -bit ( -16 to +15 )
8 -bit ( -128 to +127 )
16 -bit ( -32768 to +32767 )
The two's complement 5 -bit offset is included in the postbyte and, therefore, is most efficient in use of bytes and cycles. The two's complement 8 -bit offset is contained in a single byte following the postbyte. The two's complement 16-bit offset is in the two bytes following the postbyte. In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically.

Examples of constant-offset indexing are:

$$
\begin{array}{ll}
\text { LDA } & 23, X \\
\text { LDX } & -2, \mathrm{~S} \\
\text { LDY } & 300, \mathrm{X} \\
\text { LDU } & \text { CAT,Y }
\end{array}
$$

## Accumulator-Offset Indexed

This mode is similar to constant offset indexed except that the two's-complement value in one of the accumulators (A, B or D) and the contents of one of the pointer registers are added to form the effective address of the operand. The contents of both the accumulator and the pointer register are unchanged by the addition. The postbyte specifies which accumulator to use as an offset and no additional bytes are required. The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run-time.

Some examples are:
LDA B,Y
LDX D,Y
LEAX B,X

## Auto Increment/Decrement Indexed

In the auto increment addressing mode, the pointer register contains the address of the operand. Then, after the pointer register is used it is incremented by one or two. This addressing mode is useful in stepping through tables, moving data, or for the creation of software stacks. In auto decrement, the pointer register is decremented prior to use as the address of the data. The use of auto decrement is similar to that of auto increment; but the tables, etc., are scanned from the "High" to "Low" addresses. The size of the increment/decrement can be either one or two to allow for tables of either 8 or 16-bit data to be accessed and is selectable by the programmer. The predecrement, post-increment nature of these modes allow them to be used to create additional software stacks that behave identically to the U and S stacks.

Some examples of the auto increment/decrement addressing modes are:

| LDA | , $\mathrm{X}+$ |
| :--- | :--- |
| STD | , $\mathrm{Y}++$ |
| LDB | ,-Y |
| LDX | ,--S |

Care should be taken in performing operations on 16-bit pointer registers ( $\mathbf{X}, \mathbf{Y}, \mathrm{U}, \mathrm{S}$ ) where the same register is used to calculate the effective address.

Consider the following instruction:
STX $0, \mathrm{X}++(\mathrm{X}$ initialized to 0$)$
The desired result is to store a 0 in locations $\$ 0000$ and $\$ 0001$ then increment $X$ to point to $\$ 0002$. In reality, the following occurs:

$$
\begin{array}{ll}
0 \rightarrow \text { temp } & \text { calculate the EA; temp is a holding register } \\
X+2 \rightarrow X & \text { perform autoincrement } \\
X \rightarrow \text { (temp) } & \text { do store operation }
\end{array}
$$

## - Indexed Indirect

All of the indexing modes with the exception of auto increment/decrement by one, or a $\pm 4$-bit offset may have an additional level of indirection specified. In indirect addressing, the effective address is contained at the location specified by the contents of the Index register plus any offset. In the example below, the A accumulator is loaded indirectly using an effective address calculated from the Index register and an offset.

Before Execution
A $=x \times$ (don't care)
$\mathrm{X}=\$ \mathrm{~F} 000$
$\$ 0100$ LDA [\$10,X]
EA is now \$F010
\$F010 \$F1
\$F011 \$50
$\$ F 150$ is now the new EA

## \$F150 \$AA

After Execution

$$
\mathbf{A}=\$ \mathbf{A A} \text { Actual Data Loaded }
$$

$$
\mathrm{X}=\$ \mathrm{~F} 000
$$

All modes of indexed indirect are included except those which are meaningless (e.g., auto increment/decrement by 1 indirect). Some examples of indexed indirect are:

| LDA | $[, \mathrm{X}]$ |
| :--- | :--- |
| LDD | $[10, \mathrm{~S}]$ |
| LDA | $[\mathrm{B}, \mathrm{Y}]$ |
| LDD | $[, \mathrm{X}++]$ |

## - Relative Addressing

The byte(s) following the branch opcode is (are) treated as a signed offset which may be added to the program counter. If the branch condition is true then the calculated address (PC + signed offset) is loaded into the program counter. Program execution continues at the new location as indicated by the PC; short ( 1 byte offset) and long ( 2 bytes offset) relative addressing modes are available. All of memory can be reached in long relative addressing as an effective address is interpreted modulo $2^{16}$. Some examples of relative addressing are:

|  | BEQ | CAT | (short) |
| :--- | :--- | :--- | :--- |
|  | BGT | DOG | (short) |
| CAT | LBEQ | RAT | (long) |
| DOG | LBGT | RABBIT | (long) |


|  | $\bullet$ |
| :--- | :--- |
|  | $\bullet$ |
| RAT | NOP |
| RABBIT | NOP |

## - Program Counter Relative

The PC can be used as the pointer register with 8 or 16 -bit signed offsets. As in relative addressing, the offset is added to the current PC to create the effective address. The effective address is then used as the address of the operand or data. Program Counter Relative Addressing is used for writing position independent programs. Tables related to a particular routine will maintain the same relationship after the routine is moved, if referenced relative to the Program Counter. Examples are:

```
LDA CAT, PCR
LEAX TABLE, PCR
```

Since program counter relative is a type of indexing, an additional level of indirection is available.

```
LDA [CAT, PCR]
LDU [DOG,PCR]
```


## - HD6809 INSTRUCTION SET

The instruction set of the HD6809 is similar to that of the HD6800 and is upward compatible at the source code level. The number of opcodes has been reduced from 72 to 59 , but because of the expanded architecture and additional addressing modes, the number of available opcodes (with different addressing modes) has risen from 197 to 1464.
Some of the new instructions and addressing modes are described in detail below:

## - PSHU/PSHS

The push instructions have the capability of pushing onto either the hardware stack (S) or user stack (U) any single register, or set of registers with a single instruction.

- PULU/PULS

The pull instructions have the same capability of the push instruction, in reverse order. The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled. The actual PUSH/PULL sequence is fixed; each bit defines a unique register to push or pull, as shown in below.

PUSH/PULL POST BYTE


| $\leftarrow$ Pull Order |  |  |  | Push Order $\rightarrow$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | DP | B | A | CC |
| FFFF...ヶ increasing memory address ..... 0000 |  |  |  |  |  |  |  |
| PC | S | Y | X | DP | B | A | CC |

## -TFR/EXG

Within the HD6809, any register may be transferred to or exchanged with another of like-size; i.e., 8 -bit to 8 -bit or 16 -bit to 16 -bit. Bits $4-7$ of postbyte define the source register, while bits $0-3$ represent the destination register. Three are denoted as follows:

| $0000-\mathrm{D}$ | $0101-\mathrm{PC}$ |
| :--- | :--- |
| $0001-\mathrm{X}$ | $1000-\mathrm{A}$ |
| $0010-\mathrm{Y}$ | $1001-\mathrm{B}$ |
| $0011-\mathrm{U}$ | $1010-\mathrm{CC}$ |
| $0100-\mathrm{S}$ | $1011-\mathrm{DP}$ |

(NOTE) All other combinations are undefined and INVALID.
TRANSFER/EXCHANGE POST BYTE

## SOURCE DESTTNATION

## - LEAX/LEAY/LEAU/LEAS

The LEA (Load Effective Address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in Table 4.

The LEA instruction also allows the user to access data in a position independent manner. For example:

| LEAX | MSG1, PCR |
| ---: | :--- |
| LBSR | PDATA (Print message roútine) |
| $\bullet$ |  |
| $\bullet$ |  |
| 1 FCC | 'MESSAGE' |

This sample program prints: 'MESSAGE'. By writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located, when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the $\mathbf{X}$ pointer register. This code is totally position independent.
The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the autoincrement and autodecrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows:

| LEAa, $b+$ | (any of the 16 -bit pointer registers $X, Y, U$ <br> or S may be substituted for a and $b)$. |
| :--- | :--- |
| 1. $b \rightarrow$ temp | (calculate the EA) |
| 2. $b+1 \rightarrow b$ | (modify $b$, postincrement) |
| 3. temp $\rightarrow a$ | (load a) |
| LEAa, -b |  |
| 1. $b-1 \rightarrow$ temp (calculate EA with predecrement) <br> 2. $b-1 \rightarrow b$ (modify $b$, predecrement) <br> 3. temp $\rightarrow a$ (load a) |  |

Autoincrement-by-two and autodecrement-by-two instructions work similarly. Note that LEAX, $\mathbf{X}+$ does not change $\mathbf{X}$, however LEAX, -X does decrement X. LEAX 1, X should be used to increment $\mathbf{X}$ by one.

Table 4 LEA Examples

| Instruction | Operation | Comment |
| :--- | :--- | :--- |
| LEAX 10, X | $\mathrm{X}+10 \rightarrow \mathrm{X}$ | Adds 5-bit constant 10 to X |
| LEAX 500, X | $\mathrm{X}+500 \rightarrow \mathrm{X}$ | Adds 16-bit constant 500 to X |
| LEAY $\mathrm{A}, \mathrm{Y}$ | $\mathrm{Y}+\mathrm{A} \rightarrow \mathrm{Y}$ | Adds 8-bit accumulator to Y |
| LEAY $\quad \mathrm{D}, \mathrm{Y}$ | $\mathrm{Y}+\mathrm{D} \rightarrow \mathrm{Y}$ | Adds 16-bit D accumulator to Y |
| LEAU $-10, \mathrm{U}$ | $\mathrm{U}-10 \rightarrow \mathrm{U}$ | Subtracts 10 from U |
| LEAS $-10, \mathrm{~S}$ | $\mathrm{~S}-10 \rightarrow \mathrm{~S}$ | Used to reserve area on stack |
| LEAS | 10, S | $\mathrm{S}+10 \rightarrow \mathrm{~S}$ |
| LEAX | Used to 'clean up' stack |  |

## - MUL

Multiplies the unsigned binary numbers in the A and B accumulator and places the unsigned result into the 16 -bit D accumulator. This unsigned multiply also allows multipleprecision multiplications.

## Long And Short Relative Branches

The HD6809 has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 or 16 -bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64 k memory map. Position independent code can be easily generated through the use of relative branching. Both short (8-bit) and long (16-bit) branches are available.

## - SYNC

After encountering a Sync instruction, the MPU enters a Sync state, stops processing instructions and waits for an interrupt. If the pending interrupt is non-maskable ( $\overline{\mathrm{NMI})}$ or maskable (FIRQ, IRQ) with its mask bit (F or I) clear, the processor will clear the Syne state and perform the normal interrupt stacking and service routine. Since $\overline{\text { FIRQ }}$ and $\overline{\overline{I R Q}}$ are not edge-triggered, a "Low" level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) with its mask bit (F or I) set, the processor will clear the Sync state and continue processing by executing the next inline instruction. Fig. 19 depicts Sync timing.

## Software Interrupts

A Software Interrupt is an instruction which will cause an interrupt, and its associated vector fetch. These Software Interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on this HD6809, and are prioritized in the following order: SWI, SWI2, SWI3.

## 16-Bit Operation

The HD6809 has the capability of processing 16-bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes and pulls.

## - CYCLE-BY-CYCLE OPERATION

The address bus cycle-by-cycle performance chart illustrates the memory-access sequence corresponding to each possible instruction and addressing mode in the HD6809. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this technique considerably speeds throughput.) Next, the operation of each opcode will follow the flow chart. $\overline{\text { VMA }}$ is an indication of

FFFF $_{16}$ on the address bus, R/W="High" and BS="Low". The following examples illustrate the use of the chart; see Fig. 20.

| Example 1: LBSR (Branch Taken) Before Execution SP = F000 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| - |  |  |  |  |
| - |  |  |  |  |
| \$8000 |  | LBSR | CAT |  |
|  |  | - |  |  |
|  |  | - |  |  |
| \$A000 | CAT | - |  |  |
|  |  | CYCLE-BY-CYCLE FLOW |  |  |
| Cycle \# | Address | Data | R/W | Description |
| $1$ | $8000$ | $17$ | $1$ | Opcode Fetch |
| 2 | 8001 | 1F | 1 O | Offset High Byte |
| 3 | 8002 | FD | 10 | Offset Low Byte |
| 4 | FFFF | * | 1 V | VMA Cycle |
| 5 | FFFF | * | 1 V | VMA Cycle |
| 6 | A000 | * | 1 C | Computed Branch |
|  |  |  |  | Address |
| 7 | FFFF | * | 1 V | VMA Cycle |
| 8 | EFFF | 03 | 0 S | Stack Low Order |
|  |  |  |  | Byte of Return Address |
| 9 | EFFE | 80 | 0 S | Stack High Order |
|  |  |  |  | Byte of Return |
|  |  |  |  | Address |

Example 2: DEC (Extended)

| $\begin{aligned} & \$ 8000 \\ & \$ A 000 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { FCB } \end{aligned}$ |  | $\begin{aligned} & \$ A 000 \\ & \$ 80 \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | CYCLE-BY-CYCLE FLOW |  |  |
| Cycle \# | Address | Data | R/W | Description |
| 1 | 8000 | 7A | 1 | Opcode Fetch |
| 2 | 8001 | A0 | 1 | Operand Address, High Byte |
| 3 | 8002 | 00 | 1 | Operand Address, Low Byte |
| 4 | FFFF | * | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | * | 1 | VMA Cycle |
| 7 | A000 | 7F | 0 | Store the Decremented Data |

* The data bus has the data at that particular address.


## - HD6809 INSTRUCTION SET TABLES

The instructions of the HD6809 have been broken down into five different categories. They are as follows:

16-Bit operation (Table 6) Index register/stack pointer instructions (Table 7) Relative branches (long or short) (Table 8) Miscellaneous instructions (Table 9) HD6809 instruction set tables and Hexadecimal Values of instructions are shown in Table 10 and Table 11.

(NOTES) * If the associated mask bit is set when the interrupt is requested, this cycle will be an instruction fetch from address location PC +1 However, if the interrupt is accepted (NMI or an unmasked FIRQ or IRQ) interrupt processing continues with this cycle as (m) on Figure 9 and 10 (Interrupt Timing)
**. If mask bits are clear, IRQ and FIRQ must be held "Low" for three cycles to guarantee that interrupt will be taken, although only one cycle is necessary to bring the processor out of SYNC.

Figure 19 Sync Timing

(NOTE) Write operation during store instruction.
Figure 20 Address Bus Cycle-by-Cycle Performance

(NOTE) STACK': Address stored in stack pointer before execution. STACK'': Address set to stack pointer as the result of the execution.

Figure 20 Address Bus Cycle-by-Cycle Performance (Continued)


Figure 20 Address Bus Cycle-by-Cycle Performance (Continued)

Table 5 8-Bit Accumulator and Memory Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADCA, ADCB | Add memory to accumulator with carry |
| ADDA, ADDB | Add memory to accumulator |
| ANDA, ANDB | And memory with accumulator |
| ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left |
| ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right |
| BITA, BITB | Bit test memory with accumulator |
| CLR, CLRA, CLRB | Clear accumulator or memory location |
| CMPA, CMPB | Compare memory from accumulator |
| COM, COMA, COMB | Complement accumultor or memory location |
| DAA | Decimal adjust A accumulator |
| DEC, DECA, DECB | Decrement accumulator or memory location |
| EORA, EORB | Exclusive or memory with accumulator |
| EXG R1, R2 | Exchange R1 with R2 (R1, R2 = A, B, CC, DP) |
| INC, INCA, INCB | Increment accumulator or memory location |
| LDA, LDB | Load accumulator from memory |
| LSL, LSLA, LSLB | Logical shift left accumulator or memory location |
| LSR, LSRA, LSRB | Logical shift right accumulator or memory location |
| MUL | Unsigned multiply (A $\times$ B $\rightarrow$ D) |
| NEG, NEGA, NEGB | Negate accumulator or memory |
| ORA, ORB | Or memory with accumulator |
| ROL, ROLA, ROLB | Rotate accumulator or memory left |
| ROR, RORA, RORB | Rotate accumulator or memory right |
| SBCA, SBCB | Subtract memory from accumulator with borrow |
| STA, STB | Store accumulator to memory |
| SUBA, SUBB | Subtract memory from accumulator |
| TST, TSTA, TSTB | Test accumulator or memory location |
| TFR R1, R2 | Transfer R1 to R2 (R1, R2 $=$ A, B, CC, DP) |

(NOTE) A, B, CC or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 6 16-Bit Accumulator and Memory Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADDD | Add memory to D accumulator |
| CMPD | Compare memory from D accumulator |
| EXG D, R | Exchange D with $X, Y$, S, U or PC |
| LDD | Load D accumulator from memory |
| SEX | Sign Extend B accumulator into $A$ accumulator |
| STD | Store D accumulator to memory |
| SUBD | Subtract memory from D accumulator |
| TFR D, R | Transfer D to $X, Y, S, U$ or PC |
| TFR R,D | Transfer $X, Y, S, U$ or PC to $D$ |

(NOTE) D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 7 Index Register/Stack Pointer Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| CMPS, CMPU | Compare memory from stack pointer |
| CMPX, CMPY | Compare memory from index register |
| LEA R1, R2 | Exchange $D, X, Y, S, U$ or PC with $D, X, Y, S, \cup$ or PC |
| LEAX, LEAU | Load effective address into stack pointer |
| LDS, LDU | Load effective address into index register |
| LDX, LDY | Load stack pointer from memory |
| PSHS | Load index register from memory |
| PSHU | Push A, B, CC, DP, D, X, Y, U, or PC onto hardware stack |
| PULS | Push A, B, CC, DP, D, X, Y, S, or PC onto user stack |
| PULU | Pull A, B, CC, DP, D, X, Y, U or PC from hardware stack |
| STS, STU | Pull A, B, CC, DP, D, X, Y, S or PC from user stack |
| STX, STY | Store stack pointer to memory |
| TFR R1, R2 | Store index register to memory |
| ABX | Transfer D, X, Y, S, U or PC to D, X, Y, S, U or PC |
| Add B accumulator to X (unsigned) |  |

Table 8 Branch Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| Operation |  |
| BEQ, LBEQ | SIMPLE BRANCHES |
| BNE, LBNE | Branch if equal |
| BMI, LBMI | Branch if not minus |
| BPL, LBPL | Branch if plus |
| BCS, LBCS | Branch if carry set |
| BCC, LBCC | Branch if carry clear |
| BVS, LBVS | Branch if overflow set |
| BVC, LBVC | Branch if overflow clear |
| BGT, LBGT | SIGNED BRANCHES |
| BGE, LBGE | Branch if greater (signed) |
| BEQ, LBEQ | Branch if equal |
| BLE, LBLE | Branch if less than or equal (signed) |
| BLT, LBLT | Branch if less than (signed) |
| BHI, LBHI | UNSIGNED BRANCHES |
| BHS, LBHS | Branch if higher (unsigned) |
| BEQ, LBEQ | Branch if higher or same (unsigned) |
| BLS, LBLS | Branch if equal |
| BLO, LBLO | Branch if lower or same (unsigned) |
| BSR, LBSR | Branch if lower (unsigned) |
| BRA, LBRA | Branch to subroutine |
| BRN, LBRN | Branch never |

Table 9 Miscellaneous Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| ANDCC | AND condition code register |
| CWAI | AND condition code register, then wait for interrupt |
| NOP | No operation |
| ORCC | OR condition code register |
| JMP | Jump |
| JSR | Jump to subroutine |
| RTI | Return from interrupt |
| RTS | Return from subroutine |
| SWI, SWI2, SWI3 | Software interrupt (absolute indirect) |
| SYNC | Synchronize with interrupt line |

Table 10 HD6809 Instruction Set Table

(to be continued)

(to be continued)

(NOTES)
(1) This column gives a base cycle and byte count. To obtain total count, and the values obtained from the INDEXED ADDRESSING MODES table.
(2) R1 and R2 may be any pair of 8 bit or any pair of 16 bit registers.

The 8 bit registers are: $A, B, C C, D P$
The 16 bit registers are: X, Y, U, S, D, PC
(3) EA is the effective address.
(4) The PSH and PUL instructions require 5 cycle plus 1 cycle for each byte pushed or pulled.
5) $5(6)$ means: 5 cycles if branch not taken, 6 cycles if taken.

SWI sets 1 and F bits. SWI2 and SWI3 do not affect I and F.
(7) Conditions Codes set as a direct result of the instruction.
(8) Value of half-carry flag is undefined.
(9) Special Case - Carry set if b7 is SET.
(10) Condition Codes set as a direct result of the instruction if CC is specified, and not affected otherwise.

## LEGEND:

| OP | Operation Code (Hexadecimal) |
| :--- | :--- |
| $\sim$ | Number of MPU Cycles |
| $\#$ | Number of Program Bytes |
| + | Arithmetic Plus |
| $\bar{X}$ | Arithmetic Minus |
| Muitiply |  |
| M | Complement of M |
| $\vec{H}$ | Transfer Into |
| H | Half-carry (from bit 3) |
| N | Negative (sign bit) |


| Z | Zero (byte) |
| :--- | :--- |
| V | Overflow, 2's complement |
| C | Carry from bit 7 |
| $\ddagger$ | Test and set if true, cleared otherwise |
| $\bullet$ | Not Affected |
| CC | Condition Code Register |
| $\vdots$ | Concatenation |
| V | Logical or |
| $\uparrow$ | Logical and |
| $\oplus$ | Logical Exclusive or |

Table 11 Hexadecimal Values of Machine Codes

| OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | 4+ | $2+$ | 60 | NEG | Indexed | $6+$ | 2+ |
| 01 |  | 4 |  |  | 31 | LEAY | 4 | 4+ | $2+$ | 61 |  | A |  |  |
| 02 | * |  |  |  | 32 | LEAS | $\checkmark$ | 4+ | 2+ | 62 | * |  |  |  |
| 03 | COM |  | 6 | 2 | 33 | LEAU | Indexed | 4+ | $2+$ | 63 | COM |  | 6+ | 2+ |
| 04 | LSR |  | 6 | 2 | 34 | PSHS | Implied | 5+ | 2 | 64 | LSR |  | $6+$ | 2+ |
| 05 | * |  |  |  | 35 | PULS | 4 | $5+$ | 2 | 65 | * |  |  |  |
| 06 | ROR |  | 6 | 2 | 36 | PSHU |  | $5+$ | 2 | 66 | ROR |  | $6+$ | 2+ |
| 07 | ASR |  | 6 | 2 | 37 | PULU |  | 5+ | 2 | 67 | ASR |  | $6+$ | $2+$ |
| 08 | ASL, LSL |  | 6 | 2 | 38 | * |  |  |  | 68 | ASL, LSL |  | $6+$ | 2+ |
| 09 | ROL |  | 6 | 2 | 39 | RTS |  | 5 | 1 | 69 | ROL |  | $6+$ | 2+ |
| OA | DEC |  | 6 | 2 | 3A | ABX | $\downarrow$ | 3 | 1 | 6A | DEC |  | $6+$ | $2+$ |
| OB | * |  |  |  | 3B | RTI | Implied | 6,15 | 1 | 6B | * |  |  |  |
| OC | INC |  | 6 | 2 | 3 C | CWAI | Immed | $\geqq 20$ | 2 | 6C | INC |  | 6+ | $2+$ |
| OD | TST |  | 6 | 2 | 3D | MUL | Implied | 11 | 1 | 6D | TST |  | $6+$ | $2+$ |
| OE | JMP | $\dagger$ | 3 | 2 | 3E | * |  |  |  | 6E | JMP |  | $3+$ | $2+$ |
| OF | CLR | Direct | 6 | 2 | 3F | SWI | Implied | 19 | 1 | 6 F | CLR | Indexed | $6+$ | 2+ |
| 10 | See | - | - | - | 40 | NEGA | Implied | 2 | 1 | 70 | NEG | Extended | 7 | 3 |
| 11 | Next Page | - | - | - | 41 | * | 4 |  |  | 71 |  | 4 |  |  |
| 12 | NOP | Implied | 2 | 1 | 42 | * |  |  |  | 72 | * |  |  |  |
| 13 | SYNC | Implied | $\geqq 4$ | 1 | 43 | COMA |  | 2 | 1 | 73 | COM |  | 7 | 3 |
| 14 | * |  |  |  | 44 | LSRA |  | 2 | 1 | 74 | LSR |  | 7 | 3 |
| 15 | * |  |  |  | 45 | * |  |  |  | 75 | * |  |  |  |
| 16 | LBRA | Relative | 5 | 3 | 46 | RORA |  | 2 | 1 | 76 | ROR |  | 7 | 3 |
| 17 | LBSR | Relative | 9 | 3 | 47 | ASRA |  | 2 | 1 | 77 | ASR |  | 7 | 3 |
| 18 | * |  |  |  | 48 | ASLA, LSLA |  | 2 | 1 | 78 | ASL, LSL |  | 7 | 3 |
| 19 | DAA | Implied | 2 | 1 | 49 | ROLA |  | 2 | 1 | 79 | ROL |  | 7 | 3 |
| 1 A | ORCC | Immed | 3 | 2 | 4A | DECA |  | 2 | 1 | 7A | DEC |  | 7 | 3 |
| 1 B | * |  |  |  | 4B | * |  |  |  | 78 | * |  |  |  |
| 1 C | ANDCC | Immed | 3 | 2 | 4C | INCA |  | 2 | 1 | 7C | INC |  | 7 | 3 |
| 1D | SEX | Implied | 2 | 1 | 4D | TSTA |  | 2 | 1 | 7 D | TST |  | 7 | 3 |
| 1E | EXG | $\uparrow$ | 8 | 2 | 4E | * | $\dagger$ |  |  | 7E | JMP |  | 4 | 3 |
| 1 F | TFR | Implied | 6 | 2 | 4F | CLRA | Implied | 2 | 1 | 7F | CLR | Extended | 7 | 3 |
| 20 | BRA | Relative | 3 | 2 | 50 | NEGB | Implied | 2 | 1 | 80 | SUBA | Immed | 2 | 2 |
| 21 | BRN | 4 | 3 | 2 | 51 | * | 4 |  |  | 81 | CMPA | 4 | 2 | 2 |
| 22 | BHI |  | 3 | 2 | 52 | * |  |  |  | 82 | SBCA |  | 2 | 2 |
| 23 | BLS |  | 3 | 2 | 53 | COMB |  | 2 | 1 | 83 | SUBD |  | 4 | 3 |
| 24 | BHS, BCC |  | 3 | 2 | 54 | LSRB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 |
| 25 | BLO, BCS |  | 3 | 2 | 55 | * |  |  |  | 85 | BITA |  | 2 | 2 |
| 26 | BNE |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 86 | LDA |  | 2 | 2 |
| 27 | BEQ |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 87 | * |  |  |  |
| 28 | BVC |  | 3 | 2 | 58 | ASLB, LSLB |  | 2 | 1 | 88 | EORA |  | 2 | 2 |
| 29 | BVS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 89 | ADCA |  | 2 | 2 |
| 2A | BPL |  | 3 | 2 | 5A | DECB |  | 2 | 1 | 8A | ORA |  | 2 | 2 |
| 2 B | BMI |  | 3 | 2 | 5B | * |  |  |  | 8B | ADDA | $\downarrow$ | 2 | 2 |
| 2C | BGE |  | 3 | 2 | 5C | INCB |  | 2 | 1 | 8C | CMPX | Immed | 4 | 3 |
| 2D | BLT |  | 3 | 2 | 5D | TSTB |  | 2 | 1 | 8D | BSR | Relative | 7 | 2 |
| 2E | BGT | 1 | 3 | 2 | 5E | * | $\dagger$ |  |  | 8E | LDX | Immed | 3 | 3 |
| 2F | BLE | Relative | 3 | 2 | 5F | CLRB | Implied | 2 | 1 | 8F | * |  |  |  |

LEGEND:
(to be continued)

[^5]

| OP | Mnem | Mode | $\sim$ | $\#$ |
| :--- | :--- | :---: | :---: | :--- |
| FC | LDD | Extended | 6 | 3 |
| FD | STD |  | 6 | 3 |
| FE | LDU |  | 6 | 3 |
| FF | STU | Extended | 6 | 3 |


| 2 Bytes Opcode |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 1021 | LBRN | Relative | 5 | 4 |
| 1022 | LBHI | 4 | 5(6) | 4 |
| 1023 | LBLS |  | 5(6) | 4 |
| 1024 | LBHS, L | CC | 5(6) | 4 |
| 1025 | LBCS, | LO | 5(6) | 4 |
| 1026 | LBNE |  | 5(6) | 4 |
| 1027 | LBEQ |  | 5(6) | 4 |
| 1028 | LBVC |  | 5(6) | 4 |
| 1029 | LBVS |  | 5(6) | 4 |
| 102A | LBPL |  | 5(6) | 4 |
| 102B | LBMI |  | 5(6) | 4 |
| 102C | LBGE |  | 5(6) | 4 |
| 102D | LBLT |  | 5(6) | 4 |
| 102E | LBGT | $\checkmark$ | 5(6) | 4 |
| 102F | LBLE | Relative | 5(6) | 4 |
| 103F | SWI2 | Implied | 20 | 2 |
| 1083 | CMPD | 1 mmed | 5 | 4 |
| 108C | CMPY | 4 | 5 | 4 |
| 108E | LDY | 1 mmed | 4 | 4 |
| 1093 | CMPD | Direct | 7 | 3 |
| 109C | CMPY | A | 7 | 3 |
| 109E | LDY | $\dagger$ | 6 | 3 |
| 109F | STY | Direct | 6 | 3 |
| 10A3 | CMPD | Indexed | 7+ | 3+ |
| 10AC | CMPY | A | $7+$ | 3+ |
| 10AE | LDY | $\nabla$ | $6+$ | 3+ |
| 10AF | STY | Indexed | $6+$ | $3+$ |
| 10B3 | CMPD | Extended | 8 | 4 |
| 10BC | CMPY | 4 | 8 | 4 |
| 10BE | LDY |  | 7 | 4 |
| 10BF | STY | Extended | 7 | 4 |
| 10CE | LDS | 1 mmed | 4 | 4 |
| 10DE | LDS | Direct | 6 | 3 |
| 10DF | STS | Direct | 6 | 3 |
| 10EE | LDS | Indexed | $6+$ | $3+$ |
| 10EF | STS | Indexed | 6+ | $3+$ |
| 10FE | LDS | Extended | 7 | 4 |
| 10FF | STS | Extended | 7 | 4 |
| 113F | SWI3 | Implied | 20 | 2 |
| 1183 | CMPU | Immed | 5 | 4 |
| 118C | CMPS | Immed | 5 | 4 |
| 1193 | CMPU | Direct | 7 | 3 |
| 119C | CMPS | Direct | 7 | 3 |
| 11A3 | CMPU | Indexed | 7+ | 3+ |
| 11AC | CMPS | Indexed | 7+ | $3+$ |
| 11 B 3 | CMPU | Extended | 8 | 4 |
| 11BC | CMPS | Extended | 8 | 4 |

(NOTE): All unused opcodes are both undefined and illegal

- NOTE FOR USE
[1] Exceptional Operation of HD6809
(a) Exceptional Operations of DMA/BREQ, BA signals (\#1)

HD6809 acknowledges the input signal level of DMA/BREQ at the end of each cycle, then determines whether the next sequence is MPU or DMA. When "Low" level is detected, HD6809 executes DMA
sequence by setting BA, BS to "High" level. However, in the conditions shown below the assertion of BA, BS delays one clock cycle.
<Conditions for the exception >
(1) $\overline{\text { DMA/BREQ }}:$ "Low" for $6 \sim 13$ cycles
(2) DMA/BREQ : "High" for 3 cycles

(b) Exceptional Operations of DMA/BREQ, BA signals (\#2)

HD6809 includes a self refresh counter for the re-
verce cycle steal. And it is only cleare if $\overline{\text { DMA/BREQ }}$ is inactive ("High") for 3 or more MPU cycles. So 1 or 2 inactive cycle(s) doesn't affect the self refresh counter.


Figure 22 Exception of DMA/BREO
(c) How to avoid these exceptional operations

It is necessary to provide 4 or more cycles for in-


Figure 23 How to Avoid Exceptional Operations
[2] Restriction for DMA Transfer
There is a restriction for the DMA transfer in the HD6809 (MPU), HD6844 (DMAC) system. Please take care of following.
(a) An Example of the System Configuration This restriction is applied to the following system.
(1) DMA/BREQ is used for DMA request.
(2) "Halt Burst Mode" is used for DMA transfer


Figure 24 An Example of HD6809, HD6844 System
(The restriction is also applied to the system which doesn't use 7474 Flip-Flop. Fig. 24, Fig. 25 shows an example which uses 7474 for synchronizing DMA request with E.
(b) Restriction
"The number of transfer Byte per one DMA Burst transfer must be less than or equal to 14 ."

Halt burst DMA transfer should be less than or equal to 14 cycles. In another word, the number stored into DMA Byte count register should be $0 \sim 14$.
$\star$ Please than care of the section [1](b) if 2 or more DMA channels are used for the DMA transfer.
(c) Incorrect operation of HD6809, HD6844 system
"Incorrect Operation" will occur if the number of DMA transfer Byte is more than 14 bytes. If DMA/ $\overline{\text { BREQ is kept in "Low" level HD6809 performs }}$
reverse cycle steals once in 14 DMA cycles by taking back the bus control. In this case, however, the action taken by MPU is a little bit different from the DMAC.

As shown in Fig. 25, DMA controller can't stop DMA transfer (©A)) by BA falling edge and excutes an extra DMA cycle during HD6809 dead cycle. So MPU cycle is excuted right after DMA cycle, the Bus confliction occurs at the beginning of MPU cycle.
(d) How to impliment Halt Bust DMA transfer ( $>14$ cycles)

Please use HALT input of HD6809 for the DMA request instead of DMA/BREQ.


Figure 25 Comparison of HD6809, HD6844 DMA cycles
[3] Note for CLR Instruction
Cycle-by-cycle flow of CLR instruction (Direct, Extended, Indexed Addressing Mode) is shown below. In this sequence the content of the memory location specified by the operand is read before writing " 00 " into it. Note that status Flags, such as IRQ Flag, will be cleared by this extra data read operation when accessing the control/status register (sharing the same address between read and write) of peripheral devices.

| Example: CLR (Extended) |  |  |  |  |
| :---: | :---: | :---: | :---: | :--- |
| $\$ 8000$ | CLR | $\$ A 000$ |  |  |
| $\$ A 000$ | FCB | $\$ 80$ |  |  |
| Cycle \# Address Data R/ $\bar{W}$ <br> 1 8000 7 F 1Description <br> 2 | 8001 | A0 | 1 | Opcode Fetch <br> Operand Address, <br> High Byte |
| 3 | 8002 | 00 | 1 | Operand Address, <br> Low Byte |
| 4 |  |  |  | 1 | | VMA Cycle |
| :--- |
| 5 |

* The data bus has the data at that particular address.


## [4] Note for MRDY

HD6809 require synchronization of the MRDY input with the 4 f clock. The synchronization necessitates an external oscillator as shown in Figure 26. The negative transition of the

MRDY signal, normally derived from the chip select decoding, must meet the tPCS timing. MRDY's positive transition must occur with the rising edge of $4 f$.


Figure $\mathbf{2 6}$ MRDY Synchronization

# HD6809E,HD68A09E, HD68B09E MPU(Micro Processing Unit) 

The HD6809E is a revolutionary high performance 8 -bit microprocessor which supports modern programming techniques such as position independence, reentrancy, and modular programming.

This third-generation addition to the HMCS6800 family has major architectural improvements which include additional registers, instructions and addressing modes.

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The HD6809E has the most complete set of addressing modes available on any 8 -bit microprocessor today.

The HD6809E has hardware and software features which make it an ideal processor for higher level language execution or standard controller applications. External clock inputs are provided to allow synchronization with peripherals, systems or other MPUs.

## HD6800 COMPATIBLE

- Hardware - Interfaces with All HMCS6800 Peripherals
- Software - Upward Source Code Compatible Instruction Set and Addressing Modes


## - ARCHITECTURAL FEATURES

- Two 16-bit Index Registers
- Two 16-bit Indexable Stack Pointers
- Two 8-bit Accumulators can be Concatenated to Form One 16-Bit Accumulator
- Direct Page Register Allows Direct Addressing Throughout Memory
- HARDWARE FEATURES
- External Clock Inputs, E and Q, Allow Synchronization
- TSC Input Controls Internal Bus Buffers
- LIC Indicates Opcode Fetch
- AVMA Allows Efficient Use of Common Resources in A Multiprocessor System
- BUSY is a Status Line for Multiprocessing
- Fast Interrupt Request Input Stacks Only Condition Code Register and Program Counter
- Interrupt Acknowledge Output Allows Vectoring By Devices
- SYNC Acknowledge Output Allows for Synchronization to External Event
- Single Bus-Cycle RESET
- Single 5-Volt Supply Operation
- NMI Blocked After RESET Until After First Load of Stack Pointer
- Early Address Valid Allows Use With Slower Memories
- Early Write-Data for Dynamic Memories
- SOFTWARE FEATURES
- 10 Addressing Modes
- HMCS6800 Upward Compatible Addressing Modes
- Direct Addressing Anywhere in Memory Map
- Long Relative Branches
- Program Counter Relative
- True Indirect Addressing
- Expanded Indexed Addressing:

0,5,8, or 16 -bit Constant Offsets
8, or 16-bit Accumulator Offsets


Auto-Increment/Decrement by 1 or 2

- Improved Stack Manipulation
- 1464 Instruction with Unique Addressing Modes
- $8 \times 8$ Unsigned Multiply
- 16-bit Arithmetic
- Transfer/Exchange All Registers
- Push/Pull Any Registers or Any Set of Registers
- Load Effective Address


## - PIN ARRANGEMENT

| $\mathrm{vss}^{1} 0$ | O | 4 ACHALT |
| :---: | :---: | :---: |
| NMI 2 |  | $3{ }^{3}$ TSC |
| 1R0 ${ }^{1}$ |  | 38 lic |
| FIRO4 |  | 37 TES |
| 85 |  | 36 avma |
| BA6 |  | 3 3 |
| $\mathrm{Vcc}^{\text {[7] }}$ |  | 34 E |
| $A_{0} 8$ |  | 33 busy |
| $A_{1} 9$ |  | $32 \mathrm{R} / \mathrm{W}$ |
| $A_{2} 10$ |  | $3 \mathrm{D}^{\text {d }}$ |
| $A, 11$ |  | $30 \mathrm{D}_{1}$ |
| A. 12 |  | 29 D |
| As 13 |  | 28 D , |
| A. 11 |  | 27 D . |
| A, 15 |  | 26 D |
| A. 16 |  | 25 D , |
| A, 17 |  | 24 D |
| $A_{10} 18$ |  | 23 A, |
| $A_{11} 19$ |  | $2 A_{14}$ |
| $A_{12} 20$ |  | 21 $A_{13}$ |
|  | (Top View |  |

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :--- | :---: | :---: |
| Supply Voltage | Vcc* | $-0.3 \sim+7.0$ | V |
| Input Voltage | Vin* | $-0.3 \sim+7.0$ | V |
| Operating Temperature Range | Topr | $-20 \sim+75$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | Tstg | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

* With respect to Vss (SYSTEM GND)
(NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.
- RECOMMENDED OPERATING CONDITIONS

| Item |  | Symbol | min | typ | max | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage |  | Vcc* | 4.75 | 5.0 | 5.25 | V |
| Input Voltage | Logic, Q, $\overline{\mathrm{RES}}$ | VIL* | -0.2 | - | 0.8 | V |
|  | E | VILC* | -0.3 | - | 0.4 | V |
|  | Logic | Vı ${ }^{*}$ | 2.2 | - | Vcc* | V |
|  | $\overline{\text { RES }}$ |  | 4.0 | - | Vcc* | V |
|  | E | Vinc* | Vcc* -0.75 | - | Vcc* ${ }^{\text {+ }}$. 3 | V |
| Operating Temperature |  | Topr | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

* With respect to Vss (SYSTEM GND)


## - ELECTRICAL CHARACTERISTICS



| Item |  | Symbol | Test Condition | HD6809E |  |  | HD68A09E |  |  | HD68B09E |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ ${ }^{\text {+ }}$ | max | min | typ ${ }^{\text {c }}$ | max | min | typ ${ }^{\text {c }}$ | max |  |
| Input "High" Voltage | Logic, 0 |  | VIH |  | 2.2 | - | Vcc | 2.2 | - | Vce | 2.2 | - | Vce | v |
|  | RES | Vihr |  | 4.0 | - | Vcc | 4.0 | - | Vcc | 4.0 | - | Vec | v |
|  | E | VIHC |  | $\begin{array}{\|l\|} \hline \mathrm{Vcc} \\ -0.75 \\ \hline \end{array}$ | - | $\begin{gathered} \mathrm{Vcc} \\ +0.3 \end{gathered}$ | $\begin{aligned} & \mathrm{Vcc} \\ & -0.75 \end{aligned}$ | - | $\begin{aligned} & \mathrm{Vcc} \\ & +0.3 \end{aligned}$ | $\left\|\begin{array}{c} \mathrm{Vcc} \\ -0.75 \end{array}\right\|$ | - | $\begin{aligned} & \mathrm{Vcc} \\ & +0.3 \end{aligned}$ | V |
| Input "Low" Voltage | Logic, Q, $\overline{\text { RES }}$ | VIL |  | -0.2 | - | 0.8 | -0.2 | - | 0.8 | -0.2 | - | 0.8 | v |
|  | E | VILC |  | -0.3 | - | 0.4 | -0.3 | - | 0.4 | -0.3 | - | 0.4 | $v$ |
| Input Leakage Current | Logic, Q, $\overline{\text { EES }}$ | lin | $\begin{aligned} & V \text { in }=0 \sim 5.25 \mathrm{~V}, \\ & \mathrm{Vcc}=\max \end{aligned}$ | -2.5 | - | 2.5 | -2.5 | - | 2.5 | -2.5 | - | 2.5 | $\mu \mathrm{A}$ |
|  | E |  |  | -100 | - | 100 | $-100$ | - | 100 | $-100$ | - | 100 | $\mu \mathrm{A}$ |
| Output "High" Voltage | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | VOH | $I_{\text {Load }}=-205 \mu \mathrm{~A}$, $\mathrm{Vcc}=\mathrm{min}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | v |
|  | $A_{0} \sim A_{15}, R / \bar{W}$ |  | $I_{\text {Load }}=-145 \mu A$, Vcc $=\min$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
|  | BA, BS, LIC, AVMA, BUS'Y |  | $\begin{aligned} & \begin{array}{l} \text { LLoad }=-100 \mu \mathrm{~A}, \\ \text { Vcc }=\min \end{array} \end{aligned}$ | 2.4 | - | - | 2.4 | - | - | 2.4 | - | - | V |
| Output "Low" Voltage |  | Vol | $\begin{aligned} & I_{\text {Load }}=2 \mathrm{~mA}, \\ & V c c=\min \end{aligned}$ | - | - | 0.5 | - | - | 0.5 | - | - | 0.5 | V |
| Power Dissipation |  | PD |  | - | - | 1.0 | - | - | 1.0 | - | - | 1.0 | w |
| Input Capacitance | $D_{0} \sim D_{7}$, Logic Input, Q, RES | Cin | $\begin{aligned} & V i n=0 V \\ & T a=25^{\circ} \\ & f=1 \mathrm{CHz} \end{aligned}$ | - | 10 | 15 | - | 10 | 15 | - | 10 | 15 | pF |
|  | E |  |  | - | 30 | 50 | - | 30 | 50 | - | 30 | 50 | pF |
| Output Capacitance | $A_{0} \sim A_{1 S}, R / \bar{W}$, BA, BS, LIC, AVMA, BUSY | Cout | $\begin{aligned} & \operatorname{Vin}=0 \mathrm{~V}, \\ & \mathrm{Ta}=25^{\circ} \mathrm{C}, \\ & \mathbf{f}=1 \mathrm{MHz} \end{aligned}$ | - | 10 | 15 | - | 10 | 15 | - | 10 | 15 | pF |
| Frequency of Operation | E, O | $f$ |  | 0.1 | - | 1.0 | 0.1 | - | 1.5 | 0.1 | - | 2.0 | MHz |
| Three-State (Off State) Input Current | $D_{0} \sim D_{7}$ | \|tsi | $\begin{aligned} & V_{\text {in }}=0.4 \sim 2.4 \mathrm{~V}, \\ & V c c=\max \end{aligned}$ | -10 | - | 10 | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
|  | $A_{0} \sim A_{1 s}, R / W$ |  |  | -100 | - | 100 | -100 | - | 100 | -100 | - | 100 | $\mu \mathrm{A}$ |

[^6]- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.) READ/WRITE TIMING

* AVMA drives a not-valid data before providing correct output, so spec tcD max $=270 \mathrm{nsec}$ (HD68A09E) and 240 nsec (HD68B09E) are applied to this signal. When this delay time causes a problem in user's application, please use D-type latch to get stable output.


* Hold time for BA, BS not specified
(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H m i n}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure 1 Read Data from Memory or Peripherals

- Hold time for BA, BS not specified
(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{\text {IHmin }}$ and logic "Low" = $V_{\text {ILmax }}$ unless otherwise specified.
Figure 2 Write Data to Memory or Peripherals


Figure 3 HD6809E Expanded Block Diagram


C $=30 \mathrm{pF}$ for BA, BS, LIC, AVMA, BUSY
130 pF for $D_{0} \sim D_{7}$
90 pF for $A_{0} \sim A_{15}, R / \bar{W}$
$R=11.7 \mathrm{k} \Omega$ for $D_{0} \sim D_{7}$
$16.5 \mathrm{k} \Omega$ for $A_{0} \sim A_{15}, R / W$
$24 \mathrm{k} \Omega$ for BA, BS , LIC, AVMA, BUSY

All diodes are 1S2074 $(H)$ or equivalent. C includes stray capacitance.

Figure 4 Bus Timing Test Load

PROGRAMMING MODEL
As shown in Figure 5, the HD6809E adds three registers to the set available in the HD6800. The added registers include a Direct Page Register, the User Stack pointer and a second Index Register.

- Accumulators (A, B, D)

The $\mathbf{A}$ and $\mathbf{B}$ registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data.

Certain instructions concatenate the A and B registers to form a single 16 -bit accumulator. This is referred to as the D Register, and is formed with the A Register as the most significant byte.

- Direct Page Register (DP)

The Direct Page Register of the HD6809E serves to enhance the Direct Addressing Mode. The content of this register appears at the higher address outputs $\left(\mathrm{A}_{8} \sim \mathrm{~A}_{15}\right)$ during direct addressing instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure HD6800 compatibility, all bits of this register are cleared during Processor Reset.


Figure 5 Programming Model of The Microprocessing Unit

- Index Registers (X, Y)

The Index Registers are used in indexed mode of addressing. The 16-bit address in this register takes part in the calculation of effective addresses. This address may be used to point to data directly or may be modified by an optional constant or register offset. During some indexed modes, the contents of the index register are incremented or decremented to point to the next item of tabular type data. All four pointer registers ( $\mathrm{X}, \mathrm{Y}, \mathrm{U}, \mathrm{S}$ ) may be used as index registers.

## - Stack Pointer (U, S)

The Hardware Stack Pointer (S) is used automatically by the processor during subroutine calls and interrupts. The User Stack Pointer (U) is controlled exclusively by the programmer thus allowing arguments to be passed to and from subroutines with ease. The U-register is frequently used as a stack marker. Both Stack Pointers have the same indexed mode addressing capabilities as the X and Y registers, but also support Push and Pull instructions. This allows the HD6809E to be used efficiently as a stack processor, greatly enhancing its ability to support higher level languages and modular programming.
(NOTE) The stack pointers of the HD6809E point to the top of the stack, in contrast to the HD6800 stack pointer, which pointed to the next free location on stack.

## - Program Counter (PC)

The Program Counter is used by the processor to point to the address of the next instruction to be executed by the processor. Relative Addressing is provided allowing the Program Counter to be used like an index register in some situations.

## - Condition Code Register (CC)

The Condition Code Register defines the state of the processor at any given time. See Figure 6.


Figure 6 Condition Code Register Format

## ■ CONDITION CODE REGISTER DESCRIPTION

- Bit 0 (C)

Bit 0 is the carry flag, and is usually the carry from the binary ALU. C is also used to represent a 'borrow' from subtract like instructions (CMP, NEG, SUB, SBC) and is the complement of the carry from the binary ALU.

- Bit 1 (V)

Bit 1 is the overflow flag, and is set to a one by an operation which causes a signed two's complement arithmetic overflow. This overflow is detected in an operation in which the carry from the MSB in the ALU does not match the carry from the MSB-1.

- Bit $2(Z)$

Bit 2 is the zero flag, and is set to a one if the result of the previous operation was identically zero.

## - Bit 3 (N)

Bit 3 is the negative flag, which contains exactly the value of the MSB of the result of the preceding operation. Thus, a negative two's-complement result will leave N set to a one.

## - Bit 4 (I)

Bit 4 is the IRQ mask bit. The processor will not recognize interrupts from the IRQ line if this bit is set to a one. NMI, $\overline{F I R Q}, \overline{I R Q}, \overline{R E S}$ and SWI all set I to a one; SWI2 and SWI3 do not affect $I$.

## - Bit 5 (H)

Bit 5 is the half-carry bit, and is used to indicate a carry from bit 3 in the ALU as a result of an 8 -bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is undefined in all subtract-like instructions.

## - Bit 6 (F)

Bit 6 is the $\overline{\text { FIRQ }}$ mask bit. The processor will not recognize interrupts from the FIRQ line if this bit is a one. $\overline{\text { NMI, }}$, FIRQ, SWI, and $\overline{\text { RES }}$ all set $F$ to a one. $\overline{\mathrm{IRQ}}$, SWI2 and SWI3 do not affect F .

- Bit 7 (E)

Bit 7 is the entire flag, and when set to a one indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current E left in the Condition Code Register represents past action.

## - HD6809E MPU SIGNAL DESCRIPTION

- Power (Vss, Vcc)

Two pins are used to supply power to the part: Vss is ground or 0 volts, while Vcc is $+5.0 \mathrm{~V} \pm 5 \%$.

## - Address Bus $\left(A_{0} \sim A_{15}\right)$

Sixteen pins are used to output address information from the MPU onto the Address Bus. When the processor does not require the bus for a data transfer, it will output address $\mathrm{FFFF}_{16}, \mathrm{R} / \overline{\mathrm{W}}=$ "High", and BS = "Low"; this is a "dummy access" or VMA cycle. All address bus drivers are made highimpedance when output Bus Available (BA) is "High" or when TSC is asserted. Each pin will drive one Schottky TTL load or four LS TTL loads, and 90 pF . Refer to Figures 1 and 2.

- Data Bus $\left(D_{0} \sim D_{7}\right)$

These eight pins provide communication with the system bi-directional data bus. Each pin will drive one Schottky TTL load or four LS TTL loads, and 130 pF .

## - Read/Write (R/W)

This signal indicates the direction of data transfer on the data bus. A "Low" indicates that the MPU is writing data onto the data bus. $R / \bar{W}$ is made high impedance when BA is "High" or when TSC is asserted. Refer to Figures 1 and 2.

## - $\overline{\operatorname{RES}}$

A "Low" level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in Figure 7. The Reset vectors are fetched from locations FFFE $_{16}$ and FFFF $_{16}$ (Table 1) when Interrupt Acknowledge is true, ( $\overline{\mathrm{BA}} \cdot \mathrm{BS}=1$ ). During initial power-on, the Reset line should be held "Low" until the clock input signals are fully operational.

Because the HD6809E Reset pin has a Schmitt-trigger input with a threshold voltage higher than that of standard peripherals, a simple R/C network may be used to reset the entire system.

This higher threshold voltage ensures that all peripherals are out of the reset state before the Processor.

Table 1 Memory Map for Interrupt Vectors

| Memory Map for Vector <br> Locations |  | Interrupt Vector <br> Description |
| :---: | :---: | :---: |
| MS | LS |  |
| FFFE | FFFF | $\overline{\text { NMI }}$ |
| FFFC | FFFD | SWI |
| FFFA | FFFB | $\overline{\text { IRO }}$ |
| FFF8 | FFF9 | $\overline{\text { FIRO }}$ |
| FFF6 | FFF7 | SWI2 |
| FFF4 | FFF5 | SWI3 |
| FFF2 | FFF3 | Reserved |

- HALT

A "Low" level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven "High" indicating the buses are high impedance. BS is also "High" which indicates the processor is in the Halt state. While halted, the MPU will not respond to external real-time requests (FIRQ, $\overline{\text { IRQ }}$ ) although $\overline{\text { NMI }}$ or $\overline{\text { RES }}$ will be latched for later response. During the Halt state $Q$ and $E$ should continue to run normally. A halted state (BA $\cdot \mathrm{BS}=1$ ) can be achieved by pulling $\overline{\text { HALT }}$ "Low" while $\overline{\text { RES }}$ is still "Low". See Figure 8.

## - Bus Available, Bus Status (BA, BS)

The Bus Available output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. When BA goes "Low", a dead cycle will elapse before the MPU acquires the bus. BA will not be asserted when TSC is active, thus allowing dead cycle consistency.

The Bus Status output signal, when decoded with BA, represents the MPU state (valid with leading edge of $\mathbf{Q}$ ).

| MPU State |  |  |
| :--- | :---: | :--- |
| BA | BS |  |
| 0 | 0 |  |
| 0 | 1 |  |
| 1 | 0 | Normal (Running) State Definition |
| 1 | 1 | SYNC Acrupt or RESET Acknowledge |
| 1 | HALT Acknowledge |  |

Interrupt Acknowledge is indicated during both cycles of a hardware-vector-fetch (RES, NMI, FIRQ, IRQ, SWI, SWI2, SWI3). This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 1.

Sync Acknowledge is indicated while the MPU is waiting for external synchronization on an interrupt line.

Halt Acknowledge is indicated when the HD6809E is in a Halt condition.

（NOTE）Waveform measurements for all inputs and outputs are specified at logic＂High＂$=V_{\text {IHmin }}$ and logic＂Low＂$=V_{\text {ILmax }}$ unless otherwise specified．

Figure 7 RES Timing

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{\text {IHmin }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure 8 HALT and Single Instruction Execution for System Debug

## - Non Maskable Interrupt (NMI)*

A negative transition on this input requests that a nonmaskable interrupt sequence be generated. A non-maskable interrupt cannot be inhibited by the program, and also has a higher priority than $\overline{\text { FIRQ }}, \overline{\mathrm{IRQ}}$ or software interrupts. During recognition of an $\overline{\text { NMI }}$, the entire machine state is saved on the hardware stack. After reset, an NMI will not be recognized until the first program load of the Hardware Stack Pointer (S). The pulse width of NMI low must be at least one E cycle. If the NMI input does not meet the minimum set up with respect to Q , the interrupt will not be recognized until the next cycle. See Figure 9.

## - Fast-Interrupt Request (FIRQ)*

A "Low" level on this input pin will initiate a fast interrupt sequence, provided its mask bit ( F ) in the CC is clear. This sequence has priority over the standard Interrupt Request (IRQ), and is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 10.

## - Interrupt Request (IRO)*

A "Low" level input on this pin will initiate an Interrupt Request sequence provided the mask bit (I) in the CC is clear. Since IRQ stacks the entire machine state it provides a slower response to interrupts than FIRQ. IRQ also has a lower priority than FIRQ. Again, the interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 9.

* $\overline{\mathrm{NMI}}, \overline{\mathrm{FIRQ}}$, and $\overline{\mathrm{IRQ}}$ requests are sampled on the falling edge of Q . One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. If $\overline{\text { IRQ }}$ and FIRQ do not remain "Low" until completion of the current instruction they may not be recognized. However, $\overline{\text { NMI }}$ is latched and need only remain "Low" for one cycle.


## - Clock Inputs E, Q

E and Q are the clock signals required by the HD6809E. Q must lead E ; that is, a transition on Q must be followed by a similar transition on E after a minimum delay. Addresses will be valid from the MPU, $\mathrm{t}_{\mathrm{AD}}$ after the falling edge of E , and data will be latched from the bus by the falling edge of E . While the $\mathbf{Q}$ input is fully TTL compatible, the E input directly drives internal MOS circuitry and, thus, requires levels above normal TTL levels. This approach minimizes clock skew inherent with an internal buffer. Timing and waveforms for E and Q are shown in Figures 1 and 2 while Figure 11 shows a simple clock generator for the HD6809E.

## - BUSY

Busy will be "High" for the read and modify cycles of a read-modify-write instruction and during the access of the first byte
of a double-byte operation (e.g., LDX, STD, ADDD). Busy is also "High" during the first byte of any indirect or other vector fetch (e.g., jump extended, SWI indirect etc.).

In a multi-processor system, busy indicates the need to defer the rearbitration of the next bus cycle to insure the integrity of the above operations. This difference provides the indivisible memory access required for a "test-and-set" primitive, using any one of several read-modify-write instructions.

Busy does not become active during PSH or PUL operations. A typical read-modify-write instruction (ASL) is shown in Figure 12. Timing information is given in Figure 13. Busy is valid $t_{C D}$ after the rising edge of $Q$.

## - AVMA

AVMA is the Advanced VMA signal and indicates that the MPU will use the bus in the following bus cycle. The predictive nature of the AVMA signal allows efficient shared-bus multiprocessor systems. AVMA is "Low" when the MPU is in either a HALT or SYNC state. AVMA is valid $\mathrm{t}_{\mathrm{CD}}$ after the rising edge of Q .

## - LIC

LIC (Last Instruction Cycle) is "High" during the last cycle of every instruction, and its transition from "High" to "Low" will indicate that the first byte of an opcode will be latched at the end of the present bus cycle. LIC will be "High" when the MPU is Halted at the end of an instruction, (i.e., not in CWAI or RESET) in SYNC state or while stacking during interrupts. LIC is valid $t_{C D}$ after the rising edge of $Q$.

- TSC

TSC (Three-State Control) will cause MOS address, data, and $R / \overline{\mathrm{W}}$ buffers to assume a high-impedance state. The control signals (BA, BS, BUSY, AVMA and LIC) will not go to the high-impedance state. TSC is intended to allow a single bus to be shared with other bus masters (processors or DMA controllers).

While E is "Low", TSC controls the address buffers and R/信 directly. The data bus buffers during a write operation are in a high-impedance state until Q rises at which time, if TSC is true, they will remain in a high-impedance state. If TSC is held beyond the rising edge of E , then it will be internally latched, keeping the bus drivers in a high-impedance state for the remainder of the bus cycle. See Figure 14.

## - MPU Operation

During normal operation, the MPU fetches an instruction from memory and then executes the requested function. This sequence begins after $\overline{\text { RES }}$ and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Software instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI and SYNC. An interrupt or HALT input can also alter the normal execution of instructions. Figure 15 illustrates the flow chart for the HD6809E.


NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H m i n}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified. E clock shown for reference only

Figure $9 \overline{\text { IRO }}$ and $\overline{\text { NMI }}$ Interrupt Timing

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \text { min }}$ and logic "Low" $=V_{1 L m a x}$ unless otherwise specified. E clock shown for reference only.

Figure 10 FIRQ Interrupt Timing


NOTE: If optional circuit is not included the CLR and PRE inputs of U2 and U3 must be tied high.


Figure 12 Read Modify Write Instruction Example (ASL Extended Indirect)

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H m i n}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure 13 BUSY Timing (ASL Extended Indirect Instruction)

(NOTES) Data will be asserted by the MPU only during the interval while R/W is "Low" and $\mathbf{E}$ or $\mathbf{Q}$ is "High"
Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \min }$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure 14 TSC Timing


FIRD. F


Figure 15 Flowchart for HD6809E Instruction

## - ADDRESSING MODES

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The HD6809E has the most complete set of addressing modes available on any microcomputer today. For example, the HD6809E has 59 basic instructions; however, it recognizes 1464 different variations of instructions and addressing modes. The addressing modes support modern programming techniques. The following addressing modes are available on the HD6809E:
(1) Implied (Includes Accumulator)
(2) Immediate
(3) Extended
(4) Extended Indirect
(5) Direct
(6) Register
(7) Indexed

Zero-Offset
Constant Offset
Accumulator Offset
Auto Increment/Decrement
(8) Indexed Indirect
(9) Relative
(10) Program Counter Relative

## - Implied (Includes Accumulator)

In this addressing mode, the opcode of the instruction contains all the address information necessary. Examples of Implied Addressing are: ABX, DAA, SWI, ASRA, and CLRB.

## - Immediate Addressing

In Immediate Addressing, the effective address of the data is the location immediately following the opcode (i.e., the data to be used in the instruction immediately follows the opcode of the instruction). The HD6809E uses both 8 and 16 -bit immediate values depending on the size of argument specified by the opcode. Examples of instructions with immediate Addressing are:

```
LDA #$20
LDX #$F000
LDY #CAT
```

(NOTE) \# signifies immediate addressing, \$ signifies hexadecimal value.

## - Extended Addressing

In Extended Addressing, the contents of the two bytes immediately following the opcode fully specify the 16 -bit effective address used by the instruction. Note that the address generated by an extended instruction defines an absolute address and is not position independent. Examples of Extended Addressing include:

```
LDA CAT
STX MOUSE
LDD $2000
```


## - Extended Indirect

As a special case of indexed addressing (discussed below), one level of indirection may be added to Extended Addressing. In Extended Indirect, the two bytes following the postbyte of an Indexed instruction contain the address of the data.

| LDA | [CAT] |
| :--- | :--- |
| LDX | $[\$ F F F E]$ |
| STU | $[D O G]$ |

## - Direct Addressing

Direct addressing is similar to extended addressing except that only one byte of address follows the opcode. This byte specifies the lower 8 bits of the address to be used. The upper 8 bits of the address are supplied by the direct page register. Since only one byte of address is required in direct addressing, this mode requires less memory and executes faster than extended addressing. Of course, only 256 locations (one page) can be accessed without redefining the contents of the DP register. Since the DP register is set to $\$ 00$ on Reset, direct addressing on the HD6809E is compatible with direct addressing on the HD6800. Indirection is not allowed in direct addressing. Some examples of direct addressing are:

| LDA | $\$ 30$ |  |
| :--- | :--- | :--- |
| SETDP | $\$ 10$ | (Assembler directive) |
| LDB | $\$ 1030$ |  |
| LDD | <CAT |  |

(NOTE) $<$ is an assembler directive which forces direct addressing.

## - Register Addressing

Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction. This is called a postbyte. Some examples of register addressing are:

| TFR | X, Y | Transfer X into Y |
| :--- | :--- | :--- |
| EXG | A, B | Exchanges A with B |
| PSHS | A, B, X, Y | Push Y, X, B and A onto S |
| PULU | X, Y, D | Pull D, X, and Y from U |

## - Indexed Addressing

In all indexed addressing, one of the pointer registers ( $\mathbf{X}, \mathbf{Y}$, $\mathrm{U}, \mathrm{S}$, and sometimes PC) is used in a calculation of the effective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode as well as the pointer register to be used. Figure 16 lists the legal formats for the postbyte. Table 2 gives the assembler form and the number of cycles and bytes added to the basic values for indexed addressing for each variation.


Figure 16 Index Addressing Postbyte Register Bit Assignments

Table 2 Indexed Addressing Mode

| Type | Forms | Non Indirect |  |  |  | Indirect |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Assembler Form | Postbyte OP Code | $\begin{array}{\|c\|} \hline+ \\ \sim \end{array}$ | $\begin{array}{\|l} + \\ \# \\ \hline \end{array}$ | Assembler Form | Postbyte OP Code | $\pm$ | + |
| Constant Offset From R (2's Complement Offsets) | No Offset | , R | 1RR00100 | 0 | 0 | [,R] | 1RR10100 | 3 | 0 |
|  | 5 Bit Offset | n, R | ORRnnnnn | 1 | 0 | defaults to 8-bit |  |  |  |
|  | 8 Bit Offset | n, R | 1RR01000 | 1 | 1 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11000 | 4 | 1 |
|  | 16 Bit Offset | $n, R$ | 1RR01001 | 4 | 2 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11001 | 7 | 2 |
| Accumulator Offset From R (2's Complement Offsets) | A Register Offset | A, R | 1RR00110 | 1 | 0 | [ $A, R$ ] | 1RR10110 | 4 | 0 |
|  | B Register Offset | B, R | 1RR00101 | 1 | 0 | [B, R] | 1RR10101 | 4 | 0 |
|  | D Register Offset | D, R | 1RR01011 | 4 | 0 | [D, R] | 1RR11011 | 7 | 0 |
| Auto Increment/Decrement R | Increment By 1 | , R + | 1RR00000 | 2 | 0 | not allowed |  |  |  |
|  | Increment By 2 | , R + + | 1RR00001 | 3 | 0 | [, R + + ] | 1RR10001 | 6 | 0 |
|  | Decrement By 1 | , -R | 1 RR00010 | 2 | 0 | not allowed |  |  |  |
|  | Decrement By 2 | . --R | 1 RR00011 | 3 | 0 | [, - - R] | 1RR10011 | 6 | 0 |
| Constant Offset From PC (2's Complement Offsets) | 8 Bit Offset | n, PCR | 1xx01100 | 1 | 1 | [ $\mathrm{n}, \mathrm{PCR}$ ] | 1xx11100 | 4 | 1 |
|  | 16 Bit Offset | n, PCR | 1×x01101 | 5 | 2 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11101$ | 8 | 2 |
| Extended Indirect | 16 Bit Address | - | - | - | - | [ n ] | 10011111 | 5 | 2 |

$$
\begin{array}{lr}
R=X, Y, U \text { or } S & R R: \\
x=\text { Don't Care } & 00=X \\
& 01=Y \\
& 10=U \\
& 11=S
\end{array}
$$

$\underset{\sim}{ }{ }^{+}{ }^{\text {and }}{ }^{+}$indicate the number of additional cycles and bytes for the particular variation.

## Zero-Offset Indexed

In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode.

Examples are:

$$
\begin{array}{ll}
\text { LDD } & 0, \mathrm{X} \\
\text { LDA } & \mathbf{S}
\end{array}
$$

## Constant Offset Indexed

In this mode, a two's-complement offset and the contents of one of the pointer registers are added to form the effective address of the operand. The pointer register's initial content is unchanged by the addition.

Three sizes of offsets are available:

$$
\begin{aligned}
& \text { 5-bit }(-16 \text { to }+15) \\
& 8 \text {-bit }(-128 \text { to }+127) \\
& \text { 16-bit }(-32768 \text { to }+32767)
\end{aligned}
$$

The two's complement 5 -bit offset is included in the postbyte and, therefore, is most efficient in use of bytes and cycles. The two's complement 8 -bit offset is contained in a single byte following the postbyte. The two's complement 16 -bit offset is in the two bytes following the postbyte. In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically.

Examples of constant-offset indexing are:

$$
\begin{array}{ll}
\text { LDA } & 23, \mathrm{X} \\
\text { LDX } & -2, \mathrm{~S}
\end{array}
$$

| LDY | $300, \mathrm{X}$ |
| :--- | :--- |
| LDU | CAT, Y |

## Accumulator-Offset Indexed

This mode is similar to constant offset indexed except that the two's-complement value in one of the accumulators (A, B or D ) and the contents of one of the pointer registers are added to form the effective address of the operand. The contents of both the accumulator and the pointer register are unchanged by the addition. The postbyte specifies which accumulator to use as an offset and no additional bytes are required. The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run-time.

Some examples are:

$$
\begin{array}{ll}
\text { LDA } & \text { B, Y } \\
\text { LDX } & \mathrm{D}, \mathrm{Y} \\
\text { LEAX } & \mathrm{B}, \mathrm{X}
\end{array}
$$

## Auto Increment/Decrement Indexed

In the auto increment addressing mode, the pointer register contains the address of the operand. Then, after the pointer register is used it is incremented by one or two. This addressing mode is useful in stepping through tables, moving data, or for the creation of software stacks. In auto decrement, the pointer register is decremented prior to use as the address of the data. The use of auto decrement is similar to that of auto increment; but the tables, etc., are scanned from the high to low addresses. The size of the increment/decrement can be either one or two to allow for tables of either 8 - or 16 -bit data to be accessed and is selectable by the programmer. The pre-
decrement, post-increment nature of these modes allow them to be used to create additional software stacks that behave identically to the U and S stacks.

Some examples of the auto increment/decrement addressing modes are:

| LDA | , $\mathrm{X}+$ |
| :--- | :--- |
| STD | , $\mathrm{Y}++$ |
| LDB | ,-Y |
| LDX | ,--S |

Care should be taken in performing operations on 16 -bit pointer registers ( $\mathbf{X}, \mathrm{Y}, \mathrm{U}, \mathrm{S}$ ) where the same register is used to calculate the effective address.

Consider the following instruction:
STX 0, $\mathrm{X}++(\mathrm{X}$ initialized to 0$)$
The desired result is to store a 0 in locations $\$ 0000$ and $\$ 0001$ then increment X to point to $\$ 0002$. In reality, the following occurs:

$$
\begin{array}{ll}
0 \rightarrow \text { temp } & \text { calculate the EA; temp is a holding register } \\
X+2 \rightarrow X & \text { perform autoincrement } \\
X \rightarrow(\text { temp }) & \text { do store operation }
\end{array}
$$

## - Indexed Indirect

All of the indexing modes with the exception of auto increment/decrement by one, or a $\pm 4$-bit offset may have an additional level of indirection specified. In indirect addressing, the effective address is contained at the location specified by the contents of the Index Register plus any offset. In the example below, the A accumulator is loaded indirectly using an effective address calculated from the Index Register and an offset.

$$
\$ F 150 \quad \$ A A
$$

All modes of indexed indirect are included except those which are meaningless (e.g., auto increment/decrement by 1 indirect). Some examples of indexed indirect are:

| LDA | $[, \mathrm{X}]$ |
| :--- | :--- |
| LDD | $[10, \mathrm{~S}]$ |
| LDA | $[\mathrm{B}, \mathrm{Y}]$ |
| LDD | $[, \mathrm{X}++]$ |

## - Relative Addressing

The byte(s) following the branch opcode is (are) treated as a signed offset which may be added to the program counter. If the branch condition is true then the calculated address ( $\mathrm{PC}+$ signed offset) is loaded into the program counter. Program execution continues at the new location as indicated by the PC; short ( 1 byte offset) and long ( 2 bytes offset) relative addressing modes are available. All of memory can be reached in long relative addressing as an effective address is interpreted modulo $2^{16}$. Some examples of relative addressing are:

| BEQ | CAT | (short) |
| :--- | :--- | :--- |
| BGT | DOG | (short) |

$$
\begin{aligned}
& \text { Before Execution } \\
& \mathrm{A}=\mathrm{XX} \text { (don't care) } \\
& \mathrm{X}=\$ \mathrm{~F} 000 \\
& \begin{array}{lll}
\text { \$0100 } & \text { LDA }[\$ 10, \mathrm{X}] & \text { EA is now } \$ F 010 \\
\text { \$F010 } & \text { \$F1 } & \text { \$F150 is now the } \\
\text { \$F011 } & \$ 50 & \text { new EA }
\end{array} \\
& \text { After Execution } \\
& \text { A }=\$ \text { AA (Actual Data Loaded) } \\
& \mathrm{X}=\$ \mathrm{~F} 000
\end{aligned}
$$

| CAT | LBEQ | RAT | (long) |
| :--- | :--- | :--- | :--- |
| DOG | LBGT | RABBIT | (long) |
|  | ! |  |  |
|  | ! |  |  |
| RAT | NOP |  |  |
| RABBIT | NOP |  |  |

## - Program Counter Relative

The PC can be used as the pointer register with 8 or 16 -bit signed offsets. As in relative addressing, the offset is added to the current PC to create the effective address. The effective address is then used as the address of the operand or data. Program Counter Relative Addressing is used for writing position independent programs. Tables related to a particular routine will maintain the same relationship after the routine is moved, if referenced relative to the Program Counter. Examples are:
LDA
CAT, PCR
LEAX TABLE, PCR

Since program counter relative is a type of indexing, an additional level of indirection is available.
LDA [CAT, PCR]
LDU [DOG, PCR]

## - HD6809E INSTRUCTION SET

The instruction set of the HD6809E is similar to that of the HD6800 and is upward compatible at the source code level. The number of opcodes has been reduced from 72 to 59 , but because of the expanded architecture and additional addressing modes, the number of available opcodes (with different addressing modes) has risen from 197 to 1464.

Some of the new instructions are described in detail below:

## - PSHU/PSHS

The push instructions have the capability of pushing onto either the hardware stack (S) or user stack (U) any single register, or set of registers with a single instruction.

## - PULU/PULS

The pull instructions have the same capability of the push instruction, in reverse order. The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled. The actual PUSH/PULL sequence is fixed; each bit defines a unique register to push or pull, as shown in below.

## PUSH/PULL POST BYTE



## - TFR/EXG

Within the HD6809E, any register may be transferred to or exchanged with another of like-size; i.e., 8 -bit to 8 -bit or 16 -bit to 16 -bit. Bits $4 \sim 7$ of postbyte define the source register, while bits $0 \sim 3$ represent the destination register. These are denoted as follows:

| $0000-\mathrm{D}$ | $0101-\mathrm{PC}$ |
| :--- | :--- |
| $0001-\mathrm{X}$ | $1000-\mathrm{A}$ |
| $0010-\mathrm{Y}$ | $1001-\mathrm{B}$ |
| $0011-\mathrm{U}$ | $1010-\mathrm{CC}$ |
| $0100-\mathrm{S}$ | $1011-\mathrm{DP}$ |

(NOTE) All other combinations are undefined and INVALID.
TRANSFER/EXCHANGE POST BYTE


## - LEAX/LEAY/LEAU/LEAS

The LEA (Load Effective Address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in Table 3.

The LEA instruction also allows the user to access data in a position independent manner. For example:

| LEAX | MSG1, PCR |
| :--- | :--- |
| LBSR | PDATA (Print message routine) |
| - |  |
| FCC | 'MESSAGE' |

This sample program prints: 'MESSAGE'. By writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located, when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the X pointer register. This code is totally position independent.

The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the autoincrement and autodecrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows:

| LEAa, b+ | (any of the 16 -bit pointer registers $\mathrm{X}, \mathrm{Y}, \mathrm{U}$ or $S$ may be substituted for $a$ and $b$.) |
| :---: | :---: |
| 1. $\mathrm{b} \rightarrow$ temp | (calculate the EA) |
| 2. $\mathrm{b}+1 \rightarrow \mathrm{~b}$ | (modify b, postincrement) |
| 3. temp $\rightarrow$ a | (load a) |
| LEAa, - b |  |
| 1. $\mathrm{b}-1 \rightarrow$ te | mp (calculate EA with predecrement) |
| 2. $\mathrm{b}-1 \rightarrow \mathrm{~b}$ | (modify b, predecrement) |
| 3. temp $\rightarrow \mathrm{a}$ | (load a) |

Autoincrement-by-two and autodecrement-by-two instructions work similarly. Note that LEAX, $\mathrm{X}+$ does not change X , however LEAX, - X does decrement X. LEAX 1, X should be used to increment X by one.

Table 3 LEA Examples

| Instruction | Operation | Comment |
| :---: | :---: | :---: |
| LEAX 10, X | $X+10 \rightarrow X$ | Adds 5-bit constant 10 to X |
| LEAX 500, $X$ | $X+500 \rightarrow X$ | Adds 16-bit constant 500 to $X$ |
| LEAY A, Y | $Y+A \rightarrow Y$ | Adds 8-bit A accumulator to $Y$ |
| LEAY D, Y | $Y+D \rightarrow Y$ | Adds 16-bit D accumulator to Y |
| LEAU -10, U | $U-10 \rightarrow U$ | Subtracts 10 from U |
| LEAS -10, S | $S-10 \rightarrow S$ | Used to reserve area on stack |
| LEAS 10, S | $S+10 \rightarrow S$ | Used to 'clean up' stack |
| LEAX 5, S | $\mathrm{S}+5 \rightarrow \mathrm{X}$ | Transfers as well as adds |

## - MUL

Multiplies the unsigned binary numbers in the A and B accumulator and places the unsigned result into the 16 -bit $D$ accumulator. This unsigned multiply also allows multipleprecision multiplications.

## Long and Short Relative Branches

The HD6809E has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 or 16 -bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64 k memory map. Position independent code can be easily generated through the use of relative branching. Both short ( 8 -bit) and long ( 16 -bit) branches are available.

## - SYNC

After encountering a Sync instruction, the MPU enters a Sync state, stops processing instructions and waits for an interrupt. If the pending interrupt is non-maskable ( $\overline{\mathrm{NMI}}$ ) or maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) with its mask bit (F or I) clear, the processor will clear the Sync state and perform the normal interrupt stacking and service routine. Since $\overline{\text { IRQQ }}$ and $\overline{\text { IRQ }}$ are not edge-triggered, a low level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) with its mask bit ( F or I) set, the processor will clear the Sync state and continue processing by executing the next inline instruction. Figure 17 depicts Sync timing.

## Software Interrupts

A Software Interrupt is an instruction which will cause an interrupt, and its associated vector fetch. These Software Interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on this HD6809E, and are prioritized in the following order: SWI, SWI2, SWI3.

## 16-Bit Operation

The HD6809E has the capability of processing 16 -bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes and pulls.

## - CYCLE-BY-CYCLE OPERATION

The address bus cycle-by-cycle performance chart illustrates the memory-access sequence corresponding to each possible instruction and addressing mode in the HD6809E. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this
technique considerably speeds throughput.) Next, the operation of each opcode will follow the flow chart. VMA is an indication of $\mathrm{FFFF}_{16}$ on the address bus, R/W = "High" and BS = "Low". The following examples illustrate the use of the chart; see Figure 18.
Example 1: LBSR (Branch Taken)
Before Execution SP = F000

|  |  |  |  |
| :--- | :--- | :--- | :--- |
| $\$ 8000$ |  |  |  |
|  |  | LBSR | CAT |
|  |  | ! |  |
| $\$ 4000$ | CAT | ! |  |

## CYCLE-BY-CYCLE FLOW

| Cycle \# | Address <br> 1 | 8000 | Data | R/ $\bar{W}$ |
| :---: | :---: | :---: | :---: | :--- |
| 2 | 8001 | 1F | 1 | Description <br> Opcode Fetch |
| 3 | 8002 | FD | 1 | Offset High Byte |
| 4 | FFFF | $*$ | 1 | Offset Low Byte |
| 5 | FFFF | $*$ | 1 | VMA Cycle |
| 6 | FFFF | $*$ | 1 | VMA Cycle |
| 7 | FFFF | $*$ | 1 | VMA Cycle |
| 8 | EFFF | 03 | 0 | Stack Low Order <br> Byte of Return |
| 9 | EFFE | 80 | 0 | Address <br> Stack High Order <br> Byte of Return <br> Address |


| Example 2: DEC (Extended) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| \$8000 | $\begin{aligned} & \text { DEC } \\ & \text { FCB } \end{aligned}$ | \$ A000 |  |  |
| \$ A000 |  |  | \$80 |  |
|  |  | CYCLE-BY-CYCLE FLOW |  |  |
| Cycle \# | Address | Data | R/W | Description |
| 1 | 8000 | 7A | 1 | Opcode Fetch |
| 2 | 8001 | A0 | 1 | Operand Address, High Byte |
| 3 | 8002 | 00 | 1 | Operand Address, Low Byte |
| 4 | FFFF | * | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | * | 1 | VMA Cycle |
| 7 | A000 | 7F | 0 | Store the Decremented Data |

* The data bus has the data at that particular address.


## - HD6809E INSTRUCTION SET TABLES

The instructions of the HD6809E have been broken down into five different categories. They are as follows:

## 8 -Bit operation (Table 4)

16-Bit operation (Table 5)
Index register/stack pointer instructions (Table 6)
Relative branches (long or short) (Table 7)
Miscellaneous instructions (Table 8)
HD6809E instruction set tables and Hexadecimal Values of instructions are shown in Table 9 and Table 10.

(NOTES) 1. If the associated mask bit is set when the interrupt is requested, LIC will go "Low" and this cycle will be an instruction fetch from addres location PC + 1. However, if the interrupt is accepted (NMI or an unmasked FIRQ or IRQ) LIC will remain "High" and interrupt processing will start with this cycle as ( m ) on Figure 9 and 10 (Interrupt Timing).
2. If mask bits are clear, IRQ and FIRQ must be held "Low" for three cycles to guarantee that interrupt will be taken, although only one cycle if mask bits are clear, IRQ and FIRQ must be is
Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{\text {IHmin }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.

Figure 17 SYNC Timing

(NOTE)

1. Busy = "High" during access of first byte of double byte immediate load.
2. Write operation during store instruction. Busy = "High" during first two cycles of a double-byte access and the first cycle of read-modify-write access.
3. AVMA is asserted on the cycle before a VMA cycle.

Figure 18 Address Bus Cycle-by-Cycle Performance

(NOTES)

1. Stack (W) refers to the following sequence: $S P \leftarrow S P-1$, then $A D D R \leftarrow S P$ with $R / \bar{W}=$ '"Low'

Stack (R) refers to the following sequence: ADDR $\leftarrow S P$ with $R / W=$ "High", then $S P \leftarrow S P+1$.
PSHU, PULU instructions use the user stack pointer (i.e., SP = U) and PSHS, PULS use the hardware stack pointer (i.e., $S P=\mathbf{S}$ ).
2. Vector refers to the address of an interrupt or reset vector (see Table 1).
3. The number of stack accesses will vary according to the number of bytes saved.
4. VMA cycles will occur until an interrupt occurs.

## (NOTES

1. Stack (W) refers to the following sequence: $S P \leftarrow S P-1$, then $A D D R \leftarrow S P$ with $R / \bar{W}=$ "Low"

Stack $(W)$ refers to the following sequence: $S P \leftarrow S P-1$, then $A D D R \leftarrow S P$ with $R / W=$ "Low"
Stack $(R)$ refers to the following sequence: $A D D R \leftarrow S P$ with $R / \bar{W}=$ "High", then $S P \leftarrow S P+1$.
PSHU, PULU instructions use the user stack pointer (i.e., $S P=U$ ) and PSHS, PULS use the hardware stack pointer (i.e., $S P=\mathbf{S}$ ).
2. Vector refers to the address of an interrupt or reset vector (see Table 1).
3. The number of stack accesses will vary according to the number of bytes saved.
4. VMA cycles will occur until an interrupt occurs.

Figure 18 Address Bus Cycle-by-Cycle Performance (Continued)

Table 4 8-Bit Accumulator and Memory Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| ADCA, ADCB | Operation |
| ADDA, ADDB | Add memory to accumulator with carry |
| ANDA, ANDB | And memory with accumulator |
| ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left |
| ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right |
| BITA, BITB | Bit test memory with accumulator |
| CLR, CLRA, CLRB | Clear accumulator or memory location |
| CMPA, CMPB | Compare memory from accumulator |
| COM, COMA, COMB | Complement accumultor or memory location |
| DAA | Decimal adjust A accumulator |
| DEC, DECA, DECB | Decrement accumulator or memory location |
| EORA, EORB | Exclusive or memory with accumulator |
| EXG R1, R2 | Exchange R1 with R2 (R1, R2 = A, B, CC, DP) |
| INC, INCA, INCB | Increment accumulator or memory location |
| LDA, LDB | Load accumulator from memory |
| LSL, LSLA, LSLB | Logical shift left accumulator or memory location |
| LSR, LSRA, LSRB | Logical shift right accumulator or memory location |
| MUL | Unsigned multiply (A $\times$ B $\rightarrow$ D) |
| NEG, NEGA, NEGB | Negate accumulator or memory |
| ORA, ORB | Or memory with accumulator |
| ROL, ROLA, ROLB | Rotate accumulator or memory left |
| ROR, RORA, RORB | Rotate accumulator or memory right |
| SBCA, SBCB | Subtract memory from accumulator with borrow |
| STA, STB | Store accumulator to memory |
| SUBA, SUBB | Subtract memory from accumulator |
| TST, TSTA, TSTB | Test accumulator or memory location |
| TFR R1, R2 | Transfer R1 to R2 (R1, R2 = A, B, CC, DP) |

(NOTE) A, B, CC or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 5 16-Bit Accumulator and Memory Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| ADDD | Add memory to D accumulator |
| CMPD | Compare memory from D accumulator |
| EXG D, R | Exchange D with $X, Y, S$, U or PC |
| LDD | Load D accumulator from memory |
| SEX | Sign Extend B accumulator into A accumulator |
| STD | Store D accumulator to memory |
| SUBD | Subtract memory from D accumulator |
| TFR D, R | Transfer D to X, Y, S, U or PC |
| TFR R,D | Transfer X, Y,S, U or PC to D |

(NOTE) D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 6 Index Register Stack Pointer Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| CMPS, CMPU | Compare memory from stack pointer |
| CMPX, CMPY | Compare memory from index register |
| EXG R1, R2 | Exchange D, X, Y, S, U or PC with D, X, Y, S, U or PC |
| LEAS, LEAU | Load effective address into stack pointer |
| LEAX, LEAY | Load effective address into index register |
| LDS, LDU | Load stack pointer from memory |
| LDX, LDY | Load index register from memory |
| PSHS | Push A, B, CC, DP, D, X, Y, U, or PC onto hardware stack |
| PSHU | Push A, B, CC, DP, D, X, Y, S, or PC onto user stack |
| PULS | Pull A, B, CC, DP, D, X, Y, U or PC from hardware stack |
| PULU | Pull A, B, CC, DP, D, X, Y, S or PC from user stack |
| STS, STU | Store stack pointer to memory |
| STX, STY | Store index register to memory |
| TFR R1, R2 | Transfer D, X, Y, S, U or PC to D, X, Y, S, U or PC |
| ABX | Add B accumulator to X (unsigned) |

Table 7 Branch Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| SIMPLE BRANCHES |  |
| BEQ, LBEQ | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BMI, LBMI | Branch if minus |
| BPL, LBPL | Branch if plus |
| BCS, LBCS | Branch if carry set |
| BCC, LBCC | Branch if carry clear |
| BVS, LBVS | Branch if overflow set |
| BVC, LBVC | SIGNED BRANCHES |
| BGT, LBGT | Branch if greater (signed) |
| BGE, LBGE | Branch if greater than or equal (signed) |
| BEQ, LBEQ | Branch if equal |
| BLE, LBLE | Branch if less than or equal (signed) |
| BLT, LBLT | UNSIGNED BRANCHES |
| BHI, LBHI | Branch if higher (unsigned) |
| BHS, LBHS | Branch if higher or same (unsigned) |
| BEQ, LBEQ | Branch if equal |
| BLS, LBLS | Branch if lower or same (unsigned) |
| BLO, LBLO | Branch if lower (unsigned) |
| BSR, LBSR | Branch to subroutine |
| BRA, LBRA | Branch always |
| BRN, LBRN |  |

Table 8 Miscellaneous Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| ANDCC | AND condition code register |
| CWAI | AND condition code register, then wait for interrupt |
| NOP | No operation |
| ORCC | OR condition code register |
| JMP | Jump |
| JSR | Jump to subroutine |
| RTI | Return from interrupt |
| RTS | Return from subroutine |
| SWI, SWI2, SWI3 | Software interrupt (absolute indirect) |
| SYNC | Synchronize with interrupt line |

Table 9 HD6809E Instruction Set Table

(to be continued)

(to be continued)

| INSTRUCTION/ FORMS |  | HD6809E ADDRESSING MODES |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | DESCRIPTION |  | 3 | Z 2 | 1 | O |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMPLIED |  |  | DIRECT |  |  | EXTENDED |  |  | IMMEDIATE |  |  | INDEXED ${ }^{(1)}$ |  |  | RELATIVE |  |  |  | 5 |  |  |  |  |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | ~ ${ }^{6}$ | \# |  | H |  |  |  |  |
| OR | $\begin{aligned} & \text { ORA } \\ & \text { ORB } \\ & \text { ORCC } \end{aligned}$ |  |  |  | $\begin{array}{\|l\|} \hline \text { 9A } \\ \text { DA } \end{array}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \hline \mathbf{B A} \\ & \mathbf{F A} \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & \hline 8 A \\ & C A \\ & 1 A \end{aligned}$ | 2 2 3 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{array}{\|l\|} \hline \mathbf{A A} \\ \mathbf{E A} \end{array}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \end{aligned}$ |  |  |  | $\begin{aligned} & A \vee M \rightarrow A \\ & B \vee M \rightarrow B \\ & C C \vee I M M \rightarrow C C \end{aligned}$ |  | $\ddagger$ | $\left\|\begin{array}{c} 1 \\ 1 \\ (7) \end{array}\right\|$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\bullet$ |
| PSH | PSHS PSHU | 34 | $5+$ (4) $5+4$ | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Push Registers on S Stack Push Registers on U Stack | - <br> - | $1 \bullet$ |  | $\bullet$ | - |
| PUL | PULS PULU | $\begin{aligned} & 35 \\ & 37 \end{aligned}$ | 5+(4) | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Pull Registers from S Stack Pull Registers from U Stack | ( |  | (10) |  | ) |
| ROL | $\begin{aligned} & \text { ROLA } \\ & \text { ROLB } \\ & \text { ROL } \end{aligned}$ | $\begin{aligned} & 49 \\ & 59 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 09 | 6 | 2 | 79 | 7 | 3 |  |  |  | 69 | $6+$ | 2+ |  |  |  |  |  | $\begin{aligned} & 1 \\ & t \\ & t \end{aligned}$ | $\left\lvert\, \begin{aligned} & 1 \\ & t \\ & t \end{aligned}\right.$ | $\begin{aligned} & t \\ & t \\ & t \end{aligned}$ | $\dagger$ $\downarrow$ $t$ |
| ROR | RORA RORB ROR | $\begin{aligned} & 46 \\ & 56 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 06 | 6 | 2 | 76 | 7 | 3 |  |  |  | 66 | $6+$ | 2+ |  |  |  |  | $\bullet$ | $\left\lvert\, \begin{aligned} & \ddagger \\ & \downarrow \\ & \downarrow \end{aligned}\right.$ | $\begin{aligned} & \ddagger \\ & \vdots \\ & \vdots \end{aligned}$ | $\bullet$ | $t$ |
| RTI |  | 3 B | 6/15 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Return From Interrupt | $6$ |  | (7) |  | ) |
| RTS |  | 39 | 5 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Return From Subroutine | - | - | - | $\bullet$ | - |
| SBC | $\begin{aligned} & \text { SBCA } \\ & \text { SBCB } \end{aligned}$ |  |  |  | $\begin{array}{\|l\|} \hline 92 \\ \text { D2 } \end{array}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { B2 } \\ & \text { F2 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & 82 \\ & \mathrm{C} 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { E2 } \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ |  |  |  | $\begin{aligned} & A-M-C \rightarrow A \\ & B-M-C \rightarrow B \end{aligned}$ | (8) | $1 \begin{aligned} & 1 \\ & t \end{aligned}$ | $t$ | $t$ | $t$ |
| SEX |  | 1 D | 2 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Sign Extend B into $A$ | - | $\ddagger$ | $\pm$ | $0$ | - |
| ST | STA |  |  |  | 97 | 4 | 2 | B7 | 5 | 3 3 |  |  |  | A7 | $\begin{array}{\|l} 4+ \\ 4+ \end{array}$ | 2+ |  |  |  | A $\rightarrow$ M $B \rightarrow M$ | $\bullet$ | $\left\lvert\, \begin{aligned} & t \\ & t \end{aligned}\right.$ | $\ddagger$ | O | - |
|  |  |  |  |  | DD | $5$ | $2$ | FD | $6$ | $3$ |  |  |  | ED | $5+$ | 2+ |  |  |  | $D \rightarrow M: M+1$ |  | $\begin{aligned} & t \\ & t \end{aligned}$ | $t$ | 0 | - |
|  | STS |  |  |  | 10 | $6$ | $3$ | $\begin{aligned} & 10 \\ & \text { FF } \end{aligned}$ | $7$ | $4$ |  |  |  | $\begin{aligned} & 10 \\ & E F \end{aligned}$ | $6+$ | $3+$ |  |  |  | $\mathbf{S} \rightarrow \mathrm{M}: \mathbf{M + 1}$ | $10$ | $1$ | $i$ | $0$ | - |
|  | STU |  |  |  | DF | 5 | 2 | FF | 6 | 3 |  |  |  | EF | 5+ | 2+ |  |  |  | $U \rightarrow M: M+1$ | - | $t$ | 1 | 0 | - |
|  | STX |  |  |  | 9F | $5$ | $2$ | $B F$ | $6$ | $3$ |  |  |  | $A F$ | $5+$ | $2+$ |  |  |  | $X \rightarrow M: M+1$ | $10$ | $1$ | $\ddagger$ | $0$ | $\bullet$ |
|  |  |  |  |  | $\begin{aligned} & 10 \\ & 9 F \end{aligned}$ | $6$ |  | $\begin{aligned} & 10 \\ & \text { BF } \end{aligned}$ |  |  |  |  |  | $\begin{aligned} & 10 \\ & A F \end{aligned}$ | 6+ | 3+ |  |  |  | $\mathbf{Y} \rightarrow \mathrm{M}: \mathbf{M + 1}$ | - | $\ddagger$ | $\pm$ | $0$ | - |
| SUB | SUBA <br> SUBB <br> SUBD |  |  |  | $\begin{aligned} & 90 \\ & \mathrm{DO} \\ & 93 \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 6 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { B0 } \\ & \text { FO } \\ & \text { B3 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & 80 \\ & \text { C0 } \\ & 83 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { E0 } \\ & \text { A3 } \end{aligned}$ | $\begin{array}{\|l\|} 4+ \\ 4+ \\ 6+ \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \end{aligned}$ |  |  |  | $\begin{aligned} & A-M \rightarrow A \\ & B-M \rightarrow B \\ & D-M: M+1 \rightarrow D \end{aligned}$ | (8) | $\left\lvert\, \begin{aligned} & \ddagger \\ & \vdots \\ & \vdots \end{aligned}\right.$ | $\left\lvert\, \begin{aligned} & 1 \\ & \vdots \\ & 1 \end{aligned}\right.$ | $\begin{aligned} & t \\ & t \\ & t \end{aligned}$ | $t$ |
| SWI | $\begin{aligned} & \text { SWI® } \\ & \text { SWI2 } \end{aligned}$ | $\begin{aligned} & 3 F \\ & 10 \\ & 3 F \end{aligned}$ | $\begin{aligned} & 19 \\ & 20 \end{aligned}$ | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Software Interrupt1 Software Inter rupt2 | $\bullet$ |  |  |  | - |
|  | SWI3 ${ }^{(6)}$ | $\begin{aligned} & 11 \\ & 3 F \end{aligned}$ | 20 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Software Interrupt3 | - | $\bullet$ | - | - | - |
| SYNC |  | 13 | $\geqq 4$ | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Synchronize to Interrupt | - | - | - | - | - |
| TFR | R1, R2 | $1 F$ | 6 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | R1 $\rightarrow$ R2 ${ }^{\text {(3) }}$ | ( |  | (10) |  | ) |
| TST | $\begin{aligned} & \text { TSTA } \\ & \text { TSTB } \\ & \text { TST } \end{aligned}$ | $\begin{aligned} & 40 \\ & 50 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | OD | 6 | 2 | 7 D | 7 | 3 |  |  |  | 6D | $6+$ | $2+$ |  |  |  | Test A <br> Test B <br> Test M | $\bullet$ | $\left\lvert\, \begin{aligned} & \ddagger \\ & \ddagger \\ & \ddagger \end{aligned}\right.$ | 1 1 $i$ $i$ | 0 <br> 0 <br> 0 | $\stackrel{\bullet}{\bullet}$ |

## (NOTES)

(1) This column gives a base cycle and byte count. To obtain total count, and the values obtained from the INDEXED ADDRESSING MODES table.
(2) R1 and R2 may be any pair of 8 bit or any pair of 16 bit registers.

The 8 bit registers are: A, B, CC, DP
The 16 bit registers are: $X, Y, Y, U, S, D, P C$
(3) EA is the effective address.
(4) The PSH and PUL instructions require 5 cycle plus 1 cycle for each byte pushed or pulled.
(5) 5(6) means: 5 cycles if branch not taken, 6 cycles if taken.
(8) SWI sets 1 and F bits. SWI2 and SWI3 do not affect I and F.
(7) Conditions Codes set as a direct result of the instruction.
(8) Value of half-carry flag is undefined.
(9) Special Case - Carry set if b7 is SET.
(10) Condition Codes set as a direct result of the instruction if CC is specified, and not affected otherwise.

| LEGEND: |  |
| :--- | :--- |
| OP | Operation Code (Hexadecimal) |
| \# | Number of MPU Cycles |
| \# | Number of Program Bytes |
| + | Arithmetic Plus |
| $\overline{\times}$ | Arithmetic Minus <br> Multiply <br> $\mathbf{M}$ |
| $\overrightarrow{~ C o m p l e m e n t ~ o f ~ M ~}$ |  |
| $\vec{H}$ | Transfer Into <br> Half-carry (from bit 3) <br> N |
|  | Negative (sign bit) |


| 2 | Zero (byte) |
| :---: | :---: |
| V | Overflow, 2's complement |
| C | Carry from bit 7 |
| $\pm$ | Test and set if true, cleared otherwise |
| - | Not Affected |
| CC | Condition Code Register |
| : | Concatenation |
| V | Logical or |
| $\wedge$ | Logical and |
| $\oplus$ | Logical Exclusive or |

Table 10 Hexadecimal Values of Machine Codes

| OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | 4+ | 2+ | 60 | NEG | Indexed | $6+$ | 2+ |
| 01 | * | 4 |  |  | 31 | LEAY | 4 | 4+ | 2+ | 61 | * | 4 |  |  |
| 02 | * |  |  |  | 32 | LEAS | $\checkmark$ | 4+ | 2+ | 62 | * |  |  |  |
| 03 | COM |  | 6 | 2 | 33 | LEAU | Indexed | 4+ | 2+ | 63 | COM |  | 6+ | 2+ |
| 04 | LSR |  | 6 | 2 | 34 | PSHS | Implied | $5+$ | 2 | 64 | L.SR |  | $6+$ | 2+ |
| 05 | * |  |  |  | 35 | PULS | 4 | $5+$ | 2 | 65 | * |  |  |  |
| 06 | ROR |  | 6 | 2 | 36 | PSHU |  | $5+$ | 2 | 66 | ROR |  | $6+$ | 2+ |
| 07 | ASR |  | 6 | 2 | 37 | PULU |  | $5+$ | 2 | 67 | ASR |  | $6+$ | 2+ |
| 08 | ASL, LSL |  | 6 | 2 | 38 | * |  |  |  | 68 | ASL, LSL |  | $6+$ | 2+ |
| 09 | ROL |  | 6 | 2 | 39 | RTS |  | 5 | 1 | 69 | ROL |  | 6+ | 2+ |
| OA | DEC |  | 6 | 2 | 3A | $A B X$ | $\dagger$ | 3 | 1 | 6A | DEC |  | 6+ | 2+ |
| OB | * |  |  |  | 3B | RTI | Implied | 6,15 | 1 | 6B |  |  |  |  |
| OC | INC |  | 6 | 2 | 3C | CWAI | Immed | $\geqq 20$ | 2 | 6C | INC |  | 6+ | 2+ |
| OD | TST |  | 6 | 2 | 3D | MUL | Implied | 11 | 1 | 6D | TST |  | 6+ | 2+ |
| OE | JMP | $\checkmark$ | 3 | 2 | 3E | * |  |  |  | 6E | JMP | $\checkmark$ | $3+$ | 2+ |
| OF | CLR | Direct | 6 | 2 | $3 F$ | SWI | Implied | 19 | 1 | 6 F | CLR | Indexed | 6+ | 2+ |
| 10 | See | - | - | - | 40 | NEGA | Implied | 2 | 1 | 70 | NEG | Extended | 7 | 3 |
| 11 | $\}_{\text {Next Page }}$ | - | - | - | 41 |  |  |  |  | 71 |  |  |  |  |
| 12 | NOP | Implied | 2 | 1 | 42 | * |  |  |  | 72 | * |  |  |  |
| 13 | SYNC | Implied | $\geqq 4$ | 1 | 43 | COMA |  | 2 | 1 | 73 | COM |  | 7 | 3 |
| 14 | * |  |  |  | 44 | LSRA |  | 2 | 1 | 74 | LSR |  | 7 | 3 |
| 15 | * |  |  |  | 45 | * |  |  |  | 75 | * |  |  |  |
| 16 | LBRA | Relative | 5 | 3 | 46 | RORA |  | 2 | 1 | 76 | ROR |  | 7 | 3 |
| 17 | LBSR | Relative | 9 | 3 | 47 | ASRA |  | 2 | 1 | 77 | ASR |  | 7 | 3 |
| 18 | * |  |  |  | 48 | ASLA, LSLA |  | 2 | 1 | 78 | ASL, LSL |  | 7 | 3 |
| 19 | DAA | Implied | 2 | 1 | 49 | ROLA |  | 2 | 1 | 79 | ROL |  | 7 | 3 |
| 1 A | ORCC | Immed | 3 | 2 | 4A | DECA |  | 2 | 1 | 7 A | DEC |  | 7 | 3 |
| 1 B | * | - |  |  | 4B | * |  |  |  | 7 B | * |  |  |  |
| 1 C | ANDCC | Immed | 3 | 2 | 4C | INCA |  | 2 | 1 | 7 C | INC |  | 7 | 3 |
| 1D | SEX | Implied | 2 | 1 | 4D | TSTA |  | 2 | 1 | 7D |  |  | 7 | 3 |
| 1E | EXG | $\uparrow$ | 8 | 2 | 4E | * | $\nabla$ |  |  | 7E | JMP | $\nabla$ | 4 | 3 |
| 1F | TFR | Implied | 6 | 2 | 4F | CLRA | Implied | 2 | 1 | 7F | CLR | Extended | 7 | 3 |
| 20 | BRA | Relative | 3 | 2 | 50 | NEGB | Implied | 2 | 1 | 80 | SUBA | Immed | 2 | 2 |
| 21 | BRN | 4 | 3 | . 2 | 51 | - | 4 |  |  | 81 | CMPA | 4 | 2 | 2 |
| 22 | BHI |  | 3 | 2 | 52 | * |  |  |  | 82 | SBCA |  | 2 | 2 |
| 23 | BLS |  | 3 | 2 | 53 | COMB |  | 2 | 1 | 83 | SUBD |  | 4 | 3 |
| 24 | BHS, BCC |  | 3 | 2 | 54 | LSRB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 |
| 25 | BLO, BCS |  | 3 | 2 | 55 | * |  |  |  | 85 | BITA |  | 2 | 2 |
| 26 | BNE |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 86 | LDA |  | 2 | 2 |
| 27 | BEQ |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 87 | * |  |  |  |
| 28 | BVC |  | 3 | 2 | 58 | ASLB, LSLB |  | 2 | 1 | 88 | EORA |  | 2 | 2 |
| 29 | BVS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 89 | ADCA |  | 2 | 2 |
| 2A | $B P L$ |  | 3 | 2 | 5 A | DECB |  | 2 | 1 | 8A | ORA |  | 2 | 2 |
| 2B | BMI |  | 3 | 2 | 5B | * |  |  |  | 8 B | ADDA | $\checkmark$ | 2 | 2 |
| 2C | BGE |  | 3 | 2 | 5 C | INCB |  | 2 | 1 | 8C | CMPX | Immed | 4 | 3 |
| 2D | BLT |  | 3 | 2 | 5D | TSTB |  | 2 | 1 | 8D | BSR | Relative | 7 | 2 |
| 2E | BGT | - | 3 | 2 | 5 E | * | $\checkmark$ |  |  | 8 E | LDX | Immed | 3 | 3 |
| 2F | BLE | Relative | 3 | 2 | 5 F | CLRB | Implied | 2 | 1 | 8F | * |  |  |  |

[^7](to be continued)

| OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 90 | SUBA | Direct | 4 | 2 | C6 | LDB | Immed | 2 | 2 |
| 91 | CMPA | 4 | 4 | 2 | C7 | * | 4 |  |  |
| 92 | SBCA |  | 4 | 2 | C8 | EORB |  | 2 | 2 |
| 93 | SUBD |  | 6 | 2 | C9 | ADCB |  | 2 | 2 |
| 94 | ANDA |  | 4 | 2 | CA | ORB |  | 2 | 2 |
| 95 | BITA |  | 4 | 2 | CB | ADDB |  | 2 | 2 |
| 96 | LDA |  | 4 | 2 | CC | LDD |  | 3 | 3 |
| 97 | STA |  | 4 | 2 | CD | * | $\nabla$ |  |  |
| 98 | EORA |  | 4 | 2 | CE | LDU | Immed | 3 | 3 |
| 99 | ADCA |  | 4 | 2 | CF | * |  |  |  |
| 9A | ORA |  | 4 | 2 |  |  |  |  |  |
| 98 | ADDA |  | 4 | 2 | DO | SUBB | Direct | 4 | 2 |
| 9C | CMPX |  | 6 | 2 | D1 | CMPB | 4 | 4 | 2 |
| 9 D | JSR |  | 7 | 2 | D2 | SBCB |  | 4 | 2 |
| 9E | LDX |  | 5 | 2 | D3 | ADDD |  | 6 | 2 |
| 9F | STX | Direct | 5 | 2 | D4 | ANDB |  | 4 | 2 |
|  |  |  |  |  | D5 | BITB |  | 4 | 2 |
| AO | SUBA | Indexed | 4+ | 2+ | D6 | LDB |  | 4 | 2 |
| A1 | CMPA | A | 4+ | 2+ | D7 | STB |  | 4 | 2 |
| A2 | SBCA |  | 4+ | 2+ | D8 | EORB |  | 4 | 2 |
| A3 | SUBD |  | 6+ | 2+ | D9 | ADCB |  | 4 | 2 |
| A4 | ANDA |  | 4+ | 2+ | DA | ORB |  | 4 | 2 |
| A5 | BITA |  | 4+ | 2+ | DB | ADDB |  | 4 | 2 |
| A6 | LDA |  | 4+ | 2+ | DC | LDD |  | 5 | 2 |
| A7 | STA |  | 4+ | 2+ | DD | STD |  | 5 | 2 |
| A8 | EORA |  | 4+ | 2+ | DE | LDU |  | 5 | 2 |
| A9 | ADCA |  | 4+ | 2+ | DF | STU | Direct | 5 | 2 |
| AA | ORA |  | 4+ | 2+ |  |  |  |  |  |
| AB | ADDA |  | 4+ | 2+ | E0 | SUBB | Indexed | 4+ | 2+ |
| AC | CMPX |  | 6+ | 2+ | E1 | CMPB | 4 | $4+$ | 2+ |
| AD | JSR |  | $7+$ | 2+ | E2 | SBCB |  | $4+$ | 2+ |
| AE | LDX | $\nabla$ | $5+$ | 2+ | E3 | ADDD |  | $6+$ | 2+ |
| AF | STX | Indexed | 5+ | 2+ | E4 | ANDB |  | $4+$ | 2+ |
|  |  |  |  |  | E5 | BITB |  | 4+ | 2+ |
| B0 | SUBA | Extended | 5 | 3 | E6 | LDB |  | 4+ | 2+ |
| B1 | CMPA | 4 | 5 | 3 | E7 | STB |  | 4+ | 2+ |
| B2 | SBCA |  | 5 | 3 | E8 | EORB |  | 4+ | 2+ |
| B3 | SUBD |  | 7 | 3 | E9 | ADCB |  | 4+ | 2+ |
| B4 | ANDA |  | 5 | 3 | EA | ORB |  | 4+ | 2+ |
| B5 | BITA |  | 5 | 3 | EB | ADDB |  | 4+ | 2+ |
| B6 | LDA |  | 5 | 3 | EC | LDD |  | $5+$ | 2+ |
| B7 | STA |  | 5 | 3 | ED | STD |  | $5+$ | 2+ |
| B8 | EORA |  | 5 | 3 | EE | LDU | 1 | $5+$ | 2+ |
| 89 | ADCA |  | 5 | 3 | EF | STU | Indexed | $5+$ | 2+ |
| BA | ORA |  | 5 | 3 |  |  |  |  |  |
| BB | ADDA |  | 5 | 3 | F0 | SUBB | Extended | 5 | 3 |
| BC | CMPX |  | 7 | 3 | F1 | CMPB | $\wedge$ | 5 | 3 |
| BD | JSR |  | 8 | 3 | F2 | SBCB |  | 5 | 3 |
| BE | LDX | $\dagger$ | 6 | 3 | F3 | ADDD |  | 7 | 3 |
| BF | STX | Extended | 6 | 3 | F4 | ANDB |  | 5 | 3 |
|  |  |  |  |  | F5 | BITB |  | 5 | 3 |
| CO | SUBB | Immed | 2 | 2 | F6 | LDB |  | 5 | 3 |
| C1 | CMPB | 4 | 2 | 2 | F7 | STB |  | 5 | 3 |
| C2 | SBCB |  | 2 | 2 | F8 | EORB |  | 5 | 3 |
| C3 | ADDD |  | 4 | 3 | F9 | ADCB |  | 5 | 3 |
| C4 | ANDB | $\checkmark$ | 2 | 2 | FA | ORB | $\downarrow$ | 5 | 3 |
| C5 | BITB | Immed | 2 | 2 | FB | ADDB | Extended | 5 | 3 |


| OP | Mnem | Mode | $\sim$ | $\#$ |
| :--- | :--- | :---: | :---: | :---: |
|  |  |  |  |  |
| FC | LDD | Extended | 6 | 3 |
| FD | STD | 4 | 6 | 3 |
| FE | LDU |  | 6 | 3 |
| FF | STU | Extended | 6 | 3 |

2 Bytes Opcode

| 1021 | LBRN | Relative | 5 | 4 |
| :---: | :---: | :---: | :---: | :---: |
| 1022 | LBHI | 4 | 5(6) | 4 |
| 1023 | LBLS |  | 5(6) | 4 |
| 1024 | LBHS, L | BCC | 5(6) | 4 |
| 1025 | LBCS, | LO | 5(6) | 4 |
| 1026 | LBNE |  | 5(6) | 4 |
| 1027 | LBEQ |  | 5(6) | 4 |
| 1028 | LBVC |  | 5(6) | 4 |
| 1029 | LBVS |  | 5(6) | 4 |
| 102A | LBPL |  | 5(6) | 4 |
| 102B | LBMI |  | 5(6) | 4 |
| 102C | LBGE |  | 5(6) | 4 |
| 102D | LBLT |  | 5(6) | 4 |
| 102E | LBGT | $\dagger$ | 5(6) | 4 |
| 102F | LBLE | Relative | 5(6) | 4 |
| 103F | SWI2 | Implied | 20 | 2 |
| 1083 | CMPD | Immed | 5 | 4 |
| 108C | CMPY |  | 5 | 4 |
| 108E | LDY | Immed | 4 | 4 |
| 1093 | CMPD | Direct | 7 | 3 |
| 109C | CMPY | 4 | 7 | 3 |
| 109 E | LDY |  | 6 | 3 |
| 109F | STY | Direct | 6 | 3 |
| 10 A 3 | CMPD | Indexed | 7+ | 3+ |
| 10AC | CMPY | , | $7+$ | 3+ |
| 10AE | LDY | $\dagger$ | $6+$ | 3+ |
| 10AF | STY | Indexed | 6+ | $3+$ |
| 10B3 | CMPD | Extended | 8 | 4 |
| 10BC | CMPY | A | 8 | 4 |
| 10BE | LDY |  | 7 | 4 |
| 10BF | STY | Extended | 7 | 4 |
| 10CE | LDS | Immed | 4 | 4 |
| 10DE | LDS | Direct | 6 | 3 |
| 10DF | STS | Direct | 6 | 3 |
| 10EE | LDS | Indexed | $6+$ | 3+ |
| 10EF | STS | Indexed | 6+ | 3+ |
| 10FE | LDS | Extended | 7 | 4 |
| 10FF | STS | Extended | 7 | 4 |
| 113F | SWI3 | Implied | 20 | 2 |
| 1183 | CMPU | Immed | 5 | 4 |
| 118C | CMPS | Immed | 5 | 4 |
| 1193 | CMPU | Direct | 7 | 3 |
| 119C | CMPS | Direct | 7 | 3 |
| 11 A 3 | CMPU | Indexed | 7+ | 3+ |
| 11AC | CMPS | Indexed | 7+ | $3+$ |
| $11 \mathrm{B3}$ | CMPU | Extended | 8 | 4 |
| 11BC | CMPS | Extended | 8 | 4 |

(NOTE): All unused opcodes are both undefined and illegal

## - NOTE FOR USE

## Execution Sequence of CLR Instruction

Cycle-by-cycle flow of CLR instruction (Direct, Extended, Indexed Addressing Mode) is shown below. In this sequence the content of the memory location specified by the operand is read before writing " 00 " into it. Note that status Flags, such as IRQ Flag, will be cleared by this extra data read operation when accessing the control/status register (sharing the same address between read and write) of peripheral devices.

| Example: | CbR (Extended) |  |  |  |
| :---: | :---: | :---: | :---: | :--- |
| $\$ 8000$ | CLR | $\$ A 000$ |  |  |
| $\$ A 000$ | FCB | $\$ 80$ |  |  |
| Cycle \# | Address | Data | R/W | Description <br> 1 |
| 2 | 8000 | 7 F | 1 | Opcode Fetch <br> Operand Address, |
| 3 | 8001 | A0 | 1 | High Byte <br> Operand Address, |
|  | 8002 | 00 | 1 | Low Byte |
| 4 | FFFF | $*$ | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | $*$ | 1 | VMA Cycle |
| 7 | A000 | 00 | 0 | Store Fixed "00" <br> into Specified <br> Location |

* The data bus has the data at that particular address.


## CMOS 8-BIT MICROPROCESSOR

## HD6303R,HD63A03R, HD63B03R CMOS MPU (Micro Processing Unit)

The HD6303R is an 8 -bit CMOS micro processing unit which has the completely compatible instruction set with the HD6301V1. 128 bytes RAM, Serial Communication Interface (SCI), parallel I/O ports and multi function timer are incorporated in the HD6303R. It is bus compatible with HMCS6800 and can be expanded up to 65 k bytes. Like the HMCS6800 family, I/O level is TTL compatible with +5.0 V single power supply. As the HD6303R is CMOS MPU, power dissipation is extremely low. And also HD6303R has Sleep Mode and Stand-by Mode as lower power dissipation mode. Therefore, flexible low power consumption application is possible.

- FEATURES
- Object Code Upward Compatible with the HD6800, HD6801, HD6802
- Multiplexed Bus ( $\left.D_{0} / A_{0} \sim D_{7} / A_{7} A_{8} \sim A_{15}\right)$, Non Multiplexed Bus ( $\left.D_{0} \sim D_{7}, A_{0} \sim A_{15}\right)$
- Abundant On-Chip Functions Compatible with the HD6301V1; 128 Bytes RAM, 13 Parallel I/O Lines, 16 -bit Timer, Serial Communication Interface (SCI)
- Low Power Consumption Mode; Sleep Mode, Stand-By Mode
- Minimum Instruction Execution Time
$1 \mu \mathrm{~s}(f=1 \mathrm{MHz}), 0.67 \mu \mathrm{~s}(\boldsymbol{f}=1.5 \mathrm{MHz}), 0.5 \mu \mathrm{~s}(f=2.0 \mathrm{MHz})$
- Bit Manipulation, Bit Test Instruction
- Error Detecting Function; Address Trap, Op Code Trap
- Up to 65k Bytes Address Space
- Wide Operation Range

$$
\begin{aligned}
& V_{c c}=3 \text { to } 6 \mathrm{~V}(f=0.1 \sim 0.5 \mathrm{MHz}) \\
& f=0.1 \text { to } 2.0 \mathrm{MHz}\left(\mathrm{~V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%\right)
\end{aligned}
$$

## - TYPE OF PRODUCTS

| Type No. | Bus Timing |
| :--- | :---: |
| HD6303R | 1.0 MHz |
| HD63A03R | 1.5 MHz |
| HD63B03R | 2.0 MHz |



HD6303RF, HD63A03RF, HD63B03RF

(FP-54)
HD6303RCG,HD63A03RCG, HD63B03RCG

(CG-40)
HD6303RCP, HD63A03RCP, HD63B03RCP

(CP-52)


- HD6303RCP, HD63A03RCP, HD63B03RCP

- BLOCK DIAGRAM


ABSOLUTE MAXIMUM RATINGS

| Itert | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{cc}}+0.3$ | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{opr}}$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{co}}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

(NOTE) This product has protection circuits in input terminal from high static electricity voltage and high electric field. But be careful not to apply over, circuits. To assure the normal operation, we recommend $V_{\text {in }}, V_{\text {out }}: V_{\text {SS }} \leq\left(V_{\text {in }}\right.$ or $\left.V_{\text {out }}\right) \leq V_{\text {CC }}$.

- ELECTRICAL CHARACTERISTICS
- DC CHARACTERISTICS $\left(\mathrm{V}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input "High" Voltage | $\overline{\text { RES, STB }}$ S | $\mathrm{V}_{\mathrm{IH}}$ |  | $\mathrm{V}_{\mathrm{cc}}-0.5$ | - | $\begin{gathered} V_{c c} \\ +0.3 \end{gathered}$ | V |
|  | EXTAL |  |  | $\mathrm{V}_{\mathrm{cc}} \times 0.7$ | - |  |  |
|  | Other Inputs |  |  | 2.0 | - |  |  |
| Input "Low" Voltage | All Inputs | $V_{\text {IL }}$ |  | -0.3 | - | 0.8 | V |
| Input Leakage Current | $\overline{\text { NMI, }} \overline{\text { RO }} 1, \overline{\mathrm{RES}}, \overline{\text { STBY }}$ | $1 i l_{\text {in }} 1$ | $\mathrm{V}_{\text {in }}=0.5 \sim V_{\text {cc }}-0.5 \mathrm{~V}$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Three State (off-state) Leakage Current | $\begin{aligned} & P_{10} \sim P_{17}, P_{20} \sim P_{24}, \\ & D_{0} \sim D_{7}, A_{8} \sim A_{15} \end{aligned}$ | " ${ }_{\text {TSII }} 1$ | $\mathrm{V}_{\text {in }}=0.5 \sim \mathrm{~V}_{\text {cc }}-0.5 \mathrm{~V}$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Output "High" Voltage | All Outputs | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  |  |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{cc}}-0.7$ | - | - | V |
| Output "Low" Voltage | All Outputs | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | - | 0.55 | V |
| Input Capacitance | All Inputs | $\mathrm{C}_{\text {in }}$ | $\begin{aligned} & \mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{f}=1.0 \mathrm{MHz}, \\ & \mathrm{Ta}=25^{\circ} \mathrm{C} \end{aligned}$ | - | - | 12.5 | pF |
| Standby Current | Non Operation | $\mathrm{I}_{\mathrm{cc}}$ |  | - | 2.0 | 15.0 | $\mu \mathrm{A}$ |
| Current Dissipation* |  | ${ }^{\text {cc }}$ | Operating (f=1 $\mathrm{MHz}^{* *}$ ) | - | 6,0 | 10.0 | mA |
|  |  | Sleeping ( $\mathrm{f}=1 \mathrm{MHz}^{* *}$ ) | - | 1.0 | 2.0 |  |  |
| RAM Stand-By Voltage |  |  | $\mathrm{V}_{\text {RAM }}$ |  | 2.0 | - | - | V |

- $\mathrm{V}_{\text {IH }} \min =\mathrm{V}_{\mathrm{CC}}-1.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}$ max $=0.8 \mathrm{~V}$
** Current Dissipation of the operating or sleeping condition is proportional to the operating frequency. So the typ. or max. values about Current Dissipations at $\mathrm{f}=\boldsymbol{x} \mathbf{M H z}$ operation are decided according to the following formula;
typ. value $(f=x \mathrm{MHz})=$ typ. value $(\mathrm{f}=1 \mathrm{MHz}) \times x$
max. value $(f=x M H z)=\max$, value $(f=1 M H z) \times x$
(both the sleeping and operating)
- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

BUS TIMING

| Item |  |  | Symbol | Test Condition | HD6303R |  |  | HD63A03R |  |  | HD63B03R |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Cycle Time |  |  |  | $\mathrm{t}_{\text {cyc }}$ | Fig. 1 <br> Fig. 2 | 1 | - | 10 | 0.666 | - | 10 | 0.5 | - | 10 | $\mu \mathrm{s}$ |
| Address Strobe Pulse Width * "High" |  |  | PW ${ }_{\text {ASH }}$ | 220 |  | - | - | 150 | - | - | 110 | - | - | ns |
| Address Strobe Rise Time |  |  | $\mathrm{t}_{\text {ASr }}$ | - |  | - | 20 | - | - | 20 | - | - | 20 | ns |
| Address Strobe Fall Time |  |  | $\mathrm{t}_{\text {ASf }}$ | - |  | - | 20 | - | - | 20 | - | - | 20 | ns |
| Address Strobe Delay Time * |  |  | $t_{\text {ASO }}$ | 60 |  | - | - | 40 | - | - | 20 | - | - | ns |
| Enable Rise Time |  |  | $\mathrm{t}_{\mathrm{Er}}$ | - |  | - | 20 | - | - | 20 | - | - | 20 | ns |
| Enable Fall Time |  |  | $\mathrm{t}_{\mathrm{E}+}$ | - |  | - | 20 | - | - | 20 | - | - | 20 | ns |
| Enable Pulse Width "High" Level* |  |  | $\mathrm{PW}_{\text {EH }}$ | 450 |  | - | - | 300 | - | - | 220 | - | - | ns |
| Enable Pulse Width "Low" Level* |  |  | $\mathrm{PW}_{\mathrm{EL}}$ | 450 |  | - | - | 300 | - | - | 220 | - | - | ns |
| Address Strobe to Enable Delay* Time |  |  | $\mathrm{t}_{\text {ASED }}$ | 60 |  | - | - | 40 | - | - | 20 | - | - | ns |
| Address Delay Time |  |  | $t_{A D 1}$ | - |  | - | 250 | - | - | 190 | - | - | 160 | ns |
|  |  |  | $\mathrm{t}_{\text {AD2 }}$ | - |  | - | 250 | - | - | 190 | - | - | 160 | ns |
| Address Delay Time for Latch* |  |  | $\mathrm{t}_{\text {ADL }}$ | - |  | - | 250 | - | - | 190 | - | - | 160 | ns |
| Data Set-up Time |  | Write | ${ }^{\text {t }}$ DSW | 230 |  | - | - | 150 | - | - | 100 | - | - | ns |
|  |  | Read | $\mathrm{t}_{\text {DSR }}$ | 80 |  | - | - | 60 | - | - | 50 | - | - | ns |
| Data Hold Time |  | Read | $t_{\text {HR }}$ | 0 |  | - | - | 0 | - | - | 0 | - | - | ns |
|  |  | Write | $\mathrm{t}_{\text {HW }}$ | 20 |  | - | - | 20 | - | - | 20 | - | - | ns |
| Address Set-up Time for Latch* |  |  | $t_{\text {ASL }}$ | 60 |  | - | - | 40 | - | - | 20 | - | - | ns |
| Address Hold Time for Latch |  |  | $t_{\text {AHL }}$ | 30 |  | - | - | 20 | - | - | 20 | - | - | ns |
| Address Hold Time |  |  | $t_{\text {th }}$ | 20 |  | - | - | 20 | - | - | 20 | - | - | ns |
| $A_{0} \sim A_{7}$ Set-up Time Before $E^{*}$ |  |  | $\mathrm{t}_{\text {ASM }}$ | 200 |  | - | - | 110 | - | - | 60 | - | - | ns |
| Peripheral Read Access Time | NonBus | ultiplexed | $\left(t_{\text {ACCN }}\right)$ | - |  | - | 650 | - | - | 395 | - | - | 270 | ns |
|  | Multi | exed Bus* | $\left(t_{\text {ACcm }}\right)$ | - |  | - | 650 | - | - | 395 | - | - | 270 | ns |
| Oscillator stabilization Time |  |  | $\mathrm{t}_{\text {RC }}$ | Fig. 8 | 20 | - | - | 20 | - | - | 20 | - | - | ms |
| Processor Control Set-up Time |  |  | $t_{\text {Pcs }}$ | Fig. 9 | 200 | - | - | 200 | - | - | 200 | - | - | ns |

*These timings change in approximate proportion to $t_{c y c}$. The figures in this characteristics represent those when $t_{\text {cyc }}$ is minimum (= in the highest speed operation).

## PERIPHERAL PORT TIMING

| Item |  |  | Symbol | Test Condition | HD6303R |  |  | HD63A03R |  |  | HD63B03R |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Peripheral Data Set-up Time | Port 1, 2 |  |  | tpdsu $^{\text {d }}$ | Fig. 3 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Peripheral Data Hold Time | Port 1, 2 |  | ${ }^{\text {tPDH }}$ | Fig. 3 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Delay Time, Enable Negative Transition to Peripheral Data Valid |  | $\begin{array}{\|l\|} \hline \text { Port 1, } \\ 2^{*} \end{array}$ | $t_{\text {PWO }}$ | Fig. 4 | - | - | 300 | - | - | 300 | - | - | 300 | ns |

* Except $P_{21}$

TIMER, SCI TIMING

| Item | Symbol | Test Condition | HD6303R |  |  | HD63A03R |  |  | HD63B03R |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| Timer Input Pulse Width | $\mathrm{t}_{\text {PWT }}$ |  | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| Delay Time, Enable Positive Transition to Timer Out | ${ }_{\text {t }}^{\text {tod }}$ | Fig. 5 | - | - | 400 | - | - | 400 | - | - | 400 | ns |
| SCI Input Clock Cycle | $\mathrm{t}_{\text {Scyc }}$ |  | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| SCI Input Clock Pulse Width | $\mathrm{t}_{\text {Pwsck }}$ |  | 0.4 | - | 0.6 | 0.4 | - | 0.6 | 0.4 | - | 0.6 | $\mathrm{t}_{\text {scyc }}$ |

MODE PROGRAMMING

| Item | Symbol | Test Condition | HD6303R |  |  | HD63A03R |  |  | HD63B03R |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| RES "Low" Pulse Width | PW ${ }_{\text {RSTL }}$ | Fig. 6 | 3 | - | - | 3 | - | - | 3 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| Mode Programming Set-up Time | $\mathrm{t}_{\text {MPS }}$ |  | 2 | - | - | 2 | - | - | 2 | - | - | trye |
| Mode Programming Hold Time | $\mathrm{t}_{\text {MPH }}$ |  | 150 | - | - | 150 | - | - | 150 | - | - | ns |





Figure 7 Bus Timing Test Loads (TTL Load)


Figure 8 Interrupt Sequence


Figure 9 Reset Timing

## - FUNCTIONAL PIN DESCRIPTION

- $\mathbf{V}_{\mathbf{C C}}, \mathbf{V}_{\mathbf{S S}}$

These two pins are used for power supply and GND. Recommended power supply voltage is $5 \mathrm{~V} \pm 10 \% .3$ to 6 V can be used for low speed operation ( $100 \sim 500 \mathrm{kHz}$ ).

- XTAL, EXTAL

These two pins are connected with parallel resonant funda-
mental crystal, AT cut. For instance, in order to obtain the system clock 1 MHz , a 4 MHz resonant fundamental crystal is used because the devide-by- 4 circuitry is included. An example of the crystal interface is shown in Fig. 10. EXTAL accepts an external clock input of duty $45 \%$ to $55 \%$ to drive. For external clock, XTAL pin should be open. The crystal and capacitors should be mounted as close as possible to the pins.


Figure 10 Crystal Interface

- Standby ( $\overline{\text { STBY }}$ )

This pin is used to place the MPU in the standby mode. If this goes to "Low" level, the oscillation stops, the internal clock is tied to $\mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\text {CC }}$ and the MPU is reset. In order to retain information in RAM during standby, write " 0 " into RAM enable bit (RAME). RAME is bit 6 of the RAM Control Register at address $\$ 0014$. This disables the RAM, so the contents of RAM is guaranteed. For details of the standby mode, see the Standby section.

## - Reset (RES)

This input is used to reset the MPU. RES must be held "Low" for at least 20 ms when the power starts up. It should be noted that, before clock generator stabilize, the internal state and I/O ports are uncertain, because MPU can not be reset without clock. To reset the MPU during system operation, it must be held "Low" for at least 3 system clock cycles. From the third cycle, all address buses become "high-impedance" and it continues while RES is "Low". If RES goes to "High", CPU does the following.
(1) I/O Port 2 bits $2,1,0$ are latched into bits PC2, PC1, PC0 of program control register.
(2) The contents of the two Start Addresses, \$FFFE, \$FFFF are brought to the program counter, from which program starts (see Table 1).
(3) The interrupt mask bit is set. In order to have the CPU recognize the maskable interrupts $\overline{\mathbb{R Q}_{1}}$ and $\overline{\mathrm{IR} Q_{2}}$, clear it before those are used.

## - Enable (E)

This output pin supplies system clock. Output is a singlephase, TTL compatible and $1 / 4$ the crystal oscillation frequency. It will drive two LS TTL load and 40 pF capacitance.

## - Non Maskable Interrupt (NMI)

When the falling edge of the input signal of this pin is recognized, NMI sequence starts. The current instruction is continued to complete, even if NMI signal is detected. Interrupt mask bit in Condition Code Register has no effect on NMI detection. In response to NMI interrupt, the information of Program Counter, Index Register, Accumulators, and Condition Code Register are stored on the stack. On completion of this sequence, vectoring address $\$$ FFFC and $\$$ FFFD are generated to load the contents to the program counter. Then the CPU branch to a non maskable interrupt service routine.

- Interrupt Request ( $\overline{\mathbf{R} \mathbf{Q}_{1}}$ )

This level sensitive input requests a maskable interrupt sequence. When IRQ ${ }_{1}$ goes to "Low", the CPU waits until it completes the current instruction that is being executed. Then, if the interrupt mask bit in Condition Code Register is not set, CPU begins interrupt sequence; otherwise, interrupt request is neglected.

Once the sequence has started, the information of Program Counter, Index Register, Accumulator, Condition Code Register are stored on the stack. Then the CPU sets the interrupt mask bit so that no further maskable interrupts may be responded.


At the end of the cycle, the CPU generates 16 bit vectoring addresses indicating memory addresses \$FFF8 and \$FFF9, and loads the contents to the Program Counter, then branch to an interrupt service routine.

The Internal Interrupt will generate signal ( $\overline{\operatorname{IRQ}}{ }_{2}$ ) which is quite the same as $\overline{R_{R}}{ }_{1}$ except that it will use the vector address \$FFF0 to \$FFF7.
When $\overline{\mathrm{IRQ}}$ 1 and $\overline{\mathrm{IRQ}} \mathbf{2}_{2}$ are generated at the same time, the former precedes the latter. Interrupt Mask Bit in the condition code register, if being set, will keep the both interrupts off.

On occurrence of Address error or Op-code error, TRAP interrupt is invoked. This interrupt has priority next to RES. Regardless of the interrupt Mask Bit condition, the CPU will start an interrupt sequence. The vector for this interrupt will be \$FFEE, \$FFEF.

## - Read/Write (R/WV)

This TTL compatible output signals peripheral and memory devices whether CPU is in Read ("High"), or in Write ("Low"). The normal stand-by state is Read ("High"). Its output will drive one TTL load and 90 pF capacitance.

## - Address Strobe (AS)

In the multiplexed mode, address strobe signal appears at this pin. It is used to latch the lower 8 bits addresses multiplexed with data at $D_{0} / A_{0} \sim D_{7} / A_{7}$. The 8 -bit latch is controlled by address strobe as shown in Figure 15. Thereby, $\mathrm{D}_{0} / \mathrm{A}_{0} \sim \mathrm{D}_{7} / \mathrm{A}_{7}$ can become data bus during E pulse. The timing chart of this signal is shown in Figure 1.

Address Strobe (AS) is sent out even if the internal address is accessed.

## - PORTS

There are two I/O ports on HD6303R MPU (one 8-bit ports and one 5 -bit port). Each port has an independent write-only data direction register to program individual $1 / 0$ pins for input or output.*

When the bit of associated Data Direction Register is " 1 ", $\mathrm{I} / 0 \mathrm{pin}$ is programmed for output, if " 0 ", then programmed for

## an input.

There are two ports: Port 1, Port 2. Addresses of each port and associated Data Direction Register are shown in Table 2.

* Only one exception is bit 1 of Port 2 which becomes either a data input or a timer output. It cannot be used as an output port.

Table 2 Port and Data Direction Register Addresses

| Ports | Port Address | Data Direction <br> Register Address |
| :---: | :---: | :---: |
| I/O Port 1 | $\$ 0002$ | $\$ 0000$ |
| I/O Port 2 | $\$ 0003$ | $\$ 0001$ |

## - 1/O Port 1

This is an 8 -bit port, each bit being defined individually as input or outputs by associated Data Direction Register. The 8 -bit output buffers have three-state capability, maintaining in high impedance state when they are used for input. In order to be read accurately, the voltage on the input lines must be more than 2.0 V for logic " 1 " and less than 0.8 V for logic " 0 ".

These are TTL compatible. After the MPU has been reset, all I/O lines are configured as inputs in Multiplexed mode. In Non Multiplexed mode, Port 1 will be output line for lower order address lines ( $A_{0} \sim A_{7}$ ), which can drive one TTL load and 30 pF capacitance.

## - 1/O Port 2

This port has five lines, whose I/O direction depends on its data direction register. The 5 -bit output buffers have three-state capability, going high impedance state when used as inputs. In order to be read accurately, the voltage on the input lines must be more than 2.0 V for logic " 1 " and less than 0.8 V for logic " 0 ". After the MPU has been reset, $\mathrm{I} / \mathrm{O}$ lines are configured as inputs. These pins on Port $2\left(\mathrm{P}_{20} \sim \mathrm{P}_{22}\right.$ of the chip) are used to program the mode of operation during reset. The values of these three pins during reset are latched into the upper 3 bits (bit 7, 6 and 5) of Port 2 Data Register which is explained in the MODE SELECTION section.

In all modes, Port 2 can be configured as I/O lines. This port also provides access to the Serial I/O and the Timer. However, note that bit $1\left(P_{21}\right)$ is the only pin restricted to data input or Timer output.

## - BUS

- $D_{0} / A_{0} \sim D_{7} / A_{7}$

This TTL compatible three-state buffer can drive one TTL load and 90 pF capacitance.
Non Multiplexed Mode
In this mode, these pins become only data bus ( $D_{0} \sim D_{7}$ ). Multiplexed Mode

These pins becomes both the data bus ( $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ ) and lower bits of the address bus $\left(A_{0} \sim A_{7}\right)$. An address strobe output is "High" when the address is on the pins.

- $A_{8} \sim A_{15}$

Each line is TTL compatible and can drive one TTL load and 90 pF capacitance. After reset, these pins become output for upper order address lines ( $\mathrm{A}_{8} \sim \mathrm{~A}_{15}$ ).

## - MODE SELECTION

The operation mode after the reset must be determined by the user wiring the $P_{20}, P_{21}$, and $P_{22}$ externally. These three pins are lower order bits; I/O 0, I/O 1, I/O 2 of Port 2. They are latched into the control bits PC0, PC1, PC2 of I/O Port 2 register when RES goes "High". I/O Port 2 Register is shown below.

## Port 2 DATA REGISTER



An example of external hardware used for Mode Selection is shown in Figure 11. The HD14053B is used to separate the peripheral device from the MPU during reset. It is necessary if the data may conflict between peripheral device and Mode generation circuit.

No mode can be changed through software because the bits 5, 6, and 7 of Port 2 Data Register are read-only. The mode selection of the HD6303R is shown in Table 3.

The HD6303R operates in two basic modes: (1) Multiplexed Mode, (2) Non Multiplexed Mode.

## - Multiplexed Mode

The data bus and the lower order address bus are multiplexed in the $D_{0} / A_{0} \sim D_{7} / A_{7}$ and can be separated by the Address Strobe.

Port 2 is configured for 5 parallel I/O or Serial I/O, or Timer, or any combination thereof. Port 1 is configured for $\mathbf{8}$ parallel I/O.

## - Non Multiplexed Mode

In this mode, the HD6303R can directly address HMCS6800 peripherals with no address latch. $D_{0} / A_{0} \sim D_{7} / A_{7}$ become a data bus and Port 1 becomes $A_{0} \sim A_{7}$ address bus.

In this mode, the HD6303R is expandable up to 65k bytes with no address latch.

## - Lower Order Address Bus Latch

Because the data bus is multiplexed with the lower order address bus in $D_{0} / A_{0} \sim D_{7} / A_{7}$ in the multiplexed mode, address bits must be latched. It requires the 74LS373 Transparent octal D-type to latch the LSB. Latch connection of the HD6303R is shown in Figure 15.

2) RC』Reset Constant
3) $R_{1}=10 \mathrm{k} \Omega$

Figure 11 Recommended Circuit for Mode Selection


| Truth Table |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Control Input |  |  |  | On Switch |  |
| Inhibit | Select |  |  |  |  |
|  | C | 8 | A | HD140538 |  |
| 0 | 0 | 0 | 0 | $z_{0}$ | $Y_{0} x_{0}$ |
| 0 | 0 | 0 | 1 | $z_{0}$ | $Y_{0} \mathrm{Y}_{1} \mathrm{X}_{1}$ |
| 0 | 0 | 1 | 0 | $Z_{0}$ | $y_{1} x_{0}$ |
| 0 | 0 | 1 | 1 | $z_{0}$ | $Y_{1} x_{1}$ |
| 0 | 1 | 0 | 0 | $z_{1}$ | $r_{0} x_{0}$ |
| 0 | 1 | 0 | 1 | $z_{1}$ | $r_{0} r_{1} x_{1}$ |
| 0 | 1 | 1 | 0 | $z_{1}$ | $r_{1}{ }_{1} x_{0}$ |
| 0 | 1 | 1 | 1 | $\mathbf{z}_{1}$ | $r_{1}{ }^{\prime} x_{1}$ |
| 1 | x | x | x |  |  |

Figure 12 HD14053B Multiplexers/De-Multiplexers


Figure 13 HD6303R MPU Multiplexed Mode


Figure 14 HD6303R MPU Non Multiplexed Mode


Figure 15 Latch Connection

Table 3 Mode Selection

| Operating Mode | $\mathrm{P}_{\mathbf{2 0}}$ | $\mathrm{P}_{\mathbf{2 1}}$ | $\mathrm{P}_{\mathbf{2 2}}$ |
| :--- | :---: | :---: | :---: |
| Multiplexed Mode | L | H | L |
|  | L | L | H |
| Non Multiplexed Mode | H | L | L |

$L$ : logic " 0 "
H: logic "1"

## - MEMORY MAP

The MPU can provide up to 65 k byte address space. Figure 16 shows a memory map for each operating mode. The first 32 locations of each map are for the CPU's internal register only, as shown in Table 4.

Table 4 Internal Register Area

| Register | Address |
| :--- | :---: |
| Port 1 Data Direction Register*** | $00^{*}$ |
| Port 2 Data Direction Register** | 01 |
| Port 1 Data Register | $00^{*}$ |
| Port 2 Data Register | 03 |
| Timer Control and Status Register | 08 |
| Counter (High Byte) | 09 |
| Counter (Low Byte) | $0 A$ |
| Output Compare Register (High Byte) | $0 B$ |
| Output Compare Register (Low Byte) | $0 C$ |
| Input Capture Register (High Byte) | 00 |
| Input Capture Register (Low Byte) | $0 E$ |
| Rate and Mode Control Register | 10 |
| Transmit/Receive Control and Status Register | 11 |
| Receive Data Register | 12 |
| Transmit Data Register | 13 |
| RAM Control Register | 14 |
| Reserved | $15-1 F$ |

* External address in Non Multiplexed Mode
* 1 = Output, $0=$ Input


Figure 16 HD6303R Memory Maps

## - PROGRAMMABLE TIMER

The HD6303R contains 16-bit programmable timer which may measure input waveform. In addition to that it can generate an output waveform by itself. For both input and output waveform, the pulse width may vary from a few microseconds to several seconds.
The timer hardware consists of

- an 8-bit control and status register
- a 16 -bit free running counter
- a 16 -bit output compare register
- a 16 -bit input capture register

A block diagram of the timer is shown in Figure 17.


Figure 17 Programmable Timer Block Diagram

- Free Running Counter (\$0009: \$000A)

The key element in the programmable timer is a 16 -bit free running counter, that is driven by an E (Enable) clock to increment its values. The counter value will be read out by the CPU software at any time with no effects on the counter. Reset will clear the counter.

When the MSB of this counter is read, the LSB is stored in temporary latch. The data is fetched from this latch by the subsequent read of LSB. Thus consistent double byte data can be read from the counter.

When the CPU writes arbitrary data to the MSB (\$09), the value of \$FFF8 is being pre-set to the counter ( $\$ 09, \$ 0 \mathrm{~A}$ ) regardless of the write data value. Then the CPU writes arbitrary data to the LSB (\$0A), the data is set to the "Low" byte of the counter, at the same time, the data preceedingly written in the MSB (\$09) is set to "High" byte of the counter.

When the data is written to this counter, a double byte store instruction (ex. STD) must be used. If only the MSB of counter is written, the counter is set to \$FFF8.

The counter value written to the counter using the double byte store instruction is shown in Figure 18.

To write to the counter can disturb serial operations, so it should be inhibited during using the SCI. If external clock mode is used for SCI, this will not disturb serial operations.

(5AF3 written to the counter)
Figure 18 Courter Write Timing

- Output Compare Register ( $\mathbf{\$ 0 0 0 B} \mathbf{\$ 0 0 0 C}$ )

This is a 16 -bit read/write register which is used to control an output waveform. The contents of this register are constantly being compared with current value of the free running counter.

When the contents match with the value of the free running counter, a flag (OCF) in the timer control/status register (TCSR) is set and the current value of an output level Bit (OLVL) in the TCSR is transferred to Port 2 bit 1 . When bit 1 of the Port 2 data direction register is " 1 " (output), the OLVL value will appear on the bit 1 of Port 2 . Then, the value of Output Compare Register and Output level bit may be changed for the next compare.

The output compare register is set to \$FFFF during reset.
The compare function is inhibited at the cycle of writing to the high byte of the output compare register and at the cycle just after that to ensure valid compare. It is also inhibited in same manner at writing to the free running counter.

In order to write a data to Output Compare Register, a double byte store instruction (ex.STD) must be used.

## - Input Capture Register (\$000D: \$000E)

The input capture register is a 16 -bit read-only register used to hold the current value of free running counter captured when the proper transition of an external input signal occurs.

The input transition change required to trigger the counter transfer is controlled by the input edge bit (IEDG).

To allow the external input signal to go in the edge detect unit, the bit of the Data Direction Register corresponding to bit 0 of Port 2 must have been cleared (to zero).

To insure input capture in all cases, the width of an input pulse requires at least 2 Enable cycles.

## - Timer Control/Status Register (TCSR) (\$0008)

This is an 8 -bit register. All 8 -bits are readable and the lower 5 bits may be written. The upper 3 bits are read-only, indicating the timer status information as is shown below.
(1) A proper transition has been detected on the input pin (ICF).
(2) A match has been found between the value in the free running counter and the output compare register (OCF).
(3) When counting up to $\$ 0000$ (TOF).

Each flag has an individual enable bit in TCSR which determines whether or not an interrupt request may occur (IRQ2). If the I-bit in Condition Code Register has been cleared, a prior vectored address occurs corresponding to each flag. A description of each bit is as follows.

Timer Control / Status Register


Bit 0 OLVL (Output Level); When a match is found in the value between the counter and the output com-
pare register, this bit is transferred to the Port 2 bit 1 . If the DDR corresponding to Port 2 bit 1 is set " 1 ", the value will appear on the output pin of Port 2 bit 1 .
Bit 1 IEDG (Input Edge): This bit control which transition of an input of Port 2 bit 0 will trigger the data transfer from the counter to the input capture register. The DDR corresponding to Port 2 bit 0 must be clear in advance of using this function.
When IEDG $=0$, trigger takes place on a negative edge ("High"-to-"Low" transition). When IEDG = 1, trigger takes place on a positive edge ("Low"-to"High" transition).
Bit 2 ETOI (Enable Timer Overflow Interrupt); When set, this bit enables TOF interrupt to generate the interrupt request ( $\overline{\mathrm{IRQ}}{ }_{2}$ ). When cleared, the interrupt is inhibited.
Bit 3 EOCI (Enable Output Compare Interrupt); When set, this bit enables OCF interrupt to generate the interrupt request ( $\mathrm{IRQ}_{2}$ ). When cleared, the interrupt is inhibited.
Bit 4 EICI (Enable Input Capture Interrupt); When set, this bit enables ICF interrupt to generate the interrupt request (IRQ ${ }_{2}$ ). When cleared, the interrupt is inhibited.
Bit 5 TOF (Timer Over Flow Flag); This read-only bit is set at the transition of $\$$ FFFF to $\$ 0000$ of the counter. It is cleared by CPU read of TCSR (with TOF set) followed by a CPU read of the counter (\$0009).
Bit 6 OCF (Output Compare Flag); This read-only bit is set when a match is found in the value between the output compare register and the counter. It is cleared by a read of TCSR (with OCF set) followed by a CPU write to the output compare register ( $\$ 000 \mathrm{~B}$ or $\$ 000 \mathrm{C}$ ).
Bit 7 ICF (Input Capture Flag); The read-only bit is set by a proper transition on the input, and is cleared by a read of TCSR (with ICF set) followed by a CPU read of Input Capture Register (\$000D)
Reset will clear each bit of Timer Control and Status Register.

## - SERIAL COMMUNICATION INTERFACE

The HD6303R contains a full-duplex asynchronous Serial Communication Interface (SCI). SCI may select the several kinds of the data rate. It consists of a transmitter and a receiver which operate independently but with the same data format and the same data rate. Both of transmitter and receiver communicate with the CPU via the data bus and with the outside world through Port 2 bit 2,3 and 4 . Description of hardware, software and register is as follows.

## - Wake-Up Feature

In typical multiprocessor applications the software protocol will usually have the designated address at the initial byte of the message. The purpose of Wake-Up feature is to have the nonselected MPU neglect the remainder of the message. Thus the non-selected MPU can inhibit the all further interrupt process until the next message begins.

Wake-Up feature is re-enabled by a ten consecutive "l"s which indicates an idle transmit line. Therefore software protocol must put an idle period between the messages and must prevent it within the message.

With this hardware feature, the non-selected MPU is reenabled (or "waked-up") by the next message.

## - Programmable Options

The HD6303R has the following programmable features.

- data format; standard mark/space (NRZ)
- clock source; external or internal
- baud rate; one of 4 rates per given E clock frequency or 1/8 of external clock
- wake-up feature; enabled or disabled
-interrupt requests; enabled or masked individually for transmitter and receiver
- clock output; internal clock enabled or disabled to Port 2 bit 2
- Port 2 (bits 3, 4); dedicated or not dedicated to serial I/O individually


## - Serial Communication Hardware

The serial communications hardware is controlled by 4 registers as shown in Figure 19. The registers include:

- an 8 -bit control/status register
- a 4-bit rate/mode control register (write-only)
- an 8 -bit read-only receive data register
- an 8 -bit write-only transmit data register

Besides these 4 registers, Serial I/O utilizes Port 2 bit 3 (input) and bit 4 (output). Port 2 bit 2 can be used when an option is selected for the internal-clock-out or the external-clock-in.

## - Transmit/Keceive Control Status Register (TRCSR)

TRCS Register consists of 8 bits which all may be read while only bits 0 to 4 may be written. The register is initialized to $\$ 20$ on RES. The bits of the TRCS Register are explained below.


Bit 0 WU (Wake Up); Set by software and cleared by hardware on receipt of ten consecutive " 1 "s. While this bit is " 1 ", RDRF and ORFE flags are not set even if data are received or errors are detected. Therefore received data are ignored. It should be noted that RE flag must have already been set in advance of WU flag's set.
Bit 1 TE (Transmit Enable); This bit enables transmitter. When this bit is set, bit 4 of Port 2 DDR is also forced to be set. It remains set even if TE is cleared. Preamble of ten consecutive " 1 " $s$ is transmitted just after this bit is set, and then transmitter becomes ready to send data. If this bit is cleared, the transmitter is disabled and serial I/O affects nothing on Port 2 bit 4.
Bit 2 TIE (Transmit Interrupt Enable); When this bit is set, TDRE (bit 5) causes an $\overline{I R Q_{2}}$ interrupt. When cleared, TDRE interrupt is masked.
Bit 3 RE (Receive Enable); When set, Port 2 bit 3 can be used as an input of receive regardless of DDR value for this bit. When cleared, the receiver is disabled.
Bit 4 RIE (Receive Interrupt Enable); When this bit is set, KDRF (bit 7) or ORFE (bit 6) cause an $\mathrm{IRQ}_{2}$ interrupt. When cleared, this interrupt is masked.

Bit 5 TDRE (Transmit Data Register Empty); When the data is transferred from the Transmit Data Register to Output Shift Register, this bit is set by hardware. The bit is cleared by reading the status register followed by writing the next new data into the Transmit Data Register. TDRE is initialized to 1 by RES.
Bit 6 ORFE (Over Run Framing Error); When overrun or framing error occurs (receive only), this bit is set by hardware. Over Run Error occurs if the attempt is made to transfer the new byte to the receive data register while the RDRF is " 1 ". Framing Error occurs when the bit counter is not synchronized with the boundary of the byte in the re-
ceiving bit stream. When Framing Error is detected, RDRF is not set. Therefore Framing Error can be distinguished from Overrun Error. That is, if ORFE is " 1 " and RDRF is " 1 ", Overrun Error is detected. Otherwise Framing Error occurs. The bit is cleared by reading the status register followed by reading the receive data register, or by RES.
Bit 7 RDRF (Receive Data Register Full); This bit is set by hardware when the data is transferred from the receive shift register to the receive data register. It is cleared by reading the status register followed by reading the receive data register, or by RES.


Figure 19 Serial I/O Register


Table 5 SCI Bit Times and Transfer Rates

|  |  | XTAL | 2.4576 MHz | 4.0 MHz | 4.9152 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SS1 | SSO | $E$ | 614.4 kHz | 1.0 MHz | 1.2288 MHz |
| 0 | 0 | $E \div 16$ | $26 \mu \mathrm{~s} / 38,400$ Baud | $16 \mu \mathrm{~s} / 62,500$ Baud | $13 \mu \mathrm{~s} / 76.8008$ aud |
| 0 | 1 | $E \div 128$ | $208 \mu \mathrm{~s} / 4,800$ Baud | $128 \mu \mathrm{~s} / 7812.5$ Baud | $104.2 \mu \mathrm{~s} / 9.600$ Boud |
| 1 | 0 | $E \div 1024$ | $1.67 \mathrm{~ms} / 600$ Baud | $1.024 \mathrm{~ms} / 976.6$ Baud | $833.3 \mu \mathrm{~s} / 1.2008$ aud |
| 1 | 1 | $E \div 4096$ | $6.67 \mathrm{~ms} / 150$ Baud | $4.096 \mathrm{~ms} / 244.1$ Baud | $3.333 \mathrm{~ms} / 3008$ oud |

Table 6 SCI Format and Clock Source Control

| CC1: CCO | Format | Clock Source | Port 2 Bit 2 | Port 2 Bit 3 | Port 2 Bit 4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | - | - | - | - |  |
| 0 | 1 | NRZ | Internal | Not Used*** | $\ldots$ | $\ldots$ |
| 1 | 0 | NRZ | Internal | Output | $\ldots$ | $\ldots$ |
| 1 | 1 | NRZ | External | Input | $\ldots$ | $\ldots$ |

- Clock output is available regardless of values for bits RE and TE.
* Bit 3 is used for serial input if RE $={ }^{*} 1$ " in TRCS. Bit 4 is used for serial output if TE $=" 1$ " in TRCS.
*** This pin can be used as $1 / 0$ port.


## - Transfer Rate/Mode Control Register (RMCR)

The register controls the following serial I/O functions:

- Bauds rate -data format - clock source
- Port 2 bit 2 feature

It is 4 -bit write-only register, cleared by RES. The 4 bits are considered as a pair of 2 -bit fields. The lower 2 bits control the bit rate of internal clock while the upper 2 bits control the format and the clock select logic.

## Bit 0 SSO <br> Bit 1 SS1 \} Speed Select

These bits select the Baud rate for the internal clock. The rates selectable are function of $\mathbf{E}$ clock frequency of the CPU . Table 5 lists the available Baud Rates.

## $\left.\begin{array}{l}\mathrm{Bit} 2 \mathrm{CCO} \\ \text { Bit }\end{array}\right\}$ <br> Bit 3 CC 1$\}$ <br> Clock Control/Format Select

They control the data format and the clock select logic. Table 6 defines the bit field.

## - Internally Generated Clock

If the user wish to use externally an internal clock of the serial $\mathrm{I} / \mathrm{O}$, the following requirements should be noted.

- CC1, CC0 must be set to " 10 ".
-The maximum clock rate must be $\mathrm{E} / 16$.
- The clock rate is equal to the bit rate.
-The values of RE and TE have no effect.


## - Externally Generated Clock

If the user wish to supply an external clock to the Serial I/O, the following requirements should be noted.

- The CC1, CC0 must be set to " 11 " (See Table 6).
- The external clock must be set to 8 times of the desired baud rate.
-The maximum external clock frequency is $\mathrm{E} / 2$ clock.


## - Serial Operations

The serial I/O hardware must be initialized by the software before operation. The sequence will be normally as follows.

- Writing the desired operation control bits of the Rate and Mode Control Register.
- Writing the desired operation control bits of the TRCS register.
If Port 2 bit 3, 4 are used for serial I/O, TE, RE bits may be kept set. When TE, RE bit are cleared during SCl operation, and subsequently set again, it should be noted that TE, RE must be kept " 0 " for at least one bit time of the current baud rate. If TE, RE are set again within one bit time, there may be the case where the initializing of internal function for transmitter and receiver does not take place correctly.


## - Transmit Operation

Data transmission is enabled by the TE bit in the TRCS
register. When set, the output of the transmit shift register is connected with Port 2 bit 4 which is unconditionally configured as an output.

After RES, the user should initialize both the RMC register and the TRCS register for desired operation. Setting the TE bit causes a transmission of ten-bit preamble of " 1 "s. Following the preamble, internal synchronization is established and the transmitter is ready to operate. Then either of the following states exists.
(1) If the transmit data register is empty (TDRE = 1), the consecutive " 1 "s are transmitted indicating an idle states.
(2) If the data has been loaded into the Transmit Data Register (TDRE $=0$ ), it is transferred to the output shift register and data transmission begins.
During the data transfer, the start bit (" 0 ") is first transferred. Next the 8 -bit data (beginning at bit 0 ) and finally the stop bit (" 1 "). When the contents of the Transmit Data Register is transferred to the output shift register, the hardware sets the TDRE flag bit: If the CPU fails to respond to the flag within the proper time, TDRE is kept set and then a continuous string of 1 's is sent until the data is supplied to the data register.

## - Receive Operation

The receive operation is enabled by the RE bit. The serial input is connected with Port 2 bit 3. The receiver operation is determined by the contents of the TRCS and RMC register. The received bit stream is synchronized by the first " 0 " (start bit). During 10 -bit time, the data is strobed approximately at the center of each bit. If the tenth bit is not " 1 " (stop bit), the system assumes a framing error and the ORFE is set.

If the tenth bit is " 1 ", the data is transferred to the receive data register, and the RDRF flag is set. If the tenth bit of the next data is received and still RDRF is preserved set, then ORFE is set indicating that an overrun error has occurred.

After the CPU read of the status register as a response to RDRF flag or ORFE flag, followed by the CPU read of the receive data register, RDRF or ORFE will be cleared.

## - RAM CONTROL REGISTER

The register assigned to the address $\$ 0014$ gives a status information about standby RAM.


Bit 0 Not used.
Bit 1 Not used.
Bit 2 Not used.

Bit 3 Not used.
Bit 4 Not usod.
Bit 5 Not used.
Bit 6 RAM Enable (RAME).
Using this control bit, the user can disable the RAM. RAM Enable bit is set on the positive edge of RES and RAM is enabled. The program can write " 1 " or " 0 ". If RAME is cleared, the RAM address becomes external address and the CPU may read the data from the outside memory.

## Bit 7 Standby Power Bit (STBY PWR)

This bit can be read or written by the user program. It is cleared when the $\mathrm{V}_{\mathrm{CC}}$ voltage is removed. Normally this bit is set by the program before going into stand-by mode. When the CPU recovers from stand-by mode, this bit should be checked. If it is " 1 ", the data of the RAM is retained during stand-by and it is valid.

## - GENERAL DESCRIPTION OF INSTRUCTION SET

The HD6303R has an upward object code compatible with the HD6801 to utilize all instruction sets of the HMCS6800. The execution time of the key instruction is reduced to increase the system through-put. In addition, the bit operation instruction, the exchange instruction between the index and the accumulator, the sleep instruction are added. This section describes:

- CPU programming model (See Fig. 20)
- Addressing modes
- Accumulator and memory manipulation instructions (See Table 7)
- New instructions
- Index register and stack manipulation instructions (See Table 8)
- Jump and branch instructions (See Table 9)
-Condition code register manipulation instructions (See Table 10)
- Op-code map (See Table 11)
- Cycle-by-cycle operation (See Table 12)


## - CPU Programming Model

The programming model for the HD6303R is shown in Figure 20 . The double accumulator is physically the same as the accumulator A concatenated with the accumulator $\mathbf{B}$, so that the contents of $A$ and $B$ is changed with executing operation of an accumulator $\mathbf{D}$.


Figure 20 CPU Programming Model

## - CPU Addressing Modes

The HD6303R has seven address modes which depend on both of the instruction type and the code. The address mode for
every instruction is shown along with execution time given in terms of machine cycles (Table 7 to 11). When the clock frequency is 4 MHz , the machine cycle will be microseconds. Accumulator (ACCX) Addressing

Only the accumulator ( $\mathbf{A}$ or $\mathbf{B}$ ) is addressed. Either accumulator $\mathbf{A}$ or $\mathbf{B}$ is specified by one-byte instructions.

## Immediate Addressing

In this mode, the operand is stored in the second byte of the instruction except that the operand in LDS and LDX, etc are stored in the second and the third byte. These are two or three-byte instructions.

## Direct Addressing

In this mode, the second byte of instruction indicates the address where the operand is stored. Direct addressing allows the user to directly address the lowest 256 bytes in the machine; locations zero through 255. Improved execution times are achieved by storing data in these locations. For system configuration, it is recommended that these locations should be RAM and be utilized preferably for user's data realm. These are two-byte instructions except the AIM, OIM, EIM and TIM which have three-byte.

## Extended Addrossing

In this mode, the second byte indicates the upper 8 bit addresses where the operand is stored, while the third byte indicates the lower 8 bits. This is an absolute address in memory. These are three-byte instructions.

## Indexed Addressing

In this mode, the contents of the second byte is added to the lower 8 bits in the Index Register. For each of AIM, OIM, EIM and TIM instructions, the contents of the third byte are added to the lower 8 bits in the Index Register. In addition, the resulting "carry" is added to the upper 8 bits in the Index Register. The result is used for addressing memory. Because the modified address is held in the Temporary Address Register, there is no change to the Index Register. These are two-byte instructions but AIM, OIM, EIM, TIM have three-byte.

## Implied Addressing

In this mode, the instruction itself gives the address; stack pointer, index register, etc. These are 1-byte instructions.

## Relative Addressing

In. this mode, the contents of the second byte is added to the lower 8 bits in the program counter. The resulting carry or borrow is added to the upper 8 bits. This helps the user to address the data within a range of -126 to +129 bytes of the current execution instruction. These are two-byte instructions.

Table 7 Accumulator, Memory Manipulation Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Booleen/ Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIRECT |  |  | INDEX |  |  | Extend |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | ~ | * | OP | $\sim$ | * | OP | $\sim$ | * | OP | ~ | * | OP | $\sim$ | * |  | H | 1 | N | 2 | $v$ | c |
| Add | ADDA | 88 | 2 | 2 | 98 | 3 | 2 | AB | 4 | 2 | B8 | 4 | 3 |  |  |  | $A+M \rightarrow A$ | 1 | $\bullet$ | 1 | 1 | 1 | 1 |
|  | ADDB | CB | 2 | 2 | D8 | 3 | 2 | EB | 4 | 2 | F8 | 4 | 3 |  |  |  | $B+M \rightarrow B$ | $t$ | - | 1 | $t$ | 1 | 1 |
| Add Dosble | ADDD | C3 | 3 | 3 | D3 | 4 | 2 | E3 | 5 | 2 | F3 | 5 | 3 |  |  |  | $A: B+M: M+1 \rightarrow A: B$ | $\bullet$ | - | 1 | $t$ | 1 | 1 |
| Add Accumulators | ABA |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 1 | 1 | $A+B \rightarrow A$ | 1 | - | 1 | $\pm$ | : | 1 |
| Add With Cerry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | B9 | 4 | 3 |  |  |  | $A+M+C \rightarrow A$ | 1 | $\bullet$ | \% | $t$ | : | 1 |
|  | ADCB | Co | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 |  |  |  | $B+M+C \rightarrow B$ | 1 | - | 1 | 1 | 1 | 1 |
| AND | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A 4 | 4 | 2 | B4 | 4 | 3 |  |  |  | $A \cdot M \rightarrow A$ | - | - | $t$ | $\pm$ | R | - |
|  | ANDB | Ca | 2 | 2 | D4 | 3 | 2 | EA | 4 | 2 | F4 | 4 | 3 |  |  |  | $B \cdot M \rightarrow B$ | - | - | 1 | $\pm$ | R | $\bullet$ |
| Bit Test | BIT A | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | B5 | 4 | 3 |  |  |  | A.M | $\bullet$ | - | \% | 1 | R | $\bullet$ |
|  | BIT B | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 |  |  |  | B.M | $\bullet$ | - | 1 | $t$ | R | $\bullet$ |
| Clear | CLR |  |  |  |  |  |  | $6 F$ | 5 | 2 | 7F | 5 | 3 |  |  |  | OO $\rightarrow$ M | $\bullet$ | - | R | 5 | R | R |
|  | CLRA |  |  |  |  |  |  |  |  |  |  |  |  | 4F | 1 | 1 | $00 \rightarrow A$ | $\bullet$ | - | R | S | R | R |
|  | CLR8 |  |  |  |  |  |  |  |  |  |  |  |  | 5 F | 1 | 1 | OO $\rightarrow$ B | $\bullet$ | - | A | S | R | R |
| Compere | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | B1 | 4 | 3 |  |  |  | A - M | $\bullet$ | - | 1 | 1 | 1 | 1 |
|  | CMPB | C1 | 2 | 2 | 01 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 |  |  |  | $B-M$ | - | - | 1 | $t$ | $t$ | 1 |
| Compere Accumulators | CRA |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 1 | 1 | A-8 | - | - | : | : | 1 | 1 |
| Complement, 1's | COM |  |  |  |  |  |  | 63 | 6 | 2 | 73 | 6 | 3 |  |  |  | $\overline{\mathrm{M}} \rightarrow \mathrm{M}$ | $\bullet$ | $\bullet$ | 1 | 1 | R | 5 |
|  | COMA |  |  |  |  |  |  |  |  |  |  |  |  | 43 | 1 | 1 | $\bar{A} \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $t$ | R | 5 |
|  | COMB |  |  |  |  |  |  |  |  |  |  |  |  | 53 | 1 | 1 | $\stackrel{-1}{B} \rightarrow B$ | - | - | 1 | 1 | R | S |
| Complement, 2's (Negate) | NEG |  |  |  |  |  |  | 60 | 6 | 2 | 70 | 6 | 3 |  |  |  | $00-\mathrm{M} \rightarrow \mathrm{M}$ | $\bullet$ | - | ? | 1 | (1) | (3) |
|  | NEGA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 1 | 1 | $00-A \rightarrow A$ | - | - | 1 | $t$ | (1) | (3) |
|  | NEGB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 1 | 1 | OO-B $\rightarrow$ B | $\bullet$ | - | 1 | $t$ | (1) | (3) |
| Decimal Adjust. A | DAA |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 | Converts binary add of BCD characters into BCD format | - | - | 1 | : | \% | (1) |
| Decrement | DEC |  |  |  |  |  |  | 6A | 6 | 2 | 7A | 6 | 3 |  |  |  | M - $1 \rightarrow M$ | - | - | 1 | $t$ | (1) | $\bullet$ |
|  | DECA |  |  |  |  |  |  |  |  |  |  |  |  | 4A | 1 | 1 | $A-1 \rightarrow A$ | $\bullet$ | - | 1 | 1 | (1) | $\bullet$ |
|  | DECB |  |  |  |  |  |  |  |  |  |  |  |  | 5A | 1 | 1 | $B-1 \rightarrow B$ | $\bullet$ | - | 1 | 1 | (a) | $\bullet$ |
| Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | 88 | 4 | 3 |  |  |  | $A \oplus M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | 1 | A | $\bullet$ |
|  | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | 78 | 4 | 3 |  |  |  | $B$ ¢ $) \mathrm{M} \rightarrow \mathrm{B}$ | $\bullet$ | : | 8 | 1 | R | $\bullet$ |
| Increment | INC |  |  |  |  |  |  | 6 C | 6 | 2 | 7 C | 6 | 3 |  |  |  | $M+1 \rightarrow M$ | $\bullet$ | - | 1 | $t$ | (1) | $\bullet$ |
|  | INCA |  |  |  |  |  |  |  |  |  |  |  |  | 4 C | 1 | 1 | $A+1 \rightarrow A$ | $\bullet$ | - | 8 | 1 | (1) | $\cdot$ |
|  | INCB |  |  |  |  |  |  |  |  |  |  |  |  | 5 C | 1 | 1 | $B+1 \rightarrow B$ | $\bullet$ | - | 1 | 1 | (1) | $\bullet$ |
| Loed Accumulator | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | 86 | 4 | 3 |  |  |  | $M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $t$ | A | $\bullet$ |
|  | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 |  |  |  | M $\rightarrow$ B | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Loed Double Accumulotor | LOD | CC | 3 | 3 | OC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 |  |  |  | $M+1 \rightarrow B, M \rightarrow A$ | - | - | 1 | $t$ | R | $\bullet$ |
| Multiply Unsigned | MUL |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 7 | 1 | $A \times B \rightarrow A: B$ | $\bullet$ | $\bullet$ | - | - | $\bullet$ | 11 |
| OR, Inclusive | ORAA | 8 A | 2 | 2 | 9 A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 |  |  |  | $A+M \rightarrow A$ | $\bullet$ | - | 1 | 1 | A | $\bullet$ |
|  | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 |  |  |  | $B+M \rightarrow B$ | $\bullet$ | $\bullet$ | $t$ | 1 | R | $\bullet$ |
| Push Date | PSHA |  |  |  |  |  |  |  |  |  |  |  |  | 36 | 4 | 1 | $A \rightarrow$ Msp, SP - $1 \rightarrow$ SP | $\bullet$ | - | - | - | - | ${ }^{\circ}$ |
|  | PSHB |  |  |  |  |  |  |  |  |  |  |  |  | 37 | 4 | 1 | $\mathrm{B} \rightarrow$ Msp, SP - $1 \rightarrow$ SP | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Pull Data | PULA |  |  |  |  |  |  |  |  |  |  |  |  | 32 | 3 | 1 | SP $+1 \rightarrow$ SP, M 4 P $\rightarrow$ A | $\bullet$ | - | - | $\bullet$ | $\bullet$ | ${ }^{\bullet}$ |
|  | PULB |  |  |  |  |  |  |  |  |  |  |  |  | 33 | 3 | 1 | SP $+1 \rightarrow$ SP, M 2 P $\rightarrow 8$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\stackrel{-}{\circ}$ |
| Rotate Left | ROL |  |  |  |  |  |  | 69 | 6 | 2 | 79 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | 1 | 1 | (1) | 1 |
|  | ROLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 1 | 1 |  | $\bullet$ | - | 1 | 8 | (1) | 1 |
|  | ROLB |  |  |  |  |  |  |  |  |  |  |  |  | 59 | 1 | 1 |  | $\bullet$ | - | 1 | 1 | (1) | 1 |
| Rotate Right | ROR |  |  |  |  |  |  | 66 | 6 | 2 | 76 | 6 | 3 |  |  |  |  | $\bullet$ | - | 1 | 8 | (1) | 1 |
|  | RORA |  |  |  |  |  |  |  |  |  |  |  |  | 46 | 1 | 1 |  | $\bullet$ | - | 1 | 8 | (1) | 1 |
|  | RORB |  |  |  |  |  |  |  |  |  |  |  |  | 56 | 1 | 1 |  | $\bullet$ | - | 1 | 8 | (a) | 1 |

Table 7 Accumulator, Memory Manipulation Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Booleen/ <br> Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | * | OP | $\sim$ | \# |  | H | 1 | N | 2 | V | C |
| Shift Left Arithmetic | ASL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  |  | $\bullet$ | - | 1 | 1 | (3) | 1 |
|  | ASLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 1 | 1 |  | - | - | 1 | 1 | (3) | 1 |
|  | ASLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 1 | 1 |  | - | - | 1 | 1 | (6) | 1 |
| Double Shift Left, Arithmetic | ASLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 1 | 1 |  | - | - | $t$ | * | O | 1 |
| Shift Right Arithmetic | ASR |  |  |  |  |  |  | 67 | 6 | 2 | 77 | 6 | 3 |  |  |  |  | - | - | $t$ | 1 | (3) | 1 |
|  | ASRA |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 1 | 1 |  | $\bullet$ | - | 1 | 1 | (B) | $\frac{1}{1}$ |
|  | ASRB |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 1 | 1 |  | - | - | 1 | $\ddagger$ | (6) | 1 |
| Shift Right Logical | LSR |  |  |  |  |  |  | 64 | 6 | 2 | 74 | 6 | 3 |  |  |  | $\left(\begin{array}{l} m \\ A \\ 0 \end{array}\right\}$ | - | - | A | 1 | (6) | 1 |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 1 | 1 |  | - | - | R | 1 | (6) | 1 |
|  | LSRB |  |  |  |  |  |  |  |  |  |  |  |  | 54 | 1 | 1 |  | - | - | R | $t$ | (6) | 1 |
| Double Shift Right Logical | LSRD |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 1 | 1 | $0 \rightarrow \square_{A 7 \quad A C C A / A C C E}^{\square A D}$ | - | - | R | * | (6) | $\ddagger$ |
| Store Accumulator | STAA |  |  |  | 97 | 3 | 2 | A7 | 4 | 2 | 87 | 4 | 3 |  |  |  | $A \rightarrow M$ | $\bullet$ | - | $t$ | $t$ | R | $\bullet$ |
|  | STAB |  |  |  | D7 | 3 | 2 | E7 | 4 | 2 | F7 | 4 | 3 |  |  |  | $B \rightarrow M$ | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Store Double Accumulator | STD |  |  |  | DD | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 |  |  |  | $\begin{aligned} & A \rightarrow M \\ & B \rightarrow M+1 \end{aligned}$ | - | - | $t$ | $t$ | R | - |
| Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | 80 | 4 | 3 |  |  |  | $A-M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $t$ | 1 | $\pm$ |
|  | SUBB | CO | 2 | 2 | DO | 3 | 2 | EO | 4 | 2 | FO | 4 | 3 |  |  |  | $B-M \rightarrow B$ | $\bullet$ | $\bullet$ | 1 | $t$ | 1 | $t$ |
| Double Subtract | SUBD | 83 | 3 | 3 | 93 | 4 | 2 | A3 | 5 | 2 | B3 | 5 | 3 |  |  |  | $A: B-M: M+1 \rightarrow A: B$ | - | - | 1 | 1 | 1 | $t$ |
| Subtrect Accumulators | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 1 | 1 | $A-B \rightarrow A$ | - | - | 1 | \% | $t$ | $t$ |
| Subtract With Carry | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | B2 | 4 | 3 |  |  |  | $A-M-C \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $t$ | 1 | $t$ |
|  | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C \rightarrow B$ | $\bullet$ | - | $t$ | $t$ | 1 | $t$ |
| Transfer Accumulators | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 1 | 1 | $A \rightarrow B$ | $\bullet$ | $\bullet$ | 1 | $t$ | R | $\bullet$ |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 1 | 1 | $B \rightarrow A$ | - | - | $t$ | 1 | R | $\bullet$ |
| Test Zaro or Minus | TST |  |  |  |  |  |  | 6D | 4 | 2 | 70 | 4 | 3 |  |  |  | $M-00$ | $\bullet$ | $\bullet$ | $\ddagger$ | 1 | R | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 1 | 1 | $A-00$ | $\bullet$ | - | $\pm$ | $t$ | R | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 1 | 1 | B-00 | $\bullet$ | - | $\pm$ | $t$ | R | R |
| And Immediate | AIM |  |  |  | 71 | 6 | 3 | 61 | 7 | 3 |  |  |  |  |  |  | $M \cdot I M M \rightarrow M$ | - | - | $\pm$ | 1 | R | $\bullet$ |
| OR Immediate | OIM |  |  |  | 72 | 6 | 3 | 62 | 7 | 3 |  |  |  |  |  |  | $M+I M M \rightarrow M$ | - | - | $\pm$ | $\ddagger$ | R | $\bullet$ |
| EOR Immediate | EIM |  |  |  | 75 | 6 | 3 | 65 | 7 | 3 |  |  |  |  |  |  | $M \oplus \mid M M \rightarrow M$ | - | - | $\pm$ | $\ddagger$ | R | $\bullet$ |
| Test Immediate | TIM |  |  |  | 78 | 4 | 3 | 68 | 5 | 3 |  |  |  |  |  |  | M.IMM | - | - | $t$ | 1 | R | - |

Note) Condition Code Register will be explained in Note of Table 10.

## - New Instructions

In addition to the HD6801 Instruction Set, the HD6303R has the following new instructions:
AIM --. (M) • (IMM) $\rightarrow$ (M)
Evaluates the AND of the immediate data and the memory, places the result in the memory.
OIM---- (M) $+($ IMM $) \rightarrow(M)$
Evaluates the OR of the immediate data and the memory, places the result in the memory.
EIM---(M) $\oplus($ IMM $) \rightarrow$ (M)
Evaluates the EOR of the immediate data and the memory, places the result in the memory.

TIM---(M) • (IMM)
Evaluates the AND of the immediate data and the memory, changes the flag of associated condition code register
Each instruction has three bytes; the first is op-code, the second is immediate data, the third is address modifier.
XGDX- $(\mathbf{A C C D}) \leftrightarrow$ (IX)
Exchanges the contents of accumulator and the index register.
SLP----The MPU is brought to the sleep mode. For sleep mode, see the "sleep mode" section.

Table 8 Index Register, Stack Manipulation Instructions

| Pointer Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | 2 | V | C |
| Compere Index Reg | CPX | 8 C | 3 | 3 | 9C | 4 | 2 | AC | 5 | 2 | BC | 5 | 3 |  |  |  | $X-M: M+1$ | $\bullet$ | $\bullet$ | $\pm$ | $t$ | I | $t$ |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 1 | 1 | $x-1 \rightarrow x$ | $\bullet$ | $\bullet$ | - | $t$ | $\bullet$ | $\bullet$ |
| Decrement Stack Pntr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 1 | 1 | SP - $1 \rightarrow$ SP | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 1 | 1 | $x+1 \rightarrow x$ | $\bullet$ | $\bullet$ | $\bullet$ | $t$ | $\bullet$ | $\bullet$ |
| Increment Stack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 1 | 1 | SP + $1 \rightarrow$ SP | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Loed Index Reg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 |  |  |  | M $\rightarrow X_{H}(M+1) \rightarrow X_{L}$ | $\bullet$ | $\bullet$ | (7) | 1 | A | $\bullet$ |
| Loed Stack Pntr | LDS | 8 E | 3 | 3 | 9E | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 |  |  |  | $M \rightarrow S P_{H},(M+1) \rightarrow S P_{L}$ | $\bullet$ | $\bullet$ | (7) | 1 | R | $\bullet$ |
| Store Index Reg | STX |  |  |  | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 |  |  |  | $X_{H} \rightarrow M_{,} X_{L} \rightarrow(M+1)$ | $\bullet$ | - | (7) | 1 | R | $\bullet$ |
| Store Stack Pntr | STS |  |  |  | 9F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 |  |  |  | SP ${ }_{H} \rightarrow M, S P_{L} \rightarrow(M+1)$ | - | - | (7) | 1 | R | $\bullet$ |
| Index Reg $\rightarrow$ Stack Pntr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 1 | 1 | $X-1 \rightarrow S P$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Steck Pntr $\rightarrow$ Index Reg | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 1 | 1 | SP $+1 \rightarrow X$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - |
| Add | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3 A | 1 | 1 | $\underline{B+X} \rightarrow \mathrm{X}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Push Data | PSHX |  |  |  |  |  |  |  |  |  |  |  |  | 3C | 5 | 1 | $\begin{aligned} & X_{L} \rightarrow M_{E P} . S P-1 \rightarrow S P \\ & X_{H} \rightarrow M_{\text {sp }} . S P-1 \rightarrow S P \end{aligned}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Pull Date | PULX |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 4 | 1 | $\begin{aligned} & S P+1 \rightarrow S P, M_{8 P} \rightarrow X_{H} \\ & S P+1 \rightarrow S P, M_{E P} \rightarrow X_{L} \end{aligned}$ | - | $\bullet$ | - | - | - | $\bullet$ |
| Exchange | XGDX |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 2 | 1 | ACCD $\sim 1 X$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ | - |

Note) Condition Code Register will be explained in Note of Table 10.

Table 9 Jump, Branch Instruction

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Branch Test | Condition Code Register |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | RELATIVE |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |  |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | * |  | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | 2 | V | C |  |
| Branch Always | BRA | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | None | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  |
| Branch Never | BRN | 21 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | None | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  |
| Branch If Carry Cleer | BCC | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{C}=0$ | $\bullet$ | - | - | - | $\bullet$ | $\bullet$ |  |
| Brench If Cerry Set | BCS | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $C=1$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |  |
| Branch If = Zero | BEQ | 27 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{Z}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  |
| Branch If $>$ Zero | BGE | 2C | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | N ¢ $\mathrm{V}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  |
| Branch If $>$ Zero | BGT | 2E | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | $\bullet$ | $\bullet$ | - | - | - | $\bullet$ |  |
| Branch If Higher | BHI | 22 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $C+z=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |  |
| Branch If < Zero | BLE | 2F | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N+V)=1$ | $\bullet$ | - | - | - | - | - |  |
| Branch If Lower Or Serne | BLS | 23 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $C+2=1$ | - | - | - | - | - | $\bullet$ |  |
| Branch if < Zero | BLT | 2 D | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N} \oplus+\mathrm{V}=1$ | $\bullet$ | - | - | - | - | - |  |
| Branch If Minus | BMI | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $N=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  |
| Branch If Not Equal Zero | BNE | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathbf{z}=0$ | - | - | - | - | - | - |  |
| Branch If Overfiow Cloar | BVC | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $v=0$ | - | - | - | - | - | $\bullet$ |  |
| Branch If Overflow Set | BVS | 29 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $V=1$ | $\bullet$ | - | $\bullet$ | - | $\bullet$ | $\bullet$ |  |
| Branch If Plus | BPL | 2A | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |  |
| Branch To Subroutine | 8SR | 8D | 5 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\bullet$ | - | - | - | - | - |  |
| Jump | JMP |  |  |  |  |  |  | 6 E | 3 | 2 |  | 7E | 3 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |  |
| Jump To Subroutine | JSR |  |  |  | 90 | 5 | 2 | AD | 5 | 2 |  | BD | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | - | - | - | - |  |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 1 | 1 | Advences Prog. Cntr. Only | - | - | - | - | - | - |  |
| Return From Interrupt\| | RTI |  |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 10 | 1 |  |  |  |  | (1) |  |  |  |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  | - | - | - | - | - | - |  |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  |  |  |  |  | 3F | 12 | 1 |  | - | S | $\bullet$ | $\bullet$ | - | - |  |
| Wait for Interrupt* | WAI |  |  |  |  |  |  |  |  |  |  |  |  |  | 3 E | 9 | 1 |  | - | (1) | - | $\bullet$ | $\bullet$ | - |  |
| Sleep | SLP |  |  |  |  |  |  |  |  |  |  |  |  |  | 1A | 4 | 1 |  | - | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |  |

Note) "WAl puts R/W high; Address Bus goes to FFFF; Data Bus goes to the three state
Condition Code Register will be explained in Note of Table 10.

Table 10 Condition Code Register Manipulation Instructions

| Opertions | Mnemonic | AddressingModes |  |  | Boolean Operstion | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | $\ldots$ |  | H | 1 | N | 2 | $v$ | C |
| Cloer Cerry | CLC | OC | 1 | 1 | $0 \rightarrow C$ | - | - | $\bullet$ | - | $\bullet$ | ค |
| Cioer Interrupt Mask | CLI | OE | 1 | 1 | $0 \rightarrow 1$ | - | R | - | $\bullet$ | - | $\bullet$ |
| Cleer Overflow | CLV | OA | 1 | 1 | $0 \rightarrow V$ | - | - | $\bullet$ | - | ค | $\bullet$ |
| Set Cerry | SEC | 00 | 1 | 1 | $1 \rightarrow C$ | - | - | $\bullet$ | $\bullet$ | - | S |
| Set Interrupt Mask | SEI | OF | 1 | 1 | $1 \rightarrow 1$ | - | S | - | $\bullet$ | - | - |
| Set Overfiow | SEV | 08 | 1 | 1 | $1 \rightarrow V$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | S | $\bullet$ |
| Accumuletor $A \rightarrow$ CCR | TAP | 08 | 1 | 1 | $A \rightarrow$ CCA |  |  |  |  |  |  |
| CCR $\rightarrow$ Aceumulator $\mathbf{A}$ | TPA | 07 | 1 | 1 | $\mathbf{C C R ~} \rightarrow \mathrm{A}$ | - | - | - | - | - | $\bullet$ |

[NOTE 1] Condition Code Register Notes: (Bit set if test is true and cleared otherwise)

| (1) | (Bit V) | Test: Result $=10000000$ ? |
| :---: | :---: | :---: |
| (2) | (Bit C) | Test: Result \& 00000000? |
| (3) | (Bit C) | Test: BCD Character of high-order byte greater than 9 ? (Not cleared if previously set) |
| (4) | (Bit V) | Test: Operand $=10000000$ prior to execution? |
| (5) | (Bit V) | Test: Operand = 01111111 prior to execution? |
| (6) | (Bit V) | Test: Set equal to $\mathrm{NeC}=1$ after the execution of instructions |
| (7) | (Bit N) | Test: Result less than zero? (Bit 15=1) |
| (8) | (All Bit) | Load Condition Code Register from Stack. |
| (9) | (Bit I) | Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state. |
| (10) | (All Bit) | Set according to the contents of Accumulator A. |
| (11) | (Bit C) | Result of Multiplication Bit 7=1 of ACCB? |

[NOTE 2] CLI instruction and interrupt.
 and then CLI instruction is executed, the CPU responds as follows.
(1) The next instruction of CLI is one-machine cycle instruction.

Subsequent two instructions are executed before the interrupt is responded.
That is, the next and the next of the next instruction are executed.
(2) The next instruction of CLI is two-machine cycle (or more) instruction.

Only the next instruction is executed and then the CPU jump to the interrupt routine.
Even if TAP instruction is used, instead of CLI, the same thing occurs.

Table 11 OP-Code Map

| $\begin{aligned} & O P \\ & \text { CODE } \end{aligned}$ |  |  |  |  | $\begin{gathered} \mathrm{ACC} \\ \mathbf{A} \end{gathered}$ | $\begin{gathered} \mathrm{ACC} \\ \mathrm{~B} \end{gathered}$ | IND | EXT/ | ACCA or SP |  |  |  | ACC8 or X |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  | IMM | DIR | IND | EXT | IMM | DIR | IND | EXT |  |
|  | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 |  |
| 10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | $F$ |  |
| 0000 0 | $\square$ | SBA | BRA | TSX | NEG |  |  |  | SUB |  |  |  |  |  |  |  | 0 |
| 0001 1 <br> 0010  | NOP | CBA | BRN | INS | , |  | AIM |  | CMP |  |  |  |  |  |  |  | 1 |
| 0010 2 | 7 | $\square$ | BHI | PULA |  |  | OIM |  | SBC |  |  |  |  |  |  |  | 2 |
| 0011 3 <br> 0  | $\square$ | $\bigcirc$ | BLS | PULB | COM |  |  |  | SUBD |  |  |  | ADDD |  |  |  | 3 |
| 0100 4 | LSRD |  | BCC | DES | LSR |  |  |  | AND |  |  |  |  |  |  |  | 4 |
| 0101 5 <br> 010  | ASLD | $\square$ | BCS | TXS | - |  | EIM |  | BIT |  |  |  |  |  |  |  | 5 |
| 0110 6 <br> 011  | TAP | TAB | BNE | PSHA | ROR |  |  |  | LDA |  |  |  |  |  |  |  | 6 |
| 0111 7 <br> 1000  | TPA | TBA | BEQ | PSHB | ASR |  |  |  | $\sim$ | STA |  |  | $\bigcirc$ | STA |  |  | 7 |
| 1000 8 | INX | XGDX | BVC | PULX | ASL |  |  |  | EOR |  |  |  |  |  |  |  | 8 |
| 1001 9 | DEX | DAA | BVS | RTS | ROL |  |  |  | ADC |  |  |  |  |  |  |  | 9 |
| 1010 A | CLV | SLP | BPL | ABX | DEC |  |  |  | ORA |  |  |  |  |  |  |  | $A$ |
| 1011 8 <br> 1100  | SEV | ABA | BMI | RTI | - |  | TIM |  | ADD |  |  |  |  |  |  |  | 8 |
| 1100 C | CLC | $\square$ | BGE | PSHX | INC |  |  |  | CPX |  |  |  | LDD |  |  |  | C |
| 1101 0 <br> 1110  | SEC | 7 | BLT | MUL | TST |  |  |  | BSR | JSR |  |  |  | STD |  |  | D |
| 1110 $E$ | CLI | 2 | BGT | WAI | 7 | 7 | JMP |  | LDS |  |  |  | LDX |  |  |  | $E$ |
| 1111 $F$ | SEI | 7 | BLE | SWI | CLR |  |  |  | $\bigcirc$ | STS |  |  | 7 | STX |  |  | $F$ |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 0 | E | $F$ |  |

UNDEFINED OP CODE $\square$

* Only for instructions of AIM, OIM, EIM, TIM


## - Instruction Execution Cycles

In the HMCS6800 series, the execution cycle of each instruction is the number of cycles between the start of the current instruction fetch and just before the start of the subsequent instruction fetch.

The HD6303R uses a mechanism of the pipeline control for the instruction fetch and the subsequent instruction fetch is performed during the current instruction being executed.

Therefore, the method to count instruction cycles used in the HMCS6800 series cannot be applied to the instruction cycles such as MULT, PULL, DAA and XGDX in the HD6303R.

Table 12 provides the information about the relationship among each data on the Address Bus, Data Bus, and R/W status in cycle-by-cycle basis during the execution of each instruction.

Table 12 Cycle-by-Cycle Operation

|  <br> Instructions | Cycles | Cycle <br> $\#$ | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |

IMMEDIATE

| ADC | ADD |  | 1 | Op Code Address+1 | 1 | Operand Data |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| AND | BIT |  | 2 | Op Code Address +2 | 1 | Next Op Code |
| CMP | EOR | 2 |  |  |  |  |
| LDA | ORA |  |  |  |  |  |
| SBC | SUB |  |  |  |  |  |
| ADDD | CPX |  | 1 | Op Code Address+1 | 1 | Operand Data (MSB) |
| LDD | LDS | 3 | 2 | Op Code Address+2 | 1 | Operand Data (LSB) |
| LDX | SUBD |  | 3 | Op Code Address +3 | 1 | Next Op Code |



Table 12 Cycle-by-Cycle Operation (Continued)

| Addre Inst | Mode \& uctions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INDEXED |  |  |  |  |  |  |
| JMP |  |  | 1 | Op Code Address+1 | 1 | Offset |
|  |  | 3 | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 3 | Jump Address | 1 | First Op Code of Jump Routine |
| ADC | ADD | 4 | 1 | Op Code Address +1 | 1 | Offset |
| AND | BIT |  | 2 | FFFF | 1 | Restart Address (LSB) |
| CMP | EOR |  | 3 | IX + Offset | 1 | Operand Data |
| LDA | ORA |  | 4 | Op Code Address + 2 | 1 | Next Op Code |
| SBC | SUB |  |  |  |  |  |
| TST |  |  |  |  |  |  |
| STA |  | 4 | 1 | Op Code Address + 1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 3 | IX + Offset | 0 | Accumulator Data |
|  |  |  | 4 | Op Code Address + 2 | 1 | Next Op Code |
| ADDD |  | 5 | 1 | Op Code Address + 1 | 1 | Offset |
| CPX | LDD |  | 2 | FFFF | 1 | Restart Address (LSB) |
| LDS | LDX |  | 3 | IX+Offset | 1 | Operand Data (MSB) |
| SUBD |  |  | 4 | IX + Offset +1 | 1 | Operand Data (LSB) |
|  |  |  | 5 | Op Code Address + 2 | 1 | Next Op Code |
| $\begin{aligned} & \hline \text { STD } \\ & \text { STX } \end{aligned}$ | STS | 5 | 1 | Op Code Address +1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 3 | $1 \mathrm{X}+$ Offset | 0 | Register Data (MSB) |
|  |  |  | 4 | IX + Offset +1 | 0 | Register Data (LSB) |
|  |  |  | 5 | Op Code Address + 2 | 1 | Next Op Code |
| JSR |  | 5 | 1 | Op Code Address+1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | Return Address (LSB) |
|  |  |  | 4 | Stack Pointer-1 | 0 | Return Address (MSB) |
|  |  |  | 5 | IX+Offset | 1 | First Subroutine Op Code |
| ASL | ASR | 6 | 1 | Op Code Address + 1 | 1 | Offset |
| COM | DEC |  | 2 | FFFF | 1 | Restart Address (LSB) |
| INC | LSR |  | 3 | IX + Offset | 1 | Operand Data |
| NEG | ROL |  | 4 | FFFF | 1 | Restart Address (LSB) |
| ROR |  |  | 5 | IX+Offset | 0 | New Operand Data |
|  |  |  | 6 | Op Code Address + 2 | 1 | Next Op Code |
| TIM |  | 5 | 1 | Op Code Address +1 | 1 | Immediate Data |
|  |  |  | 2 | Op Code Address + 2 | 1 | Offset |
|  |  |  | 3 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 4 | IX + Offset | 1 | Operand Data |
|  |  |  | 5 | Op Code Address + 3 | 1 | Next Op Code |
| CLR |  | 5 | 1 | Op Code Address + 1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 3 | IX+Offset | 1 | Operand Data |
|  |  |  | 4 | IX+Offset | 0 | 00 |
|  |  |  | 5 | Op Code Address + 2 | 1 | Next Op Code |
| $\begin{aligned} & \text { AIM } \\ & \text { OIM } \end{aligned}$ | EIM | 7 | 1 | Op Code Address +1 | 1 | Immediate Data |
|  |  |  | 2 | Op Code Address + 2 | 1 | Offset |
|  |  |  | 3 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 4 | IX+Offset | 1 | Operand Data |
|  |  |  | 5 | FFFF | 1 | Restart Address (LSB) |
|  |  |  | 6 | IX + Offset | 0 | New Operand Data |
|  |  |  | 7 | Op Code Address + 3 | 1 | Next Op Code |

Table 12 Cycle-by-Cycle Operation (Continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EXTEND |  |  |  |  |  |
| JMP |  |  | Op Code Address + 1 | 1 | Jump Address (MSB) |
|  | 3 | 2 | Op Code Address + 2 | 1 | Jump Address (LSB) |
|  |  | 3 | Jump Address | 1 | Next Op Code |
| ADC ADD TST |  | 1 | Op Code Address +1 | 1 | Address of Operand (MSB) |
| AND BIT | 4 | 2 | Op Code Address +2 | 1 | Address of Operand (LSB) |
| CMP EOR | 4 | 3 | Address of Operand | 1 | Operand Data |
| LDA ORA |  | 4 | Op Code Address+3 | 1 | Next Op Code |
| SBC SUB |  |  |  |  |  |
| STA | 4 | 1 | Op Code Address + 1 | 1 | Destination Address (MSB) |
|  |  | 2 | Op Code Address + 2 | 1 | Destination Address (LSB) |
|  |  | 3 | Destination Address | 0 | Accumulator Data |
|  |  | 4 | Op Code Address + 3 | 1 | Next Op Code |
| ADDD | 5 | 1 | Op Code Address + 1 | 1 | Address of Operand (MSB) |
| CPX LDD |  | 2 | Op Code Address +2 | 1 | Address of Operand (LSB) |
| LDS LDX |  | 3 | Address of Operand | 1 | Operand Data (MSB) |
| SUBD |  | 4 | Address of Operand+1 | 1 | Operand Data (LSB) |
|  |  | 5 | Op Code Address + 3 | 1 | Next Op Code |
| STD STSSTX | 5 | 1 | Op Code Address + 1 | 1 | Destination Address (MSB) |
|  |  | 2 | Op Code Address + 2 | 1 | Destination Address (LSB) |
|  |  | 3 | Destination Address | 0 | Register Data (MSB) |
|  |  | 4 | Destination Address + 1 | 0 | Register Data (LSB) |
|  |  | 5 | Op Code Address + 3 | 1 | Next Op Code |
| JSR | 6 | 1 | Op Code Address + 1 | 1 | Jump Address (MSB) |
|  |  | 2 | Op Code Address + 2 | 1 | Jump Address (LSB) |
|  |  | 3 | FFFF | 1 | Restart Address (LSB) |
|  |  | 4 | Stack Pointer | 0 | Return Address (LSB) |
|  |  | 5 | Stack Pointer-1 | 0 | Return Address (MSB) |
|  |  | 6 | Jump Address | 1 | First Subroutine Op Code |
| ASL ASR | 6 |  | Op Code Address + 1 | 1 | Address of Operand (MSB) |
| COM DEC |  | 2 | Op Code Address + 2 | 1 | Address of Operand (LSB) |
| INC LSR |  | 3 | Address of Operand | 1 | Operand Data |
| NEG ROL |  | 4 | FFFF | 1 | Restart Address (LSB) |
| ROR |  | 5 | Address of Operand | 0 | New Operand Data |
|  |  | 6 | Op Code Address + 3 | 1 | Next Op Code |
| CLR | 5 | 1 | Op Code Address + 1 | 1 | Address of Operand (MSB) |
|  |  | 2 | Op Code Address + 2 | 1 | Address of Operand (LSB) |
|  |  | 3 | Address of Operand | 1 | Operand Data |
|  |  | 4 | Address of Operand | 0 |  |
|  |  | 5 | Op Code Address + 3 | 1 | Next Op Code |

> - Continued -

Table 12 Cycle-by-Cycle Operation (Continued)


- Continued -

Table 12 Cycle-by-Cycle Operation (Continued)

| Address Mode \& Instructions | Cycles | $\begin{gathered} \text { Cycle } \\ \# \end{gathered}$ | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IMPLIED |  |  |  |  |  |
| WAI | 9 | 1 | Op Code Address + 1 | 1 | Next Op Code |
|  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  | 3 | Stack Pointer | 0 | Return Address (LSB) |
|  |  | 4 | Stack Pointer - 1 | 0 | Return Address (MSB) |
|  |  | 5 | Stack Pointer-2 | 0 | Index Register (LSB) |
|  |  | 6 | Stack Pointer-3 | 0 | Index Register (MSB) |
|  |  | 7 | Stack Pointer-4 | 0 | Accumulator, A |
|  |  | 8 | Stack Pointer-5 | 0 | Accumulator B |
|  |  | 9 | Stack Pointer-6 | 0 | Conditional Code Register |
| RTI | 10 | 1 | Op Code Address + 1 | 1 | Next Op Code |
|  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  | 3 | Stack Pointer +1 | 1 | Conditional Code Register |
|  |  | 4 | Stack Pointer + 2 | 1 | Accumulator B |
|  |  | 5 | Stack Pointer + 3 | 1 | Accumulator A |
|  |  | 6 | Stack Pointer + 4 | 1 | Index Register (MSB) |
|  |  | 7 | Stack Pointer +5 | 1 | Index Register (LSB) |
|  |  | 8 | Stack Pointer +6 | 1 | Return Address (MSB) |
|  |  | 9 | Stack Pointer + 7 | 1 | Return Address (LSB) |
|  |  | 10 | Return Address | 1 | First Op Code of Return Routine |
| SWI | 12 | 1 | Op Code Address + 1 | 1 | Next Op Code |
|  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  | 3 | Stack Pointer | 0 | Return Address (LSB) |
|  |  | 4 | Stack Pointer - 1 | 0 | Return Address (MSB) |
|  |  | 5 | Stack Pointer - 2 | 0 | Index Register (LSB) |
|  |  | 6 | Stack Pointer - 3 | 0 | Index Register (MSB) |
|  |  | 7 | Stack Pointer - 4 | 0 | Accumulator A |
|  |  | 8 | Stack Pointer - 5 | 0 | Accumulator B |
|  |  | 9 | Stack Pointer - 6 | 0 | Conditional Code Register |
|  |  | 10 | Vector Address FFFA | 1 | Address of SWI Routine (MSB) |
|  |  | 11 | Vector Address FFFB | 1 | Address of SWI Routine (LSB) |
|  |  | 12 | Address of SWI Routine | 1 | First Op Code of SWI Routine |
| SLP | 4 |  | Op Code Address + 1 | 1 | Next Op Code |
|  |  |  | FFFF | 1 | Restart Address (LSB) |
|  |  |  | FFFF |  | High Impedance-Non MPX Mode |
|  |  |  |  |  | Address Bus -MPX Mode |
|  |  |  | $\downarrow$ |  |  |
|  |  | 3 | FFFF |  | Restart Address (LSB) |
|  |  | 4 | Op Code Address + 1 |  | Next Op Code |

Table 12 Cycle-by-Cycle Operation (Continued)

| Addr In | Mode \& uctions | Cycles | $\begin{gathered} \text { Cycle } \\ \# \\ \hline \end{gathered}$ | Address Bus | R/ $\overline{\mathbf{W}}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE |  |  |  |  |  |  |
| BCC | BCS | 3 | 1 | $\begin{aligned} & \text { Op Code Address }+1 \\ & \text { FFFF } \\ & \left\{\begin{array}{l} \text { Branch Address......Test="1" } \\ \text { Op Code Address }+1 \cdots \text { Test }=" 0 " \end{array}\right. \end{aligned}$ | 1 | Branch Offset |
| BEQ | BGE |  | 2 |  | 1 | Restart Address (LSB) |
| BGT | BHI |  | 3 |  | 1 | First Op Code of Branch Routine Next Op Code |
| BLE | BLS |  |  |  |  |  |
| BNE | BPL |  |  |  |  |  |
| BRA | BRN |  |  |  |  |  |
| BVC | BVS |  |  |  |  |  |
| BSR |  |  | 1 | Op Code Address + 1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | Restart Address (LSB) |
|  |  | 5 | 3 | Stack Pointer | 0 | Return Address (LSB) |
|  |  |  | 4 | Stack Pointer - 1 | 0 | Return Address (MSB) |
|  |  |  |  | Branch Address |  | First Op Code of Subroutine |

## - LOW POWER CONSUMPTION MODE

The HD6303R has two low power consumption modes; sleep and standby mode.

## - Sleap Mode

On execution of SLP instruction, the MPU is brought to the sleep mode. In the sleep mode, the CPU stops its operation, but the contents of the registers in the CPU are retained. In this mode, the peripherals of CPU will remain active. So the operations such as transmit and receive of the SCI data and counter may keep in operation. In this mode, the power consumption is reduced to about $1 / 6$ the value of a normal operation.

The escape from this mode can be done by interrupt, $\overline{\mathrm{RES}}$, STBY. The RES resets the MPU and the STBY brings it into the standby mode (This will be mentioned later). When interrupt is requested to the CPU and accepted, the sleep mode is released, then the CPU is brought in the operation mode and jumps to the interrupt routine. When the CPU has masked the interrupt, after recovering from the sleep mode, the next instruction of SLP starts to execute. However, in such a case that the timer interrupt is inhibited on the timer side, the sleep mode cannot be released due to the absence of the interrupt request to the CPU.


Figure 21 Standby Mode Timing

This sleep mode is available to reduce an average power consumption in the applications of the HD6303R which may not be always running.

## - Standby Mode

Bringing STBY "Low", the CPU becomes reset and all clocks of the HD6303R become inactive. It goes into the standby mode. This mode remarkably reduces the power consumptions of the HD6303R.

In the standby mode, if the HD6303R is continuously supplied with power, the contents of RAM is retained. The standby mode should escape by the reset start. The following is the typical application of this mode.

First, NMI routine stacks the CPU's internal information and the contents of SP in RAM, disables RAME bit of RAM control register, sets the standby bit, and then goes into the standby mode. If the standby bit keeps set on reset start, it means that the power has been kept during stand-by mode and the contents of RAM is normally guaranteed. The system recovery may be possible by returning SP and bringing into the condition before the standby mode has started. The timing relation for each line in this application is shown in Figure 21.

## - ERROR PROCESSING

When the HD6303R fetches an undefined instruction or fetches an instruction from unusable memory area, it generates the highest priority internal interrupt, that may protect from system upset due to noise or a program error.

## - Op-Code Error

Fetching an undefined op-code, the HD6303R will stack the CPU register as in the case of a normal interrupt and vector to the TRAP (\$FFEE, SFFEF), that has a second highest priority (RES is the highest).

## - Address Error

When an instruction is fetched from other than a resident RAM, or an external memory area, the CPU starts the same interrupt as op-code error. In the case which the instruction is fetched from external memory area and that area is not usable, the address error can not be detected.

The address which cause address error are shown in Table 13.

This feature is applicable only to the instruction fetch, not to normal read/write of data accessing.

Transitions among the active mode, sleep mode, standby mode and reset are shown in Figure 22.

Figures 23, 24 show a system configuration.
The system flow chart of HD6303R is shown in Figure 25.

Table 13 Address Error

| Address Error |
| :---: |
| $\$ 0000 \sim \$ 001 F$ |



Figure 23 HD6303R MPU Multiplexed Mode


Figure 22 Transitions among Active Mode, Standby Mode, Sleep Mode, and Reset


Figure 24 HD6303R MPU Non-Multiplexed Mode


Figure 25 HD6303R System Flow Chart

## - PRECAUTION TO THE BOARD DESIGN OF OSCILLA-

 TION CIRCUITAs shown in Fig. 26, there is a case that the cross talk disturbs the normal oscillation if signal lines are put near the oscillation circuit. When designing a board, pay attention to this. Crystal and $C_{L}$ must be put as near the HD6303R as possible.


Do not use this kind of print board design.
Figure 26 Precaution to the boad design of oscillation circuit


Fig. 27 Example of Oscillation Circuits in Board Design

- PIN CONDITIONS AT SLEEP AND STANDBY STATE - Sleap State

The conditions of power supply pins, clock pins, input pins and E clock pin are the same as those of operation. Refer to Table 14 for the other pin conditions.

## - Standby State

Only power supply pins and STBY are active. As for the clock pin EXTAL, its input is fixed internally so the MPU is not influenced by the pin conditions. XTAL is in " 1 " output. All the other pins are in high impedance.

Table 14 Pin Condition in Sleep State

| Pin Mode |  | Non Multiplexed Mode | Multiplexed Mode |
| :---: | :---: | :---: | :---: |
| $\mathrm{P}_{20} \sim \mathrm{P}_{24}$ | Function | I/O Port | I/O Port |
|  | Condition | Keep the condition just before sleep | - |
| $\begin{aligned} & A_{0} / P_{10} \sim \\ & A_{7} / P_{17} \end{aligned}$ | Function | Address Bus ( $\mathrm{A}_{0} \sim \mathrm{~A}_{7}$ ) | 1/O Port |
|  | Condition | Output "1" | Keep the condition just before sleep |
| $A_{8} \sim A_{15}$ | Function | Address Bus ( $A_{8} \sim A_{15}$ ) | Address Bus ( $\mathrm{A}_{8} \sim A_{15}$ ) |
|  | Condition | Output "1" | $\checkmark$ |
| $\begin{aligned} & D_{0} / A_{0} \sim \\ & D_{1} / A_{7} \end{aligned}$ | Function | Data Bus ( $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ ) | $\bar{E}$ : Address Bus $\left(A_{0} \sim A_{7}\right), \mathrm{E}$ : Data Bus |
|  | Condition | High Impedance | $\overline{\mathrm{E}}$ : Output "1", E: High Impedance |
| R/W | Function | R/W Signal | R/̄W Signal |
|  | Condition | Output "1" | $\underline{\square}$ |
| AS |  | - | Output AS |

Table 15 Pin Condition during RESET

|  | Non-Multiplexed Mode | Multiplexed Mode |
| :---: | :---: | :---: |
| $\mathrm{P}_{20} \sim \mathrm{P}_{24}$ | High Impedance | $\longleftarrow \sim$ |
| $\mathrm{A}_{0} / \mathrm{P}_{10} \sim \mathrm{~A}_{7} / \mathrm{P}_{17}$ | High Impedance | $\longleftarrow$ |
| $A_{8} \sim A_{15}$ | High Impedance | $\square$ |
| $\mathrm{D}_{0} / \mathrm{A}_{0} \sim \mathrm{D}_{7} / \mathrm{A}_{7}$ | High Impedance | (High Impedance) |
| R/W | "1" Output | - |
| AS | $\bar{E}$ : " 1 " Output <br> E: High Impedance | 4 |

(Note) In the multiplexed mode, the data bus is set to " 1 " output state during $E=$ " 1 " and it causes the conflict with the output of external memory. Following 1 and 2 should be done to avoid the conflict;
(1) Construct the system that disables the external memory during reset.
(2) Add $4.7 \mathrm{k} \Omega$ pull-down resistance to the $A S$ pin to make $A S$ pin " 0 " level during $E=$ " 1 ". This operation makes the data bus high impedance state.

- DIFFERENCE BETWEEN HD6303 AND HD6303R

The HD6303R is an upgraded version of the HD6303. The difference between HD6303 and HD6303R is shown in Table 16.

Table 16 Difference between HD6303 and HD6303R

| Item | HD6303 | HD6303R |
| :--- | :--- | :--- |
| Operating <br> Mode | Mode 2: Not defined | Mode 2: Multiplexed <br> Mode <br> (Equivalent to Mode 4) |
| Electrical <br> Character- <br> istics | The electrical character- <br> istics of 2MHz version <br> (B version) are not spec-- <br> ified. | Some characteristics <br> are improved. <br> The 2MHz version is <br> guaranteed. |
| Timer | Has problem in output <br> compare function. <br> (Can be avoided by soft- <br> ware.) | The problem is solved. |

- RECEIVE MARGIN OF THE SCI

Receive margin of the SCI contained in the HD6303R is shown in Table 17.
Note: SCI = Serial Communication Interface
Table 17

|  | Bit distortion <br> tolerance <br> (t-to)/to | Character <br> distortion tolerance <br> $(T-$ To $/$ To |
| :---: | :---: | :---: |
| HD6303R | $\pm 37.5 \%$ | $+3.75 \%$ |

Ideal Waveform


## - APPLICATION NOTE FOR HIGH SPEED SYSTEM

 DESIGN USING THE HD6303RThis note describes the solutions of the potential problem caused by noise generation in the system using the HD6303R.

The CMOS ICs and LSIs featured by low power consumption
and high noise immunity are generally considered to be enough with simply designed power source and the GND line.

But this does not apply to the applications configured of high speed system or of high speed parts. Such high speed system may have a chance to work incorrectly because of the noise
by the transient current generated during switching. One of example is a system in which the HD6303R directly accesses high speed memory such as the HM6264. The noise generation owing to the over current (Sometimes it may be several hundreds mA for peak level.) during switching may cause data write error.

This noise problem may be observed only at the Expanded Mode (Mode 1, 2, 4, 5 and 6) of the HD6303R.

Assuming the HD6303R is used as CPU in a system.

## I. Noise Occurrence

If the HD6303R is connected to high speed RAM, a write error may occur. As shown in Fig. 28, the noise is generated in address bus during write cycle and data is written into an unexpected address from the HD6303R. This phenomenon causes random failures in systems whose data bus load capacitance exceeds the specification value ( 90 pF max.) and/or the impedance of the GND line is high.


Fig. 28 Noise Occurrence in address bus during write cycle

If the data bus $D_{0} \sim D_{7}$ changes from " $F F$ " to " 00 ", extremely large transient current flows through the GND line. Then the noise is generated on the LSI's $\mathrm{V}_{S S}$ pins proportioning to the transient current and to the impedance $[\mathrm{Zg}]$ of the GND line.


Fig. 29 Noise Source
This noise level. $\mathrm{V}_{\mathrm{n}}$. appears on all output pins on the LSI including the address bus.

Fig. 30 shows the dependency of the noise voltage on the each parameter.


Fig. 30 Dependency of the noise voltage on each parameter

## II. Noise Protection

To avoid the noise on the address bus during the system operation mentioned before, there are two solutions as follows:

The one method is to isolate the HD6303R from peripheral devices so that peripherals are not affected by the noise. The other is to reduce noise level to the extent of not affecting peripherals using analog method.

## 1. Noise Isolation

Addresses should be latched at the negative edge of the AS signal or at the positive edge of the E signal. The 74LS373 is often used in this case.


## 2. Noise Reduction

As the noise level depends on each parameter such $\mathrm{Cd}, \mathrm{V}_{\mathrm{CC}}$, Zg , the noise level can be reduced to the allowable level by controlling those analog parameters.
(a) Transient Current Reduction
(1) Reduce the data bus load capacitance. If large load capacitance is expected, a bus buffer should be inserted.
(2) Lower the power supply voltage $\mathrm{V}_{\mathrm{CC}}$ within specification.
(3) Increase a time constant at transient state by inserting a resistor ( $100 \sim 200 \Omega$ ) to Data Buses in series to keep noise level down.
Table 18 shows the relationship between a series resistor and noise level or a resistor and DC/AC characteristics.


Table 18.

| Item Resistor |  |  | No | $100 \Omega$ | $200 \Omega$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Noise Voltage Level |  |  | See Fig. 31 |  |  |
| DC Characteristics |  | ${ }^{1} \mathrm{OL}$ | 1.6 mA | 1.6 mA | 1.0 mA |
| AC <br> Characteristics | $\mathrm{f}=1 \mathrm{MHz}$ | No change |  |  |  |
|  |  | ${ }^{t} A D L$ | 190 ns | 190 ns | 210 ns |
|  | $f=1.5 \mathrm{MHz}$ | ${ }^{\text {t }}$ ACCM | 395 ns | 395 ns | 375 ns |
|  | $\mathrm{f}=\mathbf{2 M H z}$ | ${ }^{t}$ ADL | 160 ns | 180 ns | 200 ns |
|  |  | ${ }^{\text {t }}$ ASL | 20 ns | 20 ns | 0 ns |
|  |  | ${ }^{\text {t }}$ ACCM | 270 ns | 250 ns | 230 ns |

Fig. 31 shows an example of the dependency of the noise voltage on the load capacitance of the data bus.*

*Note: The value of series resistor should be carefully selected because it heavily depends on each parameter of actual application system.

Fig. 32 shows the typical wave form of the noise.

Fig. 31
(b) Reduction of GND line impedance
(1) Widen the GND line width on the PC board.
(2) Place the HD6303R close by power source.
(3) Insert a bypass capacitor between the $\mathrm{V}_{\mathrm{CC}}$ line and the GND of the HD6303R. A tantalum capacitor (about $0.1 \mu \mathrm{~F})$ is effective on the reduction.


Fig. 33 Layout of the HD6303R on the PC board

- POWER-ON RESET

At power-on it is necessary to hold RES "low" to reset the internal state of the device and to provide sufficient time for the oscillator to stabilize. Pay attention to the following.
*Just after power-on, the MPU doesn't enter reset state until the oscillation starts. This is because the reset signal is input internally, with the clocked synchronization as shown below.


Fig. 34 Reset Circuit

Thus, just after power-on the LSI state (I/O port, mode condition etc.) is unstable until the oscillation starts. If it is
necessary to inform the LSI state to the external devices during this period, it needs to be done by the external circuits.

## HD6303X,HD63A03X, HD63B03X CMOS MPU(Micro Processing Unit)

The HD6303X is a CMOS 8-bit micro processing unit (MPU) which includes a CPU compatible with the HD6301VI, 192 bytes of RAM, 24 parallel I/O pins, a Serial Communication Interface (SCI) and two timers on chip.

## - FEATURES

- Instruction Set Compatible with the HD6301V1
- 192 Bytes of RAM
- 24 Parallel I/O Pins

16 I/O Pins-Port 2, 6
8 Input Pins-Port 5

- Darlington Transistor Drive (Port 2, 6)
- 16-Bit Programmable Timer

Input Capture Register $\times 1$
Free Running Counter $\times 1$
Output Compare Register $\times 2$

- 8-Bit Reloadable Timer

External Event Counter Square Wave Generation

- Serial Communication Interface
- Memory Ready
- Halt
- Error-Detection (Address Trap, Op-Code Trap)
- Interrupts . . . 3 External, 7 Internal
- Up to 65k Bytes Address Space
- Low Power Dissipation Mode

Sleep Mode
Standby Mode

- Minimum Instruction Execution Time $-0.5 \mu \mathrm{~s}$ ( $\mathrm{f}=\mathbf{2 . 0} \mathrm{MHz}$ )
- Wide Range of Operation

$$
\begin{aligned}
& V_{c c}=3 \sim 6 \mathrm{~V} \quad(f=0.1 \sim 0.5 \mathrm{MHz}) . \\
& V_{c c}=5 \mathrm{~V} \pm 10 \%\left[\begin{array}{l}
f=0.1 \sim 1.0 \mathrm{MHz} ; H D 6303 X \\
f=0.1 \sim 1.5 \mathrm{MHz} ; \mathrm{HD} 63 \mathrm{~A} 03 \mathrm{X} \\
f=0.1 \sim 2.0 \mathrm{MHz} ; H D 63 B 03 X
\end{array}\right.
\end{aligned}
$$



## - PIN ARRANGEMENT (Top View)

- HD6303XP, HD63A03XP, HD63B03XP

- HD6303XCP, HD63A03XCP, HD63B03XCP

- HD6303XF, HD63A03XF, HD63B03XF



Hitachi America Ltd. • 2210 O'Toole Avenue • San Jose, CA 95131 • (408) 435-8300

ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{cc}}+0.3$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {sto }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

(NOTE) This product has protection circuits in input terminal from high static electricity voltage and high electric field. But be careful not to apply overvoltage more than maximum ratings to these high input impedance protection circuits. To assure the normal operation, we recommend $V_{\text {in }}, V_{\text {out }}: V_{\text {SS }} \leqq\left(V_{\text {in }}\right.$ or $\left.V_{\text {out }}\right) \leqq V_{\text {Cc }}$.

- ELECTRICAL CHARACTERISTICS
- DC CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input "High" Voltage | $\overline{\text { RES }}$, STBY | $\mathrm{V}_{\mathrm{iH}}$ |  | $\mathrm{V}_{\mathrm{cc}}-0.5$ | - | $\begin{aligned} & V_{c c} \\ & +0.3 \end{aligned}$ | V |
|  | EXTAL |  |  | $\mathrm{V}_{\text {cc }} \times 0.7$ | - |  |  |
|  | Other Inputs |  |  | 2.0 | - |  |  |
| Input "Low" Voltage | All Inputs | $\mathrm{V}_{\text {IL }}$ |  | -0.3 | - | 0.8 | V |
| Input Leakage Current | $\overline{\text { NMI, }} \overline{\mathrm{RES}}, \overline{\text { STBY }}$, $M P_{0}, M P_{1}$, Port 5 | $11{ }_{\text {in }} 1$ | $\mathrm{V}_{\text {in }}=0.5 \sim V_{\text {cc }}-0.5 \mathrm{~V}$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Three State (off-state) Leakage Current | $A_{0} \sim A_{15}, D_{0} \sim D_{7}, \overline{R D},$ $\text { WR, R/W,Port 2,Port } 6$ | \|ITsıl | $\mathrm{V}_{\text {in }}=0.5 \sim \mathrm{~V}_{\text {cc }}-0.5 \mathrm{~V}$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Output "High" Voltage | All Outputs | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}=-200 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  |  |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {cc }}-0.7$ | - | - | V |
| Output "Low" Voltage | All Outputs | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |
| Darlington Drive Current | Ports 2, 6 | $-\mathrm{IOH}$ | Vout $=1.5 \mathrm{~V}$ | 1.0 | - | 10.0 | mA |
| Input Capacitance | All Inputs | $\mathrm{C}_{\text {in }}$ | $\begin{aligned} & V_{\text {in }}=0 V, f=1 \mathrm{MHz}, \\ & T a=25^{\circ} \mathrm{C} \end{aligned}$ | - | - | 12.5 | pF |
| Standby Current | Non Operation | $I_{\text {STB }}$ |  | - | 3.0 | 15.0 | $\mu \mathrm{A}$ |
| Current Dissipation* |  | IsLp | Sleeping ( $f=1 \mathrm{MHz}^{* *}$ ) | - | 1.5 | 3.0 | mA |
|  |  | Sleeping ( $\mathrm{f}=1.5 \mathrm{MHz**}$ ) | - | 2.3 | 4.5 | mA |  |
|  |  | Sleeping ( $\mathrm{f}=2 \mathrm{MHz}^{* *}$ ) | - | 3.0 | 6.0 | mA |  |
|  |  | Icc | Operating ( $f=1 \mathrm{MHz}^{* *}$ ) | - | 7.0 | 10.0 | mA |
|  |  | Operating ( $f=1.5 \mathrm{MHz}^{* *}$ ) | - | 10.5 | 15.0 | mA |  |
|  |  | Operating ( $\mathrm{f}=2 \mathrm{MHz**}$ ) | - | 14.0 | 20.0 | mA |  |
| RAM Standby Voltage |  |  | $V_{\text {RAM }}$ |  | 2.0 | - | - | V |

* $\mathrm{V}_{\text {IH }} \min =\mathrm{V}_{\text {CC }}-1.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }} \max =0.8 \mathrm{~V}$, All output terminals are at no load.
** Current Dissipation of the operating or sleeping condition is proportional to the operating frequency. So the typ. or max. values about Current Dissipations at $x \mathrm{MHz}$ operation are decided according to the following formula;
typ. value $(f=x M H z)=$ typ. value $(f=1 M H z) \times x$
max. value $(f=x \mathrm{MHz})=\max$. value $(\mathrm{f}=1 \mathrm{MHz}) \times x$

> (both the sleeping and operating)

- AC CHARACTERISTICS $\left(\mathrm{V}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}_{\mathrm{a}}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

BUS TIMING

| Item |  | Symbol | Test Condition | HD6303X |  |  | HD63A03X |  |  | HD63B03X |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Cycle Time |  |  | $\mathrm{t}_{\text {cyc }}$ | Fig. 1 | 1 | - | 10 | 0.666 | - | 10 | 0.5 | - | 10 | $\mu \mathrm{s}$ |
| Enable Rise Time |  | $\mathrm{t}_{\mathrm{Er}}$ | - |  | - | 25 | - | - | 25 | - | - | 25 | ns |
| Enable Fall Time |  | $\mathrm{t}_{\text {Ef }}$ | - |  | - | 25 | - | - | 25 | - | - | 25 | ns |
| Enable Pulse Width "High" Level* |  | $\mathrm{PW}_{\text {EH }}$ | 450 |  | - | - | 300 | - | - | 220 | - | - | ns |
| Enable Pulse Width "Low" Level" |  | PWEL | 450 |  | - | - | 300 | - | - | 220 | - | - | ns |
| Address, R/W Delay Time* |  | ${ }^{\text {t }}$ AD | - |  | - | 250 | - | - | 190 | - | - | 160 | ns |
| Data Delay Time | Write | todw | - |  | - | 200 | - | - | 160 | - | - | 120 | ns |
| Data Set-up Time | Read | $t_{\text {dSR }}$ | 80 |  | - | - | 70 | - | - | 70 | - | - | ns |
| Address, R/V̄ Hold Time* |  | $\mathrm{t}_{\text {AH }}$ | 80 |  | - | - | 50 | - | - | 35 | - | - | ns |
| Data Hold Time | Write* | $\mathrm{t}_{\text {HW }}$ | 80 |  | - | - | 50 | - | - | 40 | - | - | ns |
|  | Read | $\mathrm{t}_{\text {HR }}$ | 0 |  | - | - | 0 | - | - | 0 | - | - | ns |
| $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Pulse Width* |  | $\mathrm{PW}_{\text {RW }}$ | 450 |  | - | - | 300 | - | - | 220 | - | - | ns |
| $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Delay Time |  | $\mathrm{t}_{\text {RWD }}$ | - |  | - | 40 | - | - | 40 | - | - | 40 | ns |
| RD, WR Hold Time |  | thrw | - |  | - | 30 | - | - | 30 | - | - | 25 | ns |
| LIR Delay Time |  | $t_{\text {DLR }}$ | - |  | - | 200 | - | - | 160 | - | - | 120 | ns |
| $\overline{\text { LIR Hold Time }}$ |  | $\mathrm{t}_{\text {HLR }}$ | 10 |  | - | - | 10 | - | - | 10 | - | - | ns |
| MR Set-up Time* |  | $t_{\text {SMR }}$ | Fig. 2 | 400 | - | - | 280 | - | - | 230 | - | - | ns |
| MR Hold Time* |  | $t_{\text {HMR }}$ |  | - | - | 90 | - | - | 40 | - | - | 0 | ns |
| E Clock Pulse Width at MR |  | PWEMA |  | - | - | 9 | - | - | 9 | - | - | 9 | $\mu \mathrm{s}$ |
| Processor Control Set-up Time |  | $t_{\text {tpes }}$ | $\begin{aligned} & \text { Fig. } 3, \\ & \text { 10. } \end{aligned}$ | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Processor Control Rise Time |  | tPCr | Fig. 2, 3 | - | - | 100 | - | - | 100 | - | - | 100 | ns |
| Processor Control Fall Time |  | $\mathrm{t}_{\text {PCf }}$ |  | - | - | 100 | - | - | 100 | - | - | 100 | ns |
| BA Delay Time |  | $t_{\text {BA }}$ | Fig. 3 | - | - | 250 | - | - | 190 | - | - | 160 | ns |
| Oscillator Stabilization Time |  | $\mathrm{t}_{\mathrm{RC}}$ | Fig. 11 | 20 | - | - | 20 | - | - | 20 | - | - | ms |
| Reset Pulse Width |  | PW ${ }_{\text {RST }}$ |  | 3 | - | - | 3 | - | - | 3 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ |

* These timings change in approximate proportion to $t_{c y c}$. The figures in this characteristics represent those when $t_{c y c}$ is minimum (= in the highest speed operation).

PERIPHERAL PORT TIMING

| Item |  |  | Symbol | Test Condition | HD6303X |  |  | HD63A03X |  |  | HD63B03X |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Peripheral Data Set-up Time | Ports 2, 5, 6 |  |  | $\mathrm{t}_{\text {pDSU }}$ | Fig. 5 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Peripheral Data Hold Time | Ports 2, 5, 6 |  | ${ }_{\text {tPDH }}$ | Fig. 5 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Delay Time (Enable Negative Transition to Peripheral Data Valid) |  | Ports 2, 6 | $t_{\text {pwo }}$ | Fig. 6 | - | - | 300 | - | - | 300 | - | - | 300 | ns |

TIMER, SCI TIMING

| Item |  | Symbol | Test Condition | HD6303X |  |  | HD63A03X |  |  | HD63B03X |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Timer 1 Input Pulse Width |  |  | tpwt | Fig. 8 | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| Delay Time (Enable Positive Transition to Timer Output) |  | tто才 | Fig. 7 | - | - | 400 | - | - | 400 | - | - | 400 | ns |
| SCI Input Clock Cycle | Async. Mode | ${ }^{\text {tscye }}$ | Fig. 8 | 1.0 | - | - | 1.0 | - | - | 1.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
|  | Clock Sync. |  | Fig. 4, 8 | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| SCI Transmit Data Delay Time (Clock Sync. Mode) |  | ${ }_{\text {t }} \times \mathbf{D}$ | Fig. 4 | - | - | 200 | - | - | 200 | - | - | 200 | ns |
| SCI Receive Data Set-up Time (Clock Sync. Mode) |  | ${ }^{\text {tsRX }}$ |  | 290 | - | - | 290 | - | - | 290 | - | - | ns |
| SCI Receive Data Hold Time (Clock Sync. Mode) |  | $t_{\text {HRX }}$ |  | 100 | - | - | 100 | - | - | 100 | - | - | ns |
| SCI Input Clock Pulse Width |  | $t_{\text {tpwsck }}$ | Fig. 8 | 0.4 | - | 0.6 | 0.4 | - | 0.6 | 0.4 | - | 0.6 | ${ }^{\text {tscyc }}$ |
| Timer 2 Input Clock Cycle |  | $\mathrm{t}_{\text {tcyc }}$ |  | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ |
| Timer 2 Input Clock Pulse Width |  | tpwtck |  | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Timer 1-2, SCI Input Clock Rise Time |  | ${ }^{\text {chekr }}$ |  | - | - | 100 | - | - | 100 | - | - | 100 | ns |
| Timer 1-2, SCI Input Clock Fall Time |  | ${ }_{\text {t }}^{\text {ckf }}$ |  | - | - | 100 | - | - | 100 | - | - | 100 | ns |



Figure 1 Bus Timing


Figure 2 Memory Ready and E Clock Timing


Figure $3 \overline{\text { HALT }}$ and BA Timing


Figure $4 \mathbf{S C l}$ Clocked Synchronous Timing


Figure 5 Port Data Set-up and Hold Times (MPU Read)
Figure 6 Port Data Delay Times (MPU Write)


Figure 7 Timer Output Timing



Figure 10 Interrupt Sequence


Figure 11 Reset Timing

## - FUNCTIONAL PIN DESCRIPTION

- $V_{c c}, V_{S S}$
$\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ provide power to the MPU with $5 \mathrm{~V} \pm 10 \%$ supply. In the case of low speed operation ( $\mathrm{fmax}=500 \mathrm{kHz}$ ), the MPU can operate with three through six volts. Two V ${ }_{\text {SS }}$ pins should be tied to ground.


## - XTAL, EXTAL

These two pins interface with an AT-cut parallel resonant crystal. Divide-by-four circuit is on chip, so if 4 MHz crystal oscillator is used, the system clock is 1 MHz for example.

AT Cut ParalleI Resonant Crystal Oscillator


Figure 12 Crystal Interface
EXTAL pin can be drived by the external clock of 45 to $55 \%$ duty, and one fourth frequency of the external clock is produced in the LSI. The external clock frequency should be less than four times of the maximum operable frequency. When using the external clock, XTAL pin should be open. Fig. 12 shows an example of the crystal interface. The crystal and $\mathrm{C}_{\mathrm{L} 1}, \mathrm{C}_{\mathrm{L} 2}$ should be mounted as close as possible to XTAL
and EXTAL pins. Any line must not cross the line between the crystal oscillator and XTAL, EXTAL.

- STBY

This pin makes the MPU standby mode. In "Low" level, the oscillation stops and the internal clock is stabilized to make reset condition. To retain the contents of RAM at standby mode, " 0 " should be written into RAM enable bit (RAME). RAME is the bit 6 of the RAM/port 5 control register at $\$ 0014$. RAM is disabled by this operation and its contents is sustained.

Refer to "LOW POWER DISSIPATION MODE" for the standby mode.

## - Reset ( $\overline{\mathrm{RES}}$ )

This pin resets the MPU from power OFF state and provides a startup procedure. During power-on, $\overline{\text { RES }}$ pin must be held "Low" level for at least 20 ms .

The CPU registers (accumulator, index register, stack pointer, condition code register except for interrupt mask bit), RAM and the data register of a port are not initialized during reset, so their contents are unknown in this procedure.

To reset the MPU during operation, $\overline{\operatorname{RES}}$ should be held "Low" for at least 3 system-clock cycles. At the 3rd cycle during "Low" level, all the address buses become "High". When $\overline{\mathrm{RES}}$ remains "Low", the address buses keep "High". If $\overline{\mathrm{RES}}$ becomes "High", the MPU starts the next operation.
(1) Latch the value of the mode program pins; $\mathbf{M P}_{0}$ and $\mathbf{M P}_{1}$.
(2) Initialize each internal register (Refer to Table 3).
(3) Set the interrupt mask bit. For the CPU to recognize the maskable interrupts $\overline{I R Q_{1}}, \overline{I R Q_{2}}$ and $\mathrm{IRQ}_{3}$, this bit should be cleared in advance.
(4) Put the contents (= start address) of the last two addresses (\$FFFE, \$FFFF) into the program counter and start the program from this address. (Refer to Table 1).
*The MPU is usable to accept a reset input until the clock
becomes normal oscillation after power on (max. 20 ms ). During this transient time, the MPU and I/O pins are undefined. Please be aware of this for system designing.

## - Enable (E)

This pin provides a TTL-compatible system clock to external circuits. Its frequency is one fourth that of the crystal oscillator or external clock. This pin can drive one TTL load and 90 pF capacitance.

## - Non-Maskable Interrupt (NMI)

When the falling edge of the input signal is detected at this pin, the CPU begins non-maskable interrupt sequence internally. As well as the IRQ mentioned below, the instruction being executed at NMI signal detection will proceed to its completion. The interrupt mask bit of the condition code register doesn't affect non-maskable interrupt at all.

When starting the acknowledge to the $\overline{\text { NMI }}$, the contents of the program counter, index register, accumulators and condition code register will be saved onto the stack. Upon completion of this sequence, a vector is fetched from \$FFFC and \$FFFD to transfer their contents into the program counter and branch to the non-maskable interrupt service routine.
(Note) After reset start, the stack pointer should be initialized on an appropreate memory area and then the falling edge
should be input to $\overline{\text { NMI }}$ pin.

- Interrupt Request ( $\overline{\mathbf{R} \mathbf{Q}_{1}}, \overline{\mathbf{R} \mathbf{Q}_{2}}$ )

These are level-sensitive pins which request an internal interrupt sequence to the CPU. At interrupt request, the CPU will complete the current instruction before its request acknowledgement. Unless the interrupt mask in the condition code register is set, the CPU starts an interrupt sequence; if set, the interrupt request will be ignored. When the sequence starts, the contents of the program counter, index register, accumulators and condition code register will be saved onto the stack, then the CPU sets the interrupt mask bit and will not acknowledge the maskable request. During the last cycle, the CPU fetches vectors depicted in Table 1 and transfers their contents to the program counter and branches to the service routine.

The CPU uses the external interrupt pins, $\overline{\overline{R Q}_{1}}$ and $\overline{I_{R} Q_{2}}$, also as port pins $\mathbf{P}_{50}$ and $P_{51}$, so it provides an enable bit to Bit 0 and 1 of the RAM port 5 control register at \$0014. Refer to "RAM/PORT 5 CONTROL REGISTER" for the details.

When one of the internal interrupts, ICI, OCI, TOI, CMI or SIO is generated, the CPU produces internal interrupt signal $\left(\mathrm{IRQ}_{3}\right) . \mathrm{IRQ}_{3}$ functions just the same as $\overline{\mathrm{IRQ}}{ }_{1}$ or $\overline{\mathrm{IRQ}}{ }_{2}$ except for its vector address. Fig. 13 shows the block diagram of the interrupt circuit.

Table 1 Interrupt Vector Memory Map

| Priority | Vector |  | Interrupt |
| :---: | :---: | :---: | :---: |
|  | MSB | LSB |  |
| Highest | FFFE | FFFF | RES |
|  | FFEE | FFEF | TRAP |
|  | FFFC | FFFD | $\overline{\text { NMI }}$ |
|  | FFFA | FFFB | SWI (Software Interrupt) |
|  | FFF8 | FFF9 | $\overline{\mathbf{I R O}_{1}}$ |
|  | FFF6 | FFF7 | ICI (Timer 1 Input Capture) |
|  | FFF4 | FFF5 | OCI (Timer 1 Output Compare 1, 2) |
|  | FFF2 | FFF3 | TOI (Timer 1 Overflow) |
|  | FFEC | FFED | CMI (Timer 2 Counter Match) |
|  | FFEA | FFEB | $\overline{\mathrm{TRO}}$ |
| Lowest | FFFO | FFF1 | SIO (RDRF+ORFE+TDRE) |



Figure 13 Interrupt Circuit Block Diagram

- Mode Program ( $\mathbf{M P}_{0}, \mathbf{M P}_{1}$ )

To operate MPU, MP $\mathbf{0}_{0}$ pin should be connected to "High" level and $\mathrm{MP}_{1}$ should be connected to "Low" level (refer to Fig. 15).

## - Read/Write (R/W)

This signal, usually be in read state ("High"), shows whether the CPU is in read ("High") or write ("Low") state to the peripheral or memory devices. This can drive one TTL load and 30 pF capacitance.

- $\overline{\mathbf{R D}}, \overline{\mathrm{WR}}$

These signals show active low outputs when the CPU is reading/writing to the peripherals or memories. This enables the CPU easy to access the peripheral LSI with $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ input pins. These pins can drive one TTL load and 30 pF capacitance.

## - Load Instruction Register (니R)

This signal shows the instruction opecode being on data bus (active low). This pin can drive one TTL load and 30 pF capacitance.

## - Memory Ready (MR; $\mathbf{P}_{52}$ )

This is the input control signal which stretches the system clock's "High" period to access low-speed memories. During this signal is in "High", the system clock operates in normal sequence. But this signal in "Low", the "High" period of the system clock will be stretched depending on its "Low" level duration in integral multiples of the cycle time. This allows the CPU to interface with low-speed memories (see Fig. 2). Up to $9 \mu \mathrm{~s}$ can be stretched.

During internal address space access or nonvalid memory
access, MR is prohibited internally to prevent decrease of operation speed. Even in the halt state, MR can also stretch "High" period of system clock to allow peripheral devices to access low-speed memories. As this signal is used also as $\mathrm{P}_{\mathbf{5 2}}$, an enable bit is provided at bit 2 of the RAM/port 5 control register at \$0014. Refer to "RAM/PORT 5 CONTROL REGISTER" for more details.

- Halt ( $\overline{\mathrm{HALT}} ; \mathrm{P}_{53}$ )

This is an input control signal to stop instruction execution and to release buses. When this signal switches to "Low", the CPU stops to enter into the halt state after having executed the present instruction. When entering into the halt state, it makes BA ( $\mathrm{P}_{74}$ ) "High" and also an address bus, data bus, $\overline{\mathrm{RD}}$, $\overline{\mathrm{WR}}, \mathrm{R} / \overline{\mathrm{W}}$ high impedance. When an interrupt is generated in the halt state, the CPU uses the interrupt handler after the halt is cancelled.
(Note) Please don't switch the HALT signal to "Low" when the CPU executes the WAI instruction and is in the interrupt wait state to avoid the trouble of the CPU's operation after the halt is cancelled.

## - Bus Available (BA)

This is an output control signal which is normally "Low" but "High" when the CPU accepts $\overline{\text { HALT }}$ and releases the buses. The HD6800 and HD6802 make BA "High" and release the buses at WAI execution, while the HD6303X doesn't make BA "High" under the same condition. But if the HALT becomes "Low" when the CPU is in the interrupt wait state after having executed the WAI, the CPU makes BA "High" and releases the buses. And when the HALT becomes "High", the CPU returns to the interrupt wait state.

- PORT

The HD6303X provides three I/O ports. Table 2 gives the address of ports and the data direction register and Fig. 14 the block diagrams of each port.

Table 2 Port and Data Direction Register Address

| Port | Port Address | Data Direction Register |
| :---: | :---: | :---: |
| Port 2 | $\$ 0003$ | $\$ 0001$ |
| Port 5 | $\$ 0015$ | - |
| Port 6 | $\$ 0017$ | $\$ 0016$ |

## - Port 2

An 8 -bit input/output port. The data direction register (DDR) of port 2 controls the I/O state. It provides two bits; bit 0 decides the $I / O$ direction of $P_{20}$ and bit 1 the $I / O$ direction of $\mathrm{P}_{21}$ to $\mathrm{P}_{27}$ (" 0 " for input, " 1 " for output).


Port 2 is also used as an I/O pin for the timers and the SCI. When used as an I/O pin for the timers and the SCI, port 2 except $P_{20}$ automatically becomes an input or an output depending on their functions regardless of the data direction register's value.

## Port 2 Data Direction Register

$\left.\begin{array}{|c|c|c|c|c|ccc|cc}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\ \hline- & - & - & - & - & - & \begin{array}{c}\text { DDR } \\ 1-7\end{array} & \text { DDR } \\ 0\end{array}\right\} 0001$

A reset clears the DDR of port 2 and configures port 2 as an input port. This port can drive one TTL and 30 pF capacitance. In addition, it can produce 1 mA current when $\mathrm{V}_{\text {out }}=$ 1.5 V to drive directly the base of Darlington transistors.


Figure 14 Port Block Diagram

## - Port 5

An 8-bit port for input only. The lower four bits are also usable as input pins for interrupt, MR and $\overline{\text { HALT }}$.

## - Port 6

An 8-bit I/O port. This port provides an 8-bit DDR corresponding to each bit and can specify input or output by the bit (" 0 " for input, " 1 " for output). This port can drive one TTL load and 30 pF capacitance. A reset clears the DDR of port 6. In addition, it can produce 1 mA current when $\mathrm{V}_{\text {out }}=1.5 \mathrm{~V}$ to drive directly the base of Darlington transistors.

- BUS
- $D_{0} \sim D_{7}$

These pins are data bus and can drive one TTL load and 90 pF capacitance respectively.

- $A_{0} \sim A_{15}$

These pins are address bus and can drive one TTL load and 90 pF capacitance respectively.

## - RAM/PORT 5 CONTROL REGISTER

The control register located at $\$ 0014$ controls on-chip

## RAM and port 5.

## RAM/Port 5 Control Register

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STBY <br> PWR | RAME | - | - | HLTE | MRE | $\mid R Q_{2}$ <br> $E$ | $\mid R Q_{1}$ <br> $E$ |

Bit 0 , Bit $1 \overline{\mathrm{RO}_{1}}, \overline{\mathrm{IRQ}_{2}}$ Enable Bit $\left(I R Q_{1} \mathrm{E}, \mid R Q_{2} \mathrm{E}\right)$
When using $P_{50}$ and $P_{51}$ as interrupt pins, write " 1 " in these bits. When " 0 ", the CPU doesn't accept an external interrupt or a sleep cancellation by the external interrupt. These bits become " 0 " during reset.

Bit 2 Memory Ready Enable Bit (MRE)
When using $\mathrm{P}_{52}$ as an input for Memory Ready signal, write " 1 " in this bit. When " 0 ". the memory ready function is prohibited and $\mathrm{P}_{52}$ can be used as I/O port. This bit becomes " 1 " during reset.

Bit 3 Halt Enable bit (HLTE)
When using $P_{53}$ as an input for Halt signal, write " 1 " in this
bit. When " 0 ", the halt function is prohibited and $P_{53}$ can be used as I/O port. This bit becomes " 1 " during reset.
(Note) When using $P_{52}$ and $P_{53}$ as the input ports in mode 1 and 2, MRE and HLTE bit should be cleared just after the reset.
Notice that memory ready and halt function is enable till MRE and HLTE bit is cleared.

## Bit 4, Bit 5 Not Used.

## Bit 6 RAM Enable (RAME)

On-chip RAM can be disabled by this control bit. By resetting the MPU, " 1 " is set to this bit, and on-chip RAM is enabled. This bit can be written " 1 " or " 0 " by software. When RAM is in disable condition (= logic " 0 "), on-chip RAM is invalid and the CPU can read data from external memory. This bit should be " 0 " before getting into the standby mode to protect on-chip RAM data.

## Bit 7 Standby Power Bit (STBY PWR)

When $\mathrm{V}_{\mathrm{CC}}$ is not provided in standby mode, this bit is cleared. This is a flag for both read/write by software. If this bit is set before standby mode, and remains set even after returning from standby mode, $\mathrm{V}_{\mathrm{CC}}$ voltage is provided during standby mode and the on-chip RAM data is valid.


Figure 15 Operation Mode

## - MEMORY MAP

The MPU can address up to 65 k bytes. Fig. 16 gives memory map of HD6303X. 32 internal registers use addresses from "00" as shown in Table 3.

Table 3 Internal Register

| Address | Registers | R/W*** | Initialize at RESET |
| :---: | :---: | :---: | :---: |
| 00 | - | - | - |
| 01 | Port 2 Data Direction Register | W | \$FC |
| 02* | - | - | - |
| 03 | Port 2 | R/W | Undefined |
| 04* | - | - | - |
| 05 | - | - | - |
| 06* | - | - | - |
| 07* | - | - | - |
| 08 | Timer Control/Status Register 1 | R/W | \$00 |
| 09 | Free Running Counter ("High") | R/W | \$00 |
| OA | Free Running Counter ("Low") | R/W | \$00 |
| OB | Output Compare Register 1 ("High") | R/W | \$FF |
| OC | Output Compare Register 1 ("Low") | R/W | \$FF |
| OD | Input Capture Register ("High") | R | \$00 |
| OE | Input Capture Register ("Low") | R | \$00 |
| OF | Timer Control/Status Register 2 | R/W | \$10 |
| 10 | Rate, Mode Control Register | R/W | \$00 |
| 11 | Tx/Rx Control Status Register | R/W | \$20 |
| 12 | Receive Data Register | R | \$00 |
| 13 | Transmit Data Register | W | \$00 |
| 14 | RAM/Port 5 Control Register | R/W | \$7C or \$FC |
| 15 | Port 5 | R | - |
| 16 | Port 6 Data Direction Register | W | \$00 |

(continued)

Table 3 Internal Register

| Address | Registers | R/W*** | Initialize at RESET |
| :---: | :---: | :---: | :---: |
| 17 | Port 6 | R/W | Undefined |
| $18^{*}$ | - | - | - |
| 19 | Output Compare Register 2 ("High") | R/W | \$FF |
| 1 A | Output Compare Register 2 ("Low") | R/W | \$FF |
| 18 | Timer Control/Status Register 3 | R/W | \$20 |
| 1 C | Time Constant Register | W | \$FF |
| 1D | Timer 2 Up Counter | R/W | \$00 |
| $1 E$ | - | - | - |
| $1 F^{* *}$ | Test Register | - | - |

> * External Address.
> ** Test Register. Do not access to this register.
> W : Read Only Register
> W : Write Only Register
> R/W: Read/Write Register


Figure 16 HD6303X Memory Map

## - TIMER 1

The HD6303X provides a 16-bit programmable timer which can simultaneously measure an input waveform and generate two independent output waveforms. The pulse widths of both input/output waveforms vary from microseconds to seconds.

Timer 1 is configurated as follows (refer to Fig. 18).

- Control/Status Register 1 (8 bit)
- Control/Status Register 2 ( 7 bit)
- Free Running Counter ( 16 bit)
- Output Compare Register 1 ( 16 bit)
- Output Compare Register 2 ( 16 bit)
- Input Capture Register ( 16 bit)
- Free-Running Counter (FRC) (\$0009:000A)

The key timer element is a 16 -bit free-running counter driven
and incremented by system clock. The counter value is readable by software without affecting the counter. The counter is cleared by reset.

When writing to the upper byte ( $\$ 09$ ), the CPU writes the preset value (\$FFF8) into the counter (address $\$ 09, \$ 0 \mathrm{~A}$ ) regardless of the write data value. But when writing to the lower byte ( $\$ 0 \mathrm{~A}$ ) after the upper byte writing, the CPU writes not only the lower byte data into lower 8 bit, but also the upper byte data into higher 8 bit of the FRC.

The counter will be as follows when the CPU writes to it by double store instructions (STD, STX etc.).


In the case of the CPU write (\$5AF3) to the FRC
Figure 17 Counter Write Timing

- Output Compare Register (OCR)
( $\$ 000 \mathrm{~B}, \$ 000 \mathrm{C} ;$ OCR1) ( $\$ 0019, \$ 001 \mathrm{~A}$; OCR2)
The output compare register is a 16 -bit read/write register which can control an output waveform. The data of OCR is always compared with the FRC.

When the data matches, output compare flag (OCF) in the timer control/status register (TCSR) is set. If an output enable bit (OE) in the TCSR2 is " 1 ", an output level bit (OLVL) in the TCSR will be output to bit 1 (Tout 1) and bit 5 (Tout 2) of port 2. To control the output level again by the next compare, the value of OCR and OLVL should be changed. The OCR is set to \$FFFF at reset. The compare function is inhibited for a cycle just after a write to the OCR or to the upper byte of the FRC. This is to begin the comparison after setting the 16 -bit value valid in the register and to inhibit the compare function at this cycle, because the CPU writes the upper byte to the FRC, and at the next cycle the counter is set to \$FFF8.

* For data write to the FRC or the OCR, 2-byte transfer instruction (such as STX etc.) should be used.
- Input Capture Register (ICR) (\$000D : 000E)

The input capture register is a 16 -bit read only register which stores the FRC's value when external input signal transition
generates an input capture pulse. Such transition is controlled by input edge bit (IEDG) in the TCSR1.

In order to input the external input signal to the edge detecter, a bit of the DDR corresponding to bit 0 of port 2 should be cleared (" 0 "). When an input capture pulse occurs by the external input signal transition at the next cycle of CPU's high-byte read of the ICR, the input capture pulse will be delayed by one cycle. In order to ensure the input capture operation, a CPU read of the ICR needs 2 -byte transfer instruction. The input pulse width should be at least 2 system cycles. This register is cleared ( $\$ 0000$ ) during reset.

## - Timer Control/Status Register 1 (TCSR1) (\$0008)

The timer control/status register 1 is an 8 -bit register. All bits are readable and the lower 5 bits are also writable. The upper 3 bits are read only which indicate the following timer status.
Bit 5 The counter value reached to $\$ 0000$ as a result of counting-up (TOF).
Bit 6 A match has occured between the FRC and the OCR 1 (OCF1).
Bit 7 Defined transition of the timer input signal causes the counter to transfer its data to the ICR (ICF).
The followings are each bit descriptions.

## Timer Control/Status Register 1



Bit 0 OLVL1 Output Level 1
OLVL1 is transferred to port 2 , bit 1 when a match occurs between the counter and the OCR1. If bit 0 of the TCSR2 (OE1) is set to " 1 ", OLVL1 will appear at bit 1 of port 2 .
Bit 1 IEDG Input Edge
This bit determines which edge, rising or falling, of input signal of port 2 , bit 0 will trigger data transfer from the counter to the ICR. For this function, the DDR corresponding to port 2 , bit 0 should be cleared beforehand.
IEDG=0, triggered on a falling edge ("High" to "Low")
IEDG $=1$, triggered on a rising edge ("Low" to "High")
Bit 2 ETOI Enable Timer Overflow Interrupt
When this bit is set, an internal interrupt (IRQ3) by TOI interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 3 EOCII Enable Output Compare Interrupt 1
When this bit is set, an internal interrupt (IRQ3) by OCII interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 4 EICI Enable Input Capture Interrupt
When this bit is set, an internal interrupt ( $\mathrm{IRQ}_{3}$ ) by ICI interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 5 TOF Timer Overflow Flag
This read-only bit is set when the counter increments from SFFFF by 1 . Cleared when the counter's upper byte ( $\$ 0009$ ) is ready by the CPU after the TCSR1 read.
Bit 6 OCF 1 Output Compare Flag 1
This read-only bit is set when a match occurs between the OCR1 and the FRC. Cleared when writing
to the OCR1 ( $\$ 000 \mathrm{~B}$ or $\$ 000 \mathrm{C}$ ) after the TCSR1 or TCSR2 read.
Bit 7 ICF Input Capture Flag
This read-only bit is set when an input signal of port 2, bit 0 makes a transition as defined by IEDG and the FRC is transferred to the ICR. Cleared when reading the upper byte ( $\$ 000 \mathrm{D}$ ) of the ICR following the TCSR1 or TCSR2 read.

- Timer Control/Status Register 2 (TCSR2) (\$000F)

The timer control/status register 2 is a 7 -bit register. All bits are readable and the lower 4 bits are also writable. But the upper 3 bits are read-only which indicate the following timer status.
Bit 5 A match has occured between the FRC and the OCR2 (OCF2).
Bit 6 The same status flag as the OCF1 flag of the TCSR1, bit 6.
Bit 7 The same status flag as the ICF flag of the TCSR1, bit 7. The followings are the each bit descriptions.

## Timer Control/Status Register 2



Bit 0 OE1 Output Enable 1
This bit enables the OLVL1 to appear at port 2, bit 1 when a match has occurred between the counter and the output compare register 1 . When this bit is cleared, bit 1 of port 2 will be an $I / O$ port. When set, it will be an output of OLVL1 automatically.
OE2 Output Enable 2
This bit enables the OLVL2 to appear at port 2, bit 5 when a match has occurred between the counter and the output compare register 2 . When this bit is cleared, port 2 , bit 5 will be an I/O port. When set, it will be an output of OLVL2 automatically.

OLVL2 is transferred to port 2 , bit 5 when a match has occurred between the counter and the OCR2. If bit 5 of the TCSR2 (OE2) is set to " 1 ", OLVL2 will appear at port 2, bit 5 .
Bit 3 EOCI2 Enable Output Compare Interrupt 2
When this bit is set, an internal interrupt (IRQ3) by OCI2 interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 4 Not Used
Bit 5 OCF2 Output Compare Flag 2
This read-only bit is set when a match has occurred between the counter and the OCR2. Cleared when writing to the OCR2 (\$0019 or \$001A) after the TCSR2 read.
Bit 6 OCF1 Output Compare Flag 1
Bit 7 ICF Input Capture Flag
OCF1 and ICF addresses are partially decoded. The CPU read of the TCSR1/TCSR2 makes it possible to read OCF1 and ICF into bit 6 and bit 7.
Both the TCSR1 and TCSR2 will be cleared during reset.
(Note) If OE1 or OE2 is set to " 1 " before the first output compare match occurs after reset restart, bit 1 or bit 5 of port 2 will produce " 0 " respectively.


Figure 18 Timer 1 Block Diagram

- TIMER 2

In addition to the timer 1, the HD6303X provides an 8 -bit reloadable timer, which is capable of counting the external event. This timer 2 contains a timer output, so the MPU can generate three independent waveforms (refer to Fig. 19).

The timer 2 is configured as follows:
Control/Status Register 3 ( 7 bit)
8 -bit Up Counter
Time Constant Register (8 bit)

## - Timer 2 Up Counter (T2CNT) (\$001D)

This is an 8 -bit up counter which operates with the clock decided by CKSO and CKS1 of the TCSR3. The CPU can read the value of the counter without affecting the counter. In addition, any value can be written to the counter by software even during counting.

The counter is cleared when a match occurs between the counter and the TCONR or during reset.

If a write operation is made by software to the counter at the cycle of counter clear, it does not reset the counter but put the write data to the counter.

- Time Constant Register (TCONR) (\$001C)

The time constant register is an 8 -bit write only register. It is always compared with the counter.

When a match has occurred, counter match flag (CMF) of the timer control status register 3 (TCSR3) is set and the value selected by TOSO and TOS1 of the TCSR3 will appear at port 2, bit 6 . When CMF is set, the counter will be cleared simultaneously and then start counting from $\$ 00$. This enables regular interrupts and waveform outputs without any software support. The TCONR is set to "\$FF" during reset.

- Timer Control/Status Register 3 (TCSR3) (\$001B)

The timer control/status register 3 is a 7 -bit register. All bits are readable and 6 bits except for CMF can be written.

The followings are each pin descriptions.
Timer Control/Status Register 3



Figure 19 Timer 2 Block Diagram

Bit 0 CKSO Input Clock Select 0
Bit 1 CKS 1 Input Clock Select 1
Input clock to the counter is selected as shown in Table 4 depending on these two bits. When an external clock is selected, bit 7 of port 2 will be a clock input automatically. Timer 2 detects the rising edge of the external clock and increments the counter. The external clock is countable up to half the frequency of the system clock.

Table 4 Input Clock Select

| CKS1 | CKSO | Input Clock to the Counter |
| :---: | :---: | :--- |
| 0 | 0 | E clock |
| 0 | 1 | E clock $/ 8^{*}$ |
| 1 | 0 | E clock $/ 128^{*}$ |
| 1 | 1 | External clock |

*These clocks come from the FRC of the timer 1. If one of these clocks is selected as an input clock to the up counter, the CPU should not write to the FRC of the timer 1.
Bit 2 TOSO Timer Output Select 0
Bit 3 TOS1 Timer Output Select 1
When a match occurs between the counter and the TCONR timer 2 outputs shown in Table 5 will appear at port 2, bit 6 depending on these two bits. When both TOSO and TOS1 are " 0 ", bit 6 of port 2 will be an I/O port.

Table 5 Timer 2 Output Select

| TOS1 | TOS0 | Timer Output |
| :---: | :---: | :--- |
| 0 | 0 | Timer Output Inhibited |
| 0 | 1 | Toggle Output" |
| 1 | 0 | Output "0" |
| 1 | 1 | Output "1" |

*When a match occurs between the counter and the TCONR, timer 2 output level is reversed. This leads to production of a square wave with $50 \%$ duty to the external without any software support.

Bit 4 T2E Timer 2 Enable Bit
When this bit is cleared, a clock input to the up counter is prohibited and the up counter stops. When set to " 1 ", a clock selected by CKS1 and CKSO (Table 4) is input to the up counter.
(Note) $P_{26}$ outputs " 0 " when T2E bit cleared and timer 2 set in output enable condition by TOS1 or TOSO. It also outputs " 0 " when T2E bit set " 1 " and timer 2 set in output enable condition before the first counter match occurs.
Bit 5 Not Used
Bit 6 ECMI Enable Counter Match Interrupt
When this bit is set, an internal interrupt ( $\mathrm{IRQ}_{3}$ ) by CMI is enabled. When cleared, the interrupt is inhibited.
Bit 7 CMF Counter Match Flag
This read-only bit is set when a match occurs between the up counter and the TCONR. Cleared by writing " 0 " by software write (unable to write " 1 " by software).
Each bit of the TCSR3 is cleared during reset.

## - SERIAL COMMUNICATION INTERFACE (SCI)

The HD6303X SCI contains two operation modes; one is an asynchronous mode by the NRZ format and the other is a clocked synchronous mode which transfers data synchronizing with the serial clock.

The SCI consists of the following registers as shown in Fig. 20 Block Diagram:

- Control/Status Register (TRCSR)
- Rate/Mode Control Register (RMCR)
- Receive Data Register (RDR)
- Receive Data Shift Register (RDSR)
- Transmit Data Register (TDR)
- Transmit Data Shift Register (TDSR)

The serial I/O hardware requires an initialization by software for operation. The procedure is usually as follows:

1) Write a desirable operation mode into each corresponding control bit of the RMCR.
2) Write a desirable operation mode into each corresponding control bit of the TRCSR.
When using bit 3 and 4 of port 2 for serial I/O only, there is no problem even if TE and RE bit are set. But when setting the baud rate and operation mode, TE and RE should be " 0 ". When clearing TE and RE bit and setting them again, more than 1 bit cycle of the current baud rate is necessary. If set in less than 1 bit cycle, there may be a case that the internal transmit/receive initialization fails.

## - Asynchronous Mode

An asynchronous mode contains the following two data formats:

1 Start Bit +8 Bit Data +1 Stop Bit
1 Start Bit +9 Bit Data +1 Stop Bit
In addition, if the 9th bit is set to " 1 " when making 9 bit data format, the format of 1 Start bit +8 Bit Data +2 Stop Bit
is also transferred.
Data transmission is enabled by setting TE bit of the TRCSR, then port 2 , bit 4 will become a serial output independently of the corresponding DDR.

For data transmit, both the RMCR and TRCSR should be set under the desirable operating conditions. When TE bit is set during this process, 10 bit preamble will be sent in 8 -bit data format and 11 bit in 9 bit data format. When the preamble is produced, the internal synchronization will become stable and the transmitter is ready to act.

The conditions at this stage are as follows.

1) If the TDR is empty (TDRE=1), consecutive 1's are produced to indicate the idle state.
2) If the TDR contains data (TDRE $=0$ ), data is sent to the transmit data shift register and data transmit starts.
During data transmit, a start bit of " 0 " is transmitted first. Then 8 -bit or 9 -bit data (starts from bit 0 ) and a stop bit " 1 " are transmitted.
When the TDR is "empty", hardware sets TDRE flag bit. If the CPU doesn't respond to the flag in proper timing (the TDRE is in set condition till the next normal data transfer starts from the transmit data register to the transmit sift register), " 1 " is transferred instead of the start bit " 0 " and continues to be transferred till data is provided to the data register. While the TDRE is " 1 ". " 0 " is not transferred.

Data receive is possible by setting RE bit. This makes port 2 , bit 3 be a serial input. The operation mode of data receive is decided by the contents of the TRCSR and RMCR. The first " 0 " (space) synchronizes the receive bit flow. Each bit of the following data will be strobed in the middle. If a stop bit is not " 1 ", a framing error assumed and ORFE is set

When a framing error occurs, receive data is transferred to the receive data register and the CPU can read error-generating data. This makes it possible to detect a line break.

If the stop bit is " 1 ", data is transferred to the receive data register and an interrupt flag RDRF is set. If RDRF is still set when receiving the stop bit of the next data, ORFE is set to indicate overrun generation.

When the CPU read the receive data register as a response to RDRF flag or ORFE flag after having read TRCS, RDRF or ORFE is cleared.
(Note) Clock Source in Asynchronous Mode
If $\mathrm{CC} 1: \mathrm{CC}=10$, the internal bit rate clock is provided at $\mathrm{P}_{22}$ regardless of the values for TE or RE. Maximum clock rate is $\mathrm{E} \div 16$.
If both CC 1 and CCO are set, an external TTL compatible clock must be connected to $\mathrm{P}_{22}$ at sixteen times (16x) the desired bit rate, but not greater than $E$.

## - Clocked Synchronous Mode

In the clocked synchronous mode, data transmit is synchronized with the clock pulse. The HD6303X SCI provides functionally independent transmitter and receiver which makes full duplex operation possible in the asynchronous mode. But in the clocked synchronous mode an SCI clock I/O pin is only $\mathrm{P}_{22}$, so the simultaneous receive and transmit operation is not available. In this mode, TE and RE should not be in set condition ("1") simultaneously. Fig. 21 gives a synchronous clock and a data format in the clocked synchronous mode.


Figure 20 Serial Communication Interface Block Diagram

Data transmit is realized by setting TE bit in the TRCSR. Port 2, bit 4 becomes an output unconditionally independent of the value of the corresponding DDR.

Both the RMCR and TRCSR should be set in the desirable operating condition for data transmit.

When an external clock input is selected, data transmit is
performed under the TDRE flag " 0 " from port 2, bit 4, synchronizing with 8 clock pulses input from external to port 2 , bit 2.

Data is transmitted from bit 0 and the TDRE is set when the transmit data shift register is "empty". More than 9th clock pulse of external are ignored.


- Transmit data is output from a falling edge of a synchronous clock to the next falling edge.
- Receive data is latched at the rising edge.

Figure 21 Clocked Synchronous Mode Format

When data transmit is selected to the clock output, the MPU produces transmit data and synchronous clock at TDRE flag clear.

Data receive is enabled by setting RE bit. Port 2, bit 3 will be a serial input. The operating mode of data receive is decided by the TRCSR and the RMCR.

If the external clock input is selected, RE bit should be set when $\mathrm{P}_{22}$ is "High". Then 8 external clock pulses and the synchronized receive data are input to port 2 , bit 2 and bit 3 respectively. The MPU put receive data into the receive data shift register by this clock and set the RDRF flag at the termination of 8 bit data receive. More than 9th clock pulse of external input are ignored. When RDRF is cleared by reading the receive data register, the MPU starts
receiving the next data. So RDRF should be cleared with $\mathbf{P}_{22}$ "High"

When data receive is selected to the clock output, 8 synchronous clocks are output to the external by setting RE bit. So receive data should be input from external, synchronously with this clock. When the first byte data is received, the RDRF flag is set. After the second byte, receive operation is performed and output the synchronous clock to the external by clearing the RDRF bit.

## - Transmit/Receive Control Status Register (TRCSR) (\$0011)

The TRCSR is composed of 8 bits which are all readable. Bits 0 to 4 are also writable. This register is initialized to $\$ 20$ during reset. Each bit functions as follows.

## Transmit/Receive Control Status Register



Bit 0 WU Wake-up
In a typical multi-processor configuration, the software protocol provides the destination address at the first byte of the message. In order to make uninterested MPU ignore the remaining message, a wake-up function is available. By this, uninterested MPU can inhibit all further receive processing till the next message starts.

Then wake-up function is triggered by consecutive 1 's with 1 frame length ( 10 bits for 8 -bit data, 11 for 9 -bit). The software protocol should provide the idle time between messages.

By setting this bit, the MPU stops data receive till the next message. The receive of consecutive " 1 " with one frame length wakes up and clears this bit and then the MPU restarts receive operation. However, the RE flag should be already set before setting this bit. In the clocked synchronous mode WU is not available, so this bit should not be set.
Bit 1 TE Transmit Enable
When this bit is set, transmit data will appear at port 2, bit 4 after one frame preamble in asynchronous mode, while in clocked synchronous mode it appears immediately. This is executed regardless of the value of the corresponding DDR. When TE is cleared, the serial I/O doesn't affect port 2, bit 4 .
Bit 2 TIE Transmit Interrupt Enable
When this bit is set, an internal interrupt (IRQ3) is enabled when TDRE (bit 5 ) is set. When cleared, the interrupt is inhibited.
Bit 3 RE Receive Enable
When set, a signal is input to the receiver from port 2 , bit 3 regardless of the value of the DDR. When RE is cleared, the serial I/O doesn't affect port 2, bit 3.
Bit 4 RIE Receive Interrupt Enable
When this bit is set, an internal interrupt, $\mathrm{IRQ}_{3}$ is enabled when RDRF (bit 7) or ORFE (bit 6) is set. When cleared, the interrupt is inhibited.
Bit 5 TDRE Transmit Data Register Empty
TDRE is set when the TDR is transferred to the transmit data shift register in the asynchronous mode, while in clocked synchronous mode when the TDSR is "empty". This bit is reset by reading the TRCSR and writing new transmit data to the transmit data register. TDRE is set to " 1 " during reset.
(Note) TDRE should be cleared in the transmittable state after the TE set.
ORFE Overrun Framing Error
ORFE is set by hardware when an overrun or a framing error is generated (during data receive only). An overrun error occurs when new receive data is ready to
be transferred to the RDR during RDRF still being set. A framing error occurs when a stop bit is " 0 ". But in clocked synchronous mode, this bit is not affected. This bit is cleared when reading the TRCSR, then the RDR, or during reset.
Bit 7 RDRF Receive Data Register Full
RDRF is set by hardware when the RDSR is transferred to the RDR. Cleared when reading the TRCSR, then the RDR, or during reset.
(Note) When a few bits are set between bit 5 to bit 7 in the TRCSR, a read of the TRCSR is sufficient for clearing those bits. It is not necessary to read the TRCSR everytime to clear each bit.

## - Transmit Rate/Mode Control Register (RMCR)

The RMCR controls the following serial I/O:

$$
\begin{array}{ll}
\cdot \text { Baud Rate } & \text { - Data Format } \\
\cdot \text { Clock Source } & \cdot \text { Port 2, Bit } 2 \text { Function }
\end{array}
$$

In addition, if 9 -bit data format is set in the asynchronous mode, the 9 th bit is put in this register. All bits are readable and writable except bit 7 (read only). This register is set to $\$ 00$ during reset.

## Transfer Rate/Mode Control Register


$\left.\begin{array}{ll}\text { Bit } 0 & \text { SSO } \\ \text { Bit 1 } & \text { SS1 } \\ \text { Bit 5 } & \text { SS2 }\end{array}\right\} \quad$ Speed Select

These bits control the baud rate used for the SCI. Table 6 lists the available baud rates. The timer 1 FRC (SS2=0) and the timer 2 up counter (SS2=1) provide the internal clock to the SCI. When selecting the timer 2 as a baud rate source, it functions as a baud rate generator. The timer 2 generates the baud rate listed in Table 7 depending on the value of the TCONR.
(Note) When operating the SCI with internal clock, do not perform write operation to the timer/counter which is the clock source of the SCI.
$\left.\begin{array}{ll}\text { Bit } 2 & \text { CCO } \\ \text { Bit } 3 & \text { CC1 } \\ \text { Bit } 4 & \text { CC2 }\end{array}\right\} \quad$ Clock Control/Format Select*

These bits control the data format and the clock source (refer to Table 8).

* CC0, CC1 and CC2 are cleared during reset and the MPU goes to the clocked synchronous mode of the external clock operation. Then the MPU sets port 2, bit 2 into the clock input state. When using port 2, bit 2 as an output port, the DDR of port 2 should be set to " 1 " and CC1 and CC0 to " 0 " and " 1 " respectively.

Table 6 SCI Bit Times and Transfer Rates
(1) Asynchronous Mode

|  |  |  | XTAL | 2.4576 MHz | 4.0 MHz | 4.9152 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SS2 | SS1 | SSO | E | 614.4 kHz | 1.0 MHz | 1.2288 MHz |
| 0 | 0 | 0 | $E \div 16$ | $26 \mu \mathrm{~s} / 38400$ Baud | $16 \mu \mathrm{~s} / 62500 \mathrm{Baud}$ | $13 \mu \mathrm{~s} / 76800 \mathrm{Baud}$ |
| 0 | 0 | 1 | $E \div 128$ | $208 \mu \mathrm{~s} / 4800$ Baud | $128 \mu \mathrm{~s} / 7812.5$ Baud | $104.2 \mu \mathrm{~s} / 9600 \mathrm{Baud}$ |
| 0 | 1 | 0 | $E \div 1024$ | $1.67 \mathrm{~ms} / 600$ Baud | $1.024 \mathrm{~ms} / 976.6$ Baud | $833.3 \mu \mathrm{~s} / 1200 \mathrm{Baud}$ |
| 0 | 1 | 1 | $E \div 4096$ | $6.67 \mathrm{~ms} / 150$ Baud | $4.096 \mathrm{~ms} / 244.1$ Baud | $3.333 \mathrm{~ms} / 300$ Baud |
| 1 | - | - | - | * | * | * |

* When SS2 is " 1 ", Timer 2 provides SCI clocks. The baud rate is shown as follows with the TCONR as N.

$$
\text { Baud Rate }=\frac{\mathrm{f}}{32(\mathrm{~N}+1)} \quad\binom{\mathrm{f}: \text { input clock frequency to the }}{\text { timer } 2 \text { counter }}
$$

(2) Clocked Synchronous Mode *

|  |  |  | XTAL | 4.0 MHz | 6.0 MHz | 8.0 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SS | SS1 | SSO | E | 1.0 MHz | 1.5 MHz | 2.0 MHz |
| 0 | 0 | 0 | $\mathrm{E} \div 2$ | $2 \mu \mathrm{~s} / \mathrm{bit}$ | $1.33 \mu \mathrm{~s} / \mathrm{bit}$ | $1 \mu \mathrm{~s} / \mathrm{bit}$ |
| 0 | 0 | 1 | $\mathrm{E} \div 16$ | $16 \mu \mathrm{~s} / \mathrm{bit}$ | $10.7 \mu \mathrm{~s} / \mathrm{bit}$ | $8 \mu \mathrm{~s} / \mathrm{bit}$ |
| 0 | 1 | 0 | $\mathrm{E} \div 128$ | $128 \mu \mathrm{~s} / \mathrm{bit}$ | $85.3 \mu \mathrm{~s} / \mathrm{bit}$ | $64 \mu \mathrm{~s} / \mathrm{bit}$ |
| 0 | 1 | 1 | $\mathrm{E} \div 512$ | $512 \mu \mathrm{~s} / \mathrm{bit}$ | $341 \mu \mathrm{~s} / \mathrm{bit}$ | $256 \mu \mathrm{sit} / \mathrm{bit}$ |
| 1 | - | - | - | $* *$ | $* *$ | $* *$ |

* Bit rates in the case of internal clock operation. In the case of external clock operation, the external clock is operatable up to $D C \sim 1 / 2$ system clock.
** The bit rate is shown as follows with the TCONR as N .

$$
\text { Bit Rate }(\mu \mathrm{s} / \mathrm{bit})=\frac{4(\mathrm{~N}+1)}{\mathrm{f}} \quad\left(\begin{array}{l}
f: \text { input clock frequency to the } \\
\text { timer } 2 \text { counter } \\
\mathrm{N}=0 \sim 255
\end{array}\right)
$$

Table 7 Baud Rate and Time Constant Register Example

| Baud Rate (Baud) | 2.4576 MHz | 3.6864 MHz | 4.0MHz | 4.9152MHz | 8.0 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 110 | 21* | $32^{*}$ | $35^{*}$ | $43^{*}$ | 70* |
| 150 | 127 | 191 | 207 | 255 | $51^{\circ}$ |
| 300 | 63 | 95 | 103 | 127 | 207 |
| 600 | 31 | 47 | 51 | 63 | 103 |
| 1200 | 15 | 23 | 25 | 31 | 51 |
| 2400 | 7 | 11 | 12 | 15 | 25 |
| 4800 | 3 | 5 | - | 7 | 12 |
| 9600 | 1 | 2 | - | 3 | -- |
| 19200 | 0 | - | - | 1 | - |
| 38400 | - | - | - | 0 | - |

* $\mathrm{E} / 8$ clock is input to the timer 2 up counter and E clock otherwise.

Table 8 SCI Format and Clock Source Control

| CC2 | CC1 | CCO | Format | Mode | Clock Source | Port 2, Bit 2 | Port 2, Bit 3 | Port 2, Bit 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 8-bit data | Clocked Synchronous | External | Input | When the TRCSR, RE bit is " 1 ". bit 3 is used as a serial input. |  |
| 0 | 0 | 1 | 8-bit data | Asynchronous | Internal | Not Used** |  |  |
| 0 | 1 | 0 | 8 -bit data | Asynchronous | Internal | Output* |  |  |
| 0 | 1 | 1 | 8-bit data | Asynchronous | External | Input |  |  |
| 1 | 0 | 0 | 8 -bit data | Clocked Synchronous | Internal | Output | When the TRCSR, TE bit is " 1 ", bit 4 is used as a serial output. |  |
| 1 | 0 | 1 | 9-bit data | Asynchronous | Internal | Not Used** |  |  |
| 1 | 1 | 0 | 9 -bit data | Asynchronous | Internal | Output* |  |  |
| 1 | 1 | 1 | 9 -bit data | Asynchronous | External | Input |  |  |

* Clock output regardless of the TRCSR, bit RE and TE.
** Not used for the SCI.

Bit 6 TD8 Transmit Data Bit 8
When selecting 9-bit data format in the asynchronous mode, this bit is transmitted as the 9th data. In transmitting 9-bit data, write the 9th data into this bit then write data to the receive data register.
Bit 7 RD8 Receive Data Bit 8
When selecting 9 -bit data format in the asynchronous mode, this bit stores the 9th bit data. In receiving 9-bit data, read this bit then the receive data register.

- TIMER, SCI STATUS FLAG

Table 9 shows the set and reset conditions of each status
flag in the timer 1, timer 2 and SCI.
As for Timer 1 and Timer 2 status flag, if the set and reset condition occur simultaneously, the set condition is prior to the reset condition. But in case of SCI control status flag, the reset condition has priority. Especially as for OCF1 and OCF2 of Timer 1, the set signal is generated periodically whenever FRC matches OCR after the set, and which can cause the unclear of the flag. To clear surely, the method is necessary to avoid the occurence of the set signal between TCSR Read and OCR write. For example, match the OCR value to FRC first, and next read TCSR, and then write OCR at once.

Table 9 Timer 1, Timer 2 and SCI Status Flag

|  |  | Set Condition | Reset Condition |
| :---: | :---: | :---: | :---: |
| Timer 1 | ICF | FRC $\rightarrow$ ICR by edge input to $\mathrm{P}_{\mathbf{2 0}}$. | 1. Read the TCSR1 or TCSR2 then ICRH, when ICF = 1 <br> 2. $\mathrm{RES}=0$ |
|  | OCF 1 | OCR1=FRC | 1. Read the TCSR1 or TCSR2 then write to the OCR1H or OCR1L, when OCF1=1 <br> 2. $\mathrm{RES}=0$ |
|  | OCF2 | OCR2=FRC | 1. Read the TCSR2 then write to the OCR2H or OCR2L, when OCF2 $=1$ <br> 2. $\mathrm{RES}=0$ |
|  | TOF | FRC=\$FFFF+1 cycle | 1. Read the TCSR1 then FRCH, when TOF $=1$ <br> 2. $\overline{R E S}=0$ |
| $\begin{gathered} \text { Timer } \\ 2 \end{gathered}$ | CMF | T2CNT $=$ TCONR | 1. Write " 0 " to CMF, when $C M F=1$ <br> 2. $\overline{R E S}=0$ |
| SCI | RDRF | Receive Shift Register $\rightarrow$ RDR | 1. Read the TRCSR then RDR, when RDRF $=1$ <br> 2. $R E S=0$ |
|  | ORFE | 1. Framing Error (Asynchronous Mode) Stop Bit $=0$ <br> 2. Overrun Error (Asynchronous Mode) Receive Shift Register $\rightarrow$ RDR when RDRF=1 | 1. Read the TRCSR then RDR, when ORFE $=1$ <br> 2. $\overline{\mathrm{RES}}=0$ |
|  | TDRE | 1. Asynchronous Mode TDR $\rightarrow$ Transmit Shift Register <br> 2. Clocked Synchronous Mode Transmit Shift Register is "empty" | Read the TRCSR then write to the TDR, when TDRE=1 <br> (Note) TDRE should be reset after the TE set. |

(Note) 1. $\rightarrow$; transfer
2. For example; "ICRH" means High byte of ICR.

## 4) HITACHI

- LOW POWER DISSIPATION MODE

The HD6303X provides two low power dissipation modes; sleep and standby.

## - Sleep Mode

The MPU goes to the sleep mode by SLP instruction execution. In the sleep mode, the CPU stops its operation, while the registers' contents are retained. In this mode, the peripherals except the CPU such as timers, SCI etc. continue their functions. The power dissipation of sleep-condition is one fifth that of operating condition.

The MPU returns from this mode by an interrupt, $\overline{\text { RES }}$ or $\overline{\text { STBY; it goes to the reset state by } \overline{\text { RES }} \text { and the standby mode }}$ by STBY. When the CPU acknowledges an interrupt request, it cancels the sleep mode, returns to the operation mode and branches to the interrupt routine. When the CPU masks this interrupt, it cancels the sleep mode and executes the next instruction. However, for example if the timer 1 or 2 prohibits a timer interrupt, the CPU doesn't cancel the sleep mode because of no interrupt request.

This sleep mode is effective to reduce the power dissipation
for a system with no need of the HD6303X's consecutive operation.

## - Standby Mode

The HD6303X stops all the clocks and goes to the reset state with STBY "Low". In this mode, the power dissipation is reduced conspicuously. All pins except for the power supply, the STBY and XTAL are detached from the MPU internally and go to the high impedance state.

In this mode the power is supplied to the HD6303X, so the contents of RAM is retained. The MPU returns from this mode during reset. The followings are typical usage of this mode.

Save the CPU information and SP contents on RAM by $\overline{\text { NMI }}$. Then disable the RAME bit of the RAM control register and set the STBY PWR bit to go to the standby mode. If the STBY PWR bit is still set at reset start, that indicates the power is supplied to the MPU and RAM contents are retained properly. So system can restore itself by returning their pre-standby informations to the SP and the CPU. Fig. 22 depicts the timing at each pin with this example.


Figure 22 Standby Mode Timing

## - TRAP FUNCTION

The CPU generates an interrupt with the highest priority (TRAP) when fetching an undefined instruction or an instruction from non-memory space. The TRAP prevents the systemburst caused by noise or a program error.

## - Op Code Error

When fetching an undefined op code, the CPU saves CPU registers as well as a normal interrupt and branches to the TRAP (\$FFEE, \$FFEF). This has the priority next to reset.

## - Address Error

When an instruction fetch is made from internal register ( $\$ 0000 \sim \$ 001 F$ ), the MPU generates an interrupt as well as an op code error. But on the system with no memory in its external memory area, this function is not applicable if an instruction fetch is made from the external non-memory area.

This function is available only for an instruction fetch and is not applicable to the access of normal data read/write.
(Note) The TRAP interrupt provides a retry function differently from other interrupts. This is a program flow return to the address where the TRAP occurs when a sequence returns to a main routine from the TRAP interrupt routine by RTI. The retry can prevent the system burst caused by noise etc.
However, if another TRAP occurs, the program repeats the TRAP interrupt forever, so the consideration is necessary in programming.

- INSTRUCTION SET

The HD6303X provides object code upward compatible with the HD6801 to utilize all instruction set of the HMCS6800. It also reduces the execution times of key instruc-
tions for throughput improvement.
Bit manipulation instruction, change instruction of the index register and accumulator and sleep instruction are also added.

The followings are explained here

- CPU Programming Model (refer to Fig. 23)
- Addressing Mode
- Accumulator and Memory Manipulation Instruction (refer to Table 10)
- New Instruction
- Index Register and Stack Manipulation Instruction (refer to Table 11)
- Jump and Branch Instruction (refer to Table 12)
- Condition Code Register Manipulation (refer to Table 13)
- Op Code Map (refer to Table 14)


## - Programming Model

Fig. 23 depicts the HD6303X programming model. The double accumulator D consists of accumulator $A$ and $B$, so when using the accumulator $D$, the contents of $A$ and $B$ are destroyed.


Figure 23 CPU Programming Model

## - CPU Addressing Mode

The HD6303X provides 7 addressing modes. The addressing mode is decided by an instruction type and code. Table 10 through 14 show addressing modes of each instruction with the execution times counted by the machine cycle.

When the clock frequency is 4 MHz , the machine cycle time becomes microseconds directly.
Accumulator (ACCX) Addressing
Only an accumulator is addressed and the accumulator A or $B$ is selected. This is a one-byte instruction. Immediate Addressing

This addressing locates a data in the second byte of an instruction. However, LDS and LDX locate a data in the second and third byte exceptionally. This addressing is a 2 or 3 -byte instruction.
Direct Addressing

In this addressing mode, the second byte of an instruction shows the address where a data is stored. 256 bytes ( $\$ 0$ through $\$ 255$ ) can be addressed directly. Execution times can be reduced by storing data in this area so it is recommended to make it RAM for users' data area in configurating a system. This is a 2-byte instruction, while 3-byte with regard to AIM, OIM, EIM and TIM.

## Extended Addressing

In this mode, the second byte shows the upper 8 bit of the data stored address and the third byte the lower 8 bit . This indicates the absolute address of 3-byte instruction in the memory.

## Indexed Addressing

The second byte of an instruction and the lower 8 bit of the index register are added in this mode. As for AIM, OIM, EIM and TIM, the third byte of an instruction and the lower 8 bits of the index register are added.

This carry is added to the upper 8 bit of the index register and the result is used for addressing the memory. The modified address is retained in the temporary address register, so the contents of the index register doesn't change. This is a 2-byte instruction except AIM, OIM, EIM and TIM (3-byte instruction).

## Implied Addressing

An instruction itself specifies the address. That is, the instruction addresses a stack pointer, index register etc. This is a one-byte instruction.

## Relative Addressing

The second byte of an instruction and the lower 8 bits of the program counter are added. The carry or borrow is added to the upper 8 bit. So addressing from -126 to +129 byte of the current instruction is enabled. This is a 2 -byte instruction.
(Note) CLI, SEI Instructions and Interrupt Operation When accepting the IRQ at a preset timing with CLI and SEI instructions, more than 2 cycles are necessary between the CLI and SEI instructions. For example, the following program (a) (b) don't accept the IRQ but (c) accepts it.

| $\cdot$ | $\cdot$ | $\cdot$ |
| :---: | :---: | :---: |
| $\cdot$ | $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ | CLI |
| CLI | CLI | NOP |
| SEI | NOP | NOP |
| $\cdot$ | SEI | SEI |
| $\cdot$ | $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ | $\cdot$ |
| (a) | (b) | (c) |

The same thing can be said to the TAP instruction instead of the CLI and SEI instructions.

Table 10 Accumulator, Memory Manipulation Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ <br> Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | * | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | 2 | V | C |
| Add | ADDA | 88 | 2 | 2 | 98 | 3 | 2 | AB | 4 | 2 | B8 | 4 | 3 |  |  |  | $A+M \rightarrow A$ | $t$ | $\bullet$ | $\pm$ | 1 | 1 | 1 |
|  | ADDB | CB | 2 | 2 | DB | 3 | 2 | EB | 4 | 2 | FB | 4 | 3 |  |  |  | $B+M \rightarrow B$ | $\pm$ | $\bullet$ | 1 | $\ddagger$ | $t$ | 1 |
| Add Double | ADDO | C3 | 3 | 3 | D3 | 4 | 2 | E3 | 5 | 2 | F3 | 5 | 3 |  |  |  | $A: B+M: M+1 \rightarrow A: B$ | - | - | 1 | 1 | 1 | $t$ |
| Add Accumulators | ABA |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 1 | 1 | $A+B \rightarrow A$ | $\pm$ | $\bullet$ | $\pm$ | $\pm$ | 1 | 1 |
| Add With Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | B9 | 4 | 3 |  |  |  | $A+M+C \rightarrow A$ | $t$ | $\bullet$ | $\pm$ | $\pm$ | $\pm$ | 1 |
|  | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 |  |  |  | $B+M+C \rightarrow B$ | $t$ | - | $\pm$ | $\pm$ | $\pm$ | 1 |
| AND | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A4 | 4 | 2 | B4 | 4 | 3 |  |  |  | $A \cdot M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $\pm$ | R | $\bullet$ |
|  | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 |  |  |  | $B \cdot M \rightarrow B$ | $\bullet$ | $\bullet$ | $\pm$ | $\ddagger$ | R | $\bullet$ |
| Bit Test | BIT A | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | B5 | 4 | 3 |  |  |  | A M M | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
|  | BIT B | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 |  |  |  | B.M | $\bullet$ | $\bullet$ | $t$ | $\pm$ | R | $\bullet$ |
| Clear | CLR |  |  |  |  |  |  | $6 F$ | 5 | 2 | 7 F | 5 | 3 |  |  |  | OO $\rightarrow \mathrm{M}$ | $\bullet$ | $\bullet$ | R | S | R | R |
|  | CLRA |  |  |  |  |  |  |  |  |  |  |  |  | 4 F | 1 | 1 | $00 \rightarrow A$ | $\bullet$ | $\bullet$ | R | S | R | R |
|  | CLRB |  |  |  |  |  |  |  |  |  |  |  |  | 5 F | 1 | 1 | $00 \rightarrow B$ | $\bullet$ | - | R | S | R | R |
| Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | 81 | 4 | 3 |  |  |  | $A-M$ | $\bullet$ | $\bullet$ | $t$ | $t$ | $t$ | $t$ |
|  | CMPB | Cl | 2 | 2 | D1 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 |  |  |  | $B-M$ | $\bullet$ | $\bullet$ | $t$ | $t$ | $t$ | $t$ |
| Compere Accumulators | CBA |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 1 | 1 | A-B | - | - | $\pm$ | $t$ | 1 | $t$ |
| Complement, 1's | COM |  |  |  |  |  |  | 63 | 6 | 2 | 73 | 6 | 3 |  |  |  | $\bar{M} \rightarrow M$ | - | - | 1 | $t$ | A | S |
|  | COMA |  |  |  |  |  |  |  |  |  |  |  |  | 43 | 1 | 1 | $\bar{A} \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $t$ | R | S |
|  | COMB |  |  |  |  |  |  |  |  |  |  |  |  | 53 | 1 | 1 | $\bar{B} \rightarrow B$ | - | - | 1 | 1 | R | S |
| Complement, 2's (Negate) | NEG |  |  |  |  |  |  | 60 | 6 | 2 | 70 | 6 | 3 |  |  |  | OO-M $\rightarrow$ M | $\bullet$ | - | 1 | 1 | (1) | 0 |
|  | NEGA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 1 | 1 | O0-A $\rightarrow$ A | $\bullet$ | $\bullet$ | $\pm$ | $t$ | © | (3) |
|  | NEGB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 1 | 1 | OO-B $\rightarrow$ B | $\bullet$ | $\bullet$ | $\pm$ | $t$ | (1) | (1) |
| Decimal Adjust. A | DAA |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 | Converts binary add of BCD characters into BCD format | - | - | $t$ | $t$ | $\pm$ | (2) |
| Decrement | DEC |  |  |  |  |  |  | 6 6 | 6 | 2 | 7 A | 6 | 3 |  |  |  | M-1 $\rightarrow$ M | $\bullet$ | - | $\pm$ | $t$ | (1) | $\bullet$ |
|  | DECA |  |  |  |  |  |  |  |  |  |  |  |  | 4 A | 1 | 1 | $A-1 \rightarrow A$ | $\bullet$ | - | 1 | $\pm$ | (1) | $\bullet$ |
|  | DECB |  |  |  |  |  |  |  |  |  |  |  |  | 5A | 1 | 1 | $B-1 \rightarrow 8$ | $\bullet$ | - | 1 | $t$ | (1) | $\bullet$ |
| Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | 88 | 4 | 3 |  |  |  | $A \oplus M \rightarrow A$ | $\bullet$ | - | $\pm$ | $\pm$ | R | $\bullet$ |
|  | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 |  |  |  | $B \oplus M \rightarrow B$ | $\bullet$ | $\cdots$ | $\pm$ | 1 | R | $\bullet$ |
| Increment | INC |  |  |  |  |  |  | 6 C | 6 | 2 | 7 C | 6 | 3 |  |  |  | $M+1 \rightarrow M$ | $\bullet$ | $\bullet$ | $t$ | $t$ | (2) | $\bullet$ |
|  | INCA |  |  |  |  |  |  |  |  |  |  |  |  | 4C | 1 | 1 | $A+1 \rightarrow A$ | $\bullet$ | - | $t$ | $t$ | (2) | $\bullet$ |
|  | INCB |  |  |  |  |  |  |  |  |  |  |  |  | 5C | 1 | 1 | $B+1 \rightarrow B$ | $\bullet$ | - | 1 | 1 | (3) | $\bullet$ |
| Load Accumulator | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | B6 | 4 | 3 |  |  |  | $M \rightarrow A$ | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
|  | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 |  |  |  | $M \rightarrow B$ | - | - | $\pm$ | 1 | R | $\bullet$ |
| Load Double Accumulator | LDO | CC | 3 | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 |  |  |  | $M+1 \rightarrow B, M \rightarrow A$ | - | - | $\pm$ | $t$ | R | - |
| Multiply Unsigned | MUL |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 7 | 1 | $A \times B \rightarrow A: B$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | 1 |
| OR, Inclusive | ORAA | 8 A | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 |  |  |  | $A+M \rightarrow A$ | - | - | 1 | : | R | $\bullet$ |
|  | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 |  |  |  | $B+M \rightarrow B$ | $\bullet$ | $\bullet$ | 1 | 1 | R | - |
| Push Data | PSHA |  |  |  |  |  |  |  |  |  |  |  |  | 36 | 4 | 1 | $A \rightarrow$ Msp, $S P-1 \rightarrow$ SP | - | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
|  | PSHB |  |  |  |  |  |  |  |  |  |  |  |  | 37 | 4 | 1 | $\mathrm{B} \rightarrow$ Msp. $\mathrm{SP}-1 \rightarrow \mathrm{SP}$ | - | - | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Pull Data | PULA |  |  |  |  |  |  |  |  |  |  |  |  | 32 | 3 | 1 | SP $+1 \rightarrow$ SP, Msp $\rightarrow$ A | $\bullet$ | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
|  | PULB |  |  |  |  |  |  |  |  |  |  |  |  | 33 | 3 | 1 | $S P+1 \rightarrow S P . M 8 p \rightarrow B$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Rotate Left | ROL |  |  |  |  |  |  | 69 | 6 | 2 | 79 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | 1 | 1 | (\%) | 1 |
|  | ROLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 1 | 1 |  | - | - | 1 | $\ddagger$ | (3) | 1 |
|  | ROLB |  |  |  |  |  |  |  |  |  |  |  |  | 59 | 1 | 1 |  | - | - | 1 | 1 | \% | 1 |
| Rotate Right | ROR |  |  |  |  |  |  | 66 | 6 | 2 | 76 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | 1 | $t$ | (2) | 1 |
|  | RORA |  |  |  |  |  |  |  |  |  |  |  |  | 46 | 1 | 1 |  | $\bullet$ | $\bullet$ | $t$ | $t$ | (2) | 1 |
|  | RORB |  |  |  |  |  |  |  |  |  |  |  |  | 56 | 1 | 1. |  | - | $\bullet$ | 1 | $t$ | (2) | 1 |

(Note) Condition Code Register will be explained in Note of Table 13.

Table 10 Accumulator, Memory Manipulation Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ <br> Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED. |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | * | OP | $\sim$ | * | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | * |  | H | 1 | N | 2 | V | C |
| Shift Left Arithmetic | ASL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | 1 | 1 | (6) | 1 |
|  | ASLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 1 | 1 |  | $\bullet$ | $\bullet$ | 1 | $\pm$. | (C) | 1 |
|  | ASLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 1 | 1 |  | - | $\bullet$ | $t$ | $\pm$ | (6) | 1 |
| Double Shift Left, Arithmetic | ASLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 1 | 1 | $\begin{array}{ll} \square & A C C \overline{N A C C B} \\ C & A 7 \end{array}$ | - | - | $t$ | $t$ | (6) | $\ddagger$ |
| Shift Right Arithmetic | ASR |  |  |  |  |  |  | 67 | 6 | 2 | 77 | 6 | 3 |  |  |  |  | - | - | \$ | 1 | (6) | $t$ |
|  | ASRA |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 1 | 1 |  | - | - | $\ddagger$ | $t$ | (6) | $t$ |
|  | ASRB |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 1 | 1 |  | $\bullet$ | $\bullet$ | 1 | $t$ | (6) | 1 |
| Shift Right Logical | L.SR |  |  |  |  |  |  | 64 | 6 | 2 | 74 | 6 | 3 |  |  |  |  | - | - | R | 1 | (6) | $t$ |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 1 | 1 |  | $\bullet$ | - | R | \% | (6) | $t$ |
|  | LSRB |  |  |  |  |  |  |  |  |  |  |  |  | 54 | 1 | 1 |  | - | $\bullet$ | R | $t$ | (6) | 1 |
| Double Shift Right Logical | LSRD |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 1 | 1 |  | - | - | R | ! | (6) | \% |
| Stora <br> Accumulator | STAA |  |  |  | 97 | 3 | 2 | A7 | 4 | 2 | B7 | 4 | 3 |  |  |  | $A \rightarrow M$ | - | - | 1 | $\dagger$ | R | $\bullet$ |
|  | STAB |  |  |  | 07 | 3 | 2 | E 7 | 4 | 2 | F7 | 4 | 3 |  |  |  | $B \rightarrow M$ | $\bullet$ | - | 1 | $t$ | R | - |
| Store Double Accumulator | STD |  |  |  | DO | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 |  |  |  | $\begin{aligned} & A \rightarrow M \\ & B \rightarrow M+1 \end{aligned}$ | - | - | 1 | $t$ | R | - |
| Subtract | SUBA | 80 | 2 | 2 | 50 | 3 | 2 | AO | 4 | 2 | 80 | 4 | 3 |  |  |  | $A-M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $\dagger$ | 1 | 1 |
|  | SUBB | co | 2 | 2 | D0 | 3 | 2 | EO | 4 | 2 | FO | 4 | 3 |  |  |  | $B-M \rightarrow B$ | $\bigcirc$ | $\cdots$ | 1 | $t$ | 1 | 1 |
| Double Subtract | SUBD | 83 | 3 | 3 | 93 | 4 | 2 | A3 | 5 | 2 | 83 | 5 | 3 |  |  |  | $A: B-M ; M+1 \rightarrow A: B$ | - | - | 1 | $\dagger$ | 1 | 1 |
| Subtract Aceumulators | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 1 | 1 | $A-B \rightarrow A$ | - | - | 1 | 1 | 1 | $t$ |
| Subtract With Cerry | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | B2 | 4 | 3 |  |  |  | $A-M-C \rightarrow A$ | - | - | 1 | 1 | 1 | 1 |
|  | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C \rightarrow B$ | - | - | 1 | $t$ | 1 | 1 |
| Transfor Accumulators | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 1 | 1 | $A \rightarrow B$ | $\bullet$ | $\bullet$ | 1 | 1 | A | $\cdots$ |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 1 | 1 | $B \rightarrow A$ | - | - | 1 | 1 | A | $\bullet$ |
| Test Zero or Minus | TST |  |  |  |  |  |  | 60 | 4 | 2 | 70 | 4 | 3 |  |  |  | $M=00$ | - | - | 1 | 1 | A | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 4D | 1 | 1 | A - 00 | - | - | 1 | $t$ | A | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 1 | 1 | B-00 | - | - | 1 | 1 | R | $R$ |
| And Immediate | AIM |  |  |  | 71 | 6 | 3 | 61 | 7 | 3 |  |  |  |  |  |  | $M \cdot I M M \rightarrow M$ | - | - | $!$ | $\ddagger$ | R | $\bullet$ |
| OR Immediate | OIM |  |  |  | 72 | 6 | 3 | 62 | 7 | 3 |  |  |  |  |  |  | $M+1 M M \rightarrow M$ | - | - | $!$ | $!$ | R | $\bullet$ |
| EOR Immediate | EIM |  |  |  | 75 | 6 | 3 | 65 | 7 | 3 |  |  |  |  |  |  | $M \oplus \mid M M \rightarrow M$ | $\bullet$ | - | $\ddagger$ | ! | R | $\bullet$ |
| Test Immodiate | TIM |  |  |  | 78 | 4 | 3 | 6B | 5 | 3 |  |  |  |  |  |  | M.IMM | $\bullet$ | - | 1 | $\ddagger$ | R | $\bullet$ |

(Note) Condition Code Register will be explained in Note of Table 13.

## - Additional Instruction

In addition to the HD6801 instruction set, the HD6303X prepares the following new instructions.

AIM
Executes "AND" operation to immediate data and the memory contents and stores its result in the memory.

OIM
$(\mathrm{M})+(\mathrm{IMM}) \rightarrow(\mathrm{M})$
Executes "OR" operation to immediate data and the memory contents and stores its result in the memory.

EIM
M . . . . . . (M) $\oplus($ IMM) $\rightarrow$ (M)
Executes "EOR" operation to immediate data and the memory contents and stores its result in the memory.

TIM . . . . . . . (M) • (IMM)
Executes "AND" operation to immediate data and changes the relative flag of the condition code register.

These area 3-byte instructions; the first byte is op code, the second immediate data and the third address modifier.

$$
\text { XGDX . . . . (ACCD) } \leftrightarrow \text { (IX) }
$$

Exchanges the contents of accumulator and the index register.

## SLP

Goes to the sleep mode. Refer to "LOW POWER DISSIPATION MODE" for more details of the sleep mode.

Table 11 Index Register, Stack Manipulation Instructions

| Pointer Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ <br> Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED. |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \% | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | 2 | V | C |
| Compare Index Reg | CPX | 8 C | 3 | 3 | 9C | 4 | 2 | AC | 5 | 2 | BC | 5 | 3 |  |  |  | $X-M: M+1$ | - | - | : | 1 | : | 1 |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 1 | 1 | $x-1 \rightarrow X$ | $\bullet$ | - | $\bullet$ | $t$ | $\bullet$ | $\bullet$ |
| Decrement Stack Pntr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 1 | 1 | SP-1 $\rightarrow$ SP | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 1 | 1 | $x+1 \rightarrow X$ | $\bullet$ | $\bullet$ | $\bullet$ | $t$ | $\bullet$ | $\bullet$ |
| Increment Stack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 1 | 1 | SP + $1 \rightarrow$ SP | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Loed Index Reg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 |  |  |  | $M \rightarrow X_{H}(M+1) \rightarrow X_{L}$ | $\bullet$ | - | (7) | 1 | R | $\bullet$ |
| Load Stack Pntr | LDS | 8 E | 3 | 3 | 9E | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 |  |  |  | $M \rightarrow S P_{H},(M+1) \rightarrow S P_{L}$ | $\bullet$ | $\bullet$ | (7) | 1 | R | $\bullet$ |
| Store Index Reg | STX |  |  |  | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 |  |  |  | $X_{H} \rightarrow M_{1} X_{L} \rightarrow(M+1)$ | - | - | (7) | $t$ | R | - |
| Store Stack Pntr | STS |  |  |  | 9 F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 |  |  |  | $\mathrm{SP}_{\mathbf{H}} \rightarrow \mathbf{M}, \mathbf{S P} \mathbf{L}_{\text {l }} \rightarrow(\mathrm{M}+1)$ | $\bullet$ | - | (7) | $t$ | R | $\bullet$ |
| Index Reg $\rightarrow$ Stack Pntr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 1 | 1 | $\mathrm{X}-1 \rightarrow \mathrm{SP}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Stick Pntr $\rightarrow$ Index Reg | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 1 | 1 | SP + $1 \rightarrow X$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Add | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3A | 1 | 1 | $B+X \rightarrow X$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Push Data | PSHX |  |  |  |  |  |  |  |  |  |  |  |  | 3C | 5 | 1 | $\begin{aligned} & X_{L} \rightarrow M_{\text {sp }} . S P-1 \rightarrow S P \\ & X_{H} \rightarrow M_{\text {gp }} . S P-1 \rightarrow S P \end{aligned}$ | - | - | - | - | - | - |
| Pull Data | PULX |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 4 | 1 | $\begin{aligned} & S P+1 \rightarrow S P, M_{s p} \rightarrow X_{H} \\ & S P+1 \rightarrow S P, M_{\mathrm{mp}} \rightarrow X_{L} \end{aligned}$ | - | - | - | $\bullet$ | - | $\bullet$ |
| Exchange | XGDX |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 2 | 1 | ACCD $\cdot$ - $1 X$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

(Note) Condition Code Register will be explained in Note of Table 13.

Table 12 Jump, Branch Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Branch Test | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | RELATIVE |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | * | OP | $\sim$ | * |  | H | 1 | N | 2 | v | C |
| Branch Always | BRA | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | None | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch Never | BRN | 21 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | None | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Carry Clear | BCC | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{C}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Carry Set | BCS | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If = Zero | BEO | 27 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $z=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If $>$ Zero | BGE | 2C | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N \oplus V=0$ | - | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Branch If $>$ Zero | BGT | 2 E | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Higher | BHI | 22 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C+Z=0$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If < Zero | BLE | 2F | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Lower Or Same | BLS | 23 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C+z=1$ | - | - | - | - | - | $\bullet$ |
| Branch If < Zoro | BLT | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N} \oplus \mathrm{f}=1$ | $\bullet$ | - | $\bullet$ | $\cdots$ | $\bullet$ | $\bullet$ |
| Branch If Minus | BMI | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\cdots$ | $\bullet$ | $\bullet$ |
| Branch If Not Equal Zero | BNE | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | 2-0 | - | - | $\bullet$ | - | - | - |
| Branch If Overflow Clear | BVC | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $V=0$ | - | - | - | - | - | - |
| Branch If Overflow Set | 日VS | 29 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $v=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Plus | BPL | 2 A | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N=0$ | - | $\bullet$ | $\bullet$ | - | - | - |
| Branch To Subroutin | BSR | 80 | 5 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | - | $\square$ | - | - | $\bullet$ | - |
| Jump | JMP |  |  |  |  |  |  | $6 E$ | 3 | 2 | 7 F | 3 | 3 |  |  |  |  | - | - | $\bullet$ | - | $\bullet$ | $\cdots$ |
| Jump To Subroutine | JSR |  |  |  | 90 | 5 | 2 | AD | 5 | 2 | BD | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 1 | 1 | Advances Prog. Cntr. Only | - | - | - | - | - | $\bullet$ |
| Meturn From Interrupt | RTI |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 10 | 1 |  |  |  |  | + | - | - |
| Raturn From Subroutine | RTS |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  | - | - | - | - | - | - |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  |  |  |  | $3 F$ | 12 | 1 |  | - | S | - | - | - | - |
| Wait for Interrupt* | WAI |  |  |  |  |  |  |  |  |  |  |  |  | 3E | 9 | 1 |  | - | (1) | - | - | - | - |
| sleep | SLP |  |  |  |  |  |  |  |  |  |  |  |  | IA | 4 | 1 |  | $\bullet$ | $\bigcirc$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

(Note) *WAI puts R/W̄ high; Address Bus goes to FFFF; Data Bus goes to the three state. Condition Code Register will be explained in Note of Table 13.

Table 13 Condition Code Register Manipulation Instructions

| Operations | Mnemonic | AddressingModes <br> IMPLIED <br> OP |  |  | Boolean Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# |  | H | 1 | N | 2 | v | C |
| Clear Carry | CLC | OC | 1 | 1 |  | $0 \rightarrow C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | R |
| Clear Interrupt Mesk | CLI | OE | 1 | 1 | $0 \rightarrow 1$ | $\bullet$ | R | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Clear Overfiow | CLV | OA | 1 | 1 | $0 \rightarrow V$ | $\bullet$ | $\bullet$ | - | - | R | $\bullet$ |
| Set Carry | SEC | OD | 1 | 1 | $1 \rightarrow C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | S |
| Set Interrupt Mask | SEI | OF | 1 | 1 | $1 \rightarrow 1$ | $\bullet$ | S | - | - | - | $\bullet$ |
| Set Overflow | SEV | 08 | 1 | 1 | $1 \rightarrow V$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | S | $\bullet$ |
| Accumulator $\mathrm{A} \rightarrow$ CCR | TAP | 06 | 1 | 1 | $A \rightarrow$ CCR |  | - |  | - |  |  |
| CCR $\rightarrow$ Accumulator $A$ | TPA | 07 | 1 | 1 | $\mathrm{CCR} \rightarrow \mathrm{A}$ | $\bullet$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ |

## LEGEND

OP Operation Code (Hexadecimal)
CONDITION CODE SYMBOLS
~ Number of MCU Cycles
H Half-carry from bit 3 to bit 4
$M_{\text {SP }}$ Contents of memory location pointed to by Stack Pointer
nterrupt mask
\# Number of Program Bytes
Negative (sign bit)
\# Number of Progr
$+\quad$ Arithmetic Plus
Zero (byte)

- Arithmetic Minus
verfiow, 2's complement
- Boolean AND

Carry/Borrow from/to bit 7
Reset Always

+ Boolean Inclusive OR
Set Always
$\oplus$ Boolean Exclusive OR
1 Set if true after test or clear
M Complement of $M$
$\rightarrow \quad$ Transfer into
$0 \quad$ Bit $=$ Zero
00 Byte $=$ Zero
(Note) Condition Code Register Notes: (Bit set if test is true and cleared otherwise)

| (1) | (Bit V) | Test: Result $=10000000$ ? |
| :---: | :---: | :---: |
| (2) | (Bit C) | Test: Result $\ddagger 00000000$ ? |
| (3) | (Bit C) | Test: BCD Character of high-order byte greater than 10? (Not cleared if previously set) |
| (4) | (Bit V) | Test: Operand $=10000000$ prior to execution? |
| 5 | (Bit V) | Test: Operand = 01111111 prior to execution? |
| 6 | (Bit V) | Test: Set equal to $\mathrm{N} \oplus \mathbf{C}=1$ after the execution of instructions |
| (7) | (Bit N) | Test: Result less than zero? (Bit 15=1) |
| (8) | (All Bit) | Load Condition Code Register from Stack. |
| (9) | (Bit I) | Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state. |
| (10) | (All Bit) | Set according to the contents of Accumulator $A$. |
| (i1) | (Bit C) | Result of Multiplication Bit 7=1? (ACCB) |

Table 14 OP-Code Map


## - CPU OPERATION

## - CPU Instruction Flow

When operating, the CPU fetches an instruction from a memory and executes the required function. This sequence starts with $\overline{\text { RES }}$ cancel and repeats itself limitlessly if not affected by a special instruction or a control signal. SWI, RTI, WAI and SLP instructions change this operation, while $\overline{\text { NMI }}$, $\overline{I_{R Q}}, \overline{I_{2}}{ }_{2}$, IRQ $_{3}, \overline{\text { HALT }}$ and STBY control it. Fig. 24 gives the CPU mode transition and Fig. 25 the CPU system flow chart. Table 15 shows CPU operating states and port states.

## - Operation at Each Instruction Cycle

Table 16 shows the operation at each instruction cycle. By the pipeline control of the HD6303X, MULT, PUL, DAA and XGDX instructions etc. prefetch the next instruction. So attention is necessary to the counting of the instruction cycles because it is different from the usual one ...... op code fetch to the next instruction op code.

Table 15 CPU Operation State and Port State

| Port | Reset | STBY $^{* * *}$ | HALT | Sleep |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{\mathbf{0}} \sim \mathrm{A}_{7}$ | H | T | T | H |
| Port 2 | T | T | Keep | Keep |
| $\mathrm{D}_{\mathbf{0}} \sim \mathrm{D}_{7}$ | T | T | T | T |
| $\mathrm{~A}_{\mathbf{8}} \sim \mathrm{A}_{15}$ | H | T | T | H |
| Port 5 | T | T | T | T |
| Port 6 | T | T | Keep | Keep |
| Contral <br> Signal | $*$ | T | $* *$ | $*$ |

## $H$; High, L:Low, $T$; High Impedance

- $\overline{\operatorname{RD}}, \overline{W R}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{LIR}}=\mathrm{H}, \mathrm{BA}=\mathrm{L}$
** $\overline{R D}, \overline{W R}, R / \bar{W}=T, \overline{L I R}, B A=H$
*** E pin goes to high impedance state.


Figure 24 CPU Operation Mode Transition


Figure 25 HD6303X System Flow Chart

Table 16 Cycle-by-Cycle Operation

| Address Mode \& Instructions |  | Cycles | Cycle II | Address Bus | R/W | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{L T R}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMMEDIATE |  |  |  |  |  |  |  |  |  |
| ADC | ADD |  | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Operand Data |
| AND | BIT |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code |
| CMP | EOR | 2 |  |  |  |  |  |  |  |
| LDA | ORA |  |  |  |  |  |  |  |  |
| SBC | SUB |  |  |  |  |  |  |  |  |
| ADDD | CPX |  | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Operand Data (MSB) |
| LDD | LDS | 3 | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Operand Data (LSB) |
| LDX | SUBD |  | 3 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |


| ADC | ADD | 3 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (LSB) Operand Data <br> Next Op Code |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AND | BIT |  | 2 | Address of Operand | 1 | 0 | 1 | 1 |  |
| CMP | EOR |  | 3 | Op Code Address + 2 | 1 | 0 | 1 | 0 |  |
| LDA | ORA |  |  |  |  |  |  |  |  |
| SBC | SUB |  |  |  |  |  |  |  |  |
| STA |  | 3 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Destination Address <br> Accumulator Data <br> Next Op Code |
|  |  |  | 2 | Destination Address | 0 | 1 | 0 | 1 |  |
|  |  |  | 3 | Op Code Address + 2 | 1 | 0 | 1 | 0 |  |
| ADDD | CPX | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (LSB) <br> Operand Data (MSB) <br> Operand Data (LSB) <br> Next Op Code |
| LDD | LDS |  | 2 | Address of Operand | 1 | 0 | 1 | 1 |  |
| LDX | SUBD |  | 3 | Address of Operand + 1 | 1 | 0 | 1 | 1 |  |
|  |  |  | 4 | Op Code Address + 2 | 1 | 0 | 1 | 0 |  |
| $\begin{aligned} & \text { STD } \\ & \text { STX } \end{aligned}$ | STS | 4 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Destination Address (LSB) <br> Register Data (MSB) <br> Register Data (LSB) <br> Next Op Code |
|  |  |  | 2 | Destination Address | 0 | 1 | 0 | 1 |  |
|  |  |  | 3 | Destination Address + 1 | 0 | 1 | 0 | 1 |  |
|  |  |  | 4 | Op Code Address + 2 | 1 | 0 | 1 | 0 |  |
| JSR |  | 5 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Jump Address (LSB) <br> Restart Address (LSB) <br> Return Address (LSB) <br> Return Address (MSB) <br> First Subroutine Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 |  |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 |  |
|  |  |  | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 |  |
|  |  |  | 5 | Jump Address | 1 | 0 | 1 | 0 |  |
| TIM |  | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Immediate Data <br> Address of Operand (LSB) <br> Operand Data <br> Next Op Code |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 |  |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 |  |
|  |  |  | 4 | Op Code Address + 3 | 1 | 0 | 1 | 0 |  |
| AIMOIM | EIM | 6 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Immediate Data <br> Address of Operand (LSB) <br> Operand Data <br> Restart Address (LSB) <br> New Operand Data <br> Next Op Code |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 |  |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 |  |
|  |  |  | 4 | FFFF | 1 | 1 | 1 | 1 |  |
|  |  |  | 5 | Address of Operand | 0 | 1 | 0 | 1 |  |
|  |  |  | 6 | Op Code Address + 3 | 1 | 0 | 1 | 0 |  |

(Continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/ $\overline{\mathbf{W}}$ | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{L T R}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INDEXED |  |  |  |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Op Code Address + 1 FFFF <br> Jump Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> First Op Code of Jump Routine |
| ADC ADD <br> AND BIT <br> CMP EOR <br> LDA ORA <br> SBC SUB <br> TST  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address + 1 FFFF <br> IX + Offset <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Operand Data <br> Next Op Code |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 FFFF <br> IX + Offset <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Accumulator Data <br> Next Op Code |
| ADDD  <br> CPX LDD <br> LDS LDX <br> SUBD  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address + 1 FFFF <br> IX X Offset <br> IX + Offset + 1 <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Operand Data (MSB) <br> Operand Data (LSB) <br> Next Op Code |
| $\begin{array}{ll} \text { STD } & \text { STS } \\ \text { STX } & \end{array}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & \text { Op Code Address +1 } \\ & \text { FFFF } \\ & \text { IX + Offset } \\ & \text { IX Offset + } 1 \\ & \text { Op Code Address +2 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Register Data (MSB) <br> Register Data (LSB) <br> Next Op Code |
| JSR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address + 1 FFFF <br> Stack Pointer <br> Stack Pointer - 1 <br> IX + Offset | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Return Address (LSB) <br> Return Address (MSB) <br> First Subroutine Op Code |
| ASL ASR <br> COM DEC <br> INC LSR <br> NEG ROL <br> ROR  | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & \text { Op Code Address +1 } \\ & \text { FFFF } \\ & \text { IX + Offset } \\ & \text { FFFF } \\ & \text { IX+Offset } \\ & \text { Op Code Address + } 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Operand Data <br> Restart Address (LSB) <br> New Operand Data <br> Next Op Code |
| TIM | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 <br> FFFF <br> IX + Offset <br> Op Code Address + 3 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Immediate Data <br> Offset <br> Restart Address (LSB) <br> Operand Data <br> Next Op Code |
| CLR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 FFFF <br> $1 X+$ Offset <br> $1 \mathrm{X}+$ Offset <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Offset <br> Restart Address (LSB) <br> Operand Data <br> 00 <br> Next Op Code |
| AIM EIM OIM | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & \hline \end{aligned}$ | Op Code Address + 1 <br> Op Code Address + 2 <br> FFFF <br> IX + Offset <br> FFFF <br> IX + Offset <br> Op Code Address +3 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Immediate Data <br> Offset <br> Restart Address (LSB) <br> Operand Data <br> Restart Address (LSB) <br> New Operand Data <br> Next Op Code |

(Continued)

| $\begin{gathered} \text { Addres } \\ \text { Instt } \end{gathered}$ | ss Mode 8 ructions | Cycles | Cycle \# | Address Bus | R/W | $\overline{\text { RD }}$ | $\overline{W R}$ | $\overline{L T R}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EXTEND |  |  |  |  |  |  |  |  |  |
| JMP |  | 3 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Jump Address (MSE) |
|  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Jump Address (LSB) |
|  |  | 3 | Jump Address | 1 | 0 | 1 | 0 | Next Op Code |
| $\begin{aligned} & \text { ADC } \\ & \text { AND } \\ & \text { CMP } \\ & \text { LDA } \\ & \text { SBC } \end{aligned}$ | ADD TST <br> BIT  <br> EOR  <br> ORA  <br> SUB  |  | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  |  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  | 3 |  | Address of Operand | 1 | 0 | 1 | 1 | Operand Data |
|  |  | 4 |  | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  |  |  |  |  |  |  |  |
| STA |  | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Destination Address (MSB) |
|  |  |  | 2 | Op Code Addiess + 2 | 1 | 0 | 1 | 1 | Destination Address (LSB) |
|  |  |  | 3 | Destination Address | 0 | 1 | 0 | 1 | Accumulator Data |
|  |  |  | 4 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| ADDD CPX LDS SUBD | LDD | 5 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  |  |  | 2 | Op Code Address +2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data (MSB) |
|  |  |  | 4 | Address of Operand+1 | 1 | 0 | 1 | 1 | Operand Data (LSB) |
|  |  |  | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| $\begin{aligned} & \text { STD } \\ & \text { STX } \end{aligned}$ | STS | 5 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Destination Address (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Destination Address (LSB) |
|  |  |  | 3 | Destination Address | 0 | 1 | 0 |  | Register Data (MSB) |
|  |  |  | 4 | Destination Address + 1 | 0 | 1 | 0 | 1 | Register Data (LSB) |
|  |  |  | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| JSR |  | 6 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Jump Address (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Jump Address (LSB) |
|  |  |  | 3 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 4 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) |
|  |  |  | 5 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) |
|  |  |  | 6 | Jump Address | 1 | 0 | 1 | 0 | First Subroutine Op Code |
| ASL <br> COM <br> INC <br> NEG <br> ROR | $\begin{aligned} & \text { ASR } \\ & \text { DEC } \\ & \text { LSR } \\ & \text { ROL } \end{aligned}$ | 6 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data |
|  |  |  | 4 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 5 | Address of Operand | 0 | 1 | 0 | 1 | New Operand Data |
|  |  |  | 6 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| CLR |  | 5 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  |  |  | 2 | Op Code Address +2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data |
|  |  |  | 4 | Address of Operand | 0 | 1 | 0 | 1 | 00 |
|  |  |  | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |

(Continued)

| Addres Inst | Mode \& uctions | Cycles | Cycle \# | Address Bus | R/W | $\overline{\mathrm{R}}$ | $\overline{W R}$ | $\overline{L T R}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMPLIED |  |  |  |  |  |  |  |  |  |
| ABA | ABX | 1 | 1 | Op Code Address +1 | 1 | 0 | 1 | 0 | Next Op Code |
| ASL | ASLD |  |  |  |  |  |  |  |  |
| ASR | CBA |  |  |  |  |  |  |  |  |
| CLC | CLI |  |  |  |  |  |  |  |  |
| CLR | CLV |  |  |  |  |  |  |  |  |
| COM | DEC |  |  |  |  |  |  |  |  |
| DES | DEX |  |  |  |  |  |  |  |  |
| INC | ins |  |  |  |  |  |  |  |  |
| INX | LSR |  |  |  |  |  |  |  |  |
| LSRD | ROL |  |  |  |  |  |  |  |  |
| ROR | NOP |  |  |  |  |  |  |  |  |
| SBA | SEC |  |  |  |  |  |  |  |  |
| SEI | SEV |  |  |  |  |  |  |  |  |
| TAB | TAP |  |  |  |  |  |  |  |  |
| TBA | TPA |  |  |  |  |  |  |  |  |
| TST | TSX |  |  |  |  |  |  |  |  |
| TXS |  |  |  |  |  |  |  |  |  |
| DAA | XGDX | 2 | 1 | Op Code Address +1 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  | 2 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
| PULA | PULB | 3 |  | ```Op Code Address+1 FFFF Stack Pointer +1``` | 1 |  | 1 | 0 | Next Op Code |
|  |  |  | 2 |  | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 |  | 1 | 0 | 1 | 1 | Data from Stack |
| PSHA | PSHB | 4 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Accumulator Data |
|  |  |  | 4 | Op Code Address + 1 | 1 | 0 |  | 0 |  |
| PULX |  | 4 | 1 | Op Code Address +1 | 1 | 0 | 1 | 0 | Next Op Code |
|  | , |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer +1 | 1 | 0 | 1 | 1 | Data from Stack (MSB) |
|  |  |  |  | Stack Pointer +2 | 1 | 0 |  | 1 | Data from Stack (LSB) |
| PSHX |  | 5 |  |  |  |  | 1 | 1 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 |  |
|  |  |  | 4 | Stack Pointer-1 | 0 | 1 | 0 | 1 | Index Register (MSB) |
|  |  |  | 5 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |
| RTS |  | 5 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer +1 | 1 | 0 | 1 | 1 | Return Address (MSB) |
|  |  |  | 4 | Stack Pointer + 2 | 1 | 0 | 1 | 1 | Return Address (LSB) |
|  |  |  | 5 | Return Address | 1 | 0 | 1 | 0 | First Op Code of Return Routine |
| MUL |  | 7 | 1 | Op Code Address +1 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 4 | FFFF | 1 | 1 | 1 |  | Restart Address (LSB) |
|  |  |  | 5 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 6 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 7 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |

(Continued)

| Address Mode \& Instructions | Cycies | $\begin{gathered} \text { Cycle } \\ \# \end{gathered}$ | Address Bus | R/W | RD | WR | TIR | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMPLIED |  |  |  |  |  |  |  |  |
| WAI | 9 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) |
|  |  | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) |
|  |  | 5 | Stack Pointer - 2 | 0 | 1 | 0 | 1 | Index Register (LSB) |
|  |  | 6 | Stack Pointer-3 | 0 | 1 | 0 | 1 | Index Register (MSB) |
|  |  | 7 | Stack Pointer - 4 | 0 | 1 | 0 | 1 | Accumulator A |
|  |  | 8 | Stack Pointer - 5 | 0 | 1 | 0 | 1 | Accumulator B |
|  |  | 9 | Stack Pointer - 6 | 0 | 1 | 0 | 1 | Conditional Code Register |
| RTI | 10 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  | 3 | Stack Pointer +1 | 1 | 0 | 1 | 1 | Conditional Code Register |
|  |  | 4 | Stack Pointer +2 | 1 | 0 | 1 | 1 | Accumulator B |
|  |  | 5 | Stack Pointer + 3 | 1 | 0 | 1 | 1 | Accumulator A |
|  |  | 6 | Stack Pointer + 4 | 1 | 0 | 1 | 1 | Index Register (MSB) |
|  |  | 7 | Stack Pointer + 5 | 1 | 0 | 1 | 1 | Index Register (LSB) |
|  |  | 8 | Stack Pointer +6 | 1 | 0 | 1 | 1 | Return Address (MSB) |
|  |  | 9 | Stack Pointer + 7 | 1 | 0 | 1 | 1 | Return Address (LSB) |
|  |  | 10 | Return Address | 1 | 0 | 1 | 0 | First Op Code of Return Routine |
| SWI | 12 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  | 2 | fFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) |
|  |  | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) |
|  |  | 5 | Stack Pointer - 2 | 0 | 1 | 0 | 1 | Index Register (LSB) |
|  |  | 6 | Stack Pointer-3 | 0 | 1 | 0 | 1 | Index Register (MSB) |
|  |  | 7 | Stack Pointer - 4 | 0 | 1 | 0 | 1 | Accumulator A |
|  |  | 8 | Stack Pointer - 5 | 0 | 1 | 0 | 1 | Accumulator B |
|  |  | 9 | Stack Pointer -6 | 0 | 1 | 0 | 1 | Conditional Code Register |
|  |  | 10 | Vector Address FFFA | 1 | 0 | 1 | 1 | Address of SWI Routine (MSB) |
|  |  | 11 | Vector Address FFFB | 1 | 0 | 1 | 1 | Address of SWI Routine (LSB) |
|  |  | 12 | Address of SWI Routine | 1 | 0 | 1 | 0 | First Op Code of SWI Routine |
| SLP | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  | 2 | FFFF | , | 1 | 1 | , | Restart Address (LSB) |
|  |  | Sleep <br> Sleep |  | 1 | 1 | . | , | - |
|  |  | 3 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  | 4 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |


| BCC | BCS | 3 | 1 | Op Code Address + 1 |  |  | 1 | 1 | Branch Offset |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BEO | BGE |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
| BGT | BHI |  | 3 | $\left\{\begin{array}{l} \text { Branch Address } \cdots \cdots \cdot \text { Test }=" 1 " \\ \text { Op Code Address }+1 \cdots \text { Test }=-0 " \end{array}\right.$ | 1 | 0 | 1 | 0 | First Op Code of Branch Routine Next Op Code |
| BLE | BLS |  |  |  |  |  |  |  |  |
| BNE | BPL |  |  |  |  |  |  |  |  |
| BRA | BRN |  |  |  |  |  |  |  |  |
| BVC | BVS |  |  |  |  |  |  |  |  |
| BSR |  | 5 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) |
|  |  |  | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) |
|  |  |  | 5 | Branch Address | 1 | 0 | 1 | 0 | First Op Code of Subroutine |

- PRECAUTION TO THE BOARD DESIGN OF OSCILLA. TION CIRCUIT
As shown in Fig. 26, there is a case that the cross talk disturbs the normal oscillation if signal lines are put near the oscillation circuit. When designing a board, pay attention to this. Crystal and $C_{L}$ must be put as near the HD6303X as possible.


Figure 26 Precaution to the boad design of oscillation circuit

- RECEIVE MARGIN OF THE SCI

Receive margin of the SCI contained in the HD6303X is shown in Table 17.
Note: SCI = Serial Communication Interface


Figure 27 Example of Oscillation Circuits in Board Design
Table 17

|  | Bit distortion <br> (tolerance <br> (t-to) /to | Character <br> distortion tolerance <br> $(T-T o) / T o$ |
| :--- | :---: | :---: |
| HD6303X | $\pm 43.7 \%$ | $\pm 4.37 \%$ |



- POWER-ON RESET

At power-on it is necessary to hold $\overline{\text { RES }}$ "low" to reset the internal state of the device and to provide sufficient time for the oscillator to stabilize. Pay attention to the following.
*Just after power-on, the MPU doesn't enter reset state until the oscillation starts. This is because the reset signal is input internally, with the clocked synchronization as shown below.


Inside the LSI

Fig. 28 Reset Circuit

Thus, just after power-on the LSI state (I/O port, mode condition etc.) is unstable until the oscillation starts. If it is necessary to inform the LSI state to the external devices during this period, it needs to be done by the external circuits.

- RESET SIGNAL AND MEMORY READY FUNCTION

The reset signal is strobed to CPU synchronized with internal clock. Since internal clock is held to "High" level during memory-ready-state ( $\overline{\mathrm{MR}}=$ "Low"), reset sygnal is not strobed to CPU .

Please $\overline{\mathrm{MR}}$ input ( $\mathrm{P}_{52}$ ) should be "High" level during resetstate.

## HD6303Y,HD63A03Y, HD63B03Y CMOS MPU (Micro Processing Unit)

The HD6303Y is a CMOS 8 -bit micro processing unit which contains a CPU compatible with the HD6301V1, 256 bytes of RAM, 24 parallel I/O Pins, Serial Communication Interface (SCI) and two timers.

## - FEATURES

- Instruction Set Compatible with the HD6301V1
- 256 Bytes of RAM
- 24 Parallel I/O Pins
- Parallel Handshake Interface (Port 6)
- Darlington Transistor Drive (Port 2, 6)
- 16-bit Programmable Timer Input Capture Register $\times 1$
Free Running Counter $\times 1$
Output Compare Registers $\times 2$
- 8-Bit Reloadable Timer

External Event Counter Square Wave Generation

- Serial Communication Interface (SCI)

Asynchronous Mode (8 Transmit Formats, Hardware Parity)
Clocked Synchronous Mode

- Three Kinds of Memory Ready
- Halt
- Error Detection (Address Error, Op-code Error)
- Interrupt - 3 External, 7 Internal
- Maximum 65k Bytes Address Space
- Low Power Dissipation Mode

Sleep
Standby (Hardware Set, Software Set)

- Wide Operating Range

$$
V_{C C}=3 \text { to } 5.5 \quad(f=0.1 \text { to } 0.5 \mathrm{MHz})
$$

$V_{C C}=5 \mathrm{~V} \pm 10 \%(f=0.1 \sim 3 \mathrm{MHz})$

- Minimum Instruction Cycle Time
- HD6303Y ......... . $1 \mu \mathrm{~S}$ ( $\mathrm{f}=1 \mathrm{MHz}$ )
- HD63A03Y ....... $0.67 \mu \mathrm{~s}$ ( $\mathrm{f}=1.5 \mathrm{MHz}$ )
- HD63B03Y ....... $0.5 \mu \mathrm{~s}(\mathrm{f}=2.0 \mathrm{MHz})$
- HD63C03Y . . . . . . $0.33 \mu \mathrm{~s}(\mathrm{f}=3.0 \mathrm{MHz})$
- TYPE OF PRODUCTS

| Type No. | Bus Timing |
| :---: | :---: |
| HD6303Y | 1 MHz |
| HD63A03Y | 1.5 MHz |
| HD63B03Y | 2 MHz |
| HD63C03Y* | 3 MHz |

* Preliminary

HD6303YP, HD63A03YP, HD63B03YP, HD63C03YP*

(DP-64S)
HD6303YF, HD63A03YF,
HD63B03YF, HD63C03YF

(FP-64)
HD6303YCP, HD63A03YCP, HD63B03YCP, HD63C03YCP

(CP-68)

## －PIN ARRANGEMENT

－HD6303YP，HD63A03YP， HD63B03YP，HD63C03YP

| $\mathrm{V}_{5 s} \square_{0}$ | 54 E |
| :---: | :---: |
| XTAL 2 | $33^{\text {PD }}$ |
| EXTAL 3 | $6{ }^{6} \bar{W}$ |
| MPo 4 | 518 m |
| MP， 5 | $5{ }^{51 / 4}$ |
| TES 6 | $5{ }^{51} 8$ |
| STBY 7 | $580^{\circ}$ |
| NMI ${ }^{8}$ | 570 |
| $P_{20} 9$ | 560 |
| $P_{21}$［10 | 35 O |
| $\mathrm{P}_{12} 1$ | 54 D ． |
| $P_{12} 12$ | 53 D ， |
| $P_{14} 113$ | 52 D 。 |
| $P_{25} 5$ | 510 |
| $P_{26}$ 近 | $50 A^{\circ}$ |
| $P_{2}$ ， 16 | 49 $A_{1}$ |
| $\mathrm{Psos}^{1717}$ | $48 A_{1}$ |
| $P_{51} 18$ | 47 A ， |
| $P_{52} 19$ | 48． |
| $\mathrm{PS3}_{53} 2$ | 45 A ， |
| $P_{54}{ }^{21}$ | $4 A^{4}$ 。 |
| Pss 22 | 43 A ， |
| $P_{50} 23$ | $42 \mathrm{~V}_{\text {SS }}$ |
| $P_{5}{ }^{24}$ | （41）$A_{2}$ |
| Poo 25 | 44 A 。 |
| $P_{0} 126$ | $3 \mathrm{~A}_{10}$ |
| $P_{62}{ }^{27}$ | 38 $A_{11}$ |
| $P_{03} 28$ | $37{ }^{3} A_{12}$ |
| P64 29 | $36 A_{1}$ ， |
| Pes 30 | $35 \mathrm{~A}_{1}$ ， |
| Pat 31 | $34 A_{15}$ |
| $\mathrm{P}_{81} 32$ | $33 \mathrm{v}_{\text {cC }}$ |

（Top View）
－HD6303YF，HD63A03YF， HD63B03YF，HD63C03YF







－HD6303YCP，HD63A03YCP， HD63B03YCP，HD63C03YCP



## ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{cc}}+0.3$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

(NOTE) This product has protection circuits in input terminal from high static electricity voltage and high electric field.
But be careful not to apply overvoltage more than maximum ratings to these high input impedance protection circuits. To assure the normal operation, we recommend $\mathrm{V}_{\text {in }}, \mathrm{V}_{\text {out }}: \mathrm{V}_{\mathrm{SS}} \leqq\left(\mathrm{V}_{\text {in }}\right.$ or $\left.\mathrm{V}_{\text {out }}\right) \leqq \mathrm{V}_{\mathrm{Cc}}$.

ELECTRICAL CHARACTERISTICS

- DC CHARACTERISTICS ( $\mathbf{V}_{\mathbf{c c}}=\mathbf{5 . 0 V} \pm \mathbf{1 0 \%}, \mathrm{V}_{\mathbf{s s}}=\mathbf{0 V}, \mathbf{T a}=\mathbf{0 \sim + 7 0}{ }^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item |  | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input "High" Voltage | RES, STBY | $\mathrm{V}_{\mathbf{H}}$ |  | $\mathrm{V}_{c c}-0.5$ | - | $\begin{gathered} v_{c c} \\ +0.3 \end{gathered}$ | v |
|  | EXTAL |  |  | $\mathrm{V}_{\mathrm{cc}} \times 0.7$ | - |  |  |
|  | Other Inputs |  |  | 2.0 | - |  |  |
| Input "Low" Voltage | All Inputs | $\mathrm{V}_{\mathrm{ll}}$ |  | -0.3 | - | 0.8 | V |
| Input Leakage Current | NMM, RES, STBY, $M P_{0}, M P_{1}$ | $\left\|i_{\text {in }}\right\|$ | $\mathrm{V}_{\text {in }}=0.5 \sim \mathrm{~V}_{\mathrm{cc}}-0.5 \mathrm{~V}$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Three State Leakage Current | $A_{0}-A_{15}, D_{0} \sim D_{7}, \overline{R D},$ <br> WR, R/W, Ports 2, 5, 6 | $\left\|i_{\text {TSII }}\right\|$ | $\mathrm{V}_{\text {in }}=0.5 \sim \mathrm{~V}_{\mathrm{cc}}-0.5 \mathrm{~V}$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Output "High" Voltage | All Outputs | $\mathrm{V}_{\text {OH }}$ | $\mathrm{IOH}^{\text {O }}=-200 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  |  |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{cc}}-0.7$ | - | - | V |
| Output "Low" Voltage | All Outputs | $\mathrm{V}_{0}$ | $\mathrm{loL}_{\text {L }}=1.6 \mathrm{~mA}$ | - | - | 0.4 | V |
| Darlington Drive Current | Ports 2, 6 | $-\mathrm{IOH}$ | $V_{\text {out }}=1.5 \mathrm{~V}$ | 1.0 | - | 10.0 | mA |
| Input Capacitance | All Inputs | $\mathrm{C}_{\text {in }}$ | $\begin{aligned} & \mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}, \\ & \mathrm{Ta}_{\mathrm{a}}=25^{\circ} \mathrm{C} \end{aligned}$ | - | - | 12.5 | pF |
| Standby Current | Non Operation | $\mathrm{I}_{\text {STB }}$ |  | - | 3.0 | 15.0 | $\mu \mathrm{A}$ |
| Current Dissipation ${ }^{\text {- }}$ |  | $\mathrm{I}_{\text {SLP }}$ | Sleeping ( $\mathrm{f}=1 \mathrm{MHz}^{\circ} \mathrm{C}$ ) | - | 1.5 | 3.0 | mA |
|  |  | Sleeping ( $\mathrm{f}=1.5 \mathrm{MHz}{ }^{\circ}{ }^{\circ}$ ) | - | 2.3 | 4.5 | mA |  |
|  |  | Sleeping ( $\mathbf{f}=\mathbf{2 M H z}{ }^{\circ}$ ) | - | 3.0 | 6.0 | mA |  |
|  |  | ${ }^{\text {cce }}$ | Operating ( $\mathrm{f}=1 \mathrm{MHz}{ }^{\circ}{ }^{\circ}$ ) | - | 7.0 | 10.0 | mA |
|  |  | Operating ( $f=1.5 \mathrm{MHz}^{\circ}$ ) | - | 10.5 | 15.0 | mA |  |
|  |  | Operating ( $\mathrm{f}=\mathbf{2} \mathbf{M H z}{ }^{\circ}$ ) | - | 14.0 | 20.0 | mA |  |
| RAM Standby Voltage |  |  | $\mathrm{V}_{\text {RAM }}$ |  | 2.0 | - | - | V |

. $V_{H H} \min =V_{C C}-1.0 \mathrm{~V}, V_{k} \max =0.8 \mathrm{~V}$ (All output terminals are at no load.)
-* Current Dissipation of the operating or sleeping condition is proportional to the operating frequency. So the typ. or max. values about Current Dissipations at $\chi \mathrm{MHz}$ operation are decided according to the following formula:
typ. value ( $f=X \mathrm{MHz}$ ) $=$ typ. value $(f=1 \mathrm{MHz}) \times \chi$
max. value $(f=\chi \mathbf{M H z})=$ max. value $(f=1 \mathrm{MHz}) \times \chi$
(both the sleeping and operating)

- AC CHARACTERISTICS $\left(V_{c C}=5.0 \mathrm{~V} \pm 10 \%, V_{s s}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

BUS TIMING


- These timings change in approximate proportion to $t_{\text {cyc }}$. The figures in this characteristics represent those when $t_{\text {cyc }}$ is minimum $(=$ in the highest speed operation).

PERIPHERAL PORT TIMING

| Item |  | Symbol | Test Condition | HD6303Y |  |  | HD63A03Y |  |  | HD63B03Y |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Peripheral Data Set Up Time | Port 2, 5, 6 |  | $t_{\text {PDSU }}$ | Fig. 5 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Peripheral Data Hold Time | Port 2, 5, 6 | $\mathrm{t}_{\text {PDH }}$ | 200 |  | - | - | 200 | - | - | 200 | - | - | ns |
| Delay Time (From Enable Fall Edge to Peripheral Output) | Port 2, 5, 6 | towo | Fig. 6 | - | - | 300 | - | - | 300 | - | - | 300 | ns |
| Input Strobe Pulse Width |  | $t_{\text {PWIS }}$ | Fig. 10 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Input Data Hold Time | Port 6 | $t_{\text {H }}$ |  | 150 | - | - | 150 | - | - | 150 | - | - | ns |
| Input Data Set-Up Time | Port 6 | ${ }_{4}$ |  | 100 | - | - | 100 | - | - | 100 | - | - | ns |
| Output Strobe Delay Time |  | tosD1 | Fig. 11 | - | - | 200 | - | - | 200 | - | - | 200 | ns |
|  |  | tosD2 |  |  |  |  |  |  |  |  |  |  |  |

TIMER, SCI TIMING

| Item |  | Symbol | Test Condition | HD6303Y |  |  | HD63A03Y |  |  | HD63B03Y |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max | min | typ | max |  |
| Timer 1 Input Pulse Width |  |  | ${ }_{\text {PWWT }}$ | Fig. 9 | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| Delay Time (Enable Positive Transition to Timer Output) |  | ${ }_{\text {t }}$ TOD | Fig. 7, 8 | - | - | 400 | - | - | 400 | - | - | 400 | ns |
| SCI Input Clock Cycle | Async. Mode | ${ }^{\text {tscyc }}$ | Fig. 9 | 1.0 | - | - | 1.0 | - | - | 1.0 | - | - | ${ }_{\text {tayc }}$ |
|  | Clock Sync. |  | Fig. 4 | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| SCI Transmit Data Delay Time (Clock Sync. Mode) |  | ${ }^{\text {T TXD }}$ | Fig. 4 | - | - | 220 | - | - | 220 | - | - | 220 | ns |
| SCI Receive Data Set-up Time (Clock Sync. Mode) |  | ${ }^{\text {t }}$ SRX |  | 260 | - | - | 260 | - | - | 260 | - | - | ns |
| SCI Receive Data Hold Time (Clock Sync. Mode) |  | $t_{\text {HRX }}$ |  | 100 | - | - | 100 | - | - | 100 | - | - | ns |
| SCI Input Clock Pulse Width |  | ${ }^{\text {tpwsck }}$ | Fig. 9 | 0.4 | - | 0.6 | 0.4 | - | 0.6 | 0.4 | - | 0.6 | ${ }^{\text {t }}$ Scyc |
| Timer 2 Input Clock Cycle |  | $\mathrm{t}_{\mathbf{t c y c}}$ |  | 2.0 | - | - | 2.0 | - | - | 2.0 | - | - | $\mathrm{t}_{\text {cyc }}$ |
| Timer 2 Input Clock Pulse Width |  | ${ }^{\text {t }}$ PWTCK |  | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Timer 1-2, SCI Input Clock Rise Time |  | ${ }^{\text {t }} \mathbf{C K}$ |  | - | - | 100 | - | - | 100 | - | - | 100 | ns |
| Timer 1-2, SCI Input Clock Fall Time |  | ${ }^{\mathbf{t}} \mathbf{C K}{ }^{\text {f }}$ |  | - | - | 100 | - | - | 100 | - | - | 100 | ns |



Figure 1 Bus Timing


Figure 2 Memory Ready and E Clock Timing


Figure $3 \overline{\text { HALT }}$ and BA Timing


Figure 4 SCI Clocked Synchronous Timing


Figure 6 Port Data Delay Times (MPU Write)


Figure 7 Timer 1 Output Timing


Figure 9 Timer 1.2, SCI Input Clock Timing

(TCONR=N)
Figure 8 Timer 2 Output Timing


Figure 10 Port 6 Input Latch Timing


Figure 12 Bus Timing Test Loads (TTL Load)


Figure 13 Interrupt Sequence


Figure 14 Reset Timing

## FUNCTIONAL PIN DESCRIPTION

$V_{\mathrm{cc}}, \mathrm{V}_{\mathrm{ss}}$
$\mathbf{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{ss}}$ provide power to the MPU with $5 \mathrm{~V} \pm 10 \%$ supply. In the case of low speed operation ( $\mathrm{fmax}=500 \mathrm{kHz}$ ), the MPU can operate with 3 to 5.5 volts. Two $\mathbf{V}_{\text {ss }}$ pins should be tied to ground.

## - XTAL, EXTAL

These two pins interface with an AT-cut parallel resonant crystal. Divide-by-four circuit is on chip, so if 4 MHz crystal oscillator is used, the system clock is 1 MHz for example.

EXTAL pin can be drived by the external clock with $45 \%$ to $55 \%$ duty. The system clock which is one fourth frequency of the external clock is generated in the LSI. The external clock frequency should be less than four times of the maximum operating frequency. When using the external clock, XTAL pin should be open. Fig. 15 shows examples of connection circuit. The crystal and $\mathrm{C}_{\mathrm{L} 1}, \mathrm{C}_{\mathrm{L} 2}$ should be mounted as close as possible to XTAL and EXTAL pins. Any line must not cross the line between the crystal oscillator and XTAL, EXTAL.

AT Cut Parallel Resonant Crystal Oscillator


Figure 15 Connection Circuit

- STBY

This pin makes the MPU standby mode. In "Low" level, the oscillation stops and the internal clock is stabilized to make reset condition. To retain the contents of RAM at standby mode, " 0 " should be written into RAM enable bit (RAME). RAME is the bit 6 of the RAM/port 5 control register at $\$ 0014$. RAM is disabled by this operation and its contents is sustained.

Refer to "LOW POWER DISSIPATION MODE" for the standby mode.

## - Reset (RES)

This pin resets the MPU from power OFF state and provides a startup procedure. During power-on, RES pin must be held "Low" level for at least 20 ms .

The CPU registers (accumulator, index register, stack pointer, condition code register except for interrupt mask bit), RAM and the data register of ports are not initialized during reset, so their contents are undefined in this procedure.

To reset the MPU during operation, $\overline{R E S}$ should be held "Low" for at least 3 system-clock cycles. At the 3rd cycle during "Low" level, all the address buses become "High". When RES remains "Low", the address buses keep "High". If RES becomes "High", the MPU starts the next operation.
(1) Latch the value of the mode program pins; $\mathbf{M P}_{0}$ and $\mathbf{M P}_{1}$.
(2) Initialize each internal register (Refer to Table 4).
(3) Set the interrupt mask bit. For the CPU to recognize the maskable interrupts $\overline{I R Q}_{1}, \overline{\text { IRQ }_{2}}$ and IRQ $_{3}$, this bit should be cleared in advance.
(4) Put the contents (=start address) of the last two addresses (SFFFE, SFFFF) into the program counter and start the program from this address. (Refer to Table 1).

## - Enable (E)

This pin provides a TTL-compatible system clock to external circuits. Its frequency is one fourth that of the crystal oscillator or external clock. This pin can drive one TTL load and 90 pF capacitance.

- Non-Maskable Interrupt (NMI)

When the falling edge of the input signal is detected at this pin, the CPU begins non-maskable interrupt sequence internally. As
well as the IRQ mentioned below, the instruction being executed at NMI signal detection will proceed to its compeletion. The interrupt mask bit of the condition code register doesn't affect non-maskable interrupt at all.

In response to an $\overline{\mathrm{NMI}}$ interrupt, the contents of the program counter, index register, accumulators and condition code register will be saved onto the stack. Upon completion of this sequence, a vector is fetched from \$FFFC and \$FFFD to transfer their contents into the program counter and branch to the non-maskable interrupt service routine.
(Note) At reset start, the stack pointer should be initialized on an appropriate memory area and then the falling edge be input to NMI pin.

## - Interrupt Request (TR $\boldsymbol{T}_{1}$, IR $_{2}$ )

These are level-sensitive pins which request an internal interrupt sequence to the CPU. At interrupt request, the CPU will complete
the current instruction before the acceptance of the request. Unless the interrupt mask in the condition code register is set, the CPU starts an interrupt sequence; if set, the interrupt request will be ignored. When the sequence starts, the contents of the program counter, index register, accumulators and condition code register will be saved onto the stack, then the CPU sets the interrupt mask bit and will not acknowledge the maskable request. During the last cycle, the CPU fetches vectors depicted in Table 1 and transfers their contents to the program counter and branches to the service routine.

The CPU uses the external interrupt pins ( $\overline{\text { IRQ }}_{1}$ and $\overline{\mathrm{IRQ}}_{2}$ ) also as port pins $P_{50}$ and $P_{51}$, so it provides an enable bit to Bit 0 and 1 of the RAM port 5 control register at \$0014. Refer to "RAM/PORT 5 CONTROL REGISTER" for the details.

When one of the internal interrupts, ICI, OCI, TOI, CMI or SIO is generated, the CPU produces internal interrupt signal (IRQ ${ }_{3}$ ). IRQ $_{3}$ functions just the same as $\overline{\operatorname{IRQ}}_{1}$ or $\overline{\operatorname{IRQ}}_{2}$ except for its vector address. Fig. 16 shows the block diagram of the interrupt circuit.


Figure 16 Interrupt Circuit Block Diagram

Table 1 Interrupt Vector Memory Map

| Priority | Vector |  | Interrupt |
| :---: | :---: | :---: | :---: |
|  | MSB | LSB |  |
| Highest | FFFE | FFFF | RES |
|  | FFEE | FFEF | TRAP |
|  | FFFC | FFFD | NMMI |
|  | FFFA | FFFB | SWI <br> (Software Interrupt) |
|  | FFF8 | FFF9 | IRO $_{1}$, ISF (port 6 Input Strobe) |
|  | FFF6 | FFF7 | ICI (Timer 1 Input Capture) |
|  | FFF4 | FFF5 | OCI <br> (Timer 1 Output Compare 1, 2) |
|  | FFF2 | FFF3 | TOI (Timer 1 Overflow) |
|  | FFEC | FFED | CMI <br> (Timer 2 Counter Match) |
|  | FFEA | FFEB | $\mathrm{TRO}_{2}$ |
|  | FFFO | FFF1 | ```SIO (RDRF+ORFE+TDRE + PER)``` |

- Mode Program (MPo, MP1)

Set MP ${ }_{0}$ "High" and MP ${ }_{1}$ "Low".

- Read/Write (R/W)

This signal, usually be in read state ("High'), shows whether the CPU is in read ("High") or write ("Low") state to the peripheral or memory devices. This can drive one TTL load and 30 pF capacitance.

- RD, WR

These signals show active low outputs when the CPU is reading/ writing to the peripherals or memories. This enables the CPU easy to access the peripheral LSI with $\overline{R D}$ and $\overline{W R}$ input pins. These pins can drive one TTL load and 30 pF capacitance.

## - Load Instruction Register (LIR)

This signal shows the instruction opecode being on data bus (active low). This pin can drive one TTL load and 30 pF capacitance.

## - Memory Ready (MR; P P $_{52}$ )

This is the input control signal which stretches the system clock's "High" period to access low-speed memories. HD6303Y can select three kinds of low-speed memory access method by RAM/Port 5 Control Register's MRE bit and AMRE bit. In the case that CPU accesses low-speed memories by the external MR signal (MRE=" 1 ", AMRE=" 0 "), the system clock operates in normal sequence when this signal is in "High".

But this signal in "Low", the "High" period of the system clock will be stretched depending on its "Low" level duration in integral multiples of the cycle time. This allows the CPU to interface with low-speed memories (See Fig. 2). Up to $9 \mu \mathrm{~s}$ can be stretched.

During internal address space access or nonvalid memory access, MR is prohibited internally to prevent decrease of operation speed. Even in the halt state, MR can also stretch "High" period of system clock to allow peripheral devices to access low-speed memo-
ries. Refer to "RAM/PORT 5 CONTROL REGISTER" for more details.

- Halt (HALT; $\mathrm{P}_{\mathrm{E3}}$ )

This is an input control signal to stop instruction execution and to release buses. When this signal switches to "Low", the CPU stops to enter into the halt state after having executed the present instruction. When entering into the halt state, it makes BA "High" and also an address bus, data bus, $\overline{\mathbf{R D}}, \overline{\mathrm{WR}}, \mathbf{R} / \overline{\mathbf{W}}$ high impedance. When an interrupt is generated in the halt state, the CPU uses the interrupt handler after the halt is cancelled. When halted during the sleep state, the CPU keeps the sleep state, while BA is "High" and releases the buses. Then the CPU returns to the previous sleep state when the HALT signal becomes "High".
(Note) Please don't switch the HALT signal to "Low" when the CPU executes the WAI instruction and is in the interrupt wait state to avoid the trouble of the CPU's operation after the halt is cancelled.

## - Bus Available (BA)

This is an output control signal which is normally "Low" but "High" when the CPU accepts HALT and releases the buses. The HD6800 and HD6802 make BA "High" and release the buses at WAI execution, while the HD6303Y doesn't make BA "High" under the same condition.

## - PORT

The HD6303Y provides three 8-bit I/O ports. Each port provides Data Direction Register (DDR) which controls the I/O state by the bit.

Table 2 Port and Data Direction Register Address

| Port | Port Address | Data Direction Register |
| :---: | :---: | :---: |
| Port 2 | $\$ 0003$ | $\$ 0001$ |
| Port 5 | $\$ 0015$ | $\$ 0020$ |
| Port 6 | $\$ 0017$ | $\$ 0016$ |

- Port 2

An 8-bit I/O port. Port 2 DDR (P2DDR) controls the I/O state. This port provides DDR corresponding to each bit and can define input or output by the bit (" 0 " for input, " 1 " for output).

As Port 2 DDR is cleared during reset, it will be an input port.
Port 2 is also used as an I/O pin for timer 1, Timer 2 and the SCI. Pins for Timers and the SCI set or reset each DDR depending on their functions and become I/O pins. When port 2 functions as an I/ O port after used as I/O pins of the timers or the SCI, the I/O direction of the pins remain as it is used as the I/O pin of timer and SCI.

Port 2 can drive one TTL load and 30 pF capacitance. This port can produce $\operatorname{lmA}$ when $\mathrm{V}_{\text {out }}=1.5 \mathrm{~V}$ to drive directly the base of Darlington transistor.
$P_{20}$ (Tin)
$P_{20}$ is also used as an external input pin for the input-capture. This pin is an I/O port which is an input or output as defined by the Data Direction Register ( $\mathrm{P}_{20}$ DDR) (" 0 " for an input and " 1 " for an output). Then either a signal to or from $P_{20}$ ("to"' for an output port, "from" for an input port) is always input to the Timer 1 input capture.

$\mathbf{P}_{21}$ (Tout 1), $\mathbf{P}_{\mathbf{2 4}}$ (Tx), $\mathrm{P}_{\mathbf{2 5}}$ (Tout 2), $\mathrm{P}_{25}$ (Tout 3)
These four pins can be also used as output pins for Timer 1, Timer 2 and a transmit output of the SCI. Timer 1, and the SCI
have a register which enables output. By setting these registers, they automatically will be output pins of timer or the SCI.


## $P_{22}$ (SCLK)

$\mathrm{P}_{22}$ is also used as a clock I/O pin for the SCI. It is selected as a clock input or output pin by the operating mode of the SCI. It is usa-
ble as an I/O port when the SCI has no clock input or output (as an output port if $\mathbf{P}_{22}$ DDR $=1$, as an input port if $\mathbf{P}_{22}$ DDR $=0$ ).


## $P_{23}$ (Rx), $P_{27}$ (TCLK)

$\mathrm{P}_{23}$ and $\mathrm{P}_{27}$ are also used as received data input pins for the SCI and external clock input pins for Timer 2. The SCI and Timer 2 have registers which enable input. If the registers are set, the DDR ( $P_{23}$ DDR, $P_{27}$ DDR) are cleared and $P_{23}$ and $P_{27}$ will be input pins for Rx and TCLK.

Since the SCI will be a clocked synchronous mode by an external clock-input during reset, the DDR of $\mathrm{P}_{22}$ is cleared automatically and $P_{22}$ is an input port. Set the SCI to a mode where $P_{22}$ is not used (CC0 or CC1 of the RMC Register is " 0 " or " 1 " respectively) and write " 1 " to the $\mathbf{P}_{22}$ DDR to make $\mathbf{P}_{22}$ an output port.

MSB

| $P_{27}$ | $\mathbf{P}_{26}$ | $P_{25}$ | $P_{24}$ | $P_{23}$ | $P_{22}$ | $P_{21}$ | $\mathbf{P}_{20}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR | DDR | DDR | DDR | DDR | DDR | DDR | DDR |

PORT2 DDR (\$0001)
Write only, \$00
during reset.)


PORT2 $(\$ 0003)$
(R/W, not initialized during reset.)

## - Port 5

An 8-bit I/O port. The DDR of port 5 controls I/O state. Each bit of port 5 has a DDR which defines I/O state (" 0 " for input and " 1 " for output).

During reset, the DDR of port 5 is cleared and port 5 becomes an input port.

Port 5 is also usable as $\overline{\text { IRQ }_{1}}, \overline{\text { IRQ }}, \overline{\text { HALT, MR }}$ and the strobed signal of port 6 for handshake (IS, OS). It is set to input or output automatically if it is used as these control signal pins (except $\mathrm{P}_{54}$, IS). Since the DDR of port 5, as is port 2 , is set or reset by the control signal, I/O directions of the I/O ports are retained after the control signal is disabled. Port 5 can drive one TTL load and 90 pF capacitance.
$P_{50}\left(\overline{\mathrm{R} \alpha_{1}}\right), \mathrm{P}_{51}\left(\overline{\mathrm{R} \boldsymbol{Q}_{2}}\right)$
$P_{50}$ and $P_{51}$ are also usable as interrupt pins. The RAM/port 5 control registers of $\mathrm{IRQ}_{1}$ and $\mathrm{IRQ}_{2}$ have enable bits (IQ1E, IQ2E). When these bits are set to " 1 ", $\mathrm{P}_{50}$ and $\mathrm{P}_{51}$ will automatically be interrupt input pins.
$P_{52}$ (MR), $\mathrm{P}_{53}$ (ㄷALT)
${ }_{\mathbf{P}_{52}}$ and $\mathrm{P}_{53}$ are also usable as MR and $\overline{\text { HALT }}$ inputs. MR and HALT have enable bits (MRE, HLTE) in the RAM/Port 5 Control Register as $\overline{\mathrm{IRQ}}_{1}$ and $\overline{\mathrm{IRQ}}_{2}$. Since MRE is cleared during reset, $\mathrm{P}_{52}$ is usable as an I/O port, and HLTE is set during reset, the DDR of $\mathrm{P}_{53}$ will be automatically reset to be a HALT input pin. HLTE of the RAM/Port 5 Control Register has to be cleared to use $P_{53}$ as an I/O port.


- Initializing value during reset;

IRQ1E = " 0 " $"$, IRQ2E $=" 0 "$, MRE $=" 0 "$, HLTE $=" 1 "$
$P_{5 A}(\bar{S})$
$\mathrm{P}_{54}$ is also usable as the input strobe ( $\overline{\mathrm{IS}}$ ) for port 6 handshake interface. This pin, as is $\mathrm{P}_{20}$, is always an I/O port. If $\mathrm{P}_{54}$ is used as an
output port (set the DDR of $\mathrm{P}_{54}$ to " 1 "), an output signal from $\mathrm{P}_{54}$ will be the input to IS.


## (0) HITACHI

$\mathrm{P}_{55}$ (రS)
$P_{55}$ is also usable as the output strobe ( $\overline{\mathrm{OS}}$ ) for port 6 handshake interface. It will be an I/O port during reset, and an OS output pin
by setting the OS enable register (OSE) of the port 6 Control Status Register (P6CSR).

$\mathrm{P}_{56}, \mathrm{P}_{57}$
$P_{56}$ and $P_{57}$ are I/O ports.

MSB

| $P_{57}$ <br> DDR | $P_{58}$ <br> DDR | $P_{55}$ | $P_{54}$ | $P_{53}$ | $P_{52}$ | $P_{51}$ | $P_{50}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR | DDR | DDR | PORT5 DDR ( $\$ 0020)$ <br> WDR | DDR | DDR |  |  |
| Write only, $\$ 00$ |  |  |  |  |  |  |  |
| during reset.) |  |  |  |  |  |  |  |


| $P_{57}$ | $P_{56}$ | $P_{55}$ | $P_{54}$ | $P_{53}$ | $P_{52}$ | $P_{51}$ | $P_{50}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| PORT5 (\$0015) <br> (R/W, not ini- <br> tialized during <br> reset.) |  |  |  |  |  |  |  |

## - Port 6

8-bit I/O port. Port 6 DDR controls I/O state. Each bit of port 6 has a DDR and designates input or output (" 0 " for input, " 1 " for output). During reset, Port 6 DDR is cleared and port 6 becomes an input port.

Port 6 controls parallel handshake interface besides functions as an I/O port. Therefore, it provides DDRs to control and IS LATCH to latch the input data.

Port 6 can drive one TTL load and 30 pF capacitance. It can drive directly the base of Darlington transistor as port 2.


BUS

- Address Bus $\left(A_{0} \sim A_{15}\right)$

Address Bus $\left(A_{0} \sim A_{15}\right)$ is used for addressing the memory and peripheral LSI.

This bus can interface with the bus of HMCS 6800 and drive one TTL load and 90 pF capacitance.

- Data Bus ( $\left.D_{0} \sim D_{7}\right)$

8-bit parallel data bus for data transmit between the memory or peripheral LSI. This bus can drive one TTL load and 90 pF capacitance.

## - RAM/PORT 5 CONTROL REGISTER

The control register located at \$0014 controls on-chip RAM and port 5.

## RAM/Port 5 Control Register (RP5CR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { STBY } \\ & \text { PWWR } \end{aligned}$ | RAME | $\begin{aligned} & \text { STBY } \\ & \text { FLAG } \end{aligned}$ | AMR E | HLTE | MRE | $\underset{E}{\mathrm{IRO}_{\mathbf{2}}}$ | $\underset{E}{\operatorname{IRO}_{1}}$ |

$\$ 0014$

When using $P_{50}$ and $P_{51}$ as interrupt pins, write " 1 " in these bits. When the bit is set to " 1 ", the DDRs corresponding to $P_{50}$ and
$P_{51}$ are cleared and become $\overline{I R Q_{1}}$ input pin and $\overline{I R Q}_{2}$ input pin. When IRQ $Q_{1} E$ and $I R Q_{2} E$ are set, $P_{50}$ and $P_{51}$ cannot be used as an output ports. When " 0 ", the CPU doesn't accept an external interrupt or a sleep cancellation by the external interrupt. These bits are cleared during reset.

## Bit 2 Memory Ready Enable Bit (MRE)

When using $P_{52}$ as an input pin of the "memory ready"' signal, write " 1 " in this bit. When set, $\mathbf{P}_{52}$ DDR is automatically cleared and becomes the MR input pin. The bit is cleared during reset.

## Bit 3 Halt Enable Bit (HLTE)

When using $P_{53}$ as an input pin of the HALT signal, write " 1 " in this bit. When this bit is set, $\mathrm{P}_{53}$ DDR is automatically cleared and becomes the Halt input pin. If the bit is " 0 ", the Halt function is inhibited and $P_{53}$ is used as an I/O port. The bit is set to " 1 " during reset.

## Bit 4 Auto Memory Ready Enable Bit (AMRE)

When the bit is set and the CPU accesses the external address, "memory ready" operates automatically and stretches the E clock's "High" duration for one system clock. When MRE bit of bit 2 is cleared and when the CPU accesses the external address space, the function operates. When MRE bit is set and then the CPU accesses the external address space with $\mathrm{P}_{52}(\mathrm{MR})$ pin in "low', "memory ready" operates automatically. This bit is set to " 1 " during reset.

Table 3 "Memory Ready" Function

| MRE | AMRE | Function |
| :---: | :---: | :--- |
| 0 | 0 | "Memory ready" inhibited. |
| 0 | 1 | When the CPU accesses the external address, "High" duration of E clock automatically becomes one-cycle <br> longer. This state is retained during reset. |
| 1 | 0 | "Memory ready" operates by $P_{52}$ (MR) pin. The function is the same as that of the HD6301X0. |
| 1 | 1 | When the CPU accesses the external address space with the $P_{52}$ (MR) pin in "low"' the "auto memory <br> ready" operates. This function is effective if it has both "high-speed memory" and "slow memory" <br> outside. Input CS signal of "slow memory" to MR pin. |

## Bit 5 Standby Flag (STBY FLAG)

By clearing this flag, HD6303Y gets into the standby mode by software. This flag is set to " 1 " during reset, so the standby mode is canceled with RES pin in "low". The RES pin should be in "low" until oscillation becomes stable ( min . 20ms.). If the STBY pin in is in "low", the standby mode can not be canceled with the RES pin in "low".

## Bit 6 RAM Enable (RAME)

On-chip RAM can be disabled by this control bit. By resetting the MPU, " 1 " is set to this bit, and on-chip RAM is enabled. When
this bit is cleared (= logic " 0 ") on-chip RAM is invalid and the CPU can read data from external memory. This bit should be " 0 " before getting into the standby mode to protect on-chip RAM data.

## Bit 7 Standby Power Bit (STBY PWR)

When $\mathbf{V}_{\text {CC }}$ is not provided in standby mode, this bit is cleared. This is a flag for read/write and can be read by software. If this bit is set before standyby mode, and remains set even after returning from standby mode, $\mathbf{V}_{\mathrm{cc}}$ voltage is provided during standby mode and the on-chip RAM data is valid.
(a) $M R E=0, A M R E=1$

(b) $M R E=1$, AMRE $=1$

(c) $\mathrm{MRE}=1, \mathrm{AMRE}=0$ (HD6301X0 Compatible Mode)


Figure 17 Memory Ready Timing

## - Port 6 Control/Status Register

This is the Control/Status Register for parallel handshake interface using Port 6. The functions are as follows;

1) Latches input data to Port 6 at the $\overline{\mathrm{IS}}\left(\mathrm{P}_{54}\right)$ falling edge.
2) Outputs a strobe signal $\overline{O S}\left(P_{55}\right)$ outward by reading or writing to port 6.
3) When IS FLAG is set at the $\overline{\mathbf{I S}}$ falling edge, an interrupt occurs.

The following shows Port 6 Control/Status Register (P6CSR).

$\$ 0021$
${ }^{-B i t} 7$ is Read-Only bit

Bit 0
Bit 1 Not used.
Bit 2

## Bit 3: Latch Enable

This register controls the input latch for Port 6 (ISLATCH). When this bit is set to " 1 ", the input data to port 6 will be latched inward at the IS ( $\mathrm{P}_{54}$ ) falling edge. An input latch will be canceled by reading Port 6 , which enables to latch the next data. If cleared, the input latch remains canceled and this bit functions as a usual input port. This bit is cleared during reset.

## Blt 4: OSS Output Strobe Select

This register initiates an output strobe ( $\overline{\mathrm{OS}}$ ) from $\mathrm{P}_{55}$ by reading or writing to port 6 . When cleared, OS occurs by reading Port 6. When set, $O S$ occurs by writing to Port 6. This bit is cleared during reset.

## Bit 5: OSE Output Strobe Enable

This register decides the enabling or disabling of the output
strobe. When cleared, $\mathbf{P}_{55}$ functions as an I/O port. When set, $\mathbf{P}_{55}$ functions as an OS output pin. ( $\mathrm{P}_{65}$ DDR is set by OSE.) This bit is cleared during reset.

## Bit 6: IS IRQ, Enable Input Strobe Interrupt Enable

When set, an $\mathrm{IRQ}_{1}$ interrupt to the CPU occurs by setting IS FLAG of bit 7. When cleared, the interrupt does not occur. This bit is cleared during reset.

## Bit 7: is Flag Input Strobe Fiag

This flag is set at the IS $\left(P_{54}\right)$ falling edge. This flag is for readonly. When set, the flag is cleared by reading or writing to Port 6 after reading the Port 6 Control Status Register. This bit is cleared during reset.

## - MEMORY MAP

The MPU can address up to 65 k bytes. Memory map is shown in Fig. 20. 40 addresses ( $\$ 0000 \sim \$ 0027$ except $\$ 00, \$ 02, \$ 04, \$ 05$, $\$ 06, \$ 07, \$ 18$ ) are the internal registers as shown in Table 4.


Figure 18 Input Strobe Interrupt block Diagram


Figure 19 HD6303Y Operating Function

Table 4 Internal Register

| Address | Register | Abbreviation | R/W** | Initialized value during reset ${ }^{*}$ - |
| :---: | :---: | :---: | :---: | :---: |
| 00* | Port 1 DDR (Data Direction Register) | P1DDR | W | \$FE |
| 01 | Port 2 DDR | P2DDR | W | \$00 |
| 02* | Port 1 | PORT1 | R/W | indefinite |
| 03 | Port 2 | PORT2 | R/W | indefinite |
| 04* | Port 3 DDR | P3DDR | W | \$FE |
| 05* | Port 4 DDR | P4DDR | W | \$00 |
| $06 *$ | Port 3 | PORT3 | R/W | indefinite |
| 07* | Port 4 | PORT4 | R/W | indefinite |
| 08 | Timer Control/Status Register 1 | TCSR1 | R/W | \$00 |
| 09 | Free Running Counter (MSB) | FRCH | R/W | \$00 |
| OA | Free Running Counter (LSB) | FRCL | R/W | \$00 |
| OB | Output Compare Register 1 (MSB) | OCR1H | R/W | \$FF |
| OC | Output Compare Register 1 (LSB) | OCR1L | R/W | \$FF |
| OD | Input Capture Register (MSB) | ICRH | R | \$00 |
| OE | Input Capture Register (LSB) | ICRL | R | \$00 |
| OF | Timer Control/Status Register 2 | TCSR2 | R/W | \$10 |
| 10 | Rate/Mode Control Register | RMCR | R/W | \$CO |
| 11 | Tx/Rx Control Status Register 1 | TRCSR1 | R/W | \$20 |
| 12 | Receive Data Register | RDR | R | \$00 |
| 13 | Transmit Data Register | TDR | W | indefinite |
| 14 | RAM/Port 5 Control Register | RP5CR | R/W | \$F8 or \$78 |
| 15 | Port 5 | PORT5 | R/W | indefinite |
| 16 | Port 6 DDR | P6DDR | W | \$00 |
| 17 | Port 6 | PORT6 | R/W | indefinite |
| 18 | Port 7 | PORT7 | R/W | indefinite |
| 19 | Output Compare Register 2 (MSB) | OCR2H | R/W | \$FF |
| 1 A | Output Compare Register 2 (LSB) | OCR2L | R/W | \$FF |
| 1 B | Timer Control/Status Register 3 | TCSR3 | R/W | \$20 |
| 1 C | Time Constant Register | TCONR | W | \$FF |
| 1 D | Timer 2 Up Counter | T2CNT. | R/W | \$00 |
| 1 E | Tx/Rx Control Status Register 2 | TRCSR2 | R/W | \$28 |
| $1 F^{\circ * * *}$ | Test Register* | TSTREG | - | - |
| 20 | PORT 5 DDR | P5DDR | W | \$00 |
| 21 | PORT 6 Control/Status Register | P6CSR | R/W | \$07 |
| 22 | - | - | - | - |
| 23 | - | - | - | - |
| 24 | - | - | - | - |
| 25 | - | - | - | - |
| 26 | - | - | - | - |
| 27 | - | - | - | - |

[^8]

Figure 20 HD6303Y Memory Map

- TIMER 1

The HD6303Y provides a 16 -bit programmable timer which can simultaneously measure an input waveform and generate two independent output waveforms. The pulse widths of both input/output waveforms vary from microseconds to seconds.

Timer 1 is configured as follows (refer to Fig. 22).

- Control/Status Register 1 (8 bit)
- Control/Status Register 2 ( 7 bit)
- Free Running Counter (16 bit)
- Output Compare Register 1 ( 16 bit)
- Output Compare Register 2 (16 bit)
- Input Capture Register ( 16 bit)
- Free-Running Counter (FRC) (\$0009:000A)

The key timer element is a 16 -bit free-running counter driven and incremented by system clock. The counter value is readable by software without affecting the counter. The counter is cleared during reset.

When writing to the upper byte ( $\$ 09$ ), the CPU writes the preset value ( $\$$ FFF8) into the counter (address $\$ 09, \$ 0 \mathrm{~A}$ ) regardless of the write data value. But when writing to the lower byte ( $\$ 0 \mathrm{~A}$ ) after the upper byte writing, the CPU writes not only lower byte data into lower 8 bit, but also upper byte data into higher 8 bit of the FRC.

The counter will be as follows when the CPU writes to it by double store instructions (STD, STX, etc.)


In the case of the CPU write (\$5AF3) to the FRC

Figure 21 Counter Write Timing

## - Output Compare Register (OCR)

(\$000B, \$000C; OCR1) (\$0019, \$001A: OCR2)
The output compare register is a 16 -bit read/write register which can control an output waveform. The data of OCR is always compared with the FRC.

When the data matches, output compare flag (OCF) in the timer control/status register (TCSR) is set. If an output enable bit (OE) in the TCSR2 is " 1 ", an output level bit(OLVL) in the TCSR will be output to bit 1 (OCR 1) and bit 5 (OCR 2) of port 2. To control the output level again by the next compare, the value of OCR and OLVL should be changed. The OCR is set to \$FFFF at reset. The compare function is inhibited for a cycle just after a write to the upper byte of the OCR or FRC. This is to set the 16 -bit value valid in the counter register for compare. In addition, it is because counter is to set \$FFF8 at the next cycle of the CPU's upper byte write to the FRC.

* For data write to the FRC or the OCR, 2-byte transfer instruction (such as STX, etc.) should be used.
- Input Capture Register (ICR) (\$000D : O00E)

The input capture register is a 16 -bit read-only register which stores the FRC's value when external input signal transition generates an input capture pulse. Such transition is controled by input edge bit (IEDG) in the TCSR1.

In order to input the external input signal to the edge detector, a bit of the DDR corresponding to bit 0 of port 2 should be cleared ("0"). When an input capture pulse occurs by external input signal transition at the next cycle of CPU's high-byte read of the ICR, the input capture pulse will be delayed by one cycle. In order to ensure the input capture operation, a CPU read of the ICR needs 2 -byte transfer instruction. The input pulse width should be at least 2 system cycles. This register is cleared ( $\$ 0000$ ) during reset.

## - Timer Control/Status Register 1 (TCSR1) (\$0008)

The timer control/status register 1 is an 8 -bit register. All bits are readable and the lower 5 bits are also writable. The upper 3 bits are read-only which indicate the following timer status.
Bit 5 The counter value reached to $\$ 0000$ as a result of coun-ting-up (TOF).
Bit 6 A match has occurred between the FRC and the OCR 1 (OCF1).
Bit 7 Defined transition of the timer input signal causes the counter to transfer its data to the ICR (ICF).
The followings are the each bit descriptions.
Timer Control/Status Register 1


Bit 0 OLVL1 Output Level 1
OLVL1 is transferred to port 2 , bit 1 when a match occurs between the counter and the OCR1. If bit 0 of the TCSR2 (OE1). is set to " 1 ", OLVL1 will appear at bit 1 of port 2 .
Bit 1 IEDG Input Edge
This bit determines which edge, rising or falling, of input signal of bit 0 of port 2 will trigger data transfer from the counter to the ICR. For this function, the DDR corresponding to port 2, bit 0 should be cleared beforehand.

$$
\begin{gathered}
\text { IEDG }=0, \text { triggered on a falling edge } \\
\text { ("High" to "Low") } \\
\text { IEDG }=1, \begin{array}{l}
\text { triggered on a rising edge } \\
\text { ("Low" to "High") }
\end{array}
\end{gathered}
$$

## Bit 2 ETOI Enable Timer Overflow Interrupt

When this bit is set, an internal interrupt (IRQ ${ }_{3}$ ) by TOI interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 3 EOCII Enable Output Compare Interrupt 1

When this bit is set, an internal interrupt ( $\mathrm{IRQ}_{3}$ ) by OCIl interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 4 EICI Enable Input Capture Interrupt
When this bit is set, an internal interrupt $\left(\right.$ IRQ $\left._{3}\right)$ by ICI interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 5 TOF Timer Overflow Fiag
This read-only bit is set when the counter increments from SFFFF by 1. Cleared when the counter's MSB byte ( $\mathbf{\$ 0 0 0 9 \text { ) is }}$ read by the CPU after the TCSR1 read at TOF=1.
Bit 6 OCF1 Output Compare Flag 1
This read-only bit is set when a match occurs between the OCR1 and the FRC. Cleared when writing to the OCR1 (\$000B or $\$ \mathbf{O O C}$ ) after the TCSR1 or TCSR2 read at OCF $=1$.
Bit 7 ICF Input Capture Fiag
This read-only bit is set when an input signal of port 2 , bit 0 makes a transition as defined by IEDG and the FRC is transferred to the ICR. Cleared when reading the upper byte ( $\$ 000 \mathrm{D}$ ) of the ICR after the TCSR1 or TCSR2 read at ICF=1.

- Timer Control/Status Register 2 (TCSR2) (\$000F)

The timer control/status register 2 is a 7 -bit register. All bits are readable and the lower 4 bits are also writable. But the upper 3 bits are read-only which indicate the following timer status.
Bit 5 A match has occurred between the FRC and the OCR2 (OCF2).
Bit 6

## Timer Control/Status Register 2



Bit 7 The same status flag as the ICF flag of the TCSR1, bit 7. The followings are the each bit descriptions.

## Bit 0 OE1 Output Enable 1

This bit enables the OLVL1 to appear at port 2 , bit 1 when a match has occurred between the counter and the output compare register 1 . When this bit is cleared, bit 1 of port 2 will be an I/O port. When set, it will be an output of OLVL1 automatically.

## Bit 1

OE2 Output Enable 2
This bit enables the OLVL2 to appear at port 2, bit 5 when a match has occurred between the counter and the output compare register 2. When this bit is cleared, port 2, bit 5 will be an I/ 0 port. When set, it will be an output of OLVL2 automatically.
Bit 2 OLVL2 Output Level 2
OLVL2 is transferred to port 2, bit 5 when a match has occurred between the counter and the OCR2. If bit 5 of the TCSR2 (OE2), is set to " 1 ", OLVL2 will appear at port 2 , bit 5 .
Bit 3 EOCI2 Enable Output Compare Interrupt 2
When this bit is set, an internal interrupt (IRQ ${ }_{3}$ ) by OCI2 interrupt is enabled. When cleared, the interrupt is inhibited.
Bit 4 Not used
Bit 5 OCF2 Output Compare Flag 2
This read-only bit is set when a match has occurred between the counter and the OCR2. Cleared when writing to the OCR2 ( $\$ 0019$ or $\$ 001 \mathrm{~A}$ ) after the TCSR2 read at $0 C F 2=1$.
Bit 6 OCF1 Output Compare Flag 1
Bit 7 ICF Input Capture Fiag
OCF1 and ICF are dual addressed. If which register, TCSR1 or TCSR2, CPU reads, it can read OCF1 and ICF to bit 6 and bit 7.

Both the TCSR1 and TCSR2 will be cleared during reset.
(Note) If OE1 or OE2 is set to " 1 " before the first output compare match occurs after reset restart, bit 1 or bit 5 of port 2 will produce " 0 " respectively.


Figure 22 Timer 1 Block Diagram

## - TIMER 2

In addition to the timer 1, the HD6303Y provides an 8 -bit reloadable timer, which is capable of counting the external event. The timer 2 contains a timer output, so the MPU can generate three independent waveforms. (Refer to Fig. 23.)

The timer 2 is configured as follows:

- Control/Status Register 3 ( 7 bits)
- 8-bit Up Counter
- Time Constant Register (8 bits)
- Timer 2 Up Counter (T2CNT) (\$001D)

This is an 8 -bit up counter which operates with the clock decided by CKS0 and CKS1 of the TCSR3. The CPU can read the value of the counter without affecting the counter. In addition, any value can be written to the counter by software even during counting.

The counter is cleared when a match occurs between the counter and the TCONR or during reset.

If the write operation is made by software to the counter at the cycle of counter clear, it does not reset the counter but put the write data to the counter.

- Time Constant Register (TCONR) (\$001C)

The time constant register is an 8 -bit write only register. The data of register is always compared with the counter.

When a match has occurred, the counter match flag (CMF) of the timer control status register 3 (TCSR3) is set and the value
selected by TOS0 and TOS1 of the TCSR 3 will appear at port 2 , bit 6. When CMF is set, the counter will be cleared simultaneously and then start counting from $\$ 00$. This enables regular interrupts and waveform outputs without any software support. The TCONR is set to " $\$ F F$ " during reset.

- Timer Control/Status Register 3 (TCSR3) (\$001B)

The timer control/status register 3 is a 7 -bit register. All bits are readable and 6 bits except for CMF can be written.

The followings are each pin descriptions.
Timer Control/Status Register 3


Bit 0 CKSO Input Clock Select 0
Bit 1 CKS1 Input Clock Select 1
Input clock to the counter is selected as shown in Table 5 depending on these two bits. When an external clock is selected, bit 7 of port 2 will be a clock input automatically. Timer 2 detects the rising edge of the external clock and increments the counter. The external clock is countable up to half the frequency of the system clock.


Figure 23 Timer 2 Block Diagram

Table 5 Input Clock Select

| CKS1 | CKSO | Input Clock to the Counter |
| :---: | :---: | :--- |
| 0 | 0 | E clock |
| 0 | 1 | E clock/8 |
| 1 | 0 | E clock/128 |
| 1 | 1 | External clock |

- These clocks come from the FRC of the timer 1. If one of these clocks is selected as an input clock to the up counter, the CPU' should not write to the FRC of the timer 1.

Bit 2 TOSO Timer Output Select 0
Bit 3 TOS 1 Timer Output Select 1
When a match occurs between the counter and the TCONR timer 2 outputs shown in Table 6 will appear at port 2, bit 6 depending on these two bits. When both TOS0 and TOS1 are " 0 ", bit 6 of port 2 will be an I/O port.

Table 6 Timer 2 Output Select

| TOS 1 | TOSO | Timer Output |
| :---: | :---: | :--- |
| 0 | 0 | Timer Output Inhibited |
| 0 | 1 | Toggle Output" |
| 1 | 0 | Output "0" |
| 1 | 1 | Output "1" |

- When a match occurs between the counter and the TCONR, timer 2 output level is reversed. This leads to production of a square wave with $\mathbf{5 0 \%}$ duty to the external without any software support.


## Bit 4 T2E Timer 2 Enable Bit

When this bit is cleared, a clock input to the up counter is inhibited and the up counter stops. When set to " 1 ", a clock
selected by CKS1 and CKS0 (Table 5) is input to the up counter. (Note) $P_{26}$ outputs " 0 " when T2E bit cleared and timer 2 set in output enable condition by TOS1 or TOSO. It also outputs " 0 " when T2E bit set " 1 " and timer 2 set in output enable condition before the first counter match occurs.

## Bit 5 Not Used.

## Bit 6 ECMI Enable Counter Match Interrupt

When this bit is set, an internal interrupt $\left(\right.$ IRQ $\left._{3}\right)$ by CMI is enabled. When cleared, the interrupt is inhibited.

## Bit 7 CMF Counter Match Fiag

This read-only bit is set when a match occurs between the up counter and the TCONR. Cleared by writing " 0 '" at CMF $=1$ by software (unable to write " 1 " by software).
Each bit of the TCSR 3 is cleared during reset.

## - SERIAL COMMUNICATION INTERFACE (SCI)

The Serial Communication Interface (SCI) in the HD6303Y contains the following two operating modes: asynchronous mode by the NRZ format, and clocked synchronous mode which transfers data synchronously with the clock. In the asynchronous mode, data length, parity bits and number of stop bits can be selected, and eight transfer formats are provided.

The SCI consists of the following registers as shown in Fig. 24 Block Diagram.

- Transmit/Receive Control Status Register 1 (TRCSR1)
- Rate/Mode Control Register (RMCR)
- Transmit/Receive Control Status Register 2 (TRCSR2)
- Receive Data Register (RDR)
- Recevie Shift Register
- Transmit Data Register (TDR)
- Transmit Shift Register

To operate the SCI, initialize the RMCR and TRCSR2, after selecting the desirable operating mode and transfer format. Next, set the enable bit (TE or RE) of the TRCSR1. Operating mode and transfer format should be changed when the enable bit (TE, RE) is cleared. When setting the TE or RE again after changing the operating mode or transfer format, interval of more than a 1 -bit cycle of the baud rate or bit rate is necessary. If a 1 -bit cycle or more is not allowed, the SCI block may not be initialized.


## - Asynchronous Mode

Asynchronous mode contains 8 transfer formats as shown in Fig. 25.

Data transmission is enabled by setting TE bit of the TRCSR1, then port 2 , bit 4 will unconditionally become a serial output independently of the corresponding DDR.

To transmit data, set the desirable transmit format with RMCR and TRCSR2. When the TE bit is set, the data can be transmitted after transmitting the one frame of preamble (" 1 ").

The conditions at this stage are as follows.

1) If the TDR is empty (TDRE=1), consecutive 1 's are produced to indicate the idle state.
2) If the TDR contains data (TDRE=0), data is sent to the Transmit Shift Register and data transmit starts.
During data transmit, a start bit of " 0 " is transmitted first. Then 7-bit or 8 -bit data (starts from bit 0 ) is transmitted. With PEN $=1$, the parity bit, even or odd, selected by EOP bit is added, lastly the stop bit ( 1 bit or 2 bis) is sent.

When the TDR is "empty", hardware sets TDRE flag bit. If the CPU doesn't respond to the flag in proper timing (the TDRE is in set condition till the next normal data transfer starts from the transmit data register to the transmit sift register), " 1 " is transferred instead of the start bit " 0 " and continues to be transferred till data is provided to the data register. While the TDRE is " 1 ", " 0 " is not transferred.

Data receive is possible by setting RE bit. This makes port 2 , bit 3 a serial input. The operation mode of data receive is decided by
the contents of the TRCSR2 and RMCR at first, and set RE bit of TRCSR1. The first " 0 " (space) synchronizes the receive bit flow. Each bit of the following data will be strobed in the middle. If a stop bit is not " 1 ", a framing error assumed and ORFE is set.

When a framing error occurs, receive data is transferred to the Receive Data Register and the CPU can read the error-generating data. This makes it possible to detect a line break

When PEN bit is set, the parity check is done. If the parity bit does not match the EOP bit, a parity error occurs and the PER bit is set, not the RDRF bit. Also, when the parity error occurs the receive data can be read just like in the case of the framing error.

The RDRF flag is set when the data is received without a framing error and a parity error.

If RDRF is still set when receiving the stop bit of the next data, ORFE is set to indicate the overrun generation. CPU can get the receive data by reading RDR. When 7 bit data format is selected, the 8th bit of RDR is " 0 ".

When the CPU read the receive Data Register as a response to RDRF flag or ORFE flag after having read TRCSR, RDRF or ORFE is cleared.
(Note) Clock Source in Asynchronous Mode
If $\mathrm{CCl}: \mathrm{CCO}=10$, the internal bit rate clock is provided at $\mathbf{P}_{22}$ regardless of the values for TE or RE. Maximum clock rate is $\mathrm{E}+16$.
If both CCl and CC 0 are set, an external TTL compatible clock must be connected to $P_{22}$ at sixteen times ( $16 \times$ ) the desired bit rate, but not greater than E .


Figure 25 Asynchronous Mode Transfer Format

## - Clocked Synchronous Mode

In the clocked synchronous mode, data transmit is synchronized with the clock pulse. The HD6303Y SCI provides functionally independent transmitter and receiver which makes full duplex operation possible in the asynchronous mode. But in the clocked synchronous mode an SCI clock I/O pin is only $P_{22}$, so the simultaneous receive and transmit operation is not available. In this mode, TE and RE should not be in set condition (" 1 ") simultaneously. Fig. 26 gives a synchronous clock and a data format in the clocked synchronous mode.

## 1) Data transmit

Data transmit is realized by setting TE bit in the TRCSR 1. Port 2, bit 4 becomes an output unconditionally independent of the value of the corresponding DDR.

Both the RMCR and TRCSR should be set in the desirable operating condition for data transmit.

When an external clock input is selected and the TDRE flag is " 0 ", data transmit is performed from port 2 , bit 4 , synchronizing with 8 clock pulses input from external to port 2 , bit 2.

Data is transmitted from bit 0 and the TDRE is set when the Transmit Shift Register (TSR) is "empty". More than 9th clock pulse of external are ignored.

When data transmit is selected to the clock output, the MPU produces transmit data and synchronous clock at TDRE flag clear. 2) Data receive

Data receive is enabled by setting RE bit. Port 2 , bit 3 will be a serial input. The operating mode of data receive is decided by the TRCSR1 and the RMCR.

If the external clock input is selected, 8 external clock pulses and the synchronized receive data are input to port 2 , bit 2 and bit 3 respectively. The MPU put receive data into the receive data shift register by this clock and set the RDRF flag at the termination of $\mathbf{8}$ bit
data receive. More than 9th clock pulse of external input are ig nored. When RDRF is cleared, the MPU starts receiving the next data instantly. So, RDRF should be cleared with $\mathrm{P}_{22}$ "High".

When data receive is selected with the clock output, 8 synchronous clocks are output to the external by setting RE bit. So re-
ceive data should be input from external synchronously with this clock. When the first byte data is received, the RDRF flag is set. After the second byte, receive operation is performed by sending the synchronous clock to the external after clearing the RDRF bit.


- Transmit data is produced from a falling edge of a synchronous clock to the next falling edge.
- Receive data is latched at the rising edge.

Figure 26 Clocked Synchronous Mode Format

- Transmit/Receive Control Status Register (TRCSR1) (\$0011)
The TRCSR1 is composed of 8 bits which are all readable. Bits 0 to 4 are also writable. This register is initialized to $\mathbf{\$ 2 0}$ during reset. Each bit functions are as follows.

Transmit/Receive Control Status Register


50011

## Bit 0 WU Wake-up

In a typical multi-processor configuration, the software pro tocol provides the destination address at the first byte of the message. In order to make uninterested MPU ignore the remaining message, a wake-up function is available. By this, uninterested MPU can inhibit all further receive processing till the next message starts.
Then wake-up function is triggered by consecutive l's with 1 frame length. The software protocol should provide the idle time between messages.
By setting this bit, the MPU stops data receive till the next message. The receive of consecutive " 1 " with one frame length wakes up and clears this bit by hardware and then the MPU restarts receive operation. However, the RE flag should be already set before setting this bit. In the clocked synchronous mode WU is not available, so this bit should not be set.
Bit 1
TE Transmit Enable
When this bit is set, transmit data will appear at port 2, bit 4 after one frame preamble in asynchronous mode, while in clocked synchronous mode it appears immediately. This is executed regardless of the value of the corresponding DDR. When TE is cleared, the serial I/O doesn't affect port 2, bit 4.
Bit 2 TIE Transmit Interrupt Enable
When this bit is set, an internal interrupt ( $\mathrm{IRQ}_{3}$ ) is enabled when TDRE (bit 5) is set. When cleared, the interrupt is inhibited.

## Bit 3 RE Receive Enable

When set, a signal is input to the receiver from port 2, bit 3 regardless of the value of the DDR. When RE is cleared, the serial I/O doesn't afffect port 2, bit 3.
Bit 4 RIE Receive Interrupt Enable
When this bit is set, an internal interrupt $\left(\mathrm{IRQ}_{3}\right)$ is enabled when RDRF (bit 7) or ORFE (bit 6) is set. When cleared, the interrupt is inhibited.

Bit 5 TDRE Transmit Data Register Empty TDRE is set by hardware when the TDR is transferred to the Transmit Shift Register in the asynchronous mode, while in clocked synchronous mode when the TDSR is "empty". This bit is cleared by reading the TRCSR1 or TRCSR2 and writing new transmit data to the TDR when TDRE=1 TDRE is set to " 1 " during reset.
Bit 6 ORFE Overrun Framing Error
ORFE is set by hardware when an overrun or a framing error is generated (during data-receive only). An overrun error occurs when new receive data is ready to be transferred to the RDR during RDRF still being set. A framing error occurs when a stop bit is " 0 ". But in clocked synchronous mode, this bit is not affected. This bit is cleared by reading the TRCSR1 or TRCSR2, and the RDR, when RDRF $=1$. ORFE is cleared during reset.
Bit 7 RDRF Receive Data Register Full
RDRF is set by hardware when data is received normally and transferred from the Receive Shift Register (RSR) to the RDR. This bit is cleared by reading TRCSR1 or TRCSR2, and the RDR, when $R D R F=1$. This bit is cleared during reset.

- Transmit Rate/Mode Control Register (RMCR)

The RMCR controls the following serial I/O:

- Baud Rate
Data Format
- Clock source
- Port 2, Bit 2 Function
- Operation Mode

All bits are readable/writable. Bit 0 to 5 of the RMCR are cleared during reset.

Transfer Rate/Mode Control Register

$\$ 0010$

| Bit 0 | SS0 |  |
| :--- | :--- | :--- |
| Bit 1 | SS1 | Speed Select |
| Bit 5 | SS2 |  |

These bits control the baud rate used for the SCI. Table 7 lists the available baud rates. The timer 1 FRC $(S S 2=0)$ and the timer 2 up counter (SS2=1) provide the internal clock to the SCI. When selecting the timer 2 as a baud rate clock source, it functions as a baud rate generator. The timer 2 generates the baud rate listed in Table 8 depending on the value of the TCONR.
(Note) When operating the SCI with internal clock, do not perform write operation to the timer/counter which is the

Table 7 SCI Bit Times and Transfer Rates
(1) Asynchronous Mode

|  |  |  | XTAL | 2.4576 MHz | 4.0 MHz | 4.9152 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SS2 | SS1 | SSO | E | 614.4 kHz | 1.0 MHz | 1.2288 MHz |
| 0 | 0 | 0 | $E \div 16$ | 26;is/38400Baud | 16 $\mu$ S/62500Baud | $13 \mu s / 76800 \mathrm{Baud}$ |
| 0 | 0 | 1 | $E \div 128$ | $208 \mu \mathrm{~s} / 4800 \mathrm{Baud}$ | $128 / \mu \mathrm{s} / 7812.5 \mathrm{Baud}$ | $104.2 \mu s / 9600 B a u d$ |
| 0 | 1 | 0 | $E \div 1024$ | $1.67 \mathrm{~ms} / 600$ Baud | $1.024 \mathrm{~ms} / 976.6$ Baud | $833.3 \mu \mathrm{~s} / 12008 \mathrm{aud}$ |
| 0 | 1 | 1 | $E \div 4096$ | $6.67 \mathrm{~ms} / 150 \mathrm{Baud}$ | $4.096 \mathrm{~ms} / 244.1$ Baud | $3.333 \mathrm{~ms} / 3008 \mathrm{aud}$ |
| 1 | - | - | - | * | * | * |

* When SS2 is " 1 ", Timer 2 provides SCI clocks. The baud rate is shown as follows with the TCONR as N.

$$
\text { Baud Rate }=\frac{\mathrm{f}}{32(\mathrm{~N}+1)} \quad\left(\begin{array}{l}
\mathrm{f}: \text { input clock frequency to the } \\
\text { timer } 2 \text { counter } \\
\mathrm{N}=0 \sim 255
\end{array}\right)
$$

(2) Clocked Synchronous Mode *

|  |  |  | XTAL | 4.0 MHz | 6.0 MHz | 8.0 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SS2 | SS1 | SSO | $E$ | 1.0 MHz | 1.5 MHz | 2.0 MHz |
| 0 | 0 | 0 | $E \div 2$ | $2 \mu \mathrm{~s} / \mathrm{bit}$ | $1.33 \mu \mathrm{~s} / \mathrm{bit}$ | $1 \mu \mathrm{~s} / \mathrm{bit}$ |
| 0 | 0 | 1 | $E \div 16$ | $16 \mu \mathrm{~s} / \mathrm{bit}$ | $10.7 \mu \mathrm{~s} / \mathrm{bit}$ | $8 \mu \mathrm{~s} / \mathrm{bit}$ |
| 0 | 1 | 0 | $E \div 128$ | $128 \mu \mathrm{~s} / \mathrm{bit}$ | $85.3 \mu \mathrm{~s} / \mathrm{bit}$ | $64 \mu \mathrm{~s} / \mathrm{bit}$ |
| 0 | 1 | 1 | $E \div 512$ | $512 \mu \mathrm{~s} / \mathrm{bit}$ | $341 \mu \mathrm{~s} / \mathrm{bit}$ | $256 \mu \mathrm{~s} / \mathrm{bit}$ |
| 1 | - | - | - | $* *$ | $* *$ | $* *$ |

* Bit rates in the case of internal clock operation. In the case of external clock operation, the external clock is operatable up to $D C \sim 1 / 2$ system clock.
** The bit rate is shown as follows with the TCONR as N .

$$
\text { Bit Rate }(\mu \mathrm{s} / \mathrm{bit})=\frac{4(\mathrm{~N}+1)}{\mathrm{f}} \quad\left(\begin{array}{l}
\mathrm{f}: \text { input clock frequency to the } \\
\text { timer } 2 \text { counter } \\
\mathrm{N}=0 \sim 255
\end{array}\right)
$$

Table 8 Baud Rate and Time Constant Register Example

| XTAL | 2.4576 MHz | 3.6864 MHz | 4.0 MHz | 4.9152 MHz | 8.0 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Baud Rate (Baud) | $21^{\circ}$ | $32^{\circ}$ | $35^{\circ}$ | $43^{\circ}$ | $70^{\circ}$ |
| 110 | 127 | 191 | 207 | 255 | $51^{\circ}$ |
| 150 | 63 | 95 | 103 | 127 | 207 |
| 300 | 31 | 47 | 51 | 63 | 103 |
| 600 | 15 | 23 | 25 | 31 | 51 |
| 1200 | 7 | 11 | 12 | 15 | 25 |
| 2400 | 3 | 5 | - | 7 | 12 |
| 4800 | 1 | 2 | - | - |  |
| 9600 | 0 | - | - | 1 | - |
| 19200 | - | - | - | 0 | - |
| 38400 |  |  |  |  |  |

*E/8 clock is input to the timer 2 up counter and E clock otherwise.
clock source of the SCI.
Blt 2 CCO
Bit 3 CC1
Bit 4 CC2
These bits control the data format and the clock source (refer to Table 9).

* CC0, CC1 and CC2 are cleared during reset and the MPU goes to the clocked synchronous mode of the external clock operation. Then the MPU automatically set port 2, bit 2 into the clock input state. When using port 2 , bit 2 as an output port, the DDR of port 2 should be set to " 1 " and CC1 and CC0 to " 0 " and " 1 " respectively.


## Bit 6 Not Used.

Bit 7 Not Used

- Transmit/Receive Control Status Register 2 (TRCSR2)

The TRCSR2 is a 7 -bit register which can select a data format in the asynchronous mode. The upper 3 bits are the same address as the TRCSR1. Therefore, the RDRF, ORFE and TDRE can be read by either the TRCSR1 or TRCSR2. Bits 0 to 2 of the TRCSR2 are used for read/write. Bits 4 to 7 are used only for read.

Transmit/Receive Control Status Register 2


## Bit 0 8BL 8top Blt Length

This bit selects the stop bit length in the asynchronous mode. If this bit is " 0 ", the stop bit is 1 -bit. If " 1 ", the stop bit is 2 -bit. This bit is cleared during reset.
Bit 1 EOP Even/Odd Parity
This bit selects the parity generated and checked when the PEN is " 1 ". If this bit is " 0 ", the parity is even. If " 1 ", it is odd. This bit is cleared during reset.

## Bit 2 PEN Parity Enable

This bit decides whether the parity bit should be generated and checked in the asynchronous mode or not. If this bit is " 0 ", the parity bit is neither generated nor checked. If " 1 ", it is generated and checked. This bit is cleared during reset.

The 3 bits above do not affect the SCI opertion in the clocked synchronous mode.

## Bit 3 Not Used

Bit 4 PER Parity Error
This bit is set when the PEN is " 1 " and a parity error occurs. It is cleared by reading the RDR after reading the TRCSR2, when $\operatorname{PER}=1$.

## Bit 5 TDRE

Transmit Data Register Empty
Bit 6 ORFE
Overrun/Framing Error
Bit 7 RDRF
Receive Data Register Full

* Each flag of the TDRE, ORFE, and RDRF can be read from either the TRCSR1 or TRCSR2.
- TIMER, SCI STATUS FLAG

Table 10 shows the set and reset conditions of each status flag in the timer 1 , timer 2 and SCI.

Table 9 SCI Format and Clock Source Control

| CC2 | CC1 | CCO | Format | Mode | Clock Source | Port 2, Bit 2 | Port 2, Bit 3 | Port 2, Bit 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 8-bit data | Clocked Synchronous | External | Input | When the TRCSR1, RE bit is " 1 ". bit $\mathbf{3}$ is used as a serial input. |  |
| 0 | 0 | 1 | 8-bit data | Asynchronous | Internal | Not Used** |  |  |
| 0 | 1 | 0 | 8-bit data | Asynchronous | Internal | Output* |  |  |
| 0 | 1 | 1 | 8-bit data | Asynchronous | External | Input |  |  |
| 1 | 0 | 0 | 8-bit data | Clocked Synchronous | Internal | Output | When the TRCSR1, TE bit is " 1 ", bit 4 is used as a serial output. |  |
| 1 | 0 | 1 | 7-bit data | Asynchronous | Internal | Not Used** |  |  |
| 1 | 1 | 0 | 7-bit data | Asynchronous | Internal | Output* |  |  |
| 1 | 1 | 1 | 7-bit data | Asynchronous | External | Input |  |  |

* Clock output regardless of the TRCSR1, bit RE and TE.
** Not used for the SCI.

Table 10 Timér 1, Timer 2 and SCI Status Flag

|  |  | Set Condition | Clear Condition |
| :---: | :---: | :---: | :---: |
| P6CSR | IS FLAG | Falling edge input to $P_{54}$ (IS) | 1. Read the P6CSR then read or write the PORT6, when IS FLAG $=1$ <br> 2. RES $=0$ |
| Timer 1 | ICF | FRC $\rightarrow$ ICR by Rising or Falling edge input to $P_{20}$ <br> (Selecting with the IEDG bit) | 1. Read the TCSR1 or TCSR2 then ICRH, when ICF = 1 <br> 2. $\overline{\text { RES }}=0$ |
|  | OCF 1 | OCR1 $=$ FRC | 1. Read the TCSR1 or TCSR2 then write to the OCR1H or OCR1L, when OCF1 = 1 <br> 2. $\overline{R E S}=0$ |
|  | OCF2 | OCR2 $=$ FRC | 1. Read the TCSR2 then write to the OCR2H or OCR2L, when OCF2 $=1$ <br> 2. $\overline{\mathrm{RES}}=0$ |
|  | TOF | FRC $=$ \$FFFF+1 cycle | 1. Read the TCSR1 then FRCH, when $T O F=1$ <br> 2. $\overline{\mathrm{RES}}=0$ |
| Timer 2 | CMF | T2CNT $=$ TCONR | 1. Write " $O$ " to CMF, when CMF $=1$ <br> 2. $\overline{\mathrm{RES}}=0$ |
| SCl | RDRF | Receive Shift Register $\rightarrow$ RDR | 1. Read the TRCSR1 or TRCSR2 then RDR, when RDRF $=1$ <br> 2. $\overline{\mathrm{RES}}=0$ |
|  | ORFE | 1. Framing Error (Asynchronous Mode) Stop Bit $=0$ <br> 2. Overrun Error (Asynchronous Mode) Receive Shift Register $\rightarrow$ RDR when RDRF $=1$ | 1. Read the TRCSR1 or TRCSR2 then RDR, when ORFE $=1$ <br> 2. RES $=0$ |
|  | TDRE | 1. Asynchronous Mode TDR $\rightarrow$ Transmit Shift Register <br> 2. Clocked Synchronous Mode Transmit Shift Register is "empty" <br> 3. $\overline{\text { RES }}=0$ | Read the TRCSR1 or TRCSR2 then write to the TDR, when TDRE $=1$ |
|  | PER | Parity when PEN=1 | 1. Read the TRCSR2 then RDR, when $P E R=1$ <br> 2. $\overline{R E S}=0$ |
| $($ Note $) \rightarrow$ Transfer $=$; equal |  | ICRH; Upper byte of ICR OCR1H; Upper byte of OCR1 OCR2H; Upper byte of OCR2 | OCR1L; Lower byte of OCR1 <br> OCR2L; Lower byte of OCR2 <br> FRCH; Upper byte of FRC |

## - LOW POWER DIS8IPATION MODE

The HD6303Y provides two low power dissipation modes; sleep and standby.

Sleop Mode
The MPU goes to the sleep mode by SLP instruction execution. In the sleep mode, the CPU stops its operation, while the registers' contents are retained. In this mode, the peripherals except the CPU such as timers, SCI, etc. continue their functions. The power dissipation of sleep-condition is one fourth that of operating condition.

The MPU returns from this mode by an interrupt, $\overline{\text { RES }}$ or STBY; it goes to the reset state by RES and the standby mode by STBY. When the CPU acknowledges an interrupt request, it cancels the sleep mode, returns to the operation mode and branches to the interrupt routine. When the CPU masks this interrupt, it cancels the sleep mode and executes the next instruction. However, for example, if the timer 1 or 2 prohibits a timer interrupt, the CPU doesn't cancel the sleep mode because of no interrupt request.

This sleep mode is effective to reduce the power dissipation for a system with no need of the HD6303Y's consecutive operation.

## -. Standby Mode

The MPU goes to the standby mode with the STBY "Low" or by clearing the STBY flag. In this mode, the HD6303Y stops all the clocks and goes to the reset state. In this mode, the power dissipation is reduced to several $\mu \mathrm{A}$. During standby, all pins, except the power supply ( $\mathbf{V}_{\mathbf{C C}}, \mathbf{V}_{\mathbf{S S}}$ ), the STBY, RES and XTAL (which outputs " 0 "), go to the high impedance state. In this mode, power ( $\mathrm{V}_{\mathrm{CC}}$ ) is supplied to the HD6303Y, and the contents of RAM is retained. The MPU returns from this mode during reset. When the MPU goes to the standby mode with STBY "Low", it will restart at the timing shown in Fig. 27(a). When the MPU goes to the standby mode by clearing the STBY flag, it will restart only by keeping the RES "Low" for longer than the oscillating stabilization time. (Fig. 27(b))


Figure 27 Standby Mode Timing

## - TRAP FUNCTION

The CPU generates an interrupt with the highest priority (TRAP) when fetching an undefined instruction or an instruction from non-memory space. The TRAP prevents the system-burst caused by noise or a program error.

## - Op Code Error

When fetching an undefined op code, the CPU saves registers as well as a normal interrupt and branches to the TRAP (\$FFEE \$FFEF). This has the priority next to reset.

## - Address Error

When an instruction fetch is made from the address of internal register, the MPU generaters an interrupt as well as an op code error. But on the system with no memory in its external memory area, this function is not applicable if an instruction fetch is made from the external non-memory area. Addresses where an address error occurs are from $\$ 0000$ to $\$ 0027$.

This function is available only for an instruction fetch and is not applicable to the access of normal data read/write.
(Note) The TRAP interrupt provides a retry function differently from other interrupts. This is a program flow return to the address where the TRAP occurs when a sequence returns to a main routine from the TRAP interrupt routine by RTI. The retry can prevent the system burst caused by noise, etc.
However, if another TRAP occurs, the program repeats the TRAP interrupt forever, so the consideration is necessary in programming.

## - INSTRUCTION SET

The HD6303Y provides object code upward compatible with the HD6801 to utilize all instruction set of the HMCS6800. It also reduces the execution times of key instructions for throughput improvement.

Bit manipulation instruction, change instruction of the index register and accumulator and sleep instruction are also added.

The followings are explained here.

- CPU Programming Model (refer to Fig. 28)
- Addressing Mode
- Accumulator and Memory Manipulation Instruction (refer to Table 11)
- New Instruction
- Index Register and Stack Manipulation Instruction (refer to Table 12)
- Jump and Branch Instruction (refer to Table 13)
- Condition Code Register Manipulation (refer to Table 14)
- Op Code Map (refer to Table 15)


## - Programming Model

Fig. 28 depicts the HD6303Y programming model. The double accumulator $D$ consists of accumulator $A$ and $B$, so when using the accumulator $D$, the contents of $A$ and $B$ are destroyed.

## - CPU Addressing Mode

The HD6303Y provides 7 addressing modes. The addressing mode is determined by an instruction type and code. Tables 11 through 15 show addressing modes of each instruction with the execution times counted by the machine cycle.

When the clock frequency is 4 MHz , the machine cycle time becomes microseconds directly.

## Accumulator (ACCX) Addressing

Only an accumulator is addressed and the accumulator A or B is selected. This is a one-byte instruction.

## Immediate Addressing

This addressing locates a data in the second byte of an instruction. However, LDS and LDX locate a data in the second and third byte exceptionally. This addressing is a 2 or $\mathbf{3 - b y t e}$ instruction.

## Direct Addressing

In this addressing mode, the second byte of an instruction shows


Figure 28 CPU Programming Model
the address where a data is stored. 256 bytes ( $\$ 0$ through $\$ 255$ ) can be addressed directly. Execution times can be reduced by storing data in this area so it is recommended to make it RAM for users' data area in configurating a system. This is a 2 -byte instruction, while 3 byte with regard to AIM, OIM, EIM and TIM.

## Extended Addressing

In this mode, the second byte shows the upper 8 bit of the data stored address and the third byte the lower 8 bit. This indicates the absolute address of 3 byte instruction in the memory.

## Indexed Addressing

The second byte of an instruction and the lower 8 bit of the index register are added in this mode. As for AIM, OIM, EIM and TIM, the third byte of an instruction and the lower 8 bits of the index register are added.

This carry is added to the upper 8 bit of the index register and the result is used for addressing the memory. The modified address is retained in the temporary address register, so the contents of the index register doesn't change. This is a 2 -byte instruction except AIM, OIM, EIM and TIM (3-byte instruction).

## Implied Addressing

An instruction itself specifies the address. This is, the instruction addresses a stack pointer, index register, etc. This is a one-byte instruction.

## Relative Addressing

The second byte of an instruction and the lower 8 bits of the program counter are added. The carry or borrow is added to the upper 8 bit. So addressing from -126 to +129 byte of the current instruction is enabled. This is a 2 -byte instruction.
(Note) CLI, SEI Instructions and Interrupt Operation
When accepting the IRQ at a preset timing with CLI and SEI instructions, more than 2 cycles are necessary between the CLI and SEI instructions. For example, the following program (a)(b) don't accept the IRQ but (c) accepts it.

| - | - | - |
| :---: | :---: | :---: |
| - | - | - |
| . | - | CLI |
| CLI | CLI | NOP |
| SEI | NOP | NOP |
| - | SEI | SEI |
| - | - | - |
| - | - | - |
| - | - | - |
| - |  | ( ) |
| (a) | (b) | (c) |

The same thing can be said to the TAP instruction instead of the CLI and SEI instructions.

Table 11 Accumulator, Memory Manipulation Instructions

(Note) Condition Code Register will be explained in Note of Table 14.

Table 11 Accumulator, Memory Manipulation Instruetions

| Opertions | Mromenic | Addressing Medes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Beelean/ Arithmetis Operation | Cendition Cede Repinter |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIAICT |  |  | INDEX |  |  | -XTEND |  |  | IMPLID |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\approx$ | * | OP | * | \% | OP | * | * | $0 \cdot$ | $\approx$ | \# | OP | * | , |  | H | 1 | N | 2 | V | c |
| Chifi Left Arlthmetie | Ast |  |  |  |  |  |  | 0 | E | 2 | 78 | 6 | 3 |  |  |  |  | - | $\bullet$ | 1 | 1 | (3) | 1 |
|  | ABLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 1 | 1 |  | $\bullet$ | 0 | + | 1 | (3) | 1 |
|  | A8L |  |  |  |  |  |  |  |  |  |  |  |  | 5 | 1 | 1 |  | - | 0 | 8 | $t$ |  | 1 |
| Dauble 斯ift Left, Arithmetle | AsL0 |  |  |  |  |  |  |  |  |  |  |  |  | $0{ }^{*}$ | 1 | 1 |  | - | - | * | \% | 1 | 1 |
| Ehift Aight Arlthmeric | As |  |  |  |  |  |  | 67 | 6 | 2 | 77 | 6 | 2 |  |  |  | $\begin{gathered} M \\ M \end{gathered}$ | $\bullet$ | - | 1 | 1 | (1) | 1 |
|  | Asma |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 1 | 1 |  | $\bullet$ | - | 8 | 8 | () | 4 |
|  | Ann |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 1 | 1 |  | 0 | $\cdots$ | 8 | \% | () | 8 |
| filf Right Legical | Lem |  |  |  |  |  |  | 4 | 6 | 2 | 74 | 6 | 3 |  |  |  |  | - | - | A | 4 | () | 1 |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 1 | 1 |  | $\bullet$ | - | ค | 5 | () | 8 |
|  | L8ค8 |  |  |  |  |  |  |  |  |  |  |  |  | 84 | 1 | 1 |  | - | - | R | 8 | ( C$)$ | 8 |
| Double 8hift Right Legical | LSRD |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 1 | 1 |  | - | - | ค | 1 | Q | 1 |
| Stere Accumulator | STAA |  |  |  | 97 | 3 | 2 | A7 | 4 | 2 | 87 | 4 | 3 |  |  |  | $A \rightarrow M$ | $\bullet$ | $\bullet$ | 8 | 8 | A | $\bullet$ |
|  | STAB |  |  |  | 07 | 3 | 2 | E7 | 4 | 2 | F7 | 4 | 3 |  |  |  | $B \rightarrow M$ | $\bullet$ | - | 8 | 8 | A | $\bullet$ |
| Stere Double Aecumulator | STO |  |  |  | DD | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 |  |  |  | $\begin{aligned} & A \rightarrow M \\ & B \rightarrow M+1 \end{aligned}$ | - | - | 1 | 1 | R | - |
| Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | 80 | 4 | 3 |  |  |  | $A-M \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | SUBP | C0 | 2 | 2 | DO | 3 | 2 | EO | 4 | 2 | FO | 4 | 3 |  |  |  | $B-M \rightarrow B$ | $\bullet$ | - | 1 | 1 | 1 | $\ddagger$ |
| Double Suberact | SUBD | 83 | 3 | 3 | 93 | 4 | 2 | A3 | 5 | 2 | B3 | 5 | 3 |  |  |  | $A: B-M: M+1 \rightarrow A: B$ | - | - | \% | $t$ | 8 | 1 |
| Subtrect Accumulators | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 1 | 1 | $A-8 \rightarrow A$ | - | - | \% | 1 | $t$ | $t$ |
| Subtrect With Carry | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | 82 | 4 | 3 |  |  |  | $A-M-C \rightarrow A$ | $\bullet$ | - | 1 | 8 | 8 | 1 |
|  | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C \rightarrow B$ | $\bullet$ | $\cdots$ | $\ddagger$ | 1 | 1 | 1 |
| Trensfor Aceumulators | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 1 | 1 | $A \rightarrow B$ | $\bullet$ | $\cdots$ | 1 | 1 | A | $\bullet$ |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 1 | 1 | $B \rightarrow A$ | $\bullet$ | - | 1 | 1 | ค | $\bullet$ |
| Test Zero or Minus | TST |  |  |  |  |  |  | 60 | 4 | 2 | 70 | 4 | 3 |  |  |  | M-00 | $\bullet$ | $\bullet$ | $t$ | 1 | R | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 1 | 1 | A - 00 | $\bullet$ | - | $t$ | 1 | A | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 1 | 1 | B-00 | $\bullet$ | $\bullet$ | $t$ | 1 | R | R |
| And Immediate | AlM |  |  |  | 71 | 6 | 3 | 61 | 7 | 3 |  |  |  |  |  |  | M.IMM $\rightarrow$ M | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
| OR Immediate | OIM |  |  |  | 72 | 6 | 3 | 62 | 7 | 3 |  |  |  |  |  |  | $M+1 N M \rightarrow M$ | - | $\bullet$ | $\ddagger$ | $\dagger$ | R | $\bullet$ |
| EOR immediate | EIM |  |  |  | 75 | 6 | 3 | 65 | 7 | 3 |  |  |  |  |  |  | M $\dagger$ IMM $\rightarrow$ M | $\bullet$ | - | I | ! | R | $\bullet$ |
| Test Immediate | TIM |  |  |  | 78 | 4 | 3 | 68 | 5 | 3 |  |  |  |  |  |  | M.IMM | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |

(Note) Condition Code Register will be explained in Note of Table 14.

- Additional Instruction

In addition to the HD6801 instruction set, the HD6303Y prepares the following new instructions.

AIM $\ldots \ldots \ldots$ (M)•(IMM) $\rightarrow$ (M)
Executes "AND" operation to immediate data and the memory contents and stores its result in the memory.
OIM
Executes "OR" operation to immediate data and the memory contents and stores its result in the memory.
EIM
$(\mathrm{M}) \oplus(\mathrm{IMM}) \rightarrow(\mathrm{M})$
Executes "EOR" operation to immediate data and the memory contents and stores its result in the memory.

TIM
(M).(IMM)

Executes "AND" operation to immediate data and changes the relative flag of the condition code register.
These are the 3-byte instructions; the first byte is op code, the second immediate data and the third address modifier.

XGDX $\ldots \ldots \ldots$. (ACCD) $\rightarrow$ (IX)
Exchanges the contents of accumulator and the index register.
SLP
Goes to the sleep mode. Refer to "LOW POWER DISSIPATION MODE" for more details of the sleep mode.

Table 12 Index Register, Stack Manipulation Instructions

| Pointer Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ Arithmetic Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED. |  |  | DIRECT |  |  | INDEX |  |  | EXTEND |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \% | OP | $\sim$ | * | OP | $\sim$ | \# | OP | $\sim$ | \% | OP | $\sim$ | \% |  | H | 1 | N | 2 | V | C |
| Compere Index Reg | CPX | 8C | 3 | 3 | 9C | 4 | 2 | AC | 5 | 2 | BC | 5 | 3 |  |  |  | $X-M: M+1$ | $\bullet$ | $\bullet$ | 1 | 1 | ! | 1 |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 1 | 1 | $\underline{x}-1 \rightarrow x$ | $\bullet$ | $\bullet$ | $\bullet$ | 1 | $\bullet$ | $\bullet$ |
| Decrement Stack Pntr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 1 | 1 | SP-1 $\rightarrow$ SP | - | - | - | $\bullet$ | - | $\bullet$ |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 1 | 1 | $x+1 \rightarrow x$ | - | - | - | 1 | - | $\bullet$ |
| Increment Stack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 1 | 1 | SP + $1 \rightarrow$ SP | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bigcirc$ | $\bullet$ |
| Loed Index Reg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 |  |  |  | $M \rightarrow X_{M}(M+1) \rightarrow X_{L}$ | - | - | (7) | 1 | A | $\bullet$ |
| Loed Stack Pntr | LDS | 8 E | 3 | 3 | 9E | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 |  |  |  | $M \rightarrow S P_{M}(M+1) \rightarrow S P_{L}$ | $\bullet$ | - | (7) | 1 | R | $\bullet$ |
| Store Index Reg | STX |  |  |  | OF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 |  |  |  | $X_{M} \rightarrow M_{1} X_{L} \rightarrow(M+1)$ | - | - | 7 | 1 | R | - |
| Store Stack Pntr | STS |  |  |  | 9F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 |  |  |  | $\underline{S P} P_{M} \rightarrow M_{\text {, }} \mathbf{S P} P_{L} \rightarrow(M+1)$ | $\bullet$ | - | 7 | 1 | R | - |
| Index Reg $\rightarrow$ Stack Pntr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 1 | 1 | $\mathrm{X}-1 \rightarrow$ SP | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Stack Pntr $\rightarrow$ Index Reg | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 1 | 1 | SP + $1 \rightarrow x$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\cdots$ | $\bullet$ |
| Add | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3 A | 1 | 1 | $B+X \rightarrow X$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Push Date | PSHX |  |  |  |  |  |  |  |  |  |  |  |  | 3 C | 5 | 1 | $\begin{aligned} & X_{L} \rightarrow M_{\text {mp }} . S_{P}-1 \rightarrow S P \\ & X_{M} \rightarrow M_{\text {mP }} . S P-1 \rightarrow S P \end{aligned}$ | - | - | - | - | - | - |
| Pull Date | PULX |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 4 | 1 | $\begin{aligned} & S P+1 \rightarrow S P, M_{8 P} \rightarrow X_{H} \\ & S P+1 \rightarrow S P, M_{E P} \rightarrow X_{L} \end{aligned}$ | - | - | - | - | - | - |
| Exchange | XGDX |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 2 | 1 | ACCD. 1 IX | - | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |

(Note) Condition Code Register will be explained in Note of Table 14.

Table 13 Jump, Branch Instruotion

| Oparntions | Mnemenie | Addressing Medes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | -ramh Fert | Conalition CettActuter |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 成部ATIV |  |  | DIMCT |  |  | INDEX |  |  | WXPEND |  |  | 1mphate |  |  |  | 3 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\cdots 1$ | \% | 9P | $\geqslant$ | \% | 0 | * | \% | 0 | $\sim$ | \# | OP | \% | \% |  | M | 1 | N | 2 | V | \% |
| Urimin Ampys | InA | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | Nent | $\bullet$ | $\bullet$ | $\bullet$ | $\cdots$ | $\bullet$ | ${ }^{-}$ |
| Braneh Nover | DAN | 31 | 5 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | None | - | $\bullet$ | - | $\pm$ | 0 | - |
| Irandh If Corry Cimar | Ccc | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | 6 mid | - | - | - | - | - | - |
| dranch If Cerry got | 18 | \% | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | 6mid | $\square$ | - | $\theta$ | 0 | 0 | - |
| Eraneh If : zere | ETe | 27 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | K | $\bullet$ | $\bullet$ | $\bullet$ | $\bigcirc$ | 0 | $\cdots$ |
| Eranoh If \% zere | DOE | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N$ (3) $V=0$ | 0 | $\bullet$ | 0 | $\bullet$ | $\cdots$ | $\bullet$ |
| Draneh $19>$ Zare | 20T | 21 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | H + (N@V) $=0$ | $\bullet$ | $\bullet$ | $\cdots$ | - | - | - |
| Breneh if Migher | 1HI | 22 | 2 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $C+2=0$ | - | - | - | - | - | $\cdots$ |
| Draneh 1f a Zoro | WLE | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $Z+(N Q V)=1$ | - | - | - | - | - | - |
| Broneh If Lower Or came | 148 | 23 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | C+z=1 | - | - | - | - | - | - |
| Brangh If < 2ers | B6T | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $N(1)$ | - | - | $\bullet$ | - | - | - |
| Eraneh If Minus | OMI | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
| $\begin{aligned} & \text { Braneh If Not Equal } \\ & \text { Zoro } \end{aligned}$ | BNE | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | 2=0 | - | - | - | - | - | - |
| Branch If Overflow Clear | eve | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $V=0$ | $\bullet$ | - | - | - | - | - |
| Branch If Overflow 8et | EV8 | 29 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $V \mathrm{~m} 1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Plus | BPL | 2 A | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Branch To Subroutime | 88n | 80 | 5 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  | - | $\bullet$ | - | $\bullet$ | - | - |
| Jump | JMP |  |  |  |  |  |  | CE | 3 | 2 | 7E | 3 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Jump To Subroutine | J8R |  |  |  | 20 | 5 | 2 | AD | 5 | 2 | 30 | 6 | 3 |  |  |  |  | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 1 | 1 | Advences Prog. Cntr. Only | - | $\bullet$ | - | - | - | - |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 10 | 1 |  |  | - | ( | 1 |  |  |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  | - | - | - | - | - | - |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  |  |  |  | $3 F$ | 12 | 1 |  | $\bullet$ | 5 | $\bullet$ | - | - | $\bullet$ |
| Wait for Interrupt ${ }^{\circ}$ | WAI |  |  |  |  |  |  |  |  |  |  |  |  | 3E | 9 | 1 |  | - | (1) | - | - | - | $\bullet$ |
| Sieep | SLP |  |  |  |  |  |  |  |  |  |  |  |  | 1 A | 4 | 1 |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bigcirc$ | - | $\bullet$ |

(Note) *WAI puts R/TW high; Address Bus goes to FFFF; Data Bus goes to the three state.
Condition Code Register will be explained in Note of Table 14.

Table 14 Condition Code Register Manipulation Instructions

| Operations | Mnemonic | AddressingModes <br> IMPLIED <br> OP |  |  | Boolean Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | * |  | H | 1 | N | 2 | V | C |
| Cleer Cerry | CLC | OC | 1 | 1 |  | $0 \rightarrow C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | R |
| Cleer Interrupt Mesk | CLI | OE | 1 | 1 | $0 \rightarrow 1$ | $\bullet$ | R | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Cleer Overflow | CLV | OA | 1 | 1 | $0 \rightarrow V$ | $\bullet$ | - | $\bullet$ | $\bullet$ | R | $\bullet$ |
| Set Cerry | SEC | 0 O | 1 | 1 | $1 \rightarrow C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | S |
| Set Interrupt Mesk | SEI | OF | 1 | 1 | $1 \rightarrow 1$ | $\bullet$ | S | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Set Overflow | SEV | 08 | 1 | 1 | $1 \rightarrow V$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 5 | $\bullet$ |
| Accumulotor $A \rightarrow$ CCR | TAP | 06 | 1 | 1 | $A \rightarrow$ CCR |  | - | - |  |  |  |
| CCR $\rightarrow$ Accumulator $A$ | TPA | 07 | 1 | 1 | $\mathbf{C C R ~} \rightarrow \mathbf{A}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

## LEGEND

OP Operation Code (Hexadecimal)

## CONDITION CODE SYMBOLS

H Half-carry from bit 3 to bit 4
~ Number of MCU Cycles
MSP Contents of memory location pointed by Stack Pointer
1 Interrupt mask

* Number of Program Bytes
$N \quad$ Negative (sign bit)
+ Arithmetic Plus
2 Zero (byte)
- Arithmetic Minus
$v$ Overfiow, 2's complement
- Boolean AND

C Carry/Borrow from/to bit 7

+ Boolean Inclusive OR
R Reset Always
- Boolean Exclusive OR

S Set Always
$\overline{\mathrm{M}}$ Complement of M
1 Set if true after test or clear
$\rightarrow$ Transfer into
$0 \quad$ Bit $=$ Zero
00 Byte = Zero
(Note) Condition Code Register Notes: (Bit set if test is true and cleared otherwise)

| (1) | (Bit V) | Test: Result $=10000000$ ? |
| :---: | :---: | :---: |
| (2) | (Bit C) | Test: Result $\ddagger 00000000$ ? |
| (3) | (Bit C) | Test: BCD Character of high-order byte greater than 10? (Not cleared if previously set) |
| (4) | (Bit V) | Test: Operand $=10000000$ prior to execution? |
| (5) | (Bit V) | Test: Operand = 01111111 prior to execution? |
| (6) | (Bit V) | Test: Set equal to $\mathrm{N} \oplus \mathrm{C}=1$ after the execution of instructions |
| (7) | (Bit N) | Test: Result less than zero? (Bit 15=1) |
| (8) | (All Bit) | Load Condition Code Register from Stack. |
| (9) | (Bit I) | Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state. |
| (1) | (All Bit) | Set according to the contents of Accumulator A. |
| (11) | (Bit C) | Result of Multiplication Bit 7=1? (ACCB) |

Table 15 OP-Code Map

| $\begin{aligned} & \text { OP } \\ & \text { CODE } \end{aligned}$ |  |  |  |  |  | $\begin{gathered} \text { ACC } \\ \mathbf{A} \end{gathered}$ | $\begin{gathered} \hline \text { ACC } \\ \text { B } \end{gathered}$ | IND | EXT/ | ACCA or SP |  |  |  | ACCB or X |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  | IMM | DIR | IND | EXT | IMM | DIR | IND | EXT |  |
| LO |  | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 |  |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 0 | E | $F$ |  |
| 0000 | 0 | $\bigcirc$ | SBA | BRA | TSX | NEG |  |  |  | SUB |  |  |  |  |  |  |  |  |
| 0001 | 1 | NOP | CBA | BRN | INS | - | - | AIM |  | CMP |  |  |  |  |  |  |  |  |
| 0010 | 2 | $\square$ | - | BHI | PULA | - |  | OIM |  | SBC |  |  |  |  |  |  |  |  |
| 0011 | 3 | $\bigcirc$ | - | BLS | PULB | COM |  |  |  | SUBD |  |  |  | ADOD |  |  |  |  |
| 0100 | 4 | LSRD | $\bigcirc$ | BCC | DES | LSR |  |  |  | AND |  |  |  |  |  |  |  |  |
| 0101 | 5 | ASLD | $\square$ | BCS | TXS | - | - | EIM |  | Bit |  |  |  |  |  |  |  |  |
| 0110 | 6 | TAP | TAB | BNE | PSHA | ROR |  |  |  | LDA |  |  |  |  |  |  |  |  |
| 0111 | 7 | TPA | TBA | BEO | PSHB | ASR |  |  |  | - | STA |  |  | $\square$ | STA |  |  |  |
| 1000 | 1 | InX | XGDX | BVC | PULX | ASL |  |  |  | EOR |  |  |  |  |  |  |  |  |
| 1001 | 9 | DEX | DAA | BVS | RTS | ROL |  |  |  | ADC |  |  |  |  |  |  |  |  |
| 1010 | A | CLV | SLP | BPL | ABX | DEC |  |  |  | ORA |  |  |  |  |  |  |  |  |
| 1011 | 8 | SEV | ABA | BMI | RTI | TIM |  |  |  | ADD |  |  |  |  |  |  |  |  |
| 1100 | C | CLC | - | BGE | PSHX | INC |  |  |  | CPX |  |  |  | LDD |  |  |  |  |
| 1101 | D | SEC | - | BLT | MUL | TST |  |  |  | BSR | JSR |  |  |  | STD |  |  |  |
| 1110 | E | CLI | , | BGT | WAI | JMP |  |  |  | LDS |  |  |  | LDX |  |  |  |  |
| 1111 | F | SEI | $\square$ | BLE | SWI | CLR |  |  |  | $\bigcirc$ | STS |  |  | - | STX |  |  |  |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | D | E | $F$ |  |

UNDEFINED OP CODE

- Only each instructions of AIM, OIM, EIM, TIM


## CPU OPERATION

- CPU Instruction Fiow

When operating, the CPU fetches an instrution from a memory and executes the required function. This sequence starts with RES cancel and repeats itself limitlessly if not affected by a special instruction or a control signal. SWI, RTI, WAI and SLP instructions change this operation, while $\overline{\text { NMI }}, \overline{\text { IRQ }} 1, \overline{I R Q}_{2}$, IRQ $_{3}, \overline{\text { HALT }}$ and STBY control it. Fig. 29 gives the CPU mode transition and Fig. 30 the CPU system flow chart. Table 16 shows CPU operating states
and port states.

- Operation at Each Instruction Cycle

Table 17 shows the operation at each instruction cycle. By the pipeline control of the HD6303Y, MULT, PUL, DAA and XGDX instructions, etc. prefetch the next instruction. So attention is necessary to the counting of the instruction cycles because it is different from the usual one-from op code fetch to the next instruction op code.


Figure 29 CPU Operation Mode Transition
Table 16 CPU Operation State and Port, Bus, Control Signal State

| Port | Reset | STBY $^{\cdot 3}$ | HALT | Sleep |
| :--- | :---: | :---: | :---: | :---: |
| $A_{0} \sim A_{7}$ | H | T | T | H |
| Port 2 | T | T | Keep | Keep |
| $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | T | T | T | T |
| $\mathrm{~A}_{8} \sim \mathrm{~A}_{15}$ | H | T | T | H |
| Port 5 | T | T | Keep | Keep |
| Port 6 | T | T | Keep | Keep |
| Control Signal | $\cdot \cdot$ | T | $\cdot 2$ | $\cdot 1$ |

-1 $\overline{R D}, W R, R / W, \overline{L R}=H, B A=L$

- 2 RD, WR, R/W = T, LIR, BA $=\mathrm{H}$
-3 Epin goes to high impedance state.


| Address Mode \& Instructions |  | Cycles | Cycle $\#$ | Address Bus | R/ $\overline{\mathbf{W}}$ | $\overline{\mathrm{R}}$ | $\bar{W}$ | $\overline{\text { LIR }}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EXTEND |  |  |  |  |  |  |  |  |  |
| JMP |  | 3 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Jump Address (MSB) |
|  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Jump Address (LSB) |
|  |  | 3 | Jump Address | 1 | 0 | 1 | 0 | Next Op Code |
| ADC ADD TST <br> AND BIT  <br> CMP EOR  <br> LDA ORA  <br> SBC SUB  <br>    |  |  | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  |  | 2 |  | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  | 3 |  | Address of Operand | 1 | 0 | 1 | 1 | Operand Data |
|  |  | 4 |  | Op Code Address +3 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  |  |  |  |  |  |  |  |
| STA |  |  | 4 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Destination Address (MSB) |
|  |  | 2 |  | Op Code Address +2 | 1 | 0 | 1 | 1 | Destination Address (LSB) |
|  |  | 3 |  | Destination Address | 0 | 1 | 0 | 1 | Accumulator Data |
|  |  | 4 |  | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| ADDD <br> CPX <br> LDS <br> SUBD | $\begin{aligned} & \text { LDD } \\ & \text { LDX } \end{aligned}$ | 5 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data (MSB) |
|  |  |  | 4 | Address of Operand + 1 | 1 | 0 | 1 | 1 | Operand Data (LSB) |
|  |  |  | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| $\begin{aligned} & \text { STD } \\ & \text { STX } \end{aligned}$ | STS | 5 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Destination Address (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Destination Address (LSB) |
|  |  |  | 3 | Destination Address | 0 | 1 | 0 | 1 | Register Data (MSB) |
|  |  |  | 4 | Destination Address + 1 | 0 | 1 | 0 | 1 | Register Data (LSB) |
|  |  |  | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| JSR |  | 6 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Jump Address (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Jump Address (LSB) |
|  |  |  | 3 | FFFF | 1 | 1 |  | 1 | Restart Address (LSB) |
|  |  |  | 4 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) |
|  |  |  | 5 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) |
|  |  |  | 6 | Jump Address | 1 | 0 | 1 | 0 | First Subroutine Op Code |
| ASL <br> COM <br> INC <br> NEG <br> ROR |  |  | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Address of Operand (MSB) |
|  | DEC |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  | LSR | 6 | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data |
|  | ROL | 6 | 4 | FFFF |  | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 5 | Address of Operand | 0 | 1 | 0 | 1 | New Operand Data |
|  |  |  | 6 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |
| CLR |  | 5 | 1 | Op Code Address +1 |  | 0 | , | 1 | Address of Operand (MSB) |
|  |  |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSB) |
|  |  |  | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data |
|  |  |  | 4 | Address of Operand | 0 | 1 | 0 | 1 | 00 |
|  |  |  | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |


| $\begin{aligned} & \text { Addre: } \\ & \text { Inst } \end{aligned}$ | Mode \& uctions | Cycles | $\begin{gathered} \text { Cycle } \\ \# \end{gathered}$ | Address Bus | R/ $\bar{W}$ | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{L T R}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMPLIED |  |  |  |  |  |  |  |  |  |
| ABA ABX |  | 1 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |
| ASL | ASLD |  |  |  |  |  |  |  |  |
| ASR | CBA |  |  |  |  |  |  |  |  |
| CLC | CLI |  |  |  |  |  |  |  |  |
| CLR | CLV |  |  |  |  |  |  |  |  |
| COM | DEC |  |  |  |  |  |  |  |  |
| DES | DEX |  |  |  |  |  |  |  |  |
| INC | INS |  |  |  |  |  |  |  |  |
| INX | LSR |  |  |  |  |  |  |  |  |
| LSRD | ROL |  |  |  |  |  |  |  |  |
| ROR | NOP |  |  |  |  |  |  |  |  |
| SBA | SEC |  |  |  |  |  |  |  |  |
| SEI | SEV |  |  |  |  |  |  |  |  |
| TAB | TAP |  |  |  |  |  |  |  |  |
| TBA | TPA |  |  |  |  |  |  |  |  |
| TST | TSX |  |  |  |  |  |  |  |  |
| TXS |  |  |  |  |  |  |  |  |  |
| DAA | XGDX | 2 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
| PULA | PULB | 3 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer +1 | 1 | 0 | 1 | 1 | Data from Stack |
| PSHA | PSHB | 4 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | , | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Accumulator Data |
|  |  |  | 4 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |
| PULX |  | 4 | 1 | Op Code Address +1 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  | 2 | FFFF |  | 1 |  | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer +1 | 1 | 0 | 1 | 1 | Data from Stack (MSB) |
|  |  |  | 4 | Stack Pointer +2 | 1 | 0 | 1 | 1 | Data from Stack (LSB) |
| PSHX |  | 5 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Index Register (LSB) |
|  |  |  | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Index Register (MSB) |
|  |  |  | 5 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code |
| RTS |  | 5 | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer +1 | 1 | 0 | 1 | 1 | Return Address (MSB) |
|  |  |  | 4 | Stack Pointer + 2 | 1 | 0 | 1 | 1 | Return Address (LSB) |
|  |  |  | 5 | Return Address | 1 | 0 | 1 | 0 | First Op Code of Return Routine |
| MUL |  | 7 | 1 | Op Code Address +1 | 1 | 0 | 1 | 0 | Next Op Code |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | FFFF | 1 | 1 | 1 | , | Restart Address (LSB) |
|  |  |  | 4 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 5 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 6 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 7 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |

Table 17 Cycle-by-Cycle Operation

| Address Mode \& Instructions |  | Cycles | Cycle \# | Address Bus | R/W | $\overline{\mathrm{R}}$ | $\overline{\text { WR }}$ | LTR | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMMEDIATE |  |  |  |  |  |  |  |  |  |
| ADC | ADD |  | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Operand Data |
| AND | BIT |  | 2 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code |
| CMP | EOR | 2 |  |  |  |  |  |  |  |
| LDA | ORA |  |  |  |  |  |  |  |  |
| SBC | SUB |  |  |  |  |  |  |  |  |
| ADDD | CPX |  | 1 | Op Code Address +1 | 1 | 0 | 1 | 1 | Operand Data (MSB) |
| LDD | LDS | 3 | 2 | Op Code Address + 2 | 1 | 0 | 1 | , | Operand Data (LSB) |
| LDX | SUBD |  | 3 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code |


(Continued)

(Continued)


Relative

| BCC | BCS | 3 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Branch Offset |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BEQ | BGE |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
| BGT | BHI |  | 3 | $\left\{\begin{array}{l} \text { Branch Address } \cdots \cdots \cdot \text { Test }=" 1 " \\ \text { Op Code Address }+1 \cdots \text { Test }=" 0 " \end{array}\right.$ | 1 | 0 | 1 | 0 | First Op Code of Branch Routine Next Op Code |
| BLE | BLS |  |  |  |  |  |  |  |  |
| BLT | BMT |  |  |  |  |  |  |  |  |
| BNE | $B P L$ |  |  |  |  |  |  |  |  |
| BRA | BRN |  |  |  |  |  |  |  |  |
| BVC | BVS |  |  |  |  |  |  |  |  |
| BSR |  | 5 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset |
|  |  |  | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) |
|  |  |  | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) |
|  |  |  | 4 | Stack Pointer-1 | 0 | 1 | 0 | 1 | Return Address (MSB) |
|  |  |  | 5 | Branch Address | 1 | 0 | 1 | 0 | First Op Code of Subroutine |

## - PRECAUTION TO THE BOARD DESION OF O8CILLA.

 TION CIRCUITAs shown in Fig. 31, there is a case that the cross talk dis. turbs the normal oseillation if signal lines are put near the oscillation elrcuit. When designing a board, pay attention to this. Crystal and $\mathrm{C}_{\mathrm{L}}$ must be put as near the HD6303Y as possible.


Do not use this kind of print board design.
Figure 31 Precaution to the boad design of oscillation circuit

(Top View)
Figure 32 Example of Oscillation Circuits in Board Design

## - RECEIVE MARGIN OF THE SCI

Receive margin of the SCI contained in the HD6303Y is shown in Table 18.
Note: $\mathbf{S C I}=$ Serial Communication Interface
Table 18

|  | Bit distortion <br> tolerance <br> (t-to) /to | Character <br> distortion tolerance <br> (T-To)/To |
| :--- | :---: | :---: |
| HD6303Y | $\pm 43.7 \%$ | $\pm 4.37 \%$ |

Ideal Waveform


Real Waveform


# HD6305X2,HD63A05X2,HD63B05X2 HD6305Y2,HD63A05Y2,HD63B05Y2 CMOS MPU (Micro Processing Unit) 

The HD6305X2 and the HD6305Y2 are CMOS 8-bit micro processing units which contains a CPU, a clock generator, RAM, I/O terminals, two timers, and a Serial Communication Interface (SCI). The memory space is expandable up to 16 k bytes externally.

The HD6305X2 and the HD6305Y2 provides the equivalent functions as the HD6305X0 and the HD6305Y0 except for the number of $I / O$ terminals.

## - HARDWARE FEATURES

-8-bit based MPU

- 128-bytes of RAM (HD6305X2),

256-bytes of RAM (HD6305Y2)

- A total of 31 terminals, including 24 I/O's, 7 inputs
- Two timers
- 8-bit timer with a 7 -bit prescaler (programmable prescaler; event counter)
- 15-bit timer (multiplexed with the SCI clock divider)
- On-chip serial interface circuit (synchronized with clock)
- Six interrupts (two external, two timer, one serial and one software)
- Low power dissipation modes
- Wait . . . . In this mode, the clock oscillator is on and the CPU halts but the timer/serial/interrupt function is operatable.
- Stop... . In this mode, the clock stops but the RAM data, I/O status and registers are held.
- Standby. . In this mode, the clock stops, the RAM data is held, and the other internal condition is reset.
- Minimum instruction cycle time
- HD6305X2/Y2 .... $1 \mu \mathrm{~s}(\mathrm{f}=1 \mathrm{MHz}$ )
- HD63A05X2/Y2 ... $0.67 \mu \mathrm{~s}(\mathrm{f}=1.5 \mathrm{MHz})$
- HD63B05X2/Y2 $\ldots 0.5 \mu \mathrm{~s}(\mathrm{f}=2 \mathrm{MHz})$
-Wide operating range

$$
\mathrm{V}_{\mathrm{CC}}=3 \text { to } 6 \mathrm{~V} \text { (f }=0.1 \text { to } 0.5 \mathrm{MHz} \text { ) }
$$

- HD6305X2/Y2 . . . . f $=0.1$ to $1 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right.$ )
- HD63A05X2/Y2 ...f $=0.1$ to $1.5 \mathrm{MHz}\left(V_{C C}=5 \mathrm{~V} \pm 10 \%\right)$
- HD63B05X2/Y2 ...f $f=0.1$ to $2 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right.$ )
- System development fully supported by an evaluation kit
- Compatibility with the HD6305X0 and the HD6305YO except for external memory expansion and the number of I/O terminals.



## - SOFTWARE FEATURES

- Similar to HD6800
- Byte efficient instruction set
- Powerful bit manipulation instructions (Bit Set, Bit Clear, and Bit Test and Branch usable for all RAM bits and all I/O terminals)
- A variety of interrupt operations
- Index addressing mode useful for table processing
- A variety of conditional branch instructions
- Ten powerful addressing modes
- All addressing modes adaptable to RAM, and I/O instructions
- Three new instructions, STOP, WAIT and DAA, added to the HD6805 family instruction set
－PIN ARRANGEMENT（Top Vlow）
－HD8308X2P，HD63A05X2P，HD83B08X2P HD8308Y2P，HD63A08Y2P，HD63B05Y2P

| $V_{M} \square_{0} 0$ | $\square$ datao |
| :---: | :---: |
| 同回 | $\stackrel{\text { data }}{ }$ |
| NTE | $\checkmark$ Datal |
| TIYC | $1)^{\text {DATA }}$ |
| XTAL | DATA4 |
| EXALE | －Datas |
| NUM［ | $1 \cdot$ Datas |
| TIMEA | 17．Data， |
| A，${ }^{\text {a }}$ | 1 |
| $A_{1} \mathrm{CL}^{10}$ | 1．1．MA |
| $A_{3}$（1） | $\cdots \mathrm{ADR}$ |
| A． 4 （t） | \％ADA： |
| $A_{3}(\underline{L T}$ | 1．7 ADA11 |
| $A_{\text {，III }}$ | （1）ADR 10 |
| A，［1］： | $\cdots$ ADA |
| AoII． | A ADR． |
| B，W | A ADA， |
| $0 \cdot 1$ | 7．ADA． |
| B6［10 | 4．ADR： |
|  | 21．ADA4 |
| B，${ }^{\text {a }}$ | $\pm$ ADA ${ }^{\text {a }}$ |
| 82 | 24 ADR 2 |
| B，${ }^{\text {ck }}$ | 24．ADR， |
| B0－2 | （1）ADR。 |
| C，ITM ${ }^{\text {cta }}$ | 20， |
| Co／Rx | $\mathrm{C}_{0} / \mathrm{HNT}_{2}$ |
| Cs／CR $\mathrm{EH}_{4}$ | 8！$D_{0}$ |
| $\mathrm{C}_{6}$ 20 |  |
| $\mathrm{C}_{3} \times$ | 2？． $\mathrm{D}_{3}$ |
| $\mathrm{C}_{2} \mathrm{CO}$ | 63．0 $\mathrm{D}_{2}$ |
| $\mathrm{C}_{1}$（11） | 2r |
| Coski | kk Vcc |

－HD6305X2F，HD63A05X2F，HD83B05X2F HD830：Y2F，HD83A05Y2F，HD63B0EY2F




HD6305X2/HD6305Y2

## - ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{CC}}+0.3$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

[NOTE] These products have a protection circuit in their input terminals against high electrostatic voltage or high electric fields. Notwithstanding, be careful not to apply any voltage higher than the absolute maximum rating to these high input impedance circuits. To assure normal operation, we recommended $V_{\text {in }}, V_{\text {out }} ; V_{\text {SS }} \leqq\left(V_{\text {in }}\right.$ or $\left.V_{\text {out }}\right) \leqq V_{\text {CC }}$.

- ELECTRICAL CHARACTERISTICS
- DC CHARACTERISTICS ( $\mathrm{V}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=\mathbf{O V}, \mathbf{T a}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

|  | Item | Symbol | Test Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input "High" Voltage | $\overline{\text { RES, }}$ STBY | $\mathrm{V}_{\text {IH }}$ |  | $\mathrm{V}_{\mathrm{cc}}-0.5$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |
|  | EXTAL |  |  | $\mathrm{V}_{\mathrm{cc}} \times 0.7$ | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ |  |
|  | Other Inputs |  |  | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ |  |
| Input "Low" Voltage | All Inputs | $V_{\text {IL }}$ |  | -0.3 | - | 0.8 | V |
| Output "High' Voltage | All Outputs | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  |  |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{cc}}-0.7$ | - | - |  |
| Output "Low" Voltage | All Outputs | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | - | 0.55 | V |
| Input Leakage Current | TIMER, INT, $\mathrm{D}_{1} \sim \mathrm{D}_{7}, \overline{\text { STBY }}$ | \| $\mathrm{ILL}^{\mathrm{L}}$ | $\mathrm{Vin}_{\text {in }}=0.5 \sim \mathrm{~V}_{\text {cc }}-0.5$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Three-state Current | $A_{0} \sim A_{7}, B_{0} \sim B_{7}$, $C_{0} \sim C_{7}, A D R_{0} \sim A D R_{13}{ }^{*}$, DATA $_{0} \sim$ DATA $_{7}, E^{*}$, R/W | \|ltal |  | - | - | 1.0 | $\mu \mathrm{A}$ |
| Current Dissipation** | Operating | Icc | $f=1 \mathrm{MHz}^{* * *}$ | - | 5 | 10 | mA |
|  | Wait |  |  | - | 2 | 5 | mA |
|  | Stop |  |  | - | 2 | 10 | $\mu \mathrm{A}$ |
|  | Standby |  |  | - | 2 | 10 | $\mu \mathrm{A}$ |
| Input Capacitance | All Terminals | Cin | $f=1 \mathrm{MHz}, \mathrm{Vin}=0 \mathrm{~V}$ | - | - | 12 | pF |

* Only at standby
** $\mathrm{V}_{1 H} \min =\mathrm{V}_{\mathrm{CC}}-1.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}$ max $=0.8 \mathrm{~V}$, all output and $\overline{\mathrm{RES}}$ terminal are open and penetrate current of input are not included.
* ** The value at $\mathrm{f}=x \mathrm{MHz}$ is given by using.
$I_{C C}(f=x M H z)=I_{C C}(f=1 \mathrm{MHz}) \times x$
- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item | Symbol | Test Condition | HD6305X2 <br> HD6305Y2 |  |  | HD63A05X2. <br> HD63A05Y2 |  |  | HD63B05X2 <br> HD63B05Y2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| Cycle Time | $\mathrm{t}_{\text {cyc }}$ | Fig. 1 | 1 | - | 10 | 0.666 | - | 10 | 0.5 | - | 10 | $\mu \mathrm{s}$ |
| Enable Rise Time | $\mathrm{t}_{\mathrm{Er}}$ |  | - | - | 20 | - | - | 20 | - | - | 20 | ns |
| Enable Fall Time | $t_{\text {Ef }}$ |  | - | - | 20 | - | - | 20 | - | - | 20 | ns |
| Enable Pulse Width('High' Level) | PW EH |  | 450 | - | - | 300 | - | - | 220 | - | - | ns |
| Enable Pulse Width("Low" Level) | PW EL |  | 450 | - | - | 300 | - | - | 220 | - | - | ns |
| Address Delay Time | $t_{\text {AD }}$ |  | - | - | 250 | - | - | 190 | - | - | 180 | ns |
| Address Hold Time | $t_{\text {AH }}$ |  | 40 | - | - | 30 | - | - | 20 | - | - | ns |
| Data Delay Time | $t_{\text {DW }}$ |  | - | - | 200 | - | - | 160 | - | - | 120 | ns |
| Data Hold Time (Write) | $t_{\text {HW }}$ |  | 40 | - | - | 30 | - | - | 20 | - | - | ns |
| Data Set-up Time (Read) | $t_{\text {DSR }}$ |  | 80 | - | - | 60 | - | - | 50 | - | - | ns |
| Data Hold Time (Read) | $t_{\text {HR }}$ |  | 0 | - | - | 0 | - | - | 0 | - | - | ns |

PORT TIMING ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\text {SS }}=0 \mathrm{~V}, \mathrm{Ta}=\mathbf{0} \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item | Symbol | Test Condition | HD6305×2, HD6305Y2 |  |  | H063A05×2, HD63A05Y2 |  |  | н063805х2, но63805Y2 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| Port Data Set-up Time (Port A, B, C, D) | tpos | Fig. 2 | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Port Data Hold Time (Port A, B, C, D) | ${ }_{\text {tPDH }}$ |  | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Port Data Delay Time (Port A, B, C) | tpow | Fig. 3 | - | - | 300 | - | - | 300 | - | - | 300 | ns |

- CONTROL SIGNAL TIMING $\left(V_{C C}=5.0 \mathrm{~V} \pm 10 \%, V_{S S}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}\right.$, unless otherwise noted.)

| Item | Symbol | Test Condition | HD6305×2, HD6305Y2 |  |  | HD63A05×2, HD63A05Y2 |  |  | HD63805×2, HD63805Y2 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| INT Pulse Width | ${ }^{\text {I }}$ wL |  | $\begin{aligned} & t_{\text {cyc }} \\ & +250 \end{aligned}$ | - | - | $\begin{aligned} & \hline \mathrm{t}_{\text {cyc }} \\ & +200 \end{aligned}$ | - | - | $\begin{aligned} & t_{\text {cyc }} \\ & +200 \end{aligned}$ | - | - | ns |
| $\overline{N_{N T}{ }_{2}}$ Pulse Width | ${ }^{\text {t w L L } 2}$ |  | $\begin{aligned} & \mathrm{t}_{\text {cyc }} \\ & +250 \\ & \hline \end{aligned}$ | - | - | $\begin{aligned} & t_{\text {cyc }} \\ & +200 \end{aligned}$ | - | - | $\begin{aligned} & t_{\text {cyc }} \\ & +200 \end{aligned}$ | - | - | ns |
| $\overline{\overline{R E S}}$ Pulse Width | $t_{\text {RWL }}$ |  | 5 | - | - | 5 | - | - | 5 | - | - | $\mathrm{t}_{\mathrm{cyc}}$ |
| Control Set-up Time | $\mathrm{t}_{\mathrm{cs}}$ | Fig. 5 | 250 | - | - | 250 | - | - | 250 | - | - | ns |
| Timer Pulse Width | ${ }^{\text {t }}$ WL |  | $\begin{aligned} & \mathrm{t}_{\text {cyc }} \\ & +250 \\ & \hline \end{aligned}$ | - | - | $\begin{aligned} & \hline \mathrm{t}_{\text {cyc }} \\ & +200 \\ & \hline \end{aligned}$ | - | - | $\begin{aligned} & \mathbf{t}_{\text {cyc }} \\ & +200 \\ & \hline \end{aligned}$ | - | - | ns |
| Oscillation Start Time (Crystal) | tose | Fig.5, Fig. $20^{*}$ | - | - | 20 | - | - | 20 | - | - | 20 | ms |
| Reset Delay Time | $\mathrm{t}_{\text {RHL }}$ | Fig. 19 | 80 | - | - | 80 | - | - | 80 | - | - | ms |

${ }^{*} C_{L}=22 p F \pm 20 \%, R_{s}=60 \Omega$ max.

- SCI TIMING ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item | Symbol | Test Condition | HD6305×2, HD6305Y2 |  |  | HD63A05×2, HD63A05Y2. |  |  | HD63B05×2, HD63B05Y2 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max | min | typ | max |  |
| Clock Cycle | ${ }^{\text {tscyc }}$ | Fig. 6, Fig. 7 | 1 | - | 32768 | 0.67 | - | 21845 | 0.5 | - | 16384 | $\mu \mathrm{s}$ |
| Data Output Delay Time | ${ }_{\text {t }}^{\text {TXD }}$ |  | - | - | 250 | - | - | 250 | - | - | 250 | ns |
| Data Set-up Time | ${ }_{\text {t }}$ (tr $X$ |  | 200 | - | - | 200 | - | - | 200 | - | - | ns |
| Data Hold Time | $t_{\text {HRX }}$ |  | 100 | - | - | 100 | - | - | 100 | - | - | ns |

$\qquad$


Figure 1 Bus Timing


Figure 2 Port Data Set-up and Hold Times (MPU Read)


Figure 4 Interrupt Sequence


Figure5 Reset Timing


Figure6 SCI Timing (Internal Clock)


Figure7 SCI Timing(External Clock)

[NOTES] 1. The load capacitance includes stary capacitance caused by the probe, etc.
2. All diodes are 1 S2074 $\Theta$.

Figure 8 Test Load

- DESCRIPTION OF TERMINAL FUNCTIONS

The input and output signals of the MPU are described here.

## - VCc, $\mathbf{V}_{\mathbf{S S}}$

Voltage is applied to the MPU through these two terminals. $\mathrm{V}_{\mathrm{CC}}$ is $5.0 \mathrm{~V} \pm 10 \%$, while $\mathrm{V}_{\mathrm{SS}}$ is grounded.

- $\overline{\mathbf{N T}}, \overline{\mathbf{I N T}}$

External interrupt request inputs to the MPU. For details, refer to "INTERRUPT". The $\overline{I_{N T}^{2}} 2$ terminal is also used as the port $D_{6}$ terminal.

## - XTAL, EXTAL

These terminals provide input to the on-chip clock circuit. A crystal oscillator (AT cut, 2.0 to 8.0 MHz ) or ceramic filter is connected to the terminal. Refer to "INTERNAL OSCILLATOR" for using these input terminals.

## - TIMER

This is an input terminal for event counter. Refer to "TIMER" for details.

## - $\overline{\text { RES }}$

Used to reset the MPU. Refer to "RESET" for details.

## - NUM

This terminal is not for user application. This terminal should be connected to $\mathrm{V}_{\text {SS }}$.

## - Enable (E)

This output terminal supplies E clock. Output is a singlephase, TTL compatible and $1 / 4$ crystal oscillation frequency or $1 / 4$ external clock frequency. It can drive one TTL load and a 90 pF condenser.

## - Read/Write (R/W)

This TTL compatible output signal indicates to peripheral and memory devices whether MPU is in Read ("High"), or in Write ("Low"). The normal standby state is Read ("High"). Its output can drive one TTL load and a 90 pF condenser.

## - Data Bus (DATA $0_{0}$ - DATA $)_{7}$ )

This TTL compatible three-state buffer can drive one TTL load and 90 pF .

- Address Bus (ADR $\mathbf{N a}_{0}-\mathrm{ADR}_{13}$ )

Each terminal is TTL compatible and can drive one TTL load and 90 pF .

- Ports A, B, C ( $\left.A_{0}-A_{7}, B_{0}-B_{7}, C_{0}-C_{7}\right)$

These 24 terminals consist of three 8 -bit I/O ports (A, B, C). Each of them can be used as an input or output terminal on a bit through program control of the data direction register. For details, refer to "I/O PORTS."

## - Port D ( $\left.D_{1}-D_{7}\right)$

These seven input-only terminals are TTL or CMOS compatible. Of the port D's, D6 is also used as $\overline{\mathrm{INT}_{2}}$. If $\mathrm{D}_{6}$ is used as a port, the $\overline{\mathrm{INT}} 2$ interrupt mask bit of the miscellaneous register must be set to " 1 " to prevent an $\overline{\mathrm{INT}}_{2}$ interrupt from being accidentally accepted.

- $\overline{\text { STBY }}$

This terminal is used to place the MPU into the standby mode. With STBY at "Low" level, the oscillation stops and the internal condition is reset. For details, refer to "Standby Mode."

The terminals described in the following are I/O pins for serial communication interface (SCI). They are also used as ports $\mathrm{C}_{5}, \mathrm{C}_{6}$ and $\mathrm{C}_{7}$. For details, refer to "SERIAL COMMUNICATION INTERFACE."

- $\overline{\mathbf{C K}}\left(C_{5}\right)$

Used to input or output clocks for serial operation.

- $\mathbf{R x}\left(C_{6}\right)$

Used to receive serial data.

- Tx (C7)

Used to transmit serial data.

## -MEMORY MAP

The memory map of the MPU is shown in Fig. 9. During interrupt processing, the contents of the CPU registers are saved into the stack in the sequence shown in Fig. 10. This saving begins with the lower byte (PCL) of the program counter. Then the value of the stack pointer is decremented and the higher byte (PCH) of the program counter, index register (X), accumulator (A) and condition code register (CCR) are stacked in that order. In a subroutine call, only the contents of the program counter (PCH and PCL) are stacked.

(a) HD6305×2

(b) HD6305Y2

Figure 9 Memory Maps of MPU


* In a subroutine call, only PCL and PCH are stacked.

Figure 10 Sequence of Interrupt Stacking

## -REGISTERS

There are five registers which the programmer can operate.


Figure 11 Programming Model

## - Accumulator (A)

This accumulator is a general purpose 8 -bit register which holds operands or the result of arithmetic operation or data processing.

## - Index Register (X)

The index register is an 8-bit register, and is used for index addressing mode. Each of the addresses contained in the register consists of 8 bits which, combined with an offset value, provides an effective address.

In the case of a read/modify/write instruction, the index register can be used like an accumulator to hold operation data or the result of operation.

If not used in the index addressing mode, the register can be used to store data temporarily.

## - Program Counter (PC)

The program counter is a 14 -bit register that contains the address of the next instruction to be executed.

## - Stack Pointer (SP)

The stack pointer is a 14 -bit register that indicates the address of the next stacking space. Just after reset, the stack pointer is set at address $\$ 00 \mathrm{FF}$. It is decremented when data is pushed, and incremented when pulled. The upper 8 bits of the stack pointer are fixed to 00000011 . During the MPU being reset or during a reset stack pointer (RSP) instruction, the pointer is set to address $\$ 00 \mathrm{FF}$. Since a subroutine or interrupt can use space up to address $\$ 00 \mathrm{C} 1$ for stacking, the subroutine can be used up to 31 levels and the interrupt up to 12 levels.

## - Condition Code Register (CCR)

The condition code register is a 5 -bit register, each bit indicating the result of the instruction just executed. The bits can be individually tested by conditional branch instruc-
tions. The CCR bits are as follows:
Half Carry (H): Used to indicate that a carry occurred between bits 3 and 4 during an arithmetic operation (ADD, ADC).
Interrupt (I): Setting this bit causes all interrupts, except a software interrupt, to be masked. If an interrupt occurs with the bit I set, it is latched. It will be processed the instant the interrupt mask bit is reset. (More specifically, it will enter the interrupt processing routine after the instruction following the CLI has been executed.)
Negative (N): Used to indicate that the result of the most recent arithmetic operation, logical operation or data processing is negative (bit 7 is logic "1").
Zero (Z): Used to indicate that the result of the most recent arithmetic operation, logical operation or data processing is zero.
Carry/ Represents a carry or borrow that occurred Borrow (C): in the most recent arithmetic operation. This bit is also affected by the Bit Test and Branch instruction and a Rotate instruction.

## - INTERRUPT

There are six different types of interrupt: external interrupts ( $\overline{\mathrm{INT}}, \overline{\mathrm{INT}})_{2}$, internal timer interrupts (TIMER, TIMER2), serial interrupt (SCI) and interrupt by an instruction (SWI).

Of these six interrupts, the $\overline{\mathrm{INT}_{2}}$ and TIMER or the SCI and TIMER2 generate the same vector address, respectively.

When an interrupt occurs, the program in progress stops and the then CPU status is saved onto the stack. And then, the interrupt mask bit (I) of the condition code register is set and the start address of the interrupt processing routine is obtained from a particular interrupt vector address. Then the interrupt routine starts from the start address. System can exit from the interrupt routine by an RTI instruction. When this instruction is executed, the CPU status before the interrupt (saved onto the stack) is pulled and the CPU restarts the sequence with the instruction next to the one at which the interrupt occurred. Table 1 lists the priority of interrupts and their vector addresses.

Table 1 Priority of Interrupts

| Interrupt | Priority | Vector Address |
| :--- | :---: | :---: |
| $\overline{\text { RES }}$ | 1 | \$1FFE, \$1FFF |
| SWI | 2 | \$1FFC, \$1FFD |
| $\overline{\text { INT }}$ | 3 | \$1FFA, \$1FFB |
| TIMER// $\overline{\mathrm{INT}}_{2}$ | 4 | \$1FF8, \$1FF9 |
| SCI/TIMER2 | 5 | \$1FF6, \$1FF7 |

A flowchart of the interrupt sequence is shown in Fig. 12. A block diagram of the interrupt request source is shown in Fig. 13.


Figure 12 Interrupt Flow Chart

In the block diagram, both the external interrupts $\overline{\text { INT }}$ and $\overline{\mathrm{INT}_{2}}$ are edge trigger inputs. At the falling edge of each input, an interrupt request is generated and latched. The INT interrupt request is automatically cleared if jumping is made to the INT processing routine. Meanwhile, the $\overline{I N T}_{2}$ request is cleared if " 0 " is written in bit 7 of the miscellaneous register.

For the external interrupts ( $\overline{\mathrm{INT}}, \overline{\mathrm{INT}_{2}}$ ), internal timer interrupts (TIMER, TIMER2) and serial interrupt (SCI), each interrupt request is held, but not processed, if the I bit of the condition code register is set. Immediately after the I bit is cleared, the corresponding interrupt processing starts according to the priority.

The INT ${ }_{2}$ interrupt can be masked by setting bit 6 of the miscellaneous register; the TIMER interrupt by setting bit 6 of the timer control register; the SCI interrupt by setting bit 5 of the serial status register; and the TIMER2 interrupt by setting bit 4 of the serial status register.

The status of the INT terminal can be tested by a BIL or BIH instruction. The $\overline{\mathrm{INT}}$ falling edge detector circuit and its latching circuit are independent of testing by these instructions. This is also true with the status of the $\overline{\mathrm{INT}} \mathrm{T}_{2}$ terminal.

## - Miscellaneous Register (MR; \$000A)

The interrupt vector address for the external interrupt $\overline{\mathrm{INT}_{2}}$ is the same as that for the TIMER interrupt, as shown in Table 1. For this reason, a special register called the miscellaneous register (MR; $\$ 000 \mathrm{~A}$ ) is available to control the $\overline{\mathrm{INT}} \mathbf{2}$ interrupts.

Bit 7 of this register is the $\overline{\mathrm{INT}}_{2}$ interrupt request flag. When the falling edge is detected at the $\overline{\mathrm{INT}}_{2}$ terminal, " 1 " is set in bit 7. Then the software in the interrupt routine (vector addresses: \$1FF8, \$1FF9) checks bit 7 to see if it is $\overline{\mathrm{INT}} \mathbf{2}$ interrupt. Bit 7 can be reset by software.


Miscellaneous Register (MR; \$000A)

Bit 6 is the $\overline{\text { INT }} 2$ interrupt mask bit. If this bit is set to " 1 ", then the $\overline{\mathrm{INT}_{2}}$ interrupt is disabled. Both read and write are possible with bit 7 but " 1 " cannot be written in this bit by software. This means that an interrupt request by software is impossible.

When reset, bit 7 is cleared to " 0 " and bit 6 is set to " 1 ".

## -TIMER

Figure 14 shows a MPU timer block diagram. The timer data register is loaded by software and, upon receipt of a clock input, begins to count down. When the timer data


Figure 13 Interrupt Request Generation Circuitry
register (TDR) becomes " 0 ", the timer interrupt request bit (bit 7) in the timer control register is set. In response to the interrupt request, the CPU saves its status into the stack and fetches timer interrupt routine address from addresses \$1FF8 and \$1FF9 and execute the interrupt routine. The timer interrupt can be masked by setting the timer interrupt mask bit (bit 6) in the timer control register. The mask bit (I) in the condition code register can also mask the timer interrupt.

The source clock to the timer can be either an external signal from the timer input terminal or the internal E signal (the oscillator clock divided by 4). If the E signal is used as the source, the clock input can be gated by the input to the timer input terminal.

Once the timer count has reached " 0 ", it starts counting down with " $\$ F F$ ". The count can be monitored whenever desired by reading the timer data register. This permits the program to know the length of time having passed after the occurrence of a timer interrupt, without disturbing the contents of the counter.

When the MPU is reset, both the prescaler and counter are initialized to logic " 1 ". The timer interrupt request bit (bit 7) then is cleared and the timer interrupt mask bit (bit 6 ) is set.

To clear the timer interrupt request bit (bit 7), it is necessary to write " 0 " in that bit.

| TCR7 | Timer interrupt request |
| :---: | :---: |
| 0 | Absent |
| 1 | Present |
| TCR6 | Timer interrupt mask |
| 0 | Enabled |
| 1 | Disabled |

## - Timer Control Register. (TCR; \$0009)

Selection of a clock source, selection of a prescaler frequency division ratio, and a timer interrupt can be controlled by the timer control register (TCR; \$0009).

For the selection of a clock source, any one of the four modes (see Table 2) can be selected by bits 5 and 4 of the timer control register (TCR).

Timer Control Register (TCR; \$0009)


After reset, the TCR is initialized to "E under timer terminal control" (bit $5=0$, bit $4=1$ ). If the timer terminal is " 1 ", the counter starts counting down with " $\$ F F$ " immediately after reset.

When " 1 " is written in bit 3 , the prescaler is initialized. This bit always shows " 0 " when read.

Table 2 Clock Source Selection

| TCR |  | Clock input source |
| :---: | :---: | :--- |
| Bit 5 | Bit 4 |  |
| 0 | 0 | Internal clock E |
| 0 | 1 | E under timer terminal control |
| 1 | 0 | No clock input (counting stopped) |
| 1 | 1 | Event input from timer terminal |



Figure 14 Timer Block Diagram

A prescaler division ratio is selected by the combination of three bits (bits 0,1 and 2 ) of the timer control register (see Table 3). There are eight different division ratios: $\div 1, \div 2, \div 4$, $\div 8, \div 16, \div 32, \div 64$ and $\div 128$. After reset, the TCR is set to the $\div 1$ mode.

Table 3 Prescaler Division Ratio Selection

| TCR |  |  | Prescaler division ratio |
| :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 |  |
| 0 | 0 | 0 | $\div 2$ |
| 0 | 0 | 1 | $\div 4$ |
| 0 | 1 | 0 | $\div 8$ |
| 0 | 1 | 1 | $\div 16$ |
| 1 | 0 | 0 | $\div 32$ |
| 1 | 0 | 1 | $\div 64$ |
| 1 | 1 | 0 | $\div 128$ |
| 1 | 1 | 1 |  |

A timer interrupt is enabled when the timer interrupt mask bit is " 0 ", and disabled when the bit is " 1 ". When a timer interrupt occurs, " 1 " is set in the timer interrupt request bit. This bit can be cleared by writing " 0 " in that bit.

## -SERIAL COMMUNICATION INTERFACE (SCI)

This interface is used for serial transmission or reception of 8 -bit data. Sixteen transfer rates are available in the range from $1 \mu \mathrm{~s}$ to approx. 32 ms (for oscillation at 4 MHz ).

The SCI consists of three registers, one eighth counter and one prescaler. (See Fig. 15.) SCI communicates with the CPU via the data bus, and with the outside world through bits 5 , 6 and 7 of port C. Described below are the operations of each register and data transfer.

- SCI Control Register (SCR; \$0010)



Figure 15 SCI Block Diagram

| SCR7 |  | $\mathrm{C}_{7}$ terminal |  |
| :---: | :---: | :---: | :---: |
| 0 |  | Used as 1/O terminal (by DDR). |  |
| 1 |  | Serial data output (DDR output) |  |
| SCR6 |  | $\mathrm{C}_{6}$ terminal |  |
| 0 |  | Used as I/O terminal (by DDR). |  |
| 1 |  | Serial data input (DDR input) |  |
| SCR5 | SCR4 | Clock source | $\mathrm{C}_{5}$ terminal |
| 0 | 0 | - | Used as I/O terminal (by DDR). |
| 0 | 1 | - |  |
| 1 | 0 | Internal | Clock output (DDR output) |
| 1 | 1 | External | Clock input (DDR input) |

Bit 7 (SCR7)
When this bit is set, the DDR corresponding to the $\mathrm{C}_{7}$ becomes " 1 " and this terminal serves for output of SCI data. After reset, the bit is cleared to " 0 ".

## Bit 6 (SCR6)

When this bit is set, the DDR corresponding to the $\mathrm{C}_{6}$ becomes " 0 " and this terminal serves for input of SCI data. After reset, the bit is cleared to " 0 ".

Bits 5 and 4 (SCR5, SCR4)
These bits are used to select a clock source. After reset, the bits are cleared to " 0 ".

Bits 3-0 (SCR3-SCR0)
These bits are used to select a transfer clock rate. After reset, the bits are cleared to " 0 ".

| SCR3 | SCR2 | SCR1 | SCRO | Transfer clock rate |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 4.00 MHz | 4.194 MHz |
| 0 | 0 | 0 | 0 | $1 \mu \mathrm{~s}$ | $0.95 \mu \mathrm{~s}$ |
| 0 | 0 | 0 | 1 | $2 \mu \mathrm{~s}$ | $1.91 \mu \mathrm{~s}$ |
| 0 | 0 | 1 | 0 | $4 \mu \mathrm{~s}$ | $3.82 \mu \mathrm{~s}$ |
| 0 | 0 | 1 | 1 | $8 \mu \mathrm{~s}$ | $7.64 \mu \mathrm{~s}$ |
| 2 | 2 | 2 | 2 | 2 | 2 |
| 1 | 1 | 1 | 1 | $32768 \mu \mathrm{~s}$ | $1 / 32 \mathrm{~s}$ |

- SCI Data Register (SDR; \$0012)

A serial-parallel conversion register that is used for transfer of data.

## - SCI Status Register (SSR; \$0011)



Bit 7 (SSR7)
Bit 7 is the SCI interrupt request bit which is set upon completion of transmitting or receiving 8 -bit data. It is cleared when reset or data is written to or read from the SCI data register with the SCR $5=$ " 1 ". The bit can also be cleared by writing " 0 " in it.

Bit 6 (SSR6)
Bit 6 is the TIMER $_{2}$ interrupt request bit. TIMER $_{2}$ is multiplexed with the serial clock generator, and SSR6 is set each time the internal transfer clock falls. When reset, the bit is cleared. It also be cleared by writing " 0 " in it. (For details, see TIMER 2 .)

## Bit 5 (SSR5)

Bit 5 is the SCI interrupt mask bit which can be set or cleared by software. When it is " 1 ", the SCI interrupt (SSR7) is masked. When reset, it is set to " 1 ".

## Bit 4 (SSR4)

Bit 4 is the TIMER ${ }_{2}$ interrupt mask bit which can be set or cleared by software. When the bit is " 1 ", the TIMER $_{2}$ interrupt (SSR6) is masked. When reset, it is set to " 1 ".

Bit 3 (SSR3)
When " 1 " is written in this bit, the prescaler of the transfer clock generator is initialized. When read, the bit always is " 0 ".

Bits 2-0
Not used.

| SSR7 | SCI interrupt request |  |
| :---: | :---: | :---: |
| 0 | Absent |  |
| 1 | Present |  |
|  |  |  |
| SSR6 | TIMER $_{2}$ interrupt request |  |
| 0 | Absent |  |
| 1 | Present |  |
|  |  |  |
| SSR5 | SCI interrupt mask |  |
| 0 | Enabled |  |
| 1 | Disabled |  |
| SSR4 | TIMER 2 interrupt mask |  |
| 0 | Enabled |  |
| 1 | Disabled |  |

## - Data Transmission

By writing the desired control bits into the SCI control registers, a transfer rate and a source of transfer clock are determined and bits 7 and 5 of port $C$ are set at the serial data output terminal and the serial clock terminal, respectively. The transmit data should be stored from the accumulator or index register into the SCI data register. The data written in the SCI data register is output from the $\mathrm{C}_{7} / \mathrm{Tx}$ terminal, starting with the LSB, synchronously with the falling edge of the serial clock. (See Fig. 16.) When 8 bit of
data have been transmitted, the interrupt request bit is set in bit 7 of the SCI status register with the rising edge of the last serial clock. This request can be masked by setting bit 5 of the SCI status register. Once the data has been sent, the 8th bit data (MSB) stays at the $\mathrm{C}_{7} / \mathrm{Tx}$ terminal. If an external clock source has been selected, the transfer rate determined by bits $0-3$ of the SCI control register is ignored, and the Cs/CK terminal is set as input. If the internal clock has been selected, the Cs/ $\overline{\mathbf{C K}}$ terminal is set as output and clocks are output at the transfer rate selected by bits $0-3$ of the SCI control register.


Figure 16 SCI Timing Chart

## - Data Reception

By writing the desired control bits into the SCI control register, a transfer rate and a source of transfer clock are determined and bit 6 and 5 of port C are set at the serial data input terminal and the serial clock terminal, respectively. Then dummy-writing or -reading the SCI data register, the system is ready for receiving data. (This procedure is not needed after reading the subsequent received data. It must be taken after reset and after not reading the subsequent received data.)

The data from the $\mathrm{C}_{6} / \mathrm{Rx}$ terminal is input to the SCI data register synchronously with the rising edge of the serial clock (see Fig. 16). When 8 bits of data have been received, the interrupt request bit is set in bit 7 of the SCI status register. This request can be masked by setting bit 5 of the SCI status register. If an external clock source have been selected, the transfer rate determined by bits $0-3$ of the SCI control register is ignored and the data is received synchronously with the clock from the $\mathrm{C}_{5} / \overline{\mathrm{CK}}$ terminal. If the internal clock has been selected, the $\mathrm{C}_{5} / \overline{\mathrm{CK}}$ terminal is set as output and clocks are output at the transfer rate selected by bits 0 3 of the SCI control register.

## - TIMER2

The SCI transfer clock generator can be used as a timer. The clock selected by bits $3-0$ of the SCI control register ( $4 \mu \mathrm{~s}$ - approx. 32 ms (for oscillation at 4 MHz ) ) is input to bit 6 of the SCI status register and the TIMER 2 interrupt request bit is set at each falling edge of the clock. Since interrupt requests occur periodically, TIMER2 can be used as a reload counter or clock.

(1) : Transfer clock generator is reset and mask bit (bit 4 of SCl status register) is cleared.
(2), (4) : TIMER2 interrupt request
(3). (5) : TIMER2 interrupt request bit cleared

TIMER $_{2}$ is multiplexed with the SCI transfer clock generator. If wanting to use TIMER ${ }_{2}$ independently of the SCI, specify "External" (SCR5 = 1, SCR4 =1) as the SCI clock source.

If "Internal" is selected as the clock source, reading or writing the SDR causes the prescaler of the transfer clock generator to be initialized.

## -1/O PORTS

There are 24 input/output terminals (ports A, B, C). Each I/O terminal can be selected for either input or output by the data direction register. More specifically, an I/O port will be input if " 0 " is written in the data direction register, and output if " 1 " is written in the data direction register. Port A, $B$ or $C$ reads latched data if it has been programmed as output, even with the output level being fluctuated by the output load. (See Fig. 17.)

When reset, the data direction register and data register go to " 0 " and all the input/output terminals are used as input.


| Bit of data <br> direction <br> register | Bit of <br> output <br> data | Status of <br> output | Input to <br> CPU |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| 0 | $X$ | 3 -state | Pin |

Figure 17 Input/Output Port Diagram
Seven input-only terminals are available (port D). Writing to an input terminal is invalid.

All input/output terminals and input terminals are TTL compatible and CMOS compatible in respect of both input and output.

If I/O ports or input ports are not used, they should be connected to VSS via resistors. With none connected to these terminals, there is the possibility of power being consumed despite that they are not used.

## - RESET

The MPU can be reset either by external reset input ( $\overline{\mathrm{RES}}$ ) or power-on reset. (See Fig. 18.) On power up, the reset input must be held "Low" for at least tosc to assure that the internal oscillator is stabilized. A sufficient time of delay can be obtained by connecting a capacitance to the $\overline{\mathrm{RES}}$ input as shown in Fig. 19.


Figure 18 Power On and Reset Timing


Figure 19 Input Reset Delay Circuit

## - INTERNAL OSCILLATOR

The internal oscillator circuit is designed to meet the


Figure 20 Internal Oscillator Circuit
requirement for minimum external configurations. It can be driven by connecting a crystal (AT cut $2.0-8.0 \mathrm{MHz}$ ) or ceramic oscillator between pins 5 and 6 depending on the required oscillation frequency stability.

Three different terminal connections are shown in Fig. 20.
Figs. 21, and 22 illustrate the specifications and typical arrangement of the crystal, respectively.


Figure 21 Parameters of Crystal

[NOTE] Use as short wirings as possible for connection of the crystal with the EXTAL and XTAL terminals. Do not allow these wirings to cross others.

Figure 22 Typical Crystal Arrangement

## -LOW POWER DISSIPATION MODE

The HD6305X2 and the HD6305Y2 provides three low power dissipation modes: wait, stop and standby.

## - Wait Mode

When WAIT instruction being executed, the MPU enters into the wait mode. In this mode, the oscillator stays active but the internal clock stops. The CPU stops but the peripheral functions - the timer and the serial communication interface - stay active. (NOTE: Once the system has entered the wait mode, the serial communication interface can no longer be retriggered.) In the wait mode, the registers, RAM and I/O terminals hold their condition just before entering into the wait mode.

The escape from this mode can be done by interrupt (INT, TIMER/INT ${ }_{2}$ or SCI/TIMER2), $\overline{\text { RES }}$ or STBY. The $\overline{\text { RES }}$ resets the MPU and the STBY brings it into the standby mode. (This will be mentioned later.)

When interrupt is requested to the CPU and accepted, the wait mode escapes, then the CPU is brought to the operation mode and vectors to the interrupt routine. If the interrupt is masked by the I bit of the condition code register, after releasing from the wait mode the MPU executes the instruction next to the WAIT. If an interrupt other than the INT (i.e., TIMER//INT ${ }_{2}$ or SCI/TIMER 2 ) is masked by the timer control
register, miscellaneous register or serial status register, there is no interrupt request to the CPU, so the wait mode cannot be released.

Fig. 23 shows a flowchart for the wait function.

## - Stop Mode

When STOP instruction being executed, MPU enters into the stop mode. In this mode, the oscillator stops and the CPU and peripheral functions become inactive but the RAM, registers and I/O terminals hold their condition just before entering into the stop mode.

The escape from this mode can be done by an external interrupt (INT or $\overline{\text { INT }} \mathbf{2}$ ), RES or STBY. The RES resets the MPU and the STBY brings into the standby mode.

When interrupt is requested to the CPU and accepted, the stop mode escapes, then the CPU is brought to the operation mode and vectors to the interrupt routine. If the interrupt is masked by the I bit of the condition code register, after releasing from the stop mode, the MPU executes the instruction next to the STOP. If the $\overline{\mathrm{INT}_{2}}$ interrupt is masked by the miscellaneous register, there is no interrupt request to the MPU, so the stop mode cannot be released.

Fig. 24 shows a flowchart for the stop function. Fig. 25 shows a timing chart of return to the operation mode from the stop mode.

For releasing from the stop mode by an interrupt, oscillation starts upon input of the interrupt and, after the internal delay time for stabilized oscillation, the CPU becomes active.

For restarting by $\overline{\mathrm{RES}}$, oscillation starts when the $\overline{\mathrm{RES}}$ goes " 0 " and the CPU restarts when the RES goes " 1 ". The duration of RES=" 0 " must exceed $t_{\text {osc }}$ to assure stabilized oscillation.

## - Standby Mode

The MPU enters into the standby mode when the STBY terminal goes "Low". In this mode, all operations stop and the internal condition is reset but the contents of the RAM are hold. The I/O terminals turn to high-impedance state. The standby mode should escape by bringing STBY "High". The CPU must be restarted by reset. The timing of input signals at the RES and STBY terminals is shown in Fig. 26.

Table 4 lists the status of each parts of the MPU in each low power dissipation modes. Transitions between each mode are shown in Fig. 27.
(Note) When I bit of condition code register is " 1 " and interrupt ( $\overline{\mathrm{INT}}$, TIMER $/ \overline{\mathrm{INT}_{2}}, \mathrm{SCI} / \mathrm{TIMER}_{2}$ ) is held, MPU does not enter WAIT mode by the execution of WAIT instruction.
In that case, after the 4 dummy cycles MCU executes the next instruction.
In the same way, when external interrupts ( $\overline{\mathrm{INT}}, \overline{\mathrm{INT}}{ }_{2}$ ) are held at the bit I set, MPU does not enter STOP mode by the execution of STOP instruction. In that case, also, MPU executes the next instruction after the 4 dummy cycles.


Figure 23 Wait Mode Flow Chart


Figure 24 Stop Mode Flow Chart


Figure 25 Timing Chart of Releasing from Stop Mode


Figure 26 Timing Chart of Releasing from Standby Mode

Table 4 Status of Each Part of MPU in Low Power Dissipation Modes

| Mode | Start |  | Condition |  |  |  |  |  | Escape |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Oscillator | CPU | Timer, Serial | Register | RAM | $\begin{gathered} 1 / 0 \\ \text { terminal } \end{gathered}$ |  |
| WAIT | Software | WAIT instruction | Active | Stop | Active | Keep | Keep | Keep | STBY, RES, INT, INT ${ }_{2}$, each interrupt request of TIMER, TIMER2, SCI |
| STOP |  | STOP instruction | Stop | Stop | Stop | Keep | Keep | Keep | $\overline{\text { STBY }}, \overline{\mathrm{RES}}, \overline{\mathrm{INT}}, \overline{\mathrm{INT}}{ }_{2}$ |
| Standby | Hardware | $\overline{\text { STBY }}$ "'Low ${ }^{\prime \prime}$ | Stop | Stop | Stop | Reset | Keep | High impedance | $\overline{\text { STBY }}=$ " ${ }^{\text {High }}$ " |



Figure 27 Transitions among Active Mode, Wait Mode, Stop Mode, Standby Mode and Reset

## - BIT MANIPULATION

The MPU can use a single instruction (BSET or BCLR) to set or clear one bit of the RAM within page 0 or an I/O port (except the write-only registers such as the data direction register). Every bit of memory or I/O within page 0 ( $\$ 00-$ $\$ F F$ ) can be tested by the BRSET or BRCLR instruction; depending on the result of the test, the program can branch to required destinations. Since bits in the RAM, or I/O can be manipulated, the user may use a bit within the RAM as a flag or handle a single I/O bit as an independent I/O terminal. Fig. 28 shows an example of bit manipulation and the validity of test instructions. In the example, the program is configured assuming that bit 0 of port A is connected to a zero cross detector circuit and bit 1 of the same port to the trigger of a triac.
'The program shown can activate the triac within a time of $10 \mu$ s from zero-crossing through the use of only 7 bytes on the memory. The on-chip timer provides a required time of delay and pulse width modulation of power is also possible.

SELF 1. BRCLR 0, PORT A, SELF 1
BSET 1, PORT A
BCLR 1, PORT A
:
Figure 28 Example of Bit Manipulation

## - ADDRESSING MODES

Ten different addressing modes are available to the MPU.

## - Immediate

See Fig. 29. The immediate addressing mode provides access to a constant which does not vary during execution of the program.

This access requires an instruction length of 2 bytes. The effective address (EA) is PC and the operand is fetched from
the byte that follows the operation code.

## - Direct

See Fig. 30. In the direct addressing mode, the address of the operand is contained in the 2rid byte of the instruction. The user can gain direct access to memory up to the lower 255th address. All RAM (HD6305X2) or 192 bytes of RAM (HD6305Y2), and I/O registers are on page 0 of address space so that the direct addressing mode may be utilized.

## - Extended

See Fig. 31. The extended addressing is used for referencing to all addresses of memory. The EA is the contents of the 2 bytes that follow the operation code. An extended addressing instruction requires 3 bytes.

## - Relative

See Fig. 32. The relative addressing mode is used with branch instructions only. When a branch occurs, the program counter is loaded with the contents of the byte following the operation code. EA $=(\mathrm{PC})+2+$ Rel., where Rel. indicates a signed 8 -bit data following the operation code. If no branch occurs, Rel. $=0$. When a branch occurs, the program jumps to any byte in the range +129 to -127 . A branch instruction requires 2 bytes.

## - Indexed (No Offset)

See Fig. 33. The indexed addressing mode allows access up to the lower 255th address of memory. In this mode, an instruction requires a length of one byte. The EA is the contents of the index register.

## - Indexed (8-bit Offset)

See Fig. 34. The EA is the contents of the byte following the operation code, plus the contents of the index register. This mode allows access up to the lower 511th address of memory. Each instruction when used in the index addressing mode ( 8 -bit offset) requires 2 bytes.

## - Indexed (16-bit Offset)

See Fig. 35. The contents of the 2 bytes following the operation code are added to content of the index register to compute the value of EA. In this mode, the complete memory can be accessed. When used in the indexed addressing mode ( 16 -bit offset), an instruction requires 3 bytes.

## - Bit Set/Clear

See Fig. 36. This addressing mode is applied to the BSET and BCLR instructions that can set or clear any bit on page 0 . The lower 3 bits of the operation code specify the bit to be set or cleared. The byte that follows the operation code indicates an address within page 0 .

## - Bit Test and Branch

See Fig. 37. This addressing mode is applied to the BRSET and BRCLR instructions that can test any bit within page 0 and can be branched in the relative addressing mode. The byte to be tested is addressed depending on the contents of the byte following the operation code. Individual bits within the byte to be tested are specified by the lower 3 bits of the operation code. The 3rd byte represents a relative value which will be added to the program counter when a branch condition is established. Each of these instructions requires 3 bytes. The value of the test bit is written in the carry bit of the condition code register.

## - Implied

See Fig. 38. This mode involves no EA. All information needed for execution of an instruction is contained in the operation code. Direct manipulation on the accumulator and index register is included in the implied addressing mode. Other instructions such as SWI and RTI are also used in this mode. All instructions used in the implied addressing mode requires one byte.


Figure 29 Example of Immediate Addressing


Figure 30 Example of Direct Addressing


Figure 31 Example of Extended Addressing


Figure 32 Example of Relative Addressing


Figure 33 Example of Indexed (No Offset) Addressing


Figure 34 Example of Index (8-bit Offset) Addressing


Figure 35 Example of Index (16-bit Offset) Addressing


Figure 36 Example of Bit Set/Clear Addressing


Figure 37 Example of Bit Test and Branch Addressing


Figure 38 Example of Implied Addressing

## - INSTRUCTION SET

There are 62 basic instructions available to the HD6305X2 and the HD6305Y2. They can be classified into five categories: register/memory, read/modify/write, branch, bit manipulation, and control. The details of each instruction are described in Tables 5 through 11.

## - Register/Memory Instructions

Most of these instructions use two operands. One operand is either an accumulator or index register. The other is derived from memory using one of the addressing modes used on the HD6305X2 and the HD6305Y2. There is no register operand in the unconditional jump instruction (JMP) and the subroutine jump instruction (JSR). See Table 5.

## - Read/Modify/Write Instructions

These instructions read a memory or register, then modify or test its contents, and write the modified value into the memory or register. Zero test instruction (TST) does not write data, and is handled as an exception in the read/modify/ write group. See Table 6.

## - Branch Instructions

A branch instruction branches from the program sequence in progress if a particular condition is established. See Table 7.

## - Bit Manipulation Instructions

These instructions can be used with any bit located up to the lower 255th address of memory. Two groups are available; one for setting or clearing and the other for bit testing and branching. See Table 8.

## - Control Instructions

The control instructions control the operation of the MPU which is executing a program. See Table 9.

## - List of Instructions in Alphabetical Order

Table 10 lists all the instructions used on the HD6305X2 and the HD6305Y2 MPU in the alphabetical order.

## - Operation Code Map

Table 11 shows the operation code map for the instructions used on the MPU.

Table 5 Register/Memory Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/ Arithmetic Operation | Condition Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Immediate |  |  | Direct |  |  |  | Extended |  |  | Indexed <br> (No Offset) |  |  | Indexed (8-Bit Offset) |  |  | Indexed(16-Bin Offset) |  |  |  |  |  |  |  |  |
|  |  | OP | \# | $\sim$ | OP | P \# | \# | - | OP | \# | - | OP | \# | - | OP | \# | - | OP | \# | $\sim$ |  | H | 1 | N | z | C |
| Load A from Memory | LDA | A6 | 2 | 2 | B6 |  | 2 | 3 | C6 | 3 | 4 | F6 | 1 | 3 | E6 | 2 | 4 | D6 | 3 | 5 | M $\rightarrow$ A | $\bullet$ | - | $\wedge$ | $\wedge$ | $\bullet$ |
| Load X from Memory | LDX | AE | 2 | 2 | BE |  | 2 | 3 | CE | 3 | 4 | FE | 1 | 3 | EE | 2 | 4 | DE | 3 | 5 | $M \rightarrow X$ | $\bullet$ | - | $\wedge$ | $\wedge$ | $\bullet$ |
| Store A in Memory | STA | - | - | - | B7 | 72 | 2 | 3 | C7 | 3 | 4 | F7 | 1 | 4 | E7 | 2 | 4 | D7 | 3 | 5 | $A \rightarrow M$ | $\bullet$ | - | $\wedge$ | $\wedge$ | $\bullet$ |
| Store X in Memory | STX | - | - | - | BF |  | 2 | 3 | CF | 3 | 4 | FF | 1 | 4 | EF | 2 | 4 | DF | 3 | 5 | $X \rightarrow M$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| Add Memory to A | ADD | AB | 2 | 2 | BB | 82 | 2 | 3 | CB | 3 | 4 | FB | 1 | 3 | EB | 2 | 4 | DB | 3 | 5 | $A+M \rightarrow A$ | $\wedge$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| Add Memory and Carry to $A$ | ADC | A9 | 2 | 2 | B9 |  | 2 | 3 | C9 | 3 | 4 | F9 | 1 | 3 | E9 | 2 | 4 | D9 | 3 | 5 | $A+M+C \rightarrow A$ | $\wedge$ | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Subtract Memory | SUB | AO | 2 | 2 | 80 | 02 | 2 | 3 | CO | 3 | 4 | FO | 1 | 3 | EO | 2 | 4 | DO | 3 | 5 | $A-M \rightarrow A$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| Subtract Memory from A with Borrow | SBC | A2 | 2 | 2 | B2 | 2.2 | 2 | 3 | C2 | 3 | 4 | F2 | 1 | 3 | E2 | 2 | 4 | D2 | 3 | 5 | $A-M-C \rightarrow A$ | $\bullet$ | - | $\wedge$ | $\wedge$ | $\wedge$ |
| AND Memory to A | AND | A4 | 2 | 2 | B4 | 42 | 2 | 3 | C4 | 3 | 4 | F4 | 1 | 3 | E4 | 2 | 4 | D4 | 3 | 5 | $A \cdot M \rightarrow A$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| OR Memory with A | ORA | AA | 2 | 2 | BA | A 2 | 2 | 3 | CA | 3 | 4 | FA | 1 | 3 | EA | 2 | 4 | DA | 3 | 5 | $A+M \rightarrow A$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | - |
| Exclusive OR Memory with A | EOR | A8 | 2 | 2 | 88 |  | 2 | 3 | C8 | 3 | 4 | F8 | 1 | 3 | E8 | 2 | 4 | D8 | 3 | 5 | $A \oplus M \rightarrow A$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | - |
| Arithmetic Compare A with Memory | CMP | A1 | 2 | 2 | B1 |  | 2 | 3 | C1 | 3 | 4 | F1 | 1 | 3 | E1 | 2 | 4 | D1 | 3 | 5 | A-M | - | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Arithmetic Compare $X$ with Memory | CPX | A3 | 2 | 2 | B3 |  | 2 | 3 | C3 | 3 | 4 | F3 | 1 | 3 | E3 | 2 | 4 | D3 | 3 | 5 | X-M | - | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Bit Test Memory with A (Logical Compare) | BIT | A5 | 2 | 2 | B5 |  | 2 | 3 | C5 | 3 | 4 | F5 | 1 | 3 | E5 | 2 | 4 | D5 | 3 | 5 | A. M | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | - |
| Jump Unconditional | JMP | - | - | - | BC | C 2 | 2 | 2 | CC | 3 | 3 | FC | 1 | 2 | EC | 2 | 3 | DC | 3 | 4 |  | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Jump to Subroutine | JSR | - | - | - | BD | D 2 | 2 | 5 | CD | 3 | 6 | FD | 1 | 5 | ED | 2 | 5 | DD | 3 | 6 |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

Symbols: $\mathrm{Op}=$ Operation
\# = Number of bytes
~ = Number of cycles

Table 6 Read/Modify/Write Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Boolean/Arithmetic Operstion | $\begin{gathered} \text { Condition } \\ \text { Code } \end{gathered}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Implied(A) |  |  | Implied(X) |  |  | Direct |  |  | Indexed (No Offset) |  |  | $\begin{gathered} \text { Indexed } \\ \text { (8-Bit Offset) } \end{gathered}$ |  |  |  |  |  |  |  |  |
|  |  | OP | \# | - | OP | \# | - | OP | \# | - | OP | \# | - | OP | \# | $\sim$ |  | H | 1 | $N$ | 2 | C |
| Increment | INC | 4C | 1 | 2 | 5C | 1 | 2 | 3C | 2 | 5 | 7C | 1 | 5 | 6C | 2 | 6 | $A+1 \rightarrow A$ or $X+1 \rightarrow X$ or $M+1 \rightarrow M$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| Decrement | DEC | 4A | 1 | 2 | 5A | 1 | 2 | 3A | 2 | 5 | 7A | 1 | 5 | 6A | 2 | 6 | $A-1 \rightarrow A$ or $X-1 \rightarrow X$ or $M-1 \rightarrow M$ | - | - | $\wedge$ | $\wedge$ | $\bullet$ |
| Clear | CLR | 4F | 1 | 2 | 5F | 1 | 2 | 3F | 2 | 5 | 7F | 1 | 5 | 6F | 2 | 6 | $00 \rightarrow A$ or $00 \rightarrow X$ or $00 \rightarrow M$ | $\bullet$ | - | 0 | 1 | $\bullet$ |
| Complement | COM | 43 | 1 | 2 | 53 | 1 | 2 | 33 | 2 | 5 | 73 | 1 | 5 | 63 | 2 | 6 | $\bar{A} \rightarrow A$ or $\bar{X} \rightarrow X$ or $\bar{M} \rightarrow M$ | $\bullet$ | - | $\wedge$ | $\wedge$ | 1 |
| Negate <br> (2's Complement) | NEG | 40 | 1 | 2 | 50 | 1 | 2 | 30 | 2 | 5 | 70 | 1 | 5 | 60 | 2 | 6 | $\begin{aligned} & 00-A \rightarrow A \text { or } 00-X \rightarrow X \\ & \text { or } 00 \rightarrow M \rightarrow M \end{aligned}$ | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| Rotate Left Thru Carry | ROL | 49 | 1 | 2 | 59 | 1 | 2 | 39 | 2 | 5 | 79 | 1 | 5 | 69 | 2 | 6 |  | - | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Rotate Right Thru Carry | ROR | 46 | 1 | 2 | 56 | 1 | 2 | 36 | 2 | 5 | 76 | 1 | 5 | 66 | 2 | 6 |  | - | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Logical Shift Left | LSL | 48 | 1 | 2 | 58 | 1 | 2 | 38 | 2 | 5 | 78 | 1 | 5 | 68 | 2 | 6 |  | - | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Logical Shift Right | LSR | 44 | 1 | 2 | 54 | 1 | 2 | 34 | 2 | 5 | 74 | 1 | 5 | 64 | 2 | 6 |  | - | - | 0 | $\wedge$ | $\wedge$ |
| Arithmetic Shift Right | ASR | 47 | 1 | 2 | 57 | 1 | 2 | 37 | 2 | 5 | 77 | 1 | 5 | 67 | 2 | 6 | $\square \square \square_{0}^{b_{1}}$ | - | - | $\wedge$ | $\wedge$ | $\wedge$ |
| Arithmetic Shift Left | ASL | 48 | 1 | 2 | 58 | 1 | 2 | 38 | 2 | 5 | 78 | 1 | 5 | 68 | 2 | 6 | Equal to LSL | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| Test for Negative or Zero | TST | 4D | 1 | 2 | 50 | 1 | 2 | 3D | 2 | 4 | 70 | 1 | 4 | 60 | 2 | 5 | A-00 or X-00 or M-00 | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| Symbols: Op = Operatio <br> \# = Number <br> $\sim$ = Number | tes <br> cles |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Table 7 Branch Instructions

| Operations | Mnemonic | Addressing Modes |  |  | Branch Test | Condition Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Relative |  |  |  |  |  |  |  |  |
|  |  | OP | \# | $\sim$ |  | H | 1 | N | Z | C |
| Branch Always | BRA | 20 | 2 | 3 | None | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch Never | BRN | 21 | 2 | 3 | None | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Higher | BHI | 22 | 2 | 3 | $C+Z=0$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Lower or Same | BLS | 23 | 2 | 3 | $C+Z=1$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Carry Clear | BCC | 24 | 2 | 3 | $\mathrm{C}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
| (Branch IF Higher or Same) | (BHS) | 24 | 2 | 3 | $\mathrm{C}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Carry Set | BCS | 25 | 2 | 3 | $\mathrm{C}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| (Branch IF Lower) | (BLO) | 25 | 2 | 3 | $\mathrm{C}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Not Equal | BNE | 26 | 2 | 3 | $\mathrm{Z}=0$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Equal | BEQ | 27 | 2 | 3 | $\mathrm{Z}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Half Carry Clear | BHCC | 28 | 2 | 3 | $\mathrm{H}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Half Carry Set | BHCS | 29 | 2 | 3 | $\mathrm{H}=1$ | - | $\bullet$ | $\bullet$ | $\bullet$ | - |
| Branch IF Plus | BPL | 2A | 2 | 3 | $\mathrm{N}=0$ | $\bullet$ | - | $\bullet$ | - | - |
| Branch IF Minus | BMI | 2B | 2 | 3 | $\mathrm{N}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Interrupt Mask Bit is Clear | BMC | 2C | 2 | 3 | $1=0$ | - | - | $\bullet$ | $\bullet$ | - |
| Branch IF Interrupt Mask Bit is Set | BMS | 2D | 2 | 3 | $\mathrm{I}=1$ | - | $\bullet$ | - | - | $\bullet$ |
| Branch IF Interrupt Line is Low | BIL | 2E | 2 | 3 | $\mathrm{INT}=0$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch IF Interrupt Line is High | BIH | 2F | 2 | 3 | INT = 1 | $\bullet$ | $\bullet$ | - | - | - |
| Branch to Subroutine | BSR | AD | 2 | 5 | - | - | $\bullet$ | - | $\bullet$ | - |

Symbols: $\mathrm{Op}_{\mathrm{p}}=$ Operation
\# = Number of bytes
$\sim$ = Number of cycles

Table 8 Bit Manipulation Instructions

| Operations | Mnemonic | Addressing Modes |  |  |  |  |  | Boolean/ Arithmetic Operation | Branch Test | Condition Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Bit Set/Clear |  |  | Bit Test and Branch |  |  |  |  |  |  |  |  |  |
|  |  | OP | \# | $\sim$ | OP | \# | $\sim$ |  |  | H | 1 | N | 2 | C |
| Branch If Bit $\boldsymbol{n}$ is set | BRSET $\mathrm{n}(\mathrm{n}=0 \cdots 7)$ | - | - | - | $2 \cdot n$ | 3 | 5 | - | $M \mathrm{n}=1$ | $\bullet$ | $\bullet$ | - | - | $\wedge$ |
| Branch IF Bit $\boldsymbol{n}$ is clear | BRCLR $n(n=0 \cdots 7)$ | - | - | - | $01+2 \cdot n$ | 3 | 5 | - | $\mathrm{Mn}=0$ | $\bullet$ | - | - | - | $\wedge$ |
| Set Bit $n$ | BSET $n(n=0 \cdots 7)$ | $10+2 \cdot n$ | 2 | 5 | -- | - | - | $1 \rightarrow \mathrm{Mn}$ | - | - | - | - | - | - |
| Clear Bit $n$ | BCLR $n(n=0 \cdots 7)$ | $11+2 \cdot n$ | 2 | 5 | - | - | - | $\mathrm{O} \rightarrow \mathrm{Mn}$ | - | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |

[^9]\[

$$
\begin{aligned}
& \#=\text { Number of bytes } \\
& \sim=\text { Number of cycles }
\end{aligned}
$$
\]

Table 9 Control Instructions

| Operations | Mnemonic | Addressing Modes |  |  | Boolean Operation | Condition Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Implied |  |  |  |  |  |  |  |  |
|  |  | OP | \# | $\sim$ |  | H | 1 | N | 2 | C |
| Transfer A to X | TAX | 97 | 1 | 2 | $A \rightarrow X$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Transfer X to A | TXA | 9F | 1 | 2 | $\mathrm{X} \rightarrow \mathrm{A}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Set Carry Bit | SEC | 99 | 1 | 1 | $1 \rightarrow C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 1 |
| Clear Carry Bit | CLC | 98 | 1 | 1 | $0 \rightarrow \mathrm{C}$ | $\bullet$ | $\bullet$ | $\bullet$ | - | 0 |
| Set Interrupt Mask Bit | SEI | 9B | 1 | 2 | $1 \rightarrow 1$ | $\bullet$ | 1 | $\bullet$ | - | $\bullet$ |
| Clear Interrupt Mask Bit | CLI | 9A | 1 | 2 | $0 \rightarrow 1$ | - | 0 | $\bullet$ | - | $\bullet$ |
| Software Interrupt | SWI | 83 | 1 | 10 |  | $\bullet$ | 1 | $\bullet$ | - | $\bullet$ |
| Return from Subroutine | RTS | 81 | 1 | 5 |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Return from Interrupt | RTI | 80 | 1 | 8 |  | ? | ? | ? | ? | ? |
| Reset Stack Pointer | RSP | 9 C | 1 | 2 | \$FF $\rightarrow$ SP | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| No-Operation | NOP | 9D | 1 | 1 | Advance Prog. Cntr. Only | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Decimal Adjust A | DAA | 8D | 1 | 2 | Converts binary add of BCD charcters into | $\bullet$ | - | $\wedge$ | $\wedge$ | $\wedge^{*}$ |
| Stop | STOP | 8 E | 1 | 4 |  | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Wait | WAIT | 8F | 1 | 4 |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

Symbols: $O p=$ Operation

* Are BCD characters of upper byte 10 or more? (They are not cleared if set in advance.)
\# = Number of bytes
$\sim$ = Number of cycles
Table 10 Instruction Set (in Alphabetical Order)

|  | Addressing Modes |  |  |  |  |  |  |  |  |  | Condition Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Implied | Immediate | Direct | Extended | Relative | $\begin{gathered} \text { Indexed } \\ \text { (No Offset) } \end{gathered}$ | Indexed (8-Bit) | Indexed (16-Bit) | Bit <br> Set/ <br> Clear | Bit <br>  <br> Branch | H | 1 | N | Z | C |
| ADC |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\wedge$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| ADD |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\wedge$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| AND |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| ASL | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| ASR | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| BCC |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BCLR |  |  |  |  |  |  |  |  | $\times$ |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BCS |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BEQ |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| BHCC |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| BHCS |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BHI |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| (BHS) |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BIH |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
| BIL |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BIT |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| (BLO) |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BLS |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BMC |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BMI |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| BMS |  |  |  |  | $x$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BNE |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
| BPL |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| BRA |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Condition Code Symbols: (to be continued) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| H Half | Half Carry (From Bit 3) C |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 Interr | Interrupt Mask |  | Test and Set if True, Cleared Otherwise |  |  |  |  |  |  |  |  |  |  |  |  |
| $N$ Nega | Negative (Sign Bit) |  | Not Affected |  |  |  |  |  |  |  |  |  |  |  |  |
| Z Zero |  | ? | Load CC Register From Stack |  |  |  |  |  |  |  |  |  |  |  |  |

Table 10 Instruction Set (in Alphabetical Order)

|  | Addressing Modes |  |  |  |  |  |  |  |  |  | Condition Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Implied | Immediate | Direct | Extended | Relative | Indexed (No Offset) | Indexed (8-Bit) | Indexed (16-Bit) | Bit <br> Set/ <br> Clear | Bit <br>  <br> Branch | H | 1 | N | Z | C |
| BRN |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BRCLR |  |  |  |  |  |  |  |  |  | $\times$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\wedge$ |
| BRSET |  |  |  |  |  |  |  |  |  | $\times$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\wedge$ |
| BSET |  |  |  |  |  |  |  |  | $\times$ |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BSR |  |  |  |  | $\times$ |  |  |  |  |  | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
| CLC | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 0 |
| CLI | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | 0 | $\bullet$ | $\bullet$ | $\bullet$ |
| CLR | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | 0 | 1 | $\bullet$ |
| CMP |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| COM | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | 1 |
| CPX |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| DAA | $x$ |  |  |  |  |  |  |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| DEC | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| EOR |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| INC | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | - | $\wedge$ | $\wedge$ | $\bullet$ |
| JMP |  |  | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| JSR |  |  | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| LDA |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| LDX |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| LSL | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| LSR | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | - | 0 | $\wedge$ | $\wedge$ |
| NEG | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| NOP | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| ORA |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| ROL | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| ROR | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| RSP | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| RTI | $\times$ |  |  |  |  |  |  |  |  |  | ? | ? | ? | ? | ? |
| RTS | $\times$ |  |  |  |  |  |  |  |  |  | - | $\bullet$ | $\bullet$ | - | $\bullet$ |
| SBC |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| SEC | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 1 |
| SEI | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | 1 | $\bullet$ | $\bullet$ | - |
| STA | - |  | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | - | - | $\wedge$ | $\wedge$ | $\bullet$ |
| STOP | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
| STX |  |  | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| SUB |  | $\times$ | $\times$ | $\times$ |  | $\times$ | $\times$ | $\times$ |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\wedge$ |
| SWI | $\times$ |  |  |  |  |  |  |  |  |  | - | 1 | - | $\bullet$ | $\bullet$ |
| TAX | $\times$ |  |  |  |  |  |  |  |  |  | - | $\bullet$ | - | - | $\bullet$ |
| TST | $\times$ |  | $\times$ |  |  | $\times$ | $\times$ |  |  |  | $\bullet$ | $\bullet$ | $\wedge$ | $\wedge$ | $\bullet$ |
| TXA | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
| WAIT | $\times$ |  |  |  |  |  |  |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

Condition Code Symbols:

| H | Half Carry (From Bit 3) |
| :--- | :--- |
| I | Interrupt Mask |
| N | Negative (Sign Bit) |
| Z | Zero |

Haif Carry (From Bit 3)
Negative (Sign Bit)
C Carry/Borrow
$\wedge$ Test and Set if True, Cleared Otherwise

- Not Affected
? Load CC Register From Stack

Table 11 Operation Code Map

(NOTES) 1. "-" is an undefined operation code.
2. The lowermost numbers in each column represent a byte count and the number of cycles required (byte count/number of cycles). The number of cycies for the mnemonics asterisked (*) is as follows:

| RTI | 8 | TAX | 2 |
| :--- | ---: | :--- | :--- |
| RTS | 5 | RSP | 2 |
| SWI | 10 | TXA | 2 |
| DAA | 2 | BSR | 5 |
| STOP | 4 | CLI | 2 |
| WAIT | 4 | SEI | 2 |

3. The parenthesized numbers must be added to the cycle count of the particular instruction.

## - Additional Instructions

The following new instructions are used on the HD6305X2 and the HD6305Y2:
DAA Converts the contents of the accumulator into BCD code.
WAIT Causes the MPU to enter the wait mode. For this mode, see the topic, Wait Mode.
STOP Causes the MPU to enter the stop mode. For this mode, see the topic, Stop Mode.

- OPERATION AT EACH INSTRUCTION CYCLE

The HD6305X2 and the HD6305Y2 employs a mechanism of the pipeline control for the instruction fetch and the subsequent instruction fetch is performed during the current instruction being executed.

Table 12 provides the information about the relationship among each data on the Address Bus, Data Bus and $R / \bar{W}$ status in cycle-by-cycle basis during the execution of each instruction.

Table 12 Cycle-by-Cycle Operation

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IMMEDIATE |  |  |  |  |  |
| ADC, ADD, AND, BIT, CMP, CPX, EOR, LDA, LDX, ORA, SBC, SUB | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Operand Data Next Op Code |
| DIRECT |  |  |  |  |  |
| ADC, ADD, AND, BIT, CMP, CPX, EOR, LDA, LDX, ORA, SBC, SUB | 3 | 1 2 3 | Op Code Address +1 Address of Operand Op Code Address +2 | 1 1 1 | Address of Operand Operand Data Next Op Code |


| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| STA, STX | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Op Code Address +1 <br> Address of Operand <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 0 \\ & 1 \end{aligned}$ | ```Address of Operand (Data from Acc. Data from Ix. Next Op Code``` |
| JMP | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Op Code Address +1 Jump Address | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Jump Address Next Op Code |
| JSR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> 1FFF <br> Stack Pointer <br> Stack Pointer - 1 <br> Jump Address | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Jump Address (LSB) <br> Irrelevant Data <br> Return Address (LSB) <br> Return Address (MSB) <br> First Subroutine Op Code |
| ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> Address of Operand <br> 1FFF <br> Address of Operand <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Address of Operand <br> Operand Data <br> Irrelevant Data <br> New Operand Data <br> Next Op Code |
| TST | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 Address of Operand 1FFF <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Address of Operand Operand Data Irrelevant Data Next Op Code |
| EXTENDED |  |  |  |  |  |
| ADC, ADD, AND, BIT, CMP, CPX, EOR, LDA, LDX, ORA, SBC, SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 <br> Address of Operand <br> Op Code Address +3 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Address of Operand (MSB) <br> Address of Operand (LSB) <br> Operand Data <br> Next Op Code |
| STA, STX | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 <br> Address of Operand <br> Op Code Address +3 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Address of Operand (MSB) <br> Address of Operand (LSB) <br> (Data from Acc. <br> Data from Ix. <br> Next Op Code |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 <br> Jump Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Jump Address. (MSB) Jump Address (LSB) Next Op Code |
| JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 <br> 1FFF <br> Stack Pointer <br> Stack Pointer - 1 <br> Jump Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Jump Address (MSB) <br> Jump Address (LSB) <br> Irrelevant Data <br> Return Address (LSB) <br> Return Address (MSB) <br> First Subroutine Op Code |
| INDEXED (No offset) |  |  |  |  |  |
| ADC, ADD, AND, BIT, CMP, CPX, EOR, LDA, LDX, ORA, SBC, SUB | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | ```Op Code Address +1 1x Op Code Address +1``` | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Next Op Code Operand Data Next Op Code |
| STA, STX | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 1FFF <br> $1 \times$ <br> Op Code Address +1 | 1 1 0 1 | Next Op Code Irrelevant Data (Data from Acc. Data from lx. Next Op Code |
| JMP | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Op Code Address +1 Ix | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Next Op Code <br> First Op Code of Jump Routine |

(to be continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{J S R}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | ```Op Code Address +1 1FFF Stack Pointer Stack Pointer -1 lx``` | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Next Op Code Irrelevant Data Return Address (LSB) Return Address (MSB) First Subroutine Op Code |
| ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | ```Op Code Address +1 Ix 1FFF Ix Op Code Address +1``` | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Next Op Code Operand Data Irrelevant Data New Operand Data Next Op Code |
| TST | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | ```Op Code Address +1 Ix 1FFF Op Code Address +1``` | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Next Op Code Operand Data Irrelevant Data Next Op Code |
| INDEXED (8-bit offset) |  |  |  |  |  |
| ADC, ADD, AND, BIT, CMP, CPX, EOR, LDA, LDX, ORA, SBC, SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 <br> 1FFF <br> Ix + Offset <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Offset <br> Irrelevant Data <br> Operand Data <br> Next Op Code |
| STA, STX | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 1FFF Ix + Offset Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Offset Irrelevant Data ( Data from Acc. Next Op Code |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { Op Code Address +1 } \\ & \text { 1FFF } \\ & \text { 1x + Offset } \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Offset <br> Irrelevant Data <br> First Op Code of Jump Routine |
| JSR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> 1FFF <br> Stack Pointer <br> Stack Pointer - 1 <br> Ix + Offset | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Offset <br> Irrelevant Data <br> Return Address (LSB) <br> Return Address (MSB) <br> First Subroutine Op Code |
| ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Op Code Address +1 <br> 1FFF <br> $1 \mathrm{x}+$ Offset <br> 1FFF <br> IX + Offset <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Offset <br> Irrelevant Data <br> Operand Data <br> Irrelevant Data <br> New Operand Data <br> Next Op Code |
| TST | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | ```Op Code Address +1 1FFF Ix + Offset 1FFF Op Code Address +2``` | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Offset Irrelevant Data Operand Data Irrelevant Data Next Op Code |
| INDEXED (16-bit offset) |  |  |  |  |  |
| ADC, ADD, AND, BIT, CMP, CPX, EOR, LDA, LDX, ORA, SBC, SUB | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +2 <br> 1FFF <br> Ix + Offset <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Offset (MSB) <br> Offset (LSB) <br> Irrelevant Data <br> Operand Data <br> Next Op Code |

(to be continued)

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| STA, STX | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & \text { Op Code Address +1 } \\ & \text { Op Code Address +2 } \\ & \text { 1FFF } \\ & 1 \times+ \text { Offset } \\ & \text { Op Code Address +3 } \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Offset (MSB) Offset (LSB) Irrelevant Data ( $\begin{aligned} & \text { Data from Acc. } \\ & \text { Data from Ix. }\end{aligned}$ Next Op Code |
| JMP | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | ```Op Code Address +1 Op Code Address +2 1FFF Ix + Offset``` | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Offset (MSB) <br> Offset (LSB) <br> Irrelevant Data <br> First Op Code of Jump Routine |
| JSR | 6 | $1$ | Op Code Address +1 <br> Op Code Address +2 <br> 1FFF <br> Stack Pointer <br> Stack Pointer - 1 <br> Ix + Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Offset (MSB) <br> Offset (LSB) <br> Irrelevant Data <br> Return Address (LSB) <br> Return Address (MSB) <br> First Subroutine Op Code |
| IMPLIED |  |  |  |  |  |
| ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR, TST | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Next Op Code Next Op Code |
| CLC, NOP, SEC | 1 | 1 | Op Code Address +1 | 1 | Next Op Code |
| RSP, TAX, TXA | 2 | $\begin{aligned} & 1 \\ & 2 \\ & \hline \end{aligned}$ | Op Code Address +1 <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ | Next Op Code Next Op Code |
| CLI, SEI | 2 | $\begin{aligned} & 1 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { Op Code Address +1 } \\ \text { 1FFF } \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ | Next Op Code Irrelevant Data |
| DAA | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Op Code Address +1 <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ | Next Op Code Next Op Code |
| STOP, WAIT | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Op Code Address +1 <br> 1FFF <br> 1FFF <br> Op Code Address +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Next Op Code Irrelevant Data Irrelevant Data Next Op Code |
| RTI | 8 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \\ & \hline \end{aligned}$ | Op Code Address +1 1FFF <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer +2 <br> Stack Pointer +3 <br> Stack Pointer +4 <br> Return Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Next Op Code <br> Irrelevant Data <br> CC <br> Acc. <br> lx. <br> Return Address (MSB) <br> Return Address (LSB) <br> First Op Code of Return Routine |
| RTS | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 1FFF <br> Stack Pointer <br> Stack Pointer +1 <br> Return Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Next Op Code <br> Irrelevant Data <br> Return Address (MSB) <br> Return Address (LSB) <br> First Op Code of Return Routine |
| SWI | 10 | $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ \hline \end{array}$ | Op Code Address +1 1FFF <br> Stack Pointer <br> Stack Pointer-1 <br> Stack Pointer-2 ${ }^{\text {- }}$ <br> Stack Pointer-3 <br> Stack Pointer-4 <br> Vector Address 1FFC <br> Vector Address 1FFD <br> Address of SWI Routine | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Next Op Code <br> Irrelevant Data <br> Return Address (LSB) <br> Return Address (MSB) <br> Ix. <br> Acc. <br> CC <br> Address of SWI Routine (MSB) <br> Address of SWI Routine (LSB) <br> First Op Code of SWI Routine |

$\qquad$

| Address Mode \& Instructions | Cycles | Cycle \# | Address Bus | R/W | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELATIVE |  |  |  |  |  |
| $B C C, B C S, B E Q$, BHCC, BHCS, BHI, BIH, BIL, BLS, BMC, BMI, BMS, BNE, BPL, BRA, BRN | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | ```Op Code Address +1 1FFF ( Branch Address ...........Test = "1"``` | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Next Op Code Irrelevant Data \(\left(\begin{array}{l}\text { First Op Code of Branch Routine } \\ \text { Next Op Code }\end{array}\right.\)``` |
| BSR | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> 1FFF <br> Stack Pointer <br> Stack Pointer-1 <br> Branch Address | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Offset <br> Irrelevant Data <br> Return Address (LSB) <br> Return Address (MSB) <br> First Op Code of Subroutine |
| BIT TEST AND BRANCH |  |  |  |  |  |
| BRCLR, BRSET | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 <br> Address of Operand <br> Op Code Address +2 <br> 1FFF $\left(\begin{array}{l} \text { Branch Address ..............Test }=" 1 " \\ \text { Op Code Address }+3 . . . . . \text { Test }=" 0 " \end{array}\right.$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Address of Operand <br> Operand Data <br> Offset <br> Irrelevant Data $\left(\begin{array}{l} \text { First Op Code of Branch Address } \\ \text { Next Op Code } \end{array}\right.$ |
| BIT SET/CLEAR |  |  |  |  |  |
| BCLR, BSET | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Op Code Address +1 Address of Operand 1FFF <br> Address of Operand Op Code Address +1 | 1 1 1 0 1 | Address of Operand Operand Data Irrelevant Data New Operand Data Next Op Code |

## PRECAUTIONS

- Precaution; Board Design of Oscillation Circuit


Figure 39 Example of Circuit Causing Trouble in Oscillation

Wire the signal lines to the neighboring XTAL and EXTAL pins as far apart as possible. And locate crystal and capacity as close to XTAL and EXTAL as possible.

- Precaution; Program of Write Only Register

Read/Modify/Write instructions are applied to Write Only Register (e.g. DDR; Data Direction Register of I/O port) of the HD6305X2 and the HD6305Y2 and its contents cannot be changed.
(1) Data cannot be read from Write Only Register. (e.g. DDR of I/O port)

Read/Modify/Write instructions are executed in the following sequence.
(i) Reads the contents from appointed address.
(ii) Changes the data which has been read.
(iii) Turn the data back to the original address.

Evidently, Read/Modify/Write instructions cannot be applied to Write Only Register such as DDR.
(2) For the same reason, do not set DDR of I/O port using BSET and BCLR instructions of the HD6305X2 and the

HD6305Y2.
(3) In the correct writing method into Write Only Register, stored instruction as STA and STX, etc. are used.

- Precaution; Sending/Receiving Program of Serial Data

Reading from or Writing into the SCI data register (SDR: $\$ 0012$ ) during sending/receiving of serial data may make sending/receiving operation of SCI out of order.

## - Precaution; WAIT/STOP Instructions Program

When I bit of condition code register is " 1 " and interrupt ( $\overline{\mathrm{INT}}$, TIMER/ $/ \mathrm{INT}_{2}$, SCI/TIMER ${ }_{2}$ ) is held, MCU does not enter WAIT mode by the execution of WAIT instruction.

In that case, after the 4 dummy cycles MCU executes the next instruction.

In the same way, when external interrupts ( $\overline{\mathrm{INT}}, \overline{\mathrm{INT}_{2}}$ ) are held at the bit I set, MCU does not enter STOP mode by the execution of STOP instruction. In that case, also, MCU executes the next instruction after the 4 dummy cycles.

# HD63B09, HD63C09 CMOS MPU (Micro Processing Unit) 

## Description

The HD6309 is the highest 8 -bit microprocessor of HMCS6800 family, which is compatible with the conventional HD6809.

The HD6309 has hardware and software features which make it an ideal processor for higher level language execution or standard controller applications.

The HD6309 is complete CMOS device and its power dissipation is extremely low. Moreover, the SYNC and CWAI instruction makes low power application possible.

## Features

- Hardware
-Interfaces with all HMCS6800 peripherals
-DMA transfer with no auto-refresh cycle
- Software: object code compatible with the HD6809
- Low power consumption mode (Sleep mode)
-SYNC state of SYNC Instruction
-WAIT state of CWAI Instruction
- On chip oscillator
- Wide operation range: $\mathrm{f}=0.5$ to $3 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{CC}}=\right.$ $5 \mathrm{~V} \pm 10 \%$ )


## Type of Products

| Type No. | Bus Timing |
| :--- | :--- |
| HD63B09 | 2.0 MHz |
| HD63C09 | 3.0 MHz |

Pin Arrangement

(Top view)

- PLCC package available



## Block Diagram



Hitachi America Ltd. • 2210 O'Toole Avenue • San Jose, CA 95131 • (408) 435-8300

## Programming Model

As shown in figure 1, the HD6309 adds three registers to the set available in the HD6800. The added registers are a direct page register, the user stack pointer and a second index register.

## Accumulators (A, B, D)

The A and B registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data.

Certain instructions concatenate the A and B registers to form a single 16 -bit accumulator. This is referred to as the $D$ register. It is formed with the A register as the most significant byte.

## Direct Page Register (DP)

The direct page register of the HD6309 serves to enhance the direct addressing mode. The contents of this register appears at the higher address outputs $\left(\mathrm{A}_{8}-\mathrm{A}_{15}\right)$ during direct addressing instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure HD6800 compatibility, all bits of this register are cleared during processor reset.

## Index Registers (X, Y)

The index registers are used in indexed mode addressing. The 16 -bit address in this register takes
part in the calculation of effective addresses. This address may be used to point to data directly or may be modified by an optional constant or register offset. In some indexed modes, the contents of the index register are incremented or decremented to point to the next item of tabular data. All four pointer registers ( $\mathrm{X}, \mathrm{Y}, \mathrm{U}, \mathrm{S}$ ) may be used as index registers.

## Stack Pointer (U, S)

The hardware stack pointer (S) is used automatically by the processor during subroutine calls and interrupts. The stack pointers of the HD6309 point to the top of the stack, in contrast to the HD6800 stack pointer, which pointed to the next free location on the stack. The user stack pointer (U) is controlled exclusively by the programmer thus allowing arguments to be passed to and from subroutines with ease. Both stack pointers have the same indexed mode addressing capabilities as the X and $Y$ registers, but also support push and pull instructions. This allows the HD6309 to be used efficiently as a stack processor, greatly enhancing its ability to support higher level languages and modular programming.

Note: The stack pointers of the HD6309 point to the top of the stack, in contrast to the HD6800 stack pointer, which pointed to the next free location on stack.


Figure 1. Programming Model of The Microprocessing Unit

## Program Counter (PC)

The program counter is used by the processor to point to the address of the next instruction to be executed by the processor. Relative addressing is provided allowing the program counter to be used
like an index register in some situations.

## Condition Code Register (CC)

The condition code register defines the state of the processor at any given time. See figure 2.

## Condition Code Register Description

## Bit 0 (C)

Bit 0 is the carry flag. It is usually the carry from the binary ALU. C is also used to represent a 'borrow' from subtract-like instructions (CMP, NEG, SUB, SBC). Then, it is the complement of the carry from the binary ALU.

## Bit 1 (V)

Bit 1 is the overflow flag. It is set to a one by an operation which causes a signed two's complement arithmetic overflow. This overflow is detected in an operation in which the carry from the MSB in the ALU does not match the carry from the MSB minus 1 .

## Bit 2 (Z)

Bit 2 is the zero flag. It is set to one if the result of the previous operation was identically zero.

## Bit 3 (N)

Bit 3 is the negative flag. It contains exactly the value of the MSB of the result of the preceding operation. Thus, a negative two's-complement result will leave N set to one.

## Bit 4 (I)

Bit 4 is the $\overline{\mathrm{IRQ}}$ mask bit. The processor will not
recognize interrupts from the $\overline{\text { IRQ }}$ line if this bit is set to one. $\overline{\mathrm{NMI}}, \overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}, \overline{\mathrm{RES}}$, and SWI all set I to one; SWI2 and SWI3 do not affect I.

## Bit 5 (H)

Bit 5 is the half-carry bit. It is used to indicate a carry from bit 3 in the ALU as a result of an 8 -bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is undefined in all subtract-like instructions.

## Bit 6 (F)

Bit 6 is the FIRQ mask bit. The processor will not recognize interrupts from the $\overline{F I R Q}$ line if this bit is a one. $\overline{\mathrm{NMI}}, \overline{\mathrm{FIRQ}}, \mathrm{SWI}$, and $\overline{\mathrm{RES}}$ all set F to one. $\overline{\text { IRQ, SWI2 }}$ and SWI3 do not affect F.

## Bit 7 (E)

Bit 7 is the entire flag. Set to one, it indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current $E$ left in the condition code register represents past action.


Figure 2. Condition Code Register Format

## Signal Description

## Power (Vss, Vcc)

Two pins supply power to the part: Vss is ground or 0 volts, while $\mathrm{V}_{\mathrm{CC}}$ is $+5.0 \mathrm{~V} \pm 10 \%$.

Address Bus ( $\mathrm{A}_{\mathbf{0}}-\mathrm{A}_{15}$ )
Sixteen pins output address information from the MPU onto the address bus. When the processor does not require the bus for a data transfer, it will output address $\mathrm{FFFF}_{16}, \mathrm{R} / \overline{\mathrm{W}}=$ high, and $\mathrm{BS}=$ low. This is a "dummy access" or VMA cycle (see figures 25 and 26). All address bus drivers are made high impedance when the bus available output (BA) is high. Each pin will drive one Schottky TTL load or four LS TTL loads, and typically 90 pF .

## Data Bus ( $\mathrm{D}_{\mathbf{0}}-\mathrm{D}_{7}$ )

These eight pins provide communication with the system bi-directional data bus. Each pin will drive one Schottky TTL load or four LS TTL loads, and typically 130 pF .

## Read/Write (R/产)

This signal indicates the direction of data transfer on the data bus. A low indicates that the MPU is writing data onto the data bus. $\mathrm{R} / \overline{\mathrm{W}}$ is made high impedance when BA is high. Refer to figures 25 and 26.

## Reset ( $\overline{\text { RES }}$ )

A low level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in figure 3 . The reset vectors are fetched from locations $\mathrm{FFFE}_{16}$ and $\mathrm{FFFF}_{16}$ (table 2) when interrupt acknowledge is true, $(\overline{\mathrm{BA}} \cdot \mathrm{BS}=1)$. During initial power-on, the reset line should be held low until the clock oscillator is fully operational. See figure 4.

Because the HD6309 reset pin has a Schmitttrigger input with a threshold voltage higher than that of standard peripherals, a simple R/C network may be used to reset the entire system. This higher

Table 1. Pin Description

| Symbol | Pin No. | 1/0 | Function |
| :---: | :---: | :---: | :---: |
| Vss | 1 |  | Ground |
| $\overline{\mathrm{NMI}}$ | 2 | I | Non maskable interrupt |
| $\overline{\text { IRQ }}$ | 3 | 1 | Interrupt request |
| $\overline{\text { FIRO }}$ | 4 | 1 | Fast interrupt request |
| BS, BA | 5,6 | 0 | Bus status, Bus available |
| Vcc | 7 |  | +5 V power supply |
| $\mathrm{A}_{0}-\mathrm{A}_{15}$ | 8-23 | 0 | Address bus, bits 0-15 |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 24-31 | 1/0 | Data bus, bits 0-7 |
| $\mathrm{R} / \overline{\mathrm{W}}$ | 32 | 0 | Read / Write output |
| DMA/BREO | 33 | 1 | DMA Bus request |
| E, Q | 34, 35 | 0 | Clock signal |
| MRDY | 36 | 1 | Memory ready |
| $\overline{\text { RES }}$ | 37 | 1 | Reset input |
| EXTAL, XT.AL | 38, 39 | 1 | Oscillator connection |
| $\overline{\text { HALT }}$ | 40 | 1 | Halt input |

threshold voltage ensures that all peripherals are out of the reset state before the processor.

## Halt ( $\overline{\text { HALT }})$

A low level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven high indicating the buses are high impedance. BS is also high which indicates the processor is in the halt or bus grant state. While halted, the MPU will not respond to external realtime requests ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) although $\overline{\text { DMA/BREQ }}$ will always be accepted, and $\overline{\text { NMI }}$ or RES will be latched for later response. During the halt state, $Q$ and $E$ continue to run normally. If the MPU is not running ( $\overline{\mathrm{RES}}$ ), a halted state (BA $\cdot \mathrm{BS}$ $=1$ ) can be achieved by pulling HALT low while $\overline{\mathrm{RES}}$ is still low. See figure 5.

## Bus Available, Bus Status (BA, BS)

The BA output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. This signal does not imply that the bus will be available for more than one cycle. When BA goes low, an additional dead cycle will elapse before the MPU acquires the bus.

The BS output signal, when decoded with BA, represents the MPU state.

Interrupt Acknowledge is indicated during both cycles of a hardware vector fetch ( $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$, FIRQ, $\overline{\mathrm{IRQ}}, \mathrm{SWI}, \mathrm{SWI} 2, \mathrm{SWI} 3)$. This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 2.

Sync Acknowledge is indicated while the MPU is waiting for external synchronization on an interrupt line.

Halt/Bus Grant is true when the HD6309 is in a halt or bus grant condition.

## Non Maskable Interrupt ( $\overline{\mathrm{NMI}}$ )

A negative edge on NMI requests that a nonmaskable interrupt sequence be generated. A nonmaskable interrupt cannot be inhibited by the program, and also has a higher priority than FIRQ, IRQ or software interrupts. During recognition of an NMI, the entire machine state is saved on the hardware stack. After reset, an NMI will not be recognized until the first program load of the hardware stack pointer (S). The pulse width of $\overline{\mathrm{NMI}}$ low must be at least one E cycle. If the $\overline{\mathrm{NMI}}$ input does not meet the minimum set up with respect to $Q$, the interrupt will not be recognized until the next cycle See figure 6 .

Table 2. Memory Map for Interrupt Vectors
Memory Map for Vector Locations

| MS | LS |  |
| :--- | :--- | :--- |
| FFFE | FFFF | Interrupt Vector <br> Description |
| FFFC | FFFD | $\overline{\text { RES }}$ |
| FFFA | FFFB | $\underline{S W I}$ |
| FFF8 | FFF9 | $\underline{\overline{R Q Q}}$ |
| FFF6 | FFF7 | $\overline{\text { FIRQ }}$ |
| FFF4 | FFF5 | SWI2 |
| FFF2 | FFF3 | SWI3 |
| FFF0 | FFF1 | Reserved |

Table 3. MPU State Definition
BA BS MPU State

| 0 | 0 | Normal (Running) |
| :--- | :--- | :--- |
| 0 | 1 | Interrupt or RESET Acknowledge |
| 1 | 0 | SYNC Acknowledge |
| 1 | 1 | HALT or Bus Grant |



Figure 3. $\overline{\mathrm{RES}}$ Timing


Figure 4. Crystal Connections and Oscillator Start Up


Figure 5. $\overline{\text { HALT }}$ and Single Instruction Execution for System Debug


Figure 6. $\overline{\mathrm{IRQ}}$ and $\overline{\mathrm{NMI}}$ Interrupt Timing


Figure 7. $\overline{\text { FIRQ Interrupt Timing }}$

## Fast Interrupt Request ( $\overline{\text { FIRQ }}$ )

A low level on $\overline{\text { FIRQ }}$ input will initiate a fast interrupt sequence provided its mask bit ( F ) in the CC is clear. This sequence has priority over the standard interrupt request ( $\overline{\mathrm{IRQ}}$ ). It is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See figure 7.

## Interrupt Request ( $\overline{\mathbf{I R Q}})$

A low level input on $\overline{\mathrm{IRQ}}$ will initiate an interrupt request sequence provided the mask bit (I) in the CC is clear. Since $\overline{I R Q}$ stacks the entire machine state it provides a slower response to interrupts than $\overline{F I R Q}$. IRQ also has a lower priority than FIRQ. Again, the interrupt service routine should clear the source of the interrupt before doing an RTI. See figure 6 .

Note: $\overline{\text { NMI }}, \overline{\text { FIRQ }}$, and $\overline{\mathrm{IRQ}}$ requests are sampled on the falling edge of $Q$. One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. IfIRQ and $\overline{\text { FIRQ }}$ do not remain low until completion of the current
instruction they may not be recognized. However, NMI is latched and need only remain low for one cycle.

## XTAL, EXTAL

These two pins are connected with parallel resonant fundamental crystal, AT cut. Alternately, the pin EXTAL may be used as a TTL level input for external timing with XTAL floating. The crystal or external frequency is four times the bus frequency. See figure 4. Proper RF layout techniques should be observed in the layout of printed circuit boards.

Note for Board Design of the Oscillation Circuit: In designing the board, the following notes should be taken when the crystal oscillator is used. See figure 8.

1. Crystal oscillator and load capacity Cin, Cout must be placed near the LSI as much as possible. (Normal oscillation may be disturbed when external noise is induced to pin 38 and 39.)
2. Pin 38 and 39 signal line should be wired apart from other signal line as much as possible. Don't wire them in parallel with other lines. (Normal oscillation may be disturbed when E or Q signal feeds back to pin 38 and 39.)


Figure 8. Board Design of the Oscillation Circuit

Designs to be Avoided: A signal line or a power source line must not cross or go near the oscillation circuit line as shown in figure 9 to prevent induction from these lines. The resistance between XTAL, EXTAL and other pins should be over $10 \mathrm{M} \Omega$.

## $\mathbf{E}, \mathbf{Q}$

E is similar to the HD6800 bus timing signal $\phi_{2}$ : Q is a quadrature clock signal which leads E . Q has no parallel on the HD6800. Data is latched on the falling edge of $E$. Timing for $E$ and $Q$ is shown in figure 10.

## Memory Ready (MRDY)

This input control signal allows stretching of E and $Q$ to extend data-access time. $E$ and $Q$ operate normally while MRDY is high. When MRDY is low, E and Q may be stretched in integral multiples of half $(1 / 2)$ bus cycles, thus allowing interface to slow memories, as shown in figure 11. The maximum stretch is 5 microseconds.

During nonvalid memory access ( $\overline{\text { VMA }}$ cycles) MRDY has no effect on stretching E and Q: this inhibits slowing the processor during "don't care"
bus accesses. MRDY may also be used to stretch clocks (for slow memory) when bus control has been transferred to an external device (through the use of HALT and DMA/BREQ).

MRDY also stretches $E$ and $Q$ during dead cycles.

## DMA Bus Request ( $\overline{\mathrm{DMA} / \mathrm{BREQ}})$

The $\overline{\text { DMA/BREQ }}$ input provides a method of suspending execution and acquiring the MPU bus for another use, as shown in figure 12. Typical uses include DMA and dynamic memory refresh.

Transition of DMA/BREQ should occur during Q. A low level on this pin will stop instruction execution at the end of the current cycle. The MPU will acknowledge $\overline{\text { DMA/BREQ by setting BA and }}$ BS to high level. The HD6309 does not perform the auto-refresh executed in the HD6809. See figure 13.

Typically, the DMA controller will request to use the bus by asserting DMA/BREQ pin low on the leading edge of E . When the MPU replies by setting BA and BS to one, that cycle will be a dead cycle used to transfer bus mastership to the DMA controller.


Figure 9. Example of Normal Oscillation may be Disturbed

False memory accesses may be prevented during dead cycles by developing a system DMAVMA signal which is low in any cycle when BA has changed.

When BA goes low (a result of DMA/BREQ $=$
high), another dead cycle will elapse before the MPU accesses memory, to allow transfer of bus mastership without contention.

The DMA/BREQ input should be tied high during reset state.


Figure 10. E/Q Relationship


Figure 11. MRDY Clock Stretching

## MPU Operation

During normal operation, the MPU fetches an instruction from memory and then executes the requested function. This sequence begins at $\overline{\mathrm{RES}}$ and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Soft-
ware instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI and SYNC. An interrupt, $\overline{\mathrm{HALT}}$ or DMA/BREQ can also alter the normal execution of instructions. Figure 14 illustrates the flow chart for the HD6309.


Figure 12. Typical DMA Timing


Figure 13. DMA Timing


Figure 14. Flowchart for HD6309 Instruction

## Addressing Modes

The basic instructions of any computer are greatly enhanced by the presence of powerful ad－ dressing modes．The HD6309 has the most complete set of addressing modes available on any micro－ computer today．For example，the HD6309 has 59 basic instructions，however，it recognizes 1464 dif－ ferent variations of instructions and addressing modes．The addressing modes support modern pro－ gramming techniques．The following addressing modes are available on the HD6309：
－Implied（includes accumulator）
－Immediate
－Extended
－Extended indirect
－Direct
－Register
－Indexed
－Zero－offset
－Constant offset
－Accumulator offset
－Auto increment／decrement
－Indexed indirect
－Relative
－Program counter relative

## Implied（Includes Accumulator）

In this addressing mode，the opcode of the instruction contains all the address information necessary．Examples of implied addressing are： ABX，DAA，SWI，ASRA，and CLRB．

## Immediate Addressing

In immediate addressing，the effective address of the data is the location immediately following the opcode（i．e．，the data to be used in the instruction immediately follows the opcode of the instruction）． The HD6309 uses both 8 －and 16 －bit immediate values depending on the size of the argument speci－ fied by the opcode．Examples of instructions with immediate addressing are：

> LDA \#\$20
> LDX \#\$F000
> LDY \#CAT

Note：\＃signifies immediate addressing，\＄signifies hexadecimal value．

## Extended Addressing

In extended addressing，the contents of the two bytes immediately following the opcode fully spec－ ify the 16 －bit effective address used by the instruc－ tion．Note that the address generated by an
extended instruction defines an absolute address and is not position independent．Examples of extended addressing include：

| LDA | CAT |
| :--- | :--- |
| STX | MOUSE |
| LDD | $\$ 2000$ |

## Extended Indirect

As a special case of indexed addressing（discus－ sed below），one level of indirection may be added to extended addressing．In extended indirect，the two bytes following the postbyte of an indexed instruc－ tion contain the address of the data．

| LDA | 【CAT】 |
| :--- | :--- |
| LDX | 【\＄FFFE】 |
| STU | 【DOG】 |

## Direct Addressing

Direct addressing is similar to extended address－ ing except that only one byte of address follows the opcode．This byte specifies the lower 8 bits of the address to be used．The upper 8 bits of the address are supplied by the direct page register．Since only one byte of address is required in direct addressing， this mode requires less memory and executes faster than extended addressing．Of course，only 256 loca－ tions（one page）can be accessed without redefining the contents of the DP register．Since the DP regis－ ter is set to $\$ 00$ on reset，direct addressing on the HD6309 is compatible with direct addressing on the HD6800．Indirection is not allowed in direct ad－ dressing．Some examples of direct addressing are：

| LDA | $\$ 30$ |
| :--- | :--- |
| SETDP | $\$ 10$（Assembler directive） |
| LDB | $\$ 1030$ |
| LDD | $<$ CAT |

Note：＜is an assembler directive which forces direct addressing．

## Register Addressing

Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction．This is called a postbyte．Some exam－ ples of register addressing are：

| TFR | X，Y | Transfers X into Y |
| :--- | :--- | :--- |
| EXG | A，B | Exchanges A with B |
| PSHS | A，B，X，Y | Push Y，X，B，and A onto S |
| PULU | X，Y，D | Pull D，X，and Y from U |

## Indexed Addressing

In all indexed addressing, one of the pointer registers ( $\mathrm{X}, \mathrm{Y}, \mathrm{U}, \mathrm{S}$, and sometimes PC ) is used in a calculation of the effective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode as well as the pointer register to be used. Figure 15 lists the legal formats for the postbyte. Table 4 gives the assembler form and the number of cycles
and bytes added to the basic values for indexed addressing for each variation.

Zero-Offset Indexed: In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode.

Examples are:
LDD
$0, \mathrm{X}$
LDA
S

| Post-byte Register Bit |  |  |  |  |  |  |  | Indexed <br> Addressing Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0 | R | R | d | d | d | d | d | $E A=, R+5$ Bit Offset |
| 1 | R | R | 0 | 0 | 0 | 0 | 0 | , R+ |
| 1 | R | R | 0/1 | 0 | 0 | 0 | 1 | , R++ |
| 1 | R | R | 0 | 0 | 0 | 1 | 0 | , -R |
| 1 | R | R | 0/1 | 0 | 0 | 1 | 1 | , - - R |
| 1 | R | R | 0/1 | 0 | 1 | 0 | 0 | $E A=, R+0$ Offset |
| 1 | R | R | 0/1 | 0 | 1 | 0 | 1 | $E A=, R+B$ Offset |
| 1 | R | R | 0/1 | 0 | 1 | 1 | 0 | $E A=, R+A$ Offset |
| 1 | R | R | 0/1 | 1 | 0 | 0 | 0 | $E A=, R+8$ Bit Offset |
| 1 | R | R | 0/1 | 1 | 0 | 0 | 1 | $E A=, R+16$ Bit Offset |
| 1 | R | R | 0/1 | 1 | 0 | 1 | 1 | $E A=, R+D$ Offset |
| 1 | $\times$ | $\times$ | 0/1 | 1 | 1 | 0 | 0 | $E A=, P C+8$ Bit Offset |
| 1 | $\times$ | $\times$ | 0/1 | 1 | 1 | 0 | 1 | $E A=, P C+16$ Bit Offset |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | $\mathrm{EA}=$ 【, Address】 |
|  |  |  |  |  |  |  |  |  |

Figure 15. Indexed Addressing Postbyte Register Bit Assignments

Constant Offset Indexed：In this mode，a two＇s －complement offset and the contents of one of the pointer registers are added to form the effective address of the operand．The pointer register＇s initial content is unchanged by the addition．

Three sizes of offsets are available：

$$
\begin{aligned}
& 5 \text {-bit }(-16 \text { to }+15) \\
& 8 \text {-bit }(-128 \text { to }+127) \\
& 16 \text {-bit }(-32768 \text { to }+32767)
\end{aligned}
$$

The two＇s complement 5－bit offset is included in the postbyte and，therefore，is most efficient in use of bytes and cycles．The two＇s complement 8 －bit offset is contained in a single byte following the postbyte．The two＇s complement 16 －bit offset is in
the two bytes following the postbyte．In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically．

Examples of constant－offset indexing are：

| LDA | $23, \mathrm{X}$ |
| :--- | :--- |
| LDX | $-2, \mathrm{~S}$ |
| LDY | $300, \mathrm{X}$ |
| LDU | CAT，Y |

Accumulator Offset Indexed：This mode is similar to constant offset indexed except that the two＇s－complement value in one of the accumulators（ $\mathrm{A}, \mathrm{B}$ or D ）and the contents of one of the pointer registers are added to form

Table 4．Indexed Addressing Mode

| Type | Forms | Non Indirect |  | Indirect |  | Postbyte OP Code | $\begin{gathered} ++ \\ \sim \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Assembler Form | Postbyte OP Code |  | Assembler Form |  |  |
| Constant Offset From R （2＇s Complement Offsets） | No Offset | ，R | 1 RR00100 | 00 | 【，R】 | 1 RR10100 | 30 |
|  | 5 Bit Offset | $n, R$ | ORRnnnnn | 10 | defaults to 8－bit |  |  |
|  | 8 Bit Offset | $n, R$ | 1 RRO1000 | 11 | ［ $\mathrm{n}, \mathrm{R}$ 】 | 1 RR11000 | 41 |
|  | 16 Bit Offset | $n, R$ | 1 RR01001 | 42 | ［ $\mathrm{n}, \mathrm{R}$ 】 | 1RR11001 | 72 |
| Accumulator Offset From R （2＇s Complement Offsets） | A Register Offset | A，R | 1 RR00110 | 10 | 【A，R】 | 1RR10110 | 40 |
|  | B Register Offset | B，R | 1 RR00101 |  | ［B，R】 | 1RR10101 | 40 |
|  | D Register Offset | D，R | 1 RR01011 | 40 | ［D，R】 | 1RR11011 | 70 |
| Auto Increment／Decrement R | Increment By 1 | ，R＋ | 1 RR00000 | 20 | not allowed |  |  |
|  | Increment By 2 | ，R＋＋ | 1 RR00001 |  | \，R＋＋】 | 1 RR10001 | 60 |
|  | Decrement By 1 | ，－R | 1 RR00010 | 20 | not allowed |  |  |
|  | Decrement By 2 | ,--R | 1 RR00011 |  | ［，－－R】 | 1 RR10011 | 60 |
| Constant Offset From PC （2＇s Complement Offsets） | 8 Bit Offset | n，PCR | 1xx01100 | 11 | ［ $\mathrm{n}, \mathrm{PCR}$ 】 | $1 \times x 11100$ | 41 |
|  | 16 Bit Offset | n，PCR | $1 \times x 01101$ | 52 | ［ $\mathrm{n}, \mathrm{PCR}$ ］ | 1xx11101 | 82 |
| Extended Indirect | 16 Bit Address |  |  |  | ［ n ］ | 10011111 | 52 |


| $R=X, Y, U$ or $S$ | $R R:$ |
| :--- | :--- |
| $x=$ Don＇t Care | $00=X$ |
|  | $01=Y$ |
|  | $10=U$ |
|  | $11=S$ |

$\pm$ and $_{\#}^{+}$indicate the number of additional cycles and bytes for the particular variation．
the effective address of the operand．The con－ tents of both the accumulator and the pointer register are unchanged by the addition．The postbyte specifies which accumulator to use as an offset and no additional bytes are required． The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run－time．

Some examples are：

$$
\begin{array}{ll}
\text { LDA } & \text { B, Y } \\
\text { LDX } & \text { D, Y } \\
\text { LEAX } & \text { B, X }
\end{array}
$$

Auto Increment／Decrement Indexed：In the auto increment addressing mode，the pointer regis－ ter contains the address of the operand．Then，after the pointer register is used it is incremented by one or two．This addressing mode is useful in stepping through tables，moving data，or for the creation of software stacks．In auto decrement，the pointer register is decremented prior to use as the address of the data．The use of auto decrement is similar to that of auto increment；but the tables，etc，are scanned from high to low addresses．The size of the increment／decrement can be either one or two to allow for tables of either 8 －or 16 －bit data to be accessed，selectable by the programmer．The pre－ decrement，post－increment nature of these modes allow them to be used to create additional software stacks that behave identically to the U and S stacks．

Some examples of the auto increment／decrement addressing modes are：

| LDA | ， $\mathrm{X}+$ |
| :--- | :--- |
| STD | , $\mathrm{Y}++$ |
| LDB | ,-Y |
| LDX | ,--S |

Care should be taken in performing operations on 16 －bit pointer registers（X，Y，U，S）where the same register is used to calculate the effective address．

Consider the following instruction：

$$
\text { STX } 0, \mathrm{X}++(\mathrm{X} \text { initialized to } 0)
$$

The desired result is to store a 0 in locations $\$ 0000$ and $\$ 0001$ then increment X to point to $\$ 0002$ ． In reality，the following occurs：

| $0 \rightarrow$ temp | calculate the EA ；temp is a <br> holding register |
| :--- | :--- |
| $\mathrm{X}+2 \rightarrow \mathrm{X}$ | perform autoincrement <br> do store operation |
| $\mathrm{X} \rightarrow$（temp） |  |

## Indexed Indirect

All of the indexing modes with the exception of
auto increment／decrement by one，or a $\pm 4$－bit offset may have an additional level of indirection specified．In indirect addressing，the effective address is contained at the location specified by the contents of the index register plus any offset．In the example below，the A accumulator is loaded in－ directly using an effective address calculated from the index register and an offset．

Before Execution：

$$
\begin{aligned}
& \mathrm{A}=\times \times(\text { don't care }) \\
& \mathrm{X}=\$ \mathrm{~F} 000
\end{aligned}
$$

$\$ 0100 \quad$ LDA 【\＄10，X】 EA is now $\$ \mathrm{~F} 010$
$\$ \mathrm{~F} 010 \quad \$ \mathrm{~F} 1 \quad \$ \mathrm{~F} 150$ is now the
\＄F011 $\$ 50$ new EA
\＄F150 \＄AA
After Execution：

$$
\begin{aligned}
& \mathrm{A}=\$ \mathrm{AA}(\text { Actual Data Loaded }) \\
& \mathrm{X}=\$ \mathrm{~F} 000
\end{aligned}
$$

All modes of indexed indirect are included except those which are meaningless（e．g．，auto increment／ decrement by 1 indirect）．Some examples of indexed indirect are：

| LDA | $【, \mathrm{X}$ 】 |
| :--- | :--- |
| LDD | $【 10, \mathrm{~S} 】$ |
| LDA | $【 \mathrm{~B}, \mathrm{Y} 】$ |
| LDD | $【, \mathrm{X}++】$ |

## Relative Addressing

The byte（s）following the branch opcode is（are） treated as a signed offset which may be added to the program counter．If the branch condition is true then the calculated address（ $\mathrm{PC}+$ signed offset）is loaded into the program counter．Program execu－ tion continues at the new location as indicated by the PC．Short（ 1 byte offset）and long（ 2 bytes offset） relative addressing modes are available．All of memory can be reached in long relative addressing as an effective address is interpreted modulo $2^{16}$ ． Some examples of relative addressing are：

|  | BEQ | CAT | （short） |
| :--- | :--- | :--- | :--- |
|  | BGT | DOG | （short） |
| CAT | LBEQ | RAT | （long） |
| DOG | LBGT | RABBIT | （long） |
|  | $\cdot$ |  |  |
|  | $\vdots$ |  |  |
| RAT | NOP |  |  |
| RABBIT | NOP |  |  |

## Program Counter Relative

The PC can be used as the pointer register with 8 －or 16 －bit signed offsets．As in relative addressing， the offset is added to the current PC to create the effective address．The effective address is then used as the address of the operand or data．Program counter relative addressing is used for writing position independent programs．Tables related to a particular routine will maintain the same relation－ ship after the routine is moved，if referenced rela－
tive to the program counter．Examples are：
LDA
CAT，PCR
LEAX
TABLE，PCR

Since program counter relative is a type of in－ dexing，an additional level of indirection is avail－ able．

| LDA | 【CAT，PCR】 |
| :--- | :--- |
| LDU | 【DOG，PCR】 |

## HD6309 Instruction Set

The instruction set of the HD6309 is similar to that of the HD6800 and is upward compatible at the source code level．The number of opcodes has been reduced from 72 to 59 ，but because of the expanded architecture and additional addressing modes，the number of available opcodes（with different ad－ dressing modes）has risen from 197 to 1464.

Some of the instructions and addressing modes are described in detail below：

## PSHU／PSHS

The push instructions can push onto either the
hardware stack（S）or user stack（U）any single register，or set of registers with a single instruc－ tion．

## PULU／PULS

The pull instructions have the same capability of the push instruction，in reverse order．The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled．The actual PUSH／PULL sequence is fixed：each bit defines a unique register to push or pull，as shown in figure 16.


Figure 16．Push and Pull Order

## TFR/EXG

Within the HD6309, any register may be transferred to or exchanged with another of like-size: i. e., 8 -bit to 8 -bit or 16 -bit to 16 -bit. Bits $4-7$ of the postbyte define the source register, while bits $0-3$ represent the destination register (figure 17). They are denoted as follows:

| $0000-\mathrm{D}$ | $0101-\mathrm{PC}$ |
| :--- | :--- |
| $0001-\mathrm{X}$ | $1000-\mathrm{A}$ |
| $0010-\mathrm{Y}$ | $1001-\mathrm{B}$ |
| $0011-\mathrm{U}$ | $1010-\mathrm{CC}$ |
| $0100-\mathrm{S}$ | $1011-\mathrm{DP}$ |

Note: All other combinations are undefined and invalid.

## LEAX/LEAY/LEAU/LEAS

The LEA (load effective address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in table 5.

The LEA instruction also allows the user to access data in a position independent manner. For example:

```
LEAX MSG1, PCR
LBSR PDATA(Print message routine)
```

MSG1 FCC 'MESSAGE’ •

This sample program prints: ‘MESSAGE’. By
writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located, when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the X pointer register. This code is totally position independent.

The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the autoincrement and autodecrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows:
$\left.\begin{array}{ll}\text { LEAa }, \mathrm{b}+ & \begin{array}{l}\text { (any of the 16-bit pointer } \\ \text { registers } \mathrm{X}, \mathrm{Y}, \mathrm{U}, \text { or } \mathrm{S}\end{array} \\ \text { may be substituted for } \mathrm{a}\end{array}\right)$

Autoincrement-by-two and autodecrement-bytwo instructions work similarly. Note that LEAX, $\mathrm{X}+$ does not change X , however LEAX, -X does decrement X. LEAX 1, X should be used to increment X by one.

## MUL

Multiplies the unsigned binary numbers in the $A$


Figure 17. TFR/EXG Format

Table 5. LEA Examples

| Instruction | Operation | Comment |
| :---: | :---: | :---: |
| LEAX 10, X | $x+10 \rightarrow x$ | Adds 5-bit constant 10 to $X$ |
| LEAX 500, | $x+500 \rightarrow X$ | Adds 16-bit constant 500 to $X$ |
| LEAY A, Y | $Y+A \rightarrow Y$ | Adds 8-bit A accumulator to $Y$ |
| LEAY D, Y | $Y+D \rightarrow Y$ | Adds 16-bit D accumulator to $Y$ |
| LEAU-10, U | $\mathrm{U}-10 \rightarrow \mathrm{U}$ | Subtracts 10 from U |
| LEAS-10, S | S-10 $\rightarrow$ S | Used to reserve area on stack |
| LEAS 10, S | $S+10 \rightarrow S$ | Used to 'clean up' stack |
| LEAX 5, S | $S+5 \rightarrow X$ | Transfers as well as adds |

and B accumulator and places the unsigned result into the 16 -bit D accumulator. This unsigned multiply also allows multiple-precision multiplications.

## Long And Short Relative Branches

The HD6309 has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 -or 16 -bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64 k memory map. Position independent code can be easily generated through the use of relative branching. Both short (8-bit) and long ( 16 -bit) branches are available.

## SYNC

After encountering a sync instruction, the MPU enters a sync state, stops processing instructions, and waits for an interrupt. If the pending interrupt
is non-maskable ( $\overline{\mathrm{NMI}}$ ) or maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) with its mask bit ( F or I) clear, the processor will clear the sync state and perform the normal interrupt stacking and service routine. Since FIRQ and $\overline{\mathrm{IRQ}}$ are not edge-triggered, a low level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable (FIRQ, IRQ) with its mask bit ( F or I) set, the processor will clear the sync state and continue processing by executing the next inline instruction. Figure 18 depicts sync timing.

## Software Interrupt

A software interrupt instruction will cause an interrupt, and its associated vector fetch. These software interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on this HD6309, and are prioritized in the following order: SWI, SWI2, SWI3.


Figure 18. Sync Timing

## 16-Bit Operation

The HD6309 has the capability of processing 16bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes and pulls.

## Cycle-by-Cycle Operation

The address bus cycle-by-cycle performance chart illustrates the memory-access sequence corresponding to each possible instruction and address ing mode in the HD6309. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this technique considerably speeds throughput.) Next, the operation of each opcode will follow the flow chart.VMA is an indication of $\mathrm{FFFF}_{16}$ on the address bus, $\mathrm{R} / \mathrm{W}=$ high and $\mathrm{BS}=$ low. The following examples illustrate the use of the chart : see figure 19 .

Example 1: LBSR (Branch Taken)
Before Execution SP $=\mathrm{F} 000$

|  |  |  |  |
| :--- | :--- | :--- | :--- |
|  |  | • |  |
| $\$ 8000$ | - |  |  |
|  |  | LBSR | CAT |
|  |  | • |  |
| $\$ A 000$ | CAT | • |  |

Cycle-by-Cycle Flow
Cycle \# Address Data R/产 Description

| 1 | 8000 | 17 | 1 | Opcode Fetch |
| :--- | :--- | :--- | :--- | :--- |
| 2 | 8001 | 1 F | 1 | Offset High Byte |
| 3 | 8002 | FD | 1 | Offset Low Byte |
| 4 | FFFF | $*$ | 1 | VMA Cycle |
| 5 | FFFF | $*$ | 1 | VMA Cycle |
| 6 | FFFF | $*$ | 1 | VMA Cycle |
| 7 | FFFF | $*$ | 1 | VMA Cycle |
| 8 | EFFF | 03 | 0 | Stack Low Order <br> Byte of Return <br> Address <br> Stack High Order <br> Byte of Return <br> Address |

Example 2: DEC (Extended)

| $\$ 8000$ | DEC | $\$$ A000 |
| :--- | :--- | :--- |
| $\$$ A000 | FCB | $\$ 80$ |

Cycle-by-Cycle Flow
Cycle \# Address Data R/嘼 Description

| 1 | 8000 | 7A | 1 | Opcode Fetch <br> 2 |
| :--- | :--- | :---: | :--- | :--- |
| 8001 | A0 | 1 | Operand Address, <br> High Byte |  |
| 3 | 8002 | 00 | 1 | Operand Address, <br> Low Byte |
| 4 | FFFF | $*$ | 1 | VMA Cycle <br> 5 |
| A000 | 80 | 1 | Read the Data |  |
| 6 | FFFF | $*$ | 1 | $\overline{\text { VMA Cycle }}$VMA <br> 7 |
| A000 | 7 F | 0 | Store the Decremented <br> Data |  |

* The data bus has the data at that particular address.


Notes: 1. Each state shows
Data Bus Offset High
Address Bus NNNN+1(2)
2. Address NNNN is location of opcode.
3. If opcode is two byte opcode subsequent addresses are in parenthesis ().
4. Two-byte opcodes are highlighted.

Figure 19. Cycle-by-Cycle Performance


Figure 19. Cycle-by-Cycle Performance (Cont.)


Figure 19. Cycle-by-Cycle Performance (Cont.)


Figure 19. Cycle-by-Cycle Performance (Cont.)


| Constant Offset |
| :--- |
| No Offset |
| 5-Bit Offset |
| 8-Bit Offset |
| 16-Bit Offset |
| Accumulator Offsei |
| A Register Offset |
| B Register Offset |
| D Register Offset |
| Auto Increment/Decrement |
| Increment by 1 |
| Increment by 2 |
| Decrement by 1 |
| Decrement by 2 |
| Program Counter Relative |
| 8-Bit Offset |
| $16-$ Bit Offset |
| Indirect |
| Direct |
| Extended |

Effective Address (EA)
Pointer Register
Pointer Register + Post Byte
Pointer Register + Offset Byte
Pointer Register + Offset High Byte: Offset Low Byte
Pointer Register + A Register
Pointer Register + B Registe
Pointer Register + D Register
Pointer Register *
Pointer Register *
Pointer Register - 1
Program Counter + Offset Byt
Program Counter + Offset High Byte: Offset Low Byte Indirect High Byte: Indirect Low Byte
Direct Page Register: Address Low Byte
Address High Byte: Address Low Byte
NNNN +1 (2)

* Pointer Register is incremented following the indexed access.

Figure 19. Cycle-by-Cycle Performance (Cont.)

## Sleep Mode

During the interrupt wait period in the SYNC instruction (the sync state) and in the CWAI instruction (the wait state), MPU operation is halted and goes to the sleep mode. However, the state of I/O pins is the same as that of the HD6809 in this mode.

## HD6309 Instruction set Tables

The instructions of the HD6309 have been broken down into five different categories. They are as follows:

- 8-Bit operation (table 6)
- 16-Bit operation (table 7)
- Index register/stack pointer instructions (table 8)
- Relative branches (long or short) (table 9)
- Miscellaneous instructions (table 10)

HD6309 instruction set tables and Hexadecimal Values of instructions are shown in table 11 and table 12.

Table 6. 8-Bit Accumulator and Memory Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADCA, ADCB | Add memory to accumulator with carry |
| ADDA, ADDB | Add memory to accumulator |
| ANDA, ANDB | AND memory with accumulator |
| ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left |
| ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right |
| BITA, BITB | Bit test memory with accumulator |
| CLR, CLRA, CLRB | Clear accumulator or memory location |
| CMPA, CMPB | Compare memory from accumulator |
| COM, COMA, COMB | Complement accumulator or memory location |
| DAA | Decimal adjust A accumulator |
| DEC, DECA, DECB | Decrement accumulator or memory location |
| EORA, EORB | Exclusive OR memory with accumulator |
| EXG R1, R2 | Exchange R1 with R2 (R1, R2 =A, B, CC, DP) |
| INC, INCA, INCB | Increment accumulator or memory location |
| LDA, LDB | Load accumulator from memory |
| LSL, LSLA, LSLB | Logical shift left accumulator or memory location |
| LSR, LSRA, LSRB | Logical shift right accumulator or memory location |
| MUL | Unsigned multiply (A $\times$ B $\rightarrow$ D) |
| NEG, NEGA, NEGB | Negate accumulator or memory |
| ORA, ORB | OR memory with accumulator |
| ROL, ROLA, ROLB | Rotate accumulator or memory left |
| ROR, RORA, RORB | Rotate accumulator or memory right |
| SBCA, SBCB | Subtract memory from accumulator with borrow |
| STA, STB | Store accumulator to memory |
| SUBA, SUBB | Subtract memory from accumulator |
| TST, TSTA, TSTB | Test accumulator or memory location |
| TFR R1, R2 | Transfer R1 or R2 (R1, R2 =A, B, CC, DP) |

Note: A, B, CC or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 7. 16-Bit Accumulator and Memory Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADDD | Add memory to $D$ accumulator |
| CMPD | Compare memory from $D$ accumulator |
| EXG D, R | Exchange D with $X, Y, S, U$ or PC |
| LDD | Load D accumulator from memory |
| SEX | Sign Extend $B$ accumulator into $A$ accumulator |
| STD | Store $D$ accumulator to memory |
| SUBD | Subtract memory from $D$ accumulator |
| TFR D, R | Transfer $D$ to $X, Y, S, U$ or PC |
| TFR R, D | Transfer $X, Y, S, U$ or PC to $D$ |

Note: D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 8. Index Register/Stack Pointer Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| CMPS, CMPU | Compare memory from stack pointer |
| CMPX, CMPY | Compare memory from index register |
| EXG R1, R2 | Exchange D, X, Y, S, U or PC with D, X, Y, S, U or PC |
| LEAS, LEAU | Load effective address into stack pointer |
| LEAX, LEAY | Load effective address into index register |
| LDS, LDU | Load stack pointer from memory |
| LDX, LDY | Load index register from memory |
| PSHS | Push A, B, CC, DP, D, X, Y, U or PC onto hardware stack |
| PSHU | Push A, B, CC, DP, D, X, Y, S or PC onto user stack |
| PULS | Pull A, B, CC, DP, D, X, Y, U or PC from hardware stack |
| PULU | Pull A, B, CC, DP, D, X, Y, S or PC from user stack |
| STS, STU | Store stack pointer to memory |
| STX, STY | Store index register to memory |
| TFR R1, R2 | Transfer D, X, Y, S, U or PC to D, X, Y, S, U or PC |
| ABX | Add B accumulator to $X$ (unsigned) |

Table 9. Branch Instructions

|  | Operation |
| :--- | :--- |
| BEQ, LBEQ | Simple Branches |
| BNE, LBNE | Branch if equal |
| BMI, LBMI | Branch if not equal |
| BPL, LBPL | Branch if minus |
| BCS, LBCS | Branch if plus |
| BCC, LBCC | Branch if carry set |
| BVS, LBVS | Branch if carry clear |
| BVC, LBVC | Branch if overflow set |
| BGT, LBGT | Branch if overflow clear |
| BGE, LBGE | Signed Branches |
| BEQ, LBEQ | Branch if greater (signed) |
| BLE, LBLE | Branch if greater than or equal (signed) |
| BLT, LBLT | Branch if equal |
|  | Branch if less than or equal (signed) |
| BHI, LBHI | Branch if less than (signed) |
| BHS, LBHS | Unsigned Branches |
| BEQ, LBEQ | Branch if higher (unsigned) |
| BLS, LBLS | Branch if higher or same (unsigned) |
| BLO, LBLO | Branch if equal |
| BSR, LBSR | Branch if lower or same (unsigned) |
| BRA, LBRA | Branch if lower (unsigned) |
| BRN, LBRN | Other Branches |
|  | Branch to subroutine |
|  | Branch always |
|  | Branch never |

Table 10. Miscellaneous Instructions

| Mnemonic(s) | Operation |
| :--- | :--- |
| ANDCC | AND condition code register |
| CWAI | AND condition code register, then wait for interrupt |
| NOP | No operation |
| ORCC | OR condition code register |
| JMP | Jump |
| JSR | Jump to subroutine |
| RTI | Return from interrupt |
| RTS | Return from subroutine |
| SWI, SWI2, SWI3 | Software interrupt (absolute indirect) |
| SYNC | Synchronize with interrupt line |

Table 11. HD6309 Instruction Set

| Instruction/ <br> Forms |  | HD6309 Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Description |  | $\begin{array}{ll} 3 & 2 \\ \hline N & Z \end{array}$ | $\frac{1}{v}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Implied |  |  | Direct |  |  | Extended |  |  | Immediate |  |  | Indexed ${ }^{(1)}$ |  |  | Relative |  |  | 5 |  |  |  |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP ~ 5 | \# |  | H |  |  |  |
| $A B X$ |  | 3A | 3 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $B+X \rightarrow X$ <br> (Unsigned) | - | - - | - | - |
| ADC | $\begin{aligned} & \text { ADCA } \\ & \text { ADCB } \end{aligned}$ |  |  |  | $\begin{array}{\|l} 99 \\ \mathrm{D} 9 \end{array}$ | 4 | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { B9 } \\ & \text { F9 } \end{aligned}$ | 5 | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | $\begin{array}{\|l} 89 \\ \mathrm{C} 9 \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ |  |  |  |  |  | $\begin{aligned} & A+M+C \rightarrow A \\ & B+M+C \rightarrow B \end{aligned}$ | 1 | $\begin{array}{ll} 1 & 1 \\ 1 & 1 \end{array}$ | 1 | 1 |
| ADD | ADDA ADDB ADDD |  |  |  | 9B | 4 4 6 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { BB } \\ & \text { FB } \\ & \text { F3 } \end{aligned}$ | 5 5 7 | 3 3 3 | 8B CB C3 | 2 2 4 | 2 2 3 |  | $4+$ <br> $4+$ <br> $6+$ | $2+$ $2+$ $2+$ + |  |  | $A+M \rightarrow A$ $B+M \rightarrow B$ $D+M: M+1 \rightarrow D$ | $!$ | $\begin{array}{ll}1 & 1 \\ 1 & 1 \\ 1 & 1\end{array}$ | 1 | 1 1 1 |
| AND | ANDA ANDB ANDCC |  |  |  | $\begin{array}{\|l\|} 94 \\ \text { D4 } \end{array}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $2$ | B4 | 5 5 | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | 84 C4 14 | $\begin{aligned} & 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |  |  |  |  | $A \wedge M \rightarrow A$ $B \wedge M \rightarrow B$ $\mathrm{CC} \wedge \mathrm{IMM} \rightarrow \mathrm{CC}$ |  | $\begin{array}{cc} 1 & 1 \\ 1 & 1 \\ \hline \end{array}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\bigcirc$ |
| ASL | $\begin{aligned} & \text { ASLA } \\ & \text { ASL.B } \\ & \text { ASL } \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 08 | 6 | 2 | 78 | 7 | 3 |  |  |  | 68 | $6+$ |  |  |  | $\left.\begin{array}{l}A \\ B \\ M\end{array}\right\} \underset{c}{\square-\prod_{b 7}-0}$ | (8) (8) (8) | $\begin{array}{ll}1 & 1 \\ 1 & 1 \\ 1 & 1\end{array}$ | ! $!$ | 1 1 1 |
| ASR | ASRA ASRB ASR |  |  | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | 6 | 2 | 77 | 7 | 3 |  |  |  | 67 | $6+$ | $2+$ |  |  |  | 8 8 8 8 | $\begin{array}{ll}1 & 1 \\ 1 & 1 \\ 1 & 1\end{array}$ | - |  |
| BCC | $\begin{aligned} & \text { BCC } \\ & \text { LBCC } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{cc} 24 & 3 \\ 10 & 5(6) \\ 24 & \end{array}$ |  | Branch C=0 Long Branch $C=0$ | $\bullet$ | $0$ | - | - |
| BCS | $\begin{aligned} & \text { BCS } \\ & \text { LBCS } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 25 & 3 \\ 10 & 5(6) \\ 25 & \end{array}$ |  | Branch $\mathrm{C}=1$ <br> Long Branch $C=1$ | $\bullet$ | - | - | - |
| BEQ | BEQ LBEQ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 27 & 3 \\ 10 & 5(6) \\ 27 & \end{array}$ |  | Branch Z=1 Long Branch $Z=1$ | $\cdot$ | $0$ | - |  |
| BGE | BGE <br> LBGE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 2 C & 3 \\ 10 & 5(6) \\ 2 C & \end{array}$ |  | Branch $N \oplus V=0$ Long Branch $N \oplus V=0$ | $\cdot$ | - ${ }^{-1}$ | - |  |
| BGT | $\begin{aligned} & \text { BGT } \\ & \text { LBGT } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 2 \mathrm{E} & 3 \\ 10 & 5(6) \\ 2 \mathrm{E} & \end{array}$ |  | Branch $\mathrm{Z} V(\mathrm{~N} \oplus \mathrm{~V})=0$ <br> Long Branch <br> $\mathrm{Z} \backslash(\mathrm{N} \oplus \mathrm{V})=0$ | $\cdot$ | - ${ }^{-1}$ | - |  |
| BHI | $\begin{aligned} & \mathrm{BHI} \\ & \mathrm{LBHI} \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{cc} 22 & 3 \\ 10 & 5(6) \\ 22 & \end{array}$ |  | Branch $C \vee Z=0$ Long Branch $C \vee Z=0$ | $\cdot$ | - ${ }^{-1}$ | - | $\bigcirc$ |
| BHS | BHS LBHS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{cc} 24 & 3 \\ 10 & 5(6) \\ 24 & \end{array}$ | 2 4 | Branch $C=0$ <br> Long Branch $\mathrm{C}=0$ | - | - - | - | $\bullet$ |
| BIT | $\begin{aligned} & \text { BITA } \\ & \text { BITB } \end{aligned}$ |  |  |  | $\begin{aligned} & 95 \\ & \text { D5 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { B5 } \\ & \text { F5 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & 85 \\ & \mathrm{C} 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | A5 | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ |  |  | Bit Test $A(M \wedge A)$ <br> Bit Test $B(M \wedge B)$ | $\bullet$ | $\begin{array}{ll} 1 & 1 \\ 1 & 1 \end{array}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |
| BLE | BLE <br> LBLE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 2 F & 3 \\ 10 & 5(6) \\ 2 F & \end{array}$ |  | Branch $\mathrm{ZV}(\mathrm{N} \oplus \mathrm{V})=1$ <br> Long Branch <br> $\mathrm{Z} V(\mathrm{~N} \oplus \mathrm{~V})=1$ | $\bullet$ | - ${ }^{-1}$ | - |  |
| BLO | $\begin{aligned} & \text { BLO } \\ & \text { LBLO } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 25 & 3 \\ 10 & 5(6) \\ 25 & \end{array}$ | 2 | Branch $\mathrm{C}=1$ <br> Long Branch $\mathrm{C}=1$ | $\bullet$ | - ${ }^{-1}$ |  | $\bullet$ |
| BLS | BLS LBLS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{cc} 23 & 3 \\ 10 & 5(6) \\ 23 & \end{array}$ | 2 4 | Branch <br> $C \vee Z=1$ <br> Long Branch $C \vee Z=1$ | - | - | - | $\cdots$ |
| BLT | $\begin{aligned} & \text { BLT } \\ & \text { LBLT } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 2 D & 3 \\ 10 & 5(6) \\ 2 D & \end{array}$ | 2 | Branch $N \oplus V=1$ Long Branch $N \oplus V=1$ | - | $0$ | $0$ | - |
| BMI | BMI LBMI |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{lc} 2 B & 3 \\ 10 & 5(6) \\ 2 B & \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\mathrm{N}=1$ <br> Long Branch $N=1$ | - | - | - | $\bigcirc$ |

Table 11. HD6309 Instruction Set (Cont.)


Table 11. HD6309 Instruction Set (Cont.)


Table 11. HD6309 Instruction Set (Cont.)

| Instruction/ <br> Forms |  | HD6309 Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Description |  | 53 | 2 | 10 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Implied |  |  | Direct |  |  | Extended |  |  | Immediate |  |  | Indexed ${ }^{(1)}$ |  |  | Relative |  |  |  |  |  |  |  |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP ~ (5) | \# |  | H | N | 2 | V | c |
| SUB | SUBA SUBB SUBD |  |  |  | $\begin{array}{\|l\|} \hline 90 \\ \mathrm{DO} \\ 93 \end{array}$ | 4 4 6 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { BO } \\ & \text { F0 } \\ & \text { B3 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{array}{\|l\|} \hline 80 \\ C 0 \\ 83 \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 3 \end{aligned}$ | AO |  |  |  |  | $\begin{aligned} & A-M \rightarrow A \\ & B-M \rightarrow B \\ & D-M: M+1 \rightarrow D \end{aligned}$ | (8) | 1 1 1 | $!$ | ! | 1 1 1 |
| SWI | SWI ${ }^{(6)}$ <br> SWI2 ${ }^{6}$ <br> SWI3 ${ }^{6}$ | $3 F$ 10 $3 F$ 11 $3 F$ | 19 20 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Software Interrupt Software Interrupt <br> Software Interrupt | $\stackrel{+}{-}$ | - | - | - | $\bigcirc$ |
| SYNC |  |  | $\geqq 4$ | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Synchronize to Interrupt | - | - |  |  | - |
| TFR | R1, R2 |  | 6 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{R} 1 \rightarrow \mathrm{R} \mathbf{2}^{(2)}$ |  |  |  |  |  |
| TST | TSTA TSTB TST |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | 6 | 2 | 7D | 7 | 3 |  |  |  | 6D | $6+$ | $2+$ |  |  | Test A Test B Test M | $\bullet$ | 1 1 1 | 1 | 0 0 0 | - |

Legend: OP Operation Code (Hexadecimal)
~ Number of MPU Cycles
\# Number of Program Bytes
$+\quad$ Arithmetic Plus

- Arithmetic Minus
$\begin{array}{ll}\times & \text { Multiply } \\ M & \text { Complement of } M\end{array}$
$\rightarrow \quad$ Transfer Into
H Half-carry (from bit 3)
$\mathrm{N} \quad$ Negative (sign bit)

Z Zero (byte)
$\checkmark$ Overflow, 2's complement
C Carry from bit 7
! Test and set if true, cleared otherwise

- Not Affected

CC Condition Code Register
: Concatenation
$\checkmark \quad$ Logical or
$\wedge \quad$ Logical and
$\oplus \quad$ Logical Exclusive or

Notes: (1) This column gives a base cycle and byte count. To obtain total count, and the values obtained from the Indexed Addressing Modes table.
(2) R1 and R2 may be any pair of 8-bit or any pair of 16-bit registers.

The 8-bit registers are: A, B, CC, DP
The 16 -bit registers are: $\mathrm{X}, \mathrm{Y}, \mathrm{U}, \mathrm{S}, \mathrm{D}, \mathrm{PC}$
(3) EA is the effective address.
(4) The PSH and PUL instructions require 5 cycle plus 1 cycle for each byte pushed or pulled.
(5) $5(6)$ means: 5 cycles if branch not taken, 6 cycles if taken.
(6) SWI sets $I$ and $F$ bits. SWI2 and SWI3 do not affect $I$ and F.
(7) Conditions Codes set as a direct result of the instruction.
(8) Value of half-carry flag is undefined.
(9) Special Case-Carry set if b7 is SET.
(10) Condition Codes set as a direct result of the instruction if CC is specified, and not affected otherwise.

Table 12. Hexadecimal Values of Machine Codes

| OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | 4+ | $2+$ | 60 | NEG | Indexed | $6+$ | $2+$ |
| 01 | * | 4 |  |  | 31 | LEAY | 4 | 4+ | $2+$ | 61 | * | 4 |  |  |
| 02 | * |  |  |  | 32 | LEAS | $\checkmark$ | 4+ | $2+$ | 62 | * |  |  |  |
| 03 | COM |  | 6 | 2 | 33 | LEAU | Indexed | 4+ | $2+$ | 63 | COM |  | $6+$ | $2+$ |
| 04 | LSR |  | 6 | 2 | 34 | PSHS | Implied | $5+$ | 2 | 64 | LSR |  | $6+$ | $2+$ |
| 05 | * |  |  |  | 35 | PULS | 4 | $5+$ | 2 | 65 | * |  |  |  |
| 06 | ROR |  | 6 | 2 | 36 | PSHU |  | $5+$ | 2 | 66 | ROR |  | $6+$ | $2+$ |
| 07 | ASR |  | 6 | 2 | 37 | PULU |  | 5+ | 2 | 67 | ASR |  | $6+$ | $2+$ |
| 08 | ASL, LSL |  | 6 | 2 | 38 | * |  |  |  | 68 | ASL, LSL |  | $6+$ | $2+$ |
| 09 | ROL |  | 6 | 2 | 39 | RTS |  | 5 | 1 | 69 | ROL |  | 6+ | 2+ |
| OA | DEC |  | 6 | 2 | 3A | $A B X$ | $\dagger$ | 3 | 1 | 6 A | DEC |  | $6+$ | $2+$ |
| OB | * |  |  |  | 3B | RTI | Implied | 6, 15 | 1 | 6B | * |  |  |  |
| OC | INC |  | 6 | 2 | 3C | CWAI | Immed | $\geq 20$ | 2 | 6C | INC |  | $6+$ | $2+$ |
| OD | TST |  | 6 | 2 | 3D | MUL | Implied | 11 | 1 | 6D | TST |  | $6+$ | $2+$ |
| OE | JMP | $\dagger$ | 3 | 2 | 3 E | * |  |  |  | 6E | JMP | $\checkmark$ | 3+ | $2+$ |
| OF | CLR | Direct | 6 | 2 | 3F | SWI | Implied | 19 | 1 | 6 F | CLR | Indexed | $6+$ | $2+$ |
| 10 | See | - | - | - | 40 | NEGA | Implied | 2 | 1 | 70 | NEG | Extended | 7 | 3 |
| 11 | Next Page | - | - | - | 41 | * | 4 |  |  | 71 | * | 4 |  |  |
| 12 | NOP | Implied | 2 | 1 | 42 | * |  |  |  | 72 | * |  |  |  |
| 13 | SYNC | Implied | $\geqq 4$ | 1 | 43 | COMA |  | 2 | 1 | 73 | COM |  | 7 | 3 |
| 14 | * |  |  |  | 44 | LSRA |  | 2 | 1 | 74 | LSR |  | 7 | 3 |
| 15 | * |  |  |  | 45 | * |  |  |  | 75 | * |  |  |  |
| 16 | LBRA | Relative | 5 | 3 | 46 | RORA |  | 2 | 1 | 76 | ROR |  | 7 | 3 |
| 17 | LBSR | Relative | 9 | 3 | 47 | ASRA |  | 2 | 1 | 77 | ASR |  | 7 | 3 |
| 18 | * |  |  |  | 48 | ASLA, LSLA |  | 2 | 1 | 78 | ASL, LSL |  | 7 | 3 |
| 19 | DAA | Implied | 2 | 1 | 49 | ROLA |  | 2 | 1 | 79 | ROL |  | 7 | 3 |
| 1 A | ORCC | Immed | 3 | 2 | 4A | DECA |  | 2 | 1 | 7 A | DEC |  | 7 | 3 |
| 1 B | * |  |  |  | 4B | * |  |  |  | 7 B | * |  |  |  |
| 1C | ANDCC | Immed | 3 | 2 | 4C | INCA |  | 2 | 1 | 7 C | INC |  | 7 | 3 |
| 1 D | SEX | Implied | 2 | 1 | 4D | TSTA |  | 2 | 1 | 7 D | TST |  | 7 | 3 |
| 1 E | EXG | $\dagger$ | 8 | 2 | 4 E | * | $\dagger$ |  |  | 7E | JMP | , | 4 | 3 |
| 1 F | TFR | Implied | 6 | 2 | 4F | CLRA | Implied | 2 | 1 | 7F | CLR | Extended | 7 | 3 |
| 20 | BRA | Relative | 3 | 2 | 50 | NEGB | Implied | 2 | 1 | 80 | SUBA | Immed | 2 | 2 |
| 21 | BRN | 4 | 3 | 2 | 51 | * | 4 |  |  | 81 | CMPA | 4 | 2 | 2 |
| 22 | BHI |  | 3 | 2 | 52 | * |  |  |  | 82 | SBCA |  | 2 | 2 |
| 23 | BLS |  | 3 | 2 | 53 | COMB |  | 2 | 1 | 83 | SUBD |  | 4 | 3 |
| 24 | BHS, BCC |  | 3 | 2 | 54 | LSRB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 |
| 25 | BLO, BCS |  | 3 | 2 | 55 | * |  |  |  | 85 | BITA |  | 2 | 2 |
| 26 | BNE |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 86 | LDA |  | 2 | 2 |
| 27 | BEQ |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 87 | * |  |  |  |
| 28 | BVC |  | 3 | 2 | 58 | ASLB, LSLB |  | 2 | 1 | 88 | EORA |  | 2 | 2 |
| 29 | BVS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 89 | ADCA |  | 2 | 2 |
| 2 A | BPL |  | 3 | 2 | 5A | DECB |  | 2 | 1 | 8A | ORA |  | 2 | 2 |
| 2B | BMI |  | 3 | 2 | 5B | * |  |  |  | 8B | ADDA | $\downarrow$ | 2 | 2 |
| 2C | BGE |  | 3 | 2 | 5C | INCB |  | 2 | 1 | 8C | CMPX | Immed | 4 | 3 |
| 2D | BLT |  | 3 | 2 | 5D | TSTB |  | 2 | 1 | 8D | BSR | Relative | 7 | 2 |
| 2E | BGT | $\dagger$ | 3 | 2 | 5 E | * | $\dagger$ |  |  | 8E | LDX | Immed | 3 | 3 |
| 2 F | BLE | Relative | 3 | 2 | 5F | CLRB | Implied | 2 | 1 | 8 F | * |  |  |  |

[^10]Table 12. Hexadecimal Values of Machine Codes (Cont.)

| OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 90 | SUBA | Direct | 4 | 2 | C6 | LDB | Immed | 2 | 2 | FC | LDD | Extended | 6 | 3 |
| 91 | CMPA | 1 | 4 | 2 | C7 | * | 4 |  |  |  | STD | 4 | 6 | 3 |
| 92 | SBCA |  | 4 | 2 | C8 | EORB |  | 2 | 2 |  | LDU | $\checkmark$ | 6 | 3 |
| 93 | SUBD |  | 6 | 2 | C9 | ADCB |  | 2 | 2 |  | STU | Extended | 6 | 3 |
| 94 | ANDA |  | 4 | 2 | CA | ORB |  | 2 | 2 |  |  |  |  |  |
| 95 | BITA |  | 4 | 2 | CB | ADDB |  | 2 | 2 |  |  |  |  |  |
| 96 | LDA |  | 4 | 2 | CC | LDD |  |  | 3 | 2 By | es Opcode |  |  |  |
| 197 | STA |  | 4 | 2 | CD | * | $\dagger$ |  |  |  |  |  |  |  |
| 98 | EORA |  | 4 | 2 | CE | LDU | Immed | 3 | 3 | 1021 | LBRN | Relative | 5 | 4 |
| 99 | ADCA |  | 4 | 2 | CF | * |  |  |  | 1022 | LBHI | 4 | 5(6) | 4 |
| 9A | ORA |  | 4 | 2 |  |  |  |  |  | 1023 | LBLS |  | $5(6)$ | 4 |
| 9 B | ADDA |  | 4 | 2 | DO | SUBB | Direct | 4 | 2 | 1024 | LBHS, LBCC |  | $5(6)$ | 4 |
| 9 C | CMPX |  | 6 | 2 | D1 | CMPB | 4 | 4 | 2 | 1025 | LBCS, LBLO |  | $5(6)$ | 4 |
| 9D | JSR |  | 7 | 2 | D2 | SBCB |  | 4 | 2 | 1026 | LBNE |  | $5(6)$ | 4 |
| 9E | LDX | $\dagger$ | 5 | 2 | D3 | ADDD |  | 6 | 2 | 1027 | LBEQ |  | $5(6)$ | 4 |
| 9 F | STX | Direct | 5 | 2 | D4 | ANDB |  | 4 | 2 | 1028 | LBVC |  | $5(6)$ | 4 |
|  |  |  |  |  | D5 | BITB |  | 4 | 2 | 1029 | LBVS |  | $5(6)$ | 4 |
| AO | SUBA | Indexed | 4+ | $2+$ | D6 | LDB |  | 4 | 2 | 102A | LBPL |  | $5(6)$ | 4 |
| A1 | CMPA | 4 | 4+ | $2+$ | D7 | STB |  | 4 | 2 | 102B | LBMI |  | $5(6)$ | 4 |
| A2 | SBCA |  | 4+ | $2+$ | D8 | EORB |  | 4 | 2 | 102C | LBGE |  | $5(6)$ | 4 |
| A3 | SUBD |  | $6+$ | 2+ | D9 | ADCB |  | 4 | 2 | 102D | LBLT |  | $5(6)$ | 4 |
| A4 | ANDA |  | 4+ | $2+$ | DA | ORB |  | 4 | 2 | 102E | LBGT | $\downarrow$ | $5(6)$ | 4 |
| A5 | BITA |  | 4+ | $2+$ | DB | ADDB |  | 4 | 2 | 102F | LBLE | Relative | 5(6) | 4 |
| A6 | LDA |  | 4+ | 2+ | DC | LDD |  | 5 | 2 | 103F | SWI2 | Implied | 20 | 2 |
| A7 | STA |  | 4+ | $2+$ | DD | STD |  | 5 | 2 | 1083 | CMPD | Immed | 5 | 4 |
| A8 | EORA |  | 4+ | $2+$ | DE | LDU | 1 | 5 | 2 | 108C | CMPY | $\downarrow$ | 5 | 4 |
| A9 | ADCA |  | 4+ | $2+$ | DF | STU | Direct | 5 | 2 | 108E | LDY | Immed | 4 | 4 |
| AA | ORA |  | 4+ | $2+$ |  |  |  |  |  | 1093 | CMPD | Direct | 7 | 3 |
| $A B$ | ADDA |  | 4+ | $2+$ | EO | SUBB | Indexed | $4+$ | $2+$ | 109C | CMPY | 4 | 7 | 3 |
| $A C$ | CMPX |  | $6+$ | $2+$ | E1 | CMPB | 4 | 4+ | $2+$ | 109E | LDY | 1 | 6 | 3 |
| AD | JSR |  | $7+$ | $2+$ | E2 | SBCB |  | $4+$ | $2+$ | 109F | STY | Direct | 6 | 3 |
| AE | LDX | 1 | $5+$ | $2+$ | E3 | ADDD |  | $6+$ | $2+$ | 10A3 | CMPD | Indexed | 7+ | $3+$ |
| AF | STX | Indexed | $5+$ | $2+$ | E4 | ANDB |  | $4+$ | $2+$ | 10AC | CMPY | 4 | $7+$ | $3+$ |
|  |  |  |  |  | E5 | BITB |  | $4+$ | $2+$ | 10AE | LDY | $\dagger$ | 6+ | $3+$ |
| BO | SUBA | Extended | 5 | 3 | E6 | LDB |  | 4+ | $2+$ | 10AF | STY | Indexed | $6+$ | $3+$ |
| B1 | CMPA | 4 | 5 | 3 | E7 | STB |  | 4+ | $2+$ | 1083 | CMPD | Extended | 8 | 4 |
| B2 | SBCA |  | 5 | 3 | E8 | EORB |  | 4+ | $2+$ | 10BC | CMPY | 4 | 8 | 4 |
| B3 | SUBD |  | 7 | 3 | E9 | ADCB |  | $4+$ | $2+$ | 10BE | LDY | $\checkmark$ | 7 | 4 |
| B4 | ANDA |  | 5 | 3 | EA | ORB * |  | 4+ | $2+$ | 10BF | STY | Extended | 7 | 4 |
| B5 | BITA |  | 5 | 3 | EB | ADDB |  | 4+ | $2+$ | 10CE | LDS | Immed | 4 | 4 |
| B6 | LDA |  | 5 | 3 | EC | LDD |  | $5+$ | $2+$ | 10DE | LDS | Direct | 6 | 3 |
| B7 | STA |  | 5 | 3 | ED | STD |  | $5+$ | $2+$ | 10DF | STS | Direct | 6 | 3 |
| B8 | EORA |  | 5 | 3 | EE | LDU | $\dagger$ | $5+$ | $2+$ | 10EE | LDS | Indexed | $6+$ | $3+$ |
| B9 | ADCA |  | 5 | 3 | EF | STU | Indexed | $5+$ | $2+$ | 10EF | STS | Indexed | 6+ | $3+$ |
| BA | ORA |  | 5 | 3 |  |  |  |  |  | 10FE | LDS | Extended | 7 | 4 |
| BB | ADDA |  | 5 | 3 | FO | SUBB | Extended | 5 | 3 | 10FF | STS | Extended | 7 | 4 |
| BC | CMPX |  | 7 | 3 | F1 | CMPB | 4 | 5 | 3 | 113F | SWI3 | Implied | 20 | 2 |
| BD | JSR |  | 8 | 3 | F2 | SBCB |  | 5 | 3 | 1183 | CMPU | Immed | 5 | 4 |
| BE | LDX | 1 | 6 | 3 | F3 | ADDD |  | 7 | 3 | 118C | CMPS | Immed | 5 | 4 |
| BF | STX | Extended | 6 | 3 | F4 | ANDB |  | 5 | 3 | 1193 | CMPU | Direct | 7 | 3 |
|  |  |  |  |  | F5 | BITB |  | 5 | 3 | 119C | CMPS | Direct | 7 | 3 |
| CO | SUBB | Immed | 2 | 2 | F6 | LDB |  | 5 | 3 | 11A3 | CMPU | Indexed | 7+ | $3+$ |
| C1 | CMPB | 4 | 2 | 2 | F7 | STB |  | 5 | 3 | 11AC | CMPS | Indexed | 7+ | $3+$ |
| C2 | SBCB |  | 2 | 2 | F8 | EORB |  | 5 | 3 | 11B3 | CMPU | Extended | 8 | 4 |
| C3 | ADDD |  | 4 | 3 | F9 | ADCB |  | 5 | 3 | 11 BC | CMPS | Extended | 8 | 4 |
| C4 | ANDB | 1 | 2 | 2 | FA | ORB | $\dagger$ | 5 | 3 |  |  |  |  |  |
| C5 | BITB | Immed | 2 | 2 | FB | ADDB | Extended | 5 | 3 |  |  |  |  |  |

Note: All unused opcodes are both undefined and illegal.

## Note for Use

## Compatibility with NMOS MPU (HD6809)

The difference between HD6309 (CMOS) and HD6809 (NMOS) is shown in table 13.

## Execution Sequence of CLR Instruction

Cycle-by-cycle flow of CLR instruction (direct, extended, indexed addressing mode) is shown below. In this sequence the contents of the memory location specified by the operand is read before writing 00 into it. Note that status flags, such as IRQ Flag, will be cleared by this extra data read operation when accessing the control/status register (sharing the same address between read and write) of peripheral devices.

Example: CLR (Extended)

| $\$ 8000$ | CLR | $\$ A 000$ |
| :--- | :--- | :--- |
| $\$ A 000$ | FCB | $\$ 80$ |

Cycle \# Address Data R/要 Description

| 1 | 8000 | 7 F | 1 | Opcode Fetch <br> 2 |
| :--- | :--- | :--- | :--- | :--- |
| 8001 | A0 | 1 | Operand Address, <br> High Byte |  |
| 3 | 8002 | 00 | 1 | Operand Address, <br> Low Byte |
| 4 | FFFF | $*$ | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | $*$ | 1 | VMA Cycle <br> 7 |
| A000 | 00 | 0 | Store Fixed 00 into <br> Specified Location |  |

* The data bus has the data at that particular address.

Table 13. Difference between HD6309 and HD6809

| Item | HD6309 (CMOS) | HD6809 (NMOS) |  |
| :--- | :--- | :--- | :--- |
| MRDY | Stretch Unit | integral multiples of half (1/2) bus <br> cycles | integral multiples of quarter $(1 / 4)$ bus <br> cycles |



|  | Stretch Time | $5 \mu \mathrm{~s}$ max |
| :--- | :--- | :--- |
| DMA/BREQ | Auto-refresh | None |
| External Clock Input | XTAL floating | Executed |



## Application Note for System Design

At the trailing edge of the address bus, the noise pulses may appeare on the output signals in HD6309.

Note the noise pulses and the following measures against them.

Noise Occurrence Condition: As shown in figure 20 , the noise pulses which are 0.8 V or over may appear on E and Q clocks when the address bus changes from high to low.

If the address buses $\left(\mathrm{A}_{0}-\mathrm{A}_{15}\right.$, and $\left.\mathrm{R} / \overline{\mathrm{W}}\right)$ change from high to low, the transient current flows through the GND. The noise pulses are generated on the LSI's $\mathrm{V}_{\text {SS }}$ pins according to the current and to the impedance state of the GND wirings.

Figure 21 shows the noise voltage dependency on the each parameter.

Figure 23 shows the noise voltage dependency on
the load capacitance of the address bus.
Note: The noise level should be carefully checked because it depends on the each parameter of actual application system.

## Noise Reduction:

1. Control each parameter such as $\mathrm{Cd}, \mathrm{V} \mathrm{cc}, \mathrm{Zg}$ in figure 21, and the noise level is reduced to be allowable.
2. Insert a bypass capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and the GND of the HD6309.
3. Connect the CMOS buffer with noise margin to E and Q clocks.
4. Insert the damping registors to the address bus. That is effective for the noise level to reduce less than 0.8 V . The damping resistor is about $40-50$ $\Omega$ on the higher byte of the address bus ( $\mathrm{A}_{15}-$ $\mathrm{A}_{8}$ ) and about $130-140 \Omega$ on the lower byte of the address bus $\left(\mathrm{A}_{7}-\mathrm{A}_{0}\right)$, and $\mathrm{R} / \overline{\mathrm{W}}$ as shown in figure 22. Electrical characteristics do not change by inserting the damping resistors.


Figure 20. Noise at Address Bus Output Changing


Figure 21. Dependency of the Noise Voltage on Each Parameter


Figure 22. Connecting Damping Resistors to Address Bus


Figure 23. Dependency of the Noise Voltage on the Load Capacitance of the Address Bus

## Absolute Maximum Ratings

| Item | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}{ }^{1}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{1}$ | -0.3 to +7.0 | V |
| Maximum Output Current | $\left\|\mathrm{I}_{\mathrm{o}}\right\|^{2}$ | 5 | mA |
| Maximum Total Output Current | $\left\|\Sigma \mathrm{I}_{\mathrm{o}}\right\|^{3}$ | 100 | mA |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

Notes: 1. With respect to $\mathrm{V}_{\mathrm{SS}}$ (system GND)
2. Maximum output current is the maximum currents which can flow out from one output terminal and $1 / O$ common terminal $\left(A_{0}-A_{15}, R / \bar{W}, D_{0}-D_{7}, B A, B S, Q, E\right)$.
3. Maximum total output current is the total sum of output currents which can flow out simultaneously from output terminals and I/O common terminals $\left(A_{0}-A_{15}, R / \bar{W}, D_{0}-D_{7}, B A, B S, Q, E\right)$.
4. Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.

Recommended Operating Conditions

| Item |  | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage |  | $\mathrm{V}_{\mathrm{cc}}{ }^{1}$ | 4.5 | 5.0 | 5.5 | V |
| Input Voltage | EXTAL | $V_{\text {IL }}{ }^{1}$ | -0.3 |  | 0.6 | V |
|  | Other Inputs |  | -0.3 |  | 0.8 | V |
|  | $\overline{\text { RES }}$ | $V_{1 H}{ }^{1}$ | $\mathrm{V}_{C C}-0.5$ |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |
|  | EXTAL |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
|  | Other Inputs |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Operating Temperature |  | $\mathrm{T}_{\text {opr }}$ | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

Note: 1. With respect to Vss (system GND)

## Electrical Characteristics

DC Characteristics $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=-20\right.$ to $+75^{\circ} \mathrm{C}$, unless otherwise noted.)


AC Characteristics $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=-20\right.$ to $+75^{\circ} \mathrm{C}$, unless otherwise noted.)

## Clock Timing

| Item | Symbol | HD63B09 |  |  | HD63C09 |  |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| Frequency of Operation (Crystal External Input) | $\mathrm{f}_{\text {XTAL }}$ | 2 |  | 8 | 2 |  | 12 | MHz | Figs. 25, 26 |
| Cycle Time | $\mathrm{t}_{\text {cyc }}$ | 500 |  | 2000 | 333 |  | 2000 | ns |  |
| Total Up Time | tut | 480 |  |  | 310 |  |  | ns |  |
| Processor Clock High | tPWEH | 220 |  | 5000 | 140 |  | 5000 | ns |  |
| Processor Clock Low | tPWEL | 210 |  | 1000 | 140 |  | 1000 | ns |  |
| E Rise and Fall Time | $t_{\text {Er }}, t_{\text {Ef }}$ |  |  | 20 |  |  | 20 | ns |  |
| $E_{\text {Low }}$ to $\mathrm{O}_{\text {High }}$ Time | $\mathrm{t}_{\text {Avs }}$ | 100 |  | 140 | 70 |  | 100 | ns |  |
| Q Clock High | trwor | 220 |  | 1000 | 140 |  | 1000 | ns |  |
| Q Clock Low | tpwol | 220 |  | 5000 | 140 |  | 5000 | ns |  |
| Q Rise and Fall Time | $\mathrm{tarar}_{\text {r }}$ taf |  |  | 20 |  |  | 20 | ns |  |
| $\mathrm{Q}_{\text {Low }}$ to $\mathrm{E}_{\text {Low }}$ Time | $\mathrm{t}_{\text {LE }}$ | 100 |  |  | 70 |  |  | ns |  |

Bus Timing

| Item |  | Symbol | HD63B09 |  |  | HD63C09 |  |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| Address Delay |  |  | $t_{\text {AD }}$ |  |  | 110 |  |  | 110 | ns | Figs. 25, 26 |
| Peripheral Read Access Time $\left({ }_{U T T^{-}} t_{A D}-t_{D S R}=t_{A C C}\right)$ |  | $\mathrm{t}_{\text {ACC }}$ | 330 |  |  | 160 |  |  | ns |  |
| Data Set Up Time (Read) |  | tose | 40 |  |  | 40 |  |  | ns |  |
| Input Data Hold Time |  | $\mathrm{t}_{\text {DHR }}$ | 10 |  |  | 10 |  |  | ns |  |
| Address Hold Time | $\mathrm{Ta}=0$ to $+75^{\circ} \mathrm{C}$ | $\mathrm{t}_{\text {AH }}$ | 20 |  |  | 20 |  |  | ns |  |
|  | $\mathrm{Ta}=-20$ to $0^{\circ} \mathrm{C}$ |  | 10 |  |  | 10 |  |  |  |  |
| Data Delay Time (Write) |  | todw |  |  | 110 |  |  | 70 | ns |  |
| Output Hold Time | $\mathrm{Ta}=0$ to $+75^{\circ} \mathrm{C}$ | tDHW | 30 |  |  | 30 |  |  | ns |  |
|  | Ta $=-20$ to $0^{\circ} \mathrm{C}$ |  | 20 |  |  | 20 |  |  |  |  |

## Processor Control Timing

| Item | Symbol | HD63B09 |  |  | HD63C09 |  |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| MRDY Set Up Time | tPCSM | 110 |  |  | 70 |  |  | ns | Figs. 3-7 |
| MRDY Set Up Time 2 | tresm2 | 240 |  |  | 160 |  |  | ns | Figs. 11, 12 |
| Interrupts Set Up Time | tecs | 110 |  |  | 70 |  |  | ns |  |
| HALT Set Up Time | tPCSH | 110 |  |  | 70 |  |  | ns |  |
| $\overline{\overline{R E S}}$ Set Up Time | teser $^{\text {chen }}$ | 110 |  |  | 110 |  |  | ns |  |
| DMA/BREQ Set Up Time | $\mathrm{t}_{\text {PCSD }}$ | 110 |  |  | 70 |  |  | ns |  |
| Processor Control Rise and | ${ }^{2} \mathrm{P}_{\mathrm{C}}$, trcf |  |  | 100 |  |  | 100 | ns |  |
| Crystal Oscillator Start Time | $\mathrm{trg}^{\text {c }}$ | 20 |  |  | 20 |  |  | ms |  |



$$
\begin{aligned}
& \cdot \mathrm{C}= 30 \mathrm{pF}(\mathrm{BA}, \mathrm{BS}) \\
& 130 \mathrm{pF}\left(\mathrm{D}_{0}-\mathrm{D}_{7}, \mathrm{E}, \mathrm{Q}\right) \\
& 90 \mathrm{pF}\left(\mathrm{~A}_{0}-A_{15}, R / \bar{W}\right) \\
& \cdot R= 10 \mathrm{k} \Omega\left(\mathrm{D}_{0}-D_{7}\right) \\
& 10 \mathrm{k} \Omega\left(A_{0}-A_{15}, E, Q, R / \bar{W}\right) \\
& \quad 10 \mathrm{k} \Omega(B A, B S) \\
& \text { All diodes are } 1 \mathrm{~S} 2074(-1) \text { or equivalent. } \\
& \mathrm{C} \text { includes stray capacitance. }
\end{aligned}
$$

Figure 24. Bus Timing Test Load


Figure 25. Read Data from Memory or Peripherals


Figure 26. Write Data to Memory or Peripherals

## Package Dimensions

Unit: mm (inch)


CP-44


## HD63B09E,HD63C09E CMOS MPU (Micro Processing Unit)

The HD6309E is the highest 8 -bit microprocessor of HMCS6800 family, which is just compatible with the conventional HD6809E.

The HD6309E has hardware and software features which make it an ideal processor for higher level language execution or standard controller applications. External clock inputs are provided to allow synchronization with peripherals, systems or other MPUs.

The HD6309E is complete CMOS device and the power dissipation is extremely low. Moreover, the SYNC and CWAI instruction makes low power application possible.

- FEATURES
- Hardware - Interface with All HMCS6800 Peripherals
- Software - Object Code Compatible with the HD6809E
- Low Power Consumption Mode (Sleep mode)

SYNC state of SYNC Instruction WAIT state of CWAI Instruction

- External Clock Inputs, E and Q, Allow Synchronization
- Wide Operation Range
$\mathrm{f}=0.5$ to $3 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Type No. | Bus Timing |
| :--- | :---: |
| HD63B09E | 2.0 MHz |
| HD63C09E | 3.0 MHz |



- PIN ARRANGEMENT

| $\mathrm{v}_{\text {SS }}$ | OHD6309E | 40 HALT |
| :---: | :---: | :---: |
| NMI 2 |  | 39 TSC |
| IRO 3 |  | 38 LIC |
| FIRO4 |  | 37 $\overline{\text { RES }}$ |
| BS 5 |  | 36 AVMA |
| BA 6 |  | $3{ }^{3}$ |
| $\mathrm{V}_{\mathrm{CC}} 7$ |  | 3 E |
| $A_{0} 8$ |  | 33 Busy |
| $A_{1} 9$ |  | 327 R/W |
| $A_{2} 10$ |  | (31 $\mathrm{D}_{0}$ |
| $A_{3}{ }^{17}$ |  | $30 \mathrm{D}_{1}$ |
| A. 12 |  | $2 \mathrm{D}_{2}$ |
| $A_{5} 13$ |  | 28 D |
| $A_{6} 14$ |  | 27 D , |
| A, 15 |  | $26 D_{5}$ |
| As 16 |  | 25 D6 |
| A, 17 |  | $24 \mathrm{D}_{7}$ |
| A 1018 |  | 23 A 15 |
| $A_{1,19}$ |  | $2{ }^{2} A_{14}$ |
| $A_{12} 20$ |  | (2) $A_{13}$ |

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | $-0.3 \sim+7.0$ | V |
| Maximum Output Current | $\left.\mathrm{I}_{\mathrm{O}}\right\|^{* *}$ | 5 | mA |
| Maximum Total Output Current | $\left\|\Sigma \mathrm{I}_{\mathrm{O}}\right\|^{* * *}$ | 100 | mA |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $-20 \sim+75$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

* With respect to $V_{S S}$ (SYSTEM GND)
** Maximum output current is the maximum currents which can flow out from one output terminal and I/O common terminal. $\left(A_{0} \sim A_{15}, R / W, D_{0} \sim D_{7}, B A, B S\right.$, LIC, AVMA, BUSY)
*** Maximum total output current is the total sum of output currents which can flow out simultaneously from output terminals and I/O common terminals. $\left(A_{0} \sim A_{15}, R / W, D_{0} \sim D_{7}, B A, B S, L I C, A V M A, B U S Y\right)$
(NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.
- RECOMMENDED OPERATING CONDITIONS

| Item |  | Symbol | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage |  | $\mathrm{V}_{\mathrm{CC}}{ }^{*}$ | 4.5 | 5.0 | 5.5 | V |
| Input Voltage | Logic, $\overline{\text { RES }}$ | $\mathrm{V}_{\text {IL }}{ }^{*}$ | -0.3 | - | 0.8 | V |
|  | E, O | $\mathrm{V}_{\text {ILC }}{ }^{*}$ | -0.3 | - | 0.4 | V |
|  | Logic | $\mathrm{V}_{1 H}{ }^{*}$ | 2.0 | - | $V_{\text {cc }}$ | V |
|  | E, Q |  | 3.0 | - | $V_{\text {cc }}$ | V |
|  | $\overline{\text { RES }}$ |  | $\mathrm{V}_{\mathrm{CC}}-0.5$ | - | $\mathrm{V}_{\mathrm{Cc}}$ | V |
| Operating Temperature |  | $\mathrm{T}_{\text {opr }}$ | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

* With respect to $\mathrm{V}_{\mathrm{SS}}$ (SYSTEM GND)
- ELECTRICAL CHARACTERISTICS


| Item |  | Symbol | Test Condition | HD63B09E |  |  | HD63C09E |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ* | max | min | typ* | max |  |
|  | Logic |  | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.0 | - | $V_{\text {cc }}$ | 2.0 | - | $V_{C C}$ | V |
| Input "High" Voltage | E, Q | $\mathrm{V}_{\text {IH }}$ |  | 3.0 | - | $\mathrm{V}_{\text {cc }}$ | 3.0 | - | $V_{\text {cc }}$ | V |
|  | RES | $V_{\text {IHR }}$ |  | $\mathrm{V}_{\mathrm{CC}}-0.5$ | - | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}-0.5$ | - | $\mathrm{V}_{\text {cc }}$ | V |
|  | Logic, $\overline{\text { RES }}$ | $V_{\text {IL }}$ |  | -0.3 | - | 0.8 | -0.3 | - | 0.8 | V |
|  | E, O | VILC |  | -0.3 | - | 0.4 | -0.3 | - | 0.4 | V |
|  | Logic, Q, $\overline{\text { RES }}$ |  | $\mathrm{V}_{\text {in }}=0 \sim V_{\text {cc, }}$ | -2.5 | - | 2.5 | -2.5 | - | 2.5 | $\mu \mathrm{A}$ |
|  | E |  |  | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
|  | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ |  | $\mathrm{I}_{\text {LOAD }}=-400 \mu \mathrm{~A}$ | 4.1 | - | - | 4.1 | - | - | $v$ |
|  | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ |  | ILOAD $\leqq-10 \mu \mathrm{~A}$ | $\mathrm{VCC}^{-0.1}$ | - | - | $\mathrm{V}_{\text {CC }}-0.1$ | - | - | $\checkmark$ |
|  |  |  | ILOAD $=-400 \mu \mathrm{~A}$ | 4.1 | - | - | 4.1 | - | - | $v$ |
| Output "High" Voitage | $A_{0} \sim A_{15}, R / W$ | VOH | ILOAD $\leq-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.1$ | - | - | $\mathrm{V}_{\mathrm{cc}}-0.1$ | - | - |  |
|  | BA, BS, LIC, |  | $I_{\text {LOAD }}=-400 \mu \mathrm{~A}$ | 4.1 | - | - | 4.1 | - | - | V |
|  | AVMA, BUSY |  | ILOAD $\leqq-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.1$ | - | - | $\mathrm{V}_{\text {cc }}-0.1$ | - | - |  |
| Output "Low" Voltage |  | VOL | $\mathrm{I}_{\text {LOAD }}=2 \mathrm{~mA}$ | - | - | 0.5 | - | - | 0.5 | V |
| Input Capacitance | $\begin{aligned} & \mathrm{D}_{0} \sim \mathrm{D}_{7}, \text { Logic } \\ & \text { Input } \mathrm{Q}, \overline{\mathrm{RES}} \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{in}}=0 \mathrm{~V}, \\ & \mathrm{Ta}=25^{\circ} \mathrm{C}, \end{aligned}$ | - | 10 | 15 | - | 10 | 15 | pF |
| Input Capacitance | E |  | $f=1 \mathrm{MHz}$, | - | 30 | 50 | - | 30 | 50 | pF |
| Output Capacitance | $A_{0} \sim A_{s}, R / \bar{W}$, BA, BS, LIC, AVMA, BUSY | $\mathrm{C}_{\text {out }}$ | $\begin{aligned} & \hline V_{\text {in }}=0 \mathrm{~V}, \\ & \mathrm{Ta}=25^{\circ} \mathrm{C}, \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ | - | 10 | 15 | - | 10 | 15 | pF |
| Frequency of Operation | E, Q | $f$ |  | 0.5 | - | 2.0 | 0.5 | - | 3.0 | MHz |
| Three-State (Off State) Input Current |  | ITSI | $\begin{aligned} & V_{\text {in }}=0.4 \sim V_{\text {cc }}, \\ & V_{\text {cC }}=\max \end{aligned}$ | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
|  | $A_{0} \sim A_{15}, R / \bar{W}$ |  |  | -10 | - | 10 | -10 | - | 10 | $\mu \mathrm{A}$ |
| Current Dissipation |  | ICC | Operating | - | - | 20 | - | - | 30 | mA |
|  |  | Sleeping | - | - | 10 | - | - | 15 |  |

${ }^{*} \mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}{ }^{5} 5 \mathrm{~V}$

- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=\mathbf{0}, \mathrm{T}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.)


## 1. CLOCK TIMING

| Item |  | Symbol | Test Condition | HD63B09E |  |  | HD63C09E |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max |  |
| Cycle Time |  |  | ${ }_{\text {t }}^{\text {cyc }}$ | Fig. 1,2 | 500 | - | 2000 | 333 | - | 2000 | ns |
| E Clock "Low" |  | tPWEL | 210 |  | - | 1000 | 140 | - | 1000 | ns |
| E Clock "High" (Measured at $\mathrm{V}_{\mathbf{1 H}}$ ) |  | tPWEH | 220 |  | - | 1000 | 140 | - | 1000 | ns |
| $E$ Rise and Fall Time |  | ${ }_{\text {ter }}$, tef | - |  | - | 20 | - | - | 15 | ns |
| Q Clock "High" |  | tPWQH | 220 |  | - | 1000 | 140 | - | 1000 | ns |
| Q Rise and Fall Time |  | tar, taf | - |  | - | 20 | - | - | 15 | ns |
| E "Low" to Q Rising | E "Loww" $\rightarrow$ Q"High" | tEQ1 | 100 |  | - | - | 65 | - | - | ns |
| Q "High" to E Rising | Q "High" $\rightarrow$ E "High" | tEQ2 | 100 |  | - | - | 65 | - | - | ns |
| E "High" to Q Falling | E "High" $\rightarrow$ Q"Low" | teq3 | 100 |  | - | - | 65 | - | - | ns |
| Q "Low" to E Falling | Q "Low" $\rightarrow$ E "Low" | ${ }^{\text {t E O }}$ | 100 |  | - | - | 65 | - | - | ns |

## 2. BUS TIMING

| Item |  | Symbol | Test Condition | HD63B09E |  |  | HD63C09E |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | typ | max | min | typ | max |  |
| Address Delay |  |  | ${ }^{t} A D$ | Fig. 1, 2 | - | - | 110 | - | - | 110 | ns |
| Address Hold Time (Address, R/W, BA, BS) | $\mathrm{Ta}=0 \sim 75^{\circ} \mathrm{C}$ | ${ }^{\text {t }}$ AH | 20 |  | - | - | 20 | - | - |  |
|  | $\mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C}$ |  | 10 |  | - | - | 10 | - | - |  |
| Peripheral Read Access Times ( $t_{\text {cyc }}-t_{E f}-t_{A D}-t_{D S R}=t_{A C C}$ ) |  | ${ }^{\text {t }}$ ACC | 330 |  | - | - | 185 | - | - | ns |
| Data Setup Time (Read) |  | ${ }^{\text {t DSR }}$ | 40 |  | - | - | 20 | - | - | ns |
| Input Data Hold Time |  | tDHR | 20 |  | - | - | 20 | - | - | ns |
| Data Delay Time (Write) |  | todw | - |  | - | 110 | - | - | 70 | ns |
| Output Data Hold Time | $\mathrm{Ta}=0 \sim 75^{\circ} \mathrm{C}$ | ${ }^{\text {t }}$ HWW | 30 |  | - | - | 30 | - | - | ns |
|  | $\mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C}$ |  | 20 |  | - | - | 20 | - | - |  |

## 3. PROCESSOR CONTROL TIMING

| Item | Symbol | Test Condition | HD63B09E |  |  | HD63C09E |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | typ | max | min | typ | max |  |
| Control Delay (BUSY, LIC, AVMA) | ${ }^{\text {t }} \mathrm{CD}$ | Fig. 1, 2,$7 \sim 10$$14 \text { and } 17$ | - | - | 200 | - | - | 130 | ns |
| Interrupts Set Up Time | tPCS |  | 110 | - | - | 70 | - | - | ns |
| $\overline{\text { HALT }}$ Set Up Time | tPCS |  | 110 | - | - | 70 | - | - | ns |
| RES Set Up Time | tPCS |  | 110 | - | - | 70 | - | - | ns |
| TSC Setup. Time | tPCS |  | 110 | - | - | 70 | - | - | ns |
| TSC Drive to Valid Logic Levels | tTSA |  | - | - | 120 | - | - | 120 | ns |
| TSC Release MOS Buffers to High Impedance | tTSR |  | - | - | 110 | - | - | 110 | ns |
| TSC Three-State Delay | ${ }^{\text {t }}$ TSD |  | - | - | 80 | - | - | 80 | ns |
| Processor Control Rise/Fall | ${ }^{\text {tPCr, }}$ tPCf |  | - | - | 100 | - | - | 100 | ns |
| TSC Input Delay | tPCT |  | 30 | - | - | 30 | - | - | ns |


(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \text { min }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure 1 Read Data from Memory or Peripherals

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H m i n}$ and logic "Low" $=V_{1 L m a x}$ unless otherwise specified.
Figure 2 Write Data to Memory or Peripherals


Figure 3 HD6309E Expanded Block Diagram


C $=30 \mathrm{pF}$ for BA, BS, LIC, AVMA, BUSY
130 pF for $\mathrm{D}_{0} \sim \mathrm{D}_{7}$
90 pF for $\mathrm{A}_{0} \sim \mathrm{~A}_{15}, R / \bar{W}$
$R=10 \mathrm{k} \Omega$ for $D_{0} \sim D_{7}$
$10 \mathrm{k} \Omega$ for $A_{0} \sim A_{15}, R / \bar{W}$
$10 \mathrm{k} \Omega$ for BA, BS , LIC, AVMA, BUSY
All diodes are $1 \mathrm{~S} 2074(H)$ or equivalent. C includes stray capacitance.

Figure 4 Bus Timing Test Load

## - PROGRAMMING MODEL

As shown in Figure 5, the HD6309E adds three registers to the set available in the HD6800. The added registers include a Direct Page Register, the User Stack pointer and a second Index Register.

- Accumulators (A, B, D)

The $A$ and $B$ registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data.

Certain instructions concatenate the $A$ and $B$ registers to form a single 16 -bit accumulator. This is referred to as the D Register, and is formed with the A Register as the most significant byte.

- Direct Page Register (DP)

The Direct Page Register of the HD6309E serves to enhance the Direct Addressing Mode. The content of this register appears at the higher address outputs $\left(\mathbf{A}_{8} \sim \mathbf{A}_{15}\right)$ during direct addressing instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure HD6800 compatibility, all bits of this register are cleared during Processor Reset.


Figure 5 Programming Model of The Microprocessing Unit

## - Index Registers (X, Y)

The Index Registers are used in indexed mode of addressing. The 16 -bit address in this register takes part in the calculation of effective addresses. This address may be used to point to data directly or may be modified by an optional constant or register offset. During some indexed modes, the contents of the index register are incremented or decremented to point to the next item of tabular type data. All four pointer registers ( $\mathrm{X}, \mathrm{Y}, \mathrm{U}, \mathrm{S}$ ) may be used as index registers.

## - Stack Pointer (U, S)

The Hardware Stack Pointer (S) is used automatically by the processor during subroutine calls and interrupts. The User Stack Pointer (U) is controlled exclusively by the programmer thus allowing arguments to be passed to and from subroutines with ease. The U-register is frequently used as a stack marker. Both Stack Pointers have the same indexed mode addressing capabilities as the X and Y registers, but also support Push and Pull instructions. This allows the HD6309E to be used efficiently as a $\cdot$ stack processor, greatly enhancing its ability to support higher level languages and modular programming.
(NOTE) The stack pointers of the HD6309E point to the top of the stack, in contrast to the HD6800 stack pointer, which pointed to the next free location on stack.

## - Program Counter (PC)

The Program Counter is used by the processor to point to the address of the next instruction to be executed by the processor. Relative Addressing is provided allowing the Program Counter to be used like an index register in some situations.

## - Condition Code Register (CC)

The Condition Code Register defines the state of the processor at any given time. See Figure 6.


Figure 6 Condition Code Register Format

## - CONDITION CODE REGISTER DESCRIPTION

- Bit 0 (C)

Bit 0 is the carry flag, and is usually the carry from the binary ALU. C is also used to represent a 'borrow' from subtract like instructions (CMP, NEG, SUB, SBC) and is the complement of the carry from the binary ALU.

## - Bit 1 (V)

Bit 1 is the overflow flag, and is set to a one by an operation which causes a signed two's complement arithmetic overflow. This overflow is detected in an operation in which the carry from the MSB in the ALU does not match the carry from the MSB-1.

- Bit $2(Z)$

Bit 2 is the zero flag, and is set to a one if the result of the previous operation was identically zero.

## - Bit 3 (N)

Bit 3 is the negative flag, which contains exactly the value of the MSB of the result of the preceding operation. Thus, a negative two's-complement result will leave N set to a one.

- Bit 4 (I)

Bit 4 is the $\overline{I R Q}$ mask bit. The processor will not recognize interrupts from the IRQ line if this bit is set to a one. NMI, FIRQ, IRQ, $\overline{\text { RES }}$ and SWI all set I to a one; SWI2 and SWI3 do not affect I .

## - Bit 5 (H)

Bit 5 is the half-carry bit, and is used to indicate a carry from bit 3 in the ALU as a result of an 8-bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is undefined in all subtract-like instructions.

## - Bit 6 (F)

Bit 6 is the FIRQ mask bit. The processor will not recognize interrupts from the FIRQ line if this bit is a one. NMI, FIRQ, SWI, and RES all set F to a one. IRQ, SWI2 and SWI3 do not affect $F$.

- Bit 7 (E)

Bit 7 is the entire flag, and when set to a one indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current E left in the Condition Code Register represents past action.

## - HD6309E MPU SIGNAL DESCRIPTION

- Power (Vss, Vcc)

Two pins are used to supply power to the part: V.ss is ground or 0 volts, while Vcc is $+5.0 \mathrm{~V} \pm 10 \%$.

## - Address Bus ( $A_{0} \sim A_{15}$ )

Sixteen pins are used to output address information from the MPU onto the Address Bus. When the processor does not require the bus for a data transfer, it will output address $\mathrm{FFFF}_{16}, \mathrm{R} / \mathrm{W}=$ "High", and BS = "Low"; this is a "dummy access" or VMA cycle. All address bus drivers are made highimpedance when output Bus Available (BA) is "High" or when TSC is asserted. Each pin will drive one Schottky TTL load or four LS TTL loads, and 90 pF. Refer to Figures 1 and 2.

- Data Bus ( $D_{0} \sim D_{7}$ )

These eight pins provide communication with the system bi-directional data bus. Each pin will drive one Schottky TTL load or four LS TTL loads, and 130 pF .

## - Read/Write (R/W)

This signal indicates the direction of data transfer on the data bus. A "Low" indicates that the MPU is writing data-onto the data bus. $R / \bar{W}$ is made high impedance when BA is "High" or when TSC is asserted. Refer to Figures 1 and 2.

- $\overline{R E S}$

A "Low" level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in Figure 7. The Reset vectors are fetched from locations $\mathrm{FFFE}_{16}$ and $\mathrm{FFFF}_{16}$ (Table 1) when Interrupt Acknowledge is true, ( $\overline{\mathrm{BA}} \cdot \mathrm{BS}=1$ ). During initial power-on, the Reset line should be held "Low" until the clock input signals are fully operational.

Because the HD6309E Reset pin has a Schmitt-trigger input with a threshold voltage higher than that of standard peripherals, a simple $\mathrm{R} / \mathrm{C}$ network may be used to reset the entire system.

This higher threshold voltage ensures that all peripherals are out of the reset state before the Processor.

Table 1 Memory Map for Interrupt Vectors

| Memory Map for Vector <br> Locations |  | Interrupt Vector <br> Description |
| :---: | :---: | :---: |
| MS | LS |  |
| FFFE | FFFF | $\overline{\text { RES }}$ |
| FFFC | FFFD | NMI |
| FFFA | FFFB | SWI |
| FFF8 | FFF9 | IRD |
| FFF6 | FFF7 | FIRQ |
| FFF4 | FFF5 | SWI2 |
| FFF2 | FFF3 | SWI3 |
| FFF0 | FFF1 | Reserved |

## - HALT

A "Low" level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven "High" indicating the buses are high impedance. BS is also "High" which indicates the processor is in the Halt state. While halted, the MPU will not respond to external real-time requests (FIRQ, $\overline{\mathrm{IRQ}}$ ) although $\overline{\text { NMI }}$ or $\overline{\mathrm{RES}}$ will be latched for later response. During the Halt state $Q$ and $E$ should continue to run normally. A halted state (BA $\cdot \mathrm{BS}=1$ ) can be achieved by pulling $\overline{\text { HALT }}$ "Low" while $\overline{\text { RES }}$ is still "Low". See Figure 8.

## - Bus Available, Bus Status (BA, BS)

The Bus Available output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. When BA goes "Low", a dead cycle will elapse before the MPU acquires the bus. BA will not be asserted when TSC is active, thus allowing dead cycle consistency.

The Bus Status output signal, when decoded with BA, represents the MPU state (valid with leading edge of $\mathbf{Q}$ ).

| MPU State |  | MPU State Definition |
| :---: | :---: | :--- |
| BA | BS |  |
| 0 | 0 |  |
| 0 | 1 | Normal (Running) |
| 1 | 0 | Interrupt or RESET Acknowledge |
| 1 | 1 | SYNC Acknowledge |
| HALT Acknowledge |  |  |

Interrupt Acknowledge is indicated during both cycles of a hardware-vector-fetch (RES, $\overline{\text { NMI, }}$ FIRQ, IRQ, SWI, SWI2, SWI3). This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 1.

Sync Acknowledge is indicated while the MPU is waiting for external synchronization on an interrupt line.

Halt Acknowledge is indicated when the HD6309E is in a Halt condition.

## HITACHI


(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{\text {IHmin }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \text { min }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure $8 \overline{\text { HALT }}$ and Single Instruction Execution for System Debug

## - Non Maskable Interrupt (NNI)*

A negative transition on this input requests that a nonmaskable interrupt sequence be generated. A non-maskable interrupt cannot be inhibited by the program, and also has a higher priority than $\overline{\text { FIRQ }}, \overline{\text { IRQ }}$ or software interrupts. During recognition of an NMI, the entire machine state is saved on the hardware stack. After reset, an NMI will not be recognized until the first program load of the Hardware Stack Pointer (S). The pulse width of $\overline{\text { NMI }}$ low must be at least one E cycle. If the NMI input does not meet the minimum set up with respect to Q , the interrupt will not be recognized until the next cycle. See Figure 9.

## - Fast-Interrupt Request ( $\overline{\text { FIRO}})^{*}$

A "Low" level on this input pin will initiate a fast interrupt sequence, provided its mask bit ( F ) in the CC is clear. This sequence has priority over the standard Interrupt Request (IRQ), and is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 10.

## - Interrupt Request (IRO)*

A "Low" level input on this pin will initiate an Interrupt Request sequence provided the mask bit (I) in the CC is clear. Since IRQ stacks the entire machine state it provides a slower response to interrupts than $\overline{\text { FIRQ. }} \overline{\text { IRQ }}$ also has a lower priority than $\overline{\text { FIRQ. Again, the interrupt service routine should clear }}$ the source of the interrupt before doing an RTI. See Figure 9.

* $\overline{\text { NMI }} \overline{\mathrm{FIRQ}}$, and $\overline{\mathrm{IRQ}}$ requests are sampled on the falling edge of Q . One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. If IRQ and FIRQ do not remain "Low" until completion of the current instruction they may not be recognized. However, NMI is latched and need only remain "Low" for one cycle.
- Clock Inputs E, Q

E and Q are the clock signals required by the HD6309E. $\mathbf{Q}$ must lead $\mathbf{E}$; that is, a transition on $\mathbf{Q}$ must be followed by a similar transition on E after a minimum delay. Addresses will be valid from the MPU, $\mathrm{t}_{\mathrm{AD}}$ after the falling edge of E , and data will be latched from the bus by the falling edge of E . While the $\mathbf{Q}$ input is fully TTL compatible, the E input directly drives internal MOS circuitry and, thus, requires levels above normal TTL levels. This approach minimizes clock skew inherent with an internal buffer. Timing and waveforms for E and Q are shown in Figures 1 and 2 while Figure 11 shows a simple clock generator for the HD6309E.

## - BUSY

Busy will be "High" for the read and modify cycles of a read-modify-write instruction and during the access of the first byte
of a double-byte operation (e.g., LDX, STD, ADDD). Busy is also "High" during the first byte of any indirect or other vector fetch (e.g., jump extended, SWI indirect etc.).

In a multi-processor system, busy indicates the need to defer the rearbitration of the next bus cycle to insure the integrity of the above operations. This difference provides the indivisible memory access required for a "test-and-set" primitive, using any one of several read-modify-write instructions.

Busy does not become active during PSH or PUL operations. A typical read-modify-write instruction (ASL) is shown in Figure 12. Timing information is given in Figure 13. Busy is valid $t_{C D}$ after the rising edge of $Q$.

## - AVMA

AVMA is the Advanced VMA signal and indicates that the MPU will use the bus in the following bus cycle. The predictive nature of the AVMA signal allows efficient shared-bus multiprocessor systems. AVMA is "Low" when the MPU is in either a HALT or SYNC state. AVMA is valid $t_{C D}$ after the rising edge of Q .

- LIC

LIC (Last Instruction Cycle) is "High" during the last cycle of every instruction, and its transition from "High" to "Low" will indicate that the first byte of an opcode will be latched at the end of the present bus cycle. LIC will be "High" when the MPU is Halted at the end of an instruction, (i.e., not in CWAI or RESET) in SYNC state or while stacking during interrupts. LIC is valid $\mathrm{t}_{\mathrm{CD}}$ after the rising edge of Q .

- TSC

TSC (Three-State Control) will cause MOS address, data, and $\mathrm{R} / \overline{\mathrm{W}}$ buffers to assume a high-impedance state. The control signals (BA, BS, BUSY, AVMA and LIC) will not go to the high-impedance state. TSC is intended to allow a single bus to be shared with other bus masters (processors or DMA controllers).

While E is "Low", TSC controls the address buffers and R/信 directly. The data bus buffers during a write operation are in a high-impedance state until Q rises at which time, if TSC is true, they will remain in a high-impedance state. If TSC is held beyond the rising edge of E , then it will be internally latched, keeping the bus drivers in a high-impedance state for the remainder of the bus cycle. See Figure 14.

## - MPU Operation

During normal operation, the MPU fetches an instruction from memory and then executes the requested function. This sequence begins after $\overline{\mathrm{RES}}$ and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Software instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI and SYNC. An interrupt or HALT input can also alter the normal execution of instructions. Figure 15 illustrates the flow chart for the HD6309E.

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \text { min }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified E clock shown for reference only.

Figure $9 \overline{\mathrm{IRO}}$ and $\overline{\text { NMI }}$ Interrupt Timing


(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \text { min }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified. E clock shown for reference only

Figure 10 FIRO Interrupt Timing


Figure 11 HD6309E Clock Generator


Figure 12 Read Modify Write Instruction Example (ASL Extended Indirect)

(NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{\text {IHmin }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.
Figure 13 BUSY̌ Timing (ASL Extended Indirect Instruction)

(NOTES) Data will be asserted by the MPU only during the interval while $R / \bar{W}$ is "Low" and $E$ or $Q$ is "High". Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H \text { min }}$ and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.


## ADDRESSING MODES

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The HD6309E has the most complete set of addressing modes available on any microcomputer today. For example, the HD6309E has 59 basic instructions; however, it recognizes 1464 different variations of instructions and addressing modes. The addressing modes support modern programming techniques. The following addressing modes are available on the HD6309E:
(1) Implied (Includes Accumulator)
(2) Immediate
(3) Extended
(4) Extended Indirect
(5) Direct
(6) Register
(7) Indexed

Zero-Offset
Constant Offset
Accumulator Offset
Auto Increment/Decrement
(8) Indexed Indirect
(9) Relative
(10) Program Counter Relative

## - Implied (Includes Accumulator)

In this addressing mode, the opcode of the instruction contains all the address information necessary. Examples of Implied Addressing are: ABX, DAA, SWI, ASRA, and CLRB.

## - Immediate Addressing

In Immediate Addressing, the effective address of the data is the location immediately following the opcode (i.e., the data to be used in the instruction immediately follows the opcode of the instruction). The HD6309E uses both 8 and 16 -bit immediate values depending on the size of argument specified by the opcode. Examples of instructions with Immediate Addressing are:

```
LDA #$20
LDX #$F000
LDY #CAT
```

(NOTE) \# signifies immediate addressing, $\$$ signifies hexadecimal value.

## - Extended Addressing

In Extended Addressing, the contents of the two bytes immediately following the opcode fully specify the 16 -bit effective address used by the instruction. Note that the address generated by an extended instruction defines an absolute address and is not position independent. Examples of Extended Addressing include:

| LDA | CAT |
| :--- | :--- |
| STX | MOUSE |
| LDD | $\$ 2000$ |

## - Extended Indirect

As a special case of indexed addressing (discussed below), one level of indirection may be added to Extended Addressing. In Extended Indirect, the two bytes following the postbyte of an Indexed instruction contain the address of the data.

```
LDA [CAT]
LDX [$FFFE]
STU [DOG]
```


## - Direct Addressing

Direct addressing is similar to extended addressing except that only one byte of address follows the opcode. This byte specifies the lower 8 bits of the address to be used. The upper 8 bits of the addres, are supplied by the direct page register. Since only one byte of address is required in direct addressing, this mode requires less memory and executes faster than extended addressing. Of course, only 256 locations (one page) can be accessed without redefining the contents of the DP register. Since the DP register is set to $\$ 00$ on Reset, direct addressing on the HD6309E is compatible with direct addressing on the HD6800. Indirection is not allowed in direct addressing. Some examples of direct addressing are:

| LDA | $\$ 30$ |  |
| :--- | :--- | :--- |
| SETDP | $\$ 10$ |  |
| LDB | $\$ 1030$ |  |
| LDD | <CAT |  | (Assembler directive)

(NOTE) $<$ is an assembler directive which forces direct addressing.

## - Register Addressing

Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction. This is called a postbyte. Some examples of register addressing are:

| TFR | X, Y | Transfer X into Y |
| :--- | :--- | :--- |
| EXG | A, B | Exchanges A with B |
| PSHS | A, B, X, Y | Push Y, X, B and A onto S |
| PULU | X, Y, D | Pull D, X, and Y from U |

## - Indexed Addressing

In all indexed addressing, one of the pointer registers ( $\mathrm{X}, \mathrm{Y}$, $\mathrm{U}, \mathrm{S}$, and sometimes PC) is used in a calculation of the effective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode as well as the pointer register to be used. Figure 16 lists the legal formats for the postbyte. Table 2 gives the assembler form and the number of cycles and bytes added to the basic values for indexed addressing for each variation.


Figure 16 Index Addressing Postbyte Register Bit Assignments

Table 2 Indexed Addressing Mode

| Type | Forms | Non Indirect |  |  |  | Indirect |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Assembler Form | Postbyte OP Code | $\stackrel{+}{\sim}$ | $\begin{aligned} & + \\ & \# \end{aligned}$ | Assembler Form | Postbyte OP Code | $\stackrel{+}{\sim}$ | + |
| Constant Offset From R (2's Complement Offsets) | No Offset | ,R | 1RR00100 | 0 | 0 | [,R] | 1RR10100 | 3 | 0 |
|  | 5 Bit Offset | n, R | ORRnnnnn | 1 | 0 | defaults to 8-bit |  |  |  |
|  | 8 Bit Offset | $n, R$ | 1RR01000 | 1 | 1 | [ $\mathrm{n}, \mathrm{R}$ ] | 1 RR11000 | 4 | 1 |
|  | 16 Bit Offset | $n, R$ | 1RR01001 | 4 | 2 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11001 | 7 | 2 |
| Accumulator Offset From R (2's Complement Offsets) | A Register Offset | A, R | 1RR00110 | 1 | 0 | [ $A, R$ ] | 1RR10110 | 4 | 0 |
|  | B Register Offset | B, R | 1RR00101 | 1 | 0 | [ $\mathrm{B}, \mathrm{R}$ ] | 1RR10101 | 4 | 0 |
|  | D Register Offset | D, R | 1RR01011 | 4 | 0 | [D, R] | 1RR11011 | 7 | 0 |
| Auto Increment/Decrement R | Increment By 1 | , R + | 1RR00000 | 2 | 0 | not allowed |  |  |  |
|  | Increment By 2 | , R++ | 1RR00001 | 3 | 0 | [, R + + ] | 1RR10001 | 6 | 0 |
|  | Decrement By 1 | , -R | 1RR00010 | 2 | 0 | not allowed |  |  |  |
|  | Decrement By 2 | , --R | 1RR00011 | 3 | 0 | [, - - R] | 1RR10011 | 6 | 0 |
| Constant Offset From PC (2's Complement Offsets) | 8 Bit Offset | n, PCR | 1×x01100 | 1 | 1 | [ $\mathrm{n}, \mathrm{PCR}$ ] | 1xx11100 | 4 | 1 |
|  | 16 Bit Offset | n, PCR | 1x×01101 | 5 | 2 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times 11101$ | 8 | 2 |
| Extended Indirect | 16 Bit Address | - | - | - | - | [ n ] | 10011111 | 5 | 2 |

$R=X, Y, U$ or $S$
RR:

$\stackrel{+}{\sim}$ and ${ }_{\#}^{+}$indicate the number of additional cycles and bytes for the particular variation.

## Zero-Offset Indexed

In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode.

Examples are:

$$
\begin{array}{ll}
\text { LDD } & 0, \mathrm{X} \\
\text { LDA } & \mathrm{S}
\end{array}
$$

## Constant Offset Indexed

In this mode, a two's-complement offset and the contents of one of the pointer registers are added to form the effective address of the operand. The pointer register's initial content is unchanged by the addition.

Three sizes of offsets are available:

$$
\begin{aligned}
& \text { 5-bit }(-16 \text { to }+15) \\
& \text { 8-bit }(-128 \text { to }+127) \\
& \text { 16-bit }(-32768 \text { to }+32767)
\end{aligned}
$$

The two's complement 5 -bit offset is included in the postbyte and, therefore, is most efficient in use of bytes and cycles. The two's complement 8 -bit offset is contained in a single byte following the postbyte. The two's complement 16 -bit offset is in the two bytes following the postbyte. In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically.

Examples of constant-offset indexing are:
$\begin{array}{ll}\text { LDA } & 23, \mathrm{X} \\ \text { LDX } & -2, \mathrm{~S}\end{array}$

## LDY 300, X <br> LDU CAT, Y

## Accumulator-Offset Indexed

This mode is similar to constant offset indexed except that the two's-complement value in one of the accumulators (A, B or $D$ ) and the contents of one of the pointer registers are added to form the effective address of the operand. The contents of both the accumulator and the pointer register are unchanged by the addition. The postbyte specifies which accumulator to use as an offset and no additional bytes are required. The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run-time.

Some examples are:

$$
\begin{array}{ll}
\text { LDA } & \text { B, Y } \\
\text { LDX } & \text { D,Y } \\
\text { LEAX } & \text { B, X }
\end{array}
$$

## Auto Increment/Decrement Indexed

In the auto increment addressing mode, the pointer register contains the address of the operand. Then, after the pointer register is used it is incremented by one or two. This addressing mode is useful in stepping through tables, moving data, or for ti.e creation of software stacks. In auto decrement, the pointer register is decremented prior to use as the address of the data. The use of auto decrement is similar to that of auto increment; but the tables, etc., are scanned from the high to low addresses. The size of the increment/decrement can be either one or two to allow for tables of either 8 - or 16 -bit data to be accessed and is selectable by the programmer. The pre-
decrement, post-increment nature of these modes allow them to be used to create additional software stacks that behave identically to the U and S stacks.

Some examples of the auto increment/decrement addressing modes are:

$$
\begin{array}{ll}
\text { LDA } & , \mathrm{X}+ \\
\text { STD } & , \mathrm{Y}++ \\
\text { LDB } & ,-\mathrm{Y} \\
\text { LDX } & ,--\mathrm{S}
\end{array}
$$

Care should be taken in performing operations on 16 -bit pointer registers (X, Y, U, S) where the same register is used to calculate the effective address.

Consider the following instruction:
STX $0, \mathrm{X}++(\mathrm{X}$ initialized to 0$)$
The desired result is to store a 0 in locations $\$ 0000$ and $\$ 0001$ then increment $X$ to point to $\$ 0002$. In reality, the following occurs:

$$
\begin{array}{ll}
0 \rightarrow \text { temp } & \text { calculate the EA; temp is a holding register } \\
\mathrm{X}+2 \rightarrow \mathrm{X} & \text { perform autoincrement } \\
\mathrm{X} \rightarrow \text { (temp) } & \text { do store operation }
\end{array}
$$

## - Indexed Indirect

All of the indexing modes with the exception of auto increment/decrement by one, or a $\pm 4$-bit offset may have an additional level of indirection specified. In indirect addressing, the effective address is contained at the location specified by the contents of the Index Register plus any offset. In the example below, the A accumulator is loaded indirectly using an effective address calculated from the Index Register and an offset.

|  | Before Execution <br>  <br>  <br>  <br>  <br> $X=X X$ (don't care) |
| :--- | :--- | :--- |
| X $\$$ F000 |  |

All modes of indexed indirect are included except those which are meaningless (e.g., auto increment/decrement by 1 indirect). Some examples of indexed indirect are:

| LDA | $[, \mathrm{X}]$ |
| :--- | :--- |
| LDD | $[10, \mathrm{~S}]$ |
| LDA | $[\mathrm{B}, \mathrm{Y}]$ |
| LDD | $[, \mathrm{X}++]$ |

## - Relative Addressing

The byte(s) following the branch opcode is (are) treated as a signed offset which may be added to the program counter. If the branch condition is true then the calculated address ( $\mathrm{PC}+$ signed offset) is loaded into the program counter. Program execution continues at the new location as indicated by the PC; short ( 1 byte offset) and long ( 2 bytes offset) relative addressing modes are available. All of memory can be reached in long relative addressing as an effective address is interpreted modulo $2^{16}$. Some examples of relative addressing are:

| BEQ | CAT | (short) |
| :--- | :--- | :--- |
| BGT | DOG | (short) |


| CAT | LBEQ | RAT | (long) |
| :--- | :--- | :--- | :--- |
| DOG | LBGT | RABBIT | (long) |
|  | $\cdot$ |  |  |
|  | - |  |  |
| RAT | NOP |  |  |
| RABBIT | NOP |  |  |

## Program Counter Relative

The PC can be used as the pointer register with 8 or 16 -bit signed offsets. As in relative addressing, the offset is added to the current PC to create the effective address. The effective address is then used as the address of the operand or data. Program Counter Relative Addressing is used for writing position independent programs. Tables related to a particular routine will maintain the same relationship after the routine is moved, if referenced relative to the Program Counter. Examples are:

```
LDA CAT, PCR
LEAX TABLE,PCR
```

Since program counter relative is a type of indexing, an additional level of indirection is available.

```
LDA [CAT, PCR]
LDU [DOG,PCR]
```


## - HD6309E INSTRUCTION SET

The instruction set of the HD6309E is similar to that of the HD6800 and is upward compatible at the source code level. The number of opcodes has been reduced from 72 to 59 , but because of the expanded architecture and additional addressing modes, the number of available opcodes (with different addressing modes) has risen from 197 to 1464.

Some of the instructions are described in detail below:

## - PSHU/PSHS

The push instructions have the capability of pushing onto either the hardware stack ( S ) or user stack (U) any single register, or set of registers with a single instruction.

## - PULU/PULS

The pull instructions have the same capability of the push instruction, in reverse order. The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled. The actual PUSH/PULL sequence is fixed; each bit defines a unique register to push or pull, as shown in below.

PUSH/PULL POST BYTE



## - TFR/EXG

Within the HD6309E, any register may be transferred to or exchanged with another of like-size; i.e., 8 -bit to 8 -bit or 16 -bit to 16 -bit. Bits $4 \sim 7$ of postbyte define the source register, while bits $0 \sim 3$ represent the destination register. These are denoted as follows:

| $0000-\mathrm{D}$ | $0101-\mathrm{PC}$ |
| :--- | :--- |
| $0001-\mathrm{X}$ | $1000-\mathrm{A}$ |
| $0010-\mathrm{Y}$ | $1001-\mathrm{B}$ |
| $0011-\mathrm{U}$ | $1010-\mathrm{CC}$ |
| $0100-\mathrm{S}$ | $1011-\mathrm{DP}$ |

(NOTE) All other combinations are undefined and INVALID.
TRANSFER/EXCHANGE POST BYTE

| SOURCE | DESTINATION |
| :--- | :--- | :--- |

## - LEAX/LEAY/LEAU/LEAS

The LEA (Load Effective Address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in Table 3.

The LEA instruction also allows the user to access data in a position independent manner. For example:

| LEAX | MSG1, PCR |
| :--- | :--- |
| LBSR | PDATA (Print message routine) |
| - |  |
| - |  |
| FCC | 'MESSAGE' |

This sample program prints: 'MESSAGE'. By writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located, when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the X pointer register. This code is totally position independent.

The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the autoincrement and autodecrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows:

| LEAa, $b+$ | (any of the 16-bit pointer registers $\mathrm{X}, \mathrm{Y}, \mathrm{U}$ <br> or $S$ may be substituted for a and b. ) |
| :--- | :--- |
| 1. $\mathrm{b} \rightarrow$ temp <br> (calculate the EA) |  |
| 2. $\mathrm{b}+1 \rightarrow \mathrm{~b}$ | (modify b, postincrement) |
| 3. temp $\rightarrow \mathrm{a}$ | (load a) |
| LEAa, -b |  |
| 1. $\mathrm{b}-1 \rightarrow$ temp (calculate EA with predecrement) <br> 2. $\mathrm{b}-1 \rightarrow \mathrm{~b}$ (modify b, predecrement) <br> 3. temp $\rightarrow \mathrm{a}$ (load a) |  |

Autoincrement-by-two and autodecrement-by-two instructions work similarly. Note that LEAX, X+ does not change X , however LEAX, - X does decrement X. LEAX 1, X should be used to increment $X$ by one.

Table 3 LEA Examples

| Instruction | Operation | Comment |
| :---: | :---: | :---: |
| LEAX 10, X | $X+10 \rightarrow X$ | Adds 5-bit constant 10 to $X$ |
| LEAX 500, $X$ | $X+500 \rightarrow X$ | Adds 16-bit constant 500 to $X$ |
| LEAY A, Y | $Y+A \rightarrow Y$ | Adds 8-bit A accumulator to $Y$. |
| LEAY D, Y | $Y+D \rightarrow Y$ | Adds 16-bit D accumulator to $Y$ |
| LEAU -10, U | $U-10 \rightarrow U$ | Subtracts 10 from U |
| LEAS -10, S | $S-10 \rightarrow S$ | Used to reserve area on stack |
| LEAS 10, S | $\mathrm{S}+10 \rightarrow \mathrm{~S}$ | Used to 'clean up' stack |
| LEAX 5, S | $S+5 \rightarrow X$ | Transfers as well as adds |

## - MUL

Multiplies the unsigned binary numbers in the $\mathbf{A}$ and B accumulator and places the unsigned result into the 16 -bit $D$ accumulator. This unsigned multiply also allows multipleprecision multiplications.

## Long and Short Relative Branches

The HD6309E has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 or 16 -bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64 k memory map. Position independent code can be easily generated through the use of relative branching. Both short ( 8 -bit) and long ( 16 -bit) branches are available.

## - SYNC

After encountering a Sync instruction, the MPU enters a Sync state, stops processing instructions and waits for an interrupt. If the pending interrupt is non-maskable ( $\overline{\mathrm{NMI}}$ ) or maskable (FIRQ, $\overline{\mathrm{IRQ}}$ ) with its mask bit (F or I) clear, the processor will clear the Sync state and perform the normal interrupt stacking and service routine. Since FIRQ and IRQ are not edge-triggered, a low level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$ ) with its mask bit (F or I) set, the processor will clear the Sync state and continue processing by executing the next inline instruction. Figure 17 depicts Sync timing.

## Software Interrupts

A Software Interrupt is an instruction which will cause an interrupt, and its associated vector fetch. These Software Interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on this HD6309E, and are prioritized in the following order: SWI, SWI2, SWI3.

## 16-Bit Operation

The HD6309E has the capability of processing 16 -bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes and pulls.

## - CYCLE-BY-CYCLE OPERATION

The address bus cycle-by-cycle performance chart illustrates the memory-access sequence corresponding to each possible instruction and addressing mode in the HD6309E. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this
technique considerably speeds throughput.) Next, the operation of each opcode will follow the flow chart. VMA is an indication of $\mathrm{FFFF}_{16}$ on the address bus, R/ $\overline{\mathrm{W}}=$ "High" and BS = "Low". The following examples illustrate the use of the chart; see Figure 18.


Example 2: DEC (Extended)

| $\begin{aligned} & \$ 8000 \\ & \$ A 000 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { FCB } \end{aligned}$ | \$A000$\$ 80$ |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | CYCLE-BY-CYCLE FLOW |  |  |
| Cycle \# | Address | Data | R/W | Description |
| 1 | 8000 | 7 A | 1 | Opcode Fetch |
| 2 | 8001 | A0 | 1 | Operand Address, <br> High Byte |
| 3 | 8002 | 00 | 1 | Operand Address, Low Byte |
| 4 | FFFF | * | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | * | 1 | VMA Cycle |
| 7 | A000 | 7F | 0 | Store the Decremented Data |

* The data bus has the data at that particular address.


## - SLEEP MODE

During the interrupt wait period in the SYNC instruction (the SYNC state) and that period in the CWAI instruction (the WAIT state), MPU operation is halted and goes to the sleep mode. However, the state of I/O pins is the same as that of the HD6809E in this mode.

## - HD6309E INSTRUCTION SET TABLES

The instructions of the HD6309E have been broken down into five different categories. They are as follows:

8 -Bit operation (Table 4)
16-Bit operation (Table 5)
Index register/stack pointer instructions (Table 6)
Relative branches (long or short) (Table 7)
Miscellaneous instructions (Table 8)
HD6309E instruction set tables and Hexadecimal Values of instructions are shown in Table 9 and Table 10.

(NOTES) 1. If the associated mask bit is set when the interrupt is requested, LIC will go "Low" and this cycle will be an instruction fetch from address location PC +1 . However, if the interrupt is accepted (NMI or an unmasked FIRQ or $\overline{\mathrm{FRQ}}$ ) LIC will remain "High" and interrupt processing location PC +1 . However, if the interrupt is accepted (NMI or an unn
will start with this cycle as ( m ) on Figure 9 and 10 (Interrupt Timing)
2. If mask bits are clear, IRQ and FIRQ must be held "Low" for three cycles to guarantee that interrupt will be taken, although only one cycle is necessary to bring the processor out of SYNC.
3. Waveform measurements for all inputs and outputs are specified at logic "High" $=V_{1 H}$ min and logic "Low" $=V_{\text {ILmax }}$ unless otherwise specified.

Figure 17 SYNC Timing

(NOTE)

1. Busy $=$ "High" during access of first byte of double byte immediate load.
2. Write operation during store instruction. Busy = "High" during first two cycles of a double-byte access and the first cycle of read-modify-write access.
3. AVMA is asserted on the cycle before a VMA cycle.

Figure 18 Address Bus Cycle-by-Cycle Performance

(NOTES)

1. Stack ( $W$ ) refers to the following sequence: $S P \leftarrow S P-1$, then $A D D R \leftarrow S P$ with $R / \bar{W}=$ " $L$ ow" Stack $(R)$ refers to the following sequence: $A D D R \leftarrow S P$ with $R / \bar{W}=$ "High", then $S P \leftarrow S P+1$. PSHU, PULU instructions use the user stack pointer (i.e., $S P=U$ ) and PSHS, PULS use the hardware stack pointer (i.e., $S P=S$ ).
2. Vector refers to the address of an interrupt or reset vector (see Table 1)
3. The number of stack accesses will vary according to the number of bytes saved
4. VMA cycles will occur until an interrupt occurs.

Figure 18 Address Bus Cycle-by-Cycle Performance (Continued)

(NOTES)
Stack (W) refers to the following sequence: $S P \leftarrow S P-1$, then ADDR $\leftarrow S P$ with $R / \bar{W}=$ " $L$ ow Stack ( $R$ ) refers to the following sequence: $A D D R \leftarrow S P$ with $R / \bar{W}=$ "High", then $S P \leftarrow S P+1$.
PSHU, PULU instructions use the user stack pointer (i.e., $\mathbf{S P}=\mathrm{U}$ ) and PSHS, PULS use the hardware stack pointer (i.e., $\mathbf{S P}=\mathbf{S}$ ).
2. Vector refers to the address of an interrupt or reset vector (see Table 1)
3. The number of stack accesses will vary according to the number of bytes saved.

VMA cycles will occur until an interrupt occurs.

Figure 18 Address Bus Cycie-by-Cycle Performance (Continued)

Table 4 8-Bit Accumulator and Memory Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| ADCA, ADCB | Add memory to accumulator with carry |
| ADDA, ADDB | Add memory to accumulator |
| ANDA, ANDB | And memory with accumulator |
| ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left |
| ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right |
| BITA, BITB | Bit test memory with accumulator |
| CLR, CLRA, CLRB | Clear accumulator or memory location |
| CMPA, CMPB | Compare memory from accumulator |
| COM, COMA, COMB | Complement accumultor or memory location |
| DAA | Decimal adjust A accumulator |
| DEC, DECA, DECB | Decrement accumulator or memory location |
| EORA, EORB | Exclusive or memory with accumulator |
| EXG R1, R2 | Exchange R1 with R2 (R1, R2 = A, B, CC, DP) |
| INC, INCA, INCB | Increment accumulator or memory location |
| LDA, LDB | Load accumulator from memory |
| LSL, LSLA, LSLB | Logical shift left accumulator or memory location |
| LSR, LSRA, LSRB | Logical shift right accumulator or memory location |
| MUL | Unsigned multiply (A $\times$ B $\rightarrow$ D) |
| NEG, NEGA, NEGB | Negate accumulator or memory |
| ORA, ORB | Or memory with accumulator |
| ROL, ROLA, ROLB | Rotate accumulator or memory left |
| ROR, RORA, RORB | Rotate accumulator or memory right |
| SBCA, SBCB | Subtract memory from accumulator with borrow |
| STA, STB | Store accumulator to memory |
| SUBA, SUBB | Subtract memory from accumulator |
| TST, TSTA, TSTB | Test accumulator or memory location |
| TFR R1, R2 | Transfer R1 to R2 (R1, R2 $=$ A, B, CC, DP) |

(NOTE) A, B, CC or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 5 16-Bit Accumulator and Memory Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| ADDD | Add memory to D accumulator |
| CMPD | Compare memory from D accumulator |
| EXG D, R | Exchange D with $X, Y, S, U$ or PC |
| LDD | Load D accumulator from memory |
| SEX | Sign Extend B accumulator into $A$ accumulator |
| STD | Store D accumulator to memory |
| SUBD | Subtract memory from D accumulator |
| TFR D, R | Transfer $D$ to $X, Y, S, U$ or PC |
| TFR R,D | Transfer X,Y,S, U or PC to D |

(NOTE) D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions.

Table 6 Index Register Stack Pointer Instructions

| Mnemonic(s) | Operation |
| :---: | :---: |
| CMPS, CMPU | Compare memory from stack pointer |
| CMPX, CMPY | Compare memory from index register |
| EXG R1, R2 | Exchange D, X, Y, S, U or PC with D, X, Y, S, U or PC |
| LEAS, LEAU | Load effective address into stack pointer |
| LEAX, LEAY | Load effective address into index register |
| LDS, LDU | Load stack pointer from memory |
| LDX, LDY | Load index register from memory |
| PSHS | Push A, B, CC, DP, D, X, Y, U, or PC onto hardware stack |
| PSHU | Push A, B, CC, DP, D, X, Y, S, or PC onto user stack |
| PULS | Pull A, B, CC, DP, D, X, Y, U or PC from hardware stack |
| PULU | Pull A, B, CC, DP, D, X, Y, S or PC from user stack |
| STS, STU | Store stack pointer to memory |
| STX, STY | Store index register to memory |
| TFR R1, R2 | Transfer D, X, Y, S, U or PC to D, X, Y, S, U or PC |
| ABX | Add B accumulator to X (unsigned) |

Table 7 Branch Instructions

| Mnemonic(s) | Operation |
| :---: | :---: |
| SIMPLE BRANCHES |  |
| BEO, LBEO | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BMI, LBMI | Branch if minus |
| BPL, LBPL | Branch if plus |
| BCS, LBCS | Branch if carry set |
| BCC, LBCC | Branch if carry clear |
| BVS, LBVS | Branch if overflow set |
| BVC, LBVC | Branch if overflow clear |
| SIGNED BRANCHES |  |
| BGT, LBGT | Branch if greater (signed) |
| BGE, LBGE | Branch if greater than or equal (signed) |
| BEQ, LBEQ | Branch if equal |
| BLE, LBLE | Branch if less than or equal (signed) |
| BLT, LBLT | Branch if less than (signed) |
| UNSIGNED BRANCHES |  |
| BHI, LBHI | Branch if higher (unsigned) |
| BHS, LBHS | Branch if higher or same (unsigned) |
| BEQ, LBEQ | Branch if equal |
| BLS, LBLS | Branch if lower or same (unsigned) |
| BLO, LBLO | Branch if lower (unsigned) |
| OTHER BRANCHES |  |
| BSR, LBSR | Branch to subroutine |
| BRA, LBRA | Branch always |
| BRN, LBRN | Branch never |

Table 8 Miscellaneous Instructions

| Mnemonic(s) |  |
| :--- | :--- |
| ANDCC | AND condition code register |
| CWAI | AND condition code register, then wait for interrupt |
| NOP | No operation |
| ORCC | OR condition code register |
| JMP | Jump |
| JSR | Jump to subroutine |
| RTI | Return from interrupt |
| RTS | Return from subroutine |
| SWI, SWI2, SWI3 | Software interrupt (absolute indirect) |
| SYNC | Synchronize with interrupt line |

Table 9 HD6309E Instruction Set Table

(to be continued)


(NOTES)
(1) This column gives a base cycle and byte count. To obtain total count, and the values obtained from the INDEXED ADDRESSING MODES table.
(2) R1 and R2 may be any pair of 8 bit or any pair of 16 bit registers.

The 8 bit registers are: A, B, CC, DP
The 16 bit registers are: $\dot{X}, \dot{Y}, U, S, D, P C$
(3) EA is the effective address.
(4) The PSH and PUL instructions require 5 cycle plus 1 cycle for each byte pushed or pulled.
(5) 5(6) means: 5 cycles if branch not taken, 6 cycles if taken.
(6) SWI sets 1 and F bits. SWI2 and SWI3 do not affect I and F
(7) Conditions Codes set as a direct result of the instruction.
(8) Value of half-carry flag is undefined.
(9) Special Case - Carry set if b7 is SET.
(10) Condition Codes set as a direct result of the instruction if CC is specified, and not affected otherwise.

| LEGEND: |  |
| :--- | :--- |
| OP | Operation Code (Hexadecimal) |
| $\sim$ | Number of MPU Cycles |
| $\#$ | Number of Prugram Bytes |
| + | Arithmetic Plus |
| $\bar{X}$ | Arithmetic Minus |
| Multiply |  |
| $\mathbf{M}$ | Complement of M |
| $\vec{H}$ | Transfer Into <br> Half-carry (from bit 3) <br> N |
|  | Negative (sign bit) |


| z | Zero (byte) |
| :--- | :--- |
| v | Overflow, 2's complement |
| C | Carry from bit 7 |
| $\ddagger$ | Test and set if true, cleared otherwise |
| $\bullet$ | Not Affected |
| CC | Condition Code Register |
| $\vdots$ | Concatenation |
| $\vee$ | Logical or |
| $\wedge$ | Logical and |
| $\oplus$ | Logical Exclusive or |

Table 10 Hexadecimal Values of Machine Codes

| OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | $\sim$ | \# |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | 4+ | 2+ | 60 | NEG | Indexed | 6+ | $2+$ |
| 01 | * | 4 |  |  | 31 | LEAY | 4 | 4+ | 2+ | 61 |  | 4 |  |  |
| 02 | * |  |  |  | 32 | LEAS | $\checkmark$ | 4+ | 2+ | 62 | * |  |  |  |
| 03 | COM |  | 6 | 2 | 33 | LEAU | Indexed | 4+ | $2+$ | 63 | COM |  | $6+$ | $2+$ |
| 04 | LSR |  | 6 | 2 | 34 | PSHS | Implied | $5+$ | $2{ }^{\prime}$ | 64 | LSR |  | $6+$ | $2+$ |
| 05 | * |  |  |  | 35 | PULS | 4 | $5+$ | 2 | 65 | * |  |  |  |
| 06 | ROR |  | 6 | 2 | 36 | PSHU |  | $5+$ | 2 | 66 | ROR |  | 6+ | 2+ |
| 07 | ASR |  | 6 | 2 | 37 | PULU |  | $5+$ | 2 | 67 | ASR |  | $6+$ | $2+$ |
| 08 | ASL, LSL |  | 6 | 2 | 38 | * |  |  |  | 68 | ASL, LSL |  | $6+$ | $2+$ |
| 09 | ROL |  | 6 | 2 | 39 | RTS |  | 5 | 1 | 69 | ROL |  | 6+ | $2+$ |
| OA | DEC |  | 6 | 2 | 3A | ABX | $\dagger$ | 3 | 1 | 6A | DEC |  | 6+ | 2+ |
| OB | * |  |  |  | 3 B | RTI | Implied | 6,15 | 1 | 6B | * |  |  |  |
| OC | INC |  | 6 | 2 | 3 C | CWAI | Immed | $\geqq 20$ | 2 | 6C | INC |  | $6+$ | 2+ |
| OD | TST |  | 6 | 2 | 3D | MUL | Implied | 11 | 1 | 6D | TST |  | $6+$ | $2+$ |
| OE | JMP | $\dagger$ | 3 | 2 | 3E | * |  |  |  | 6 E | JMP |  | $3+$ | $2+$ |
| OF | CLR | Direct | 6 | 2 | 3F | SWI | Implied | 19 | 1 | 6 F | CLR | Indexed | 6+ | $2+$ |
| 10 | See | - | - | - | 40 | NEGA | Implied | 2 | 1 | 70 | NEG | Extended | 7 | 3 |
| 11 | N Next Page | - | - | - | 41 | * | 4 |  |  | 71 |  | 4 |  |  |
| 12 | NOP | Implied | 2 | 1 | 42 | * |  |  |  | 72 | * |  |  |  |
| 13 | SYNC | Implied | $\geqq 4$ | 1 | 43 | COMA |  | 2 | 1 | 73 | COM |  | 7 | 3 |
| 14 | * |  |  |  | 44 | LSRA |  | 2 | 1 | 74 | LSR |  | 7 | 3 |
| 15 | * |  |  |  | 45 | * |  |  |  | 75 | * |  |  |  |
| 16 | LBRA | Relative | 5 | 3 | 46 | RORA |  | 2 | 1 | 76 | ROR |  | 7 | 3 |
| 17 | LBSR | Relative | 9 | 3 | 47 | ASRA |  | 2 | 1 | 77 | ASR |  | 7 | 3 |
| 18 | * |  |  |  | 48 | ASLA, LSLA |  | 2 | 1 | 78 | ASL, LSL |  | 7 | 3 |
| 19 | DAA | Implied | 2 | 1 | 49 | ROLA |  | 2 | 1 | 79 | ROL |  | 7 | 3 |
| 1A | ORCC | Immed | 3 | 2 | 4A | DECA |  | 2 | 1 | 7A | DEC |  | 7 | 3 |
| 1 B | - | - |  |  | 4B | * |  |  |  | 7B | * |  |  |  |
| 1 C | ANDCC | Immed | 3 | 2 | 4 C | INCA |  | 2 | 1 | 7 C | INC |  | 7 | 3 |
| 10 | SEX | Implied | 2 | 1 | 4D | TSTA |  | 2 | 1 | 70 | TST |  | 7 | 3 |
| 1E | EXG | 4 | 8 | 2 | 4E | * | $\dagger$ |  |  | 7E | JMP |  | 4 | 3 |
| 1F | TFR | Implied | 6 | 2 | 4F | CLRA | Implied | 2 | 1 | 7F | CLR | Extended | 7 | 3 |
| 20 | BRA | Relative | 3 | 2 | 50 | NEGB | Implied | 2 | 1 | 80 | SUBA | Immed | 2 | 2 |
| 21 | BRN | 4 | 3 | 2 | 51 | * | 4 |  |  | 81 | CMPA | 4 | 2 | 2 |
| 22 | BHI |  | 3 | 2 | 52 | * |  |  |  | 82 | SBCA |  | 2 | 2 |
| 23 | BLS |  | 3 | 2 | 53 | COMB |  | 2 | 1 | 83 | SUBD |  | 4 | 3 |
| 24 | BHS, BCC |  | 3 | 2 | 54 | LSRB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 |
| 25 | BLO, BCS |  | 3 | 2 | 55 | * |  |  |  | 85 | BITA |  | 2 | 2 |
| 26 | BNE |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 86 | LDA |  | 2 | 2 |
| 27 | BEQ |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 87 | * |  |  |  |
| 28 | BVC |  | 3 | 2 | 58 | ASLB, LSLB |  | 2 | 1 | 88 | EORA |  | 2 | 2 |
| 29 | BVS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 89 | ADCA |  | 2 | 2 |
| 2A | BPL |  | 3 | 2 | 5A | DECB |  | 2 | 1 | 8A | ORA |  | 2 | 2 |
| 2B | BMI |  | 3 | 2 | 5 B | * |  |  |  | 8B | ADDA | $\dagger$ | 2 | 2 |
| 2C | BGE |  | 3 | 2 | 5C | INCB |  | 2 | 1 | 8C | CMPX | 1 mmed | 4 | 3 |
| 2D | BLT |  | 3 | 2 | 5D | TSTB |  | 2 | 1 | 8D | BSR | Relative | 7 | 2 |
| 2E | BGT | $\dagger$ | 3 | 2 | 5E | * | $\downarrow$ |  |  | 8 E | LDX | Immed | 3 | 3 |
| 2F | BLE | Relative | 3 | 2 | 5F | CLRB | Implied | 2 | 1 | 8F | * |  |  |  |

LEGEND:
(to be continued)

(NOTE): All unused opcodes are both undefined and illegal

- NOTE FOR USE
- Execution Sequence of CLR Instruction

| Example: | CLR (Extended) |  |  |  |
| :---: | :---: | :---: | :---: | :--- |
| $\$ 8000$ | CLR | $\$ A 000$ |  |  |
| $\$ A 000$ | FCB | $\$ 80$ |  |  |
| Cycle \# Address Data R/ $\overline{\mathbf{W}}$ | Description <br> 1 | 8000 | 7 F | 1 | | Opcode Fetch |
| :--- |
| 2 |

* The data bus has the data at that particula

Cycle-by-cycle flow of CLR instruction (Direct, Extended, Indexed Addressing Mode) is shown below. In this sequence the content of the memory location specified by the operand is read before writing " 00 " into it. Note that status Flags, such as IRQ Flag, will be cleared by this extra data read operation when accessing the control/status register (sharing the same address between read and write) of peripheral devices.

- The Noise of HD6309E at Bus Outputs Changing

We shall notify you of the noise of the HD6309E.
The noise over 0.8 V may appear on the output signals when data bus or address bus outputs change from "High" to "Low". Problems and countermeasure are shown as follows.
(1) The Noise at Data Bus Outputs Changing ("High $\rightarrow$ "Low") Problem: The noise over 0.8 V may appear on $\mathrm{A}_{15} \sim \mathrm{~A}_{13}, \mathrm{R} / \mathrm{W}$ outputs change (worst case; $\$ \mathrm{FF} \rightarrow \$ 00$ ) as shown in Figure 19.


Noise peak (worst case); about 1.5V
Period of the noise occurrence (reference data)
Test condition
$\mathrm{Ta}=-20^{\circ} \mathrm{C}$
$V_{C C}=5.5 \mathrm{~V} \quad \mathrm{t}=8 \sim 43 \mathrm{~ns}\left(\mathrm{Ta}=25^{\circ} \mathrm{C}\right)$
Number of data bus lines switching from "High" to "Low" = 8
$t=8 \sim 43 \mathrm{~ns} \quad\left(\mathrm{Ta}=25^{\circ} \mathrm{C}\right)$
$\mathrm{t}=12 \sim 54 \mathrm{~ns} \quad\left(\mathrm{Ta}=75^{\circ} \mathrm{C}\right)$
( $\$ \mathrm{FF} \rightarrow \$ 00$ ) data bus load capacitance $=130 \mathrm{pF}$

Figure 19 Noise at data bus output changing

Countermeasure: If the noise level can not be reduced by controlling data bus load capacitance or reducing $\mathrm{V}_{\mathrm{CC}}$ in your application system, connect damping resistors (about $100 \sim 150 \Omega$ ) to data bus to reduce the noise level as shown in

Figure 20. Table 11 shows the relationship between damping resistors and electrical characteristics. Connecting damping resistors to data bus is effective to reduce the noise level as shown in Figure 21.


Figure 20 Connecting damping resistors to data bus

Table 11 The relationship between damping resistors and electrical characteristics

|  |  |  | $\mathrm{R}=0 \Omega$ | $R=100 \sim 150 \Omega$ |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { HD63B09E } \\ (2 \mathrm{MHz}) \end{gathered}$ | tDHW | $\mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C}$ | 20 ns | 10 ns |
|  |  | $\mathrm{Ta}=0 \sim 75^{\circ} \mathrm{C}$ | 30 ns | 15 ns |
| $\begin{aligned} & \text { HD63C09E } \\ & (3 \mathrm{MHz}) \end{aligned}$ | todw |  | 70 ns | 80 ns |
|  | tDHW | $\mathrm{Ta}=-20 \sim 0^{\circ} \mathrm{C}$ | 20 ns | 10 ns |
|  |  | $\mathrm{Ta}=0 \sim 75^{\circ} \mathrm{C}$ | 30 ns | 15 ns |



Figure 21 An example of the dependency of the noise voltage on damping resistors

## 2. The Noise at Address Bus Outputs Changing

 ("High" $\rightarrow$ "Low")Problem: The noise over 0.8 V may appear on BUSY, LIC,

AVMA outputs when address bus outputs change (worst case; \$FFFF $\rightarrow \$ 0000$ ) as shown in Figure 22.


Noise peak (worst case); about 1.5V
Test condition $\mathrm{Ta}=-20^{\circ} \mathrm{C}$
$V_{C c}=5.5 \mathrm{~V}$
Number of address bus lines switching from "High" to "Low" =
16 (\$FFFF $\rightarrow \$ 0000$ ) address bus load capacitance $=90 \mathrm{pF}$

Period of the noise occurrence (reference data)

$$
\begin{aligned}
& t=25 \sim 65 \mathrm{~ns}\left(\mathrm{Ta}=-20^{\circ} \mathrm{C}\right) \\
& \mathrm{t}=30 \sim 74 \mathrm{~ns}\left(\mathrm{Ta}=25^{\circ} \mathrm{C}\right) \\
& \mathrm{t}=34 \sim 83 \mathrm{~ns}\left(\mathrm{Ta}=75^{\circ} \mathrm{C}\right)
\end{aligned}
$$

Figure 22 Noise at address bus output changing

Countermeasure: To prevent the noise on BUSY, LIC, AVMA outputs from appearing, this signals must be latched at the negative edge of E or Q clock as
shown in Figure 23. An example of countermeasure circuit is shown in Figure 24.


Figure 23 An example of countermeasure of the noise


Figure 24 An example of countermeasure circuit

## HD64180R 8-BIT CMOS (Micro Processing Unit)

The HD64180R is an 8-bit MPU developed with a microcoded execution unit and advanced CMOS manufacturing technology. It incorporates high performance CPU, a memory management unit (MMU), two channel direct memory access controller (DMAC), two channel 16 -bit programmable reload timer, two channel asynchronous serial communication interface (ASCI), clock synchronous serial I/O port.

The HD64180R featuring MMU is suitable for high end application requiring 1 M byte memory physical address space. This device including the numerous peripheral functions is also suitable for system applications which require compactness as well as high performance.

## - Software Features

- Enhanced standard 8-bit software architecture:

Upward compatible with CP/M-80 ${ }^{\text {® }}$

## - Hardware Features

- On-chip MMU supporting 1M byte memory (Provided 512K byte for DP-64S)
- Two channel DMAC with memory-memory, memory-I/O and memory-memory mapped I/O transfer capabilities
- Two channel, full duplex asynchronous serial communication interface (ASCI) with programmable baud rate generator and modem control handshake signals
- One channel clocked serial I/O port with serial/parallel shift register
- Two channel 16 -bit programmable reload timer for output waveform generation
- Four external and eight internal interrupts
- Dual bus interface compatible with Motorola 68 family and with Intel 80 family
- On-chip clock generator
- Operating Frequency up to 8 MHz
- Low power dissipation: 50 mW at 4 MHz Operation (typ.)

TYPE OF PRODUCTS

| Type No. | Clock <br> Frequency | Address <br> Space | Package |
| :--- | :---: | :---: | :---: |
| HD64180RP-6 | 6 MHz | 512 Kb | DP-64S |
| HD64180RP-8 | 8 MHz |  | FP-80 |
| HD64180RF-6 | 6 MHz |  |  |
| HD64180RF-8 | 8 MHz | 1 Mb | FP-68 |
| HD64180RCP-6X | 6 MHz |  |  |



(10) HITACHI


## 4.Electrical characteristics

## ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | Value | Unit |
| :--- | :--- | :--- | :---: |
| Supply Voltage | Vcc | $-0.3 \sim+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | $-0.3 \sim \mathrm{Vcc}+0.3$ | V |
| Operating Temperature | $\mathrm{T}_{\text {opr }}$ | $-20 \sim+75$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

〔NOTE〕 Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.
DC CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%\right.$, Vss $=0 \mathrm{~V}, \mathrm{Ta}=-20 \sim+75^{\circ} \mathrm{C}$, unless otherwise noted.)

| Item | Symbol | Condition | min | typ | max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\frac{\text { Input " } \mathrm{H} \text { " Voltage }}{\text { RESET, EXTAL, } \overline{\text { NMI }}}$ | $\mathrm{V}_{1+1}$ |  | Vcc-0.6 | - | $\mathrm{Vcc}+0.3$ | V |
| Input " H " Voltage <br> Except RESET, EXTAL, $\overline{\text { NMI }}$ | $\mathrm{V}_{1 \mathrm{H} 2}$ |  | 2.0 | - | $\mathrm{Vcc}+0.3$ | V |
| Input "L" Voltage <br> RESET, EXTAL, NMI | $\mathrm{V}_{\text {IL1 }}$ |  | -0.3 | - | 0.6 | V |
| Input "L" Voltage Except $\overline{\mathrm{RESET}}, \mathrm{EXTAL}, \overline{\mathrm{NMI}}$ | $V_{\text {IL2 }}$ |  | -0.3 | - | 0.8 | V |
| Output "H" Voltage All Outputs | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ | 2.4 | - | - | V |
|  |  | $\mathrm{IOH}^{\text {O }}=-20 \mu \mathrm{~A}$ | Vcc-1.2 | - | - |  |
| Output "L" Voltage All Outputs | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ | - | - | 0.45 | V |
| Input Leakage Current All Inputs Except XTAL,EXTAL | IIL | $\mathrm{Vin}=0.5 \sim \mathrm{Vcc}-0.5$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Three State Leakage Current | $I_{T L}$ | Vin $=0.5 \sim \mathrm{Vcc}-0.5$ | - | - | 1.0 | $\mu \mathrm{A}$ |
| Power Dissipation (Normal Operation) | Icc | $f=4 \mathrm{MHz}$ | - | 10 | 20 | mA |
|  |  | $\mathrm{f}=6 \mathrm{MHz}$ | - | 15 | 30 |  |
|  |  | $\mathrm{f}=8 \mathrm{MHz}$ | - | 20 | 40 |  |
| Power Dissipation (SYSTEM STOP mode) |  | $\mathrm{f}=4 \mathrm{MHz}$ | - | 2.5 | 5.0 |  |
|  |  | $f=6 \mathrm{MHz}$ | - | 3.3 | 7.5 |  |
|  |  | $f=8 \mathrm{MHz}$ | - | 5.0 | 10.0 |  |
| Pin Capacitance | Cp | $\begin{aligned} & \mathrm{Vin}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz} \\ & \mathrm{Ta}=25^{\circ} \mathrm{C} \end{aligned}$ | - | - | 12 | pF |

## (6) HITACHI

AC CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{Vss}^{2}=0 \mathrm{~V}, \mathrm{Ta}=-20 \sim+75^{\circ} \mathrm{C}\right.$, unless otherwise noted. )

| Item | Symbol | HD64180R -4 |  | HD64180R -6 |  | HD64180R -8 |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min | max | min | $\boldsymbol{\operatorname { m a x }}$ | min | max |  |
| Clock Cycle Time | $\mathrm{t}_{\text {cyc }}$ | 250 | 2000 | 162 | 2000 | 125 | 2000 | ns |
| Clock "H" Pulse Width | ${ }^{\text {chew }}$ | 110 |  | 65 |  | 50 |  | ns |
| Clock "L" Pulse Width | $\mathrm{t}_{\text {CLW }}$ | 110 |  | 65 |  | 50 |  | ns |
| Clock Fall Time | $\mathrm{t}_{\mathrm{cf}}$ |  | 15 |  | 15 |  | 15 | ns |
| Clock Rise Time | $\mathrm{t}_{\mathrm{cr}}$ |  | 15 |  | 15 |  | 15 | ns |
| Address Delay Time | $\mathrm{t}_{\mathrm{AD}}$ |  | 110 |  | 90 |  | 80 | ns |
| Address Set-up Time ( $\overline{M E}$ or $\overline{\mathrm{OE}} \downarrow$ ) | $\mathrm{t}_{\text {AS }}$ | 50 |  | 30 |  | 20 |  | ns |
| $\overline{\mathrm{ME}}$ Delay Time 1 | $\mathrm{t}_{\text {MED } 1}$ |  | 85 |  | 60 |  | 50 | ns |
| $\overline{\mathrm{RD}}$ Delay Time 1 | $\mathrm{t}_{\text {RDD1 }}$ |  | 85 |  | 60 |  | 50 | ns |
| $\overline{\text { LIR Delay Time } 10100}$ | $\mathrm{t}_{\text {LD } 1}$ |  | 100 |  | 80 |  | 70* | ns |
| Address Hold Time 1 <br> ( $\overline{\mathrm{ME}}, \overline{\mathrm{IOE}}, \overline{\mathrm{RD}}$ or $\overline{W R} \uparrow$ ) | $\mathrm{t}_{\mathrm{AH}}$ | 80 |  | 35 |  | 20 |  | ns |
| $\overline{\mathrm{ME}}$ Delay Time 2 | $\mathrm{t}_{\text {MED2 }}$ |  | 85 |  | 60 |  | 50 | ns |
| $\overline{\mathrm{RD}}$ Delay Time 2 | $\mathrm{t}_{\text {RDD2 }}$ |  | 85 |  | 60 |  | 50 | ns |
| $\overline{L I R}$ Delay Time 2 | $\mathrm{t}_{\text {LD2 }}$ |  | 100 |  | 80 |  | 70* | $n s$ |
| Data Read Set-up Time | $t_{\text {DRS }}$ | 50 |  | 40 |  | 30 |  | ns |
| Data Read Hold Time | $t_{\text {DRH }}$ | 0 |  | 0 |  | 0 |  | ns |
| ST Delay Time 1 | ${ }^{\text {STD }}$ ( |  | 110 |  | 90 |  | 70 | ns |
| ST Delay Time 2 | ${ }_{\text {tstd2 }}$ |  | 110 |  | 90 |  | 70 | ns |
| $\overline{\text { WAIT Set-up Time }}$ | tws | 80 |  | 40 |  | 40 |  | ns |
| $\overline{\text { WAIT Hold Time }}$ | ${ }^{\text {WWH }}$ | 70 |  | 40 |  | 40 |  | ns |
| Write Data Floating Delay Time | ${ }_{\text {t }}^{\text {WDZ }}$ |  | 100 |  | 95 |  | 70 | ns |
| $\overline{\mathrm{WR}}$ Delay Time 1 | $t_{\text {WRD }}$ |  | 90 |  | 65 |  | 60 | ns |
| Write Data Delay Time | $t_{\text {WDD }}$ |  | 110 |  | 90 |  | 80 | ns |
| Write Data Set-up Time ( $\overline{W R} \downarrow$ ) | twos | 60 |  | 40 |  | 20 |  | ns |
| $\overline{W R}$ Delay Time 2 | $t_{\text {WRD2 }}$ |  | 90 |  | 80 |  | 60 | ns |
| $\overline{\overline{W R}}$ Pulse Width | $t_{\text {WRP }}$ | 280 |  | 170 |  | 130 |  | ns |

* For a loading capacitance of less than or equal to 40 picofarads and operating temperature from 0 to 50 degrees, substract 10 nanoseconds from the value given in the maximun columns.

| Item | Symbol | HD64180R -4 |  | HD64180R -6 |  | HD64180R -8 |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min | max | min | max | min | max |  |
| Write Data Hold Time ( $\overline{\mathrm{WR}} \uparrow$ ) | ${ }^{\text {W WDH }}$ | 60 |  | 40 |  | 15 |  | ns |
|  | $\mathrm{t}_{\text {IOD } 1}$ |  | 85 |  | 60 |  | 50 | ns |
| $\overline{\text { IOE }}$ Delay Time 2 | $\mathrm{t}_{10 \mathrm{D} 2}$ |  | 85 |  | 60 |  | 50 | ns |
| $\overline{\text { IOE Delay Time } 3}$ ( $\overline{\text { LIR }} \downarrow$ ) | $\mathrm{t}_{1003}$ | 540 |  | 340 |  | 250 |  | ns |
| $\overline{\text { INT }}$ Set-up Time ( $\phi \downarrow$ ) | $\mathrm{t}_{\text {INTS }}$ | 80 |  | 40 |  | 40 |  | ns |
| $\overline{\text { INT Hold Time }}$ ( $\phi \downarrow$ ) | $\mathrm{t}_{\text {INTH }}$ | 70 |  | 40 |  | 40 |  | ns |
| $\overline{\text { NMI Pulse Width }}$ | $\mathrm{t}_{\text {NMIW }}$ | 120 |  | 120 |  | 100 |  | ns |
| $\overline{B U S R E O}$ Set-up Time ( $\phi \downarrow$ ) | $\mathrm{t}_{\text {BRS }}$ | 80 |  | 40 |  | 40 |  | ns |
| BUSREQ Hold Time ( $\phi \downarrow$ ) | $\mathrm{t}_{\text {BRH }}$ | 70 |  | 40 |  | 40 |  | ns |
| BUSACK Delay Time 1 | $\mathrm{t}_{\text {BAD1 }}$ |  | 100 |  | 95 |  | 70 | ns |
| $\overline{\text { BUSACK }}$ Delay Time 2 | $\mathrm{t}_{\text {BAD2 }}$ |  | 100 |  | 95 |  | 70 | ns |
| Bus Floating Delay Time | $\mathrm{t}_{\text {BZD }}$ |  | 130 |  | 125 |  | 90 | ns |
| $\overline{\text { ME Pulse Width (HIGH) }}$ | $\mathrm{t}_{\text {MEWH }}$ | 200 |  | 110 |  | 90 |  | ns |
| $\overline{\mathrm{ME}}$ Pulse Width (LOW) | $\mathrm{t}_{\text {MEWL }}$ | 210 |  | 125 |  | 100 |  | ns |
| $\overline{\text { REF }}$ Delay Time 1 | $\mathrm{t}_{\text {RFD } 1}$ |  | 110 |  | 90 |  | 80 | ns |
| $\overline{\text { REF }}$ Delay Time 2 | $\mathrm{t}_{\text {RFD2 }}$ |  | 110 |  | 90 |  | 80 | ns |
| HALT Delay Time 1 | $\mathrm{t}_{\text {HAD1 }}$ |  | 110 |  | 90 |  | 80 | ns |
| HALT Delay Time 2 | $t_{\text {HAD2 }}$ |  | 110 |  | 90 |  | 80 | ns |
| $\overline{\text { DREQ }}$ i Set-up Time | $t_{\text {DRQS }}$ | 80 |  | 40 |  | 40 |  | ns |
| $\overline{\text { DREQ }}$ i Hold Time | $t_{\text {DRQH }}$ | 70 |  | 40 |  | 40 |  | ns |
| $\overline{\text { TEND }}$; Delay Time 1 | $\mathrm{t}_{\text {TED1 }}$ |  | 85 |  | 70 |  | 60 | ns |
| $\overline{\text { TEND }}$; Delay Time 2 | $\mathrm{t}_{\text {TED2 }}$ |  | 85 |  | 70 |  | 60 | ns |
| Enable Delay Time 1 | $\mathrm{t}_{\text {ED1 }}$ |  | 100 |  | 95 |  | 70 | ns |
| Enable Delay Time 2 | $\mathrm{t}_{\text {ED2 }}$ |  | 100 |  | 95 |  | 70 | ns |
| E Pulse Width (HIGH) | $\mathrm{P}_{\text {WEH }}$ | 150 |  | 75 |  | 65 |  | ns |
| E Pulse Width (LOW) | $P_{\text {Wel }}$ | 300 |  | 180 |  | 130 |  | ns |


| Item | Symbol | HD64180R -4 |  | HD64180R -6 |  | HD64180R -8 |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min | max | min | max | min | max |  |
| Enable Rise Time | $\mathrm{t}_{\mathrm{Er}}$ |  | 25 |  | 20 |  | 20 | ns |
| Enable Fall Time | $\mathrm{t}_{\mathrm{Ef}}$ |  | 25 |  | 20 |  | 20 | ns |
| Timer Output Delay Time | ${ }_{\text {t }}^{\text {TOD }}$ |  | 300 |  | 200 |  | 200 | ns |
| CSI/O Transmit Data <br> Delay Time <br> (Internal Clock Operation) | ${ }_{\text {tstoi }}$ |  | 200 |  | 200 |  | 200 | ns |
| CSI/O Transmit Data <br> Delay Time <br> (External Clock Operation) | $\mathrm{t}_{\text {StDe }}$ |  | $\begin{aligned} & 7.5 \mathrm{tcyc} \\ & +300 \end{aligned}$ |  | $\begin{aligned} & 7.5 \text { tcyc } \\ & +300 \end{aligned}$ |  | $\begin{aligned} & 7.5 \text { tcyc } \\ & +200 \end{aligned}$ | ns |
| CSI/O Receive Data <br> Set-up Time <br> (Internal Clock Operation) | ${ }^{\text {t }}$ SRS | 1 |  | 1 |  | 1 |  | teyc |
| CSI/O Receive Data <br> Hold Time <br> (Internal Clock Operation) | $\mathrm{t}_{\text {SRHI }}$ | 1 |  | 1 |  | 1 |  | tcyc |
| CSI/O Receive Data <br> Set-up Time <br> (External Clock Operation) | $\mathrm{t}_{\text {SRSE }}$ | 1 |  | 1 |  | 1 |  | tcyc |
| CSI/O Receive Data <br> Hold Time <br> (External Clock Operation) | $t_{\text {SRHE }}$ | 1 |  | 1 |  | 1 |  | tcyc |
| $\overline{\text { RESET Set-up Time }}$ | $t_{\text {RES }}$ | 120 |  | 120 |  | 100 |  | ns |
| RESET Hold Time | $\mathrm{t}_{\text {REH }}$ | 80 |  | 80 |  | 70 |  | ns |
| Oscillator Stabilization Time | tosc |  | 20 |  | 20 |  | 20 | ms |
| External Clock Rise Time (EXTAL) | $\mathrm{t}_{\text {EX }}$ |  | 25 |  | 25 |  | 25 | ns |
| External Clock fall Time (EXTAL) | $\mathrm{t}_{\mathrm{EXf}}$ |  | 25 |  | 25 |  | 25 | ns |
| $\overline{\text { RESET Rise Time }}$ | $\mathrm{t}_{\mathrm{Rr}}$ |  | 50 |  | 50 |  | 50 | ms |
| $\overline{\text { RESET Fall Time }}$ | $\mathrm{t}_{\text {Rf }}$ |  | 50 |  | 50 |  | 50 | ms |
| Input Rise Time (except EXTAL, $\overline{R E S E T}$ ) | $t_{1 r}$ |  | 100 |  | 100 |  | 100 | ns |
| Input fall Time (except EXTAL, $\overline{\text { RESET }}$ | $t_{\text {If }}$ |  | 100 |  | 100 |  | 100 | ns |


*1 Output buffer is off at this point.

Figure 1 CPU Timing (1)
(10) HITACHI


Figure 1 CPU Timing (2)


Figure 2 DMA Control Signals


Figure 3 E Clock Timing (1)


Figure 3 E Clock Timing (2)


Figure 4 Timer Output Timing


Figure 5 SLP Execution Cycle


Figure 6 CSI/O Receive/Transmit Timing



Reference Level (Input)


Reference Level (Output)


EXTAL Rise time and Fall time


Inputs, other than EXTAL, Rise time and Fall time

Figure 7 Bus Timing Test Load (TTL Load)

INDEX

1. PIN DESCRIPTION ..... 398
2. CPU REGISTERS ..... 400
3. ADRESSING MODES ..... 401
4. CPU BUS TIMING ..... 403
5. HALT AND LOW POWER OPERATION MODES ..... 408
6. INTERRUPTS ..... 410
7. MEMORY MANAGEMENT UNIT (MMU) ..... 420
8. DYNAMIC RAM REFRESH CONTROL ..... 424
9. WAIT STATE GENERATOR ..... 425
10. DMA CONTROLLER (DMAC) ..... 427
11. ASYNCHRONOUS SERIAL COMMUNICATION INTERFACE (ASCI) ..... 434
12. CLOCKET SERIAL I/O PORT (CSI/O) ..... 439
13. PROGRAMMABLE RELOAD TIMER (PRT) ..... 443
14. INTERNAL I/O REGISTERS ..... 446
15. E CLOCK OUTPUT TIMING -6800 TYPE BUS INTERFACE- ..... 449
16. ON-CHIP CLOCK GENERATOR ..... 451
17. MISCELLANEOUS ..... 453
18. OPERATION NOTES ..... 453
19. INSTRUCTION SET ..... 458
20. INSTRUCTION SUMMARY IN ALPHABETICAL ORDER ..... 474
21. OP-CODE MAP ..... 484
22. BUS AND CONTROL SIGNAL CONDITION IN EACH MACHINE CYCLE ..... 487
23. REQUEST ACCEPTANCES IN EACH OPERATING MODE ..... 506
24. REQUEST PRIORITY ..... 507
25. OPERATION MODE TRANSITION ..... 507
26. STATUS SIGNALS ..... 508
27. PIN STATUS DURING RESET AND LOW POWER OPERATION MODES ..... 509
28. INTERNAL I/O REGISTERS ..... 510

## 1 PIN DESCRIPTION

XTAL (IN)
Crystal oscillator connection. Should be left open if an external TTL clock is used. It is noted this input is not a TTL level input. See Table D.C. characteristics.

## EXTAL (IN)

Crystal oscillator connection. An external TTL clock can be input on this line. This input is schmitt triggered.

## $\phi$ (OUT)

System Clock. The frequency is equal to one-half of crystal oscillator.

## $\overline{\text { RESET }}$ - CPU Reset (IN)

When LOW, initializes the HD64180 CPU. All output signals are held inactive during RESET.
$A_{0}-A_{17}$ - Address Bus (OUT, 3-STATE)
$\mathrm{A}_{18}$ /TOUT
19-bit address bus provides physical memory addresses of up to 512 k bytes. The address bus enters the high impedance state during RESET and when another device acquires the bus as indicated by BUSREQ and BUSACK LOW. $\mathrm{A}_{18}$ is multiplexed with the TOUT output from PRT channel 1. During RESET, the address bus function is selected. TOUT function can be selected under software control.

## $\mathrm{D}_{0}-\mathrm{D}_{7}$ - Data Bus (IN/OUT, 3-STATE)

Bidirectional 8 -bit data bus. The data bus enters the high impedance state during RESET and when another device acquires the bus as indicated by BUSREQ and BUSACK LOW.

## $\overline{\mathrm{RD}}$ - Read (OUT, 3-STATE)

Used during a CPU read cycle to enable transfer from the external memory or I/O device to the CPU data bus.

## $\overline{W R}$ - Write (OUT, 3-STATE)

Used during a CPU write cycle to enable transfer from the CPU data bus to the external memory or I/O device.

## $\overline{M E}$ - Memory Enable (OUT, 3-STATE)

Indicates memory read or write operation. The HD64180 asserts ME LOW in the following cases.
(a) When fetching instructions and operands.
(b) When reading or writing memory data.
(c) During memory access cycles of DMA.
(d) During dynamic RAM refresh cycles.

## IOE - I/O Enable (OUT, 3-STATE)

Indicates I/O read or write operation. The HD64180 asserts $\overline{\mathrm{IOE}}$ LOW in the following cases.
(a) When reading or writing I/O data.
(b) During I/O access cycles of DMA.
(c) During $\overline{\mathrm{NT}}_{0}$ acknowledge cycle

## $\overline{\text { WAIT }}$ - Bus Cycle Wait (IN)

Introduces wait states to extend memory and I/O cycles. If LOW at the falling edge of $T_{2}$, a wait state (Tw) is inserted. Wait states will continue to be inserted until the WAIT input is sampled HIGH at the falling edge of Tw , at which time the bus cycle will proceed to completion.

## E - Enable (OUT)

Synchronous clock for connection to HD63 $\times \times$ series and other 6800/6500 series compatible peripheral LSIs.

[^11]places the address bus, data bus, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{ME}}$ and $\overline{\mathrm{IOE}}$ in the high impedance state.

## BUSACK - Bus Acknowledge (OUT)

When the CPU completes bus release (in response to BUSREQ LOW), it will assert BUSACK LOW. This acknowledges that the bus is free for use by the requesting device.

## $\overline{\text { HALT }}$ - Halt/Sleep Status (OUT)

Asserted LOW after execution of the HALT or SLP instructions. Used with $\overline{\text { LIR }}$ and ST output pins to encode CPU status.
$\overline{\text { LIR }}$ - Load Instruction Register (OUT)
Asserted LOW when the current cycle is an op-code fetch cycle. Used with HALT and ST output pins to encode CPU status.

ST - Status (OUT)
Used with the $\overline{\text { HALT }}$ and $\overline{\text { LIR }}$ output pins to encode CPU status.

Table 1 Status Summary

| ST | $\overline{\text { HALT }}$ | $\overline{\mathrm{LIR}}$ | Operation |
| :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | CPU operation <br> (1st op-code fetch) |
| 1 | 1 | 0 | CPU operation <br> (2nd op-code and <br> 3rd op-code fetch) |
| 1 | 1 | 1 | CPU operation <br> (MC except for op-code fetch) |
| 0 | X | 1 | DMA operation |
| 0 | 0 | 0 | HALT mode |
| 1 | 0 | 1 | SLEEP mode (including <br> SYSTEM STOP mode) |

NOTE) X: Don't care
MC: Machine cycle

## $\overline{\text { REF }}$ - Refresh (OUT)

When LOW, indicates the CPU is in the dynamic RAM refresh cycle and the low-order 8 bits ( $\mathrm{A}_{0}-\mathrm{A}_{7}$ ) of the address bus contain the refresh address.

## NMI - Non-Maskable Interrupt (IN)

When edge transition from HIGH to LOW is detected, forces the CPU to save certain state information and vector to an interrupt service routine at address 0066 H . The saved state information is restored by executing the RETN (Return from Non-Maskable Interrupt) instruction.

## INT - Maskable Interrupt Level 0 (IN)

When LOW, requests a CPU interrupt (unless masked) and saves certain state information unless masked by software. $\overline{\mathrm{INT}}_{0}$ requests service using one of three software programmable interrupt modes.

| Mode | Operation |
| :---: | :--- |
| 0 | Instruction fetched and executed from data bus. |
| 1 | Instruction fetched and executed from address <br> 0038 H. |
| 2 | Vector System - Low-order 8 bits vector table <br> address fetched from data bus. |

In all modes, the saved state information is restored by executing RETI (Return from Interrupt) instruction.
$\overline{\mathbf{I N T}_{1}}, \overline{\mathbf{N} \mathbf{N T}_{\mathbf{2}}}$ - Maskable Interrupt Level 1, $\mathbf{2}$ (IN)
When LOW, requests a CPU interrupt (unless masked) and saves certain state information unless masked by software. $\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ (and internally generated interrupts) request interrupt service using a vector system similar to Mode 2 of INT ${ }_{0}$.
$\overline{\text { DREQ }_{0}}$ - DMA Request - Channel 0 (IN)
When LOW (programmable edge or level sensitive), requests DMA transfer service from channel 0 of the HD64180 DMAC. $\overline{\mathrm{DREQ}}_{0}$ is used for Channel 0 memory $\longleftrightarrow$ I/O and memory $\longleftrightarrow$ memory mapped I/O transfers. DREQ ${ }_{0}$ is not used for memory $\longleftrightarrow$ memory transfers. This pin is multiplexed with $\mathrm{CKA}_{0}$.

## $\overline{T_{E N D}^{0}} \mathbf{~ - ~ T r a n s f e r ~ E n d ~ - ~ C h a n n e l ~} 0$ (OUT)

Asserted LOW synchronous with the last write cycle of channel 0 DMA transfer to indicate DMA completion to an external device. This pin is multiplexed with $\mathrm{CKA}_{1}$.

## $\overline{\text { DREQ }_{1}}$ - DMA Request - Channel 1 (IN)

When LOW (programmable edge or level sense), requests DMA transfer service from channel 1 of the HD64180 DMAC. Channel 1 supports Memory $\longleftrightarrow$ I/O transfers.
$\overline{\text { TEND }_{1}}$ - Transfer End - Channel 1 (OUT)
Asserted LOW synchronous with the last write cycle of channel 1 DMA transfer to indicate DMA completion to an external device.

TXA 0 - Asynchronous Transmit Data - Channel 0 (OUT)
Asynchronous transmit data from channel 0 of the Asynchronous Serial Communication Interface (ASCI).

RXA $\mathbf{D}_{0}$ - Asynchronous Receive Data - Channel 0 (IN)
Asynchronous receive data to channel 0 of the ASCI.
CKA $\mathbf{O}_{0}$ - Asynchronous Clock - Channel 0 (IN/OUT)
Clock input/output for channel 0 of the ASCI. This pin is multiplexed (software selectable) with $\mathrm{DREQ}_{0}$.
$\overline{\text { RTS }_{\mathbf{0}}}$ - Request to Send - Channel 0 (OUT)
Programmable modem control output signal for channel 0 of the ASCI.
$\overline{\text { CTS }_{0}}$ - Clear to Send - Channel O (IN)
Modem control input signal for channel 0 of the ASCI.
$\overline{D C D_{0}}$ - Data Carrier Detect - Channel 0 (IN)
Modem control input signal for channel 0 of the ASCI.
TXA 1 - Asynchronous Transmit Data - Channel 1 (OUT)
Asynchronous transmit data from channel 1 of the ASCI.

RXA 1 - Asynchronous Receive Data - Channel 1 (IN)
Asynchronous receive data to channel 1 of the ASCI.
CKA 1 - Asynchronous Clock - Channel 1 (IN/OUT)
Clock input/output for channel 1 of the ASCI. This pin is multiplexed (software selectable) with $\overline{\text { TEND }_{0}}$
$\overline{\text { CTS }_{1}}$ - Clear to Send - Channel 1 (IN)
Modem control input signal for channel 1 of the ASCI. This pin is multiplexed (software selectable) with RXS.

TXS - Clocked Serial Transmit Data (OUT)
Clocked serial transmit data from the Clocked Serial I/O Port (CSI/O).

RXS - Clocked Serial Receive Data (IN)
Clocked serial receive data to the CSI/O. This pin is multiplexed (software selectable) with ASCI channel $1 \overline{\mathrm{CTS}}_{1}$ modem control input

## CKS - Serial Clock (IN/OUT)

Input or output clock for the CSI/O.
TOUT - Timer Output (OUT)
Pulse output from Programmable Reload Timer channel 1. This pin is multiplexed (software selectable) with $\mathrm{A}_{18}$ (Address 18).
$\mathbf{V}_{\text {Cc }}$ - Power Supply
$\mathbf{V}_{\text {SS }}$ - Ground

## Multiplexed pin descriptions

## A 18 /TOUT

During RESET, this pin is initialized as $\mathrm{A}_{18}$ pin. If either TOC1 or TOC0 bit in Timer Control Register (TCR) is set to 1, TOUT function is selected.

If TOC1 and TOC0 bits are cleared to $0, \mathrm{~A}_{18}$ function is selected.
$\mathrm{CKA}_{0} / \overline{\mathrm{DREQ}_{0}}$
During RESET, this pin is initialized as CKA $_{0}$ pin. If either DM1 or SM1 in DMA Mode Register (DMODE) is set to $1, \overline{\mathrm{DREQ}_{0}}$ function is always selected.

## CKA $_{1} / \overline{\text { TEND }_{0}}$

During RESET, this pin is initialized as CKA Pin. If $_{\text {CKA1D }}$ bit in ASCI control register ch 1 (CNTLA1) is set to 1, TEND $_{0}$ function is selected. If CKA1D bit is set to $0, \mathrm{CKA}_{1}$ function is selected.

## RXS/ $\overline{\mathbf{C T S}_{1}}$

During RESET, this pin is initialized as RXS pin. If CTSIE bit in ASCI status register ch1 (STAT1) is set to $1, \overline{\mathrm{CTS}_{1}}$ function is selected.

If CTS1E bit is set to 0 , RXS function is selected.

## 2 CPU REGISTERS

The HD64180 CPU registers consist of Register Set GR, Register Set GR' and Special Registers.

The Register Set GR consists of 8-bit Accumulator (A), 8-bit Flag Register (F), and three General Purpose Registers (BC, DE, and HL) which may be treated as 16 -bit registers (BC, DE, and HL ) or as individual 8-bit registers ( $B, C, D, E, H$, and $L$ ) depending on the instruction to be executed. The Register Set GR' is alternate register set of Register Set GR and also contains Accumulator
(A'), Flag Register (F') and three General Purpose Registers (BC', DE', and HL'). While the alternate Register Set GR' contents are not directly accessible, the contents can be programmably exchanged at high speed with those of Register Set GR.

The Special Registers consist of 8-bit Interrupt Vector Register (I), 8-bit R Counter (R), two 16-bit Index Registers (IX and IY), 16-bit Stack Pointer (SP), and 16-bit Program Counter (PC).

Fig. 8 shows CPU registers configuration.


Register Set GR'

| Accumulator <br> $A^{\prime}$ | Flag Register <br> $F^{\prime}$ |
| :---: | :---: |
| $B^{\prime}$ Register | C' $^{\prime}$ Register |
| $D^{\prime}$ Register | E' $^{\prime}$ Register |
| $H^{\prime}$ Register | L' $^{\prime}$ Register |
| General <br> Purpose <br> Registers |  |

Special Registers

| Interrupt <br> Vector Register <br> I | R Counter <br> R |
| :--- | :--- |
| Index Register | IX |
| Index Register | IY |
| Stack Pointer | SP |
| Program Counter PC |  |

Figure 8 CPU Register Configuration

### 2.1 Register Description

(1) Accumulator ( $A, A^{\prime}$ )

The Accumulator (A) serves as the primary register used for many arithmetic, logical and I/O instructions.

## (2) Flag Registers (F, F')

The flag register stores various status bits (described in the next section) which reflect the results of instruction execution.
(3) General Purpose Registers (BC, BC', DE, DE', HL, HL')

The General Purpose Registers are used for both address and data operation. Depending on instruction, each half ( 8 bits ) of these registers (B, C, D, E, H, and L) may also be used.

## (4) Interrupt Vector Register (I)

For interrupts which require a vector table address to be calculated ( $\overline{\mathrm{INT}}_{0}$ Mode 2, $\overline{\mathrm{INT}}_{1}, \overline{\mathrm{INT}}_{2}$ and internal interrupts), the Interrupt Vector Register (I) provides the most significant byte of the vector table address.

## 5) R Counter (R)

The least significant seven bits of the $R$ Counter ( $R$ ) serve to count the number of instructions executed by the HD64180. R is
incremented for each CPU op-code fetch cycles (each LIR cycles).

## (6) Index Registers (IX, and IY)

The Index Registers are used for both address and data operations. For addressing, the contents of a displacement specified in the instruction are added to or subtracted from the Index Register to determine an effective operand address.

## (7) Stack Pointer (SP)

The Stack Pointer (SP) contains the memory address based LIFO stack.

## (8) Program Counter (PC)

The Program Counter (PC) contains the address of the instruction to be executed and is automatically updated after each instruction fetch.

## (9) Flag Register (F)

The Flag Register stores the logical state reflecting the results of instruction execution. The contents of the Flag Register are used to control program flow and instruction operation.
bit


Flag Register (F)

## S: Sign (bit 7)

S stores the state of the most significant bit (bit 7) of the result. This is useful for operations with signed numbers in which values with bit $7=1$ are interpreted as negative.

## Z: Zero (bit 6)

$\mathbf{Z}$ is set to 1 when instruction execution results containing 0 . Otherwise, $Z$ is reset to 0 .

## H: Half Carry (bit 4)

$H$ is used by the DAA (Decimal Adjust Accumulator) instruction to reflect borrow or carry from the least significant 4 bits and thereby adjust the results of BCD addition and subtraction.

## P/V: Parity/Overflow (bit 2)

P/V serves a dual purpose. For logical operations P/V is set to 1 if the number of 1 bit in the result is even and $P / V$ is reset to 0 if the number of 1 bit in the result is odd. For two complement arithmetic, $\mathrm{P} / \mathrm{V}$ is set to 1 if the operation produces a result which is outside the allowable range $(+127$ to -128 for 8 -bit operations, +32767 to -32768 for 16 -bit operations).

## N: Negative (bit 1)

$\mathbf{N}$ is set to 1 if the last arithmetic instruction was a subtract operation (SUB, DEC, CP, etc.) and $N$ is reset to 0 if the last arithmetic
instruction was an addition operation (ADD, INC, etc.).

## C: Carry (bit 0)

C is set to 1 when a carry (addition) or borrow (subtraction) from the most significant bit of the result occurs. $C$ is also affected by Accumulator logic operations such as shifts and rotates.

3 ADDRESSING MODES
The HD64180 instruction set includes eight addressing modes.
Implied Register
Register Direct
Register Indirect
Indexed
Extended
Immediate
Relative
IO
(1) Implied Register (IMP)

Certain op-codes automatically imply register usage, such as the arithmetic operations which inherently reference the Accumulator, Index Registers, Stack Pointer and General Purpose Registers.

## (2) Register Direct (REG)

Many op-codes contain bit fields specifying registers to be used for the operation. The exact bit field definition vary depending on instruction as follows.

| ww field | Register |
| :---: | :---: |
| $0 \quad 0$ | B C |
| $0 \quad 1$ | D E |
| $1 \quad 0$ | HL |
| $1 \quad 1$ | S P |


| $x x$ field | Register |
| :---: | :---: |
| $0 \quad 0$ | B C |
| $0 \quad 1$ | D E |
| $1 \quad 0$ | IX |
| $1 \quad 1$ | S P |


| yy field | Register |
| :---: | :---: |
| $0 \quad 0$ | B C |
| 01 | D E |
| $1 \quad 0$ | IY |
| $1 \quad 1$ | S P |

## 16-bit Register

| zz field | Register |
| :---: | :---: |
| $0 \quad 0$ | B C |
| 01 | D E |
| $1 \quad 0$ | HL |
| $1 \quad 1$ | A F |

8-bit Register

| g or $\mathrm{g}^{\prime}$ field |  | Register |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | B |
| 0 | 0 | 1 | C |
| 0 | 1 | 0 | D |
| 0 | 1 | 1 | E |
| 1 | 0 | 0 | H |
| 1 | 0 | 1 | L |
| 1 | 1 | 0 | - |
| 1 | 1 | 1 | A |

Suffixed $H$ and $L$ to $w w, x x, y y, z z$ (ex. $w w H, I X L$ ) indicate upper and lower 8-bit of the 16-bit register respectively.

## (3) Register Indirect (REG)

The memory operand address is contained in one of the 16 -bit General Purpose Registers (BC, DE and HL).

(4) Indexed (INDX)

The memory operand address is calculated using the contents of an Index Register (IX or IY) and an 8-bit signed displacement specified in the instruction.

(5) Extended (EXT)

The memory operand address is specified by two bytes contained in the instruction.


## (6) Immediate (IMMED)

The memory operands are contained within one or two bytes of the instruction.


## (7) Relative (REL)

Relative addressing mode is only used by the conditional and unconditional branch instructions. The branch displacement (relative to the contents of the program counter) is contained in the instruction.


## (8) 10 (10)

IO addressing mode is used only by I/O instructions. This mode specifies I/O address ( $\overline{\mathrm{IOE}}=0$ ) and outputs them as follows.
(1) An operand is output to $A_{0}-A_{7}$. The Contents of Accumulator is output to $A_{8}-A_{15}$.
(2) The Contents of Register $B$ is output to $A_{0}-A_{7}$. The Contents of Register $C$ is output to $\mathbf{A}_{\mathbf{8}}-A_{15}$.
(3) An operand is output to $A_{0}-A_{7} .00 H$ is output to $A_{8}-A_{15}$. (useful for internal I/O register access)
(4) The Contents of Register $C$ is output to $A_{0}-A_{7} .00 \mathrm{H}$ is output to $\mathrm{A}_{8}-\mathrm{A}_{15}$.
(useful for internal I/O register access)

## 4 CPU BUS TIMING

This section explains the HD64180 CPU timing for the following operations.
(1) Instruction (op-code) fetch timing.
(2) Operand and data read/write timing.
(3) I/O read/write timing.
(4) Basic instruction (fetch and execute) timing.
(5) RESET timing.
(6) $\overline{\text { BUSREQ }} / \overline{\mathrm{BUSACK}}$ bus exchange timing.

The basic CPU operation consists of one or more "machine cycles" (MC). A machine cycle consists of three system clocks, $T_{1}, T_{2}$ and $T_{3}$ while accessing memory or I/O, or it consists of one system clock, Ti while the CPU internal operation. The system clock $(\phi)$ is half frequency of crystal oscillation (Ex. 8 MHz crystal $\longrightarrow \phi$ of 4
$\mathrm{MHz}, 250 \mathrm{nsec}$ ). For interfacing to slow memory or peripherals, optional wait states (Tw) may be inserted between $\mathrm{T}_{2}$ and $\mathrm{T}_{3}$.

### 4.1 Instruction (op-code) Fetch Timing

Fig. 9 shows the instruction (op-code) fetch timing with no wait states.

An op-code fetch cycle is externally indicated when the LIR (Load Instruction Register) output pin is LOW.

In the first half of $\mathrm{T}_{1}$, the address bus $\left(\mathrm{A}_{0}-\mathrm{A}_{18}\right)$ is driven with the contents of the Program Counter (PC). Note that this is the translated address output of the HD64180 on-chip MMU.

In the second half of $T_{1}$, the $\overline{M E}$ (Memory Enable) and $\overline{\mathrm{RD}}$ (Read) signals are asserted LOW, enabling the memory.

The op-code on the data bus is latched at the rising edge of $\mathrm{T}_{3}$ and the bus cycle terminates at the end of $\mathrm{T}_{3}$.


Figure 9 Op-Code Fetch Timing

Fig. 10 illustrates the insertion of wait states (Tw) into the opcode fetch cycle. Wait states (Tw) are controlled by the external WAIT input combined with an on-chip programmable wait state generator.

At the falling edge of $T_{2}$ the combined $\overline{\text { WAIT }}$ input is sampled. If
$\overline{\text { WAIT }}$ input is asserted LOW, a wait state (Tw) is inserted. The address bus, $\overline{\mathrm{ME}}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{LIR}}$ are held stable during wait states. When the WAIT is sampled inactive HIGH at the falling edge of Tw , the bus cycle enters $\mathrm{T}_{3}$ and completes at the end of $\mathrm{T}_{3}$.


Figure 10 Op-Code Fetch Timing (with wait state)

### 4.2 Operand and Data Read/Write Timing

The instruction operand and data read/write timing differs from op-code fetch timing in two ways. First, the LIR output is held inactive. Second, the read cycle timing is relaxed by one-half clock cycle since data is latched at the falling edge of $\mathrm{T}_{3}$.

Instruction operands include immediate data, displacement and extended addresses and have the same timing as memory data reads.

During memory write cycles the $\overline{\mathrm{ME}}$ signal goes active in the
second half of $T_{1}$. At the end of $T_{1}$, the data bus is driven with the write data

At the start of $\mathrm{T}_{2}$ the $\overline{\mathrm{WR}}$ signal is asserted LOW enabling the memory. ME and $\overline{W R}$ go inactive in the second half of $\mathrm{T}_{3}$ followed by deactivation of the write data on the data bus.

Wait states (Tw) are inserted as previously described for op-code fetch cycles.

Fig. 11 illustrates the read/write timing without wait states (Tw), while Fig. 12 illustrates read/write timing with wait states (Tw).


Figure 11 Memory Read/Write Timing (without wait state)


Figure 12 Memory Read/Write Timing (with wait state)

### 4.3 I/O Read/Write Timing

I/O instructions cause data read/write transfer which differs from memory data transfer in the following three ways. The $\overline{\mathrm{IOE}}$ (I/ O Enable) signal is asserted LOW instead of the ME signal. The 16bit I/O address is not translated by the MMU and $\mathrm{A}_{16}-\mathrm{A}_{18}$ are held

LOW. At least one wait state (Tw) is always inserted for I/O read and write cycles (except internal I/O cycles).

Fig. 13 shows I/O read/write timing with the automatically inserted wait state (Tw).


Figure 13 I/ORead/Write Timing

### 4.4 Basic Instruction Timing

An instruction may consist of a number of machine cycles including op-code fetch, operand fetch and data read/write cycles. An instruction may also include cycles for internal processing in which case the bus is idle.

The example in Fig. 14 illustrates the bus timing for the data transfer instruction LD (IX+d),g. This instruction moves the contents of a CPU register (g) to the memory location with address
computed by adding an signed 8 -bit displacement (d) to the contents of an index register (IX).

The instruction cycle starts with the two machine cycles to read the two bytes instruction op-code as indicated by LIR LOW. Next, the instruction operand (d) is fetched.

The external bus is idle while the CPU computes the effective address. Finally, the computed memory location is written with the contents of the CPU register (g).


Figure 14 LD ( $\mathrm{IX}+\mathrm{d}$ ), g Instruction Tíming

### 4.5 RESET Timing

Fig. 15 shows the HD64180 hardware RESET timing. If the RESET pin is LOW for at least six clock cycles, processing is termi-
nated and the HD64180 restarts execution from (logical and physical) address 00000 H .


Figure 15 RESET Timing

## 4.6 $\overline{\text { BUSREQ }} / \overline{B U S A C K}$ Bus Exchange Timing

The HD64180 can coordinate the exchange of control, address and data bus ownership with another bus master. The alternate bus master can request the bus release by asserting the BUSREQ (Bus Request) input LOW. After the HD64180 releases the bus, it relinquishes control to the alternate bus master by asserting the BUSACK (Bus Acknowledge) output LOW.

The bus may be released by the HD64180 at the end of each machine cycle. In this context a machine cycle consists of a minimum of 3 clock cycles (more if wait states are inserted) for op-code fetch, memory read/write and I/O read/write cycles. Except for these cases, a machine cycle corresponds to one clock cycle.

When the bus is released, the address $\left(A_{0}-A_{18}\right)$, data $\left(D_{0}-D_{7}\right)$
and control ( $\overline{\mathrm{ME}}, \overline{\mathrm{IOE}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ ) signals are placed in the high impedance state.

Note that dynamic RAM refresh is not performed when the HD64180 has released the bus. The alternate bus master must provide dynamic memory refreshing if the bus is released for long periods of time.

Fig. 16 illustrates $\overline{\text { BUSREQ }} / \overline{\text { BUSACK }}$ bus exchange during a memory read cycle. Fig. 17 illustrates bus exchange when the bus release is requested during an HD64180 CPU internal operation. BUSREQ is sampled at the falling edge of the system clock prior to $\mathrm{T}_{3}, \mathrm{Ti}$ and Tx (BUS RELEASE state). If BUSREQ is asserted LOW at the falling edge of the clock state prior to Tx, another Tx is executed.


Figure 16 Bus Exchange Timing (1)


Figure 17 Bus Exchange Timing (2)

## (直) HITACHI

## 5 HALT AND LOW POWER OPERATION MODES

The HD64180 can operate in 4 different modes. HALT mode, IOSTOP mode and two low power operation modes - SLEEP and SYSTEM STCP. Note that in all operating modes, the basic CPU clock (XTAL, EXTAL) must remain active.

### 5.1 HALT Mode

HALT mode is entered by execution of the HALT instruction (op-code $=76 \mathrm{H}$ ) and has the following characteristics.
(1) The internal CPU clock remains active.
(2) All internal and external interrupts can be received.
(3) Bus exchange ( $\overline{\mathrm{BUSREQ}}$ and $\overline{\mathrm{BUSACK}}$ ) can occur.
(4) Dynamic RAM refresh cycle ( $\overline{\mathrm{REF}}$ ) insertion continues at the programmed interval.
(5) I/O operations (ASCI, CSI/O and PRT) continue.
(6) The DMAC can operate.
(7) The $\overline{\text { HALT }}$ output pin is asserted LOW.
(8) The external bus activity consists of repeated 'dummy' fetches of the op-code following the HALT instruction.

Essentially, the HD64180 operates normally in HALT mode, except that instruction execution is stopped.

HALT mode can be exited in the following two ways.

## RESET Exit from HALT Mode

If the RESET input is asserted LOW for at least six clock cycles, HALT mode is exited and the normal RESET sequence (restart at address 00000 H ) is initiated.

## Interrupt Exit from HALT Mode

When an internal or external interrupt is generated, HALT mode is exited and the normal interrupt response sequence is initiated.

If the interrupt source is masked (individually by enable bit, or globally by $\mathrm{IEF}_{1}$ state), the HD64180 remains in HALT mode. However, NMI interrupt will initiate the normal NMI interrupt response sequence independent of the state of $\mathrm{IEF}_{1}$.

HALT timing is shown in Fig. 18.


Figure 18 HALT Timing

### 5.2 SLEEP Mode

SLEEP mode is entered by execution of the 2 byte SLP instruction. SLEEP mode has the following characteristics.
(1) The internal CPU clock stops, reducing power consumption.
(2) The internal crystal oscillator does not stop.
(3) Internal and external interrupt inputs can be received.
(4) DRAM refresh cycles stop.
(5) I/O operations using on-chip peripherals continue.
(6) The internal DMAC stop.
(7) BUSREQ can be received and acknowledged.
(8) Address outputs go HIGH and all other control signal output become inactive HIGH.
(9) Data Bus, 3-state.

SLEEP mode is exited in one of two ways as shown below.

## RESET Exit from SLEEP Mode

If the RESET input is held LOW for at least six clock cycles, the HD64180 will exit SLEEP mode and begin the normal RESET sequence with execution starting at address (logical and physical) 00000 H .

## Interrupt Exit from SLEEP Mode

The SLEEP mode is exited by detection of an external ( $\overline{\mathrm{NMI}}$, $\overline{\mathrm{INT}_{0}}, \overline{\mathrm{INT}}_{1}, \overline{\mathrm{INT}}_{2}$ ) or internal (ASCI, CSI/O, PRT) interrupt.

In the case of NMI, SLEEP Mode is exited and the CPU begins the normal NMI interrupt response sequence.

In the case of all other interrupts, the interrupt response depends on the state of the global interrupt enable flag ( $\mathrm{IEF}_{1}$ ) and the individual interrupt source enable bit.

If the individual interrupt condition is disabled by the corresponding enable bit, occurrence of that interrupt is ignored and the CPU remains in the SLEEP state.

Assuming the individual interrupt condition is enabled, the response to that interrupt depends on the global interrupt enable flag $\left(\mathrm{IEF}_{1}\right)$. If interrupts are globally enabled $\left(\mathrm{IEF}_{1}=1\right)$ and an individually enabled interrupt occurs, SLEEP mode is exited and the appropriate normal interrupt response sequence is executed.

If interrupts are globally disabled $\left(\mathrm{IEF}_{1}=0\right)$ and an individually enabled interrupt occurs, SLEEP mode is exited and instruction execution begins with the instruction following the SLP instruction. Note that this provides a technique for synchronization with high speed external events without incurring the latency imposed by an interrupt response sequence.
Fig. 19 shows SLEEP timing.

### 5.3 IOSTOP Mode

IOSTOP mode is entered by setting the IOSTP bit of the I/O Control Register (ICR) to 1. In this case, on-chip I/O (ASCI, CSI/ O, PRT) stops operating. However, the CPU continues to operate. Recovery from IOSTOP mode is by clearing the IOSTP bit in ICR to 0 .

### 5.4 SYSTEM STOP Mode

SYSTEM STOP mode is the combination of SLEEP and IOSTOP modes. SYSTEM STOP mode is entered by setting the IOSTP bit in ICR to 1 followed by execution of the SLP instruction. In this mode, on-chip I/O and CPU stop operating, reducing power consumption. Recovery from SYSTEM STOP mode is the same as recovery from SLEEP mode, noting that internal I/O sources (disabled by IOSTOP) cannot generate a recovery interrupt.


Figure 19 SLEEP Timing

## 6 INTERRUPTS

The HD64180 CPU has twelve interrupt sources, four external and eight internal, with fixed priority.

This section explains the CPU registers associated with interrupt
processing, the TRAP interrupt, interrupt response modes and the external interrupts. The detailed discussion of internal interrupt generation (except TRAP) is presented in the appropriate hardware section (i.e. PRT, DMAC, ASCI and CSI/O).

| Priority |  | Interrupt | Internal Interrupt |
| :---: | :---: | :---: | :---: |
| Higher | 1 | TRAP (Undefined Op-code Trap) |  |
| Priority | 2 | $\overline{\text { NMT }}$ (Non Maskable Interrupt) |  |
|  | 3 | $\overline{\mathrm{INTo}_{0}}$ (Maskable Interrupt Level 0) | External Interrupt |
|  | 4 | $\overline{\mathrm{NT}_{1}}$ (Maskable Interrupt Level 1) |  |
|  | 5 | $\overline{\mathrm{NT}_{2}}$ (Maskable Interrupt Level 2) |  |
|  | 6 | Timer 0 |  |
|  | 7 | Timer 1 |  |
|  | 8 | DMA channel 0 |  |
|  | 9 | DMA channel 1 | Internal Interrupt |
| $\downarrow$ | 10 | Clocked Serial I/O Port |  |
| Lower | 11 | Asynchronous SCl channel 0 |  |
| Priority ${ }^{\prime}$ | 12 | Asynchronous SCI channel 1 |  |

Figure 20 Interrupt Sources

### 6.1 Interrupt Control Registers and Flags

The HD64180 contains three registers and two flags which are associated with interrupt processing.

| Register and <br> Flag Name | Function | Access Method |
| :---: | :--- | :--- |
| I | Contains upper 8-bit <br> of interrupt vector | LD A, I and <br> LD I, A instructions |
| IL | Contains lower 8-bit <br> of interrupt vector | I/O instruction <br> (addr $=33 H)$ |
| ITC | Interrupt/Trap control | I/O instruction <br> (addr $=34 H$ ) |
| IEF $_{1}, \mathrm{IEF}_{2}$ | Enable/disable <br> interrupt | EI, DI, <br> LD A, I, and <br> LD A, R instructions |

## (1) Interrupt Vector Register (I)

Mode 2 for $\overline{\mathrm{INT}}_{0}$ external interrupt, $\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ external interrupts and all internal interrupts (except TRAP) use a programmable vectored technique to determine the address at which interrupt processing starts. In response to the interrupt a 16 -bit address is generated. This address accesses a vector table in memory to obtain the address at which execution restarts.

While the method for generation of the least significant byte of the table address differs, all vectored interrupts use the contents of I as the most significant byte of the table address. By programming the contents of I, vector tables can be relocated on 256 bytes boundaries throughout the 64 k bytes logical address space.

Note that I is read/written with the LD A, I and LD I, A instructions rather than I/O (IN, OUT) instructions.

I is initialized to 00 H during RESET.
(2) Interrupt Vector Low Register (IL) Interupt Vector Low Register (IL : $/ 1 \mathrm{O}$ Address $=\mathbf{3 3 H}$ )


This register determines the most significant three bits of the low-order byte of the interrupt vector table address for external interrupts $\overline{\mathrm{NT}}_{1}$ and $\overline{\mathrm{NT}}_{2}$ and all internal interrupts (except TRAP). The five least significant bits are fixed for each specific interrupt source. By programming IL the vector table can be relocated on 32 bytes boundaries.

IL is initialized to 00 H during RESET.
(3) INT/TRAP Control Register (ITC)

INT/TRAP Control Register (ITC : //O Address $=\mathbf{3 4 H}$ )


ITC is used to handle TRAP interrupts and to enable or disable the external maskable interrupt inputs $\mathrm{INT}_{0}, \overline{\mathrm{INT}}_{1}$, and $\overline{\mathrm{INT}}_{2}$.

## TRAP (bit 7)

This bit is set to 1 when an undefined op-code is fetched. TRAP can be reset under program control by writing it with 0 , however it cannot be written with 1 under program control. TRAP is cleared to 0 during RESET.

## UFO: Undefined Fetch Object (bit 6)

When a TRAP interrupt occurs (TRAP bit is set to 1 ), the contents of UFO allow determination of the starting address of the undefined instruction. This is necessary since the TRAP may occur on either the second or third byte of the op-code. UFO allows the stacked PC value (stacked in response to TRAP) to be correctly adjusted. If UFO $=0$, the first op-code should be interpreted as the stacked PC-1. If UFO $=1$, the first op-code address is stacked PC-2. UFO is read-only.

## ITE2,1,0: Interrupt Enable 2,1,0 (bits 2-0)

ITE2, ITE1 and ITE0 enable and disable the external interrupt inputs $\overline{\mathrm{INT}}_{2}, \overline{\mathrm{INT}}_{1}$, and $\overline{\mathrm{INT}}_{0}$ respectively. If cleared to 0 , the interrupt is masked. During RESET, ITE0 is initialized to 1 while ITE1 and ITE2 are initialized to 0 .

## - Interrupt Enable Flag $\mathbf{1 , 2}\left(\mathbf{I E F}_{1}, \mathrm{IEF}_{\mathbf{2}}\right)$

IEF $_{1}$ controls the overall enabling and disabling of all internal and external maskable interrupts (i.e. all interrupts except $\overline{\text { NMI }}$ and

TRAP).
If $\mathrm{IEF}_{1}=0$, all maskable interrupts are disabled. $\mathrm{IEF}_{1}$ can be reset to 0 by the DI (Disable Interrupts) instruction and set to 1 by the EI (Enable Interrupts) instruction.

The purpose of $\mathrm{IEF}_{2}$ is to correctly manage the occurrence of $\overline{\text { NMI. During }} \overline{\text { NMI, }}$, the prior interrupt reception state is saved and all maskable interrupts are automatically disabled ( $\mathrm{IEF}_{1}$ copied to
$\mathrm{IEF}_{2}$ and then $\mathrm{IEF}_{1}$ cleared to 0 ). At the end of the $\overline{\mathrm{NMI}}$ interrupt service routine, execution of the RETN (Return from Non-maskable Interrupt) will automatically restore the interrupt receiving state (by copying $\mathrm{IEF}_{2}$ to $\mathrm{IEF}_{1}$ ) prior to the occurrence of NMI.
$\mathrm{IEF}_{2}$ state can be reflected in the P/V bit of the CPU Status register by executing LD A, I or LD A, R instructions.

Table 2 shows the state of $\mathrm{IEF}_{1}$ and $\mathrm{IEF}_{2}$.

Table 2 State of IEF ${ }_{1}$ and IEF $_{2}$

| CPU Operation | IEF $_{1}$ | IEF $_{2}$ |  |
| :--- | :---: | :---: | :--- |
| RESET | 0 | 0 | REMARKS |
| $\overline{\text { NMI }}$ | 0 | IEF $_{1}$ | Copies the contents of IEF ${ }_{1}$ to IEF |
| 2 |  |  |  |$]$.

### 6.2 TRAP Interrupt

The HD64180 generates a non-maskable (not affected by the state of IEF ${ }_{1}$ ) TRAP interrupt when an undefined op-code fetch occurs. This feature can be used to increase software reliability, implement an 'extended' instruction set, or both. TRAP may occur during op-code fetch cycles and also if an undefined op-code is fetched during the interrupt acknowledge cycle for $\overline{\mathrm{INT}_{0}}$ when Mode 0 is used.

When a TRAP interrupt occurs the HD64180 operates as follows.
(1) The TRAP bit in the Interrupt TRAP/Control (ITC) register is set to 1 .
(2) The current PC (Program Counter) value, reflecting the location of the undefined op-code, is saved on the stack.
(3) The HD64180 vectors to logical address 0 . Note that if logical
address 0000 H is mapped to physical address 00000 H , the vector is the same as for RESET. In this case, testing the TRAP bit in ITC will reveal whether the restart at physical address 00000 H was caused by RESET or TRAP.

The state of the UFO (Undefined Fetch Object) bit in ITC allows TRAP manipulation software to correctly 'adjust' the stacked PC depending on whether the second or third byte of the op-code generated the TRAP. If UFO $=0$, the starting address of the invalid instruction is equal to the stacked $P C-1$. If $U F O=1$, the starting address of the invalid instruction is equal to the stacked PC -2 . Fig. 21 shows TRAP Timing.

Note that Bus Release cycle, Refresh cycle, DMA cycle and WAIT cycle can't be inserted just after $\mathrm{T}_{\text {TP }}$ state which is inserted for TRAP interrupt sequence.


Figure 21 (a) TRAP Timing - 2nd Op-code Undefined


Figure 21 (b) TRAP Timing - 2nd Op-code Undefined

### 6.3 External Interrupts

The HD64180 has four external hardware interrupt inputs.
(1) NMI - Non-maskable Interrupt
(2) $\overline{\mathrm{INT}_{0}}$ - Maskable Interrupt Level 0
(3) $\mathrm{INT}_{1}$ - Maskable Interrupt Level 1
(4) $\overline{\mathrm{INT}}_{2}-$ Maskable Interrupt Level 2
$\overline{\mathrm{NMI}}, \overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ have fixed interrupt response modes. $\overline{\mathrm{INT}}_{0}$ has three different software programmable interrupt response modes - Mode 0, Mode 1 and Mode 2.

### 6.4 NMI - Non-Maskable Interrupt

The NMI interrupt input is edge sensitive and cannot be masked by software. When NMI is detected, the HD64180 operates as follows.
(1) DMAC operation is suspended by clearing the DME (DMA Main Enable) bit in DCNTL.
(2) The PC is pushed onto the stack.
(3) The contents of $\mathrm{IEF}_{1}$ are copied to $\mathrm{IEF}_{2}$. This saves the interrupt reception state that existed prior to NMI.
(4) $\mathrm{IEF}_{1}$ is cleared to 0 . This disables all external and internal maskable interrupts (i.e. all interrupts except $\overline{\mathrm{NMI}}$ and TRAP).
(5) Execution commences at logical address 0066 H .

The last instruction of an NMI service routine should be RETN (Return from Non-maskable Interrupt). This restores the stacked PC, allowing the interrupted program to continue. Furthermore, RETN causes $\mathrm{IEF}_{2}$ to be copied to $\mathrm{IEF}_{1}$, restoring the interrupt reception state that existed prior to the NMI

Note that NMI, since it can be accepted during HD64180 onchip DMAC operation, can be used to externally interrupt DMA transfer. The NMI service routine can reactivate or abort the DMAC operation as required by the application.

For NMI, special care must be taken to insure that interrupt inputs do not 'overrun' the $\overline{\text { NMI }}$ service routine. Unlimited $\overline{\text { NMI }}$ inputs without a corresponding number of RETN instructions will eventually cause stack overflow.

Fig. 22 shows the use of NMI and RETN while Fig. 23 details $\overline{\text { NMI }}$ response timing. $\overline{\text { NMI }}$ is edge sensitive and the internally latched NMI falling edge is held until it is sampled. If the falling edge of NMI is latched before the falling edge of clock state prior to $\mathrm{T}_{3}$ or Ti in the last machine cycle, the internally latched NMI is sampled at the falling edge of the clock state prior to $\mathrm{T}_{3}$ or Ti in the last machine cycle and NMI acknowledge cycle begins at the end of the current machine cycle.


Figure 22 NMI Sequence


Figure 23 NMI Timing

## $6.5 \overline{\mathbf{I N T}_{0}}$ - Maskable Interrupt Level 0

The next highest priority external interrupt after $\overline{\mathrm{NMI}}$ is $\overline{\mathrm{INT}_{0}}$. $\overline{\mathrm{INT}}_{0}$ is sampled at the falling edge of the clock state prior to $\mathrm{T}_{3}$ or Ti in the last machine cycle. If $\mathrm{INT}_{0}$ is asserted LOW at the falling edge of the clock state prior to $\mathrm{T}_{3}$ or Ti in the last machine cycle, $\overline{\mathrm{INT}}_{0}$ is accepted. The interrupt is masked if either the IEF, flag or the ITE0 (Interrupt Enable 0) bit in ITC are cleared to 0 . Note that after RESET the state is as follows.
(1) $\mathrm{IEF}_{1}$ is 0 , so $\mathrm{INT}_{0}$ is masked.
(2) ITE 0 is 1 , so $\overline{\mathrm{INT}}_{0}$ is enabled by execution of the EI (Enable Interrupts) instruction.
The $\overline{\mathrm{INT}}_{0}$ interrupt is unique in that three programmable interrupt response modes are available - Mode 0 , Mode 1, and Mode 2. The specific mode is selected with the IM 0, IM 1 and IM 2 (Set Interrupt Mode) instructions. During RESET, the HD64180 is initialized to use Mode 0 for $\overline{\overline{I N T}_{0}}$.

The three interrupt response modes for $\overline{\mathrm{INT}}_{0}$ are...
(1) Mode 0 -- Instruction fetch from data bus.
(2) Mode 1 - Restart at logical address 0038 H .
(3) Mode 2 - Low byte vector table address fetch from data bus.

## $\overline{\mathbf{N N T}_{0}}$ Mode 0

During the interrupt acknowledge cycle, an instruction is fetched from the data bus ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) at the rising edge of $\mathrm{T}_{3}$. Often, this instruction is one of the eight single byte RST (RESTART) instructions which stack the PC and restart execution at a fixed logical address. However, multibyte instructions can be processed if the interrupt acknowledging device can provide a multibyte response. Unlike all other interrupts, the PC is not automatically stacked.

Note that TRAP interrupt will occur if an invalid instruction is fetched during $\overline{I N T}_{0}$ Mode 0 interrupt acknowledge.

Fig. 24 shows $\mathrm{INT}_{0}$ Mode 0 Timing.


Figure 24 *Two wait states are aut

INT Mode 1
When $\mathrm{INT}_{0}$ is received, the PC is stacked and instruction execution restarts at logical address 0038 H . Both IEF $_{1}$ and IEF $_{2}$ flags are reset to 0 , disabling all maskable interrupts. The interrupt service routine should normally terminate with the EI (Enable Interrupts)
instruction followed by the RETI (Return from Interrupt) instruction, so that the interrupts are reenabled. Fig. 25 shows the use of $\overline{\mathrm{INT}}_{0}$ (Mode 1) and RETI.

Fig. 26 shows $\overline{\mathrm{INT}}_{0}$ Mode 1 timing.


Figure $25 \sqrt{\mathrm{NT}_{0}}$ Mode 1 Interrupt Sequence


Figure $26 \overline{\mathrm{INT}_{0}}$ Mode 1 Timing

## $\overline{\text { INT }}_{0}$ Mode 2

This method determines the restart address by reading the contents of a table residing in memory. The vector table consists of up to 128 two-byte restart addresses stored in low byte, high byte order.

The vector table address is located on 256 bytes boundaries in the 64 k bytes logical address space as programmed in the 8 -bit Interrupt Vector Register (I). Fig. 27 shows the $\overline{\mathrm{INT}}_{0}$ Mode 2 Vector acquisition.

During $\overline{\mathrm{INT}}_{0}$ Mode 2 acknowledge cycle, first, the low-order 8 bits of vector is fetched from the data bus at the rising edge of $\mathrm{T}_{3}$
and CPU acquires the 16 -bit vector.
Next, the PC is stacked. Finally, the 16 -bit restart address is fetched from the vector table and execution commences at that address.

Note that external vector acquisition is indicated by $\overline{\mathrm{LIR}}$ and $\overline{\text { IOE both LOW. Two wait states (Tw) are automatically inserted for }}$ external vector fetch cycles.

During RESET the Interrupt Vector Register (I) is initialized to 00 H and, if necessary, should be set to a different value prior to the occurrence of a $\mathrm{INT}_{0}$ Mode 2 interrupt. Fig. 28 shows $\overline{\mathrm{INT}_{0}}$ Mode 2 interrupt Timing.

Memory


Figure $27 \widetilde{\mathrm{NT}}_{0}$ Mode 2 Vector Acquisition


Figure $28 \overline{\mathbb{N} T_{0}}$ Mode 2 Timing

## $6.6 \overline{\mathrm{INT}_{1}}, \overline{\mathrm{NT}_{2}}$

The operation of external interrupts $\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ is a vector mode similar to $\overline{\mathrm{INT}}_{0}$ Mode 2. The difference is that $\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ generate the low-order byte of vector table address using the IL (Interrupt Vector Low) register rather than fetching it from the data bus. This is also the interrupt response sequence used for all internal interrupts (except TRAP).

As shown in Fig. 29 the low-order byte of vector table address is comprised of the most significant three bits of the software programmable IL register and the least significant five bits which are a unique fixed value for each interrupt ( $\overline{\mathrm{INT}_{1}}, \overline{\mathrm{INT}}_{2}$ and internal) source.
$\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ are globally masked by $\mathrm{IEF}_{1}=0$. Each is also individually maskable by respectively clearing the ITE1 and ITE2 (bits 1,2 ) of the INT/TRAP control register to 0 .

During RESET, IEF $_{1}$, ITE1 and ITE2 bits are initialized to 0.

### 6.7 Internal Interrupts

Internal interrupts (except TRAP) use the same vectored response mode as $\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ (Fig. 29). Internal interrupts are globally masked by $\mathrm{IEF}_{1}=0$. Individual internal interrupts are enabled/disabled by programming each individual I/O (PRT, $\mathrm{DMAC}, \mathrm{CSI} / \mathrm{O}, \mathrm{ASCI})$ control register. The lower vector of $\overline{\mathrm{INT}_{1}}$, $\mathrm{INT}_{2}$, and internal interrupt are summarized in Table 3.


Figure $29 \overline{\mathbf{I N T}}_{1}, \overline{\mathbb{I N T}_{2}}$ and Internal Interrupts Vector Acquisition

Table 3 Interrupt Source and Lower Vector

| Interrupt Source | Priority | IL. |  |  | Fixed Code |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{b}_{7}$ | $\mathrm{b}_{6}$ | $\mathrm{b}_{5}$ | $\mathrm{b}_{4}$ | $\mathrm{b}_{3}$ | $\mathrm{b}_{2}$ | $\mathrm{b}_{1}$ | $\mathrm{b}_{0}$ |
| $\sqrt{\mathrm{NT}_{1}}$ | Highest <br> Lowest | * | * | * | 0 | 0 | 0 | 0 | 0 |
| $\overline{\mathrm{NT}}_{2}$ |  | * | * | * | 0 | 0 | 0 | 1 | 0 |
| PRT channel 0 |  | * | * | * | 0 | 0 | 1 | 0 | 0 |
| PRT channel 1 |  | * | * | * | 0 | 0 | 1 | 1 | 0 |
| DMA channel 0 |  | * | * | * | 0 | 1 | 0 | 0 | 0 |
| DMA channel 1 |  | * | * | * | 0 | 1 | 0 | 1 | 0 |
| CSI/O |  | * | * | * | 0 | 1 | 1 | 0 | 0 |
| ASCl channel 0 |  | * | * | * | 0 | 1 | 1 | 1 | 0 |
| ASCl channel 1 |  | * | * | * | 1 | 0 | 0 | 0 | 0 |

* Programmable


## Interrupt Acknowledge Cycle Timing

Fig. 30 shows interrupt acknowledge cycle timing for internal interrupts, $\overline{\mathrm{INT}}_{1}$, and $\overline{\mathrm{INT}}_{2} . \overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ are sampled at the falling
edge of clock state prior to $\mathrm{T}_{3}$ or Ti in the last machine cycle. If $\overline{\mathrm{INT}}$ or $\overline{\mathrm{INT}}_{2}$ is asserted LOW at the falling edge of clock state prior to $\mathrm{T}_{3}$ or Ti in the last machine cycle, the interrupt request is accepted.


Figure $30 \overline{\mathbb{N T}}_{1}, \overline{\mathbb{N T}}_{2}$ and Internal Interrupts Timing

### 6.8 Interrupt Sources and Reset

## (1) Interrupt Vector Register (I)

All bits are reset to 0 .
Since $I=0$ locates the vector tables starting at logical address 0000 H , vectored interrupts ( $\overline{\mathrm{INT}}_{0}$ Mode $2, \overline{\mathrm{INT}}_{1}, \overline{\mathrm{INT}}_{2}$ and internal interrupts) will overlap with fixed restart interrupts like RESET (0), $\overline{\mathrm{NMI}}(0066 \mathrm{H}), \overline{\mathrm{INT}}_{0}$ Mode $1(0038 \mathrm{H})$ and RST $(0000 \mathrm{H}-0038 \mathrm{H})$. The vector table(s) can be built elsewhere in memory and located on 256 bytes boundaries by reprogramming I with the LD I, A instruction.
(2) IL Register

Bits $7-5$ are reset to 0 .
The IL Register can be programmed to locate the vector table for $\overline{\mathrm{INT}}_{1}, \overline{\mathrm{INT}}_{2}$ and internal interrupts on 32 bytes sub-boundaries within the 256 bytes area specified by I.
(3) $\mathrm{IEF}_{1}, \mathrm{IEF}_{2}$ Flags

Reset to 0 .
Interrupts other than $\overline{\text { NMI }}$ and TRAP are disabled.
(4) ITC Register

ITE0 are set to 1. ITE1 and ITE2 are reset to 0 .
$\overline{\mathrm{INT}}_{0}$ can be enabled by the EI instruction, which sets $\mathrm{IEF}_{1}=1$. To enable $\overline{\mathrm{INT}}_{1}$ and $\overline{\mathrm{INT}}_{2}$ also requires that the ITE1 and ITE2 bits be respectively set $=1$ by writing to ITC.

## (5) I/O Control Registers

Interrupt enable bits reset to 0 .
All HD64180 on-chip I/O (PRT, DMAC, CSI/O, ASCI) interrupts are disabled and can be individually enabled by writing to each I/O control register interrupt enable bit.
6.9 Difference between $\overline{\mathrm{INT}} \mathbf{T}_{0}$ interrupt and the other interrupts (INT,$\overline{\mathbf{I N T}} \mathbf{2}$ and internal interrupts) in the interrupt acknowledge cycles
As shown in Fig. 24, Fig. 26, Fig. 28 and Fig. 30, the interrupt acknowledge cycle of $\overline{\mathrm{INT}}_{0}$ is different from those of the other interrupts, that is, $\overline{\mathrm{INT}}_{1}, \overline{\mathrm{INT}}_{2}$ and internal interrupts concerning the state of control signals. The state of the control signals in each interrupt acknowledge cycle are shown below.
$\overline{\mathrm{INT}}_{0}$ interrupt acknowledge cycle: $\overline{\mathrm{LIR}}=0, \overline{\mathrm{IOE}}=0, \mathrm{ST}=0$
$\overline{\mathrm{INT}}_{1}, \overline{\mathrm{INT}}_{2}$, and internal interrupt acknowledge cycle: $\mathrm{LIR}=1$,
$\overline{\mathrm{OEE}}^{1}=1, \mathrm{ST}=0$

## 7 MEMORY MANAGEMENT UNIT (MMU)

The HD64180 contains an on-chip MMU which performs the translation of the CPU 64 k bytes (16-bit addresses- 0000 H to FFFFH) logical memory address space into a 512 k bytes (19-bit ad-dresses- 00000 H to 7 FFFFH ) physical memory address space. Address translation occurs internally in parallel with other CPU operation.

### 7.1 Logical Address Spaces

The 64 k bytes CPU logical address space is interpreted by the MMU as consisting of up to three separate logical address areas, Common Area 0, Bank Area and Common Area 1.

As shown in Fig. 31 a variety of logical memory configurations are possible. The boundaries between the Common and Bank Areas can be programmed with 4 k bytes resolution.


Figure 31 Logical Address Mapping Examples

### 7.2 Logical to Physical Address Translation

Fig. 32 shows an example in which the three logical address space portions are mapped into a 512 k bytes physical address space. The important points to note are that Common and Bank Areas can
overlap and that Common Area 1 and Bank Area can be freely relocated (on 4 k bytes physical address boundaries). Common Area 0 (if it exists) is always based at physical address 00000 H .


Figure 32 Logical $\rightarrow$ Physical Memory Mapping Example

### 7.3 MMU Block Diagram

The MMU block diagram is shown in Fig. 33. The MMU translates internal 16 -bit logical addresses to external 19-bit physical addresses.


Figure 33 MMU Block Diagram

Whether address translation takes place depends on the type of CPU cycle as follows.
(1) Memory Cycles

Address Translation occurs for all memory access cycles including instruction and operand fetches, memory data reads and writes, hardware interrupt vector fetch and software interrupt restarts.
(2) I/O Cycles

The MMU is logically bypassed for I/O cycles. The 16-bit logical I/O address space corresponds directly with the 16 -bit physical I/O address space. The upper three bits $\left(\mathrm{A}_{16}-\mathrm{A}_{18}\right)$ of the physical address are always 0 during I/O cycles.


Figure 34 I/O Address Translation

## (3) DMA Cycles

When the HD64180 on-chip DMAC is using the external bus, the MMU is physically bypassed. The 19 -bit source and destination
registers in the DMAC are directly output on the physical address bus ( $\mathrm{A}_{0}-\mathrm{A}_{18}$ ).

### 7.4 MMU Registers

Three MMU registers are used to program a specific configuration of logical and physical memory.
(1) MMU Common/Bank Area Register (CBAR)
(2) MMU Common Base Register (CBR)
(3) MMU Bank Base Register (BBR)

CBAR is used to define the logical memory organization, while CBR and BBR are used to relocate logical areas within the 512 k bytes physical address space. The resolution for both setting boundaries within the logical space and relocation within the physical
space is 4 k bytes.
The CAR field of CBAR determines the start address of Common Area 1 (Upper Common) and by default, the end address of the Bank Area. The BAR field determines the start address of the Bank Area and by default, the end address of Common Area 0 (Lower Common).

The CA and BA fields of CBAR may be freely programmed subject only to the restriction that CA may never be less than BA. Fig. 35 and Fig. 36 shows example of logical memory organizations associated with different values of CA and BA.


Figure 35 Logical Memory Organization


Figure 36 Logical Space Configuration (Example)

### 7.5 MMU Register Description

## (1) MMU Common/Bank Area Register (CBAR)

CBAR specifies boundaries within the HD64180 64k bytes logical address space for up to three areas, Common Area 0, Bank Area, and Common Area 1.

MMU Common/Bank Area Register (CBAR : I/O Address $=3 \mathrm{AH}$ )


## CA3-CAO: CA (bits 7-4)

CA specifies the start (low) address (on 4 k bytes boundaries) for the Common Area 1. This also determines the last address of the Bank Area. All bits of CA are initialized to 1 during RESET.

## BA3-BA0: BA (bits 3-0)

BA specifies the start (low) address (on 4 k bytes boundaries) for the Bank Area. This also determines the last address of the Common Area 0 . All bits of BA are initialized to 0 during RESET.

## (2) MMU Common Base Register (CBR)

CBR specifies the base address (on 4 k bytes boundaries) used to generate a 19-bit physical address for Common Area 1 accesses. All bits of CBR are initialized to 0 during RESET.


## (3) MMU Bank Base Register (BBR)

BBR specifies the base address (on $4 k$ bytes boundaries) used to generate a 19-bit physical address for Bank Area accesses. All bits of BBR are initialized to 0 during RESET.


### 7.6 Physical Address Translation

Fig. 37 shows the way in which physical addresses are generated based on the contents of CBAR, CBR and BBR. MMU comparators classify an access by logical area as defined by CBAR. Depending on which of the three potential logical areas (Common Area 1, Bank Area or Common Area 0) is being accessed, the appropriate 7 -bit base address is added to the upper 4 bits of the logical address, yielding a 19-bit physical address. CBR is associated with Common Area 1 accesses. Common Area 0 accesses use a (non-accessible, internal) base register which contains 0. Thus, Common Area 0, if defined, is always based at physical address 00000 H .


Figure 37 Physical Address Generation

### 7.7 MMU and RESET

During RESET, all bits of the CA field of CBAR are set to 1 while all bits of the BA field of CBAR, CBR, and BBR are cleared to 0 . The logical 64 k bytes address space corresponds directly with the first 64 k bytes $(0000 \mathrm{H}$ to FFFFH ) of the 512 k bytes $(00000 \mathrm{H}$ to 7FFFFH) physical address space. Thus, after RESET, the HD64180 will begin execution at logical and physical address 0 .

### 7.8 MMU Register Access Timing

When data is written into CBAR, CBR, or BBR, the value will be effective from the cycle immediately following the I/O write cycle which updates these registers.

Care must be taken during MMU programming to insure that CPU program execution is not disrupted. Observe that the next cycle following MMU register programming will normally be an opcode fetch from the newly translated address. One simple technique is to localize all MMU programming routines in a Common Area that is always enabled.

## 8 DYNAMIC RAM REFRESH CONTROL

The HD64180 incorporates a dynamic RAM refresh control circuit including 8 -bit refresh address generation and programmable refresh timing. This circuit generates asynchronous refresh cycles inserted at the programmable interval independent of CPU program execution. For systems which don't use dynamic RAM, the refresh function can be disabled.

When the internal refresh controller determines that a refresh cycle should occur, the current instruction is interrupted at the first breakpoint between machine cycles. The refresh cycle is inserted by placing the refresh address on $\mathrm{A}_{0}-\mathrm{A}_{7}$ and the $\overline{\mathrm{REF}}$ output is driven LOW.

Refresh cycles may be programmed to be either two or three clock cycles in duration by programming the REFW (Refresh Wait) bit in Refresh Control Register (RCR). Note that the external WAIT input and the internal wait state generator are not effective during refresh.

Fig. 38 shows the timing of a refresh cycle with a refresh wait ( $\mathrm{T}_{\mathrm{RW}}$ ) cycle.


NOTE: * If three refresh cycles are specified, $T_{R W}$, is inserted. Otherwise, $T_{\text {RW }}$ is not inserted.
MC: Machine Cycle
Figure 38 Refresh Timing

### 8.1 Refresh Control Register (RCR)

RCR specifies the interval and length of refresh cycles, as well as enabling or disabling the refresh function.


REFE: Refresh Enable (bit 7)
REFE $=0$ disables the refresh controller while $\mathrm{REFE}=1$ enables refresh cycle insertion. REFE is set to 1 during RESET.

## REFW: Refresh Wait (bit 6)

REFW $=0$ causes the refresh cycle to be two clocks in duration. REFW $=1$ causes the refresh cycle to be three clocks in duration by adding a refresh wait cycle $\left(\mathrm{T}_{\mathrm{RW}}\right)$. REFW is set to 1 during RESET.

CYC1, 0: Cycle Interval (bits 1-0)
CYC1 and CYC0 specify the interval (in clock cycles) between refresh cycles.

In the case of dynamic RAMs requiring 128 refresh cycles every 2 ms (or 256 cycles every 4 ms ), the required refresh interval is less than or equal to $15.625 \mu \mathrm{~s}$. Thus, the underlined values indicate the best refresh interval depending on CPU clock frequency. CYC0 and $\mathrm{CYC1}$ are cleared to 0 during RESET.

Table 4 Refresh Interval

| CYC1 | CYC0 | Insertion <br> interval | Time interval |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 8 MHz | 6 MHz | 4 MHz | 2.5 MHz |  |
| 0 | 0 |  | $(1.0 \mu \mathrm{~s})^{*}$ | $(1.25 \mu \mathrm{~s})^{*}$ | $1.66 \mu \mathrm{~s}$ | $2.5 \mu \mathrm{~s}$ | $4.0 \mu \mathrm{~s}$ |
| 0 | 1 | 20 states | $(2.0 \mu \mathrm{~s})^{*}$ | $(2.5 \mu \mathrm{~s})^{*}$ | $3.3 \mu \mathrm{~s}$ | $5.0 \mu \mathrm{~s}$ | $\frac{8.0 \mu \mathrm{~s}}{16.0 \mu \mathrm{~s}}$ |
| 1 | 0 | 40 states | $(4.0 \mu \mathrm{~s})^{*}$ | $(5.0 \mu \mathrm{~s})^{*}$ | $6.6 \mu \mathrm{~s}$ | $10.0 \mu \mathrm{~s}$ | 16.0 |
| 1 | 1 | 80 states | $(8.0 \mu \mathrm{~s})^{*}$ | $(10.0 \mu \mathrm{~s})^{*}$ | $\underline{13.3 \mu \mathrm{~s}}$ | $20.0 \mu \mathrm{~s}$ | $32.0 \mu \mathrm{~s}$ |

- calculated interval


### 8.2 Refresh control and reset

After RESET, based on the initialized value of RCR, refresh cycles will occur with an interval of 10 clock cycles and be 3 clock cycles in duration.

### 8.3 Dynamic RAM refresh operation notes

(1) Refresh cycle insertion is stopped when the CPU is in the following states.
(a) During RESET
(b) When the bus is released in response to $\overline{\text { BUSREQ }}$
(c) During SLEEP mode
(d) During WAIT states
(2) Refresh cycles are suppressed when the bus is released in response to BUSREQ. However, the refresh timer continues to operate. Thus, the time at which the first refresh cycle occurs after the HD64180 re-acquires the bus depends on the refresh timer, and has no timing relationship with the bus exchange.
(3) Refresh cycles are suppressed during SLEEP mode. If a refresh cycle is requested during SLEEP mode, the refresh cycle request is internally 'latched' (until replaced with the next refresh request). The 'latched' refresh cycle is inserted at the end of the first machine cycle after SLEEP mode is exited. After this initial cycle, the time at which the next refresh cycle will occur depending on the refresh time, and has no timing relationship with the exit from SLEEP mode.
(4) Regarding (2) and (3), the refresh address is incremented by 1 for each successful refresh cycle, not for each refresh request. Thus, independent of the number of 'missed' refresh requests, each refresh bus cycle will use a refresh address incremented by 1 from that of the previous refresh bus cycles.

## 9 WAIT STATE GENERATOR

### 9.1 Wait State Timing

To ease interfacing with slow memory and I/O devices, the HD64180 uses wait states (Tw) to extend bus cycle timing. A wait state (s) is inserted based on the combined (logical OR) state of the external WAIT input and an internal programmable wait state (Tw) generator. Wait states (Tw) can be inserted in both CPU execution and DMA transfer cycles.

### 9.2 WAIT Input

When the external $\overline{\text { WAIT }}$ input is asserted LOW, wait state (Tw) are inserted between $\mathrm{T}_{2}$ and $\mathrm{T}_{3}$ to extend the bus cycle duration. The WAIT input is sampled at the falling edge of the system clock in $\mathrm{T}_{2}$ or Tw. If the WAIT input is asserted LOW at the falling edge of the system clock in Tw , another Tw is inserted into the bus cycle. Note that $\overline{\text { WAIT }}$ input transitions must meet specified set-up and hold times. This can easily be accomplished by externally synchronizing WAIT input transitions with the rising edge of the system clock.

Dynamic RAM refresh is not performed during wait states (Tw) and thus systems designs which uses the automatic refresh function must consider the affects of the occurrence and duration of wait states (Tw).

Fig. 39 shows $\overline{\text { WAIT }}$ timing.


Figure 39 WAIT Timing

### 9.3 Programmable Wait State Insertion

In addition to the WAIT input, wait states (Tw) can also be programmably inserted using the HD64180 on-chip wait state generator. Wait state (Tw) timing applies for both CPU execution and on-chip DMAC cycles.

By programming the 4 significant bits of the DMA/WAIT Control Register (DCNTL), the number of wait states (Tw) automatically inserted in memory and I/O cycles can be separately specified. Bits 4-5 specify the number of wait states (Tw) inserted for I/O access and bits 6-7 specify the number of wait states (Tw) inserted for memory access.


The number of wait states (Tw) inserted in a specific cycle is the maximum of the number requested by the $\overline{\text { WAIT }}$ input, and the
number automatically generated by the on-chip wait state generator.

## MWI1, MWIO: Memory Wait Insertion (bits 7-6)

For CPU and DMAC cycles which access memory (including memory mapped I/O), 0 to 3 wait states may be automatically inserted depending on the programmed value in MWIl and MWIO.

| MWII | MWIO | The number of wait states |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | 3 |

IWI1, IWIO: I/O Wait Insertion (bits 5-4)
For CPU and DMA cycles which access external I/O (and interrupt acknowledge cycles), 1 to 6 wait states (Tw) may be automatically inserted depending on the programmed value in IWI1 and IWIO.

| IWI1 | IWIO | The number of wait states |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | For external I/O registers accesses | For internal I/O registers accesses | For $\overline{\mathrm{NT}}_{0}$ interrupt acknowledge cycles when LIR is LOW | For $\overline{\mathrm{NTT}}_{1}, \overline{\mathrm{INT}}_{2}$ and internal interrupts acknowledge cycles (Note (2)) | For $\overline{\mathrm{NM}} \mathrm{I}$ interrupt acknowledge cycles when LIR is LOW (Note (2)) |
| 0 | 0 | 1 | $\begin{gathered} 0 \\ \text { (Note (1)) } \end{gathered}$ | 2 | 2 | 0 |
| 0 | 1 | 2 |  | 4 |  |  |
| 1 | 0 | 3 |  | 5 |  |  |
| 1 | 1 | 4 |  | 6 |  |  |

NOTE: (1) For HD64180 internal I/O register access (I/O addresses $0000 \mathrm{H}-003 \mathrm{FH}$ ), IWI1 and IWIO do not determine wait state (Tw) timing. For ASCI, CSI/ 0 and PRT Data Register accesses, 0 to 4 wait states (Tw) will be generated. Wait states inserted during access to these registers is a function of internal synchronization requirements and CPU state.
All other on-chip I/O register accesses (i.e. MMU, DMAC, ASCI Control Registers, etc.) have 0 wait states inserted and thus require only three clock cycles.
(2) For interrupt acknowledge cycles in which $\overline{\text { LIR }}$ is HIGH, such as interrupt vector table read and PC stacking cycle, memory access timing applies.

### 9.4 WAIT Input and RESET

During RESET, MWI1, MWI0, IWI1 and IWI0 are all set to 1 , selecting the maximum number of wait states (Tw) (3 for memory accesses, 4 for external I/O accesses).

Also, note that the $\overline{\text { WAIT }}$ input is ignored during RESET. For
example, if RESET is detected while the HD64180 is in a wait state (Tw), the wait stated cycle in progress will be aborted, and the RESET sequence initiated. Thus, RESET has higher priority than WAIT.

## 10 DMA CONTROLLER (DMAC)

The HD64180 contains a two channel DMA (Direct Memory Access) controller which supports high speed data transfer. Both channels (channel 0 and channel 1) have the following capabilities.

Memory Address Space
Memory source and destination addresses can be directly specified anywhere within the 512 k bytes physical address space using 19-bit source and destination memory addresses. In addition, memory transfers can arbitrarily cross 64 k bytes physical address boundaries without CPU intervention.

## I/O Address Space

I/O source and destination addresses can be directly specified anywhere within the 64 k bytes I/O address space (16-bit source and destination I/O addresses).

## Transfer Length

Up to 64 k bytes can be transferred based on a 16 -bit byte count register.
$\overline{\mathrm{DREQ}}$ Input
Level and edge sense $\overline{\text { DREQ }}$ input detection are selectable.
TEND Output
Used to indicate DMA completion to external devices.

## Transfer Rate

Each byte transfer can occur every six clock cycles. Wait states can be inserted in DMA cycles for slow memory or I/O devices. At the system clock $(\phi)=6 \mathrm{MHz}$, the DMA transfer rate is as high as 1.0 megabytes/second (no wait states).

Additional feature disk for DMA interrupt request by DMA END.

Each channel has the following additional specific capabilities.

Channel 0

- Memory $\longleftrightarrow$ memory, memory $\longleftrightarrow$ I/O, memory $\longleftrightarrow$ memory mapped I/O transfers
- Memory address increment, decrement, no-change
- Burst or cycle steal memory $\longleftrightarrow$ memory transfers
- DMA to and from both ASCI channels
- Higher priority than DMAC channel 1

Channel 1

- Memory $\longleftrightarrow$ I/O transfer
- Memory address increment, decrement


## DMAC Registers

Each channel of the DMAC (channel 0,1) has three registers specifically associated with that channel.

## Channel 0

SAR0 - Source Address Register
DAR0

- Destination Address Register
BCR0
- Byte Count Register

Channel 1
MAR1 - Memory Address Register
IAR1 - I/O Address Register
BCR1 - Byte Count Register
The two channels share the following three additional registers in common.
DSTAT - DMA Status Register
DMODE - DMA Mode Register
DCNTL - DMA Control Register

### 10.1 DMAC Block Diagram

Fig. 40 shows the HD64180 DMAC Block Diagram.


Figure 40 DMAC Block Diagram

### 10.2 DMAC Register Description

(1) DMA Source Address Register Channel 0 (SARO: I/O Address $=\mathbf{2 0 H}$ to 22 H )
Specifies the physical source address for channel 0 transfers. The register contains 19 bits and may specify up to 512 k bytes memory addresses or up to 64 k bytes I/O addresses. Channel 0 source can be memory, I/O or memory mapped I/O.
(2) DMA Destination Address Register Channel 0 (DARO: I/O Address $=\mathbf{2 3 H}$ to $\mathbf{2 5 H}$ )
Specifies the physical destination address for channel 0 transfers. The register contains 19 bits and may specify up to 512 k bytes memory addresses or up to 64 k bytes I/O addresses. Channel 0 destination can be memory, I/O or memory mapped I/O.
(3) DMA Byte Count Register Channel 0 (BCRO: I/O Address $=26 \mathrm{H}$ to 27 H )
Specifies the number of bytes to be transferred. This register contains 16 bits and may specify up to 64 k bytes transfers. When one byte is transferred, the register is decremented by one. If " $n$ " bytes should be transferred, " $n$ " must be stored before the DMA operation.
(4) DMA Memory Address Register Channel 1 (MAR1: I/O Address $=28 \mathrm{H}$ to 2 AH )
Specifies the physical memory address for channel 1 transfers. This may be destination or source memory address.
This register contains 19 bits and may specify up to 512 k bytes memory addresses.
(5) DMA I/O Address Register Channel 1 (IAR1: I/O Address $=2 \mathrm{BH}$ to 2 CH )
Specifies the I/O address for channel 1 transfers. This may be destination or source I/O address. This register contains 16 bits and may specify up to 64 k bytes I/O addresses.
(6) DMA Byte Count Register Channel 1 (BCR1: I/O Address $=2 \mathrm{EH}$ to 2FH)
Specifies the number of bytes to be transferred. This register contains 16 bits and may specify up to 64 k bytes transfers. When one byte is transferred, the register is decremented by one.

## (7) DMA Status Register (DSTAT)

DSTAT is used to enable and disable DMA transfer and DMA termination interrupts. DSTAT also allows determining the status of a DMA transfer i.e. completed or in progress.

$$
\text { DMA Status Register (DSTAT : l/O Address }=30 \mathrm{H} \text { ) }
$$



DE1: DMA Enable Channel 1 (bit 7)
When DE1 $=1$ and $\mathrm{DME}=1$, channel 1 DMA is enabled. When a DMA transfer terminates $(B C R 1=0)$, DE1 is reset to 0 by the DMAC. When DE1 $=0$ and the DMA interrupt is enabled ( $\mathrm{DIE1}=1$ ), a DMA interrupt request is made to the CPU.

To perform a software write to DE1, DWE1 should be written with 0 during the same register write access. Writing DE1 to 0 disables channel 1 DMA, but DMA is restartable. Writing DE1 to 1 enables channel 1 DMA and automatically sets DME (DMA Main Enable) to 1 . DE1 is cleared to 0 during RESET.

DEO: DMA Enable Channel 0 (bit 6)
When $\mathrm{DE} 0=1$ and $\mathrm{DME}=1$, channel 0 DMA is enabled. When a DMA transfer terminates $(B C R 0=0), \mathrm{DE} 0$ is cleared to 0 by the DMAC. When DEO $=0$ and the DMA interrupt is enabled
(DIE0 $=1$ ), a DMA interrupt request is made to the CPU.
To perform a software write to DE0, $\overline{\mathrm{DWEO}}$ should be written with 0 during the same register write access. Writing DE0 to 0 disables channel 0 DMA. Writing DE0 to 1 enables channel 0 DMA and automatically sets DME (DMA Main Enable) to 1. DE0 is cleared to 0 during RESET.

## DWE1: DE1 Bit Write Enable (bit 5)

When performing any software write to DE1, $\overline{\text { DWE1 }}$ should be written with 0 during the same access. $\overline{\text { DWE1 }}$ write value of 0 is not held and DWE1 is always read as 1 .

## DWEO: DEO Bit Write Enable (bit 4)

When performing any software write to DE0, $\stackrel{\mathrm{DWE} 0}{ }$ should be written with 0 during the same access. DWE0 write value of 0 is not held and $\overline{\mathrm{DWE} 0}$ is always read as 1 .

DIE1: DMA Interrupt Enable Channel 1 (bit 3)
When DIE1 is set to 1 , the termination of channel 1 DMA transfer (indicated when $D E 1=0$ ) causes a CPU interrupt request to be generated. When DIE1 $=0$, the channel 1 DMA termination interrupt is disabled. DIE1 is cleared to 0 during RESET.

DIEO: DMA Interrupt Enable Channel 0 (bit 2)
When DIE0 is set to 1 , the termination channel 0 of DMA transfer (indicated when $\mathrm{DE} 0=0$ ) causes a CPU interrupt request to be generated. When DIE $0=0$, the channel 0 DMA termination interrupt is disabled. DIE0 is cleared to 0 during RESET.

## DME: DMA Main Enable (bit 0)

A DMA operation is only enabled when its DE bit (DEO for channel 0, DE1 for channel 1) and the DME bit are set to 1 .

When NMI occurs, DME is reset to 0 , thus disabling DMA activity during the NMI interrupt service routine. To restart DMA, DE0 and/or DE1 should be written with 1 (even if the contents are already 1). This automatically sets DME to 1 , allowing DMA operations to continue. Note that DME cannot be directly written. It is cleared to 0 by NMI or indirectly set to 1 by setting DE0 and/or DE1 to 1 . DME is cleared to 0 during RESET.
(8) DMA Mode Register (DMODE)

DMODE is used to set the addressing and transfer mode for channel 0 .

DMA Mode Register (DMODE : I/O Address $=31 \mathrm{H}$ )


DM1, DM0: Destination Mode Channel 0 (bits 5, 4) Specifies whether the destination for channel 0 transfers is memory, I/O or memory mapped I/O and the corresponding address modifier. DM1 and DM0 are cleared to 0 during RESET.

Table 5 Destination

| DM1 DMO | Memory/I/O | Address <br> Increment/Decrement |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Memory | +1 |
| 0 | 1 | Memory | -1 |
| 1 | 0 | Memory | fixed |
| 1 | 1 | I/O | fixed |

SM1, SM0: Source Mode Channel 0 (bits 3, 2)
Specifies whether the source for channel 0 transfers is memory, I/O or memory mapped I/O and the corresponding address modifier. SM1 and SM0 are cleared to 0 during RESET.

Table 7 shows all DMA transfer mode combinations of DM0, DM1, SM0, SM1. Since I/O $\longleftrightarrow$ I/O transfers are not implemented, twelve combinations are available.

Table 6 Source

| SM1 | SM0 | Memory/I/O | Address <br> Increment/Decrement |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Memory | +1 |
| 0 | 1 | Memory | -1 |
| 1 | 0 | Memory | fixed |
| 1 | 1 | $1 / 0$ | fixed |

Table 7 Combination of Transfer Mode

| DM1 | DMO | SM1 | SMO | Transfer Mode | Address Increment/Decrement |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Memory $\rightarrow$ Memory | SARO + 1, DARO + 1 |
| 0 | 0 | 0 | 1 | Memory $\rightarrow$ Memory | SARO-1, DARO + 1 |
| 0 | 0 | 1 | 0 | Memory* $\rightarrow$ Memory | SARO fixed, DARO+1 |
| 0 | 0 | 1 | 1 | $\mathrm{I} / \mathrm{O} \rightarrow$ Memory | SARO fixed, DARO+1 |
| 0 | 1 | 0 | 0 | Memory $\rightarrow$ Memory | SARO + 1, DARO-1 |
| 0 | 1 | 0 | 1 | Memory $\rightarrow$ Memory | SARO-1, DARO-1 |
| 0 | 1 | 1 | 0 | Memory* $\rightarrow$ Memory | SARO fixed, DARO-1 |
| 0 | 1 | 1 | 1 | I/O $\rightarrow$ Memory | SARO fixed, DARO-1 |
| 1 | 0 | 0 | 0 | Memory $\rightarrow$ Memory ${ }^{*}$ | SARO + 1, DARO fixed |
| 1 | 0 | 0 | 1 | Memory $\rightarrow$ Memory* | SARO-1, DARO fixed |
| 1 | 0 | 1 | 0 | reserved |  |
| 1 | 0 | 1 | 1 | reserved |  |
| 1 | 1 | 0 | 0 | Memory $\rightarrow 1 / \mathrm{O}$ | SARO+1, DARO fixed |
| 1 | 1 | 0 | 1 | Memory $\rightarrow$ I/ O | SARO-1, DARO fixed |
| 1 | 1 | 1 | 0 | reserved |  |
| 1 | 1 | 1 | 1 | reserved |  |

* : includes memory mapped I/O


## MMOD: Memory Mode Channel 0 (bit 1)

When channel 0 is configured for memory $\longleftrightarrow$ memory transfers, the external $\overline{\mathrm{DREQ}}_{0}$ input is not used to control the transfer timing. Instead, two automatic transfer timing modes are selectable - burst (MMOD $=1$ ) and cycle steal (MMOD $=0$ ). For burst memory $\longleftrightarrow$ memory transfers, the DMAC will sieze control of the bus continuously until the DMA transfer completes (as shown by the byte count register $=0$ ). In cycle steal mode, the CPU is given a cycle for each DMA byte transfer cycle until the transfer is completed.

For channel 0 DMA with I/O source or destination, the $\overline{\mathrm{DREQ}_{0}}$ input times the transfer and thus MMOD is ignored. MMOD is cleared to 0 during RESET.

## DMA/WAIT Control Register (DCNTL)

DCNTL controls the insertion of wait states into DMAC (and CPU) accesses of memory or I/O. Also; the DMA request mode for each $\overline{\mathrm{DREQ}}^{\left(\overline{\mathrm{DREQ}}_{0}\right.}$ and $\left.\overline{\mathrm{DREQ}}_{1}\right)$ input is defined as level or edge sense. DCNTL also sets the DMA transfer mode for channel 1, which is limited to memory $\longleftrightarrow$ I/O transfers.
DMA/WAIT Control Register (DCNTL: I/O Address $=32 \mathrm{H}$ )
bit 7 7

| MWI1 | MWIO | W/11 | WIO | DMS1 | DMSO | DIM1 | DIMO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MW/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |

## MWI1, MWIO: Memory Wait Insertion (bits 7-6)

Specifies the number of wait states introduced into CPU or DMAC memory access cycles. MWI1 and MWI0 are set to 1 during RESET. See section of Wait State Control for details.

IWI1, IWIO: I/O Wait Insertion (bits 5-4)
Specifies the number of wait states introduced into CPU or DMAC I/O access cycles. IWI1 and IWI0 are set to 1 during RESET. See section of Wait State Control for details.

DMS1, DMSO: DMA Request Sense (bits 3-2)
DMS1 and DMS0 specify the DMA request sense for channel 0 $\left(\overline{\mathrm{DREQ}_{0}}\right)$ and channel $1\left(\overline{\mathrm{DREQ}}_{1}\right)$ respectively. When reset to 0 , the input is level sense. When set to 1 , the input is edge sense. DMS1 and DMS0 are cleared to 0 during RESET.

DIM1, DIMO: DMA Channel 1 I/O and Memory Mode (bits 1-0)
Specifies the source/destination and address modifier for channel 1 memory $\longleftrightarrow$ I/O transfer modes. IM1 and IM0 are cleared to 0 during RESET.

Table 8 Channel 1 Transfer Mode

| DIM1 | DIM0 | Transfer Mode | Address <br> Increment/Decrement |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Memory $\rightarrow$ I/O | MAR1+1, IAR1 fixed |
| 0 | 1 | Memory $\rightarrow$ I/O | MAR1 - 1, IAR1 fixed |
| 1 | 0 | I/O Memory | IAR1 fixed, MAR1+1 |
| 1 | 1 | I/O $\rightarrow$ Memory | IAR1 fixed, MAR1 -1 |

### 10.3 DMA Operation

This section discusses the three DMA operation modes for channel 0 , memory $\longleftrightarrow$ memory, memory $\longleftrightarrow$ I/O and memory $\stackrel{\longleftrightarrow}{\longleftrightarrow}$ memory mapped I/O. In addition, the operation of channel 0 DMA with the on-chip ASCI (Asynchronous Serial Communication Interface) as well as Channel 1 DMA are described.
(1) Memory $\longleftrightarrow$ Memory - Channel 0

For memory $\longleftrightarrow$ memory transfers, the external $\overline{\mathrm{DREQ}}_{0}$ input is not used for DMA transfer timing. Rather, the DMA operation is timed in one of two programmable modes - burst or cycle steal. In both modes, the DMA operation will automatically proceed until termination as shown by byte count $(B C R 0)=0$.

In burst mode, the DMA operation will proceed until termination. In this case, the CPU cannot perform any program execution
until the DMA operation is completed
In cycle steal mode, the DMA and CPU operation are alternated after each DMA byte transfer until the DMA is completed. The sequence ...

## $\binom{1$ CPU Machine Cycle }{ DMA Byte Transfer }

... is repeated until DMA is completed. Fig. 41 shows cycle steal mode DMA timing.


Figure 41 Cycle Steal Mode DMA Timing

To initiate memory $\longleftrightarrow$ memory DMA transfer for channel 0 , perform the following operations.
(1) Load the memory source and destination addresses into SAR0 and DAR0.
(2) Specify memory $\longleftrightarrow$ memory mode and address increment/decrement in the SM0, SM1, DM0 and DM1 bits of DMODE.
(3) Load the number of bytes to transfer in BCRO.
(4) Specify burst or cycle steal mode in the MMOD bit of DCNTL.
(5) Program $\mathrm{DE}=1$ (with $\overline{\mathrm{DWEO}}=0$ in the same access) in DSTAT and the DMA operation will start 1 machine cycle later. If interrupt occurs at the same time, the DIE0 bit should be set to 1 .
(2) Memory $\longleftrightarrow$ 1/O (Memory Mapped 1/O) - Channel 0

For memory $\longleftrightarrow$ I/O (and memory $\longleftrightarrow$ memory mapped I/O) the $\overline{\mathrm{DREQ}}_{0}$ input is used to time the DMA transfers. In addition, the $\mathrm{TEND}_{0}$ (Transfer End) output is used to indicate the last (byte count register $\mathrm{BCR} 0=00 \mathrm{H}$ ) transfer.

The $\overline{\mathrm{DREQ}}_{0}$ input can be programmed as level or edge sensitive.
When level sense is programmed, the DMA operation begins when $\overline{\mathrm{DREQ}}_{0}$ is sampled LOW. If $\overline{\mathrm{DREQ}}_{0}$ is sampled HIGH, after the next DMA byte transfer, control is relinquished to the HD64180 CPU. As shown in Fig. 42. $\overline{\mathrm{DREQ}}_{0}$ is sampled at the rising edge of the clock cycle prior to $T_{3}$ i.e. either $T_{2}$ or $T w$.


Figure 42 CPU Operation and DMA Operation ( $\overline{\mathrm{DREQ}}_{0}$ is programmed for level sense)

When edge sense is programmed, DMA operation begins at the falling edge of $\mathrm{DREQ}_{0}$. If another falling edge is detected before the rising edge of the clock prior to $\mathrm{T}_{3}$ during DMA write cycle (i.e. $\mathrm{T}_{2}$ or Tw), the DMAC continues operating. If an edge is not detected, the CPU is given control after the current byte DMA transfer com-
pletes. The CPU will continue operating until a $\overline{\mathrm{DREQ}}_{0}$ falling edge is detected before the rising edge of the clock prior to $\mathrm{T}_{3}$ at which time the DMA operation will (re)start. Fig. 43 shows the edge sense DMA timing.


- ${\overline{\text { DREO}_{0}}}^{\text {is }}$ s sampled at $\downarrow$.

Figure 43 CPU Operation and DMA Operation (DREQ ${ }_{0}$ is programmed for edge sense)

During the transfers for channel 0 , the $\overline{\mathrm{TEND}}_{0}$ output will go LOW synchronous with the write cycle of the last $(\mathrm{BCR} 0=00 \mathrm{H})$

DMA transfer as shown in Fig. 44.

$\overline{T E N D}{ }_{0}$

Figure $44 \overline{\text { TEND }}_{0}$ Output Timing

The $\overline{\mathrm{DREQ}}_{0}$ and $\overline{\mathrm{TEND}}_{0}$ pins are programmably multiplexed with the CKA0 and CKA1 ASCI clock input/outputs. However, when DMA channel 0 is programmed for memory $\longleftrightarrow$ I/O (and memory $\longleftrightarrow$ memory mapped I/O) transfers, the CKA0/DRE$\overline{Q_{0}}$ pin automatically functions as input pin even if it has been programmed as output pin for CKA0. And the CKA1/TEND 0 pin functions as output pin for $\mathrm{TEND}_{0}$ by setting CKA1D to 1 in CNTLA1.

To initiate memory $\longleftrightarrow$ I/O (and memory $\longleftrightarrow$ memory mapped I/O) DMA transfer for channel 0 , perform the following operations.
(1) Load the memory and I/O or memory mapped I/O source and destination addresses into SAR0 and DAR0. Note that I/O addresses (not memory mapped I/O) are limited to 16 bits ( $\mathrm{A}_{0}$ $\mathrm{A}_{15}$ ). Make sure that bits $\mathrm{A}_{16}$ and $\mathrm{A}_{17}$ are 0 ( $\mathrm{A}_{18}$ is a don't care) to correctly enable the external $\overline{\mathrm{DREQ}}_{0}$ input.
(2) Specify memory $\longleftrightarrow$ I/O or memory $\longleftrightarrow$ memory mapped I/O mode and address increment/decrement in the SM0, SM1, DM0, and DM1 bits of DMODE.
(3) Load the number of bytes to transfer in BCRO.
(4) Specify whether $\mathrm{DREQ}_{0}$ is edge or level sense by programming the DMS0 bit of DCNTL.
(5) Enable or disable DMA termination interrupt with the DIE0 bit in DSTAT.
(6) Program DEO $=1$ (with $\overline{\mathrm{DWE}}=0$ in the same access) in

DSTAT and the DMA operation will begin under the control of the $\overline{\mathrm{DREQ}}_{0}$ input.
(3) Memory $\longleftrightarrow$ ASCI - Channel 0

Channel 0 has extra capability to support DMA transfer to and from the on-chip two channel ASCI. In this case the external DRE$\mathrm{Q}_{0}$ input is not used for DMA timing. Rather, the ASCI status bits are used to generate an internal $\mathrm{DREQ}_{0}$. The TDRE (Transmit Data Register Empty) bit and the RDRF (Receive Data Register Full) bit are used to generate an internal $\mathrm{DREQ}_{0}$ for ASCI transmission and reception respectively.

To initiate memory $\longleftrightarrow$ ASCI DMA transfer, perform the following operations.
(1) Load the source and destination addresses into SAR0 and DAR0. Specify the I/O (ASCI) address as follows.
Bits $\mathrm{A}_{0}-\mathrm{A}_{7}$ should be contain the address of the ASCI channel transmitter or receiver (I/O addresses $06 \mathrm{H}-09 \mathrm{H}$ ).
Bits $\mathrm{A}_{8}-\mathrm{A}_{15}$ should equal 0 .
Bits $\mathrm{A}_{17}-\mathrm{A}_{16}$ should be set according to the following table to enable use of the appropriate ASCI status bit as an internal DMA request.

Table 9 DMA Request

| SAR18 | SAR17 | SAR16 | DMA Transfer Request |
| :---: | :---: | :---: | :---: |
| $X$ | 0 | 0 | $\overline{\text { DREQ }}_{0}$ |
| X | 0 | 1 | RDRF (ASCI channel 0) |
| X | 1 | 0 | RDRF (ASCl channel 1) |
| X | 1 | 1 | reserved |

X: Don't care

| DAR18 | DAR17 | DAR16 | DMA Transfer Request |
| :---: | :---: | :---: | :--- |
| $X$ | 0 | 0 | DREQ $_{0}$ |
| $X$ | 0 | 1 | TDRE (ASCI channel 0) |
| $X$ | 1 | 0 | TDRE (ASCI channel 1) |
| $X$ | 1 | 1 | reserved |

X: Don't care
(2) Specify memory $\longleftrightarrow$ 1/O transfer mode and address increment/decrement in the SM0, SM1, DM0 and DM1 bits of DMODE.
(3) Load the number of bytes to transfer in BCR0.
(4) The DMA request sense mode (DMS0 bit in DCNTL) MUST be specified as 'edge sense'.
(5) Enable or disable DMA termination interrupt with the DIE0 bit in DSTAT.
(6) Program $\mathrm{DE} 0=1$ (with $\overline{\mathrm{DWEO}}=0$ in the same access) in DSTAT and the DMA operation with the ASCI will begin under control of the ASCI generated internal DMA request.
The ASCI receiver or transmitter being used for DMA must be initialized to allow the first DMA transfer to begin.

The ASCI receiver must be 'empty' as shown by RDRF $=0$.
The ASCI transmitter must be 'full' as shown by TDRE $=0$.
Thus, the first byte should be written to the ASCI Transmit Data Register under program control. The remaining bytes will be transferred using DMA.

## (4) Channel 1 DMA

DMAC Channel 1 can perform memory $\longleftrightarrow$ I/O transfers. Except for different registers and status/control bits, operation is exactly the same as described for channel 0 memory $\longleftrightarrow$ I/O DMA.

To initiate DMA channel 1 memory $\longleftrightarrow$ I/O transfer perform the following operations.
(1) Load the memory address ( 19 bits) into MAR1.
(2) Load the I/O address ( 16 bits) into IAR1.
(3) Program the source/destination and address increment/decrement mode using the DIM1 and DIM0 bits in DCNTL.
(4) Specify whether $\overline{\mathrm{DREQ}}_{1}$ is level or edge sense in the DMS1 bit
in DCNTL.
(5) Enable or disable DMA termination interrupt with the DIE1 bit in DSTAT.
(6) Program DE1 $=1$ (with $\overline{\mathrm{DWE1}}=0$ in the same access) in DSTAT and the DMA operation with the external I/O device will begin using the external $\overline{\mathrm{DREQ}}_{1}$ input and $\overline{\mathrm{TEND}}_{1}$ output.

### 10.4 DMA Bus Timing

When memory (and memory mapped I/O) is specified as a source or destination, $\overline{\mathrm{ME}}$ goes LOW during the memory access. When I/O is specified as a source or destination, $\overline{\mathrm{IOE}}$ goes LOW during the I/O access.

When I/O (and memory mapped I/O) is specified as a source or destination, the DMA timing is controlled by the external $\overline{\text { DREQ }}$ input and the TEND output indicates DMA termination. Note that external I/O devices may not overlap addresses with internal I/O and control registers, even using DMA.

For I/O accesses, 1 wait state is automatically inserted. Additional wait states can be inserted by programming the on-chip wait state generator or using the external WAIT input. Note that for memory mapped I/O accesses, this automatic I/O wait state is not inserted.

For memory to memory transfers (channel 0 only), the external $\overline{\mathrm{DREQ}}_{0}$ input is ignored. Automatic DMA timing is programmed as either burst or cycle steal.

When a DMA memory address carry/borrow between bits $\mathrm{A}_{15}$ and $A_{16}$ of the address bus occurs (when crossing 64 k bytes boundaries), the minimum bus cycle is extended to four clocks by automatic insertion of one internal Ti state.

### 10.5 DMAC Channel Priority

For simultaneous $\overline{\mathrm{DREQ}}_{0}$ and $\overline{\mathrm{DREQ}}_{1}$ requests, channel 0 has priority over channel 1 . When channel 0 is performing a memory $\longleftrightarrow$ memory transfer, channel 1 cannot operate until the channel 0 operation has terminated. If channel 1 is operating, channel 0 cannot operate until channel 1 releases control of the bus.

### 10.6 DMAC and BUSREQ, BUSACK

The $\overline{\text { BUSREQ }}$ and $\overline{\text { BUSACK }}$ inputs allow another bus master to take control of the HD64180 bus. $\overline{\text { BUSREQ }}$ and BUSACK have priority over the on-chip DMAC and will suspend DMAC operation. The DMAC releases the bus to the external bus master at the breakpoint of the DMAC memory or I/O access. Since a single byte DMAC transfer requires a read and a write cycle, it is possible for the DMAC to be suspended after the DMAC read, but before the DMAC write. Even in this case, when the external master releases the HD64180 bus (BUSREQ HIGH), the on-chip DMAC will correctly continue the suspended DMA operation.

### 10.7 DMAC Internal Interrupts

Fig. 45 illustrates the internal DMA interrupt request generation circuit.


Figure 45 DMAC Interrupt Request Circuit Diagram

DE0 and DE1 are automatically cleared to 0 by the HD64180 at the completion (byte count $=0$ ) of a DMA operation for channel 0 and channel 1 respectively. They remain 0 until a 1 is written. Since DE0 and DE1 use level sense, an interrupt will occur if the CPU $\mathrm{IEF}_{1}$ flag is set to 1 . Therefore, the DMA termination interrupt service routine should disable further DMA interrupts (by programming the channel DIE bit $=0$ ) before enabling CPU interrupts (i.e. $I E F_{1}$ is set to 1 ). After reloading the DMAC address and count registers, the DIE bit can be set to 1 to reenable the channel interrupt, and at the same time DMA can resume by programming the channel DE bit $=1$.

### 10.8 DMAC and NMI

$\overline{\text { NMI }}$, unlike all other interrupts, automatically disables DMAC operation by clearing the DME bit of DSTAT. Thus, the NMI interrupt service routine may respond to time critical events without delay due to DMAC bus usage. Also, NMI can be effectively used as an external DMA abort input, recognizing that both channels are suspended by the clearing of DME.

If the falling edge of NMI occurs before the falling clock of the state prior to $\mathrm{T}_{3}\left(\mathrm{~T}_{2}\right.$ or Tw) of the DMA write cycle, the DMAC will be suspended and the CPU will start the NMI response at the end of the current cycle.

By setting a channels DE bit to 1 , that channels operation can be restarted, and DMA will correctly resume from the point at which it was suspended by NMI. See Fig. 46 for details.


Figure $46 \overline{\mathrm{NMI}}$ and DMA Operation

### 10.9 DMAC and RESET

During RESET the bits in DSTAT, DMODE, and DCNTL are initialized as stated in their individual register descriptions. Any DMA operation in progress is stopped allowing the CPU to use the
bus to perform the RESET sequence. However, the address register (SAR0, DAR0, MAR1, IAR1) and byte count register (BCR0, BCR1) contents are not changed during RESET.

## 11 ASYNCHRONOUS SERIAL COMMUNICATION INTERFACE (ASCI)

The HD64180 on-chip ASCI has two independent full duplex channels. Based on full programmability of the following functions, the ASCI can directly communicate with a wide variety of standard UARTs (Universal Asynchronous Receiver/Transmitter) including the HD6350 CMOS ACIA and the Serial Communication Interface (SCI) contained on the HD6301 series CMOS single chip controllers.

The key functions for ASCI are shown below. Each channel is independently programmable.

- Full duplex communication
- 7- or 8 -bit data length
- Program controlled 9th data bit for multiprocessor communica-
tion
- 1 or 2 stop bits
- Odd, even, no parity
- Parity, overrun, framing error detection
- Programmable baud rate generator, $/ 16$ and $/ 64$ modes Speed to 38.4 k bits per second (CPU $\mathrm{f}_{\mathrm{C}}=6.144 \mathrm{MHz}$ )
- Modem control signals - Channel 0 has $\overline{\text { DCD }_{0}}, \overline{\mathrm{CTS}_{0}}$ and $\overline{\mathrm{RTS}_{0}}$ Channel 1 has $\overline{\text { CTS }}_{1}$
- Programmable interrupt condition enable and disable
- Operation with on-chip DMAC


### 11.1 ASCI Block Diagram

Fig. 47 shows the ASCI Block Diagram.


Figure 47 ASCI Block Diagram

### 11.2 ASCI Register Description

## (1) ASCI Transmit Shift Register 0, 1 (TSRO, 1)

When the ASCI Transmit Shift Register receives data from the ASCI Transmit Data Register (TDR), the data is shifted out to the TXA pin. When transmission is completed, the next byte (if available) is automatically loaded from TDR into TSR and the next transmission starts. If no data is available for transmission, TSR idles by outputting a continuous HIGH level. This register is not program accessible.
(2) ASCI Transmit Data Register 0,1 (TDRO, 1: 1/O Address $=$ 06H, 07H)
Data written to the ASCI Transmit Data Register is transferred to the TSR as soon as TSR is empty. Data can be written to while TSR is shifting out the previous byte of data. Thus, the ASCI transmitter is double bufferred.

Data can be written into and read from the ASCI Transmit Data Register.

If data is read from the ASCI Transmit Data Register, the ASCI
data transmit operation won't be affected by this read operation.
(3) ASCI Receive Shift Register 0, 1 (RSRO, 1)

This register receives data shifted in on the RXA pin. When full, data is automatically transferred to the ASCI Receive Data Register (RDR) if it is empty. If RSR is not empty when the next incoming data byte is shifted in, an overrun error occurs. This register is not program accessible.
(4) ASCI Receive Data Register 0, 1 (RDRO, 1: I/O Address $=$ 08H, 09H)
When a complete incoming data byte is assembled in RSR, it is automatically transferred to the RDR if RDR is empty. The next incoming data byte can be shifted into RSR while RDR contains the previous received data byte. Thus, the ASCI receiver is double buffered.

The ASCI Receive Data Register is read-only-register.
However, if RDRF $=0$, data can be written into the ASCI Receive Data Register, and the data can be read.
(5) ASCI Status Register 0, 1 (STATO, 1)

Each channel status register allows interrogation of ASCI communication, error and modem control signal status as well as enabling and disabling of ASCI interrupts.


ASCI Status Register 1 (STAT1 : l/O Address $=05 \mathrm{H}$ )


RDRF: Receive Data Register Full (bit 7)
RDRF is set to 1 when an incoming data byte is loaded into RDR. Note that if a framing or parity error occurs, RDRF is still set and the receive data (which generated the error) is still loaded into RDR. RDRF is cleared to 0 by reading RDR, when the $\overline{\mathrm{DCD}}_{0}$ input is HIGH, in IOSTOP mode and during RESET.

## OVRN: Overrun Error (bit 6)

OVRN is set to 1 when RDR is full and RSR becomes full. OVRN is cleared to 0 when the EFR bit (Error Flag Reset) of CNTLA is written to 0 , when $\overline{\mathrm{DCD}_{0}}$ is HIGH, in IOSTOP mode and during RESET.

## PE: Parity Error (bit 5)

PE is set to 1 when a parity error is detected on an incoming data byte and ASCI parity detection is enabled (the MOD1 bit of CNTLA is set to 1). PE is cleared to 0 when the EFR bit (Error Flag Reset) of CNTLA is written to 0 , when $\overline{\mathrm{DCD}}_{0}$ is HIGH, in IOSTOP mode and during RESET.

## FE: Framing Error (bit 4)

If a receive data byte frame is delimited by an invalid stop bit (i.e. 0 , should be 1), FE is set to 1 . FE is cleared to 0 when the EFR bit (Error Flag Reset) of CNTLA is written to 0 , when $\overline{\mathrm{DCD}}_{0}$ is HIGH, in IOSTOP mode and during RESET.

RIE: Receive Interrupt Enable (bit 3)
RIE should be set to 1 to enable ASCI receive interrupt requests. When RIE to 1 , if any of the flags RDRF, OVRN, PE, FE become set to 1 an interrupt request is generated. For channel 0 , an interrupt will also be generated by the transition of the external $\overline{\mathrm{DCD}_{0}}$ input from LOW to HIGH. RIE is cleared to 0 during RESET.

## $\overline{D_{0}}$ : Data Carrier Detect (bit 2 STATO)

Channel 0 has an external $\overline{D C D}_{0}$ input pin. The $\overline{\mathrm{DCD}}_{0}$ bit is set to 1 when the $\overline{\mathrm{DCD}}_{0}$ input is HIGH. It is cleared to 0 on the first read of STAT0 following the HIGH to LOW transition of $\overline{\mathrm{DCD}_{0}}$ input and during RESET. When $\overline{\mathrm{DCD}_{0}}=1$, receiver unit is reset and receiver operation is inhibited.

## CTS1E: Channel 1 CTS Enable (bit 2 STAT1)

Channel 1 has an external $\overline{\mathrm{CTS}}_{1}$ input which is multiplexed with the receive data pin (RXS) for the CSI/O (Clocked Serial I/O Port). Setting CTS1E to 1 selects the $\overline{\mathrm{CTS}}_{1}$ function and clearing CTS1E to 0 selects the RXS function.

## TDRE: Transmit Data Register Empty (bit 1)

TDRE $=1$ indicates that the TDR is empty and the next transmit data byte can be written to TDR. After the byte is written to TDR, TDRE is cleared to 0 until the ASCI transfers the byte from the TDR to the TSR, at which time TDRE is again set to 1. TDRE
is set to 1 in IOSTOP mode and during RESET. When the external $\overline{\text { CTS }}$ input is HIGH, TDRE is reset to 0 .

## TIE: Transmit Interrupt Enable (bit 0)

TIE should be set to 1 to enable ASCI transmit interrupt requests. If TIE $=1$, an interrupt will be requested when $\mathrm{TDRE}=1$. TIE is cleared to 0 during RESET.

## - ASCI Control Register AO, 1 (CNTLAO, 1)

Each ASCI channel Control Register A configures the major operating modes such as receiver/transmitter enable and disable, data format, and multiprocessor communication mode.


## MPE: Multi Processor Mode Enable (bit 7)

The ASCI has a multiprocessor communication mode which utilizes an extra data bit for selective communication when a number of processors share a common serial bus. Multiprocessor data format is selected when the MP bit in CNTLB is set to 1 . If multiprocessor mode is not selected (MP bit in CNTLB $=0$ ), MPE has no effect. If multiprocessor mode is selected, MPE enables or disables the 'wake-up' feature as follows. If MPE is set to 1 , only received bytes in which the MPB (multiprocessor bit) $=1$ can affect the RDRF and error flags. Effectively, other bytes (with MPB $=0$ ) are 'ignored' by the ASCI. If MPE is reset to 0, all bytes, regardless of the state of the MPB data bit, affect the RDRF and error flags. MPE is cleared to 0 during RESET.

## RE: Receiver Enable (bit 6)

When RE is set to 1 , the ASCI receiver is enabled. When RE is cleared to 0 , the receiver is disabled and any receive operation in progress is interrupted. However, the RDRF and error flags are not reset and the previous contents of RDRF and error flags are held. RE is cleared to 0 in IOSTOP mode and during RESET.

## TE: Transmitter Enable (bit 5)

When TE is set to 1 , the ASCI transmitter is enabled. When TE is cleared to 0 , the transmitter is disabled and any transmit operation in progress is interrupted. However, the TDRE flag is not reset and the previous contents of TDRE are held. TE is cleared to 0 in IOSTOP mode and during RESET.
$\overline{\text { RTS }_{\mathbf{0}}}$ - Request to Send Channel 0 (bit 4 in CNTLAO)
When $\overline{\mathrm{RTS}} \mathrm{T}_{0}$ is cleared to 0 , the $\overline{\mathrm{RTS}_{0}}$ output pin will go LOW. When $\mathrm{RTS}_{0}$ is set to 1 , the $\overline{\mathrm{RTS}}_{0}$ output immediately goes HIGH. $\overline{\mathrm{RTS}_{0}}$ is set to 1 during RESET.

## CKA1D: CKA1 Clock Disable (bit 4 in CNTLA1)

When CKA1D is set to 1 , the multiplexed CKA1/ $\overline{\mathrm{TEND}_{0}}$ pin is used for the $\overline{T E N D}_{0}$ function. When CKA1D $=0$, the pin is used as CKA1, an external data clock input/output for channel 1. CKA1D is cleared to 0 during RESET.

MPBR/EFR: Multiprocessor Bit Receive/Error Flag Reset (bit 3)

When multiprocessor mode is enabled (MP in CNTLB $=1$ ), MPBR, when read, contains the value of the MPB bit for the last re-
ceive operation. When written to 0 , the EFR function is selected to reset all error flags (OVRN, FE and PE) to 0. MPBR/EFR is undefined during RESET.

MOD2, 1, 0: ASCI Data Format Mode 2, 1, 0 (bits 2-0)
These bits program the ASCI data format as follows.
MOD2
$=0 \rightarrow 7$ bit data
$=1 \rightarrow 8$ bit data
MOD1
$=0 \rightarrow$ No parity

$$
=1 \rightarrow \text { Parity enabled }
$$

MOD0
$=0 \rightarrow 1$ stop bit
$=1 \rightarrow 2$ stop bits
The data formats available based on all combinations of MOD2, MOD1 and MOD0 are shown in Table 10.

Table 10 Combination of Data Format

| MOD2 | MOD1 | MODO | Data Format |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Start + 7 bit data + 1 stop |
| 0 | 0 | 1 | Start + 7 bit data + 2 stop |
| 0 | 1 | 0 | Start + 7 bit data + parity + 1 stop |
| 0 | 1 | 1 | Start + 7 bit data + parity + 2 stop |
| 1 | 0 | 0 | Start + 8 bit data + 1 stop |
| 1 | 0 | 1 | Start + 8 bit data + 2 stop |
| 1 | 1 | 0 | Start + 8 bit data + parity + 1 stop |
| 1 | 1 | 1 | Start + 8 bit data + parity + 2 stop |

## (6) ASCI Control Register BO, 1 (CNTLBO, 1)

Each ASCI channel control register B configures multiprocessor mode, parity and baud rate selection.


## MPBT: Multiprocessor Bit Transmit (bit 7)

When multiprocessor communication format is selected (MP bit $=1$ ), MPBT is used to specify the MPB data bit for transmission. If MPBT $=1$, then MPB $=1$ is transmitted. If MPBT $=0$, then MPB $=0$ is transmitted. MPBT state is undefined during and after RESET.

## MP: Multiprocessor Mode (bit 6)

When MP is set to 1 , the data format is configured for multiprocessor mode based on the MOD2 (number of data bits) and MOD0 (number of stop bits) bits in CNTLA. The format is as follows.

$$
\text { Start bit }+7 \text { or } 8 \text { data bits }+ \text { MPB bit }+1 \text { or } 2 \text { stop bits }
$$

Note that multiprocessor ( $\mathrm{MP}=1$ ) format has no provision for parity. If MP $=0$, the data format is based on MOD0, MOD1 and MOD2 and may include parity. The MP bit is cleared to 0 during RESET.

## $\overline{\text { CTS }} /$ PS: Clear to Send/Prescale (bit 5)

When read, $\overline{\text { CTS }} /$ PS reflects the state of the external $\overline{\text { CTS }}$ input. If the CTS input pin is HIGH, CTS/PS will be read as 1. Note that when the CTS input pin is HIGH, the TDRE bit is inhibited (i.e. held at 0 ). For channel 1 , the $\overline{\mathrm{CTS}}_{1}$ input is multiplexed with RXS pin (Clocked Serial Receive Data). Thus, CTS/PS is only valid when read if the channel 1 CTS1E bit $=1$ and the $\overline{\mathrm{CTS}}_{1}$ input pin function is selected. The read data of $\overline{\text { CTS }} /$ PS is not affected by RESET.

When written, $\overline{\text { CTS }} /$ PS specifies the baud rate generator prescale factor. If CTS/PS is set to 1 , the system clock ( $\phi$ ) is prescaled by 30 while if CTS/PS is cleared to 0 , the system clock is prescaled by 10 . CTS/PS is cleared to 0 during RESET.

## PEO: Parity Even Odd (bit 4)

PEO selects even or odd parity. PEO does not affect the enabling/disabling of parity (MOD1 bit of CNTLA). If PEO is cleared to 0 , even parity is selected. If PEO is set to 1 , odd parity is selected. PEO is cleared to 0 during RESET.

## DR: Divide Ratio (bit 3)

DR specifies the divider used to obtain baud rate from the data sampling clock. If DR is cleared to 0 , divide by 16 is used while if DR is set to 1 , divide by 64 is used. DR is cleared to 0 during RESET.

SS2, 1, 0: Source/Speed Select 2, 1, 0 (bits 2-0)
Specify the data clock source (internal or external) and baud rate prescale factor. SS2, SS1, and SS0 are all set to 1 during RESET. Table 11 shows the divide ratio corresponding to SS2, SS1, and SS0.

Table 11 Divide Ratio

| SS2 | SS1 | SS0 | Divide Ratio |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\div 1$ |
| 0 | 0 | 1 | $\div 2$ |
| 0 | 1 | 0 | $\div 4$ |
| 0 | 1 | 1 | $\div 8$ |
| 1 | 0 | 0 | $\div 16$ |
| 1 | 0 | 1 | $\div 32$ |
| 1 | 1 | 0 | $\div 64$ |
| 1 | 1 | 1 | external clock |

The external ASCI channel 0 data clock pins are multiplexed with DMA control lines ( $\mathrm{CKA}_{0} / \overline{\mathrm{DREQ}}_{0}$ and $\mathrm{CKA}_{1} / \overline{\mathrm{TEND}}_{0}$ ). During RESET, these pins are initialized as ASCI data clock inputs. If SS2, SS1, and SS0 are reprogrammed (any other value than SS2, SS1, SS0 $=1$ ) these pins become ASCI data clock outputs. However, if DMAC channel 0 is configured to perform memory $\longleftrightarrow$ I/O (and memory mapped I/O) transfers the $\mathrm{CKA}_{0} / \overline{\mathrm{DREQ}_{0}}$ pin revert to DMA control signals regardless of SS2, SS1, and SS0 programming. Also, if the CKA1D bit in the CNTLA register is set to 1 , then the $\mathrm{CKA}_{1} / \overline{\mathrm{TEND}}_{0}$ reverts to the DMA Control output function regardless of SS2, SS1, and SS0 programming.

Final data clock rates are based on CTS/PS (prescale), DR, SS2, SS1, SS0, and the HD64180 system clock ( $\phi$ ) frequency as shown in Table 12.

Table 12 Baud Rate List

| Prescaler |  | Sampling Rate |  | Baud Rate |  |  |  | General Divide Ratio | Baud Rate (Example) (BPS) |  |  | CKA |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PS | Divide Ratio | DR | Rate | SS2 | SS1 | SS0 | Divide Ratio |  | $\begin{gathered} \phi=6.144 \\ \mathrm{MHz} \end{gathered}$ | $\begin{gathered} \phi=4.608 \\ \mathrm{MHz} \end{gathered}$ | $\begin{gathered} \phi=3.072 \\ \mathrm{MHz} \end{gathered}$ | 1/0 | Clock Frequency |
| 0 | $\phi \div 10$ | 0 | 16 | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{array}{r} \div 1 \\ 2 \\ 4 \\ 8 \\ 16 \\ 32 \\ 64 \end{array}$ | $\begin{array}{r} \phi \div 160 \\ 320 \\ 640 \\ 1280 \\ 2560 \\ 5120 \\ 10240 \end{array}$ | $\begin{array}{r} 38400 \\ 19200 \\ 9600 \\ 4800 \\ 2400 \\ 1200 \\ 600 \end{array}$ |  | $\begin{array}{r} 19200 \\ 9600 \\ 4800 \\ 2400 \\ 1200 \\ 600 \\ 300 \end{array}$ | 0 | $\begin{array}{r} \phi \div 10 \\ 20 \\ 40 \\ 80 \\ 160 \\ 320 \\ 640 \end{array}$ |
|  |  |  |  | 1 | 1 | 1 | - | $\mathrm{fc} \div 16$ | - | - | - | 1 | fc |
|  |  | 1 | 64 | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{array}{r} \div 1 \\ 2 \\ 4 \\ 8 \\ 16 \\ 32 \\ 64 \end{array}$ | $\begin{array}{r} \phi \div 640 \\ 1280 \\ 2560 \\ 5120 \\ 10240 \\ 20480 \\ 40960 \end{array}$ | $\begin{array}{r} 9600 \\ 4800 \\ 2400 \\ 1200 \\ 600 \\ 300 \\ 150 \end{array}$ |  | $\begin{array}{r} 4800 \\ 2400 \\ 1200 \\ 600 \\ 300 \\ 150 \\ 75 \end{array}$ | 0 | $\begin{array}{r} \phi \div 10 \\ 20 \\ 40 \\ 80 \\ 160 \\ 320 \\ 640 \end{array}$ |
|  |  |  |  | 1 | 1 | 1 | - | $\mathrm{fc} \div 64$ | - | - | - | 1 | fc |
| 1 | $\phi \div 30$ | 0 | 16 | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{array}{r} \div 1 \\ 2 \\ 4 \\ 8 \\ 16 \\ 32 \\ 64 \end{array}$ | $\begin{array}{r} \phi \div 480 \\ 960 \\ 1920 \\ 3840 \\ 7680 \\ 15360 \\ 30720 \end{array}$ |  | $\begin{array}{r} 9600 \\ 4800 \\ 2400 \\ 1200 \\ 600 \\ 300 \\ 150 \end{array}$ |  | 0 | $\begin{array}{r} \phi \div 30 \\ 60 \\ 120 \\ 240 \\ 480 \\ 960 \\ 1920 \end{array}$ |
|  |  |  |  | 1 | 1 | 1 | - | $\mathrm{fc} \div 16$ | - | - | - | 1 | fc |
|  |  | 1 | 64 | 0 0 0 0 1 1 1 | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{array}{r} \div 1 \\ 2 \\ 4 \\ 8 \\ 16 \\ 32 \\ 64 \end{array}$ | $\begin{array}{r} \phi \div 1920 \\ 3840 \\ 7680 \\ 15360 \\ 30720 \\ 61440 \\ 122880 \end{array}$ |  | $\begin{array}{r} 2400 \\ 1200 \\ 600 \\ 300 \\ 150 \\ 75 \\ 37.5 \end{array}$ |  | 0 | $\begin{array}{r} \phi \div 30 \\ 60 \\ 120 \\ 240 \\ 480 \\ 960 \\ 1920 \end{array}$ |
|  |  |  |  | 1 | 1 | 1 | - | $\mathrm{fc} \div 64$ | - | - | - | 1 | fc |

### 11.3 MODEM Control Signals

ASCI channel 0 has $\overline{\mathrm{CTS}}_{0}, \overline{\mathrm{DCD}}_{0}$, and $\overline{\mathrm{RTS}_{0}}$ external modem control signals. ASCI channel 1 has a $\mathrm{CTS}_{1}$ modem control signal which is multiplexed with RXS pin (Clocked Serial Receive Data).

## (1) $\overline{\text { CTS }_{0}}$ : Clear to Send 0 (input)

The $\mathrm{CTS}_{0}$ input allows external control (start/stop) of ASCI channel 0 transmit operations. When $\overline{\mathrm{CTS}}_{0}$ is HIGH, channel 0 TDRE bit is held at 0 regardless of whether the TDR 0 (Transmit Data Register) is full or empty. When $\overline{\mathrm{CTS}}_{0}$ is LOW, TDRE will reflect the state of TDR 0 . Note that the actual transmit operation is not disabled by $\overline{\mathrm{CTS}}_{0} \mathrm{HIGH}$, only TDRE is inhibited.

## (2) $\overline{\mathbf{D C D}_{\mathbf{0}}}:$ Data Carrier Detect 0 (input)

The $\overline{\mathrm{DCD}}_{0}$ input allows external control (start/stop) of ASCI channel 0 receive operations. When $\overline{\mathrm{DCD}}_{0}$ is HIGH, channel 0 RDRF bit is held at 0 regardless of whether the RDR0 (Receive Data Register) is full or empty. The error flags (PE, FE and OVRN bits) are also held at 0 . Even after the $\overline{\mathrm{DCD}}_{0}$ input goes LOW, these
bits will not resume normal operation until the status register (STAT0) is read. Note that this first read of STAT0, while enabling normal operation, will still indicate the $\overline{\mathrm{DCD}}_{0}$ input is HIGH $\overline{\text { (DCD0 }}$ bit $=1$ ) even though it has gone LOW. Thus, the STAT0 register should be read twice to insure the $\overline{\mathrm{DCD} 0}$ bit is cleared to 0 .
(3) $\overline{\text { RTS }_{0}}$ : Request to Send $\mathbf{0}$ (output)
$\overline{\mathrm{RTS}}_{0}$ allows the ASCI to control (start/stop) another communication devices transmission (for example, by connection to that devices $\overline{\mathrm{CTS}}$ input). $\overline{\mathrm{RTS}}_{0}$ is essentially a 1 bit output port, having no side effects on other ASCI registers or flags.

## (4) $\overline{\text { CTS }}_{1}$ : Clear to Send 1 (input)

Channel 1 CTS $_{1}$ input is multiplexed with the RXS pin (Clocked Serial Receive Data). The $\overline{\mathrm{CTS}}_{1}$ function is selected when the CTS1E bit in STAT1 is set to 1 . When enabled, the CTS ${ }_{1}$ operation is equivalent to $\overline{\mathrm{CTS}_{0}}$.

Modem control signal timing is shown in Fig. 48 (a) and Fig. 48 (b).
$\qquad$


Figure 48 (a) $\overline{D_{C D}}$ Timing

$\overline{W R}$

$\overline{\text { RTSO Flag }}$ $\qquad$
$\overline{\text { RTSo }}$ Pin


Figure 48 (b) $\overline{\mathrm{RTS}_{0}}$ Timing

### 11.4 ASCI Interrupts

Fig. 49 shows the ASCI interrupt request generation circuit.


Figure 49 ASCI Interrupt Request Circuit Diagram

### 11.5 ASCI $\longleftrightarrow$ DMAC operation

Operation of the ASCI with the on-chip DMAC channel 0 requires the DMAC be correctly configured to utilize the ASCI flags as DMA request signals.

### 11.6 ASCI and RESET

During RESET, the ASCI status and control registers are initialized as defined in the individual register descriptions.

Receive and Transmit operations are stopped during RESET. However, the contents of the transmit and receive data registers (TDR and RDR) are not changed by RESET.

### 11.7 ASCI Clock

In external clock input mode, the external clock is directly input to the sampling rate $(\div 16 / \div 64)$ as shown in Fig. 50 .


Figure 50 ASCI Clock Block Diagram

## 12 CLOCKED SERIAL I/O PORT (CSI/O)

The HD64180 includes a simple, high speed clock synchronous serial I/O port. The CSI/O includes transmit/receive (half duplex), fixed 8-bit data and internal or external data clock selection. High speed operation (baud rate as high as 200 k bits/second at $\mathrm{f}_{\mathrm{C}}=4$ MHz ) is provided. The CSI/O is ideal for implementing a multiprocessor communication link between the HD64180 and the HMCS400 series (4-bit) and the HD6301 series (8-bit) single chip
controllers as well as additional HD64180s. These secondary devices may typically perform a portion of the system I/O processing such as keyboard scan/decode, LDC interface etc.

### 12.1 CSI/O Block Diagram

The CSI/O block diagram is shown in Fig. 51. The CSI/O consists of two registers - the Transmit/Receive Data Register (TRDR) and Control Register (CNTR).


Figure 51 CSI/O Block Diagram

### 12.2 CSI/O Register Description

(1) CSI/O Transmit/Receive Data Register (TRDR: I/O Address $=\mathrm{OBH}$ )
TRDR is used for both CSI/O transmission and reception. Thus, the system design must insure that the constraints of half-duplex operation are met (Transmit and receive operation can't occur simultaneously). For example, if a CSI/O transmission is attempted at the same time that the CSI/O is receiving data, a CSI/O will not work. Also note that TRDR is not buffered. Therefore, attempting to perform a CSI/O transmit while the previous transmit data is still being shifted out causes the shift data to be immediately updated, thereby corrupting the transmit operation in progress. Similarly, reading TRDR while a transmit or receive is in progress should be avoided.
(2) CSI/O Control/Status Register (CNTR: I/O Address $=$ OAH)
CNTR is used to monitor CSI/O status, enable and disable the CSI/O, enable and disable interrupt generation and select the data clock speed and source.


## EF: End Flag (bit 7)

EF is set to 1 by the CSI/O to indicate completion of an 8-bit data transmit or receive operation. If EIE (End Interrupt Enable)
bit $=1$ during the time $\mathrm{EF}=1$, a CPU interrupt request will be generated. Program access of TRDR should only occur if $\mathrm{EF}=1$. The CSI/O clears EF to 0 when TRDR is read or written. EF is cleared to 0 during RESET and IOSTOP mode.

## EIE: End Interrupt Enable (bit 6)

EIE should be set to 1 to enable $\mathrm{EF}=1$ to generate a CPU interrupt request. The interrupt request is inhibited if EIE is cleared to 0. EIE is cleared to 0 during RESET.

## RE: Receive Enable (bit 5)

A CSI/O receive operation is started by setting RE to 1 . When RE is set to 1 , the data clock is enabled. In internal clock mode, the data clock is output from the CKS pin. In external clock mode, the clock is input on the CKS pin. In either case, data is shifted in on the RXS pin in synchronization with the (internal or external) data clock. After receiving 8 bits of data, the CSI/O automatically clears RE to $0, \mathrm{EF}$ is set to 1 and an interrupt (if enabled by EIE $=1$ ) will be generated. Note that RE and TE should never both be set to 1 at the same time. RE is cleared to 0 during RESET and IOSTOP mode.

Note that the RXS pin ( $\operatorname{pin} 52$ ) is multiplexed with $\overline{\text { CTS }_{1}}$ modem control input of ASCI channel 1. In order to enable the RXS function, the CTS1E bit in CNTA1 should be reset to 0 .

## TE: Transmit Enable (bit 4)

A CSI/O transmit operation is started by setting TE to 1 . When TE is set to 1 , the data clock is enabled. In internal clock mode, the data clock is output from the CKS pin. In external clock mode, the clock is input on the CKS pin. In either case, data is shifted out on the TXS pin synchronous with the (internal or external) data clock. After transmitting 8 bits of data, the CSI/O automatically clears TE
to $0, \mathrm{EF}$ is set to 1 and an interrupt (if enabled by EIE $=1$ ) will be generated. Note that TE and RE should never both be set to 1 at the same time. TE is cleared to 0 during RESET and IOSTOP mode.

SS2, 1, O: Speed Select 2, 1, 0 (bits 2-0)
SS2, SS1 and SS0 select the CSI/O transmit/receive clock source and speed. SS2, SS1 and SS0 are all set to 1 during RESET. Table 13 shows CSI/O Baud Rate Selection.

Table $13 \mathrm{CSI} / \mathrm{O}$ Baud Rate Selection

| SS2 | SS1 | SS0 | Divide <br> Ratio | Baud <br> Rate |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\div 20$ | $(200000)$ |
| 0 | 0 | 1 | $\div 40$ | $(100000)$ |
| 0 | 1 | 0 | $\div 80$ | $(50000)$ |
| 0 | 1 | 1 | $\div 160$ | $(25000)$ |
| 1 | 0 | 0 | $\div 320$ | $(12500)$ |
| 1 | 0 | 1 | $\div 640$ | $(6250)$ |
| 1 | 1 | 0 | $\div 1280$ | $(3125)$ |
| 1 | 1 | 1 | external Clock input <br> (less than $\div 20)$ |  |

( ) shows the baud rate (BPS) at $\phi=4 \mathrm{MHz}$.
After RESET, the CKS pin is configured as an external clock input (SS2, SS1, SS0 $=1$ ). Changing these values causes CKS to become an output pin and the selected clock will be output when transmit or receive operations are enabled.

### 12.3 CSI/O Interrupts

The CSI/O interrupt request circuit is shown in Fig. 52.


Figure $52 \mathrm{CSI} / O$ Interrupt Circuit Diagram

### 12.4 CSI/O Operation

The CSI/O can be operated using status polling or interrupt driven algorithms.
(1) Transmit - Polling
(1) Poll the TE bit in CNTR until TE $=0$.
(2) Write the transmit data into TRDR.
(3) Set the TE bit in CNTR to 1.
(4) Repeat 1 to 3 for each transmit data byte.
(2) Transmit - Interrupts
(1) Poll the TE bit in CNTR until TE $=0$.
(2) Write the first transmit data byte into TRDR.
(3) Set the TE and EIE bits in CNTR to 1.
(4) When the transmit interrupt occurs, write the next transmit data byte into TRDR.
(5) Set the TE bit in CNTR to 1.
(6) Repeat 4 to 5 for each transmit data byte.
(3) Receive - Polling
(1) Poll the RE bit in CNTR until RE $=0$.
(2) Set the RE bit in CNTR to 1.
(3) Poll the RE bit in CNTR until RE $=0$.
(4) Read the receive data from TRDR.
(5) Repeat 2 to 4 for each receive data byte.
(4) Receive - Interrupts
(1) Poll the RE bit in CNTR until RE $=0$.
(2) Set the RE and EIE bits in CNTR to 1.
(3) When the receive interrupt occurs read the receive data from TRDR.
(4) Set the RE bit in CNTR to 1.
(5) Repeat 3 to 4 for each receive data byte.

### 12.5 CSI/O Operation Timing Notes

(1) Note that transmitter clocking and receiver sampling timings are different from internal and external clocking modes. Fig. 53 to Fig. 54 shows CSI/O Transmit/Receive Timing.
(2) The transmitter and receiver should be disabled (TE and RE $=0$ ) when initializing or changing the baud rate.

### 12.6 CSI/O Operation Notes

(1) Disable the transmitter and receiver ( TE and $\mathrm{RE}=0$ ) before initializing or changing the baud rate. When changing the baud rate after completion of transmission or reception, a delay of at least one bit time is required before baud rate modification.
(2) When RE or TE is cleared to 0 by software, a corresponding receive or transmit operation is immediately terminated. Normally, TE or RE should only be cleared to 0 when EF $=1$.
(3) Simultaneous transmission and reception is not possible. Thus, TE and RE should not both be 1 at the same time.


Figure 53 Transmit Timing - Internal Clock


TE


EF


Figure 54 Transmit Timing - External Clock


Figure 55 Receive Timing - Internal Clock


Read or write of CSI/O Transmit/Receive Data Register

Figure 56 Receive Timing - External Clock
12.7 CSI/O and RESET

During RESET each bit in the CNTR is initialized as defined in the CNTR register description.

CSI/O transmit and receive operations in progress are aborted during RESET. However, the contents of TRDR are not changed.

## 13 PROGRAMMABLE RELOAD TIMER (PRT)

The HD64180 contains a two channel 16-bit Programmable Reload Timer. Each PRT channel contains a 16-bit down counter and a 16-bit reload register. The down counter can be directly read and written and a down counter overflow interrupt can be programmably enabled or disabled. In addition, PRT channel 1 has a TOUT output pin (multiplexed with $\mathrm{A}_{18}$ ) which can be set HIGH, LOW, or toggled. Thus PRT1 can perform programmable output waveform
generation.

### 13.1 PRT Block Diagram

The PRT block diagram is shown in Fig. 57. The two channels have separate timer data and reload registers and a common status/ control register. The PRT input clock for both channels is equal to the system clock $(\phi)$ divided by 20 .


Figure 57 PRT Block Diagram

### 13.2 PRT Register Description

(1) Timer Data Register (TMDR: I/O Address $=\mathbf{C H O}$ : ODH, OCH CH1: 15H, 14H)
PRT0 and PRT1 each have 16-bit Timer Data Registers (TMDR). TMDR0 and TMDR1 are each accessed as low and high byte registers (TMDR0H, TMDR0L and TMDR1H, TMDR1L). During RESET, TMDR0 and TMDR1 are set to FFFFH.

TMDR is decremented once every twenty $\phi$ clocks. When TMDR counts down to 0 , it is automatically reloaded with the value contained in the Reload Register (RLDR).

TMDR can be read and written by software using the following procedures. The read procedure uses a PRT internal temporary storage register to return accurate data without requiring the timer to be stopped. The write procedure requires the PRT to be stopped.

For reading (without stopping the timer), TMDR must be read in the order of lower byte - higher byte (TMDRnL, TMDRnH). The lower byte read (TMDRnL) will store the higher byte value in an internal register. The following higher byte read (TMDRnH) will access this internal register. This procedure insures timer data validity by eliminating the problem of potential 16-bit timer updating between each 8 -bit read. Specifically, reading TMDR in higher byte - lower byte order may result in invalid data. Note the implications of TMDR higher byte internal storage for applications which may read only the lower and/or higher bytes. In normal operation all TMDR read routines should access both the lower and higher bytes, in that order.

For writing, the TMDR down counting must be inhibited using the TDE (Timer Down Count Enable) bits in the TCR (Timer Control Register), following which any or both higher and lower bytes of TMDR can be freely written (and read) in any order.
(2) Timer Reload Register (RLDR: I/O Address $=\mathbf{C H O}$ : OEH, OFH CH1: 16H, 17H)
PRT0 and PRT1 each have 16 -bit Timer Reload Registers (RLDR). RLDR0 and RLDR1 are each accessed as low and high byte registers (RLDR0H, RLDR0L and RLDR1H, RLDR1L). During RESET RLDR0 and RLDR1 are set to FFFFH.

When the TMDR counts down to 0 , it is automatically reloaded with the contents of RLDR.

## (3) Timer Control Register (TCR)

TCR monitors both channels (PRT0, PRT1) TMDR status and controls enabling and disabling of down counting and interrupts as well as controlling the output pin ( $\mathrm{A}_{18} /$ TOUT) for PRT 1.


TIF1: Timer Interrupt Flag 1 (bit 7)
When TMDR1 decrements to 0 , TIF1 is set to 1 . This can generate an interrupt request if enabled by TIE1 $=1$. TIF1 is reset to 0 when TCR is read and the higher or lower byte of TMDR 1 are read. During RESET, TIF1 is cleared to 0 .

## TIFO: Timer Interrupt Flag 0 (bit 6)

When TMDR 0 decrements to 0 , TIF 0 is set to 1 . This can generate an interrupt request if enabled by TIE $0=1$. TIF0 is reset to 0 when TCR is read and the higher or lower byte of TMDR0 are read. During RESET, TIF0 is cleared to 0 .

TIE1: Timer Interrupt Enable 1 (bit 5)
When TIE1 is set to 1 , TIF1 $=1$ will generate a CPU interrupt request. When TIE1 is reset to 0 , the interrupt request is inhibited. During RESET, TIE1 is cleared to 0.

TIEO: Timer Interrupt Enable 0 (bit 4)
When TIE0 is set to 1 , TIF0 $=1$ will generate a CPU interrupt request. When TIE0 is reset to 0 , the interrupt request is inhibited. During RESET, TIE0 is cleared to 0 .

## TOC1, 0: Timer Output Control (bits 3, 2)

TOC1 and TOC0 control the output of PRT1 using the multiplexed $\mathrm{A}_{18}$ /TOUT pin as shown below. During RESET, TOC1 and TOC0 are cleared to 0 . This selects the address function for $\mathrm{A}_{18}$ / TOUT. By programming TOC1 and TOC0, the $\mathrm{A}_{18} /$ TOUT pin can be forced HIGH, LOW or toggled when TMDR 1 decrements to 0.

| TOC1 | TOCO | OUTPUT |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Inhibited | $\begin{array}{l}\text { (A } \text { 18 }_{18} \text { /TOUT pin is selected as } \\ \text { an address output function.) }\end{array}$ |
| 0 | 1 | toggled* |  |
| 1 | 0 | 0 |  |
| 1 | 1 | 1 |  |$]$| (A A 18 /TOUT pin is selected |
| :--- |
| as a PRT1 output function.) |

- When TMDR1 decrements to 0, TOUT level is reversed. This can provide square wave with $50 \%$ duty to external devices without any software support.
TDE1, 0: Timer Down Count Enable (bits 1, 0)
TDE1 and TDE0 enable and disable down counting for TMDR1 and TMDR 0 respectively. When TDEn $(\mathrm{n}=0,1)$ is set to 1 , down counting is executed for TMDRn. When TDEn is reset to 0 , down counting is stopped and TMDRn can be freely read or written. TDE1 and TDE0 are cleared to 0 during RESET and TMDRn will not decrement until TDEn is set to 1 .

Fig. 58 shows timer initialization, count down and reload timing. Fig. 59 shows timer output ( $\mathrm{A}_{18} / \mathrm{TOUT}$ ) timing.


Figure 58 PRT Operation Timing


TOUT


Figure 59 PRT Output Timing


Figure 60 PRT Interrupt Request Circuit Diagram

### 13.3 PRT Interrupts

The PRT interrupt request circuit is shown in Fig. 60.

### 13.4 PRT and RESET

During RESET the bits in TCR are initialized as defined in the TCR register description. Down counting is stopped and the TMDR and RLDR registers are initialized to FFFFH. The $\mathrm{A}_{18}$ /TOUT pin reverts to the address output function.
13.5 PRT Operation Notes
(1) TMDR data can be accurately read without stopping down counting by reading the lower (TMDRnL*) and higher (TMDRnH*) bytes in that order. Or, TMDR can be freely read or written by stopping the down counting.
(2) Care should be taken to insure that a timer reload does not occur during or between lower (RLDRnL*) and higher (RLDRnH*) byte writes. This may be guaranteed by system design/timing or by stopping down counting (with TMDR containing a non-zero value) during the RLDR updating. Similarly, in applications in which TMDR is written at each TMDR overflow, the system/software design should guarantee that RLDR can be updated before the next overflow occurs. Otherwise, time base inaccuracy will occur.
NOTE: $* \mathrm{n}=0,1$
(3) During RESET, the multiplexed $\mathrm{A}_{18}$ /TOUT pin reverts to the address output.
By reprogramming the TOC1 and TOC0 bits, the timer output
function for PRT channel 1 can be selected. The following shows the initial state of the TOUT pin after TOC1 and TOC0 are programmed to select the PRT channel 1 timer output function.
(i) PRT (channel 1) has not counted down to 0 .

If the PRT has not counted down to 0 (timed out), the initial state of TOUT depends on the programmed value in $\mathrm{TOC1}$ and TOC0:

| TOC1 | TOC0 | TOUT State After <br> Programming <br> TOC1/TOC0 | TOUT State After <br> Next Timeout |
| :---: | :---: | :---: | :---: |
| 0 | 1 | HIGH (1) | LOW (0) |
| 1 | 0 | HIGH (1) | LOW (0) |
| 1 | 1 | HIGH (1) | HIGH (1) |

(ii)PRT (channel 1) has counted down to 0 at least once. If the PRT has counted down to 0 (timed out) at least once, the initial state of TOUT depends on the number of time outs (even or odd) that have occurred.

| Numbers of Timeouts <br> (even or odd) | TOUT State After <br> Programming TOC $1 /$ TOCO |
| :---: | :---: |
| Even $(2,4,6 \ldots)$ | HIGH (1) |
| Odd $(1,3,5 \ldots)$ | LOW (0) |

## 14 INTERNAL I/O REGISTERS

The HD64180 internal I/O Registers occupy 64 I/O addresses (including reserved addresses). These registers access the internal I/O modules (ASCI, CSI/O, PRT) and control functions (DMAC, DRAM refresh, interrupts, wait state generator, MMU and I/O relocation).

To avoid address conflicts with external I/O, the HD64180 internal I/O addresses can be relocated on 64 bytes boundaries within the bottom 256 bytes of the 64 k bytes I/O address space.

### 14.1 I/O Control Register (ICR)

ICR allows relocating of the internal I/O addresses. ICR also controls enabling/disabling of the IOSTOP mode.


IOA7,6: I/O Address Relocation (bits 7-6)
IOA7 and IOA6 relocate internal I/O as shown in Fig. 61. Note that the high-order 8 bits of 16-bit internal I/O addresses are always 0 . IOA 7 and IOA6 are cleared to 0 during RESET.


Figure 61 Internal I/O Address Relocation

IOSTP: IOSTOP Mode (bit 5)
IOSTOP mode is enabled when IOSTP is set to 1 . Normal I/O operation resumes when IOSTP is reset to 0 . IOSTP is cleared to 0 during RESET.
14.2 Internal I/O Registers Address Map

The internal I/O register addresses are shown in Table 14. These addresses are relative to the 64 bytes boundary base address specified in ICR.

Table 14 Internal I/O Register Address Map (1)

|  | Register | Mnemonic | Address |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Binary | Hexadecimal |
| ASCI | ASCI Control Register A Ch 0 <br> ASCI Control Register A Ch 1 <br> ASCI Control Register B Ch 0 <br> ASCI Control Register B Ch 1 <br> ASCI Status Register Ch 0 <br> ASCI Status Register Ch 1 <br> ASCI Transmit Data Register Ch 0 <br> ASCI Transmit Data Register Ch 1 <br> ASCI Receive Data Register Ch 0 <br> ASCI Receive Data Register Ch 1 | CNTLAO <br> CNTLA1 <br> CNTLBO <br> CNTLB1 <br> STATO <br> STAT1 <br> TDRO <br> TDR1 <br> RDRO <br> RDR1 | $\begin{aligned} & \hline \text { XX000000 } \\ & \text { XX000001 } \\ & \text { XX000010 } \\ & \text { XX000011 } \\ & \text { XX000100 } \\ & \text { XX000101 } \\ & \text { XX000110 } \\ & \text { XX000111 } \\ & \text { XX001000 } \end{aligned}$ | $\begin{aligned} & \mathrm{OOH} \\ & 01 \mathrm{H} \\ & 02 \mathrm{H} \\ & 03 \mathrm{H} \\ & 04 \mathrm{H} \\ & 05 \mathrm{H} \\ & 06 \mathrm{H} \\ & 07 \mathrm{H} \\ & 08 \mathrm{H} \\ & 09 \mathrm{H} \end{aligned}$ |
| CSI/O | CSI/O Control Register <br> CSI/O Transmit/Receive Data Register | $\begin{aligned} & \text { CNTR } \\ & \text { TRDR } \end{aligned}$ | $\begin{aligned} & \mathrm{xx} 001010 \\ & \mathrm{Xx} 001011 \end{aligned}$ | $\begin{aligned} & \mathrm{OAH} \\ & \mathrm{OBH} \end{aligned}$ |
| Timer | Timer Data Register Ch OL Timer Data Register Ch OH Reload Register Ch OL <br> Reload Register Ch OH <br> Timer Control Register <br> Reserved <br> Timer Data Register Ch 1L <br> Timer Data Register Ch 1H <br> Reload Register Ch 1L <br> Reload Register Ch 1H | TMDROL TMDROH RLDROL RLDROH TCR <br> TMDR1L <br> TMDR1H <br> RLDR1L <br> RLDR1H |  | $\begin{aligned} & O C H \\ & O D H \\ & O E H \\ & O F H \\ & 10 \mathrm{H} \\ & 11 \mathrm{H} \\ & S_{1} \\ & 13 \mathrm{H} \\ & 14 \mathrm{H} \\ & 15 \mathrm{H} \\ & 16 \mathrm{H} \\ & 17 \mathrm{H} \end{aligned}$ |
| Others | Free Running Counter Reserved | FRC | $\begin{aligned} & x \times 011000 \\ & \int_{x \times 011111}^{x \times 011001} \end{aligned}$ | $\int_{1 \mathrm{FH}}^{18 \mathrm{H}}$ |

Table 14 Internal I/O Register Address Map (2)

|  | Register | Mnemonic | Address |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Binary | Hexadecimal |
| DMA | DMA Source Address Register Ch OL DMA Source Address Register Ch OH DMA Source Address Register Ch OB DMA Destination Address Register Ch OL DMA Destination Address Register Ch OH DMA Destination Address Register Ch OB DMA Byte Count Register Ch OL DMA Byte Count Register Ch OH DMA Memory Address Register Ch 1L DMA Memory Address Register Ch 1H DMA Memory Address Register Ch 1B DMA I/O Address Register Ch 1L DMA I/O Address Register Ch 1H <br> Reserved <br> DMA Byte Count Register Ch 1L DMA Byte Count Register Ch 1H DMA Status Register DMA Mode Register DMA/WAIT Control Register | SAROL <br> SAROH <br> SAROB <br> DAROL <br> DAROH <br> DAROB <br> BCROL <br> BCROH <br> MAR1L <br> MAR1H <br> MAR1B <br> IAR1L <br> IAR1H <br> BCR1L <br> BCR1H <br> DSTAT <br> DMODE <br> DCNTL | XX100000 <br> XX100001 <br> XX100010 <br> XX100011 <br> XX100100 <br> XX100101 <br> XX100110 <br> XX100111 <br> XX101000 <br> XX101001 <br> XX101010 <br> XX101011 <br> XX101100 <br> XX101101 <br> XX101110 <br> XX101111 <br> XX110000 <br> XX110001 <br> XX110010 | $\begin{aligned} & 2 \mathrm{OH} \\ & 21 \mathrm{H} \\ & 22 \mathrm{H} \\ & 23 \mathrm{H} \\ & 24 \mathrm{H} \\ & 25 \mathrm{H} \\ & 26 \mathrm{H} \\ & 27 \mathrm{H} \\ & 28 \mathrm{H} \\ & 29 \mathrm{H} \\ & 2 \mathrm{AH} \\ & 2 \mathrm{BH} \\ & 2 \mathrm{CH} \\ & 2 \mathrm{DH} \\ & 2 \mathrm{EH} \\ & 2 \mathrm{FH} \\ & 30 \mathrm{H} \\ & 31 \mathrm{H} \\ & 32 \mathrm{H} \end{aligned}$ |
| INT | IL Register (Interrupt Vector Low Register) INT/TRAP Control Register <br> Reserved | $\begin{aligned} & \text { IL } \\ & \text { ITC } \end{aligned}$ | XX110011 <br> XX110100 <br> XX110101 | $\begin{aligned} & 33 \mathrm{H} \\ & 34 \mathrm{H} \\ & 35 \mathrm{H} \end{aligned}$ |
| Refresh | Refresh Control Register Reserved | RCR | $\begin{aligned} & \mathrm{XX} \times 10110 \\ & \text { XX110111 } \end{aligned}$ | $\begin{aligned} & 36 \mathrm{H} \\ & 37 \mathrm{H} \end{aligned}$ |
| MMU | MMU Common Base Register <br> MMU Bank Base Register <br> MMU Common/Bank Area Register | CBR <br> BBR <br> CBAR | XX111000 <br> XX111001 <br> XX111010 | $\begin{aligned} & 38 \mathrm{H} \\ & 39 \mathrm{H} \\ & 3 \mathrm{AH} \end{aligned}$ |
| 1/O | Reserved <br> I/O Control Register | ICR | $\int_{x \times 111110}^{x \times 11} 1011$ | $\int_{\substack{3 E H \\ 3 F H}}^{3 B H}$ |

### 14.3 I/O Addressing Notes

The internal I/O register addresses are located in the I/O address space from 0000 H to 00 FFH ( 16 -bit I/O addresses). Thus, to access the internal I/O registers (using I/O instructions), the high-order 8 bits of the 16 -bit I/O address must be 0 .

The conventional I/O instructions (OUT (m),A/IN A,(m) / OUTI / INI/ etc.) place the contents of a CPU register on the highorder 8 bits of the address bus, and thus may be difficult to use for accessing internal I/O registers.

For efficient internal I/O register access, a number of new instructions have been added, which force the high-order 8 bits of the 16 -bit I/O address to 0 . These instructions are IN0, OUT0, OTIM,

OTIMR, OTDM, OTDMR and TSTIO (See section 19 Instruction Set).

Note that when writing to an internal I/O register, the same I/O write occurs on the external bus. However, the duplicate external I/ O write cycle will exhibit internal I/O write cycle timing. For example, the WAIT input and programmable wait state generator are ignored. Similarly, internal I/O read cycles also cause a duplicate external I/O read cycle - however, the external read data is ignored by the HD64180.

Normally, external I/O addresses should be chosen to avoid overlap with internal I/O addresses to avoid duplicate I/O accesses.

## 15 E CLOCK OUTPUT TIMING - 6800 TYPE BUS INTER-

 FACEA large selection of 6800 type peripheral devices can be connected to the HD64180, including the Hitachi 6300 CMOS series (6321 PIA, 6350 ACIA, etc.) as well as 6500 family devices.

These devices require connection with the HD64180 synchronous E clock output. The speed (access time) required for the peripheral device are determined by the HD64180 clock rate. Table 15, Fig. 62 and Fig. 63 define E clock output timing.

Table 15 E Clock Timing in Each Condition

| Condition | Duration of E Clock Output "High" |  |
| :--- | :--- | :--- |
| Op-code Fetch Cycle <br> Memory Read/Write Cycle | $\mathrm{T}_{2} \uparrow-\mathrm{T}_{3} \downarrow$ | $\left(1.5 \phi+\mathrm{n}_{\mathrm{w}} \cdot \phi\right)$ |
| l/O read Cycle | 1 st Tw $\uparrow-\mathrm{T}_{3} \downarrow$ | $\left(0.5 \phi+\mathrm{n}_{\mathrm{w}} \cdot \phi\right)$ |
| I/O Write Cycle | 1 st Tw $\uparrow-\mathrm{T}_{3} \uparrow$ | $\left(\mathrm{n}_{\mathrm{w}} \cdot \phi\right)$ |
| NMI Acknowledge 1st MC | $\mathrm{T}_{2} \uparrow-\mathrm{T}_{3} \downarrow$ | $(1.5 \phi)$ |
| INTo Acknowledge 1st MC | 1 st Tw $\uparrow-\mathrm{T}_{3} \downarrow$ | $\left(0.5 \phi+\mathrm{n}_{\mathrm{w}} \cdot \phi\right)$ |
| BUS RELEASE mode <br> SLEEP mode <br> SYSTEM STOP mode | $\phi \downarrow-\phi \downarrow$ | $(2 \phi$ or $1 \phi)$ |

$$
\begin{aligned}
\text { NOTE) } & n_{w}: \text { the number of wait states } \\
M C & \text { Machine Cycle }
\end{aligned}
$$



Figure 62 E Clock Timing (During Read/Write Cycle and Interrupt Acknowledge Cycle)

(a) E Clock Timing in BUS RELEASE Mode

(b) E Clock Timing in SLEEP Mode and SYSTEM STOP Mode

Figure 63 E Clock Timing (in BUS RELEASE mode, SLEEP mode, SYSTEM STOP mode)

Wait states inserted in op-code fetch, memory read/write and I/ O read/write cycles extend the duration of E clock output HIGH. Note that during I/O read/write cycles with no wait states (only occurs during on-chip I/O register accesses), E will not go HIGH.

The correspondence between the duration of $\mathbf{E}$ clock output HIGH and standard peripheral device speed selections is as follows.

| Device Speed Selection | Required duration of <br> E clock output HIGH |
| :--- | :---: |
| 1.0 MHz (ex: HD6321P) | $500 \mathrm{~ns} \min$. |
| $1.5 \mathrm{MHz}(\mathrm{ex}:$ HD63A21P) | 333 ns min. |
| $2.0 \mathrm{MHz}(\mathrm{ex}:$ HD63B21P) | 230 ns min. |

15.1 6800 Type Bus Interfacing Note

When the HD64180 is connected to 6800 type peripheral LSIs with E clock, the 6800 type peripheral LSIs should be located in I/O address space.

If the 6800 type peripheral LSIs are located in memory address space, $\overline{\mathrm{WR}}$ set-up time and $\overline{\mathrm{WR}}$ hold time for E clock won't be guaranteed during memory read/write cycles and 6800 type peripheral LSIs can't be connected correctly.

## 16 ON-CHIP CLOCK GENERATOR

The HD64180 contains a crystal oscillator and system clock ( $\phi$ ) generator. A crystal can be directly connected or an external clock input can be provided. In either case, the system clock ( $\phi$ ) is equal to one-half the input clock. For example, a crystal or external clock
input of 8 MHz corresponds with a system clock rate of $\phi=4$ MHz .

The following table shows the AT cut crystal characteristics (Co, Rs) and the load capacitance (CL1, CL2) required for various frequencies of HD64180 operation.

Table 16 Crystal Characteristics

| Item | Clock Frequency | 4 MHz | $4 \mathrm{MHz}<\mathrm{f} \leqq 12 \mathrm{MHz}$ |
| :---: | :---: | :---: | :---: |
|  |  | $12 \mathrm{MHz}<\mathrm{f} \leqq 16 \mathrm{MHz}$ |  |
| Co | $<7 \mathrm{pF}$ | $<7 \mathrm{pF}$ | $<7 \mathrm{pF}$ |
| Rs | $<60 \Omega$ | $<60 \Omega$ | $<60 \Omega$ |
| $\mathrm{CL}_{1}, \mathrm{CL}_{2}$ | 10 to $22 \mathrm{pF} \pm 10 \%$ | 10 to $22 \mathrm{pF} \pm 10 \%$ | 10 to $22 \mathrm{pF} \pm 10 \%$ |

If an external clock input is used instead of a crystal, the waveform (twice the $\phi$ clock rate) should exhibit a $50 \% \pm 5 \%$ duty cycle. Note that the minimum clock input HIGH voltage level is $\mathrm{V}_{\mathrm{CC}}-0.6 \mathrm{~V}$. The external clock input is connected to the EXTAL pin, while the XTAL pin is left open. Fig. 64 shows external clock interface.


## Figure 64 External Clock Interface

Fig. 65 shows the HD64180 clock generator circuit while Fig. 66 and Fig. 67 specify circuit board design rules.


Figure 65 Crystal Interface


Figure 66 Note for Board Design of the Oscillation Circuit


Figure 67 Example of Board Design

Circuit Board design should observe the followings.
(1) To prevent induced noise, the crystal and load capacitors should be physically located as close to the LSI as possible.
(2) Signal lines should not run parallel to the clock oscillator inputs. In particular, the clock input circuitry and the system clock $\phi$ output should be separated as much as possible.
(3) Similar to (2), $V_{C C}$ power lines should be separated from the clock oscillator input circuitry.
(4) Resistivity between XTAL or EXTAL and the other pins should be greater than 10 M ohms.
Signal line layout should avoid areas marked with /////.

## 17 MISCELLANEOUS

Free Running Counter (I/O Address $=18 \mathrm{H}$ )
Read only 8 -bit free running counter without control registers and status registers. The contents of the 8 -bit free running counter is counted down by 1 with an interval of $10 \phi$ clock cycles. The free running counter continues counting down without being affected by the read operation.

If data is written into the free running counter, we can't guarantee the interval of DRAM refresh cycle and baud rates of ASCI and CSI/O.

In IOSTOP mode, the free running counter continues counting down. It is initialized to FFH during RESET.

## 18 OPERATION NOTES

18.1 Precaution on Interfacing the 280* Family Peripheral LSIs to the HD64180
(1) Problem

In daisy chain, the Z80* family peripheral LSI (PIO, DMA, CTC, SIO, or DART) resets interrupt circuit (i.e. IEO changes from LOW to HIGH) by fetching the RETI op-code on the data bus concurrently during the CPU fetches the RETI. Therefore, the followings should be noted for the RETI opcode ( $\mathrm{EDH}, 4 \mathrm{DH}$ ) fetch timing in the $\mathrm{Z80}$ * peripheral LSI.

When the peripheral LSI fetches the first op-code of RETI (EDH), $\overline{\text { LIR }}$ should be negated HIGH at the rising edge of system clock $\phi$ as shown in Fig. 71, A. (This isn't referred in the manuals for the Z80* peripheral LSI.) So, LIR hold time $(\overline{\mathrm{LIR}}=\mathrm{HIGH})$ should be required as shown in Fig. 71.


Figure 71 LIR Hold Time

Because $\overline{\mathrm{LIR}}$ changes synchronously with the rising edge of system clock $\phi, \overline{\mathrm{LIR}}$ delay time is equal to $\overline{\mathrm{LIR}}$ hold time of the Z80* peripheral LSI. However, this LIR hold time may not be sufficient for the Z80* peripheral LSI in some case and IEO line may not be reset.
(2) An example of countermeasure

Fig. 72 shows an example of circuit, while Fig. 73 shows the LIR and LIR' timing in the circuit.


Figure 72 Circuit Example

* Z80 is a registered trademark of Zilog, Inc.


Figure $73 \overline{\mathrm{LIR}}$ and $\overline{\mathrm{LIR}}$ ' Timing in the Circuit
$\overline{\text { LIR }}$, which is synchronized with the falling edge of system clock $\phi$, is provided to the peripheral LSI. In this case, one-half clock cycle duration is confirmed as the hold time.

Please carefully examine the circuit before you use it on your application.

### 18.5 Precaution on Interfacing HD64180 with Z80* CTC

## (1) Problem

The following problem may happen when interfacing HD64180 with Z80* CTC (Z8430). Therefore, countermeasure shown in section 2 should be taken. Fig. 81 illustrates Z80* CTC write timing specified in Z80* CTC Data Sheet. Fig. 82 and Fig. 83 show Z80* I/ O write timing and HD64180 I/O write timing respectively.

As shown above, $\overline{\mathrm{IOE}}$ in HD64180 goes LOW by a half $\phi$ clock cycle faster than $\overline{\text { IORQ }}$ in $\mathbf{Z 8 0}$. When interfacing Z80 with Z80* CTC, data is written into Z80* CTC at the rising edge of Tw. By contrast, when interfacing HD64180 with Z80* CTC, data is written into $\mathrm{Z8O}^{*}$ CTC at the rising edge of $\mathrm{T}_{2}$. In the latter case, data may not be written into $\mathrm{Z80*}$ CTC if $\overline{\mathrm{IOE}}$ set-up time for the rising edge of $T_{2}$ is less than the set-up time specified in $Z 80^{*}$ CTC.


Figure 81 Z80* CTC Write Timing**


Figure 82 Z80* I/O Write Timing


Figure 83 HD64180 I/O Write Timing

[^12]
## (2) Countermeasure

To Avoid the problem, $\overline{\mathrm{IOE}}$ in HD64180 should be asserted LOW at the rising edge of $T_{2}$ to assure the set-up time specified in Z80* CTC. Fig. 84 (a) shows a circuit for delaying IOE by a half $\phi$ clock cycle.

If this circuit is externally connected between HD64180 and Z80* CTC, $\overline{\mathrm{IOE}}$ ' will be pulled LOW at the rising edge of $\mathrm{T}_{2}$ only in I/O read/write cycle as shown in Fig. 84 (b). While in $\overline{I N T}_{0}$ acknowledge cycle, $\overline{\mathrm{IOE}}$ and $\overline{\mathrm{IOE}}$ ' are asserted LOW at the timing shown in Fig. 84 (c). In $\overline{\mathrm{INT}}_{0}$ acknowledge cycle, $\overline{\mathrm{IOE}}$ ' delays because of propagation time of TTL gates of the countermeasure circuit and the vector access time is shortened. If vector access time for HD64180 is not assured during INT $\overline{\mathrm{I}}_{0}$ acknowledge cycle, wait states should be inserted by programming IWI0 and IWI1 bits of DMA/WAIT Control Register. However, note that wait states insertion by software should be inhibited during Z80* CTC read/write cycles, because more than one wait state can not be allowed in the case of Z80* CTC. (Please see Z80* CTC Data Sheet. One wait state is automatically inserted during the cycles.) Refer to "Fig. 85 Z80* CTC Access Flow" for details.

(a) Countermeasure Circuit

(b) I/O Read/Write Timing

(c) $\overline{\mathrm{NT}}{ }_{0}$ Acknowledge Cycle Timing

Figure 84 Countermeasure Circuit and Timings in the Circuit


Figure 85 Z80* CTC Access Flow

### 18.6 Notes on HD64180 $\overline{\text { INT }}_{0}$ Mode 0

## (1) Problem

In $\overline{\mathrm{INT}}_{0}$ Mode 0 , the CPU executes an instruction which is placed on the data bus during the interrupt acknowledge cycle. Usually, RST (1-byte instruction) or CALL (3-byte instruction) is placed on the data bus. Then, the CPU pushes the Program Counter (PC) onto the stack and jumps to the interrupt service routine In the case of RST instruction, the correct return address is pushed onto the stack. However, in the case of CALL instruction, the pushed return address is equal to the correct return address +2 .
(2) Explanation of operation

During the 1st op-code fetch cycle in the interrupt acknowledge
cycle, the CPU stops incrementing the PC. At this time, the PC contains the return address. After the 1st op-code is fetched, the CPU restarts incrementing the PC. Therefore, is RST (1-byte instruction) is executed in the interrupt acknowledge cycle, the correct return address is pushed onto the stack and the CPU can return from the interrupt service routine correctly. While, if CALL (3-byte instruction) is executed in the interrupt acknowledge cycle, the PC is incremented twice during the operand read cycle of the 2 bytes after the 1 st op-code is fetched. Therefore, the return address +2 in the PC is pushed onto the stack. So, when RETI is executed at the end of the interrupt service routine, the CPU can not return from the interrupt correctly

Fig. 86 shows the CALL execution timing in $\overline{\mathrm{INT}_{0}}$ Mode 0


Figure 86 The CALL Execution Timing in $\mathbb{N T}_{0}$ Mode 0
(3) Countermeasure

The following explains the countermeasure of the problem in $\mathrm{INT}_{0}$ Mode 0.
(1) RST

When RST is executed, the correct return address in the PC is pushed onto the stack.
(2) CALL

When CALL is executed, the stack contents must be decremented by two in the interrupt service routine to return from the interrupt correctly.

Table 18 summarizes how to adjust the stack contents depending on the instruction to be executed.

Table 18 Stack Contents Adjustment

| Instruction | Stack Contents Adjustment |
| :---: | :---: |
| RST | No |
| CALL | Decrement the stack contents by two |
| Other <br> instructions | No <br> (The PC is not stacked.) |

The $\overline{\mathrm{INT}} \mathrm{T}_{0}$ Mode 0 sequences when executing RST and CALL are shown in Fig. 87.

## Main Routine


(a) $\overline{N T} 0$ Mode 0 Sequence when executing RST

(b) $\overline{\mathbb{N T}} \mathbf{0}$ Mode 0 Sequence when executing CALL

NOTE) PC: PC indicates the return address
Figure $87 \mathbb{I N T}_{0}$ Mode 0 Sequence

## 19 INSTRUCTION SET

19.1 Instruction set overview

The HD64180 is object code compatible with standard 8-bit operating system and application software. The instruction set also contains a number of new instructions to improve system and software performance, reliability and efficiency.

| New Instructions | Operation |
| :--- | :--- |
| SLP | Enter SLEEP mode <br> 8-bit multiply with 16-bit result <br> INT <br> Input contents of immediate I/O address into <br> OUT0 (m), g <br> register |
| OTIM | Output register contents to immediate I/O ad- <br> dress |
| OTIMR | Block output - increment <br> Block output - increment and repeat |
| OTDM | Block output - decrement |
| OTDMR | Block output - decrement and repeat <br> Non-destructive AND, I/O port and accumula- <br> tor |
| TSTIO m | Non-destructive AND, register and accumula- <br> tor |
| TST g | Non-destructive AND, immediate data and ac- <br> cumulator |
| TST m | Non-destructive AND, memory data and ac- <br> cumulator |

## (1) SLP - Sleep

The SLP instruction causes the HD64180 to enter SLEEP low power consumption mode. See section 5 for a complete description of the SLEEP state.

## (2) MLT - Multiply

The MLT performs unsigned multiplication on two 8 bit numbers yielding a 16 bit result. MLT may specify BC, DE, HL or SP
registers. In all cases, the 8 -bit operands are loaded inio each half of the 16 -bit register and the 16 -bit result is returned in that register.
(3) INO g, (m) - Input, Immediate I/O address

The contents of immediately specified 8 -bit I/O address are input into the specified register. When I/O is accessed, 00 H is output in high-order bits of address automatically.

## (4) OUTO (m), g - Output, immediate I/O address

The contents of the specified register are output to the immediately specified 8 -bit I/O address. When I/O is accessed, 00 H is output in high-order bits of address automatically.

## (5) OTIM, OTIMR, OTDM, OTDMR - Block I/O

The contents of memory pointed to by HL is output to the I/O address in (C). The memory address (HL) and I/O address (C) are incremented in OTIM and OTIMR and decremented in OTDM and OTDMR respectively. B register is decremented. The OTIMR and OTDMR variants repeat the above sequence until register $B$ is decremented to 0 . Since the I/O address ( $C$ ) is automatically incremented or decremented, these instructions are useful for block I/O (such as HD64180 on-chip I/O) initialization. When I/O is accessed, 00 H is output in high-order bits of address automatically.

## (6) TSTIO m - Test I/O Port

The contents of the I/O port addressed by C are ANDed with 8bit immediate data and the status flags are updated. The I/O port contents are not written (non-destructive AND). When I/O is accessed, 00 H is output in higher bits of address automatically.

## (7) TST g - Test Register

The contents of the specified register are ANDed with the accumulator (A) and the status flags are updated. The accumulator and specified register are not changed (non-destructive AND).

## (8) TST m - Test Immediate

The 8-bit immediate data is ANDed with the accumulator (A) and the status flags are updated. The accumulator is not changed (non-destructive AND).

## (9) TST (HL) - Test Memory

The contents of memory pointed to by HL are ANDed with the accumulator (A) and the status flags are updated. The memory contents and accumulator are not changed (non-destructive AND).

### 19.2 Instruction set summary

The followings explain the symbols in instruction set, and the following tables summarize the operation of each instruction.

## (1) Register

$\mathrm{g}, \mathrm{g}, \mathrm{ww}, \mathrm{xx}, \mathrm{yy}$, and zz specify a register to be used. g and $\mathrm{g}^{\prime}$ specify an 8 -bit register. $w w, x x, y y$, and $z z$ specify a pair of 16 -bit registers. The following tables show the correspondence between symbols and registers.

| g,g' | Reg. | ww | Reg. | xx | Reg. | yy | Reg. | zz | Reg. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 000 | B | 00 | BC | 00 | BC | 00 | BC | 00 | BC |
| 001 | C | 01 | DE | 01 | DE | 01 | DE | 01 | DE |
| 010 | D | 10 | HL | 10 | IX | 10 | IY | 10 | HL |
| 011 | E | 11 | SP | 11 | SP | 11 | SP | 11 | AF |
| 100 | H |  |  |  |  |  |  |  |  |
| 101 | L |  |  |  |  |  |  |  |  |
| 111 | A |  |  |  |  |  |  |  |  |

NOTE: Suffixed H and L to ww, xx,yy,zz (ex.wwH,IXL) indicate upper and lower 8 -bit of the 16 -bit register respectively.
(2) Bit
b specifies a bit to be manipulated in the bit manipulation instruction. The following table shows the correspondence between $b$ and bits.

| b | Bit |
| :---: | :---: |
| 000 | 0 |
| 001 | 1 |
| 010 | 2 |
| 011 | 3 |
| 100 | 4 |
| 101 | 5 |
| 110 | 6 |
| 111 | 7 |

## (3) Condition

f specifies the condition in program control instructions. The following shows the correspondence between $f$ and conditions.

| f | Condition |
| :---: | :---: |
| 000 | NZ non zero |
| 001 | Z zero |
| 010 | NC non carry |
| 011 | C carry |
| 100 | PO parity odd |
| 101 | PE |
| 110 | parity even |
| 111 | sign plus |

## (4) Restart Address

$v$ specifies a restart address. The following table shows the correspondence between v and restart addresses.

| $v$ | Address |
| :---: | :---: |
| 000 | 00 H |
| 001 | 08 H |
| 010 | 10 H |
| 011 | 18 H |
| 100 | 20 H |
| 101 | 28 H |
| 110 | 30 H |
| 111 | 38 H |

(5) Flag

The following symbols show the flag conditions.

- : not affected
$\uparrow$ : affected
$\times$ : undefined
S : set to 1
R : reset to 0
$\mathbf{P}$ : parity
V : overflow

6) Miscellaneous

| ( $)_{M}$ | data in the memory address |
| :---: | :---: |
| $)_{\text {I }}^{\text {M }}$ | data in the I/O address |
| m or n | 8-bit data |
| mn | 16-bit data |
| r | 8-bit register |
| R | 16-bit register |
| $b \cdot(\quad)_{M}$ | a content of bit b in the memory address |
| b-gr | $a$ content of bit $b$ in the register gr |
| d or j | 8-bit signed displacement |
| S | source addressing mode |
| D | destination addressing mode |
| - | AND operation |
| $+$ | OR operation |
| $\oplus$ | EXCLUSIVE OR operation |

Data Manipulation Instructions

Arithmetic and Logical Instructions (8-bit)

(to be continued)

(to be continued)

Rotate and Shift Instructions

(to be continued)


Bit Manipulation Instructions


Arithmetic Instructions (16-bit)

(to be continued)

Data Transfer Instructions


16-Bit Load

(to be continued)

Block Transfer


Stack and Exchange


Program Control Instructions

(to be continued)


## I/O Instructions



(to be continued)
(3) $\begin{aligned} & z=1: B r-1=0 \\ & z=0: B r-1 \neq 0 \\ & \text { (4) }=1: M S B \text { of Data }=1 \\ & N=0: M S B \text { of Data }=0\end{aligned}$


Special Control Instructions

(5) Interrupts are not sampled at the end of DI or El.

20 INSTRUCTION SUMMARY IN ALPHABETICAL ORDER

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| ADC A.m | 2 | 2 | 6 |
| ADC Ag | 1 | 2 | 4 |
| ADC A. (HL) | 1 | 2 | 6 |
| ADC A. ( $1 \times+d)$ | 3 | 6 | 14 |
| ADC A, $0 Y+d)$ | 3 | 6 | 14 |
| ADD A,m | 2 | 2 | 6 |
| ADD A.g | 1 | 2 | 4 |
| ADD A. (HL) | 1 | 2 | 6 |
| ADD A, $0 \times 1$ d) | 3 | 6 | 14 |
| ADD A. ( $\mathrm{Y}+\mathrm{d}$ ) | 3 | 6 | 14 |
| ADC HL,ww | 2 | 6 | 10 |
| ADD HL,ww | 1 | 5 | 7 |
| ADD IX,xx | 2 | 6 | 10 |
| ADD IY.yy | 2 | 6 | 10 |
| AND $m$ | 2 | 2 | 6 |
| AND g | 1 | 2 | 4 |
| AND (HL) | 1 | 2 | 6 |
| AND $1 \times \mathrm{X}+\mathrm{d}$ ) | 3 | 6 | 14 |
| AND OY+d) | 3 | 6 | 14 |
| BT b, (HL) | 2 | 3 | 9 |
| BT b, ( $1 \times$ + d) | 4 | 5 | 15 |
| BrT b, OY+d) | 4 | 5 | 15 |
| BrT b,g | 2 | 2 | 6 |
| CALL f,mn | 3 | 2 | 6 |
|  |  |  | (If condition is false) |
|  | 3 | 6 | 16 |
|  |  |  | (If condition is true) |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| CALL mn | 3 | 6 | 16 |
| CCF | 1 | 1 | 3 |
| CPD | 2 | 6 | 12 |
| CPDR | 2 | 8 | 14 |
|  |  |  | (If $\mathrm{BC}_{\mathrm{R}} \neq 0$ and $\mathrm{Ar}=(\mathrm{HL})_{M}$ ) |
|  | 2 | 6 | 12 |
|  |  |  | (lf $\mathrm{BC}_{\mathrm{R}}=0$ or $\mathrm{Ar}=(\mathrm{HL})_{M}$ ) |
| CP (HL) | 1 | 2 | 6 |
| CPI | 2 | 6 | 12 |
| CPIR | 2 | 8 | 14 |
|  |  |  | (If $\mathrm{BC}_{\mathrm{R}} \neq 0$ and $\mathrm{Ar} \boldsymbol{\sim}=(\mathrm{HL})_{M}$ ) |
|  | 2 | 6 | 12 |
|  |  |  | (If $\mathrm{BC}_{\mathrm{R}}=0$ or $\mathrm{Ar}=(\mathrm{HL})_{M}$ ) |
| CP (IX+d) | 3 | 6 | 14 |
| $\mathbf{C P}(1 \mathrm{Y}+\mathrm{d})$ | 3 | 6 | 14 |
| CPL | 1 | 1 | 3 |
| CP m | 2 | 2 | 6 |
| CP g | 1 | 2 | 4 |
| DAA | 1 | 2 | 4 |
| DEC (HL) | 1 | 4 | 10 |
| DEC IX | 2 | 3 | 7 |
| DEC IY | 2 | 3 | 7 |
| DEC ( $1 \times \mathrm{X}+\mathrm{d}$ ) | 3 | 8 | 18 |
| DEC ( $1 \mathrm{Y}+\mathrm{d}$ ) | 3 | 8 | 18 |
| DEC $\mathbf{g}$ | 1 | 2 | 4 |
| DEC ww | 1 | 2 | 4 |
| DI | 1 | 1 | 3 |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| DJNZ j | 2 | 5 | 9 (If $\mathrm{Br} \neq 0$ ) |
|  | 2 | 3 | 7 (If $\mathrm{Br}=0$ ) |
| El | 1 | 1 | 3 |
| EX AF, AF ${ }^{\circ}$ | 1 | 2 | 4 |
| EX DE,HL | 1 | 1 | 3 |
| EX (SP),HL | 1 | 6 | 16 |
| EX (SP), IX | 2 | 7 | 19 |
| EX (SP), IY | 2 | 7 | 19 |
| EXX | 1 | 1 | 3 |
| HALT | 1 | 1 | 3 |
| IM 0 | 2 | 2 | 6 |
| IM 1 | 2 | 2 | 6 |
| IM 2 | 2 | 2 | 6 |
| INC g | 1 | 2 | 4 |
| INC (HL) | 1 | 4 | 10 |
| INC ( $1 \mathrm{X}+\mathrm{d}$ ) | 3 | 8 | 18 |
| INC ( $1 \mathrm{Y}+\mathrm{d}$ ) | 3 | 8 | 18 |
| INC ww | 1 | 2 | 4 |
| INC IX | 2 | 3 | 7 |
| INC IY | 2 | 3 | 7 |
| IN A, (m) | 2 | 3 | 9 |
| IN g, (C) | 2 | 3 | 9 |
| INI | 2 | 4 | 12 |
| INIR | 2 | 6 | 14 (if $\mathrm{Br}=0$ ) |
|  | 2 | 4 | 12 (lf $\mathrm{Br}=0$ ) |
| IND | 2 | 4 | 12 |
| INDR | 2 | 6 | 14 (If $\mathrm{Br} \neq 0$ ) |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| INDR | 2 | 4 | 12 (ff $\mathrm{Br}=0$ ) |
| INO g ,(m) | 3 | 4 | 12 |
| JP f,mn | 3 | 2 | 6 |
|  |  |  | (lf f is false) |
|  | 3 | 3 | 9 |
|  |  |  | (lf $f$ is true) |
| JP (HL) | 1 | 1 | 3 |
| JP (IX) | 2 | 2 | 6 |
| JP (IY) | 2 | 2 | 6 |
| JP mn | 3 | 3 | 9 |
| JR j | 2 | 4 | 8 |
| JR C, ${ }_{\text {j }}$ | 2 | 2 | 6 |
|  |  |  | (If condition is false) |
|  | 2 | 4 | 8 |
|  |  |  | (If condition is true) |
| JR NC, ${ }_{\text {j }}$ | 2 | 2 | 6 |
|  |  |  | (If condition is false) |
|  | 2 | 4 | 8 |
|  |  |  | (If condition is true) |
| JR $\mathbf{Z}_{\text {, }} \mathbf{j}$ | 2 | 2 | 6 |
|  |  |  | (If condition is false) |
|  | 2 | 4 | 8 |
|  |  |  | (If condition is true) |
| JR NZ, ${ }^{\text {j }}$ | 2 | 2 | 6 |
|  |  |  | (If condition is false) |
|  | 2 | 4 | 8 |
|  |  |  | (If condition is true) |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| LD A, (BC) | 1 | 2 | 6 |
| LD A, (DE) | 1 | 2 | 6 |
| LD A,I | 2 | 2 | 6 |
| LD A, (mn) | 3 | 4 | 12 |
| LD A,R | 2 | 2 | 6 |
| LD (BC), A | 1 | 3 | 7 |
| LDD | 2 | 4 | 12 |
| LD (DE), A | 1 | 3 | 7 |
| LD ww,mn | 3 | 3 | 9 |
| LD ww, (mn) | 4 | 6 | 18 |
| LDDR | 2 | 6 | 14 (If $\mathrm{BC}_{\mathrm{R}} \neq 0$ ) |
|  | 2 | 4 | 12 (If $\mathrm{BC}_{\mathrm{R}}=0$ ) |
| LD (HL),m | 2 | 3 | 9 |
| LD HL, (mn) | 3 | 5 | 15 |
| LD (HL).g | 1 | 3 | 7 |
| LDI | 2 | 4 | 12 |
| LD I,A | 2 | 2 | 6 |
| LDIR | 2 | 6 | 14 (If $\mathrm{BC}_{\mathrm{R}} \neq 0$ ) |
|  | 2 | 4 | 12 (If $\mathrm{BC}_{\mathrm{R}}=0$ ) |
| LD IX,mn | 4 | 4 | 12 |
| LD IX, (mn) | 4 | 6 | 18 |
| LD ( $1 \times$ X ${ }^{\text {d }}$ ) m | 4 | 5 | 15 |
| LD ( $1 \times$ + d ) , g | 3 | 7 | 15 |
| LD IY,mn | 4 | 4 | 12 |
| LD IY, (mn) | 4 | 6 | 18 |
| $L D(1 Y+d), m$ | 4 | 5 | 15 |
| LD ( $1 \mathrm{Y}+\mathrm{d}$ ) g | 3 | 7 | 15 |


| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| LD (mn), A | 3 | 5 | 13 |
| LD (mn),ww | 4 | 7 | 19 |
| LD (mn), HL | 3 | 6 | 16 |
| LD (mn), IX | 4 | 7 | 19 |
| LD (mn), IY | 4 | 7 | 19 |
| LD R,A | 2 | 2 | 6 |
| LD g, (HL) | 1 | 2 | 6 |
| LD g. (IX + d) | 3 | 6 | 14 |
| LD g, (IY+d) | 3 | 6 | 14 |
| LD g,m | 2 | 2 | 6 |
| LD g, ${ }^{\prime}$ | 1 | 2 | 4 |
| LD SP.HL | 1 | 2 | 4 |
| LD SP,IX | 2 | 3 | 7 |
| LD SP,IY | 2 | 3 | 7 |
| MLT ww | 2 | 13 | 17 |
| NEG | 2 | 2 | 6 |
| NOP | 1 | 1 | 3 |
| OR ( HL ) | 1 | 2 | 6 |
| OR ( $1 \mathrm{X}+\mathrm{d}$ ) | 3 | 6 | 14 |
| OR ( $\mathrm{I} Y+\mathrm{d}$ ) | 3 | 6 | 14 |
| OR m | 2 | 2 | 6 |
| OR g | 1 | 2 | 4 |
| OTDM | 2 | 6 | 14 |
| OTDMR | 2 | 8 | 16 (lf $\mathrm{Br} \neq 0$ ) |
|  | 2 | 6 | 14 (lf $\mathrm{Br}=0$ ) |
| OTDR | 2 | 6 | 14 (if $\mathrm{Br} \neq 0$ ) |
|  | 2 | 4 | 12 (lf $\mathrm{Br}=0$ ) |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| OTIM | 2 | 6 | 14 |
| OTIMR | 2 | 8 |  |
|  | 2 | 6 | 14 (lf $\mathrm{Br}=0$ ) |
| OTIR | 2 | 6 | 14 (lf $\mathrm{Br}=0$ ) |
|  | 2 | 4 | 12 (If $\mathrm{Br}=0$ ) |
| OUTD | 2 | 4 | 12 |
| OUTI | 2 | 4 | 12 |
| OUT (m),A | 2 | 4 | 10 |
| OUT (C).g | 2 | 4 | 10 |
| OUTO (m),g | 3 | 5 | 13 |
| POP IX | 2 | 4 | 12 |
| POP IY | 2 | 4 | 12 |
| POP $2 z$ | 1 | 3 | 9 |
| PUSH IX | 2 | 6 | 14 |
| PUSH IY | 2 | 6 | 14 |
| PUSH zz | 1 | 5 | 11 |
| RES b, (HL) | 2 | 5 | 13 |
| RES $b,(1 X+d)$ | 4 | 7 | 19 |
| RES $b_{\text {b }}(\mathbf{I}+\mathrm{d})$ | 4 | 7 | 19 |
| RES b,g | 2 | 3 | 7 |
| RET | 1 | 3 | 9 |
| RET f | 1 | 3 | 5 |
|  |  |  | (If condition is false) |
|  | 1 | 4 | 10 |
|  |  |  | (If condition is true) |
| RETI | 2 | 4 | 12 |
| RETN | 2 | 4 | 12 |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| RLA | 1 | 1 | 3 |
| RLCA | 1 | 1 | 3 |
| RLC (HL) | 2 | 5 | 13 |
| RLC (IX+d) | 4 | 7 | 19 |
| RLC ( $1 Y+d)$ | 4 | 7 | 19 |
| RLC g | 2 | 3 | 7 |
| RLD | 2 | 8 | 16 |
| RL (HL) | 2 | 5 | 13 |
| RL (IX +d ) | 4 | 7 | 19 |
| RL ( $\mathrm{I}+\mathrm{Cd}$ ) | 4 | 7 | 19 |
| RL g | 2 | 3 | 7 |
| RRA | 1 | 1 | 3 |
| RRCA | 1 | 1 | 3 |
| RRC (HL) | 2 | 5 | 13 |
| RRC (IX+d) | 4 | 7 | 19 |
| RRC ( $1 Y+d)$ | 4 | 7 | 19 |
| RRC 9 | 2 | 3 | 7 |
| RRD | 2 | 8 | 16 |
| RR (HL) | 2 | 5 | 13 |
| RR ( $1 X+d)$ | 4 | 7 | 19 |
| RR ( $\mathrm{I}+\mathrm{+d}$ ) | 4 | 7 | 19 |
| RR $\mathbf{g}$ | 2 | 3 | 7 |
| RST v | 1 | 5 | 11 |
| SBC A, (HL) | 1 | 2 | 6 |
| SBC A, (IX + d) | 3 | 6 | 14 |
| SBC A, (lY+d) | 3 | 6 | 14 |
| SBC A,m | 2 | 2 | 6 |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| SBC A,g | 1 | 2 | 4 |
| SBC HL,ww | 2 | 6 | 10 |
| SCF | 1 | 1 | 3 |
| SET b, (HL) | 2 | 5 | 13 |
| SET b, (IX + d) | 4 | 7 | 19 |
| SET b, (IY+d) | 4 | 7 | 19 |
| SET b,g | 2 | 3 | 7 |
| SLA (HL) | 2 | 5 | 13 |
| SLA (IX+d) | 4 | 7 | 19 |
| SLA ( $1 Y+d$ ) | 4 | 7 | 19 |
| SLA g | 2 | 3 | 7 |
| SLP | 2 | 2 | 8 |
| SRA (HL) | 2 | 5 | 13 |
| SRA (IX+d) | 4 | 7 | 19 |
| SRA ( $1 Y+d)$ | 4 | 7 | 19 |
| SRA g | 2 | 3 | 7 |
| SRL (HL) | 2 | 5 | 13 |
| SRL ( $1 X+d)$ | 4 | 7 | 19 |
| SRL ( $\mathrm{Y}+\mathrm{d}$ ) | 4 | 7 | 19 |
| SRL $\mathbf{g}$ | 2 | 3 | 7 |
| SUB (HL) | 1 | 2 | 6 |
| SUB ( $1 X+d)$ | 3 | 6 | 14 |
| SUB ( $1 Y+d$ ) | 3 | 6 | 14 |
| SUB m | 2 | 2 | 6 |
| SUB $\mathbf{g}$ | 1 | 2 | 4 |
| TSTIO m | 3 | 4 | 12 |
| TST g | 2 | 3 | 7 |

(to be continued)

| MNEMONICS | Bytes | Machine Cycles | States |
| :---: | :---: | :---: | :---: |
| TST m | 3 | 3 | 9 |
| TST (HL) | 2 | 4 | 10 |
| XOR (HL) | 1 | 2 | 6 |
| XOR (IX+d) | 3 | 6 | 14 |
| XOR ( $1 \mathrm{Y}+\mathrm{d}$ ) | 3 | 6 | 14 |
| XOR m | 2 | 2 | 6 |
| XOR g | 1 | 2 | 4 |

## 21 OP-CODE MAP

Table 18 1st op-code map
Instruction format: XX

Table 19 2nd op-code map
Instruction format: CB XX


NOTE1) If DDH is supplemented as 1 st op-code for the instructions which have ( HL ) as operand in Table 19, the instructions are executed replacing $(\mathrm{HL})$ with $(I X+d)$
If FDH is supplemented as 1 st op-code for the instructions which have ( HL ) as operand in Table 19, the instructions are executed replacing ( HL ) with (IY+d).

Table 20 2nd op-code map



| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\mathrm{ME}}$ | $\overline{\text { IOE }}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { SBC A, (IY+d) } \\ & \text { AND }(1 X+d) \\ & \text { AND }(I Y+d) \\ & \text { OR }(I X+d) \\ & \text { OR }(I Y+d) \\ & \text { XOR }(I X+d) \\ & \text { XOR }(\mid Y+d) \\ & \text { CP }(I X+d) \\ & \text { CP }(I Y+d) \end{aligned}$ | MC3 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}{ }^{\text {- }}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{4} \\ \sim \mathrm{MC}_{5} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & I Y+d \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| BIT b,g | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| BIT b, (HL) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| BIT b, (IX+d) <br> BIT b, (IY+d) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 3rd op-code Address | 3rd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & I Y+d \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| CALL mn | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| CALL f,mn (If condition is false) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |


| Instruction | $\begin{array}{\|c\|} \hline \text { Machine } \\ \text { Cycle } \end{array}$ | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\mathrm{ME}}$ | $\overline{10 E}$ | $\overline{\text { LiR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CALL f,mn (If condition is true) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1 st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | Ti | - | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| CCF | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| $\begin{aligned} & \text { CPI } \\ & \text { CPD } \end{aligned}$ | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | $\begin{aligned} & \text { 2nd } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} M C_{4} \\ \sim M C_{6} \end{array}$ | TitiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| CPIR <br> CPDR <br> (If $\mathrm{BC}_{\mathrm{R}} \neq 0$ and Ar $\left.=(\mathrm{HL})_{M}\right)$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC3 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{4} \\ \sim \mathrm{MC}_{\mathrm{d}} \end{array}$ | tititititi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| CPIR <br> CPDR <br> (if $\mathrm{BC}_{\mathrm{R}}=0$ or $\left.\mathrm{Ar}=(\mathrm{HL})_{M}\right)$ | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M C_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} M C_{4} \\ \sim M_{6} \end{array}$ | tititi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| CPL | MC ${ }_{1}$ | $\mathrm{T}_{1} \cdot \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| DAA | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M^{\prime} \mathrm{C}_{2}$ | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| DI | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{IOE}}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DJNZ j <br> (If $\mathrm{Br} \neq 0$ ) | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{C}$ | $\mathrm{Ti}{ }^{\text {e }}$ | - | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $M^{\prime} C_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{4} \\ \sim \mathrm{MC}_{5} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| DJNZ j <br> (If $\mathrm{Br}=0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti ${ }^{1}$ | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| El | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1 st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| $\begin{aligned} & \text { EX DE, HL } \\ & \text { EXX } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| EX AF, AF' | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{C}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| EX (SP), HL | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | H | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | L | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { EX (SP),IX } \\ & \text { EX (SP),IY } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | $\begin{aligned} & \text { 2nd } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | Ti | * | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

-1 DMA, REFRESH, or BUS RELEASE cannot be executed after this state. (Request is ignored)

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\text { IOE }}$ | $\overline{\mathrm{LIR}}$ | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { EX (SP), IX } \\ & \text { EX (SP), IY } \end{aligned}$ | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | $\begin{aligned} & \mathrm{IXH} \\ & \mathrm{IYH} \end{aligned}$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{7}{ }_{7}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | IXL IYL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| HALT | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | - | - | Next op-code <br> Address | Next op-code | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| M 0 IM 1 <br> M 2 | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| $\begin{aligned} & \text { NC } g \\ & \text { DEC } g \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| INC (HL) DEC (HL) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| INC ( $\mathbf{I} X+d)$ <br> $\operatorname{NNC}(\mathbf{I Y}+\mathrm{d})$ <br> DEC ( $\mathrm{I} \mathrm{X}+\mathrm{d}$ ) <br> DEC ( $\mathrm{Y}+\mathrm{d}$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{4} \\ \sim \mathrm{MC}_{5} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & Y+d \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $M^{\prime}{ }_{7}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{8}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & Y+d \end{aligned}$ | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| INC ww DEC ww | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | Ti | * | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| INC IX INC IY DEC IX DEC IY | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & 1 \mathrm{st} \\ & \text { op-dode } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | $\begin{aligned} & \text { 2nd } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

(to be continued)

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\mathrm{ME}}$ | $\overline{\mathrm{IOE}}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbb{N} A,(m)$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & m \text { to } A_{0} \sim A_{7} \\ & A \text { to } A_{8} \sim A_{15} \end{aligned}$ | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
| IN g, (C) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
| INO g, (m) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $M^{\prime}{ }_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m$ to $A_{0} \sim A_{7}$ OOH to $\mathrm{A}_{8} \sim \mathrm{~A}_{15}$ | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
| $\begin{aligned} & \|\mathbb{N}\| \\ & \mathbb{N} D \end{aligned}$ | $\mathrm{MC}_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| INIR <br> INDR <br> (If $\mathrm{Br} \neq 0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
|  | $M_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{5} \\ \sim \mathrm{MC} \mathrm{C}_{6} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| INIR <br> INDR <br> (If $\mathrm{Br}=0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\mathrm{ME}}$ | $\overline{10 E}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JP mn | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| JP f,mn (If $\mathbf{f}$ is false) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| JP f,mn (If $f$ is true) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M^{\prime} \mathrm{C}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| JP (HL) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| $\begin{aligned} & J P(I X) \\ & J P(I Y) \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| JR $\mathbf{j}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{3} \\ \sim \mathrm{MC}_{4} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| JR C $\mathrm{j}_{\mathrm{j}}$ JR NC, j JR Z, j JR NZ, j (If condition is false) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| JR C, j JR NC, ${ }_{\mathrm{j}}$ JR Z,j JR NZ, (If condition is true) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{3} \\ \sim \mathrm{MC}_{4} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| LD g.g' | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| LD g,m | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |

(to be continued)

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{IOE}}$ | $\overline{L T R}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LD g, (HL) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { LD g, ( }(X+d) \\ & \text { LD g, (IY+d) } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{4} \\ \sim \mathrm{MC}_{5} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & Y+d \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| LD (HL),g | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti | * | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | g | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & L D(1 X+d), g \\ & L D(i Y+d), g \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} M C_{4} \\ \sim M C_{6} \end{array}$ | TiTiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $M_{7}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & Y+d \end{aligned}$ | g | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| LD ( HL ), m | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{C 2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & L D(I X+d), m \\ & L D(I Y+d), m \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand <br> Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & I Y+d \end{aligned}$ | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { LD A, (BC) } \\ & \text { LD A, (DE) } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{OE}}$ | LIR | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LD A, (BC) <br> LD A, (DE) | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & \mathrm{BC} \\ & \mathrm{DE} \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| LD A, (mn) | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { LD (BC),A } \\ & \text { LD (DE),A } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & \mathrm{BC} \\ & \mathrm{DE} \end{aligned}$ | A | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| LD (mn), A | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | A | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| LD A,I LD A,R | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| $\begin{aligned} & \text { LD I,A } \\ & \text { LD R,A } \end{aligned}$ | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| LD ww, mn | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand <br> Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| LD IX,mn <br> LD $\mathrm{X}, \mathrm{mn}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand <br> Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| LD HL, (mn) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand <br> Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | त $\overline{\text { D }}$ | WR | $\overline{M E}$ | TOE | LIR | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LD HL, (mn) | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m \mathrm{n}+1$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| LD ww, (mn) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m n+1$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { LD IX,(mn) } \\ & \text { LD } \mathrm{IY},(m n) \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m \mathrm{n}+1$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| LD (mn), HL | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC3 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{4}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | L | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m n+1$ | H | 1 | 0 | 0 | 1 | 1 | 1 | 1 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { LIR }}$ | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LD (mn),ww | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}{ }_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | $n$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m \mathrm{n}$ | wwL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{7}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m n+1$ | wwh | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { LD }(m n) \text {,IX } \\ & \text { LD }(m n), I Y \end{aligned}$ | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | $\begin{aligned} & \text { 2nd } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand <br> Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | mn | $\begin{array}{\|l\|} \hline I X L \\ I Y L \end{array}$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{7}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m n+1$ | $\begin{array}{\|l\|} \hline \text { IXH } \\ \text { IYH } \end{array}$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| LD SP, HL | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| LD SP,IX <br> LD SP,IY | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{array}{\|l\|} \hline \text { 1st } \\ \text { op-code } \end{array}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | $\begin{aligned} & \text { 2nd } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $M^{\prime}{ }_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { LDI } \\ & \text { LDD } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | $\begin{aligned} & \text { 2nd } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | DE | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |

(to be continued)

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\text { ME }}$ | $\overline{\text { OE }}$ | $\overline{L T}$ | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LDIR <br> LDDR <br> (If $\mathrm{BC}_{\mathrm{R}} \neq 0$ ) | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | DE | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $\begin{array}{r} M C_{5} \\ -M C_{6} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| LDIR <br> LDDR <br> (if $\mathrm{BC}_{\mathrm{R}}=0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC ${ }_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | DE | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| MLT ww | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathbf{M C}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\begin{gathered} M C_{3} \\ \sim M C_{13} \\ \hline \end{gathered}$ | $\begin{aligned} & \text { TiTiTiTi } \\ & \text { Titititi } \\ & \text { TiTiTi } \end{aligned}$ | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| NEG | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| NOP | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| OUT (m),A | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & m \text { to } A_{0} \sim A_{7} \\ & A \text { to } A_{8} \sim A_{15} \end{aligned}$ | A | 1 | 0 | 1 | 0 | 1 | 1 | 1 |

(to be continued)

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OUT (C).g | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | g | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| OUTO (m).g | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{4}{ }_{4}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $m$ to $A_{0} \sim A_{7}$ $00 H$ to $A_{d} \sim A_{15}$ | g | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| OTIM OTDM | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $C$ to $A_{0} \sim A_{7}$ 00 H to $\mathrm{A}_{\boldsymbol{d}} \sim \mathrm{A}_{15}$ | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
|  | MC6 | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| OTIMR OTDMR (If $\mathrm{Br} \neq 0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & C \text { to } A_{0} \sim A_{7} \\ & O O H \text { to } A_{d} \sim A_{15} \end{aligned}$ | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{6} \\ \sim \mathrm{MC}_{3} \end{array}$ | Tititi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{OE}}$ | पाR | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OTIMR <br> OTDMR <br> (If $\mathrm{Br}=0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & C \text { to } A_{0} \sim A_{7} \\ & O O H \text { to } A_{8} \sim A_{15} \end{aligned}$ | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
|  | MC6 | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { OUTI } \\ & \text { OUTD } \end{aligned}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC3 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| OTIR <br> OTDR <br> (If $\mathrm{Br} \neq 0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC3 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{5} \\ \sim \mathrm{MC}_{6} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| OTIR <br> OTDR <br> (if $\mathrm{Br}=0$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | BC | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| POP 22 | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \text { POP IX } \\ & \text { POP IY } \end{aligned}$ | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |

(to be continued)

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{IOE}}$ | $\overline{L T}$ | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { POP IX } \\ & \text { POP IY } \end{aligned}$ | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | ${ }^{\bullet}$ | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| PUSH zz | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\begin{array}{r} \mathrm{MC}_{2} \\ \sim \mathrm{MC}_{3} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | zzH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | zzL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| PUSH IX PUSH IY | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M^{\prime}{ }_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\begin{array}{r} \mathrm{MC}_{3} \\ -\mathrm{MC}_{4} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | $\begin{array}{\|l\|} \hline \text { IXH } \\ \text { IYH } \end{array}$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | $\begin{aligned} & \hline \mathrm{IXL} \\ & \mathrm{IYL} \end{aligned}$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| RET | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC ${ }_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| RET f <br> (If condition is false) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\begin{array}{r} \mathrm{MC}_{2} \\ \sim \mathrm{MC}_{3} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| RET f <br> (If condition is true) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| RETI RETN | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | WR | $\overline{M E}$ | TOE | प | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RETI RETN | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| RLCA <br> RLA <br> RRCA <br> RRA | MC | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| RLC g <br> RL $g$ <br> RRC $g$ <br> RR g <br> SLA g <br> SRA $g$ <br> SRL $\mathbf{g}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | $\begin{aligned} & \text { 1 st } \\ & \text { op-code } \end{aligned}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| RLC (HL) <br> RL (HL) <br> RRC (HL) <br> RR (HL) <br> SLA (HL) <br> SRA (HL) <br> SRL (HL) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| RLC (IX+d) <br> RLC ( $(\mathbf{Y}+\mathrm{d})$ <br> RL (IX $\mathbf{X}+\mathrm{d})$ <br> RL (IY+d) <br> RRC (IX+d) <br> RRC ( $\mathrm{I}+\mathrm{d}$ ) <br> RR (IX $+\mathbf{d}$ ) <br> RR ( $\mathbf{I}+\mathbf{d}$ ) <br> SLA ( $\mathbf{X}+\mathrm{d}$ ) <br> SLA ( $\mathbf{Y}+\mathrm{d}$ ) <br> SRA ( $1 \times+d$ ) <br> SRA (IY+d) <br> SRL ( $1 X+d)$ <br> SRL ( $\mathrm{I}+\mathrm{d}$ ) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC3 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 3rd op-code <br> Address | 3rd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & I Y+d \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{7}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & Y+d \end{aligned}$ | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| RLD RRD | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |

(to be continued)

| Instruction | $\begin{array}{c\|} \hline \text { Machine } \\ \text { Cycle } \end{array}$ | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{IOE}}$ | $\overline{\text { LIR }}$ | HALT | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RLD RRD | $\begin{array}{r} \mathrm{MC}_{4} \\ \sim \mathrm{MC}_{7} \end{array}$ | Titititi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC8 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| RST v | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\begin{array}{r} \mathrm{MC}_{2} \\ \sim \mathrm{MC}_{3} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| SCF | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| SET b,g RES b,g | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M^{\prime} \mathrm{C}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| SET b, (HL) RES b, (HL) | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | MC2 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | Ti | - | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| SET b, (IX+d) <br> SET b, ( $\mathbf{I}+\mathrm{d}$ ) <br> RES $b$, ( $\mathbf{X}+\mathrm{d}$ ) <br> RES b, ( $\mathrm{I}+\mathrm{d}$ ) | MC1 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M^{\prime} \mathrm{C}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 3rd op-code <br> Address | 3rd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & I Y+d \end{aligned}$ | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{7}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & I X+d \\ & I Y+d \end{aligned}$ | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 |


| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\mathrm{IOE}}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SLP | MC | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | - | - | 7FFFFH | Z | 1 | 1 | 1 | 1 | 1 | 0 | 1 |
| TSTIO m | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $\begin{aligned} & C \text { to } A_{0} \sim A_{7} \\ & O O H \text { to } A_{8} \sim A_{15} \end{aligned}$ | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 |
| TST g | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| TST m | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code <br> Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code <br> Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st operand Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| TST (HL) | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 1st op-code Address | 1st op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | 2nd op-code Address | 2nd op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | Ti | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |

## INTERRUPT

| $\overline{\text { NMI }}$ | MC ${ }_{1}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | Next op-code <br> Address (PC) |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{array}{r} \mathrm{MC}_{2} \\ \sim \mathrm{MC}_{3} \end{array}$ | TiTi | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\overline{\mathbf{N T}_{0}}$ MODE 0 (RST INSERTED) | MC ${ }_{1}$ | $\begin{aligned} & T_{1} T_{2} T_{w} \\ & T_{w} T_{3} \end{aligned}$ | Next op-code Address (PC) | $\begin{aligned} & \text { 1st } \\ & \text { op-code } \end{aligned}$ | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|  | $\begin{array}{r} \mathrm{MC}_{2} \\ \sim \mathrm{MC}_{3} \end{array}$ | TiTi | * | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

(to be continued)

## HITACHI

| Instruction | Machine Cycle | States | ADDRESS | DATA | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{M E}$ | $\overline{\text { IOE }}$ | $\overline{\text { LIR }}$ | $\overline{\text { HALT }}$ | ST |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { INTo MODE } O}$ (RST NSERTED) | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| INTO MODE 0 (CALL INSERTED) | MC ${ }_{1}$ | $\begin{aligned} & \mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{\mathrm{w}} \\ & \mathrm{~T}_{\mathrm{w}} \mathrm{~T}_{3} \end{aligned}$ | Next op-code <br> Address (PC) | 1st op-code | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|  | $M_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | PC | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | $P C+1$ | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | Ti | - | $z$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | $\mathrm{PC}+2(\mathrm{H})$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | $\mathrm{PC}+2(\mathrm{~L})$ | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\overline{\text { INTo }}$ MODE 1 | MC | $\begin{aligned} & T_{1} T_{2} T_{W} \\ & T_{w} T_{3} \end{aligned}$ | Next op-code Address (PC) |  | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\overline{\text { NTO }}$ MODE 2 | MC ${ }_{1}$ | $\begin{aligned} & T_{1} T_{2} T_{w} \\ & T_{w} T_{3} \end{aligned}$ | Next op-code Address (PC) | Vector | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|  | MC ${ }_{2}$ | Ti | - | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | $M_{C 4}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | I, Vector | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | I, Vector+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| $\begin{aligned} & \overline{\mathbb{N T}_{1}} \\ & \overline{\mathbb{N T}_{2}} \\ & \text { Internal Interrupts } \end{aligned}$ | MC ${ }_{1}$ | $\begin{aligned} & T_{1} T_{2} T_{W} \\ & T_{w} T_{3} \end{aligned}$ | Next op-code Address (PC) |  | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
|  | $\mathrm{MC}_{2}$ | Ti | - | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|  | $\mathrm{MC}_{3}$ | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-1 | PCH | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC4 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | MC5 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | I, Vector | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
|  | MC6 | $\mathrm{T}_{1} \mathrm{~T}_{2} \mathrm{~T}_{3}$ | I, Vector+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 |


| Request | $\begin{array}{r} \begin{array}{r} \text { Current } \\ \text { Status } \end{array} \\ \hline \end{array}$ | Normal Operation (CPU mode) (IOSTOP mode) | WAIT State | Refresh Cycle | Interrupt Acknowledge Cycle | DMA Cycle | BUS RELEASE mode | SLEEP mode | SYSTEM STOP mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { WAIT }}$ |  | Acceptable | Acceptable | Not acceptable | Acceptable | Acceptable | Not acceptable | Not acceptable | Not acceptable |
| Refresh Request (Request of Refresh by the on-chip Refresh Controller) |  | Refresh cycle begins at the end of MC. | Not acceptable | Not acceptable | Refresh cycle begins at the end of MC. | Refresh cycle begins at the end of MC. | Not acceptable | Not acceptable | Not acceptable |
| $\frac{\overline{\text { DREO }}}{\frac{\text { DREO }}{0}}$ |  | DMA cycle begins at the end of MC. | DMA cycle begins at the end of MC. | Acceptable <br> - Refresh cycle precedes. DMA cycle begins at the end of one MC. | Acceptable DMA cycle begins at the end of MC. | Acceptable Refer to " 2.9 DMA Controller" for details. | Accentable <br> - After BUS RELEASE cycle, DMA cycle begins at the end of one MC. | Not acceptable | Not acceptable |
| $\overline{\text { BUSREQ }}$ |  | Bus is released at the end of MC. | Not acceptable | Not acceptable | Bus is released at the end of MC. | Bus is released at the end of MC. | Continue BUS RELEASE mode. | Acceptable | Acceptable |
| Interrupt | $\overline{\overline{\mathbb{N} T_{2}}, \overline{\mathbb{N} T_{1}},}$ | Accepted after executing the current instruction. | Accepted after executing the current instruction | Not acceptable | Not acceptable | Not acceptable | Not acceptable | Acceptable Return from SLEEP mode to normal operation. | Acceptable Return from SYSTEM STOP mode to normal operation. |
|  | Intemal <br> I/O <br> Interrupt | $\dagger$ | $\dagger$ | 1 | 1 | 1 | $\dagger$ | $\dagger$ | Not acceptable |
|  | $\overline{\mathrm{NMII}}$ | 1 | 1 | 1 | Not acceptable Interrupt acknowledge cycle precedes. $\overline{\mathrm{NMI}}$ is accepted after executing the next instruction. | Acceptable DMA cycle stops. | $\dagger$ | $\dagger$ | Acceptable Return from SYSTEM STOP mode to normal operation. |

NOTE) * : not acceptable when DMA Request is in level sense.
$\dagger$ : same as the above
MC: Machine Cycle

## 24 REQUEST PRIORITY

The HD64180 has the following three types of requests. Type 1.

To be accepted in specified state. . . . . . . . . . . WAIT
Type 2.
To be accepted in each machine cycle...... Refresh Req DMA Req. Bus Req.
Type 3.
To be accepted in each instruction $\qquad$ Interrupt Req.

## 25 OPERATION MODE TRANSITION



NOTE) - 1 NORMAL: CPU executes instructions normally in NORMAL mode.

- 2 DMA request: DMA is requested in the following cases.
(1) DREO $_{0}$, DREQ $_{1}=0$ (memory $\longleftrightarrow$ (memory mapped) I/O DMA transfer) (2) $\mathrm{DEO}=1$ (memory $\longleftrightarrow$ memory DMA transfer)
*3 DMA end: DMA ends in the following cases
(1) $\overline{\text { DREQ }_{0}}, \overline{\text { DREQ }}_{1}=1$ (memory $\longleftrightarrow$ (memory mapped) I/O DMA transfer)
(2) BCRO, BCR1 $=0000 \mathrm{H}$ (all DMA transfers)
(3) $\overline{\mathrm{NMI}}=\mathbf{0}$ (all DMA transfers)


Type 1, Type 2, and Type 3 requests priority is shown as follows. highest priority Type $1>$ Type $2>$ Type 3 lowest priority Each request priority in Type 2 is shown as follows. highest priority Bus Req. > Refresh Req. > DMA Req. lowest priority
(NOTE) If Bus Req. and Refresh Req. occurs simultaneously, Bus Req. is accepted but Refresh Req. is cleared.
Refer to "2.7 Interrupts" for each request priority in Type 3.

Other operation mode transitions
The following operation mode transitions are also possible.

1. HALT $\left.\longrightarrow \begin{array}{l}\text { DMA } \\ \text { REFRESH } \\ \text { BUS RELEASE }\end{array}\right]$
2. SLEEP $\left.\longrightarrow \begin{array}{l}\text { DMA } \\ \text { REFRESH } \\ \text { BUS RELEASE }\end{array}\right]$
BUS RELEASE

SYSTEM STOP $\because$ BUS RELEASE

## 26 STATUS SIGNALS

The following table shows pin outputs in each operating mode.

| Mode |  | $\overline{\text { LIR }}$ | $\overline{\text { ME }}$ | $\overline{10 E}$ | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\text { REF }}$ | HALT | $\overline{\text { BUSACK }}$ | ST | Address BUS | Data <br> BUS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CPU operation | Op-code Fetch (1st op-code) | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | A | IN |
|  | Op-code Fetch (except 1st op-code) | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | A | $\mathbb{N}$ |
|  | Memory Read | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | A | $\mathbb{N}$ |
|  | Memory Write | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | A | OUT |
|  | I/O Read | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | A | $\mathbb{N}$ |
|  | I/O Write | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | A | OUT |
|  | Internal Operation | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | A | IN |
| Refresh |  | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | - | A | $\underline{N}$ |
| Interrupt <br> Acknowledge <br> Cycle <br> (1st machine <br> cycle) | $\overline{\text { NMT }}$ | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | A | IN |
|  | $\overline{\mathrm{NT} 0_{0}}$ | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | A | $\mathbb{N}$ |
|  | $\overline{\mathbb{N T}_{1}}, \overline{\mathbb{N T}_{2}}$ \& Intemal Interrupts | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | A | IN |
| BUS RELEASE |  | 1 | Z | Z | Z | Z | 1 | 1 | 0 | - | Z | $\mathbb{N}$ |
| HALT |  | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | A | $\mathbb{N}$ |
| SLEEP |  | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | $\underline{N}$ |
| Intemal DMA | Memory Read | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | A | IN |
|  | Memory Write | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | A | OUT |
|  | I/O Read | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | A | $\mathbb{N}$ |
|  | I/O Write | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | A | OUT |
| RESET |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Z | $\mathbb{N}$ |

NOTE)

| 1 | $:$ |
| :--- | :--- |
| 0 | HIGH |
| A | LOW |
| Z | Programmable |
| Z | High Impedance |
| $\mathbb{N}$ | $:$ input |
| OUT $:$ | Output |
| - | : Invalid |

27 PIN STATUS DURING RESET AND LOW POWER OPERATION MODES

| Pin No. | Symbol | Pin function | Pin status in each operation mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | RESET | SLEEP | IOSTOP | SYSTEM STOP |
| 4 | WAIT | - | IN (N) | $\underline{N}(\mathbb{N})$ | IN (A) | $\underline{N}(\mathbb{N})$ |
| 5 | BUSACK | - | 1 | OUT | OUT | OUT |
| 6 | BUSREQ | - | $\underline{\mathrm{N}}$ ( N ) | $\underline{N(A)}$ | IN (A) | IN (A) |
| 7 | RESET | - | 0 | IN (A) | IN (A) | $\underline{N}(\mathrm{~A})$ |
| 8 | $\overline{\mathrm{NMI}}$ | - | $\underline{N}(\mathbb{N})$ | IN (A) | IN (A) | IN (A) |
| 9 | $\overline{\text { NTo }}$ | - | $\underline{N}(\mathbb{N})$ | IN (A) | IN (A) | IN (A) |
| 10 | $\overline{\text { NT }} 1$ | - | $\underline{N}(\mathbb{N})$ | IN (A) | IN (A) | IN (A) |
| 11 | $\overline{\mathrm{NT}}{ }^{2}$ | - | $\underline{N}(\mathbb{N})$ | $\underline{N}(\mathrm{~A})$ | IN (A) | IN (A) |
| 12 | ST | - | 1 | 1 | OUT | 1 |
| 13~30 | $A_{0} \sim A_{17}$ | - | Z | 1 | A | 1 |
| 31 | $\mathrm{A}_{1} /$ TOUT | A1a | Z | 1 | A | 1 |
|  |  | TOUT | Z | OUT | H | H |
| 34~41 | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ | - | Z | Z | A | Z |
| 42 | $\overline{\text { RTS }}$ | - | 1 | H | OUT | H |
| 43 | CTSo | - | IN ( N ) | IN (A) | $\underline{N(N)}$ | $\underline{N}(\mathbb{N})$ |
| 44 | $\overline{\text { DCD }}$ | - | $\underline{N}(\mathbb{N})$ | IN (A) | $\mathbb{N}(\mathbb{N})$ | $\underline{N}(\mathbb{N})$ |
| 45 | TXAo | - | 1 | OUT | H | H |
| 46 | RXA0 | - | $\mathbb{N}(\mathbb{N})$ | $\mathbb{N}(A)$ | $\mathrm{N}(\mathrm{N})$ | $\underline{\mathrm{N}}$ ( N$)$ |
| 47 | CKA0/ $\overline{\text { REGQ }}$ | CKAo lintemal clock mode) | Z | OUT | Z | Z |
|  |  | CKAo (external clock mode) | Z | $\underline{N}(\mathrm{~A})$ | $\mathrm{IN}(\mathbb{N})$ | $\underline{N}(\mathbb{N})$ |
|  |  | DREQ | Z | $\underline{N}(\mathbb{N})$ | IN (A) | $\underline{N}(\mathrm{~N})$ |
| 48 | TXA ${ }_{1}$ | - | 1 | OUT | H | H |
| 49 | RXA ${ }_{1}$ | - | $\underline{N}(\mathbb{N})$ | $\underline{N}(A)$ | $\mathrm{N}(\mathbb{N})$ | IN (N) |
| 50 | CKA $_{1} / \overline{\text { TEND }}{ }_{0}$ | CKA ${ }_{1}$ (intemal clock mode) | Z | OUT | z | Z |
|  |  | CKA ${ }_{1}$ (external clock mode) | Z | $\mathbb{N}(\mathrm{A})$ | $\underline{N}(\mathbb{N})$ | $\underline{N}(\mathbb{N})$ |
|  |  | TENDo | Z | 1 | OUT | 1 |
| 51 | TXS | - | 1 | OUT | H | H |
| 52 | RXS/ $\overline{\text { CTS }} 1$ | RXS | $\underline{N}(\mathbb{N})$ | $\underline{1 N}(A)$ | $\underline{N(N)}$ | $\underline{N(N)}$ |
|  |  | $\overline{\text { CTS }}{ }_{1}$ | $\mathbb{N}(\mathbb{N})$ | IN (A) | $\underline{N}(\mathbb{N})$ | $\underline{N}(\mathbb{N})$ |
| 53 | CKS | CKS (internal clock mode) | Z | OUT | 1 | 1 |
|  |  | CKS (extemal clock mode) | Z | $\underline{N}(\mathrm{~A})$ | Z | Z |
| 54 | $\overline{\text { DREQ }}$ | - | $\mathbb{N}(\mathbb{N})$ | $\mathbb{N}(\mathbb{N})$ | IN (A) | $\underline{N}(\mathbb{N})$ |
| 55 | TEND, | - | 1 | 1 | OUT | 1 |
| 56 | $\overline{\text { HALT }}$ | - | 1 | 0 | OUT | 0 |
| 57 | $\overline{\text { REF }}$ | - | 1 | 1 | OUT | 1 |
| 58 | $\overline{\text { IOE }}$ | - | 1 | 1 | OUT | 1 |
| 59 | $\overline{\mathrm{ME}}$ | - | 1 | 1 | OUT | 1 |
| 60 | E | - | 0 | E clock output | $\leftarrow$ | $\leftarrow$ |
| 61 | $\overline{L R}$ | - | 1 | 1 | OUT | 1 |
| 62 | $\overline{W R}$ | - | 1 | 1 | OUT | 1 |
| 63 | $\overline{\mathrm{R}}$ | - | 1 | 1 | OUT | 1 |
| 64 | $\phi$ | - | $\phi$ clock output | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ |

1: HIGH O: LOW A: Programmable Z: High Impedance
$\mathbb{N}(A)$ : Input (Active) $\mathbb{N}(\mathbb{N})$ : Input (Not active) OUT: Output
H : Holds the previous state
$\leftarrow$ : same as the left

## 28 INTERNAL I/O REGISTERS

By programming IOA7 and IOA6 in the I/O control register, in-
ternal I/O register addresses are relocatable within ranges from 0000 H to 00 FFH in the I/O address space.



(to be continued)

| REGISTER ${ }^{\text {a }}$ MNEMONICS | ADDRESS |  | REMARKS |
| :---: | :---: | :---: | :---: |
| Timer Data Register Channel 1L <br> : TMDR1L | 14 |  |  |
| Timer Data Register Channel 1H <br> : TMDR1H | 15 |  |  |
| Timer Reload Register Channel 1L <br> : RLDR1L | 16 |  |  |
| Timer Reload Register Channel 1H : RLDR1H | 17 |  |  |
| Free Running Counter | 18 | read only |  |
| : FRC |  |  |  |
| DMA Source Address Register Channel OL | 20 |  |  |
| : SAROL |  |  |  |
| DMA Source Address Register Channel OH | 21 |  |  |
| : SAROH |  |  |  |
| DMA Source Address Register Channel OB | 22 | Bits 0-2 are used for SAROB. $A_{18}, A_{17}, A_{16}$ | DMA Transfer Request |
| : SAROB |  | $\begin{array}{lll} \hline \mathbf{X} & 0 & 0 \\ \mathrm{X} & 0 & 1 \\ \mathrm{X} & 1 & 0 \end{array}$ | DREO $_{0}$ (extemal) RDRO (ASCIO) RDR1 (ASCI1) |
| DMA Destination Address Register Channel OL | 23 | $\begin{array}{lll}\times & 1\end{array}$ | Not Used |
| : DAROL |  |  |  |
| DMA Destination Address Register Channel OH | 24 |  |  |
| : DAROH |  |  |  |
| DMA Destination Address Register | 25 | Bits 0-2 are used for DAROB. |  |
| Channel OB |  | $A_{18}, A_{17}, A_{16}$ | DMA Transfer Request |
| : DAROB |  | $\mathbf{X}$ 0 0 <br> $\mathbf{X}$ 0 1 <br> $\mathbf{X}$ 1 0 | DREO ${ }_{0}$ (external) TDRO (ASCIO) TDR1 (ASCI1) |
| DMA Byte Count Register Channel OL | 26 | X 11 | Not Used |
| : BCROL |  |  |  |
| DMA Byte Count Register Channel OH | 27 |  |  |
| BCROH |  |  |  |
| DMA Memory Address Register Channel 1L | 28 |  |  |
| : MAR1L |  |  |  |
| DMA Memory Address Register Channel 1H | 29 |  |  |
| : MAR1H |  |  |  |
| DMA Memory Address Register Channel 1B | 2 A | Bits 0-2 are used for MAR1B. |  |
| : MAR1B |  |  |  |
| DMA I/O Address Register Channel 1L | 2 B |  |  |
| : IAR1L |  |  |  |
| DMA I/O Address Register Channel 1H <br> : IAR1H | 2 C |  |  |
|  |  |  |  |

(to be continued)

(to be continued)

(to be continued)


## 16-BIT MICROPROCESSOR

## HD68000/HD68HC000 MPU (Micro Processing Unit)

## - HD68000 -

The HD68000 is the first in a family of advanced microprocessors from Hitachi. Utilizing VLSI technology, the HD68000 is a fully-implemented 16-bit microprocessor with 32 -bit registers, a rich basic instruction set, and versatile addressing modes.

The HD68000 possesses an asynchronous bus structure with a 24 -bit address bus and a 16 -bit data bus.

## FEATURES

- 32-Bit Data and Address Registers
- 16 Megabyte Direct Addressing Range
- 56 Powerful Instruction Types
- Operations of Five Main Data Types
- Memory Mapped I/O
- 14 Addressing Modes


## - HD68HCOOO -

The HD68HC000 is a 16-bit microprocessor of HD68000 family, which is exactly compatible with the conventional HD68000.

The HD68HC000 is a complete CMOS device and the power dissipation is extremely low.

## FEATURES

- Instruction Compatible with NMOS HD68000
- Pin Compatible with NMOS HD68000
- AC Timing Compatible with NMOS HD68000
- Low Power Dissipation (Icc typ $=\mathbf{2 0} \mathrm{mA}$, Icc max $=\mathbf{3 5} \mathrm{mA}$ at $f=12.5 \mathrm{MHz}$ )

HD68000-8, HD68000-10, HD68000-12 HD68HC000-8, HD68HC000-10, HD68HC000-12

(DC-64)
HD68000Y-8, HD68000Y-10, HD68000Y-12 HD68HC000Y-8, HD68HC000Y-10, HD68HC000Y-12


## HD68000P-8

HD68HC000P-8, HD68HC000P-10, HD68HC000P-12


HD68000PS-8
HD68HC000PS-8, HD68HC000PS-10, HD68HC000PS-12

(DP-64S)
HD68000CP-8
HD68HC000CP-8, HD68HC000CP-10, HD68HC000CP-12

(CP-68)

- TYPE OF PRODUCTS

| Type No. | Process | Clock Frequency (MHz) | Package |
| :---: | :---: | :---: | :---: |
| HD68000-8 | NMOS | 8.0 | DC-64 |
| HD68000-10 |  | 10.0 |  |
| HD68000-12 |  | 12.5 |  |
| HD68000Y-8 |  | 8.0 | PGA-68 |
| HD68000Y-10 |  | 10.0 |  |
| HD68000Y-12 |  | 12.5 |  |
| HD68000R8 |  | 8.0 | DP.64 |
| HD68000PS8 |  | 8.0 | DP-64S |
| HD68000CP8 |  | 8.0 | CP-68 |
| HD68HC000-8 | CMOS | 8.0 | DC-64 |
| HD68HC000-10 |  | 10.0 |  |
| HD68HC000-12 |  | 12.5 |  |
| HD68HC000Y8 |  | 8.0 | PGA-68 |
| HD68HC000Y-10 |  | 10.0 |  |
| HD68HC000Y-12 |  | 12.5 |  |
| HD68HC000R8 |  | 8.0 | DP-64 |
| HD68HC000P-10 |  | 10.0 |  |
| HD68HC000R-12 |  | 12.5 |  |
| HD68HC000P98 |  | 8.0 | DP-64S |
| HD68HC000PS-10 |  | 10.0 |  |
| HD68HC000PS-12 |  | 12.5 |  |
| HD68HC000CR8 |  | 8.0 | CP-68 |
| HD68HC000CP10 |  | 10.0 |  |
| HD68HC000CP-12 |  | 12.5 |  |

(Note) HD68000 refers to the NMOS version 68000, and HD68HC000 refers to the CMOS version 68000. 68000 stands for NMOS and CMOS version.

- PIN ARRANGEMENT
- DC-64, DP-64, DP-64S

- PGA-68

|  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin No. | Function | Pin No. | Function | Pin No. | Function | Pin No. | Function |
| 1 | N/C | 18 | A, | 35 | $\mathrm{D}_{1}$ | 52 | $\mathrm{A}_{12}$ |
| 2 | DTACK | 19 | N/C | 36 | $\overline{\text { AS }}$ | 53 | $A_{15}$ |
| 3 | BGACK | 20 | $\mathrm{A}_{14}$ | 37 | $\overline{\text { LDS }}$ | 54 | $\mathrm{A}_{18}$ |
| 4 | $\overline{B R}$ | 21 | $\mathrm{A}_{16}$ | 38 | $\overline{\mathbf{B G}}$ | 55 | $\mathrm{V}_{\text {cc }}$ |
| 5 | CLK | 22 | $\mathrm{A}_{17}$ | 39 | $\mathrm{V}_{\mathrm{cc}}$ | 56 | $\mathrm{V}_{\text {ss }}$ |
| 6 | HALT | 23 | $\mathrm{A}_{19}$ | 40 | $V_{\text {ss }}$ | 57 | $\mathrm{A}_{23}$ |
| 7 | VMA | 24 | $A_{30}$ | 41 | $\overline{\text { RES }}$ | 58 | $\mathrm{D}_{14}$ |
| 8 | E | 25 | $\mathrm{A}_{21}$ | 42 | VPA | 59 | $\mathrm{D}_{11}$ |
| 9 | $\overline{\text { BERR }}$ | 26 | $\mathrm{A}_{12}$ | 43 | $\overline{\mathrm{PP} \mathrm{L}_{2}}$ | 60 | $\mathrm{D}_{1}$ |
| 10 | N/C | 27 | $\mathrm{D}_{15}$ | 44 | $\mathrm{PPL}_{0}$ | 61 | $\mathrm{D}_{6}$ |
| 11 | $\mathrm{FC}_{2}$ | 28 | $\mathrm{D}_{12}$ | 45 | $\mathrm{FC}_{1}$ | 62 | $\mathrm{D}_{3}$ |
| 12 | $\mathrm{FC}_{0}$ | 29 | $\mathrm{D}_{10}$ | 46 | N/C | 63 | $\mathrm{D}_{0}$ |
| 13 | $A_{1}$ | 30 | $\mathrm{D}_{1}$ | 47 | $\mathrm{A}_{2}$ | 64 | $\overline{\text { UOS }}$ |
| 14 | $A_{3}$ | 31 | $\mathrm{D}_{7}$ | 48 | $A_{s}$ | 65 | R/W |
| 15 | $A_{4}$ | 32 | $\mathrm{D}_{5}$ | 49 | $A_{8}$ | 66 | $\overline{\mathrm{PP}} \mathrm{A}_{1}$ |
| 16 | $A_{6}$ | 33 | $\mathrm{D}_{4}$ | 50 | $A_{10}$ | 67 | $\mathrm{A}_{13}$ |
| 17 | $A_{1}$ | 34 | $\mathrm{D}_{2}$ | 51 | $\mathrm{A}_{11}$ | 68 | $\mathrm{D}_{13}$ |

- CP-68

- ABSOLUTE MAXIMUM RATINGS

| Item | Symbol | HD68000 | HD68HC000 | Unit |
| :--- | :---: | :---: | :---: | :---: |
|  |  | Value | Value |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}{ }^{*}$ | $-0.3 \sim+7.0$ | $-0.3 \sim+6.5$ | V |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | $-0.3 \sim+7.0$ | $-0.3 \sim+6.5$ | V |
| Operating Temperature Range | $\mathrm{T}_{\text {opr }}$ | $0 \sim+70$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

*With respect to $V_{S S}$ (SYSTEM GND)
(NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI.

Since the HD68HC000 is a C-MOS device, users are expected to be cautious on "latch-up" problem caused by voltage fracturations.

- RECOMMENDED OPERATING CONDITIONS

| Item |  | Symbol | HD68000 |  |  | HD68HC000 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min | typ | max | min | typ | max |  |
| Supply Voltage |  |  | VCC* | 4.75 | 5.0 | 5.25 | 4.75 | 5.0 | 5.25 | V |
| Input Voltage | CLK | $\mathrm{VIH}^{*}$ | 2.0 | - | Vcc | 2.8 | - | $\mathrm{V}_{\text {cc }}$ | V |
|  | Other Inputs |  |  |  |  | 2.0 | - | $V_{\text {cc }}$ |  |
|  | All Inputs | $\mathrm{VIL}^{*}$ | -0.3 | - | 0.8 | -0.3 | - | 0.8 | V |
| Operating Temperature |  | Topr | 0 | 25 | 70 | 0 | 25 | 70 | ${ }^{\circ} \mathrm{C}$ |

* With respect to $\mathrm{V}_{\text {SS }}$ (SYSTEM GND)
- ELECTRICAL CHARACTERISTICS
- DC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=\mathbf{5 V} \pm \mathbf{5 \%}, \mathrm{V}_{\text {SS }}=\mathbf{0 V}, \mathrm{Ta}_{\mathrm{a}}=\mathbf{0} \sim+\mathbf{7 0} 0^{\circ} \mathrm{C}$, Fig. 1 , unless otherwise noted.)

| Item |  | Symbol | Test Condition | HD68000 |  | HD68HC000 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min |  | max | min | max |  |
| Input "High" Voltage | CLK |  | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.0 | $V_{\text {cc }}$ | 2.8 | $\mathrm{V}_{\mathrm{Cc}}$ | V |
|  | Other Inputs |  |  | 2.0 |  |  | $\mathrm{V}_{\text {cc }}$ |  |  |
| Input "Low" Voltage |  | $\mathrm{V}_{\text {IL }}$ |  | $\mathrm{V}_{\text {SS }}-0.3$ | 0.8 | $\mathrm{V}_{\text {ss }}-0.3$ | 0.8 | V |  |
| Input Leakage Current | BERR, BGACK, BR, DTACK, $\overline{\mathrm{PL}_{0}} \sim \overline{\mathrm{PL}_{2}}, \overline{\mathrm{VPA}}, \mathrm{CLK}$ | $I_{\text {in }}$ | @ 5.25V | - | 2.5 | - | 2.5 | $\mu \mathrm{A}$ |  |
|  | $\overline{\text { HALT }}, \overline{\text { RES }}$ |  |  | - | 20 | - | 20 |  |  |
| Three-State (Off State) Input Current | $\begin{aligned} & \overline{\mathrm{AS}}, \mathrm{~A}_{1} \sim \mathrm{~A}_{23}, \mathrm{D}_{0} \sim \mathrm{D}_{15}, \\ & \mathrm{FC}_{0} \sim \mathrm{FC} C_{2}, \overline{\mathrm{LDS}}, \mathrm{R} / \bar{W}, \overline{\mathrm{UDS}}, \\ & \overline{\mathrm{VMA}} \end{aligned}$ | ${ }^{\text {ITSI }}$ | @ 2.4V/0.4V | - | 20 | - | 20 | $\mu \mathrm{A}$ |  |
| Output "High" Voltage | $\overline{A S}, A_{1} \sim A_{23}, \overline{B G}, D_{0} \sim D_{15}$, $\mathrm{FC}_{0} \sim \mathrm{FC}_{2}, \overline{\mathrm{LDS}}, \mathrm{R} / \mathrm{W}, \mathrm{UDS}$, VMA, E | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ | 2.4 | - | $V_{C c}-0.75$ | - | V |  |
|  | $E^{*}$ |  |  | $\mathrm{V}_{\text {cc }}-0.75$ | - |  |  |  |  |
| Output "Low" Voltage | HALT | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ | - | 0.5 | - | 0.5 | V |  |
|  | $\mathrm{A}_{1} \sim \mathrm{~A}_{23}, \overline{\mathrm{BG}}, \mathrm{FC}_{0} \sim \mathrm{FC}_{2}$ |  | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ | - | 0.5 | - | 0.5 |  |  |
|  | $\overline{\text { RES }}$ |  | $\mathrm{I}_{\mathrm{OL}}=5.0 \mathrm{~mA}$ | - | 0.5 | - | 0.5 |  |  |
|  | $\overline{\mathrm{AS}}, \mathrm{D}_{0} \sim \mathrm{D}_{15}, \overline{\mathrm{LDS}}, \mathrm{R} / \overline{\mathrm{W}}, \mathrm{E}$, $\overline{U D S}, \overline{V M A}$ |  | $\mathrm{I}_{\mathrm{OL}}=5.3 \mathrm{~mA}$ | - | 0.5 | - | 0.5 |  |  |
| Power Dissipation | CERAMIC PACKAGE | $P_{\text {D }}$ | $\mathrm{f}=6 \mathrm{MHz}$ | - | 1.5 | - | - | W |  |
|  |  |  | $f=8 \mathrm{MHz}$ |  |  |  |  |  |  |
|  |  |  | $\mathrm{f}=12.5 \mathrm{MHz}$ | - | 1.75 |  |  |  |  |
|  | PLASTIC PACKAGE |  | $\begin{aligned} & \mathrm{f}=8 \mathrm{MHz}, \\ & \mathrm{VcC}=5 \mathrm{~V}, \\ & \mathrm{Ta}=25^{\circ} \mathrm{C} \end{aligned}$ | - | 0.9 |  |  |  |  |
| Current Dissipation |  | $\mathrm{I}^{*}$ ** | $\mathrm{f}=8 \mathrm{MHz}$ | - | - | - | 25 | mA |  |
|  |  | $\mathrm{f}=10 \mathrm{MHz}$ | - | - | - | 30 |  |  |  |
|  |  | $\mathrm{f}=12.5 \mathrm{MHz}$ | - | - | - | 35 |  |  |  |
| Capacitance (Package Type Dependent) |  |  | $c_{\text {in }}$ | $\begin{aligned} & V_{\text {in }}=0 \mathrm{~V}, \\ & \mathrm{Ta}=25^{\circ} \mathrm{C}, \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ | - | 20.0 | - | 20.0 | pF |

*With external pull up resistor of $1.1 \mathrm{k} \Omega$.
" "Without load.


Figure 1 Test Loads

HD68000/HD68HC000

- AC CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{Ta}=0 \sim+70^{\circ} \mathrm{C}$, unless otherwise noted.)


## CLOCK TIMING

| Item | Symbol | Test Condition | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min | max | min | max | min | max |  |
| Frequency of Operation | $f$ | Fig. 2 | 4.0 | 8.0 | 4.0 | 10.0 | 4.0 | 12.5 | MHz |
| Cycle Time | $\mathrm{t}_{\mathrm{cyc}}$ |  | 125 | 250 | 100 | 250 | 80 | 250 | ns |
| Clock Pulse Width | ${ }_{\text {t }}^{\text {cl }}$ |  | 55 | 125 | 45 | 125 | 35 | 125 | ns |
|  | ${ }_{\text {teH }}$ |  | 55 | 125 | 45 | 125 | 35 | 125 | ns |
| Rise and Fall Times | $\mathrm{t}_{\mathrm{Cr}}$ |  | - | 10 | - | 10 | - | 5 | ns |
|  | $\mathrm{t}_{\mathrm{Cf}}$ |  | - | 10 | - | 10 | - | 5 | ns |


(NOTE)
Timing measurements are referenced to and from a low voltage of 0.8 volt and high a voltage of 2.0 volts, unless otherwise noted.
The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts.

Figure 2 Clock Input Timing

READ AND WRITE CYCLES

| Num. | Item | Symbol | Test Condition | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | max | min | max | min | max |  |
| 1 | Clock Period | $\mathrm{t}_{\text {cyc }}$ | Fig. 3, Fig. 4 | 125 | 250 | 100 | 250 | 80 | 250 | ns |
| 2 | Clock Width Low | tcL |  | 55 | 125 | 45 | 125 | 35 | 125 | ns |
| 3 | Clock Width High | ${ }_{\text {ten }}$ |  | 55 | 125 | 45 | 125 | 35 | 125 | ns |
| 4 | Clock Fall Time | ${ }_{\text {t }}{ }_{\text {f }}$ |  | - | 10 | - | 10 | - | 5 | ns |
| 5 | Clock Rise Time | ${ }_{\text {t }}^{\text {cr }}$ |  | - | 10 | - | 10 | - | 5 | ns |
| 6 | Clock Low to Address Valid | telav |  | - | 70 | - | 60 | - | 55* | ns |
| 6A | Clock High to FC Valid | ${ }^{\text {t }}$ CHFCV |  | - | 70 | - | 60 | - | 55 | ns |
| 7 | Clock High to Address, Data Bus High Impedance (Maximum) | ${ }^{\text {t }}$ Chadz |  | - | 80 | - | 70 | - | 60 | ns |
| 8 | Clock High to Address, FC Invalid (Minimum) | tCHAFI |  | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ CHSL |  | 0 | 60 | 0 | 55 | 0 | 55 | ns |
| $11^{2}$ | Address Valid to $\overline{\text { AS }}, \overline{\mathrm{DS}}$ Low (Read)/ $\overline{A S}$ Low (Write) | ${ }^{\text {t }}$ AVSL |  | 30 | - | 20 | - | 0 | - | ns |
| 11A ${ }^{2}$ | FC Valid to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low (Read)/ $\overline{\mathrm{AS}}$ Low (Write) | $\mathrm{t}_{\text {flCVSL }}$ |  | 60 | - | 50 | - | 40 | - | ns |
| $12^{1}$ | Clock Low to $\overline{\text { AS, }} \overline{\text { DS }}$ High | ${ }^{\text {t CLSH }}$ |  | - | 70 | - | 55 | - | 50 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Address/FC Invalid | ${ }_{\text {t }}$ |  | 30 | - | 20 | - | 10 | - | ns |
| $14^{2}$ | $\overline{\text { AS, }} \overline{\text { DS }}$ Width Low (Read)/ $\overline{\text { AS }}$ Low (Write) | tSL |  | 240 | - | 195 | - | 160 | - | ns |
| $14 \mathrm{~A}^{2}$ | DS Width Low (Write) | tDSL |  | 115 | - | 95 | - | 80 | - | ns |
| $15^{2}$ | $\overline{\text { AS, }} \overline{\mathrm{DS}}$ Width High | ${ }^{\text {t }}$ S |  | 150 | - | 105 | - | 65 | - | ns |
| 16 | Clock High to Control Bus High Impedance | ${ }^{\text {t }} \mathrm{CHCZ}$ |  | - | 80 | - | 70 | - | 60 | ns |
| $17^{2}$ | $\overline{\text { AS, }} \overline{\text { DS }}$ High to R/W High (Read) | ${ }_{\text {t }}$ SHRH |  | 40 | - | 20 | - | 10 | - | ns |
| $18^{1}$ | Clock High to R/W High | tehri |  | 0 | 70 | 0 | 60 | 0 | 60 | ns |
| $20^{1}$ | Clock High to R/W Low (Write) | tCHRL |  | - | 70 | - | 60 | - | 60 | ns |
| 20A ${ }^{6}$ | $\overline{\text { AS }}$ Low to R/W Valid (Write) | $t_{\text {ASRV }}$ |  | - | 20 | - | 20 | - | 20 | ns |
| $21^{2}$ | Address Valid to R/W Low (Write) | tavRL |  | 20 | - | 0 | - | 0 | - | ns |
| 21A ${ }^{2}$ | FC Valid to R/ד/ Low (Write) | $\mathrm{t}_{\text {F }}$ CVRL |  | 60 | - | 50 | - | 30 | - | ns |
| $22^{2}$ | R/W Low to $\overline{\mathrm{DS}}$ Low (Write) | ${ }^{\text {traLSL }}$ |  | 80 | - | 50 | - | 30 | - | ns |
| 23 | Clock Low to Data Out Valid (Write) | tcloo |  | - | 70 | - | 55 | - | 55 | ns |
| $25^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data Out Invalid (Write) | TSHDOI |  | 30 | - | 20 | - | 15 | - | ns |
| $26^{2}$ | Data Out Valid to $\overline{\mathrm{DS}}$ Low (Write) | $\mathrm{t}_{\text {DOSL }}$ |  | 30 | - | 20 | - | 15 | - | ns |
| $27^{5}$ | Data In to Clock Low (Setup Time on Read) | $\mathrm{t}_{\text {DICL }}$ |  | 15 | - | 10 | - | 10 | - | ns |
| $28^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{DTACK}}$ High | ${ }_{\text {tSHDAH }}$ |  | 0 | 245 | 0 | 190 | 0 | 150 | ns |
| 29 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data In Invalid (Hold Time on Read) | tSHDII |  | 0 | - | 0 | - | 0 | - | ns |
| 30 | $\overline{\text { AS, }} \overline{\text { DS }}$ High to $\overline{\text { BERR }}$ High | ${ }^{\text {t SHBEH }}$ |  | 0 | - | 0 | - | 0 | - | ns |
| $31^{2,5}$ | $\overline{\text { DTACK }}$ Low to Data In (Setup Time) | tDALDI |  | - | 90 | - | 65 | - | 50 | ns |
| 32 | HALT and $\overline{\text { RESET }}$ Input Transition Time | $\mathrm{t}_{\text {RHr, }} \mathrm{f}$ |  | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| 33 | Clock High to $\overline{\mathrm{BG}}$ Low | teHGL |  | - | 70 | - | 60 | - | 50 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | ${ }^{\text {t }} \mathrm{CHGH}$ |  | - | 70 | - | 60 | - | 50 | ns |
| 35 | $\overline{\mathrm{BR}}$ Low to $\overline{\mathrm{BG}}$ Low | $t_{\text {trelgl }}$ |  | 1.5 | $\begin{array}{\|c\|} \hline 90 \\ \mathrm{~ns} \\ +3.5 \end{array}$ | 1.5 | $\begin{array}{r} \hline 80 \\ \mathrm{~ns} \\ +3.5 \end{array}$ | 1.5 | $\begin{array}{\|c\|} \hline 70 \\ \mathrm{~ns} \\ +3.5 \end{array}$ | CIk. Per. |

## HD68000/HD68HC000

READ AND WRITE CYCLES (CONTINUED)

| Num. | Item | Symbol | Test Condition | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | max | min | max | min | max |  |
| $36^{7}$ | $\overline{\mathrm{BR}}$ High to $\overline{\mathrm{BG}}$ High | $\mathrm{t}_{\text {BRHGH }}$ | Fig. 3, Fig. 4 | 1.5 | $\begin{gathered} 90 \mathrm{~ns} \\ +3.5 \end{gathered}$ | 1.5 | $\begin{aligned} & \hline 80 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | 1.5 | $\begin{array}{r} 70 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | Clk.Per. |
| 37 | $\overline{\text { BGACK }}$ Low to $\overline{\text { BG }}$ High | tGALGH |  | 1.5 | $\begin{gathered} 90 \mathrm{~ns} \\ +3.5 \end{gathered}$ | 1.5 | $\begin{gathered} \hline 80 \mathrm{~ns} \\ +3.5 \end{gathered}$ | 1.5 | $\begin{aligned} & 70 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | Clk.Per. |
| $37 A^{8}$ | $\overline{\text { BGACK }}$ Low to $\overline{B R}$ High | $\mathrm{t}_{\text {GALBrH }}$ |  | 20 | $\begin{gathered} 1.5 \\ \text { Clocks } \end{gathered}$ | 20 | $\begin{array}{\|c\|} \hline 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | 20 | $\begin{gathered} 1.5 \\ \text { Clocks } \end{gathered}$ | ns |
| 38 | $\overline{\mathrm{BG}}$ Low to Control, Address, Data Bus High Impedance ( $\overline{\text { AS }}$ High) | tGLZ |  | - | 80 | - | 70 | - | 60 | ns |
| 39 | $\overline{\text { BG Width High }}$ | $\mathrm{t}_{\mathrm{GH}}$ |  | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| 40 | Clock Low to $\overline{\text { VMA }}$ Low | tCLVML |  | - | 70 | - | 70 | - | 70 | ns |
| 41 | Clock Low to E Transition | $\mathrm{t}_{\text {CLET }}$ |  | - | 70 | - | 55 | - | 45 | ns |
| 42 | E Output Rise and Fall Time | $\mathrm{t}_{\mathrm{Er}, \mathrm{f}} \mathrm{f}$ |  | - | 25 | - | 25 | - | 25 | ns |
| 43 | VMA Low to E High | tVMLEH |  | 200 | - | 150 | - | 90 | - | ns |
| 44 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{VPA}}$ High | TSHVPH |  | 0 | 120 | 0 | 90 | 0 | 70 | ns |
| 45 | E Low to Control, Address Bus Invalid (Address Hold Time) | telcal |  | 30 | - | 10 | - | 10 | - | ns |
| 46 | BGACK Width Low | tGAL |  | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| $47^{5}$ | Asynchronous Input Setup Time | $\mathrm{taSI}^{\text {a }}$ |  | 20 | - | 20 | - | 20 | - | ns |
| $48^{3}$ | $\overline{\text { BERR }}$ Low to DTACK Low | tBELDAL |  | 20 | - | 20 | - | 20 | - | ns |
| $49^{9}$ | $\overline{A S}, \overline{\text { DS }}$ High to E Low | tSHEL |  | -70 | 70 | -55 | 55 | -45 | 45 | ns |
| 50 | E Width High | teh |  | 450 | - | 350 | - | 280 | - | ns |
| 51 | E Width Low | tel |  | 700 | - | 550 | - | 440 | - | ns |
| 53 | Clock High to Data Out Invalid | $\mathrm{t}_{\text {CHDOI }}$ |  | 0 | - | 0 | - | 0 | - | ns |
| 54 | E Low to Data Out Invalid | teldoi |  | 30 | - | 20 | - | 15 | - | ns |
| 55 | R/W to Data Bus Driven | trldbi |  | 30 | - | 20 | - | 10 | - | ns |
| $56^{4}$ | $\overline{\text { HALT } / \overline{R E S E T} \text { Pulse Width }}$ | threw |  | 10 | - | 10 | - | 10 | - | Clk.Per. |
| 57 | $\overline{\text { BGACK }}$ High to Control Bus Driven | tGABD |  | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| $58^{7}$ | $\overline{\text { BG }}$ High to Control Bus Driven | $\mathrm{t}_{\text {GHBD }}$ |  | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |

NOTES:
. For a loading capacitance of less than or equal to $\mathbf{5 0}$ picofarads, substract $\mathbf{5}$ nanoseconds from the value given in the maximum columns. Actual value depends on clock period.
If \#47 is satisfied for both $\overline{D T A C K}$ and $\overline{B E R R}, \# 48$ may be 0 nanoseconds.
. For power up, the MPU must be held in $\overline{\operatorname{RES}}$ state for 100 ms to allow stabilization of on-chip circuitry. After the system is powered up, \#56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (\#47) requirements are satisfied, the DTACK low-to-data setup time (\#31) requirement can be ignored. The data must only satisfy the date-in clock-low setup time (\#27) for the following cycle.
6. When $\overline{A S}$ and $R / \bar{W}$ are equally loaded ( $\pm 20 \%$ ), subtract 10 nanoseconds from the values given in these columns.
7. The processor will negate $\overline{\mathbf{B G}}$ and begin driving the bus again if external arbitration logic negates $\overline{B R}$ before asserting $\overline{B G A C R}$.
8. The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, $\overline{B G}$ may be reasserted.
9. The falling edge of $\mathbf{S 6}$ triggers both the negation of the strobes ( $\overline{\mathrm{AS}}$ and $\overline{\mathrm{DS}}$ ) and the falling edge of E . Either of these events can occur first, depending upon the loading on each signal. Specification \#49 indicates the absolute maximum skew that will occur between the rising edge of the strobes and the falling edge of the E clock.

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and
output signals. Refer to other functional descriptions and their related diagrams for device operation.


NOTES:

1. Setup time for the synchronous inputs $\overline{\mathrm{BGACK}}, \overline{\mathrm{PL}_{0-2}}$ and $\overline{\mathrm{VPA}}$ guarantees their recognition at the next falling edge of the clock.
2. $\overline{B R}$ need fall at this time only in order to insure being recognized at the end of this bus cycle.
3. Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage 2.0 volts, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts.

Figure 3. Read Cycle Timing

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output
signals. Refer to other functional descriptions and their related diagrams for device operation.


NOTES:

1. Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts.
2. Because of loading variations, $R / \bar{W}$ may be valid after $\overline{A S}$ even though both are initiated by the rising edge of $\mathbf{S 2}$ (Specification $20 A$ ).

Figure 4. Write Cycle Timing

## - HMCS6800 TIMING

| Num. | Item | Symbol | TestCondition | 6 MHz |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | max | min | max | min | max | min | max |  |
| 12 | Clock Low to $\overline{\text { AS, }} \overline{\text { DS }}$ High | tclsh | Fig. 5, <br> Fig. 6 | - | 80 | - | 70 | - | 55 | - | 50 | ns |
| 18 | Clock High to R/W High | ${ }^{\text {t }}$ CHRH |  | 0 | 80 | 0 | 70 | 0 | 60 | 0 | 60 | ns |
| 20 | Clock High to R/W Low (Write) | ${ }^{\text {t }}$ CHRL |  | - | 80 | - | 70 | - | 60 | - | 60 | ns |
| 23 | Clock Low to Data Out Valid (Write) | teldo |  | - | 80 | - | 70 | - | 55 | -- | 55 | ns |
| 27 | Data In to Clock Low (Setup Time on Read) | ${ }^{\text {t }}$ DCL |  | 25 | - | 15 | - | 10 | - | 10 | - | ns |
| 29 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data In Invalid (Hold Time on Read) | tSHDII |  | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 40 | Clock Low to VMA Low | tCLVML |  | - | 80 | - | 70 | - | 70 | - | 70 | ns |
| 41 | Clock Low to E Transition | tCLET |  | - | 35 | - | 70 | - | 55 | - | 45 | ns |
| 42 | E Output Rise and Fall Time | tEr, $f$ |  | - | 25 | - | 25 | - | 25 | - | 25 | ns |
| 43 | VMA Low to E High | tVMLEH |  | 240 | - | 200 | - | 150 | - | 90 | - | ns |
| 44 | $\overline{\text { AS, }} \overline{\text { DS }}$ High to $\overline{\text { VPA }}$ High | SSHVPH |  | 0 | 160 | 0 | 120 | 0 | 90 | 0 | 70 | ns |
| 45 | E Low to Control, Address Bus Invalid (Address Hold Time) | telcal |  | 35 | - | 30 | - | 10 | - | 10 | - | ns |
| 47 | Asynchronous Input Setup Time | $t_{\text {ASI }}$ |  | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| $49^{1}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to E Low | tSHEL |  | -80 | - | -70 | 70 | -55 | 55 | -45 | 45 | ns |
| 50 | E Width High | teh |  | 600 | - | 450 | - | 350 | - | 280 | - | ns |
| 51 | E Width Low | tel |  | 900 | - | 700 | - | 550 | - | 440 | - | ns |
| 54 | E Low to Data Out Invalid | teldoi |  | 40 | - | 30 | - | 20 | - | 15 | - | ns |

NOTE:

1. The falling edge of $\mathbf{S 6}$ triggers both the negation of the strobes ( $\overline{\mathrm{AS}}$ and $\times \overline{\mathrm{DS}}$ ) and the falling edge of E . Either of these events can occur first, depending upon the loading on each signal. Specification \#49 indicates the absolute maximum skew that will occur between the rising edge of the strobes and the falling edge of the E clock.


NOTE: This timing diagram is included for those who wish to design their own circuit to generate $\overline{\mathrm{VMA}}$. It shows the best case possibly attainable.
Figure 5. HD6800 Timing-Best Case


NOTE: This timing diagram is included for those who wish to design their own circuit to generate $\overline{\mathrm{VMA}}$. It shows the worst case possibly attainable.
Figure 6. HD6800 Timing-Worst Case

## BUS ARBITRATION

|  | Item | Symbol | Test Condition | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | min | max | min | max | min | max |  |
| 7 | Clock High to Address, Data Bus High Impedance | ${ }^{\text {t CHADZ }}$ | Fig. $7 \sim$ Fig. 9 | - | 80 | - | 70 | - | 60 | ns |
| 16 | Clock High to Control Bus High Impedance | tCHCZ |  | - | 80 | - | 70 | - | 60 | ns |
| 33 | Clock High to $\overline{\mathrm{BG}}$ Low | tengl |  | - | 70 | - | 60 | - | 50 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | tCHGH |  | - | 70 | - | 60 | - | 50 | ns |
| 35 | $\overline{B R}$ Low to $\overline{B G}$ Low | tBrLGL |  | 1.5 | $\begin{gathered} 90 \mathrm{~ns} \\ +3.5 \end{gathered}$ | 1.5 | $\begin{gathered} \hline 80 \mathrm{~ns} \\ +3.5 \end{gathered}$ | 1.5 | $\begin{aligned} & 70 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | Clk.Per. |
| 361 | $\overline{B R}$ High to $\overline{B G}$ High | $\mathrm{t}_{\text {BRHGH }}$ |  | 1.5 | $\begin{gathered} 90 \mathrm{~ns} \\ +3.5 \\ \hline \end{gathered}$ | 1.5 | $\begin{aligned} & 80 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | 1.5 | $\begin{gathered} 70 \mathrm{~ns} \\ +3.5 \end{gathered}$ | Clk.Per. |
| 37 | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BG}}$ High | tGALGH |  | 1.5 | $\begin{aligned} & 90 \mathrm{~ns} \\ & +3.5 \\ & \hline \end{aligned}$ | 1.5 | $\begin{array}{\|l\|} \hline 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|r\|} \hline 70 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | Clk.Per. |
| 37A ${ }^{2}$ | BGACK Low to $\overline{\text { BR }}$ High | tGALBRH |  | 20 | $\begin{array}{\|c\|} \hline 1.5 \\ \text { Clocks } \end{array}$ | 20 | $\begin{array}{\|c\|} \hline 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | 20 | $\begin{array}{\|c\|} \hline 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | ns |
| 38 | BG Low to Control, Address, Data Bus High Impedance ( $\overline{\mathrm{AS}} \mathrm{High}$ ) | $\mathrm{t}_{\text {GLZ }}$ |  | - | 80 | - | 70 | - | 60 | ns |
| 39 | $\overline{\text { BG Width High }}$ | $\mathrm{t}_{\mathrm{GH}}$ |  | 1.5 | - | 1.5 | - | 1.5 | - | Cak.Per. |
| 46 | $\overline{\text { BGACK }}$ Width Low | tGAL |  | 1.5 | - | 1.5 | - | 1.5 | - | Clik.Per. |
| 47 | Asynchronous Input Setup Time | ${ }_{\text {tasi }}$ |  | 20 | - | 20 | - | 20 | - | ns |
| 57 | $\overline{\text { BGACK }}$ High to Control Bus Driven | tGABD |  | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| $58^{1}$ | $\overline{\text { BG }}$ High to Control Bus Driven | tGHBD |  | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |

NOTES:

1. The processor will negate $\overline{\mathrm{BG}}$ and begin driving the bus again if external arbitration logic negates $\overline{\mathrm{BR}}$ before asserting $\overline{\mathrm{BGACK}}$.
2. The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, $\overline{B G}$ may be reasserted.

Figures 7, 8, and 9 depict the three bus arbitration cases that can arise. Figure 7 shows the timing where $\overline{\mathrm{AS}}$ is negated when the processor asserts $B G$ (Idle Bus Case). Figure 8 shows the timing where $\overline{\mathrm{AS}}$ is asserted when the processor asserts $\overline{\mathrm{BG}}$ (Active Bus Case). Figure 9 shows the timing where more than one bus master are requesting the bus. Refer to Bus Arbitration for a complete discussion of bus arbitration.

The waveforms shown in Figures 7, 8, and 9 should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation.


Figure 7. Bus Arbitration Timing Diagram - Idle Bus Case


Figure 8. Bus Arbitration Timing Diagram - Active Bus Case


Figure 9. Bus Arbitration Timing Diagram - Multiple Bus Requests

## - INTRODUCTION

As shown in the programming model, the 68000 offers seventeen 32 -bit registers in addition to the 32 -bit program counter and a 16 -bit status register. The first eight registers (D0 ~ D7) are used as data registers for byte (8-bit), word (16-bit), and long word (32-bit) data operations. The second set of seven registers ( $\mathrm{A} 0 \sim \mathrm{~A} 6$ ) and the system stack pointer may be used as software stack pointers and base address registers. In addition, these registers may be used for word and long word address operations. All 17 registers may be used as index registers.

The status register contains the interrupt mask (eight levels available) as well as the condition codes; extend (X), negative (N), zero (Z), overflow (V), and carry (C). Additional status bits indicate that the processor is in a trace ( T ) mode and/or in a supervisor (S) state.

## Status Register



Unused, read as zero.

## - DATA TYPES AND ADDRESSING MODES

Five basic data types are supported. These data types are:
(1) Bits
(2) BCD Digits (4 bits)
(3) Bytes (8 bits)
(4) Word (16 bits)
(5) Long Words ( 32 bits)

In addition, operations on other data types such as memory address, status word data, etc., are provided for in the instruction set.

The 14 addressing modes, shown in Table 1, includes six basic types:
(1) Register Direct
(2) Register Indirect
(3) Absolute
(4) Immediate
(5) Program Counter Relative
(6) Implied

Included in the register indirect addressing modes is the capability to do postincrementing, predecrementing, offsetting and indexing. Program counter relative mode can also be modified via indexing and offsetting.


Table 1 Addressing Modes

| Mode | Generation |
| :---: | :---: |
| Register Direct Addressing Data Regišter Diredt Address Register Direct | $\begin{aligned} & E A=D n \\ & E A=A n \end{aligned}$ |
| Absolute Data Addressing <br> Absolute Short <br> Absolute Long | $E A=($ Next Word $)$ $E A=($ Next Two Words) |
| Program Counter Relative Addressing <br> Relative with Offset <br> Relative with Index and Offset | $\begin{aligned} & E A=(P C)+d_{16} \\ & E A=(P C)+\left(X_{n}\right)+d_{8} \end{aligned}$ |
| Register Indirect Addressing <br> Register Indirect <br> Postincrement Register Indirect <br> Predecrement Register Indirect <br> Register Indirect with Offset <br> Indexed Register Indirect with Offset | $\begin{aligned} & E A=(A n) \\ & E A=(A N), A n \leftarrow A n+N \\ & A n \leftarrow A n-N, E A=(A n) \\ & E A=(A n)+d_{16} \\ & E A=(A n)+(X n)+d_{8} \end{aligned}$ |
| Immediate Data Addressing Immediate Quick Immediate | DATA $=$ Next Word(s) <br> Inherent Data |
| Implied Addressing Implied Register | $E A=S R, U S P, S P, P C$ |

(NOTES)

| $E A=$ Effective Address | $d_{16}=$ | Sixteen-bit Offset |
| :--- | ---: | :--- |
| (displacement) |  |  |

An = Address Register (displacement)
Dn = Data Register
Xn $=$ Address or Data Register used
$N=1$ for Byte, 2 for Words and 4 for Long Words. If An is the stack pointer and the operand size is byte, $N=2$ to keep the stack pointer on a word boundary.
$\leftarrow=$ Replaces
as Index Register

SR $=$ Status Register
PC = Program Counter
( ) = Contents of
$d_{8}=$ Eight-bit Offset (displacement)

## - INSTRUCTION SET OVERVIEW

The 68000 instruction set is shown in Table 2. Some additional instructions are variations, or subsets, of these and they appear in Table 3. Special emphasis has been given to the instruction set's support of structured high-level languages to facilitate ease of programming. Each instruction, with few exceptions, operates on bytes, words, and long words and most
instructions can use any of the 14 addressing modes. Combining instruction types, data types, and addressing modes, over 1000 useful instructions are provided. These instructions include signed and unsigned multiply and divide, "quick" arithmetic operations, BCD arithmetic and expanded operations (through traps).

Table 2 Instruction Set

| Mnemonic | Description | Mnemonic | Description | Mnemonic | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ABCD | Add Decimal with Extend <br> Add <br> Logical And <br> Arithmetic Shift Left <br> Arithmetic Shift Right | EOR | Exclusive Or <br> Exchange Registers <br> Sign Extend | PEA | Push Effective Address |
| ADD |  | EXG |  | RESET | Reset External Devices <br> Rotate Left without Extend <br> Rotate Right without Extend <br> Rotate Left with Extend |
| AND |  | EXT |  | ROL |  |
| ASL |  | JMP | Jump <br> Jump to Subroutine | ROR |  |
| ASR |  | JSR |  | ROXL |  |
| ${ }^{B}$ cc BCHG | Branch Conditionally <br> Bit Test and Change <br> Bit Test and Clear <br> Branch Always <br> Bit Test and Set <br> Branch to Subroutine <br> Bit Test | LEA |  | ROXR | Rotate Right with Extend Return from Exception |
|  |  | LINK |  | RTE |  |
| BCLR |  | LSL | Link Stack <br> Logical Shift Left |  | Return and Restore Return from Subroutine |
| BRA |  | LSR | Logical Shift Left <br> Logical Shift Right |  |  |
| BSET |  | MOVE | Move <br> Move Multiple Registers <br> Move Peripheral Data <br> Signed Multiply <br> Unsigned Multiply |  |  |
| BSR BTST |  | MOVEM |  | $\mathbf{S}_{\mathbf{C C}}$ STOP | Set Conditional |
| BTST |  | MOVEP |  |  | Stop |
| CHK | Check Register Against Bounds | MULS |  | SUB | Subtract |
| CLRCMP | Clear Operand | MULU |  | SWAP | Swap Data Register Halves |
|  | Compare | NBCD NEG | Negate Decimal with Extend Negate | TAS | Test and Set Operand |
| DBCC |  |  |  | TRAPTRAPV | Trap |
|  | Test Condition, Decrement and Branch | NOP | No Operation |  | Trap on Overflow |
| DIVS | Signed Divide Unsigned Divide | NOT | One's Complement | TST | Test |
| DIVU |  | OR | Logical Or | UNLK | Unlink |

Table 3 Variations of Instruction Types

| Instruction Type | Variation | Description | Instruction Type | Variation | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | ADD <br> ADDA <br> ADDO <br> ADDI <br> ADDX | Add <br> Add Address <br> Add Quick <br> Add Immediate <br> Add with Extend | MOVE | MOVE <br> MOVEA <br> MOVEQ <br> MOVE from SR <br> MOVE to SR | Move <br> Move Address <br> Move Quick <br> Move from Status Register <br> Move to Status Register |
| AND | AND <br> ANDI <br> ANDI to CCR <br> ANDI to SR | Logical And And Immediate And Immediate to Condition Codes And Immediate to Status Register |  |  | Move to Condition Codes Move User Stack Pointer |
|  |  |  | NEG | NEG <br> NEGX | Negate <br> Negate with Extend |
|  |  |  | OR | OR ORI | Logical Or Or Immediate |
| CMP | CMP <br> CMPA <br> CMPM <br> CMPI | Compare <br> Compare Address <br> Compare Memory <br> Compare Immediate |  | ORI to CCR ORI to SR | Or Immediate to Condition Codes Or Immediate to Status Register |
| EOR | EOR <br> EORI <br> EORI to CCR <br> EORI to SR | Exclusive Or <br> Exclusive Or Immediate Exclusive Or Immediate to Condition Codes Exclusive Or Immediate to Status Register | SUB | SUB <br> SUBA <br> SUBI <br> SUBO <br> SUBX | Subtract <br> Subtract Address <br> Subtract Immediate <br> Subtract Quick <br> Subtract with Extend |

## - REGISTER DESCRIPTION AND DATA ORGANIZATION

The following paragraphs describe the registers and data organization of the 68000 .

## - OPERAND SIZE

Operand sizes are defined as follows: a byte equals 8 bits, a word equals 16 bits, and a long word equals 32 bits. The operand size for each instruction is either explicitly encoded in the instruction or implicitly defined by the instruction operation. Implict instructions support some subset of all three sizes.

## - DATA ORGANIZATION IN REGISTERS

The eight data registers support data operands of $1,8,16$, or 32 bits. The seven address registers together with the active stack pointer support address operands of 32 bits.

## DATA REGISTERS

Each data register is 32 bits wide. Byte operands occupy the low order 8 bits, word operands the low order 16 bits, and long word operands the entire 32 bits. The least significant bit is addressed as bit zero; the most significant bit is addressed as bit 31 .

When a data register is used as either a source or destination operand, only the appropriate low-order portion is changed; the remaining high-order portion is neither used nor changed.

## ADDRESS REGISTERS

Each address register and the stack pointer is 32 bits wide and holds a full 32 bit address. Address registers do not support byte sized operands. Therefore, when an address register is used as a source operand, either the low order word or the entire long word operand is used depending upon the operation size. When an address register is used as the destination operand, the entire register is affected regardless of the operation size. If the operation size is word, any other operands are sign extended to 32 bits before the operation is performed.

## - DATA ORGANIZATION IN MEMORY

Bytes are individually addressable with the high order byte having an even address the same as the word, as shown in Figure 10. The low order byte has an odd address that is one count higher than the word address. Instructions and multibyte data are accessed only on word (even byte) boundaries. If a long word datum is located at address $n$ ( $n$ even), then the second word of that datum is located at address $n+2$.

The data types supported by the 68000 are: bit data, integer data of 8,16 , or 32 bits, 32 -bit addresses and binary coded decimal data. Each of these data types is put in memory, as shown in Figure 11. The numbers indicate the order in which the data would be accessed from the processor.


Figure 10 Word Organization in Memory


## - ADDRESSING

Instructions for the 68000 contain two kinds of information: the type of function to be performed, and the location of the operand(s) on which to perform that function. The methods used to locate (address) the operand(s) are explained in the following paragraphs.

Instructions specify an operand location in one of three ways:

Register Specification - the number of the register is given in the register field of the instruction.
Effective Address - use of the different effective address modes.
Implicit Reference - the definition of certain instructions implies the use of specific registers.

## - INSTRUCTION FORMAT

Instructions are from one to five words in length, as shown in Figure 12. The length of the instruction and the operation to be performed is specified by the first word of the instruction which is called the operation word. The remaining words further specify the operands. These words are either immediate operands or extensions to the effective address mode specified in the operation word.

## - PROGRAM/DATA REFERENCES

The 68000 separates memory references into two classes: program references, and data references. Program references, as the name implies, are references to that section of memory that
contains the program being executed. Data references refer to that section of memory that contains data. Operand reads are from the data space except in the case of the program counter relative addressing mode. All operand writes are to the data space.

## - REGISTER SPECIFICATION

The register field within an instruction specifies the register to be used. Other fields within the instruction specify whether the register selected is an address or data register and how the register is to be used.

## - EFFECTIVE ADDRESS

Most instructions specify the location of an operand by using the effective address field in the operation word. For example, Figure 13 shows the general format of the single effective address instruction operation word. The effective address is composed of two 3-bit fields: the mode field, and the register field. The value in the mode field selects the different address modes. The register field contains the number of a register.

The effective address field may require additional information to fully specify the operand. This additional information, called the effective address extension, is contained in the following word or words and is considered part of the instruction, as shown in Figure 12. The effective address modes are grouped into three categories: register direct, memory addressing, and special.


Figure 12 Instruction Format


Figure 13 Single-Effective-Address Instruction Operation Word General Format

## REGISTER DIRECT MODES

These effective addressing modes specify that the operand is in one of the 16 multifunction registers.

## Data Register Direct

The operand is in the data register specified by the effective address register field.

## EXAMPLE

MPU


MOVE D0, \$1F00

MEMORY
COMMENTS

- $E A=D n$


## - Machine Level Coding

MOVE DO, \$1F00


Address Register Direct
The operand is in the address register specified by the effective address register field.


COMMENTS

- $E A=A n$
- Machine Level Coding

MOVE A4, \$201000



COMMENTS

- $E A=A n$
- Address Register Sign Extended
- Machine Level Coding

MOVE \$201000, A4


## MEMORY ADDRESS MODES

These effective addressing modes specify that the operand is in memory and provide the specific address of the operand.

## Address Register Indirect

The address of the operand is in the address register specified by the register field. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.


## Address Register Indirect With Postincrement

The address of the operand is in the address register specified by the register field. After the operand address is used, it is incremented by one, two, or four depending upon whether the size of the operand is byte, word, or long word. If the
address register is the stack pointer and the operand size is byte, the address is incremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.


## Address Register Indirect With Predecrement

The address of the operand is in the address register specified by the register field. Before the operand address is used, it is decremented by one, two, or four depending upon whether the operand size is byte, word, or long word. If the address
register is the stack pointer and the operand size is byte, the address is decremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.


## (0) HITACHI

## Address Register Indirect With Displacement

This address mode requires one word of extension. The address of the operand is the sum of the address in the address
register and the sign-extended 16 -bit displacement integer in the extension word. The reference is classified as a data reference with the exception of the jump to subroutine instructions.


## Address Register Indirect With Index

This address mode requires one word of extension. The address of the operand is the sum of the address in the address register, the signextended displacement integer in the low order
eight bits of the extension word, and the contents of the index register. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

EXAMPLE
MPU


MOVE \$04(AO, D0), $\$ 1000$

ADDRESS
CALCULATION:
$A O=00002000$
$D 0=00002 B D C$ $d=00000004$

00004BEO

MEMORY


COMMENTS

- $E A=A n+R x+d_{H}$

Where
An $\longrightarrow$ Pointer Register
$R x \rightarrow$ Designated Index Register, (Either Address Register or Data Register)
$\mathrm{d}_{\mathrm{s}} \longrightarrow$ 8-Bit Displacement

- $R \times \&_{d} d_{s}$ are Sign Extended
- Rx may be Word or Long Word

Long Word may be Designated with Rx.L.

- Machine Level Coding

MOVE \$04(AO, DO), \$1000


## Absolute Short Address

This address mode requires one word of extension. The address of the operand is the extension word. The 16 -bit address is sign extended before it is used. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

## SPECIAL ADDRESS MODE

The special address modes use the effective address register field to specify the special addressing mode instead of a register number.

## EXAMPLE

MPU


NOT.L \$2000

## EXAMPLE

## MPU



MOVE \$1000, \$2000

MEMORY


COMMENTS

- EA = (Next Word)
- 16-Bit Word is Sign Extended
- Machine Level Coding

NOT.L \$2000


COMMENTS

- EA = (Next Word)
- 16-Bit Word is Sign Extended
- Machine Level Coing

MOVE \$1000, \$2000


## Absolute Long Address

This address mode requires two words of extension. The address of the operand is developed by the concatenation of the extension words. The high-order part of the address is the
first extension word; the low-order part of the address is the second extension word. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

EXAMPLE
MPU

NEG $\$ 014000$


COMMENTS

- EA = (Next Two Words)

MEMORY


- Machine Level Coding

NEG $\$ 014000$


## Program Counter With Displacement

This address mode requires one word of extension. The address of the operand is the sum of the address in the program counter and the sign-extended 16 -bit displacement integer in
the extension word. The value in the program counter is the address of the extension word. The reference is classified as a program reference.


## Program Counter With Index

This address mode requires one word of extension. This address is the sum of the address in the program counter, the sign-extended displacement integer in the lower eight bits of the extension word, and the contents of the index register. The value in the program counter is the address of the extension word. This reference is classified as a program reference.
$E A=(P C)+(R x)+d_{x}$


## (NOTE)

## Extension Word

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $D / A$ | Register | $W / L$ | 0 | 0 | 0 |  | Displacement Integer |  |  |  |  |  |  |  |  |

D/A : Data Register $=0$, Address Register $=1$
Register: Index Register Number
W/L : Sign extented, low order Word integer in Index Register = 0
Long Word in Index Register = 1


## Immediate Data

This address mode requires either one or two words of extension depending on the size of the operation.

Byte operation - operand is low order byte of extension word
Word operation - operand is extension word
Long word operation - operand is in the two extension words, high-order 16 bits are in the first extension word, low-order 16 bits are in the second extension word.

Extension Word



COMMENTS

- Data $=$ Next Word(s)
- Data is Sign Extended for Address Register but not Data Register
- Machine Level Coding

MOVE \#\$1000, A0


COMMENTS

- Inherent Data
- Data is Sign Extended to Long Word
- Destination must be a Data Register
- Machine Level Coding

MOVEQ \#\$5A, D3


## Condition Codes or Status Register

A selected set of instructions may reference the status register by means of the effective address field. These are:
ANDI to CCR
ANDI to SR
EORI to CCR
EORI to SR
ORI to CCR
ORI to SR
MOVE to CCR
MOVE to SR
MOVE from SR

## COMMENTS

- EA = (Next Word)
- Note: This Example is a Privileged Instruction
- Machine Level Coding

MOVE \$1020, SR


- EFFECTIVE ADDRESS ENCODING SUMMARY

Table 4 is a summary of the effective addressing modes discussed in the previous paragraphs.

Table 4 Effective Address Encoding Summary

| Addressing Mode | Mode | Register |
| :--- | :---: | :---: |
| Data Register Direct | 000 | register number |
| Address Register Direct | 001 | register number |
| Address Register Indirect | 010 | register number |
| Address Register Indirect with <br> Postincrement | 011 | register number |
| Address Register Indirect with <br> Predecrement | 100 | register number |
| Address Register Indirect with <br> Displacement | 101 | register number |
| Address Register Indirect with <br> Index | 110 | register number |
| Absolute Short | 111 | 000 |
| Absolute Long | 111 | 001 |
| Program Counter with |  |  |
| Displacement |  |  |

## - IMPLICIT REFERENCE

Some instructions make implicit reference to the program counter (PC), the system stack pointer (SP), the supervisor
stack pointer (SSP), the user stack pointer (USP), or the status register (SR).

## SYSTEM STACK

The system stack is used implicitly by many instructions; user stacks and queues may be created and maintained through the addressing modes. Address register seven (A7) is the system stack pointer (SP). The system stack pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), depending on the state of the $S$-bit in the status register. If the S-bit indicates supervisor state, SSP is the active system stack pointer, and the USP cannot be referenced as an address register. If the $S$-bit indicates user state, the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory.

SYSTEM STACK POINTERS


The address mode SP@ - creates a new item on the active system stack, and the address mode SP @ + deletes an item from the active system stack.

The program counter is saved on the active system stack on subroutine calls, and restored from the active system stack on returns. On the other hand, both the program counter and the status register are saved on the supervisor stack during the processing of traps and interrupts. Thus, the correct execution of the supervisor state code is not dependent on the behavior of user code and user programs may use the user stack pointer arbitrarily.

In order to keep data on the system stack aligned properly, data entry on the stack is restricted so that data is always put in the stack on a word boundary. Thus byte data is pushed on or pulled from the system stack in the high order half of the word; the lower half is unchanged.

## USER STACKS

User stacks can be implemented and manipulated by employing the address register indirect with postincrement and predecrement addressing modes. Using an address register (on of A0 through A6), the user may implement stacks which are filled either from high memory to low memory, or vice versa. The important things to remember are:

- using predecrement, the register is decremented before its contents are used as the pointer into the stack,
- using postincrement, the register is incremented after its contents are used as the pointer into the stack,
- byte data must be put on the stack in pairs when mixed with word or long data so that the stack will not get misaligned when the data is retrieved. Word and long accesses must be on word boundary (even) addresses.
Stack growth from high to low memory is implemented with An@- to push data on the stack, An@+ to pull data from the stack.
After eigher a push or a pull operation, register An points to the last (top) item on the stack. This is illustrated as:


Stack growth from low to high memory is implemented with An@+ to push data on the stack,
An@- to pull data from the stack.
After either a push or a pull operation, register An points to the next available space on the stack. This is illustrated as:


## QUEUES

User queues can be implemented and manipulated with the address register indirect with postincrement or predecrement addressing modes. Using a pair of address registers (two of A0 through A6), the user may implement queues which are filled either from high memory to low memory, or vice versa. Because queues are pushed from one end and pulled from the other, two registers are used: the put and get pointers.

Queue growth from low to high memory is implemented with
Aput $(a)+$ to put data into the queue,
Aget $@+$ to get data from the queue.
After a put operation, the put address register points to the next available space in the queue and the unchanged get address register points to the next item to remove from the queue. After a get operation, the get address register points to the next item to remove from the queue and the unchanged put adders register points to the next available space in the queue. Thus is illustrated as:


If the queue is to be implemented as a circular buffer, the address register should be checked and, if necessary, adjusted before the put or get operation is performed. The address register is adjusted by subtracting the buffer length (in bytes).

Queue growth from high to low memory is implemented with
Aput@- to put data into the queue.
Aget@ - to get data from the queue.
After a put operation, the put address register points to the last item put in the queue, and the unchanged get address register points to the last item removed from the queue. After a get operation, the get address register points to the last item removed from the queue and the unchanged put address register points to the last item put in the queue. This is illustrated as:


If the queue is to be implemented as a circular buffer, the get or put operation should be performed first, and then the address register should be checked and, if necessary, adjusted. The address register is adjusted by adding the buffer length (in bytes).

## -INSTRUCTION SET SUMMARY

The following paragraphs contain an overview of the form and structure of the 68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

## Data Movement <br> Integer Arithmetic <br> Logical <br> Shift and Rotate <br> Bit Manipulation <br> Binary Coded Decimal <br> Program Control <br> System Control

The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development.

## - DATA MOVEMENT OPERATIONS

The basic method of data acquisition (transfer and storage) is provided by the move (MOVE) instruction. The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to memory, and register to register. Address move instructions allow word and long word operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (LEA), push effective address (PEA),
link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 5 is a summary of the data movement operations.

Table 5 Data Movement Operations

| Instruction | Operand Size | Operation |
| :--- | :---: | :--- |
| EXG | 32 | $\mathrm{Rx} \leftrightarrow \mathrm{Ry}$ |
| LEA | 32 | $\mathrm{EA} \rightarrow \mathrm{An}$ |
| LINK | - | $\mathrm{An} \rightarrow-(\mathrm{SP})$ <br> $(\mathrm{SP} \rightarrow \mathrm{An} ;$ <br> $\mathrm{SP}+\mathrm{d} \rightarrow \mathrm{SP}$ |
| MOVE | $8,16,32$ | $(\mathrm{EA}) \mathrm{s} \rightarrow \mathrm{EAd}$ |
| MOVEM | 16,32 | $(E A) \rightarrow A n, \mathrm{Dn}$ <br> $\mathrm{An}, \mathrm{Dn} \rightarrow \mathrm{EA}$ |
| MOVEP | 16,32 | $(\mathrm{EA}) \rightarrow \mathrm{Dn}$ <br> $\mathrm{Dn} \rightarrow \mathrm{EA}$ |
| MOVEQ | 8 | $\mathrm{\# xxx} \mathrm{\rightarrow Dn}$ |
| PEA | 32 | $\mathrm{EA} \mathrm{\rightarrow-(SP)}$ |
| SWAP | 32 | $\mathrm{Dn}[31: 16] \leftrightarrow \mathrm{Dn}[15: 0]$ |
| UNLK | - | $\mathrm{An} \rightarrow \mathrm{Sp} ;$ <br> $(\mathrm{SP})+\rightarrow \mathrm{An}$ |

(NOTES)

$$
s=\text { source }
$$

$d=$ destination
-()$=$ indirect with predecrement
[ ] = bit numbers

## - INTEGER ARITHMETIC OPERATIONS

The arithmetic operations include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, with data operations accepting all operand sizes. Address operations are limited to legal address size operands ( 16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long word product, and a long word dividend with word divisor to produce a word quotien with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 6 is a summary of the integer arithmetic operations.

Table 6 Integer Arithmetic Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| ADD | $\begin{gathered} \hline 8,16,32 \\ 16,32 \\ \hline \end{gathered}$ | $\begin{aligned} & D n+(E A) \rightarrow D n \\ & (E A)+D n \rightarrow E A \\ & (E A)+\# x \times x \rightarrow E A \\ & A N+(E A) \rightarrow A n \end{aligned}$ |
| ADDX | $\begin{gathered} 8,16,32 \\ 16,32 \\ \hline \end{gathered}$ | $\begin{aligned} & D x+D y+X \rightarrow D x \\ & -(A x)+-(A y)+X \rightarrow(A x) \\ & \hline \end{aligned}$ |
| CLR | 8, 16, 32 | $\begin{aligned} & (E A) \rightarrow M P U \\ & 0 \rightarrow E A \end{aligned}$ |
| CMP | $\begin{gathered} 8,16,32 \\ 16,32 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { Dn-(EA) } \\ & (E A)-\# x x x \\ & (A x)+-(A y)+ \\ & A n-(E A) \end{aligned}$ |
| DIVS | $32 \div 16$ | $D n \div(E A) \rightarrow$ Dn |
| DIVU | $32 \div 16$ | $D n \div(E A) \rightarrow D n$ |
| EXT | $\begin{aligned} & 8 \rightarrow 16 \\ & 16 \rightarrow 32 \end{aligned}$ | $\begin{aligned} & (D n)_{8} \rightarrow D n_{16} \\ & (D n)_{16} \rightarrow D n_{32} \end{aligned}$ |
| MULS | $16 \times 16 \rightarrow 32$ | Dn $\times(E A) \rightarrow$ Dn |
| MULU | $16 \times 16 \rightarrow 32$ | Dn $\times(E A) \rightarrow$ Dn |
| NEG | 8, 16, 32 | $0-(E A) \rightarrow E A$ |
| NEGX | 8, 16, 32 | O-(EA)-X-EA |
| SUB | $\begin{gathered} 8,16,32 \\ 16,32 \end{gathered}$ | $\begin{aligned} & D n-(E A) \rightarrow D n \\ & (E A)-D n \rightarrow E A \\ & (E A)-\# \times \times x \rightarrow E A \\ & A n-(E A) \rightarrow A n \end{aligned}$ |
| SUBX | 8, 16, 32 | $\begin{aligned} & D x-D y-X \rightarrow D x \\ & -(A x)--(A y)-x \rightarrow(A x) \end{aligned}$ |
| TAS | 8 | (EA) $-0,1 \rightarrow$ EA[7] |
| TST | 8, 16, 32 | (EA) -0 |

(NOTE) [ ] = bit number
-()$=$ indirect with predecrement
( ) $+=$ indirect with postincrement \# = immediate data

## - LOGICAL OPERATIONS

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 7 is a summary of the logical operations.

Table 7 Logical Operations

| Instruction | Operand Size | Operation |
| :--- | :---: | :--- |
| AND | $8,16,32$ | Dn^ $(E A) \rightarrow D n$ <br> $(E A) \wedge D n \rightarrow E A$ <br> $(E A) \wedge=x \times x \rightarrow E A$ |
| OR | $8,16,32$ | Dn $\vee(E A) \rightarrow \mathrm{Dn}$ <br> $(E A) \vee D n \rightarrow E A$ <br> $(E A) \vee=x \times x \rightarrow E A$ |
| EOR | $8,16,32$ | $(E A) \oplus D y \rightarrow E A$ <br> $(E A) \oplus \# x \times x \rightarrow E A$ |
| NOT | $8,16,32$ | $\sim(E A) \rightarrow E A$ |

$$
\text { [NOTE] } \begin{aligned}
\sim & =\text { invert } \\
v & =\text { logical } O R \\
\# & =\text { immediate data } \\
\hat{A} & =\text { logical AND }
\end{aligned}
$$

$\oplus=$ exclusive OR

## - SHIFT AND ROTATE OPERATIONS

Shift operations in both directions are provided by the arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All
shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand sizes and allow a shift count specified in the instruction of one to eight bits, or 0 to 63 specified in a data register.

Memory shifts and rotates are for word operands only and allow only single-bit shifts or rotates. Table 8 is a summary of the shift and rotate operations.

Table 8 Shift and Rotate Operations

| Instruction | Operand Size | Operation |
| :--- | :--- | :---: |
| ASL | $8,16,32$ | $X / C$ |
| ASR | $8,16,32$ |  |
| LSL | $8,16,32$ | $X / C$ |
| LSR | $8,16,32$ | 0 |
| ROL | $8,16,32$ | $C$ |
| ROR | $8,16,32$ |  |
| ROXL | $8,16,32$ | $C$ |
| ROXR | $8,16,32$ | $X$ |

## - BIT MANIPULATION OPERATIONS

Bit manipulation operations are accomplished using the following instructions: bit test (BTST), bit test and set (BSIT), bit test and clear (BCLR), and bit test and change (BCHC) Table 9 is a summary of the bit manipulation operations. (Bit 2 of the status register is Z .)

Table 9 Bit Manipulation Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| BTST | 8,32 | $\sim$ bit of (EA) $\rightarrow \mathbf{Z}$ |
| BSET | 8,32 | $\left(\begin{array}{l}\sim \text { bit of }(E A) \rightarrow Z ; \\ 1 \rightarrow \text { bit of EA }\end{array}\right.$ |
| BCLR | 8,32 | $\left(\begin{array}{l}\sim \text { bit of }(E A) \rightarrow Z ; \\ 0 \rightarrow \text { bit of EA }\end{array}\right.$ |
| BCHG | 8,32 | $\left(\begin{array}{l}\sim \text { bit of }(E A) \rightarrow Z ; \\ \sim \text { bit of }(E A) \rightarrow \text { bit of EA }\end{array}\right.$ |

(Note) $\sim=$ invert

## - BINARY CODED DECIMAL OPERATIONS

Multiprecision arithmetic operations on binary coded decimal numbers are accomplished using the following instructions: add decimal with extend ( $A B C D$ ), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 10 is a summary of the binary coded decimal operations.

Table 10 Binary Coded Decimal Operations

| Instruction | Operand Size | Operation |
| :--- | :---: | :---: |
| $A B C D$ | 8 | $D x_{10}+D y_{10}+X \rightarrow D x$ <br> $-(A x)_{10}+-(A y)_{10}+X \rightarrow(A x)$ |
| SBCD | 8 | $D x_{10}-D y_{10}-X \rightarrow D x$ <br> $-(A x)_{10}--(A y)_{10}-X \rightarrow(A x)$ |
| NBCD | 8 | $0-(E A)_{10}-X \rightarrow E A$ |

-()$=$ indirect with predecrement

## - PROGRAM CONTROL OPERATIONS

Program control operations are accomplished using a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 11.

The conditional instructions provide setting and branching for the following conditions:

| CC - carry clear | LS - low or same |
| :--- | :--- |
| CS - carry set | LT - less than |
| EQ - equal | MI - minus |
| F - never true | NE - not equal |
| GE - greater or equal | PL - plus |
| GT - greater than | T - always true |
| HI - high | VC - no overflow |
| LE - less or equal | VS - overflow |

Table 11 Program Control Operations

| Instruction | Operation |
| :--- | :--- |
| Conditional | Branch conditionally (14 conditions) <br> 8- and 16-bit displacement <br> Test condition, decrement, and branch <br> 16-bit displacement |
| Set byte conditionally (16 conditions) |  |

- SYSTEM CONTROL OPERATIONS

System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 12.

Table 12 System Control Operations

| Instruction | Operation |
| :--- | :--- |
| Privileged |  |
| RESET | Reset external devices |
| RTE | Return from exception |
| STOP | Stop program execution |
| ORI to SR | Logical OR to status register |
| MOVE USP | Move user stack pointer |
| ANDI to SR | Logical AND to status register |
| EORI to SR | Logical EOR to status register |
| MOVE EA to SR | Load new status register |
| Trap Generating |  |
| TRAP | Trap |
| TRAPV | Trap on overflow |
| CHK | Check register against bounds |
| Status Register |  |
| ANDI to CCR | Logical AND to condition codes |
| EORI to CCR | Logical EOR to condition codes |
| MOVE EA to CCR | Load new condition codes |
| ORI to CCR | Logical OR to condition codes |
| MOVE SR to EA | Store status register |

## BRANCH INSTRUCTION ADDRESSING

BRANCH INSTRUCTION FORMAT

|  | 15 |  |
| :--- | :--- | :--- |
|  | 15 |  |
| Operation Word |  |  |
| Extension Word | Operation Code | 8 bit Displacement |
|  | 16 bit Displacement if 8 bit Displacement $=0$ |  |

RELATIVE, FORWARD REFERENCE, 8-BIT OFFSET


RELATIVE, BACKWARD REFERENCE 8-BIT OFFSET


RELATIVE, FORWARD REFERENCE, 16-BIT OFFSET


## - SIGNAL AND BUS OPERATION DESCRIPTION

The following paragraphs contain a brief description of the input and output signals. A discussion of bus operation during the various machine cycles and operations is also given.
(NOTE) The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The term assert or assertion is used to indicate that a signal is active or true independent of whether that voltage is low or high. The term negate or negation is used to indicate that a signal is inactive or false.

## - SIGNAL DESCRIPTION

The input and output signals can be functionally organized into the groups shown in Figure 14. The following paragraphs provide a brief description of the signals and also a reference (if applicable) to other paragraphs that contain more detail about the function being performed.


Figure 14 Input and Output Signals

## ADDRESS BUS ( $A_{1}$ through $A_{23}$ )

This 23-bit, unidirectional, three-state bus is capable of addressing 8 megawords of data. It provides the address for bus operation during all cycles except interrupt cycles. During interrupt cycles, address lines $\mathbf{A}_{1}, \mathbf{A}_{\mathbf{2}}$, and $\mathbf{A}_{3}$. Provide information about what level interrupt is being serviced while address lines A4 through A23 are all set to a logic high.

## DATA BUS ( $\mathrm{D}_{0}$ through $\mathrm{D}_{15}$ )

This 16-bit, bidirectional, three-state bus is the general purpose data path. It can transfer and accept data in either word or byte length. During an interrupt acknowledge cycle, an external device supplies the vector number on data lines $\mathrm{D}_{0}$ through $\mathrm{D}_{7}$.

## ASYNCHRONOUS BUS CONTROL

Asynchronous data transfer are handled using the following control signals: address strobe, read/write, upper and lower data strobes, and data transfer acknowledge. These signals are explained in the following paragraphs.

## Address Strobe ( $\overline{\mathrm{AS}}$ )

This signal indicates that there is a valid address on the address bus.

## Read/Write (R/W)

This signal defines the data bus transfer as a read or write cycle. The $R / W$ signal also works in conjunction with the upper and lower data strobes as explained in the following paragraph.

## Upper and Lower Data Strobes ( $\overline{\text { UDS }}, \overline{\text { LDS }}$ )

These signals control the data on the data bus, as shown in Table 13. When the $R / \bar{W}$ line is high, the processor will read from the data bus as indicated. When the $R / \bar{W}$ line is low, the processor will write to the data bus as shown.

Table 13 Data Strobe Control of Data Bus

| $\overline{\text { UDS }}$ | $\overline{\mathrm{LDS}}$ | $\mathrm{R} / \overline{\mathrm{W}}$ | $\mathrm{D}_{8} \sim \mathrm{D}_{15}$ | $\mathrm{D}_{0} \sim \mathrm{D}_{7}$ |
| :---: | :---: | :---: | :---: | :---: |
| High | High | - | No valid data | No valid data |
| Low | Low | High | Valid data bits <br> $8 \sim 15$ | Valid data bits <br> $0 \sim 7$ |
| High | L ow | High | No valid data | Valid data bits <br> $0 \sim 7$ |
| Low | High | High | Valid data bits <br> $8 \sim 15$ | No valid data |
| Low | Low | Low | Valid data bits <br> $8 \sim 15$ | Valid data bits <br> $0 \sim 7$ |
| High | Low | Low | Valid data bits <br> $0 \sim 7^{*}$ | Valid data bits <br> $0 \sim 7$ |
| Low | High | Low | Valid data bits <br> $8 \sim 15$ | Valid data bits <br> $8 \sim 15^{*}$ |

* These conditions are a result of current implementation and may not appear on future devices.


## Data Transfer Acknowledge (DTACK)

This input indicates that the data transfer is completed. When the processor recognizes $\overline{\text { DTACK }}$ during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle is terminated.
(Refer to ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION)

## BUS ARBITRATION CONTROL

These three signats form a bus arbitration circuit to determine which device will be the bus master device.

## Bus Request ( $\overline{\mathbf{B R}}$ )

This input is wire ORed with all other devices that could be bus masters. This input indicates to the processor that some other device desires to become the bus master.

## Bus Grant ( $\overline{\mathbf{B G}}$ )

This output indicates to all other potential bus master devices that the processor will release bus control at the end of the current bus cycle.

## Bus Grand Acknowledge (BGACK)

This input indicates that some other device has become the bus master. This signal cannot be asserted until the following four conditions are met:
(1) A Bus Grant has been received
(2) Address Strobe is inactive which indicates that the microprocessor is not using the bus
(3) Data Transfer Acknowledge is inactive which indicates
that neither memory nor peripherals are using the bus
(4) Bus Grant Acknowledge is inactive which indicates that no other device is still claiming bus mastership.

## INTERRUPT CONTROL ( $\left.\overline{\mathrm{IPL}}_{0}, \overline{\mathrm{PL}}_{1}, \overline{\mathrm{IPL}}_{2}\right)$

These input pins indicate the encoded priority level of the device requesting an interrupt. Level seven is the highest priority while level zero indicates that no interrupts are requested. Level seven can not be masked. The least significant bit is given in IPLo and the most significant bit is contained in IPL2. These lines must remain stable until the processor signals interrupt acknowledge ( $\mathrm{FCo} \sim \mathrm{FC}_{2}$ are all high) to insure that the interrupt is recognized.

## SYSTEM CONTROL

The system control inputs are used to either reset or halt the processor and to indicate to the processor that bus errors have occurred. The three system control inputs are explained in the following paragraphs.

## Bus Error ( $\overline{\mathbf{B E R R}}$ )

This input informs the processor that there is a problem with the cycle currently being executed. Problems may be a result of:
(1) Nonresponding devices
(2) Interrupt vector number acquisition failure
(3) Illegal access request as determined by a memory management unit
(4) Other application dependent errors.

The bus error signal interacts with the halt signal to determine if exception processing should be performed or if the current bus cycle should be retried.

Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction of the bus error and halt signals.

## Reset ( $\overline{\mathrm{RES}}$ )

This bidirectional signal line acts to reset (initiate a system initialization sequence) the processor in response to an external reset signal. An internally generated reset (result of a RESET instruction) causes all external devices to be reset and the internal state of the processor is not affected. A total system reset (processor and external devices) is the result of external HALT and RESET signals applied at the same time. Refer to RESET OPERATION paragraph for additional information about reset operation.

## Halt (HALT)

When this bidirectional line is driven by an external device, it will cause the processor to stop at the completion of the current bus cycle. When the processor has been halted using this input, all control signals are inactive and all three-state lines are put in their high-impedance state. Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction between the halt and bus error signals.

When the processor has stopped executing instructions, such as in a double bus fault condition, the halt line is driven by the processor to indicate to external devices that the processor has stopped.

## HMCS6800 PERIPHERAL CONTROL

These control signals are used to allow the interfacing of synchronous HD6800 peripheral devices with the asynchronous 68000. These signals are explained in the following paragraphs.

## Enable (E)

This signal is the standard enable signal common to all HD6800 type peripheral devices. The period for this output is ten 68000 clock periods (six clocks low; four clocks high). Enable is generated by an internal ring counter which may come up in any state (i.e., at power on, it is impossible to guarantee phase relationship of E to CLK), E is a free-running clock and runs regardless of the state of the bus on the MPU.

## Valid Peripheral Address ( $\overline{\mathrm{VPA}}$ )

This input indicates that the device or region addressed is a HD6800 family device and that data transfer should be synchronized with the enable ( E ) signal. This input also indicates that the processor should use automatic vectoring for an interrupt. Refer to INTERFACE WITH HD6800 PERIPHERALS. ALS.

## Valid Memory Address (VMA)

This output is used to indicate to HD6800 peripheral devices that there is a valid address on the address bus and the processor is synchronized to enable. This signal only responds to a valid peripheral address ( $\overline{\mathrm{VPA}}$ ) input which indicates that the peripheral is a HD6800 family device.

## PROCESSOR STATUS ( $\mathrm{FC}_{0}, \mathrm{FC}_{1}, \mathrm{FC}_{2}$ )

These function code outputs indicate the state (user or supervisor) and the cycle type currently being executed, as shown in Table 14. The information indicated by the function code outputs is valid whenever address strobe ( $\overline{\mathrm{AS}}$ ) is active.

Table 14 Function Code Outputs

| $\mathrm{FC}_{2}$ | $\mathrm{FC}_{1}$ | $\mathrm{FC}_{0}$ | Cycle Type |
| :---: | :---: | :---: | :---: |
| Low | Low | Low | (Undefined, Reserved) |
| Low | Low | High | User Data |
| Low | High | Low | User Program |
| Low | High | High | (Undefined, Reserved) |
| High | Low | Low | (Undefined, Reserved) |
| High | Low | High | Superviser Data |
| High | High | Low | Supervisor Program |
| High | High | High | Interrupt Acknowledge |

## CLOCK (CLK)

The clock input is a TTL-compatible signal that is internally buffered for development of the internal clocks needed by the processor. The clock input should not be gated off at any time, and the clock signal must conform to minimum and maximum pulse width time.

## SIGNAL SUMMARY

Table 15 is a summary of all the signals discussed in the previous paragraphs.

## - BUS OPERATION

The following paragraphs explain control signal and bus operation during data transfer operations, bus arbitration, bus error and halt conditions, and reset operation.

Table 15 Signal Summary

| Signal Name | Mnemonic | Input/Output | Active State | Three State |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | On $\overline{\text { BGACK }}$ | On पALT |
| Address Bus | $A_{1} \sim A_{23}$ | output | high | yes | yes |
| Data Bus | $D_{0} \sim D_{15}$ | input/output | high | yes | yes |
| Address Strobe | $\overline{\text { AS }}$ | output | low | yes | no |
| Read/Write | $\mathrm{R} / \bar{W}$ | output | read-high write-low | yes | no |
| Upper and Lower Data Strobes | UDS, $\overline{\text { LDS }}$ | output | low | yes | no |
| Data Transfer Acknowledge | DTACK | input | low | no | no |
| Bus Request | $\overline{B R}$ | input | low | no | no |
| Bus Grant | $\overline{\text { BG }}$ | output | low | no | no |
| Bus Grant Acknowledge | BGACK | input | low | no | no |
| Interrupt Priority Level | $\overline{\mathrm{PL}_{0}}, \overline{\mathrm{PL}_{1}}, \overline{\mathrm{PL}}_{2}$ | input | low | no | no |
| Bus Error | $\overline{\text { BERR }}$ | input | low | no | no |
| Reset | $\overline{\text { RES }}$ | input/output | low | no* | no* |
| Halt | HALT | input/output | low | no* | no* |
| Enable | E | output | high | no | no |
| Valid Memory Address | $\overline{\text { VMA }}$ | output | low | yes | no |
| Valid Peripheral Address | VPA | input | low | no | no |
| Function Code Output | $\mathrm{FC}_{0}, \mathrm{FC}_{1}, \mathrm{FC}_{2}$ | output | high | yes | no |
| Clock | CLK | input | high | no | no |
| Power Input | $V_{\text {cc }}$ | input | - | - | - |
| Ground | $V_{\text {ss }}$ | input | - | - | - |

- Open drain


## DATA TRANSFER OPERATIONS

Transfer of data between devices involve the following leads:
(1) Address Bus $\mathrm{A}_{1}$ through $\mathrm{A}_{23}$
(2) Data Bus $D_{0}$ through $D_{15}$
(3) Control Signals

The address and data buses are separate parallel buses used to transfer data using an asynchronous bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. In addition, the bus master is responsible for deskewing the acknowledge and data signals from the slave device.

The following paragraphs explain the read, write, and read-modify-write cycles. The indivisible read-modify-write cycle is the method used by the 68000 for interlocked multiprocessor communications.

## Read Cycle

During a read cycle, the processor receives data from memory or a peripheral device. The processor reads bytes of data in all cases. If the instruction specifies a word (or double word) operation, the processor reads both upper and lower bytes simultaneously by asserting both upper and lower data strobes. When the instruction specifies byte operation, the processor uses an internal Ao bit to determine which byte to read and then issues the data strobe required for that byte. For bytes operations, when the Ao bit equals zero, the upper data strobe is issued. When the Ao bit equals one, the lower data strobe is issued. When the data is received, the processor correctly positions it internally.

A word read cycle flow chart is given in Figure 15. A byte
read cycle flow chart is given in Figure 16. Read cycle timing is given in Figure 17. Figure 18 details word and byte read cycle operations. Refer to these illustrations during the following detailed.

At state zero ( S 0 ) in the read cycle, the address bus ( $\mathrm{A}_{1}$ through $\mathrm{A}_{23}$ ) is in the high impedance state. A function code is asserted on the function code output line ( $\mathrm{FC}_{0}$ through $\mathrm{FC}_{2}$ ). The read/write ( $R / W$ ) signal is switched high to indicate a read cycle. One half clock cycle later, at state 1 , the address bus is released from the high impedance state. The function code outputs indicate which address space that this cycle will operate on.

In state 2 , the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted to indicate that there is a valid address on the address bus and the upper and lower data strobe ( $\overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}$ ) is asserted as required. The memory or peripheral device uses the address bus and the address strobe to determine if it has been selected. The selected device uses the read/write signal and the data strobe to place its information on the data bus. Concurrent with placing data on the data bus, the selected device asserts data transfer acknowledge ( $\overline{\mathrm{DTACK}}$ ).

Data transfer acknowledge must be present at the processor at the start of state 5 or the processor will substitute wait states for states 5 and 6 . State 5 starts the synchronization of the returning data transfer acknowledge. At the end of state 6 (beginning of state 7) incoming data is latched into an internal data bus holding register.

During state 7 , address strobe and the upper and/or lower data strobes are negated. The address bus is held valid through state 7 to allow for static memory operation and signal skew.

## BUS MASTER

SLAVE

## Address Device

1) Set $R / W$ to Read
2) Place Function Code on $\mathrm{FC}_{0} \sim \mathrm{FC}_{2}$
3) Place Address on $A_{1} \sim A_{23}$
4) Assert Address Strobe ( $\overline{\mathrm{AS}})$
5) Assert Upper Data Strobe ( $\overline{\mathrm{UDS}}$ ) and Lower

Data Strobe (LDS)


Input Data

1) Decode Address
2) Place Data on $D_{0} \sim D_{1 s}$
3) Assert Data Transfer Acknowledge (DTACK)


Terminate Cycle

1) Latch Data
2) Negate UDS and LDS
3) Negate $\overline{A S}$

4) Remove Data from $D_{0} \sim D_{1 s}$


Figure 15 Word Read Cycle Flow Chart

BUS MASTER
SLAVE

## Address Device

1) Set $R / \bar{W}$ to Read
2) Place Function Code on $\mathrm{FC}_{0} \sim \mathrm{FC}_{2}$
3) Place Address on $A_{1} \sim A_{23}$
4) Assert Address Strobe ( $\overline{\mathrm{AS}}$ )
5) Assert Upper Data Strobe ( $\overline{U D S}$ ) or Lower Data Strobe ( $\overline{\mathrm{LDS}}$ ) (based on $\mathrm{A}_{0}$ )

6) Decode Address
7) Place Data on $D_{0} \sim D_{7}$ or $D_{8} \sim D_{15}$ (based on $\overline{U D S}$ or $\overline{\mathrm{LDS}}$
8) Assert Data Transfer Acknowledge (DTACK)

9) Latch Data
10) Negate UDS or LDS
11) Negate $\overline{A S}$

12) Remove Data from $D_{0} \sim D_{7}$ or $D_{H} \sim D_{1 s}$ 2) Negate DTACK


Figure 16 Byte Read Cycle Flow Chart


Figure 17 Read and Write Cycle Timing Diagram


Figure 18 Word and Byte Read Cycle Timing Diagram

The read/write signal and the function code outputs also remain valid through state 7 to ensure a correct transfer operation. The slave device keeps its data asserted until it detects the negation of either the address strobe or the upper and/or lower data strobe. The slave device must remove its data and data transfer acknowledge within one clock period of recognizing the negation of the address or data strobes. Note that the data bus might not become free and data transfer acknowledge might not be removed until state 0 or 1 .

When address strobe is negated, the slave device is released. Note that a slave device must remain selected as long as address strobe is asserted to ensure the correct functioning of the read-modify-write cycle.

## Write Cycle

During a write cycle, the processor sends data to memory or a peripheral device. The processor writes bytes of data in all cases. If the instruction specifies a word operation, the processor writes both bytes. When the instruction specifies a byte operation, the processor uses an internal $\mathrm{A}_{0}$ bit to determine which byte to write and then issues the data strobe required for that byte. For byte operations, when the $\mathrm{A}_{0}$ bit equals zero, the upper data strobe is issued. When the $\mathrm{A}_{0}$ bit equals one, the lower data strobe is issued. A word write cycle flow chart is given in Figure 19. A byte write cycle flow chart is given in Figure 20. Write cycle timing is given in Figure 17. Figure 21 details word and byte write cycle operation. Refer to these illustrations during the following detailed discussion.

At state zero ( S 0 ) in the write cycle, the address bus ( $\mathrm{A}_{1}$ through $\mathrm{A}_{23}$ ) is in the high impedance state. A function code is asserted on the function code output line ( $\mathrm{FC}_{0}$ through $\mathrm{FC}_{2}$ ).
(NOTE) The read/write ( $\mathrm{R} / \overline{\mathrm{W}}$ ) signal remains high until state 2 to prevent bus conflicts with preceding read cycles. The data bus is not driven until state 3 .

One half clock later, at state 1 , the address bus is released from the high impedance state. The function code outputs indicate which address space that this cycle will operate on.

In state 2 , the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted to indicate that there is a valid address on the address bus. The memory or peripheral device uses the address bus and the address strobe to determine if it has been selected. During state 2, the read/ write signal is switched low to indicate a write cycle. When external processor data bus buffers are required, the read/write line provides sufficient directional control. Data is not asserted during this state to allow sufficient turn around time for external data buffers (if used). Data is asserted onto the data bus during state 3 .

In state 4, the data strobes are asserted as required to indicate that the data bus is stable. The selected device uses the read/write signal and the data strobes to take its information from the data bus. The selected device asserts data transfer acknowledge ( $\overline{\mathrm{DTACK}}$ ) when it has successfully stored the data.

Data transfer acknowledge must be present at the processor at the start of state 5 or the processor will substitute wait states for states 5 and 6. State 5 starts the synchronization of the returning data transfer acknowledge.

During state 7 , address strobe and the upper and/or lower data strobes are negated. The address and data buses are held valid through state 7 to allow for static memory operation and signal skew. The read/write signal and the function code outputs also remain valid through state 7 to ensure a correct transfer operation. The slave device keeps its data transfer acknowledge asserted until it detects the negation of either the address strobe or the upper and/or lower data strobe. The slave device must remove its data transfer acknowledge within one clock period after recognizing the negation of the address or data strobes. Note that the processor releases the data bus at the end of state 7 but that data transfer acknowledge might not be removed until state 0 or 1 . When address strobe is negated, the slave device is released.


Figure 19 Word Write Cycle Flow Chart

## BUS MASTER <br> SLAVE

Address Device

1) Place Function Code on $\mathrm{FC}_{0} \sim \mathrm{FC}_{2}$
2) Place Address on $A_{1} \sim A_{23}$
3) Assert Address Strobe ( $\overline{\mathrm{AS}}$ )
4) Set $R / \bar{W}$ to Write
5) Place Data on $D_{0} \sim D_{7}$ or $D_{y} \sim D_{1 s}$ (according
to $A_{0}$ )
6) Assert Upper Data Strobe (UDS) or Lower Data Strobe (LDS) (based on $\mathrm{A}_{0}$ )

7) Decode Address
8) Store Data on $D_{0} \sim D_{7}$ if $\overline{L D S}$ is asserted Store Data on $D_{8} \sim D_{15}$ if UDS is asserted
9) Assert Data Transfer Acknowledge (DTACK)

Terminate Output Transfer

1) Negate $\overline{U D S}$ and $\overline{L D S}$
2) Negate $\overline{A S}$
3) Remove Data from $D_{0} \sim D_{7}$ or $D_{8} \sim D_{15}$
4) Set $R / \bar{W}$ to Read


Figure 20 Byte Write Cycle Flow Chart


Figure 21 Word and Byte Write Cycle Timing Diagram

## Read-Modify-Write Cycle

The read-modify-write cycle performs a read, modifies the data in the arithmetic-logic unit, and writes the data back to the same address. In the 68000 this cycle is indivisible in that the address strobe is asserted throughout the entire cycle. The test and set (TAS) instruction uses this cycle to provide meaningful communication between processors in a multiple processor environment. This instruction is the only instruction that uses the read-modify-write cycle and since the test and set instruction only operates on bytes, all read-modify-write cycles are byte operations. A read-modify-write cycle flow chart is given in Figure 22 and a timing diagram is given in Figure 23. Refer to these illustrations during the following detailed discussions.

At state zero ( $\mathbf{S} 0$ ) in the read-modify-write cycle, the address bus ( $A_{1}$ through $A_{23}$ ) is in the high impedance state. A function code is asserted on the function code output line ( $\mathrm{FC}_{0}$ through $\mathrm{FC}_{2}$ ). The read/write ( $\mathrm{R} / \overline{\mathrm{W}}$ ) signal is switched high to indicate a read cycle. One half clock cycle later, at state 1 , the address bus is released from the high impedance state. The function code outputs indicate which address space that this cycle will operate on.

In state 2, the address strobe (AS) is asserted to indicate that there is a valid address on the address bus and the upper or lower data strobe (UDS, $\overline{\mathrm{LDS}}$ ) is asserted as required. The memory or peripheral device uses the address bus and the address strobe to determine if it has been selected. The selected device uses the read/write signal and the data strobe to place its information on the data bus. Concurrent with placing data on the data bus, the selected device asserts data transfer acknowledge (DTACK).

Data transfer acknowledge must be present at the processor at the start of state 5 or the processor will substitute wait states for states 5 and 6. State 5 starts the synchronization of the returning data transfer acknowledge. At the end of state 6 (beginning of state 7) incoming data is latched into an internal data bus holding register.

During state 7, the upper or lower data strobe is negated. The address bus, address strobe, read/write signal, and function code outputs remain as they were in preparation for the write portion of the cycle. The slave device keeps its data asserted until it detects the negation of the upper or lower data strobe. The slave device must remove its data and data transfer acknowledge within one clock period of recognizing the negation of the data strobes. Internal modification of data may occur from state 8 to state 11 .
(NOTE) The read/write signal remains high until state 14 to prevent bus conflicts with the preceding read portion of the cycle and the data bus is not asserted by the processor until state 15 .
In state 14 , the read/write signal is switched low to indicate a write cycle. When external processor data bus buffers are required, the read/write line provides sufficient directional control. Data is not asserted during this state to allow sufficient turn around time for external data buffers (if used). Data is asserted onto the data bus during state 15 .

In state 16, the data strobe is asserted as required to indicate
that the data bus is stable. The selected device uses the read/ write signal and the data strobe to take its information from the data bus. The selected device asserts data transfer acknowledge ( $\overline{\text { DTACK }}$ ) when it has successfully stored its data.

Data transfer acknowledge must be present at the processor at the start of state 17 or the processor will substitute wait states for states 17 and 18 . State 17 starts the synchronization of the returning data transfer acknowledge for the write portion of the cycle. The bus interface circuitry issues requests for subsequent internal cycles during state 18.

During state 19 , address strobe and the upper or lower data strobe is negated. The address and data buses are held valid through state 19 to allow for static memory operation and signal skew. The read/write signal and the function code outputs also remain valid through state 19 to ensure a correct transfer operation. The slave device keeps its data transfer acknowledge asserted until it detects the negation of either the address strobe or the upper or lower data strobe. The slave device must remove its data transfer acknowledge within once clock period after recognizing the negation of the address or data strobes. Note that the processor releases the data bus at the end of state 19 but that data transfer acknowledge might not be removed until state 0 or 1 . When address strobe is negated the slave device is released.

## BUS ARBITRATION

Bus arbitration is a technique used by master-type devices to request, be granted, and acknowledge bus mastership. In its simplest form, it consists of:
(1) Asserting a bus mastership request.
(2) Receiving a grant that the bus is available at the end of the current cycle.
(3) Acknowledging that mastership has been assumed.

Figure 24 is a flow chart showing the detail involved in a request from a single device. Figure 25 is a timing diagram for the same operations. This technique allows processing of bus requests during data transfer cycles.

The timing diagram shows that the bus request is negated at the time that an acknowledge is asserted. This type of operation would be true for a system consisting of the processor and one device capable of bus mastership. In systems having a number of devices capable of bus mastership, the bus request line from each device is wire ORed to the processor. In this system, it is easy to see that there could be more than one bus request being made. The timing diagram shows that the bus grant signal is negated a few clock cycles after the transition of the acknowledge ( $\overline{\mathrm{BGACK}}$ ) signal.

However, if the bus requests are still pending, the processor will assert another bus grant within a few clock cycles after it was negated. This additional assertion of bus grant allows external arbitration circuitry to select the next bus master before the current bus master has completed its requirements. The following paragraphs provide additional information about the three steps in the arbitration process.


Figure 22 Read-Modify-Write Cycle Flow Chart


Figure 23 Read-Modify-Write Cycle Timing Diagram

PROCESSOR

## REQUESTING DEVICE

Request the Bus

1) Assert Bus Request ( $\overline{\mathrm{BR}}$ )

Grant Bus Arbitration

1) Assert Bus Grant ( $\overline{\mathrm{BG}}$ )

Acknowledge Bus Mastership

1) External arbitration determines next bus master
2) Next bus master waits for current cycle to complete
3) Next bus master asserts Bus Grant Acknowledge (BGACK) to become new master


Re-Arbitrate or Resume Processor Operation

Figure 24 Bus Arbitration Cycle Flow Chart

## Requesting the Bus

External devices capable of becoming bus masters request the bus by asserting the bus request $(\overline{\mathrm{BR}})$ signal. This is a wire ORed signal (although it need not be constructed from open collector devices) that indicates to the processor that some external device requires control of the external bus. The processor is effectively at a lower bus priority level that the external device and will relinquish the bus after it has completed the last bus cycle it has started.

When no acknowledge is received before the bus request signal goes inactive, the processor will continue processing when it detects that the bus request is inactive. This allows ordinary processing to continue if the arbitration circuitry responded to noise inadvertently.

## Receiving the Bus Grant

The processor asserts bus grant ( $\overline{\mathrm{BG}}$ ) as soon as possible. Normally this is immediately after internal synchronization. The only exception to this occurs when the processor has made an internal decision to execute the next bus cycle but has not progressed far enough into the cycle to have asserted the address strobe ( $\overline{\mathrm{AS}}$ ) signal. In this case, bus grant will not be asserted until one clock after address strobe is asserted to indicate to external devices that a bus cycle is being executed.

The bus grant signal may be routed through a daisy-chained network or through a specific priority encoded network. The processor is not affected by the external method of arbitration as long as the protocol is obeyed.

## Acknowledgement of Mastership

Upon receiving a bus grant, the requesting device waits until address strobe, data transfer acknowledge, and bus grant acknowledge are negated before issuing its own BGACK. The negation of the address strobe indicates that the previous master has completed its cycle, the negation of bus grant acknowledge indicates that the previous master has released the bus. (While address strobe is asserted no device is allowed to "break into" a cycle.) The negation of data transfer acknowledge indicates the previous slave has terminated its connection to the previous master. Note that in some applications data


Figure 25 Bus Arbitration Cycle Timing Diagram
transfer acknowledge might not enter into this function. General purpose devices would then be connected such that they were only dependent on address strobe. When bus grant acknowledge is issued the device is bus master until it negates bus grant acknowledge. Bus grant acknowledge should not be negated until after the bus cycle(s) is (are) completed. Bus mastership is terminated at the negation of bus grant acknowledge.

The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still pending, another bus grant will be asserted within a few clocks of the negation of bus grant. Refer to Bus Arbitration Control section. Note that the processor does not perform any external bus cycles before it re-asserts bus grant.

## BUS ARBITRATION CONTROL

The bus arbitration control unit in the 68000 is implemented with a finite state machine. A state diagram of this machine is shown in Figure 26. All asynchronous signals to the 68000 are synchronized before being used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time (\#47) has
been met (see Figure 27). The input signal is sampled on the falling edge of the clock and is valid internally after the next falling edge.

As shown in Figure 26, input signals labeled $R$ and $A$ are internally synchronized on the bus request and bus grant acknowledge pins respectively. The bus grant output is lebeled G and the internal three-state control signal T . If T is true, the address, data, function code line, and control buses are placed in a high-impedance state when $\overline{\mathrm{AS}}$ is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level.

State changes (valid outputs) occur on the next rising edge after the internal signal is valid.

A timing diagram of the bus arbitration sequence during a processor bus cycle is shown in Figure 28. The bus arbitration sequence while the bus is inactive (i.e., executing internal operations such as a multiply instruction) is shown in Figure 29.

If a bus request is made at a time when the MPU has already begun a bus cycle but $\overline{\mathrm{AS}}$ has not been asserted (bus state SO ), $\overline{B G}$ will not be asserted on the next rising edge. Instead, $\overline{B G}$ will be delayed until the second rising edge following it's internal assertion. This sequence is shown in Figure 30.

$\overline{B R}$ (Internal)

Figure 27 Timing Relationship of External Asynchronous Inputs to Internal Signals


Figure 28 Bus Arbitration During Processor Bus Cycle


Figure 29 Bus Arbitration with Bus Inactive


Figure 30 Bus Arbitration During Processor Bus Cycle Special Case

## BUS ERROR AND HALT OPERATION

In a bus architecture that requires a handshake from an external device, the possibility exists that the handshake might not occur. Since different systems will require a different maximum response time, a bus error input is provided. External circuitry must be used to determine the duration between address strobe and data transfer acknowledge before issuing a bus error signal. When a bus error signal is received, the processor has two options initiate a bus error exception sequence or try running the bus cycle again.

## Exception Sequence

When the bus error signal is asserted, the current bus cycle is terminated. If $\overline{B E R R}$ is asserted before the falling edge of S2, $\overline{\mathrm{AS}}$ will be negated in S 7 in either a read or write cycle. As long as $\overline{\mathrm{BERR}}$ remains asserted, the data and address buses will be in the high-impedance state. When BERR is negated, the processor will begin stacking for exception processing. Figure 31 is a timing diagram for the exception sequence. The sequence is composed of the following elements.
(1) Stacking the program counter and status register
(2) Stacking the error information
(3) Reading the bus error vector table entry
(4) Executing the bus error handler routine

The stacking of the program counter and the status register is the same as if an interrupt had occurred. Several additional
items are stacked when a bus error occurs. These items are used to determine the nature of the error and correct it, if possible. The bus error vector is vector number two located at address $\$ 000008$. The processor loads the new program counter from this location. A software bus error handler routine is then executed by the processor. Refer to EXCEPTION PROCESSING for additional information.

## Re-Running the Bus Cycle

When, during a bus cycle, the processor receives a bus error signal and the halt pin is being driven by an external device, the processor enters the re-run sequence. Figure 32 is a timing diagram for re-running the bus cycle.

The processor terminates the bus cycle, then puts the address and data output lines in the high-impedance state. The processor remains "halted," and will not run another bus cycle until the halt signal is removed by external logic. Then the processor will re-run the previous bus cycle using the same address, the same function codes, the same data (for a write operation), and the same controls. The bus error signal should be removed at least one clock cycle before the halt signal is removed.
(NOTE) The processor will not re-run a read-modify-write cycle. This restriction is made to guarantee that the entire cycle runs correctly and that the write operation of a Test-and-Set operation is performed without ever releasing AS. If BERR and HALT are asserted during a read-modify-write bus cycle, a bus error operation results.


Figure 31 Bus Error Timing Diagram


Figure 32 Re-Run Bus Cycle Timing Information

## Halt Operation with No Bus Error

The halt input signal to the 68000 perform a Halt/Run/ Single-Step function in a similar fashion to the HD6800 halt function. The halt and run modes are somewhat self explanatory in that when the halt signal is constantly active the processor "halts" (does nothing) and when the halt signal is constantly inactive the processor "runs" (does something).

The single-step mode is derived from correctly timed transitions on the halt signal input. It forces the processor to execute a single bus cycle by entering the "run" mode until the processor starts a bus cycle then changing to the "halt" mode. Thus, the single-step mode allows the user to proceed through (and therefore debug) processor operations one bus cycle at a time.

Figure 33 details the timing required for correct single-step operations and Figure 34 shows a simple circuit for providing the single-step function. Some care must be exercised to avoid harmful interactions between the bus error signal and the halt
pin when using the single cycle mode as a debugging tool. This is also true of interactions between the halt and reset lines since these can reset the machine.

When the processor completes a bus cycle after recognizing that the halt signal is active, most three-state signals are put in the high-impedance state. These include:
(1) Address lines
(2) Data lines

This is required for correct performance of the re-run bus cycle operation.

While the processor is honoring the halt request, bus arbitration performs as usual. That is, halting has no effect on bus arbitration. It is the bus arbitration function that removes the control signals from the bus.

The halt function and the hardware trace capability allow the hardware debugger to trace single bus cycles or single instructions at a time. These processor capabilities, along with a software debugging package, give total debugging flexibility.


Figure 33 Halt Signal Timing Characteristics


Figure 34 Simplified Single-Step Circuit

## Double Bus Faults

When a bus error exception occurs, the processor will attempt to stack several words containing information about the state of the machine. If a bus error exception occurs during the stacking operation, there have been two bus errors in a row. This is commonly referred to as a double bus fault. When a double bus fault occurs, the processor will halt. Once a bus error exception has occurred, any bus error exception occurring before the execution of the next instruction constitutes a double bus fault.

Note that a bus cycle which is re-run does not constitute a bus error exception, and does not contribute to a double bus
fault. Note also that this means that as long as the external hardware requests it, the processor will continue to re-run the same bus cycle.

The bus error pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor.

## RESET OPERATION

The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure 35 is a timing diagram for the reset operations. Both the halt and reset lines must be asserted to ensure total reset of the processor.

When the reset and halt lines are driven by an external device, it is recognized as an entire system reset, including the processor. The processor responds by reading the reset vector table entry (vector unumber zero, address $\$ 000000$ ) and loads it into the supervisor stack pointer (SSP). Vector table entry number one at address $\$ 000004$ is read next and loaded into the program counter. The processor initializes the status register to an interrupt level of seven. No other
registers are affected by the reset sequence.
When a RESET instruction is executed, the processor drives the reset pin for 124 clock periods. In this case, the processor is trying to reset the rest of the system. Therefore, there is no effect on the internal state of the processor. All of the processor's internal registers and the status register are unaffected by the execution of a RESET instruction. All external devices connected to the reset line should be reset at the completion of the RESET instruction.

Asserting the Reset and Halt pins for 10 clock cycles will cause a processor reset, except when $\mathrm{V}_{\mathrm{CC}}$ is initially applied to the processor. In this case, an external reset must be applied for 100 milliseconds.


Figure 35 Reset Operation Timing Diagram

## THE RELATIONSHIP OF DTACK, $\overline{B E R R}$, AND $\overline{\text { HALT }}$

In order to properly control termination of a bus cycle for a re-run or a bus error condition, DTACK, BERR, and HALT should be asserted and negated on the rising edge of the 68000 clock. This will assure that when two signals are asserted simultaneously, the required setup time (\#47) for both of them will be met during the same bus state.

This, or some equivalent precaution, should be designed external to the 68000 . Parameter \#48 is intended to ensure this operation in a totally asynchronous system, and may be ignored if the above conditions are met.

The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 16):
Normal Termination: DTACK occurs first (case 1).
Halt Termination: HALT is asserted at the same time or before DTACK and $\overline{\text { BERR }}$ remains negated (cases 2 and 3).
Bus Error Termination: BERR is asserted in lieu of, at the same time, or before DTACK (case 4); $\overline{\text { BERR }}$ is negated at the same time or after DTACK.
Re-Run Termination: $\overline{\text { HALT }}$ and $\overline{\text { BERR }}$ are asserted in lieu of, at the same time, or before DTACK
(cases 6 and 7); HALT must be held at least one cycle after $\overline{\text { BERR }}$. Case 5 indicates $\overline{\text { BERR }}$ may precede $\overline{\text { HALT }}$ which allows fully asynchronous assertion.
Table 16 details the resulting bus cycle termination under various combinations of control signal sequences. The negation of these same control signals under several conditions is shown in Table 17 (DTACK is assumed to be negated normally in all cases; for best results, both DTACK and BERR should be negated when address strobe is negated.)

Example A: A system uses a watch-dog timer to terminate accesses to un-populated address space. The timer asserts $\overline{\text { DTACK }}$ and $\overline{\text { BERR }}$ simultaneously after time-out. (case 4)

Example B: A system uses error detection on RAM contents. Designer may (a) delay DTACK until data verified, and return $\overline{\mathrm{BERR}}$ and $\overline{\mathrm{HALT}}$ simultaneously to re-run error cycle (case 6), or if valid, return DTACK; (b) delay DTACK until data verified, and return $\overline{\overline{B E R R}}$ at same time as $\overline{\text { DTACK }}$ if data in error (case 4); (c) return DTACK prior to data verification, as described in previous section. If data invalid, $\overline{\mathrm{BERR}}$ is asserted (case 1) in next cycle. Error-handling software must know how to recover error cycle.

Table 16 DTACK, $\overline{\text { BERR }}, \overline{\text { HALT }}$ Assertion Results

| Case No. | Control Signal | Asserted on Rising Edge of State |  | Result |
| :---: | :---: | :---: | :---: | :---: |
|  |  | N | $N+2$ |  |
| 1 | $\overline{\text { DTACK }}$ BERR HALT | $\begin{gathered} \text { A } \\ \text { NA } \\ \text { NA } \\ \hline \end{gathered}$ | $\begin{aligned} & \hline \mathrm{S} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | Normal cycle terminate and continue. |
| 2 | DTACK BERR HALT | $\begin{gathered} \text { A } \\ \text { NA } \\ A \end{gathered}$ | $\begin{aligned} & \hline \mathrm{S} \\ & \mathrm{X} \\ & \mathrm{~S} \end{aligned}$ | Normal cycle terminate and halt. Continue when HALT removed. |
| 3 | DTACK BERR HALT | $\begin{gathered} \text { NA } \\ \text { NA } \\ \text { A } \end{gathered}$ | $\begin{gathered} \text { A } \\ \text { NA } \\ \text { S } \end{gathered}$ | Normal cycle terminate and halt. Continue when $\overline{\text { HALT }}$ removed. |
| 4 | DTACK <br> BERR <br> HALT | $\begin{gathered} X \\ A \\ N A \end{gathered}$ | $\begin{gathered} \mathrm{X} \\ \mathrm{~S} \\ \mathrm{NA} \end{gathered}$ | Terminate and take bus error trap. |
| 5 | DTACK BERR HALT | $\begin{gathered} \text { NA } \\ \text { A } \\ \text { NA } \end{gathered}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{~S} \\ & \mathrm{~A} \\ & \hline \end{aligned}$ | Terminate and re-run. |
| 6 | DTACK BERR HALT | $\begin{aligned} & X \\ & \text { A } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & X \\ & X \\ & S \\ & S \end{aligned}$ | Terminate and re-run when $\overline{H A L T}$ removed. |
| 7 | $\overline{\text { DTACK }}$ BERR HALT | $\begin{gathered} \text { NA } \\ \text { NA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{~A} \\ & \mathrm{~S} \end{aligned}$ | Terminate and re-run when $\overline{\text { HALT }}$ removed. |

## gend:

N - The number of the current even bus state (e.g., S4, S6, etc.)
A - Signal is asserted in this bus state
NA - Signal is not asserted in this state
$X$ - Don't care
S - Signal was asserted in previous state and remains asserted in this state
Table $17 \overline{\text { BERR }}$ and $\overline{\text { HALT }}$ Negation Results

| Conditions of Termination in Table A | Control Signal | Negated on Rising Edge of State |  |  | Results - Next Cycle |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | N |  | $\mathrm{N}+2$ |  |
| Bus Error | $\frac{\overline{\text { BERR }}}{\frac{\text { HALT }}{}}$ | $\bullet$ |  | $\bullet$ | Takes bus error trap. |
| Re-run | $\frac{\overline{\text { BERR }}}{\overline{\text { HALT }}}$ |  |  |  | Illegal sequence; usually traps to vector number 0 . |
| Re-run | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | - |  | - | Re-runs the bus cycle. |
| Normal | $\begin{aligned} & \overline{\text { BERR }} \\ & \hline \text { HALT } \end{aligned}$ | $\bullet$ |  | - | May lengthen next cycle. |
| Normal | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | - |  | $\stackrel{\bullet}{\text { none }}$ | If next cycle is started it will be terminated as a bus error. |

## ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION

## Asynchronous Operation

To achieve clock frequency independence at a system level, the 68000 can be used in an asynchronous manner. This entails using only the bus handshake lines ( $\overline{\mathrm{AS}}, \overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}$, $\overline{\text { DTACK, }} \overline{\mathrm{BERR}}, \overline{\mathrm{HALT}}$, and $\overline{\mathrm{VPA}})$ to control the data transfer. Using this method, $\overline{\text { AS }}$ signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle. The slave device (memory or peripheral) then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowledge signal (DTACK) to terminate the bus cycle. If no slave responds or the access is invalid, external control logic
asserts the $\overline{\mathrm{BERR}}$, or $\overline{\mathrm{BERR}}$ and $\overline{\mathrm{HALT}}$, signal to abort or re-run the bus cycle.

The DTACK signal is allowed to be asserted before the data from a slave device is valid on a read cycle. The length of time that DTACK may precede data is given as parameter \#31 and it must be met in any asynchronous system to insure that valid data is latched into the processor. Notice that there is no maximum time specified from the assertion of $\overline{\mathrm{AS}}$ to the assertion of DTACK. This is because the MPU will insert wait cycles of one clock period each until DTACK is recognized.

The $\overline{B E R R}$ signal is allowed to be asserted after the $\overline{\text { DTACK }}$ signal is asserted. BERR must be asserted within the time given as parameter \#48 after DTACK is asserted in any asynchronous
system to insure proper operation. If this maximum delay time is violated, the processor may exhibit erratic behavior.

## Synchronous Operation

To allow for those systems which use the system clock as a signal to generate DTACK and other asynchronous inputs, the asynchronous input setup time is given as parameter \#47. If this setup is met on an input, such as DTACK, the processor is guaranteed to recognize that signal on the next falling edge of the system clock. However, the converse is not true - if the input signal does not meet the setup time it is not guaranteed not to be recognized. In addition, if DTACK is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter \#27. Given this, parameter \#31 may be ignored. Note that if DTACK is asserted, with the required setup time, before the falling edge of $S 4$, no wait status will be incurred and the bus cycle will run at its maximum speed of four clock periods.

In order to assure proper operation in a synchronous system when $\overline{\mathrm{BERR}}$ is asserted after $\overline{\mathrm{DTACK}}, \overline{\mathrm{BERR}}$ must meet the setup time parameter \#27A prior to the falling edge of the clock one clock cycle after $\overline{\text { DTACK }}$ was recognized. This setup time is critical to proper operation, and the HD68000 may exhibit erratic behavior if it is violated.

## (NOTE)

During an active bus cycle, $\overline{\mathrm{VPA}}$ and $\overline{\mathrm{BERR}}$ are sampled on every falling edge of the clock starting with So. DTACK is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S6 during a read. The bus cycle will then be terminated in S7 except when $\overline{B E R R}$ is asserted in the absence of $\overline{\text { DTACK, }}$, in which case it will terminate one clock cycle later in S9.

## - PROCESSING STATES

This section describes the actions the 68000 which are outside the normal processing associated with the execution of instructions. The functions of the bits in the supervisor portion of the status register are covered: the supervisor/user bit, the trace enable bit, and the processor interrupt priority mask. Finally, the sequence of memory references and actions taken by the processor on exception conditions is detailed.

The 68000 . is always in one of three processing states: normal, exception, or halted. The normal processing state is that associated with instruction execution: the memory refcrences are to fetch instructions and operands, and to store results. A special case of the normal state is the stopped state which the processor enters when a STOP instruction is executed. In this state, no further memory references are made.

The exception processing state is associated with interrupts, trap instructions, tracing and other exceptional conditions. The exception may be internally generated by an instruction or by an unusual condition arising during the execution of an instruction. Externally, exception processing can be forced by an interrupt, by a bus error, or by a reset. Exception processing is designed to provide an efficient context switch so that the processor may handle unusual conditions.

The halted processing state is an indication of catastrophic hardware failure. For example, if during the exception processing of a bus error another bus error occurs, the processor
assumes that the system is unusable and halts. Only an external reset can restart a halted processor. Note that a processor in the stopped state is not in the halted state, nor vice versa.

PROCESSING STATES

| NORMAL | INSTRUCTION <br> EXECUTION <br> (INCLUDING STOP) |
| :--- | :--- |
|  | INTERRUUPTS <br> TRAPS <br> TRACING ETC. |
| HALTED | HARDWARE HALT <br> DOUBLE BUS FAULT |

## - PRIVILEGE STATES

The processor operates in one of two states of privilege: the "user" state or the "supervisor" state. The privilege state determines which operations are legal, are used to choose between the supervisor stack pointer and the user stack pointer in instruction references, and may be used by an external memory management device to control and translate accesses.

The privileges state is a mechanism for providing security in a computer system. Programs should access only their own code and data areas, and ought to be restricted from accessing information which they do not need and must not modify.

The privilege mechanism provides security by allowing most programs to execute in user state. In this state, the accesses are controlled, and the effects on other parts of the system are limited. The operating system executes in the supervisor state, has access to all resources, and performs the overhead tasks for the user state programs.

## SUPERVISOR STATE

The supervisor state is the higher state of privilege. For instruction execution, the supervisor state is determined by the S-bit of the status register; if the S-bit is asserted (high), the processor is in the supervisor state. All instructions can be executed in the supervisor state. The bus cycles generated by instructions executed in the supervisor state are classified as supervisor references. While the processor is in the supervisor privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly access the supervisor stack pointer.

All exception processing is done in the supervisor state, regardless of the setting of the S-bit. The bus cycles generated during exception processing are classified as supervisor references. All stacking operations during exception processing use the supervisor stack pointer.

## USER STATE

The user state is the lower state of privilege. For instruction execution, the user state is determined by the S-bit of the status register; if the $S$-bit is negated (low), the processor is executing instructions in the user state.

Most instructions execute the same in user state as in the supervisor state. However, some instructions which have important system effects are made privileged. User programs are not permitted to execute the STOP instruction, or the

RESET instruction. To ensure that a user program cannot enter the supervisor state except in a controlled manner, the instructions which modify the whole status register are privileged. To aid in debugging programs which are to be used as operating systems, the move to user stack pointer (MOVE to USP) and move from user stack pointer (MOVE from USP) instructions are also privileged.

The bus cycles generated by an instruction executed in user state are classified as user state references. This allows an external memory management device to translate the address and to control access to protected portions of the address space. While the processor is in the user privilege state, those instructions which use either the system stack pointer implicitly, or address register seven explicitly, access the use stack pointer.

## PRIVILEGE STATE CHANGES

Once the processor is in the user state and executing instructions, only exception processing can change the privilege state. During exception processing, the current setting of the S-bit of the status register is saved and the S-bit is asserted, putting the processing in the supervisor state. Therefore, when instruction execution resumes at the address specified to process the exception, the processor is in the supervisor privilege state.

## USER/SUPERVISOR MODES

## TRANSITION ONLY MAY OCCUR

 DURING EXCEPTION PROCESSING

TRANSITION MAY BE MADE BY: RTE; MOVE, ANDI, EORI TO STATUS WORD

## REFERENCE CLASSIFICATION

When the processor makes a reference, it classifies the kind of reference being made, using the encoding on the three function code output lines. This allows external translation of addresses, control of access, and differentiation of special processor states, such as interrupt acknowledge. Table 18 lists the classification of references.

Table 18 Reference Classification

| Function Code Output |  |  | $*$ |
| :---: | :---: | :---: | :--- |
| $\mathrm{FC}_{2}$ | $\mathrm{FC}_{1}$ | $\mathrm{FC}_{0}$ |  |
| 0 | 0 | 0 |  |
| 0 | 0 | 1 | (Unassigned) |
| 0 | 1 | 0 | User Data |
| 0 | 1 | 1 | User Program |
| 1 | 0 | 0 | (Unassigned) |
| 1 | 0 | 1 | (Unassigned) |
| 1 | 1 | 0 | Supervisor Data |
| 1 | 1 | 1 | Supervisor Program |

## - EXCEPTION PROCESSING

Before discussing the details of interrupts, traps, and tracing, a general description of exception processing is in order. The processing of an exception occurs in four steps, with variations for different exception causes. During the first step, a temporary copy of the status register is made, and the status register is set for exception processing. In the second step the exception vector is determined, and the third step is the saving of the current processor context. In the fourth step a new context is obtained, and the processor switches to instruction processing.

## EXCEPTION VECTORS

Exception vectors are memory locations from which the processor fetches the address of a routine which will handle that exception. All exception vectors are two words in length (Figure 36), except for the reset vector, which is four words. All exception vectors lie in the supervisor data space, except for the reset vector which is in the supervisor program space. A vector number is an eight-bit number which, when multiplied by four, gives the address of an exception vector. Vector numbers are generated internally or externally depending on the cause of the exception. In the case of interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8 -bit vector number (Figure 37) to the processor on data bus lines $\mathrm{D}_{0}$ through $\mathrm{D}_{7}$. The processor translates the vector number into a full 24 -bit address, as shown in Figure 38. The memory layout for exception vectors is given in Table 19.

As shown in Table 19, the memory layout is 512 words long ( 1024 bytes). It starts at address 0 and proceeds through address 1023. This provides 255 unique vectors; some of these are reserved for TRAPS and other system functions. Of the 255 , there are 192 reserved for user interrupt vectors. However. there is no protection on the first 64 entries, so user interrupt vectors may overlap at the discretion of the systems designer

## KINDS OF EXCEPTIONS

Exceptions can be generated by either internal or external causes. The externally generated exceptions are the interrupts and the bus error and reset requests. The interrupts are requests from peripheral devices for processor action while the bus error and reset inputs are used for access control and processor restart. The internally generated exceptions come from instructions, or from address error or tracing. The trap (TRAP), trap on overflow (TRAPV), check register against bounds (CHK) and divide (DIV) instructions all can generate exceptions as part of their instruction execution. In addition, illegal instructions, word fetches from odd addresses and privilege violations cause exceptions. Tracing behaves like a very high priority, internally generated interrupt after each instruction execution.

## EXCEPTION PROCESSING SEQUENCE

Exception processing occurs in four identifiable steps. In the first step, an internal copy is made of the status register. After the copy is made, the S-bit is asserted, putting the processor into the supervisor privilege state. Also, the T-bit is negated which will allow the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated.

In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor fetch, classified as an interrupt acknowledge. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector.


Figure 36 Exception Vector Format


Figure 37 Peripheral Vector Number Format


Figure 38 Address Translated From 8-Bit Vector Number

Table 19 Exception Vector Assignment

| Vector Number(s) | Address |  |  | Assignment |
| :---: | :---: | :---: | :---: | :---: |
|  | Dec | Hex | Space |  |
| 0 | 0 | 000 | SP | Reset: Initial SSP |
| - | 4 | 004 | SP | Reset: Initial PC |
| 2 | 8 | 008 | SD | Bus Error |
| 3 | 12 | 00 C | SD | Address Error |
| 4 | 16 | 010 | SD | Illegal Instruction |
| 5 | 20 | 014 | SD | Zero Divide |
| 6 | 24 | 018 | SD | CHK Instruction |
| 7 | 28 | 01C | SD | TRAPV Instruction |
| 8 | 32 | 020 | SD | Privilege Violation |
| 9 | 36 | 024 | SD | Trace |
| 10 | 40 | 028 | SD | Line 1010 Emulator |
| 11 | 44 | 02C | SD | Line 1111 Emulator |
| 12* | 48 | 030 | SD | (Unassigned, reserved) |
| $13^{*}$ | 52 | 034 | SD | (Unassigned, reserved) |
| 14* | 56 | 038 | SD | (Unassigned, reserved) |
| 15 | 60 | 03C | SD | Uninitialized Interrupt Vector |
| $16 \sim 23^{*}$ | 64 | 040 | SD | (Unassigned, reserved) |
|  | 95 | 05F |  |  |
| 24 | 96 | 060 | SD | Spurious Interrupt |
| 25 | 100 | 064 | SD | Level 1 Interrupt Autovector |
| 26 | 104 | 068 | SD | Level 2 Interrupt Autovector |
| 27 | 108 | 06C | SD | Level 3 Interrupt Autovector |
| 28 | 112 | 070 | SD | Level 4 Interrupt Autovector |
| 29 | 116 | 074 | SD | Level 5 Interrupt Autovector |
| 30 | 120 | 078 | SD | Level 6 Interrupt Autovector |
| 31 | 124 | 07C | SD | Level 7 Interrupt Autovector |
| $32 \sim 47$ | 128 | 080 | SD | TRAP Instruction Vectors |
|  | 191 | OBF |  |  |
| 48~63* | 192 | OCO | SD | (Unassigned, reserved) |
|  | 255 | OFF |  |  |
| 64~255 | 256 | 100 | SD | User Interrupt Vectors |
|  | 1023 | 3FF |  |  |

[^13] No user peripheral devices should be assigned these numbers.

The third step is to save the current processor status, except for the reset exception. The current program counter value and the saved copy of the status register are stacked using the supervisor stack pointer as shown in Figure 39. The program counter value stacked usually points to the next unexecuted instruction, however for bus error and address error, the value stacked for the program counter is unpredictable, and may be incremented from the address of the instruction which
caused the error. Additional information defining the current context is stacked for the bus error and address error exceptions.

The last step is the same for all exceptions. The new program counter value is fetched from the exception vector. The processor then resumes instruction execution. Then instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started.


Figure 39 Exception Stack Order (Group 1, 2)


Figure 40 Exception Processing Sequence (Not Reset)

## MULTIPLE EXCEPTIONS

These paragraphs describe the processing which occurs when multiple exceptions arise simultaneously. Exceptions can be grouped according to their occurrence and priority. The Group 0 exceptions are reset, bus error, and address error. These exceptions cause the instruction currently being executed to be aborted, and the exeception processing to commence within two clock cycles. The Group 1 exceptions are trace and interrupt, as well as the privilege violations and illegal instructions. These exceptions allow the current instruction to execute to completion, but preempt the execution of the next instruction by forcing exception processing to occur (privilege violations and illegal instructions are detected when they are the next instruction to be executed). The Group 2 exceptions occur as part of the normal processing of instructions. The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these exceptions, the normal execution of an instruction may lead to exception processing.

Group 0 exceptions have highest priority, while Group 2 exceptions have lowest priority. Within Group 0, reset has highest priority, followed by address error and then bus error. Within Group 1, trace has priority over external interrupts, which in turn takes priority over illegal instruction and privilege violation. Since only one instruction can be executed at a time, there is no priority relation within Group 2.

The priority relation between two exceptions determines which is taken, or taken first, if the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the T-bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. A summary of exception grouping and priority is given in Table 20.

Table 20 Exception Grouping and Priority

| Group | Exception | Processing |
| :---: | :--- | :--- |
| 0 | Reset <br> Address Error <br> Bus Error | Exception processing begins <br> within two clock cycles. |
| 1 | Trace <br> Interrupt <br> Illegal <br> Privilege | Exception processing begins <br> before the next instruction |
| 2 | TRAP, TRAPV <br> CHK, <br> Zero Divide | Exception processing is started by <br> normal instruction execution |

## RECOGNITION TIMES OF EXCEPTIONS, HALT, AND BUS ARBITRATION

END OF A CLOCK CYCLE RESET<br>END OF A BUS CYCLE<br>ADDRESS ERROR<br>BUS ERROR<br>HALT<br>BUS ARBITRATION<br>END OF AN INSTRUCTION CYCLE<br>TRACE EXCEPTION<br>INTERRUPT EXCEPTIONS<br>ILLEGAL INSTRUCTION<br>UNIMPLEMENTED INSTRUCTION<br>PRIVILEGE VIOLATION<br>WITHIN AN INSTRUCTION CYCLE<br>TRAP, TRAPV<br>CHK<br>ZERO DIVIDE

## - EXCEPTION PROCESSING DETAILED DISCUSSION

Exceptions have a number of sources, and each exception has processing which is peculiar to it. The following paragraphs detail the sources of exceptions, how each arises, and how each is processed.

## RESET

The reset input provides the highest exception level. The processing of the reset signal is designed for system initiation, and recovery from catastrophic failure. Any processing in progress at the time of the reset is aborted and cannot be recovered. The processor is forced into the supervisor state, and the trace state is forced off. The processor interrupt priority mask is set at level seven. The vector number is internally generated to reference the reset exception vector at location 0 in the supervisor program space. Because no assumptions can be made about the validity of register contents, in particular the supervisor stack pointer, neither the program counter nor the status register is saved. The address contained in the first two words of the reset exception vector is fetched as the initial supervisor stack pointer, and the address in the last two words of the reset exception vector is fetched as the initial program counter. Finally, instruction execution is started at the address in the program counter. The power-up/restart code should be pointed to by the initial program counter.

The RESET instruction does not cause loading of the reset vector, but does assert the reset line to reset external devices. This allows the software to reset the system to a known state and then continue processing with the next instruction.


Figure 41 Reset Exception Processing

## INTERRUPTS

Seven levels of interrupt priorities are provided. Devices may be chained externally within interrupt priority levels, allowing an unlimited number of peripheral devices to interrupt the processor. Interrupt priority levels are numbered from one to seven, with level seven being the highest priority. The status register contains a three-bit mask which indicates the current processor priority, and interrupts are inhibited for all priority levels less than or equal to the current processor priority.

An interrupt request is made to the processor by encoding the interrupt request level on the interrupt request lines; a zero indicates no interrupt request. Interrupt requests arriving at the processor do not force immediate exception processing,
but are made pending. Pending interrupts are detected between instruction executions. If the priority of the pending interrupt is lower than or equal to the current processor priority, execution continues with the next instruction and the interrupt exception processing is postponed. (The recognition of level seven is slightly different, as explained in a following paragraph.)

If the priority of the pending interrupt is greater than the current processor priority, the exception processing sequence is started. First a copy of the status register is saved, and the privilege state is set to supervisor, tracing is suppressed, and the processor priority level is set to the level of the interrupt being acknowledged. The processor fetches the vector number from the interrupting device, classifying the reference as an interrupt acknowledge and displaying the level number of
the interrupt being acknowledged on the address bus. If external logic requests an automatic vectoring, the processor internally generates a vector number which is determined by the interrupt level number. If external logic indicates a bus error, the interrupt is taken to be spurious, and the generated vector number references the spurious interrupt vector. The processor then proceeds with the usual exception processing, saving the program counter and status register on the supervisor stack. The saved value of the program counter is the address of the instruction which would have been executed had the interrupt not been present. The content of the interrupt vector whose vector number was previously obtained is fetched and loaded into the program counter, and normal instruction execution commences in the interrupt handling routine. A flow chart for the interrupt acknowledge sequence is given in Figure 42, a timing diagram is given in Figure 43, and the interrupt exception timing sequence is shown in Figure 44.

Table 21 Internal Interrupt Level

| Level | 12 | 11 | 10 | Interrupt |
| :---: | :---: | :---: | :---: | :---: |
| 7 | 1 | 1 | 1 | Non-Maskable Interrupt |
| 6 | 1 | 1 | 0 |  |
| 5 | 1 | 0 | 1 |  |
| 4 | 1 | 0 | 0 |  |
| 3 | 0 | 1 | 1 |  |
| 2 | 0 | 1 | 0 |  |
| 1 | 0 | 0 | 1 |  |
| 0 | 0 | 0 | 0 | No Interrupt |

(NOTE) The internal interrupt mask level ( $12,11,10$ ) are inverted to the logic level applied to the pins ( $\mathrm{TPL}_{2}, \overline{\mathrm{P} \mathrm{L}_{1}}, \overline{\mathrm{P} \mathrm{P}_{0}}$ ).

## PROCESSOR

INTERRUPTING DEVICE

Grant Interrupt

1) Compare interrupt level in status register and wait for current instruction to complete
2) Place interrupt level on $A_{1}, A_{2}, A_{3}$
3) Set $R / \bar{W}$ to read
4) Set function code to interrupt acknowledge
5) Assert address strobe ( $\overline{\mathrm{AS}}$ )
6) Assert lower data strobe (UDS* ${ }^{*}$ and [DS)


Provide Vector Number

1) Place vector number of $D_{0} \sim D_{7}$
2) Assert data transfer acknowledge ( $\overline{\mathrm{DTACK}}$ )

3) Negate $\overline{\text { DTACK }}$

## Start Interrupt Processing

* Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing. The processor does not recognize anything on data lines $D_{8}$ through $D_{15}$ at this time.
Figure 42 Interrupt Acknowledge Sequence Flow Chart

* Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing. The processor does not recognize anything on data lines $D_{8}$ through $D_{15}$ at this time.

Figure 43 Interrupt Acknowledge Sequence Timing Diagram


Note: SSP refers to the value of the supervisor stack pointer before the interrupt occurs.
Figure 44 Interrupt Exception Timing Sequence

Priority level seven is a special case. Level seven interrupts cannot be inhibited by the interrupt priority mask, thus providing a "non-maskable interrupt" capability. An interrupt is generated each time the interrupt request level changes from some lower level to level seven. Note that a level seven interrupt may still be caused by the level comparison if the request level is a seven and the processor priority is set to a lower level by an instruction.

## UNINITIALIZED INTERRUPT

An interrupting device asserts VPA or provides an interrupt vector during an interrupt acknowledge cycle to the 68000 . If the vector register has not been initialized, the responding HD68000 Family peripheral will provide vector 15 , the unitialized interrupt vector. This provides a uniform way to recover from a programming error.

## SPURIOUS INTERRUPT

If during the interrupt acknowledge cycle no device responds by asserting $\overline{\text { DTACK }}$ or VPA, the bus error line should be asserted to terminate the vector acquisition. The processor separates the processing of this error from bus error by fetching the spurious interrupt vector instead of the bus error vector. The processor then proceeds with the usual exception processing.

## INSTRUCTION TRAPS

Traps are exceptions caused by instructions. They arise either from processor recognition of abnormal conditions during instruction execution, or from use of instructions whose normal behavior is trapping.

Some instructions are used specifically to generate traps. The TRAP instruction always forces an exception, and is useful for implementing system calls for user programs. The TRAPV and CHK instructions force an exception if the user program detects a runtime error, which may be an arithmetic overflow or a subscript out of bounds.

The signed divide (DIVS) and unsigned divide (DIVU) instructions will force an exception if a division operation is attempted with a divisor of zero.

## ILLEGAL AND UNIMPLEMENTED INSTRUCTIONS

Illegal instruction is the term used to refer to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is fetched, an illegal instruction exception occurs.

Word patterns with bits 15 through 12 equaling 1010 or 1111 are distinguished as unimplemented instructions and separate exception vectors are given to these patterns to permit efficient emulation. This facility allows the operating system to detect program errors, or to emulate unimplemented instructions in software.

ILLEGAL INSTRUCTION EXAMPLE


## PRIVILEGE VIOLATIONS

In order to provide system security, various instructions are privileged. An attempt to execute one of the privileged instructions while in the user state will cause an exception. The privileged instruction are:

$$
\begin{array}{ll}
\text { STOP } & \text { AND (word) Immediate to SR } \\
\text { RESET } & \text { EOR (word) Immediate to SR } \\
\text { RTE } & \text { OR (word) Immediate to SR } \\
\text { MOVE to SR } & \text { MOVE USP }
\end{array}
$$

## TRACING

To aid in program development, the 68000 includes a facility to allow instruction by instruction tracing. In the trace state, after each instruction is executed an exceptions is forced, allowing a debugging program to monitor the execution of the program under test.

The trace facility uses the T-bit in the supervisor portion of the status register. If the T-bit is negated (off), tracing is disabled, and instruction execution proceeds from instruction to instruction as normal. If the T-bit is asserted (on) at the beginning of the execution of an instruction, a trace exception will be generated after the execution of that instruction is completed. If the instruction is not executed. either because an interrupt is taken, or the instruction is illegal or privileged, the trace exception does not occur. The trace exception also does not occur if the instruction is aborted by a reset, bus
error, or address error exception. If the instruction is indeed executed and an interrupt is pending on completion, the trace exception is processed before the interrupt exception. If, during the execution of the instruction, an exception is forced by that instruction, the forced exception is processed before the trace exception.

As an extreme illustration of the above rules, consider the arrival of an interrupt during the execution of a TRAP instruction while tracing is enabled. First the trap exception is processed, then the trace exception, and finally the interrupt exception. Instruction execution resumes in the interrupt handler routine.


1. If, upon completion of an instruction, $T=1$. go to trace exception processing.
2. Execute trace exception sequence.
3. Execute trace service routine.
4. At the end of the service routine, execute return from exception (RTE).

## BUS ERROR

Bus error exceptions occur when the external logic requests that a bus error be processed by an exception. The current bus cycle which the processor is making is then aborted. Whether the processor was doing instruction or exception processing, that processing is terminated, and the processor immediately begins exception processing.

Exception processing for bus error follows the usual sequence of steps. The status register is copied, the supervisor state is entered, and the trace state is turned off. The vector number is generated to refer to the bus error vector. Since the processor was not between instructions when the bus error exception request was made, the context of the processor is
more detailed. To save more of this context, additional information is saved on the supervisor stack. The program counter and the copy of the status register are of course saved. The value saved for the program counter is advanced by some amount, one to five words beyond the address of the first word of the instruction which made the reference causing the bus error. If the bus error occurred during the fetch of the next instruction, the saved program counter has a value in the vicinity of the current instruction, even if the current instruction is a branch, a jump, or a return instruction. Besides the usual information, the processor saves its internal copy of the first word of the instruction being processed, and the address which was being accessed by the aborted bus cycle. Specific information about the access is also saved: whether it was a read or a write, whether the processor was processing an instruction or not, and the classification displayed on the function code outputs when the bus error occurred. The processor is processing an instruction if it is in the normal state or processing a Group 2 exception; the processor is not processing an instruction if it is processing a Group 0 or a Group 1 exception. Figure 45 illustrates how this information is organized on the supervisor stack. Although this information is not sufficient in general to effect full recovery from the bus error, it does allow software diag. nosis. Finally, the processor commences instruction processing at the address contained in the vector. It is the responsibility of the error handler routine to clean up the stack and determine where to continue execution.

If a bus error occurs during the exception processing for a bus error, address error, or reset, the processor is halted, and all processing cases. This simplifies the detection of catastrophic system failure, since the processor removes itself from the system rather than destroy all memory contents. Only the RES pin can restart a halted processor.

## ADDRESS ERROR

Address error exceptions occur when the processor attempts to access a word or a long word operand or an instruction at an odd address. The effect is much like an internally generated bus error, so that the bus cycle is aborted, and the processor ceases whatever processing it is currently doing and begins exception processing. After exception processing commences, the sequence is the same as that for bus error including the information that is stacked, except that the vector number refers to the address error vector instead. Likewise, if an address error occurs during the exception processing for a bus error, address error, or reset, the processor is halted. As shown in Figure 46, an address error will execute a short bus cycle followed by exception processing.

$R / \bar{W}(r e a d / w r i t e):$ write $=0$, read $=1 . I / N($ instruction $/$ not $):$ instruction $=0$, not $=1$
Figure 45 Exception Stack Order (Group 0)


Figure 46 Address Error Timing

## INTERFACE WITH HD6800 PERIPHERALS

Hitachi's extensive line of HD6800 peripherals are directly compatible with the 68000 . Some of these devices that are particularly useful are:

| HD6821 | Peripheral Interface Adapter |
| :--- | :--- |
| HD6840 | Programmable Timer Module |
| HD6843 | Floppy Disk Controller |
| HD6845S | CRT Controller |
| HD46508 | Analog Data Acquisition Unit |
| HD6850 | Asynchronous Communication Interface |
|  | Adapter |
| HD6852 | Synchronous Serial Data Adapter |

To interface the synchronous HD6800 peripherals with the asynchronous 68000 , the processor modifies its bus cycle to meet the HD6800 cycle requirements whenever an HD6800 device address is detected. This is possible since both processors use memory mapped I/O. Figure 48 is a flow chart of the interference operation between the processor and HD6800 devices.

- DATA TRANSFER OPERATION

Three signals on the processor provide the HD6800 interface. They are enable ( E ), valid memory address ( $\overline{\mathrm{VMA}}$ ), and valid peripheral address ( $\overline{\mathrm{VPA}}$ ). Enable corresponds to the E or $\phi_{2}$ signal in existing HD6800 systems. The bus frequency is one tenth of the incoming 68000 clock frequency. The timing of $\mathbf{E}$ allows 1 MHz peripherals to be used with an 8 MHz 68000 . Enable has a $60 / 40$ duty cycle; that is, it is low for six input clocks and high for four input clocks. This duty cycle allows the processor to do successive VPA accesses on successive E pulses.

HD6800 cycle timing is given in Figures 49 and 50. At state zero ( S 0 ) in the cycle, the address bus is in the high-impedance state. A function code is asserted on the function code output lines. One-half clock later, in state 1 the address bus is released from the high-impedance state.

During state 2 , the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the upper and/or lower data strobes are also asserted in state 2 . If the bus cycle is a write cycle,


Figure 47 Connection of HD6800 Peripherals
the read/write $(R / \bar{W})$ signal is switched to low (write) during state 2 . One half clock later, in state 3 , the write data is placed on the data bus, and in state 4 the data strobes are issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of VPA.

The VPA input signals the processor that the address on the bus is the address of an HD6800 device (or an area reserved for HD6800 devices) and that the bus should conform to the $\phi_{2}$ transfer characteristics of the HD6800 bus. Valid peripheral address is derived by decoding the address bus, conditioned by address strobe. Chip select for the HD6800 peripherals should be derived by decoding the address bus conditioned by VMA.

After the recognition of VPA, the processor assures that the Enable (E) is low, by waiting if necessary, and subsequently asserts VMA. Valid memory address is then used as part of the chip select equation of the peripheral. This ensures that the HD6800 peripherals are selected and deselected at the correct time. The peripheral now runs in cycle during the high portion of the $E$ signal. Figures 49 and 50 depict the best and worst case HD6800 cycle timing. This cycle length is dependent strictly upon when VPA is asserted in relationship to the E clock.
dependent strictly upon when $\overline{\mathrm{VPA}}$ is asserted in relationship to the E clock.

If we assume that external circuitry asserts VPA as soon as possible after the assertion of $\overline{\mathrm{AS}}$, then VPA will be recognized as being asserted on the falling edge of S 4 . In this case, no "extra" wait cycles will be inserted prior to the recognition of $\overline{\text { VPA }}$ asserted and only the wait cycles inserted to synchronize with the E clock will determine the total length of the cycle. In any case, the synchronization delay will be some integral number of clock cycles within the following two extremes:

1. Best Case - VPA is recognized as being asserted on the falling edge three clock cycles before E rises (or three clock cycles after E falls).
2. Worst Case -- VPA is recognized as being asserted on the falling edge two clock cycles before E rises(or four clock cycles after E falls).
During a read cycle, the processor latches the peripheral data in state 6. For all cycles, the processor negates the address and data strobes one half clock cycle later in state 7, and the Enable signal goes low at this time. Another half clock later, the address bus is put in the high-impedance state. During a write cycle, the data bus is put in the high-impedance state


Figure 48 HD6800 Interface Flow Chart


Figure 4968000 to HD6800 Peripheral Timing-Best Case


Figure 5068000 to HD6800 Peripheral Timing-Worst Case

HD68000/HD68HC000


Figure 5168000 to HD6800 Peripheral Timing Diagram


Figure 52 HD6800 Interface-Example 1

## (0) HITACHI



Figure 53 HD6800 Interface-Example 2
and the read/write signal is switched high. The peripheral logic must remove VPA within one clock after address strobe is negated.

Figure 51 shows the timing required by HD6800 peripherals, the timing specified for HD6800, and the corresponding timing for the 68000 . Two example systems with HD6800 peripherals are shown in Figures 52 and 53. The system in Figure 52 reserves the upper eight megabytes of memory for HD6800 peripherals. The system in Figure 53 is more efficient with memory and easily expandable, but more complex.
$\overline{\text { DTACK }}$ should not be asserted while $\overline{\mathrm{VPA}}$ is asserted. Notice that the 68000 VMA is active low, contrasted with the active high HD6800 VMA. This allows the processor to put its buses in the high-impedance state on DMA requests without inadvertently selecting peripherals.

## - INTERRUPT OPERATION

During an interrupt acknowledge cycle while the processor is fetching the vector, if VPA is asserted, the 68000 will assert VMA and complete a normal HD6800 read cycle as shown in Figure 54. The processor will then use an internally generated


* Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing. The processor does not recognize anything on data lines $D_{s}$ through $D_{1 s}$ at this time.

Figure 54 Autovector Operation Timing Diagram
vector that is a function of the interrupt being serviced. This process is known as autovectoring. The seven autovectors are vector numbers 25 through 31 (decimal).

This operates in the same fashion (but is not restricted to) HD6800 interrupt sequence. The basic difference is that there are six normal interrupt vectors and one NMI type vector. As with both the HD6800 and the 68000's normal vectored interrupt, the interrupt service routine can be located anywhere in the address space. This is due to the fact that while the vector numbers are fixed, the contents of the vector table entries are assigned by the user.

Since $\overline{\mathrm{VMA}}$ is asserted autovectoring, the HD6800 peripheral address decoding should prevent unintended accesses.

## - CONDITION CODES COMPUTATION

This provides a discussion of how the condition codes were developed, the meanings of each bit, how they are computed, and how they are represented in the instruction set details.

## - CONDITION CODE REGISTER

The condition code register portion of the status register contains five bits:

N - Negative
Z - Zero
V - Overflow
C - Carry
X - Extend
The first four bits are true condition code bits in that they reflect the condition of the result of a processor operation. The X-bit is an operand for multiprecision computations. The carry bit (C) and the multiprecision operand extend bit (X) are separate in the 68000 to simplify the programming model.

- CONDITION CODE REGISTER NOTATION

In the instruction set details, the description of the effect on the condition codes is given in the following form:
Condition Codes:
Where


N (negative) set if the most significant bit of the result is set. Cleared otherwise.
$\mathbf{Z}$ (zero) set if the result equals zero. Cleared otherwise.
$\mathbf{V}$ (overflow) set if there was an arithmetic overflow. This implies that the result is not representable in the operand size. Cleared otherwise.
C (carry) set if a carry is generated out of the most significant bit of the operands for an addition. Also set if a borrow is generated in a subtraction. Cleared otherwise.
$X$ (extend) transparent to data movement. When affected, it is set the same as the C-bit.
The notational convention that appears in the representation of the condition code registers is:

* set according to the result of the operation
-- not affected by the operation
0 cleared
1 set
U undefined after the operation


## - CONDITION CODE COMPUTATION

Most operations take a source operand and a destination operand, compute, and store the result in the destination location. Unary operations take a destination operand, compute, and store the result in the destination location. Table 22 details how each instruction sets the condition codes.

Table 22 Condition Code Computations

|  | Operations | X | N | Z | V | C | Special Definition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ABCD | * | U | $?$ | U | ? | $\begin{aligned} & C=\text { Decimal Carry } \\ & Z=Z \cdot \overline{R m} \cdot \ldots \cdot \overline{\mathrm{RO}} \end{aligned}$ |
|  | $\begin{aligned} & \text { ADD, ADDI, } \\ & \text { ADDQ } \end{aligned}$ | * | * | * | $?$ | $?$ | $\begin{aligned} & V=S m \cdot \mathrm{Dm} \cdot \overline{R m}+\overline{S m} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \mathrm{Dm}+\overline{\mathrm{Rm}} \cdot \mathrm{Dm}+\mathrm{Sm} \cdot \overline{\mathrm{Rm}} \end{aligned}$ |
|  | ADDX | * | * | ? | $?$ | $?$ | $\begin{aligned} & V=S m \cdot \mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\overline{S m} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & C=S m \cdot \overline{\mathrm{Dm}}+\overline{\mathrm{Rm}} \cdot \mathrm{Dm}+\mathrm{Sm} \cdot \overline{\mathrm{Rm}} \\ & Z=Z \cdot \overline{\mathrm{Rm}} \cdot \ldots \cdot \overline{\mathrm{RO}} \end{aligned}$ |
|  | AND, ANDI, EOR, EORI, MOVEQ, MOVE, OR, ORI, CLR, EXT, NOT, TAS, TST | - | * | * | 0 | 0 |  |
|  | CHK | - | $*$ | U | U | U |  |
|  | SUB, SUBI SUBQ | * | * | * | $?$ | $?$ | $\begin{aligned} & V=\overline{S m} \cdot \overline{D m} \cdot \overline{R m}+\overline{S m} \cdot \overline{D m} \cdot R m \\ & C=S m \cdot \overline{D m}+R m \cdot \overline{D m}+S m \cdot R m \end{aligned}$ |
|  | SUBX | * | * | $?$ | $?$ | $?$ | $\begin{aligned} & V=\overline{S m} \cdot \overline{D m} \cdot \overline{R m}+S m \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \overline{\mathrm{Dm}}+\mathrm{Rm} \cdot \overline{\mathrm{Dm}}+\mathrm{Sm} \cdot \mathrm{Rm} \\ & \mathrm{Z}=\mathrm{Z} \cdot \overline{\mathrm{Rm}} \cdot \ldots \cdot \overline{\mathrm{RO}} \end{aligned}$ |
|  | CMP, CMPI, CMPM | - | * | * | $?$ | $?$ | $\begin{aligned} & \mathrm{V}=\overline{\mathrm{Sm}} \cdot \overline{\mathrm{Dm}} \cdot \overline{\mathrm{Rm}}+\mathrm{Sm} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \overline{\mathrm{Dm}}+\mathrm{Rm} \cdot \overline{\mathrm{Dm}}+\mathrm{Sm} \cdot \mathrm{Rm} \end{aligned}$ |
|  | DIVS, DIVU | - | * | * | $?$ | 0 | $V=$ Division Overflow |
|  | MULS, MULU | - | * | * | 0 | 0 |  |
|  | SBCD, NBCD | * | $\mathbf{U}$ | ? | U | ? | $\begin{aligned} & \mathrm{C}=\text { Decimal Borrow } \\ & \mathrm{Z}=\mathrm{Z} \cdot \overline{\mathrm{Rm}} \cdot \ldots \cdot \overline{\mathrm{RO}} \end{aligned}$ |
|  | NEG NEGX | * | * | $?$ | $?$ | $?$ | $\begin{aligned} & V=D m \cdot R m, C=D m+R m \\ & V=D m \cdot R m, C=D m+R m \\ & Z=Z \cdot R m \cdot \ldots \cdot R O \end{aligned}$ |
|  | BTST, BCHG, BSET, BCLR | - | - | ? | - | - | $Z=\overline{\mathbf{D}} \mathbf{n}$ |
|  | ASL | * | * | * | $?$ | $?$ | $\begin{aligned} V= & D_{m} \cdot\left(\overline{D_{m-1}}+\ldots+\overline{D_{m-r}}\right) \\ & +\overline{D_{m}} \cdot\left(D_{m-1}+\ldots+D_{m-r}\right) \\ C= & D_{m-r+1} \end{aligned}$ |
|  | ASL ( $r=0$ ) | - | * | * | 0 | 0 |  |
|  | LSL, ROXL | * | * | * | 0 | ? | $C=D_{m-r+1}$ |
|  | LSR ( $\mathrm{r}=0$ ) | - | * | * | 0 | 0 |  |
|  | ROXL ( $\mathrm{r}=0$ ) | - | * | * | 0 | ? | $\mathrm{C}=\mathrm{X}$ |
|  | ROL | - | * | * | 0 | ? | $C=D_{m-r+1}$ |
|  | ROL ( $\mathrm{r}=0$ ) | - | * | * | 0 | 0 |  |
|  | ASR, LSR, ROXR | * | * | * | 0 | ? | $C=D_{\text {r }-1}$ |
|  | ASR, LSR ( $r=0$ ) | - | * | * | 0 | 0 |  |
|  | $R O X R(r=0)$ | - | * | * | 0 | ? | $C=X$ |
|  | ROR | - | * | * | 0 | $?$ | $C=D_{r-1}$ |
|  | ROR ( $\mathrm{r}=0$ ) | - | * | * | 0 | 0 |  |
| - Not affected <br> U Undefined <br> ? Other-see Special Definition |  |  | - General Case:$\begin{aligned} & X=C \\ & N=R m \\ & Z=\overline{R m} \cdot \ldots \cdot \overline{R O} \end{aligned}$ |  |  |  | Sm - Source operand most significant bit <br> Dm - Destination operand most significant bit <br> Rm - Result bit most significant bit <br> n - bit number <br> r - shift amount |

## - CONDITIONAL TESTS

Table 23 lists the condition names, encodings, and tests for the conditional branch and set instructions. The test associated with each condition is a logical formula based on the current state of the condition codes. If this formula evaluates to

1 , the condition succeeds, or is true. If the formula evaluates to 0 , the condition is unsuccessful, or false. For example, the T condition always succeeds, while the EQ condition succeeds only if the Z bit is currently set in the condition codes.

Table 23 Conditional Tests

| Mnemonic | Condition | Encoding | Test |
| :---: | :--- | :---: | :--- |
| T | true | 0000 | 1 |
| F | false | 0001 | 0 |
| HI | high | 0010 | $\overline{\mathrm{C}} \cdot \overline{\mathrm{Z}}$ |
| LS | low or same | 0011 | $\mathrm{C}+\mathrm{Z}$ |
| CC | carry clear | 0100 | $\overline{\mathrm{C}}$ |
| CS | carry set | 0101 | C |
| NE | not equal | 0110 | $\overline{\mathrm{Z}}$ |
| EQ | equal | 0111 | Z |
| VC | overflow clear | 1000 | $\overline{\mathrm{~V}}$ |
| VS | overflow set | 1001 | V |
| PL | plus | 1010 | $\bar{N}$ |
| MI | minus | 1011 | N |
| GE | greater or equal | 1100 | $\mathrm{~N} \cdot \mathrm{~V}+\overline{\mathrm{N}} \cdot \overline{\mathrm{V}}$ |
| LT | less than | 1101 | $\mathrm{~N} \cdot \overline{\mathrm{~V}+\overline{\mathrm{N}} \cdot \mathrm{V}}$ |
| GT | greater than | 1110 | $\mathrm{~N} \cdot \mathrm{~V} \cdot \overline{\mathrm{Z}}+\overline{\mathrm{N}} \cdot \overline{\mathrm{V}} \cdot \overline{\mathrm{Z}}$ |
| LE | less or equal | 1111 | $\mathrm{Z}+\mathrm{N} \cdot \overline{\mathrm{V}}+\overline{\mathrm{N}} \cdot \mathrm{V}$ |

## - INSTRUCTION SET

The following paragraphs provide information about the addressing categories and instruction set of the 68000 .

## - ADDRESSING CATEGORIES

Effective address modes may be categorized by the ways in which they may used. The following classifications will be used in the instruction definitions.
Data If an effective address mode may be used to refer to data operands, it is considered a data addressing effective address mode.
Memory If an effective address mode may be used to refer to memory operands, it is considered a memory addressing effective address mode.
Alterable If an effective address mode may be used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode.
Control If an effective address mode may be used to refer to memory operands without an associated size, it is considered a control addressing effective address mode.
Table 24 shows the various categories to which each of the effective address modes belong. Table 25 is the instruction set summary.

The status register addressing mode is not permitted unless it is explicitly mentioned as a legal addressing mode.

These categories may be combined so that additional, more restrictive, classifications may be defined. For example, the instruction descriptions use such classifications as alterable
memory or data alterable. The former refers to those addressing modes which are both alterable and memory addresses, and the latter refers to addressing modes which are both data and alterable.

## - INSTRUCTION PRE-FETCH

The 68000 uses a 2 -word tightly-coupled instruction prefetch mechanism to enhance performance. This mechanism is described in terms of the microcode operations involved. If the execution of an instruction is defined to begin when the microroutine for that instruction is entered, some features of the prefetch mechanism can be described.

1) When execution of an instruction begins, the operation word and the word following have already been fetched. The operation word is in the instruction decoder.
2) In the case of multi-word instructions, as each additional word of the instruction is used internally, a fetch is made to the instruction stream to replace it.
3) The last fetch from the instruction stream is made when the operation word is discarded and decoding is started on the next instruction.
4) If the instruction is a single-word instruction causing a branch, the second word is not used. But because this word is fetched by the preceding instruction, it is impossible to avoid this superfluous fetch. In the case of an interrupt or trace exception, both words are not used.
5) The program counter usually points to the last word fetched from the instruction stream.

Table 24 Effective Addressing Mode Categories

| Effective Address Modes | Mode | Register | Data | Addressing Categories |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Memory | Control | Alterable |
| Dn <br> An An@ | $\begin{aligned} & 000 \\ & 001 \\ & 010 \end{aligned}$ | register number register number register number | $\begin{aligned} & x \\ & \bar{x} \end{aligned}$ | $\overline{\bar{x}}$ | $\overline{\bar{x}}$ | $\begin{aligned} & \hline x \\ & x \\ & x \end{aligned}$ |
| An@+ <br> An@- <br> An@(d) | $\begin{aligned} & 011 \\ & 100 \\ & 101 \\ & \hline \end{aligned}$ | register number register number register number | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\overline{\bar{x}}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ |
| $\begin{aligned} & \text { An@(d, ix) } \\ & \text { xxx.W } \\ & \text { xxx.L } \end{aligned}$ | $\begin{aligned} & 110 \\ & 111 \\ & 111 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline \text { register number } \\ 000 \\ 001 \\ \hline \end{gathered}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \times \\ & \times \\ & \times \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ |
| PC@(d) <br> PC@(d, ix) <br> \#xxx | $\begin{aligned} & 111 \\ & 111 \\ & 111 \\ & \hline \end{aligned}$ | $\begin{aligned} & 010 \\ & 011 \\ & 100 \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | - |

The following example illustrates many of the features of instruction prefetch. The contents of memory are assumed to be as illustrated in Figure 55.


Figure 55 Instruction Prefetch Example, Memory Contents

The sequence we shall illustrate consists of the power-up reset, the execution of NOP, BRA, SUB, the taking of an interrupt, and the execution of the MOVE.W xxx. L to yyy.L.

The order of operations described within each microroutine is not exact, but is intended for illustrative purpose only.

| Microroutine | Operation | Location | Operand |
| :---: | :---: | :---: | :---: |
| Reset | Read | 0 | SSP High |
|  | Read | 2 | SSP Low |
|  | Read | 4 | PC High |
|  | Read | 6 | PC Low |
|  | Read | (PC) | NOP |
|  | Read <begin NOP> | +(PC) | BRA |
| NOP | Read <br> <begin BRA> | +(PC) | ADD |
| BRA | $\mathrm{PC}=\mathrm{PC}+\mathrm{d}$ | (PC) |  |
|  | Read <br> Read <begin SUB> | $\begin{aligned} & (P C) \\ & +(P C) \end{aligned}$ | DISP |
| SUBINTERRUPT | Read | $+(\mathrm{PC})$ | CMP |
|  | Read | $\operatorname{DISP}(A 0)$ $+(P C)$ | < src> SGE |
|  | <begin CMP> | <take INT> |  |
|  | Write | -(SSP) | PC Low |
| NTERRUPT | Read | <INT ACK> | Vector \# |
|  | Write | - (SSP) |  |
|  | Write | -(SSP) | PC High |
|  | Read | (VR) | PC High |
|  | Read | +(VR) | PC Low |
|  | Read | (PC) | MOVE |
|  | Read <begin MOVE> | $+(\mathrm{PC})$ | xxx High |
| MOVE | Read | + (PC) | xxx Low |
|  | Read | +(PC) | yyy High |
|  | Read | x×x | <sre> |
|  | Read Write | +(PC) | yyy Low <dest> |
|  | Read | + (PC) | NOP |
|  | Read <begin NOP> | +(PC) | SWAP |

Figure 56 Instruction Prefetch Example

- DATA PREFETCH

Normally the 68000 prefetches only instructions and not data. However, when the MOVEM instruction is used to move data from memory to registers, the data stream is prefetched in
\(\left.$$
\begin{array}{|llll|}\hline & \text { MOVEM.L } & & \begin{array}{l}\text { MOVE TWO } \\
\text { LONGWORDS }\end{array}
$$ <br>

A DO/D1 \& INTO REGISTERS\end{array}\right]\)|  |  |  |
| :--- | :--- | :--- |
| B | DC.W | 1 |
| DC.W | 2 | WORD 1 |
| D | DC.W | 3 |
| DC.W | 4 | WORD 2 |
| F | DC.W | 5 |
| DC.W | 6 | WORD 4 |
|  |  |  |

Figure 57 MOVEM Example, Memory Contents
order to optimize performance. As a result, the processor reads one extra word beyond the higher end of the source area. For example, the instruction sequence in Figure 57 will operate as shown in Figure 58.

| Assume Effective Address Evaluation is Already Done |  |  |  |
| :---: | :---: | :---: | :---: |
| Microroutine | Operation | Location | Other Operations |
| MOVEM | Read | A |  |
|  |  |  | Prepare to Fill D0 |
|  | Read | B | $\mathrm{A} \rightarrow \mathrm{DOH}$ |
|  | Read | C | $\mathrm{B} \rightarrow \mathrm{DOL}$ |
|  |  |  | Prepare to Fill D1 |
|  | Read | D | $\mathrm{C} \rightarrow \mathrm{D1H}$ |
|  | Read | E | $\mathrm{D} \rightarrow \mathrm{D} 1 \mathrm{~L}$ |
|  |  |  | Detect Register List Complete |

Figure 58 MOVEM Example, Operation Sequence

Table 25 Instruction Set


```
Note : Reter to Consition Cook Computations
-assfor condition COd
*: Word only value
*: Number of Program Bytes
                Opcode Bit Pattern Key
M, M. Destination EA Mode S. Size.00 Byte
01.Word
lu
lo- Long word
( In the MOV 
O1 Byte
```



## (0) HITACHI



```
Nas for condition Code
< Word only 
```

\#: Number of Program Bytes

- Number of Clock Periods

```
A; Address Register
```



```
e: Source Effective Adare
E. Destination Effective Address
```

In the move
01 Byte
10 . Long
10 - Long Word
11 Word

- INSTRUCTION FORMAT SUMMARY

This provides a summary of the first word in each instruction of the instruction set. Table 26 is an operation code (op-code) map which illustrates how bits 15 through 12 are used to specify the operations. The remaining paragraph groups the
instructions according to the op-code map.

$$
\begin{aligned}
\text { where, Size } & \text { Byte }=00 \\
& \text { Word }=01 \\
& \text { Long Word }=10
\end{aligned}
$$

Table 26 Operation Code Map

| Bits <br> 15 thru 12 | Operation |
| :--- | :--- |
| 0000 | Bit Manipulation/MOVEP/Immediate |
| 0001 | Move Byte |
| 0010 | Move Long |
| 0011 | Move Word |
| 0100 | Miscellaneous |
| 0101 | ADDQ/SUBQ/S ${ }_{\text {CC }} /$ DB $_{\mathrm{CC}}$ |
| 0110 | B CC $^{\text {M }}$ |
| 0111 | MOVEQ |
| 1000 | OR/DIV/SBCD |
| 1001 | SUB/SUBX |
| 1110 | (Unassigned) |
| 1011 | CMP/EOR |
| 1100 | AND/MUL/ABCD/EXG |
| 1101 | ADD/ADDX |
| 1110 | Shift/Rotate |
| 1111 | (Unassigned) |

(1) BIT MANIPULATION, MOVE PERIPHERAL, IMMEDIATE INSTRUCTIONS

Dynamic Bit

| 15 | 14 | 13 | 12 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | Register | 1 | Type |  | Effective Address |  |  |  |  |  |  |

Static Bit

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 7 | 6 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Type | Effective Address |  |  |  |  |

Bit Type Codes: TST $=00, \mathrm{CHG}=01, \mathrm{CLR}=10, \mathrm{SET}=11$

MOVEP
$\left.\begin{array}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}\hline 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1\end{array}\right)$

Op-Mode; Word to Reg $=100$, Long to Reg $=101$, Word to Mem $=110$, Long to Mem $=111$
OR Immediate

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Size |  | Effective Address |  |  |  |  |

AND Immediate


SUB Immediate


ADD Immediate

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

EOR Immediate

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Size |  | Effective Address |  |  |

CMP Immediate

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 1 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | Size |  | Effective Address |  |  |  |  |

(2) MOVE BYTE INSTRUCTION

MOVE Byte

(3) MOVE LONG INSTRUCTION

MOVE Long

(4) MOVE WORD INSTRUCTION

MOVE Word

(5) MISCELLANEOUS INSTRUCTIONS
negx

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Size |  | Effective Address |  |  |  |  |

MOVE from SR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |  | Effective Address |  |  |  |  |

CLR


NEG

$\left.\begin{array}{|c|c|c|c|c|c|c|c|c|c|c|c|c|}\hline 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3\end{array}\right) 2$| Effective Address |
| :--- |

MOVE to CCR

$$
\begin{array}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 \\
\hline
\end{array}
$$

NOT


MOVE to SR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | $\mathbf{1} 0$

NBCD

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | 1

PEA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |  | Effective Address |  |  |  |  |

SWAP

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Register |  |  |

MOVEM Registers to EA

EXTW

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Register |  |

EXTL

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |  |

TST

TAS

## MOVEM EA to Registers

\[

\]

TRAP

LINK

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 4 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | Register |

UNLK

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | Register |  |  |

MOVE to USP

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | Register |  |

MOVE from USP

RESET

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |

NOP

$$
\begin{array}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 0 & 1 \\
\hline
\end{array}
$$

STOP

$$
\begin{array}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 1 & 0 \\
\hline
\end{array}
$$

RTE

RTS

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |

TRAPV

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |

RTR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |

JSR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

JMP

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

CHK

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 |  | Register | 1 | 1 | 0 | 1 | Effective Address |  |  |

LEA

(6) ADD QUICK, SUBTRACT QUICK, SET CONDITIONALLY, DECREMENT INSTRUCTIONS

ADDO


SUBQ

$\mathrm{S}_{\mathrm{cc}}$

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

$\mathrm{DB}_{\mathrm{cc}}$

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 1 |  | Condition | 1 | 1 | 0 | 0 | 1 | Register |  |  |  |  |

(7) BRANCH CONDITIONALLY, BRANCH TO SUBROUTINE INSTRUCTION $B_{c c}$

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 1 | 0 |  | Condition |  |  | 8 bit Displacement |  |  |  |  |  |  |

BSR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |  | 0 |  |  |  |  |  |

(8) MOVE QUICK INSTRUCTION

MOVEQ

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | 00

(9) OR, DIVIDE, SUBTRACT DECIMAL INSTRUCTIONS

OR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | 0


| $B$ | $W$ | $L$ |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 000 | 001 | 010 | Dn $\vee E A \rightarrow D n$ |  |
| 100 | 101 | 110 | EA $\vee D n \rightarrow E A$ |  |

DIVU

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

DIVS


SBCD

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

R/M (register/memory): register - register = 0, memory - memory = 1
(10) SUBTRACT, SUBTRACT EXTENDED INSTRUCTIONS

SUB

| 15 | 14 | 13 | 12 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 1 | Register |  |  | Op-Mode |  |  | Effective Address |  |  |  |  |

\[

\]

SUBX
$\left.\begin{array}{|l|l|l|l|l|c|c|c|c|c|c|c|c|}\hline 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3\end{array}\right) 2$

R/M (register/memory): register - register $=0$, memory - memory $=1$
(11) COMPARE, EXCLUSIVE OR INSTRUCTIONS

CMP


CMPM

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 1 | 1 |  | Register | 1 | Size | 0 | 0 | 1 | Register |  |  |

EOR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 1 | 1 |  | Register | 1 | Size |  | Effective Address |  |  |

(12) AND, MULTIPLY, ADD DECIMAL, EXCHANGE INSTRUCTIONS

AND


MULU

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | 1

MULS

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | Register | 1 | 1 | 1 | 1 | 0 |  |  |  |

ABCD

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | 0

$$
R / M \text { (register/memory): register }- \text { register }=0, \text { memory }- \text { memory }=1
$$

EXGD

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | Data Register | 1 | 0 | 1 | 0 | 0 | 0 | Data Register |  |  |

EXGA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 0 | 0 | Address Register | 1 | 0 | 1 | 0 | 0 | 1 | Address Register |  |  |  |

EXGM

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | Data Register | 1 | 1 | 0 | 0 | 0 | 1 | Address Register |  |  |

(13) ADD, ADD EXTENDED INSTRUCTIONS

ADD


ADDX

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | 1

$R / M$ (register/memory) : register - register $=0$, memory - memory $=1$
(14) SHIFT/ROTATE INSTRUCTIONS

Data Register Shifts


Memory Shifts

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | 0 | Type | $d$ | 1 | 1 | 1 | 0 |  |  |

Shift Type Codes: $A S=00, L S=01$, ROX $=10, R O=11$
d (direction): Right $=0$, Left $=1$
$\mathrm{i} / \mathrm{r}$ (count source): Immediate Count $=0$, Register Count $=1$

## - INSTRUCTION EXECUTION TIMES

The following paragraphs contain listings of the instruction execution times in terms of external clock (CLK) periods. In this timing data, it is assumed that both memory read and write cycle times are four clock periods. Any wait states caused by a longer memory cycle must be added to the total instruction time. The number of bus read and write cycles for each instruction is also included with the timing data. This data is enclosed in parenthesis following the execution periods and is shown as: ( $\mathrm{r} / \mathrm{w}$ ) where r is the number of read cycles and $\mathbf{w}$ is the number of write cycles.
(NOTE) The number of periods includes instruction fetch and all applicable operand fetches and stores.

## - EFFECTIVE ADDRESS OPERAND CALCULATION TIMING

Table 27 lists the number of clock periods required to compute an instruction's effective address. It includes fetching of any extension words, the address computation, and fetching of the memory operand. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). Note there are no write cycles involved in processing the effective address.

## - MOVE INSTRUCTION CLOCK PERIODS

Table 28 and 29 indicate the number of clock periods for the move instruction. This data includes instruction fetch, operand reads, and operand writes. The number of bus read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ).

- STANDARD INSTRUCTION CLOCK PERIODS

The number of clock periods shown in Table 30 indicates
the time required to perform the operations, store the results, and read the next instruction. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

In Table 30 the headings have the following meanings: $\mathbf{A n}=$ address register operand, $\mathrm{Dn}=$ data register operand, ea $=$ an operand specified by an effective address, and $M=$ memory effective address operand.

## - IMMEDIATE INSTRUCTION CLOCK PERIODS

The number of clock periods shown in Table 31 includes the time to fetch immediate operands, perform the operations, store the results, and read the next operation. The number of bus read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

In Table 31, the headings have the following meanings: \# = immediate. operand, $\mathrm{Dn}=$ data register operand, $\mathrm{An}=\mathrm{ad}-$ dress register operand, $\mathrm{M}=$ memory operand, $\mathrm{CCR}=$ condition code register, and SR = status register.

## - SINGLE OPERAND INSTRUCTION CLOCK PERIODS

Table 32 indicates the number of clock periods for the single operand instructions. The number of bus read and write cycles is shown in parenthesis as: $(\mathrm{r} / \mathrm{w})$. The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 27 Effective Address Calculation Timing

| Addressing Mode |  | Byte, Word | Long |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{Dn} \\ & \text { An } \\ & \hline \end{aligned}$ | Data Register Direct Address Register Direct | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ |
| $\begin{aligned} & \text { An@ } \\ & \text { An@ + } \end{aligned}$ | Memory <br> Address Register Indirect <br> Address Register Indirect with Postincrement | $\begin{aligned} & 4(1 / 0) \\ & 4(1 / 0) \end{aligned}$ | $\begin{aligned} & 8(2 / 0) \\ & 8(2 / 0) \end{aligned}$ |
| An@ - <br> An@(d) | Address Register Indirect with Predecrement Address Register Indirect with Displacement | $\begin{aligned} & 6(1 / 0) \\ & 8(2 / 0) \end{aligned}$ | $\begin{aligned} & 10(2 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & \text { An@(d, ix)* } \\ & x_{x x . W}{ }^{*} \end{aligned}$ | Address Register Indirect with Index Absolute Short | $\begin{gathered} \hline 10(2 / 0) \\ 8(2 / 0) \end{gathered}$ | $\begin{aligned} & 14(3 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| xxx. L <br> PC@(d) | Absolute Long <br> Program Counter with Displacement | $\begin{gathered} 12(3 / 0) \\ 8(2 / 0) \end{gathered}$ | $\begin{aligned} & 16(4 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & \text { PC@(d, ix)* } \\ & \# \times x x \end{aligned}$ | Program Counter with Index Immediate | $\begin{gathered} 10(2 / 0) \\ 4(1 / 0) \end{gathered}$ | $\begin{gathered} 14(3 / 0) \\ 8(2 / 0) \end{gathered}$ |

[^14]Table 28 Move Byte and Word Instruction Clock Periods

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | An@ | An@ + | An@ - | An@(d) | An@(d, ix)* | xxx.W | xxx.L |
| Dn | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) |
| An | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) |
| An@ | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |
| An@+ | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |
| An@ - | 10(2/0) | 10(2/0) | 14(2/1) | 14(2/1) | 14(2/1) | 18(3/1) | 20(3/1) | 18(3/1) | 22(4/1) |
| An@(d) | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| An@(d, ix)* | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) |
| xxx. W | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| xxx.L | 16(4/0) | 16(4/0) | 20(4/1) | 20(4/1) | 20(4/1) | 24(5/1) | 26(5/1) | 24(5/1) | 28(6/1) |
| PC@(d) | 12(2/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| PC@(d, ix)* | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) |
| \#xxx | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |

* The size of the index register (ix) does not affect execution time.

Table 29 Move Long Instruction Clock Periods

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | An@ | An@ + | An@ - | An@ (d) | An@(d, ix)* | xxx. W | xxx. L |
| Dn | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) |
| An | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) |
| An@ | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |
| An@ + | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |
| An@ - | 14(3/0) | 14(3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 26(4/2) | 28(4/2) | 26(4/2) | 30(5/2) |
| An@(d) | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| An@(d, ix)* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| xxx.W | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| xxx.L | 20(5/0) | 20(5/0) | 28(5/2) | 28(5/2) | 28(5/2) | 32(6/2) | 34(6/2) | 32(6/2) | 36(7/2) |
| PC@(d) | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| PC@(d, ix)* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| \#xxx | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |

* The size of the index register (ix) does not affect execution time.

Table 30 Standard Instruction Clock Periods

| Instruction | Size | op $\langle$ ea>, An | op $<$ ea $>$, Dn | op Dn, <M > |
| :---: | :---: | :---: | :---: | :---: |
| ADD | Byte, Word | $8(1 / 0)+$ | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)+* *$ | $6(1 / 0)+* *$ | 12(1/2) + |
| AND | Byte, Word | - | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | - | $6(1 / 0)+* *$ | 12(1/2) + |
| CMP | Byte, Word | $6(1 / 0)+$ | 4(1/0) + | - |
|  | Long | $6(1 / 0)+$ | $6(1 / 0)+$ | - |
| DIVS | - | - | 158(1/0) + * | - |
| DIVU | - | - | 140(1/0) +* | - |
| EOR | Byte, Word | - | 4(1/0) *** | $8(1 / 1)+$ |
|  | Long | - | 8(1/0) *** | 12(1/2) + |
| MULS | - | - | 70(1/0) + * | - |
| MULU | - | - | 70(1/0) + * | - |
| OR | Byte, Word | - | 4(1/0) + | $8(1 / 1)+$ |
|  | Long | - | $6(1 / 0)+* *$ | 12(1/2) + |
| SUB | Byte, Word | $8(1 / 0)+$ | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)+$ ** | $6(1 / 0)+$ ** | 12(1/2) + |

## + add effective address calculation time

* indicates maximum value
** total of 8 clock periods for instruction if the effective address is register direct
*** only available effective address mode is data register direct

DIVS, DIVU - The divide algorithm used by the 68000 provides less than $10 \%$ difference between the best and worst case timings.
MULS, MULU - The multiply algorithm requires $38+2 n$ clocks when $n$ is defined as MULU; $n=$ the number of ones in the < ea > MULS; $n=$ concatanate the $<$ ea $>$ with a zero as the LSB; $n$ is the resultant number of 10 or 01 patterns in the 17-bit source; i.e. worst case happens when the source is $\$ 5555$.

Table 31 Immediation Instruction Clock Periods

| Instruction | Size | op \#, Dn | op \#, An | op \#, M | op \#, CCR/SR |
| :--- | :--- | ---: | :---: | :---: | :---: |
|  | Byte, Word | $8(2 / 0)$ | - | $12(2 / 1)+$ | - |
|  | Long | $16(3 / 0)$ | - | $20(3 / 2)+$ | - |
| ADDO | Byte, Word | $4(1 / 0)$ | $8(1 / 0)^{*}$ | $8(1 / 1)+$ | - |
|  | Long | $8(1 / 0)$ | $8(1 / 0)$ | $12(1 / 2)+$ | - |
| ANDI | Byte, Word | $8(2 / 0)$ | - | $12(2 / 1)+$ | $20(3 / 0)$ |
|  | Long | $16(3 / 0)$ | - | $20(3 / 1)+$ | - |
| CMPI | Byte, Word | $8(2 / 0)$ | $8(2 / 0)$ | $8(2 / 0)+$ | - |
|  | Long | $14(3 / 0)$ | $14(3 / 0)$ | $12(3 / 0)+$ | - |
| EORI | Byte, Word | $8(2 / 0)$ | - | $12(2 / 1)+$ | $20(3 / 0)$ |
|  | Long | $16(3 / 0)$ | - | $20(3 / 2)+$ | - |
| MOVEO | Long | $4(1 / 0)$ | - | - | - |
|  | Byte, Word | $8(2 / 0)$ | - | $12(2 / 1)+$ | $20(3 / 0)$ |
|  | Long | $16(3 / 0)$ | - | $20(3 / 2)+$ | - |
| SUBI | Byte, Word | $8(2 / 0)$ | - | $12(2 / 1)+$ | - |
|  | Long | $16(3 / 0)$ | - | $20(3 / 2)+$ | - |
| SUBO | Byte, Word | $4(1 / 0)$ | $8(1 / 0)^{*}$ | $8(1 / 1)+$ | - |
|  | Long | $8(1 / 0)$ | $8(1 / 0)$ | $12(1 / 2)+$ | - |

+ add effective address calculation time
* word only

Table 32 Single Operand Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :--- | :--- | :---: | :---: |
|  | Byte, Word | $4(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)$ | $12(1 / 2)+$ |
| NBCD | Byte | $6(1 / 0)$ | $8(1 / 1)+$ |
|  | Byte, Word | $4(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)$ | $12(1 / 2)+$ |
| NEGX | Byte, Word | $4(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)$ | $12(1 / 2)+$ |
| NOT | Byte, Word | $4(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)$ | $12(1 / 2)+$ |
| SCC | Byte, False | $4(1 / 0)$ | $8(1 / 1)+$ |
|  | Byte, True | $6(1 / 0)$ | $8(1 / 1)+$ |
| TAS | Byte | $4(1 / 0)$ | $10(1 / 1)+$ |
|  | Byte, Word | $4(1 / 0)$ | $4(1 / 0)+$ |
|  | Long | $4(1 / 0)$ | $4(1 / 0)+$ |

+ add effective address calculation time


## - SHIFT/ROTATE INSTRUCTION CLOCK PERIODS

Table 33 indicates the number of clock periods for the shift and rotate instructions. The number of bus read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

- BIT MANIPULATION INSTRUCTION CLOCK PERIODS

Table 34 indicates the number of clock periods required for the bit manipulation instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

- CONDITIONAL INSTRUCTION CLOCK PERIODS

Table 35 indicates the number of clock periods required for the conditional instructions. The number of bus read and write cycles is indicated in parenthesis as: $(\mathrm{r} / \mathrm{w})$. The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

- JMP, JSR, LEA, PEA, MOVEM INSTRUCTION CLOCK PERIODS
Table 36 indicates the number of clock periods required for the jump, jump to subroutine, load effective address, push effective address, and move multiple registers instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w).

Table 33 Shift/Rotate Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :---: | :--- | :---: | :---: |
|  | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| LSR, LSL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| ROR, ROL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| ROXR, ROXL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |

Table 34 Bit Manipulation Instruction Clock Periods

| Instruction | Size | Dynamic |  | Static |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Register | Memory | Register | Memory |
| BCHG | Byte | - | $8(1 / 1)+$ | - | $12(2 / 1)+$ |
|  | Long | $8(1 / 0)^{*}$ | - | $12(2 / 0)^{*}$ | - |
| BCLR | Byte | - | $8(1 / 1)+$ | - | $12(2 / 1)+$ |
|  | Long | $10(1 / 0)^{*}$ | - | $14(2 / 0)^{*}$ | - |
| BSET | Byte | - | $8(1 / 1)+$ | - | $12(2 / 1)+$ |
|  | Long | $8(1 / 0)^{*}$ | - | $12(2 / 0)^{*}$ | - |
| BTST | Byte | - | $4(1 / 0)+$ | - | $8(2 / 0)+$ |
|  | Long | $6(1 / 0)$ | - | $10(2 / 0)$ | - |

+ add effective address calculation time
* indicates maximum value

Table 35 Conditional Instruction Clock Periods

| Instruction | Displacement | Trap or Branch Taken | Trap of Branch Not Taken |
| :---: | :---: | :---: | :---: |
| $\mathrm{B}_{\mathrm{cc}}$ | Byte | 10(2/0) | 8(1/0) |
|  | Word | 10(2/0) | 12(2/0) |
| BRA | Byte | 10(2/0) | - |
|  | Word | 10(2/0) | - |
| BSR | Byte | 18(2/2) | - |
|  | Word | 18(2/2) | - |
| $\mathrm{DB}_{\text {cc }}$ | CC true | - | 12(2/0) |
|  | CC false | 10(2/0) | 14(3/0) |
| CHK | - | 40(5/3) + * | 10(1/0) + |
| TRAP | - | 34(4/3) | - |
| TRAPV | - | 34(5/3) | 4(1/0) |

+ add effective address calculation time
* indicates maximum value

Table 36 JMP, JSR, LEA, PEA, MOMEM Instruction Clock Periods

| Instr | Size | An@ | An@ + | An@ - | An@(d) | An@(d, ix) * | xxx.W | xxx.L | PC@(d) | PC@(d, ix) * |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | - | 8(2/0) | - | - | 10(2/0) | 14(3/0) | 10(2/0) | 12(3/0) | 10(2/0) | 14(3/0) |
| JSR | - | 16(2/2) | - | - | 18(2/2) | 22(2/2) | 18(2/2) | 20(3/2) | 18(2/2) | 22(2/2) |
| LEA | - | 4(1/0) | - | - | 8(2/0) | 12(2/0) | 8(2/0) | 12(3/0) | 8(2/0) | 12(2/0) |
| PEA | - | 12(1/2) | - | - | 16(2/2) | 20(2/2) | 16(2/2) | 20(3/2) | 16(2/2) | 20(2/2) |
| MOVEM | Word | $\begin{gathered} 12+4 n \\ (3+n / 0) \end{gathered}$ | $\begin{array}{r} 12+4 n \\ (3+n / 0) \end{array}$ | - | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 18+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 20+4 n \\ (5+n / 0) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 18+4 n \\ (4+n / 0) \end{array}$ |
| $M \rightarrow R$ | Long | $\begin{array}{r} 12+8 n \\ (3+2 n / 0) \end{array}$ | $\begin{array}{r} 12+8 n \\ (3+2 n / 0) \end{array}$ | - | $\begin{gathered} 16+8 n \\ (4+2 n / 0) \end{gathered}$ | $\begin{array}{r} 18+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 20+8 n \\ (5+2 n / 0) \end{array}$ | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 18+8 n \\ (4+2 n / 0) \end{array}$ |
| MOVEM | Word | $\begin{aligned} & 8+4 n \\ & (2 / n) \end{aligned}$ | - | $\begin{aligned} & 8+4 n \\ & (2 / n) \end{aligned}$ | $\begin{array}{r} 12+4 n \\ (3 / n) \end{array}$ | $\begin{array}{r} 14+4 n \\ (3 / n) \end{array}$ | $\begin{array}{r} 12+4 n \\ (3 / n) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4 / n) \end{array}$ | - | - |
| $\mathrm{R} \rightarrow \mathrm{M}$ | Long | $\begin{gathered} 8+8 n \\ (2 / 2 n) \\ \hline \end{gathered}$ | - | $\begin{array}{r} 8+8 n \\ (2 / 2 n) \\ \hline \end{array}$ | $\begin{aligned} & 12+8 n \\ & (3 / 2 n) \\ & \hline \end{aligned}$ | $\begin{aligned} & 14+8 n \\ & (3 / 2 n) \\ & \hline \end{aligned}$ | $\begin{aligned} & 12+8 n \\ & (3 / 2 n) \\ & \hline \end{aligned}$ | $\begin{aligned} & 16+8 n \\ & (4 / 2 n) \\ & \hline \end{aligned}$ | - | $-$ |

$n$ is the number of registers to move

* is the size of the index register (ix) does not affect the instruction's execution time
- MULTI-PRECISION INSTRUCTION CLOCK PERIODS

Table 37 indicates the number of clock periods for the multiprecision instructions. The number of clock periods includes the time to fetch both operands, perform the operations, store
the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ).

In Table 37, the headings have the following meanings: $\mathrm{Dn}=$ data register operand and $\mathbf{M}=$ memory operand.

Table 37 Multi-Precision Instruction Clock Periods

| Instruction | Size | op Dn, Dn | op M, M |
| :--- | :--- | :---: | :---: |
| ADDX | Byte, Word | $4(1 / 0)$ | $18(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $30(5 / 2)$ |
| CMPM | Byte, Word | - | $12(3 / 0)$ |
|  | Long | - | $20(5 / 0)$ |
| SUBX | Byte, Word | $4(1 / 0)$ | $18(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $30(5 / 2)$ |
| ABCD | Byte | $6(1 / 0)$ | $18(3 / 1)$ |
| SBCD | Byte | $6(1 / 0)$ | $18(3 / 1)$ |

## - MISCELLANEOUS INSTRUCTION CLOCK PERIODS

Table 38 indicates the number of clock periods for the following miscellaneous instructions. The number of bus read and write cycles is shown in parenthesis as: $(\mathbf{r} / \mathrm{w})$. The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

## - EXCEPTION PROCESSING CLOCK PERIODS

Table 39 indicates the number of clock periods for exception processing. The number of clock periods includes the time for all stacking, the vector fetch, and the fetch of the first instruction of the handler routine. The number of bus read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ).

Table 38 Miscellaneous Instruction Clock Periods

| Instruction | Size | Register | Memory | Register $\rightarrow$ Memory | Memory $\rightarrow$ Register |
| :--- | :---: | :---: | :---: | :---: | :---: |
| MOVE from SR | - | $6(1 / 0)$ | $8(1 / 1)+$ | - | - |
| MOVE to CCR | - | $12(2 / 0)$ | $12(2 / 0)+$ | - | - |
| MOVE to SR | - | $12(2 / 0)$ | $12(2 / 0)+$ | - | - |
| MOVEP | Word | - | - | $16(2 / 2)$ | $16(4 / 0)$ |
|  | Long | - | - | $24(2 / 4)$ | $24(6 / 0)$ |
| EXG | - | $6(1 / 0)$ | - | - | - |
| EXT | Word | $4(1 / 0)$ | - | - | - |
|  | Long | $4(1 / 0)$ | - | - | - |
| MOVE from USP | - | $16(2 / 2)$ | - | - | - |
| MOVE to USP | - | $4(1 / 0)$ | - | - | - |
| NOP | - | $4(1 / 0)$ | - | - | - |
| RESET | - | $4(1 / 0)$ | - | - | - |
| RTE | - | $132(1 / 0)$ | - | - | - |
| RTR | - | $20(5 / 0)$ | - | - | - |
| RTS | - | $20(5 / 0$ | - | - | - |
| STOP | - | $16(4 / 0)$ | - | - | - |
| SWAP | - | $4(0 / 0)$ | - | - | - |
| UNLK | - | $4(1 / 0)$ | - | - | - |

+ add effective address calculation time

Table 39 Exception Processing Clock Periods

| Exception | Periods |
| :--- | :--- |
| Reset ${ }^{* *}$ | $38.5(6 / 0)$ |
| Address Error | $50(4 / 7)$ |
| Bus Error | $50(4 / 7)$ |
| Interrupt | $44(5 / 3)^{*}$ |
| Illegal Instruction | $34(4 / 3)$ |
| Privileged Violation | $34(4 / 3)$ |
| Trace | $34(4 / 3)$ |

* The interrupt acknowledge bus cycle is assumed to take four external clock periods.
** Indicates the time from when RES and HALT are first sampled as negated to when instruction execution starts.
- MASK VERSION

| Type No. | Mask version |
| :--- | :---: |
| HD68000-8 |  |
| HD68000-10 |  |
| HD68000-12 |  |
| HD68000Y8 |  |
| HD68000Y-10 |  |
| HD68000Y-12 |  |
| HD68000P8 |  |
| HD68000Ps8 |  |
| HD68000CR8 | $68000 U$ |

The difference of function between mask version 68000 S1 and 68000 U is only as following (Figure 59).

The function of HD68HC000 is as same as mask version 68000U.


Figure 59 Address Error Timing

## - NOTE FOR USE

- Power Supply Circuit

When designing $V_{C C}$ and $V_{S S}$ pattern of the circuit board, the capacitors need to be located nearest to $V_{C C}$ and $V_{S S}$ as shown in the Figure 60.

$1 \mu \mathrm{~F} / 35 \mathrm{~V}$ Tantalum Capacitor (2 pairs)
Figure 60 Power Supply Circuit

# Hitachi America, Ltd. <br> SEMICONDUCTOR and IC DIVISION 

Hitachi America, Ltd.
Semiconductor \& IC Division
Hitachi Plaza
2000 Sierra Point Parkway
Brisbane, CA 94005-1819
Telephone: 415-589-8300
Telex: 17-1581
Twx: 910-338-2103
FAX: 415-583-4207

## REGIONAL OFFICES

MID-ATLANTIC REGION
Hitachi America, Ltd 1700 Galloping Hill Rd.
Kenilworth, NJ 07033
201/245-6400

## NORTHEAST REGION

Hitachi America, Ltd 5 Burlington Woods Drive Burlington, MA 01803 617/229-2150

NORTH CENTRAL REGION
Hitachi America, Ltd. 500 Park Blvd., Suite 415
Itasca, IL 60143
312/773-4864

## NORTHWEST REGION

Hitachi America, Ltd.
2000 Sierra Point Parkway
Brisbane, CA 94005-1819
415/589-8300
SOUTH CENTRAL REGION
Hitachi America, Ltd.
Two Lincoln Centre, Suite 865
5420 LBJ Freeway
Dallas, TX 75240
214/991-4510

## SOUTHWEST REGION

Hitachi America, Ltd.
18300 Von Karman Avenue,
Suite 730
Irvine, CA 92715
714/553-8500

## SOUTHEAST REGION

Hitachi America, Ltd
4901 N.W. 17th Way, Suite 302
Fort Lauderdale, FL 33309 305/491-6154

## AUTOMOTIVE

Hitachi America, Ltd.
6 Parklane Blvd., \#558
Dearborn, MI 48126
313/271-4410

## DISTRICT OFFICES

Hitachi America, Ltd.
3800 W. 80th Street
Suite 1050
Bloomington, MN 55431
612/896-3444
Hitachi America, Ltd.
21 Old Main Street, Suite 104
Fishkill, NY 12524
914/897-3000

Hitachi America, Ltd.
6161 Savoy Dr., Suite 850
Houston, TX 77036
713/974-0534
Hitachi (Canadian) Ltd.
2625 Queensview Dr.
Ottawa, Ontario, Canada K2A 3Y4
613/596-2777

Hitachi America, Ltd.
401 Harrison Oaks Blvd.
Suite \#317
Cary, NC 27513
919/481-3908

Our Standards Set Standards
Hitachi America, Ltd.
Semiconductor and IC Division
Hitachi Plaza
2000 Sierra Point Parkway, Brisbane, CA 94005-1819
1-415-589-8300


[^0]:    * In power-down mode, maximum power dissipation is less than 42 mW .
    - $T_{a}=25^{\circ} C, V_{c}=5 V$
    ** As RES input has histeresis character, applied voltage up to 2.4 V is regarded as "Low" level when it goes up from 0 V .
    **** Does not include EXTAL and XTAL, which are crystal inputs.

[^1]:    ${ }^{4} \mathbf{t}_{\text {RES }}=\mathbf{2 0} \mathbf{~ m s e c} \mathbf{~ m i n}$. for $S$ type, $50 \mathrm{msec} \mathbf{m i n}$. for $R$ type.

[^2]:    * $T_{\mathrm{a}}=25^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V}$
    ** As RES input has histeresis character, applied voltage up to 2.4 V is regarded as "Low" level when it goes up from 0 V .
    *** Does not include EXTAL and XTAL, which are crystal inputs.
    *** In power-down mode, maximum power dissipation is less than 42 mW .

[^3]:    * Except $P_{21}$

[^4]:    * $\mathrm{Ta}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

[^5]:    ~ Number of MPU cycles (less possible push pull or indexed-mode cycles) \# Number of program bytes
    Denotes unused opcode

[^6]:    - $\mathrm{Ta}=\mathbf{2 5}{ }^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

[^7]:    LEGEND:

[^8]:    - External address.
    * R: Read-only register, W: Write-only register, R/W: Read/Write register.
    ". When empty bit is in the register, it is set to " 1 ".
    **** Register for test. Don't access this register.

[^9]:    Symbols: $\mathbf{O p}=$ Operation

[^10]:    Legend: ~ Number of MPU cycles (less possible push pull or indexed-mode cycles)
    \# Number of program bytes

    * Denotes unused opcode

[^11]:    BUSREO - Bus Request (IN)
    Another device may request use of the bus by asserting BUSREQ LOW. The CPU will stop executing instructions and

[^12]:    * Z80 is a registered trademark of Zilog, Inc.
    ** Copied from Z80* CTC Data Sheet (April, 1985)

[^13]:    SP: Supervisor program, SD: Supervisor data

    * Vector numbers 12, 13, 14, 16 through 23 and 48 through 63 are reserved for future enhancements by Hitachi.

[^14]:    - The size of the index register (ix) does not affect execution time.

