

August, 1987



8/16-BIT PERIPHERAL LSI  
DATA BOOK



#U70-A

# **8/16-BIT PERIPHERAL LSI DATA BOOK**

#U70-A



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

### **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 semiconductor-applied 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 .....                 | vii |
| • Introduction of Packages .....              | 1   |
| • Reliability and Quality Assurance .....     | 12  |
| • Reliability Test Data of Microcomputer..... | 18  |

## ■ DATA SHEETS

|                                                                          |     |
|--------------------------------------------------------------------------|-----|
| HD6321 Peripheral Interface Adapter (CMOS).....                          | 27  |
| HD6821 Peripheral Interface Adapter (NMOS).....                          | 27  |
| HD6340 Programmable Timer Module (CMOS).....                             | 49  |
| HD6840 Programmable Timer Module (NMOS).....                             | 49  |
| HD6844 Direct Memory Access Controller (NMOS).....                       | 66  |
| HD6345 CRT Controller (CMOS).....                                        | 99  |
| HD6445 CRT Controller (CMOS).....                                        | 99  |
| HD6845R CRT Controller (NMOS).....                                       | 139 |
| HD6845S CRT Controller (NMOS).....                                       | 139 |
| HD6350 Asynchronous Communications Interface Adapter (CMOS) .....        | 181 |
| HD6850 Asynchronous Communications Interface Adapter (NMOS) .....        | 181 |
| HD6852 Synchronous Serial Data Adapter (NMOS).....                       | 193 |
| HD46508 Analog Data Acquisition Unit (NMOS) .....                        | 207 |
| HD46508A Analog Data Acquisition Unit (NMOS) .....                       | 207 |
| HD63084 Document Image Pre-Processor (CMOS).....                         | 227 |
| HD63085Y Document Image Compression and Expansion Processor (CMOS) ..... | 259 |
| HD68230 Parallel Interface Timer (NMOS).....                             | 273 |
| HD63310 Smart Dual Port RAM (CMOS) .....                                 | 305 |
| HD63450 Direct Memory Access Controller (CMOS) .....                     | 307 |
| HD68450 Direct Memory Access Controller (NMOS) .....                     | 356 |
| HD63463 Hard Disk Controller (CMOS) .....                                | 404 |
| HD63484 Advanced CRT Controller (CMOS).....                              | 472 |
| HD63485 Graphic Memory Interface Controller (Hi-Bi CMOS).....            | 531 |
| HD63486 Graphic Video Attribute Controller (Hi-Bi CMOS).....             | 567 |
| HD68562 Dual Universal Serial Communications Controller (NMOS) .....     | 600 |
| HD63645 LCD Timing Controller (CMOS) .....                               | 603 |
| HD64941 Asynchronous Communications Interface (NMOS) .....               | 641 |
| HD146818 Real Time Clock Plus RAM (CMOS) .....                           | 644 |
| Hitachi Sales Offices .....                                              | 663 |



## **GENERAL INFORMATION**

- **Quick Reference Guide**
- **Introduction of Packages**
- **Reliability and Quality Assurance**
- **Reliability Test Data of Microcomputer**



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



# QUICK REFERENCE GUIDE

## ■ 8-BIT MICROCOMPUTER PERIPHERAL

| Division                                                                                        | Type No <sup>†</sup> | LSI Characteristics |                       |                    |                               |                      | Function       | Compatibility                                                    | Reference Page               |
|-------------------------------------------------------------------------------------------------|----------------------|---------------------|-----------------------|--------------------|-------------------------------|----------------------|----------------|------------------------------------------------------------------|------------------------------|
|                                                                                                 |                      | Process             | Clock Frequency (MHz) | Supply Voltage (V) | Operating*** Temperature (°C) | Package <sup>†</sup> |                |                                                                  |                              |
| PIA                                                                                             | HD6321*              |                     | CMOS                  | 1                  | 5.0                           | -20~+75              | DP-40<br>FP-54 | Peripheral Interface Adapter                                     | 27                           |
|                                                                                                 | HD63A21*             |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD63B21*             |                     |                       | 2                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD6821               | HD46821             | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-40          | Peripheral Interface Adapter                                     | MC6821<br>MC68A21<br>MC68B21 |
|                                                                                                 | HD68A21              | HD468A21            |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD68B21              | HD468B21            |                       | 2                  |                               |                      |                |                                                                  |                              |
| PTM                                                                                             | HD6340*              |                     | CMOS                  | 1                  | 5.0                           | -20~+75              | DP-28          | Programmable Timer Module                                        | 49                           |
|                                                                                                 | HD63A40*             |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD63B40*             |                     |                       | 2                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD6840               |                     | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-28          | Programmable Timer Module                                        | MC6840<br>MC68A40<br>MC68B40 |
|                                                                                                 | HD68A40              |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD68B40              |                     |                       | 2                  |                               |                      |                |                                                                  |                              |
| DMAC                                                                                            | HD6844               | HD46504             | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-40          | Direct Memory Access Controller                                  | MC6844<br>MC68A44<br>MC68B44 |
|                                                                                                 | HD68A44              | HD46504-1           |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD68B44              | HD46504-2           |                       | 2                  |                               |                      |                |                                                                  |                              |
| CRTC                                                                                            | HD6345*              |                     | CMOS                  | 1                  | 5.0                           | -20~+75              | DP-40          | CRT Controller (4.5 MHz High Speed Display) 6800 type bus timing | 99                           |
|                                                                                                 | HD63A45*             |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD63B45*             |                     |                       | 2                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD6845               | HD46505R            | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-40          | CRT Controller (3.0 MHz High Speed Display)                      | MC6845<br>MC68A45<br>MC68B45 |
|                                                                                                 | HD68A45              | HD46505R-1          |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD68B45              | HD46505R-2          |                       | 2                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD6845S              | HD46505S-1          | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-40          | CRT Controller (3.7 MHz High Speed Display)                      | 139                          |
|                                                                                                 | HD68A45S             | HD46505S-1          |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD68B45S             | HD46505S-2          |                       | 2                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD6445-4*            |                     | CMOS                  | 4                  | 5.0                           | -20~+75              | DP-40          | CRT Controller (4.5 MHz High Speed Display) 80 type bus timing   | 99                           |
| ACIA                                                                                            | HD6350               |                     | CMOS                  | 1                  | 5.0                           | -20~+75              | DP-24          | Asynchronous Communications Interface Adapter                    | 181                          |
|                                                                                                 | HD63A50              |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD63B50              |                     |                       | 2                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD6850               | HD46850             | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-24          | Asynchronous Communications Interface Adapter                    | 181                          |
| SSDA                                                                                            | HD68A50              | HD468A50            | NMOS                  | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD68A52              | HD468A52            | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-24          | Synchronous Serial Data Adapter                                  | MC6852<br>MC68A52            |
| ADU                                                                                             | HD46508              |                     | NMOS                  | 1                  | 5.0                           | -20~+75              | DP-24          | Analog Data Aquisition Unit                                      | 207                          |
|                                                                                                 | HD46508-1            |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD46508A             |                     |                       | 1                  |                               |                      |                |                                                                  |                              |
|                                                                                                 | HD46508A-1           |                     |                       | 1.5                |                               |                      |                |                                                                  |                              |
| RTC                                                                                             | HD146818             |                     | CMOS                  | 1                  | 5.0                           | 0~+70                | DP-24<br>FP-24 | Real Time Clock plus RAM                                         | MC146818                     |
| DIPP                                                                                            | HD63084*             |                     | CMOS                  | 10(max)            | 5.0                           | 0~+70                | DP-64S         | Document Image Pre-Processor                                     | 227                          |
| DICEP                                                                                           | HD63085*             |                     | CMOS                  | 32(max)            | 5.0                           | 0~+70                | PC-72          | Document Image Compression and Expansion Processor               | 259                          |
| S-DPRAM                                                                                         | HD63310**            |                     | CMOS                  |                    | 5.0                           | 0~+70                | DP-48          | Smart Dual Port RAM                                              | 305                          |
| LCTC                                                                                            | HD63645**            |                     | CMOS                  | 2                  | 5.0                           | -20~+75              | FP-80          | LCD Timing Controller                                            | 603                          |
| ACI                                                                                             | HD64941**            |                     | NMOS                  |                    | 5.0                           | 0~+70                | DP-24N         | Asynchronous Communications Interface                            | SCN264I                      |
| * Preliminary ** Under development *** Wide temperature range (-40~+85°C) version is available. |                      |                     |                       |                    |                               |                      |                |                                                                  |                              |

\* Preliminary \*\* Under development \*\*\* Wide temperature range (-40~+85°C) version is available.  
<sup>†</sup>DP: Plastic DIP, FP: Flat Plastic Package, DC: Ceramic DIP, PGA: Pin Grid Array, PC: Ceramic Pin Grid Array,  
CP: Plastic Leaded Chip Carrier



## QUICK REFERENCE GUIDE

---

### ■ 16-BIT MICROCOMPUTER PERIPHERAL

| Division | Type No.    | LSI Characteristics |                       |                    |                            |                                             | Function                                        | Compatibility       | Reference Page |
|----------|-------------|---------------------|-----------------------|--------------------|----------------------------|---------------------------------------------|-------------------------------------------------|---------------------|----------------|
|          |             | Process             | Clock Frequency (MHz) | Supply Voltage (V) | Operating Temperature (°C) | Package                                     |                                                 |                     |                |
| PI/T     | HD68230P8*  | NMOS                | 8                     | 5.0                | 0~+70                      | DP-48                                       | Parallel Interface Timer                        | MC68230L8           | 273            |
|          | HD68230P10* |                     | 10                    |                    |                            |                                             |                                                 | MC68230L10          |                |
| DMAC     | HD63450-6*  | CMOS                | 6                     | 5.0                | 0~+70                      | DC-64<br>DP-64<br>DP-64S<br>PGA-68<br>CP-68 | Direct Memory Access Controller                 |                     | 307            |
|          | HD63450-8*  |                     | 8                     |                    |                            |                                             |                                                 |                     |                |
|          | HD63450-10* |                     | 10                    |                    |                            |                                             |                                                 |                     |                |
|          | HD63450-12* |                     | 12.5                  |                    |                            |                                             |                                                 |                     |                |
|          | HD68450-4   | NMOS                | 4                     | 5.0                | 0~+70                      | DP-64<br>PGA-68                             | Direct Memory Access Controller                 | MC68450L4           | 356            |
|          | HD68450-6   |                     | 6                     |                    |                            |                                             |                                                 | MC68450L6           |                |
|          | HD68450-8   |                     | 8                     |                    |                            |                                             |                                                 | MC68450L8           |                |
|          | HD68450-10  |                     | 10                    |                    |                            |                                             |                                                 |                     |                |
| HDC      | HD63463-4   | CMOS                | 4                     | 5.0                | 0~+70                      | DC-48<br>DP-48<br>CP-52                     | Hard Disk Controller                            |                     | 404            |
|          | HD63463-6   |                     | 6                     |                    |                            |                                             |                                                 |                     |                |
|          | HD63463-8   |                     | 8                     |                    |                            |                                             |                                                 |                     |                |
| ACRTC    | HD63484-4   | CMOS                | 4                     | 5.0                | 0~+70                      | DC-64<br>DP-64<br>CP-68                     | Advanced CRT Controller                         |                     | 472            |
|          | HD63484-6   |                     | 6                     |                    |                            |                                             |                                                 |                     |                |
|          | HD63484-8   |                     | 8                     |                    |                            |                                             |                                                 |                     |                |
| GMIC     | HD63485**   | Hi-Bi CMOS          |                       | 5.0                | 0~+70                      | DP-64S<br>CP-68                             | Graphic Memory Interface Controller             |                     | 531            |
| GVAC     | HD63486**   | Hi-Bi CMOS          |                       | 5.0                | 0~+70                      | DP-64S<br>CP-68                             | Graphic Video Attribute Controller              |                     | 567            |
| DUSCC    | HD68562**   | NMOS                | 4 (max)               | 5.0                | 0~+70                      | DC-48                                       | Dual Universal Serial Communications Controller | MC68562<br>SCN68562 | 600            |

\* Preliminary

\*\* Under development



## ■ 8/16 BIT MICROCOMPUTER PERIPHERAL

| Division                | Type No.    | LSI Characteristics |                       |                    |                            |                         | Function                                                            | Compatibility       | Reference Page |
|-------------------------|-------------|---------------------|-----------------------|--------------------|----------------------------|-------------------------|---------------------------------------------------------------------|---------------------|----------------|
|                         |             | Process             | Clock Frequency (MHz) | Supply Voltage (V) | Operating Temperature (°C) | Package †               |                                                                     |                     |                |
| Display Control         | HD6845      | NMOS                | 1                     | 5.0                | -20~+75'                   | DP-40                   | CRT Controller (3.0 MHz High Speed Display)                         | MC6845              | 139            |
|                         | HD68A45     |                     | 1.5                   |                    |                            |                         |                                                                     | MC68A45             |                |
|                         | HD68B45     |                     | 2                     |                    |                            |                         |                                                                     | MC68B45             |                |
|                         | HD6845S     | NMOS                | 1                     | 5.0                | -20~+75                    | DP-40                   | CRT Controller (3.7 MHz High Speed Display)                         |                     | 139            |
|                         | HD68A45S    |                     | 1.5                   |                    |                            |                         |                                                                     |                     |                |
|                         | HD68B45S    |                     | 2                     |                    |                            |                         |                                                                     |                     |                |
|                         | HD6345*     | CMOS                | 1                     | 5.0                | -20~+75                    | DP-40                   | CRT Controller (4.5 MHz High Speed Display)<br>6800 type bus timing |                     | 99             |
|                         | HD63A45*    |                     | 1.5                   |                    |                            |                         |                                                                     |                     |                |
|                         | HD63B45*    |                     | 2                     |                    |                            |                         |                                                                     |                     |                |
|                         | HD6445-4*   | CMOS                | 4                     | 5.0                | -20~+75                    | DP-40                   | CRT Controller (4.5 MHz High Speed Display)<br>80 type bus timing   |                     | 99             |
| LCTC                    | HD63645**   | CMOS                | 2                     | 5.0                | -20~+75                    | FP-80                   | LCD Timing Controller                                               |                     | 603            |
| ACRTC                   | HD63484-4   | CMOS                | 4                     | 5.0                | 0~+70                      | DC-64<br>DP-64<br>CP-68 | Advanced CRT Controller                                             |                     | 472            |
|                         | HD63484-6   |                     | 6                     |                    |                            |                         |                                                                     |                     |                |
|                         | HD63484-8   |                     | 8                     |                    |                            |                         |                                                                     |                     |                |
| GMIC                    | HD63485**   | Hi-Bi CMOS          |                       | 5.0                | 0~+70                      | DP-64S<br>CP-68         | Graphic Memory Interface Controller                                 |                     | 531            |
| GVAC                    | HD63486**   | Hi-Bi CMOS          |                       | 5.0                | 0~+70                      | DP-64S<br>CP-68         | Graphic Video Attribute Controller                                  |                     | 567            |
| Communication Interface | HD6850      | NMOS                | 1                     | 5.0                | -20~+75                    | DP-24                   | Asynchronous Communications Interface Adapter                       | MC6850              | 181            |
|                         | HD68A50     |                     | 1.5                   |                    |                            |                         |                                                                     | MC68A50             |                |
|                         | HD6350      | CMOS                | 1                     | 5.0                | -20~+75                    | DP-24                   | Asynchronous Communications Interface Adapter                       |                     | 181            |
|                         | HD63A50     |                     | 1.5                   |                    |                            |                         |                                                                     |                     |                |
|                         | HD63B50     |                     | 2                     |                    |                            |                         |                                                                     |                     |                |
|                         | HD6852      | NMOS                | 1                     | 5.0                | -20~+75                    | DP-24                   | Synchronous Serial Data Adapter                                     | MC6852              | 193            |
|                         | HD68A52     |                     | 1.5                   |                    |                            |                         |                                                                     | MC68A52             |                |
| DUSCC                   | HD68562**   | NMOS                | 4 (max)               | 5.0                | 0~+70                      | DC-48                   | Dual Universal Serial Communications Control                        | SCN68562<br>MC68562 | 600            |
| ACI                     | HD64941**   | NMOS                |                       | 5.0                | 0~+70                      | DP-24N                  | Asynchronous Communications Control                                 | SCN2641             | 641            |
| Timer Control           | HD6840      | NMOS                | 1                     | 5.0                | -20~+75                    | DP-28                   | Programmable Timer Module                                           | MC6840              | 49             |
|                         | HD68A40     |                     | 1.5                   |                    |                            |                         |                                                                     | MC68A40             |                |
|                         | HD68B40     |                     | 2                     |                    |                            |                         |                                                                     | MC68B40             |                |
|                         | HD6340*     | CMOS                | 1                     | 5.0                | -20~+75                    | DP-28                   | Programmable Timer Module                                           |                     | 49             |
|                         | HD63A40*    |                     | 1.5                   |                    |                            |                         |                                                                     |                     |                |
|                         | HD63B40*    |                     | 2                     |                    |                            |                         |                                                                     |                     |                |
| RTC                     | HD146818    | CMOS                | 1                     | 5.0                | 0~+70                      | DP-24<br>FP-24          | Real Time Clock Plus RAM                                            | MC146818            | 644            |
| PI/T                    | HD68230P8*  | NMOS                | 8                     | 5.0                | 0~+70                      | DP-48                   | Parallel Interface Timer                                            | MC68230L8           | 273            |
|                         | HD68230P10* |                     | 10                    |                    |                            |                         |                                                                     | MC68230L10          |                |
| File Control            | HD63463-4   | CMOS                | 4                     | 5.0                | 0~+70                      | DC-48<br>DP-48<br>CP-52 | Hard Disk Controller                                                |                     | 404            |
|                         | HD63463-6   |                     | 6                     |                    |                            |                         |                                                                     |                     |                |
|                         | HD63463-8   |                     | 8                     |                    |                            |                         |                                                                     |                     |                |

\* Preliminary \*\* Under development \*\*\* Wide temperature range (-40 ~ +85°C) version is available

† DP: Plastic DIP, DC: Ceramic DIP, FP: Flat Plastic Package, PGA: Pin Grid Array,

PC: Ceramic Pin Grid Array, CP: Plastic Leaded Chip Carrier



## QUICK REFERENCE GUIDE

### ■ 8/16 BIT MICROCOMPUTER PERIPHERAL

| Division                 |          | Type No.    | LSI Characteristics |                       |                    |                               |                                                    | Function                               | Compatibility | Reference Page |  |
|--------------------------|----------|-------------|---------------------|-----------------------|--------------------|-------------------------------|----------------------------------------------------|----------------------------------------|---------------|----------------|--|
|                          |          |             | Process             | Clock Frequency (MHz) | Supply Voltage (V) | Operating*** Temperature (°C) | Package †                                          |                                        |               |                |  |
| System Control           | DMAC     | HD6844      | NMOS                | 1                     | 5.0                | -20~+75                       | DP-40                                              | 8-Bit Direct Memory Access Controller  | MC6844        | 66             |  |
|                          |          | HD68A44     |                     | 1.5                   |                    |                               |                                                    |                                        | MC68A44       |                |  |
|                          |          | HD68B44     |                     | 2                     |                    |                               |                                                    |                                        | MC68B44       |                |  |
|                          |          | HD68450-4   |                     | 4                     |                    |                               |                                                    | 16-bit Direct Memory Access Controller | MC68450L4     | 356            |  |
|                          |          | HD68450-6   | NMOS                | 6                     | 5.0                | 0~+70                         | DC-64 PGA-68                                       |                                        | MC68450L6     |                |  |
|                          |          | HD68450-8   |                     | 8                     |                    |                               |                                                    |                                        | MC68450L8     |                |  |
|                          |          | HD68450-10  |                     | 10                    |                    |                               |                                                    |                                        | MC68450L10    |                |  |
|                          |          | HD63450-6*  | CMOS                | 6                     | 5.0                | 0~+70                         | DC-64 DP-64 DP-64S PGA-68 CP-68                    | 16-Bit Direct Memory Access Controller |               | 307            |  |
|                          |          | HD63450-8*  |                     | 8                     |                    |                               |                                                    |                                        |               |                |  |
|                          |          | HD63450-10* |                     | 10                    |                    |                               |                                                    |                                        |               |                |  |
|                          |          | HD63450-12* |                     | 12.5                  |                    |                               |                                                    |                                        |               |                |  |
| Peripheral Interface     | S-DPRAM  | HD63310**   | CMOS                |                       | 5.0                | 0~+70                         | DP-48                                              | Smart Dual Port RAM                    |               | 305            |  |
|                          | PIA      | HD6821      | NMOS                | 1                     | 5.0                | -20~+75                       | DP-40                                              | Peripheral Interface Adapter           | MC6821        | 27             |  |
|                          |          | HD68A21     |                     | 1.5                   |                    |                               |                                                    |                                        | MC68A21       |                |  |
|                          |          | HD68B21     |                     | 2                     |                    |                               |                                                    |                                        | MC68B21       |                |  |
|                          |          | HD6321*     | CMOS                | 1                     | 5.0                | -20~+75                       | DP-40 FP-54                                        | Peripheral Interface Adapter           |               | 27             |  |
|                          |          | HD63A21*    |                     | 1.5                   |                    |                               |                                                    |                                        |               |                |  |
|                          |          | HD63B21*    |                     | 2                     |                    |                               |                                                    |                                        |               |                |  |
|                          | ADU      | HD46508     | NMOS                | 1                     | 5.0                | -20~+75                       | DP-40                                              | Analog Data Acquisition Unit           |               | 207            |  |
|                          |          | HD46508-1   |                     | 1.5                   |                    |                               |                                                    |                                        |               |                |  |
|                          |          | HD46508A    |                     | 1                     |                    |                               |                                                    |                                        |               |                |  |
|                          |          | HD46508A-1  |                     | 1.5                   |                    |                               |                                                    |                                        |               |                |  |
| Document Image Processor | PI/T     | HD68230P8*  | NMOS                | 8                     | 5.0                | 0~+70                         | DP-48                                              | Parallel Interface Timer               | MC68230L8     | 273            |  |
|                          |          | HD68230P10* |                     | 10                    |                    |                               |                                                    |                                        | MC68230L10    |                |  |
| DIPP                     | HD63084* | CMOS        | 10 (max)            | 5.0                   | 0~+70              | DP-64S                        | Document Image Pre-Processor                       |                                        |               | 227            |  |
| DICEP                    | HD63085* | CMOS        | 32 (max)            | 5.0                   | 0~+70              | PC-72                         | Document Image Compression and Expansion Processor |                                        |               | 259            |  |

\* Preliminary      \*\* Under development      \*\*\* Wide temperature range (-40 ~ +85°C) version is available.

† DP: Plastic DIP, DC: Ceramic DIP, FP: Flat Plastic Package, PGA: Pin Grid Array, PC: Ceramic Pin Grid Array, CP: Plastic leaded chip carrier



# INTRODUCTION OF PACKAGES

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.

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



DIP; DUAL IN LINE PACKAGE  
S-DIP; SHRINK DUAL IN LINE PACKAGE  
PGA; PIN GRID ARRAY  
FLAT-DIP; FLAT DUAL IN LINE PACKAGE  
FLAT-QUIP; FLAT QUAD IN LINE PACKAGE  
CC; CHIP CARRIER  
SOP; SMALL OUTLINE PACKAGE  
FPP; FLAT PLASTIC PACKAGE  
PLCC; PLASTIC LEADED CHIP CARRIER  
LCC ; LEADLESS CHIP CARRIER

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



## INTRODUCTION OF PACKAGES

### 2. Type No. and Package Code Indication

Type No. of Hitachi 8/16 bit microcomputer peripheral device is followed by package material and outline specifications, as shown below. The package type used for each device

is identified by code as follows, illustrated in the data sheet of each device.

When ordering, please write the package code beside the type number.

#### Type No. Indication

HD X X X X P

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

Type No.; HD63450PS8

Package designation

#### Package Classification

|               |                                     |
|---------------|-------------------------------------|
| No Indication | : Ceramic DIP                       |
| P             | ; Plastic DIP                       |
| F (FP)        | ; SOP, FPP                          |
| CP            | ; PLCC                              |
| Y             | ; PGA (16-bit microcomputer device) |

#### Package Code Indication

DP—64S

Outline  
D ; DIP  
C ; CC  
F ; FLAT  
P ; PGA

Materials  
P ; Plastic  
G ; Glass Sealed ceramic  
C ; Ceramic

Number of Pins

Additional Outline  
S; S-DIP  
N; Neet (skinny)

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

Package Code Indication;

PGA-68

Package Classification

Number of Pins



**3. Package Dimensional Outline**

Hitachi multi-chip microcomputer device employs the pack-

ages 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          | DP-24 DP-24N<br>DP-28 DP-40<br>DP-64 |
|                       | Shrink Outline         |                      | Ceramic          | DC-48<br>DC-64                       |
|                       | S-DIP                  | Plastic              |                  | DP-64S                               |
| Surface Mounting Type | PGA                    | Glass Sealed Ceramic |                  | PGA-68 PC-72                         |
|                       | FLAT-DIP (SOP)         | Plastic              |                  | FP-24                                |
| Flat Package          | FLAT-QUIP (FPP)        |                      |                  | FP-54<br>FP-80                       |

## Plastic DIP

## ● DP-24

Scale : 1/1



(Unit: mm)

## ● DP-24N

Scale: 1/1



(Unit: mm)



## INTRODUCTION OF PACKAGES

### ● DP-28

Scale : 1/1



(Unit: mm)

### ● DP-40

Scale : 1/1



Unit (mm)

### ● DP-48



(Unit: mm)



## ● DP-64

Scale : 1/1



(Unit: mm)



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

## INTRODUCTION OF PACKAGES

### Ceramic DIP

#### • DC-48



Scale : 1/1

(Unit: mm)

#### • DC-64

Scale : 1/1



(Unit: mm)



## Shrink Type Plastic DIP

## ● DP-64S

Scale: 1/1



(Unit: mm)

## Pin Grid Array

## ● PGA-68

Scale : 1/1



(Unit: mm)

## ● PC-72

Scale: 1/1



(Unit: mm)



## INTRODUCTION OF PACKAGES

### Plastic Leaded Chip Carrier

<PLCC>

#### ● CP-52

Scale: 1/1



(Unit: mm)

#### ● CP-68

Scale: 1/1



(Unit: mm)

#### **Flat Package**

<SOP>

•FP-24

Scale : 1/1



(Unit: mm)

<FPP>

•FP-54

Scale : 3/2



(Unit: mm)

• FP-80

Scale: 3/2



(Unit: mm)



### 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\text{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\text{C}$ . The surface temperature of the resin should be kept at  $235^\circ\text{C}$  max. for 10 minutes or less.

- (1) The temperature of the leads should be kept at  $260^\circ\text{C}$  for 10 minutes or less.
- (2) The temperature of the resin should be kept at  $235^\circ\text{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\text{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.



Meaning of Each Mark

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



# RELIABILITY AND QUALITY ASSURANCE

## 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 run 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 Figure 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 Figure 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 Figure 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, automation 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 Sub-materials

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 cleanliness in manufacturing site are executed with paying intensive attention on buildings, facilities, air-conditioning 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,<br>Parts                  | Important<br>Control Items                                                                                                             | Point for Check                                                                                                             |
|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Wafer                               | Appearance<br>Dimension<br>Sheet Resistance<br>Defect Density<br>Crystal Axis                                                          | Damage and Contamination on Surface<br>Flatness<br>Resistance<br>Defect Numbers                                             |
| Mask                                | Appearance<br>Dimension<br>Restoration<br>Gradation                                                                                    | Defect Numbers, Scratch Dimension Level<br>Uniformity of Gradation                                                          |
| Fine<br>Wire for<br>Wire<br>Bonding | Appearance<br>Dimension<br>Purity<br>Elongation Ratio                                                                                  | Contamination, Scratch, Bend, Twist<br>Purity Level<br>Mechanical Strength                                                  |
| Frame                               | Appearance<br>Dimension<br>Processing Accuracy<br>Plating<br>Mounting Characteristics                                                  | Contamination, Scratch Dimension Level<br>Bondability, Solderability Heat Resistance                                        |
| Ceramic<br>Package                  | Appearance<br>Dimension<br>Leak Resistance<br>Plating<br>Mounting Characteristics<br>Electrical Characteristics<br>Mechanical Strength | Contamination, Scratch Dimension Level<br>Airtightness<br>Bondability, Solderability Heat Resistance<br>Mechanical Strength |
| Plastic                             | Composition<br>Electrical Characteristics<br>Thermal Characteristics<br>Molding Performance<br>Mounting Characteristics                | Characteristics of Plastic Material<br>Molding Performance<br>Mounting Characteristics                                      |



| Process                         | Control Point | Purpose of Control                               |
|---------------------------------|---------------|--------------------------------------------------|
| Wafer                           | Wafer         | Characteristics, Appearance                      |
| Surface Oxidation               | Oxidation     | Appearance, Thickness of Oxide Film              |
| Photo Resist                    | Photo Resist  | Dimension, Appearance                            |
| Inspection on Photo Resist      | Diffusion     | Diffusion Depth, Sheet Resistance                |
| △ PQC Level Check               |               | Gate Width                                       |
| Diffusion                       |               | Characteristics of Oxide Film                    |
| Inspection on Diffusion         |               | Breakdown Voltage                                |
| △ PQC Level Check               |               |                                                  |
| Evaporation                     | Evaporation   | Thickness of Vapor Film, Scratch, Contamination  |
| Inspection on Evaporation       |               |                                                  |
| △ PQC Level Check               |               |                                                  |
| Wafer Inspection                | Wafer         | Thickness, $V_{TH}$ Characteristics              |
| Inspection on Chip              | Chip          | Electrical Characteristics                       |
| Electrical Characteristics      |               |                                                  |
| Chip Scribe                     |               | Appearance of Chip                               |
| Inspection on Chip              |               |                                                  |
| Appearance                      |               |                                                  |
| △ PQC Lot Judgement             |               |                                                  |
| Frame                           | Assembling    | Appearance after Chip Bonding                    |
|                                 |               | Appearance after Wire Bonding                    |
|                                 |               | Pull Strength, Compression Width, Shear Strength |
|                                 |               | Appearance after Assembling                      |
| Package                         | Sealing       | Appearance after Sealing                         |
|                                 | Marking       | Outline, Dimension                               |
|                                 |               | Marking Strength                                 |
|                                 |               | Analysis of Failures, Failure Mode, Mechanism    |
| Sealing                         |               |                                                  |
| △ PQC Level Check               |               |                                                  |
| Final Electrical Inspection     |               |                                                  |
| △ Failure Analysis              |               |                                                  |
| Appearance Inspection           |               |                                                  |
| Sampling Inspection on Products |               |                                                  |
| Receiving                       |               |                                                  |
| Shipment                        |               |                                                  |

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 microcomputer Peripheral 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.



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°C, 1000hr                                                                                                                                                                                                                                  | 1005,2                                                             |
| High Temp, Storage<br>Low Temp, Storage<br>Steady State Humidity<br>Steady State Humidity Biased                                                                                        | Tstg max, 1000hr<br>Tstg min, 1000hr<br>65°C 95%RH, 1000hr<br>85°C 85%RH, 1000hr                                                                                                                                                               | 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 | -55°C ~ 150°C, 10 cycles<br>-20°C ~ 125°C, 200 cycles<br>0°C ~ 100°C, 100 cycles<br>260°C, 10 sec<br>1500G 0.5 msec, 3 times/X, Y, Z<br>60Hz 20G, 32hrs/X, Y, Z<br>20~2000Hz 20G, 4 min/X, Y, Z<br>20000G, 1 min/X, Y, Z<br>225gr, 90° 3 times | 1010,4<br>1011,3<br>2002,2<br>2005,1<br>2007,1<br>2001,2<br>2004,3 |



## RELIABILITY TEST DATA OF MICROCOMPUTER

### 3.2 Reliability Test Result

Reliability Test Result of 8-bit microcomputer Peripheral devices is shown in Table 3 to Table 7, that of 16-bit micro-

computer Peripheral devices 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 microcomputer Peripheral)**

| Device Type | Sample Size | Component Hours | Failures |
|-------------|-------------|-----------------|----------|
| HD6821      | 399         | 266368          | 1*       |
| HD6850      | 158         | 158000          | 0        |
| HD6852      | 170         | 125816          | 0        |
| HD6846      | 69          | 69000           | 0        |
| HD6843      | 66          | 66000           | 0        |
| HD6844      | 80          | 69000           | 0        |
| HD6845S     | 88          | 55000           | 0        |
| HD6840      | 64          | 64000           | 0        |
| HD46508     | 140         | 140000          | 0        |
| HD146818    | 44          | 44000           | 0        |
| HD6350      | 70          | 70000           | 0        |
| HD6321      | 45          | 45000           | 0        |
| Total       | 1,393       | 1,172,184       | 1        |

\*leakage current

Estimated Field Failure Rate  
= 0.01% / 1000 hrs at Ta = 75°C  
(Activation Energy = 0.7eV, Confidence Level 60%)

**Table 4 High Temperature, High Humidity Test (8-bit multi-chip microcomputer) (Moisture Resistance Test)**

#### (1) 85°C 85%RH Bias Test

| Device Type | Vcc Bias | 168 hrs | 500 hrs | 1000 hrs |
|-------------|----------|---------|---------|----------|
| HD6850P     | 5.5V     | 0/45    | 0/45    | 0/45     |
| HD6852P     | 5.5V     | 0/22    | 0/22    | 0/22     |
| HD6843P     | 5.5V     | 0/22    | 0/22    | 0/22     |
| HD6844P     | 5.5V     | 0/22    | 0/22    | 0/22     |
| HD6845SP    | 5.5V     | 0/137   | 0/137   | 0/137    |
| HD6840P     | 5.5V     | 0/22    | 0/22    | 0/22     |
| HD46508P    | 5.5V     | 0/22    | 0/22    | 0/22     |
| HD146818P   | 5.5V     | 0/22    | 0/22    | 0/22     |
| HD6321P     | 5.5V     | 0/22    | 0/22    | 0/22     |
| Total       |          | 0/336   | 0/336   | 0/336    |



RELIABILITY TEST DATA OF MICROCOMPUTER

(2) High Temperature-High Humidity Storage Life Test

| Device Type | Condition  | 168 hrs | 500 hrs | 1000 hrs |
|-------------|------------|---------|---------|----------|
| HD6850P     | 65°C 95%RH | 0/135   | 0/135   | 0/135    |
| HD6850P     | 80°C 90%RH | 0/22    | 0/22    | 0/22     |
| HD6852P     | 85°C 95%RH | 0/22    | 0/22    | 0/22     |
| HD6844P     | 80°C 90%RH | 0/22    | 0/22    | 0/22     |
| HD6845SP    | 80°C 90%RH | 0/22    | 0/22    | 0/22     |
| HD6840P     | 65°C 95%RH | 0/22    | 0/22    | 0/22     |
| HD46508P    | 65°C 95%RH | 0/70    | 0/70    | 0/70     |
| HD146818P   | 65°C 95%RH | 0/45    | 0/45    | 0/45     |
| HD6350P     | 65°C 95%RH | 0/70    | 0/70    | 0/70     |
| HD6321P     | 65°C 95%RH | 0/70    | 0/70    | 0/70     |

(3) Pressure Cooker Test

(Condition : 2atm 121°C)

| Device Type | 40 hrs | 60 hrs | 100 hrs | 200 hrs |
|-------------|--------|--------|---------|---------|
| HD6821P     | 0/44   | 0/44   | 0/44    | —       |
| HD6850P     | 0/22   | 0/22   | 0/22    | —       |
| HD6843P     | 0/22   | 0/22   | 0/22    | —       |
| HD6845SP    | 0/43   | 0/43   | 0/43    | 1*/43   |
| HD46508P    | 0/45   | 0/45   | 0/45    | —       |
| HD146818P   | 0/22   | 0/22   | 0/22    | —       |
| HD6350P     | 0/22   | 0/22   | 0/22    | —       |
| HD6321P     | 0/22   | 0/22   | 0/22    | —       |

\* Aluminum corrosion

(4) MIL-STD-883B Moisture Resistance Test

(Condition; 65°C ~ -10°C, over 90%RH, Vcc = 5.5V)

| Device Type | 10 cycles | 20 cycles | 40 cycles |
|-------------|-----------|-----------|-----------|
| HD6821P     | 0/25      | 0/25      | 0/25      |



Table 5 Temperature Cycling Test (8-bit microcomputer Peripheral) (-55°C ~ 25°C ~ 150°C)

| Device Type | 10 cycles | 100 cycles | 200 cycles |
|-------------|-----------|------------|------------|
| HD6821P     | 0/420     | 0/44       | 1*/44      |
| HD6850P     | 0/151     | 0/38       | 0/38       |
| HD6852P     | 0/149     | 0/38       | 0/38       |
| HD6843P     | 0/247     | 0/44       | 0/44       |
| HD6844P     | 0/150     | 0/44       | 0/44       |
| HD6845SP    | 0/358     | 0/76       | 0/76       |
| HD6840P     | 0/148     | 0/22       | 0/22       |
| HD46508P    | 0/207     | 0/44       | 0/44       |
| HD146818P   | 0/103     | 0/22       | 0/22       |
| HD6350P     | 0/150     | 0/45       | 0/45       |
| HD6321P     | 0/120     | 0/45       | 0/45       |

\* Static damage

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

| Device           | Temperature    | 168 hrs       | 500 hrs       | 1000 hrs      |
|------------------|----------------|---------------|---------------|---------------|
| Peripheral total | 150°C<br>-55°C | 0/110<br>0/88 | 0/110<br>0/88 | 0/110<br>0/88 |

Table 7 Mechanical and Environmental Test (8-bit microcomputer peripheral)

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



**RELIABILITY TEST DATA OF MICROCOMPUTER**

**Table 8 Dynamic Life Test (16-bit microcomputer peripheral)**

| Device Type | Condition      |                 | 168 hrs | 500 hrs | 1000 hrs |
|-------------|----------------|-----------------|---------|---------|----------|
|             | T <sub>a</sub> | V <sub>CC</sub> |         |         |          |
| HD68450     | 125°C          | 5.5V            | 0/44    | 0/44    | 0/44     |
|             | 150°C          | 5.5V            | 0/32    | 0/32    | 0/32     |
| HD63484     | 125°C          | 5.5V            | 0/45    | 0/45    | 0/45     |

**Estimated Field Failure Rate**  
 = 0.013%/1000 hrs at T<sub>a</sub> = 75°C  
 (Activation Energy 0.7eV, Confidence Level 80%)

**Table 9 Mechanical and Environmental Test (16-bit microcomputer peripheral)**

| Test Item                | Condition                            | Device Type |
|--------------------------|--------------------------------------|-------------|
|                          |                                      | HD68450     |
| High Temperature Storage | T <sub>a</sub> = 295°C, 1000 hrs     | 0/22        |
| Low Temperature Storage  | T <sub>a</sub> = -55°C, 1000 hrs     | 0/42        |
| Temperature Cycling (1)  | -55°C ~ 25°C ~ 150°C<br>10 cycles    | 0/45        |
| Temperature Cycling (2)  | -20°C ~ 25°C ~ 125°C<br>500 cycles   | 0/22        |
| Thermal Shock            | -55°C ~ 125°C<br>15 cycles           | 0/22        |
| Soldering heat           | 260°C, 10 sec                        | 0/22        |
| Solderability            | 230°C, 5 sec                         | 0/22        |
| Mechanical Shock         | 1500G, 0.5 msec<br>3 times/X, Y, Z   | 0/22        |
| Vibration Variable Freq. | 20 ~ 2000 Hz, 20G<br>3 times/X, Y, Z | 0/22        |
| Constant Acceleration    | 20000G<br>1 min/X, Y, Z              | 0/22        |



#### 4. PRECAUTION

##### 4.1 Storage

- It is preferable to store semiconductor devices in the following ways to prevent deterioration in their electrical characteristics, solderability, and appearance, or breakage.
- (1) Store in an ambient temperature of 5 to 30°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°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 electricity, workers should be properly 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 to allow 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°C for 10 seconds and 350°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 following conditions are advisable:

- Frequency: 28 to 29 kHz (to avoid device resonance)
- Ultrasonic output: 15W/l
- Keep the devices out of direct contact with the power generator.
- Cleaning time: Less than 30 seconds



# **DATA SHEETS**

**8-BIT · 16-BIT  
PERIPHERAL LSI**



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



# HD6321/HD6821

## PIA (Peripheral Interface Adapter)

The HD6321/HD6821 Peripheral Interface Adapter provides the universal means of interfacing peripheral equipment to the HD6800 Microprocessing Unit (MPU). This device is capable of interfacing the MPU to peripherals through two 8-bit bi-directional peripheral data buses and four control lines. No external logic is required for interfacing to most peripheral devices.

The functional configuration of the PIA is programmed by the MPU during system initialization. Each of the peripheral data lines can be programmed to act as an input or output, and each of the four control/interrupt lines may be programmed for one of several control modes. This allows a high degree of flexibility in the over-all operation of the interface.

### FEATURES

- Two Bi-directional 8-bit Peripheral Data Bus for interface to Peripheral devices
- Two programmable control, Data Direction Registers
- Four Individually Controlled Interrupt Input Lines: Two Usable as Peripheral Control Outputs
- Handshake Control Logic for Input and Output Peripheral Operation
  - CA<sub>1</sub>, CA<sub>2</sub> .... Port A (PA<sub>0</sub> ~ PA<sub>7</sub>)
  - CB<sub>1</sub>, CB<sub>2</sub> .... Port B (PB<sub>0</sub> ~ PB<sub>7</sub>)
- High-Impedance 3-State and Direct Transistor Drive Peripheral Lines
- Two TTL Drive Capability on All A and B Side Buffers

### —HD6321—

- Low-Power, High-Speed, High-Density CMOS
- Wide Range Operating Voltage (V<sub>cc</sub> = 5V ± 10%)
- Compatible with NMOS PIA (HD6821) (Refer to Electrical Specification as to Minor difference)

### —HD6821—

- Compatible with MC6821, MC68A21 and MC68B21

### ■ TYPE OF PRODUCTS

| Type No. | Process | Clock Frequency | Package |
|----------|---------|-----------------|---------|
| HD6321   |         | 1.0 MHz         | DP-40   |
| HD63A21  | CMOS    | 1.5 MHz         | FP-54   |
| HD63B21  |         | 2.0 MHz         |         |
| HD6821   |         | 1.0 MHz         |         |
| HD68A21  | NMOS    | 1.5 MHz         |         |
| HD68B21  |         | 2.0 MHz         | DP-40   |

HD6321P, HD6821P



(DP-40)

HD6321FP



(FP-54)

The specifications of the HD6321 are for preliminary and may change hereafter. Please make an inquire at sales office upon adoption of the HD6321.



## ■ PIN ARRANGEMENT

● HD6321P, HD6821P



(Top View)



(Top View)

## ■ BLOCK DIAGRAM



### ■ ABSOLUTE MAXIMUM RATINGS

| Item                         | Symbol                | Value       |             | Unit |
|------------------------------|-----------------------|-------------|-------------|------|
|                              |                       | HD6321      | HD6821      |      |
| Supply Voltage               | V <sub>CC</sub> *     | -0.3 ~ +7.0 | -0.3 ~ +7.0 | V    |
| Input Voltage                | V <sub>IN</sub> *     | -0.3 ~ +7.0 | -0.3 ~ +7.0 | V    |
| Maximum Output Current       | I <sub>O</sub>   **   | 10          | -           | mA   |
| Maximum Total Output Current | ΣI <sub>O</sub>   *** | 100         | -           | mA   |
| Operating Temperature        | T <sub>OPR</sub>      | -20 ~ +75   | -20 ~ +75   | °C   |
| Storage Temperature          | T <sub>STG</sub>      | -55 ~ +150  | -55 ~ +150  | °C   |

\* With respect to V<sub>SS</sub> (SYSTEM GND)

\*\* Maximum output current is the maximum current which can flow in or flow out from one output terminal and I/O common terminal, (PA<sub>0</sub>~PA<sub>7</sub>, CA<sub>2</sub>, PB<sub>0</sub>~PB<sub>7</sub>, CB<sub>2</sub>, D<sub>0</sub>~D<sub>7</sub>)

\*\*\* Maximum total output current is the total sum of output current which can flow in or flow out simultaneously from output terminals and I/O common terminals. (PA<sub>0</sub>~PA<sub>7</sub>, CA<sub>2</sub>, PB<sub>0</sub>~PB<sub>7</sub>, CB<sub>2</sub>, D<sub>0</sub>~D<sub>7</sub>)

(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             | HD6321 |      |                 | HD6821 |      |                 | Unit |
|-----------------------|--------------------|--------|------|-----------------|--------|------|-----------------|------|
|                       |                    | min.   | typ. | max.            | min.   | typ. | max.            |      |
| Supply Voltage        | V <sub>CC</sub> *  | 4.5    | 5.0  | 5.5             | 4.75   | 5.0  | 5.25            | V    |
| Input "Low" Voltage   | V <sub>IIL</sub> * | -0.3   | -    | 0.8             | -0.3   | -    | 0.8             | V    |
| Input "High" voltage  | V <sub>IH</sub> *  | 2.2    | -    | V <sub>CC</sub> | 2.0    | -    | V <sub>CC</sub> | V    |
|                       |                    |        |      |                 |        |      |                 |      |
| Operating Temperature | T <sub>OPR</sub>   | -20    | 25   | 75              | -20    | 25   | 75              | °C   |

\* With respect to V<sub>SS</sub> (SYSTEM GND)

\*\* Characteristics will be improved.



## ■ ELECTRICAL CHARACTERISTICS

● DC CHARACTERISTICS (HD6321;  $V_{CC} = 5V \pm 10\%$ , HD6821;  $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20 \sim +75^\circ C$ , unless otherwise noted.)

| Item                                  |                                                                                                                                                                                                                                                          | Symbol           | HD6321                                          |                      |      |                 | HD6821                                          |        |      |                 | Unit |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------|----------------------|------|-----------------|-------------------------------------------------|--------|------|-----------------|------|
|                                       |                                                                                                                                                                                                                                                          |                  | Test Condition                                  | min.                 | typ* | max             | Test Condition                                  | min    | typ* | max             |      |
| Input "High" Voltage                  | D <sub>0</sub> ~D <sub>7</sub> , PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>1</sub> , CA <sub>2</sub> , PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>1</sub> , CB <sub>2</sub>                                                                             | V <sub>IH</sub>  |                                                 | 2.2                  | —    | V <sub>CC</sub> |                                                 | 2.0    | —    | V <sub>CC</sub> | V    |
|                                       | E, R/W, CS <sub>0</sub> , CS <sub>2</sub> , CS <sub>1</sub> , RS <sub>0</sub> , RS <sub>1</sub> , RES                                                                                                                                                    |                  |                                                 | 3.0**                | —    | V <sub>CC</sub> |                                                 |        |      |                 |      |
| Input "Low" Voltage                   | All Inputs                                                                                                                                                                                                                                               | V <sub>IL</sub>  |                                                 | -0.3                 | —    | 0.8             |                                                 | -0.3   | —    | 0.8             | V    |
| Input Leakage Current                 | R/W, RES, RS <sub>0</sub> , RS <sub>1</sub> , CS <sub>0</sub> , CS <sub>1</sub> , CS <sub>2</sub> , CA <sub>1</sub> , CB <sub>1</sub> , E                                                                                                                | I <sub>IN</sub>  | V <sub>IN</sub> = 0 ~ V <sub>CC</sub>           | -2.5                 | —    | 2.5             | V <sub>IN</sub> = 0 ~ V <sub>CC</sub>           | -2.5   | —    | 2.5             | μA   |
| Three State (Off State) Input Current | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub><br>D <sub>0</sub> ~D <sub>7</sub> , PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub>                                                                                                                | I <sub>TSI</sub> | V <sub>IN</sub> = 0.4 ~ V <sub>CC</sub>         | -10                  | —    | 10              | V <sub>IN</sub> = 0.4 ~ 2.4V                    | -10    | —    | 10              | μA   |
| Input "High" Current                  | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub>                                                                                                                                                                                                       | I <sub>IH</sub>  |                                                 |                      |      |                 | V <sub>IH</sub> = 2.4V                          | -200   | —    | —               | μA   |
| Input "Low" Current                   | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub>                                                                                                                                                                                                       | I <sub>IL</sub>  |                                                 |                      |      |                 | V <sub>IL</sub> = 0.4V                          | —      | —    | -2.4            | mA   |
| Output "High" Voltage                 | D <sub>0</sub> ~D <sub>7</sub>                                                                                                                                                                                                                           | V <sub>OH</sub>  | I <sub>OH</sub> = -400μA                        | 4.1                  | —    | —               | I <sub>OH</sub> = -205μA                        | 2.4    | —    | —               | V    |
|                                       | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub><br>PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub>                                                                                                                                                 |                  | I <sub>OH</sub> ≤ -10μA                         | V <sub>CC</sub> -0.1 | —    | —               |                                                 |        |      |                 |      |
|                                       | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub>                                                                                                                                                                                                       |                  | I <sub>OH</sub> = -400μA                        | 4.1                  | —    | —               |                                                 |        |      |                 |      |
|                                       | PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub>                                                                                                                                                                                                       |                  | I <sub>OH</sub> < -10μA                         | V <sub>CC</sub> -0.1 | —    | —               | I <sub>OH</sub> = -200μA                        | 2.4*** | —    | —               |      |
| Output "Low" Voltage                  | D <sub>0</sub> ~D <sub>7</sub> , IRQA, IRQB                                                                                                                                                                                                              | V <sub>OL</sub>  | I <sub>OL</sub> = 1.6mA                         | —                    | —    | 0.4             | I <sub>OL</sub> = 1.6mA                         | —      | —    | 0.4             | V    |
|                                       | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub>                                                                                                                                                                                                       |                  | I <sub>OL</sub> = 3.2mA                         | —                    | —    | 0.6             | I <sub>OL</sub> = 1.6mA                         | —      | —    | 0.4             |      |
|                                       | PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub>                                                                                                                                                                                                       |                  | I <sub>OL</sub> = 3.2mA                         | —                    | —    | 0.6             | I <sub>OL</sub> = 3.2mA                         | —      | —    | 0.6             |      |
| Output "High" Current                 | D <sub>0</sub> ~ D <sub>7</sub>                                                                                                                                                                                                                          | I <sub>OH</sub>  |                                                 |                      |      |                 | V <sub>OH</sub> = 2.4V                          | -205   | —    | —               | μA   |
|                                       | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub>                                                                                                                                                                                                       |                  |                                                 |                      |      |                 | V <sub>OH</sub> = 2.4V**                        | -200   | —    | —               | μA   |
|                                       | PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub>                                                                                                                                                                                                       |                  |                                                 |                      |      |                 | V <sub>OH</sub> = 1.5V                          | -1.0   | —    | -10             | mA   |
| Output Leakage Current (Off State)    | IRQA, IRQB                                                                                                                                                                                                                                               | I <sub>LOH</sub> | V <sub>OH</sub> = V <sub>CC</sub>               | —                    | —    | 10              | V <sub>OH</sub> = V <sub>CC</sub>               | —      | —    | 10              | μA   |
| Input Capacitance                     | PA <sub>0</sub> ~PA <sub>7</sub> , PB <sub>0</sub> ~PB <sub>7</sub> , CA <sub>2</sub> , CB <sub>2</sub> , D <sub>0</sub> ~D <sub>7</sub>                                                                                                                 | C <sub>IN</sub>  | V <sub>IN</sub> = 0V<br>Ta = 25°C<br>f = 1.0MHz | —                    | —    | 12.5            | V <sub>IN</sub> = 0V<br>Ta = 25°C<br>f = 1.0MHz | —      | —    | 12.5            | pF   |
|                                       | R/W, RES, RS <sub>0</sub> , RS <sub>1</sub> , CS <sub>0</sub> , CS <sub>1</sub> , CS <sub>2</sub> , CA <sub>1</sub> , CB <sub>1</sub> , E                                                                                                                |                  |                                                 | —                    | —    | 10              |                                                 | —      | —    | 10              |      |
| Output Capacitance                    | IRQA, IRQB                                                                                                                                                                                                                                               | C <sub>OUT</sub> | V <sub>IN</sub> = 0V<br>Ta = 25°C<br>f = 1.0MHz | —                    | —    | 10              | V <sub>IN</sub> = 0V<br>Ta = 25°C<br>f = 1.0MHz | —      | —    | 10              | pF   |
| Supply Current ****                   | •PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> , PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub> are specified as input.<br>•Chip is not selected.<br>•Input level<br>V <sub>IH</sub> min = V <sub>CC</sub> - 0.8V<br>V <sub>IL</sub> max = 0.8V | I <sub>CC</sub>  | E = 1.0MHz                                      | —                    | —    | 300             |                                                 |        |      |                 | μA   |
|                                       |                                                                                                                                                                                                                                                          |                  | E = 1.5MHz                                      | —                    | —    | 400             |                                                 |        |      |                 |      |
|                                       |                                                                                                                                                                                                                                                          |                  | E = 2.0MHz                                      | —                    | —    | 500             |                                                 |        |      |                 |      |
|                                       | •PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> and PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub> are specified as input.<br>•Under Data Bus R/W operation.                                                                                     |                  | E = 1.0MHz                                      | —                    | —    | 4               |                                                 |        |      |                 |      |
|                                       |                                                                                                                                                                                                                                                          |                  | E = 1.5MHz                                      | —                    | —    | 5               |                                                 |        |      |                 |      |
|                                       |                                                                                                                                                                                                                                                          |                  | E = 2.0MHz                                      | —                    | —    | 6               |                                                 |        |      |                 |      |
| Power Dissipation                     | P <sub>D</sub>                                                                                                                                                                                                                                           |                  |                                                 |                      |      |                 |                                                 | —      | 260  | 550             | mW   |

\* Ta = 25°C,  $V_{CC}$  = 5.0V

\*\* Characteristics will be improved.

\*\*\* HD6821;  $V_{OH}$  = 2.2V min. (PA<sub>0</sub>~PA<sub>7</sub>, CA<sub>2</sub>)

\*\*\*\* Supply current is defined on the condition that there is no current flow from output terminals. Supply current will be increased when the current from output terminal exists. Also the current will be increased for charging and discharging the capacitive load. Please take this case into consideration in estimating system power.



● AC CHARACTERISTICS (HD6321;  $V_{CC} = 5V \pm 10\%$ , HD6821;  $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20 \sim +75^\circ C$  unless otherwise noted)

1. PERIPHERAL TIMING

| Item                                                                                     | Symbol                                                                      | Test Condition | HD6321                         |          | HD63A21 |          | HD63B21 |          | HD6821 |       | HD68A21 |       | HD68B21 |       | Unit    |    |
|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|----------------|--------------------------------|----------|---------|----------|---------|----------|--------|-------|---------|-------|---------|-------|---------|----|
|                                                                                          |                                                                             |                | min                            | max      | min     | max      | min     | max      | min    | max   | min     | max   | min     | max   |         |    |
| Peripheral Data Setup Time                                                               | $t_{PDSU}$                                                                  | Fig. 1         | 100                            | —        | 100     | —        | 100     | —        | 200    | —     | 135     | —     | 100     | —     | ns      |    |
| Peripheral Data Hold Time                                                                | $t_{PDH}$                                                                   | Fig. 1         | 0                              | —        | 0       | —        | 0       | —        | 0      | —     | 0       | —     | 0       | —     | ns      |    |
| Delay Time, Enable negative Transition to CA <sub>2</sub> negative transition            | Enable → CA <sub>2</sub> Negative                                           | $t_{CA2}$      | Fig. 2, Fig. 3                 | —        | 200     | —        | 200     | —        | 200    | —     | 1000    | —     | 670     | —     | 500 ns  |    |
| Delay Time, Enable negative transition to CA <sub>2</sub> positive transition            | Enable → CA <sub>2</sub> Positive                                           | $t_{RS1}$      | Fig. 2                         | —        | 200     | —        | 200     | —        | 200    | —     | 1000    | —     | 670     | —     | 500 ns  |    |
| Rise and Fall Times for CA <sub>1</sub> and CA <sub>2</sub> input signals                | CA <sub>1</sub> , CA <sub>2</sub>                                           | $t_r, t_f$     | Fig. 3                         | —        | 100     | —        | 100     | —        | 100    | —     | 1000    | —     | 1000    | —     | 1000 ns |    |
| Delay Time from CA <sub>1</sub> active transition to CA <sub>2</sub> positive transition | CA <sub>1</sub> → CA <sub>2</sub>                                           | $t_{RS2}$      | Fig. 3                         | —        | 300     | —        | 300     | —        | 300    | —     | 2000    | —     | 1350    | —     | 1000 ns |    |
| Delay Time, Enable negative transition to Peripheral Data Valid                          | Enable → Peripheral Data                                                    | $t_{PDW}$      | Fig. 4, Fig. 5                 | —        | 300     | —        | 300     | —        | 300    | —     | 1000    | —     | 670     | —     | 500 ns  |    |
| Delay Time, Enable negative transition to Peripheral CMOS Data Valid                     | Enable → Peripheral Data PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> | $t_{CMOS}$     | $V_{CC}-30\% V_{CC}$<br>Fig. 4 | \        |         |          |         |          |        | —     | 2000    | —     | 1350    | —     | 1000 ns |    |
| Delay Time, Enable positive transition to CB <sub>2</sub> negative position              | Enable → CB <sub>2</sub>                                                    | $t_{CB2}$      | Fig. 6, Fig. 7                 | —        | 200     | —        | 200     | —        | 200    | —     | 1000    | —     | 670     | —     | 500 ns  |    |
| Delay Time, Peripheral Data Valid to CB <sub>2</sub> negative transition                 | Peripheral Data → CB <sub>2</sub>                                           | $t_{DC}$       | Fig. 5                         | 20       | —       | 20       | —       | 20       | —      | 20    | —       | 20    | —       | 20    | —       | ns |
| Delay Time, Enable positive transition to CB <sub>2</sub> positive transition            | Enable → CB <sub>2</sub>                                                    | $t_{RS1}$      | Fig. 6                         | —        | 200     | —        | 200     | —        | 200    | —     | 1000    | —     | 670     | —     | 500 ns  |    |
| Peripheral Control Output Pulse Width, CA <sub>2</sub> /CB <sub>2</sub>                  | CA <sub>2</sub> CB <sub>2</sub>                                             | $PW_{CT}$      | Fig. 2, Fig. 6                 | 550      | —       | 375      | —       | 250      | —      | 550   | —       | 550   | —       | 500   | —       | ns |
| Rise and Fall Time for CB <sub>1</sub> and CB <sub>2</sub> input signals                 | CB <sub>1</sub> , CB <sub>2</sub>                                           | $t_r, t_f$     | Fig. 7                         | —        | 100     | —        | 100     | —        | 100    | —     | 1000    | —     | 1000    | —     | 1000 ns |    |
| Delay Time, CB <sub>1</sub> active transition to CB <sub>2</sub> positive transition     | CB <sub>1</sub> → CB <sub>2</sub>                                           | $t_{RS2}$      | Fig. 7                         | —        | 300     | —        | 300     | —        | 300    | —     | 2000    | —     | 1350    | —     | 1000 ns |    |
| Interrupt Release Time, IROA and IRQB                                                    | IROA, IRQB                                                                  | $t_{IR}$       | Fig. 9                         | —        | 800     | —        | 800     | —        | 800    | —     | 1600    | —     | 1100    | —     | 850 ns  |    |
| Interrupt Response Time                                                                  | IROA, IROB                                                                  | $t_{RS3}$      | Fig. 8                         | —        | 400     | —        | 400     | —        | 400    | —     | 1000    | —     | 1000    | —     | 1000 ns |    |
| Interrupt Input Pulse Width                                                              | CA <sub>1</sub> , CA <sub>2</sub> , CB <sub>1</sub> , CB <sub>2</sub>       | $PWI$          | Fig. 8                         | 1E cycle | —       | 1E cycle | —       | 1E cycle | —      | 500** | —       | 500** | —       | 500** | —       | ns |
| Reset "Low" Time                                                                         | RES*                                                                        | $t_{RL}$       | Fig. 10                        | 200      | —       | 200      | —       | 200      | —      | 1000  | —       | 660   | —       | 500   | —       | ns |

\* The Reset line must be "High" a minimum of 1.0 $\mu s$  before addressing the PIA.

\*\* At least one Enable "High" pulse should be included in this period.



## 2. BUS TIMING

## 1) READ

| Item                             | Symbol              | Test Condition | HD6321  |     | HD63A21 |     | HD63B21 |     | HD6821 |     | HD68A21 |     | HD68B21 |     | Unit |    |
|----------------------------------|---------------------|----------------|---------|-----|---------|-----|---------|-----|--------|-----|---------|-----|---------|-----|------|----|
|                                  |                     |                | min     | max | min     | max | min     | max | min    | max | min     | max | min     | max |      |    |
| Enable Cycle Time                | $t_{cycE}$          | Fig. 11        | 1000    | —   | 666     | —   | 500     | —   | 1000   | —   | 666     | —   | 500     | —   | ns   |    |
| Enable Pulse Width, "High"       | $PW_{EH}$           | Fig. 11        | 450     | —   | 280     | —   | 220     | —   | 450    | —   | 280     | —   | 220     | —   | ns   |    |
| Enable Pulse Width, "Low"        | $PW_{EL}$           | Fig. 11        | 430     | —   | 280     | —   | 210     | —   | 430    | —   | 280     | —   | 210     | —   | ns   |    |
| Enable Pulse Rise and Fall Times | $t_{Er}, t_{Ef}$    | Fig. 11        | —       | 25  | —       | 25  | —       | 20  | —      | 25  | —       | 25  | —       | 25  | ns   |    |
| Setup Time                       | Address, R/W-Enable | $t_{AS}$       | Fig. 12 | 80  | —       | 60  | —       | 60* | —      | 140 | —       | 140 | —       | 70  | —    | ns |
| Address Hold Time                |                     | $t_{AH}$       | Fig. 12 | 10  | —       | 10  | —       | 10  | —      | 10  | —       | 10  | —       | 10  | —    | ns |
| Data Delay Time                  |                     | $t_{DDR}$      | Fig. 12 | —   | 290     | —   | 180     | —   | 150    | —   | 320     | —   | 220     | —   | 180  | ns |
| Data Hold Time                   |                     | $t_{DHR}$      | Fig. 12 | 20  | 100     | 20  | 100     | 20  | 100    | 10  | —       | 10  | —       | 10  | —    | ns |

\* Characteristics will be improved.

## 2) WRITE

| Item                             | Symbol              | Test Condition | HD6321  |     | HD63A21 |     | HD63B21 |     | HD6821 |     | HD68A21 |     | HD68B21 |     | Unit |    |
|----------------------------------|---------------------|----------------|---------|-----|---------|-----|---------|-----|--------|-----|---------|-----|---------|-----|------|----|
|                                  |                     |                | min     | max | min     | max | min     | max | min    | max | min     | max | min     | max |      |    |
| Enable Cycle Time                | $t_{cycE}$          | Fig. 11        | 1000    | —   | 666     | —   | 500     | —   | 1000   | —   | 666     | —   | 500     | —   | ns   |    |
| Enable Pulse Width, "High"       | $PW_{EH}$           | Fig. 11        | 450     | —   | 280     | —   | 220     | —   | 450    | —   | 280     | —   | 220     | —   | ns   |    |
| Enable Pulse Width, "Low"        | $PW_{EL}$           | Fig. 11        | 430     | —   | 280     | —   | 210     | —   | 430    | —   | 280     | —   | 210     | —   | ns   |    |
| Enable Pulse Rise and Fall Times | $t_{Er}, t_{Ef}$    | Fig. 11        | —       | 25  | —       | 25  | —       | 20  | —      | 25  | —       | 25  | —       | 25  | ns   |    |
| Setup Time                       |                     | $t_{AS}$       | Fig. 13 | 80  | —       | 60  | —       | 60* | —      | 140 | —       | 140 | —       | 70  | —    | ns |
| Address Hold Time                | Address, R/W-Enable | $t_{AH}$       | Fig. 13 | 10  | —       | 10  | —       | 10  | —      | 10  | —       | 10  | —       | 10  | —    | ns |
| Data Setup Time                  |                     | $t_{DSW}$      | Fig. 13 | 165 | —       | 80  | —       | 60  | —      | 195 | —       | 80  | —       | 60  | —    | ns |
| Data Hold Time                   |                     | $t_{DHW}$      | Fig. 13 | 10  | —       | 10  | —       | 10  | —      | 10  | —       | 10  | —       | 10  | —    | ns |

\* Characteristics will be improved.





Figure 1 Peripheral Data Setup and Hold Times (Read Mode)

Figure 2 CA<sub>2</sub> Delay Time  
(Read Mode; CRA5=CRA3=1, CRA4=0)Figure 3 CA<sub>2</sub> Delay Time  
(Read Mode; CRA5=1, CRA3=CRA4=0)Figure 4 Peripheral Data Delay Times  
(Write Mode; CRA5=CRA3=1, CRA4=0)Figure 5 Peripheral Data and CB<sub>2</sub> Delay Times  
(Write Mode; CRB5=CRB3=1, CRB4=0)Figure 6 CB<sub>2</sub> Delay Time  
(Write Mode; CRB5=CRB3=1, CRB4=0)Figure 7 CB<sub>2</sub> Delay Time  
(Write Mode; CRB5=1, CRB3=CRB4=0)

\*\* 0.6V for HD6321, 0.4V for HD6821

\*\*\* 2.4V for HD6821



Figure 8 Interrupt Pulse Width and TRO Response



\* The RES line must be a  $V_{IH}$  for a minimum of 1.0  $\mu s$  before addressing the PIA.

Figure 9 IRQ Release Time



Figure 10 RES Low Time

Figure 11 Enable Signal Characteristics



\*\* 0.6V for HD6321, 0.4V for HD6821.  
\*\*\* 2.4V for HD6821.

LOAD A  
( $PA_0 \sim PA_7, PB_0 \sim PB_7, CA_2, CB_2$ )

All diodes are 1S2074 or equivalent.

Adjust  $R_L$  so that  $I_{OL} = 1.6\text{mA}$ , then test  $V_{OL}$   
Adjust  $R_L$  so that  $I_{OL} = 3.2\text{mA}$ , then test  $V_{OL}$

LOAD B  
( $D_0 \sim D_7$ )LOAD C  
(IRQ Only)

LOAD D (HD6821)



Figure 14 Bus Timing Test Loads



## ■ PIA INTERFACE SIGNALS FOR MPU

The PIA interfaces to the HD6800 MPU with an eight-bit bi-directional data bus, three chip select lines, two register select lines, two interrupt request lines, read/write line, enable line and reset line. These signals, in conjunction with the HD6800 VMA output, permit the MPU to have complete control over the PIA. VMA should be utilized in conjunction with an MPU address line into a chip select of the PIA.

- Bi-Directional Data ( $D_0 \sim D_7$ )

|       |                                                    |
|-------|----------------------------------------------------|
| Input | Pin No. 33 ~ 26 (DP-40)<br>Pin No. 43 ~ 36 (FP-54) |
|-------|----------------------------------------------------|

The bi-directional data lines ( $D_0 \sim D_7$ ) allow the transfer of data between the MPU and the PIA. The data bus output drivers are three-state devices that remain in the high-impedance (off) state except when the MPU performs a PIA read operation. The R/W line is in the Read ("High") state when the PIA is selected for a Read operation.

- Enable (E)

|              |                                          |
|--------------|------------------------------------------|
| Input/Output | Pin No. 25 (DP-40)<br>Pin No. 32 (FP-54) |
|--------------|------------------------------------------|

The enable pulse, E, is the only timing signal that is supplied to the PIA. Timing of all other signals is referenced to the leading and trailing edges of the E pulse. This signal will normally be a derivative of the HMCS6800 System  $\phi_2$  Clock. This signal must be continuous clock pulse.

- Read/Write (R/W)

|       |                                          |
|-------|------------------------------------------|
| Input | Pin No. 21 (DP-40)<br>Pin No. 28 (FP-54) |
|-------|------------------------------------------|

This signal is generated by the MPU to control the direction of data transfers on the Data Bus. A "Low" state on the PIA line enables the input buffers and data is transferred from the MPU to the PIA on the E signal if the device has been selected. A "High" on the R/W line sets up the PIA for a transfer of data to the bus. The PIA output buffers are enabled when the proper address and the enable pulse E are present.

- Reset (RES)

|       |                                          |
|-------|------------------------------------------|
| Input | Pin No. 34 (DP-40)<br>Pin No. 44 (FP-54) |
|-------|------------------------------------------|

The active "Low" RES line is used to reset all register bits in the PIA to a logical zero "Low". This line can be used as a power-on reset and as a master reset during system operation.

- Chip Select ( $CS_0$ ,  $CS_1$  and  $\overline{CS}_2$ )

|       |                                                          |
|-------|----------------------------------------------------------|
| Input | Pin No. 22, 24, 23 (DP-40)<br>Pin No. 29, 31, 30 (FP-54) |
|-------|----------------------------------------------------------|

These three input signals are used to select the PIA.  $CS_0$  and  $CS_1$  must be "High" and  $\overline{CS}_2$  must be "Low" for selection of the device. Data transfers are then performed under the control of the E and R/W signals. The chip select lines must be stable for the duration of the E pulse. The device is deselected when any of the chip selects are in the inactive state.

- Register Select ( $RS_0$  and  $RS_1$ )

|       |                                                  |
|-------|--------------------------------------------------|
| Input | Pin No. 36, 35 (DP-40)<br>Pin No. 50, 45 (FP-54) |
|-------|--------------------------------------------------|

The two register select lines are used to select the various registers inside the PIA. These two lines are used in conjunction with internal Control Registers to select a particular register that is to be written or read.

The register and chip select lines should be stable for the duration of the E pulse while in the read or write cycle.

- Interrupt Request (IRQA and IRQB)

|       |                                                  |
|-------|--------------------------------------------------|
| Input | Pin No. 38, 37 (DP-40)<br>Pin No. 52, 51 (FP-54) |
|-------|--------------------------------------------------|

The active "Low" Interrupt Request lines (IRQA and IRQB) act to interrupt the MPU either directly or through interrupt priority circuitry. These lines are "open drain" (no load device on the chip). This permits all interrupt request lines to be tied together in a wire-or configuration.

Each IRQ line has two internal interrupt flag bits that can cause the IRQ line to go "Low". Each flag bit is associated with a particular peripheral interrupt line. Also four interrupt enable bits are provided in the PIA which may be used to inhibit a particular interrupt from a peripheral device.

Servicing an interrupt by the MPU may be accomplished by a software routine that, on a prioritized basis, sequentially reads and tests the two control registers in each PIA for interrupt flag bits that are set.

The interrupt flags are cleared (zeroed) as a result of an MPU Read Peripheral Data Operation of the corresponding data register. After being cleared, the interrupt flag bit cannot be enabled to be set until the PIA is deselected during an E pulse. The E pulse is used to condition the interrupt control lines ( $CA_1$ ,  $CA_2$ ,  $CB_1$ ,  $CB_2$ ). When these lines are used as interrupt inputs at least one E pulse must occur from the inactive edge to the active edge of the interrupt input signal to condition the edge sense network. If the interrupt flag has been enabled and the edge sense circuit has been properly conditioned, the interrupt flag will be set on the next active transition of the interrupt input pin.



### ■ PIA PERIPHERAL INTERFACE LINES

The PIA provides two 8-bit bi-directional data buses and four interrupt/control lines for interfacing to peripheral devices.

There is difference between HD6821 and HD6321 in Port structure. Fig. 15 shows the block diagram of Port A and Port B in HD6321. The output drivers of Port A and Port B consist of three-state drivers, allowing them to enter a High-impedance state when the peripheral data line is used as an input. Port A and Port B have the same output buffer. But the circuit configuration is slightly different and this makes the difference on data flow when MPU reads Port A and Port B in the case each

Port is specified as output. As shown in Fig. 15, the output of the peripheral data A is transferred to internal data bus when used as output. On the other hand, in the case of Port B the contents of output register (ORB) is directly transferred to internal data bus through the multiplexor.

Secondly the equivalent circuit of the port in HD6821 is shown in Fig. 16. The output circuits of A port is different from that of B port. When the port is used as input, the input is pullup to  $V_{cc}$  side through load MOS in A port and B port becomes "Off" (high impedance).



Figure 15 Block Diagram of Port A and Port B (HD6321)



Figure 16 Circuit of Port A and Port B (HD6821)

● Port A Peripheral Data ( $PA_0 \sim PA_7$ )

|              |                                                        |
|--------------|--------------------------------------------------------|
| Input/Output | Pin No. 2 ~ 9 (DP-40)<br>Pin No. 2 ~ 5, 9 ~ 12 (FP-54) |
|--------------|--------------------------------------------------------|

Each of the peripheral data lines can be programmed to act as an input or output. This is accomplished by setting a "1" in the corresponding Data Direction Register bit for those lines which are to be outputs. A "0" in a bit of the Data Direction Register causes the corresponding peripheral data line to act as an input. During an MPU Read Peripheral Data Operation, the data on peripheral lines programmed to act as inputs appears directly on the corresponding MPU Data Bus lines.

The data in Output Register A will appear on the peripheral data lines that are programmed to be outputs. A logical "1" written into the register will cause a "High" on the corresponding peripheral data line while a "0" results in a "Low". Data in Output Register A may be read by an MPU "Read Peripheral Data A" operation when the corresponding lines are programmed as outputs.

But concerning HD6821, this data will be read properly if the voltage on the peripheral data lines is greater than 2.0 volts for a logic "1" output and less than 0.8 volt for a logic "0" output. Loading the output lines such that the voltage on these lines does not reach full voltage causes the data transferred into the MPU on a Read operation to differ from that contained in the respective bit of Output Register A.

● Port B Peripheral Data ( $PB_0 \sim PB_7$ )

|              |                                                             |
|--------------|-------------------------------------------------------------|
| Input/Output | Pin No. 10 ~ 17 (DP-40)<br>Pin No. 13 ~ 18, 23 ~ 24 (FP-54) |
|--------------|-------------------------------------------------------------|

Each of the Port B peripheral data bus can be programmed to act as an input or output like  $PA_0 \sim PA_7$ .

$PB_0 \sim PB_7$  are in High-impedance condition because they are three-state outputs just like  $PA_0 \sim PB_0$  when the peripheral buses are used as inputs, when programmed as outputs, MPU read of Port B make it possible to read the output register regardless of  $PB_0 \sim PB_7$ , loads and concerning HD6821, these line may be used as a source of up to 2.5 milliampare (typ.) at 1.5 volt to directly drive the base of transistor switch.

● Interrupt Input ( $CA_1$  and  $CB_1$ )

|       |                                                  |
|-------|--------------------------------------------------|
| Input | Pin No. 40, 18 (DP-40)<br>Pin No. 54, 25 (FP-54) |
|-------|--------------------------------------------------|

The peripheral Input lines  $CA_1$ , and  $CB_1$  are input only lines that set the interrupt flags of the control registers. The active transition for these signals is also programmed by the two control registers.

● Peripheral Control ( $CA_2$ )

|              |                                          |
|--------------|------------------------------------------|
| Input/Output | Pin No. 39 (DP-40)<br>Pin No. 53 (FP-54) |
|--------------|------------------------------------------|

The peripheral control line  $CA_2$  can be programmed to act as an interrupt input or as a peripheral control output.

The function of this signal is programmed by the Control Register A. When used as an input, this signal is in High-impedance state.

● Peripheral Control ( $CB_2$ )

|              |                                          |
|--------------|------------------------------------------|
| Input/Output | Pin No. 19 (DP-40)<br>Pin No. 26 (FP-54) |
|--------------|------------------------------------------|

The peripheral Control line  $CB_2$  may also be programmed to act as an interrupt input or peripheral control output.

This line is programmed by Control Register B.  
When used as an input, this signal is in High-impedance.



**(NOTE)** 1. Pulse width of interrupt inputs CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub> and CB<sub>2</sub> shall be greater than a E cycle time. In the case that "High" time of E signal is not contained in Interrupt pulse, an interrupt flag may not be set.



#### ■ INTERNAL CONTROLS

There are six locations within the PIA accessible to the MPU data bus: two Peripheral Registers, two Data Direction Registers, and two Control Registers. Selection of these locations is controlled by the RS<sub>0</sub> and RS<sub>1</sub> inputs together with bit 2 in the Control Register, as shown in Table 1.

Table 1 Internal Addressing

| RS <sub>1</sub> | RS <sub>0</sub> | Control Register Bit |      | Location Selected         |
|-----------------|-----------------|----------------------|------|---------------------------|
|                 |                 | CRA2                 | CRB2 |                           |
| 0               | 0               | 1                    | x    | Peripheral Register A*    |
| 0               | 0               | 0                    | x    | Data Direction Register A |
| 0               | 1               | x                    | x    | Control Register A        |
| 1               | 0               | x                    | 1    | Peripheral Register B*    |
| 1               | 0               | x                    | 0    | Data Direction Register B |
| 1               | 1               | x                    | x    | Control Register B        |

x = Don't Care

\* Peripheral interface register is a generic term containing peripheral data bus and output register.

#### ● Initialization

A "Low" reset line has the effect of zeroing all PIA registers. This will set PA<sub>0</sub>~PA<sub>7</sub>, PB<sub>0</sub>~PB<sub>7</sub>, CA<sub>2</sub> and CB<sub>2</sub> as inputs, and all interrupts disabled. The PIA must be configured during the restart program which follows the reset.

Details of possible configurations of the Data Direction and Control Register are as follows.

#### ● Data Direction Registers (DDRA and DDRB)

The two Data Direction Registers allow the MPU to control the direction of data through each corresponding peripheral data line. A Data Direction Register bit set at "0" configures the corresponding peripheral data line as an input; a "1" results in an output.

#### ● Control Registers (CRA and CRB)

The two Control Registers (CRA and CRB) allow the MPU to

control the operation of the four peripheral control lines CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub> and CB<sub>2</sub>. In addition they allow the MPU to enable the interrupt lines and monitor the status of the interrupt flags. Bits 0 through 5 of the two registers may be written or read by the MPU when the proper chip select and register select signals are applied. Bits 6 and 7 of the two registers are read only and are modified by external interrupts occurring on control lines CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub> or CB<sub>2</sub>. The format of the control words is shown in Table 2.

Table 2 Control Word Format

|     | 7     | 6     | 5                       | 4 | 3 | 2           | 1                       | 0 |
|-----|-------|-------|-------------------------|---|---|-------------|-------------------------|---|
| CRA | IRQA1 | IRQA2 | CA <sub>1</sub> Control |   |   | DDRA Access | CA <sub>1</sub> Control |   |
| CRB | IRQB1 | IRQB2 | CB <sub>1</sub> Control |   |   | DDRB Access | CB <sub>1</sub> Control |   |

#### Data Direction Access Control Bit (CRA2 and CRB2)

Bit 2 in each Control register (CRA and CRB) allows selection of either a Peripheral Interface Register or the Data Direction Register when the proper register select signals are applied to RS<sub>0</sub> and RS<sub>1</sub>.

#### Interrupt Flags (CRA6, CRA7, CRB6, and CRB7)

The four interrupt flag bits are set by active transitions of signals on the four Interrupt and Peripheral Control lines when those lines are programmed to be inputs. These bits cannot be set directly from the MPU Data Bus and are reset indirectly by a Read Peripheral Data Operation on the appropriate section.

#### Control of CA<sub>1</sub> and CB<sub>1</sub> Interrupt Lines (CRA0, CRB0, CRA1, and CRB1)

The two lowest order bits of the control registers are used to control the interrupt input lines CA<sub>1</sub> and CB<sub>1</sub>. Bits CRA0 and CRB0 are used to enable the MPU interrupt signals IRQA and IRQB, respectively. Bits CRA1 and CRB1 determine the active transition of the interrupt input signals CA<sub>1</sub> and CB<sub>1</sub> (Table 3).

#### Control of CA<sub>2</sub> and CB<sub>2</sub> Peripheral Control Lines (CRA3, CRA4, CRA5, CRB3, CRB4, and CRB5)

Bits 3, 4 and 5 of the two control registers are used to control the CA<sub>2</sub> and CB<sub>2</sub> Peripheral Control lines. These bits determine if the control lines will be an interrupt input or an output control signal. If bit CRA5 (CRB5) is "0" CA<sub>2</sub> (CB<sub>2</sub>) is an interrupt input line similar to CA<sub>1</sub> (CB<sub>1</sub>) (Table 4). When CRA5 (CRB5) is "1", CA<sub>2</sub> (CB<sub>2</sub>) becomes an output signal that may be used to control peripheral data transfers. When in the output mode, CA<sub>2</sub> and CB<sub>2</sub> have slightly different characteristics (Table 5 and 6).



Table 3 Control of Interrupt Inputs CA<sub>1</sub> and CB<sub>1</sub>

| CRA1<br>(CRB1) | CRA0<br>(CRB0) | Interrupt Input<br>CA <sub>1</sub> (CB <sub>1</sub> ) | Interrupt Flag<br>CRA7 (CRB7)                         | MPU Interrupt<br>Request<br>IRQA (IRQB)                             |
|----------------|----------------|-------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------|
| 0              | 0              | ↓ Active                                              | Set "1" on ↓ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Disabled – IRQ remains<br>"High"                                    |
| 0              | 1              | ↓ Active                                              | Set "1" on ↓ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Goes "Low" when the inter-<br>rupt flag bit CRA7 (CRB7)<br>goes "1" |
| 1              | 0              | ↑ Active                                              | Set "1" on ↑ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Disabled – IRQ remains<br>"High"                                    |
| 1              | 1              | ↑ Active                                              | Set "1" on ↑ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Goes "Low" when the inter-<br>rupt flag bit CRA7 (CRB7)<br>goes "1" |

- (Notes) 1. ↑ indicates positive transition ("Low" to "High")  
 2. ↓ indicates negative transition ("High" to "Low")  
 3. The interrupt flag bit CRA7 is cleared by an MPU Read of the A Peripheral Register and CRB7 is cleared by an MPU Read of the B Peripheral Register.  
 4. If CRA0 (CRB0) is "0" when an interrupt occurs (Interrupt disabled) and is later brought "1", IRQA (IRQB) occurs after CRA0 (CRB0) is written to a "1".

Table 4. Control of CA<sub>2</sub> and CB<sub>2</sub> as Interrupt Inputs – CRA5 (CRB5) is "0"

| CRA5<br>(CRB5) | CRA4<br>(CRB4) | CRA3<br>(CRB3) | Interrupt Input<br>CA <sub>2</sub> (CB <sub>2</sub> ) | Interrupt Flag<br>CRA6 (CRB6)                         | MPU Interrupt<br>Request<br>IRQA (IRQB)                             |
|----------------|----------------|----------------|-------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------|
| 0              | 0              | 0              | ↓ Active                                              | Set "1" on ↓ of CA <sub>2</sub><br>(CB <sub>2</sub> ) | Disabled – IRQ remains<br>"High"                                    |
| 0              | 0              | 1              | ↓ Active                                              | Set "1" on ↓ of CA <sub>2</sub><br>(CB <sub>2</sub> ) | Goes "Low" when the inter-<br>rupt flag bit CRA6 (CRB6)<br>goes "1" |
| 0              | 1              | 0              | ↑ Active                                              | Set "1" on ↑ of CA <sub>2</sub><br>(CB <sub>2</sub> ) | Disabled – IRQ remains<br>"High"                                    |
| 0              | 1              | 1              | ↑ Active                                              | Set "1" on ↑ of CA <sub>2</sub><br>(CB <sub>2</sub> ) | Goes "Low" when the inter-<br>rupt flag bit CRA6 (CRB6)<br>goes "1" |

- (Notes) 1. ↑ indicates positive transition ("Low" to "High")  
 2. ↓ indicates negative transition ("High" to "Low")  
 3. The interrupt flag bit CRA6 is cleared by an MPU Read of the A Peripheral Register and CRB6 is cleared by an MPU Read of the B Peripheral Register.  
 4. If CRA3 (CRB3) is "0" when an interrupt occurs (Interrupt disabled) and is later brought "1", IRQA (IRQB) occurs after CRA3 (CRB3) is written to a "1".

Table 5 Control of CB<sub>2</sub> as an Output – CRB5 is "1"

| CRB5 | CRB4 | CRB3 | CB <sub>2</sub>                                                                                             |                                                                                                                                                  |  |
|------|------|------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
|      |      |      | Cleared                                                                                                     | Set                                                                                                                                              |  |
| 1    | 0    | 0    | "Low" on the positive transition of<br>the first E pulse after MPU<br>Write "B" Data Register operation.    | "High" when the interrupt flag bit<br>CRB7 is set by an active transition<br>of the CB <sub>1</sub> signal. (See Figure 16)                      |  |
| 1    | 0    | 1    | "Low" on the positive transition of<br>the first E pulse after an MPU Write<br>"B" Data Register operation. | "High" on the positive edge of the<br>first "E" pulse following an "E"<br>pulse which occurred while the<br>part was deselected. (See Figure 16) |  |
| 1    | 1    | 0    | "Low"<br>(The content of CRB3 is output on CB <sub>2</sub> )                                                |                                                                                                                                                  |  |
| 1    | 1    | 1    | "High"<br>(The content of CRB3 is output on CB <sub>2</sub> )                                               |                                                                                                                                                  |  |



Table 6 Control of CA<sub>2</sub> as an Output — CRA5 is "1"

| CRA5 | CRA4 | CRA3 | CA <sub>2</sub>                                                         |                                                                                                                       |
|------|------|------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
|      |      |      | Cleared                                                                 | Set                                                                                                                   |
| 1    | 0    | 0    | "Low" on negative transition of E after an MPU Read "A" Data Operation. | "High" when the interrupt flag bit CRA7 is set by an active transition of the CA <sub>1</sub> signal. (See Figure 16) |
| 1    | 0    | 1    | "Low" on negative transition of E after an MPU Read "A" Data operation. | "High" on the negative edge of the first "E" pulse which occurs during a deselect. (See Figure 16)                    |
| 1    | 1    | 0    |                                                                         | "Low"<br>(The content of CRA3 is output on CA <sub>2</sub> )                                                          |
| 1    | 1    | 1    |                                                                         | "High"<br>(The content of CRA3 is output on CA <sub>2</sub> )                                                         |

## ■ PIA OPERATION

### ● Initialization

When the external reset input RES goes "Low", all internal registers are cleared to "0". Peripheral data port (PA<sub>0</sub>~PA<sub>7</sub>, PB<sub>0</sub>~PB<sub>7</sub>) is defined to be input and control lines (CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub> and CB<sub>2</sub>) are defined to be the interrupt input lines. PIA is also initialized by software sequence as follows.



### ● Read/Write Operation Not Using Control Lines

#### <Read Operation>



## &lt;Write Operation&gt;



## • Read/Write Operating Using Control Lines

Read/write request from peripherals shall be put into the control lines as an interrupt signal, and then MPU reads or writes after detecting interrupt request.

## &lt;Read&gt;

The following case is that Port A is used and that the rising edge of CA<sub>1</sub> indicates the request for read from peripherals.



To read the peripheral data, the data is directly transferred to the data buses D<sub>0</sub>~D<sub>7</sub>, through PA<sub>0</sub>~PA<sub>7</sub>, or PB<sub>0</sub>~PB<sub>7</sub>, and they are not latched in the PIA. If necessary, the data should be held in the external latch until MPU completes reading it.

When initializing the control register, interrupt flag bit (CRA7, CRA6, CRB7, CRB6) cannot be written from MPU. If necessary the interrupt flag must be reset by dummy read of Peripheral Register A and B.

## &lt;Write&gt;

Write operation using the interrupt signal is as follows. In this case, B port is used and interrupt request is input to CB<sub>1</sub>. And the IRQ flag is set at the rising edge of CB<sub>1</sub>.





Interrupt request flag bits (CRA7, CRA6, CRB7 and CRB6) cannot be written and they cannot be also reset by write operation to the peripheral interface register. So dummy read of peripheral interface register is needed to reset the flags.

To accept the next interrupt, it is essential to reset indirectly the interrupt flag by dummy read of peripheral interface register.

Software polling method mentioned above requires MPU to continuously monitor the control register to detect the read/write request from peripherals. So other programs cannot run at the same time. To avoid this problem, hardware interrupt may be used. The MPU is interrupted by IRQA or IRQB when the read/write request is occurred from peripherals and then MPU analyzes cause of the interrupt request during interrupt processing.

#### • Handshake Mode

The functions of CRA and CRB are similar but not identical in the hand-shake modes. Port A is used for read hand-shake operation and Port B is used for write hand-shake mode.

CA<sub>1</sub> and CB<sub>1</sub> are used for interrupt input requests and CA<sub>2</sub> and CB<sub>2</sub> are control outputs (answer) in hand-shake mode.

Fig. 17, Fig. 18 and Fig. 19 show the timing of hand-shake mode.

#### < Read Hand-shake Mode >

CRA5=“1”, CRA4=“0” and CRA3=“0”

- ① A peripheral device puts the 8-bit data on the peripheral data lines after the control output CA<sub>2</sub> goes “Low”.
- ② The peripheral requests MPU to read the data by using CA<sub>1</sub> input.

③ CRA7 flag is set and CA<sub>2</sub> becomes “High” (CA<sub>2</sub> automatically becomes “High” by the interrupt CA<sub>1</sub>). This indicates the peripheral to maintain the current data and not to transfer the next data.

④ MPU accepts the read request by IRQA hardware interrupt or CRA read. Then MPU reads the peripheral register A.

⑤ CA<sub>2</sub> goes “Low” on the following edge of read Enable pulse. This informs that the peripheral can set the next data to port A.

#### <Write Hand-shake>

CRB5 = “1”, CRB4 = “0” and CRB3 = “0”

① A peripheral device requests MPU to write the data by using CB<sub>1</sub> input. CB<sub>2</sub> output remains “High” until MPU write data to the peripheral interface register.

② CRB7 flag is set and MPU accepts the write request.

③ MPU reads the peripheral interface register to reset CRB7 (dummy read).

④ Then MPU write data to the peripheral interface register. The data is output to port B through the output register.

⑤ CB<sub>2</sub> automatically becomes “Low” to tell the peripheral that new data is on port B.

⑥ The peripheral read the data on Port B peripheral data lines and set CB<sub>1</sub> to “Low” to tell MPU that the data on the peripheral data lines has been taken and that next data can be written to the peripheral interface register.

#### < Pulse mode >

CRA5 = “1”, CRA4 = “0” and CRA3 = “1”

CRB5 = “1”, CRB4 = “0” and CRB3 = “1”

This mode is shown in Figure 17, Figure 20 and Figure 21.



Figure 17 Timing of Hand-shake Mode and Pulse Mode





Figure 18 Bits 5, 4, 3 of CRA = 100 (Hand-shake Mode)



Figure 19 Bits 5, 4, 3 of CRB = 100 (Hand-shake Mode)



Figure 20 Bits 5, 4, 3 of CRA = 101 (Pulse Mode)



Figure 21 Bits 5, 4, 3 of CRB = 101 (Pulse Mode)



## ■ SUMMARY OF CONTROL REGISTERS CRA AND CRB

Control registers CRA and CRB have total control of CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub>, and CB<sub>2</sub> lines. The status of eight bits of the control registers may be read into the MPU. However, the MPU can only write into Bit 0 through Bit 5 (6 bits), since Bit 6 and Bit 7 are set only by CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub>, or CB<sub>2</sub>.

### ● Addressing PIAs

Before addressing PIAs, the data direction (DDR) must first be loaded with the bit pattern that defines how each line is to function, i.e., as an input or an output. A logic "1" in the data direction register defines the corresponding line as an output while a logic "0" defines the corresponding line as an input. Since the DDR and the peripheral interface register have the same address, the control register bit 2 determines which register is being addressed. If Bit 2 in the control register is a logic "0", then the DDR is addressed. If Bit 2 in the control register is a logic "1", the peripheral interface register is addressed. Therefore, it is essential that the DDR be loaded first before setting Bit 2 of the control register.

#### <Example>

Given a PIA with an address of 4004, 4005, 4006, and 4007. 4004 is the address of the A side peripheral interface register. 4005 is the address of the A side control register. 4006 is the address of the B side peripheral interface register. 4007 is the address of the B side control register. On the A side, Bits 0, 1, 2, and 3 will be defined as inputs, while Bits 4, 5, 6, and 7 will be used as outputs. On the B side, all lines will be used as outputs.

|               |              |
|---------------|--------------|
| PIA1AD = 4004 | (DDRA, PIRA) |
| PIA1AC = 4005 | (CRA)        |
| PIA1BD = 4006 | (DDRB, PIRB) |
| PIA1BC = 4007 | (CRB)        |

1. LDA A #%11110000 (4 outputs, 4 inputs)
2. STA A PIA1AD (Loads A DDR)
3. LDA A #%11111111 (All outputs)
4. STA A PIA1BD (Loads B DDR)
5. LDA A #%00000100 (Sets Bit 2)
6. STA A PIA1AC (Bit 2 set in A control register)
7. STA A PIA1BC (Bit 2 set in B control register)

Statement 2 addresses the DDR, since the control register (Bit 2) has not been loaded. Statements 6 and 7 load the control registers with Bit 2 set, so addressing PIA1AD or PIA1BD accesses the peripheral interface register.

### ● PIA Programming Via The Index Register

The program shown in the previous section can be accomplished using the Index Register.

1. LDX #\$F004
2. STX PIA1AD \$F0→PIA1AD;\$04→PIA1AC
3. LDX #\$FF04
4. STX PIA1BD \$FF→PIA1BD;\$04→PIA1BC

Using the index register in this example has saved six bytes of program memory as compared to the program shown in the previous section.

### ● Active Low Outputs

When all the outputs of given PIA port are to be active "Low" (True  $\leq 0.4$  volts), the following procedure should be used.

- a) Set Bit 2 in the control register.
- b) Store all 1s (\$FF) in the peripheral interface register.
- c) Clear Bit 2 in the control register.
- d) Store all 1s (\$FF) in the data direction register.
- e) Store control word (Bit 2 = 1) in control register.

#### <Example>

The B side of PIA1 is set up to have all active low outputs. CB<sub>1</sub> and CB<sub>2</sub> are set up to allow interrupts in the HAND-SHAKE MODE and CB<sub>1</sub> will respond to positive edges ("Low"-to-"High" transitions). Assume reset conditions. Addresses are set up and equated to the same labels as previous example.

1. LDA A #4
2. STA A PIA1BC Set Bit 2 in PIA1BC (control register)
3. LDA B #\$FF
4. STA B PIA1BD All 1s in peripheral interface register
5. CLR PIA1BC Clear Bit 2
6. STA B PIA1BD All 1s in data direction register
7. LDA A #\$27
8. STA A PIA1BC 00100111→ control register

The above procedure is required in order to avoid outputs going "Low", to the active "Low" TRUE STATE, when all 1s are stored to the data direction register as would be the case if the normal configuration procedure were followed.

### ● Interchanging RS<sub>0</sub> And RS<sub>1</sub>

Some system applications may require movement of 16 bits of data to or from the "outside world" via two PIA ports (A side + B side). When this is the case it is an advantage to interconnect RS<sub>1</sub> and RS<sub>0</sub> as follows.

RS<sub>0</sub> to A1 (Address Line A1)  
RS<sub>1</sub> to A0 (Address Line A0)

This will place the peripheral interface registers and control registers side by side in the memory map as follows.

| Table  | Example Address |
|--------|-----------------|
| PIA1AD | \$4004          |
| PIA1BD | \$4005          |
| PIA1AC | \$4006          |
| PIA1BC | \$4007          |

The index register or stackpointer may be used to move the 16-bit data in two 8-bit bytes with one instruction. As an example:

LDX PIA1AD PIA1AD→IX<sub>H</sub>; PIA1BD→IX<sub>L</sub>

### ● PIA – After Reset

When the RES (Reset Line) has been held "Low" for a minimum of one microsecond, all registers in the PIA will be cleared.

Because of the reset conditions, the PIA has been defined as



follows.

1. All I/O lines to the "outside world" have been defined as inputs.
2. CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub>, and CB<sub>2</sub> have been defined as interrupt input lines that are negative edge sensitive.
3. All the interrupts on the control lines are masked. Setting of interrupt flag bits will not cause IRQA or IRQB to go "Low".

#### ■ SUMMARY OF CA<sub>1</sub>-CB<sub>1</sub> PROGRAMMING

Bits 1 and 0 of the respective control registers are used to program the interrupt input control lines CA<sub>1</sub> and CB<sub>1</sub>.

| b1 | b0 |                                 |
|----|----|---------------------------------|
| 0  | 0  | b1 = Edge (0 = -, 1 = +)        |
| 0  | 1  | b0 = Mask (0 = Mask, 1 = Allow) |
| 1  | 0  |                                 |
| 1  | 1  |                                 |

Note that this is the same logic as Bits 4 and 3 for CA<sub>2</sub>-CB<sub>2</sub> when CA<sub>2</sub>-CB<sub>2</sub> are programmed as inputs.

#### ■ SUMMARY OF CA<sub>2</sub>-CB<sub>2</sub> PROGRAMMING

Bits 5, 4, and 3 of the control registers are used to program the operation of CA<sub>2</sub>-CB<sub>2</sub>.

| CA <sub>2</sub> -CB <sub>2</sub> | b5 | b4   | b3 | CA <sub>2</sub> -CB <sub>2</sub> Input Mode |
|----------------------------------|----|------|----|---------------------------------------------|
| Input                            | 0  | 0(-) | 0  | (Mask) b4 = Edge (0 = -, 1 = +)             |
| Mode                             | 0  | 0(-) | 1  | (Allow) b3 = Mask (0 = Mask, 1 = Allow)     |
|                                  | 0  | 1(+) | 0  | (Mask) b3 = Mask (0 = Mask, 1 = Allow)      |
|                                  | 0  | 1(+) | 1  | (Allow) b3 = Mask (0 = Mask, 1 = Allow)     |

  

| CA <sub>2</sub> -CB <sub>2</sub> | b1 | b0 | CA <sub>2</sub> -CB <sub>2</sub> Output Mode |
|----------------------------------|----|----|----------------------------------------------|
| Output                           | 1  | 0  | 0 - Handshake Mode                           |
| Mode                             | 1  | 0  | 1 - Pulse Mode                               |
|                                  | 1  | 1  | 0 } b3 Following Mode                        |
|                                  | 1  | 1  | 1 }                                          |

#### I/O As Follow:

##### Control Lines:

- CA<sub>1</sub> — Positive Edge, Allow Interrupt
- CA<sub>2</sub> — Pulse Mode
- CB<sub>1</sub> — Negative Edge, Mask Interrupt
- CB<sub>2</sub> — Hand Shake Mode

#### Assume Reset Condition

- PIA1AD
- PIA1AC
- PIA1BD
- PIA1BC

#### PIA Configuration Solution

```

LDA A #$BC      10111100
STA A PIA1AD    I/O to DDRA
LDA A #$FF      1111 1111
STA A PIA1BD    I/O to DDRB
LDA A #$2F      0010 1111
STA A PIA1AC    To "A" Control
LDA A #$24      0010 0100
STA A PIA1BC    To "B" Control

```



Figure 22 PIA Configuration Problem



## ■ NOTE FOR USE

## Compatibility with NMOS PIA (HD6821)

Table 7 Comparison CMOS PIA (HD6321) with NMOS PIA (HD6821)

| Item                       | CMOS PIA (HD6321)                                           | NMOS PIA (HD6821)         |
|----------------------------|-------------------------------------------------------------|---------------------------|
| Port A<br>Output<br>Buffer | <p>Three-state output</p> <p>Measure for Input floating</p> | <p>Pull-up output</p>     |
| Port B<br>Output<br>Buffer | <p>Three-state output</p> <p>Measure for Input floating</p> | <p>Three-state output</p> |

There is no difference between CMOS PIA and NMOS PIA in pin arrangement.

# HD6340/HD6840

## PTM (Programmable Timer Module)

The HD6340/HD6840 (PTM) is a programmable subsystem component of the HMCS6800 family designed to provide variable system time intervals.

The PTM has three 16-bit binary counters, three corresponding control registers and a status register. These counters are under software control and may be used to cause system interrupts and/or generate output signals. The PTM may be utilized for such tasks as frequency measurements, event counting, interval measuring and similar tasks. The device may be used for square wave generation, gated delay signals, single pulses of controlled duration, and pulse width modulation as well as system interrupts.

### ■ FEATURES

- Operates from a Single 5 volts Power Supply
  - Single System Clock Required (E)
  - Selectable Prescaler on Timer 3 Capable of 4 MHz for the HD6340/HD6840, 6 MHz for the HD63A40/HD68A40 and 8 MHz for the HD63B40/HD68B40.
  - Programmable Interrupts (IRQ) Output to MPU
  - Readable Down Counter Indicates Counts to Go until Time-out
  - Selectable Gating for Frequency or Pulse-Width Comparison
  - Three Asynchronous External Clock and Gate/Trigger Input Internally Synchronized
  - Three Maskable Outputs
- HD6340 —
- Wide Range Operating Voltage ( $V_{CC} = 5V \pm 10\%$ )
  - Low-Power, High-Speed, High-Density CMOS
  - Compatible with NMOS PTM (HD6840)
- HD6840 —
- Compatible with MC6840, MC68A40 and MC68B40

### ■ TYPE OF PRODUCTS

| Type    | Process | Clock Frequency | Package |
|---------|---------|-----------------|---------|
| HD6340  | CMOS    | 1.0 MHz         | DP-28   |
| HD63A40 |         | 1.5 MHz         |         |
| HD63B40 |         | 2.0 MHz         |         |
| HD6840  | NMOS    | 1.0 MHz         | DP-28   |
| HD68A40 |         | 1.5 MHz         |         |
| HD68B40 |         | 2.0 MHz         |         |

HD6340P, HD6840P



(DP-28)

The specifications of the HD6340 are for preliminary and may change hereafter.

Please make an inquire at sales office upon adoption of the HD6340.



(Top View)



HITACHI

**■ ABSOLUTE MAXIMUM RATINGS**

| Item                   | Symbol             | Value     |           | Unit |
|------------------------|--------------------|-----------|-----------|------|
|                        |                    | HD6340    | HD6840    |      |
| Supply Voltage         | V <sub>cc</sub> *  | -0.3~+7.0 | -0.3~+7.0 | V    |
| Input Voltage          | V <sub>in</sub> *  | -0.3~+7.0 | -0.3~+7.0 | V    |
| Maximum Output Current | I <sub>O</sub>  ** | 10        |           | mA   |
| Operating Temperature  | T <sub>opr</sub>   | -20~+75   | -20~+75   | °C   |
| Storage Temperature    | T <sub>stg</sub>   | -55~+150  | -55~+150  | °C   |

\* With respect to V<sub>ss</sub> (SYSTEM GND)\*\* Maximum output current is the maximum currents which can flow out from one output terminal or I/O common terminal. (D<sub>0</sub> ~ D<sub>7</sub>, O<sub>1</sub> ~ O<sub>3</sub>,  $\overline{I}_{RD}$ )

(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             | HD6340 |     |                 | HD6840          |     |                 | Unit |
|-----------------------|--------------------|--------|-----|-----------------|-----------------|-----|-----------------|------|
|                       |                    | min    | typ | max             | min             | typ | max             |      |
| Supply Voltage        | V <sub>cc</sub> *  | 4.5    | 5.0 | 5.5             | 4.75            | 5.0 | 5.25            | V    |
| Input "Low Voltage    | V <sub>IL</sub> *  | 0      | —   | 0.8             | -0.3            | —   | 0.8             | V    |
| Input "High" Voltage  | E <sub>1</sub> R/W | 2.6**  | —   | V <sub>cc</sub> | 2.2             | —   | V <sub>cc</sub> | V    |
|                       | Other Inputs       |        | 2.2 | —               | V <sub>cc</sub> | —   |                 |      |
| Operating Temperature | T <sub>opr</sub>   | -20    | 25  | 75              | -20             | 25  | 75              | °C   |

\* With respect to V<sub>ss</sub> (SYSTEM GND)

\*\* Characteristics to be improved.



■ ELECTRICAL CHARACTERISTICS

● DC CHARACTERISTICS (HD6340;  $V_{cc} = 5V \pm 10\%$ , HD6840;  $V_{cc} = 5V \pm 5\%$ ,  $V_{ss} = 0V$ ,  $T_a = -20\sim+75^\circ C$ , unless otherwise noted.)

| Item                                  | Symbol       | HD6340                                                                                                                                                                                                                                                                                                        |                       |     |          | HD6840                                                          |                                                                  |                  |     | Unit     |      |
|---------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----|----------|-----------------------------------------------------------------|------------------------------------------------------------------|------------------|-----|----------|------|
|                                       |              | Test Condition                                                                                                                                                                                                                                                                                                |                       | min | typ*     | max                                                             | Test Condition                                                   |                  | min |          |      |
| Input "High" Voltage                  | E, R/W       | $V_{IH}$                                                                                                                                                                                                                                                                                                      | 2.6**                 | —   | $V_{cc}$ | —                                                               | —                                                                | 2.2              | —   | $V_{cc}$ |      |
|                                       | Other Inputs |                                                                                                                                                                                                                                                                                                               | 2.2                   | —   | $V_{cc}$ | —                                                               |                                                                  | —                | —   | V        |      |
| Input "Low" Voltage                   | $V_{IL}$     | —                                                                                                                                                                                                                                                                                                             | -0.3                  | —   | 0.8      | —                                                               | —                                                                | -0.3             | —   | 0.8 V    |      |
| Input Leakage Current                 | $I_{in}$     | $V_{in} = 0 \sim V_{cc}$ (Except $D_0 \sim D_7$ )                                                                                                                                                                                                                                                             | -2.5                  | —   | 2.5      | $V_{in}=0 \sim V_{cc}$ (Except $D_0 \sim D_7$ )                 | -2.5                                                             | —                | 2.5 | $\mu A$  |      |
| Three-State Input Current (Off-state) | $I_{TSI}$    | $V_{in} = 0.4 \sim V_{cc}$ ,<br>$V_{cc} = 5.5V$ ( $D_0 \sim D_7$ )                                                                                                                                                                                                                                            | -10                   | —   | 10       | $V_{in} = 0.4 \sim 2.4V$<br>$V_{cc} = 5.25V$ ( $D_0 \sim D_7$ ) | -10                                                              | —                | 10  | $\mu A$  |      |
| Output "High" Voltage                 | $V_{OH}$     | $I_{LOAD} = -400\mu A$ ( $D_0 \sim D_7$ )                                                                                                                                                                                                                                                                     | 4.1                   | —   | —        | $I_{LOAD} = -205\mu A$ ( $D_0 \sim D_7$ )                       | 2.4                                                              | —                | —   | V        |      |
|                                       |              | $I_{LOAD} \leq 10\mu A$ ( $D_0 \sim D_7$ )                                                                                                                                                                                                                                                                    | $V_{cc}-0.1$          | —   | —        |                                                                 |                                                                  | —                | —   | —        |      |
|                                       |              | $I_{LOAD} = -400\mu A$ (Other Outputs)                                                                                                                                                                                                                                                                        | 4.1                   | —   | —        |                                                                 |                                                                  | —                | —   | —        |      |
|                                       |              | $I_{LOAD} \leq 10\mu A$ (Other Outputs)                                                                                                                                                                                                                                                                       | $V_{cc}-0.1$          | —   | —        |                                                                 |                                                                  | —                | —   | —        |      |
| Output "Low" Voltage                  | $V_{OL}$     | $I_{LOAD} = 1.6mA$ ( $D_0 \sim D_7$ )                                                                                                                                                                                                                                                                         | —                     | —   | 0.4      | $I_{LOAD} = 1.6mA$ ( $D_0 \sim D_7$ )                           | —                                                                | —                | 0.4 | V        |      |
|                                       |              | $I_{LOAD} = 3.2mA$ ( $O_1 \sim O_3$ , $\overline{IRQ}$ )                                                                                                                                                                                                                                                      |                       |     |          | $I_{LOAD} = 3.2mA$ ( $O_1 \sim O_3$ , $\overline{IRQ}$ )        |                                                                  |                  |     |          |      |
| Output Leakage Current (Off-state)    | $I_{LOH}$    | $V_{OH} = V_{cc} (\overline{IRQ})$                                                                                                                                                                                                                                                                            | —                     | —   | 10       | $V_{OH} = 2.4V (\overline{IRQ})$                                | —                                                                | —                | 10  | $\mu A$  |      |
| Supply Current                        | $I_{CC}$     | <ul style="list-style-type: none"> <li>• Chip is not selected.</li> <li>• All counter latches are preset.</li> <li>• <math>O_1 \sim O_3</math> outputs are masked.</li> <li>• Input level (Except E) <math>\{V_{IH} \text{ min} = V_{cc} - 0.8V</math><br/><math> V_{IL} \text{ max} = 0.8V</math></li> </ul> | $E = 1.0 \text{ MHz}$ | —   | —        | 1.0                                                             | mA                                                               |                  |     |          |      |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $E = 1.5 \text{ MHz}$ | —   | —        | 1.5                                                             |                                                                  |                  |     |          |      |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $E = 2.0 \text{ MHz}$ | —   | —        | 2.0                                                             |                                                                  |                  |     |          |      |
|                                       |              | <ul style="list-style-type: none"> <li>• Chip is not selected</li> <li>• Counters are operating.</li> <li>• <math>O_1 \sim O_3</math> operating with load.</li> <li>• Input level (Except E) <math>\{V_{IH} \text{ min} = V_{cc} - 0.8V</math><br/><math> V_{IL} \text{ max} = 0.8V</math></li> </ul>         | $E = 1.0 \text{ MHz}$ | —   | —        | 3.0                                                             |                                                                  |                  |     |          |      |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $E = 1.5 \text{ MHz}$ | —   | —        | 4.0                                                             |                                                                  |                  |     |          |      |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $E = 2.0 \text{ MHz}$ | —   | —        | 6.0                                                             |                                                                  |                  |     |          |      |
|                                       |              | <ul style="list-style-type: none"> <li>• Data bus in R/W operation.</li> <li>• Counters are operating.</li> <li>• <math>O_1 \sim O_3</math> operating with load.</li> </ul>                                                                                                                                   | $E = 1.0 \text{ MHz}$ | —   | —        | 5.0                                                             |                                                                  |                  |     |          |      |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $E = 1.5 \text{ MHz}$ | —   | —        | 8.0                                                             |                                                                  |                  |     |          |      |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $E = 2.0 \text{ MHz}$ | —   | —        | 10.0                                                            |                                                                  |                  |     |          |      |
| Power Dissipation                     | $P_D$        |                                                                                                                                                                                                                                                                                                               |                       |     |          | —                                                               | 330                                                              | 550              | mW  |          |      |
| Input Capacitance                     | $C_{in}$     | $V_{in} = 0V$ ,<br>$T_a = 25^\circ C$ ,<br>$f = 1 \text{ MHz}$                                                                                                                                                                                                                                                | $D_0 \sim D_7$        | —   | —        | 12.5                                                            | $V_{in} = 0V$ ,<br>$T_a = 25^\circ C$ ,<br>$f = 1.0 \text{ MHz}$ | $D_0 \sim D_7$   | —   | —        | 12.5 |
|                                       |              |                                                                                                                                                                                                                                                                                                               | Other Input           | —   | —        | 7.5                                                             | Other Input                                                      | —                | —   | 7.5      | pF   |
| Output Capacitance                    | $C_{out}$    | $V_{in} = 0V$ ,<br>$T_a = 25^\circ C$ ,<br>$f = 1 \text{ MHz}$                                                                                                                                                                                                                                                | $\overline{IRQ}$      | —   | —        | 5.0                                                             | $V_{in} = 0V$ ,<br>$T_a = 25^\circ C$ ,<br>$f = 1.0 \text{ MHz}$ | $\overline{IRQ}$ | —   | —        | 5.0  |
|                                       |              |                                                                                                                                                                                                                                                                                                               | $O_1, O_2, O_3$       | —   | —        | 10.0                                                            | $O_1, O_2, O_3$                                                  | —                | —   | 10.0     | pF   |

\*  $T_a = 25^\circ C$ ,  $V_{cc} = 5.0V$    \*\*  $V_{IH} = 2.2V$  at  $V_{cc} = 5V \pm 5\%$ ,  $T_a = 0\sim 70^\circ C$ , Characteristics to be improved.



## HD6340/HD6840

• AC CHARACTERISTICS (HD6340;  $V_{CC} = 5V \pm 10\%$ , HD6840;  $5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_A = -20\sim+75^\circ C$ , unless otherwise noted.)

### 1. MPU READ TIMING

| Item                      | Symbol           | Test Condition | HD6340 |       | HD63A40 |       | HD63B40 |       | HD6840 |       | HD68A40 |       | HD68B40 |       | Unit |
|---------------------------|------------------|----------------|--------|-------|---------|-------|---------|-------|--------|-------|---------|-------|---------|-------|------|
|                           |                  |                | min    | max   | min     | max   | min     | max   | min    | max   | min     | max   | min     | max   |      |
| Enable Cycle Time         | $t_{cycE}$       | Fig. 1         | 1000   | 10000 | 666     | 10000 | 500     | 10000 | 1000   | 10000 | 666     | 10000 | 500     | 10000 | ns   |
| Enable "High" Pulse Width | $PWEH$           |                | 450    | 9500  | 280     | 9500  | 220     | 9500  | 450    | 4500  | 280     | 4500  | 220     | 4500  | ns   |
| Enable "Low" Pulse Width  | $PWEL$           |                | 430    | 9500  | 280     | 9500  | 210     | 9500  | 430    | —     | 280     | —     | 210     | —     | ns   |
| Enable Rise and Fall Time | $t_{ER}, t_{EF}$ |                | —      | 25    | —       | 25    | —       | 20    | —      | 25    | —       | 25    | —       | 25    | ns   |
| Address Set-up Time       | $t_{AS}$         |                | 80     | —     | 60      | —     | 40      | —     | 140    | —     | 140     | —     | 70      | —     | ns   |
| Data Delay Time           | $t_{DDR}$        |                | —      | 290   | —       | 180   | —       | 150   | —      | 320   | —       | 220   | —       | 180   | ns   |
| Data Hold Time            | $t_{HR}$         |                | 20     | 100   | 20      | 100   | 20      | 100   | 10     | —     | 10      | —     | 10      | —     | ns   |
| Address Hold Time         | $t_{AH}$         |                | 10     | —     | 10      | —     | 10      | —     | 10     | —     | 10      | —     | 10      | —     | ns   |
| Data Access Time          | $t_{ACC}$        |                | —      | 370   | —       | 240   | —       | 190   | —      | 480   | —       | 360   | —       | 250   | ns   |

### 2. MPU WRITE TIMING

| Item                      | Symbol           | Test Condition | HD6340 |       | HD63A40 |       | HD63B40 |       | HD6840 |       | HD68A40 |       | HD68B40 |       | Unit |
|---------------------------|------------------|----------------|--------|-------|---------|-------|---------|-------|--------|-------|---------|-------|---------|-------|------|
|                           |                  |                | min    | max   | min     | max   | min     | max   | min    | max   | min     | max   | min     | max   |      |
| Enable Cycle Time         | $t_{cycE}$       | Fig. 2         | 1000   | 10000 | 666     | 10000 | 500     | 10000 | 1000   | 10000 | 666     | 10000 | 500     | 10000 | ns   |
| Enable "High" Pulse Width | $PWEH$           |                | 450    | 9500  | 280     | 9500  | 220     | 9500  | 450    | 4500  | 280     | 4500  | 220     | 4500  | ns   |
| Enable "Low" Pulse Width  | $PWEL$           |                | 430    | 9500  | 280     | 9500  | 210     | 9500  | 430    | —     | 280     | —     | 210     | —     | ns   |
| Enable Rise and Fall Time | $t_{ER}, t_{EF}$ |                | —      | 25    | —       | 25    | —       | 20    | —      | 25    | —       | 25    | —       | 25    | ns   |
| Address Set-up Time       | $t_{AS}$         |                | 80     | —     | 60      | —     | 40      | —     | 140    | —     | 140     | —     | 140     | —     | ns   |
| Data Set-up Time          | $t_{DSW}$        |                | 165    | —     | 80      | —     | 60      | —     | 195    | —     | 80      | —     | 60      | —     | ns   |
| Data Hold Time            | $t_{HW}$         |                | 10     | —     | 10      | —     | 10      | —     | 10     | —     | 10      | —     | 10      | —     | ns   |
| Address Hold Time         | $t_{AH}$         |                | 10     | —     | 10      | —     | 10      | —     | 10     | —     | 10      | —     | 10      | —     | ns   |

### 3. TIMING OF PTM SIGNAL

| Item                     | Symbol                                        | Test Condition | HD6340         |                             | HD63A40                      |     | HD63B40                      |     | HD6840                       |      | HD68A40                      |      | HD68B40                      |      | Unit                         |      |    |
|--------------------------|-----------------------------------------------|----------------|----------------|-----------------------------|------------------------------|-----|------------------------------|-----|------------------------------|------|------------------------------|------|------------------------------|------|------------------------------|------|----|
|                          |                                               |                | min            | max                         | min                          | max | min                          | max | min                          | max  | min                          | max  | min                          | max  |                              |      |    |
| Input Rise and Fall Time | $\bar{C}_3, \bar{G}, \bar{RES}$               | $t_r, t_f$     | Fig. 3, Fig. 4 | —                           | 1000*                        | —   | 666*                         | —   | 500*                         | —    | 1000*                        | —    | 666*                         | —    | 500*                         | ns   |    |
| Input "Low" Pulse Width  | $\bar{C}_3, \bar{G}, \bar{RES}$               | $PW_L$         |                | Fig. 3<br>Asynchronous Mode | $t_{cycE} + t_{SU} + t_{HD}$ | —   | $t_{cycE} + t_{SU} + t_{HD}$ | —   | $t_{cycE} + t_{SU} + t_{HD}$ | —    | $t_{cycE} + t_{SU} + t_{HD}$ | —    | $t_{cycE} + t_{SU} + t_{HD}$ | —    | $t_{cycE} + t_{SU} + t_{HD}$ | —    |    |
| Input "High" Pulse Width | $\bar{C}_3, \bar{G}$                          | $PW_H$         |                | Fig. 4<br>Asynchronous Mode | $t_{cycE} + t_{SU} + t_{HD}$ | —   | $t_{cycE} + t_{SU} + t_{HD}$ | —   | $t_{cycE} + t_{SU} + t_{HD}$ | —    | $t_{cycE} + t_{SU} + t_{HD}$ | —    | $t_{cycE} + t_{SU} + t_{HD}$ | —    | $t_{cycE} + t_{SU} + t_{HD}$ | —    |    |
| Input Setup Time         | $\bar{C}_3, \bar{G}, \bar{RES}$               | $t_{SU}$       |                | Fig. 5<br>Synchronous Mode  | 200                          | —   | 120                          | —   | 75                           | —    | 200                          | —    | 120                          | —    | 75                           | —    |    |
| Input Hold Time          | $\bar{C}_3, \bar{G}, \bar{RES}$               | $t_{HD}$       |                | Fig. 5<br>Synchronous Mode  | 50                           | —   | 50                           | —   | 50                           | —    | 50                           | —    | 50                           | —    | 50                           | —    |    |
| Input Pulse Width        | $\bar{C}_3$ ( $\leftarrow$ 8 Pre-scaler Mode) | $PW_L, PW_H$   |                | Asynchronous Mode           | 120                          | —   | 80                           | —   | 60                           | —    | 125                          | —    | 84                           | —    | 62.5                         | —    |    |
| Output Delay Time        | $O_1 \sim O_3$                                | $t_{co}$       |                | Fig. 6                      | —                            | 200 | —                            | 200 | —                            | 200  | —                            | 700  | —                            | 460  | —                            | 340  | ns |
|                          |                                               | $t_{cm}$       |                |                             |                              |     |                              |     |                              |      | —                            | 450  | —                            | 450  | —                            | 340  | ns |
|                          |                                               | $t_{emos}$     |                |                             |                              |     |                              |     |                              |      | —                            | 2000 | —                            | 1350 | —                            | 1000 | ns |
| Interrupt Release Time   | $t_{IR}$                                      | Fig. 7         | —              | 1200                        | —                            | 900 | —                            | 700 | —                            | 1200 | —                            | 900  | —                            | 700  | ns                           |      |    |

\*  $t_r, t_f \leq t_{cycE}$





Figure 3 Input Pulse Width "Low"



Figure 4 Input Pulse Width "High"



Figure 5 Input Setup and Hold Times



Figure 6 Output Delay



Figure 7 IRQ Release Time

\* 2.4V for HD6840  
\*\*, \*\*\* HD6840 only



#### ■ GENERAL DESCRIPTION

The PTM is part of the HMCS6800 microprocessor family and is fully bus compatible with HD6800 systems. The three timers in the HD6340/HD6840 operate independently and in several distinct modes to fit a wide variety of measurement and synthesis applications.

The PTM is an integrated set of three distinct counter/timers. It consists of three 16-bit data latches, three 16-bit counters (clocked independently), and the comparison and enable circuitry necessary to implement various measurement and synthesis functions. In addition, it contains interrupt drivers to alert the processor that a particular function has been completed.

In a typical application, a timer will be loaded by first storing two bytes of data into an associated Counter Latch. This data is then transferred into the counter via a Counter initialization cycle. If the counter is enabled, the counter decrements on each subsequent clock period which may be an external clock, or Enable (E) until one of several predetermined conditions causes it to halt or recycle. The timers are thus programmable, cyclic in nature, controllable by external inputs or the MPU program, and accessible by the MPU at any time.

#### ■ PTM INTERFACE SIGNALS FOR MPU

The Programmable Timer Module (PTM) interfaces to the HMCS6800 Bus with an eight-bit bidirectional data bus, two Chip Select lines, a Read/Write line, an Enable (System  $\phi_2$ ) line, an Interrupt Request line, an external Reset line, and three Register Select lines. These signals, in conjunction with the HD6800 VMA output, permit the MPU to control the PTM. VMA should be utilized in conjunction with an MPU address line into a Chip Select of the PTM, when the HD6800, HD6802 are used.

#### • Bidirectional Data ( $D_0 \sim D_7$ )

|              |                 |
|--------------|-----------------|
| Input/Output | Pin No. 25 ~ 18 |
|--------------|-----------------|

The bidirectional data lines ( $D_0 \sim D_7$ ) allow the transfer of data between the MPU and PTM. The data bus output drivers are three-state devices which remain in the high-impedance (off) state except when the MPU performs a PTM read operation (Read/Write and Enable lines "High" and PTM Chip Selects

- activated).
- Chip Select ( $\bar{CS}_0, CS_1$ )

|       |                |
|-------|----------------|
| Input | Pin No. 15, 16 |
|-------|----------------|

These two signals are used to activate the Data Bus interface and allow transfer of data from the PTM. With  $\bar{CS}_0 = \text{"Low"}$  and  $CS_1 = \text{"High"}$ , the device is selected and data transfer will occur.

- Read/Write (R/W)

|       |            |
|-------|------------|
| Input | Pin No. 13 |
|-------|------------|

This signal is generated by the MPU to control the direction of data transfer on the Data Bus. With the PTM selected, a "Low" state on the PTM R/W line enables the input buffers and data is transferred from the MPU to the PTM on the trailing edge of the Enable (System  $\phi_2$ ) signal. Alternately, (under the same conditions) R/W = "High" and Enable "High" allows data in the PTM to be read by the MPU.

- Enable (E)

|       |            |
|-------|------------|
| Input | Pin No. 17 |
|-------|------------|

This signal synchronizes data transfer between the MPU and the PTM. It also performs an equivalent synchronization function on the external clock, reset, and gate inputs of the PTM.

- Interrupt Request (IRQ)

|                     |           |
|---------------------|-----------|
| Output (open drain) | Pin No. 9 |
|---------------------|-----------|

The active "Low" Interrupt Request signal is normally tied directly (or through priority interrupt circuitry) to the IRQ input of the MPU. This is an "open drain" output (no load device on the chip) which permits other similar interrupt request lines to be tied together in a wire-OR configuration.

The IRQ line is activated if, and only if, the Composite Interrupt Flag (Bit 7 of the Internal Status Register) is asserted. The



conditions under which the  $\overline{IRQ}$  line is activated are discussed in conjunction with the Status Register.

- **Reset (RES)**

|       |           |
|-------|-----------|
| Input | Pin No. 8 |
|-------|-----------|

A "Low" level at this input is clocked into the PTM by the Enable (System  $\phi_2$ ) input. Two Enable pulses are required to synchronize and process the signal. The PTM then recognizes the active "Low" or inactive "High" on the third Enable pulse. If the  $\overline{RES}$  signal is asynchronous, an additional Enable period is required if setup times are not met. The  $\overline{RES}$  input must be stable "High"/"Low" for the minimum time stated in the AC Characteristics.

Recognition of a "Low" level at this input by the PTM causes the following action to occur:

- a. All counter latches are preset to their maximal count values.
- b. All Control Register bits are cleared with the exception of CR10 (internal reset bit) which is set.
- c. All counters are preset to the contents of the latches.
- d. All counter outputs are reset and all counter clocks are disabled.
- e. All Status Register bits (interrupt flags) are cleared.

- **Register Select Lines ( $RS_0$ ,  $RS_1$ ,  $RS_2$ )**

These inputs are used in conjunction with the R/W line to select the internal registers, counters and latches as shown in Table 1.

Table 1 Register Selection

| Register Select Inputs * |        |        | Operations                                                                   |                          |
|--------------------------|--------|--------|------------------------------------------------------------------------------|--------------------------|
| $RS_2$                   | $RS_1$ | $RS_0$ | $R/W = "Low"$                                                                | $R/W = "High"$           |
| L                        | L      | L      | CR20 = "0" Write Control Register #3<br>CR20 = "1" Write Control Register #1 | All bits "0"             |
| L                        | L      | H      | Write Control Register #2                                                    | Read Status Register     |
| L                        | H      | L      | Write MSB Buffer Register                                                    | Read Timer #1 Counter    |
| L                        | H      | H      | Write Timer #1 Latches                                                       | Read LSB Buffer Register |
| H                        | L      | L      | Write MSB Buffer Register                                                    | Read Timer #2 Counter    |
| H                        | L      | H      | Write Timer #2 Latches                                                       | Read LSB Buffer Register |
| H                        | H      | L      | Write MSB Buffer Register                                                    | Read Timer #3 Counter    |
| H                        | H      | H      | Write Timer #3 Latches                                                       | Read LSB Buffer Register |

\* L; "Low" level, H; "High" level

of the setup and hold times for the inputs. The asynchronous clock rate can vary from dc to the limit imposed by Enable (System  $\phi_2$ ) Setup, and Hold time.

The external clock inputs are clocked in by Enable (System  $\phi_2$ ) pulses. Three Enable periods are used to synchronize and process the external clock. The fourth Enable pulse decrements the internal counter. This does not affect the input frequency, it merely creates a delay between a clock input transition and internal recognition of that transition by the PTM. All references to  $\overline{C}$  inputs in this document relate to internal recognition of the input transition. Note that a clock "High" or "Low" level which does not meet setup and hold time specifications may require an additional Enable pulse for recognition. When observing recurring events, a lack of synchronization will result in "jitter" being observed on the output of the PTM when using asynchronous clocks and gate input signals. There are two types of jitter. "System jitter" is the result of the input signals being out of synchronization with the Enable (System  $\phi_2$ ), permitting

|       |                    |
|-------|--------------------|
| Input | Pin No. 10, 11, 12 |
|-------|--------------------|

It has been previously stated that the PTM is accessed via MPU Load and Store operations in much the same manner as a memory device. The instructions available with the HMC6800 family of MPUs which perform operations directly on memory should not be used when the PTM is accessed. These instructions actually fetch a byte from memory, perform an operation, then restore it to the same address location. Since the PTM used the R/W line as an additional register select input, the modified data may not be restored to the same register if these instructions are used.

- **PTM ASYNCHRONOUS INPUT/OUTPUT SIGNALS**

Each of the three timers within the PTM has external clock and gate inputs as well as a counter output line. The inputs are high impedance, TTL compatible lines and outputs are capable of driving two standard TTL loads.

- **Clock Inputs ( $\overline{C}_1$ ,  $\overline{C}_2$ ,  $\overline{C}_3$ )**

|       |                  |
|-------|------------------|
| Input | Pin No. 28, 4, 7 |
|-------|------------------|

Input pins  $\overline{C}_1$ ,  $\overline{C}_2$ , and  $\overline{C}_3$  will accept asynchronous TTL voltage level signals to decrement Timers 1, 2, and 3, respectively. The "High" and "Low" levels of the external clocks must each be stable for at least one system clock period plus the sum

signals with marginal setup and hold time to be recognized by either the bit time nearest the input transition or the subsequent bit time.

"Input jitter" can be as great as the time between input signal negative going transitions plus the system jitter, if the first transition is recognized during one system cycle, and not recognized the next cycle, or vice versa.

External clock input  $\overline{C}_3$  represents a special case when Timer #3 is programmed to utilize its optional  $\frac{1}{8}$  prescaler mode. The maximum input frequency and allowable duty cycles for this case are specified under the AC Characteristics. The output of the  $\frac{1}{8}$  prescaler is treated in the same manner as the previously discussed clock inputs. That is, it is clocked into the counter by Enable pulses, is recognized on the fourth Enable pulse (provided setup and hold time requirements are met), and must



produce an output pulse at least as wide as the sum of an Enable period, setup, and hold times.



- **Gate Inputs ( $\overline{G}_1$ ,  $\overline{G}_2$ ,  $\overline{G}_3$ )**

| Input | Pin No. 26, 2, 5 |
|-------|------------------|
|-------|------------------|

Input pins  $\overline{G}_1$ ,  $\overline{G}_2$ , and  $\overline{G}_3$  accept asynchronous TTL-compatible signals which are used as triggers or clock gating functions to Timers 1, 2, and 3, respectively. The gating inputs are clocked into the PTM by the Enable (System  $\phi_1$ ) signal in the same manner as the previously discussed clock inputs. That is, a Gate transition is recognized by the PTM on the fourth Enable pulse (provided setup and hold time requirements are met), and the "High" or "Low" levels of the Gate input must be stable for at least one system clock period plus the sum of setup and hold times. All references to  $\overline{G}$  transition in this document relate to internal recognition of the input transition.

The Gate inputs of all timers directly affected the internal 16-bit counter. The operation of  $\overline{G}_3$  is therefore independent of the  $\div 8$  prescaler selection.

- **Timer Outputs ( $O_1$ ,  $O_2$ ,  $O_3$ )**

| Output | Pin No. 27, 3, 6 |
|--------|------------------|
|--------|------------------|

Timer outputs  $O_1$ ,  $O_2$ , and  $O_3$  are capable of driving up to two TTL loads and produce a defined output waveform for either Continuous or Single-Shot Timer modes. Output waveform definition is accomplished by selecting either Single 16-bit or Dual 8-bit operating modes. The single 16-bit mode will produce a square-wave output in the continuous timer mode and will produce a single pulse in the Single-Shot Timer mode. The Dual 8-bit mode will produce a variable duty cycle pulse in both the continuous and single shot Timer modes. "1" bit of each Control Register (CRX7) is used to enable the corresponding output. If this bit is cleared, the output will remain "Low" ( $V_{OL}$ ) regardless of the operating mode.

If it is cleared while the output is high the output will go low during the first enable cycle following a write to the Control Register.

The Continuous and Single-Shot Timer Modes are the only ones for which output response is defined in this data sheet. Signals appear at the outputs (unless CRX7 = "0") during Frequency and Pulse Width comparison modes, but the actual waveform is not predictable in typical applications.

- **CONTROL REGISTER**

Each timer in the HD6340 has a corresponding write-only Control Register. Control Register #2 has a unique address space (RS0="High", RS1="Low", RS2="Low") and therefore may be written into at any time. The remaining Control Registers (#1 and #3) share the Address Space selected by a "Low" level on all Register Select inputs.

- **CR20**

The least-significant bit of Control Register #2 (CR20) is used as an additional addressing bit for Control Registers #1 and

#3. Thus, with all Register selects and R/W inputs at "Low" level. Control Register #1 will be written into if CR20 is a logic "1". Under the same conditions, control Register #3 can also be written into after a RES "Low" condition has occurred, since all control register bits (except CR10) are cleared. Therefore, one may write in the sequence CR3, CR2, CR1.

- **CR10**

The least-significant bit of Control Register #1 is used as an internal Reset bit. When this bit is a logic "0", all timers are allowed to operate in the modes prescribed by the remaining bits of the control registers. Writing a "1" into CR10 causes all counters to be preset with the contents of the corresponding counter latches, all counter clocks to be disabled, and the timer outputs and interrupt flags (Status Register) to be reset. Counter Latches and Control Registers are undisturbed by an Internal Reset and may be written into regardless of the state of CR10.

- **CR30**

The least-significant bit of Control Register #3 is used as a selector for a  $\div 8$  prescaler which is available with Timer #3 only. The prescaler, if selected, is effectively placed between the clock input circuitry and the input to Counter #3. It can therefore be used with either the internal clock (Enable) or an external clock source.

- **CRX1 ~ CRX7 (X=1~3)**

The functions depicted in the foregoing discussions are tabulated in Table 2 for ease of reference.

Control Register Bits CR10, CR20, and CR30 are unique in that each selects a different function. The remaining bits (1 through 7) of each Control Register select common functions, with a particular Control Register affecting only its corresponding timer.

- **CRX1**

Bit 1 of Control Register #1 (CR11) selects whether an internal or external clock source is to be used with Timer #1. Similarly, CR21 selects the clock source for Timer #2, and CR31 performs this function for Timer #3. The function of each bit of Control Register "X" can therefore be defined as shown in the remaining section of Table 2.

- **CRX2**

Control Register Bit 2 selects whether the binary information contained in the Counter Latches (and subsequently loaded into the counter) is to be treated as a single 16-bit word or two 8-bit bytes. In the single 16-bit Counter Mode (CRX2=0) the counter will decrement to zero after N + 1 enabled ( $\overline{G}$ ="Low") clock periods, where N is defined as the 16-bit number in the Counter Latches. With CRX2 = 1, a similar Time Out will occur after  $(L + 1) \cdot (M + 1)$  enabled clock periods, where L and M, respectively, refer to the LSB and MSB bytes in the Counter Latches.

- **CRX3 ~ CRX7**

Control Register Bits 3, 4, and 5 are explained in detail in the Timer Operating Mode section. Bit 6 is an interrupt mask bit which will be explained more fully in conjunction with the Status Register, and bit 7 is used to enable the corresponding Timer Output. A summary of the control register programming modes is shown in Table 3.

- **STATUS REGISTER/INTERRUPT FLAGS**

The PTM has an internal Read-Only Status Register which contains four Interrupt Flags. (The remaining four bits of the register are not used, and default to "0" when being read.) Bits 0, 1, and 2 are assigned to Timers 1, 2, and 3, respectively, as individual flag bits, while Bit 7 is a Composite Interrupt Flag. This flag bit will be asserted if any of the individual flag bits is

Table 2 Control Register Bits

| CONTROL REGISTER #1                                                      |                                                                                                          | CONTROL REGISTER #2                                                                                                             |                                                           | CONTROL REGISTER #3                                             |                        |  |  |
|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------|------------------------|--|--|
| CR10                                                                     | Internal Reset Bit                                                                                       | CR20                                                                                                                            | Control Register Address Bit                              | CR30                                                            | Timer #3 Clock Control |  |  |
| "0" All timers allowed to operate<br>"1" All timers held in preset state |                                                                                                          | "0" CR #3 may be written<br>"1" CR #1 may be written                                                                            |                                                           | "0" T3 Clock is not prescaled<br>"1" T3 Clock is prescaled by 8 |                        |  |  |
| CRX1*                                                                    |                                                                                                          | Timer #X Clock Source<br>TX uses external clock source on CX input<br>TX uses Enable clock                                      |                                                           |                                                                 |                        |  |  |
| CRX2                                                                     |                                                                                                          | Timer #X Counting Mode Control<br>TX configured for normal (16-bit) counting mode<br>TX configured for dual 8-bit counting mode |                                                           |                                                                 |                        |  |  |
| CRX3                                                                     | CRX4                                                                                                     | CRX5                                                                                                                            | Timer #X Counter Mode and Interrupt Control (See Table 3) |                                                                 |                        |  |  |
| CRX6                                                                     | Timer #X Interrupt Enable<br>Interrupt Flag masked on <u>IRQ</u><br>Interrupt Flag enabled to <u>IRQ</u> |                                                                                                                                 |                                                           |                                                                 |                        |  |  |
| CRX7                                                                     | Timer #X Counter Output Enable<br>TX Output masked on output OX<br>TX Output enabled on output OX        |                                                                                                                                 |                                                           |                                                                 |                        |  |  |

\* Control Register for Timer 1, 2, or 3, Bit 1.

set while Bit 6 of the corresponding Control Register is at a logic "1". The conditions for asserting the Composite Interrupt Flag bit can therefore be expressed as:

$$\text{INT} = I_1 \cdot \text{CR16} + I_2 \cdot \text{CR26} + I_3 \cdot \text{CR36}$$

where INT = Composite Interrupt Flag (Bit 7)

$I_1$  = Timer #1 Interrupt Flag (Bit 0)

$I_2$  = Timer #2 Interrupt Flag (Bit 1)

$I_3$  = Timer #3 Interrupt Flag (Bit 2)

| STATUS REGISTER |   |   |   |   |       |       |       |
|-----------------|---|---|---|---|-------|-------|-------|
| 7               | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
| INT             | / | / | / | / | $I_3$ | $I_3$ | $I_3$ |

An interrupt flag is cleared by a Timer Reset condition, i.e., External RES = "Low" or Internal Reset Bit (CR10) = "1". It will also be cleared by a Read Timer Counter Command provided that the Status Register has previously been read while the interrupt flag was set. This condition on the Read Status Register - Read Timer Counter (RS-RT) sequence is designed to prevent missing interrupts which might occur after the status register is read, but prior to reading the Timer Counter.

An Individual Interrupt Flag is also cleared by a Write Timer Latches (W) command or a Counter Initialization (CI) sequence, provided that W or CI affects the Timer corresponding to the individual Interrupt Flag.

#### ■ COUNTER LATCH INITIALIZATION

Each of the three independent timers consists of a 16-bit addressable counter and 16 bits of addressable latches. The counters are preset to the binary numbers stored in the latches. Counter initialization results in the transfer of the latch contents to the counter. See notes in Table 5 regarding the binary number N, L, or M placed into the Latches and their relationship to the output waveforms and counter Time-Outs.

Since the PTM data bus is 8-bits wide and the counters are 16-bits wide, a temporary register (MSB Buffer Register) is provided. This "write only" register is for the Most Significant

Byte of the desired latch data. Three addresses are provided for the MSB Buffer Register (as indicated in Table 1), but they all lead to the same Buffer. Data from the MSB Buffer will automatically be transferred into the Most Significant Byte of Timer #X when a Write Timer #X Latches Command is performed. So it can be seen that the PTM has been designed to allow transfer of two bytes of data into the counter latches provided that the MSB is transferred first.

In many applications, the source of the data will be as HMCS6800 MPU. It should be noted that the 16-bit store operations of the HMCS6800 microprocessors (STS and STX etc.) transfer data in the order required by the PTM. A Store Index Register Instruction, for example, results in the MSB of the X register being transferred to the selected address, then the LSB of the X register being written into the next higher location. Thus, either the index register or stack pointer may be transferred directly into a selected counter latch with a single instruction.

A logic "Low" at the RES input also initializes the counter latches. In this case, all latches will assume a maximum count of  $(65,536)_{10}$ . It is important to note that an Internal Reset (Bit 0 of Control Register 1 Set) has no effect on the counter latches.

#### ■ COUNTER INITIALIZATION

Counter Initialization is defined as the transfer of data from the latches to the counter with subsequent clearing of the Individual Interrupt Flag associated with the counter. Counter Initialization always occurs when a reset condition (RES = "Low" or CR10 = "1") is recognized. It can also occur - depending on Timer Mode - with a Write Timer Latches command or recognition of a negative transition of the Gate input.

Counter recycling or re-initialization occurs when a negative transition of the clock input is recognized after the counter has reached an all-zero state. In this case, data is transferred from the Latches to the Counter.

#### ■ TIMER OPERATING MODES

The PTM has been designed to operate effectively in a wide variety of applications. This is accomplished by using three bits of each control register (CRX3, CRX4, and CRX5) to



defined different operating modes of the Timers. These modes are divided into Wave Synthesis and Wave Measurement modes, and outlined in Table 3.

Table 3 Operating Modes

| Control Register |      |      | Timer Operating Mode   | Wave<br>Synthesis |
|------------------|------|------|------------------------|-------------------|
| CRX3             | CRX4 | CRX5 |                        |                   |
| 0                | *    | 0    | Continuous             |                   |
| 0                | *    | 1    | Single-Shot            |                   |
| 1                | 0    | *    | Frequency Comparison   | Wave              |
| 1                | 1    | *    | Pulse Width Comparison | Measurement       |

\* Defines Additional Timer Functions.

One of the WAVE SYNTHESIS modes is the Continuous Operating mode, which is useful for cyclic wave generation. Either symmetrical or variable duty-cycle waves can be generated in this mode. The other wave synthesis mode, the Single-Shot mode, is similar in use to the Continuous operating mode, however, a single pulse is generated, with a programmable preset width.

The WAVE MEASUREMENT modes include the Frequency Comparison and Pulse Width Comparison modes which are used to measure cyclic and singular pulse widths, respectively.

In addition to the four timer modes in Table 3, the remaining control register bit is used to modify counter initialization and enabling or interrupt conditions.

## ■ WAVE SYNTHESIS MODES

### ● Continuous Operating Mode (Table 4)

The continuous mode will synthesize a continuous wave with a period proportional to the preset number in the particular timer latches.

Any of the timers in the PTM may be programmed to operate in a continuous mode by writing "0's into bits 3 and 5 of the corresponding control register. Assuming that the timer output is enabled (CRX7 = "1"), either a square wave or a variable duty cycle waveform will be generated at the Timer Output, OX. The type of output is selected via Control Register Bit 2.

Either a Timer Reset (CR10 = "1" or External  $\overline{\text{RES}} = \text{"Low"}$ ) condition or internal recognition of a negative transition of the Gate input results in Counter Initialization. A Write Timer Latches command can be selected as a Counter Initialization signal by clearing CRX4.

The counter is enabled by an absence of a Timer Reset condition and a "Low" level at the Gate input. In the 16-bit mode, the counter will decrement on the first clock cycle during or after the counter initialization cycle. It continues to decrement on each clock signal so long as G remains "Low" and no reset condition exists. A Counter Time Out (the first clock after all

Table 4 Continuous Operating Modes

| CONTINUOUS MODE<br>(CRX3 = "0", CRX5 = "0") |      |                                   | Initialization/Output Waveforms |
|---------------------------------------------|------|-----------------------------------|---------------------------------|
| Control Register                            | CRX4 | Counter Initialization            | *Timer Output (OX) (CRX7 = "1") |
| 0                                           | 0    | $\overline{G} \downarrow + W + R$ |                                 |
|                                             | 1    | $\overline{G} \downarrow + R$     |                                 |
| 1                                           | 0    | $\overline{G} \downarrow + W + R$ |                                 |
|                                             | 1    | $\overline{G} \downarrow + R$     |                                 |

$\overline{G} \downarrow$  = Negative transition of Gate input.  
W = Write Timer Latches Command.  
R = Timer Reset (CR10 = "1" or External  $\overline{\text{RES}} = \text{"Low"}$ ).  
N = 16-Bit Number in Counter Latch.  
L = 8-Bit Number in LSB Counter Latch.  
M = 8-Bit Number in MSB Counter Latch.  
T = Clock Input Negative Transitions to Counter.  
 $t_0$  = Counter Initialization Cycle.  
TO = Counter Time Out (All Zero Condition).

\* All time intervals shown above assume the Gate ( $\overline{G}$ ) and Clock ( $\overline{C}$ ) signals are synchronized to Enable (System  $\phi_2$ ) with the specified setup and hold time requirements.



## Control Register Bits





Figure 9 Timer Output Waveform Example  
(Continuous Dual 8-Bit Mode using Internal Enable)

counter bits = "0") results in the Individual Interrupt Flag being set and re-initialization of the counter.

In the dual 8-bit mode (CRX2 = "1") [Refer to the example in Fig. 9] the MSB decrements once for every full countdown of the LSB + 1. When the LSB = "0", the MSB is unchanged; on the next clock pulse the LSB is reset to the count in the LSB Latches and the MSB is decremented by 1 (one). The output, if enabled, remains "Low" during and after initialization and will remain "Low" until the counter MSB is all "0"s. The output will go "High" at the beginning of the next clock pulse. The output remains "High" until both the LSB and MSB of the counter are all "0"s. At the beginning of the next clock pulse the defined Time Out (TO) will occur and the output will go "Low". In the Dual 8-bit mode the period of the output of the example in Fig. 9 would span 20 clock pulses as opposed to the 1546 clock pulses using the Normal 16-bit mode.

A special time-out condition exists for the dual 8-bit mode (CRX2 = "1") if  $L = 0$ . In this case, the counter will revert to a mode similar to the single 16-bit mode, except Time Out occurs after  $M+1$  clock pulses. The output, if enabled, goes "Low" during the Counter Initialization cycle and reverses state at each Time Out. The counter remains cyclical (i.e. re-initialized at each Time Out) and the Individual Interrupt Flag is set when Time Out occurs. If  $M = L = 0$ , the internal counters do not change, but the output toggles at a rate of 1/2 the clock frequency.

The discussion of the Continuous Mode has assumed that the

application requires an output signal. It should be noted that the Timer operates in the same manner with the output disabled (CRX7 = "0"). A Read Timer Counter command is valid regardless of the state of CRX7.

#### • Single-Shot Timer Mode

This mode is identical to the Continuous Mode with three exceptions. The first of these is obvious from the name — the output returns to a "Low" level after the initial Time Out and remains "Low" until another Counter Initialization cycle occurs. The waveforms available are shown in Table 5.

As indicated in Table 5, the internal counting mechanism remains cyclical in the Single-Shot Mode. Each Time Out of the counter results in the setting of an Individual Interrupt Flag and re-initialization of the counter.

The second major difference between the Single-Shot and Continuous modes is that the internal counter enable is not dependent on the Gate input level remaining in the "Low" state for the Single-Shot mode.

Another special condition is introduced in the Single-Shot mode. If  $L = M = 0$  (Dual 8-bit) or  $N = 0$  (Single 16-bit), the output goes "Low" on the first clock received during or after Counter Initialization. The output remains "Low" until the Operating Mode is changed or nonzero data is written into the Counter Latches. Time Outs continue to occur at the end of each clock period.

The three differences between Single-Shot and Continuous Timer Modes can be summarized as attributes of the Single-Shot

mode:

1. Output is enabled for only one pulse until it is reinitialized.

2. Counter Enable is independent of Gate.

3. L = M = "0" or N = "0" disables output.

Aside from these differences, the two modes are identical.

Table 5 Single-Shot Operating Modes

| Single-Shot Mode<br>(CRX3 = "0", CRX7 = "1", CRX5 = "1") |      |                                 |                   |
|----------------------------------------------------------|------|---------------------------------|-------------------|
| Control Register                                         |      | Initialization/Output Waveforms |                   |
| CRX2                                                     | CRX4 | Counter Initialization          | Timer Output (TO) |
| 0                                                        | 0    | $\bar{G} \downarrow + W + R$    |                   |
| 0                                                        | 1    | $\bar{G} \downarrow + R$        |                   |
| 1                                                        | 0    | $\bar{G} \downarrow + W + R$    |                   |
| 1                                                        | 1    | $\bar{G} \downarrow + R$        |                   |

Symbols are as defined in Table 5

#### ■ WAVE MEASUREMENT MODES

The Wave Measurement Modes are the Frequency (period) Measurement and Pulse Width Comparison Modes, and are provided for those applications which require more flexibility of interrupt generation and Counter Initialization. Individual Interrupt Flags are set in these modes as a function of both Counter Time Out and transitions of the Gate input. Counter Initialization is also affected by Interrupt Flag status.

A timer's output is normally not used in a Wave Measurement mode, but it is defined. If the output is enabled, it will

operate as follows. During the period between reinitialization of the timer and the first Time Out, the output will be a logical zero. If the first Time Out is completed (regardless of its method of generation), the output will go "High". If further TO's occur, the output will change state at each completion of a Time-Out.

The counter does operate in either Single 16-bit or Dual 8-bit modes as programmed by CRX2. Other features of the Wave Measurement Modes are outlined in Table 6.

Table 6 Wave Measurement Modes

| CRX3 = "1" |      |                        |                                                                                      |
|------------|------|------------------------|--------------------------------------------------------------------------------------|
| CRX4       | CRX5 | Application            | Condition for Setting Individual Interrupt Flag                                      |
| 0          | 0    | Frequency Comparison   | Interrupt Generated if Gate Input Period (1/F) is less than Counter Time Out (TO)    |
| 0          | 1    | Frequency, Comparison  | Interrupt Generated if Gate Input Period (1/F) is greater than Counter Time Out (TO) |
| 1          | 0    | Pulse Width Comparison | Interrupt Generated if Gate Input "Down Time" is less than Counter Time Out (TO)     |
| 1          | 1    | Pulse Width Comparison | Interrupt Generated if Gate Input "Down Time" is greater than Counter Time Out (TO)  |

#### ● Frequency Comparison or Period Measurement Mode (CRX3 = "1", CRX4 = "0")

The Frequency Comparison Mode with CRX5 = "1" is straightforward. If Time Out occurs prior to the first negative transition of the Gate input after a Counter Initialization cycle, an Individual Interrupt Flag is set. The counter is disabled, and a Counter Initialization cycle cannot begin until the interrupt flag is cleared and a negative transition on  $\bar{G}$  is detected.

If CRX5 = "0", as shown in Table 6 and Table 7, an interrupt is generated if Gate input returns "Low" prior to a Time Out. If Counter Time-Out occurs first, the counter is recycled and continues to decrement. A bit is set within the timer on the initial Time Out which precludes further individual interrupt generation until a new Counter Initialization cycle has been completed. When this internal bit is set, a negative transition of the Gate input starts a new Counter Initialization cycle. (The

condition of  $\bar{G} \downarrow \cdot \bar{T} \cdot TO$  is satisfied, since a Time Out has occurred and no individual interrupt has been generated.)

Any of the timers within the PTM may be programmed to compare the period of a pulse (giving the frequency after calculations) at the Gate input with the time period requested for Counter Time-Out. A negative transition of the Gate input enables the counter and starts a Counter Initialization cycle — provided that other conditions as noted in Table 7 are satisfied. The counter decrements on each clock signal recognized during or after Counter Initialization until an Interrupt is generated, a Write Timer Latches command is issued, or a Timer Reset condition occurs. It can be seen from Table 7 that an interrupt condition will be generated if CRX5 = "0" and the period of the pulse (single pulse or measured separately repetitive pulses) at the Gate input is less than the Counter Time Out period. If CRX5 = "1", an interrupt is generated if the reverse is true.



Assume now with CRX5 = "1" that a Counter Initialization has occurred and that the Gate input has returned "Low" prior to Counter Time Out. Since there is no Individual Interrupt Flag generated, this automatically starts a new Counter Initialization Cycle. The process will continue with frequency comparison being performed on each Gate input cycle until the mode is changed, or a cycle is determined to be above the predetermined limit.

- Pulse Width Comparison Mode (CRX3 = "1", CRX4 = "1")**

This mode is similar to the Frequency Comparison Mode except for a positive, rather than negative, transition of the Gate

input terminates the count. With CRX5 = "0", an Individual Interrupt Flag will be generated if the "Low" level pulse applied to the Gate input is less than the time period required for Counter Time Out. With CRX5 = "1", the interrupt is generated when the reverse condition is true.

As can be seen in Table 8, a positive transition of the Gate input disables the counter. With CRX5 = "0", it is therefore possible to directly obtain the width of any pulse causing an interrupt. Similar data for other Time Interval Modes and conditions can be obtained, if two sections of the PTM are dedicated to the purpose.

Table 7 Frequency Comparison Mode

| CRX3 = "1", CRX4 = "0"   |                                                                             |                                                                                    |                                     |                                     |
|--------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------|
| Control Reg Bit 5 (CRX5) | Counter Initialization                                                      | Counter Enable Flip-Flop Set (CE)                                                  | Counter Enable Flip-Flop Reset (CE) | Interrupt Flag Set (I)              |
| 0                        | $\overline{G} \downarrow \cdot \overline{T} \cdot (\overline{C}E + TO) + R$ | $\overline{G} \downarrow \cdot \overline{W} \cdot \overline{R} \cdot \overline{T}$ | $W + R + I$                         | $\overline{G} \downarrow$ Before TO |
| 1                        | $\overline{G} \downarrow \cdot \overline{T} + R$                            | $\overline{G} \downarrow \cdot \overline{W} \cdot \overline{R} \cdot \overline{T}$ | $W + R + I$                         | TO Before $\overline{G} \downarrow$ |

I represents the interrupt for a given timer.

Table 8 Pulse Width Comparison Mode

| CRX3 = "1", CRX4 = "1"   |                                                  |                                                                                    |                                     |                                   |
|--------------------------|--------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------|-----------------------------------|
| Control Reg Bit 5 (CRX5) | Counter Initialization                           | Counter Enable Flip-Flop Set (CE)                                                  | Counter Enable Flip-Flop Reset (CE) | Interrupt Flag Set (I)            |
| 0                        | $\overline{G} \downarrow \cdot \overline{T} + R$ | $\overline{G} \downarrow \cdot \overline{W} \cdot \overline{R} \cdot \overline{T}$ | $W + R + I + G$                     | $\overline{G} \uparrow$ Before TO |
| 1                        | $\overline{G} \downarrow \cdot \overline{T} + R$ | $\overline{G} \downarrow \cdot \overline{W} \cdot \overline{R} \cdot \overline{T}$ | $W + R + I + G$                     | TO Before $\overline{G} \uparrow$ |

G = Level sensitive recognition of Gate input.



**Table 9 Control Register Programming**

|                        | <b>Register 1</b>                  | <b>Register 2</b>                                                                                                                                      | <b>Register 3</b> |
|------------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| <b>7 6 5 4 3 2 1 0</b> | "0"   All Timers Operate           | "0"   Reg #3 May Be Written                                                                                                                            | T3 Clk ÷ 1        |
| X X X X X X X X †      | "1"   All Timers Preset            | "1"   Reg #1 May Be Written                                                                                                                            | T3 Clk ÷ 8        |
| <b>7 6 5 4 3 2 1 0</b> | "0"   External Clock (CX Input)    |                                                                                                                                                        |                   |
| X X X X X X X X † X    | "1"   Internal Clock (Enable)      |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> | "0"   Normal (16-Bit) Count Mode   |                                                                                                                                                        |                   |
| X X X X X † X X X      | "1"   Dual 8-Bit Count Mode        |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Continuous Operating Mode: Gate ↓ or Write to Latches or Reset Causes Counter Initialization                                                           |                   |
| X X 0 0 0 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Frequency Comparison Mode: Interrupt if Gate  is < Counter Time Out   |                   |
| X X 0 0 1 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Continuous Operating Mode: Gate ↓ or Reset Causes Counter Initialization                                                                               |                   |
| X X 0 1 0 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Pulse Width Comparison Mode: Interrupt if Gate  is < Counter Time Out |                   |
| X X 0 1 1 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Single Shot Mode: Gate ↓ or Write to Latches or Reset Causes Counter Initialization                                                                    |                   |
| 1 X 1 0 0 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Frequency Comparison Mode: Interrupt If Gate  is > Counter Time Out   |                   |
| X X 1 0 1 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Single Shot Mode: Gate ↓ or Reset Causes Counter Initialization                                                                                        |                   |
| 1 X 1 1 0 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    | Pulse Width Comparison Mode: Interrupt If Gate  is > Counter Time Out |                   |
| X X 1 1 1 X X X X      |                                    |                                                                                                                                                        |                   |
| <b>7 6 5 4 3 2 1 0</b> | "0"   Interrupt Flag Masked (IRQ)  | "0"   Timer Output Masked                                                                                                                              |                   |
| X † X X X X X X X      | "1"   Interrupt Flag Enabled (IRQ) | "1"   Timer Output Enable                                                                                                                              |                   |
| <b>7 6 5 4 3 2 1 0</b> |                                    |                                                                                                                                                        |                   |
| † X X X X X X X X      |                                    |                                                                                                                                                        |                   |

(NOTE) Reset is Hardware or Software Reset ( $\overline{\text{RES}} = \text{"Low"}$  or  $\text{CR10} = \text{"1"}$ ).

■ NOTE FOR USE (HD6340 only)

Input signal, which is not necessary for user's application, should be used fixed to "High" or "Low" level. This is applicable to the following signal pins.

$\overline{C_1}$ ,  $\overline{C_2}$ ,  $\overline{C_3}$ ,  $\overline{G_1}$ ,  $\overline{G_2}$ ,  $\overline{G_3}$

■ RESTRICTION FOR USE



Figure 10 The O<sub>1</sub> – O<sub>3</sub> Outputs Noise in the MPU Read Cycle

(2) Cause

When the data buffer turns from "H" to "L", the excessive transient current runs to the GND (the discharge current of the data bus load capacity). Therefore, the noise occurs in the GND pin of the LSI because of the impedance of the GND wiring (resistance and inductance). See Fig. 11 for the details.

Fig. 12 indicates the dependence of the noise voltage upon each parameter.



Figure 11 Cause of the Noise



$V_n$ : Noise voltage  
 $C_d$ : Data bus load capacitance

$Z_g$ : GND impedance  
 $N$ : Number of data bus which changes according to H → L.

Figure 12 The Dependence of the Noise Voltage upon Each Parameter



However, it is important to consider the fact that the noise voltage varies according to the type of parameter as indicated in Fig. 12.

### (3) Countermeasures

When the noise cause the erroneous operation of the system, the countermeasures to be taken are as follows.

- (a) Latch the  $O_1 - O_3$  outputs by the falling edge of the signal "E".



#### ■ Precautions when using Timer 3 (HD6340 only)

When using the HD63B40P Timer 3 under the conditions

- 1) external clock mode (CR31 = 0)
- 2) + 8 prescaler unused (CR30 = 0)

and changing the bits of the control register #3 except for the CR30 bit (e.g. in a case where the interrupt mask bit and O<sub>3</sub> output enable bit are changed and the CR30 is not), there is the possibility that one decrement clock may be omitted.

This phenomenon occurs when  $t_{DSW}$  (data setup time; standard spec. 60ns minimum) is less than 80ns, and does not occur when  $t_{DSW}$  is greater than 80ns.

Therefore, please avoid to use the HD63B40P in the above status when  $t_{DSW}$  is less than 80ns.  
(This phenomenon doesn't occur in the HD6340P and HD63A40P.)



# HD6844, HD68A44, HD68B44 DMAC (Direct Memory Access Controller)

The HD6844 Direct Memory Access Controller (DMAC) performs the function of transferring data directly between memory and peripheral device controllers. It controls the address and data buses in place of the MPU in bus organized systems such as the HMCS6800 Microprocessor System.

The bus interface of the HD6844 includes select, read/write, interrupt, transfer request/grant, and bus interface logic to allow the data transfer over an 8-bit bidirectional data bus. The functional configuration of the DMAC is programmed via the data bus. The internal structure provides for control and handling of four individual channels, each of which is separately configured. Programmable control registers provide control for the transfer location and length, individual channel control and transfer mode configuration, priority of servicing, data chaining, and interrupt control. Status and control lines provide control to the peripheral controllers.

The mode of transfer for each channel can be programmed as cycle-stealing or a burst transfer mode.

Typical applications would be with the Floppy Disk Controller (FDC), etc..

## ■ FEATURES

- Four DMA Channels, Each Having a 16-Bit Address Register and a 16-Bit Byte Count Register
- 1 M Byte/Sec (HD6844), 1.5 M Byte/Sec (HD68A44), 2.0 M Byte/Sec (HD68B44)  
Maximum Data Transfer Rate
- Selection of Fixed or Rotating Priority Service Control
- Separate Control Bits for Each Channel
- Data Chain Function
- Address Increment or Decrement Update
- Programmable Interrupts and DMA End to Peripheral Controllers
- Compatible with MC6844, MC68A44, MC68B44

## ■ BLOCK DIAGRAM



## ■ PIN ARRANGEMENT

|                 |    |   |                         |
|-----------------|----|---|-------------------------|
| V <sub>ss</sub> | 1  | O | 40 φ <sub>2</sub> , DMA |
| CS/TxAKB        | 2  |   | 39 RES                  |
| R/W             | 3  |   | 38 DGRNT                |
| A <sub>0</sub>  | 4  |   | 37 DRQT                 |
| A <sub>1</sub>  | 5  |   | 36 DRQH                 |
| A <sub>2</sub>  | 6  |   | 35 TxAKA                |
| A <sub>3</sub>  | 7  |   | 34 TxSTB                |
| A <sub>4</sub>  | 8  |   | 33 IRQ/DEND             |
| A <sub>5</sub>  | 9  |   | 32 TxRQ <sub>0</sub>    |
| A <sub>6</sub>  | 10 |   | 31 TxRQ <sub>1</sub>    |
| A <sub>7</sub>  | 11 |   | 30 TxRQ <sub>2</sub>    |
| A <sub>8</sub>  | 12 |   | 29 TxRQ <sub>3</sub>    |
| A <sub>9</sub>  | 13 |   | 28 D <sub>0</sub>       |
| A <sub>10</sub> | 14 |   | 27 D <sub>1</sub>       |
| A <sub>11</sub> | 15 |   | 26 D <sub>2</sub>       |
| A <sub>12</sub> | 16 |   | 25 D <sub>3</sub>       |
| A <sub>13</sub> | 17 |   | 24 D <sub>4</sub>       |
| A <sub>14</sub> | 18 |   | 23 D <sub>5</sub>       |
| A <sub>15</sub> | 19 |   | 22 D <sub>6</sub>       |
| V <sub>cc</sub> | 20 |   | 21 D <sub>7</sub>       |

HD6844

(Top View)

### ■ ABSOLUTE MAXIMUM RATINGS

| Item                  | Symbol     | Value       | Unit |
|-----------------------|------------|-------------|------|
| Supply Voltage        | $V_{CC}^*$ | -0.3 ~ +7.0 | V    |
| Input Voltage         | $V_{in}^*$ | -0.3 ~ +7.0 | V    |
| Operating Temperature | $T_{opr}$  | -20 ~ +75   | °C   |
| Storage Temperature   | $T_{stg}$  | -55 ~ +150  | °C   |

\* With respect to  $V_{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 |
|-----------------------|------------|------|-----|----------|------|
| Power Supply Voltage  | $V_{CC}^*$ | 4.75 | 5.0 | 5.25     | V    |
| Input Voltage         | $V_{IL}^*$ | -0.3 | —   | 0.8      | V    |
|                       | $V_{IH}^*$ | 2.0  | —   | $V_{CC}$ | V    |
| Operating Temperature | $T_{opr}$  | -20  | 25  | 75       | °C   |

\* With respect to  $V_{SS}$  (SYSTEM GND)

### ■ ELECTRICAL CHARACTERISTICS ( $V_{CC}=5V\pm5\%$ , $V_{SS}=0V$ , $T_a=-20\sim+75^\circ C$ , unless otherwise noted.)

#### ● DC CHARACTERISTICS

| Item                                    | Symbol    | Test Condition                               | min  | typ* | max      | Unit |
|-----------------------------------------|-----------|----------------------------------------------|------|------|----------|------|
| Input "High" Voltage                    | $V_{IH}$  |                                              | 2.0  | —    | $V_{CC}$ | V    |
| Input "Low" Voltage                     | $V_{IL}$  |                                              | -0.3 | —    | 0.8      | V    |
| Input Leakage Current                   | $I_{in}$  | $V_{in}=0\sim 5.25V$                         | -2.5 | —    | 2.5      | μA   |
| Three-State (off state) Leakage Current | $I_{TSI}$ | $V_{in}=0.4\sim 2.4V$                        | -10  | —    | 10       | μA   |
| Output "High" Voltage                   | $I_{OH}$  | $I_{OH}=-205\mu A$                           | 2.4  | —    | —        | V    |
|                                         | $I_{OH}$  | $I_{OH}=-145\mu A$                           | 2.4  | —    | —        |      |
|                                         | $I_{OH}$  | $I_{OH}=-100\mu A$                           | 2.4  | —    | —        |      |
| Output "Low" Voltage                    | $I_{OL}$  | $I_{OL}=1.6mA$                               | —    | —    | 0.4      | V    |
| Source Current                          | $I_{CSS}$ | $V_{in}=0V$ , Fig. 10                        | —    | 10   | 16       | mA   |
| Power Dissipation                       | $P_D$     |                                              | —    | 500  | 1000     | mW   |
| Input Capacitance                       | $C_{in}$  | $V_{in}=0V$ , $T_a=25^\circ C$<br>$f=1.0MHz$ | —    | —    | 20       | pF   |
|                                         |           |                                              | —    | —    | 12.5     |      |
|                                         |           |                                              | —    | —    | 10       |      |
| Output Capacitance                      | $C_{out}$ | $V_{in}=0V$ , $T_a=25^\circ C$ , $f=1MHz$    | —    | —    | 12       | pF   |

\*  $V_{CC}=5.0V$ ,  $T_a=25^\circ C$



## HD6844, HD68A44, HD68B44

### ● AC CHARACTERISTICS (Load Condition Fig. 9)

#### 1. CLOCK TIMING

| Item                            | Symbol                   | Test Condition | HD6844 |     |     | HD68A44 |     |     | HD68B44 |     |     | Unit |    |
|---------------------------------|--------------------------|----------------|--------|-----|-----|---------|-----|-----|---------|-----|-----|------|----|
|                                 |                          |                | min    | typ | max | min     | typ | max | min     | typ | max |      |    |
| $\phi_2$ DMA Cycle Time         | $t_{cyc\phi}$            | Fig. 2         | 1000   | —   | —   | 666     | —   | —   | 500     | —   | —   | ns   |    |
| $\phi_2$ DMA Pulse Width        | "High" Level             | $t_{PW\phi H}$ | Fig. 2 | 450 | —   | —       | 280 | —   | —       | 235 | —   | —    | ns |
|                                 | "Low" Level              | $t_{PW\phi L}$ | Fig. 2 | 400 | —   | —       | 230 | —   | —       | 210 | —   | —    | ns |
| $\phi_2$ DMA Rise and Fall Time | $t_{\phi r}, t_{\phi f}$ | Fig. 2         | —      | —   | 25  | —       | —   | 25  | —       | —   | 25  | ns   |    |

#### 2. DMA TIMING (Load Condition Fig. 9)

| Item                              | Symbol                          | Test Condition | HD6844           |     |     | HD68A44 |     |     | HD68B44 |     |     | Unit |    |
|-----------------------------------|---------------------------------|----------------|------------------|-----|-----|---------|-----|-----|---------|-----|-----|------|----|
|                                   |                                 |                | min              | typ | max | min     | typ | max | min     | typ | max |      |    |
| TxRQ Setup Time                   | $\phi_2$ DMA Rising Edge        | $t_{TQS1}$     | Fig. 3           | 120 | —   | —       | 120 | —   | —       | 120 | —   | —    | ns |
|                                   | $\phi_2$ DMA Falling Edge       | $t_{TQS2}$     |                  | 210 | —   | —       | 210 | —   | —       | 155 | —   | —    |    |
| TxRQ Hold Time                    | $\phi_2$ DMA Rising Edge        | $t_{TQH1}$     | Fig. 3           | 20  | —   | —       | 10  | —   | —       | 10  | —   | —    | ns |
|                                   | $\phi_2$ DMA Falling Edge       | $t_{TQH2}$     |                  | 20  | —   | —       | 10  | —   | —       | 10  | —   | —    |    |
| DGRNT Setup Time                  | DGRNT                           | $t_{DGS}$      | Fig. 4           | 155 | —   | —       | 125 | —   | —       | 115 | —   | —    | ns |
| DGRNT Hold Time                   | DGRNT                           | $t_{DGH}$      |                  | 10  | —   | —       | 10  | —   | —       | 10  | —   | —    |    |
| Address Output Delay Time         | $A_0 \sim A_{15}, R/W$<br>TxSTB | $t_{AD}$       | Fig. 6           | —   | —   | 270     | —   | —   | 180     | —   | —   | 160  | ns |
| Address Output Hold Time          | $A_0 \sim A_{15}, R/W$<br>TxSTB | $t_{AHO}$      | Fig. 6<br>Fig. 7 | 30  | —   | —       | 20  | —   | —       | 20  | —   | —    | ns |
|                                   |                                 |                |                  | 35  | —   | —       | 35  | —   | —       | 35  | —   | —    |    |
| Address Three-State Delay Time    | $A_0 \sim A_{15}, R/W$          | $t_{ATSD}$     | Fig. 7           | —   | —   | 270     | —   | —   | 270     | —   | —   | 270  | ns |
| Address Three-State Recovery Time | $A_0 \sim A_{15}, R/W$          | $t_{ATSR}$     | Fig. 7           | —   | —   | 270     | —   | —   | 270     | —   | —   | 270  | ns |
| Delay Time                        | DRQH, DRQT                      | $t_{DQD}$      | Fig. 5           | —   | —   | 375     | —   | —   | 250     | —   | —   | 210  | ns |
| TxAK Delay Time                   | $\phi_2$ DMA Rising Edge        | $t_{TKD1}$     | Fig. 5           | —   | —   | 400     | —   | —   | 310     | —   | —   | 250  | ns |
|                                   | DGRNT Rising Edge               | $t_{TKD2}$     | Fig. 8           | —   | —   | 190     | —   | —   | 160     | —   | —   | 150  |    |
| TRQ/DEND Delay Time               | $\phi_2$ DMA Falling Edge       | $t_{DED1}$     | Fig. 6           | —   | —   | 300     | —   | —   | 250     | —   | —   | 210  | ns |
|                                   | DGRNT Rising Edge               | $t_{DED2}$     | Fig. 8           | —   | —   | 190     | —   | —   | 160     | —   | —   | 125  |    |

#### 3. BUS TIMING

##### 1) READ TIMING

| Item                    | Symbol                  | Test Condition | HD6844 |     |     | HD68A44 |     |     | HD68B44 |     |     | Unit |    |
|-------------------------|-------------------------|----------------|--------|-----|-----|---------|-----|-----|---------|-----|-----|------|----|
|                         |                         |                | min    | typ | max | min     | typ | max | min     | typ | max |      |    |
| Address Setup Time      | $A_0 \sim A_4, R/W, CS$ | $t_{AS}$       | Fig. 2 | 140 | —   | —       | 140 | —   | —       | 70  | —   | —    | ns |
| Address Input Hold Time | $A_0 \sim A_4, R/W, CS$ | $t_{AHI}$      |        | 10  | —   | —       | 10  | —   | —       | 10  | —   | —    | ns |
| Data Delay Time         | $D_0 \sim D_7$          | $t_{DDR}$      |        | —   | —   | 320     | —   | —   | 220     | —   | —   | 180  | ns |
| Data Access Time        | $D_0 \sim D_7$          | $t_{ACC}$      |        | —   | —   | 460     | —   | —   | 360     | —   | —   | 280  | ns |
| Data Output Hold Time   | $D_0 \sim D_7$          | $t_{DHR}$      |        | 10  | —   | —       | 10  | —   | —       | 10  | —   | —    | ns |



## 2) WRITE TIMING

| Item                    | Symbol                  | Test Condition | HD6844 |     |     | HD68A44 |     |     | HD68B44 |     |     | Unit |
|-------------------------|-------------------------|----------------|--------|-----|-----|---------|-----|-----|---------|-----|-----|------|
|                         |                         |                | min    | typ | max | min     | typ | max | min     | typ | max |      |
| Address Setup Time      | $A_0 \sim A_4, R/W, CS$ | Fig. 2         | 140    | —   | —   | 140     | —   | —   | 70      | —   | —   | ns   |
| Address Input Hold Time | $A_0 \sim A_4, R/W, CS$ |                | 10     | —   | —   | 10      | —   | —   | 10      | —   | —   | ns   |
| Data Setup Time         | $D_0 \sim D_7$          |                | 195    | —   | —   | 80      | —   | —   | 60      | —   | —   | ns   |
| Data Input Hold Time    | $D_0 \sim D_7$          |                | 10     | —   | —   | 10      | —   | —   | 10      | —   | —   | ns   |



Figure 1 Expanded Block Diagram





Figure 2 Read/Write Sequence



Figure 3 Timing of TxRQ Input





Figure 4 Timing of DGRNT Input



Figure 5 Timing of DRQH, DRQT, TxAKA Outputs



Figure 6 Timing of Address and  $\overline{IRQ}/\overline{DEND}$  OutputsRecovery Time of Address Three-stateDelay Time of Address Three-state

Figure 7 Timing of Address Three-state





Figure 8 Timing of Synchronous DGRNT Output



| Test terminal                         | C      | R     |
|---------------------------------------|--------|-------|
| D <sub>0</sub> ~D <sub>7</sub>        | 130 pF | 11 kΩ |
| A <sub>0</sub> ~A <sub>15</sub> , R/W | 90 pF  | 16 kΩ |
| CS/TxAKB                              | 50 pF  | 24 kΩ |
| All other outputs                     | 30 pF  | 24 kΩ |

D<sub>1</sub>~D<sub>4</sub> : 1S2074 (H) or equivalent.

Figure 9 Load Circuit



Figure 10 Source Current Measurement Circuit for CS/TxAKB Terminal



## ■ DEVICE OPERATION

The DMAC has fifteen addressable registers, eight of them are sixteen bits in length. Each channel has a separate Address Register and a Byte Count Register, each of which is sixteen bits. There are also four Channel Control Registers. The three General Control Registers common to all four channels are the Priority Control Register, the Interrupt Control Register, and the Data Chain Register.

To prepare a channel for DMA, the Address Registers must be loaded with the starting memory address and the Byte Count Register loaded with the number of bytes to be transferred. The bits in the Channel Control Register establish the direction of the transfer, the mode, and the address increment or decrement after each cycle. Each channel can be set for one of three transfer modes: Three-State Control (TSC) Steal, Halt Steal, or Halt Burst. Two read-only status bits in the Channel Control Register indicate when the channel is busy transferring data and when the DMA transfer is completed.

The Priority Control Register enables the transfer requests from the peripheral controllers and establishes either a fixed priority or rotating priority scheme of servicing these requests.

When the DMA transfer for a channel is complete (the Byte Count Register is zero), a DMA End signal is directed to the peripheral controller and an IRQ goes to the MPU. Enabling of these interrupts is done in the interrupt Control Register. The IRQ flag bit is read from this register.

Chaining of data transfers is controlled by the Data Chain Register. When enabled, the contents of the Address and Byte Count Registers for channel #3 are put into the registers of the channel selected for chaining when its Byte Count Register becomes zero. This allows for repetitively reading or writing a block of memory.

During the DMA mode, the DMAC controls the address bus and data bus for the system as well as providing the R/W line and a signal to be used as VMA. When a peripheral device controller desires a DMA transfer, it is requested by a Transfer Request. Assuming this request is enabled and meets the test of highest priority, the DMAC will issue a DMA Request. When the DMAC receives the DMA Grant, it gives a Transfer Acknowledge to the peripheral device controller, at which time the data is transferred. When the channel's Byte Count Register equals zero, the transfer is complete and a DMA End is given to the peripheral device controller, and an IRQ is given to the MPU.

### ● Initialization

During a power-on sequence, the DMAC is reset via the RES input. All registers, with the exception of the Address and Byte Count Registers, are set to a logic "0" state. This disables all requests and the Data Chain function while masking all interrupts. The Address, Byte Count, and Channel Control Registers must be programmed before the respective transfer request bit is enabled in the Priority Control Register.

### ● Transfer Modes

There are three ways in which a DMA transfer may be done. The one used is determined by the data transfer rate required, the number of channels attached, and the hardware complexity allowable. Refer to Figures 12, 16 and 17.

Two of the modes, TSC Steal and Halt Steal, are done by cycle-stealing from the MPU. The Three-State Control (TSC) Steal mode is initiated by the DMAC bringing the DRQH line "Low". This line goes to the system clock driver which returns a "High" on DGRNT on the rising edge of the system  $\phi_1$  clock.

The DGRNT signal must cause the address control and data lines to go to the high impedance state. The DMAC now supplies the address from the Address Register of the channel requesting. It also supplies the R/W signal as determined from the Channel Control Register. After one byte is transferred, control is returned to the MPU. This method stretches the  $\phi_1$  and  $\phi_2$  clocks while the DMAC uses the memory.

The second method of cycle-stealing is the Halt Steal mode. This method actually halts the MPU instead of stretching the  $\phi_1$  clock for the transfer period. This mode is initiated by the DMAC bringing the DRQH line "Low". This line connects to the MPU HALT input. The MPU Bus Available (BA) line is the DGRNT input to the DMAC. While the MPU is halted, its Address Bus, Data Bus, and R/W are in the high impedance state. The DMAC now supplies the address and R/W line. After one byte is transferred, the HALT line is returned "High" and the MPU regains control. In this mode, the MPU stops internal activity and is removed from the system while the DMAC uses the memory.

The third mode of transfer is the Halt Burst mode. This mode is similar to the Halt Steal mode, except that the transfer does not stop with one byte. The MPU is halted while an entire block of data is transferred. When the channel's Byte Count Register equals zero, the transfer is complete and control is returned to the MPU. This mode gives the highest data transfer rate, at the expense of the MPU being inactive during the transfer period.

## ■ INPUT/OUTPUT FUNCTIONS

### ● DMAC Interface Signals for the MPU

The DMAC interfaces with the HMCS6800 MPU through the eight-bit bidirectional data bus, the CS line, five address lines, an IRQ line, the Read/Write line, and the RES line. These signals, in conjunction with the HMCS6800 VMA output, permit the MPU to have access to the DMAC. Four other lines associated with the MPU and the clock driver are the DRQT, DRQH, DGRNT, and the  $\phi_2$  DMA.

### Bi-directional Data ( $D_0 \sim D_7$ )

The Bi-directional Data lines ( $D_0 \sim D_7$ ) allow for data transfer between the DMAC and the MPU. The data bus output drivers are three-state devices that remain in the high impedance state except when the MPU performs DMAC read operations.

### Chip Select/Transfer Acknowledge B ( $\overline{CS/T} \times AKB$ )

This line is multiplexed, serving both as an input and an output.  $\overline{CS/T} \times AKB$  is an output in the four-channel mode during the DMA transfer. At all other times, it is a high impedance TTL compatible input used to address the DMAC. The DMAC is selected when  $\overline{CS/T} \times AKB$  is "Low". VMA must be used in generating this input to insure that false selects will not occur. Transfers of data to and from the DMAC are then performed under the control of the  $\phi_2$  DMA, Read/Write, and  $A_0 \sim A_4$  address lines. In the four-channel mode when TxAKB is needed, the CS gate must have an open-collector output (a pull-up resistor should not be used). In the two-channel mode,  $\overline{CS/T} \times AKB$  is always an input.

### Address Lines ( $A_0 \sim A_4$ )

Address lines  $A_0 \sim A_4$  are both input and output lines. In the MPU mode, these are high impedance inputs used to address the DMAC registers. In the DMA mode, these lines are outputs which are set to the contents of the Address Register of the channel being processed.



**Interrupt Request/DMA End (IRQ/DEND)**

IRQ/DEND is a TTL compatible, active "Low" output that is used to interrupt the MPU and to signal the peripheral controller that the data block transfer has ended. If the Interrupt has been enabled, the IRQ/DEND line will go "Low" after the last DMA cycle of a transfer. An open collector gate must be connected to DGRNT and IRQ/DEND to prevent false interrupts from the DEND signal when interrupts are not enabled. Refer to the section of "DMA End Control".

**Read/Write (R/W)**

Read/Write is a TTL compatible line that is a high impedance input in the MPU mode and an output in the DMA mode. In the MPU mode, it is used to control the direction of data flow through the DMAC's input/output data bus interface. When Read/Write is "High" (MPU read cycle) and the chip is selected, DMAC data output buffers are turned on and a selected register is read. When it is "Low", the DMAC output drivers are turned off and the MPU writes into a selected register.

In the DMA mode, Read/Write is an output to drive the memory and peripheral controllers. Its state is determined by bit 0 of the Channel Control Register for the channel being serviced. When Read/Write is "High", the memory is read and the data from the memory is written into the peripheral controller. When it is "Low", the peripheral controller is read and its data stored in the memory. In the DMA mode, the DMAC data buffers are off.

**Reset (RES)**

The RES input provides a means of resetting the DMAC from an external source. In the "Low" state, the RES input causes all registers, with the exception of the Address and Byte Count Registers, to be reset to the logic "0" state. This disables all transfer requests, masks all interrupts, disables the data chain function, and puts each Channel Control Register into the condition of memory write, Halt Steal transfer mode, and address increment.

**Transfer Signals to the MPU**

Two DMA request output lines and a DMA Grant input line, together with the system clock, synchronize the DMAC with the MPU system.

**DMA Request Three-State Control Steal (DRQ<sub>T</sub>)**

This active "Low" output requests a DMA transfer for a channel configured for the TSC Steal transfer mode. This line is connected to the system clock driver, requesting a  $\phi_1$  clock stretch. It will remain in the "Low" state until the transfer has begun.

**DMA Request Halt (DRQH)**

This active "Low" output requests a DMA transfer for a channel programmed for the Halt Steal or Halt Burst mode transfer. This line is connected directly to the MPU HALT input and remains "Low" until the last byte has begun to be transferred.

**DMA Grant (DGRNT)**

This is a high impedance input to the DMAC, giving it control of the system busses. For the TSC Steal mode, the signal comes from the system clock drive circuit (DMA Grant), indicating that the clock is being stretched. For either of the Halt modes, this signal is the Bus Available from the MPU,

indicating that the MPU has halted and turned control of its busses over to the DMAC. For a design involving TSC Steal and Halt mode transfers, this input must be the OR of the clock driven DMA Grant and the MPU BA.

 **$\phi_2$  DMA**

Transferring in and out of the DMAC registers, sampling of channel request lines and gating of other control signals to the system is done internally in conjunction with the  $\phi_2$  DMA high impedance input. This input must be the system memory clock (non-stretched  $\phi_2$  clock).

**Transfer Signals From the Peripheral Controller****Transfer Request (TxRQ<sub>0</sub> ~ TxRQ<sub>3</sub>)**

Each of the four channels has its own high impedance input request for transfer line. The peripheral controller requests a transfer by setting its TxRQ line "High" (a logic "1"). The lines are sampled according to the priority and enabling established in the Priority Control Register. In the Steal mode and the first byte of the Halt Burst mode, the TxRQ signals are tested on the positive edge of  $\phi_2$  DMA and the highest priority channel is strobed. Once strobed, the TxRQs are not tested until that channel's data transfer is finished. In the succeeding bytes of the Halt Burst mode transfer, the TxRQ is tested on the negative edge of  $\phi_2$  DMA, and data is transferred on the next  $\phi_2$  DMA cycle if TxRQ is "High".

**Transfer Signals to the Peripheral Controller**

Two encoded lines select the channel to be serviced. A strobe line acknowledges the request and performs the transfer. The DEND line signals to the peripheral controller that the DMA transfer is completed.

**Transfer Acknowledge A (TxAKA)**

The Transfer Acknowledge A (TxAKA) is a TTL compatible output used in conjunction with the CS/TxAKB line to select the channel to be strobed for transfer and to give the DMA End Signal. In the two-channel mode, only TxAKA is used to select channel 0 or channel 1, and CS/TxAKB is always an input.

**Chip Select/Transfer Acknowledge B (CS/TxAKB)**

In the DMA mode, this dual purpose line is encoded together with TxAKA to select the channel being serviced. Table 1 shows the encoding order.

Table 1 Encoding Order

| CS/TxAKB | TxAKA | Channel # |
|----------|-------|-----------|
| 0        | 0     | 0         |
| 0        | 1     | 1         |
| 1        | 0     | 2         |
| 1        | 1     | 3         |

**Transfer Strobe (TxSTB)**

The TxSTB causes acknowledgement to be given to the peripheral controller and transfers the data to or from the memory. This line is also intended to be the VMA signal for the system in the DMA mode. In a one-channel system, TxSTB may be inverted and run to the peripheral controller's Acknowledge input. In a two or four-channel system, TxSTB enables the decode of TxAKA and CS/TxAKB to select the device controller to be acknowledged.



### **Interrupt Request/DMA End (IRQ/DEND)**

In the DMA mode, this dual purpose line is "Low" for the last byte of transfer, indicating a DMA End. This occurs when the Byte Count register decrements to zero.

This line, through the decode of TxAKA and CS/TxAKB, can be used to strobe a DMA End to each device controller.

- **Address Lines to the Memory**

### **Address Lines ( $A_0 \sim A_{15}$ )**

These output lines are in the high impedance state during the MPU mode. In the DMA mode, these lines are outputs which are set to the contents of the Address Register of the channel being processed.

## ■ THE DMAC REGISTERS

The HD6844 (DMAC) has Address Register (ADR), Byte Count Register (BCR), Channel Control Register (CHCR), and General Control Register (GCR).

General Control Register (GCR) is composed of Priority Control Register (PCR) that controls priority among the channels, Interrupt Control Register (ICR) that controls interrupt

and Data Chain Control Register (DCR) that controls data chain function. Refer to Table 2 and Figure 1.

These are Read/Write registers and MPU can exchange the data with DMAC when CS is at "Low" level. A<sub>0</sub>~A<sub>4</sub> specifies the address of the registers. How to specify the registers is shown in Table 2.

2-byte ADR and BCR can be read or written by one instruction, using 2-byte instruction of the MPU.

#### • Function of Internal Registers

## • Function of Register

Each channel has 16-bit Address Register. Initial address of memory used for DMA transfer is programmed to this register. The contents of ADR are output to address bus ( $A_0 \sim A_{15}$ ) during DMA transfer operation. When 1-byte transfer has completed, the 16-bit address is incremented or decremented by one.

The address which the MPU reads out is the renewed one, that is, the memory address for the next transfer. When 1-block transfer has completed, final memory address +1 or -1 is read out.

**Table 2 Internal Registers of the DMAC**

| Register Name               | Symbol           | Channel | Address Bus Signal |                |                |                |                | Address<br>(Hexadecimal) |
|-----------------------------|------------------|---------|--------------------|----------------|----------------|----------------|----------------|--------------------------|
|                             |                  |         | A <sub>4</sub>     | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> |                          |
| Address Register            | ADR <sub>H</sub> | 0       | 0                  | 0              | 0              | 0              | 0              | 00                       |
|                             | ADR <sub>L</sub> | 0       | 0                  | 0              | 0              | 0              | 1              | 01                       |
| Byte Count Register         | BCR <sub>H</sub> | 0       | 0                  | 0              | 0              | 1              | 0              | 02                       |
|                             | BCR <sub>L</sub> | 0       | 0                  | 0              | 0              | 1              | 1              | 03                       |
| Address Register            | ADR <sub>H</sub> | 1       | 0                  | 0              | 1              | 0              | 0              | 04                       |
|                             | ADR <sub>L</sub> | 1       | 0                  | 0              | 1              | 0              | 1              | 05                       |
| Byte Count Register         | BCR <sub>H</sub> | 1       | 0                  | 0              | 1              | 1              | 0              | 06                       |
|                             | BCR <sub>L</sub> | 1       | 0                  | 0              | 1              | 1              | 1              | 07                       |
| Address Register            | ADR <sub>H</sub> | 2       | 0                  | 1              | 0              | 0              | 0              | 08                       |
|                             | ADR <sub>L</sub> | 2       | 0                  | 1              | 0              | 0              | 1              | 09                       |
| Byte Count Register         | BCR <sub>H</sub> | 2       | 0                  | 1              | 0              | 1              | 0              | 0A                       |
|                             | BCR <sub>L</sub> | 2       | 0                  | 1              | 0              | 1              | 1              | 0B                       |
| Address Register            | ADR <sub>H</sub> | 3       | 0                  | 1              | 1              | 0              | 0              | 0C                       |
|                             | ADR <sub>L</sub> | 3       | 0                  | 1              | 1              | 0              | 1              | 0D                       |
| Byte Count Register         | BCR <sub>H</sub> | 3       | 0                  | 1              | 1              | 1              | 0              | 0E                       |
|                             | BCR <sub>L</sub> | 3       | 0                  | 1              | 1              | 1              | 1              | 0F                       |
| Channel Control Register    | CHCR             | 0       | 1                  | 0              | 0              | 0              | 0              | 10                       |
|                             | CHCR             | 1       | 1                  | 0              | 0              | 0              | 1              | 11                       |
|                             | CHCR             | 2       | 1                  | 0              | 0              | 1              | 0              | 12                       |
|                             | CHCR             | 3       | 1                  | 0              | 0              | 1              | 1              | 13                       |
| Priority Control Register   | PCR              | —       | 1                  | 0              | 1              | 0              | 0              | 14                       |
| Interrupt Control Register  | ICR              | —       | 1                  | 0              | 1              | 0              | 1              | 15                       |
| Data Chain Control Register | DCR              | —       | 1                  | 0              | 1              | 1              | 0              | 16                       |

(NOTE) 1) All the registers can be accessed by Read/Write operation. Unused bit of the register is read out "0".

2) H/L of ADR and BCR means the higher (H) 8 bits/the lower (L) 8 bits of a 16-bit register.

3) Being allocated to continuous address, 16-bit ADR and BCR can be read or written by one instruction, using MPU's 2-byte LOAD/STORE instruction.

e.g. LDX \$<sub>10</sub> OC , Y (ADR H 3) → (Index Register H)  
           Address of DMAC (ADRL 3) → (Index Register L)

**BCR (Byte Count Register)**

Each channel has a 16-bit Byte Count Register. Number of DMA transfer words is programmed into this register. The content of the Byte Count Register is decremented by one everytime one-byte transfer has completed. When it becomes "0", DEND output goes "Low" level and informs I/O controller of the end of one-block DMA transfer. When IRQ is not masked, IRQ output goes "Low" level and MPU is interrupted to be informed of the end of DMA transfer. Moreover, IRQ and DEND signals are output, multiplexed with IRQ/DEND pin.

**CHCR (Channel Control Register)**

Each channel has Channel Control Register. This register is

**Table 3 Bit Structure of CHCR (Channel Control Register)**

| Bit No. | Name              | Read/Write | Function                                                     |                                                             |
|---------|-------------------|------------|--------------------------------------------------------------|-------------------------------------------------------------|
|         |                   |            | "1"                                                          | "0"                                                         |
| 0       | R/W               | R/W        | Transfer from memory to I/O controller (R/W output = "High") | Transfer from I/O controller to memory (R/W output = "Low") |
| 1       | Burst/Cycle Steal | R/W        | Burst Mode                                                   | Cycle Steal Mode*                                           |
| 2       | TSC/HALT          | R/W        | TSC Mode                                                     | HALT Mode*                                                  |
| 3       | Address down/up   | R/W        | Address: -1                                                  | Address: +1                                                 |
| 4       | Not used          | -          | -                                                            | -                                                           |
| 5       | Not used          | -          | -                                                            | -                                                           |
| 6       | Busy/Ready Flag   | R          | Busy<br>(DMA Transfer Operation)                             | Ready<br>(No DMA Transfer Operation)                        |
| 7       | DEND Flag         | R          | DMA End & Interrupt                                          | No Interrupt                                                |

\* Burst transfer in TSC mode is prohibited. R: Read, W: Write

Note that during DMA transfer operation, the function of R/W signal is accommodated to the memory Read/Write operation. Therefore, on the side of I/O device during DMA transfer operation, R/W input should be interpreted in inverse of the MPU Read/Write. That is, data should be output when R/W input is at "Low" level (In the case of MPU's read operation, I/O device outputs the data when it is at "High" level).

This arises from that during DMA transfer operation, I/O side performs data transfer independently instead of MPU. Moreover, such family LSI as HD6843 (FDC), etc. has this function and R/W signal is automatically interpreted inversely.

**(2) Burst/Cycle Steal Bit – CHCR Bit 1**

This bit is used to decide that DMA transfer should be performed in burst mode or cycle steal mode. When it is at "1", it specifies burst mode. That is, once DMA transfer is performed, MPU remains stopped until one-block data transfer is completed.

When this bit is "0", it specifies cycle steal mode. That is, everytime one-byte transfer has completed, MPU takes back the bus control, and DMA transfer and MPU operation are performed in time sharing.

(NOTE) Only in the case of HALT mode, burst mode can be specified. In TSC mode, burst mode cannot be specified.

**(3) TSC/HALT Mode Bit – CHCR Bit 2**

This bit is used to decide that DMA transfer should be

used to program the control information of its corresponding channel. Structure of CHCR is shown in Table 3.

**(1) R/W Control (specifies the direction of transfer)**

Bit – CHCR Bit 0

This bit controls the direction of DMA transfer. When it is at "1", R/W signal of DMAC goes "High" level during DMA transfer operation. This means to read out memory and write into I/O controller, that is, data is transferred from memory to I/O controller.

When it is at "0", R/W output goes "Low" level and data is transferred from I/O controller to memory.

**Table 3 Bit Structure of CHCR (Channel Control Register)**

performed by using MPU's TSC function or HALT function. When it is at "0", DMA transfer request signal is output from DRQH of DMAC.

When it is at "1", DMA transfer request signal is output from DRQT of DMAC.

**(4) Address down/up Bit – CHCR Bit 3**

This bit is used to decide that the address of memory region used for DMA transfer should be renewed up (increment of address) or down (decrement of address). When it is at "1", the address is decremented by one after one-byte transfer. When it is at "0", the address is incremented by one.

**(5) Busy/Ready Flag Bit – CHCR Bit 6**

This bit is a status flag to indicate whether its corresponding channel is performing DMA transfer or not. (READ only)

When it receives the first TxRQ of its corresponding channel, it goes to "1". When one-block transfer is completed and BCR becomes "0", it is reset to "0".

Also this flag is cleared when corresponding TxRQ Enable Bit in the PCR becomes "0".

**(6) DEND Flag Bit – CHCR Bit 7**

This bit is an interrupt flag to indicate that one-block DMA transfer of its corresponding channel has completed. (READ only).

When one-block transfer of its corresponding channel is completed and BCR becomes "0", it goes to "1". As soon as this flag is read out, i.e. CHCR of this channel is read



out, it is reset to "0".

Moreover, this bit is connected to  $\overline{\text{IRQ}}$  output. When it is at "1" and IRQ enable bit (within ICR register described later) is at "1",  $\overline{\text{IRQ}}$  output goes "Low" level.

#### PCR (Priority Control Register)

Priority Control Register is a 5-bit register to decide the operation mode of priority control circuit. Structure of PCR is shown in Table 4.

Table 4 Bit Structure of PCR (Priority Control Register)

| Bit No. | Name                               | Read /Write | Function                       |                                                    |
|---------|------------------------------------|-------------|--------------------------------|----------------------------------------------------|
|         |                                    |             | "1"                            | "0"                                                |
| 0       | TxRQ Enable #0 ( $\text{TxEN}_0$ ) | R/W         | TxRQ of Channel 0 is accepted. | TxRQ of Channel 0 is not accepted.                 |
| 1       | TxRQ Enable #1 ( $\text{TxEN}_1$ ) | R/W         | TxRQ of Channel 1 is accepted. | TxRQ of Channel 1 is not accepted.                 |
| 2       | TxRQ Enable #2 ( $\text{TxEN}_2$ ) | R/W         | TxRQ of Channel 2 is accepted. | TxRQ of Channel 2 is not accepted.                 |
| 3       | TxRQ Enable #3 ( $\text{TxEN}_3$ ) | R/W         | TxRQ of Channel 3 is accepted. | TxRQ of Channel 3 is not accepted.                 |
| 4       |                                    | -           | -                              | -                                                  |
| 5       | Not used                           | -           | -                              | -                                                  |
| 6       |                                    | -           | -                              | -                                                  |
| 7       | Rotate Control                     | R/W         | Rotate Mode                    | The order of priority is fixed at numerical order. |

R: Read, W: Write

(1) TxRQ Enable Bit ( $\text{TxEN}_0 \sim \text{TxEN}_3$ ) – PCR Bit 0~3

Each channel has this TxRQ Enable bit. When it is at "1", TxRQ input of its corresponding channel is accepted to perform DMA transfer. When it goes to "0", TxRQ of its corresponding channel is masked not to be received and TxAK is not output. During DMA transfer operation, when this bit goes to "0" before BCR becomes "0", following TxRQ input is not accepted and DMA transfer is interrupted. Then contents of ADR and BCR remain unchanged. When it rises to "1" again, DMA transfer is reopened. Therefore, in the case of cycle steal DMA, it is possible for the program to change the priority of the specific channel temporarily by manipulating this bit.

(2) Rotate Control Bit – PCR Bit 7

When this bit is at "0", the order of priority among DMA channels is fixed at numerical order. That is, Channel 0 is given a first priority and then is followed by Channel 1 → 2 → 3.

When this bit is at "1", priority control is due to rotate mode. That is, the channel that ended in the first time is given a first priority and the channel ended in the last time is controlled to be given a last priority.

#### ICR (Interrupt Control Register)

Interrupt Control Register is a 5-bit register to control  $\overline{\text{IRQ}}$  output. Its structure is shown in Table 5.

(1) IRQ Enable Bit – ICR Bit 0~3

Each channel has IRQ Enable Bit. When this bit is at "1" and DEND Flag of its corresponding channel is set to "1", IRQ output goes "Low" level. But when it is at "0", IRQ output is masked not to be output even if DEND Flag is set to "1".

These bits enable to control to output only a necessary channel to  $\overline{\text{IRQ}}$ .

(2) IRQ Flag – ICR Bit 7

This is a read-only bit and the status of  $\overline{\text{IRQ}}$  output is directly reflected on it. That is, when  $\overline{\text{IRQ}}$  output goes to "Low" level, it becomes "1".

$\overline{\text{IRQ}}$  output of DMAC is output as logical OR of 4-channel DEND Flag according to the following equation.  

$$\overline{\text{IRQ}} = (\text{DEND}_0 \cdot \overline{\text{IRQ Enable}}_0) + (\text{DEND}_1 \cdot \overline{\text{IRQ Enable}}_1) + (\text{DEND}_2 \cdot \overline{\text{IRQ Enable}}_2) + (\text{DEND}_3 \cdot \overline{\text{IRQ Enable}}_3)$$

#### DCR (Data Chain Control Register)

Data Chain Control Register is a 4-bit register and three of those bits are used to control data chain function. Remaining one bit is used to specify 2-channel/4-channel mode.

Structure of DCR is shown in Table 6.

(1) Data Chain Enable Bit – DCR Bit 0

When this bit is at "1", data chain function of DMAC is enabled. That is, when DMA transfer of a specified channel has completed and BCR goes to "0", the contents of ADR and BCR of Channel #3 are automatically transferred to ADR and BCR of the specified channel.

(2) Data Chain Channel Bit – DCR Bit 1~2

These bits are used to specify which channel should be used for the data chain. How to specify the channel is shown in Table 7. Data Chain Channel bit specifies the channel to which data should be transferred from Channel #3. Channel #3 contains the data for replacement. Channel #3 is fixed and cannot be changed.

(3) 2/4-channel Mode Bit – DCR Bit 3

This bit has no relation to the data chain function.

It is used to specify whether  $\overline{\text{CS}}/\text{TxAKB}$  is used for only input pin or I/O pin. When this bit is "0",  $\overline{\text{CS}}/\text{TxAKB}$  becomes  $\overline{\text{CS}}$  input pin in 2-channel mode since  $\text{TxAKB}$  output is not necessary for application up to 2-channel.

When this bit is "1",  $\overline{\text{CS}}/\text{TxAKB}$  becomes I/O pin in 4-channel mode (See Fig. 11).



Table 5 ICR (Interrupt Control Register)

| Bit No. | Name          | Read /Write | Function                               |                                    |
|---------|---------------|-------------|----------------------------------------|------------------------------------|
|         |               |             | "1"                                    | "0"                                |
| 0       | IRQ Enable #0 | R/W         | IRQ of Channel 0 is able to be output. | IRQ output of Channel 0 is masked. |
| 1       | IRQ Enable #1 | R/W         | IRQ of Channel 1 is able to be output. | IRQ output of Channel 1 is masked. |
| 2       | IRQ Enable #2 | R/W         | IRQ of Channel 2 is able to be output. | IRQ output of Channel 2 is masked. |
| 3       | IRQ Enable #3 | R/W         | IRQ of Channel 3 is able to be output. | IRQ output of Channel 3 is masked. |
| 4       |               | -           | -                                      | -                                  |
| 5       | Not used      | -           | -                                      | -                                  |
| 6       |               | -           | -                                      | -                                  |
| 7       | IRQ Flag      | R           | IRQ output "Low"                       | IRQ output "High" (off state)      |

R: Read, W: Write

Table 6 Bit Structure of DCR (Data Chain Control Register)

| Bit No. | Name               | Read /Write | Function                                                                                                                     |                                                            |
|---------|--------------------|-------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
|         |                    |             | "1"                                                                                                                          | "0"                                                        |
| 0       | Data Chain Enable  | R/W         | Data Chain is performed.                                                                                                     | Data Chain is not performed.                               |
| 1       | Data Chain Channel | R/W         | The channel which performs Data Chain is specified.<br>(The channel where contents of ADR and BCR of Channel #3 are loaded.) |                                                            |
| 2       |                    |             |                                                                                                                              |                                                            |
| 3       | 2/4-Channel Mode   | R/W         | 4-Channel Mode (CS/TxAKB is I/O pin.)                                                                                        | 2-Channel Mode (CS/TxAKB is designated to only input pin.) |
| 4       | Not used           | -           | -                                                                                                                            | -                                                          |
| 5       |                    | -           | -                                                                                                                            | -                                                          |
| 6       |                    | -           | -                                                                                                                            | -                                                          |
| 7       |                    | -           | -                                                                                                                            | -                                                          |

R: Read, W: Write

Table 7 How to specify Data Chain Channel

| DCR Bit 1 | DCR Bit 2 | Specified Channel |
|-----------|-----------|-------------------|
| 0         | 0         | Channel #0        |
| 1         | 0         | Channel #1        |
| 0         | 1         | Channel #2        |
| 1         | 1         | -                 |



Figure 11 How to Use CS/TxAKB Pin



## ■ OPERATION OF THE DMAC

### ● Transfer Mode of the DMAC

There are three DMA transfer modes such as HALT Cycle Steal, HALT Burst and TSC Cycle Steal. Operation in each mode is explained in the following.

#### HALT Cycle Steal Mode

This is a basic DMA transfer mode utilizing HALT state of MPU. In this mode, everytime 1-byte transfer has completed, MPU takes back the bus control and executes instruction cycle. That is, DMA transfer and MPU operation are performed in time sharing.

Timing chart is shown in Fig. 12 and flow chart is shown in Fig. 13. Procedure of transfer operation is the following. (No. ① ~ ⑪ in Fig. 12 correspond to the following items.)

- ①  $\text{TxRQ}_0 \sim \text{TxRQ}_3$  input is checked at the rising edge of  $\phi_2\text{DMA}$ . When it is at "High" level, it gets into the following operation.
- ②  $\text{DRQH} = \text{"Low"}$  is output and MPU is requested to stop its operation.
- ③  $\text{TxAKA}$  is driven (Level output).
- ④ MPU stops its operation and DMAC waits until  $\text{DGRNT}$  goes to "High" level.
- ⑤ When  $\text{DGRNT}$  goes to "High" level, DMAC drives  $\text{TxAKB}$ ,  $A_0 \sim A_{15}$  and  $\text{R}/\overline{\text{W}}$  lines.
- ⑥  $\text{TxSTB}$  is given to perform DMA transfer.
- ⑦ Address is incremented or decremented by one and number of transfer words is decremented by one.

- ⑧ When  $\text{DRQH}$  rises to "High" level, MPU gets into Instruction Cycle again.
- ⑨  $\text{TxRQ}$  falls to "Low" level.
- ⑩  $A_0 \sim A_{15}$  and  $\text{R}/\overline{\text{W}}$  get into high impedance state again.
- ⑪  $\text{DGRNT}$  falls to "Low" level.

[Note]  $\text{TxRQ}_0 \sim \text{TxRQ}_3$  input in HALT cycle steal is, in principle as shown in Fig. 12, set to "High" every 1-byte transfer on account of I/O request. When  $\text{TxSTB}$  of the DMAC is driven, it is reset to "Low". Take care not to be against this principle, or the following states may happen.

- (1) In the case where  $\text{TxRQ}$  becomes "High", but it is reset to "Low" before  $\text{DGRNT}$  becomes "High". In this case, the DMAC is in the wait state without sending out  $\text{TxSTB}$  until  $\text{TxRQ}$  rises to "High" again. As  $\text{DRQH}$  remains "Low" the MPU is forced to be stopped, and the system is in dead lock state until  $\text{TxRQ}$  rises to "High" again (Fig. 14).
- (2) In the case where  $\text{TxRQ}$  is not reset to "Low" though  $\text{TxSTB}$  has been driven. In this case, unless  $\text{TxRQ}$  returns to "Low" by the time  $\phi_2\text{DMA}$  rises after  $\text{TxSTB}$  has risen to "High", it is considered as a new I/O request, which leads the above-mentioned operation ①, ② → . If  $\text{TxRQ}$  falls to "Low" immediately after that, the same state as (1) happens (Fig. 15).



- \* IRQ of another channel or its own IRQ (remaining)
- \*\* Its own IRQ (output) or its own IRQ (remaining) or IRQ of another channel
- \*\*\* This is the last cycle of transfer

Figure 12 HALT Cycle Steal Mode



Figure 13 Flow Chart of DMAC Operation



Figure 14 Extraordinary TxRQ Input (1)

( In the case where TxRQ is reset to  
"Low" before the transfer )



Figure 15 Extraordinary TxRQ Input (2)

( In the case where TxRQ doesn't fall to "Low" after  
the transfer has been completed. )

**HALT Burst Mode**

In the case of cycle steal mode, MPU gets into Instruction Cycle everytime 1-byte transfer has completed. But in the case of burst mode, MPU remains stopped until 1-block transfer is finished. That is, DRQH continues to be output "Low" level until BCR becomes "0".

Its timing chart and flow chart are shown in Fig. 16 and Fig. 13 respectively. Procedure of transfer is the following (No. ① ~ ⑯ in Fig. 16 correspond to the following items).

- ① TxRQ input is checked at the rising edge of  $\phi_2$  DMA. When it is at "High" level, it goes into the following operation.
- ② DRQH="Low" level is given and MPU is requested to stop its operation.
- ③ TxAKA is driven.
- ④ MPU stops and DMAC waits for DGRNT rising "High" level.
- ⑤ When DGRNT rises "High" level, DMAC drives TxAKB,  $A_0 \sim A_{15}$ , and R/W lines.
- ⑥ TxSTB is sent out to perform DMA transfer.
- ⑦ Address is incremented or decremented by one and number of transfer words is decremented by one.
- ⑧ TxRQ falls to "Low" level.
- ⑨ When number of transfer words is 0, from ⑪ to ⑯ operations are performed.

⑩ When BCR is not "0", TxRQ is checked at the falling edge of  $\phi_2$  DMA. When TxRQ is at "High" level, DMA transfer is performed through ⑥ ~ ⑧ again. When TxRQ is not at "High" level, DMAC waits for becoming "High" level.

- ⑪ IRQ/DEND output goes to "Low" level.
- ⑫ DRQH output rises to "High" level and MPU gets into Instruction Cycle again.
- ⑬  $A_0 \sim A_{15}$  and R/W get into high impedance state.
- ⑭ DGRNT falls to "Low" level.

The transfer of the first byte (① ~ ⑥) is performed in the same way as that in HALT cycle steal mode. But in the second-byte and subsequent transfer, TxRQ is checked at the falling edge of  $\phi_2$  DMA and if TxRQ is at "High" level, DMA transfer is performed at the following cycle. Therefore, a high-speed response (MAX. 1 byte/1 cycle) is feasible.

In burst mode, TxRQ should be also, in principle, set to "High" when I/O request is asserted, and reset to "Low" when TxSTB goes to "Low". If TxRQ is asserted as level input without being reset, DMA transfer is performed at all cycles of  $\phi_2$  DMA since TxRQ is always at "High" level at the falling edge of  $\phi_2$  DMA. Its example is shown in the second-byte and the third-byte transfer in Fig. 16.



Figure 16 HALT Burst Mode

**TSC Cycle Steal Mode**

In the above-mentioned modes, DMA is performed by using the HALT function of the MPU. In TSC cycle steal mode, DMA is performed by using the TSC function of the MPU.

Its timing chart and flow chart are shown in Fig. 17 and Fig. 13 respectively.

Basic operation of the DMAC is the same as that in HALT cycle steal mode, but the detailed timing is different. The difference is explained in the following.

- (1) DRQT is used for DMA transfer request instead of DRQH.
- (2) DRQT is sent to the external clock control circuit to

extend clock E ( $\phi_2$ ) of MPU.

- (3) To DGRNT, the external clock control circuit inputs response signals.

In TSC mode, there isn't a burst mode. Because the MPU clock cannot be extended for a long time because MPU performs dynamic operation. When TSC mode is specified, DRQT returns to "High" and the MPU gets into the instruction cycle everytime 1-byte transfer has finished.



Figure 17 TSC Cycle Steal Mode

### ● Priority Control

#### Basic priority Control

There are two kinds of the DMAC priority control function. One is to mask TxRQ on each channel by TxRQ Enable bit of PCR. The other is priority-order-determining-circuit which the DMAC has as a hardware.

Moreover, the priority-order-determining-circuit has two operation modes (the rotate mode and the normal mode).

Structure of the priority control circuit is shown in Fig. 18. As shown in Fig. 18, TxRQ of the channel whose TxRQ Enable bit is at "1" level becomes an input of the priority-order-determining-circuit. Then it is checked whether TxRQ is at "High" level or not.

(Note) In this case, ZERO flag needs to be at "1" level. ZERO flag will be described later.

If one of TxRQ<sub>0</sub>~TxRQ<sub>3</sub> is at "High" level, its channel is selected, being given a first priority. Then it is latched by an executing-channel-number-latch-circuit to perform DMA transfer. Once an executing channel is determined and latched, it is unchanged until its DMA transfer has been completed. That is, the channel number strobe signal of DMAC doesn't go to "1" and the contents of the channel-number-latch-circuit are unchanged. In the cycle steal mode, the channel is fixed until 1-byte transfer has completed. In the burst mode, it is fixed until BCR becomes "0".



Figure 18 Structure of Priority Control Circuit

Therefore, once a long-period DMA transfer of a channel is performed in the burst mode, other channels need to wait until it has completed even if they have higher priority than the channel. Take much care to this point in designing response time to TxRQ of DMA channel.

(Note) As explained above, TxRQ input is latched internally. So

once it is accepted and latched, the channel number cannot be changed even though it returns to "Low". But as explained in HALT Cycle Steal Mode, DMA transfer is not performed unless TxRQ rises to "High" again.

Strobe timing of executing-channel-number-latch-circuit which allow modification or decision of executing channel is shown in Fig. 19.



Figure 19 Strobe Timing of Executing-Channel-Number-Latch-Circuit (the cycle steal mode)

But, as shown in Fig. 19, only the channel under executing DMA transfer is prohibited to accept TxRQ during DMA transfer operation, in order that one more byte transfer may not be

performed when the reset timing of TxRQ is delayed. Strobe timing in the burst mode is shown in Fig. 20.





Figure 20 Strobe Timing of Executing-Channel-Number-Latch-Circuit (the burst mode)

**Rotate Mode**

There are two operation modes in priority-order-determining circuit. These are Normal Mode and Rotate Mode. In the normal mode, the order of priority is fixed at numerical order. (Channel 0 is given a first priority and then is followed by Channel 1 → 2 → 3.) In the rotate mode, the channel next to the channel with

which DMA was executed in the last sequence, is given a first priority and the channel in the last sequence is given a last priority. But immediately after it gets into the reset state, the order of priority is the following: Channel 0 → 1 → 2 → 3.

An example of the rotate mode is shown in Fig. 21.



Figure 21 Example of Operation in the Rotate Mode

Next, Fig. 22 shows an example of the difference between the operation in the rotate mode and that in the normal mode. In this example, TxRQ of all channels is always at "High" level.

Moreover, BCR=2 and TxEN=1 are assumed. As a transfer mode, HALT cycle steal mode is used.



Figure 22 Difference between the operation in the rotate mode and that in the normal mode

The reason why the order of priority is not  $\#0 \rightarrow \#0 \rightarrow \#1 \rightarrow \#1 \rightarrow \dots$  in the normal mode is that during DMA transfer operation,  $TxRQ$  of an executing channel is prohibited from being accepted.

#### DMA Operation Timing with priority control

When more than 2 channels perform DMA transfer in parallel, the abovementioned priority-order-determining-circuit is used to determine the priority. The channel with lower priority waits until the channel with higher priority completes the transfer. Then it gets into DMA transfer operation. In this case, the following combinations of transfer modes are conceivable.

- (1) From HALT mode to HALT mode (Fig. 23)
- (2) From TSC mode to TSC mode (Fig. 24)
- (3) From HALT mode to TSC mode ] (Fig. 25)
- (4) From TSC mode to HALT mode ] (Fig. 25)

In changing from HALT mode to HALT mode, only one dead cycle is intervened. That is, even in the cycle steal mode, DMA transfer of the next channel is performed without returning the bus control to the MPU ( $\overline{DRQH}$  remains "Low").

In changing from TSC mode to TSC mode, DMA transfer

of the next channel is performed, after returning the bus control to MPU for one cycle.

In the case of HALT  $\rightarrow$  HALT, it doesn't return the bus control to MPU in order not to increase the response time of DMA transfer and dead cycles of the system.

On the other hand, in the case of TSC  $\rightarrow$  TSC mode, same mean cannot be applicable because MPU clock cannot remain stopped for a long time as in the case of HALT mode.

Both in the case of HALT  $\rightarrow$  TSC mode and in the case of TSC  $\rightarrow$  HALT mode, DMA operation timing is based on the same idea as the above two kinds of mode change. (In detail, see Fig. 25).

The timing in the case where the next byte is transferred without changing the channel is shown in Fig. 26. This is the case of HALT  $\rightarrow$  HALT mode. In this case, the bus control returns to MPU, before the next byte is transferred. In the case of TSC  $\rightarrow$  TSC mode, its timing is almost the same as than in Fig. 24, that is, after 1-byte transfer has completed, MPU executes the Instruction Cycle for one clock and then DMAC executes 1-byte transfer again.





Figure 23 Channel Change (HALT Mode → HALT Mode)



Figure 24 Channel Change (TSC Mode → TSC Mode)



Figure 25 Channel Change (HALT Mode → TSC Mode → HALT Mode)

Figure 26 Successive 2-byte Transfer of One Channel (HALT Cycle Steal Mode)  
HALT → HALT (by one channel)

### ● Status Flag

DMAC has BUSY Flag, DEND Flag and ZERO Flag on each channel. The former two of these flags can be read out by MPU, but ZERO Flag cannot be read out. Set and reset timing of each flag are shown in Fig. 27.

### BUSY/READY Flag

This flag is set to "1" when it accepts the first-byte TxRQ of its corresponding channel. After 1-block transfer has completed and BCR becomes "0", it is reset to "0". Therefore, while this flag is "1", that is, its corresponding channel is being used, the next block transfer cannot be performed.

Also this flag is cleared when corresponding TxRQ Enable Bit in the PCR becomes "0".

### DEND Flag

This is the interrupt flag to indicate the end of DMA transfer of its corresponding channel. After 1-block transfer has completed and BCR becomes "0", this flag is set to "1". This flag is reset to "0" immediately after the Channel Control Register having this flag is read out.

### ZERO Flag

This is the internal flag to indicate whether the data stored in the BCR is "0" or not (It cannot be read out).



Figure 27 Timing of Status Flag (Suppose that BCR is 2 in the initial state)

When BCR is "0", ZERO Flag is "0". When BCR is not "0", it is "1".

In the reset state, this flag is "0". If data that is not "0" is written into BCR, this flag is set to "1". When BCR becomes "0" after 1-block data transfer has completed, or MPU writes "0" into BCR, this flag is reset to "0".

The function of ZERO Flag is to prohibit accepting TxRQ of its corresponding channel while this flag is "0" (that is, BCR is "0") (See Fig. 18). While ZERO Flag is "0", TxRQ is not accepted even if TxEN is "1". This function avoids an false operation even if "High" input is provided to TxRQ before the initialization of the register.

When RES pin goes to "Low", this flag becomes "0", but the number in BCR is not reset to "0". Therefore, the state of this flag and BCR are not the same. In this case new data should be written into BCR (Then ZERO Flag becomes "1").

### ● DMA End Control

#### Function of IRQ/DEND Pin

DMAC has IRQ output and DEND output to perform DMA End Control. These are multiplexed outputs to IRQ/DEND.

### DEND pin.

The function of DEND output is to inform I/O controller of the end of 1-block transfer. After 1-block transfer has been completed and BCR becomes "0", DEND output provides "Low" pulse whose cycle is one clock, being synchronous with the final 1-byte data transfer. 4 channels have only one DEND output in common, so each channel determines whether DEND output is its own output or not, combining with TxAK signal. When TxAK of the channel is "High" and DEND is "Low", it shows that the cycle is the last one of DMA (See Fig. 29 and 30).

The function of IRQ output is to inform MPU of the end of 1-block transfer by interrupting it. As shown in Fig. 28, IRQ output is logical AND-OR of the interrupt flag (DEND Flag) and IRQ Enable bit of each channel.

IRQ and DEND outputs are multiplexed. IRQ/DEND pin is used as DEND output during DMAC cycle and IRQ output during MPU cycle. Moreover, DGRNT signal separates DEND and IRQ by its "High" or "Low". In detail, see Fig. 29 and Fig. 30.

Figure 28 Logic of  $\overline{\text{IRQ}}$  OutputFigure 29 Timing of  $\overline{\text{IRQ}}/\overline{\text{DEND}}$  Output



Figure 30 How to Use IRQ/DEND Output Signal

**Unusual DMA End**

Following section describes how to terminate or change normal sequence of DMA transfer.

## (1) When "0" is written into BCR

When "0" is written into BCR before it becomes "0", subsequent TxRQ are not accepted and this causes the termination of the DMA transfer since the internal ZERO Flag is reset to "0". In this case, note that DEND pulse is not provided.

## (2) When "1" is written into BCR

When "1", instead of "0", is written into BCR, only the next TxRQ is accepted and 1-byte DMA transfer is performed. In this case, DEND pulse is provided, being synchronous with the last transfer.

## (3) When another value is written into ADR &amp; BCR during the transfer

When the data in ADR & BCR are changed during the transfer, the following transfer is performed according to the change of the data.

## (4) When "0" is written into TxRQ Enable bit

When TxEN is reset to "0" during the transfer, this causes TxRQ comes not to be accepted and the transfer halts. But the state is different from that in the case (1), the number in BCR remains unchanged. Therefore, when TxEN is set to "1" again, the transfer is performed again.

## (5) When RES pin is set to "Low"

When RES is provided during the transfer, the transfer stops.

Then all of the control registers and their internal flags are reset to "0". But the data in ADR & BCR are not reset.

**(Supplement)**

It is only in the cycle steal mode that DMAC registers such as BCR and ADR can be read or written during the transfer. In the burst mode, it is usually impossible (But special external circuits enable it).

**• Data Chain Function**

The data chain function of DMAC is to transfer the contents of ADR & BCR of Channel #3 to ADR & BCR of a specified channel automatically and renew the data of them after the channel has completed 1-block transfer.



Figure 31 Data Chain Operation

Its detailed timing is shown in Fig. 32 and Fig. 33. As shown in these figures the contents of ADR & BCR of Channel #3 are transferred to the channel during the clock cycle next to the last one of 1-block transfer (which provides DEND pulse). Then DRQH or DRQT provides "Low" output for one more clock cycle than in the normal case. Therefore, MPU takes back the bus control again 1-clock later than in the normal case, that is, after the data renewal of the specified channel by the data chain from Channel #3.

In the TSC mode, the stretching period of clock $\phi_1$  is longer than in the normal case.

The contents of ADR & BCR of Channel #3 remain unchanged as long as new data are not written by MPU, even if the data chain is executed.

As for DEND output, DEND Flag and BUSY Flag in the case of data chain execution, they function in the same way as in the normal case. They provide DEND pulse everytime 1-block transfer has completed, and then DEND Flag is set to "1". Therefore, in the case where more than 3-block data chain is needed, DEND Flag is used for the execution. Its sequence is shown in Fig. 34. First, DEND Flag="1" that shows the end of the first-block data chain is read out. Next, the data of ADR & BCR for the third-block data chain need to be written into Channel #3, in parallel with the execution of the second-block data chain. (This data chain is feasible only in the cycle steal mode.)



Figure 32 Data Chain Operation (HALT Mode)



Figure 33 Data Chain Operation (TSC Mode)





Figure 34 Sequence of More than 3-block Data Chain

## ■ DMAC PROGRAMMING

Preparation of a channel for a DMA transfer requires:

- 1) Load the starting address into the Address Register.
- 2) Load the number of bytes into the Byte Count Register.
- 3) Program the Channel Control Register for the transfer characteristics: direction (bit 0), mode (bits 1 and 2), and the address update (bit 3).

The channel is now configured. To enable the transfer

request, set the appropriate enable bit (bits 0~3) of the Priority Control Register, as well as the Rotate Control bit.

If an interrupt on DMA End is desired, the enable bit (bits 0~3) of the Interrupt Control Register must be set.

If data chaining for the channel is necessary, it is programmed into the Data Chain Register and the appropriate data must be written into the Address and Byte Count Registers for channel #3.

Table 8 DMAC Programming Model

| Register          | Address (Hex) | Register Content    |                 |          |          |                               |                             |                             |                        |
|-------------------|---------------|---------------------|-----------------|----------|----------|-------------------------------|-----------------------------|-----------------------------|------------------------|
|                   |               | Bit 7               | Bit 6           | Bit 5    | Bit 4    | Bit 3                         | Bit 2                       | Bit 1                       | Bit 0                  |
| Channel Control   | 1x*           | DMA End Flag (DEND) | Busy/Ready Flag | Not Used | Not Used | Address Up/Down               | TSC/Halt                    | Burst/Steal                 | Read/Write (R/W)       |
| Priority Control  | 14            | Rotate Control      | Not Used        | Not Used | Not Used | TxRQ Enable #3 (TxEN3)        | TxRQ Enable #2 (TxEN2)      | TxRQ Enable #1 (TxEN1)      | TxRQ Enable #0 (TxEN0) |
| Interrupt Control | 15            | IRQ Flag            | Not Used        | Not Used | Not Used | IRQ Enable #3 (IE3)           | IRQ Enable #2 (IE2)         | IRQ Enable #1 (IE1)         | IRQ Enable #0 (IE0)    |
| Data Chain        | 16            | Not Used            | Not Used        | Not Used | Not Used | Two/Four Channel Select (2/4) | Data Chain Channel Select B | Data Chain Channel Select A | Data Chain Enable      |

\* The x represents the binary equivalent of the channel desired.

A comparison of the response times and maximum transfer rates is shown in Table 9. The data are shown for a system clock rate of 1 MHz.

The two 8-bit bytes that form the registers in Table 10 are placed in consecutive memory locations, making it very easy to use the MPU index register in programming them.

Fig. 38 shows an example of its minimum structure (1 channel, HALT mode, combination with FDC). Fig. 39 shows an example of its maximum structure. (but only one DMAC is used.)

Table 9 Maximum Transfer Speed & Response Time of the DMAC when  $t_{cyc\phi}$  equals 1  $\mu$ sec.

| Mode             | Maximum Transfer Speed ( $\mu$ sec/byte) | Response Time ( $\mu$ sec)                                                 |                  |
|------------------|------------------------------------------|----------------------------------------------------------------------------|------------------|
|                  |                                          | maximum                                                                    | minimum          |
| HALT Cycle Steal | (executing time of one instruction) + 3  | (executing time of one instruction)<br>+3.5 - $t_{TAH1}$<br>2 - $t_{TAH2}$ | 3.5 + $t_{TAS1}$ |
| HALT Burst       |                                          |                                                                            | 1 + $t_{TAS2}$   |
| TSC Cycle Steal  |                                          | 3.5 - $t_{TAH1}$                                                           | 2.5 + $t_{TAH1}$ |



Figure 35 One Channel



Figure 36 Two Channel

Table 10 Address and Byte Count Registers

| Register        | Channel | Address (Hex) |
|-----------------|---------|---------------|
| Address High    | 0       | 0             |
| Address Low     | 0       | 1             |
| Byte Count High | 0       | 2             |
| Byte Count Low  | 0       | 3             |
| Address High    | 1       | 4             |
| Address Low     | 1       | 5             |
| Byte Count High | 1       | 6             |
| Byte Count Low  | 1       | 7             |
| Address High    | 2       | 8             |
| Address Low     | 2       | 9             |
| Byte Count High | 2       | A             |
| Byte Count Low  | 2       | B             |
| Address High    | 3       | C             |
| Address Low     | 3       | D             |
| Byte Count High | 3       | E             |
| Byte Count Low  | 3       | F             |



Figure 37 Four-Channel





Figure 38 Example of DMA System Structure (1) (minimum)



Figure 39 Example of DMA System Structure (2) (maximum)

**HITACHI**

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

## ■ APPENDIX

### Contents of the DMAC Registers

(1) ADR0 ~ ADR3 (Address Register) (1 ADR on each channel)



(2) BCR0 ~ BCR3 (Byte Count Register) (1 BCR on each channel)



(3) CHCR0 ~ CHCR3 (Channel Control Register) (1 CHCR on each channel) (6 bit x 4)



(4) PCR (Priority Control Register) (5 bit x 1)



(5) ICR (Interrupt Control Register) (5 bit x 1)



(6) DCR (Data Chain Control Register) (4 bit x1)



# HD6345

## CRTC-II (CRT Controller)

The HD6345/HD6445 CRTC-II provides an interface between MPU and a raster scan CRT display. Both are upward-compatible with the NMOS CRTC HD6845S in pin and software. The power dissipation is lowered by adopting the CMOS process.

The HD6345/HD6445 offers a variety of functions under MPU control, such as programmable timing signal outputs for CRT monitor and display screen control operation. It can be widely applied to the various types of CRT display systems.

### ■ FEATURES

HD6345 PIN AND SOFTWARE COMPATIBLE WITH

HD6845S

HD6445 SOFTWARE COMPATIBLE WITH 6845S

FLEXIBLE SCREEN FORMAT

- Programmable numbers of characters per screen and rasters per character row
- Programmable horizontal/vertical sync signals and display timing signals
- Up to 16k words refresh memory (14 bits) addressable
- Programmable raster scanning modes: non-interlace, interlace sync, or interlace sync and video modes
- Up to 256 character rows per field
- High-speed display operation at 4.5 MHz character clock
- Double-size vertical display by raster interpolation

VERSATILE DISPLAY FUNCTIONS

- Screen split (max.4 screens configurable, horizontally)
- Paging and scrolling for each screen
- Smooth scrolling
- Two cursors with programmable width
- Programmable refresh memory width

FACILITATED SYSTEM CONFIGURATION

- 68 system bus interface (HD6345)
- 80 system bus interface (HD6445)
- Three-state control of memory address and raster address
- External synchronization in master-slave or TV sync modes
- Interrupt request by vertical blanking or light pen strode detection
- Programmable timing signal for dual-port RAM in DRAM mode

SINGLE +5 V POWER SUPPLY

CMOS PROCESS

### ■ TYPE OF PRODUCTS

| Type No. | Bus Timing | CRT Display Timing |
|----------|------------|--------------------|
| HD6345   | 1.0 MHz    |                    |
| HD63A45  | 1.5 MHz    |                    |
| HD63B45  | 2.0 MHz    | 4.5 MHz Max.       |
| HD6445-4 | 4.0 MHz    |                    |

HD6345, HD63A45, HD63B45,  
HD6445-4



(DP-40)

### ■ PIN ARRANGEMENT



(Top View)

\* Additional functions to the HD6845S

+ HD6445

\* HD6345



### ■ INTERNAL BLOCK DIAGRAM



### ■ SYSTEM BLOCK DIAGRAM



## ■ FUNCTION TABLE

| Item                       | Descriptions                                                                                                                                                                                                                                                                                                                                                     | Remarks                                                                                                                                                                                                                                                                    |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Programmable Screen Format | Horizontal scanning cycle<br>Vertical scanning cycle (by row)<br>Vertical scanning cycle (Adjust)<br>Number of displayed chars. / row<br>Number of char. rows / screen<br>Number of rasters / char. row<br>Horizontal display position<br>Vertical display position<br>Vertical sync position (Adjust)<br>HSYNC pulse width<br>VSYNC pulse width<br>DISPTMG skew | Programmable by char. clock time<br>Programmable by char. row time<br>Programmable by raster time<br><br>Enabled by programming sync signal output timings<br><br>Programmable by raster time<br><br>1 or 2 character skew                                                 |
| Screen Split               | 4 split-screens start positions programmable                                                                                                                                                                                                                                                                                                                     | Discretely programmable (Unit: row)<br>2/3/4 screens format selectable                                                                                                                                                                                                     |
| Cursor Control             | Cursor display position<br><br>Cursor height<br>Cursor width<br>Cursor blink<br>Simultaneous output of 2 cursors<br>(Only 1 available in DPRAM mode)<br>Cursor display mode<br>CUDISP skew                                                                                                                                                                       | Two 14-bit Cursor registers<br>1 or 2 cursors displayed<br>Display start/end rasters programmable within a row<br>Programmable by char. clock time<br>1/16 or 1/32 field rate selectable<br>Discretely programmable<br><br>OR/EOR mode selectable<br>1 or 2 character skew |
| Raster Scanning Mode       | Non-interlace mode<br>Interlace sync mode<br>Interlace sync and video mode                                                                                                                                                                                                                                                                                       | Either one of three modes selectable                                                                                                                                                                                                                                       |
| Memory Format              | Memory width set                                                                                                                                                                                                                                                                                                                                                 | Memory width programmable wider than display width (Unit: char.)                                                                                                                                                                                                           |
| Smooth Scrolling           | Display start raster address set<br>Target screen set                                                                                                                                                                                                                                                                                                            | Programmable by char. clock time<br>Any screen selectable                                                                                                                                                                                                                  |
| Raster Interpolation       | Double-size vertical display<br>Vertical scanning cycle doubled                                                                                                                                                                                                                                                                                                  | Same raster address supplied twice                                                                                                                                                                                                                                         |
| External Synchronization   | Synchronization with external sync signals                                                                                                                                                                                                                                                                                                                       | Superimposed display enabled on other CRT or TV screens                                                                                                                                                                                                                    |
| Interrupt Request          | Interrupt request signal caused by vertical blanking period or light pen input (Disabled in DPRAM mode)                                                                                                                                                                                                                                                          | Interrupt request mode programmable                                                                                                                                                                                                                                        |
| Light Pen                  | 14-bit light pen register<br>Light pen raster register                                                                                                                                                                                                                                                                                                           | Light pen raster address detected                                                                                                                                                                                                                                          |
| Refresh Memory Addressing  | 14-bit refresh memory address output<br>Four 14-bit screen start regs.<br>(Display start address programmable for each screen)                                                                                                                                                                                                                                   | Up to 16k words refresh memory accessible<br>Paging and scrolling enabled for each screen                                                                                                                                                                                  |
| Three-State Control        | Three-state control on MA and RA                                                                                                                                                                                                                                                                                                                                 | Controlled by TSC pin input                                                                                                                                                                                                                                                |
| Programmable Timing Output | Programmable timing signal supplied from access inhibit pin                                                                                                                                                                                                                                                                                                      | In DPRAM mode                                                                                                                                                                                                                                                              |



## ■ PIN FUNCTION

| Pin No. | Symbol                            | Pin Name                    | Input/<br>Output | Functions                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------------------------|-----------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | Vss                               | Vss                         | —                | Ground (GND) pin                                                                                                                                                                                                                                                                                                                                                                                |
| 2       | <u>RES</u>                        | Reset                       | Input            | Performs external reset on CRTC-II<br><u>RES</u> assertion causes CRTC-II:<br>(1) Clear all the internal counters<br>(2) Set all the output signals at low<br>(D <sub>0</sub> –D <sub>7</sub> are excluded)<br>(3) Clear registers R30 (Control 1), R31 (Control 2/<br>Status), and R32 (Control 3)<br>(Other registers are not affected at all)<br><u>RES</u> is valid only while LPSTB is low |
| 3*      | LPSTB                             | Light Pen Strobe            | Input            | Informs light pen strobe pulse detection                                                                                                                                                                                                                                                                                                                                                        |
|         | TSC                               | Three State<br>Control      | Input            | Performs three-state control on memory and raster<br>address                                                                                                                                                                                                                                                                                                                                    |
| 4–17    | MA <sub>0</sub> –MA <sub>13</sub> | Memory Address<br>0–13      | Output           | Supplies memory address for periodical memory refresh                                                                                                                                                                                                                                                                                                                                           |
| 18      | DISPTMG                           | Display Timing              | Output           | Indicates a screen display period                                                                                                                                                                                                                                                                                                                                                               |
| 19*     | CUDISP                            | Cursor Display              | Output           | Displays cursor on a screen<br>Enabled during DISPTMG is high                                                                                                                                                                                                                                                                                                                                   |
|         | ACI                               | Access Inhibit              | Output           | Supplies DPRAM access inhibit timing (programmable)                                                                                                                                                                                                                                                                                                                                             |
|         | IRQ                               | Interrupt Request           | Output           | Indicates interrupt request to MPU<br>Enabled during DISPTMG is low                                                                                                                                                                                                                                                                                                                             |
| 20      | Vcc                               | Vcc                         | —                | Power supply (+ 5V) pin                                                                                                                                                                                                                                                                                                                                                                         |
| 21      | CLK                               | Character Clock             | Input            | Receives character clock timing                                                                                                                                                                                                                                                                                                                                                                 |
| 22      | <u>WR</u>                         | Write                       | Input            | Inputs write signal from MPU                                                                                                                                                                                                                                                                                                                                                                    |
| 23      | E                                 | Enable (HD6345)             | Input            | Enables register read/write strobe signals from MPU                                                                                                                                                                                                                                                                                                                                             |
|         | <u>RD</u>                         | Read (HD6445)               | Input            | Inputs read signal from MPU                                                                                                                                                                                                                                                                                                                                                                     |
| 24      | RS                                | Register Select             | Input            | Selects either of address register or other registers<br>Address reg. selected when at low, and others at high<br>Normally, requested to connect to "A <sub>0</sub> " of MPU address<br>bus                                                                                                                                                                                                     |
| 25      | <u>CS</u>                         | Chip Select                 | Input            | Performs addressing on CRTC-II<br>MPU read/write upon CRTC-II registers enabled when<br><u>CS</u> is low                                                                                                                                                                                                                                                                                        |
| 26–33   | D <sub>0</sub> –D <sub>7</sub>    | Data Bus 0–7                | Input/<br>Output | Bidirectional bus for data transfer between MPU and CRTC-II                                                                                                                                                                                                                                                                                                                                     |
| 34–38   | RA <sub>0</sub> –RA <sub>4</sub>  | Raster Address<br>0–4       | Output           | Supplies raster address for selecting raster on character<br>generator                                                                                                                                                                                                                                                                                                                          |
| 39*     | H SYNC                            | Horizontal Sync             | Output           | Supplies horizontal sync signal                                                                                                                                                                                                                                                                                                                                                                 |
|         | EXH SYNC                          | External<br>Horizontal Sync | Input            | Receives external horizontal sync signal                                                                                                                                                                                                                                                                                                                                                        |
| 40*     | V SYNC                            | Vertical Sync               | Output           | Supplies vertical sync signal                                                                                                                                                                                                                                                                                                                                                                   |
|         | EXV SYNC                          | External<br>Vertical Sync   | Input            | Receives external vertical sync signal                                                                                                                                                                                                                                                                                                                                                          |

Note: \* -marked pin function is alterable according to the register setting.



## ■ INTERNAL REGISTER ASSIGNMENT

Notes 1) \*: Vertical : raster / Horizontal : character

2) ■: "0" is to be set, since these bits may be used in the future.



## ■ FUNCTIONAL DESCRIPTION

### PROGRAMMABLE SCREEN FORMAT

Figure 1 illustrates the screen format example, in non-interlace mode, when programming CRTC-II registers as listed in Table 1. Figure 2 shows the relation between memory address ( $MA_0$ - $MA_1$ ), raster address ( $RA_0$ - $RA_1$ ) and the location on the CRT screen.

The timing charts of CRT interface signals are shown in Figure 3, and those details are partially shown in Figure 4 and 5.



Figure 1 CRT Screen Format

Table 1 Programmed Values in Each Register

| Register No | Register Name                   | Programmed Values |
|-------------|---------------------------------|-------------------|
| R0          | Horizontal Total Characters     | Nht               |
| R1          | Horizontal Displayed Characters | Nhd               |
| R2          | Horizontal Sync Position        | Nhsp              |
| R3          | Sync Width                      | Nvsw, Nhsw        |
| R4          | Vertical Total Rows             | Nvt               |
| R5          | Vertical Total Adjust           | Nadj              |
| R6          | Vertical Displayed Rows         | Nvd               |
| R7          | Vertical Sync Position          | Nvsp              |
| R9          | Max. Raster Address             | Nr                |
| R12         | Screen 1 Start Address (H)      | 0                 |
| R13         | Screen 1 Start Address (L)      | 0                 |
| R30         | Control 1                       | 0                 |
| R31         | Control 2 / Status              | 0                 |
| R32         | Control 3                       | 0                 |

Notes 1) Nhd < Nht, Nvd < Nvt

2) R30, R31, and R32 are cleared by a device reset.



Figure 2 Memory Address and Raster Address





Figure 3 CRTC-II Timing Chart (Non-interface mode)



Figure 4 Vertical Display / Retrace Timing  
(A detail drawing of Fig. 3 A)



Figure 5 Frame Cycle Adjustment Timing  
(A detail drawing of Fig. 3 B)

#### SCREEN SPLIT

A display screen can be divided into up to four parts in the horizontal direction. Divided four parts are defined as split-screen 1, split-screen 2, split-screen 3, and split-screen 4. Split-screens are controlled by using bits  $SP_0$  and  $SP_1$  of the control 1 register (R30) and screen start position registers (R18, R21, R24).

Starting positions of each split-screen are determined in the number of character row. Split-screen 1 is the base screen, and always starts at row 0, while the other three split-screens start at any row except row 0. Paging or scrolling (by character) is performed in each split-screen independently.

The following is the example of screen split:

| Row Number | Display Screen |
|------------|----------------|
| 0          | Split-Screen 1 |
| 1          | Split-Screen 2 |
| 2          | Split-Screen 3 |
| 3          | Split-Screen 4 |
| 4          |                |
| 5          |                |
| 6          |                |
| 7          |                |
| 8          |                |

Programmed Value of Screen 2 Start Position Register = 1  
Programmed Value of Screen 3 Start Position Register = 3  
Programmed Value of Screen 4 Start Position Register = 7

Figure 6-A Screen Split (Example 1)

When the same value is programmed into more than one screen start position registers, split-screens corresponding to these registers are not displayed.



Figure 6-B Screen Split (Example 2)



Figure 6-C Screen Split (Example 3)





Figure 7 Memory Address and Raster Address in Split-Screens

**CURSOR CONTROL**

The HD6345/HD6445 can display two separate cursors (cursor 1, cursor 2) simultaneously on the screen. These two cursors are controlled independently. The cursor 1 is always valid, while the cursor 2 becomes valid by setting the C<sub>2</sub> bit of the control 3 register (R32). In the DPRAM mode, the cursor 2 cannot be displayed.

The HD6345/HD6445 controls cursors as follows:

- 1) Starting Position  
Starting position is controlled by using the cursor 1 address registers (R14, R15), and the cursor 2 address registers (R36, R37).
- 2) Cursor Heights  
The heights of the cursor 1 and the cursor 2 can be specified independently in units of rasters by using the cursor start registers (R10, R34), and the cursor enc registers (R11, R35).

## 3) Cursor Widths

The widths of the cursor 1 and the cursor 2 can be specified independently in units of characters by using the cursor width registers (R38, R39), and bits CW<sub>1</sub> and CW<sub>2</sub> of the control 3 register (R32). If the cursor width extends over the following row, the cursor in the following row is not displayed.

## 4) Cursor Blink

Cursor display, non-display, and blink rate can be controlled by using bits B<sub>1</sub> and P<sub>1</sub> of the cursor 1 start register (R10), and bits B<sub>2</sub> and P<sub>2</sub> of the cursor 2 start register (R34).

## 5) Cursor Display Mode

When the cursor 1 and the cursor 2 are overlapped on the screen, cursor display mode in the overlapped area can be specified by the CM bit of the control 3 register (R32), as shown in Figure 9.



Figure 8 Cursors





Figure 9 Cursor Display Mode

**RASTER SCANNING MODE**

The HD6345/HD6445 performs a character display in three types of raster scanning modes: non-interlace mode, interlace sync mode, and interlace sync and video mode. The bits V and S of the interlace mode and skew register (R8) control these modes.

The period that the raster scans across a screen and returns

to the top of the raster line is designated as 'one field'. In the non-interlace mode, one field configures a single frame (Figure 10). In the interlace sync mode and the interlace sync and video mode, a single frame period is shared between two alternating, even and odd, fields (Figure 10).



Figure 10 Raster Scanning Mode

In the interlace sync mode, the scanning lines in the odd field are placed downward by 1/2 raster line space from those in the even field because of the difference in HSYNC/VSYNC phases between two alternating fields.

In the interlace sync and video mode, the placement of the scanning lines is the same as in the interlace sync mode. However, the alternating even and odd raster lines are displayed in the alternating even and odd fields. For a given number of rasters per character, this mode allows twice as many characters to be displayed in the vertical direction as the non-interlace and the interlace sync modes. Note that the raster address is supplied in the different way according to the total number of rasters in a row, even or odd, as shown in Table 2.

Table 2 Start Raster Address for Each Row  
(In interlace sync and video mode)

| Total Number<br>of Rasters<br>in a Row | Field           |                | Even Field   | Odd Field    |
|----------------------------------------|-----------------|----------------|--------------|--------------|
|                                        | Even            | Odd            |              |              |
| Odd                                    | Even Char. Row* | Odd Char. Row* | Even address | Odd address  |
|                                        |                 |                | Odd address  | Even address |

\* The start row address is assumed to be "0" (even).



Figure 11 illustrates the raster scanning example in each mode.



Figure 11 Raster Scanning Example





Figure 12 Raster Scanning Timing

### MEMORY WIDTH SETTING

The offset value which is the difference between the display screen width and the display memory width in the horizontal direction can be specified in units of characters. (See Fig. 13)

Scrolling in any direction can be accomplished in units of characters, by setting the display memory width (horizontal direction) and the offset value, and by changing the start addresses of split-screens 1–4. This is performed by the memory width offset register (R33) and the MW bit of the control 3 register (R32).



Figure 13 Memory Width



Figure 14 Scrolling by Memory Width Setting



Figure 15 Memory Address and Raster Address in Memory Width Setting



**SMOOTH SCROLLING**

Smooth scrolling in the vertical direction can be accomplished by changing the start raster address in a character row. Whether scrolling in each split-screen is available or not can be selected. Selected split-screens scroll in the same way up to four split-screens simultaneously.

Smooth scrolling is performed by bits SS<sub>1</sub>-SS<sub>4</sub> of the control 2 register (R31), and the smooth scrolling register (R29).

Smooth scrolling can be used in the non-interlace mode and the interlace sync mode, but not in the interlace sync and video mode.



Figure 16 Smooth Scrolling



Figure 17 Memory Address and Raster Address in Smooth Scrolling (R29=2)





Figure 18 Smooth Scrolling in the Split-Screens  
(Split-screen 2 is scrolling.)

#### RASTER INTERPOLATION

In raster interpolation, the raster address is incremented every two rasters, thus the displayed image is doubled in the vertical direction. The vertical scanning cycle is also doubled. Raster interpolation is performed by the RI bit of the control 2

register (R31). This function can be used in the non-interlace mode and the interlace sync mode, but not in the interlace sync and video mode.

Figure 19 is an example of display with raster interpolation.



Figure 19 Raster Interpolation



Figure 20 Raster Address Output and Raster Interpolation



**EXTERNAL SYNCHRONIZATION**

External synchronization (EX sync) has master-slave mode and TV sync mode. The EX sync mode is controlled by bits VE, VS, and TV of the control 1 register (R30).

Master-slave mode is used to synchronize slave CRTC-II's with a master CRTC-II by VSYNC of a master CRTC-II. When superimposing a master screen with slave screens on the same CRT, clocks of a master and slave CRTC-II's can operate in different frequency or conditions shown below.

- (1) Phase of master CRTC-II clock matches with slave CRTC-II clock at rising edge of VSYNC.

- (2) Both master and slave CRTC-II's have the same horizontal/vertical scanning cycle.

In the interlace sync mode and interlace sync and video mode, the control 1 register must be set as to provide VSYNC output in odd fields of master CRTC-II.

Figure 21 illustrates the system configuration.



Figure 21 Master-Slave Mode

TV sync mode is used to synchronize the CRTC-II with the HSYNC and VSYNC signals of a TV's video signal.

In the TV sync mode, VSYNC/EXVSYNC and HSYNC/EXHSYNC pins function as input pins. The length of horizontal back porch is specified by the bits 0–3 of the sync width register (R3) and determines the display position in the horizontal direction.

In the interlace sync and video mode, the TV sync mode cannot be used.

In the TV sync mode, when performing slave CRTC raster interpolation, interlace sync mode or interlace sync and video mode must not be set in a master CRTC; otherwise the screen to move up and down by one raster.

Figure 22 illustrates the system configuration.



Figure 22 TV Sync Mode



External sync is valid on the conditions shown in Table 3.

Table 3 External Sync

(V: valid, I: invalid, -: program inhibited)

| Sync Mode         | Slave Mode<br>Master Mode     | Non-Interlace | Interlace Sync Mode | Interlace Sync and Video Mode |
|-------------------|-------------------------------|---------------|---------------------|-------------------------------|
| Master-Slave Mode | Non-Interlace Mode            | V             | I                   | I                             |
|                   | Interlace Sync Mode           | I             | V                   | V                             |
|                   | Interlace Sync and Video Mode | I             | V                   | V                             |
| TV Sync Mode      | Non-Interlace Mode            | V             | -                   | -                             |
|                   | Interlace Sync Mode           | V             | -                   | -                             |
|                   | Interlace Sync and Video Mode | V             | -                   | -                             |

Note) Slave CRTC's are always non-interlace mode in TV sync mode.

#### INTERRUPT REQUEST

An interrupt request signal to the MPU is output in the timing shown in Figure 23. An interrupt request is generated by the vertical blanking period, or the light pen input.

Reading the status register (R31) clears an interrupt request signal. Thus, if MPU does not read the status register (R31) when

the interrupt request is generated, an interrupt request signal is output during the horizontal and vertical retrace period.

In the DPRAM mode, an interrupt request signal is not output.

This function is controlled by using bits IB and IL of the control 1 register (R30).



Figure 23 Interrupt Timing



**THREE-STATE CONTROL OF MA/RA**

Memory address (MA) and raster address (RA) outputs can be three-stated, using the TSC input pin. Three-state control is enabled by setting the TC bit of the control 3 register (R32).

By using this function, multiplexer (MPX) which selects address lines from MPU and CRTC-II for refresh memory is not needed.



Figure 24 Three-State Control

**DPRAM MODE**

When the DPRAM mode is selected, the HD6345/HD6445 generates a programmable timing signal from the access inhibit pin. This signal, shown in Figure 25 as access inhibit period, provides the timing for the MPU to access to dual-port memory.

In the DPRAM mode, an interrupt request signal is not output, and the cursor 2 is not displayed.

This timing signal is available by using the DR bit of the control 3 register (R32), and the cursor 2 width register (R39).



Figure 25 DPRAM Mode Output Timing



### ■ INTERNAL REGISTERS

HD6345/HD6445 has one address register (AR) and forty data registers (R0 – R39). One register out of 40 data registers is selected by writing the address number of the register into the address register. Then the MPU can transfer data to or from the selected data register.

Write 0 to unused data bits (appear as    in the register table), since these bits are reserved for the future extensions.

### ADDRESS REGISTER (AR)

| Data Bit         |   |   |   |   |   |   |   | Program Unit | R/W |
|------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 | —            | W   |
| Register Address |   |   |   |   |   |   |   |              |     |

This register specifies the address number of the data register to be accessed. When both RS and CS are at low level, this register is selected. Programming the data from 40 to 63 produces no result.

### HORIZONTAL TOTAL CHARACTERS REGISTER (R0)

| Data Bit              |   |   |   |   |   |   |   | Program Unit | R/W |
|-----------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                     | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Character    | W   |
| Nht (No. of Char. -1) |   |   |   |   |   |   |   |              |     |

This register determines the horizontal scanning cycle. The programmed value is the total number of displayed and non-displayed characters per raster, minus one.

In the interlace sync mode, the programmed value, Nht, must be odd.

### HORIZONTAL DISPLAYED CHARACTERS REGISTER (R1)

| Data Bit                   |   |   |   |   |   |   |   | Program Unit | R/W |
|----------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Character    | W   |
| Nhd (Displayed Characters) |   |   |   |   |   |   |   |              |     |

This register specifies the number of displayed characters per row. Any number less than the total number of characters can be programmed into this register.

### HORIZONTAL SYNC POSITION REGISTER (R2)

| Data Bit                            |   |   |   |   |   |   |   | Program Unit | R/W |
|-------------------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                                   | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Character    | W   |
| Nhsp (Horizontal Sync Position - 1) |   |   |   |   |   |   |   |              |     |

This register is used to program horizontal sync position as a multiple of the character clock time. The programmed value is the character number of horizontal sync position, minus one. Any number equal to or less than the horizontal total characters register value (R0) can be programmed. When the programmed value of this register is increased, the display position on the screen is shifted to the left. When the programmed value is decreased, the display position is shifted to the right. Thus the optimum horizontal position can be determined.

### SYNC WIDTH REGISTER (R3)

| Data Bit                                                                                                                        |   |   |   |   |   |   |   | Program Unit | R/W |
|---------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                                                                                                                               | 6 | 5 | 4 | 3 | 2 | 1 | 0 | H: Character | W   |
| Wv <sub>3</sub> Wv <sub>2</sub> Wv <sub>1</sub> Wv <sub>0</sub> Wh <sub>3</sub> Wh <sub>2</sub> Wh <sub>1</sub> Wh <sub>0</sub> |   |   |   |   |   |   |   |              |     |

This register determines the widths of both horizontal sync pulse and vertical sync pulse. The horizontal sync pulse width is programmed from 1-to-15 character clock times in the low-order four bits. Zero cannot be programmed. The vertical sync

pulse width is programmed from 1-to-16 raster times in the high-order four bits. When 0 is programmed in the high-order four bits, a vertical sync pulse width is 16 raster times (16H).

Table 4 Horizontal Sync Pulse Width

| HSW            |                |                |                | Pulse Width |
|----------------|----------------|----------------|----------------|-------------|
| 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup> |             |
| 0              | 0              | 0              | 0              | Not Used    |
| 0              | 0              | 0              | 1              | 1 CH        |
| 0              | 0              | 1              | 0              | 2           |
| 0              | 0              | 1              | 1              | 3           |
| 0              | 1              | 0              | 0              | 4           |
| 0              | 1              | 0              | 1              | 5           |
| 0              | 1              | 1              | 0              | 6           |
| 0              | 1              | 1              | 1              | 7           |
| 1              | 0              | 0              | 0              | 8           |
| 1              | 0              | 0              | 1              | 9           |
| 1              | 0              | 1              | 0              | 10          |
| 1              | 0              | 1              | 1              | 11          |
| 1              | 1              | 0              | 0              | 12          |
| 1              | 1              | 0              | 1              | 13          |
| 1              | 1              | 1              | 0              | 14          |
| 1              | 1              | 1              | 1              | 15          |

CH Character Clock Time

Table 5 Vertical Sync Pulse Width

| VSW            |                |                |                | Pulse Width |
|----------------|----------------|----------------|----------------|-------------|
| 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> |             |
| 0              | 0              | 0              | 0              | 16 H        |
| 0              | 0              | 0              | 1              | 1           |
| 0              | 0              | 1              | 0              | 2           |
| 0              | 0              | 1              | 1              | 3           |
| 0              | 1              | 0              | 0              | 4           |
| 0              | 1              | 0              | 1              | 5           |
| 0              | 1              | 1              | 0              | 6           |
| 0              | 1              | 1              | 1              | 7           |
| 1              | 0              | 0              | 0              | 8           |
| 1              | 0              | 0              | 1              | 9           |
| 1              | 0              | 1              | 0              | 10          |
| 1              | 0              | 1              | 1              | 11          |
| 1              | 1              | 0              | 0              | 12          |
| 1              | 1              | 0              | 1              | 13          |
| 1              | 1              | 1              | 0              | 14          |
| 1              | 1              | 1              | 1              | 15          |

H Raster Time

### VERTICAL TOTAL ROWS REGISTER (R4)

| Data Bit                    |   |   |   |   |   |   |   | Program Unit | R/W |
|-----------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                           | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Row          | W   |
| Nvt (No. of Char. Rows - 1) |   |   |   |   |   |   |   |              |     |

This register determines the vertical scanning cycle. The programmed value is the total number of character rows in a field, minus one.

**VERTICAL TOTAL ADJUST REGISTER (R5)**

| Data Bit |   |   |                       |   |   |   |   | Program Unit | R/W |
|----------|---|---|-----------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                     | 3 | 2 | 1 | 0 | Raster       | W   |
| -        | - | - | Nadj (No. of Rasters) |   |   |   |   |              |     |

This register determines the number of additional rasters to adjust total number of rasters in a field. The optimum number from 0-to-31 can be programmed. Thus fine adjustment of vertical scanning cycle is performed.

**VERTICAL DISPLAYED ROWS REGISTER (R6)**

| Data Bit |   |   |                            |   |   |   |   | Program Unit | R/W |
|----------|---|---|----------------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                          | 3 | 2 | 1 | 0 | Row          | W   |
|          |   |   | Nvd (Displayed Char. Rows) |   |   |   |   |              |     |

This register specifies the number of displayed character rows in each field. Any number less than the total number of character rows can be programmed into this register.

**VERTICAL SYNC POSITION REGISTER (R7)**

| Data Bit |   |   |                                   |   |   |   |   | Program Unit | R/W |
|----------|---|---|-----------------------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                                 | 3 | 2 | 1 | 0 | Row          | W   |
|          |   |   | Nvsp (Vertical Sync Position - 1) |   |   |   |   |              |     |

This register is used to program vertical sync position on the screen as a multiple of the character row time. The programmed value is the character number of vertical sync position, minus one. Any number equal to or less than the vertical total rows register value (R4) can be programmed. When the programmed value of this register is increased, the display position is shifted up. When the programmed value is decreased, the display position is shifted down. Thus the optimum vertical position can be determined.

**INTERLACE MODE AND SKEW REGISTER (R8)**

| Data Bit       |                |                |                |   |   |   |   | Program Unit | R/W |
|----------------|----------------|----------------|----------------|---|---|---|---|--------------|-----|
| 7              | 6              | 5              | 4              | 3 | 2 | 1 | 0 | —            | W   |
| C <sub>1</sub> | C <sub>0</sub> | D <sub>1</sub> | D <sub>0</sub> | — | — | V | S |              |     |

This register selects the raster scanning mode and controls the skew (delay) of CUDISP and DISPTMG outputs.

**• Raster Scanning Mode (V, S)**

The low-order two bits select the raster scanning mode.

| V | S | Raster Scanning Mode          |
|---|---|-------------------------------|
| 0 | 0 | Non-interlace mode            |
| 0 | 1 | Interlace sync mode           |
| 1 | 0 | Non-interlace mode            |
| 1 | 1 | Interlace sync and video mode |

**• Skew (C<sub>1</sub>, C<sub>0</sub>, D<sub>1</sub>, D<sub>0</sub>)**

The bits D<sub>1</sub>/D<sub>0</sub> and C<sub>1</sub>/C<sub>0</sub> specify the skew of DISPTMG and CUDISP outputs, respectively. Skew control makes these output timings match with the serial video signals by delaying these outputs as programmed, in order to assure the access time to refresh memory and character generator.

| D <sub>1</sub> | D <sub>0</sub> | DISPTMG            |
|----------------|----------------|--------------------|
| 0              | 0              | No skew            |
| 0              | 1              | One character skew |
| 1              | 0              | Two character skew |
| 1              | 1              | Not available      |

| C <sub>1</sub> | C <sub>0</sub> | CUDISP             |
|----------------|----------------|--------------------|
| 0              | 0              | No skew            |
| 0              | 1              | One character skew |
| 1              | 0              | Two character skew |
| 1              | 1              | Not available      |



Figure 26 DISPTMG and CUDISP (One character skew)

**MAXIMUM RASTER ADDRESS REGISTER (R9)**

| Data Bit |   |   |    |   |   |   |   | Program Unit | R/W |
|----------|---|---|----|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4  | 3 | 2 | 1 | 0 | Raster       | W   |
| -        | - | - | Nr |   |   |   |   |              |     |

This register determines the number of rasters per character row. When n means the number of rasters, the programmed value is as follows:

- non-interlace mode, interlace sync mode : n - 1
- interlace sync and video mode : n - 2

**(1) Non-Interlace mode****(2) Interlace sync mode**

In the interlace sync mode, a half number of rasters per row minus one should be programmed.

**(3) Interlace sync and video mode**

In the interlace sync and video mode, the sum of rasters per row minus two should be programmed.

**CURSOR 1 START REGISTER (R10)**

| Data Bit |                |                |                                   |   |   |   |   | Program Unit | R/W |
|----------|----------------|----------------|-----------------------------------|---|---|---|---|--------------|-----|
| 7        | 6              | 5              | 4                                 | 3 | 2 | 1 | 0 |              |     |
| -        | B <sub>1</sub> | P <sub>1</sub> | Ncs <sub>1</sub> (Raster Address) |   |   |   |   | Raster       | W   |

This register determines the start raster address and selects the cursor blink mode for the cursor 1. The low-order five bits determines the start raster address. Bits B<sub>1</sub> and P<sub>1</sub> select the cursor blink mode.

| B <sub>1</sub> | P <sub>1</sub> | Cursor Blink Mode      |
|----------------|----------------|------------------------|
| 0              | 0              | No blink               |
| 0              | 1              | No cursor              |
| 1              | 0              | Blink, 1/16 field rate |
| 1              | 1              | Blink, 1/32 field rate |

Blink Rate

**CURSOR 1 END REGISTER (R11)**

| Data Bit |   |   |                                   |   |   |   |   | Program Unit | R/W |
|----------|---|---|-----------------------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                                 | 3 | 2 | 1 | 0 |              |     |
| -        | - | - | Nce <sub>1</sub> (Raster Address) |   |   |   |   | Raster       | W   |

This register determines the end raster address for the cursor-1.

**SCREEN 1 START ADDRESS REGISTER (H, L) (R12, R13) (R12)**

| Data Bit |   |                    |   |   |   |   |                | Program Unit | R/W |
|----------|---|--------------------|---|---|---|---|----------------|--------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0              |              |     |
| -        | - | Memory Address (H) |   |   |   |   | Memory Address | R/W          |     |

(R13)

| Data Bit |   |                    |   |   |   |   |                | Program Unit | R/W |
|----------|---|--------------------|---|---|---|---|----------------|--------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0              |              |     |
| -        | - | Memory Address (L) |   |   |   |   | Memory Address | R/W          |     |

These registers determine the start memory address for the split-screen 1 display. Paging or scrolling is enabled by renewing these registers. The high-order two bits of R12 are always read as 0s.

**CURSOR 1 ADDRESS REGISTER (H, L) (R14, R15) (R14)**

| Data Bit |   |                    |   |   |   |   |                | Program Unit | R/W |
|----------|---|--------------------|---|---|---|---|----------------|--------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0              |              |     |
| -        | - | Memory Address (H) |   |   |   |   | Memory Address | R/W          |     |

(R15)

| Data Bit |   |                    |   |   |   |   |                | Program Unit | R/W |
|----------|---|--------------------|---|---|---|---|----------------|--------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0              |              |     |
| -        | - | Memory Address (L) |   |   |   |   | Memory Address | R/W          |     |

These registers determine the cursor 1 display memory address. The high-order two bits of R14 are always read as 0s.

**LIGHT PEN REGISTER (H, L) (R16, R17)**

(R16)

| Data Bit |   |                    |   |   |   |   |                    | Program Unit | R/W |
|----------|---|--------------------|---|---|---|---|--------------------|--------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0                  |              |     |
| -        | - | Memory Address (H) |   |   |   |   | Memory Address (H) |              | R   |

(R17)

| Data Bit |   |                    |   |   |   |   |                    | Program Unit | R/W |
|----------|---|--------------------|---|---|---|---|--------------------|--------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0                  |              |     |
| -        | - | Memory Address (L) |   |   |   |   | Memory Address (L) |              | R   |

These registers store the light pen detection address. The high-order two bits of R16 are always read as 0s.

Note that the stored address will be different from the actual address due to the following delays: address output delay, video signal output delay, light pen detection to LPSTB delay, and LPSTB to internal recognition delay. The relations between the LPSTB input and the memory address, raster address are shown in Figures 32, 33 in electrical characteristics.

**SCREEN 2 START POSITION REGISTER (R18)**

| Data Bit |   |               |   |   |   |   |               | Program Unit | R/W |
|----------|---|---------------|---|---|---|---|---------------|--------------|-----|
| 7        | 6 | 5             | 4 | 3 | 2 | 1 | 0             |              |     |
| -        | - | Start Row - 1 |   |   |   |   | Start Row - 1 | Row          | R/W |

This register determines the start row of the split-screen 2. The programmed value is the start row number minus one.

If the split-screen 3 (or 4) start position register (R21 (or R24)) has already been programmed with the identical data, both of the split-screens 2 and 3 (or 4) will be disabled.

**SCREEN 2 START ADDRESS REGISTER (H, L) (19, R20)**

| Data Bit |   |                    |   |   |   |   |                    | Program Unit   | R/W |
|----------|---|--------------------|---|---|---|---|--------------------|----------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | 1 | 0                  |                |     |
| -        | - | Memory Address (H) |   |   |   |   | Memory Address (H) | Memory Address | R/W |

(R20)

| Data Bit |   |                    |   |   |   |    |                    | Program Unit   | R/W |
|----------|---|--------------------|---|---|---|----|--------------------|----------------|-----|
| 7        | 6 | 5                  | 4 | 3 | 2 | -1 | 0                  |                |     |
| -        | - | Memory Address (L) |   |   |   |    | Memory Address (L) | Memory Address | R/W |

These registers determine the start memory address for the split-screen 2 display. Paging or scrolling is enabled by renewing these registers. The high-order two bits of R19 are always read as 0s.

**SCREEN 3 START POSITION REGISTER (R21)**

| Data Bit |   |               |   |   |   |   |               | Program Unit | R/W |
|----------|---|---------------|---|---|---|---|---------------|--------------|-----|
| 7        | 6 | 5             | 4 | 3 | 2 | 1 | 0             |              |     |
| -        | - | Start Row - 1 |   |   |   |   | Start Row - 1 | Row          | R/W |

This register determines the start row of the split-screen 3. The programmed value is the start row number minus one.

If the split-screen 2 (or 4) start position register (R18 (or R24)) has already been programmed with the identical data, both of the split-screens 3 and 2 (or 4) will be disabled.



**SCREEN 3 START ADDRESS REGISTER (H, L) (R22, R23)  
(R22)**

| Data Bit |   |   |   |   |   |   |   | Program Unit       | R/W |     |
|----------|---|---|---|---|---|---|---|--------------------|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Memory Address (H) |     | R/W |
| —        | — | — | — | — | — | — | — | Memory Address     |     | R/W |

(R23)

| Data Bit |   |   |   |   |   |   |   | Program Unit       | R/W |     |
|----------|---|---|---|---|---|---|---|--------------------|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Memory Address (L) |     | R/W |
| —        | — | — | — | — | — | — | — | Memory Address     |     | R/W |

These registers determine the start memory address for the split-screen 3 display. Paging or scrolling is enabled by renewing these registers. The high-order two bits of R22 are always read as 0s.

**SCREEN 4 START POSITION REGISTER (R24)**

| Data Bit |   |   |   |   |   |   |   | Program Unit  | R/W |     |
|----------|---|---|---|---|---|---|---|---------------|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Row           |     | R/W |
| —        | — | — | — | — | — | — | — | Start Row – 1 |     | R/W |

This register determines the start row of the split-screen 4. The programmed value is the start row number minus one.

If the split-screen 2 (or 3) start position register (R18 (or R21)) has already been programmed with the identical data, both of the split-screens 4 and 2 (or 3) will be disabled.

**SCREEN 4 START ADDRESS REGISTER (H, L) (R25, R26)  
(R25)**

| Data Bit |   |   |   |   |   |   |   | Program Unit       | R/W |     |
|----------|---|---|---|---|---|---|---|--------------------|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Memory Address (H) |     | R/W |
| —        | — | — | — | — | — | — | — | Memory Address     |     | R/W |

(R26)

| Data Bit |   |   |   |   |   |   |   | Program Unit       | R/W |     |
|----------|---|---|---|---|---|---|---|--------------------|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Memory Address (L) |     | R/W |
| —        | — | — | — | — | — | — | — | Memory Address     |     | R/W |

These registers determine the start memory address for the split-screen 4 display. Paging or scrolling is enabled by renewing these registers. The high-order two bits of R25 are always read as 0s.

**VERTICAL SYNC POSITION ADJUST REGISTER (R27)**

| Data Bit |   |   |   |   |   |   |   | Program Unit          | R/W |   |
|----------|---|---|---|---|---|---|---|-----------------------|-----|---|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Raster                |     | W |
| —        | — | — | — | — | — | — | — | Nvad (No. of Rasters) |     | W |



Figure 27 Vertical Sync Position (Vertical Sync Pulse Width = 6)

This register performs a fine adjustment on the vertical sync signal output in units of rasters. The VSYNC signal is supplied after the delay of Nvad rasters. Nvad is equal to or less than the maximum raster address register value (R9).

This register is enabled when "SY (bit 3) = 1" is set into the control 1 register (R30). If an adjustment is not required, the SY bit or this register (R27) is requested to be set as 0.

**LIGHT PEN RASTER REGISTER (R28)**

| Data Bit |   |   |   |   |   |   |   | Program Unit   | R/W |   |
|----------|---|---|---|---|---|---|---|----------------|-----|---|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | —              |     | — |
| DP       | — | — | — | — | — | — | — | Raster Address |     | R |

This register stores the light pen detection raster address and the detection period. The raster address is detected and stored into this register when the LPSTB input is asserted. The DP (bit 7) indicates the period in which the light pen strobe is detected. "DP = 1" is stored when the LPSTB is asserted during the display period, and "DP = 0" is stored when it occurs during the blanking period.

**SMOOTH SCROLLING REGISTER (R29)**

| Data Bit |   |   |   |   |   |   |   | Program Unit         | R/W |     |
|----------|---|---|---|---|---|---|---|----------------------|-----|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | —                    |     | —   |
| —        | — | — | — | — | — | — | — | Nss (Raster Address) |     | R/W |

This register determines the start raster address within a row. By renewing this register, smooth scrolling is provided for the screen specified by the bits SS<sub>1</sub> – SS<sub>4</sub> of the control 2 register. The programmable number is equal to or less than the maximum raster address register value (R9).

This register is valid only in the non-interlace mode and the interlace sync mode.

**CONTROL 1 REGISTER (R30)**

| Data Bit |    |    |    |    |    |                 |                 | Program Unit | R/W |   |
|----------|----|----|----|----|----|-----------------|-----------------|--------------|-----|---|
| 7        | 6  | 5  | 4  | 3  | 2  | 1               | 0               | —            |     | — |
| VE       | VS | IB | IL | SY | TV | SP <sub>1</sub> | SP <sub>0</sub> | —            |     | W |

This register controls the following by the corresponding bits. A device reset clears all bits of this register.

VE, VS, TV : External synchronization control

IB, IL : Interrupt control

SY : Vertical sync position adjust control

SP<sub>1</sub>, SP<sub>0</sub> : Screen split control

● External Synchronization Control (VE, VS, TV)

(1) Operation mode alteration

| VE | Function                                                                                                        |
|----|-----------------------------------------------------------------------------------------------------------------|
| 0  | EXVSYNC/VSYNC corresponds to VSYNC output                                                                       |
| 1  | EXVSYNC/VSYNC corresponds to EXVSYNC input                                                                      |
| VS | DISPTMG                                                                                                         |
| 0  | Activated                                                                                                       |
| 1  | Keeps low                                                                                                       |
| TV | Function                                                                                                        |
| 0  | EXHSYNC/HSYNC corresponds to HSYNC output<br>Sync width register (R3) defines the HSYNC pulse width             |
| 1  | EXHSYNC/HSYNC corresponds to EXHSYNC input<br>Sync width register (R3) defines the horizontal back porch period |

(2) EXVSYNC and VSYNC control

< VE = 1 >

| VS            | TV | EXVSYNC                                                                              |                           |
|---------------|----|--------------------------------------------------------------------------------------|---------------------------|
| 0             | 0  | Signal supplied to EXVSYNC is ignored                                                |                           |
| 0             | 1  | EXVSYNC/VSYNC corresponds to EXVSYNC input and synchronized with the external signal |                           |
| 1             | 0  |                                                                                      |                           |
| 1             | 1  |                                                                                      |                           |
| < VE = 0 >    |    |                                                                                      |                           |
| VS            | TV | VSYNC                                                                                |                           |
| Non-Interlace |    | Interlace Sync                                                                       | Interlace Sync and Video* |
| 0             |    | VSYNC signal supplied                                                                |                           |
| 1             |    | VSYNC signal supplied only in odd field scanning                                     |                           |

Note) \* Attention to the limitation item described in Note) of Table 6 for interlace sync and video mode.

Table 6 External Synchronization Control

| TV | VE | VS | Function                                                                                                               |
|----|----|----|------------------------------------------------------------------------------------------------------------------------|
| 0  | 0  | 0  | Set as master CRTC in master-slave mode*                                                                               |
| 0  | 0  | 1  | Set as master CRTC in master-slave mode, in interlace sync mode or interlace sync and video mode, upon synchronization |
| 0  | 1  | 0  | Set as slave CRTC in master-slave mode                                                                                 |
| 0  | 1  | 1  | Set as slave CRTC in master-slave mode, upon synchronization                                                           |
| 1  | 0  | 0  | Program inhibited                                                                                                      |
| 1  | 0  | 1  | Program inhibited                                                                                                      |
| 1  | 1  | 0  | Set as slave CRTC in TV sync mode**                                                                                    |
| 1  | 1  | 1  | Set as slave CRTC in TV sync mode, upon synchronization**                                                              |

Note) \* "000" is to be set also when not performing the external synchronization.

\*\* In TV sync mode, DISPTMG is supplied after the back porch period.

● Interrupt Control (IB, IL)

| Control 1 Register<br>IB | IL | IRQ Signal                                        |
|--------------------------|----|---------------------------------------------------|
| 0                        | 0  | Not supplied                                      |
| 0                        | 1  | Supplied by light pen strobe                      |
| 1                        | 0  | Supplied by vertical blanking                     |
| 1                        | 1  | Supplied by light pen strobe or vertical blanking |

Note) The IRQ signal is supplied from the IRQ pin while the DISPTMG is low

● Vertical Sync Position Adjust Control (SY)

| Control 1 Register<br>SY | Vertical Sync Position Adjust Reg. (R27) |
|--------------------------|------------------------------------------|
| 0                        | Disabled                                 |
| 1                        | Enabled                                  |

● Screen Split Control (SP<sub>1</sub>, SP<sub>0</sub>)

| Control 1 Register<br>SP <sub>1</sub> | SP <sub>0</sub> | Function                                                   |
|---------------------------------------|-----------------|------------------------------------------------------------|
| 0                                     | 0               | Screen start position regs. (R18, R21, R24) disabled       |
| 0                                     | 1               | Screen 2 start position register (R18) enabled             |
| 1                                     | 0               | Screen 2 and 3 start position regs. (R18, R21) enabled     |
| 1                                     | 1               | Screen 2 to 4 start position regs. (R18, R21, R24) enabled |

CONTROL 2 / STATUS REGISTER (R31)

| Data Bit        |                 |                 |                 |    |   |    |    | Program Unit | R/W |
|-----------------|-----------------|-----------------|-----------------|----|---|----|----|--------------|-----|
| 7               | 6               | 5               | 4               | 3  | 2 | 1  | 0  |              |     |
| SS <sub>4</sub> | SS <sub>3</sub> | SS <sub>2</sub> | SS <sub>1</sub> | RI | — | —  | —  |              | W   |
| AI              | 0               | 0               | 0               | 0  | E | SB | SL |              | R   |

Status  
Control 2

During a write transaction, this register specifies the screen to be scrolled smoothly and provides the double-size vertical display with the raster interpolation function. A device reset clears the bits of the control 2 register.

During a read transaction, this register indicates the status such as display field, vertical blanking, light pen strobe and access inhibit in DPRAM mode. A device reset clears the AI bit and SL bit of the status register.

Refer to Table 10 Reset State of Internal Registers for details.

< Control 2 Register >

SS<sub>4</sub>, SS<sub>3</sub>, SS<sub>2</sub>, SS<sub>1</sub> : Smooth scrolling control

RI : Raster interpolation control

< Status Register >

AI, E, SB, SL : Status indication

### ● Smooth Scrolling Control (SS1–SS4)

Setting the bits SS1 to SS4 enables smooth scrolling on the split-screens 1 to 4, respectively. The smooth scrolling register (R29) is enabled for the specified split-screen.

|                 |   | Smooth Scrolling               |
|-----------------|---|--------------------------------|
| SS <sub>1</sub> | 0 | Disabled on the split-screen 1 |
|                 | 1 | Enabled on the split-screen 1  |
| SS <sub>2</sub> | 0 | Disabled on the split-screen 2 |
|                 | 1 | Enabled on the split-screen 2  |
| SS <sub>3</sub> | 0 | Disabled on the split-screen 3 |
|                 | 1 | Enabled on the split-screen 3  |
| SS <sub>4</sub> | 0 | Disabled on the split-screen 4 |
|                 | 1 | Enabled on the split-screen 4  |

### ● Raster Interpolation Control (RI)

Setting 1 into this bit performs a raster interpolation. The raster address is incremented every two rasters, doubling the vertical scanning cycle.

This function is provided only in the non-interlace mode and the interlace sync mode.

### ● Status Indication (AI, E, SB, SL)

Access Inhibit Status Bit : AI

| AI | Status                          |
|----|---------------------------------|
| 0  | Refresh memory access allowed   |
| 1  | Refresh memory access inhibited |

Display Field Status Bit : E

| E | Status                    |
|---|---------------------------|
| 0 | During odd field display  |
| 1 | During even field display |

Note) E is always "0" in the non-interlace mode.

Vertical Blanking Status Bit · SB

| SB | Status                       |
|----|------------------------------|
| 0  | Not during vertical blanking |
| 1  | During vertical blanking     |

Light Pen Strobe Status Bit · SL

| SL | Status                        |
|----|-------------------------------|
| 0  | Light pen strobe not detected |
| 1  | Light pen strobe detected     |

Reading this register clears the SL, but not SB. Also, the IRQ output signal goes low upon read access of this register. The bits 3-6 of the status register are always read as 0s.

### CONTROL 3 REGISTER (R32)

| Data Bit |   |   |   |   |   |   |   | Program Unit | R/W |
|----------|---|---|---|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | —            | W   |

This register controls the following by the corresponding bits. A device reset clears this register

CM : Cursor display mode control  
C<sub>2</sub> : Cursor 2 enable  
CW<sub>1</sub> : Cursor 1 width control  
CW<sub>2</sub> : Cursor 2 width control  
MW : Memory width control  
TC : Three-state control  
DR : DPRAM mode selection

#### ● Cursors Display Mode Control (CM)

|    |                      |
|----|----------------------|
| CM | Cursors Display Mode |
| 0  | EOR mode             |
| 1  | OR mode              |

#### ● Cursor 2 Enable (C<sub>2</sub>)

|                |          |
|----------------|----------|
| C <sub>2</sub> | Cursor 2 |
| 0              | Disabled |
| 1              | Enabled  |

#### ● Cursor 1 Width Control (CW<sub>1</sub>)

|                 |                                                           |
|-----------------|-----------------------------------------------------------|
| CW <sub>1</sub> | Cursor 1 Width Register (R38)                             |
| 0               | Disabled<br>1-character width specified as cursor 1 width |
| 1               | Enabled<br>Set value in R38 specified as cursor 1 width   |

#### ● Cursor 2 Width Control (CW<sub>2</sub>)

|                 |                                                           |
|-----------------|-----------------------------------------------------------|
| CW <sub>2</sub> | Cursor 2 Width Register (R39)                             |
| 0               | Disabled<br>1-character width specified as cursor 2 width |
| 1               | Enabled<br>Set value in R39 specified as cursor 2 width   |

#### ● Memory Width Control (MW)

|    |                                                       |
|----|-------------------------------------------------------|
| MW | Memory Width Offset Register (R33)                    |
| 0  | Disabled<br>Linear address supplied as memory address |
| 1  | Enabled<br>Memory width definable                     |

#### ● Three-State Control (TC)

|    |                                                                                                                                                                                    |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TC | MA and RA Outputs                                                                                                                                                                  |
| 0  | Three-state control disabled                                                                                                                                                       |
| 1  | When TSC is low, memory address supplied on MA <sub>0</sub> -13 and RA <sub>0</sub> -4<br>When TSC is high, MA <sub>0</sub> -13 and RA <sub>0</sub> -4 stated into high- impedance |



### ● DPRAM Mode Selection (DR)

| DPRAM Mode Selection |                                   |
|----------------------|-----------------------------------|
| 0                    | DPRAM control signal not supplied |
| 1                    | Enters DPRAM mode                 |

### MEMORY WIDTH OFFSET REGISTER (R33)

| Data Bit |   |   |   |   |   |   |   | Program Unit         | R/W       |     |
|----------|---|---|---|---|---|---|---|----------------------|-----------|-----|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Nof (Offset Address) | Character | R/W |

This register specifies the offset value to be supplemented to the memory address, in units of characters, in order to define the start memory address of the next row. Adding the offset value to the memory address makes the memory width wider than the display width. Reprogramming the start memory address enables the display screen to be scrolled in any direction within a memory space by character. If this register is set to the offset value M, the start address of the next row will be the last displayed character address + M + 1.

This register is enabled when "MW (bit 3) = 1" is set into the control 3 register (R32). If an offset value is not required, the MW bit of R32 or this register (R33) is requested to be set as 0.



Figure 28 Memory Width Offset

### CURSOR 2 START REGISTER (R34)

| Data Bit                                               |   |   |   |   |   |   |   | Program Unit | R/W |
|--------------------------------------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                                                      | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Raster       | W   |
| $B_2$ P <sub>2</sub> Ncs <sub>2</sub> (Raster Address) |   |   |   |   |   |   |   |              |     |

This register determines the start raster address and selects the cursor blink mode for the cursor 2. The low-order five bits determines the start raster address. Bits  $B_2$  and P<sub>2</sub> select the cursor blink mode.

If the C<sub>2</sub> bit of the control 3 register is 0, or in the DPRAM mode, this register is invalid.

| B <sub>2</sub> | P <sub>2</sub> | Cursor Blink Mode      |
|----------------|----------------|------------------------|
| 0              | 0              | No blink               |
| 0              | 1              | No cursor              |
| 1              | 0              | Blink, 1/16 field rate |
| 1              | 1              | Blink, 1/32 field rate |

### Blink Rate



1/16 or 1/32 Field Rate

### CURSOR 2 END REGISTER (R35)

| Data Bit                                |   |   |   |   |   |   |   | Program Unit | R/W |
|-----------------------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                                       | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Raster       | W   |
| — — — Nce <sub>2</sub> (Raster Address) |   |   |   |   |   |   |   |              |     |

This register determines the end raster address for the cursor 2.

If the C<sub>2</sub> bit of the control 3 register is 0, or in the DPRAM mode, this register is invalid

### CURSOR 2 ADDRESS REGISTER (H, L) (R36, R37)

(R36)

| Data Bit                 |   |   |   |   |   |   |   | Program Unit       | R/W            |     |
|--------------------------|---|---|---|---|---|---|---|--------------------|----------------|-----|
| 7                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Memory Address (H) | Memory Address | R/W |
| — — — Memory Address (H) |   |   |   |   |   |   |   |                    |                |     |

(R37)

| Data Bit                 |   |   |   |   |   |   |   | Program Unit       | R/W            |     |
|--------------------------|---|---|---|---|---|---|---|--------------------|----------------|-----|
| 7                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Memory Address (L) | Memory Address | R/W |
| — — — Memory Address (L) |   |   |   |   |   |   |   |                    |                |     |

These registers determine the cursor 2 display memory address. The high-order two bits of R36 are always read as 0s.

This register is disabled in DPRAM mode or when "C<sub>2</sub> = 0" is set in the control 3 register (R32).

### CURSOR 1 WIDTH REGISTER (R38)

| Data Bit                                      |   |   |   |   |   |   |   | Program Unit                            | R/W       |     |
|-----------------------------------------------|---|---|---|---|---|---|---|-----------------------------------------|-----------|-----|
| 7                                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Ncw <sub>1</sub> (Number of Characters) | Character | R/W |
| — — — Ncw <sub>1</sub> (Number of Characters) |   |   |   |   |   |   |   |                                         |           |     |

This register specifies the cursor 1 width in units of characters. Writing 0 into this register disables the cursor 1 display.

This register is enabled when "CW<sub>1</sub> (bit 5) = 1" is set into the control 3 register (R32).

### CURSOR 2 WIDTH REGISTER (R39)

| Data Bit                                      |   |   |   |   |   |   |   | Program Unit                            | R/W       |     |
|-----------------------------------------------|---|---|---|---|---|---|---|-----------------------------------------|-----------|-----|
| 7                                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Ncw <sub>2</sub> (Number of Characters) | Character | R/W |
| — — — Ncw <sub>2</sub> (Number of Characters) |   |   |   |   |   |   |   |                                         |           |     |

This register specifies the cursor 2 width in units of characters. Writing 0 into this register disables the cursor 2 display.

This register is enabled when "CW<sub>2</sub> (bit 4) = 1" is set into the control 3 register (R32).

In DPRAM mode, this register specifies the ACI signal output timing, not affected by the CW<sub>2</sub> bit at all.



### ■ LIMITATION FOR PROGRAMMING

The register programmed value is limited as listed in Table 7.

Table 7 Limitation on Register Programmed Value

| Function             | Register Programmed Value Range                                                                                         | Associated Reg. |
|----------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------|
| Screen Format        | $1 < \text{Nhd} < \text{Nht} + 1 \leq 256$                                                                              | R1, R0          |
|                      | $0 < \text{Nvd} < \text{Nvt} + 1 \leq 256$                                                                              | R6, R4          |
|                      | $0 \leq \text{Nhsp} \leq \text{Nht}$                                                                                    | R2, R0          |
|                      | $0 \leq \text{Nvsp} \leq \text{Nvt}^*$                                                                                  | R7, R4          |
|                      | $2 \leq \text{Nr} \leq 30$ (Interlace sync and video mode)                                                              | R9              |
|                      | $\text{Nvad} < \text{Nr}$                                                                                               | R27, R9         |
|                      | $3 \leq \text{Nht}$ (Interlace sync mode and interlace sync and video mode)<br>$5 \leq \text{Nht}$ (Non-interlace mode) | R0              |
| Cursor Control       | $0 \leq \text{Ncs}_1 \leq \text{Nce}_1$                                                                                 | R10, R11        |
|                      | $\text{Nce}_1 \leq \text{Nr}$ (Non-interlace mode and interlace sync mode)                                              | R11, R9         |
|                      | $\text{Nce}_1 < \text{Nr}$ (Interlace sync and video mode)                                                              |                 |
|                      | $0 \leq \text{Ncs}_2 \leq \text{Nce}_2$                                                                                 | R34, R35        |
|                      | $\text{Nce}_2 \leq \text{Nr}$ (Non-interlace mode and interlace sync mode)                                              | R35, R9         |
|                      | $\text{Nce}_2 < \text{Nr}$ (Interlace sync and video mode)                                                              |                 |
|                      | $0 \leq \text{Ncw}_1 \leq 255$                                                                                          | R38             |
| Smooth Scrolling     | $0 \leq \text{Ncw}_2 \leq 255$                                                                                          | R39             |
|                      | $\text{Nss} \leq \text{Nr}$                                                                                             | R29, R9         |
| Memory Width Setting | $0 \leq \text{Nof} \leq 255$                                                                                            | R33             |

Notes 1) \* In the interlace sync mode, if the vertical sync signal assertion strides over the next field, the signal pulse width is alternately increased or decreased by 1/2 raster period in the following fields.

2) Refer to INTERNAL REGISTER ASSIGNMENT for symbols

### ■ RESET

The RES functions as a reset input signal only while the LPSTB is low. "Reset" is definable in two stages.

- (1) "During a reset state" indicates the period that the RES remains "low".
- (2) "After a reset state" indicates the state after the RES transition from low to high



Figure 29 Reset Definition

The note for a reset is listed in Table 8, and the pin status during a reset state is in Table 9.

Table 8 Note for a Reset

|                      | Note                                                                                                                                                                                                                                                      |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| During a Reset State | 1. HD6345/HD6445 sets "6845S mode**" Control registers R30, R31, and R32 cannot be programmed                                                                                                                                                             |
| After a Reset State  | 1. HD6345/HD6445 remains "6845S mode" until control registers R30, R31, R32 are programmed<br>2. In external sync mode, the additional circuit is required to prevent the contention between sync signals (VSYNC, HSYNC) of a master and those of a slave |

The RES assertion at power-on does not define the internal registers. The internal operation remains undefined until all the internal registers have been programmed.

Note) \* "6845S mode"

The 6845S mode causes the HD6345/HD6445 to implement the HD6845S functions. The HD6345/HD6445 is software-compatible with the HD6845S, and is provided with the extended functions of the HD6845S. Programming the control registers enables the extended functions. The control registers are initialized during a reset state. The HD6345 has 68-compatible bus interface. It is pin-compatible with NMOS CRTC-II HD6845S. HD6445 has 80-compatible bus interface. Note that HD6445 is not pin-compatible with NMOS CRTC HD6845S.

Table 9 Pin Status during a Reset State

| Pin No. | Symbol                            | Pin Name                 | Input/<br>Output | Functions                                                                                   |
|---------|-----------------------------------|--------------------------|------------------|---------------------------------------------------------------------------------------------|
| 1       | Vss                               | Vss                      | —                | —                                                                                           |
| 2       | <u>RES</u>                        | Reset                    | Input            | —                                                                                           |
| 3       | LPSTB                             | Light Pen Strobe         | Input            | Low Level signal requested to be supplied                                                   |
|         | TSC                               | Three State Control      | Input            |                                                                                             |
| 4-17    | MA <sub>0</sub> -MA <sub>13</sub> | Memory Address 0-13      | Output           | Goes low immediately after reset                                                            |
| 18      | DISPTMG                           | Display Timing           | Output           | Goes low immediately after reset                                                            |
| 19      | CUDISP                            | Cursor Display           | Output           | Goes low immediately after reset                                                            |
|         | ACI                               | Access Inhibit           | Output           |                                                                                             |
|         | IRQ                               | Interrupt Request        | Output           |                                                                                             |
| 20      | Vcc                               | Vcc                      | —                | —                                                                                           |
| 21      | CLK                               | Character Clock          | Input            | Not affected                                                                                |
| 22      | <u>WR</u>                         | Write                    | Input            | Not affected                                                                                |
| 23      | E                                 | Enable (HD6345)          | Input            | Not affected                                                                                |
|         | <u>RD</u>                         | Read (HD6445)            | Input            | Not affected                                                                                |
| 24      | RS                                | Register Select          | Input            | Not affected                                                                                |
| 25      | <u>CS</u>                         | Chip Select              | Input            | Not affected                                                                                |
| 26-33   | D <sub>0</sub> -D <sub>7</sub>    | Data Bus 0-7             | Input/<br>Output | Not affected                                                                                |
| 34-38   | RA <sub>0</sub> -RA <sub>4</sub>  | Raster Address 0-4       | Output           | Goes low immediately after reset                                                            |
| 39      | H SYNC                            | Horizontal Sync          | Output           | Corresponds to H SYNC until external sync mode is set into the control register after reset |
|         | EXH SYNC                          | External Horizontal Sync | Input            |                                                                                             |
| 40      | V SYNC                            | Vertical Sync            | Output           | Corresponds to V SYNC until esternal sync mode is set into the control register after reset |
|         | EXV SYNC                          | External Vertical Sync   | Input            |                                                                                             |



Table 10 Reset State of Internal Registers

| Reg No | Register Name                   | R/W | Data Bit (Reset State) |   |   |   |   |   |   |   |
|--------|---------------------------------|-----|------------------------|---|---|---|---|---|---|---|
|        |                                 |     | 7                      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| AR     | Address Register                | W   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R0     | Horizontal Total Characters     | W   |                        |   |   |   |   |   |   |   |
| R1     | Horizontal Displayed Characters | W   |                        |   |   |   |   |   |   |   |
| R2     | Horizontal Sync Position        | W   |                        |   |   |   |   |   |   |   |
| R3     | Sync Width                      | W   |                        |   |   |   |   |   |   |   |
| R4     | Vertical Total Rows             | W   |                        |   |   |   |   |   |   |   |
| R5     | Vertical Total Adjust           | W   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R6     | Vertical Displayed Rows         | W   |                        |   |   |   |   |   |   |   |
| R7     | Vertical Sync Position          | W   |                        |   |   |   |   |   |   |   |
| R8     | Interlace Mode and Skew         | W   |                        |   |   |   | 1 | 1 | 1 | 1 |
| R9     | Maximum Raster Address          | W   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R10    | Cursor 1 Start                  | W   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R11    | Cursor 1 End                    | W   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R12    | Screen 1 Start Address (H)      | R/W | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R13    | Screen 1 Start Address (L)      | R/W |                        |   |   |   |   |   |   |   |
| R14    | Cursor 1 Address (H)            | R/W | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R15    | Cursor 1 Address (L)            | R/W |                        |   |   |   |   |   |   |   |
| R16    | Light Pen (H)                   | R   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R17    | Light Pen (L)                   | R   |                        |   |   |   |   |   |   |   |
| R18    | Screen 2 Start Position         | R/W |                        |   |   |   |   |   |   |   |
| R19    | Screen 2 Start Address (H)      | R/W | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R20    | Screen 2 Start Address (L)      | R/W |                        |   |   |   |   |   |   |   |
| R21    | Screen 3 Start Position         | R/W |                        |   |   |   |   |   |   |   |
| R22    | Screen 3 Start Address (H)      | R/W | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R23    | Screen 3 Start Address (L)      | R/W |                        |   |   |   |   |   |   |   |
| R24    | Screen 4 Start Position         | R/W |                        |   |   |   |   |   |   |   |
| R25    | Screen 4 Start Address (H)      | R/W | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R26    | Screen 4 Start Address (L)      | R/W |                        |   |   |   |   |   |   |   |
| R27    | Vertical Sync Position Adjust   | W   |                        |   |   |   |   |   |   |   |
| R28    | Light Pen Raster                | R   |                        |   |   |   |   |   |   |   |
| R29    | Smooth Scrolling                | R/W |                        |   |   |   |   |   |   |   |
| R30    | Control 1                       | W   | 0                      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R31    | Control 2                       | W   | 0                      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|        | Status                          | R   | 0                      |   |   |   |   |   | * | 1 |
| R32    | Control 3                       | W   | 0                      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R33    | Memory Width Offset             | R/W |                        |   |   |   |   |   |   |   |
| R34    | Cursor 2 Start                  | W   | 1                      |   |   |   |   |   |   |   |
| R35    | Cursor 2 End                    | W   | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R36    | Cursor 2 Address (H)            | R/W | 1                      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| R37    | Cursor 2 Address (L)            | R/W |                        |   |   |   |   |   |   |   |
| R38    | Cursor 1 Width                  | R/W |                        |   |   |   |   |   |   |   |
| R39    | Cursor 2 Width                  | R/W |                        |   |   |   |   |   |   |   |

Note)  not affected  
(After power-on, the value is not fixed until it is programmed)

0 becomes "0"

1 becomes "1"

\* becomes "0" in the non-interlace mode  
becomes "1" in the interface sync mode and interlace sync and video mode  
(After power-on, its status is not fixed until the raster scanning mode is set)

not used

## ■ NOTES AND LIMITATIONS FOR HD6445

### NOTES

- (1) The CRTC-II HD6345/HD6445 is the CMOS LSI. It should be noted, peculiar to CMOS LSIs, that the input pins of the HD6345/HD6445 must not be left disconnected, etc.

(2) Refer to the RESET section for notes on a reset at power-on.

### LIMITATION FOR PROGRAMMING

Refer to "Table 7 Limitation on Register Programmed Value" for details.



**ANOMALOUS OPERATION BY REGISTER REPROGRAMMING DURING SCREEN DISPLAY**

The temporary erroneous operation may occur if programming the internal register during a screen display period. Generally, the device starts the newly specified operation on and after the following field after a renewal.

Whether or not the register reprogramming is allowed during a display is shown by the symbols ○ △ and × in the following table.

Register reprogramming is:  
 ○ : Allowable  
 △ : Allowable with some conditions  
           A temporary flicker may occur upon deviation of the conditions.  
 X : Not recommended  
           A temporary flicker may occur upon register renewal.

| Reg. No.   | Register Name                                            | Phenomenon and Renewal Recommended Period                                                                                                                                                                                                                                                                                                        |   |
|------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| R0         | Horizontal Total Characters                              | Horizontal scanning cycle is irregularized.                                                                                                                                                                                                                                                                                                      | × |
| R1         | Horizontal Displayed Characters                          | DISPTMG width may be set shorter than specified only during 1 raster period because of a momentary misrecognition of this register data.                                                                                                                                                                                                         | ○ |
| R2         | Horizontal Sync Position                                 | HSYNC will not be supplied as required, or a noise may occur. It may be supplied as programmed on and after the following field.                                                                                                                                                                                                                 | × |
| R3         | Sync Width                                               | Sync pulse width may be set shorter than specified when registers are reprogrammed during high of HSYNC and VSYNC                                                                                                                                                                                                                                | △ |
| R4         | Vertical Total Rows                                      | Vertical scanning cycle may be irregularized when reprogrammed during the last raster scanning period within a row.                                                                                                                                                                                                                              | △ |
| R5         | Vertical Total Adjust                                    | The specified number of adjust rasters will not be supplemented when reprogrammed within the last character clock time during adjust raster scanning period.                                                                                                                                                                                     | △ |
| R6         | Vertical Displayed Rows                                  | Raster scanning may be suspended (DISPTMG goes low.) immediately after being reprogrammed within a field. The programmed display is enabled on and after the following field.                                                                                                                                                                    | ○ |
| R7         | Vertical Sync Position                                   | VSYNC will not be supplied as required, or a noise may occur. It may be supplied as programmed on and after the following field.                                                                                                                                                                                                                 | × |
| R8         | Interlace Mode and Skew                                  | Reprogramming the scanning mode bit irregularizes vertical scanning cycle. Reprogramming the skew bit neglects the programmed position for screen and cursor displays.                                                                                                                                                                           | × |
| R9         | Maximum Raster Address                                   | Vertical scanning cycle is irregularized.                                                                                                                                                                                                                                                                                                        | × |
| R10<br>R11 | Cursor 1 Start<br>Cursor 1 End                           | Cursor raster scanning may be irregularized or blink period be temporarily set shorter when reprogrammed within the last character clock time during raster scanning period.                                                                                                                                                                     | △ |
| R12<br>R13 | Screen 1 Start Address (H)<br>Screen 1 Start Address (L) | Except during the last raster scanning period within a row, register reprogramming is allowable. Horizontal/vertical display period is especially recommended for reprogramming. If R12 and R13 are separately reprogrammed in the different fields, a screen display will temporarily start from the partially reprogrammed address.            | ○ |
| R14<br>R15 | Cursor 1 Address (H)<br>Cursor 1 Address (L)             | The cursor will not temporarily be displayed at the specified address when reprogrammed during display period. Horizontal/vertical retrace period is especially recommended for reprogramming. If R14 and R15 are separately reprogrammed in the different fields, a cursor will be temporarily displayed on the partially reprogrammed address. | ○ |
| R16<br>R17 | Light Pen (H)<br>Light Pen (L)                           | —                                                                                                                                                                                                                                                                                                                                                | — |
| R18        | Screen 2 Start Position                                  | Except during raster scanning period prior to the split-screen 2 start row, reprogramming is allowable. Horizontal/vertical retrace period is especially recommended for reprogramming.                                                                                                                                                          | ○ |
| R19<br>R20 | Screen 2 Start Address (H)<br>Screen 2 Start Address (L) | Except during raster scanning period prior to the split-screen 2 start row, reprogramming is allowable. Horizontal/vertical retrace period is especially recommended for reprogramming. If R19 and R20 are separately reprogrammed in the different fields, a screen display will temporarily start from the partially reprogrammed address      | ○ |
| R21        | Screen 3 Start Position                                  | Except during raster scanning period prior to the split-screen 3 start row, reprogramming is allowable. Horizontal/vertical retrace period is especially recommended for reprogramming.                                                                                                                                                          | ○ |



| Reg. No.   | Register Name                                                                            | Phenomenon and Renewal Recommended Period                                                                                                                                                                                                                                                                                                                                                                                                                       |                       |
|------------|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| R22<br>R23 | Screen 3 Start Address (H)<br>Screen 3 Start Address (L)                                 | Except during raster scanning period prior to the split-screen 3 start row, reprogramming is allowable. Horizontal/vertical retrace period is especially recommended for reprogramming. If R22 and R23 are separately reprogrammed in the different fields, a screen display will temporarily start from the partially reprogrammed address.                                                                                                                    | ○                     |
| R24        | Screen 4 Start Position                                                                  | Except during raster scanning period prior to the split-screen 4 start row, reprogramming is allowable. Horizontal/vertical retrace period is especially recommended for reprogramming.                                                                                                                                                                                                                                                                         | ○                     |
| R25<br>R26 | Screen 4 Start Address (H)<br>Screen 4 Start Address (L)                                 | Except during raster scanning period prior to the split-screen 4 start row, reprogramming is allowable. Horizontal/vertical retrace period is especially recommended for reprogramming. If R25 and R26 are separately reprogrammed in the different fields, a screen display will temporarily start from the partially reprogrammed address.                                                                                                                    | ○                     |
| R27        | Vertical Sync Position Adust                                                             | The programmed position for VSYNC output will not be satisfied.                                                                                                                                                                                                                                                                                                                                                                                                 | ✗                     |
| R28        | Light Pen Raster                                                                         | —                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                     |
| R29        | Smooth Scrolling                                                                         | For a screen not performing smooth scroll, reprogramming is allowable except during the last raster scanning period within each row. For a screen performing smooth scroll, reprogramming is allowable except during raster scanning period on the address of "programmed value-1". Horizontal/vertical retrace period is especially recommended for reprogramming.                                                                                             | △                     |
| R30        | Control 1<br>·VE<br>·TV<br>·VS, IB, IL<br>·SY<br>·SP <sub>0</sub> , SP <sub>1</sub>      | Reprogramming is allowable except at VSYNC output.<br>Reprogramming is allowable except at HSYNC output when DISPTMG is low.<br>Reprogramming is allowable.<br>VSYNC will not be supplied as required or a noise may occur. It may be supplied as programmed on and after the following field.<br>Temporary disturbance may occur on a screen when reprogrammed during the display period. Vertical retrace period is especially recommended for reprogramming. | ○<br>○<br>○<br>○<br>△ |
| R31        | Control 2<br>·SS <sub>1</sub> , - SS <sub>4</sub><br>·RI                                 | Temporary disturbance may occur on a screen when reprogramming during display period. Vertical retrace period is especially recommended for reprogramming<br>Vertical raster scanning cycle is irregularized.                                                                                                                                                                                                                                                   | △<br>✗                |
|            | Status                                                                                   | —                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                     |
| R32        | Control 3<br>·CM, C <sub>2</sub><br>·CW <sub>1</sub> , CW <sub>2</sub><br>·MW<br>·TC, DR | Temporary disturbance may occur on a cursor when reprogrammed during display period. Vertical retrace period is especially recommended for reprogramming.<br>Temporary disturbance may occur on a screen when reprogrammed during display period. Vertical retrace period is especially recommended for reprogramming.<br>Reprogramming is inhibited.                                                                                                           | △<br>△<br>✗           |
| R33        | Memory Width Offset                                                                      | The specified address for cursor display will not temporarily be satisfied upon reprogramming during display period. Horizontal/vertical retrace period is especially recommended for reprogramming.                                                                                                                                                                                                                                                            | ○                     |
| R34<br>R35 | Cursor 2 Start<br>Cursor 2 End                                                           | Cursor raster scanning may be irregularized or blink period be temporarily set shorter when reprogrammed within the last character clock time during raster scanning period.                                                                                                                                                                                                                                                                                    | △                     |
| R36<br>R37 | Cursor 2 Address (H)<br>Cursor 2 Address (L)                                             | The specified address for cursor display will not temporarily be satisfied when reprogrammed during the display period. Horizontal/vertical retrace period is especially recommended for reprogramming. If R36 and R37 are separately reprogrammed in the different fields, a cursor will be temporarily displayed at the partially reprogrammed address.                                                                                                       | ○                     |
| R38<br>R39 | Cursor 1 Width<br>Cursor 2 Width                                                         | The specified cursor width will not temporarily be satisfied when reprogrammed during display period. Horizontal/vertical retrace period is especially recommended for reprogramming.                                                                                                                                                                                                                                                                           | △                     |



### ■ ABSOLUTE MAXIMUM RATINGS

| Item                           | Symbol                | Rating                      | Unit |
|--------------------------------|-----------------------|-----------------------------|------|
| Supply Voltage                 | V <sub>CC</sub> *     | -0.3 ~ +7.0                 | V    |
| Input Voltage                  | V <sub>in</sub> *     | -0.3 ~ V <sub>CC</sub> +0.3 | V    |
| Operating Temperature          | T <sub>opr</sub>      | -20 ~ +75                   | °C   |
| Storage Temperature            | T <sub>stg</sub>      | -55 ~ +150                  | °C   |
| Allowable Output Current       | Data Bus<br>Others    | I <sub>o</sub>  **          | mA   |
|                                |                       | 5<br>3                      | mA   |
| Total Allowable Output Current | Σ I <sub>o</sub>  *** | 60                          | mA   |

\* This value is in reference to V<sub>SS</sub> = 0V

\*\* The allowable output current is the maximum current that may be drawn from, or flow out to, one output pin or one input/output common pin.

\*\*\* The total allowable output current is the total sum of currents that may be drawn from, or flow out to, output pins or input/output common pins  
 Note) Using an LSI beyond its maximum ratings may result in its permanent destruction. LSI's should usually be under recommended operating conditions. Exceeding any of these conditions may adversely affect its reliability.

### ■ RECOMMENDED OPERATING CONDITIONS

| Item                     | Symbol            | Min  | Typ | Max             | Unit |
|--------------------------|-------------------|------|-----|-----------------|------|
| Supply Voltage           | V <sub>CC</sub> * | 4.75 | 5.0 | 5.25            | V    |
| Input Low Level Voltage  | V <sub>IL</sub> * | -0.3 | —   | 0.8             | V    |
| Input High Level Voltage | V <sub>IH</sub> * | 2.0  | —   | V <sub>CC</sub> | V    |
| Operating Temperature    | T <sub>opr</sub>  | -20  | 25  | 75              | °C   |

\* This value is in reference to V<sub>SS</sub> = 0V

### ■ ELECTRICAL CHARACTERISTICS

DC CHARACTERISTICS (V<sub>CC</sub> = 5.0V±5%, V<sub>SS</sub> = 0V, Ta = -20 ~ +75°C unless otherwise noted)

| Item                                     | Symbol                                    | Measuring Condition                                                                                                                                            | Min                        | Typ* | Max             | Unit |
|------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|------|-----------------|------|
| Input High Level Voltage                 | V <sub>IH</sub>                           |                                                                                                                                                                | 2.0                        | —    | V <sub>CC</sub> | V    |
| Input Low Level Voltage                  | V <sub>IL</sub>                           |                                                                                                                                                                | -0.3                       | —    | 0.8             | V    |
| Input Leak Current                       | I <sub>in</sub>                           | V <sub>in</sub> = 0 ~ 5.25 V                                                                                                                                   | -2.5                       | —    | 2.5             | μA   |
| Three State (Off State)<br>Input Current | I <sub>TSI</sub>                          | V <sub>in</sub> = 0.4 ~ 2.4 V<br>V <sub>CC</sub> = 5.25 V                                                                                                      | -10                        | —    | 10              | μA   |
| Output High Level<br>Voltage             | D <sub>0</sub> ~ D <sub>7</sub><br>Others | V <sub>OH</sub>                                                                                                                                                | I = -205 μA<br>I = -100 μA | 2.4  | —               | V    |
| Output Low Level Voltage                 | V <sub>OL</sub>                           | I = 1.6 mA                                                                                                                                                     | —                          | —    | 0.4             | V    |
| Input Capacity                           | C <sub>in</sub>                           | V <sub>in</sub> = 0 V<br>Ta = 25°C<br>f = 1.0 MHz                                                                                                              | —                          | —    | 12.5            | pF   |
| Others                                   |                                           |                                                                                                                                                                | —                          | —    | 10              | pF   |
| Output Capacity                          | C <sub>out</sub>                          | V <sub>in</sub> = 0 V<br>Ta = 25°C<br>f = 1 MHz                                                                                                                | —                          | —    | 10              | pF   |
| Power Dissipation                        | P <sub>D</sub>                            | f <sub>CLK</sub> = 4.5 MHz<br>f <sub>E</sub> = 2 MHz<br>V <sub>CC</sub> = max, No Load<br>V <sub>IH</sub> = V <sub>CC</sub> - 1.0 V<br>V <sub>IL</sub> = 0.8 V | —                          | 50   | —               | mW   |

\* Ta = 25°C, Vcc = 5.0V



**AC CHARACTERISTICS (V<sub>CC</sub> = 5V±10%, V<sub>SS</sub> = 0V, Ta = -20 ~ +75°C, unless otherwise noted.)****1. TIMING OF CRTC SIGNAL**

| Item                                          | Symbol                                 | Test Condition | Min | Max | Unit |
|-----------------------------------------------|----------------------------------------|----------------|-----|-----|------|
| Clock Cycle Time                              | t <sub>cycC</sub>                      | Fig. 30        | 220 | —   | ns   |
| Clock High Pulse Width                        | PW <sub>CH</sub>                       |                | 100 | —   | ns   |
| Clock Low Pulse Width                         | PW <sub>CL</sub>                       |                | 100 | —   | ns   |
| Rise and Fall Time for Clock Input            | t <sub>cr</sub> , t <sub>cf</sub>      |                | —   | 20  | ns   |
| Memory Address Delay Time                     | t <sub>MAD</sub>                       |                | —   | 80  | ns   |
| Raster Address Delay Time                     | t <sub>RAD</sub>                       |                | —   | 80  | ns   |
| DISPTMG Delay Time                            | t <sub>DTD</sub>                       |                | —   | 120 | ns   |
| CUDISP Delay Time                             | t <sub>CDD</sub>                       |                | —   | 120 | ns   |
| Horizontal Sync Delay Time                    | t <sub>HSD</sub>                       |                | —   | 100 | ns   |
| Vertical Sync Delay Time                      | t <sub>VSD</sub>                       |                | —   | 120 | ns   |
| Light Pen Strobe Pulse Width                  | PW <sub>LPH</sub>                      |                | 60  | —   | ns   |
| Light Pen Strobe Uncertain Time of Acceptance | t <sub>LPD1</sub><br>t <sub>LPD2</sub> |                | —   | 70  | ns   |
| Memory Address Three-State Off Time           | t <sub>MAZ</sub>                       | Fig. 31        | —   | 50  | ns   |
| Raster Address Three-State Off Time           | t <sub>RAZ</sub>                       |                | —   | 50  | ns   |

**2. EXTERNAL SYNC TIMING**

| Item                                        | Symbol                             | Test Condition | Min  | Max | Unit |
|---------------------------------------------|------------------------------------|----------------|------|-----|------|
| Clock Halt Time                             | t <sub>CLKST</sub>                 | Fig. 34        | 100  | —   | ns   |
| External Horizontal Sync Pulse Width        | t <sub>PWHS</sub>                  |                | 1000 | —   | ns   |
| External Horizontal Sync Rise and Fall Time | t <sub>HR</sub><br>t <sub>HF</sub> |                | —    | 20  | ns   |
| External Vertical Sync Pulse Width*         | t <sub>PWVS</sub>                  |                | —    | 20  | ns   |
| External Vertical Sync Rise and Fall Time   | t <sub>VR</sub><br>t <sub>VF</sub> |                | 1660 | —   | ns   |
|                                             |                                    |                | —    | 20  | ns   |

\*: External Vertical Sync Pulse Width t<sub>PWVS</sub> = 1000 ns + 3·t<sub>cyc C</sub>**3. HD6345 MPU BUS TIMING**

| Item                                                      | Symbol                            | Test Condition     | 6345 |     | 63A45 |     | 63B45 |     | Unit |
|-----------------------------------------------------------|-----------------------------------|--------------------|------|-----|-------|-----|-------|-----|------|
|                                                           |                                   |                    | Min  | Max | Min   | Max | Min   | Max |      |
| Enable Cycle Time                                         | t <sub>cycE</sub>                 | Fig. 35<br>Fig. 36 | 1000 | —   | 666   | —   | 500   | —   | ns   |
| Enable "High" Pulse Width                                 | PW <sub>EH</sub>                  |                    | 450  | —   | 280   | —   | 220   | —   | ns   |
| Enable "Low" Pulse Width                                  | PW <sub>EL</sub>                  |                    | 400  | —   | 280   | —   | 210   | —   | ns   |
| Enable Rise and Fall Time                                 | t <sub>Er</sub> , t <sub>Ef</sub> |                    | —    | 20  | —     | 20  | —     | 20  | ns   |
| Address Set Up Time                                       | t <sub>AS</sub>                   |                    | 80   | —   | 80    | —   | 40    | —   | ns   |
| Data Set Up Time                                          | t <sub>DSW</sub>                  |                    | 195  | —   | 80    | —   | 60    | —   | ns   |
| Data Delay Time                                           | t <sub>DDR</sub>                  |                    | —    | 200 | —     | 140 | —     | 120 | ns   |
| Data Hold Time                                            | t <sub>H</sub>                    |                    | 10   | —   | 10    | —   | 10    | —   | ns   |
| Address Hold Time                                         | t <sub>AH</sub>                   |                    | 10   | —   | —     | —   | 10    | —   | ns   |
| Data Access Time                                          | t <sub>ACC</sub>                  |                    | —    | 280 | —     | 220 | —     | 160 | ns   |
| Input Signal Rise and Fall Time (RES, LPSTB, RS, CS, R/W) | tr, tf                            |                    | —    | 100 | —     | 100 | —     | 100 | ns   |



## 4. HD6445 MPU BUS TIMING

| Item                                                                | Symbol         | Test Condition | HD6445-4 |     |      |
|---------------------------------------------------------------------|----------------|----------------|----------|-----|------|
|                                                                     |                |                | Min      | Max | Unit |
| Read Address Set Up Time                                            | $t_{AR}$       |                | 0        | —   | ns   |
| Read Low Level Time                                                 | $t_{RR}$       |                | 160      | —   | ns   |
| Read Address Hold Time                                              | $t_{RA}$       |                | 0        | —   | ns   |
| Write Address Set Up Time                                           | $t_{AW}$       |                | 0        | —   | ns   |
| Write Low Level Time                                                | $t_{WW}$       |                | 190      | —   | ns   |
| Write Address Hold Time                                             | $t_{WA}$       |                | 0        | —   | ns   |
| Data Delay Time                                                     | $t_{RD}$       |                | —        | 120 | ns   |
| Data Hold Time (Read)                                               | $t_{DF}$       |                | 10       | —   | ns   |
| Data Set Up Time                                                    | $t_{DW}$       |                | 60       | —   | ns   |
| Data Hold Time (Write)                                              | $t_{WD}$       |                | 0        | —   | ns   |
| Access Inhibit Time                                                 | $t_{DIS}$      |                | 210      | —   | ns   |
| Input Signal Rise Time<br>Fall Time<br>(RES, LPSTB, RS, CS, RD, WR) | $t_r$<br>$t_f$ |                | —        | 100 | ns   |

Fig. 37  
Fig. 38

Figure 30 CRTC Timing Chart





Figure 31 Three-State Delay Timing (Three-state mode: TC = 1)



Figure 32 CRTC-CLK, MA0-MA13, and LPSTB Timing



Figure 33 CRTC-CLK, RA<sub>0</sub> - RA<sub>4</sub> and LPSTB Timing

Figure 34 External Sync Timing





Figure 35 HD6345 Read Sequence



Figure 36 HD6345 Write Sequence



Figure 37 HD6445 Read Sequence





Figure 38 HD6445 Write Sequence

**TEST LOAD**

Figure 39 Test Load



**■ COMPARISON BETWEEN HD6345/HD6445 AND HD6845S**

| HD6345/HD6445                                                                                                                                                                                                                                                                                                                                                                                       | HD6845S                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLK: 4.5 MHz CMOS<br>68 System Bus Interface (HD6345)<br>80 System Bus Interface (HD6445)<br>1. Refresh Memory Address (16k words)<br>2. Paging, Scrolling<br>3. Light Pen<br>4. TTL Compatible<br>5. Software Programmable:<br>Number of Displayed Characters on Screen<br>Number of Rasters per Character Row<br>Horizontal/Vertical Sync Signal<br>Raster Scanning Mode<br>Cursor                | CLK: 3.7 MHz NMOS<br>6800 System Bus Interface<br>1. Refresh Memory Address (16k words)<br>2. Paging, Scrolling<br>3. Light Pen<br>4. TTL Compatible<br>5. Software Programmable:<br>Number of Displayed Characters on Screen<br>Number of Rasters per Character Row<br>Horizontal/Vertical Sync Signal<br>Raster Scanning Mode<br>Cursor |
| 6. Screen Split (Up to 4)<br>7. Smooth Scrolling<br>8. External Synchronization<br>9. Interrupt Request<br>10. Raster Interpolation<br>11. Sync Position Adjustment<br>12. Light Pen Raster Address<br>13. Second Cursor<br>14. Display Memory Width Setting<br>15. Up to 256 Character Rows<br>16. Timing Signal for Dual Port RAM<br>17. Three-State Control of Memory Address and Raster Address |                                                                                                                                                                                                                                                                                                                                           |



## ■ CHARACTERISTICS DIFFERENCES BETWEEN HD6345 AND HD6845S

| No. | Item                            | Symbol              | HD6345 |     |     | HD6845S |     |      | Unit |
|-----|---------------------------------|---------------------|--------|-----|-----|---------|-----|------|------|
|     |                                 |                     | Min    | Typ | Max | Min     | Typ | Max  |      |
| 1   | Power Dissipation               | P <sub>D</sub>      | —      | 50  | —   | —       | 600 | 1000 | mW   |
| 2   | Clock Cycle Time                | t <sub>CYCC</sub>   | 220    | —   | —   | 270     | —   | —    | ns   |
| 3   | Clock "High" Pulse Width        | P <sub>WCH</sub>    | 100    | —   | —   | 130     | —   | —    | ns   |
| 4   | Clock "Low" Pulse Width         | P <sub>WCL</sub>    | 100    | —   | —   | 130     | —   | —    | ns   |
| 5   | Memory Address Delay Time       | t <sub>MAD</sub>    | —      | —   | 80  | —       | —   | 160  | ns   |
| 6   | Raster Address Delay Time       | t <sub>RAD</sub>    | —      | —   | 80  | —       | —   | 160  | ns   |
| 7   | Display Timing Delay Time       | t <sub>DTD</sub>    | —      | —   | 120 | —       | —   | 250  | ns   |
| 8   | Horizontal Sync Delay Time      | t <sub>HSD</sub>    | —      | —   | 100 | —       | —   | 200  | ns   |
| 9   | Vertical Sync Delay Time        | t <sub>VSD</sub>    | —      | —   | 120 | —       | —   | 250  | ns   |
| 10  | Cursor Display Delay Time       | t <sub>CDD</sub>    | —      | —   | 120 | —       | —   | 250  | ns   |
| 11  | Enable Cycle Time               | t <sub>CYCE</sub>   | 500    | —   | —   | 1000    | —   | —    | ns   |
| 12  | Enable "High" Pulse Width       | P <sub>WEH</sub>    | 220    | —   | —   | 450     | —   | —    | ns   |
| 13  | Enable "Low" Pulse Width        | P <sub>WEL</sub>    | 210    | —   | —   | 400     | —   | —    | ns   |
| 14  | Enable Rise and Fall Time       | t <sub>ER, EF</sub> | —      | —   | 20  | —       | —   | —    | ns   |
| 15  | Address Set Up Time             | t <sub>AS</sub>     | 40     | —   | —   | 140     | —   | —    | ns   |
| 16  | Data Set Up Time                | t <sub>DSW</sub>    | 60     | —   | —   | 195     | —   | —    | ns   |
| 17  | Data Delay Time                 | t <sub>DDR</sub>    | —      | —   | 120 | —       | —   | 320  | ns   |
| 18  | Data Access Time                | t <sub>ACC</sub>    | —      | —   | 160 | —       | —   | 460  | ns   |
| 19  | Input Signal Rise and Fall Time | t <sub>r, tf</sub>  | —      | —   | 100 | —       | —   | —    | ns   |

## ■ CHARACTERISTICS DIFFERENCES BETWEEN HD6445 AND HD6845S

| No. | Item                       | Symbol            | HD6445 |     |     | HD6845S |     |      | Unit |
|-----|----------------------------|-------------------|--------|-----|-----|---------|-----|------|------|
|     |                            |                   | Min    | Typ | Max | Min     | Typ | Max  |      |
| 1   | Power Dissipation          | P <sub>D</sub>    | —      | 50  | —   | —       | 600 | 1000 | mW   |
| 2   | Clock Cycle Time           | t <sub>CYCC</sub> | 220    | —   | —   | 270     | —   | —    | ns   |
| 3   | Clock High Pulse Width     | P <sub>WCH</sub>  | 100    | —   | —   | 130     | —   | —    | ns   |
| 4   | Clock Low Pulse Width      | P <sub>WCL</sub>  | 100    | —   | —   | 130     | —   | —    | ns   |
| 5   | Memory Address Delay Time  | t <sub>MAD</sub>  | —      | —   | 80  | —       | —   | 160  | ns   |
| 6   | Raster Address Delay Time  | t <sub>RAD</sub>  | —      | —   | 80  | —       | —   | 160  | ns   |
| 7   | Display Timing Delay Time  | t <sub>DTD</sub>  | —      | —   | 120 | —       | —   | 250  | ns   |
| 8   | Horizontal Sync Delay Time | t <sub>HSD</sub>  | —      | —   | 100 | —       | —   | 200  | ns   |
| 9   | Vertical Sync Delay Time   | t <sub>VSD</sub>  | —      | —   | 120 | —       | —   | 250  | ns   |
| 10  | Cursor Display Delay Time  | t <sub>CDD</sub>  | —      | —   | 120 | —       | —   | 250  | ns   |



## ■ PACKAGE DIMENSIONS [Unit: mm (inch)]

Scale 1/1



(DP-40)

Note) Inch value indicated for your reference.



# HD6845R/HD6845S CRT Controller (CRTC)

The CRTC is a LSI controller which is designed to provide an interface for microcomputers to raster scan type CRT displays. The CRTC belongs to the HD6800 LSI Family and has full compatibility with MPU in both data lines and control lines. Its primary function is to generate timing signal which is necessary for raster scan type CRT display according to the specification programmed by MPU. The CRTC is also designed as a programmable controller, so applicable to wide-range CRT display from small low-functioning character display up to raster type full graphic display as well as large high-functioning limited graphic display.

## ■ FEATURES

- Number of Displayed Characters on the Screen, Vertical Dot Format of One Character, Horizontal and Vertical Sync Signal, Display Timing Signal are Programmable
- 3.7 MHz High Speed Display Operation
- Line Buffer-less Refreshing
- 14-bit Refresh Memory Address Output (16k Words max. Access)
- Programmable Interlace/Non-interlace Scan Mode
- Built-in Cursor Control Function
- Programmable Cursor Height and its Blink
- Built-in Light Pen Detection Function
- Paging and Scrolling Capability
- TTL Compatible
- Single +5V Power Supply

## ■ SYSTEM BLOCK DIAGRAM



HD6845SP, HD68A45SP, HD68B45SP  
HD6845RP, HD68A45RP, HD68B45RP



(DP-40)

## ■ PIN ARRANGEMENT



(Top View)

## ■ ORDERING INFORMATION

| CRTC     | Bus Timing | CRT Display Timing |
|----------|------------|--------------------|
| HD6845S  | 1.0 MHz    |                    |
| HD68A45S | 1.5 MHz    |                    |
| HD68B45S | 2.0 MHz    | 3.7 MHz max.       |
| HD6845R  | 1.0 MHz    |                    |
| HD68A45R | 1.5 MHz    |                    |
| HD68B45R | 2.0 MHz    | 3.7 MHz max.       |



**■ ABSOLUTE MAXIMUM RATINGS**

| Item                  | Symbol     | Value       | Unit |
|-----------------------|------------|-------------|------|
| Supply Voltage        | $V_{CC}$ * | -0.3 ~ +7.0 | V    |
| Input Voltage         | $V_{in}$ * | -0.3 ~ +7.0 | V    |
| Operating Temperature | $T_{opr}$  | -20 ~ +75   | °C   |
| Storage Temperature   | $T_{stg}$  | -55 ~ +150  | °C   |

\* With respect to  $V_{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        | $V_{CC}$ * | 4.75 | 5.0 | 5.25     | V    |
| Input Voltage         | $V_{IL}$ * | -0.3 | —   | 0.8      | V    |
|                       | $V_{IH}$ * | 2.0  | —   | $V_{CC}$ | V    |
| Operating Temperature | $T_{opr}$  | -20  | 25  | 75       | °C   |

\* With respect to  $V_{SS}$  (SYSTEM GND)**■ ELECTRICAL CHARACTERISTICS****• DC CHARACTERISTICS ( $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20\sim+75^{\circ}\text{C}$ , unless otherwise noted.)**

| Item                                  | Symbol    | Test Condition                                                                                                   | min  | typ* | max      | Unit |
|---------------------------------------|-----------|------------------------------------------------------------------------------------------------------------------|------|------|----------|------|
| Input "High" Voltage                  | $V_{IH}$  |                                                                                                                  | 2.0  | —    | $V_{CC}$ | V    |
| Input "Low" Voltage                   | $V_{IL}$  |                                                                                                                  | -0.3 | —    | 0.8      | V    |
| Input Leakage Current                 | $I_{in}$  | $V_{in} = 0 \sim 5.25V$ (Except D <sub>0</sub> ~D <sub>7</sub> )                                                 | -2.5 | —    | 2.5      | μA   |
| Three-State Input Current (off-state) | $I_{TSI}$ | $V_{in} = 0.4 \sim 2.4V$<br>$V_{CC} = 5.25V$ (D <sub>0</sub> ~D <sub>7</sub> )                                   | -10  | —    | 10       | μA   |
| Output "High" Voltage                 | $V_{OH}$  | $I_{LOAD} = -205 \mu\text{A}$ (D <sub>0</sub> ~D <sub>7</sub> )<br>$I_{LOAD} = -100 \mu\text{A}$ (Other Outputs) | 2.4  | —    | —        | V    |
| Output "Low" Voltage                  | $V_{OL}$  | $I_{LOAD} = 1.6 \text{ mA}$                                                                                      | —    | —    | 0.4      | V    |
| Input Capacitance                     | $C_{in}$  | $V_{in} = 0$                                                                                                     | —    | —    | 12.5     | pF   |
|                                       |           | $T_a = 25^{\circ}\text{C}$<br>$f = 1.0 \text{ MHz}$                                                              | —    | —    | 10.0     | pF   |
| Output Capacitance                    | $C_{out}$ | $V_{in} = 0V$ , $T_a = 25^{\circ}\text{C}$ , $f = 1.0 \text{ MHz}$                                               | —    | —    | 10.0     | pF   |
| Power Dissipation                     | $P_D$     |                                                                                                                  | —    | 600  | 1000     | mW   |

\*  $T_a = 25^{\circ}\text{C}$ ,  $V_{CC} = 5.0V$ 

**• AC Characteristics**(V<sub>CC</sub> = 5V ± 5%, T<sub>A</sub> = -20 ~ +75°C, unless otherwise noted.)**1. TIMING OF CRTC SIGNAL**

| No. | Item                                             | Symbol                                 | Test Condition | HD6845R |     |     | HD6845S |     |     | Unit |
|-----|--------------------------------------------------|----------------------------------------|----------------|---------|-----|-----|---------|-----|-----|------|
|     |                                                  |                                        |                | min     | typ | max | min     | typ | max |      |
| 1   | Clock Cycle Time                                 | t <sub>cycC</sub>                      | Fig. 1         | 330     | —   | —   | 270     | —   | —   | ns   |
| 2   | Clock "High" Pulse Width                         | PW <sub>CH</sub>                       |                | 150     | —   | —   | 130     | —   | —   | ns   |
| 3   | Clock "Low" Pulse Width                          | PW <sub>CL</sub>                       |                | 150     | —   | —   | 130     | —   | —   | ns   |
| 4   | Rise and Fall Time for Clock Input               | T <sub>Cr</sub> T <sub>Cl</sub>        |                | —       | —   | 15  | —       | —   | 20  | ns   |
| 5   | Horizontal Sync Delay Time                       | t <sub>HSD</sub>                       |                | —       | —   | 250 | —       | —   | 200 | ns   |
| 6   | Light Pen Strobe Pulse Width                     | PW <sub>LPH</sub>                      |                | 80      | —   | —   | 60      | —   | —   | ns   |
| 7   | Light Pen Strobe<br>Uncertain Time of Acceptance | t <sub>LPD1</sub><br>t <sub>LPD2</sub> | Fig. 2         | —       | —   | 80  | —       | —   | 70  | ns   |
| 8   | Memory Address Delay Time                        | t <sub>MAD</sub>                       |                | —       | —   | 10  | —       | —   | 0   | ns   |
| 9   | Raster Address Delay Time                        | t <sub>RAD</sub>                       |                | —       | —   | 160 | —       | —   | 160 | ns   |
| 10  | DISPTMG Delay Time                               | t <sub>DTD</sub>                       |                | —       | —   | 160 | —       | —   | 160 | ns   |
| 11  | CUDISP Delay Time                                | t <sub>CDD</sub>                       | Fig. 1         | —       | —   | 250 | —       | —   | 250 | ns   |
| 12  | Vertical Sync Delay Time                         | t <sub>VSD</sub>                       |                | —       | —   | 250 | —       | —   | 250 | ns   |

**2. MPU READ TIMING**

| Item                      | Symbol                            | Test Condition | HD6845R<br>HD6845S |     |     | HD68A45R<br>HD68A45S |     |     | HD68B45R<br>HD68B45S |     |     | Unit |
|---------------------------|-----------------------------------|----------------|--------------------|-----|-----|----------------------|-----|-----|----------------------|-----|-----|------|
|                           |                                   |                | min                | typ | max | min                  | typ | max | min                  | typ | max |      |
| Enable Cycle Time         | t <sub>cycE</sub>                 | Fig. 3         | 1.0                | —   | —   | 0.666                | —   | —   | 0.5                  | —   | —   | μs   |
| Enable "High" Pulse Width | PW <sub>EH</sub>                  |                | 0.45               | —   | —   | 0.28                 | —   | —   | 0.22                 | —   | —   | μs   |
| Enable "Low" Pulse Width  | PW <sub>EL</sub>                  |                | 0.40               | —   | —   | 0.28                 | —   | —   | 0.21                 | —   | —   | μs   |
| Enable Rise and Fall Time | t <sub>Er</sub> , t <sub>Ef</sub> |                | —                  | —   | 25  | —                    | —   | 25  | —                    | —   | 25  | ns   |
| Address Set Up Time       | t <sub>AS</sub>                   |                | 140                | —   | —   | 140                  | —   | —   | 70                   | —   | —   | ns   |
| Data Delay Time           | t <sub>DDR</sub>                  |                | —                  | —   | 320 | —                    | —   | 220 | —                    | —   | 180 | ns   |
| Data Hold Time            | t <sub>H</sub>                    |                | 10                 | —   | —   | 10                   | —   | —   | 10                   | —   | —   | ns   |
| Address Hold Time         | t <sub>AH</sub>                   |                | 10                 | —   | —   | 10                   | —   | —   | 10                   | —   | —   | ns   |
| Data Access Time          | t <sub>ACC</sub>                  |                | —                  | —   | 460 | —                    | —   | 360 | —                    | —   | 250 | ns   |

**3. MPU WRITE TIMING**

| Item                      | Symbol                            | Test Condition | HD6845R<br>HD6845S |     |     | HD68A45R<br>HD68A45S |     |     | HD68B45R<br>HD68B45S |     |     | Unit |
|---------------------------|-----------------------------------|----------------|--------------------|-----|-----|----------------------|-----|-----|----------------------|-----|-----|------|
|                           |                                   |                | min                | typ | max | min                  | typ | max | min                  | typ | max |      |
| Enable Cycle Time         | t <sub>cycE</sub>                 | Fig. 4         | 1.0                | —   | —   | 0.666                | —   | —   | 0.5                  | —   | —   | μs   |
| Enable "High" Pulse Width | PW <sub>EH</sub>                  |                | 0.45               | —   | —   | 0.28                 | —   | —   | 0.22                 | —   | —   | μs   |
| Enable "Low" Pulse Width  | PW <sub>EL</sub>                  |                | 0.40               | —   | —   | 0.28                 | —   | —   | 0.21                 | —   | —   | μs   |
| Enable Rise and Fall Time | t <sub>Er</sub> , t <sub>Ef</sub> |                | —                  | —   | 25  | —                    | —   | 25  | —                    | —   | 25  | ns   |
| Address Set Up Time       | t <sub>AS</sub>                   |                | 140                | —   | —   | 140                  | —   | —   | 70                   | —   | —   | ns   |
| Data Set Up Time          | t <sub>DSW</sub>                  |                | 195                | —   | —   | 80                   | —   | —   | 60                   | —   | —   | ns   |
| Data Hold Time            | t <sub>H</sub>                    |                | 10                 | —   | —   | 10                   | —   | —   | 10                   | —   | —   | ns   |
| Address Hold Time         | t <sub>AH</sub>                   |                | 10                 | —   | —   | 10                   | —   | —   | 10                   | —   | —   | ns   |





This Figure shows the relation in time between CLK signal and each output signals. Output sequence is shown in Figs. 10~15.

Figure 1 Time Chart of the CRTC





Figure 2 LPSTB Input Timing &amp; Refresh Memory Address that is set into the light pen registers.



Figure 3 Read Sequence





Figure 4 Write Sequence



Figure 5 Test Loads

#### ■ SYSTEM DESCRIPTION

The CRTC is a LSI which is connected with MPU and CRT display device to control CRT display. The CRTC consists of internal register group, horizontal and vertical timing circuits, linear address generator, cursor control circuit, and light pen detection circuit. Horizontal and vertical timing circuit generate  $RA_0 \sim RA_4$ , DISP TMG, HSYNC, and VSYNC.  $RA_0 \sim RA_4$  are raster address signals and used as input signals for Character Generator. DISP TMG, HSYNC, and VSYNC signals are received by video control circuit. This horizontal and vertical timing circuit consists of internal counter and comparator circuit.

Linear address generator generates refresh memory address  $MA_0 \sim MA_{13}$  to be used for refreshing the screen. By these address signals, refresh memory is accessed periodically. As 14 refresh memory address signals are prepared, 16k words max are accessible. Moreover, the use of start address register enables paging and scrolling. Light pen detection circuit detects light pen position on the screen. When light pen strobe signal is received, light pen register memorizes linear address generated by linear address generator in order to memorize where light pen is on the screen. Cursor control circuit controls the position of cursor, its height, and its blink.





Figure 6 Internal Block Diagram of the CRTC



## ■ FUNCTION OF SIGNAL LINE

The CRTC provides 13 interface signals to MPU and 25 interface signals to CRT display.

### ● Interface Signals to MPU

#### Bi-directional Data Bus ( $D_0 \sim D_7$ )

Bi-directional data bus ( $D_0 \sim D_7$ ) are used for data transfer between the CRTC and MPU. The data bus outputs are 3-state buffers and remain in the high-impedance state except when MPU performs a CRTC read operation.

#### Read/Write ( $R/\bar{W}$ )

Read/Write signal ( $R/\bar{W}$ ) controls the direction of data transfer between the CRTC and MPU. When  $R/\bar{W}$  is at "High" level, data of CRTC is transferred to MPU. When  $R/\bar{W}$  is at "Low" level, data of MPU is transferred to CRTC.

#### Chip Select ( $\bar{CS}$ )

Chip Select signal ( $\bar{CS}$ ) is used to address the CRTC. When  $\bar{CS}$  is at "Low" level, it enables Read/Write operation to CRTC internal registers. Normally this signal is derived from decoded address signal of MPU under the condition that VMA of MPU is at "High" level.

#### Register Select (RS)

Register Select signal (RS) is used to select the address register and 18 control registers of the CRTC. When RS is at "Low" level, the address register is selected and when RS is at "High" level, control registers are selected. This signal is normally a derivative of the lowest bit (A0) of MPU address bus.

#### Enable (E)

Enable signal (E) is used as strobe signal in MPU Read/Write operation with the CRTC internal registers. This signal is normally a derivative of the HD6800 System  $\phi_2$  clock.

#### Reset ( $\bar{RES}$ )

Reset signal ( $\bar{RES}$ ) is an input signal used to reset the CRTC. When  $\bar{RES}$  is at "Low" level, it forces the CRTC into the following status.

- 1) All the counters in the CRTC are cleared and the device stops the display operation.
- 2) All the outputs go down to "Low" level.
- 3) Control registers in the CRTC are not affected and remain unchanged.

This signal is different from other HD6800 family LSIs in the following functions and has restrictions for usage.

- 1)  $\bar{RES}$  has capability of reset function only when LPSTB is at "Low" level.
- 2) The CRTC starts the display operation immediately after  $\bar{RES}$  goes "High" level.

### ● Interface Signals to CRT Display Device

#### Character Clock (CLK)

CLK is a standard clock input signal which defines character timing for the CRTC display operation. CLK is normally derived from the external high-speed dot timing logic.

#### Horizontal Sync (HSYNC)

HSYNC is an active "High" level signal which provides horizontal synchronization for display device.

#### Vertical Sync (VSYNC)

VSYNC is an active "High" level signal which provides vertical synchronization for display device.

#### Display Timing (DISPTMG)

DISPTMG is an active "High" level signal which defines the display period in horizontal and vertical raster scanning. It is necessary to enable video signal only when DISPTMG is at "High" level.

#### Refresh Memory Address ( $MA_0 \sim MA_{13}$ )

$MA_0 \sim MA_{13}$  are refresh memory address signals which are used to access to refresh memory in order to refresh the CRT screen periodically. These outputs enables 16k words max. refresh memory access. So, for instance, these are applicable up to 2000 characters/screen and 8-page system.

#### Raster Address ( $RA_0 \sim RA_4$ )

$RA_0 \sim RA_4$  are raster address signals which are used to select the raster of the character generator or graphic pattern generator etc.

#### Cursor Display (CUDISP)

CUDISP is an active "High" level video signal which is used to display the cursor on the CRT screen. This output is inhibited while DISPTMG is at "Low" level. Normally this output is mixed with video signal and provided to the CRT display device.

#### Light Pen Strobe (LPSTB)

LPSTB is an active "High" level input signal which accepts strobe pulse detected by the light pen and control circuit. When this signal is activated, the refresh memory address ( $MA_0 \sim MA_{13}$ ) which are shown in Fig. 2 are stored in the 14-bit light pen register. The stored refresh memory address need to be corrected in software, taking the delay time of the display device, light pen, and light pen control circuits into account.

## ■ REGISTER DESCRIPTION

Table 1 Internal Registers Assignment

| CS | RS | Address Register<br>4 3 2 1 0 | Register # | Register Name             | Program Unit                          | READ | WRITE | Data Bit |     |     |     |     |     |     |     |   |  |
|----|----|-------------------------------|------------|---------------------------|---------------------------------------|------|-------|----------|-----|-----|-----|-----|-----|-----|-----|---|--|
|    |    |                               |            |                           |                                       |      |       | 7        | 6   | 5   | 4   | 3   | 2   | 1   | 0   |   |  |
| 1  | x  | x x x x x                     |            |                           |                                       | -    | -     |          |     |     |     |     |     |     |     |   |  |
| 0  | 0  | x x x x x                     | AR         | Address Register          |                                       | -    | x     | o        |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 0 0 0                     | R0         | Horizontal Total *        | Character                             | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 0 0 1                     | R1         | Horizontal Displayed      | Character                             | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 0 1 0                     | R2         | Horizontal Sync* Position | Character                             | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 0 1 1                     | R3         | Sync Width                | Vertical-Raster, Horizontal-Character | x    | o     | wv3      | wv2 | wv1 | wv0 | wh3 | wh2 | wh1 | wh0 |   |  |
| 0  | 1  | 0 0 1 0 0                     | R4         | Vertical Total *          | Line                                  | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 1 0 1                     | R5         | Vertical Total Adjust     | Raster                                | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 1 1 0                     | R6         | Vertical Displayed        | Line                                  | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 0 1 1 1                     | R7         | Vertical Sync * Position  | Line                                  | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 1 0 0 0                     | R8         | Interlace & Skew          | -                                     | x    | o     | C1       | C0  | D1  | D0  |     |     |     | V   | S |  |
| 0  | 1  | 0 1 0 0 1                     | R9         | Maximum Raster Address    | Raster                                | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 1 0 1 0                     | R10        | Cursor Start Raster       | Raster                                | x    | o     |          |     | B   | P   |     |     |     |     |   |  |
| 0  | 1  | 0 1 0 1 1                     | R11        | Cursor End Raster         | Raster                                | x    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 1 1 0 0                     | R12        | Start Address(H)          | -                                     | o    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 1 1 0 1                     | R13        | Start Address(L)          | -                                     | o    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 1 1 1 0                     | R14        | Cursor(H)                 | -                                     | o    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 0 1 1 1 1                     | R15        | Cursor (L)                | -                                     | o    | o     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 1 0 0 0 0                     | R16        | Light Pen(H)              | -                                     | o    | x     |          |     |     |     |     |     |     |     |   |  |
| 0  | 1  | 1 0 0 0 1                     | R17        | Light Pen(L)              | -                                     | o    | x     |          |     |     |     |     |     |     |     |   |  |

- [NOTE]
1. The Registers marked \*. (Written Value) = (Specified Value) - 1
  2. Written Value of R9 is mentioned below.
    - 1) Non-interlace Mode } (Written Value) = (Specified Value) - 1
    - 2) Interlace Sync Mode
  - (Written Value) = (Specified Value) - 2
  3. C0 and C1 specify skew of CUDISP
  - D0 and D1 specify skew of DISPTMG
  - When S is "", V specifies video mode. S specifies the Interlace Sync Mode.
  4. B specifies the cursor blink. P specifies the cursor blink period.
  5. wv0~wv3 specify the pulse width of Vertical Sync Signal.
  6. wh0~wh3 specify the pulse width of Horizontal Sync Signal.
  7. o; Yes, x, No



## ■ FUNCTION OF INTERNAL REGISTERS

### ● Address Register (AR)

This is a 5-bit register used to select 18 internal control registers (R0~R17). Its contents are the address of one of 18 internal control registers. Programming the data from 18 to 31 produces no results. Access to R0~R17 requires, first of all, to write the address of corresponding control register into this register. When RS and CS are at "Low" level, this register is selected.

### ● Horizontal Total Register (R0)

This is a register used to program total number of horizontal characters per line including the retrace period. The data is 8-bit and its value should be programmed according to the specification of the CRT. When M is total number of characters, M-1 shall be programmed to this register. When programming for interlace mode, M must be even.

### ● Horizontal Displayed Register (R1)

This is a register used to program the number of horizontal displayed characters per line. Data is 8-bit and any number that is smaller than that of horizontal total characters can be programmed.

### ● Horizontal Sync Position Register (R2)

This is a register used to program horizontal sync position as multiples of the character clock period. Data is 8-bit and any number that is lower than the horizontal total number can be programmed. When H is character number of horizontal Sync Position, H-1 shall be programmed to this register. When programmed value of this register is increased, the display position on the CRT screen is shifted to the left. When programmed value is decreased, the position is shifted to the right. Therefore, the optimum horizontal position can be determined by this value.

### ● Sync Width Register (R3)

This is a register used to program the horizontal sync pulse width and the vertical sync pulse width. The horizontal sync pulse width is programmed in the lower 4-bit as multiples of the character clock period. "0" can't be programmed. The vertical sync pulse width is programmed in higher 4-bit as multiples of the raster period. When "0" is programmed in higher 4-bit, 16 raster period (16H) is specified.

### ● Vertical Total Register (R4)

This is a register used to program total number of lines per frame including vertical retrace period. The data is within 7-bit and its value should be programmed according to the specification of the CRTC. When N is total number of lines, N-1 shall be programmed to this register.

### ● Vertical Total Adjust Register (R5)

This is a register used to program the optimum number to adjust total number of rasters per field. This register enables to decide the number of vertical deflection frequency more strictly.

### ● Vertical Displayed Register (R6)

This is a register used to program the number of displayed character rows on the CRT screen. Data is 7-bit and any number that is smaller than that of vertical total characters can be programmed.

Table 2 Pulse Width of Vertical Sync Signal

| VSW   |       |       |       | Pulse Width |
|-------|-------|-------|-------|-------------|
| $2^7$ | $2^6$ | $2^5$ | $2^4$ |             |
| 0     | 0     | 0     | 0     | 16H         |
| 0     | 0     | 0     | 1     | 1           |
| 0     | 0     | 1     | 0     | 2           |
| 0     | 0     | 1     | 1     | 3           |
| 0     | 1     | 0     | 0     | 4           |
| 0     | 1     | 0     | 1     | 5           |
| 0     | 1     | 1     | 0     | 6           |
| 0     | 1     | 1     | 1     | 7           |
| 1     | 0     | 0     | 0     | 8           |
| 1     | 0     | 0     | 1     | 9           |
| 1     | 0     | 1     | 0     | 10          |
| 1     | 0     | 1     | 1     | 11          |
| 1     | 1     | 0     | 0     | 12          |
| 1     | 1     | 0     | 1     | 13          |
| 1     | 1     | 1     | 0     | 14          |
| 1     | 1     | 1     | 1     | 15          |

H; Raster period

Table 3 Pulse Width of Horizontal Sync Signal

| HSW   |       |       |       | Pulse Width |
|-------|-------|-------|-------|-------------|
| $2^3$ | $2^2$ | $2^1$ | $2^0$ |             |
| 0     | 0     | 0     | 0     | -(Note)     |
| 0     | 0     | 0     | 1     | 1 CH        |
| 0     | 0     | 1     | 0     | 2           |
| 0     | 0     | 1     | 1     | 3           |
| 0     | 1     | 0     | 0     | 4           |
| 0     | 1     | 0     | 1     | 5           |
| 0     | 1     | 1     | 0     | 6           |
| 0     | 1     | 1     | 1     | 7           |
| 1     | 0     | 0     | 0     | 8           |
| 1     | 0     | 0     | 1     | 9           |
| 1     | 0     | 1     | 0     | 10          |
| 1     | 0     | 1     | 1     | 11          |
| 1     | 1     | 0     | 0     | 12          |
| 1     | 1     | 0     | 1     | 13          |
| 1     | 1     | 1     | 0     | 14          |
| 1     | 1     | 1     | 1     | 15          |

CH: Character clock period

(Note) HSW = "0" can't be used



● **Vertical Sync Position Register (R7)**

This is a register used to program the vertical sync position on the screen as multiples of the horizontal character line period. Data is 7-bit and any number that is equal to or less than vertical total characters can be programmed. When V is character number of vertical sync position, V-1 shall be programmed to this register. When programmed value of this register is increased, the display position is shifted up. When programmed value is decreased, the position is shifted down. Therefore, the optimum vertical position may be determined by this value.

● **Interlace and Skew Register (R8)**

This is a register used to program raster scan mode and skew (delay) of CUDISP and DISPTMG.

**Raster Scan Mode Program Bit (V, S)**

Raster scan mode is programmed in the V, S bit.

Table 4 Raster Scan Mode ( $2^1, 2^0$ )

| V | S | Raster Scan Mode            |
|---|---|-----------------------------|
| 0 | 0 | } Non-interlace Mode        |
| 1 | 0 |                             |
| 0 | 1 | Interlace Sync Mode         |
| 1 | 1 | Interlace Sync & Video Mode |

In the non-interlace mode, the rasters of even number field and odd number field are scanned duplicatedly. In the interlace sync mode, the rasters of odd number field are scanned in the middle of even number field. Then it is controlled to display the same character pattern in two fields. In the interlace sync & video mode, the raster scan method is the same as the interlace sync mode, but it is controlled to display different character pattern in two field.

**Skew Program Bit (C1, C0, D1, D0)**

These are used to program the skew (delay) of CUDISP and DISPTMG.

Skew of these two kinds of signals are programmed separately.

Table 5 DISPTMG Skew Bit ( $2^5, 2^4$ )

| D1 | D0 | DISPTMG            |
|----|----|--------------------|
| 0  | 0  | Non-skew           |
| 0  | 1  | One-character skew |
| 1  | 0  | Two-character skew |
| 1  | 1  | Non-output         |

Table 6 CUDISP Skew Bit ( $2^7, 2^6$ )

| C1 | C0 | CUDISP             |
|----|----|--------------------|
| 0  | 0  | Non-skew           |
| 0  | 1  | One-character skew |
| 1  | 0  | Two-character skew |
| 1  | 1  | Non-output         |

Skew function is used to delay the output timing of CUDISP and DISPTMG in LSI for the time to access refresh memory, character generator or pattern generator, and to make the same phase with serial video signal.

● **Maximum Raster Address Register (R9)\***

This is a register used to program maximum raster address within 5-bit. This register defines total number of rasters per character including line space. This register is programmed as follows.

**Non-interlace Mode, Interlace Sync Mode**

When total number of rasters is RN, RN-1 shall be programmed.

**Interlace Sync & Video Mode**

When total number of rasters is RN, RN-2 shall be programmed

This manual defines total number of rasters in non-interlace mode, interlace sync mode and interlace sync & video mode as follows:

**Non-interlace Mode**

|   |                           |
|---|---------------------------|
| 0 | Total Number of Rasters:5 |
| 1 | Programmed Value: Nr = 4  |
| 2 | (The same as displayed)   |
| 3 | total number of rasters   |
| 4 |                           |

**Raster Address**

**Interlace Sync Mode**

|   |                              |
|---|------------------------------|
| 0 | Total Number of Rasters:5    |
| 1 | Programmed Value: Nr = 4     |
| 2 | In the interlace sync mode,  |
| 3 | total number of rasters in   |
| 4 | both the even and odd fields |

**Raster Address**

**Interlace Sync & Video Mode**

|   |                           |
|---|---------------------------|
| 0 | Total Number of Rasters:5 |
| 1 | Programmed Value: Nr = 3  |
| 2 |                           |
| 3 | Total number of rasters   |

**Raster Address**

● **Cursor Start Raster Register (R10)**

This is a register used to program the cursor start raster address by lower 5-bit ( $2^0 \sim 2^4$ ) and the cursor display mode by higher 2-bit ( $2^5, 2^6$ ).

Table 7 Cursor Display Mode ( $2^6, 2^5$ )

| B | P | Cursor Display Mode   |
|---|---|-----------------------|
| 0 | 0 | Non-blink             |
| 0 | 1 | Cursor Non-display    |
| 1 | 0 | Blink 16 Field Period |
| 1 | 1 | Blink 32 Field Period |

**Blink Period**



\*See Comparison of HD6845S and HD6845R on page 40.



- **Cursor End Raster Register (R11)**

This is register used to program the cursor end raster address.

- **Start Address Register (R12, R13)**

These are used to program the first address of refresh memory to read out.

Paging and scrolling is easily performed using this register. This register can be read but the higher 2-bit ( $2^6, 2^7$ ) of R12 are always "0".

- **Cursor Register (R14, R15)**

These two read/write registers stores the cursor location. The higher 2-bit ( $2^6, 2^7$ ) of R14 are always "0".

- **Light Pen Register (R16, R17)**

These read only registers are used to catch the detection address of the light pen. The higher 2-bit ( $2^6, 2^7$ ) of R16 are always "0". Its value needs to be corrected by software because there is time delay from address output of the CRTC to signal input LPSTB pin of the CRTC in the process that raster is lit after address output and light pen detects it. Moreover, delay time shown in Fig. 2 needs to be taken into account.

**Restriction on Programming Internal Register**

- 1)  $0 \leq Nhd < Nht + 1 \leq 256$
- 2)  $0 < Nvd < Nvt + 1 \leq 128$
- 3)  $0 \leq Nhsp \leq Nht$
- 4)  $0 \leq Nvsp \leq Nvt^*$
- 5)  $0 \leq NCSTART \leq NCEND \leq Nr$  (Non-interlace, Interlace sync mode)
- $0 \leq NCSTART \leq NCEND \leq Nr + 1$  (Interlace sync & video mode)

6)  $2 \leq Nr \leq 30$  (Interlace Sync & Video mode)

7)  $3 \leq Nht$  (Except non-interlace mode)  
 $5 \leq Nht$  (Non-interlace mode only)

\* In the interlace mode, pulse width is changed  $\pm 1/2$  raster time when vertical sync signal extends over two fields.

**Notes for Use**

The method of directly using the value programmed in the internal registers of LSI for controlling the CRT is adopted. Consequently, the display may flicker on the screen when the contents of the registers are changed from bus side asynchronously with the display operation.

**Cursor Register**

Writing into this register at frequent intervals for moving the cursor should be performed during horizontal and vertical retrace period.

**Start Address Register**

Writing into the start address register at frequent intervals for scrolling and paging should be performed during horizontal and vertical display period.

It is desirable to avoid programming other registers during display operation.

**OPERATION OF THE CRTC**
**Time Chart of CRT Interface Signals**

The following example shows the display operation in which values of Table 8 are programmed to the CRTC internal registers. Fig. 7 shows the CRT screen format. Fig. 10 shows the time chart of signals output from the CRTC.



Figure 7 CRT Screen Format



Table 8 Programmed Values into the Registers

| Register | Register Name            | Value      | Register | Register Name       | Value |
|----------|--------------------------|------------|----------|---------------------|-------|
| R0       | Horizontal Total         | Nht        | R9       | Max Raster Address  | Nr    |
| R1       | Horizontal Displayed     | Nhd        | R10      | Cursor Start Raster |       |
| R2       | Horizontal Sync Position | Nhsp       | R11      | Cursor End Raster   |       |
| R3       | Sync Width               | Nvsw, Nhsw | R12      | Start Address (H)   | 0     |
| R4       | Vertical Total           | Nvt        | R13      | Start Address (L)   | 0     |
| R5       | Vertical Total Adjust    | Nadj       | R14      | Cursor (H)          |       |
| R6       | Vertical Displayed       | Nvd        | R15      | Cursor (L)          |       |
| R7       | Vertical Sync Position   | Nvsp       | R16      | Light Pen (H)       |       |
| R8       | Interlace & Skew         |            | R17      | Light Pen (L)       |       |

[NOTE] Nhd &lt; Nht, Nvd &lt; Nvt

The relation between values of Refresh Memory Address ( $MA_0 \sim MA_{13}$ ) and Raster Address ( $RA_0 \sim RA_4$ ) and the display position on the screen is shown in Fig. 16. Fig. 16 shows the case where the value of Start Address is 0.

#### ● Interlace Control

Fig. 8 shows an example where the same character is displayed in the non-interlace mode, interlace sync mode, and interlace sync & video mode.

#### Non-interlace Mode Control

In non-interlace mode, each field is scanned duplicatedly. The values of raster addresses ( $RA_0 \sim RA_4$ ) are counted up one from 0.

#### Interlace Sync Mode Control

In the interlace sync mode, raster addressed in the even field and the odd field are the same as addressed in the non-interlace mode. One character pattern is displayed mutually and its displayed position in the odd field is set at 1/2 raster space down from that in the even field.



Figure 8 Example of Raster Scan Display



**Interlace Sync & Video Mode Control**

In interlace sync & video mode, the output raster address when the number of rasters is even is different from that when the number of rasters is odd.

**Table 9 The Output of Raster Address in Interlace Sync & Video Mode**

| Total Number of Rasters in a Line | Field        | Even Field   | Odd Field    |
|-----------------------------------|--------------|--------------|--------------|
| Even                              | Even Address | Odd Address  |              |
| Odd                               | Even Line*   | Even Address | Odd Address  |
|                                   | Odd Line*    | Odd Address  | Even Address |

- Internal line address begins from 0

**1) Total number of rasters in a line is even;**

When number of rasters is programmed to be even, even raster address is output in the even field and odd raster address is output in the odd field.

**2) Total number of rasters in a line is odd;**

When total number of rasters is programmed to be odd, odd and even addresses are reversed according to the odd and even lines in each field. In this case, the difference in numbers of dots displayed between even field and odd field is usually smaller the case of 1). Then interlace can be displayed more stably.

[NOTE] The wide disparity of dots between number of dots between even field and odd field influences beam current of CRT. CRT, which has a stable high-voltage part, can make interlace display normal. On the contrary, CRT, which has unstable high-voltage part, moves deflection angle of beam current and also dots displayed in the even and odd fields may be shifted. Characters appears distorting on a border of the screen. So 2) programming has an effect to decrease such evil influences as mentioned above. Fig. 13 shows fine chart in each mode when interlace is performed.

**● Cursor Control**

Fig. 9 shows the display patterns where each value is programmed to the cursor start raster register and the cursor end raster register. Programmed values to the cursor start raster register and the cursor end raster register need to be under the following condition.

$$\text{Cursor Start Raster Register} \leq \text{Cursor End Raster Register} \leq \text{Maximum Raster Address Register.}$$

Time chart of CUDISP is shown in Fig. 14 and Fig. 15.



Figure 9 Cursor Control



Figure 10 CRT Time Chart

( Output waveform of horizontal & vertical display  
in the case where values shown in Table 8 are  
Programmed to each register. )



Figure 11 Switching from Vertical Display Period over to Vertical Retrace Period (Expansion of Fig. 10- ④ )

Figure 12 Fine Adjustment Period of Frame in Vertical Display  
(Expansion of Fig. 10- ⑤ )



**Figure 13** Interlace Control





Figure 14 Relation between Line • Raster and CUDISP



Figure 15 CUDISP Timing (Expansion of Fig. 14. ◎)

[NOTE]  
 ( Cursor register = Nhd+2  
 Cursor Start  
 Raster Register = 1  
 Cursor End  
 Raster Register = 3  
 are Programmed in cursor display mode )

In blink mode, it is changed into display or non-display mode when field period is 16 or 32-time period



Valid refresh memory address (0~Nvd-Nhd-1) are shown within the thick-line square.  
Refresh memory address are provided even during horizontal and Vertical retrace period.  
This is an example in the case where the programmed value of start address register is 0.

Figure 16 Refresh Memory Address (MA<sub>0</sub>~MA<sub>13</sub>)

### ■ How to Use the CRTC

#### ● Interface to MPU

As shown in Fig. 17, the CRTC is connected with the standard bus of MPU to control the data transfer between them. The CRTC address is determined by  $\overline{CS}$  and RS, and the Read/Write operation is controlled by  $R/W$  and E. When  $\overline{CS}$  is "Low" and RS is also "Low", the CRTC address register is selected. When  $\overline{CS}$  is "Low" and RS is "High", one of 18 internal regis-

ters is selected.

$\overline{RES}$  is the system reset signal. When  $\overline{RES}$  becomes "Low", the CRTC internal control logic is reset. But internal registers shown in Table 1 ( $R0 \sim R17$ ) are not affected by  $\overline{RES}$  and remain unchanged.

The CRTC is designed so as to provide an interface to microcomputers, but adding some external circuits enables an interface to other data sources.



Figure 17 Interface to MPU

#### ● Dot Timing Generating Circuit

CRTC's CLK input (21 pin) is provided with CLK which defines horizontal character time period from the outside. This CLK is generated by dot counter shown in Fig. 18. Fig. 18 shows a example of circuit where horizontal dot number of the character is "9". Fig. 19 shows the operation time chart

of dot counter shown in Fig. 18. As this example shows explicitly, CLK is at "Low" level in the former half of horizontal character time and at "High" level in the latter half. It is necessary to be careful so as not to mistake this polarity.



Figure 18 Example of Dot Counter



Figure 19 Time Chart of Dot Counter

#### ■ INTERFACE TO DISPLAY CONTROL UNIT

Fig. 20 shows the interface between the CRTC and display control unit. Display control unit is mainly composed of Refresh Memory, Character Generator, and Video Control circuit. For refresh memory, 14 Memory Address line (0~16383) max are provided and for character generator, 5 Raster Address line (0~31) max are provided. For video control circuit, DISPTMG, CUDISP, HSYNC, and VSYNC are sent out. DISPTMG is used to control the blank period of video signal. CUDISP is used as video signal to display the cursor on the CRT screen. Moreover, HSYNC and VSYNC are used as drive signals respectively for CRT horizontal and vertical deflection circuits.

Outputs from video control circuit, (video signals and sync signals) are provided to CRT display unit to control the deflection and brightness of CRT, thus characters are displayed on the screen.

Fig. 21 shows detailed block diagram of display control unit. This shows how to use CUDISP and DISPTMG. CUDISP and DISPTMG should be used being latched at least one time at external flip-flop F1 and F2. Flip-flop F1 and F2 function to make one-character delay time so as to synchronize them with video signal from parallel-serial converter. High-speed D type flip-flop as TTL is used for this purpose. After being delayed at F1 and F2 DISPTMG is AND-ed with character video signal, and CUDISP is Or-ed with output from AND gate. By using this circuitry, blanking of horizontal and vertical retrace time is controlled. And cursor video is mixed with character video signal.

Fig. 21 shows the example in the case that both refresh memory and Character Generator can be accessed for horizontal one character time. Time chart for this case is shown in Fig. 24. This method is used when a few character needed to be displayed in horizontal direction on the screen.





Figure 20 Interface to Display Control Unit



Figure 21 Display Control Unit (1)



When many characters are displayed in horizontal direction on the screen, and horizontal one-character time is so short that both refresh memory and Character Generator cannot be accessed, the circuitry shown in Fig. 22 should be used. In this case refresh memory output shall be latched and Character Generator shall be accessed at the next cycle. The time chart in this case is shown in Fig. 25 CUDISP and DISPTMG should be provided after being delayed by one-character time by using skew bit of interlace & skew register (R8). Moreover, when

there are some troubles about delay time of MA during horizontal one-character time on high-speed display operation, system shown in Fig. 23 is adopted. The time chart in this case is shown in Fig. 26. Character video signal is delayed for two-character time because each MA outputs and refresh memory outputs are latched, and they are made to be in phase with CUDISP and DISPTMG by delaying for two-character time. Table 10 shows the circuitry selection standard of display units.

Table 10 Circuitry Standard of Display Control Unit

| Case | Relation among $t_{CH}$ Refresh Memory and Character Generator                              | Block Diagram | Interlace & Skew Register Bit Programming |    |    |    |
|------|---------------------------------------------------------------------------------------------|---------------|-------------------------------------------|----|----|----|
|      |                                                                                             |               | C1                                        | C0 | D1 | D0 |
| 1    | $t_{CH} > RM \text{ Access} + CG \text{ Access} + t_{MAD}$                                  | Fig. 21       | 0                                         | 0  | 0  | 0  |
| 2    | $RM \text{ Access} + CG \text{ Access} + t_{MAD} \geq t_{CH} > RM \text{ Access} + t_{MAD}$ | Fig. 22       | 0                                         | 1  | 0  | 1  |
| 3    | $RM \text{ Access} + t_{MAD} \geq t_{CH} > RM \text{ Access}$                               | Fig. 23       | 1                                         | 0  | 1  | 0  |

$t_{CH}$  CHCP Period,  $t_{MAD}$  MA Delay  
RM. Refresh Memory CG Character Generator



Figure 22 Display Control Unit (2)



Figure 23 Display Control Unit (For high-speed display operation) (3)





Figure 24 Time Chart of Display Control Unit (1)



Figure 25 Time Chart of Display Control Unit (2)



Figure 26 Time Chart of Display Unit (3)

#### ■ HOW TO DECIDE PARAMETERS SET ON THE CRTC

- How to Decide Parameters Based on Specification of CRT Display Unit (Monitor)

##### Number of Horizontal Total Characters

Horizontal deflection frequency  $f_h$  is given by specification of CRT display unit. Number of horizontal total characters is determined by the following equation.

$$f_h = \frac{1}{t_C (Nht + 1)}$$

where,

$t_C$  : Cycle Time of CLK (Character Clock)

$Nht$  : Programmed Value of Horizontal Total Register (R0)

##### Number of Vertical Total Characters

Vertical deflection frequency is given by specification of CRT display unit. Number of vertical Total characters is determined by the following equation.

- 1) Non-interlace Mode

$$Rt = (Nvt + 1)(Nr + 1) + Nadj$$

- 2) Interlace Sync Mode

$$Rt = (Nvt + 1)(Nr + 1) + Nadj + 0.5$$

- 3) Interlace Sync & Video Mode

$$Rt = \frac{(Nvt + 1)(Nr + 2) + 2Nadj}{2} \quad \dots \dots \dots \quad (a)$$

$$Rt = \frac{(Nvt + 1)(Nr + 2) + 2Nadj + 1}{2} \quad \dots \dots \dots \quad (b)$$

(a) is applied when both total numbers of vertical characters ( $Nvt + 1$ ) and that of rasters in a line ( $Nr + 2$ ) are odd.

(b) is applied when total number of rasters ( $Nr + 2$ ) is even, or when ( $Nr + 2$ ) is odd and total number of vertical characters ( $Nvt + 1$ ) is even.

where,

$Rt$  : Number of Total Rasters per frame  
(Including retrace period)

$Nvt$  : Programmed Value of Vertical Total Register (R4)

$Nr$  : Programmed Value of Maximum Raster Address Register (R9)

$Nadj$  : Programmed Value of Vertical Total Adjust Register (R5)

##### Horizontal Sync Pulse Width

Horizontal sync pulse width is programmed to low order 4-bit of horizontal sync width register (R3) in unit of horizontal character time. Programmed value can be selected within from 1 to 15.



### Horizontal Sync Position

As shown in Fig. 27, horizontal sync position is normally selected to be in the middle of horizontal retrace period. But there are some cases where optimum sync position is not located in the middle of horizontal retrace period according to specification of CRT. Therefore, horizontal sync position should be determined by specification of CRT. Horizontal sync pulse position is programmed in unit of horizontal character time.



Figure 27 Time Chart of HSYNC

### Vertical Sync Pulse Width

Vertical Sync Pulse Width is programmed to high order 4-bit of vertical sync pulse width register (R3) in unit of raster period. Programmed value can be selected within from 1 to 16.

### Vertical Sync Position

As shown in Fig. 28, vertical sync position is normally selected to be in the middle of vertical retrace period. But there are some cases where its optimum sync position is not located in the middle of vertical retrace period according to specification of CRT. Therefore, vertical sync position should be determined by specification of CRT. Vertical sync pulse position is programmed to vertical sync position register (R7) in unit of line period.

- How to Decide Parameters Based on Screen Format

#### Dot Number of Characters (Horizontal)

Dot number of characters (horizontal) is determined by character font and character space. An example is shown in Fig. 29. More strictly, dot number of characters (horizontal) N is determined by external N-counter. Character space is set by means shown in Fig. 30.

#### Dot Number of Characters (Vertical)

Dot number of characters (vertical) is determined by characters font and line space. An example is shown in Fig. 29. Dot number of characters (vertical) is programmed to maximum raster address (R9) of CRTC.



Figure 28 Time Chart of VSYNC



Figure 29 Dot Number of Horizontal and Vertical Characters





Figure 30 How to Make Character Space



Figure 31 Number of Horizontal Displayed Characters

#### Number of Horizontal Displayed Characters

Number of horizontal displayed characters is programmed to horizontal displayed register (R1) of the CRTC. Programmed value is based on screen format. Horizontal display period, which is given by specification of horizontal deflection frequency and horizontal retrace period of CRT display unit, determines horizontal character time, being divided by number of horizontal displayed characters. Moreover, its cycle time and access time which are necessary for CRT display system are determined by horizontal character time.

#### Number of Vertical Displayed Characters

Number of vertical displayed characters is programmed to vertical displayed register (R6). Programmed value is based on screen format. As specification of vertical deflection frequency of CRT determines number of total rasters (R1) including verti-

cal retrace period and the relation between number of vertical displayed character and total number of rasters on a screen is as mentioned above, CRT which is suitable for desired screen format should be selected.

For optimum screen format, it is necessary to adjust number of rasters per line, number of vertical displayed characters, and total adjust raster (Nadj) within specification of vertical deflection frequency.

#### Scan Mode

The CRTC can program three-scan modes shown in Table 11 to interlace mode register (R8). An example of character display in each scan mode is shown in Fig. 8.



Table 11 Program of Scan Mode

| V | S | Scan Mode              | Main Usage                                                             |
|---|---|------------------------|------------------------------------------------------------------------|
| 0 | 0 | Non-interlace          | Normal Display of Characters & Figures                                 |
| 1 | 0 | Interlace Sync         | Fine Display of Characters & Figures                                   |
| 1 | 1 | Interlace Sync & Video | Display of Many Characters & Figures Without Using High-resolution CRT |

[NOTE] In the interlace mode, the number of times per sec. in raster scanning on one spot on the screen is half as many as that in non-interlace mode. Therefore, when persistence of luminescence is short, flickering may happen. It is necessary to select optimum scan mode for the system, taking characteristics of CRT, raster scan speed, and number of displayed characters and figures into account.

#### Cursor Display Method

Cursor start raster register and cursor end raster register

(R10, R11) enable programming the display modes shown in Table 7 and display patterns shown in Fig. 9. Therefore, it is possible to change the method of cursor display dynamically according to the system conditions as well as to realize the cursor display that meets the system requirements.

#### Start Address

Start address resistors (R12, R13) give an offset to the address of refresh memory to read out. This enables paging and scrolling easily.

#### Cursor Register

Cursor registers (R14, R15) enable programming the cursor display position on the screen. As for cursor address, it is not X, Y address but linear address that is programmed.

#### ■ Applications of the CRTC

- **Monochrome Character Display**

Fig. 32 shows a system of monochrome character display. Character clock signal (CLK) is provided to the CRTC through OSC and dot counter. It is used as basic clock which drives internal control circuits. MPU is connected with the CRTC by standard bus and controls the CRTC initialization and read/write of internal registers.

Refresh memory is composed of RAM which has capacity of one frame at least and the data to be displayed is coded and stored. The data to refresh memory is changed through MPU



Figure 32 Monochrome Character Display



bus, while refresh memory is read out successively by the CRTC to display a static pattern on the screen. Refresh memory is accessed by both MPU and the CRTC, so it needs to change its address selectively by multiplexer. The CRTC has 14 MA (Memory Address output), but in fact some of them that are needed are used according to capacity of refresh memory.

Code output of refresh memory is provided to character generator. Character generator generates a dot pattern of a specified raster of a specified character in parallel according to code output from refresh memory and RA (Raster Address output) from the CRTC. Parallel-serial converter is normally composed of shift register to convert output of character generator into a serial dot pattern. Moreover, DISPTMG,

CUDISP, HSYNC, and VSYNC are provided to video control circuit. It controls blanking for output of parallel-serial converter, mixes these signals with cursor video signal, and generates sync signals for an interface to monitor.

#### ● Color Character Display

Fig. 33 shows a system of color character display. In this example, a 3-bit color control bit (R, G, B) is added to refresh memory in parallel with character code and provided to video control circuit. Video control circuit controls coloring as well as blanking and provides three primary color video signals (R, G, B signals) to CRT display device to display characters in seven kinds of color on the screen.



Figure 33 Color Character Display

#### ● Color limited Graphic Display

Limited graphic display is to display simple figures as well as character display by combination of picture element which are defined in unit of one character.

As shown in Fig. 34, graphic pattern generator is set up in parallel with character generator and output of these generators are wire-ORed. Which generator is accessed depends on

coded output of refresh memory.

In this example, graphic pattern generator adopts ROM, so only the combination of picture elements which are programmed to it is used for this graphic display system. Adopting RAM instead of ROM enables dynamically writable symbols in any combination on one display by changing the contents of them.



Figure 34 Color Limited Graphic Display



● **Monochrome Full Graphic Display**

Fig. 35 shows a system of monochrome full graphic display. While simple graphic display is figure display by combination of picture elements in unit of 1 picture elements, full graphic display is display of any figures in unit of 1 dot. In this case,

refresh memory is dot memory that stores all the dot patterns, so its output is directly provided to parallel-serial converter to be displayed. Dot memory address to refresh the screen is set up by combination of MA and RA of CRTC.



Figure 35 Monochrome Full Graphic Display



Fig. 36 shows an example of access to refresh memory by combination of MA and RA. Fig. 36 shows a refresh memory address method for full graphic display. Correspondence between dot on the CRT screen and refresh memory address is shown in Fig. 37.



Figure 36 Refresh Memory Address Method for Full Graphic Display



Figure 37 Memory Address and Dot Display Position on the Screen for Full Graphic Display

- **Color Full Graphic Display**

Fig. 38 shows a system of color full graphic display by 7-color display. Refresh memory is composed of three dot memories which are respectively used for red, green, and blue. These dot memories are read out in parallel at one time and

their output is provided to three parallel-serial converters. Then video control circuit adds the blanking control to output of these converters and provides it to CRT display device as red, green, and blue video signals with sync signals.



Figure 38 Color Full Graphic Display

- **Cluster Control of CRT Display**

The CRTC enables cluster control that is to control CRT display of plural devices by one CRTC. Fig. 39 shows a system of cluster control. Each display control unit has refresh memory, character generator, parallel-serial converter, and video control

circuit separately, but these are controlled together by the CRTC.

In this system, it is possible for plural CRT display devices to have their own display separately.



Figure 39 Cluster Control by the CRTC

#### ■ EXAMPLES OF APPLIED CIRCUIT OF THE CRTC

Fig. 41 shows an example of application of the CRTC to monochrome character display. Its specification is shown in

Table 12. Moreover, specification of CRT display unit is shown in Table 13 and initializing values for the CRTC are shown in Table 14.

**Table 12 Specification of Applied Circuit**

| Item                            | Specification                                                                                                                                                                                                                                           |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Character Format                | 5 × 7 Dot                                                                                                                                                                                                                                               |
| Character Space                 | Horizontal : 3 Dot Vertical : 5 Dot                                                                                                                                                                                                                     |
| One Character Time              | 1 μs                                                                                                                                                                                                                                                    |
| Number of Displayed Characters  | 40 characters × 16 lines = 640 characters                                                                                                                                                                                                               |
| Access Method to Refresh Memory | Synchronous Method (DISPTMG Read)                                                                                                                                                                                                                       |
| Refresh Memory                  | 640 B                                                                                                                                                                                                                                                   |
| Address Map                     | 2 <sup>15</sup> 2 <sup>14</sup> : 2 <sup>13</sup> 2 <sup>12</sup> 2 <sup>11</sup> 2 <sup>10</sup> 2 <sup>9</sup> 2 <sup>8</sup> 2 <sup>7</sup> 2 <sup>6</sup> 2 <sup>5</sup> 2 <sup>4</sup> 2 <sup>3</sup> 2 <sup>2</sup> 2 <sup>1</sup> 2 <sup>0</sup> |
|                                 | Refresh Memory 0 0 0 0 0 0 * * * * * * * * *                                                                                                                                                                                                            |
|                                 | CRTC Address Register 0 0 0 1 0 0 x x x x x x x x 0                                                                                                                                                                                                     |
|                                 | CRTC Control Register 0 0 0 1 0 0 x x x x x x x x x 1                                                                                                                                                                                                   |
|                                 | x . . . don't care, * . . . 0 or 1                                                                                                                                                                                                                      |
| Synchronization Method          | HVSYNC Method                                                                                                                                                                                                                                           |

Table 13 Specification of Character Display

| Item                                        | Specification                        |
|---------------------------------------------|--------------------------------------|
| Scan Mode                                   | Non-interlace                        |
| Horizontal Deflection Frequency             | 15.625 kHz                           |
| Vertical Deflection Frequency               | 60.1 Hz                              |
| Dot Frequency                               | 8 MHz                                |
| Character Dot (Horizontal × Vertical)       | 8 × 12 (Character Font 5 × 7)        |
| Number of Displayed Characters (Row × Line) | 40 × 16                              |
| H SYNC Width                                | 4 µs                                 |
| V SYNC Width                                | 3 H                                  |
| Cursor Display                              | Raster 9 ~ 10, Blink 16 Field Period |
| Paging, Scrolling                           | Not used                             |

Table 14 Initializing Values for Character Display

| Register | Name                     | Symbol        | Initializing Value<br>Hex (Decimal) |
|----------|--------------------------|---------------|-------------------------------------|
| R0       | Horizontal Total         | Nht           | 3F (63)                             |
| R1       | Horizontal Displayed     | Nhd           | 28 (40)                             |
| R2       | Horizontal Sync Position | Nhsp          | 34 (52)                             |
| R3       | Sync Width               | Nvsw, Nhsw    | 34                                  |
| R4       | Vertical Total           | Nvt           | 14 (20)                             |
| R5       | Vertical Total Adjust    | Nadj          | 08 (8)                              |
| R6       | Vertical Displayed       | Nvd           | 10 (16)                             |
| R7       | Vertical Sync Position   | Nvsp          | 13 (19)                             |
| R8       | Interlace & Skew         |               | 00                                  |
| R9       | Maximum Raster Address   | Nr            | 0B (11)                             |
| R10      | Cursor Start Raster      | B, P, NcSTART | 49                                  |
| R11      | Cursor End Raster        | NcEND         | 0A (10)                             |
| R12      | Start Address (H)        |               | 00 (0)                              |
| R13      | Start Address (L)        |               | 00 (0)                              |
| R14      | Cursor (H)               |               | 00 (0)                              |
| R15      | Cursor (L)               |               | 00 (0)                              |



Figure 40 Non-interlace Display (Example)





Figure 41 Example of Applied Circuit of the CRTC (Monochrome Character Display)

- **DISPLAY SEQUENCE AFTER  $\overline{\text{RES}}$  RELEASE OF HD6845S**  
HD6845S starts the display operation immediately after the release of  $\overline{\text{RES}}$ . The operation at the first field is different from the normal subsequent display operation.  
[Operation at the first field after the  $\overline{\text{RES}}$  release]

- (1) DISPTMG and CUDISP are not output. (They remain at "Low" level. The display is inhibited.)
  - (2) The data programmed in the start address register is not used. (MA and RA start at "0".)
  - (3) The sequences are shown in the following figures.



**Figure 42** RES Release Sequence



Figure 43 RES Release Sequence in The Non-interlace Mode



Figure 44 RES Release Sequence in The Interlace Mode (1)



Figure 45 RES Release Sequence in The Interlace Mode (2)

■ ANOMALOUS OPERATIONS IN HD6845S CAUSED BY REWRITING REGISTERS DURING THE DISPLAY OPERATION\*

| Register # | Register Name            | Anomalous operations caused by rewriting registers & Conditions to avoid those operations                                                                                                                                                                                                                      | Rewriting** OK or NG |
|------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| R0         | Horizontal Total         | The horizontal scan period is disturbed                                                                                                                                                                                                                                                                        | X                    |
| R1         | Horizontal Displayed     | There are some cases where the width of DISPTMG becomes shorter than the programmed value at the moment of a rewrite operation. An error operation occurs only during one raster period                                                                                                                        | O                    |
| R2         | Horizontal Sync Position | There are some cases where HSYNC is placed on the position different from the programmed value or the noise is output                                                                                                                                                                                          | X                    |
| R3         | Sync Width               | When a rewrite operation is performed at a "High" level on HSYNC pulse or VSYNC pulse, there are some cases where the width pulse becomes shorter than the programmed value at the moment of a rewrite operation                                                                                               | Δ                    |
| R4         | Vertical Total           | When a rewrite operation is performed during the last raster period in the line, there is a possibility that the disturbance occurs during the vertical scan period. There is no problem of a rewrite operation during raster period except this period                                                        | Δ                    |
| R5         | Vertical Total Adjust    | When a rewrite operation is performed in the last character time of the raster period, there are some cases where the numbers of Adjust Raster, specified by program, are not added. (Only during the adjust raster period)                                                                                    | Δ                    |
| R6         | Vertical Displayed       | After the moment of a rewrite operation, there are some cases where the Display is inhibited. However, the display according to the programmed value is performed from the next field                                                                                                                          | O                    |
| R7         | Vertical Sync Position   | There are some cases where VSYNC is placed on the position different from the programmed value or the noise is output                                                                                                                                                                                          | X                    |
| R8         | Interface & Skew         | Neither scan mode bit nor skew bit is rewritten dynamically. Dynamic Rewrite into scan mode bit and skew bit is prohibited                                                                                                                                                                                     | X                    |
| R9         | Maximum Raster Address   | The internal operation will be disordered by a rewrite operation                                                                                                                                                                                                                                               | X                    |
| R10        | Cursor Start Raster      | When a rewrite operation is performed in the last character time of the raster period, there are some cases where the jitter occurs on the cursor raster or the cursor is not displayed correctly. There is also a possibility that the blink rate becomes temporally shorter than usual.                      | Δ                    |
| R11        | Cursor End Raster        | When a rewrite operation is performed in the last character time of the raster period, there are some cases where the jitter occurs on the cursor raster or the cursor is not displayed correctly. Moreover, there are also some cases where the blink rate becomes temporally shorter than normal operation   | Δ                    |
| R12        | Start Address (H)        | R12 and R13 are used in the last raster period of the field. A rewrite operation can be performed except during this period. However, when R12 and R13 are rewritten in each field separately, the display operation, whose start address is determined temporally by programming sequence, will be performed. | O                    |
| R13        | Start Address (L)        | A rewrite operation should be performed during the horizontal/vertical display period.                                                                                                                                                                                                                         | O                    |
| R14        | Cursor (H)               | When a rewrite operation is performed during the display period, there are some cases where the cursor is temporally displayed at the address different from the programmed value. A rewrite operation should be performed during the horizontal/vertical retrace period.                                      | O                    |
| R15        | Cursor (L)               | Also, when R14 and R15 are rewritten in each field separately, the cursor is displayed temporally at the temporal address determined by programming sequence                                                                                                                                                   | O                    |

\* means temporary abnormal operations in rewriting the internal register during the display operation. Normally, after a rewrite operation, the LSI performs the specified display operation from the next field.  
(The operations in this table are outside our guarantee and are regarded as materials for reference.)

\*\* { O      A rewrite operation is possible without affecting the screen in the display so much.  
      Δ      If conditions are satisfied, a rewrite operation is possible. If conditions are not satisfied, there are some cases where a flicker and so on occur temporally  
      X      When a rewrite operation is performed, there are some cases where a flicker and so on occur temporally.

■ COMPARISON BETWEEN HD6845S AND HD6845R  
 • Comparison of function between HD6845S and HD6845R

| No. | Functional Difference                | HD6845                                                                                                                                                                                                                                                                                                                                                                                                                                                              | HD6845S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | Interlace Sync & Video Mode Display  | <p>Programming Method of Number of Vertical Characters</p>  <p>In HD6845, number of characters is vertically programmed in unit of two lines, as illustrated above. (Number of vertical total characters, Number of vertical displayed characters, Vertical Sync Position)</p> <p><u>Example of above figure</u></p> <p>Programmed number into Vertical Displayed Register = 5</p> | <p>Character line address</p>  <p>In HD6845S, number of characters is vertically programmed in unit of one line, as illustrated above. (Number of vertical total characters, Number of vertical displayed characters, Vertical Sync Position)</p> <p><u>Example of above figure</u></p> <p>Programmed number into Vertical Displayed Register = 10</p>                                                                                                                                                                                                                       |
|     | Number of Rasters Per Character Line | <p>Only even number can be specified.</p>  <p>Number of raster = 10 scan line (specified)<br/>   However, number which is programmed into register is calculated at follows.<br/>   Programmed number (Nr) = (Number specified) - 1</p>                                                                                                                                            | <p>Both even number and odd number can be specified</p> <p>Character line address 0</p>  <p>When number of raster per character line is EVEN.<br/>   Number of raster = 10 scan line (specified)</p> <p>Character line address 1</p>  <p>When number of raster per character line is ODD.<br/>   Number of raster = 9 scan line (specified)</p> <p>However, number which is programmed into register is calculated as follows.<br/>   Programmed number (Nr) = (Number specified) - 2</p> |
|     | Cursor Display                       | <p>Cursor is displayed in either EVEN field or ODD field.</p>                                                                                                                                                                                                                                                                                                                    | <p>Cursor is displayed in both EVEN field and ODD field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

(to be continued)



| No. | Functional Difference                       | HD6845R                                                                                                                                                                                                                                                                                                                                                             | HD6845S                                                                                                                                                                                                                                                                                                                  |
|-----|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | Vertical Sync Pulse Width<br>(VSYNC output) | Fixed at 16 raster scan cycle (16H)<br><br>VSYNC<br><br><br>R3<br>                                                                                                                                | Programmable (1 ~ 16 raster scan cycle)<br><br>VSYNC<br><br><br>Attached bits<br>R3<br>                                                              |
| 3   | SKEW Function                               | Not included<br><br>R8<br>                                                                                                                                                                                                                                                         | SKEW function is newly included in DISPTMG, CUDISP signals<br><br>Attached byte<br>R8<br><br><br>CUDISP DISPTMG<br><br>Example of DISPTMG output<br> |
| 4   | Start Address Register                      | Impossible to READ                                                                                                                                                                                                                                                                                                                                                  | Possible to READ                                                                                                                                                                                                                                                                                                         |
| 5   | RESET Signal (RES)                          | MA <sub>0</sub> ~ MA <sub>13</sub> Output<br>RA <sub>0</sub> ~ RA <sub>4</sub> Output<br>Other Outputs<br><br>Output signals of MA <sub>0</sub> ~ MA <sub>13</sub> , RA <sub>0</sub> ~ RA <sub>4</sub> , synchronizing with DLK "Low" level, go to "Low" level, after RES has gone to "Low" Other outputs go to "Low" immediately after RES has gone to "Low" level | MA <sub>0</sub> ~ MA <sub>13</sub> Output<br>RA <sub>0</sub> ~ RA <sub>4</sub> Output<br>Other Outputs<br><br>Output signals of MA <sub>0</sub> ~ MA <sub>13</sub> , RA <sub>0</sub> ~ RA <sub>4</sub> , and others go to "Low" level immediately after RES has gone to "Low" level                                      |

### ■ COMPATIBILITY OF HD6845S AND HD6845R

Non-interlace mode control

} Fully compatible with HD6845R\*  
HD6845R can be directly replaced by HD6845S in these modes.

Interlace sync & Video mode control .

Not compatible with HD6845R  
in regard to programming and

data for vertical direction need to be changed.

\* The functions added to HD6845S utilize undefined bits of the Control Register in HD6845R. If "0" is programmed to the undefined bits in the initial set, it is possible to replace HD6845R with HD6845S without changing the parameters.

Note) The restriction on programming of HD6845S and HD6845R should be taken into consideration.





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

# HD6350, HD6850 Asynchronous Communications Interface Adapter (CMOS) (NMOS)

The HD6350/HD6850 Asynchronous Communications Interface Adapter provides the data formatting and control to interface serial asynchronous data communications information to bus organized systems such as the HMCS6800 Micro-processing Unit.

The bus interface of the HD6350/HD6850 includes select, enable, read/write, interrupt and bus interface logic to allow data transfer over an 8-bit bi-directional data bus. The parallel data of the bus system is serially transmitted and received by the asynchronous data interface with proper formatting and error checking.

The functional configuration of the ACIA is programmed via the data bus during system initialization. A programmable Control Register provides variable word lengths, clock division ratios, transmit control, receive control, and interrupt control. For peripheral or modern operation three control lines are provided.

## FEATURES

- Serial/Parallel Conversion of Data
- Eight and Nine-bit Transmission
- Optional Even and Odd Parity
- Parity, Overrun and Framing Error Checking
- Peripheral/Modem Control Functions (Clear to Send CTS, Request to Send RTS, Data Carrier Detect DCD)
- Optional+ 1, + 16, and+ 64 Clock Modes
- One-or Two-Stop Bit Operation
- Double Buffered

### — HD6350 —

- Low-Power, High-Speed, High-Density CMOS
- Compatible with NMOS ACIA (HD6850)
- Wide Range Operating Voltage ( $V_{cc} = 5V \pm 10\%$ )
- Up to 1Mbps Transmission

### — HD6850 —

- Compatible with MC6850 and MC68A50
- Up to 500Kbps Transmission

## TYPE OF PRODUCTS

| Type    | Process | Clock Frequency | Package |
|---------|---------|-----------------|---------|
| HD6350  | CMOS    | 1.0MHz          | DP-24   |
| HD63A50 |         | 1.5MHz          |         |
| HD63B50 |         | 2.0MHz          |         |
| HD6850  | NMOS    | 1.0MHz          | DP-24   |
| HD68A50 |         | 1.5MHz          |         |

- Flat Package in Development for HD6350



## ■ PIN ARRANGEMENT



(Top View)



### ■ BLOCK DIAGRAM



### ■ ABSOLUTE MAXIMUM RATINGS

| Item                     | Symbol            | Value       |             | Unit |
|--------------------------|-------------------|-------------|-------------|------|
|                          |                   | HD6350      | HD6850      |      |
| Supply Voltage           | V <sub>cc</sub> * | -0.3 ~ +7.0 | -0.3 ~ +7.0 | V    |
| Input Voltage            | V <sub>in</sub> * | -0.3 ~ +7.0 | -0.3 ~ +7.0 | V    |
| Maximum Output Current** | I <sub>IO</sub> I | 10          |             | mA   |
| Operating Temperature    | T <sub>opr</sub>  | -20 ~ +75   | -20 ~ +75   | °C   |
| Storage Temperature      | T <sub>stg</sub>  | -55 ~ +150  | -55 ~ +150  | °C   |

\* With respect to V<sub>ss</sub> (SYSTEM GND)

\*\* Maximum output current is the maximum current which can flow out from one output terminal or I/O common terminal (D<sub>0</sub> ~ D<sub>7</sub>, RTS, Tx Data, IRQ).

(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                                                               | HD6350 |     |                 | HD6850 |     |                 | Unit |
|-----------------------|----------------------------------------------------------------------|--------|-----|-----------------|--------|-----|-----------------|------|
|                       |                                                                      | min    | typ | max             | min    | typ | max             |      |
| Supply Voltage        | V <sub>cc</sub> *                                                    | 4.5    | 5.0 | 5.5             | 4.75   | 5.0 | 5.25            | V    |
| Input "Low" Voltage   | V <sub>IL</sub> *                                                    | 0      | —   | 0.8             | -0.3   | —   | 0.8             | V    |
| Input "High" Voltage  | D <sub>0</sub> ~D <sub>7</sub> , RS, Tx CLK, DCD, CTS<br>Rx Data     | 2.0    | —   | V <sub>cc</sub> | 2.0    | —   | V <sub>cc</sub> | V    |
|                       | CS <sub>0</sub> , CS <sub>2</sub> , CS <sub>1</sub> , R/W, E, Rx CLK | 2.2    | —   | V <sub>cc</sub> |        |     |                 |      |
| Operating Temperature | T <sub>opr</sub>                                                     | -20    | 25  | 75              | -20    | 25  | 75              | °C   |

\* With respect to V<sub>ss</sub> (SYSTEM GND)



## ■ ELECTRICAL CHARACTERISTICS

● DC CHARACTERISTICS (HD6350;  $V_{CC} = 5V \pm 10\%$ , HD6850;  $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_A = -20 \sim +75^\circ C$ , unless otherwise noted.)

| Item                                  | Symbol                                                                                                                                                                                                                                                                 | HD6350         |                                              |                |          | HD6850                  |                                                          |      |     | Unit    |         |  |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------|----------------|----------|-------------------------|----------------------------------------------------------|------|-----|---------|---------|--|
|                                       |                                                                                                                                                                                                                                                                        | Test Condition | min                                          | typ*           | max      | Test Condition          | min                                                      | typ* | max |         |         |  |
| Input "High" Voltage                  | $V_{IH}$                                                                                                                                                                                                                                                               |                | 2.0                                          | —              | $V_{CC}$ |                         |                                                          |      | 2.0 | V       |         |  |
|                                       |                                                                                                                                                                                                                                                                        |                | 2.2                                          | —              | $V_{CC}$ |                         |                                                          |      | —   |         |         |  |
| Input "Low" Voltate                   | All Inputs                                                                                                                                                                                                                                                             | $V_{IL}$       | —0.3                                         | —              | 0.8      |                         | —0.3                                                     | —    | 0.8 | V       |         |  |
| Input Leakage Current                 | $R/W, CS_0, CS_1, CS_2, E$                                                                                                                                                                                                                                             | $I_{in}$       | $V_{in} = 0 \sim V_{CC}$                     | —2.5           | —        | $V_{in} = 0 \sim 5.25V$ | —2.5                                                     | —    | 2.5 | $\mu A$ |         |  |
| Three-State (Off State) Input Current | $D_0 \sim D_7$                                                                                                                                                                                                                                                         | $I_{TSI}$      | $V_{in} = 0.4 \sim V_{CC}$                   | —10            | —        | 10                      | $V_{in} = 0.4 \sim 2.4V$                                 | —10  | —   | 10      | $\mu A$ |  |
| Output "High" Voltage                 | $D_0 \sim D_7$                                                                                                                                                                                                                                                         | $I_{OH}$       | $= -400\mu A$                                | 4.1            | —        | —                       | $I_{OH} = -205\mu A$ , Enable Pulse Width $\leq 25\mu s$ | 2.4  | —   | —       | V       |  |
|                                       |                                                                                                                                                                                                                                                                        | $I_{OH}$       | $\leq -10\mu A$                              | $V_{CC} - 0.1$ | —        | —                       |                                                          |      |     |         |         |  |
|                                       | Tx Data, RTS                                                                                                                                                                                                                                                           | $I_{OH}$       | $= -400\mu A$                                | 4.1            | —        | —                       | $I_{OH} = -100\mu A$ , Enable Pulse Width $\leq 25\mu s$ | 2.4  | —   | —       | V       |  |
|                                       |                                                                                                                                                                                                                                                                        | $I_{OH}$       | $\leq -10\mu A$                              | $V_{CC} - 0.1$ | —        | —                       |                                                          |      |     |         |         |  |
| Output "Low" Voltage                  | All Outputs                                                                                                                                                                                                                                                            | $V_{OL}$       | $I_{OH} = 1.6mA$                             | —              | —        | 0.4                     | $I_{OL} = 1.6mA$ , Enable Pulse Width $\leq 25\mu s$     | —    | —   | 0.4     | V       |  |
| Output Leakage Current (Off State)    | IRQ                                                                                                                                                                                                                                                                    | $I_{LOH}$      | $V_{OH} = V_{CC}$                            | —              | —        | 10                      | $V_{OH} = 2.4V$                                          | —    | —   | 10      | $\mu A$ |  |
| Input Capacitance                     | $D_0 \sim D_7$<br>E, Tx CLK, Rx CLK, R/W, RS, RX Data, CS <sub>0</sub> , CS <sub>1</sub> , CS <sub>2</sub> , CTS, DCD                                                                                                                                                  | $C_{in}$       | $V_{in} = 0V, T_A = 25^\circ C, f = 1.0 MHz$ | —              | —        | 12.5                    | $V_{in} = 0V, T_A = 25^\circ C, f = 1.0 MHz$             | —    | —   | 12.5    | pF      |  |
|                                       |                                                                                                                                                                                                                                                                        |                |                                              | —              | —        | 7.5                     |                                                          | —    | —   | 7.5     |         |  |
| Output Capacitance                    | RTS, Tx Data                                                                                                                                                                                                                                                           | $C_{out}$      | $V_{in} = 0V, T_A = 25^\circ C, f = 1.0 MHz$ | —              | —        | 10                      | $V_{in} = 0V, T_A = 25^\circ C, f = 1.0 MHz$             | —    | —   | 10      | pF      |  |
|                                       | IRQ                                                                                                                                                                                                                                                                    |                |                                              | —              | —        | 5.0                     |                                                          | —    | —   | 5.0     |         |  |
| Supply Current                        | <ul style="list-style-type: none"> <li>Under transmitting and Receiving operation</li> <li>• 500 kbps</li> <li>• Data bus in R/W operation</li> </ul>                                                                                                                  |                | E = 1.0 MHz                                  | —              | —        | 3                       |                                                          |      |     |         | mA      |  |
|                                       | <ul style="list-style-type: none"> <li>Chip is not selected.</li> <li>• 500 kbps</li> <li>• Under non transmitting and receiving operation</li> <li>• Input level (Except E)<br/><math>V_{IH} min = V_{CC} - 0.8V</math><br/><math>V_{IL} max = 0.8V</math></li> </ul> |                | E = 1.5 MHz                                  | —              | —        | 4                       |                                                          |      |     |         |         |  |
|                                       | <ul style="list-style-type: none"> <li>• Under non transmitting and receiving operation</li> <li>• Input level (Except E)<br/><math>V_{IH} min = V_{CC} - 0.8V</math><br/><math>V_{IL} max = 0.8V</math></li> </ul>                                                    |                | E = 2.0 MHz                                  | —              | —        | 5                       |                                                          |      |     |         |         |  |
|                                       | <ul style="list-style-type: none"> <li>• Under non transmitting and receiving operation</li> <li>• Input level (Except E)<br/><math>V_{IH} min = V_{CC} - 0.8V</math><br/><math>V_{IL} max = 0.8V</math></li> </ul>                                                    |                | E = 1.0 MHz                                  | —              | —        | 200                     |                                                          |      |     |         |         |  |
|                                       | <ul style="list-style-type: none"> <li>• Under non transmitting and receiving operation</li> <li>• Input level (Except E)<br/><math>V_{IH} min = V_{CC} - 0.8V</math><br/><math>V_{IL} max = 0.8V</math></li> </ul>                                                    |                | E = 1.5 MHz                                  | —              | —        | 250                     |                                                          |      |     |         |         |  |
|                                       | <ul style="list-style-type: none"> <li>• Under non transmitting and receiving operation</li> <li>• Input level (Except E)<br/><math>V_{IH} min = V_{CC} - 0.8V</math><br/><math>V_{IL} max = 0.8V</math></li> </ul>                                                    |                | E = 2.0 MHz                                  | —              | —        | 300                     |                                                          |      |     |         |         |  |
| Power Dissipation                     | $P_D$                                                                                                                                                                                                                                                                  |                |                                              |                |          |                         | —                                                        | 300  | 525 | mW      |         |  |

\*  $T_A = 25^\circ C$ ,  $V_{CC} = 5.0V$ 

● AC CHARACTERISTICS (HD6350;  $V_{CC} = 5.0V \pm 10\%$ , HD6850;  $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20\sim+75^\circ C$ , unless otherwise noted.)

### 1. TIMING OF DATA TRANSMISSION

| Item                                                           | Symbol         | Test Condition                  | HD6350 |     | HD63A50 |     | HD63B50 |     | HD6850 /HD68A50 |     | Unit |     |
|----------------------------------------------------------------|----------------|---------------------------------|--------|-----|---------|-----|---------|-----|-----------------|-----|------|-----|
|                                                                |                |                                 | min    | max | min     | max | min     | max | min             | max |      |     |
| Minimum Clock Pulse Width                                      | +1 Mode        | PW <sub>CL</sub>                | Fig. 1 | 900 | —       | 650 | —       | 500 | —               | 900 | —    | ns  |
|                                                                | +16, +64 Modes |                                 |        | 600 | —       | 450 | —       | 280 | —               | 600 | —    | ns  |
|                                                                | +1 Mode        | PW <sub>CH</sub>                | Fig. 2 | 900 | —       | 650 | —       | 500 | —               | 900 | —    | ns  |
|                                                                | +16, +64 Modes |                                 |        | 600 | —       | 450 | —       | 280 | —               | 600 | —    | ns  |
| Clock Frequency                                                | +1 Mode        | f <sub>C</sub>                  |        | —   | 500     | —   | 750     | —   | 1000            | —   | 500  | kHz |
|                                                                | +16, +64 Modes |                                 |        | —   | 800     | —   | 1000    | —   | 1500            | —   | 800  |     |
| Clock-to-Data Delay for Transmitter                            |                | t <sub>TOD</sub>                | Fig. 3 | —   | 600     | —   | 540     | —   | 460             | —   | 1000 | ns  |
| Receive Data Setup Time                                        | +1 Mode        | t <sub>RDSU</sub>               | Fig. 4 | 250 | —       | 100 | —       | 30  | —               | 500 | —    | ns  |
| Receive Data Hold Time                                         | +1 Mode        | t <sub>RDH</sub>                | Fig. 5 | 250 | —       | 100 | —       | 30  | —               | 500 | —    | ns  |
| t <sub>IR</sub> Release Time                                   |                | t <sub>IR</sub>                 | Fig. 6 | —   | 1200    | —   | 900     | —   | 700             | —   | 1200 | ns  |
| t <sub>RTS</sub> Delay Time                                    |                | t <sub>RTS</sub>                | Fig. 6 | —   | 560     | —   | 480     | —   | 400             | —   | 1000 | ns  |
| Rise Time and Fall Time (or 10% of the pulse width if smaller) |                | t <sub>r</sub> , t <sub>f</sub> |        | —   | 1000    | —   | 500     | —   | 250             | —   | 1000 | ns  |

•

### 2. BUS TIMING CHARACTERISTICS

#### 1) READ

| Item                                                            | Symbol                            | Test Condition | HD6350 |     | HD63A50 |     | HD63B50 |     | HD6850 |       | HD68A50 |       | Unit |
|-----------------------------------------------------------------|-----------------------------------|----------------|--------|-----|---------|-----|---------|-----|--------|-------|---------|-------|------|
|                                                                 |                                   |                | min    | max | min     | max | min     | max | min    | max   | min     | max   |      |
| Enable Cycle Time                                               | t <sub>cycE</sub>                 | Fig. 7         | 1000   | —   | 666     | —   | 500     | —   | 1000   | —     | 666     | —     | ns   |
| Enable "High" Pulse Width                                       | PW <sub>EH</sub>                  | Fig. 7         | 450    | —   | 280     | —   | 220     | —   | 450    | 25000 | 280     | 25000 | ns   |
| Enable "Low" Pulse Width                                        | PW <sub>EL</sub>                  | Fig. 7         | 430    | —   | 280     | —   | 210     | —   | 430    | —     | 280     | —     | ns   |
| Setup Time, Address and R/W Valid to Enable Positive Transition | t <sub>AS</sub>                   | Fig. 7         | 80     | —   | 60      | —   | 40      | —   | 140    | —     | 140     | —     | ns   |
| Data Delay Time                                                 | t <sub>DDR</sub>                  | Fig. 7         | —      | 290 | —       | 180 | —       | 150 | —      | 320   | —       | 220   | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                    | Fig. 7         | 20     | 100 | 20      | 100 | 20      | 100 | 10     | —     | 10      | —     | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                   | Fig. 7         | 10     | —   | 10      | —   | 10      | —   | 10     | —     | 10      | —     | ns   |
| Rise and Fall Time for Enable Input                             | t <sub>Er</sub> , t <sub>Ef</sub> | Fig. 7         | —      | 25  | —       | 25  | —       | 20  | —      | 25    | —       | 25    | ns   |

#### 2) WRITE

| Item                                                            | Symbol                            | Test Condition | HD6350 |     | HD63A50 |     | HD63B50 |     | HD6850 |       | HD68A50 |       | Unit |
|-----------------------------------------------------------------|-----------------------------------|----------------|--------|-----|---------|-----|---------|-----|--------|-------|---------|-------|------|
|                                                                 |                                   |                | min    | max | min     | max | min     | max | min    | max   | min     | max   |      |
| Enable Cycle Time                                               | t <sub>cycE</sub>                 | Fig. 8         | 1000   | —   | 666     | —   | 500     | —   | 1000   | —     | 666     | —     | ns   |
| Enable "High" Pulse Width                                       | PW <sub>EH</sub>                  | Fig. 8         | 450    | —   | 280     | —   | 220     | —   | 450    | 25000 | 280     | 25000 | ns   |
| Enable "Low" Pulse Width                                        | PW <sub>EL</sub>                  | Fig. 8         | 430    | —   | 280     | —   | 210     | —   | 430    | —     | 280     | —     | ns   |
| Setup Time, Address and R/W Valid to Enable Positive Transition | t <sub>AS</sub>                   | Fig. 8         | 80     | —   | 60      | —   | 40      | —   | 140    | —     | 140     | —     | ns   |
| Data Setup Time                                                 | t <sub>DSW</sub>                  | Fig. 8         | 165    | —   | 80      | —   | 60      | —   | 195    | —     | 80      | —     | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                    | Fig. 8         | 10     | —   | 10      | —   | 10      | —   | 10     | —     | 10      | —     | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                   | Fig. 8         | 10     | —   | 10      | —   | 10      | —   | 10     | —     | 10      | —     | ns   |
| Rise and Fall Time for Enable Input                             | t <sub>Er</sub> , t <sub>Ef</sub> | Fig. 8         | —      | 25  | —       | 25  | —       | 20  | —      | 25    | —       | 25    | ns   |





Figure 1 Clock Pulse Width, "Low" State



Figure 2 Clock Pulse Width, "High" State



Figure 3 Transmit Data Output Delay

Figure 4 Receive Data Setup Time ( $\div 1$  Mode)Figure 5 Receive Data Hold Time ( $\div 1$  Mode)

- \* (1)  $\overline{\text{IRQ}}$  Release Time applied to Rx Data Register read operation.
- (2)  $\overline{\text{IRQ}}$  Release Time applied to Tx Data Register write operation.
- (3)  $\overline{\text{IRQ}}$  Release Time applied to control Register write  $\text{TIE} = 0$ ,  $\text{RIE} = 0$  operation.

\*\*  $\overline{\text{IRQ}}$  Release Time applied to Rx Data Register read operation right after read status register, when  $\overline{\text{IRQ}}$  is asserted by  $\overline{\text{DCD}}$  rising edge.

\*\*\* 2.4V for HD6850.

(Note) Note that followings take place when  $\overline{\text{IRQ}}$  is asserted by the detection of transmit data register empty status.  $\overline{\text{IRQ}}$  is released to "High" asynchronously with E signal when CTS goes "High". (Refer to Figure 14)

Figure 6  $\overline{\text{RTS}}$  Delay and  $\overline{\text{IRQ}}$  Release TimeFigure 7 Bus Read Timing Characteristics  
(Read information from ACIA)

Figure 8 Bus Write Timing Characteristics  
(Write information into ACIA)

$C = 130\text{pF}$  for  $D_0 \sim D_7$ ,  
=  $30\text{pF}$  for RTS and Tx Data  
 $R^* = 10\text{k}\Omega$  for  $D_0 \sim D_7$ , RTS and Tx Data  
All diodes are 1S2074 or Equivalent.

\* HD6840  
 $R = 11\text{k}\Omega$  for  $D_0 \sim D_7$ ,  
=  $24\text{k}\Omega$  for RTS and Tx Data.

Figure 9 Bus Timing Test Loads



Figure 10 110 Baud Serial ASCII Data Timing





|                       |      |      |
|-----------------------|------|------|
| BAUD RATE             | 150  | 300  |
| CHARACTERS/SEC        | 15   | 30   |
| BIT TIME (msec)       | 6.67 | 3.33 |
| CHARACTER TIME (msec) | 66.7 | 33.3 |

$$\text{BIT TIME} = \frac{\text{SEC}}{\text{BAUD RATE}}$$

Figure 11 150 & 300 Baud Serial ASCII Data Timing



Figure 12 Send a 7 Bit ASCII Char. "H" Even Parity  
— 2 Stop Bits H = 48<sub>16</sub> = 1001000<sub>2</sub>

#### ■ DATA OF ACIA

ACIA is an interface adapter which controls transmission and reception of Asynchronous serial data. Some examples of serial data are shown in Figs. 10 ~ 12.

#### ■ INTERNAL STRUCTURE OF ACIA

ACIA provides the following; 8-bit Bi-directional Data Buses ( $D_0 \sim D_7$ ), Receive Data Input (Rx Data), Transmit Data Output (Tx Data), three Chip Selects ( $CS_0$ ,  $CS_1$ ,  $CS_2$ ), Register Select Input (RS), Two Control Input (Read/Write: R/W, Enable: E), Interrupt Request Output(IRQ), Clear-to-Send (CTS) to control the modem, Request-to-Send (RTS), Data Carrier Detect(DCD) and Clock Inputs(Tx CLK, Rx CLK) used for synchronization of received and transmitted data. This ACIA also provides four registers; Status Register, Control Register, Receive Register and Transmit Register.

24-pin dual-in-line type package is used for the ACIA. Internal Structure of ACIA is illustrated in Fig. 13.

#### ■ ACIA OPERATION

##### • Master Reset

ACIA has an internal master reset function controlled by software, since it has no hardware reset pin. Bit 0 and bit 1 of control register should be set to "11" to execute master reset, also bit 5 and bit 6 should be programmed to get predetermined RTS output accordingly. To release the master reset, the data other than "11" should be written into bit 0, bit 1 of the control register. When the master reset is released, the control register needs to be programmed to get predetermined options such as clock divider ratios, word length, one or two stop bits, parity(even, odd, or none), etc.

It may happen that "Low" level output is provided in IRQ pin during the time after power-on till master reset. In the system using ACIA, interrupt mask bit of MPU should be released after the master reset of ACIA. (MPU interrupt should be prohibited until MPU program completes the master reset of ACIA.) Transmit Data Register (TDR) and Receive Data Register (RDR) can not be reset by master reset.





Figure 13 Internal Structure of ACIA

#### • Transmit

A typical transmitting sequence consists of reading the ACIA Status Register either as a result of an interrupt or in the ACIA's turn in a polling sequence. A character may be written into the Transmit Data Register if the status read operation has indicated that the Transmit Data Register is empty. This character is transferred to a Shift Register where it is serialized and transmitted from the Transmit Data output preceded by a start bit and followed by one or two stop bits. Internal parity (odd or even) can be optionally added to the character and will occur between the last data bit and the first stop bit. After the first character is written in the Data Register, the Status Register can be read again to check for a Transmit Data Register Empty condition and current peripheral status. If the register is empty, another character can be loaded for transmission even though the first character is in the process of being transmitted (because of double buffering). The second character will be automatically transferred into the Shift Register when the first character transmission is completed. This sequence continues until all the characters have been transmitted.

#### • Receive

Data is received from a peripheral by means of the Receive Data input. A divide-by-one clock ratio is provided for an externally synchronized clock (to its data) while the divide-by-16 and 64 ratios are provided for internal synchronization. Bit synchronization in the divide-by-16 and 64 modes is initiated by

the detection of the leading mark-space transition of the start bit. False start bit detection capability insures that a full half bit of a start bit has been received before the internal clock is synchronized to the bit time. As a character is being received, parity (odd or even) will be checked and the error indication will be available in the Status Register along with framing error, overrun error, and Receive Data Register full. In a typical receiving sequence, the Status Register is read to determine if a character has been received from a peripheral. If the Receiver Data Register is full, the character is placed on the 8-bit ACIA bus when a Read Data command is received from the MPU. When parity has been selected for an 8-bit word (7 bits plus parity), the receiver strip the parity bit ( $D_7 = "0"$ ) so that data alone is transferred to the MPU. This feature reduces MPU programming. The Status Register can continue to be read again to determine when another character is available in the Receive Data Register. The receiver is also double buffered so that a character can be read from the data register as another character is being received in the Shift register. The above sequence continues until all the characters have been received.

#### ■ ACIA INTERNAL REGISTERS

The ACIA provides four registers; Transmit Data Register (TDR), Receive Data Register(RDR), Control Register(CR) and Status Register(SR). The content of each of the registers is summarized in Table I.



Table 1 Definition of ACIA Register Contents

| Buffer Address | RS=1 • R/W=0 ****                      | RS=1 • R/W=1                          | RS=0 • R/W=0                     | RS=0 • R/W=1                   |
|----------------|----------------------------------------|---------------------------------------|----------------------------------|--------------------------------|
| Data Bus       | Transmit Data Register<br>(Write Only) | Receiver Data Register<br>(Read Only) | Control Register<br>(Write Only) | Status Register<br>(Read Only) |
|                | Data Bit 0 *                           | Data Bit 0                            | Counter Divide Select (CR0)      | Rx Data Reg. Full (RDRF)       |
| 1              | Data Bit 1                             | Data Bit 1                            | Counter Divide Select (CR1)      | Tx Data Reg. Empty (TDRE)      |
| 2              | Data Bit 2                             | Data Bit 2                            | Word Select 1 (CR2)              | Data Carrier Detect (DCD)      |
| 3              | Data Bit 3                             | Data Bit 3                            | Word Select 2 (CR3)              | Clear to Send (CTS)            |
| 4              | Data Bit 4                             | Data Bit 4                            | Word Select 3 (CR4)              | Framing Error (FE)             |
| 5              | Data Bit 5                             | Data Bit 5                            | Tx Control 1 (CR5)               | Overrun (OVRN)                 |
| 6              | Data Bit 6                             | Data Bit 6                            | Tx Control 2 (CR6)               | Parity Error (PE)              |
| 7              | Data Bit 7 ***                         | Data Bit 7 **                         | Rx Interrupt Enable (CR7)        | Interrupt Request (IRQ)        |

\* Leading bit = LSB = Bit 0

\*\* Data bit will be zero in 7-bit plus parity modes.

\*\*\* Data bit is "don't care" in 7-bit plus parity modes.

\*\*\*\* 1 ... "High" level, 0 ... "Low" level

#### • Transmit Data Register (TDR)

Data is written in the Transmit Data Register during the negative transition of the enable (E) when the ACIA has been addressed and RS • R/W is selected. Writing data into the register causes the Transmit Data Register Empty bit in the Status Register to go "0". Data can then be transmitted. If the transmitter is idling and no character is being transmitted, then the transfer will take place within 2 bit time + several E cycles of the trailing edge of the Write command. If a character is being transmitted, the new data character will commence as soon as the previous character is complete. The transfer of data causes the Transmit Data Register Empty (TDRE) bit to indicate empty.

#### • Receive Data Register (RDR)

Data is automatically transferred to the empty Receive Data Register (RDR) from the receiver deserializer (a shift register) upon receiving a complete character. This event causes the Receive Data Register Full bit (RDRF) on the status buffer to go "1" (full). Data may then be read through the bus by addressing the ACIA and R/W "High" when the ACIA is enabled. The non-destructive read cycle causes the RDRF bit to be cleared to empty although the data is retained in the RDR. The status is maintained by RDRF as to whether or not the data is current. When the Receive Data Register is full, the automatic transfer of data from the Receiver Shift Register to the Data Register is inhibited and the RDR contents remain valid with its current status stored in the Status Register.

#### • Control Register

The ACIA Control Register consists of eight bits of write-only buffer that are selected when RS and R/W are "Low". This

register controls the function of the receiver, transmitter, interrupt enables, and the Request-to-Send (RTS) peripheral/modem control output.

#### Counter Divide Select Bits (CR0 and CR1)

The Counter Divide Select Bits (CR0 and CR1) determine the divide ratios utilized in both the transmitter and receiver section of the ACIA. Additionally, these bits are used to provide a master reset for the ACIA which clears the Status Register (except for external conditions on CTS and DCD) and initializes both the receiver and transmitter. Master reset does not affect other Control Register bits. Note that after power-on or a power fail/restart, these bits must be set "1" to reset the ACIA. After resetting, the clock divide ratio may be selected. These counter select bits provide for the following clock divide ratios:

Table 2 Function of Counter Devide Select Bit

| CR1 | CR0 | Function     |
|-----|-----|--------------|
| 0   | 0   | ÷1           |
| 0   | 1   | ÷16          |
| 1   | 0   | ÷64          |
| 1   | 1   | Master Reset |

#### Word Select Bits (CR2, CR3, and CR4)

The Word Select bits are used to select word length, parity, and the number of stop bits. The encoding format is as follows:



Table 3 Function of Word Select Bit

| CR4 | CR3 | CR2 | Function                           |
|-----|-----|-----|------------------------------------|
| 0   | 0   | 0   | 7 Bits + Even Parity + 2 Stop Bits |
| 0   | 0   | 1   | 7 Bits + Odd Parity + 2 Stop Bits  |
| 0   | 1   | 0   | 7 Bits + Even Parity + 1 Stop Bit  |
| 0   | 1   | 1   | 7 Bits + Odd Parity + 1 Stop Bit   |
| 1   | 0   | 0   | 8 Bits + 2 Stop Bits               |
| 1   | 0   | 1   | 8 Bits + 1 Stop Bit                |
| 1   | 1   | 0   | 8 Bits + Even Parity + 1 Stop Bit  |
| 1   | 1   | 1   | 8 Bits + Odd Parity + 1 Stop Bit   |

Word length, Parity Select, and Stop Bit changes are not buffered and therefore become effective immediately.

#### Transmitter Control Bits (CR5 and CR6)

Two Transmitter Control bits provide for the control of the interrupt from the Transmit Data Register Empty condition, the Request-to-Send (RTS) output, and the transmission of a Break level (space). The following encoding format is used:

Table 4 Function of Transmitter Control-Bit

| CR6 | CR5 | Function                                                                                                 |
|-----|-----|----------------------------------------------------------------------------------------------------------|
| 0   | 0   | RTS = "Low", Transmitting Interrupt Disabled.                                                            |
| 0   | 1   | RTS = "Low", Transmitting Interrupt Enabled.                                                             |
| 1   | 0   | RTS = "High", Transmitting Interrupt<br>Disabled.                                                        |
| 1   | 1   | RTS = "Low", Transmits a Break level on<br>the Transmit Data Output.<br>Transmitting Interrupt Disabled. |

#### Receive Interrupt Enable Bit (CR7)

The following interrupts will be enabled by a "1" in bit position 7 of the Control Register (CR7): Receive Data Register Full, Overrun, or a "Low" to "High" transition on the Data Carrier Detect ( $\overline{DCD}$ ) signal line.



Figure 14 IRQ Internal Circuit

#### ● Status Register

Information on the status of the ACIA is available to the MPU by reading the ACIA Status Register. This read-only register is selected when RS is "Low" and R/W is "High". Information stored in this register indicates the status of the Transmit Data Register, the Receive Data Register and error logic, and the peripheral/modem status inputs of the ACIA.

#### Receive Data Register Full (RDRF), Bit 0

RDRF indicates that received data has been transferred to the Receive Data Register. RDRF is cleared after an MPU read of the Receive Data Register or by a master reset. The cleared or empty state indicates that the contents of the Receive Data Register are not current. Data Carrier Detect ( $\overline{DCD}$ ) being "High" also causes RDRF to indicate empty.

#### Transmit Data Register Empty (TDRE), Bit 1

The Transmit Data Register Empty bit being set "1" indicates that the Transmit Data Register contents have been transferred and that new data may be entered. The "0" state indicates that the register is full and that transmission of a new character has not begun since the last write data command.

#### Data Carrier Detect ( $\overline{DCD}$ ), Bit 2

The  $\overline{DCD}$  bit will be "1" when the  $\overline{DCD}$  input from a modem has gone "High" to indicate that a carrier is not present. This bit going "1" causes an Interrupt Request to be generated when the Receive Interrupt Enable is set. It remains "1" after the  $\overline{DCD}$  input is returned "Low" until cleared by first reading the Status Register and then the Data Register or until a master reset occurs. If the  $\overline{DCD}$  input remains "High" after read status and read data or master reset has occurred, the interrupt is cleared, and the  $\overline{DCD}$  status bit remains "1" and will follow the  $\overline{DCD}$  input.

#### Clear-to-Send (CTS), Bit 3

The CTS bit indicates the state of the CTS input from a modem. A "Low" CTS input indicates that there is a CTS from the modem. In the "High" state, the Transmit Data Register Empty bit is inhibited and the CTS status bit will be "1". Master reset does not affect the Clear-to-Send Status bit.

#### Framing Error (FE), Bit 4

FE flag indicates that the received character is improperly framed by a start and a stop bit and is detected by the absence of the 1st stop bit. This error indicates a synchronization error, faulty transmission, or a break condition. The FE flag is set or reset during the receive data transfer time. Therefore, this error indicator is present throughout the time that the associated character is available.

#### Receiver Overrun (OVRN), Bit 5

Overrun is an error flag that indicates that one or more characters in the data stream were lost. That is, a character or a number of characters were received but not read from the Receive Data Register (RDR) prior to subsequent characters being received. The overrun condition begins at the midpoint of the last bit of the second character received in succession without a read of the RDR having occurred. The overrun does not occur in the Status Register until the valid character prior to Overrun has been read. The RDRF bit remains set until the Overrun is reset. Character synchronization is maintained during the Overrun condition. The Overrun indication is reset after the reading of data from the Receive Data Register or by a Master Reset.

**Parity Error (PE), Bit 6**

The PE flag indicates that the number of "1's (highs) in the character does not agree with the preselected odd or even parity. Odd parity is defined to be when the total number of ones is odd. The parity error indication will be present as long as the data character is in the RDR. If no parity is selected, then both the transmitter parity generator output and the receiver parity check results are inhibited.

**Interrupt Request (IRQ), Bit 7**

The IRQ bit indicates the state of the IRQ output. Any interrupt condition with its applicable enable will be indicated in this status bit. Anytime the IRQ output is "Low" the IRQ bit will be "1" to indicate the interrupt or service request status. IRQ is cleared by a read operation to the Receive Data Register or a write operation to the Transmit Data Register. (Refer to Figure 14.)

**■ SIGNAL FUNCTIONS****● Interface Signal for MPU****Bi-Directional Data Bus (D<sub>0</sub>~D<sub>7</sub>)**

The bi-directional data bus (D<sub>0</sub>~D<sub>7</sub>) allow for data transfer between the ACIA and the MPU. The data bus output drivers are three-state devices that remain in the high impedance (off) state except when the MPU performs an ACIA read operation.

**Enable (E)**

The Enable signal, E, is a high impedance TTL compatible input that enables the bus input/output data buffers and clocks data to and from the ACIA. This signal will normally be a derivative of the HMC6800 φ<sub>2</sub> Clock. The ACIA accepts both continuous pulse signal and strobe type signal as Enable input.

**Read/Write (R/W)**

The R/W line is a high impedance input that is TTL compatible and is used to control the direction of data flow through the ACIA's input/output data bus interface. When R/W is "High" (MPU Read cycle), ACIA output drivers are turned on and a selected register is read. When it is "Low", the ACIA output drivers are turned off and the MPU writes into a selected register. Therefore, the R/W signal is used to select read-only or write-only registers within the ACIA.

**Chip Select (CS<sub>0</sub>, CS<sub>1</sub>, CS<sub>2</sub>)**

These three high impedance TTL compatible input lines are used to address the ACIA. The ACIA is selected when CS<sub>0</sub> and CS<sub>1</sub> are "High" and CS<sub>2</sub> is "Low". Transfers of data to and from the ACIA are then performed under the control of the Enable signal, Read/Write, and Register Select.

**Register Select (RS)**

The RS line is a high impedance input that is TTL compatible. A "High" level is used to select the Transmit/Receive Data Registers and a "Low" level the Control/Status Registers. The R/W signal line is used in conjunction with Register Select to select the read-only or write-only register in each register pair.

**Interrupt Request (IRQ)**

IRQ is a TTL compatible, open-drain (no internal pullup), active "Low" output that is used to interrupt the MPU. The IRQ output remains "Low" as long as the cause of the interrupt

is present and the appropriate interrupt enable within the ACIA is set.

**Clock Inputs**

Separate high impedance TTL compatible inputs are provided for clocking of transmitted and received data. Clock frequencies of 1, 16 or 64 times the data rate may be selected.

**Transmit Clock (Tx CLK)**

The Tx CLK input is used for the clocking of transmitted data. The transmitter initiates data on the negative transition of the clock.

**Receive Clock (Rx CLK)**

The Rx CLK input is used for synchronization of received data. (In the ÷ 1 mode, the clock and data must be synchronized externally.) The receiver samples the data on the positive transition of the clock.

**● Serial Input/Output Lines****Receive Data (Rx Data)**

The Rx Data line is a high impedance TTL compatible input through which data is received in a serial format. Synchronization with a clock for detection of data is accomplished internally when clock rates of 16 or 64 times the bit rate are used. Data rates are in the range of 0 to 500 kbps when external synchronization is utilized.

**Transmit Data (Tx Data)**

The Tx Data output line transfers serial data to a modem or other peripheral. Data rates in the range of 0 to 500 kbps when external synchronization is utilized.

**Modem Control**

The ACIA includes several functions that permit limited control of a peripheral or modem. The functions included are CTS, RTS and DCD.

**Clear-to-Send (CTS)**

This high impedance TTL compatible input provides automatic control of the transmitting end of a communications link via the modem CTS active "Low" output by inhibiting the Transmit Data Register Empty (TDRE) status bit. (Refer to Figure 15.)

**Request-to-Send (RTS)**

The RTS output enables the MPU to control a peripheral or modem via the data bus. The RTS output corresponds to the state of the Control Register bits CR5 and CR6. When CR6=0 or both CR5 and CR6=1, the RTS output is "Low" (the active state). This output can also be used for Data Terminal Ready (DTR). (Refer to Figure 15.)





Figure 15 RTS and CTS Timing Chart (Example of 2 bytes transmission)

**Data Carrier Detect ( $\overline{DCD}$ )**

$\overline{DCD}$  is the input signal corresponding to the “carrier detect” signal which shows carrier detect of modem.

$\overline{DCD}$  signal is used to control the receiving operation. When  $\overline{DCD}$  input goes “High”, ACIA stops all the receiving operation and sets receiving part in reset status. It means that receive shift register stops shifting, error detection circuit and synchronization circuit of receive clock are reset. When  $\overline{DCD}$  is in “High” level, the receiving part of ACIA is kept in initial

status and the operation in the receiving part is prohibited. When  $\overline{DCD}$  goes “Low”, the receiving part is allowed to receive data. In this case, the following process is needed to reset  $\overline{DCD}$  flag and restarts the receive operation. (Refer to Figure 16.)

- (1) Return  $\overline{DCD}$  input from “High” to “Low”.
- (2) Read status register. ( $\overline{DCD}$  flag = “1”)
- (3) Read receive data register (Uncertain data will be read.)

Figure 16  $\overline{DCD}$  Flag Timing Chart**■ Note for Use (HD6350 only)**

Input Signal, which is not necessary for user's application, should be used fixed to “High” or “Low” level. This is

applicable to the following signal pins.

Rx Data, Rx CLK, Tx CLK, CTS,  $\overline{DCD}$



# HD6852, HD68A52

## SSDA (Synchronous Serial Data Adapter)

The HD6852 Synchronous Serial Data Adapter provides a bi-directional serial interface for synchronous data information interchange. It contains interface logic for simultaneously transmitting and receiving standard synchronous communications characters in bus organized systems such as the HMCS6800 Microprocessor systems.

The bus interface of the HD6852 includes select, enable, read/write, interrupt, and bus interface logic to allow data transfer over an 8-bit bi-directional data bus. The parallel data of the bus system is serially transmitted and received by the synchronous data interface with synchronization, fill character insertion/deletion, and error checking. The functional configuration of the SSDA is programmed via the data bus during system initialization.

Programmable control registers provide control for variable word length, transmit control, receive control, synchronization control and interrupt control. Status, timing and control lines provide peripheral or modem control.

Typical applications include data communications terminals, floppy disk controllers, cassette or cartridge tape controllers and numerical control systems.

### ■ FEATURES

- Programmable Interrupts from Transmitter, Receiver, and Error Detection Logic
- Character Synchronization on One or Two Sync Codes
- External Synchronization Available for Parallel-Serial Operation
- Programmable Sync Code Register
- Up to 1Mkbps Transmitter
- Peripheral/Modem Control Functions
- Three Bytes of FIFO Buffering on Both Transmit and Receive
- 6, 7, or 8 Bit Data Transmission
- Optional Even and Odd Parity
- Parity, Overrun, and Underflow Status
- Compatible with MC6852 and MC68A52

HD6852P, HD68A52P



(DP-24)

### ■ PIN ARRANGEMENT



(Top View)

### ■ BLOCK DIAGRAM



**HITACHI**

### ■ ABSOLUTE MAXIMUM RATINGS

| Item                  | Symbol     | Value       | Unit |
|-----------------------|------------|-------------|------|
| Supply Voltage        | $V_{CC}^*$ | -0.3 ~ +7.0 | V    |
| Input Voltage         | $V_{IN}^*$ | -0.3 ~ +7.0 | V    |
| Operating Temperature | $T_{opr}$  | -20 ~ +75   | °C   |
| Storage Temperature   | $T_{stg}$  | -55 ~ +150  | °C   |

\* With respect to  $V_{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        | $V_{CC}^*$ | 4.75 | 5.0 | 5.25     | V    |
| Input Voltage         | $V_{IL}^*$ | -0.3 | —   | 0.8      | V    |
|                       | $V_{IH}^*$ | 2.0  | —   | $V_{CC}$ | V    |
| Operating Temperature | $T_{opr}$  | -20  | 25  | 75       | °C   |

\* With respect to  $V_{SS}$  (SYSTEM GND)

### ■ ELECTRICAL CHARACTERISTICS

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

| Item                                     | Symbol                                                                                                                             | Test Condition | min                                                         | typ* | max | Unit        |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------------------------------|------|-----|-------------|
| Input "High" Voltage                     | All Input                                                                                                                          | $V_{IH}$       | 2.0                                                         | —    | —   | V           |
| Input "Low" Voltage                      | All Input                                                                                                                          | $V_{IL}$       | -0.3                                                        | —    | 0.8 | V           |
| Output "High" Voltage                    | $D_0 \sim D_7$                                                                                                                     | $V_{OH}$       | $I_{OH} = -205 \mu A$ ,<br>$PW_{EH}, PW_{EL} \leq 25 \mu s$ | 2.4  | —   | V           |
|                                          | Tx Data<br>$\overline{DTR}, TUF$                                                                                                   | $V_{OH}$       | $I_{OH} = -100 \mu A$ ,<br>$PW_{EH}, PW_{EL} \leq 25 \mu s$ | 2.4  | —   | V           |
| Output "Low" Voltage                     | All Output                                                                                                                         | $V_{OL}$       | $I_{OL} = 1.6 mA$ ,<br>$PW_{EH}, PW_{EL} \leq 25 \mu s$     | —    | —   | 0.4 V       |
| Input Leakage Current                    | TxCLK, RxCLK,<br>Rx Data, E,<br>$\overline{RES}, \overline{RS}, \overline{R/W}$<br>$\overline{CS}, \overline{DCD}, \overline{CTS}$ | $I_{in}$       | $V_{in} = 0 \sim 5.25V$                                     | -2.5 | —   | $2.5 \mu A$ |
| Three-State Input Current<br>(Off State) | $D_0 \sim D_7$                                                                                                                     | $I_{TSI}$      | $V_{in} = 0.4 \sim 2.4V$ ,<br>$V_{CC} = 5.25V$              | -10  | —   | $10 \mu A$  |
| Output Leakage Current<br>(Off State)    | $\overline{IRO}$                                                                                                                   | $I_{LOH}$      | $V_{OH} = 2.4V$                                             | —    | —   | $10 \mu A$  |
| Power Dissipation                        |                                                                                                                                    | $P_D$          |                                                             | —    | 300 | 525 mW      |
| Input Capacitance                        | $D_0 \sim D_7$                                                                                                                     | $C_{in}$       | $V_{in} = 0V$ ,<br>$T_a = 25^\circ C$ ,<br>$f = 1 MHz$      | —    | —   | 12.5 pF     |
|                                          | RxDATA, RxCLK,<br>TxCLK, RES,<br>$\overline{CS}, \overline{RS}, \overline{R/W}, E$ ,<br>$\overline{DCD}, \overline{CTS}$           |                |                                                             | —    | —   | 7.5 pF      |
| Output Capacitance                       | TxDATA, $\overline{DTR}, TUF$ ,                                                                                                    | $C_{out}$      | $V_{in} = 0V, T_a = 25^\circ C$                             | —    | —   | 10 pF       |
|                                          | $\overline{IRO}$                                                                                                                   |                | $f = 1 MHz$                                                 | —    | —   | 5.0 pF      |

\*  $T_a = 25^\circ C$ ,  $V_{CC} = 5V$



• AC CHARACTERISTICS ( $V_{CC}=5V\pm5\%$ ,  $V_{SS}=0V$ ,  $T_a=-20\sim+75^{\circ}C$ , unless otherwise noted.)

1. TIMING OF THE DATA TRANSFER

| Item                                | Symbol     | Test Condition | HD6852 |     |      | HD68A52 |     |       | Unit    |
|-------------------------------------|------------|----------------|--------|-----|------|---------|-----|-------|---------|
|                                     |            |                | min    | typ | max  | min     | typ | max   |         |
| Clock "Low" Pulse Width             | $PW_{CL}$  | Fig. 1         | 700    | —   | —    | 400     | —   | —     | ns      |
| Clock "High" Pulse Width            | $PW_{CH}$  | Fig. 2         | 700    | —   | —    | 400     | —   | —     | ns      |
| Clock Frequency                     | $f_C$      |                | —      | —   | 600  | —       | —   | 1,000 | kHz     |
| Receive Data Setup Time             | $t_{RDSD}$ | Fig. 3         | 350    | —   | —    | 200     | —   | —     | ns      |
| Receive Data Hold Time              | $t_{RDH}$  | Fig. 3         | 350    | —   | —    | 200     | —   | —     | ns      |
| Sync Match Delay Time               | $t_{SM}$   | Fig. 3         | —      | —   | 1.0  | —       | —   | 0.666 | $\mu s$ |
| Clock-to-Data Delay for Transmitter | $t_{TDD}$  | Fig. 4,6       | —      | —   | 1.0  | —       | —   | 0.666 | $\mu s$ |
| Transmitter Underflow               | $t_{TUF}$  | Fig. 4         | —      | —   | 1.0  | —       | —   | 0.666 | $\mu s$ |
| DTR Delay Time                      | $t_{DTR}$  | Fig. 5         | —      | —   | 1.0  | —       | —   | 0.666 | $\mu s$ |
| IRQ Release Time                    | $t_{IR}$   | Fig. 5         | —      | —   | 1.2  | —       | —   | 0.8   | $\mu s$ |
| RES Pulse Width                     | $t_{RES}$  |                | 1.0    | —   | —    | 0.666   | —   | —     | $\mu s$ |
| CTS Setup Time                      | $t_{CTS}$  | Fig. 6         | 200    | —   | —    | 150     | —   | —     | ns      |
| DCD Setup Time                      | $t_{DCD}$  | Fig. 7         | 500    | —   | —    | 350     | —   | —     | ns      |
| Input Rise and Fall Times(Except E) | $t_r, t_f$ | 0.8V to 2.0V   | —      | —   | 1.0* | —       | —   | 1.0*  | $\mu s$ |

\* 1.0 $\mu s$  or 10% of the pulse width, whichever is smaller.

2. BUS TIMING

1) READ

| Item                                                            | Symbol           | Test Condition | HD6852 |     | HD68A52 |     | Unit    |
|-----------------------------------------------------------------|------------------|----------------|--------|-----|---------|-----|---------|
|                                                                 |                  |                | min    | max | min     | max |         |
| Enable Cycle Time                                               | $t_{cycE}$       | Fig. 8         | 1.0    | —   | 0.666   | —   | $\mu s$ |
| Enable "High" Pulse Width                                       | $PW_{EH}$        |                | 0.45   | 25  | 0.28    | 25  | $\mu s$ |
| Enable "Low" Pulse Width                                        | $PW_{EL}$        |                | 0.43   | —   | 0.28    | —   | $\mu s$ |
| Setup Time, Address and R/W valid to Enable positive transition | $t_{AS}$         |                | 140    | —   | 140     | —   | ns      |
| Data Delay Time                                                 | $t_{DDR}$        |                | —      | 320 | —       | 220 | ns      |
| Data Hold Time                                                  | $t_H$            |                | 10     | —   | 10      | —   | ns      |
| Address Hold Time                                               | $t_{AH}$         |                | 10     | 80  | 10      | 80  | ns      |
| Rise and Fall Time for Enable input                             | $t_{Er}, t_{Ef}$ |                | —      | 25  | —       | 25  | ns      |

2) WRITE

| Item                                                            | Symbol           | Test Condition | HD6852 |     | HD68A52 |     | Unit    |
|-----------------------------------------------------------------|------------------|----------------|--------|-----|---------|-----|---------|
|                                                                 |                  |                | min    | max | min     | max |         |
| Enable Cycle Time                                               | $t_{cycE}$       | Fig. 9         | 1.0    | —   | 0.666   | —   | $\mu s$ |
| Enable Pulse Width, "High"                                      | $PW_{EH}$        |                | 0.45   | 25  | 0.28    | 25  | $\mu s$ |
| Enable Pulse Width, "Low"                                       | $PW_{EL}$        |                | 0.43   | —   | 0.28    | —   | $\mu s$ |
| Setup Time, Address and R/W valid to Enable positive transition | $t_{AS}$         |                | 140    | —   | 140     | —   | ns      |
| Data Setup Time                                                 | $t_{DSW}$        |                | 195    | —   | 80      | —   | ns      |
| Data Hold Time                                                  | $t_H$            |                | 10     | —   | 10      | —   | ns      |
| Address Hold Time                                               | $t_{AH}$         |                | 10     | —   | 10      | —   | ns      |
| Rise and Fall Time for Enable input                             | $t_{Er}, t_{Ef}$ |                | —      | 25  | —       | 25  | ns      |





Figure 1 Clock Pulse Width ("Low" level)



Figure 2 Clock Pulse Width ("High" level)



Figure 3 Receive Data Setup and Hold Times and Sync Match Delay Time



Figure 4 Transmit Data Output Delay and Transmitter Underflow Delay Time



\* IRQ Release Time applied to TxData FIFO write operation and RxData FIFO read operation.

\*\* IRQ Release Time applied to write "1" operation to RxRS, TxRS,

CTUF, Clear CTS bits.

Figure 5 DTR and IRQ Release Time



Figure 6 CTS Setup Time

## Notes:

- ① Must occur before  $\overline{DCD}$  goes low.
- ② First data bit placed in Rx shift register.
- ③ Last data bit of byte placed in Rx shift register.
- ④ Rx Data byte transferred from shift register to Rx FIFO.
- ⑤ Clock edge required for generation of IRQ by RDA status.

Note: Refer to Figure 3 for the Rx Data setup and hold times.



Figure 7 DCD Setup Time



Figure 10 Test Loads

## ■ DEVICE OPERATION

At the bus interface, the SSDA appears as two addressable memory locations. Internally, there are seven registers: two read-only and five write-only registers. The read-only registers are Status and Receive Data; the write-only registers are Control 1, Control 2, Control 3, Sync Code and Transmit Data. The serial interface consists of serial input and output lines with independent clocks, and four peripheral/modem control lines.

Data to be transmitted is transferred directly into the 3-byte Transmit Data First-In First-Out (FIFO) Register from the data bus. Availability of the input to the FIFO is indicated by a bit in the Status Register; once data is entered, it moves through the FIFO to the last empty location. Data at the output of the FIFO is automatically transferred from the FIFO to the Transmitter Shift Register as the shift register becomes available to transmit the next character. If data is not available from the FIFO (underflow condition), the Transmitter Shift Register is automatically loaded with either a sync code or an all "1"s character. The transmit section may be programmed to append even, odd, or no parity to the transmitted word. An external control line (CTS) is provided to inhibit the transmitter without clearing the FIFO.

Serial data is accumulated in the receiver based on the synchronization mode selected. In the external sync mode used for parallel-serial operation, the receiver is synchronized by the

Data Carrier Detect (DCD) input and transfers successive bytes of data to the input of the Receiver FIFO. The single-sync-character mode requires that a match occur between the Sync Code Register and one incoming character before data transfer to the FIFO begins. The two-sync-character mode requires that two sync codes be received in sequence to establish synchronization. Subsequent to synchronization in any mode, data is accumulated in the shift register, and parity is optionally checked. An indication of parity error is carried through the Receiver FIFO with each character to the last empty location. Availability of a word at the FIFO output is indicated by a bit in the Status Register, as is a parity error.

The SSDA and its internal registers are selected by the address bus, Read/Write (R/W) and Enable control lines. To configure the SSDA, Control Registers are selected and the appropriate bits set. The Status Register is addressable for reading status.

Other I/O lines, in addition to Clear-to-Send (CTS) and Data Carrier Detect (DCD), include Sync Match/Data Terminal Ready (SM/DTR) and Transmitter Underflow (TUF). The transmitter and receiver each have individual clock inputs allowing simultaneous operation under separate clock control. Signals to the microprocessor are the Data bus and Interrupt Request (IRQ).



#### ● Initialization

During a power-on sequence, the SSDA is reset via the **RES** input and internally latched in a reset condition to prevent erroneous output transmissions. The Sync Code Register, Control Register 2, and Control Register 3 should be programmed prior to the programmed release of the Transmitter and/or Receiver Reset bits; these bits in Control Register 1 should be cleared after the RES line has gone "High".

#### ● Transmitter Operation

Data is transferred to the transmitter section in parallel form by means of the data bus and Transmit Data FIFO. The Transmit Data FIFO is a 3-byte register whose status is indicated by the Transmitter Data Register Available status bit (TDRA) and its associated interrupt enable bit. Data is transferred through the FIFO on negative edges of Enable (E) pulses. Two data transfer modes are provided in the SSDA. The 1-byte transfer mode provides for writing data to the transmitter section (and reading from the receiver section) one byte at a time. The 2-byte transfer mode provides for writing two data characters in succession.

Data will automatically transfer from the last register location in the Transmit Data FIFO (when it contains data) to the Transmitter Shift Register during the last half of the last bit of the previous character. A character is transferred into the Shift Register by the Transmitter Clock. Data is transmitted LSB first, and odd or even parity can be optionally appended. The unused bit positions in short word length characters from the data bus are "don't cares". (Note: The data bus inputs may be reversed for applications requiring the MSB to be transferred taken, e.g., IBM format for floppy disks; however, care must be taken to properly program the control registers — Table 1 will have its bit positions reversed.)

When the Shift Register becomes empty, and data is not available for transfer from the Transmit Data FIFO, an "underflow" occurs, and a character is inserted into the transmitter data stream to maintain character synchronization. The character transmitted on underflow will be either a "Mark" (all "1's") or the contents of the Sync Code Register, depending upon the state of the Transmit Sync Code on Underflow control bit. The underflow condition is indicated by a pulse ( $\approx$  Tx CLK "High" period) on the Underflow putput (when in Tx Sync on underflow mode). The Underflow output occurs coincident with the transfer of the last half of the last bit preceding the underflow character. The Underflow status bit is set until cleared by means of the Clear Underflow control bit. This output may be used in floppy disk systems to synchronize write operations and for appending CRCC.

Transmission is initiated by clearing the Transmitter Reset bit in Control Register 1. When the Transmitter Reset bit is cleared, the first full positive half-cycle of the Transmit Clock will initiate the transmit cycle, with the transmission of data or underflow characters beginning on the negative edge of the Transmit Clock pulse which started the cycle. If the Transmit Data FIFO was not loaded, an underflow character will be transmitted.

The Clear-to-Send (**CTS**) input provides for automatic control of the transmitter by means of external system hardware; e.g., the modem CTS output provides the control in a data communications system. The CTS input resets and inhibits the transmitter section when "High", but does not reset the Transmit Data FIFO. The TDRA status bit is inhibited by CTS being "High" in either the one-sync character or two-sync-character mode of operation.

In the external sync mode, TDRA is unaffected by CTS in order to provide Transmit Data FIFO status for preloading and operating the transmitter under the control of the CTS input. When the Transmitter Reset bit (Tx RS) is set, the Transmit Data FIFO is cleared and the TDRA status bit is cleared. After one E clock has occurred, the Transmit Data FIFO becomes available for new data with TDRA inhibited.

#### ● Receiver Operation

Data and a presynchronized clock are provided to the SSDA receiver section by means of the Receive Data (Rx Data) and Receive Clock (Rx CLK) inputs. The data is a continuous stream of binary data bits without means for identifying character boundaries within the stream. It is, therefore, necessary to achieve character synchronization for the data at the beginning of the data block. Once synchronization is achieved, it is assumed to be retained for all successive characters within the block.

Data communications systems utilize the detection of sync codes during the initial portion of the preamble to establish character synchronization. This requires the detection of a single code or two successive sync codes. Floppy disk and cartridge tape units require sixteen bits of defined preamble and cassettes require eight bits of preamble to establish the reference for the start of record. All three are functionally equivalent to the detection of sync codes. Systems which do not utilize code detection techniques require custom logic external to the SSDA for character synchronization and use of the parallel-to-serial (external sync) mode.

(Note: The Receiver Shift Register is set to ones when reset)

#### ● Synchronization

The SSDA provides three operating modes with respect to character synchronization: one-sync-character mode, two-sync-character mode, and external sync mode. The external sync mode requires synchronization and control of the receiving section through the Data Carrier Detect (DCD) input. This external synchronization could consist of direct line control from the transmitting end of the serial data link or from external logic designed to detect the start of the message block. The one-sync-character mode searches on a bit-by-bit basis until a match is achieved between the data in the Shift Register and the Sync Code Register. The match indicates character synchronization is complete and will be retained for the message block. In the two-sync-character mode, the receiver searches for the first sync code match on a bit-by-bit basis and then looks for a second successive sync code character prior to establishing character synchronization. If the second sync code character is not received, the bit-by-bit search for the first sync code is resumed.

Sync codes received prior to the completion of synchronization (one or two character) are not transferred to the Receive Data FIFO. Redundant sync codes during the preamble or sync codes which occur as "fill characters" can automatically be stripped from the data, when the Strip Sync control bit is set, to minimize system loading. The character synchronization will be retained until cleared by means of the Clar Sync bit, which also inhibits synchronization search when set.

#### ● Receiving Data

Once synchronization has been achieved, subsequent characters are automatically transferred into the Receive Data FIFO and clocked through the FIFO to the last empty location by E pulses (MPU System  $\phi_2$ ). The Receiver Data Available status bit



(RDA) indicates when data is available to be read from the last FIFO location (#3) when in the 1-byte transfer mode. The 2-byte transfer mode causes the RDA status bit to indicate data is available when the last two FIFO register locations are full. Data being available in the Receive Data FIFO causes an interrupt request if the Receiver Interrupt Enable (RIE) bit is set. The MPU will then read the SSDA Status Register, which will indicate that data is available for the MPU read from the Receiver Data FIFO register. The  $\overline{IRQ}$  and RDA status bits are reset by a read from the FIFO. If more than one character has been received and is resident in the Receive Data FIFO, subsequent E clocks will cause the FIFO to update and the RDA and  $\overline{IRQ}$  status bits will again be set. The read data operation for the 2-byte transfer mode requires an intervening E clock between reads to allow the FIFO data to shift. Optional parity is automatically checked as data is received, and the parity status condition is maintained with each character until the data is read from the Receive Data FIFO. Parity errors will cause an interrupt request if the Error Interrupt Enable (EIE) has been set. The parity bit is not transferred to the data bus but must be checked in the Status Register. NOTE: In the 2-byte transfer mode, parity should be checked prior to reading the second byte, since a FIFO read clears the error bit.

Other status bits which pertain to the receiver section are Receiver Overrun and Data Carrier Detect (DCD). The Overrun status bit is automatically set when a transfer of a character to the Receive Data FIFO occurs and the first register of the Receive Data FIFO is full. Overrun causes an interrupt if Error Interrupt Enable (EIE) has been set. The transfer of the overrunning character into the FIFO causes the previous character in the FIFO input register location to be lost. The Overrun status bit is cleared by reading the Status Register (when the overrun condition is present), followed by a Receive Data FIFO Register read. Overrun cannot occur and be cleared without providing an opportunity to detect its occurrence via the Status Register.

A positive transition on the  $\overline{DCD}$  input causes an interrupt if the EIE control bit has been set. The interrupt caused by  $\overline{DCD}$  is cleared by reading the Status Register when the DCD status bit is "1", followed by a Receive Data FIFO read. The DCD status bit will subsequently follow the state of the  $\overline{DCD}$  input when it goes "Low".

## ■ SSDA REGISTERS

Seven registers in the SSDA can be accessed by means of the bus. The registers are defined as read-only or write-only according to the direction of information flow. The Register Select (RS) input selects two registers in each state, one being read-only and the other write-only. The Read/Write (R/W) input defined which of the two selected registers will actually be accessed. Four registers (two read-only and two write-only) can be addressed via the bus at any particular time. These registers and the required addressing are defined in Table 1.

### ● Control Register 1 (C1)

Control Register 1 is an 8-bit write-only register that can be directly addressed from the data bus. Control Register 1 is addressed when RS = "Low" and R/W = "Low".

### Receiver Reset (Rx Rs), C1 Bit 0

The Receiver Reset control bit provides both a reset and inhibit function to the receiver section. When Rx Rs is set, it clears the receiver control logic, error logic, Rx Data FIFO

Control, Parity Error status bit, and  $\overline{DCD}$  interrupt. The Receiver Shift Register is set ones. The Rx Rs bit must be cleared after the occurrence of a "Low" level on RES in order to enable the receiver section of the SSDA.

### Transmitter Reset (Tx Rs), C1 Bit 1

The Transmitter Reset control bit provides both a reset and inhibit to the transmitter section. When Tx Rs is set, it clears the transmitter control section, Transmitter Shift Register, Tx Data FIFO Control (the Tx Data FIFO can be reloaded after one E clock pulse), the Transmitter Underflow status bit, and the  $\overline{CTS}$  interrupt, and inhibits the TDRA status bit (in the one-sync-character and two-sync-character modes). The Tx Rs bit must be cleared after the occurrence of a "Low" level on RES in order to enable the transmitter section of the SSDA. If the Tx FIFO is not preloaded, it must be loaded immediately after the Tx Rs release to prevent a transmitter underflow condition.

### Strip Synchronization Characters (Strip Sync), C1 Bit 2

If the Strip Sync bit is set, the SSDA will automatically strip all received characters which match the contents of the Sync Code Register. The characters used for synchronization (one or two characters of sync) are always stripped from the received data stream.

### Clear Synchronization (Clear Sync), C1 Bit 3

The Clear Sync control bit provides the capability of dropping receiver character synchronization and inhibiting resynchronization. The Clear Sync bit is set to clear and inhibit receiver synchronization in all modes and is reset to zero to enable resynchronization.

### Transmitter Interrupt Enable (TIE), C1 Bit 4

TIE enable both the Interrupt Request ( $\overline{IRQ}$ ) output and Interrupt Request status bit to indicate a transmitter service request. When TIE is set and the TDRA status bit is "1", the  $\overline{IRQ}$  output will go "Low" (the active state) and the  $\overline{IRQ}$  status bit will go "1".

### Receiver Interrupt Enable (RIE), C1 Bit 5

RIE enable both the Interrupt Request output ( $\overline{IRQ}$ ) and the Interrupt Request status bit to indicate a receiver service request. When RIE is set and the RDA status bit is "1", the  $\overline{IRQ}$  output will go "Low" (the active state) and the  $\overline{IRQ}$  status bit will go "1".

### Address Control 1 (AC1) and Address Control 2 (AC2), C1 Bits 6 and 7

AC1 and AC2 select one of the write-only registers – Control 2, Control 3, Sync Code, or Tx Data FIFO – as shown in Table 1, when RS = "High" and R/W = "Low".

### ● Control Register 2 (C2)

Control Register 2 is an 8-bit write-only register which can be programmed from the bus when the Address Control bits in Control Register 1 (AC1 and AC2) are reset, RS = "High" and R/W = "Low".

### Peripheral Control 1 (PC1) and Peripheral Control 2 (PC2), C2 Bits 0 and 1

Two control bits, PC1 and PC2, determine the operating characteristics of the Sync Match/DTR output. PC1, when "High", selects the Sync Match mode. PC2 provides the inhibit/



enable control for the SM/DRT output in the Sync Match mode. A one-bit-wide pulse is generated at the output when PC2 is "0", and a match occurs between the contents of the Sync Code Register and the incoming data even if sync is inhibited (Clear Sync bit = "1"). The Sync Match pulse is referenced to the negative edge of Rx CLK pulse causing the match.

The Data Terminal Ready (DTR) mode is selected when PC1 is "0". When PC2 = "1" the SM/DTR output = "Low" and vice versa. The operation of PC2 and PC1 is summarized in Table 4.

#### 1-Byte/2-Byte Transfer (1-Byte/2-Byte), C2 Bit 2

When 1-Byte/2-Byte is set, the TDRA and RDA status bits will indicate the availability if their respective data FIFO registers for a single byte data transfer. Alternately, if 1-Byte/2-Byte is reset, the TDRA and RDA status bits indicate when two bytes of data can be moved without a second status read. An intervening Enable pulse must occur between data transfers.

#### Word Length Selects (WS1, WS2, WS3), C2 Bits 3, 4, 5

Word length Select bits WS1, WS2, and WS3 select word length of 7, 8, or 9 bits including parity as shown in Table 3.

#### Transmit Sync Code on Underflow (Tx Sync), C2 Bit 6

When Tx Sync is set, the transmitter will automatically send a sync character when data is not available for transmission. If Tx Sync is reset, the transmitter will transmit a Mark character (including the parity bit position) on underflow. When the underflow is detected, a pulse approximately a Tx CLK "High" period wide will occur on the underflow output if the Tx Sync bit is "1". Internal parity generation is inhibited during underflow except for sync code fill character transmission in 8 bit plus parity word lengths.

#### Error Interrupt Enable (EIE), C2 Bit 7

When EIE is set, the IRQ status bit will go "1" and the IRQ output will go "Low" if:

- 1) A receiver overrun occurs. The interrupt is cleared by reading the Status Register and reading the Rx Data FIFO.
- 2) DCD input has gone to a "High". The interrupt is cleared by reading the Status Register and reading the Rx Data FIFO.
- 3) A parity error exists for the character in the last location (#3) of the Rx Data FIFO. The interrupt is cleared by reading the Rx Data FIFO. The interrupt is cleared by reading the Rx Data FIFO.
- 4) The CTS input has gone to a "High". The interrupt is cleared by writing a "1" in the Clear CTS bit, C3 bit 2, or by a Tx Reset.
- 5) The transmitter has underflowed (in the Tx Sync on Underflow mode). The interrupt is cleared by writing a "1" into the Clear Underflow, C3 bit 3, or Tx Reset.

When EIE is a "0", the IRQ status bit and the IRQ output are disabled for the above error conditions. A "Low" level on the RES input resets EIE to "0".

#### Control Register 3 (C3)

Control Register 3 is a 4-bit write-only register which can be programmed from the bus when RS = "High" and R/W = "Low" and Address Control bit AC1 = "1" and AC2 = "0".

#### External/Internal Sync Mode Control (E/I Sync), C3 Bit 0

When the E/I Sync Mode bit is "1", the SSDA is in the external sync mode and the receiver synchronization logic is disabled. Synchronization can be achieved by means of the DCD input or by starting Rx CLK at the midpoint of data bit "0" of

a character with DCD "Low". Both the transmitter and receiver sections operate as parallel - serial converters in the External Sync mode. The Clear Sync bit in Control Register 1 acts as a receiver sync inhibit when "High" to provide a bus controllable inhibit. The Sync Code Register can serve as a transmitter fill character register and a receiver match register in this mode. A "Low" on the RES input resets the E/I Sync Mode bit placing the SSDA in the internal sync mode.

#### One-Sync-Character/Two-Sync-Character Mode, Control (Sync/2 Sync), C3 Bit 1

When the 1 Sync/2 Sync bit is set, the SSDA will synchronize on a single match between the received data and the contents of the Sync Code Register. When the 1 Sync/2 Sync bit is reset, two successive sync characters must be received prior to receiver synchronization. If the second sync character is not detected, the bit by bit search resumes from the first bit in the second character. See the description of the Sync Code Register for more details.

#### Clear CTS Status (Clear CTS), C3 Bit 2

When a "1" is written into the Clear CTS bit, the stored status and interrupt are cleared. Subsequently, the CTS status bit reflects the state of the CTS input. The Clear CTS control bit does not affect the CTS input nor its inhibit of the transmitter section. The Clear CTS command bit is self-clearing, and writing a "0" into this bit is a nonfunctional operation.

#### Clear Transmit Underflow Status (CTUF), C3 Bit 3

When a "1" is written into the CTUF status bit, the CTUF bit and its associated interrupt are reset. The CTUF command bit is self-clearing and writing a "0" into this bit is a nonfunctional operation.

#### • Sync Code Register

The Sync Code Register is an 8-bit register for storing the programmable sync code required for received data character synchronization in the one-sync-character and two-sync-character modes. The Sync Code Register also provides for stripping the sync/fill characters from the received data (a programmable option) as well as automatic insertion of fill characters in the transmitted data stream. The Sync Code Register is not utilized for receiver character synchronization in the external sync mode; however, it provides storage of receiver match and transmit fill characters.

The Sync Code Register can be loaded when AC2 and AC1 are a "1" and "0" respectively, and R/W = "Low" and RS = "High".

The Sync Code Register may be changed after the detection of a match with the received data (the first sync code having been detected) to synchronize with a double-word sync pattern. (This sync code change must occur prior to the completion of the second character.) The sync match (SM) output can be used to interrupt the MPU system to indicate that the first eight bits have matched. The service routine would then change the sync match register to the second half of the pattern. Alternately, the one-sync-character mode can be used for sync codes for 16 or more bits by using software to check the second and subsequent bytes after reading them from the FIFO.

The detection of the sync code can be programmed to appear on the Sync Match/DTR output by writing a "1" in PC1 (C2 bit 0) and a "0" in PC2 (C2 bit 1). The Sync Match output will go "High" for one bit time beginning at the character interface between the sync code and the next character.



- Parity for Sync Character Transmitter

Transmitter does not generate parity for the sync character except 9-bit mode.

- 9-bit (8-bit + parity) – 8-bit sync character + parity
- 8-bit (7-bit + parity) – 8-bit sync character (no parity)
- 7-bit (6-bit + parity) – 7-bit sync character (no parity)

- Receiver

#### At Synchronization

Receiver automatically strips the sync character(s) (two sync characters if '2 sync' mode is selected) which is used to establish synchronization. And parity is not checked for these sync characters.

#### After Synchronization is Established

When 'strip sync' bit is selected, the sync characters (fill characters) are stripped and parity is not checked for the stripped sync (fill) characters. When 'strip sync' bit is not selected (0), the sync character is assumed to be normal data and it is transferred into FIFO after parity checking. (When non-parity format is selected, parity is not checked.)

| Strip Sync<br>(C1 Bit 2) | Data Format<br>(C2 Bit 3-5) | Operation                                                  |
|--------------------------|-----------------------------|------------------------------------------------------------|
| 1                        | x                           | No transfer of sync code.<br>No parity check of sync code. |
| 0                        | With Parity                 | *Transfer data and sync codes.<br>Parity check.            |
| 0                        | Without Parity              | *Transfer data and sync codes.<br>No parity check.         |

\* Subsequent to synchronization  
x ..... don't care

It is necessary to pay attention to the selected sync character in the following cases.

- 1) Data format is (6 + parity), (7 + parity),
- 2) Strip sync is not selected ("0").
- 3) After synchronization when sync code is used as a fill character.

Transmitter sends sync character without parity, but receiver checks the parity as if it is normal data. Therefore, the sync character should be chosen to match the parity check selected for the receiver in this special case.

- Receive Data First-In First-Out Register  
(Rx Data FIFO)

The Receive Data FIFO Register consists of three 8-bit registers which are used for buffer storage of received data. Each 8-bit register has an internal status bit which monitors its full or empty condition. Data is always transferred from a full register to an adjacent empty register. The transfer from register to register occurs on E pulses. The RDA status bit will be "1" when data is available in the last location of the Rx Data FIFO.

In an Overrun condition, the overrunning character will be transferred into the full first stage of the FIFO register and will cause the loss of that data character. Successive overruns continue to overwrite the first register of the FIFO. This destruction of data is indicated by means of the Overrun status

bit. The Overrun bit will be set when the overrun occurs and remains set until the Status Register is read, followed by a read of the Rx Data FIFO.

Unused data bits for short word lengths (including the parity bit) will appear as "0's" on the data bus when the Rx Data FIFO is read.

- Transmit Data First-In First-Out Register  
(Tx Data FIFO)

The Transmit Data FIFO Register consists of three 8-bit registers which are used for buffer storage of data to be transmitted. Each 8-bit register has an internal status bit which monitors its full or empty condition. Data is always transferred from a full register to an adjacent empty register. The transfer is clocked by E pulses.

The TDRA status bit will be "High" if the Tx Data FIFO is available for data.

Unused data bits for short word lengths will be handled as "don't cares". The parity bit is not transferred over the data bus since the SSDA generates parity at transmission.

When an Underflow occurs, the Underflow character will be either the contents of the Sync Code Register or an all "1"s character. The underflow will be stored in the Status Register until cleared and will appear on the Underflow output as a pulse approximately a Tx CLK "High" period wide.

- Status Register

The Status Register is an 8-bit read-only register which provides the real-time status of the SSDA and the associated serial data channel. Reading the Status Register is a non-destructive process. The method of clearing status bits depends upon the function each bit represents and is discussed for each bit in the register.

#### Receiver Data Available (RDA), S Bit 0

The Receiver Data Available status bit indicates when receiver data can be read from the Rx Data FIFO. The receiver data being present in the last register (#3) of the FIFO causes RDA to be "1" for the 1-byte transfer mode. The RDA bit being "1" indicates that the last two registers (#2 and #3) are full when in the 2-byte transfer mode. The second character can be read without a second status read (to determine that the character is available). And E pulse must occur between reads of the Rx Data FIFO to allow the FIFO to shift. Status must be read on a word-by-word basis if receiver data error checking is important. The RDA status bit is reset automatically when data is not available.

#### Transmitter Data Register Available (TDRA), S Bit 1

The TDRA status bit indicates that data can be loaded into the Tx Data FIFO Register. The first register (#1) of the Tx Data FIFO being empty will be indicated by a "1" in the TDRA status bit in the 1-byte transfer mode. The first two registers (#1 and #2) must be empty for TDRA to be "1" when in the 2-byte transfer mode. The Tx Data FIFO can be loaded with two bytes without an intervening status read; however, one E pulse must occur between loads. TDRA is inhibited by the Tx Reset or RES. When Tx Reset is set, the Tx Data FIFO is cleared and then released on the next E clock pulse. The Tx Data FIFO can then be loaded with up to three characters of data, even though TDRA is inhibited. This feature allows preloading data prior to the release of Tx Reset. A "High" level on the CTS input inhibits the TDRA status bit in either sync mode of operation (one-sync-character or two-sync-character). CTS does not affect TDRA in the external sync mode. This



enables the SSDA to operate under the control of the CTS input with TDRA indicating the status of the Tx Data FIFO. The CTS input does not clear the Tx Data FIFO in any operating mode.

#### Data Carrier Detect (DCD), S Bit 2

A positive transition on the DCD input is stored in the SSDA until cleared by reading both Status and Rx Data FIFO. A "1" written into Rx Rs also clears the stored DCD status. The DCD status bit, when set, indicates that the DCD input has gone "High". The reading of both Status and Receive Data FIFO allows Bit 2 of subsequent Status reads to indicate the state of the DCD input until the next positive transition.

#### Clear-to-Send (CTS), S Bit 3

A positive transition on the CTS input is stored in the SSDA until cleared by writing a "1" into the Clear CTS control bit or the Tx Rs bit. The CTS status bit, when set, indicates that the CTS input has gone "High". The Clear CTS command (a "1" into C3 Bit 2) allows Bit 3 of subsequent Status reads to indicate the state of the CTS input until the next positive transition.

#### Transmitter Underflow (TUF), S Bit 4

When data is not available for the transmitter, an underflow occurs and is so indicated in the Status Register (in the Tx Sync on underflow mode). The underflow status bit is cleared by writing a "1" into the Clear Underflow (CTUF) control bit or

the Tx Rs bit. TUF indicates that a sync character will be transmitted as the next character. A TUF is indicated on the output only when the contents of the Sync Code Register is to be transferred (transmit sync code on underflow = "1").

#### Receiver Overrun (Rx Ovrn), S Bit 5

Overrun indicates data has been received when the Rx Data FIFO is full, resulting in data loss. The Rx Ovrn status bit is set when Overrun occurs. The Rx Ovrn status bit is cleared by reading Status followed by reading the Rx Data FIFO or by setting the Rx Rs control bit.

#### Receiver Parity Error (PE), S Bit 6

The parity error status bit indicates that parity for the character in the last register of the Rx Data FIFO did not agree with selected parity. The parity error is cleared when the character to which it pertains is read from the Rx Data FIFO or when Rx Rs occurs. The DCD input does not clear the Parity Error or Rx Data FIFO status bits.

#### Interrupt Request (IRQ), S Bit 7

The Interrupt Request status bit indicates when the IRQ output is in the active state (IRQ output = "Low"). The IRQ status bit is subject to the same interrupt enables (RIE, TIE, and EIE) as the IRQ output. The IRQ status bit simplifies status inquiries for polling systems by providing single bit indication of service requests.

Table 1 SSDA Programming Model

| Register              | Control* Inputs |     | Address Control |     | Register Content                 |                                           |                                 |                                    |                                           |                                        |                                                                    |                                                |  |
|-----------------------|-----------------|-----|-----------------|-----|----------------------------------|-------------------------------------------|---------------------------------|------------------------------------|-------------------------------------------|----------------------------------------|--------------------------------------------------------------------|------------------------------------------------|--|
|                       | RS              | R/W | AC2             | AC1 | Bit 7                            | Bit 6                                     | Bit 5                           | Bit 4                              | Bit 3                                     | Bit 2                                  | Bit 1                                                              | Bit 0                                          |  |
| Status (S)            | 0               | 1   | X               | X   | Interrupt Request ( <u>IRQ</u> ) | Receiver Parity Error (PE)                | Receiver Overrun (Rx Ovrn)      | Transmitter Underflow (TUF)        | Clear-to-Send (CTS)                       | Data Carrier Detect (DCD)              | Transmitter Data Register Available (TDRA)                         | Receiver Data Available (RDA)                  |  |
| Control 1 (C1)        | 0               | 0   | X               | X   | Address Control 2 (AC2)          | Address Control 1 (AC1)                   | Receiver Interrupt Enable (RIE) | Transmitter Interrupt Enable (TIE) | Clear Sync                                | Strip Sync Characters (Strip Sync)     | Transmitter Reset (Tx Rs)                                          | Receiver Reset (Rx Rs)                         |  |
| *** Receive Data FIFO | 1               | 1   | X               | X   | D <sub>7</sub>                   | D <sub>6</sub>                            | D <sub>5</sub>                  | D <sub>4</sub>                     | D <sub>3</sub>                            | D <sub>2</sub>                         | D <sub>1</sub>                                                     | D <sub>0</sub>                                 |  |
| Control 2 (C2)        | 1               | 0   | 0               | 0   | Error Interrupt Enable (EIE)     | Transmit Sync Code on Underflow (Tx Sync) | Word Length Select 3 (WS3)      | Word Length Select 2 (WS2)         | Word Length Select 1 (WS1)                | 1-Byte/2-Byte Transfer (1-Byte/2-Byte) | Peripheral Control 2 (PC2)                                         | Peripheral Control 1 (PC1)                     |  |
| Control 3 (C3)        | 1               | 0   | 0               | 1   | Not Used                         | Not Used                                  | Not Used                        | Not Used                           | Clear Transmitter Underflow Status (CTUF) | Clear CTS Status (Clear CTS)           | One-Sync-Character/Two-Sync Character Mode Control (1 Sync/2 Sync) | External/Internal Sync Mode Control (E/I Sync) |  |
| Sync Code ***         | 1               | 0   | 1               | 0   | D <sub>7</sub>                   | D <sub>6</sub>                            | D <sub>5</sub>                  | D <sub>4</sub>                     | D <sub>3</sub>                            | D <sub>2</sub>                         | D <sub>1</sub>                                                     | D <sub>0</sub>                                 |  |
| Transmit Data FIFO    | 1               | 0   | 1               | 1   | D <sub>7</sub>                   | D <sub>6</sub>                            | D <sub>5</sub>                  | D <sub>4</sub>                     | D <sub>3</sub>                            | D <sub>2</sub>                         | D <sub>1</sub>                                                     | D <sub>0</sub>                                 |  |

\* 0 ; "Low" level, 1 ; "High" level

\*\* "FF" should not be used as Sync Code.

\*\*\* When the SSDA is used in applications requiring the MSB of data to be receive and transmitted first, the data bus inputs to the SSDA may be reversed (D<sub>0</sub> to D<sub>7</sub>, etc.). Caution must be used when this is done since the bit positions in this table will be reversed, and the parity should not be selected.



Table 2 Functions of SSDA Register

| Register                | Bit | Symbol        | Function                                                                                                                                                                    |                    |
|-------------------------|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Status Register (S)     | 7   | IRQ           | The IRQ flag is cleared when the source of the IRQ is cleared. The source is determined by the enables in the Control Registers: TIE, RIE, EIE.                             |                    |
|                         | 6   | PE            | When parity error is detected in receive data.                                                                                                                              | Conditions for Set |
|                         | 5   | Rx Ovrrn      | When receive data FIFO overruns.                                                                                                                                            |                    |
|                         | 4   | TUF           | When under flow is occurred in the transmitter.                                                                                                                             |                    |
|                         | 3   | CTS           | When CTS signal rises.                                                                                                                                                      |                    |
|                         | 2   | DCD           | When DCD signal rises.                                                                                                                                                      |                    |
|                         | 1   | TDRA          | 1 Byte Transfer Mode; when the transmit data FIFO (#1) is empty.<br>2 Byte Transfer Mode; when the transmit data FIFO (#1, #2) is empty.                                    |                    |
|                         | 0   | RDA           | 1 Byte Transfer Mode; when the data is received in the receive data FIFO (#3).<br>2 Byte Transfer Mode; when the data is received in the receive data FIFO (#2, #3).        |                    |
|                         |     |               |                                                                                                                                                                             |                    |
| Control Register 1 (C1) | 7   | AC2           | Used to access other registers, as shown Table 1.                                                                                                                           |                    |
|                         | 6   | AC1           |                                                                                                                                                                             |                    |
|                         | 5   | RIE           | When "1", enables interrupt on RDA (S Bit 0).                                                                                                                               |                    |
|                         | 4   | TIE           | When "1", enables interrupt on TDRA (S Bit 1).                                                                                                                              |                    |
|                         | 3   | Clear Sync    | When "1", clears receiver character synchronization.                                                                                                                        |                    |
|                         | 2   | Strip Sync    | When "1", strips all sync codes from the received data stream.                                                                                                              |                    |
|                         | 1   | Tx Rs         | When "1", resets and inhibits the transmitter section.                                                                                                                      |                    |
|                         | 0   | Rx Rs         | When "1", resets and inhibits the receiver section.                                                                                                                         |                    |
|                         |     |               |                                                                                                                                                                             |                    |
| Control Register 2 (C2) | 7   | EIE           | When "1", enables the PE, Rx Ovrrn, TUF, CTS, and DCD interrupt flags (S Bits 6 through 2).                                                                                 |                    |
|                         | 6   | Tx Sync       | When "1", allows sync code contents to be transferred on underflow, and enables the TUF Status bit and output. When "0", an all mark character is transmitted on underflow. |                    |
|                         | 5   | WS3           | Word Length Select                                                                                                                                                          |                    |
|                         | 4   | WS2           |                                                                                                                                                                             |                    |
|                         | 3   | WS1           |                                                                                                                                                                             |                    |
|                         | 2   | 1-Byte/2-Byte | When "1", enables the TDRA and RDA bits to indicate when a 1-byte transfer can occur; when "0", the TDRA and RDA bits indicate when a 2-byte transfer can occur.            |                    |
| Control Register 3 (C3) | 1   | PC2           | SM/DTR Output Control                                                                                                                                                       |                    |
|                         | 0   | PC1           |                                                                                                                                                                             |                    |
|                         | 3   | CTUF          | When "1", clears TUF (S Bit 4), and IRQ if enabled.                                                                                                                         |                    |
|                         | 2   | Clear CTS     | When "1", clears CTS (S Bit 3), and IRQ if enabled.                                                                                                                         |                    |
|                         | 1   | 1-Sync/2-Sync | When "1", selects the one-sync-character mode; when "0", selects the two-sync-character mode.                                                                               |                    |
|                         | 0   | E/I Sync      | When "1", selects the external sync mode; when "0", selects the internal sync mode.                                                                                         |                    |

Table 3 Word Length

| Bit 5<br>WS3 | Bit 4<br>WS2 | Bit 3<br>WS1 | Word Length          |
|--------------|--------------|--------------|----------------------|
| 0            | 0            | 0            | 6 Bits + Even Parity |
| 0            | 0            | 1            | 6 Bits + Odd Parity  |
| 0            | 1            | 0            | 7 Bits               |
| 0            | 1            | 1            | 8 Bits               |
| 1            | 0            | 0            | 7 Bits + Even Parity |
| 1            | 0            | 1            | 7 Bits + Odd Parity  |
| 1            | 1            | 0            | 8 Bits + Even Parity |
| 1            | 1            | 1            | 8 Bits + Odd Parity  |



Table 4 SM/DTR Output Control

| Bit 1<br>PC2 | Bit 0<br>PC1 | SM/DTR Output at Pin 5                                                                                    |
|--------------|--------------|-----------------------------------------------------------------------------------------------------------|
| 0            | 0            | "High" Level*                                                                                             |
| 0            | 1            | Pulse  1-Bit Wide, on SM |
| 1            | 0            | "Low" Level*                                                                                              |
| 1            | 1            | SM Inhibited, "Low"**                                                                                     |

\* OUTPUT level is fixed by the data written into PC2, PC1.

\*\* When "10" or "11", output is fixed at "Low".



#### ■ INTERFACE SIGNALS FOR MPU

The SSDA interfaces to the HD6800 MPU with an 8-bit bi-directional data bus, a chip select line, a register select line, an interrupt request line, read/write line, an enable line, and a reset line. These signals, in conjunction with the HD6800 VMA output, permit the MPU to have complete control over the SSDA.

##### ● Bi-Directional Data Bus ( $D_0 \sim D_7$ )

The bi-directional data bus ( $D_0 \sim D_7$ ) allow for data transfer between the SSDA and the MPU. The data bus output drivers are three-state devices that remain in the high impedance (off) state except when the MPU performs an SSDA read operation.

##### ● Enable (E)

The Enable signal, E, is a high impedance TTL compatible input that enables the bus input/output data buffers, clocks data to and from the SSDA, and moves data through the FIFO Registers. This signal is normally the continuous HMCS6800 System  $\phi 2$  clock, so that incoming data characters are shifted through the FIFO.

##### ● Read/Write (R/W)

The Read/Write line is a high impedance input that is TTL compatible and is used to control the direction of data flow through the SSDA's input/output data bus interface. When Read/Write is "High" (MPU read cycle), SSDA output drivers are turned on if the chip is selected and a selected register is read. When it is "Low", the SSDA output drivers are turned off and the MPU writes into a selected register. The Read/Write signal is also used to select read-only or write-only registers within the SSDA.

##### ● Chip Select (CS)

This high impedance TTL compatible input line is used to address the SSDA. The SSDA is selected when CS is "Low". VMA should be used in generating the CS input to insure that false selects will not occur. Transfers of data to and from the SSDA are then performed under the control of the Enable signal, Read/Write, and Register Select.

##### ● Register Select (RS)

The Register Select line is a high impedance input that is TTL compatible. A "High" level is used to select Control Registers C2 and C3, the Sync Code Register, and the Transmit/Receive Data Registers. A "Low" level selects the Control 1 and Status Registers (see Table 1).

##### ● Interrupt Request (IRQ)

IRQ is a TTL compatible, open-drain (no internal pullup), active "Low" output that is used to interrupt the MPU. The IRQ remains "Low" until cleared by the MPU.

##### ● Reset (RES)

The RES input provides a means of resetting the SSDA from an external source. In the "Low" state, the RES input causes the following:

- 1) Receiver Reset (Rx Rs) and Transmitter Reset (Tx Rs) bits are set causing both the receiver and transmitter sections to be held in a reset condition.
- 2) Peripheral Control bits PC1 and PC2 are reset to zero, causing the SM/DTR output to be "High".
- 3) The Error Interrupt Enable (EIE) bit is reset.
- 4) An internal synchronization mode is selected.
- 5) The Transmitter Data Register Available (TDRA) status bit is cleared and inhibited.

When RES returns "High" (the inactive state), the transmitter and receiver sections will remain in the reset state until the Receiver Reset and Transmitter Reset bits are cleared via the bus under software control. The control Register bits affected by RES (Rx Rs, Tx Rs, PC1, PC2, EIE, and E/I Sync) cannot be changed when RES is "Low".

#### ■ CLOCK INPUTS

Separate high impedance TTL compatible inputs are provided for clocking of transmitted and received data.

##### ● Transmit Clock (Tx CLK)

The Transmit Clock input is used for the clocking of transmitted data. The transmitter shifts data on the negative transition of the clock.

##### ● Receive Clock (Rx CLK)

The Receive Clock input is used for clocking in received data. The clock and data must be synchronized externally. The receiver samples the data on the positive transition of the clock.

#### ■ SERIAL INPUT/OUTPUT LINES

##### ● Receive Data (Rx Data)

The Receive Data line is a high impedance TTL compatible input through which data is received in a serial format. Data rates are from 0 to 600 kbps.

##### ● Transmit Data (Tx Data)

The Transmit Data output line transfers serial data to a modem or other peripheral. Data rates are from 0 to 600 kbps.

#### ■ PERIPHERAL/MODEM CONTROL

The SSDA includes several functions that permit limited control of a peripheral or modem. The functions included are CTS, SM/DTR, DCD, and TUF.

##### ● Clear-to-Send (CTS)

The CTS input provides a real-time inhibit to the transmitter



section (the Tx Data FIFO is not disturbed). A positive CTS transition resets the Tx Shift Register and inhibits the TDRA status bit and its associated interrupt in both the one-sync-character and two-sync-character modes of operation. TDRA is not affected by the CTS input in the external sync mode.

The positive transition of CTS is stored within the SSDA to insure that its occurrence will be acknowledged by the system. The stored CTS information and its associated IRQ (if enabled) are cleared by writing a "1" in the Clear CTS bit. The CTS status bit subsequently follows the CTS input when it goes "Low".

The CTS input provides character timing for transmitter data when in the external sync mode. Transmission is initiated on the negative transition of the first full positive clock pulse of the transmitter clock (Tx CLK) after the release of CTS (see Figure 6).

#### • Data Carrier Detect (DCD)

The DCD input provides a real-time inhibit to the receiver section (the Rx FIFO is not disturbed). A positive DCD transition resets and inhibits the receiver section except for the Receive FIFO and the RDRA status bit and its associated IRQ.

The positive transition of DCD is stored within the SSDA to insure that its occurrence will be acknowledged by the system. The stored DCD information and its associated IRQ (if enabled) are cleared by reading the Status Register and then the Receiver FIFO, or by writing a "1" into the Receiver Reset bit. The DCD status bit subsequently follows the DCD input when it goes "Low". The DCD input provides character synchronization timing for the receiver during the external sync mode of operation. The receiver will be initialized and data will be sampled on the positive transition of the first full Receive Clock

cycle after release of DCD (see Figure 7).

#### • Sync Match/Data Terminal Ready (SM/DTR)

The SM/DTR output provides four functions (see Table 4) depending on the state of the PC1 and PC2 control bits. When the Sync Match mode is selected (PC1 = "1", PC2 = "0"), the output provides a one-bit-wide pulse when a sync code is detected. This pulse occurs for each sync code match even if the receiver has already attained synchronization. The SM output is inhibited when PC2 = "1". The DTR mode (PC1 = "0") provides an output level corresponding to the complement of PC2 (DTR = "0" when PC2 = "1") (see Table 4.)

#### • Transmitter Underflow (TUF)

The Underflow output indicates the occurrence of a transfer of a "fill character" to the Transmitter Shift Register when the last location (#3) in the Transmit Data FIFO is empty. The Underflow output pulse is approximately a Tx CLK "High" period wide and occurs during the last half of the last bit of the character preceding the "Underflow" (see Figure 4). The Underflow output pulse does not occur when the Tx Sync bit is in the reset state.

#### ■ NOTE FOR USAGE

If the hold time of CS signal and R/W signal is within 50~230 ns, there is a case that Transmit Data FIFO is not cleared and TDRA flag is not set when software reset using TxRS (TxRS=1) is executed. Usual program for data transmission will start to send the data as shown in Fig. 11 and Fig. 12.

In this case, the data of the first three bytes are not preset and unexpected data which is remaining in Transmit Data FIFO are sent in the first two bytes.



Figure 11 Normal Flow of Starting the Transmission and Reception



Figure 12 Transmission Start Sequence

In case of SSDA, Address Hold Time should be from 20 to 50 ns or over 230 ns.

#### • DCD Input in External Synchronization Mode

In case of receiving data in External Synchronization Mode, Receive data is put off by one bit at times, when DCD is driven like in RxCLK cycle in which RDA flag is set.





Figure 13 Exceptional External Sync Operation

To avoid this case, use SSDA in the following method.

- (1)  $\overline{DCD}$  and RxCLK should meet the relation shown in Fig. 14.

Figure 14  $\overline{DCD}$  Input Timing in External Sync Mode

- (2) RxData should be input regarding the second RxCLK rise as  $D_0$  bit, after  $\overline{DCD}$ .

# HD46508, HD46508-1, HD46508A, HD46508A-1 ADU (Analog Data Acquisition Unit)

The HD46508 is a monolithic NMOS device with a 10-bit analog-to-digital converter, a programmable voltage comparator, a 16-channel analog multiplexer and HMCS6800 microprocessor family compatible interface.

Each of 16 analog inputs is either converted to a digital data by the analog-to-digital converter or compared with the specified value by the programmable comparator. The analog-to-digital converter uses successive approximation method as the conversion technique. It's intrinsic resolution is 10 bits but it can be 8 bits if the programmer so desires. The programmable voltage comparator compares the input voltage with the value specified by the programmer. The result (greater than, or smaller than) is reflected to the flag in the status register.

The device can expand its capability by controlling the external circuits such as sample holder, pre-amplifier and external multiplexer.

With these features, this device is ideally suited to applications such as process control, machine control and vehicle control.

## ■ FEATURES

- 16-channel Analog multiplexer
- Programmable A/D Converter resolution (10-bit or 8-bit)
- Programmable Voltage comparison (PC)
- Conversion Time 100 $\mu$ s (A/D), 13 $\mu$ s(PC)
- External Sample and Hold Circuit Control
- Auto Range-switching Control of External Amplifier
- Waiting Function for the Settling Time of External Amplifier
- Interrupt Control (Only for A/D conversion)
- Single +5V Power Supply
- Compatible with HMCS6800 Bus (The connection with other Asynchronous Buses possible)

## ■ BLOCK DIAGRAM



## ■ ORDERING INFORMATION

| ADU        | Bus Timing | Non Linearity* |
|------------|------------|----------------|
| HD46508A   | 1 MHz      | $\pm 1$ LSB    |
| HD46508A-1 | 1.5 MHz    |                |
| HD46508    | 1 MHz      | $\pm 3$ LSB    |
| HD46508-1  | 1.5 MHz    |                |

\* Specification for 10 bit A/D conversion



## ■ PIN ARRANGEMENT



(Top View)



"206" : Fixed Data for Auto Range-Switching x 4  
 "410" : Fixed Data for Auto Range-Switching x 2



Figure 1 Internal Block Diagram

**■ ABSOLUTE MAXIMUM RATINGS**

| Item                  | Symbol      | Value       | Unit |
|-----------------------|-------------|-------------|------|
| Supply Voltage        | $V_{CC}^*$  | -0.3 ~ +7.0 | V    |
| Input Voltage         | $V_{IN}^*$  | -0.3 ~ +7.0 | V    |
| Analog Input Voltage  | $V_{AIN}^*$ | -0.3 ~ +7.0 | V    |
| Operating Temperature | $T_{OPR}$   | -20 ~ +75   | °C   |
| Storage Temperature   | $T_{STG}$   | -55 ~ +150  | °C   |

\* With respect to  $V_{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           | $V_{CC}^*$                          | 4.75 | 5.0                | 5.25                    | V    |
| Input "High" Voltage     | $V_{IH}^*$                          | 2.0  | —                  | $V_{CC}$                | V    |
| Input "Low" Voltage      | $V_{IL}^*$                          | -0.3 | —                  | 0.8                     | V    |
| Analog Input Voltage     | $V_{AIN}^*$                         | 0    | —                  | $V_{REF(+)}$            | V    |
| Reference Voltage        | $V_{REF(+)}^*$                      | —    | $V_{CC}$           | $V_{CC}+0.25$           | V    |
|                          | $V_{REF(-)}^*$                      | -0.1 | 0                  | —                       |      |
| Voltage Center of Ladder | $\frac{V_{REF(+)} + V_{REF(-)}}{2}$ | —    | $\frac{V_{CC}}{2}$ | $\frac{V_{CC}+0.25}{2}$ | V    |
| Operating Temperature    | $T_{OPR}$                           | -20  | 25                 | 75                      | °C   |

\*With respect to  $V_{SS}$  (SYSTEM GND)**■ ELECTRICAL CHARACTERISTICS**

- DC CHARACTERISTICS <1> ( $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20 \sim +75^\circ C$ , unless otherwise noted.)

| Item                                     | Symbol                                                                   | Test Condition | min                                                       | typ          | max      | Unit    |
|------------------------------------------|--------------------------------------------------------------------------|----------------|-----------------------------------------------------------|--------------|----------|---------|
| Input "High" Voltage                     | $V_{IH}$                                                                 |                | 2.0                                                       | —            | $V_{CC}$ | V       |
| Input "Low" Voltage                      | $V_{IL}$                                                                 |                | -0.3                                                      | —            | 0.8      | V       |
| Output "High" Voltage                    | $D_0 \sim D_7$                                                           | $V_{OH}$       | $I_{OH} = -205\mu A$                                      | 2.4          | —        | —       |
|                                          | GAINSEL                                                                  |                | $I_{OH} = -200\mu A$                                      | 2.4          | —        | —       |
|                                          |                                                                          |                | $I_{OH} = -10\mu A$                                       | $V_{CC}-1.0$ | —        | —       |
| Output "Low" Voltage                     | $D_0 \sim D_7$ , GAINSEL                                                 | $V_{OL}$       | $I_{OL} = 1.6 \text{ mA}$                                 | —            | —        | 0.4     |
|                                          | $\overline{IRQ}$                                                         |                | $I_{OL} = 3.2 \text{ mA}$                                 | —            | —        | 0.4     |
| Input Leakage Current                    | E, CLK, R/W<br>RES, RS <sub>0</sub> , RS <sub>1</sub><br>$CS_0$ , $CS_1$ | $I_{IN}$       | $V_{IN} = 0 \sim 5.25V$                                   | -2.5         | —        | 2.5     |
| Three-State (off state)<br>Input Current | $D_0 \sim D_7$                                                           | $I_{TSI}$      | $V_{IN} = 0.4 \sim 2.4V$                                  | -10          | —        | 10      |
| Output Leakage Current                   | $\overline{IRQ}$                                                         | $I_{LOH}$      | $V_{OH} = 2.4V$                                           | —            | —        | 10      |
| Power Dissipation                        |                                                                          | $P_D$          |                                                           | —            | —        | 500 mW  |
| Input Capacitance                        | $D_0 \sim D_7$                                                           | $C_{IN}$       |                                                           | —            | —        | 12.5 pF |
|                                          | E, CLK, R/W<br>RES, RS <sub>0</sub> , RS <sub>1</sub><br>$CS_0$ , $CS_1$ |                | $V_{IN} = 0V$ , $T_a = 25^\circ C$<br>$f = 1 \text{ MHz}$ | —            | —        | 10.0 pF |
| Output Capacitance                       | $\overline{IRQ}$ , GAINSEL                                               | $C_{OUT}$      | $V_{IN} = 0V$ , $T_a = 25^\circ C$<br>$f = 1 \text{ MHz}$ | —            | —        | 10.0 pF |



● DC CHARACTERISTICS <2> ( $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20 \sim +75^\circ C$ , unless otherwise noted.)

| Item                                         | Test Condition                                                           | min  | typ | max | Unit       |
|----------------------------------------------|--------------------------------------------------------------------------|------|-----|-----|------------|
| Analog Multiplexer ON Resistance             | $V_{Ain} = 5.0V$ ,<br>$V_{CC} = 4.75V$ , $T_a = 25^\circ C$              | —    | —   | 1   | k $\Omega$ |
| OFF Channel Leakage Current                  | $V_{Ain} = 5.0V$<br>$V_{CC} = 4.75V$ , $T_a = 25^\circ C$<br>COMMON = 0V | —    | 10  | 100 | nA         |
|                                              | $V_{Ain} = 0V$ , $T_a = 25^\circ C$<br>$V_{CC} = 4.75V$ , COMMON = 5V    | -100 | -10 | —   | nA         |
| Analog Multiplexer Input Capacitance         |                                                                          | —    | —   | 7.5 | pF         |
| Ladder Resistance<br>(from REF(+) to REF(-)) | $V_{REF(+)} = 5.0V$<br>$V_{REF(-)} = 0V$ , $T_a = 25^\circ C$            | 10   | —   | 40  | k $\Omega$ |

● CONVERTER SECTION ( $T_a = 25^\circ C$ ,  $V_{CC} = V_{REF(+)} = 5.0V$ ,  $t_{cycC} = 1\mu s$ , unless otherwise noted.)

1. 10-BIT A/D CONVERSION

| Item                  | HD46508A, HD46508A-1 |           |           | HD46508, HD46508-1 |           |           | Unit |
|-----------------------|----------------------|-----------|-----------|--------------------|-----------|-----------|------|
|                       | min                  | typ       | max       | min                | typ       | max       |      |
| Resolution            | —                    | 10        | —         | —                  | 10        | —         | bits |
| Non-linearity Error * | —                    | $\pm 1/2$ | $\pm 1$   | —                  | $\pm 1$   | $\pm 3$   | LSB  |
| Zero-Error            | —                    | $\pm 1/2$ | $\pm 3/4$ | —                  | $\pm 1/2$ | $\pm 1$   | LSB  |
| Full-Scall Error      | —                    | $\pm 1/4$ | $\pm 1/2$ | —                  | $\pm 1/2$ | $\pm 1$   | LSB  |
| Quantization Error    | —                    | —         | $\pm 1/2$ | —                  | —         | $\pm 1/2$ | LSB  |
| Absolute Accuracy *   | —                    | $\pm 1$   | $\pm 3/2$ | —                  | $\pm 2$   | $\pm 4$   | LSB  |

2. 8-BIT A/D CONVERSION

| Item                  | HD46508A, HD46508A-1 |           |           | HD46508, HD46508-1 |           |           | Unit |
|-----------------------|----------------------|-----------|-----------|--------------------|-----------|-----------|------|
|                       | min                  | typ       | max       | min                | typ       | max       |      |
| Resolution            | —                    | 8         | —         | —                  | 8         | —         | bits |
| Non-linearity Error * | —                    | $\pm 1/8$ | $\pm 1/4$ | —                  | $\pm 1/4$ | $\pm 3/4$ | LSB  |
| Zero-Error            | —                    | $\pm 1/4$ | $\pm 3/8$ | —                  | $\pm 3/8$ | $\pm 1/2$ | LSB  |
| Full-Scall Error      | —                    | $\pm 1/4$ | $\pm 3/8$ | —                  | $\pm 3/8$ | $\pm 1/2$ | LSB  |
| Quantization Error    | —                    | —         | $\pm 1/2$ | —                  | —         | $\pm 1/2$ | LSB  |
| Absolute Accuracy *   | —                    | $\pm 5/8$ | $\pm 3/4$ | —                  | $\pm 3/4$ | $\pm 5/4$ | LSB  |

3. PROGRAMMABLE VOLTAGE COMPARISON (PC)

| Item                  | HD46508A, HD46508A-1 |           |           | HD46508, HD46508-1 |           |           | Unit |
|-----------------------|----------------------|-----------|-----------|--------------------|-----------|-----------|------|
|                       | min                  | typ       | max       | min                | typ       | max       |      |
| Resolution            | —                    | 8         | —         | —                  | 8         | —         | bits |
| Non-linearity Error * | —                    | $\pm 1/8$ | $\pm 1/4$ | —                  | $\pm 1/4$ | $\pm 3/4$ | LSB  |
| Zero-Error            | —                    | $\pm 1/4$ | $\pm 3/8$ | —                  | $\pm 3/8$ | $\pm 1/2$ | LSB  |
| Full-Scall Error      | —                    | $\pm 1/4$ | $\pm 3/8$ | —                  | $\pm 3/8$ | $\pm 1/2$ | LSB  |
| Absolute Accuracy *   | —                    | $\pm 3/8$ | $\pm 5/8$ | —                  | $\pm 1/2$ | $\pm 1$   | LSB  |

\*Temperature Coefficient; 25 ppm of FSR/ $^\circ C$  (max)



● AC CHARACTERISTICS ( $V_{CC} = 5.0V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = -20 \sim +75^\circ C$ , unless otherwise noted.)

1. CLOCK WAVEFORM

| Item                      | Symbol           | Test Conditions | CD * = 0 |     |     | CD * = 1 |     |     | Unit    |
|---------------------------|------------------|-----------------|----------|-----|-----|----------|-----|-----|---------|
|                           |                  |                 | min      | typ | max | min      | typ | max |         |
| CLK Cycle Time            | $t_{cycC}$       | Fig. 2          | 1.0      | —   | 10  | 0.5      | —   | 5   | $\mu s$ |
| CLK "High" Pulse Width    | $PW_{CH}$        |                 | 0.45     | —   | 4.5 | 0.22     | —   | 2.2 | $\mu s$ |
| CLK "Low" Pulse Width     | $PW_{CL}$        |                 | 0.40     | —   | 4.0 | 0.21     | —   | 2.1 | $\mu s$ |
| Rise and Fall Time of CLK | $t_{Cr}, t_{Cf}$ |                 | —        | —   | 25  | —        | —   | 25  | ns      |

\* CD : CLK Divider bit



Figure 2 CLK Waveform

2.  $\overline{IRQ}$ , GAINSEL OUTPUT

| Item                          | Symbol     | Test condition | min | typ | max | Unit |
|-------------------------------|------------|----------------|-----|-----|-----|------|
| $\overline{IRQ}$ Release Time | $t_{IR}$   | Fig. 3         | —   | —   | 750 | ns   |
| GAINSEL Delay Time            | $t_{GSD1}$ | Fig. 4         | —   | —   | 750 | ns   |
|                               | $t_{GSD2}$ |                | —   | —   | 750 | ns   |

$t_{GSD1}$  : TTL Load

$t_{GSD2}$  : CMOS Load



Figure 3  $\overline{IRQ}$  Release Time



## (1) Sample &amp; Hold



## (2) x2, x4 Auto Range-Switching, Programmable Gain



Figure 4 GAINSEL Delay Time

**3. BUS TIMING CHARACTERISTICS****READ OPERATION SEQUENCE**

| Item                         | Symbol           | Test Condition | HD46508<br>HD46508A |     |     | HD46508-1<br>HD46508A-1 |     |     | Unit |
|------------------------------|------------------|----------------|---------------------|-----|-----|-------------------------|-----|-----|------|
|                              |                  |                | min                 | typ | max | min                     | typ | max |      |
| Enable Cycle Time            | $t_{cycE}$       | Fig. 5         | 1.0                 | —   | —   | 0.666                   | —   | —   | μs   |
| Enable "High" Pulse Width    | $PW_{EH}$        |                | 0.45                | —   | —   | 0.28                    | —   | —   | μs   |
| Enable "Low" Pulse Width     | $PW_{EL}$        |                | 0.40                | —   | —   | 0.28                    | —   | —   | μs   |
| Rise and Fall Time of Enable | $t_{ER}, t_{EF}$ |                | —                   | —   | 25  | —                       | —   | 25  | ns   |
| Address Set Up Time          | $t_{AS}$         |                | 140                 | —   | —   | 140                     | —   | —   | ns   |
| Data Delay Time              | $t_{DDR}$        |                | —                   | —   | 320 | —                       | —   | 220 | ns   |
| Data Access Time             | $t_{ACC}$        |                | —                   | —   | 460 | —                       | —   | 360 | ns   |
| Data Hold Time               | $t_H$            |                | 10                  | —   | —   | 10                      | —   | —   | ns   |
| Address Hold Time            | $t_{AH}$         |                | 10                  | —   | —   | 10                      | —   | —   | ns   |



## WRITE OPERATION SEQUENCE

| Item                         | Symbol           | Test Condition | HD46508<br>HD46508A |     |     | HD46508-1<br>HD46508A-1 |     |     | Unit |
|------------------------------|------------------|----------------|---------------------|-----|-----|-------------------------|-----|-----|------|
|                              |                  |                | min                 | typ | max | min                     | typ | max |      |
| Enable Cycle Time            | $t_{cycE}$       | Fig. 6         | 1.0                 | —   | —   | 0.666                   | —   | —   | μs   |
| Enable "High" Pulse Width    | $PW_{EH}$        |                | 0.45                | —   | —   | 0.280                   | —   | —   | μs   |
| Enable "Low" Pulse Width     | $PW_{EL}$        |                | 0.40                | —   | —   | 0.280                   | —   | —   | μs   |
| Rise and Fall Time of Enable | $t_{Er}, t_{Ef}$ |                | —                   | —   | 25  | —                       | —   | 25  | ns   |
| Address Set Up Time          | $t_{AS}$         |                | 140                 | —   | —   | 140                     | —   | —   | ns   |
| Data Set Up Time             | $t_{DSW}$        |                | 195                 | —   | —   | 80                      | —   | —   | ns   |
| Data Hold Time               | $t_H$            |                | 10                  | —   | —   | 10                      | —   | —   | ns   |
| Address Hold Time            | $t_{AH}$         |                | 10                  | —   | —   | 10                      | —   | —   | ns   |



Figure 5 Read Timing



Figure 6 Write Timing



Figure 7 Test Load

## ■ SIGNAL DESCRIPTION

### ● Processor Interface

#### Data Bus ( $D_0 \sim D_7$ )

The Bi-directional data lines ( $D_0 \sim D_7$ ) allow data transfer between the ADU and MPU. Data bus output drivers are three state buffers that remain in the high-impedance state except when MPU performs a ADU read operation.

#### Enable (E)

The Enable signal (E) is used as strobe signal in MPU R/W operation with the ADU internal registers. This signal is normally derived from the HMCS6800 system clock ( $\phi_2$ ).

#### Chip Select ( $CS_0, \overline{CS}_1$ )

The Chip Select lines ( $CS_0, \overline{CS}_1$ ) are used to address the ADU. The ADU is selected when  $CS_0$  is at "High" and  $\overline{CS}_1$  is at "Low" level.

#### Read/Write (R/W)

The R/W line controls the direction of data transfer between the ADU and MPU. When R/W is at "High" level, data of ADU is transferred to MPU. When R/W is at "Low" level, data of MPU is transferred to ADU.

#### Register Select ( $RS_0, RS_1$ )

The Register Select line ( $RS_0, RS_1$ ) are used to select one of the 4 ADU internal registers. Table 1 shows the relation between ( $RS_0, RS_1$ ) address and the selected register. The lowest 2 address lines of MPU are usually used for these signals.

#### Reset (RES)

This input is used to reset the ADU. An input "Low" level on RES line forces the ADU into following status.

- 1) All the shift-registers in ADU are cleared and the conversion operation is stopped.
- 2) The GAINSEL output goes down to "Low" level. The IRQ output is made "Off" state and the  $D_0 \sim D_7$  are made high impedance state.

#### Interrupt Request (IRQ) (Open Drain Output)

This output line is used to inform the A/D conversion end signal to the MPU. This signal becomes active "Low" level when IE bit in the control register 1 is "1" and IRQ bit in the control register 2 goes "1" at the end of conversion. And this signal returns to "High" right after The MPU reads the A/D Data Register (R3). Programmable voltage comparison

does not affect this signal.

### ● Analog Data Interface

#### Analog Input ( $AI_0 \sim AI_{15}$ )

The Input Analog Data to be measured is applied to these Analog Input ( $AI_0 \sim AI_{15}$ ). These are multiplexed by internal 16 channel multiplexer and output to COMMON pin. A particular input channel is selected when the multiplexer channel address is programmed into the control Register 1 (R1).

#### Multiplexer Common Output (COMMON)

This signal is the output of the 16 channel analog multiplexer, and may be connected to the input of pre-amplifier or sample/hold circuit according to user's purposes. When no external circuit needed, this output should be connected to the COMPIN input.

#### Comparator Input (COMPIN)

This is a high impedance input line that is used to transmit selected analog data to comparator. The COMMON line is usually connected to this input. When external Pre-amplifier or Sample/hold circuit is used, output of these circuits may be connected to this input.

#### Reference Voltage (+) (REF (+))

This line is used to apply the standard voltage to the internal ladder resistors.

#### Reference Voltage (-) (REF (-))

This line is connected to the analog ground.

### ● ADU Control

#### Conversion Clock (CLK)

The CLK is a standard clock input signals which defines internal timing for A/D conversion and PC operation.

#### Gain Select (GAINSEL) (CMOS Compatible Output)

This output is used to control the external circuit. The function of this signal is programmable and it is specified by (G1, G0) bits in Control Register 0. By using this output, user can control the auto-range-switching of external pre-amplifier, also control external sample & hold circuit, etc. as well.

[NOTE] This LSI is different from other HMCS6800 family LSIs in following function

- RES doesn't affect IE bit of R0

## ■ FUNCTION OF INTERNAL REGISTERS

### ● Structure

Table 1 Internal Registers of the ADU

| $CS_1$ | $CS_0$ | $RS_1$ | $RS_0$ | Reg. # | Register Name                  | Read | Write | Data Bit |     |     |    |    |    |    |    |
|--------|--------|--------|--------|--------|--------------------------------|------|-------|----------|-----|-----|----|----|----|----|----|
|        |        |        |        |        |                                |      |       | 7        | 6   | 5   | 4  | 3  | 2  | 1  | 0  |
| 0      | 1      | 0      | 0      | R0     | Control Register 0             | ○    | ○     | IE       | CD  | ST  |    |    |    | G1 | G0 |
| 0      | 1      | 0      | 1      | R1     | Control Register 1             | ○    | ○     | SC       | GS  | PC  | MI | D3 | D2 | D1 | D0 |
| 0      | 1      | 1      | 0      | R2     | Status & A/D Data Register (H) | ○    | x     | IRQ      | BSY | PCO |    | OV | DW | C9 | C8 |
| 0      | 1      | 1      | 1      | R3     | A/D Data Register (L)          | ○    | x     | C7       | C6  | C5  | C4 | C3 | C2 | C1 | C0 |
| 0      | 1      | 1      | 1      | R4     | PC Data Register               | x    | ○     | B7       | B6  | B5  | B4 | B3 | B2 | B1 | B0 |

(Note) ○ --- YES  
x --- NO



**Control Register 0 (R0)**

|                   | "1"         | "0"           |
|-------------------|-------------|---------------|
| Mode Select       | See Table 2 |               |
| Not Used          |             |               |
| Not Used          |             |               |
| Not Used          |             |               |
| Settling Time     | Available   | Not Available |
| CLK Divider       | CLK/2       | CLK           |
| Interrupt Enable* | Enable IRQ  | Mask IRQ      |

Figure 8 Control Register 0

\*RES doesn't affect IE bit.

**Control Register 1 (R1)**

|                         | "1"                   | "0"                |
|-------------------------|-----------------------|--------------------|
| MPX Channel Address     | See Table 3           |                    |
| MPX Inhibit             | Inhibited             | Not Inhibited      |
| Prog. Comparator Select | Prog. Comparator mode | A/D Converter mode |
| GAINSEL Enable          | GAINSEL Enable        | GAINSEL Disable    |
| Short-cycle Conversion  | 8-bit Length          | 10-bit Length      |

Figure 9 Control Register 1

**Status & A/D Data Register (H)**

|                                | "1"                | "0"                  |
|--------------------------------|--------------------|----------------------|
| Upper bit (10 bit data)        |                    |                      |
| Data Weight                    | See Table 4.       |                      |
| Data Over Scale flag           | Data is over scale | Within the scale     |
| Not Used                       |                    |                      |
| Programmable Comparator Output | $V_{Ain} > V_p$    | $V_{Ain} < V_p$      |
| Busy flag                      | Under Conversion   | Conversion Completed |
| IRQ flag                       | Requested          | Not Requested        |

$V_{Ain}$ : Unknown Input Voltage  
 $V_p$ : Programmed Voltage by R4

C9, C8 bits are cleared when 8 bit A/D conversion is performed.

Figure 10 Status &amp; A/D Data Register (H)

**A/D Data Register (L)**

{Lower order 8 bit Data (Normal 10 bit Conversion)  
 8 bit Data (8 bit Short-cycle Conversion)}

Figure 11 A/D Data Register (L)





Figure 12 PC Data Register

- Description for the Internal Registers

**Control Register 0 (R0)**

This Register is a 5-bit read/write register that is used to specify Interrupt Enable (IE), CLK Divider (CD), Settling Time (ST) and Mode Select (G0, G1). This Register should be written before writing R1.

|                               |                                                                                                                                                                                                           |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IE bit:<br>(Interrupt Enable) | $\begin{cases} IE = "1", & \text{Interrupt is requested through the } IRQ \text{ output.} \\ IE = "0", & \text{Interrupt is masked.} \end{cases}$                                                         |
| CD bit:<br>(Clock Divider)    | $\begin{cases} CD = "1", & \text{CLK } \div 2 \text{ is used as internal clock.} \\ CD = "0", & \text{CLK is used directly.} \end{cases}$                                                                 |
| ST bit:<br>(Settling Time)    | $\begin{cases} ST = "1", & \text{First comparison is executed after 1 expanded cycle in order to compensate external amplifiers settling delay.} \\ ST = "0", & \text{Cycle is not delayed.} \end{cases}$ |
| G0, G1 bit;<br>(Mode select)  | These bits are used to specify the function of GAINSEL signal when GS bit is "1"                                                                                                                          |

Table 2 Function of G0, G1

| G1 | G0 | Mode Select               |
|----|----|---------------------------|
| 0  | 0  | Sample & Hold             |
| 0  | 1  | Auto Range-Switching x 2  |
| 1  | 0  | Auto Range-Switching x 4  |
| 1  | 1  | Programmable Gain Control |

**Control Register 1 (R1)**

This register is an 8-bit read/write register that is used to store the command for A/D conversion mode and programmable comparison mode. This register includes MPX channel address (D0~D3), MPX inhibit (MI), programmable comparator select (PC), GAINSEL enable (GS) and short-cycle conversion (SC) bits. When this register (R1) is programmed, each conversion mode starts.

|                                |                                                                                                                                                                                                  |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SC bit<br>(Short-cycle)        | $\begin{cases} SC = "1", & \text{Short-cycle conversion (8 bit length)} \\ SC = "0", & \text{Normal conversion (10 bit length)} \end{cases}$                                                     |
| GS bit<br>(GAINSEL Enable)     | $\begin{cases} GS = "1", & \text{GAINSEL signal is enabled. The function of GAINSEL is specified by (G0, G1) bits.} \\ GS = "0", & \text{GAINSEL signal is disabled. ("Low" level)} \end{cases}$ |
| PC bit<br>(Program comparator) | $\begin{cases} PC = "1", & \text{Programmable voltage comparator mode} \\ PC = "0", & \text{A/D conversion mode} \end{cases}$                                                                    |
| MI bit<br>(MPX Inhibit)        | $\begin{cases} MI = "1", & \text{Internal MPX channel is inhibited in order to use external MPX channel.} \\ MI = "0", & \text{Internal MPX channel is used.} \end{cases}$                       |
| D0~D3<br>(MPX channel)         | These bits are used to select the particular MPX channel.                                                                                                                                        |

Table 3 MPX Channel Addressing

| Channel #1 | D3 | D2 | D1 | D0 | Analog Input     |
|------------|----|----|----|----|------------------|
| 0          | 0  | 0  | 0  | 0  | AI <sub>0</sub>  |
| 1          | 0  | 0  | 0  | 1  | AI <sub>1</sub>  |
| 2          | 0  | 0  | 1  | 0  | AI <sub>2</sub>  |
| 3          | 0  | 0  | 1  | 1  | AI <sub>3</sub>  |
| 4          | 0  | 1  | 0  | 0  | AI <sub>4</sub>  |
| 5          | 0  | 1  | 0  | 1  | AI <sub>5</sub>  |
| 6          | 0  | 1  | 1  | 0  | AI <sub>6</sub>  |
| 7          | 0  | 1  | 1  | 1  | AI <sub>7</sub>  |
| 8          | 1  | 0  | 0  | 0  | AI <sub>8</sub>  |
| 9          | 1  | 0  | 0  | 1  | AI <sub>9</sub>  |
| 10         | 1  | 0  | 1  | 0  | AI <sub>10</sub> |
| 11         | 1  | 0  | 1  | 1  | AI <sub>11</sub> |
| 12         | 1  | 1  | 0  | 0  | AI <sub>12</sub> |
| 13         | 1  | 1  | 0  | 1  | AI <sub>13</sub> |
| 14         | 1  | 1  | 1  | 0  | AI <sub>14</sub> |
| 15         | 1  | 1  | 1  | 1  | AI <sub>15</sub> |



Table 4 Function Select

| PC | SC | Function           | GS | (G0, G1) |
|----|----|--------------------|----|----------|
| 0  | 0  | 10 bit AD CONV.    | 0  | DISABLE  |
|    |    |                    | 1  | ENABLE*  |
|    | 1  | 8 bit AD CONV.     | 0  | DISABLE  |
|    |    |                    | 1  | ENABLE*  |
| 1  | x  | PROG. COMP (8 bit) | x  | DISABLE  |

x = Do not care

\* = See Table 6

[NOTE] CD bit and ST bit are effective in every case.

**Status & A/D Data Register (H) (R2)**

This register is a 7-bit read only register that is used to store the upper 2-bit data (C8, C9), data weight (DW), data overscale (OV), programmable comparator output (PCO), busy (BSY) and interrupt request(IRQ).

(C8, C9) : These bits store upper 2-bit data measured by 10 bit length conversion.  
(Upper bit data)

DW bit : This bit indicates data weight when (Data weight) Auto range-switching mode is selected. This bit is set or reset when the conversion has completed. The conditions are shown in following Table. In this mode GAINSEL output also goes "High" or "Low" on the same condition shown in Table 5. Other status of DW bit is shown in Table 6.

OV bit (Over scale) : This bit is set when analog data is greater than or equal to reference Voltage ( $V_{REF(+)}$ ).

PCO bit (Programmable comparator Output) : This bit indicates the result of programmable voltage comparison.  
"1" → PCO  $V_{Ain} > V_p$   
"0" → PCO  $V_{Ain} < V_p$

$V_{Ain}$  : Analog Input Voltage to be compared

$V_p$  : Programmed Voltage (R4)

BSY bit (Busy) : This bit indicates that the ADU is now under conversion.

IRQ bit (Interrupt Request) : This bit is set when the A/D conversion has completed and cleared by reading the R3.

**A/D Data Register (L) (R3)**

This register is an 8-bit read-only register that is used to store the lower 8 bits data of 10-bit conversion or full 8 bits data of the 8-bit conversion.

**PC Data Register (R4)**

This register is an 8-bit write-only register prepared for Programmable Voltage comparison. Stored data is converted to digital voltage, and compared with analog input to be measured. The result of comparison is set into PCO bit.

Table 5 Data Weight (DW) Set or Reset Condition

| Mode \ Condition          | Set ("1")                                     | Reset ("0")                                   |
|---------------------------|-----------------------------------------------|-----------------------------------------------|
| Auto Range-Switching (x2) | $V_{Ain} < \frac{410}{1024} \cdot V_{REF(+)}$ | $V_{Ain} > \frac{410}{1024} \cdot V_{REF(+)}$ |
| Auto Range-Switching (x4) | $V_{Ain} < \frac{206}{1024} \cdot V_{REF(+)}$ | $V_{Ain} > \frac{206}{1024} \cdot V_{REF(+)}$ |

$V_{Ain}$  : Analog Input Voltage to be measured  
 $V_{REF(+)}$  : Voltage Applied to REF(+)





Figure 13 A/D Conversion Timing Chart (Basic Sequence)

- A/D Conversion and PC sequence ( $t_{cyc}=1\mu s$ )

10 bits A/D Conversion

- Basic Sequence**  
 $\begin{cases} SC = "0" \\ ST = "0" \\ GS = "0" \end{cases}$   
  

|                         |                |                |                |                |                |                |                |                |                         |
|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) |
|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|

Conversion Start → 9μs → 9μs → 90μs → Conversion End
- Basic Sequence (When overscale is detected)**  
  

|                         |                |                |                |                |                |                |                |                |                         |           |
|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|-----------|
| 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) | Overscale |
|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|-----------|

← 9μs → ↑ Overscale check Cycle  
(Analog Input is compared with  $V_{REF(+)}$ .)
- Expanded Sequence**  
 $\begin{cases} SC = "0" \\ ST = "1" \\ GS = "0" \end{cases}$   
  

|              |                         |                |                |                |                |                |                |                |                |                         |
|--------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| Expand Cycle | 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) |
|--------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|

← 18μs → MSB cycle is expanded to compensate external amplifier's settling delay.
- Auto Range-Switching Control Sequence**  
 $\begin{cases} SC = "0" \\ ST = "0" \\ GS = "1" \\ \{ G0 = "0", G1 = "1" \} \\ \text{or} \\ \{ G0 = "1", G1 = "0" \} \end{cases}$   
  

|            |                         |                |                |                |                |                |                |                |                |                         |
|------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| Auto Range | 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) |
|------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|

→ "GAINSEL" goes "High" according to the result of comparison.  
Auto Range-switching cycle  
(Analog Input is compared with  $1/2 V_{REF(+)}$  or  $1/4 V_{REF(+)}$  at this cycle)  
← 9μs →
- Auto Range-Switching & Expansion Control Sequence**  
 $\begin{cases} SC = "0" \\ ST = "1" \\ GS = "1" \\ \{ G0 = "0", G1 = "1" \} \\ \text{or} \\ \{ G0 = "1", G1 = "0" \} \end{cases}$   
  

|              |            |              |                         |                |                |                |                |                |                |                |                |                         |
|--------------|------------|--------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| Expand Cycle | Auto Range | Expand Cycle | 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) |
|--------------|------------|--------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|

→ "GAINSEL" goes "High"  
← 18μs → 18μs → 9μs →

b) Analog Input <  $1/2 V_{REF(+)}$  or  $1/4 V_{REF(+)}$

  

|              |            |                         |                |                |                |                |                |                |                |                |                         |
|--------------|------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| Expand Cycle | Auto Range | 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) |
|--------------|------------|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|

← 18μs → 9μs → GAINSEL doesn't go "High"

a) Analog Input <  $1/2 V_{REF(+)}$  or  $1/4 V_{REF(+)}$
- Sample & Hold Control Sequence**  
 $\begin{cases} SC = "0" \\ ST = "0" \\ GS = "1" \\ \{ G0 = "0", G1 = "0" \} \end{cases}$   
  

|                         |                |                |                |                |                |                |                |                |                         |
|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| 2 <sup>9</sup><br>(MSB) | 2 <sup>8</sup> | 2 <sup>7</sup> | 2 <sup>6</sup> | 2 <sup>5</sup> | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup><br>(LSB) |
|-------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|

↑  $td^{\#}$  → "GAINSEL" goes "High"  
← 9μs →  $t_d = 5.5\mu s + t_{GSD1} \text{ or } t_{GSD2}$

## 7) Programmable Gain Control Sequence

$\text{SC} = "0"$   
 $\text{ST} = "0"$   
 $\text{GS} = "1"$   
 $\text{G0} = "1"$   
 $\text{G1} = "1"$



## 8) Programmable Gain &amp; Expansion Control Sequence

$\text{SC} = "0"$   
 $\text{ST} = "1"$   
 $\text{GS} = "1"$   
 $\text{G0} = "1"$   
 $\text{G1} = "1"$



## 8 Bit A/D Conversion

## 1) Basic Sequence

$\text{SC} = "1"$   
 $\text{ST} = "0"$   
 $\text{GS} = "0"$



Additional conversion cycle  
for rounding the LSB - 1 Bit.

## 2) Expanded Sequence

$\text{SC} = "1"$   
 $\text{ST} = "1"$   
 $\text{GS} = "0"$



## Programmable Voltage Comparison

## 1) Basic Sequence

$\text{PC} = "1"$   
 $\text{ST} = "0"$



## 2) Expanded Sequence

$\text{PC} = "1"$   
 $\text{ST} = "1"$



## ■ HOW TO USE THE ADU

## • Functions of GAINSEL

The ADU is equipped with programmable GAINSEL output signal. By using GAINSEL output and external circuit, the ADU is able to implement following control.

## 1) Auto Range-Switching (Auto Gain) Control

## 2) Programmable Gain control

## 3) Sample &amp; Hold control

GAINSEL output is controlled by Mode Select bit (G0, G1) when GAINSEL enable bit (GS) is "1".

Table 6 GAINSEL Control

| GS | G1 | G0 | GAINSEL | Control Mode                     | DW |
|----|----|----|---------|----------------------------------|----|
| 0  | x  | x  | "Low"   | Normal Use (GAINSEL is not used) | 0  |
| 1  | 0  | 0  | "High"  | Sample & Hold control            | 0  |
| 1  | 0  | 1  | *       | Auto Range Switching x 2 control | ** |
| 1  | 1  | 0  | *       | Auto Range Switching x 4 control | ** |
| 1  | 1  | 1  | "High"  | Programmable Gain control        | 1  |

\* GAINSEL goes "High" or "Low" according to the condition shown in Table 5.

\*\* See, Table 5.



### How to Control External Circuit

#### (1) Sample & Hold Control (G1=0, G0=0)

An example of Sample & Hold circuit is shown in Fig. 14. When ADU is set in Sample & Hold Control Mode, GAINSEL becomes "High" level on conversion and controls the data holding.

#### (2) Automatic Range Switching Control (G1=0, G0=1 or G1=1, G0=0)

The GAINSEL signal controls the external amplifier which can change the ratio of voltage amplification. (GAIN: 1 → 2 times or 1 → 4 times). Fig. 15 shows Automatic Range Switching Control. In this case, when the input voltage is lower than  $206/1024 V_{REF(+)}$ , GAINSEL becomes "High" level. This makes the GAIN of the amplifier change from 1 to 4 times, and 4 times value of the input voltage is A/D converted. Using this function even if an input signal is small, it is possible to execute A/D conversion in nearly full scale. In this mode, when GAINSEL signal becomes "High", DW bit becomes "1" to show the range switching is in a progress.

#### (3) Programmable GAIN Control (G1=1, G0=1)

The GAINSEL signal is used for controlling the external amplifier of any GAIN which is fit to the system.

In this mode, GAINSEL always becomes "High" at the beginning of A/D conversion, so the change of range is controlled by GS bit. Converted data need to be corrected in software in accordance with GAIN of the amplifier.

This mode is effective in the case of converting very small input voltage.

(Note) Refer to "ADU Function Sequence" (A/D Conversion and PC Sequence) for the timing in which GAINSEL signal becomes "High". GAINSEL signal becomes "Low" in accordance with "1" → "0" change of BSY bit. Refer to Fig. 13.

### x1 Sample & Hold



Figure 14 Sample & Hold Circuit



Figure 15 Pre-amplifier Circuit  
(x1, x4 Auto-Range Switching)

#### • Overscale Check

ADU is equipped with hardware overscale detection function. The overscale detection is performed automatically when the result of A/D conversion is  $2^n - 1$  (all bits = 1). When analog input  $V_{Ain}$  is higher than  $V_{REF(+)}$ , overscale bit (OV) is set to "1". The definition of the overscale is illustrated in Fig. 17. And the flow of overscale check is shown in Fig. 16.



Figure 16 Overscale Check Flow



Figure 17 Definition ADU's Overscale

- Usage of the PC

The ADU has a programmable threshold voltage comparator (PC) function. The threshold voltage is pre-setable from 0V to 5V range with 8 bit resolution. The comparator's

output is stored into PCO bit at the end of comparison.

The programmable voltage comparison time is so short that the interrupt is not requested at this mode. The end of comparison needs to be confirmed by reading the 1 $\rightarrow$ 0 transition of the BSY bit in R2.



Figure 18 Function Diagram of the PC



Figure 19 Registers of the PC Mode



Figure 20 PC Application Flow Chart Examples





Figure 20 PC Application Flow Chart Examples (continued)

#### ■ EXAMPLE OF APPLIED CIRCUIT OF THE ADU



Figure 22 Single ADU System

#### ● How to use MI bit

MI bit (R1) functions as follows.

- { MI = 1: Internal MPX channel is inhibited in order to use attached external MPX channel.
- { MI = 0: Internal MPX channel is enabled.

MI bit used to select either of External MPX and Internal MPX. External MPX is connected as follows.



[NOTE] When external MPX is used as the way figure 20, 1 dummy AD conversion or PC at MI=1 should be performed.

Figure 21 How to use External MPX



Figure 23 Multi ADU System

\*SEE  
GAIN SEL  
USAGE



#### ■ DEFINITIONS OF ACCURACY

- Definitions of accuracy applied to HD46508 are as follows.
- (1) Resolution . . . The number of output binary digit.
  - (2) Offset Error . . . The difference between actual input voltage and ideal input voltage for the first transition. (when digital output code is changed from 000 . . . 00 to 000 . . . 01.)
  - (3) Full Scale Error . . . The difference between actual input voltage and ideal input voltage for the final transition. (when digital output code is changed from 111 . . . 10 to

111 . . . 11.)

- (4) Quantizing Error . . . Error equipped in A/D converter inherently. Always  $\pm\frac{1}{2}$  LSB is applied.
- (5) Non-linearity Error . . . The maximum deviation of the actual transfer line from an ideal straight line. This error doesn't include Quantizing Error, Offset, or Full Scale Errors.
- (6) Absolute Accuracy . . . The deviation of the digital output code from an analog input voltage. Absolute accuracy includes all of (2), (3), (4), (5).



Figure 24 Definition of Accuracy

# HD63084

## DIPP (Document Image Pre-Processor)

-PRELIMINARY-

The HD63084 (DIPP) is an document image processor used as a peripheral of a microcomputer. It reads analog image signals that have been photoelectrically converted by CCD line sensors or other optical devices, corrects the shading distortion of the signals, then converts the signals to digital form.

### ■ FEATURES

- High speed reading of image signals
  - 5M pixel/sec (at input clock frequency of 10 MHz)
- Highly accurate processing of image signals
  - Peak level of image signals, 0.1V ~ 2.0V
  - Built-in 8-bit peak value detection circuit
  - Built-in 7-bit successive approximation pixel A/D and D/A converter
  - Built-in 4-bit flash-type A/D converter
- Various output modes
  - Binary data output mode
  - Dithered data output mode (Programmable dithered pattern of 16 pixel x 16 pixel)
  - 4-bit coded data mode (16 gradations)
- Automatic judgement of horizontal and vertical resolutions
- Interfaceable with either Motorola type or Intel type MPU
- Programmable magnification and reduction rates
  - Reduction of read image signal:  
    : 0.125 ~ 1 times (about 1000 gradations)
  - Magnification of image signal to be recorded:  
    : 1 ~ 8 times (about 1000 gradations)
- Implements the following functions on a single chip
  - (Built-in) sample and hold circuit
  - (Built-in) shading distortion correction RAM
  - (Built-in) sensor interface
  - Parallel to serial conversion of the image signal to be recorded.
- 2.5  $\mu$ m CMOS process technology
- Single 5V supply



### ■ PIN ARRANGEMENT

|                  |    |   |                               |
|------------------|----|---|-------------------------------|
| RST              | 1  | ◎ | 54 MA <sub>8</sub> /MIWR      |
| LNSL             | 2  |   | 55 MA <sub>8</sub> /LSTN      |
| PRD              | 3  |   | 56 MA <sub>10</sub> /MPRD     |
| PWR              | 4  |   | 57 MA <sub>10</sub> /PDEN/MBE |
| LRD              | 5  |   | 58 φ <sub>TG</sub>            |
| LWR              | 6  |   | 59 CLKI                       |
| MAS/MDS          | 7  |   | 60 φ <sub>R</sub>             |
| MAD <sub>7</sub> | 8  |   | 61 φ <sub>I</sub>             |
| MAD <sub>6</sub> | 9  |   | 62 TRIG                       |
| MAD <sub>5</sub> | 10 |   | 63 I <sub>OUT</sub>           |
| MAD <sub>4</sub> | 11 |   | 64 AV <sub>SS</sub>           |
| MAD <sub>3</sub> | 12 |   | 65 ISIN <sub>1</sub>          |
| MAD <sub>2</sub> | 13 |   | 66 ISIN <sub>2</sub>          |
| V <sub>DD</sub>  | 14 |   | 67 V <sub>CL</sub>            |
| MAD <sub>1</sub> | 15 |   | 68 AV <sub>DD</sub>           |
| V <sub>SS</sub>  | 16 |   | 69 PEAKO                      |
| MAD <sub>0</sub> | 17 |   | 70 PEAKI                      |
| TMSK             | 18 |   | 71 V <sub>BL</sub>            |
| T/R CLK          | 19 |   | 72 DA <sub>O</sub>            |
| T/R DATA         | 20 |   | 73 SLICE <sub>1</sub>         |
| T/R DRO          | 21 |   | 74 SLICE <sub>2</sub>         |
| RCLKI            | 22 |   | 75 VT                         |
| TIMO             | 23 |   | 76 V <sub>SS</sub>            |
| D <sub>0</sub>   | 24 |   | 77 LNST/IWIN                  |
| D <sub>1</sub>   | 25 |   | 78 T/R SCAN                   |
| D <sub>2</sub>   | 26 |   | 79 T/R DACK                   |
| D <sub>3</sub>   | 27 |   | 80 R/W                        |
| D <sub>4</sub>   | 28 |   | 81 DS                         |
| D <sub>5</sub>   | 29 |   | 82 RS                         |
| D <sub>6</sub>   | 30 |   | 83 CS                         |
| D <sub>7</sub>   | 31 |   | 84 68/80                      |
| INT              | 32 |   | 85 V <sub>DD</sub>            |

(Top View)



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

## 1.1 Absolute Maximum Rating

### 1.1.1 Internal Digital Circuits

(Voltages referenced to  $V_{SS} = 0V$ .  $T_a = 25^\circ C$ )

| No. | Item                                     | Symbol   | Value                | Unit |
|-----|------------------------------------------|----------|----------------------|------|
| 1   | Supply Voltage                           | $V_{DD}$ | -0.3 to +7.0         | V    |
| 2   | Input Voltage<br>(Digital Input<br>Pins) | $V_I$    | -0.3 to $V_{DD}+0.3$ | V    |
| 3   | Input Voltage<br>(Digital I/O<br>Pins)   | $V_{IT}$ | -0.3 to $V_{DD}+0.3$ | V    |



### 1.1.2 Internal Analog Circuits

(Voltages referenced to AVss = 0V. Ta = 25°C)

| No. | Item                                    | Symbol                                                  | Value                        | Unit |
|-----|-----------------------------------------|---------------------------------------------------------|------------------------------|------|
| 1   | Supply Voltage                          | AV <sub>DD</sub>                                        | -0.3 to +7.0                 | V    |
| 2   | Reference Voltage                       | V <sub>2.5</sub><br>V <sub>CCL</sub><br>V <sub>BL</sub> | -0.3 to V <sub>DD</sub> +0.3 | V    |
| 3   | Input Voltage<br>(Analog Input<br>Pins) | V <sub>IA</sub>                                         | -0.3 to V <sub>DD</sub> +0.3 | V    |



## 1.1.3 Common Characteristics between Digital and Analog Circuits

| No. | Item                  | Symbol | Value       | Unit |
|-----|-----------------------|--------|-------------|------|
| 1   | Operating Temperature | Topr   | 0 to +70    | °C   |
| 2   | Storage temperature   | Tstg   | -55 to +125 | °C   |
| 3   | Power Consumption *1  | Pc     | 500         | mW   |

\*1) Ta = 25°C

**Precaution in Using the DIPP**

- o Applying overvoltage more than the maximum rating to the input terminals due to overshooting or under shooting may cause latch-up, electro-static breakdown, etc.
- o Precaution is needed in noise protection and shield for the analog terminals.



## 1.2 Electrical Characteristics

### 1.2.1 Internal Digital Circuits

#### 1.2.1.1 DC Characteristics

( $V_{DD}=5.0V \pm 5\%$ ,  $V_{SS}=0V$ ,  $T_a=0$  to  $+70^{\circ}C$ )

| No. | Item                                    | Symbol    | Test Condition                                                                                | min       | typ | max      | Unit    |
|-----|-----------------------------------------|-----------|-----------------------------------------------------------------------------------------------|-----------|-----|----------|---------|
| 1   | Input High Voltage                      | $V_{IH}$  | $V_{DD}=5.25V$                                                                                | 2.0       | -   | $V_{DD}$ | V       |
| 2   | Input Low Voltage                       | $V_{IL}$  | $V_{DD}=4.75V$                                                                                | -0.3      | -   | 0.8      | V       |
| 3   | Output High Voltage                     | $V_{OH}$  | $V_{DD}=4.75V$<br>$I_{OH}=-400\mu A$<br>$V_{IH}=2.0V$<br>$V_{IL}=0.8V$                        | 3.0       | -   | -        | V       |
| 4   | Output Low Voltage                      | $V_{OL}$  | $V_{DD}=4.75V$<br>$V_{IH}=2.0V$<br>$V_{IL}=0.8V$<br>Other output pins : Low<br>$I_{OL}=1.6mA$ | -         | -   | 0.4      | V       |
| 5   | Input Leakage Voltage                   | $I_{IN}$  | $V_{DD}=5.25V$<br>$V_I = 0$ to $V_{DD}$                                                       | -10<br>*1 | -   | 10       | $\mu A$ |
| 6   | Three-State (Off State) Leakage Current | $I_{OZH}$ | $V_{DD}=5.25V$<br>$V_0 = V_{DD}$                                                              | -10       | -   | 10       | $\mu A$ |
|     |                                         | $I_{OZL}$ | $V_{DD}=5.25V$<br>$V_0 = V_{SS}$                                                              | -10       | -   | 10       | $\mu A$ |

\*1) The minimum leakage current at pin 34 (68/80) is  
 $-100\mu A$  because it has an internal pull-up resistor.



## 1.2.1.2 AC Characteristics

(V<sub>DD</sub>=5.0V±5%, V<sub>SS</sub>=0V, Ta=0 to +70°C)

## (1) Motorola MPU Interface Timing (68000, etc.)

| Item                     | Symbol            | I/O | Test Condition | Applicable Pin | min   | typ | max | Unit |
|--------------------------|-------------------|-----|----------------|----------------|-------|-----|-----|------|
| DS Pulse Width           | t <sub>WDS6</sub> | I   | Fig. 1-1       | DS             | 450   | —   | —   | ns   |
| DS to R/W Setup Time     | t <sub>SRW6</sub> | I   | Fig. 1-1       | R/W            | 140   | —   | —   | ns   |
| DS to R/W Hold Time      | t <sub>HRW6</sub> | I   | Fig. 1-1       | R/W            | 10    | —   | —   | ns   |
| DS to CS Setup Time      | t <sub>SCS6</sub> | I   | Fig. 1-1       | CS             | 140   | —   | —   | ns   |
| DS to CS Hold Time       | t <sub>HCS6</sub> | I   | Fig. 1-1       | CS             | 10    | —   | —   | ns   |
| DS to RS Setup Time      | t <sub>SRS6</sub> | I   | Fig. 1-1       | RS             | 140   | —   | —   | ns   |
| DS to RS Hold Time       | t <sub>HRS6</sub> | I   | Fig. 1-1       | RS             | 50    | —   | —   | ns   |
| Read Data Access Time    | t <sub>RAC6</sub> | O   | Fig. 1-1       | D0 to D7       | —     | —   | 320 | ns   |
| Read Data Hold Time      | t <sub>RH6</sub>  | O   | Fig. 1-1       | D0 to D7       | 10    | —   | —   | ns   |
| Write Data Setup Time    | t <sub>WS6</sub>  | I   | Fig. 1-1       | D0 to D7       | 200   | —   | —   | ns   |
| Write Data Hold Time     | t <sub>WH6</sub>  | I   | Fig. 1-1       | D0 to D7       | 40    | —   | —   | ns   |
| DS to T/RDACK Setup Time | t <sub>SDK6</sub> | I   | Fig. 1-2       | T/RDACK        | (140) | —   | —   | ns   |
| DS to T/RDACK Hold Time  | t <sub>HDK6</sub> | I   | Fig. 1-2       | T/RDACK        | (10)  | —   | —   | ns   |

## (2) Intel MPU Interface Timing (8080, 8086, etc.)

| Item                                                          | Symbol     | I/O | Test Condition | Applicable Pin                  | min   | typ | max | Unit |
|---------------------------------------------------------------|------------|-----|----------------|---------------------------------|-------|-----|-----|------|
| DS ( $\overline{RD}$ ) Pulse Width                            | $t_{WDS8}$ | I   | Fig. 1-3       | DS                              | 300   | —   | —   | ns   |
| R/ $\overline{W}$ ( $\overline{WR}$ ) Pulse Width             | $t_{WRW8}$ | I   | Fig. 1-3       | R/ $\overline{W}$               | 250   | —   | —   | ns   |
| $\overline{RD}$ to $\overline{CS}$ Setup Time                 | $t_{SRC8}$ | I   | Fig. 1-3       | $\overline{CS}$                 | 125   | —   | —   | ns   |
| $\overline{RD}$ to $\overline{CS}$ Hold Time                  | $t_{HRC8}$ | I   | Fig. 1-3       | $\overline{CS}$                 | 0     | —   | —   | ns   |
| $\overline{WR}$ to $\overline{CS}$ Setup Time                 | $t_{SWC8}$ | I   | Fig. 1-3       | $\overline{CS}$                 | 125   | —   | —   | ns   |
| $\overline{WR}$ to $\overline{CS}$ Hold Time                  | $t_{HWC8}$ | I   | Fig. 1-3       | $\overline{CS}$                 | 20    | —   | —   | ns   |
| $\overline{RD}$ to $\overline{RS}$ Setup Time                 | $t_{SRR8}$ | I   | Fig. 1-3       | $\overline{RS}$                 | 125   | —   | —   | ns   |
| $\overline{RD}$ to $\overline{RS}$ Hold Time                  | $t_{HRR8}$ | I   | Fig. 1-3       | $\overline{RS}$                 | 50    | —   | —   | ns   |
| $\overline{WR}$ to $\overline{RS}$ Setup Time                 | $t_{SWR8}$ | I   | Fig. 1-3       | $\overline{RS}$                 | 125   | —   | —   | ns   |
| $\overline{WR}$ to $\overline{RS}$ Hold Time                  | $t_{HWR8}$ | I   | Fig. 1-3       | $\overline{RS}$                 | 70    | —   | —   | ns   |
| Read Data Access Time                                         | $t_{RAC8}$ | O   | Fig. 1-3       | D0 to D7                        | —     | —   | 300 | ns   |
| Read Data Hold Time                                           | $t_{RH8}$  | O   | Fig. 1-3       | D0 to D7                        | 10    | —   | —   | ns   |
| Write Data Setup Time                                         | $t_{WS8}$  | I   | Fig. 1-3       | D0 to D7                        | 180   | —   | —   | ns   |
| Write Data Hold Time                                          | $t_{WH8}$  | I   | Fig. 1-3       | D0 to D7                        | 50    | —   | —   | ns   |
| $\overline{RD}$ to $\overline{T}/\overline{RDACK}$ Setup Time | $t_{SDK8}$ | I   | Fig. 1-4       | $\overline{T}/\overline{RDACK}$ | (125) | —   | —   | ns   |
| $\overline{RD}$ to $\overline{T}/\overline{RDACK}$ Hold Time  | $t_{HDK6}$ | I   | Fig. 1-4       | $\overline{T}/\overline{RDACK}$ | (0)   | —   | —   | ns   |
| $\overline{WR}$ to $\overline{T}/\overline{RDACK}$ Setup Time | $t_{SRK8}$ | I   | Fig. 1-4       | $\overline{T}/\overline{RDACK}$ | (125) | —   | —   | ns   |
| $\overline{WR}$ to $\overline{T}/\overline{RDACK}$ Hold Time  | $t_{HRK8}$ | I   | Fig. 1-4       | $\overline{T}/\overline{RDACK}$ | (25)  | —   | —   | ns   |

## (3) MPU Interface Timing (common to Motorola MPU and Intel MPU)

| Item                                     | Symbol     | I/O | Test Condition       | Applicable Pin | min | typ | max   | Unit |
|------------------------------------------|------------|-----|----------------------|----------------|-----|-----|-------|------|
| T/RDRQ Positive Edge Delay               | $t_{DRQH}$ | 0   | Fig. 1-5             | T/RDRQ         | —   | —   | 200   | ns   |
| T/RDRQ Negative Edge Delay               | $t_{DRQL}$ | 0   | Fig. 1-5             | T/RDRQ         | —   | —   | 200   | ns   |
| INT Positive Edge Delay                  | $t_{INTH}$ | 0   | Fig. 1-6             | INT            | —   | —   | 300   | ns   |
| T/RSCAN input to INT Negative Edge Delay | $t_{INTL}$ | 0   | Fig. 1-6             | INT            | —   | —   | 100   | ns   |
| DS input to INT Negative Edge Delay      | $t_{DSIL}$ | 0   | Fig. 1-1<br>Fig. 1-3 | INT            | —   | —   | (300) | ns   |

## (4) Clock and Control Input Timing

| Item                         | Symbol     | I/O | Test Condition | Applicable Pin   | min                   | typ | max    | Unit    |
|------------------------------|------------|-----|----------------|------------------|-----------------------|-----|--------|---------|
| CLKI Cycle Time              | $t_{CYC}$  | I   | Fig. 1-7       | CLKI *2          | 100                   | —   | 1000   | ns      |
| RCLK Cycle Time              | $t_{RCYC}$ | I   | Fig. 1-7       | RCLKI *2         | 200                   | —   | $10^6$ | ns      |
| TSCAN Pulse Width            | $t_{TSW}$  | I   | Fig. 1-7       | T/RSCAN          | $(\frac{2}{t_{CYC}})$ | —   | —      | ns      |
| RSCAN Pulse Width            | $t_{RSW}$  | I   | Fig. 1-7       | T/RSCAN          | $(\frac{2}{t_{CYC}})$ | —   | —      | ns      |
| $\overline{RST}$ Pulse Width | $t_{RSTW}$ | I   | Fig. 1-7       | $\overline{RST}$ | $(\frac{2}{t_{CYC}})$ | —   | —      | ns      |
| TRIG Pulse Width             | $t_{TRIG}$ | I   | Fig. 1-7       | TRIG             | (8)                   | —   | —      | $\mu s$ |

\*2) Both CLKI and RCLKI input frequencies provide duty cycle of 50%.



## (5) Serial Output Timing

| Item                             | Symbol     | I/O | Test Condition | Applicable Pin | min | typ | max         | Unit |
|----------------------------------|------------|-----|----------------|----------------|-----|-----|-------------|------|
| CLKI Input to TMSK Output Delay  | $t_{TMDT}$ | 0   | Fig. 1-8       | TMSK           | —   | —   | 200         | ns   |
| CLKI Input to TMSK Output Hold   | $t_{TMHT}$ | 0   | Fig. 1-8       | TMSK           | —   | —   | 200         | ns   |
| TDATA Output Delay               | $t_{TDD}$  | 0   | Fig. 1-8       | T/RDATA        | —   | —   | 200         | ns   |
| TDATA Output Hold                | $t_{TDH}$  | 0   | Fig. 1-8       | T/RDATA        | —   | —   | 250         | ns   |
| TCLK Positive Edge Delay         | $t_{TCH}$  | 0   | Fig. 1-8       | T/RCLK         | —   | —   | 200         | ns   |
| TCLK Negative Edge Delay         | $t_{TCL}$  | 0   | Fig. 1-8       | T/RCLK         | —   | —   | 200         | ns   |
| RCLK Output to TMSK Output Delay | $t_{TMDR}$ | 0   | Fig. 1-9       | TMSK           | —   | —   | (200)<br>*3 | ns   |
| RCLK Output to TMSK Output Delay | $t_{TMHR}$ | 0   | Fig. 1-9       | TMSK           | —   | —   | (200)<br>*3 | ns   |
| RDATA Output Delay               | $t_{RDD}$  | 0   | Fig. 1-9       | T/RDATA        | —   | —   | (200)<br>*3 | ns   |
| RDATA Output Hold                | $t_{RDH}$  | 0   | Fig. 1-9       | T/RDATA        | —   | —   | (200)<br>*3 | ns   |
| RCLK Positive Edge Delay         | $t_{RCH}$  | 0   | Fig. 1-9       | T/RCLK         | —   | —   | (200)<br>*3 | ns   |
| RCLK Negative Edge Delay         | $t_{RCL}$  | 0   | Fig. 1-9       | T/RCLK         | —   | —   | (200)<br>*3 | ns   |

\*3) Values for reference.



## (6) Application Output and Sensor Interface Timing

| Item                                 | Symbol        | I/O | Test Condition   | Applicable Pin | min | typ | max | Unit |
|--------------------------------------|---------------|-----|------------------|----------------|-----|-----|-----|------|
| TIMO Output Delay                    | $t_{TO}$      | 0   | Fig. 1-10        | TIMO           | —   | —   | 200 | ns   |
| LNST/IWIN Output Delay               | $t_{LN}$      | 0   | Fig. 1-10 (IWIN) | LNST/IWIN      | —   | —   | 250 | ns   |
| $\phi$ TG Output Positive Edge Delay | $t_{\phi TD}$ | 0   | Fig. 1-11        | $\phi$ TG      | —   | —   | 150 | ns   |
| $\phi$ TG Output Negative Edge Delay | $t_{\phi TH}$ | 0   | Fig. 1-11        | $\phi$ TG      | —   | —   | 160 | ns   |
| $\phi$ l Output Delay                | $t_{\phi lD}$ | 0   | Fig. 1-11        | $\phi$ l       | —   | —   | 100 | ns   |
| $\phi$ l Output Hold                 | $t_{\phi lH}$ | 0   | Fig. 1-11        | $\phi$ l       | —   | —   | 130 | ns   |
| $\phi$ R Positive Edge Delay         | $t_{\phi RD}$ | 0   | Fig. 1-13        | $\phi$ R       | —   | —   | 100 | ns   |
| $\phi$ R Positive Edge Hold          | $t_{\phi RH}$ | 0   | Fig. 1-13        | $\phi$ R       | —   | —   | 100 | ns   |

## (7) Memory Bus Interface Timing

| Item                           | Symbol     | I/O | Test Condition                 | Applicable Pin                             | min | type | max | Unit |
|--------------------------------|------------|-----|--------------------------------|--------------------------------------------|-----|------|-----|------|
| MAS/MDS Positive Edge Delay    | $t_{MASD}$ | 0   | Fig. 1-14, -16, -18, -19, -20, | MAS/MDS                                    | —   | —    | 200 | ns   |
| MAS/MDS Negative Edge Delay    | $t_{MASH}$ | 0   | Fig. 1-14, -16, -18, -19, -20, | MAS/MDS                                    | —   | —    | 200 | ns   |
| LNSL Output Delay              | $t_{LSD}$  | 0   | Fig. 1-14, -8, -19,            | LNSL                                       | —   | —    | 200 | ns   |
| MA8 to 11 Output Delay *4      | $t_{MAUD}$ | 0   | Fig. 1-14, -8, -19,            | MA8/ <u>MIWR</u> to MA11/ <u>PDEN</u> /MBE | —   | —    | 200 | ns   |
| <u>LRD</u> Negative Edge Delay | $t_{LRD}$  | 0   | Fig. 1-14, -8, -19,            | <u>LRD</u>                                 | —   | —    | 200 | ns   |
| <u>LRD</u> Positive Edge Hold  | $t_{LRH}$  | 0   | Fig. 1-14, -8, -19,            | <u>LRD</u>                                 | —   | —    | 200 | ns   |
| <u>LWR</u> Negative Edge Delay | $t_{LWD}$  | 0   | Fig. 1-14, -8, -19,            | <u>LWR</u>                                 | —   | —    | 200 | ns   |

(To be continued)

\*4) Values for reference.



(Continued)

| Item                                        | Symbol     | I/O | Test Condition                      | Applicable Pin                             | min | typ | max | Unit |
|---------------------------------------------|------------|-----|-------------------------------------|--------------------------------------------|-----|-----|-----|------|
| $\overline{LWR}$ Positive Edge Hold         | $t_{LWH}$  | 0   | Fig. 1-14<br>Fig. 1-19              | $\overline{LWR}$                           | —   | —   | 200 | ns   |
| MADO to 7 Delay                             | $t_{MADD}$ | 0   | Fig. 1-14 etc.                      | MADO-7                                     | —   | —   | 200 | ns   |
| MADO to 7 Hold                              | $t_{MADH}$ | 0   | Fig. 1-14 etc.                      | MADO-7                                     | —   | —   | 200 | ns   |
| MADO to 7 Setup Time                        | $t_{RDS}$  | I   | Fig. 1-14                           | MADO-8                                     | 50  | —   | —   | ns   |
| MADO to 7 Hold Time                         | $t_{RDH}$  | I   | Fig. 1-14                           | MADO-7                                     | 50  | —   | —   | ns   |
| MBE Negative Edge Delay                     | $t_{MBEL}$ | 0   | Fig. 1-15                           | MBE                                        | —   | —   | 200 | ns   |
| T/RDACK Input to MAS Negative Edge Delay    | $t_{BASL}$ | 0   | Fig. 1-17                           | MAS/MDS                                    | —   | —   | 200 | ns   |
| T/RDACK Input to MAS Positive Edge Delay    | $t_{BASH}$ | 0   | Fig. 1-17                           | MAS/MDS                                    | —   | —   | 200 | ns   |
| T/RDACK Input to T/RDRQ Negative Edge Delay | $t_{BTDR}$ | 0   | Fig. 1-17                           | T/RDRQ                                     | —   | —   | 400 | ns   |
| MLNST Positive Edge Delay                   | $t_{MLNH}$ | 0   | Fig. 1-16<br>Fig. 1-17<br>Fig. 1-18 | MA9/LNSTN                                  | —   | —   | 250 | ns   |
| MLNST Negative Edge Delay                   | $t_{MLNL}$ | 0   | Fig. 1-16<br>Fig. 1-17<br>Fig. 1-18 | MA9/LNSTN                                  | —   | —   | 300 | ns   |
| $\overline{PRD}$ Negative Edge Delay        | $t_{PRD}$  | 0   | Fig. 1-16<br>Fig. 1-19              | $\overline{PRD}$                           | —   | —   | 200 | ns   |
| $\overline{PRD}$ Positive Edge Hold         | $t_{PRH}$  | 0   | Fig. 1-16<br>Fig. 1-19              | $\overline{PRD}$                           | —   | —   | 200 | ns   |
| $\overline{PWR}$ Negative Edge Delay        | $t_{PWD}$  | 0   | Fig. 1-18<br>Fig. 1-20              | $\overline{PWR}$                           | —   | —   | 200 | ns   |
| $\overline{PWR}$ Positive Edge Hold         | $t_{PWH}$  | 0   | Fig. 1-18<br>Fig. 1-20              | $\overline{PWR}$                           | —   | —   | 200 | ns   |
| MIWR Negative Edge Delay                    | $t_{MIWL}$ | 0   | Fig. 1-16                           | MA8/ $\overline{MIWR}$                     | —   | —   | 400 | ns   |
| MIWR Positive Edge Delay                    | $t_{MIWH}$ | 0   | Fig. 1-16                           | MA8/ $\overline{MIWR}$                     | —   | —   | 200 | ns   |
| MPRD Negative Edge Delay                    | $t_{MPRL}$ | 0   | Fig. 1-18                           | MA10/ $\overline{MPRD}$                    | —   | —   | 250 | ns   |
| MPRD Positive Edge Delay                    | $t_{MPRH}$ | 0   | Fig. 1-18                           | MA10/ $\overline{MPRD}$                    | —   | —   | 250 | ns   |
| PDEN Negative Edge Delay                    | $t_{PDEL}$ | 0   | Fig. 1-18                           | MA11/ $\overline{PDEN}$ / $\overline{MBE}$ | —   | —   | 200 | ns   |



## (Note 1) Bus Timing Test Loads



- [Notes]
1.  $C_L$  includes stray capacitance caused by the probe and load capacitance.
  2. Diodes are 1S2074 (H) or equivalents.

## (Note 2) I/O Signal Test Points





Note)  $\overline{T/RDACK}$  input must be fixed high.

Fig. 1-1 Motorola MPU Access Timing



Note)  $\overline{CS}$  input must be fixed high.

Fig. 1-2 DMA Operation Timing (Using Motorola MPU)



Note)  $\overline{T/RDACK}$  input must be fixed high.

Fig. 1-3 Intel MPU Access Timing



Note)  $\overline{CS}$  input must be fixed high.

Fig. 1-4 DMA Operation Timing (Using Intel MPU)





Fig. 1-5 T/RDRQ Output Timing



Fig. 1-6 INT Output Timing



Fig. 1-7 CLKI, RCLK, T/RSCAN,  $\overline{RST}$  and TRIG Input Timing



Fig. 1-8 Serial Output Timing (in Read (T) Mode)



Fig. 1-9 Serial Output Timing (in Receive (R) Mode)





Fig. 1-10 Application Output Timing



Note) The SMD0, SMD1 and SMD2 bits in the R09 register must be 0,0 and 0 or 0,0 and 1 respectively.

Fig. 1-11  $\phi$ TG and  $\phi$ 1 Output Timing (1)

Note) The SMD0, SMD1 and SMD2 bits must be 0,1 and 0 or 0,1 and 1 respectively.

Fig. 1-12  $\phi$ TG and  $\phi$ 1 Output Timing (2)Fig. 1-13  $\phi$ 1 and  $\phi$ R Output Timing



Fig. 1-14 Memory Bus Interface Timing in A Mode (1) During Image Data Processing



Fig. 1-15 Memory Bus Interface Timing in A Mode (2)  
During Burst DMA Transfer



Fig. 1-16 Memory Bus Interface Timing in B Mode (1)  
During 4-bit Coded Data Output



Fig. 1-17 Memory Bus Interface Timing in B Mode (2)  
During Burst DMA Transfer



Fig. 1-18 Memory Bus Interface Timing in B Mode (3)  
During Pel Correction Data Detection



Fig. 1-19 Memory Bus Interface Timing in C or D Mode (1)  
During Image Data Processing



Fig. 1-20 Memory Bus Interface Timing in C or D Mode (2)  
During Pel Correction Data Detection

## 1.2.1.3 Capacitance

| Item                     | Symbol       | Test Condition      | min | typ | max  | Unit |
|--------------------------|--------------|---------------------|-----|-----|------|------|
| Input Capacitance        | $C_{IN}$     | $f = 100\text{kHz}$ | —   | —   | 12.5 | pF   |
| Output Capacitance       | $C_{OUT}$    |                     | —   | —   | 12.5 | pF   |
| Input/Output Capacitance | $C_{in/out}$ |                     | —   | —   | 12.5 | pF   |

\* These parameters are sample values.

## 1.2.2 Internal Analog Circuits

## 1.2.2.1 DC Characteristics

| Item                | Detailed Item | Symbol       | Test Condition      | min                 | typ | max                 | Unit |
|---------------------|---------------|--------------|---------------------|---------------------|-----|---------------------|------|
| Input Current       | VBL           | $I_{BL}$     | $V_{BL}=3.5V$       | —                   | —   | 1.0                 | mA   |
| Input Voltage Range | ISIN1,2       | $V_{ISI1,2}$ |                     | 1.5                 | —   | 3.5                 | V    |
|                     | PEAKI         | $V_{INP}$    |                     | 1.5                 | —   | 3.0                 |      |
|                     | SLICE1        | $V_{INS1}$   |                     | 1.5                 | —   | 3.5                 |      |
|                     | SLICE2        | $V_{INS2}$   |                     | 1.5                 | —   | 3.5                 |      |
|                     | VBL           | $V_{IBL}$    |                     | $0.3 \times V_{DD}$ | —   | $0.7 \times V_{DD}$ |      |
|                     | VCL           | $V_{ICL}$    |                     | $0.3 \times V_{DD}$ | —   | $0.7 \times V_{DD}$ |      |
| Output Current      | IOUT          | $I_{OIO}$    |                     | -16.0               | —   | -4.0                | mA   |
|                     | PEAKO         | $I_{OPK}$    |                     | -5.0                | —   | -0.7                |      |
|                     | DAO           | $I_{ODO}$    |                     | -6.0                | —   | -0.7                |      |
| Supply Current      | Standby       | $I_{DS}$     |                     | —                   | —   | 1                   |      |
|                     | Operating     | $I_{DD}$     | $CLKI=10\text{MHz}$ | —                   | —   | 60                  |      |

(to be continued)



(continued)

| Item                  | Detailed Item | Symbol                    | Test Condition | min                             | typ  | max | Unit |   |  |
|-----------------------|---------------|---------------------------|----------------|---------------------------------|------|-----|------|---|--|
| Output Voltage        | PEAK0         | Resistance Chain Step 0   | $V_{P0}$       | $V_{CL} = V_{BL} = 3.4V$        | 3.20 | —   | 3.40 | V |  |
|                       |               | Resistance Chain Step 255 |                |                                 | 1.25 | —   | 1.65 |   |  |
|                       | DAO0          | Resistance Chain Step 0   | $V_{D0}$       |                                 | 1.40 | —   | 1.60 |   |  |
|                       |               | Resistance Chain Step 127 |                |                                 | 2.60 | —   | 3.00 |   |  |
|                       | IOUT          |                           | $V_{IOUT}$     | $V_{ISIN1} = 2.5V$              | 2.40 | —   | 2.65 |   |  |
|                       |               | ISIN1                     | $I_{LIS1}$     | $V_{IN} = 0 \text{ to } V_{DD}$ | -10  | —   | 10   |   |  |
| Input Leakage Current | ISIN2         |                           | $I_{LIS2}$     |                                 |      |     |      |   |  |
|                       | PEAK1         |                           | $I_{LPI}$      |                                 |      |     |      |   |  |
|                       | SLICE1        |                           | $I_{LSL1}$     |                                 |      |     |      |   |  |
|                       | SLICE2        |                           | $I_{LSL2}$     |                                 |      |     |      |   |  |
|                       | VCL           |                           | $I_{LVCL}$     |                                 |      |     |      |   |  |
|                       |               |                           |                |                                 |      |     |      |   |  |

### 1.2.2.2 AC Characteristics

| Item                | Detailed Item                  | Symbol   | Test Condition                        | min | typ | max | Unit |
|---------------------|--------------------------------|----------|---------------------------------------|-----|-----|-----|------|
| Input Voltage Range | Peak to Peak Voltage           | $V_{IP}$ | $f_{CLK} = 10MHz$                     | 0.1 | —   | 2.0 | V    |
| Operating Frequency | Image Signal Reading Frequency | $V_{IF}$ | $V_{BL} = 3.4V$<br>$V_{SLICE} = 1.8V$ | 0.5 | —   | 5.0 | MHz  |



## 9.2 Function of Analog Signal Processing Block



Fig. 2-1 Functional Configuration of Analog Signal Processing Block

1.2 Relation between Horizontal Resolution Conversion Ratio ( $\beta$ ) and Parameters

Table 1-1 Relation between Horizontal Resolution Conversion Ratio ( $\beta$ ) and Parameters (1)

| $\beta$ | m | k  | $\lambda$ |     | HRCM |              | $\beta$ | m | k  | $\lambda$ |     | HRCM |              |
|---------|---|----|-----------|-----|------|--------------|---------|---|----|-----------|-----|------|--------------|
|         |   |    | '1'       | '0' |      |              |         |   |    | '1'       | '0' |      |              |
| .125    | 7 | 1  | 1         | 0   | 1    |              | 1.1     | 8 | 11 | 3         | 8   | 0    |              |
| .15     | 6 | 3  | 2         | 1   | 1    |              | 1.12    | 8 | 7  | 1         | 6   | 0    |              |
| .16     | 6 | 4  | 1         | 3   | 1    |              | 1.15    | 7 | 3  | 2         | 1   | 0    |              |
| .18     | 5 | 9  | 5         | 4   | 1    |              | 1.1548  | 7 | 13 | 6         | 7   | 0    | B5→A4, B4→A3 |
| .2      | 4 | 1  | 1         | 0   | 1    |              | 1.16    | 7 | 4  | 1         | 3   | 0    |              |
| .22     | 4 | 11 | 6         | 5   | 1    |              | 1.18    | 6 | 9  | 5         | 4   | 8    |              |
| .25     | 3 | 1  | 1         | 0   | 1    |              | 1.2     | 5 | 1  | 1         | 0   | 0    |              |
| .28     | 3 | 7  | 4         | 3   | 1    |              | 1.2264  | 5 | 12 | 5         | 7   | 0    | A4→B4        |
| .3      | 3 | 3  | 1         | 2   | 1    |              | 1.2273  | 5 | 5  | 2         | 3   | 0    | A4→B4        |
| .32     | 3 | 8  | 1         | 7   | 1    |              | 1.24    | 5 | 6  | 1         | 5   | 0    |              |
| .35     | 2 | 7  | 6         | 1   | 1    |              | 1.26    | 4 | 14 | 11        | 3   | 0    |              |
| .375    | 2 | 3  | 2         | 1   | 1    |              | 1.28    | 4 | 7  | 4         | 3   | 0    |              |
| .4      | 2 | 2  | 1         | 1   | 1    |              | 1.3     | 4 | 3  | 1         | 2   | 0    |              |
| .44     | 2 | 11 | 3         | 8   | 1    |              | 1.32    | 4 | 8  | 1         | 7   | 0    |              |
| .45     | 2 | 9  | 2         | 7   | 1    |              | 1.35    | 3 | 7  | 6         | 1   | 0    |              |
| .5      | 2 | 1  | 0         | 1   | 0    |              | 1.375   | 3 | 3  | 2         | 1   | 0    |              |
| .52     | 2 | 12 | 1         | 11  | 0    |              | 1.4     | 3 | 2  | 1         | 1   | 0    |              |
| .55     | 2 | 9  | 2         | 7   | 0    |              | 1.4138  | 3 | 12 | 5         | 7   | 0    | A4→A3, B5→B4 |
| .56     | 2 | 11 | 3         | 8   | 0    |              | 1.4167  | 3 | 5  | 2         | 3   | 0    | A4→A3, B5→B4 |
| .6      | 2 | 2  | 1         | 1   | 0    |              | 1.44    | 3 | 11 | 3         | 8   | 0    |              |
| .6129   | 2 | 12 | 7         | 5   | 0    | A3→B5        | 1.45    | 3 | 9  | 2         | 7   | 0    |              |
| .625    | 2 | 3  | 2         | 1   | 0    |              | 1.48    | 3 | 12 | 1         | 11  | 0    |              |
| .65     | 2 | 7  | 6         | 1   | 0    |              | 1.5     | 2 | 1  | 1         | 0   | 0    |              |
| .68     | 3 | 8  | 1         | 7   | 0    |              | 1.52    | 2 | 13 | 12        | 1   | 0    |              |
| .7      | 3 | 3  | 1         | 2   | 0    |              | 1.55    | 2 | 11 | 9         | 2   | 0    |              |
| .7073   | 3 | 12 | 5         | 7   | 0    | A3→A4, B4→B5 | 1.56    | 2 | 14 | 11        | 3   | 0    |              |
| .72     | 3 | 7  | 4         | 3   | 0    |              | 1.6     | 2 | 3  | 2         | 1   | 0    |              |
| .75     | 3 | 1  | 1         | 0   | 0    |              | 1.6316  | 2 | 12 | 7         | 5   | 0    | B5→A3        |
| .76     | 4 | 6  | 1         | 5   | 0    |              | 1.6363  | 2 | 7  | 4         | 3   | 0    | B5→A3        |
| .78     | 4 | 11 | 6         | 5   | 0    |              | 1.65    | 2 | 13 | 7         | 6   | 0    |              |
| .8      | 4 | 1  | 1         | 0   | 0    |              | 1.6667  | 2 | 2  | 1         | 1   | 0    |              |
| .8163   | 5 | 9  | 4         | 5   | 0    | B4→A4        | 1.6875  | 2 | 11 | 5         | 6   | 0    |              |
| .8167   | 5 | 11 | 5         | 6   | 0    | B4→A4        | 1.7     | 2 | 7  | 3         | 4   | 0    |              |
| .825    | 5 | 7  | 5         | 2   | 0    |              | 1.7222  | 2 | 13 | 5         | 8   | 0    |              |
| .84     | 6 | 4  | 1         | 3   | 0    |              | 1.75    | 2 | 3  | 1         | 2   | 0    |              |
| .86     | 7 | 11 | 2         | 9   | 0    |              | 1.7692  | 2 | 10 | 3         | 7   | 0    |              |
| .866    | 7 | 13 | 6         | 7   | 0    | A3→B4, A4→B5 | 1.8     | 2 | 4  | 1         | 3   | 0    |              |
| .8661   | 7 | 15 | 7         | 8   | 0    | A3→B4, A4→B5 | 1.8235  | 2 | 14 | 3         | 11  | 0    |              |
| .875    | 7 | 1  | 1         | 0   | 0    |              | 1.8421  | 2 | 16 | 3         | 13  | 0    |              |
| .9      | 8 | 5  | 1         | 4   | 0    |              | 1.8667  | 2 | 13 | 2         | 11  | 0    |              |
| .925    | 8 | 5  | 2         | 3   | 0    |              | 1.8824  | 2 | 15 | 2         | 13  | 0    |              |
| .95     | 8 | 5  | 3         | 2   | 0    |              | 1.9     | 2 | 9  | 1         | 8   | 0    |              |
| .975    | 8 | 5  | 4         | 1   | 0    |              | 1.9231  | 2 | 12 | 1         | 11  | 0    |              |
| 1.0     | 8 | 1  | 1         | 0   | 0    |              | 1.9412  | 2 | 16 | 1         | 15  | 0    |              |
| 1.024   | 8 | 16 | 13        | 3   | 0    |              | 2.0     | 2 | 1  | 0         | 1   | 0    |              |
| 1.03    | 8 | 13 | 9         | 4   | 0    |              | 2.0625  | 2 | 16 | 1         | 15  | 1    |              |
| 1.062   | 8 | 15 | 8         | 7   | 0    |              | 2.0833  | 2 | 12 | 1         | 11  | 1    |              |
| 1.081   | 8 | 5  | 2         | 3   | 0    |              | 2.1     | 2 | 10 | 1         | 9   | 1    |              |



Table 1-1 Relation between Horizontal Resolution Conversion Ratio ( $\beta$ ) and Parameters (2)

| $\beta$ | m | k  | $\ell$ |     | HRCM |  | $\beta$ | m | k  | $\ell$ |     | HRCM |  |
|---------|---|----|--------|-----|------|--|---------|---|----|--------|-----|------|--|
|         |   |    | '1'    | '0' |      |  |         |   |    | '1'    | '0' |      |  |
| 2.125   | 2 | 8  | 1      | 7   | 1    |  | 3.3846  | 3 | 13 | 5      | 8   | 1    |  |
| 2.1429  | 2 | 7  | 1      | 6   | 1    |  | 3.4167  | 3 | 12 | 5      | 7   | 1    |  |
| 2.1667  | 2 | 6  | 1      | 5   | 1    |  | 3.4375  | 3 | 16 | 7      | 9   | 1    |  |
| 2.1875  | 2 | 16 | 3      | 13  | 1    |  | 3.4545  | 3 | 11 | 5      | 6   | 1    |  |
| 2.2143  | 2 | 14 | 3      | 11  | 1    |  | 3.5     | 3 | 2  | 1      | 1   | 1    |  |
| 2.25    | 2 | 4  | 1      | 3   | 1    |  | 3.5333  | 3 | 15 | 8      | 7   | 1    |  |
| 2.2727  | 2 | 11 | 3      | 8   | 1    |  | 3.5556  | 3 | 9  | 5      | 4   | 1    |  |
| 2.3     | 2 | 10 | 3      | 7   | 1    |  | 3.5714  | 3 | 7  | 4      | 3   | 1    |  |
| 2.3333  | 2 | 3  | 1      | 2   | 1    |  | 3.6     | 3 | 5  | 3      | 2   | 1    |  |
| 2.3637  | 2 | 11 | 4      | 7   | 1    |  | 3.625   | 3 | 8  | 5      | 3   | 1    |  |
| 2.3846  | 2 | 13 | 5      | 8   | 1    |  | 3.6667  | 3 | 3  | 2      | 1   | 1    |  |
| 2.4167  | 2 | 12 | 5      | 7   | 1    |  | 3.6923  | 3 | 13 | 9      | 4   | 1    |  |
| 2.4449  | 2 | 9  | 4      | 5   | 1    |  | 3.7     | 3 | 10 | 7      | 3   | 1    |  |
| 2.4667  | 2 | 15 | 7      | 8   | 1    |  | 3.7277  | 3 | 11 | 8      | 3   | 1    |  |
| 2.5     | 2 | 2  | 1      | 1   | 1    |  | 3.75    | 3 | 4  | 3      | 1   | 1    |  |
| 2.5385  | 2 | 13 | 7      | 6   | 1    |  | 3.7778  | 3 | 9  | 7      | 2   | 1    |  |
| 2.5625  | 2 | 16 | 9      | 7   | 1    |  | 3.8     | 3 | 5  | 4      | 1   | 1    |  |
| 2.6154  | 2 | 13 | 8      | 5   | 1    |  | 3.8572  | 3 | 7  | 6      | 1   | 1    |  |
| 2.6364  | 2 | 11 | 7      | 4   | 1    |  | 3.8889  | 3 | 9  | 8      | 1   | 1    |  |
| 2.6667  | 2 | 3  | 2      | 1   | 1    |  | 3.9091  | 3 | 11 | 10     | 1   | 1    |  |
| 2.6923  | 2 | 13 | 9      | 4   | 1    |  | 3.9231  | 3 | 13 | 12     | 1   | 1    |  |
| 2.7143  | 2 | 7  | 5      | 2   | 1    |  | 3.9375  | 3 | 16 | 15     | 1   | 1    |  |
| 2.7333  | 2 | 15 | 11     | 4   | 1    |  | 4.0     | 3 | 1  | 1      | 0   | 1    |  |
| 2.7692  | 2 | 13 | 10     | 3   | 1    |  | 4.0625  | 4 | 16 | 1      | 15  | 1    |  |
| 2.7857  | 2 | 14 | 11     | 3   | 1    |  | 4.0833  | 4 | 12 | 1      | 11  | 1    |  |
| 2.8125  | 2 | 16 | 13     | 3   | 1    |  | 4.1     | 4 | 10 | 1      | 9   | 1    |  |
| 2.8333  | 2 | 6  | 5      | 1   | 1    |  | 4.125   | 4 | 8  | 1      | 7   | 1    |  |
| 2.8571  | 2 | 7  | 6      | 1   | 1    |  | 4.1429  | 4 | 7  | 1      | 6   | 1    |  |
| 2.875   | 2 | 8  | 7      | 1   | 1    |  | 4.1667  | 4 | 6  | 1      | 5   | 1    |  |
| 2.9     | 2 | 10 | 9      | 1   | 1    |  | 4.1818  | 4 | 11 | 2      | 9   | 1    |  |
| 2.9167  | 2 | 12 | 11     | 1   | 1    |  | 4.2     | 4 | 5  | 1      | 4   | 1    |  |
| 2.9333  | 2 | 15 | 14     | 1   | 1    |  | 4.2222  | 4 | 9  | 2      | 7   | 1    |  |
| 3.0     | 2 | 1  | 1      | 0   | 1    |  | 4.25    | 4 | 4  | 1      | 3   | 1    |  |
| 3.0625  | 3 | 16 | 1      | 15  | 1    |  | 4.2667  | 4 | 15 | 4      | 11  | 1    |  |
| 3.0833  | 3 | 12 | 1      | 11  | 1    |  | 4.2857  | 4 | 7  | 2      | 5   | 1    |  |
| 3.1111  | 3 | 9  | 1      | 8   | 1    |  | 4.3077  | 4 | 13 | 4      | 9   | 1    |  |
| 3.125   | 3 | 8  | 1      | 7   | 1    |  | 4.3334  | 4 | 3  | 1      | 2   | 1    |  |
| 3.1429  | 3 | 7  | 1      | 6   | 1    |  | 4.3572  | 4 | 14 | 5      | 9   | 1    |  |
| 3.1667  | 3 | 6  | 1      | 5   | 1    |  | 4.3946  | 4 | 13 | 5      | 8   | 1    |  |
| 3.1875  | 3 | 16 | 3      | 13  | 1    |  | 4.4167  | 4 | 12 | 5      | 7   | 1    |  |
| 3.2143  | 3 | 14 | 3      | 11  | 1    |  | 4.4375  | 4 | 16 | 7      | 9   | 1    |  |
| 3.2308  | 3 | 13 | 3      | 10  | 1    |  | 4.4545  | 4 | 11 | 5      | 6   | 1    |  |
| 3.2667  | 3 | 15 | 4      | 11  | 1    |  | 4.5     | 4 | 2  | 1      | 1   | 1    |  |
| 3.2857  | 3 | 7  | 2      | 5   | 1    |  | 4.5333  | 4 | 15 | 8      | 7   | 1    |  |
| 3.3077  | 3 | 13 | 4      | 9   | 1    |  | 4.5556  | 4 | 9  | 5      | 4   | 1    |  |
| 3.33    | 3 | 3  | 1      | 2   | 1    |  | 4.5833  | 4 | 12 | 7      | 5   | 1    |  |
| 3.3636  | 3 | 11 | 4      | 7   | 1    |  | 4.625   | 4 | 8  | 5      | 3   | 1    |  |

Table 1-1 Relation between Horizontal Resolution Conversion Ratio ( $\beta$ ) and Parameters ( $\lambda$ )

| $\beta$ | m | k  | $\lambda$ |     | HRCM |  | $\beta$ | m | k  | $\lambda$ |     | HRCM |  |
|---------|---|----|-----------|-----|------|--|---------|---|----|-----------|-----|------|--|
|         |   |    | '1'       | '0' |      |  |         |   |    | '1'       | '0' |      |  |
| 4.6429  | 4 | 14 | 9         | 5   | 1    |  | 5.867   | 5 | 15 | 13        | 2   | 1    |  |
| 4.6666  | 4 | 3  | 2         | 1   | 1    |  | 5.8889  | 5 | 9  | 8         | 1   | 1    |  |
| 4.6875  | 4 | 16 | 11        | 5   | 1    |  | 5.9091  | 5 | 11 | 10        | 1   | 1    |  |
| 4.7143  | 4 | 7  | 5         | 2   | 1    |  | 5.9231  | 5 | 13 | 12        | 1   | 1    |  |
| 4.7333  | 4 | 15 | 11        | 4   | 1    |  | 5.9375  | 5 | 16 | 15        | 1   | 1    |  |
| 4.75    | 4 | 4  | 3         | 1   | 1    |  | 6.0     | 5 | 1  | 1         | 0   | 1    |  |
| 4.7779  | 4 | 9  | 7         | 2   | 1    |  | 6.0625  | 6 | 16 | 1         | 15  | 1    |  |
| 4.8     | 4 | 5  | 4         | 1   | 1    |  | 6.0667  | 6 | 15 | 1         | 14  | 1    |  |
| 4.8333  | 4 | 6  | 5         | 1   | 1    |  | 6.0833  | 6 | 12 | 1         | 11  | 1    |  |
| 4.8572  | 4 | 7  | 6         | 1   | 1    |  | 6.1     | 6 | 10 | 1         | 9   | 1    |  |
| 4.875   | 4 | 8  | 7         | 1   | 1    |  | 6.125   | 6 | 8  | 1         | 7   | 1    |  |
| 4.9     | 4 | 10 | 9         | 1   | 1    |  | 6.1428  | 6 | 7  | 1         | 6   | 1    |  |
| 4.9167  | 4 | 12 | 11        | 1   | 1    |  | 6.1667  | 6 | 6  | 1         | 5   | 1    |  |
| 4.9333  | 4 | 15 | 14        | 1   | 1    |  | 6.1818  | 6 | 11 | 2         | 9   | 1    |  |
| 5.0     | 4 | 1  | 1         | 0   | 1    |  | 6.2     | 6 | 5  | 1         | 4   | 1    |  |
| 5.0625  | 5 | 16 | 1         | 15  | 1    |  | 6.2222  | 6 | 9  | 2         | 7   | 1    |  |
| 5.0833  | 5 | 12 | 1         | 11  | 1    |  | 6.25    | 6 | 4  | 1         | 3   | 1    |  |
| 5.1     | 5 | 10 | 1         | 9   | 1    |  | 6.2727  | 6 | 13 | 3         | 10  | 1    |  |
| 5.125   | 5 | 8  | 1         | 7   | 1    |  | 6.3     | 6 | 10 | 3         | 7   | 1    |  |
| 5.1429  | 5 | 7  | 1         | 6   | 1    |  | 6.3333  | 6 | 3  | 1         | 2   | 1    |  |
| 5.1667  | 5 | 6  | 1         | 5   | 1    |  | 6.3636  | 6 | 11 | 4         | 7   | 1    |  |
| 5.1875  | 5 | 16 | 3         | 13  | 1    |  | 6.3846  | 6 | 13 | 5         | 8   | 1    |  |
| 5.2143  | 5 | 14 | 3         | 11  | 1    |  | 6.4167  | 6 | 12 | 5         | 7   | 1    |  |
| 5.2308  | 5 | 13 | 3         | 10  | 1    |  | 6.4375  | 6 | 16 | 7         | 9   | 1    |  |
| 5.2667  | 5 | 15 | 4         | 11  | 1    |  | 6.4615  | 6 | 13 | 6         | 7   | 1    |  |
| 5.2857  | 5 | 7  | 2         | 5   | 1    |  | 6.5     | 6 | 2  | 1         | 1   | 1    |  |
| 5.3077  | 5 | 13 | 4         | 9   | 1    |  | 6.5334  | 6 | 15 | 8         | 7   | 1    |  |
| 5.333   | 5 | 3  | 1         | 2   | 1    |  | 6.5556  | 6 | 9  | 5         | 4   | 1    |  |
| 5.3636  | 5 | 11 | 4         | 7   | 1    |  | 6.5833  | 6 | 12 | 7         | 5   | 1    |  |
| 5.3846  | 5 | 13 | 5         | 8   | 1    |  | 6.6154  | 6 | 13 | 8         | 5   | 1    |  |
| 5.4167  | 5 | 12 | 5         | 7   | 1    |  | 6.6364  | 6 | 11 | 7         | 4   | 1    |  |
| 5.4375  | 5 | 16 | 7         | 9   | 1    |  | 6.6667  | 6 | 3  | 2         | 1   | 1    |  |
| 5.4546  | 5 | 11 | 5         | 6   | 1    |  | 6.6923  | 6 | 13 | 9         | 4   | 1    |  |
| 5.5     | 5 | 2  | 1         | 1   | 1    |  | 6.7143  | 6 | 7  | 5         | 2   | 1    |  |
| 5.5385  | 5 | 13 | 7         | 6   | 1    |  | 6.75    | 6 | 4  | 3         | 1   | 1    |  |
| 5.5556  | 5 | 9  | 5         | 4   | 1    |  | 6.7778  | 6 | 9  | 7         | 2   | 1    |  |
| 5.5714  | 5 | 7  | 4         | 3   | 1    |  | 6.8     | 6 | 5  | 4         | 1   | 1    |  |
| 5.6     | 5 | 5  | 3         | 2   | 1    |  | 6.8334  | 6 | 6  | 5         | 1   | 1    |  |
| 5.625   | 5 | 8  | 5         | 3   | 1    |  | 6.8572  | 6 | 7  | 6         | 1   | 1    |  |
| 5.6429  | 5 | 14 | 9         | 5   | 1    |  | 6.8889  | 6 | 9  | 8         | 1   | 1    |  |
| 5.6667  | 5 | 3  | 2         | 1   | 1    |  | 6.909   | 6 | 11 | 10        | 1   | 1    |  |
| 5.6923  | 5 | 13 | 9         | 4   | 1    |  | 6.9286  | 6 | 14 | 13        | 1   | 1    |  |
| 5.7143  | 5 | 7  | 5         | 2   | 1    |  | 6.9375  | 6 | 16 | 15        | 1   | 1    |  |
| 5.7333  | 5 | 15 | 11        | 4   | 1    |  | 7.0     | 6 | 1  | 1         | 0   | 1    |  |
| 5.7692  | 5 | 13 | 10        | 3   | 1    |  | 7.0625  | 7 | 16 | 1         | 15  | 1    |  |
| 5.7857  | 5 | 14 | 11        | 3   | 1    |  | 7.0833  | 7 | 12 | 1         | 11  | 1    |  |
| 5.8182  | 5 | 11 | 9         | 2   | 1    |  | 7.1     | 7 | 10 | 1         | 9   | 1    |  |
| 5.8461  | 5 | 13 | 11        | 2   | 1    |  | 7.125   | 7 | 8  | 1         | 7   | 1    |  |



Table 1-1 Relation between Horizontal Resolution Conversion Ratio ( $\beta$ ) and Parameters (4)

| $\beta$ | m | k  | $\ell$ |     | HRCM |  | $\beta$ | m | k | $\ell$ |     | HRCM |  |
|---------|---|----|--------|-----|------|--|---------|---|---|--------|-----|------|--|
|         |   |    | '1'    | '0' |      |  |         |   |   | '1'    | '0' |      |  |
| 7.1429  | 7 | 7  | 1      | 6   | 1    |  |         |   |   |        |     |      |  |
| 7.1667  | 7 | 6  | 1      | 5   | 1    |  |         |   |   |        |     |      |  |
| 7.1875  | 7 | 16 | 3      | 13  | 1    |  |         |   |   |        |     |      |  |
| 7.2143  | 7 | 14 | 3      | 11  | 1    |  |         |   |   |        |     |      |  |
| 7.25    | 7 | 4  | 1      | 3   | 1    |  |         |   |   |        |     |      |  |
| 7.2727  | 7 | 11 | 3      | 8   | 1    |  |         |   |   |        |     |      |  |
| 7.3     | 7 | 10 | 3      | 7   | 1    |  |         |   |   |        |     |      |  |
| 7.3333  | 7 | 3  | 1      | 2   | 1    |  |         |   |   |        |     |      |  |
| 7.375   | 7 | 8  | 3      | 5   | 1    |  |         |   |   |        |     |      |  |
| 7.4     | 7 | 5  | 2      | 3   | 1    |  |         |   |   |        |     |      |  |
| 7.4286  | 7 | 7  | 3      | 4   | 1    |  |         |   |   |        |     |      |  |
| 7.4445  | 7 | 9  | 4      | 5   | 1    |  |         |   |   |        |     |      |  |
| 7.4615  | 7 | 13 | 6      | 7   | 1    |  |         |   |   |        |     |      |  |
| 7.5     | 7 | 2  | 1      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.5385  | 7 | 13 | 7      | 6   | 1    |  |         |   |   |        |     |      |  |
| 7.5625  | 7 | 16 | 9      | 7   | 1    |  |         |   |   |        |     |      |  |
| 7.5833  | 7 | 12 | 7      | 5   | 1    |  |         |   |   |        |     |      |  |
| 7.6154  | 7 | 13 | 8      | 5   | 1    |  |         |   |   |        |     |      |  |
| 7.6364  | 7 | 11 | 7      | 4   | 1    |  |         |   |   |        |     |      |  |
| 7.6666  | 7 | 3  | 2      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.6923  | 7 | 13 | 9      | 4   | 1    |  |         |   |   |        |     |      |  |
| 7.7143  | 7 | 7  | 5      | 2   | 1    |  |         |   |   |        |     |      |  |
| 7.7334  | 7 | 15 | 11     | 4   | 1    |  |         |   |   |        |     |      |  |
| 7.7692  | 7 | 13 | 10     | 3   | 1    |  |         |   |   |        |     |      |  |
| 7.8     | 7 | 5  | 4      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.8333  | 7 | 6  | 5      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.8571  | 7 | 7  | 6      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.875   | 7 | 8  | 7      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.9     | 7 | 10 | 9      | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.9231  | 7 | 13 | 12     | 1   | 1    |  |         |   |   |        |     |      |  |
| 7.9336  | 7 | 15 | 14     | 1   | 1    |  |         |   |   |        |     |      |  |
| 8.0     | 7 | 1  | 1      | 0   | 1    |  |         |   |   |        |     |      |  |



# HD63085

## DICEP (Document Image Compression and Expansion Processor)

— PRELIMINARY —

The HD63085 (DICEP) is a LSI that compresses (or encodes) and expands (or decodes) the digital data representing a document image. The DICEP uses Modified Huffman (MH) coding scheme, Modified Relative Element Address Designate (MR) coding scheme and Modified MR ( $M^2R$ ) coding scheme which are compatible with the CCITT (Comité Consultatif International Télégraphique et Téléphonique) recommendations for Group 3 and Group 4 facsimile apparatus.

As the DICEP stores coding and decoding algorithms in the microprogram ROM as firmware, a single MPU command allows this LSI to encode or decode a scan line of digital data.

This LSI is suitable for Group 3 and Group 4 facsimile apparatus, file servers, intelligent copies, terminals, word processors, laser beam printers and other office automation systems.

### ■ FEATURES

- Various coding schemes . . . . MH, MR,  $M^2R$  and Run Length coding
- Compatible with the CCITT recommendation for Group 3 and Group 4 facsimile apparatus
- Interfaceable with either Motorola type MPU or Intel type MPU
- DMA capability through the document image bus  
    4M Byte/sec (at input clock frequency of 32 MHz)
- A variety of programmable parameters
  - The length of a scan line : 0 ~ 65535 bits
  - The number of RTC or EOL code words: 0 ~ 65535
  - Programmable starting address
  - Coding and decoding of a desired part of a document
- Selectable document image bus size
  - Document image bus : 8 bits or 16 bits
  - System bus : 8 bits
- 64K Bytes of document image memory is available independently of the MPU
- 2  $\mu$ m CMOS process technology
- Single 5V supply

HD63085Y-8



(PC-72)

### ● PIN ARRANGEMENT



| Pin No | Function                      | Pin No | Function                       | Pin No | Function          |
|--------|-------------------------------|--------|--------------------------------|--------|-------------------|
| 1      | MA/M <sub>D<sub>2</sub></sub> | 25     | V <sub>DD</sub> /80            | 49     | DMA               |
| 2      | MA/M <sub>D<sub>2</sub></sub> | 26     | NC                             | 50     | V <sub>S</sub>    |
| 3      | MA/M <sub>D<sub>2</sub></sub> | 27     | RESET                          | 51     | low               |
| 4      | MA/M <sub>D<sub>2</sub></sub> | 28     | V <sub>DD</sub>                | 52     | DACK <sub>O</sub> |
| 5      | MA/M <sub>D<sub>2</sub></sub> | 29     | D <sub>0</sub>                 | 53     | DRQ <sub>I</sub>  |
| 6      | MA/M <sub>D<sub>2</sub></sub> | 30     | D <sub>1</sub>                 | 54     | NC                |
| 7      | MA/M <sub>D<sub>2</sub></sub> | 31     | D <sub>2</sub>                 | 55     | CS                |
| 8      | MA/M <sub>D<sub>2</sub></sub> | 32     | D <sub>3</sub>                 | 56     | DRQ <sub>O</sub>  |
| 9      | V <sub>S</sub>                | 33     | V <sub>DD</sub>                | 57     | BROT              |
| 10     | TEST0                         | 34     | READY                          | 58     | A <sub>2</sub>    |
| 11     | 4CLK                          | 35     | MAS                            | 59     | A <sub>0</sub>    |
| 12     | TDATA                         | 36     | MA/M <sub>D<sub>1</sub></sub>  | 60     | IROT              |
| 13     | VDS                           | 37     | MA/M <sub>D<sub>3</sub></sub>  | 61     | V <sub>DD</sub>   |
| 14     | MW                            | 38     | MA/M <sub>D<sub>5</sub></sub>  | 62     | D <sub>1</sub>    |
| 15     | SET                           | 39     | MA/M <sub>D<sub>7</sub></sub>  | 63     | D <sub>3</sub>    |
| 16     | V <sub>S</sub>                | 40     | MA/M <sub>D<sub>9</sub></sub>  | 64     | D <sub>2</sub>    |
| 17     | I <sub>OR</sub>               | 41     | MA/M <sub>D<sub>11</sub></sub> | 65     | D <sub>7</sub>    |
| 18     | DTC                           | 42     | MA/M <sub>D<sub>13</sub></sub> | 66     | V <sub>DD</sub>   |
| 19     | R/W                           | 43     | MA/M <sub>D<sub>15</sub></sub> | 67     | NC                |
| 20     | AGE                           | 44     | V <sub>S</sub>                 | 68     | MAEN              |
| 21     | DS                            | 45     | TEST1                          | 69     | NC                |
| 22     | DACK <sub>I</sub>             | 46     | LDS                            | 70     | NC                |
| 23     | BACK                          | 47     | MDEN                           | 71     | NC                |
| 24     | A <sub>1</sub>                | 48     | MR                             | 72     | NC                |



## 1.1 Absolute Maximum Rating

| No | Item                  | Symbol | Value        | Unit |
|----|-----------------------|--------|--------------|------|
| 1  | Supply Voltage        | VDD *  | -0.3 to +7.0 | V    |
| 2  | Input Voltage         | Vin *  | -0.3 to +7.0 | V    |
| 3  | Operating Temperature | Topr   | 0 to +70     | °C   |
| 4  | Storage Temperature   | Tstg   | -55 to +150  | °C   |

\* Voltages referenced to Vss=0V.

## &lt;Recommended Operating Conditions&gt;

| No | Item                  | Symbol | min  | typ | max  | Unit |
|----|-----------------------|--------|------|-----|------|------|
| 1  | Supply Voltage        | VDD *  | 4.75 | 5   | 5.25 | V    |
| 2  | Input Voltage         | Vil *  | -0.3 | -   | 0.8  | V    |
| 3  |                       | ViH *  | 2.2  | -   | VDD  | V    |
| 4  | Operating Temperature | Topr   | 0    | 25  | 70   | °C   |

\* Voltages referenced to Vss=0V.



## 1.2 DC Characteristics

( VDD=5.0V $\pm$ 5%, Vss=0V, Ta=0 to +70°C )

| No | Item                                    | Symbol | Test Condition   | min  | typ | max | Unit    |
|----|-----------------------------------------|--------|------------------|------|-----|-----|---------|
| 1  | Input High Voltage                      | VIH    |                  | 2.2  | -   | VDD | V       |
| 2  | Input Low Voltage                       | VIL    |                  | -0.3 | -   | 0.8 | V       |
| 3  | Input Leakage Voltage                   | IIN    | Vin=0 to 5.25V   | -10  | -   | 10  | $\mu$ A |
| 4  | Three-State (Off State) Leakage Current | Itsi   | Vin=0 to 5.25V   | -10  | -   | 10  | $\mu$ A |
| 5  | Output High Voltage                     | VOH    | IOH=-400 $\mu$ A | 2.4  | -   | -   | V       |
| 6  | Output Low Voltage                      | VOL    | IOL= 2mA         | -    | -   | 0.4 | V       |
| 7  | Standby Current                         | IDDS   |                  | -    | -   | 1   | mA      |
| 8  | Power Dissipation                       | PD     |                  |      | 150 | -   | mW      |

## &lt;Capacitance&gt;

| No | Item                     | Symbol | Test Codition | min | typ | max | Unit |
|----|--------------------------|--------|---------------|-----|-----|-----|------|
| 1  | Input Capacitance        | CIN    | f = 1MHz      |     |     | 8   | pF   |
| 2  | Output Capacitance       | COUT   |               |     |     | 10  | pF   |
| 3  | Input/Output Capacitance | CI/O   |               |     |     | 12  | pF   |

\* These parameters are sample values.



### 1.3 AC Characteristics

#### 1.3.1 Clock Timing

( VDD=5.0V $\pm$ 5%, Vss=0V, Ta=0 to +70°C unless otherwise noted.)

| Item             | Symbol      | Test Condition | min | typ | max | Unit | Application Terminal |
|------------------|-------------|----------------|-----|-----|-----|------|----------------------|
| 4CLK Cycle Time  | $\phi$ 4CLK | Fig. 1-1       |     |     |     | ns   | 4CLK                 |
| 4CLK Pulse Width | PWH PWL     | Fig. 1-1       |     |     |     | ns   | 4CLK                 |
| 4CLK Rise Time   | tr          | Fig. 1-1       |     |     |     | ns   | 4CLK                 |
| 4CLK Fall Time   | tf          | Fig. 1-1       |     |     |     | ns   | 4CLK                 |



## 1.3.2 System Bus Timing

## 1.3.2.1 Using a Motorola MPU (68000, 6800, etc.)

( VDD=5.0V<sub>+5%</sub>, Vss=0V, Ta=0 to +70°C Cout=140pF unless otherwise noted.)

| Item                   | Symbol       | Test Condition       | min | typ | max | Unit | Application Terminal          |
|------------------------|--------------|----------------------|-----|-----|-----|------|-------------------------------|
| DS Cycle Time          | tCYCE        | Fig. 1-2<br>Fig. 1-5 | 500 |     |     | ns   | DS                            |
| DS Pulse Width         | PWEH<br>PWEL | Fig. 1-2<br>Fig. 1-5 | 220 |     |     | ns   | DS                            |
| DS Rise or Fall Time   | tr<br>tf     | Fig. 1-2<br>Fig. 1-5 |     |     | 25  | ns   | DS                            |
| Address Setup Time     | tAS          | Fig. 1-2             | 70  |     |     | ns   | CS <sub>1</sub> A0-A2,<br>R/W |
| Address Hold Time      | tAH          | Fig. 1-2             | 30  |     |     | ns   | CS <sub>1</sub> A0-A2,<br>R/W |
| Output Data Delay Time | tDDR         | Fig. 1-2<br>Fig. 1-5 |     |     | 180 | ns   | D0-D7                         |
| Output Data Hold Time  | tDHR         | Fig. 1-2<br>Fig. 1-5 | 10  |     |     | ns   | D0-D7                         |
| Input Data Setup Time  | tDSW         | Fig. 1-2<br>Fig. 1-5 | 60  |     |     | ns   | D0-D7                         |
| Input Data Hold Time   | tDHW         | Fig. 1-2<br>Fig. 1-5 | 40  |     |     | ns   | D0-D7                         |
| IRQT Release Time      | tIRQT        | Fig. 1-2             |     |     |     | ns   | IRQT                          |
| DACKI Setup Time       | tAS          | Fig. 1-5             | 70  |     |     | ns   | DACKI                         |
| DACKI Hold Time        | tAH          | Fig. 1-5             | 30  |     |     | ns   | DACKI                         |
| DRQTO Release Time     | tDRQTO       | Fig. 1-5             |     |     |     | ns   | DRQTO                         |



## 1.3.2.2 Using and Intel Type MPU (8086, 8080, etc.)

( VDD=5.0V $\pm$ 5%, Vss=0V, Ta=0 to +70°C Cout=140pF unless otherwise noted.)

| Item                   | Symbol | Test Condition       | min | typ | max | Unit | Application Terminal     |
|------------------------|--------|----------------------|-----|-----|-----|------|--------------------------|
| Address Setup Time     | tAR    | Fig. 1-3             | 70  |     |     |      | $\overline{CS}$ , A0-A2, |
| Address Hold Time      | tRA    | Fig. 1-3             | 30  |     |     |      | $\overline{CS}$ , A0-A2, |
| Output Data Delay Time | tRD    | Fig. 1-3<br>Fig. 1-6 |     |     | 180 |      | D0-D7                    |
| Output Data Hold Time  | tDR    | Fig. 1-3<br>Fig. 1-6 | 10  |     |     |      | D0-D7                    |
| Read Pulse Width       | tRW    | Fig. 1-3<br>Fig. 1-6 | 200 |     |     |      | DS                       |
| Address Setup Time     | tAW    | Fig. 1-4             | 70  |     |     |      | $\overline{CS}$ , A0-A2  |
| Address Hold Time      | tWA    | Fig. 1-4             | 30  |     |     |      | $\overline{CS}$ , A0-A2  |
| Input Data Setup Time  | tWD    | Fig. 1-4<br>Fig. 1-7 | 60  |     |     |      | D0-D7                    |
| Input Data Hold Time   | tDW    | Fig. 1-4<br>Fig. 1-7 | 40  |     |     |      | D0-D7                    |
| Write Pulse Width      | tWW    | Fig. 1-4<br>Fig. 1-7 | 200 |     |     |      | R/W                      |
| IRQT Release Time      | tIRQT  | Fig. 1-3             |     |     |     |      | IRQT                     |
| DACKI Setup Time       | tAR    | Fig. 1-6             | 70  |     |     |      | $\overline{DACKI}$       |
| DACKI Hold Time        | tRA    | Fig. 1-6             | 30  |     |     |      | $\overline{DACKI}$       |
| DACKI Setup Time       | tAW    | Fig. 1-7             | 70  |     |     |      | $\overline{DACKI}$       |
| DACKI Hold Time        | tWA    | Fig. 1-8             | 30  |     |     |      | $\overline{DACKI}$       |
| DRQTO Release Time     | tDRQTO | Fig. 1-6<br>Fig. 1-7 |     |     |     |      | DRQTO                    |



## 1.3.3 Document Image Bus Timing

VDD=5.0V±5%, Vss=0V, Ta=0 to +70°C, Cout=140pF unless  
 otherwise noted.  
 However, the values in the parentheses are the values  
 at Cout=50pF.

| Item                               | Symbol | Test Condition       | min | typ  | max | Unit | Application Terminal |
|------------------------------------|--------|----------------------|-----|------|-----|------|----------------------|
| Address Enable Active Delay Time   | tDAEL  | Fig. 1-8<br>Fig. 1-9 |     | (70) | 150 | ns   | MAEN                 |
| Address Enable Inactive Delay Time | tDAEH  | Fig. 1-8<br>Fig. 1-9 |     | (70) | 140 | ns   | MAEN                 |
| Address Strobe Active Delay Time   | tDASH  | Fig. 1-8<br>Fig. 1-9 |     | (70) | 140 | ns   | MAS                  |
| Address Strobe Inactive Delay Time | tDASL  | Fig. 1-8<br>Fig. 1-9 |     | (60) | 120 | ns   | MAS                  |
| Data Strobe Valid Delay Time       | tDDSV  | Fig. 1-8<br>Fig. 1-9 |     | (60) | 140 | ns   | UDS, LDS             |
| Data Strobe Active Delay Time      | tDDSL  | Fig. 1-8<br>Fig. 1-9 |     | (75) | 140 | ns   | UDS, LDS             |
| Data Strobe Inactive Delay Time    | tDDSH  | Fig. 1-8<br>Fig. 1-9 |     | (75) | 140 | ns   | UDS, LDS             |
| Data Strobe Float Delay Time       | tDDSX  | Fig. 1-8<br>Fig. 1-9 |     | ( )  |     | ns   | UDS, LDS             |
| Data Enable Active Delay Time      | tDDEL  | Fig. 1-8             |     | (80) | 130 | ns   | MDEN                 |
| Data Enable Inactive Delay Time    | tDDEH  | Fig. 1-8             |     | (75) | 140 | ns   | MDEN                 |
| Read Valid Delay Time              | tDRDV  | Fig. 1-8<br>Fig. 1-9 |     | (60) | 140 | ns   | IOR, MR              |
| Read Active Delay Time             | tDRDL  | Fig. 1-8<br>Fig. 1-9 |     | (70) | 140 | ns   | IOR, MR              |
| Read Inactive Delay Time           | tDRDH  | Fig. 1-8<br>Fig. 1-9 |     | (75) | 140 | ns   | IOR, MR              |
| Read Float Delay Time              | tDRDX  | Fig. 1-8<br>Fig. 1-9 |     | ( )  |     | ns   | IOR, MR              |

(to be continued)



(continued)

| Item                                | Symbol | Test Condition       | min | typ          | max          | Unit | Application Terminal   |
|-------------------------------------|--------|----------------------|-----|--------------|--------------|------|------------------------|
| Write Valid Delay Time              | tDWRV  | Fig. 1-8<br>Fig. 1-9 |     | (60)         | 140          | ns   | <u>IOW</u> , <u>MW</u> |
| Write Active Delay Time             | tDWRL  | Fig. 1-8<br>Fig. 1-9 |     | (70)         | 140          | ns   | <u>IOW</u> , <u>MW</u> |
| Write Inactive Delay Time           | tDWRH  | Fig. 1-8<br>Fig. 1-9 |     | (80)         | 140          | ns   | <u>IOW</u> , <u>MW</u> |
| Write Float Delay Time              | tDWRX  | Fig. 1-8<br>Fig. 1-9 |     | ( )          |              | ns   | <u>IOW</u> , <u>MW</u> |
| Address Valid Delay Time            | tMAV   | Fig. 1-8<br>Fig. 1-9 |     | (75)         | 140          | ns   | MA/MDO -<br>MA/MD15    |
| Address Hold Delay Time             | tMAH   | Fig. 1-8<br>Fig. 1-9 | 25  | (50)         |              | ns   | MA/MDO -<br>MA/MD15    |
| Data Setup Time (Read)              | tDSR   | Fig. 1-8             | 10  | (10)         |              | ns   | MA/MDO -<br>MA/MD15    |
| Data Hold Time (Read)               | tDHR   | Fig. 1-8             | 70  | (70)         |              | ns   | MA/MDO -<br>MA/MD15    |
| Data Delay Time (Write)             | tDDW   | Fig. 1-8             |     | (95)         | 170          | ns   | MA/MDO -<br>MA/MD15    |
| Data Hold Time (Write)              | tDHW   | Fig. 1-8             | 15  | (15)         |              | ns   | MA/MDO -<br>MA/MD15    |
| DMA Acknowledge Active Delay Time   | tDAKL  | Fig. 1-9             |     | (60)         | 140          | ns   | <u>DACKO</u>           |
| DMA Acknowledge Inactive Delay Time | tDAKH  | Fig. 1-9             |     | (65)         | 140          | ns   | <u>DACKO</u>           |
| DMA Active Delay Time               | tDDMAL | Fig. 1-9             |     | (80)         | 140          | ns   | <u>DMA</u>             |
| DMA Inactive Delay Time             | tDDMAH | Fig. 1-9             |     | (70)         | 140          | ns   | <u>DMA</u>             |
| DTC Active Delay Time               | tDDTCH | Fig. 1-9             |     | 4CLK<br>+ 75 | 4CLK<br>+140 | ns   | DTC                    |
| DTC Inactive Delay Time             | tDDTCL | Fig. 1-9             |     | (50)         | 130          | ns   | DTC                    |







Fig. 1-3 System Bus Read Timing  
(80 Type MPU)



Fig. 1-4 System Bus Write Timing  
(80 Type MPU)





Fig. 1-5 System Bus DMA Timing  
(Motorola Type MPU)



Fig. 1-6 System Bus DMA Timing  
(DICEP → SYSTEM BUS)  
(80 Type MPU)



Fig. 1-7 System Bus DMA Timing  
(SYSTEM BUS → DICEP)  
(Intel Type MPU)



Fig. 1-8 Document Image Bus Read/Write Timing





Fig. 1-9 Document Image Bus DMA Timing

# HD68230 PI/T (Parallel Interface Timer)

—PRELIMINARY—

The HD68230 Parallel Interface/Timer provides versatile double buffered parallel interfaces and an operating system oriented timer to HD68000 systems. The parallel interfaces operate in unidirectional or bidirectional modes, either 8 or 16 bits wide. In the unidirectional modes, an associated data direction register determines whether the port pins are inputs or outputs. In the bidirectional modes the data direction registers are ignored and the direction is determined dynamically by the state of four handshake pins. These programmable handshake pins provide an interface flexible enough for connection to a wide variety of low, medium, or high speed peripherals or other computer systems. The PI/T ports allow use of vectored or autovectored interrupts, and also provide a DMA Request pin for connection to the HD68450 Direct Memory Access Controller or a similar circuit. The PI/T timer contains a 24-bit wide counter and a 5-bit prescaler. The timer may be clocked by the system clock (PI/T CLK pin) or by an external clock (TIN pin), and a 5-bit prescaler can be used. It can generate periodic interrupts, a square wave, or a single interrupt after a programmed time period. Also it can be used for elapsed time measurement or as a device watchdog.

## ■ FEATURES

- HD68000 Bus Compatible
- Port Modes Include:
  - Bit I/O
  - Unidirectional 8-Bit and 16-Bit
  - Bidirectional 8-Bit and 16-Bit
- Selectable Handshaking Options
- 24-Bit Programmable Timer
- Software Programmable Timer Modes
- Contains Interrupt Vector Generation Logic
- Separate Port and Timer Interrupt Service Requests
- Registers are Read/Write and Directly Addressable
- Registers are Addressed for MOVEP (Move Peripheral) and DMAC Compatibility

## ■ TYPE OF PRODUCTS

| Type No.    | Bus Timing |
|-------------|------------|
| HD68230P-8  | 8 MHz      |
| HD68230P-10 | 10 MHz     |



## ■ PIN ARRANGEMENT



(Top View)



## ■ PI/T SYSTEM BLOCK DIAGRAM



## ■ BLOCK DIAGRAM



## ■ ABSOLUTE MAXIMUM RATINGS

| Item                        | Symbol     | Value     | Unit |
|-----------------------------|------------|-----------|------|
| Supply Voltage              | $V_{CC}^*$ | -0.3~+7.0 | V    |
| Input Voltage               | $V_{in}^*$ | -0.3~+7.0 | V    |
| Operating Temperature Range | $T_{opr}$  | 0~+70     | °C   |
| Storage Temperature         | $T_{stg}$  | -55~+150  | °C   |

\* With respect to  $V_{SS}$  (SYSTEM GND)

(NOTE) This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either  $V_{SS}$  or  $V_{CC}$ ).

## ■ RECOMMENDED OPERATING CONDITIONS

| Item                  | Symbol     | min            | typ | max            | Unit |
|-----------------------|------------|----------------|-----|----------------|------|
| Supply Voltage        | $V_{CC}^*$ | 4.75           | 5.0 | 5.25           | V    |
| Input Voltage         | $V_{IH}^*$ | $V_{SS} + 2.0$ | —   | $V_{CC}$       | V    |
|                       | $V_{IL}^*$ | $V_{SS} - 0.3$ | —   | $V_{SS} + 0.8$ | V    |
| Operating Temperature | $T_{opr}$  | 0              | 25  | 70             | °C   |

\* With respect to  $V_{SS}$  (SYSTEM GND)

## ■ ELECTRICAL CHARACTERISTICS

### • DC CHARACTERISTICS ( $V_{CC} = 5V \pm 5\%$ , $V_{SS} = 0V$ , $T_a = 0 \sim +70^\circ C$ unless otherwise noted.)

| Item                                     |                                                                                                                                                                                                                                                                  | Symbol    | Test Condition                                                               | min            | typ | max            | Unit |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------------------------------------------------------------------|----------------|-----|----------------|------|
| Input "High" Voltage                     |                                                                                                                                                                                                                                                                  | $V_{IH}$  |                                                                              | $V_{SS} + 2.0$ | —   | $V_{CC}$       | V    |
| Input "Low" Voltage                      |                                                                                                                                                                                                                                                                  | $V_{IL}$  |                                                                              | $V_{SS} - 0.3$ | —   | $V_{SS} + 0.8$ | V    |
| Input Leakage Current                    | H1, H3, R/W, RESET<br>CLK, RS1-RS5, CS                                                                                                                                                                                                                           | $I_{in}$  | $V_{in} = 0 \sim 5.25V$                                                      | —              | —   | 10.0           | μA   |
| Three-State (Off State)<br>Input Current | <u>DTACK, PC<sub>0</sub>-PC<sub>7</sub>, D<sub>0</sub>-D<sub>7</sub></u>                                                                                                                                                                                         | $I_{TSI}$ | $V_{in} = 0.4 \sim 2.4V$                                                     | —              |     | 20             | μA   |
|                                          | <u>H2, H4, PA<sub>0</sub>-PA<sub>7</sub>, PB<sub>0</sub>-PB<sub>7</sub></u>                                                                                                                                                                                      |           |                                                                              | -0.1           |     | -1.0           | mA   |
| Output "High" Voltage                    | D <sub>0</sub> -D <sub>7</sub> , DTACK<br>PA <sub>0</sub> -PA <sub>7</sub> , PB <sub>0</sub> -PB <sub>7</sub> , H2, H4<br>PC <sub>0</sub> -PC <sub>7</sub>                                                                                                       | $V_{OH}$  | $I_{OH} = -400\mu A$<br>$I_{OH} = -150\mu A$<br>$I_{OH} = -100\mu A$         | $V_{SS} + 2.4$ | —   | —              | V    |
| Output "Low" Voltage                     | PC <sub>3</sub> /TOUT, PC <sub>2</sub> /PIRQ<br>D <sub>0</sub> -D <sub>7</sub> , DTACK<br>PA <sub>0</sub> -PA <sub>7</sub> , PB <sub>0</sub> -PB <sub>7</sub> , H2, H4<br>PC <sub>0</sub> -PC <sub>2</sub> , PC <sub>4</sub> , PC <sub>6</sub> , PC <sub>7</sub> | $V_{OL}$  | $I_{OL} = 8.8mA$<br>$I_{OL} = 5.3mA$<br>$I_{OL} = 2.4mA$<br>$I_{OL} = 2.4mA$ | —              | —   | 0.5            | V    |
| Power Dissipation                        |                                                                                                                                                                                                                                                                  | $P_{INT}$ | $T_a = 0^\circ C$                                                            | —              | —   | 500            | mW   |
| Capacitance (Package Type Dependent)     |                                                                                                                                                                                                                                                                  | $C_{in}$  | $V_{in} = 0V$ , $T_a = 25^\circ C$                                           | —              | —   | 15             | pF   |

### • CLOCK TIMING

| Characteristic            | Symbol    | 8 MHz      |             | 10 MHz |      | Unit |
|---------------------------|-----------|------------|-------------|--------|------|------|
|                           |           | HD68230P-8 | HD68230P-10 | min    | max  |      |
| Frequency of Operation    | f         | 2.0        | 8.0         | 2.0    | 10.0 | MHz  |
| Cycle Time                | $t_{CYC}$ | 125        | 500         | 100    | 500  | ns   |
| Clock Pulse Width         | $t_{CL}$  | 55         | 250         | 45     | 250  | ns   |
|                           | $t_{CH}$  | 55         | 250         | 45     | 250  |      |
| Clock Rise and Fall Times | $t_{Cr}$  | —          | 10          | —      | 10   | ns   |
|                           | $t_{cf}$  | —          | 10          | —      | 10   |      |





Figure 1 Input Clock Waveform

● AC CHARACTERISTICS ( $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = 0 \sim +70^\circ C$  unless otherwise noted.)

| No.        | Characteristic                                                                     | 8 MHz<br>HD68230P-8 |      | 10 MHz<br>HD68230P-10 |      | Unit        |
|------------|------------------------------------------------------------------------------------|---------------------|------|-----------------------|------|-------------|
|            |                                                                                    | min                 | max  | min                   | max  |             |
| 1          | R/W RS1-RS5 Valid to CS Low (Setup Time)                                           | 0                   | —    | 0                     | —    | ns          |
| 2(*11)     | CS Low to R/W and RS1-RS5 Invalid (Hold Time)                                      | 100                 | —    | 65                    | —    | ns          |
| 3(*1)      | CS Low to CLK Low (Setup Time)                                                     | 30                  | —    | 20                    | —    | ns          |
| 4(*2)      | CS Low to Data Out Valid (Delay)                                                   | —                   | 75   | —                     | 60   | ns          |
| 5          | RS1-RS5 Valid to Data Out Valid (Delay)                                            | —                   | 140  | —                     | 100  | ns          |
| 6          | CLK Low to DTACK Low (Read/Write Cycle) (Delay)                                    | 0                   | 70   | 0                     | 60   | ns          |
| 7(*3)      | DTACK Low to CS High (Hold Time)                                                   | 0                   | —    | 0                     | —    | ns          |
| 8          | CS or PIACK or TIACK High to Data Out Invalid (Hold Time)                          | 0                   | —    | 0                     | —    | ns          |
| 9          | CS or PIACK or TIACK High to D <sub>0</sub> -D <sub>7</sub> High Impedance (Delay) | —                   | 50   | —                     | 45   | ns          |
| 10         | CS or PIACK or TIACK High to DTACK High (Delay)                                    | —                   | 50   | —                     | 30   | ns          |
| 11         | CS or PIACK or TIACK High to DTACK High Impedance (Delay)                          | —                   | 100  | —                     | 55   | ns          |
| 12         | Data Invalid to CS Low (Setup Time)                                                | 0                   | —    | 0                     | —    | ns          |
| 13         | CS Low to Data in Invalid (Hold Time)                                              | 100                 | —    | 65                    | —    | ns          |
| 14         | Input Data Valid to H1(H3) Asserted (Setup Time)                                   | 100                 | —    | 60                    | —    | ns          |
| 15         | H1(H3) Asserted to Input Data Invalid (Hold Time)                                  | 20                  | —    | 20                    | —    | ns          |
| 16         | Handshake Input H1(H4) Pulse Width Asserted                                        | 40                  | —    | 40                    | —    | ns          |
| 17         | Handshake Input (H1-H4) Pulse Width Negated                                        | 40                  | —    | 40                    | —    | ns          |
| 18         | H1(H3) Asserted to H2(H4) Negated (Delay)                                          | —                   | 150  | —                     | 120  | ns          |
| 19         | CLK Low to H2(H4) Asserted (Delay)                                                 | —                   | 100  | —                     | 100  | ns          |
| 20(*4)     | H2(H4) Asserted to H1(H3) Asserted                                                 | 0                   | —    | 0                     | —    | ns          |
| 21(*5)     | CLK Low to H2(H4) Pulse Negated (Delay)                                            | —                   | 125  | —                     | 125  | ns          |
| 22(*9,*12) | Synchronized H1(H3) to CLK Low on which DMAREQ is Asserted (See Figures 18 and 19) | 2.5                 | 3.5  | 2.5                   | 3.5  | CLK Per     |
| 23         | CLK Low DMAREQ is Asserted to CLK Low on which DMAREQ is Negated                   | 3                   | 3    | 3                     | 3    | CLK Per     |
| 24         | CLK Low to Output Data Valid (Delay) (Modes 0, 1)                                  | —                   | 150  | —                     | 120  | ns          |
| 25(*9,*12) | Synchronized H1(H3) to Output Data Invalid (Modes 0, 1)                            | 1.5                 | 2.5  | 1.5                   | 2.5  | CLK Per     |
| 26         | H1 Negated to Output Data Valid (Modes 2, 3)                                       | —                   | 70   | —                     | 50   | ns          |
| 27         | H1 Asserted to Output Data High Impedance (Modes 2, 3)                             | 0                   | 70   | 0                     | 70   | ns          |
| 28         | Read Data Valid to DTACK Low (Setup Time)                                          | 0                   | —    | 0                     | —    | ns          |
| 29         | CLK Low to Data Output Valid (Interrupt Acknowledge Cycle)                         | —                   | 120  | —                     | 100  | ns          |
| 30(*7)     | H1(H3) Asserted to CLK High (Setup Time)                                           | 50                  | —    | 40                    | —    | ns          |
| 31         | PIACK or TIACK Low to CLK Low (Setup Time)                                         | 50                  | —    | 40                    | —    | ns          |
| 32(*12)    | Synchronized CS to CLK Low on which DMAREQ is Asserted (See Figures 18 and 19)     | 3                   | 3    | 3                     | 3    | CLK Per     |
| 33(*9,*12) | Synchronized H1(H3) to CLK Low on which H2(H4) is Asserted                         | 3.5                 | 4.5  | 3.5                   | 4.5  | CLK Per     |
| 34         | CLK Low to DTACK Low (Interrupt Acknowledge Cycle) (Delay)                         | —                   | 75   | —                     | 60   | ns          |
| 35         | CLK Low to DMAREQ Low (Delay)                                                      | 0                   | 120  | 0                     | 100  | ns          |
| 36         | CLK Low to DMAREQ High (Delay)                                                     | 0                   | 120  | 0                     | 100  | ns          |
| —          | CLK Low to PIRQ Low or High Impedance                                              | —                   | 200  | —                     | 150  | ns          |
| —(*8)      | TIN Frequency (External Clock) — Prescaler Used                                    | 0                   | 1    | 0                     | 1    | Fclk(Hz)(6) |
| —          | TIN Frequency (External Clock) — Prescaler Not used                                | 0                   | 1/32 | 0                     | 1/32 | Fclk(Hz)(6) |
| —          | TIN Pulse Width High or Low (External Clock)                                       | 55                  | —    | 45                    | —    | ns          |
| —          | TIN Pulse Width Low (Run/Halt Control)                                             | 1                   | —    | 1                     | —    | CLK         |
| —          | CLK Low to TOUT High, Low, or High Impedance                                       | 0                   | 200  | 0                     | 150  | ns          |
| —          | CS, PIACK, or TIACK High to CS, PIACK, or TIACK Low                                | 50                  | —    | 30                    | —    | ns          |



- (NOTES) (\*1) This specification only applies if the PI/T had completed all operations initiated by the previous bus cycle when CS was asserted. Following a normal read or write bus cycle, all operations are complete within three CLKs after the falling edge of the CLK pin on which DTACK was asserted. If CS is asserted prior to completion of these operations, the new bus cycle, and hence, DTACK is postponed. If all operations of the previous bus cycle were complete when CS was asserted, this specification is made only to insure that DTACK is asserted with respect to the falling edge of the CLK pin as shown in the timing diagram, not to guarantee operation of the part. If the CS setup time is violated, DTACK may be asserted as shown, or may be asserted one clock cycle later.
- (\*2) Assuming the RS1-RS5 to Data Valid Time has also expired.
- (\*3) This specification imposes a lower bound on CS low time, guaranteeing that CS will be low for at least 1 CLK period.
- (\*4) This specification assures recognition of the asserted edge of H1(H3).
- (\*5) This specification applies only when a pulsed handshake option is chosen and the pulse is not shortened due to an early asserted edge of H1 (H3).
- (\*6) CLK refers to the actual frequency of the CLK pin, not the maximum allowable CLK frequency.
- (\*7) If timing number 30 is violated, H1(H3) will be recognized no later than the next rising edge of the clock.
- (\*8) This limit applies to the frequency of the signal at TIN compared to the frequency of the CLK signal during each clock cycle. If any period of the waveform at TIN is smaller than the period of the CLK signal at that instant, then it is likely that the timer circuit will completely ignore one cycle of the TIN signal. Since the frequency measured by a frequency counter is the average frequency of a signal over a specific length of time, the actual frequency at any one time will vary above and below the average. These variations occur in both the TIN and CLK signals.
- If these two signals are derived from different sources they will have different instantaneous frequency variations. In this case the frequency applied to the TIN pin must be distinctly less than the frequency at the CLK pin to avoid lost cycles of the TIN signal. Measurements have shown that with signals derived from different crystal oscillators applied to the TIN and CLK pins with fast rise and fall times. The TIN frequency can approach 80 to 90% of the frequency of the CLK signal without a loss of a cycle of the TIN signal.
- If these two signals are derived from the same frequency source then the frequency of the signal applied to TIN can be 100% of the frequency at the CLK pin. They may be generated by different buffers from the same signal or one may be an inverted version of the other.
- The TIN signal may be generated by an 'AND' function of the clock and a control signal.
- (\*9) This limit applies in every case. There are no exceptions to this specification.
- (\*10) If a bus access and peripheral access occur at the same time, add one clock to specifications 22 and 33.
- (\*11) See BUS INTERFACE CONNECTION section for exception.
- (\*12) This Limit specifies the nominal outputting in PI/T clock cycles. To obtain the output timing in nanoseconds, add or subtract the appropriate setup time and/or propagation time from the signals to the respective clock edges.



Figure 2 Bus Read Cycle Timing

NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.



**Figure 3 Bus Write Cycle Timing**

**NOTE:** Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.



**Figure 4 Interrupt Acknowledge Functional Timing Diagram**

**NOTE:** Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.



**Figure 5 Peripheral Interface Input Timing**





Figure 6 Peripheral Interface Output Timing

## ■ GENERAL DESCRIPTION

The PI/T consists of two logically independent sections: the ports and the timer. The port section consists of Port A ( $PA_0\sim_7$ ), Port B ( $PB_0\sim_7$ ), four handshake pins (H1, H2, H3, and H4), two general I/O pins, and six dual-function pins. The dual-function pins can individually operate as a third port (Port C) or an alternate function related to either Ports A and B, or the timer. The four programmable handshake pins, depending on the mode, can control data transfer to and from the ports, or can be used as interrupt generating inputs, or I/O pins.

The timer consists of a 24-bit counter, optionally clocked by a 5-bit prescaler. Three pins provide complete timer I/O:  $PC_2/TIN$ ,  $PC_3/TOUT$ , and  $PC_7/TIACK$ . Of course, only the ones needed for the given configuration perform the timer function, while the others remain Port C I/O.

The system bus interface provides for asynchronous transfer of data from the PI/T to a bus master over the data bus ( $D_0\sim D_7$ ). Data transfer acknowledge (DTACK), register selects (RS1-RS5), chip select, the read/write line ( $R/W$ ), and Port Interrupt Acknowledge (PIACK) or Timer Interrupt Acknowledge (TIACK) control data transfer between the PI/T and the HD68000.

## ■ PIN DESCRIPTION

Throughout the data sheet, signals are presented using the terms active and inactive or asserted and negated independent



\*Individually Programmable Dual-Function Pin

Figure 7 Input and Output Signals

of whether the signal is active in the high-voltage state or low-voltage state. (The active state of each logic pin is given below.) Active low signals are denoted by a superscript bar. R/W indicates a write is active low and a read active high.

### Bidirectional Data Bus – ( $D_0\sim D_7$ )

The data bus pins  $D_0\sim D_7$  form an 8-bit bidirectional data bus to/from the HD68000 or other bus master. These pins are active high.

### Register Selects – (RS1-RS5)

RS1-RS5 are active high high-impedance inputs that determine which of the 25 possible registers is being addressed. They are provided by the HD68000 or other bus master.

### Read/Write Input – ( $R/W$ )

$R/W$  is the high-impedance Read/Write signal from the HD68000 or bus master, indicating whether the current bus cycle is a read (high) or write (low) cycle.

### Chip Select Input – ( $\overline{CS}$ )

$\overline{CS}$  is a high-impedance input that selects the PI/T registers for the current bus cycle. Address strobe and the data strobe (upper or lower) of the bus master, along with the appropriate address bits, must be included in the chip select equation. A low level corresponds to an asserted chip select.

### Data Transfer Acknowledge Output – (DTACK)

DTACK is an active low output that signals the completion of the bus cycle. During read or interrupt acknowledge cycles, DTACK is asserted by the HD68230 after data has been provided on the data bus; during write cycles it is asserted after data has been accepted at the data bus. Data transfer acknowledge is compatible with the HD68000 and with other Hitachi bus masters such as the HD68450 DMA controller. A holding resistor is required to maintain DTACK high between bus cycles.

### Reset Input – (RESET)

RESET is a high-impedance input used to initialize all PI/T functions. All control and data direction registers are cleared and most internal operations are disabled by the assertion of RESET (low).



**Clock Input – (CLK)**

The clock pin is a high-impedance TTL-compatible signal with the same specifications as the HD68000. The PI/T contains dynamic logic throughout, and hence this clock must not be gated off at any time. It is not necessary that this clock maintain any particular phase relationship with the HD68000 clock. It may be connected to an independent frequency source (faster or slower) as long as all bus specifications are met.

**Port A and Port B – (PA<sub>0</sub>-PA<sub>7</sub>, and PB<sub>0</sub>-PB<sub>7</sub>)**

Ports A and B are 8-bit ports that may be concatenated to form a 16-bit port in certain modes. The ports may be controlled in conjunction with the handshake pins H1-H4. For stabilization during system power-up, Ports A and B have internal pullup resistors to V<sub>CC</sub>. All port pins are active high.

**Handshake pins (I/O depending on the Mode and Submode) – (H1-H4)**

Handshake pins H1-H4 are multi-purpose pins that (depending on the operational model) may provide an interlocked handshake, a pulsed handshake, an interrupt input (independent of data transfers), or simple I/O pins. For stabilization during system power-up, H2 and H4 have internal pullup resistors to V<sub>CC</sub>. Their sense (active high or low) may be programmed in the Port General Control Register bits 3-0. Independent of the mode, the instantaneous level of the handshake pins can be read from the Port Status Register.

**(PC<sub>0</sub>-PC<sub>7</sub> /Alternate function) – (Port C)**

This port can be used as eight general purpose I/O pins (PC<sub>0</sub>-PC<sub>7</sub>) or any combination of six special function pins and two general purpose I/O pins (PC<sub>0</sub>-PC<sub>1</sub>). (Each dual function pin can be standard I/O or a special function independent of the other port C pins.) The dual function pins are defined in the following paragraphs. When used as port C pin, these pins are active high. They may be individually programmed as inputs or outputs by the Port C Data Direction Register.

The alternate functions (TIN, TOUT, and TIACK) are timer I/O pins. TIN may be used as a rising-edge triggered external clock input or an external run/halt control pin (the timer is in the run state if run/halt is high and in the halt state if run/halt is low). TOUT may provide an active low timer interrupt request output or a general-purpose square-wave output, initially high. TIACK is an active low high-impedance input used for timer interrupt acknowledge.

Port A and B functions have an independent pair of active low interrupt request (PIRQ) and interrupt acknowledge (PIACK) pins.

The DMAREQ (Direct Memory Access Request) pin provides an active low Direct Memory Access Controller (DMAC) request pulse of 3 clock cycles, completely compatible with the HD68450 DMAC.



## ■ REGISTER MODEL

A register model that includes the corresponding Register Selects is shown in Table 1.

| Register Select Bits |   |   |   |   |                         | Table 1 Register Model |               |            |               |                                 |                  |              |                                 |
|----------------------|---|---|---|---|-------------------------|------------------------|---------------|------------|---------------|---------------------------------|------------------|--------------|---------------------------------|
| 5                    | 4 | 3 | 2 | 1 | 0                       | 7                      | 6             | 5          | 4             | 3                               | 2                | 1            | 0                               |
| 0                    | 0 | 0 | 0 | 0 | 0                       | Port Mode Control      | H34 Enable    | H12 Enable | H4 Sense      | H3 Sense                        | H2 Sense         | H1 Sense     | Port General Control Register   |
| 0                    | 0 | 0 | 0 | 1 | *                       | SVCREQ Select          | Interrupt PFS |            |               | Port Interrupt Priority Control |                  |              | Port Service Request Register   |
| 0                    | 0 | 0 | 1 | 0 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port A Data Direction Register  |
| 0                    | 0 | 0 | 1 | 1 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port B Data Direction Register  |
| 0                    | 0 | 1 | 0 | 0 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port C Data Direction Register  |
| 0                    | 0 | 1 | 0 | 1 | Interrupt Vector Number |                        |               |            |               |                                 | *                | *            | Port Interrupt Vector Register  |
| 0                    | 0 | 1 | 1 | 0 | Port A Submode          |                        | H2 Control    |            |               | H2 Int Enable                   | H1 SVCREQ Enable | H1 Stat Ctrl | Port A Control Register         |
| 0                    | 0 | 1 | 1 | 1 | Port B Submode          |                        | H4 Control    |            |               | H4 Int Enable                   | H3 SVCREQ Enable | H3 Stat Ctrl | Port B Control Register         |
| 0                    | 1 | 0 | 0 | 0 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port A Data Register            |
| 0                    | 1 | 0 | 0 | 1 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port B Data Register            |
| 0                    | 1 | 0 | 1 | 0 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port A Alternate Register       |
| 0                    | 1 | 0 | 1 | 1 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port B Alternate Register       |
| 0                    | 1 | 1 | 0 | 0 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Port C Data Register            |
| 0                    | 1 | 1 | 0 | 1 | H4 Level                | H3 Level               | H2 Level      | H1 Level   | H4S           | H3S                             | H2S              | H1S          | Port Status Register            |
| 0                    | 1 | 1 | 1 | 0 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 0                    | 1 | 1 | 1 | 1 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 0 | 0 | 0 | 0 | TOUT/TIACK Control      |                        | ZD Ctrl       | *          | Clock Control |                                 |                  | Timer Enable | Timer Control Register          |
| 1                    | 0 | 0 | 0 | 1 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | Timer Interrupt Vector Register |
| 1                    | 0 | 0 | 1 | 0 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 0 | 0 | 1 | 1 | Bit 23                  | Bit 22                 | Bit 21        | Bit 20     | Bit 19        | Bit 18                          | Bit 17           | Bit 16       | Counter Preload Register (High) |
| 1                    | 0 | 1 | 0 | 0 | Bit 15                  | Bit 14                 | Bit 13        | Bit 12     | Bit 11        | Bit 10                          | Bit 9            | Bit 8        | (Mid)                           |
| 1                    | 0 | 1 | 0 | 1 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | (Low)                           |
| 1                    | 0 | 1 | 1 | 0 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 0 | 1 | 1 | 1 | Bit 23                  | Bit 22                 | Bit 21        | Bit 20     | Bit 19        | Bit 18                          | Bit 17           | Bit 16       | Count Register (High)           |
| 1                    | 1 | 0 | 0 | 0 | Bit 15                  | Bit 14                 | Bit 13        | Bit 12     | Bit 11        | Bit 10                          | Bit 9            | Bit 8        | (Mid)                           |
| 1                    | 1 | 0 | 0 | 1 | Bit 7                   | Bit 6                  | Bit 5         | Bit 4      | Bit 3         | Bit 2                           | Bit 1            | Bit 0        | (Low)                           |
| 1                    | 1 | 0 | 1 | 0 | *                       | *                      | *             | *          | *             | *                               | *                | *            | Timer Status Register           |
| 1                    | 1 | 0 | 1 | 1 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 1 | 1 | 0 | 0 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 1 | 1 | 0 | 1 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 1 | 1 | 1 | 0 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |
| 1                    | 1 | 1 | 1 | 1 | *                       | *                      | *             | *          | *             | *                               | *                | *            | (null)                          |

\* Unused, read as zero.



## ■ PROGRAMMER'S MODEL

Table 2 PI/T Register Addressing Assignments

| Register                               | Register Select Bits |   |   |   |   | Accessible | Affected by Reset | Affected by Read Cycle |
|----------------------------------------|----------------------|---|---|---|---|------------|-------------------|------------------------|
|                                        | 5                    | 4 | 3 | 2 | 1 |            |                   |                        |
| Port General Control Register (PGCR)   | 0                    | 0 | 0 | 0 | 0 | R W        | Yes               | No                     |
| Port Service Request Register (PSRR)   | 0                    | 0 | 0 | 0 | 1 | R W        | Yes               | No                     |
| Port A Data Direction Register (PADDR) | 0                    | 0 | 0 | 1 | 0 | R W        | Yes               | No                     |
| Port B Data Direction Register (PBDDR) | 0                    | 0 | 0 | 1 | 1 | R W        | Yes               | No                     |
| Port C Data Direction Register (PCDDR) | 0                    | 0 | 1 | 0 | 0 | R W        | Yes               | No                     |
| Port Interrupt Vector Register (PIVR)  | 0                    | 0 | 1 | 0 | 1 | R W        | Yes               | No                     |
| Port A Control Register (PACR)         | 0                    | 0 | 1 | 1 | 0 | R W        | Yes               | No                     |
| Port B Control Register (PBCR)         | 0                    | 0 | 1 | 1 | 1 | R W        | Yes               | No                     |
| Port A Data Register (PADR)            | 0                    | 1 | 0 | 0 | 0 | R W        | No                | **                     |
| Port B Data Register (PBDR)            | 0                    | 1 | 0 | 0 | 1 | R W        | No                | **                     |
| Port A Alternate Register (PAAR)       | 0                    | 1 | 0 | 1 | 0 | R          | No                | No                     |
| Port B Alternate Register (PBAR)       | 0                    | 1 | 0 | 1 | 1 | R          | No                | No                     |
| Port C Data Register (PCDR)            | 0                    | 1 | 1 | 0 | 0 | R W        | No                | No                     |
| Port Status Register (PSR)             | 0                    | 1 | 1 | 0 | 1 | R W*       | Yes               | No                     |
| Timer Control Register (TCR)           | 1                    | 0 | 0 | 0 | 0 | R W        | Yes               | No                     |
| Timer Interrupt Vector Register (TIVR) | 1                    | 0 | 0 | 0 | 1 | R W        | Yes               | No                     |
| Counter Preload Register High (CPRH)   | 1                    | 0 | 0 | 1 | 1 | R W        | No                | No                     |
| Counter Preload Register Middle (CPRM) | 1                    | 0 | 1 | 0 | 0 | R W        | No                | No                     |
| Counter Preload Register Low (CPRL)    | 1                    | 0 | 1 | 0 | 1 | R W        | No                | No                     |
| Count Register High (CNTRH)            | 1                    | 0 | 1 | 1 | 1 | R          | No                | No                     |
| Count Register Middle (CNTRM)          | 1                    | 1 | 0 | 0 | 0 | R          | No                | No                     |
| Count Register Low (CNTRL)             | 1                    | 1 | 0 | 0 | 1 | R          | No                | No                     |
| Timer Status Register (TSR)            | 1                    | 1 | 0 | 1 | 0 | RW*        | Yes               | No                     |

\* A write to this register may perform a special status resetting operation.

\*\* Mode dependent.

R = Read

W = Write

The internal accessible register organization is represented in Table 2. Address space within the address map is reserved for future expansion. Throughout the PI/T data sheet the following conventions are maintained:

- (1) A read from a reserved location in the map results in a read from the "null register." The null register returns all zeros for data and results in a normal bus cycle. A write to one of these locations results in a normal bus cycle but no write occurs.
- (2) Unused bits of a defined register are denoted by "—" and are read as zeroes.
- (3) Bits that are unused in the chosen mode/submode but are used in others, are denoted by "X", and are readable and writeable. Their content, however, is ignored in the chosen mode/submode.
- (4) All registers are addressable as 8-bit quantities. To facilitate operation with the MOVEP instruction and the DMAC, addresses are ordered such that certain sets of registers may also be accessed as words (2 bytes) or long words (4 bytes).

## ● Port General Control Register (PGCR)

Port General Control Register (PGCR)

| 7                 | 6          | 5          | 4        | 3        | 2        | 1        | 0 |
|-------------------|------------|------------|----------|----------|----------|----------|---|
| Port Mode Control | H34 Enable | H12 Enable | H4 Sense | H3 Sense | H2 Sense | H1 Sense |   |

The Port General Control Register (PGCR) controls many of the functions that are common to the overall operation of the ports. The PGCR is composed of three major fields; bits 7 and 6 define the operational mode of Ports A and B and affect operation of the handshake pins and status bits; bits 5 and 4 allow a software controlled disabling of particular hardware associated with the handshake pins of each port; and bits 3-0 define the sense of the handshake pins. The PGCR is always readable and writeable.

All bits are reset to 0 when the RESET pin is asserted.

The Port Mode Control field should be altered only when the H12 Enable and H34 Enable bits are 0. Except when Mode 0 is desired, the Port General Control register must be written once to establish the mode, and again to enable the respective



operation(s).

#### PGCR

| Port Mode Control |   |                                     |   |   |   |   |   |
|-------------------|---|-------------------------------------|---|---|---|---|---|
| 7                 | 6 | 5                                   | 4 | 3 | 2 | 1 | 0 |
| 0                 | 0 | Mode 0 (Unidirectional 8-Bit Mode)  |   |   |   |   |   |
| 0                 | 1 | Mode 1 (Unidirectional 16-Bit Mode) |   |   |   |   |   |
| 1                 | 0 | Mode 2 (Bidirectional 8-Bit Mode)   |   |   |   |   |   |
| 1                 | 1 | Mode 3 (Bidirectional 16-Bit Mode)  |   |   |   |   |   |

#### PGCR

| H34 Enable |          |   |   |   |   |  |  |
|------------|----------|---|---|---|---|--|--|
| 5          | 4        | 3 | 2 | 1 | 0 |  |  |
| 0          | Disabled |   |   |   |   |  |  |
| 1          | Enabled  |   |   |   |   |  |  |

#### PGCR

| H12 Enable |          |   |   |   |  |  |  |
|------------|----------|---|---|---|--|--|--|
| 4          | 3        | 2 | 1 | 0 |  |  |  |
| 0          | Disabled |   |   |   |  |  |  |
| 1          | Enabled  |   |   |   |  |  |  |

#### PGCR

| Handshake Pin Sense |   |   |                                                                                                          |  |  |  |  |
|---------------------|---|---|----------------------------------------------------------------------------------------------------------|--|--|--|--|
| 3                   | 0 | 0 | The associated pin is at the high-voltage level when negated and at the low-voltage level when asserted. |  |  |  |  |
| 1                   |   | 1 | The associated pin is at the low-voltage level when negated and at the high voltage level when asserted. |  |  |  |  |

### • Port Service Request Register (PSRR)

Port Service Request Register (PSRR)

| 7 | 6            | 5             | 4                               | 3 | 2 | 1 | 0 |
|---|--------------|---------------|---------------------------------|---|---|---|---|
| * | SVCRQ Select | Interrupt PFS | Port Interrupt Priority Control |   |   |   |   |

The Port Service Request Register (PSRR) controls other functions that are common to the overall operation to the ports. It is composed of four major fields; bit 7 is unused and is always read as 0; bits 6 and 5 define whether interrupt or DMA requests are generated from activity on the H1 and H3 handshake pins; bit 4 and 3 determine whether two dual function pins operate as Port C or port interrupt request/acknowledge pins; and bits 2, 1, and 0 control the priority among all port interrupt sources. Since bits 2, 1, and 0 affect interrupt operation, it is recommended that they be changed only when the affected interrupt(s) is (are) disabled or known to remain inactive. The PSRR is always readable and writeable.

All bits are reset to 0 when the RESET pin is asserted.

#### PSRR

| SVCRQ Select |   |                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |  |
|--------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|--|
| 6            | 5 | 4                                                                                                                                                                                                                                                                                                                                    | 3 | 2 | 1 | 0 |  |
| 0            | X | The PC <sub>4</sub> /DMAREQ pin carries the PC <sub>4</sub> function; DMA is not used.                                                                                                                                                                                                                                               |   |   |   |   |  |
| 1            | 0 | The PC <sub>4</sub> /DMAREQ pin carries the DMAREQ function and is associated with double-buffered transfers controlled by H1. H1 is removed from the PI/T's interrupt structure, and thus, does not cause interrupt requests to be generated. To obtain DMAREQ pulses, Port A Control Register bit 1 (H1 SVCRQ Enable) must be a 1. |   |   |   |   |  |
| 1            | 1 | The PC <sub>4</sub> /DMAREQ pin carries the DMAREQ function and is associated with double-buffered transfers controlled by H3. H3 is removed from the PI/T's interrupt structure, and thus, does not cause interrupt requests to be generated. To obtain DMAREQ pulses, Port B Control Register bit 1 (H3 SVCRQ Enable) must be a 1. |   |   |   |   |  |

to be generated. To obtain DMAREQ pulses, Port B Control Register bit 1 (H3 SVCRQ Enable) must be a 1.

#### PSRR

| Interrupt Pin Function Select |   |                                                            |   |   |  |  |  |
|-------------------------------|---|------------------------------------------------------------|---|---|--|--|--|
| 4                             | 3 | 2                                                          | 1 | 0 |  |  |  |
| 0                             | 0 | The PC <sub>5</sub> /PIRQ pin carries the PC5 function.    |   |   |  |  |  |
| 0                             | 1 | The PC <sub>5</sub> /PIACK pin carries the PC6 function.   |   |   |  |  |  |
| 1                             | 0 | The PC <sub>5</sub> /PIRQ pin carries the PIRQ function.   |   |   |  |  |  |
| 1                             | 1 | The PC <sub>5</sub> /PIACK pin carries the PC6 function.   |   |   |  |  |  |
| 0                             | 0 | The PC <sub>6</sub> /PIRQ pin carries the PCS function.    |   |   |  |  |  |
| 0                             | 1 | The PC <sub>6</sub> /PIACK pin carries the PIACK function. |   |   |  |  |  |
| 1                             | 0 | The PC <sub>6</sub> /PIRQ pin carries the PIRQ function.   |   |   |  |  |  |
| 1                             | 1 | The PC <sub>6</sub> /PIACK pin carries the PIACK function. |   |   |  |  |  |

Bits 2, 1, and 0 determine port interrupt priority. The priority is shown in descending order left to right.

#### PSRR

| Port Interrupt Priority Control |   |   |               |              |     |     |  |
|---------------------------------|---|---|---------------|--------------|-----|-----|--|
| 2                               | 1 | 0 | Highest ..... | ..... Lowest |     |     |  |
| 0                               | 0 | 0 | H1S           | H2S          | H3S | H4S |  |
| 0                               | 0 | 1 | H2S           | H1S          | H3S | H4S |  |
| 0                               | 1 | 0 | H1S           | H2S          | H4S | H3S |  |
| 0                               | 1 | 1 | H2S           | H1S          | H4S | H3S |  |
| 1                               | 0 | 0 | H3S           | H4S          | H1S | H2S |  |
| 1                               | 0 | 1 | H3S           | H4S          | H2S | H1S |  |
| 1                               | 1 | 0 | H4S           | H3S          | H1S | H2S |  |
| 1                               | 1 | 1 | H4S           | H3S          | H2S | H1S |  |

### • Port A Data Direction Register (PADDR)

The Port A Data Direction Register (PADDR) determines the direction and buffering characteristics of each of the Port A pins. One bit in the PADDR is assigned to each pin. A 0 indicates that the pin is used as an input, while a 1 indicates it is used as an output. The PADDR is always readable and writeable. This register is ignored in Mode 3.

All bits are reset to the 0 (input) state when the RESET pin is asserted.

### • Port B Data Direction Register (PBDDR)

The PBDR is identical to the PADDR for the Port B pins and the Port B Data Register, except that this register is ignored in Modes 2 and 3.

### • Port C Data Direction Register (PCDDR)

The Port C Data Direction Register (PCDDR) specifies whether each dual-function pin that is chosen for Port C operation is an input (0) or an output (1) pin. The PCDDR, along with bits that determine the respective pin's function, also specify the exact hardware to be accessed at the Port C Data Register address. (See the Port C Data Register description for more details.) The PCDDR is an 8-bit register that is readable and writeable at all times. Its operation is independent of the chosen PI/T mode.

These bits are cleared to 0 when the RESET pin is asserted.

### • Port Interrupt Vector Register (PIVR)

Port Interrupt Vector Register (PIVR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |

Interrupt Vector Number

\*

\*

The Port Interrupt Vector Register (PIVR) contains the upper order six bits of the four port interrupt vectors. The



contents of this register may be read two ways; by an ordinary read cycle, or by a port interrupt acknowledge bus cycle. The exact data read depends on how the cycle was initiated and other factors. Behavior during a port interrupt acknowledge cycle is summarized above in Table 5.

From a normal read cycle (CS), there is never a consequence to reading this register. Following negation of the RESET pin, but prior to writing to the PIVR, a \$OF will be read. After writing to the register, the upper 6 bits may be read and the lower 2 bits are forced to 0. No prioritization computation is performed.

#### • Port A Control Register (PACR)

Port A Control Register (PACR)

| 7              | 6          | 5 | 4 | 3              | 2                | 1              | 0 |
|----------------|------------|---|---|----------------|------------------|----------------|---|
| Port A Submode | H2 Control |   |   | H2 Int. Enable | H1 SVCREQ Enable | H1 Stat. Ctrl. |   |
|                |            |   |   |                |                  |                |   |

The Port A Control Register (PACR) in conjunction with the programmed mode and the Port B submode, control the operation of Port A and the handshake pins H1 and H2. The Port A Control Register contains five fields; bits 7 and 6 specify the Port A submode; bits 5, 4, and 3 control the operation of the H2 handshake pin and H2S status bit; bit 2 determines whether an interrupt will be generated when the H2S status bit goes to 1; bit 1 determines whether a service request (interrupt request or DMA request) will occur; bit 0 controls the operation of the H1S status bit. The PACR is always readable and writeable.

All bits are cleared to 0 when the RESET pin is asserted.

When the Port A submode field is relevant in a mode/submode definition, it must not be altered unless the H12 Enable bit in the Port General Control Register is 0. (See Table 4.)

The operation of H1 and H2 and their related status bits is given below, for each of the modes specified by Port General Control Register bits 7 and 6. This description is organized such that for each mode/submode all programmable options of each pin and status bit are given.

Bits 2 and 1 carry the same meaning in each mode/submode, and thus are specified only one.

#### PACR

##### H2 Interrupt Enable

- 0 The H2 interrupt is disabled.
- 1 The H2 interrupt is enabled.

#### PACR

##### H1 SVCREQ Enable

- 0 The H1 interrupt and DMA request are disabled.
- 1 The H1 interrupt and DMA request are enabled.

#### (1) PACR Mode 0 Port A Submode 00

#### PACR

##### H2 Control

- 0 X X Input pin – status only.
- 1 0 0 Output pin – always negated.
- 1 0 1 Output pin – always asserted.
- 1 1 0 Output pin – interlocked input handshake protocol.
- 1 1 1 Output pin – pulsed input handshake protocol.

#### PACR

##### H1 Status Control

- 0 Not Used.
- X

#### (2) PACR Mode 0 Port A Submode 01

#### PACR

##### H2 Control

- |   |   |   |                                                     |
|---|---|---|-----------------------------------------------------|
| 5 | 4 | 3 |                                                     |
| 0 | X | X | Input pin – status only.                            |
| 1 | 0 | 0 | Output pin – always negated.                        |
| 1 | 0 | 1 | Output pin – always asserted.                       |
| 1 | 1 | 0 | Output pin – interlocked output handshake protocol. |
| 1 | 1 | 1 | Output pin – pulsed output handshake protocol.      |

#### PACR

##### H1 Status Control

- |                                                                                                                                                                  |   |  |                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--------------------------------------------------------------------------------------------------------------------|
| 0                                                                                                                                                                |   |  |                                                                                                                    |
| The H1S status bit is 1 when either the Port A initial or final output latch can accept new data. It is 0 when both latches are full and cannot accept new data. | 0 |  |                                                                                                                    |
| 1                                                                                                                                                                |   |  | The H1S status bit is 1 when both of the Port A output latches are empty. It is 0 when at least one latch is full. |

#### (3) PACR Mode 0 Port A Submode 1X

#### PACR

##### H2 Control

- 0 X X Input pin – status only.
- 1 X 0 Output pin – always negated.
- 1 X 1 Output pin – always asserted.

#### PACR

##### H1 Status Control

- 0
- X Not used .

#### (4) PACR Mode 1 Port A Submode XX Port B Submode X0

#### PACR

##### H2 Control

- 0 X X Input pin – status only.
- 1 X 0 Output pin – always negated.
- 1 X 1 Output pin – always asserted.

#### PACR

##### H1 Status Control

- 0
- X Not used .

#### (5) PACR Mode 1 Port A Submode XX Port B Submode X1

#### PACR

##### H2 Control

- 0 X X Input pin – status only.
- 1 X 0 Output pin – always negated.
- 1 X 1 Output pin – always asserted.

#### PACR

##### H1 Status Control

- 0
- X Not used .

#### (6) PACR Mode 2

#### PACR

##### H2 Control

- |   |   |   |                                                     |
|---|---|---|-----------------------------------------------------|
| 5 | 4 | 3 |                                                     |
| X | X | 0 | Output pin – interlocked output handshake protocol. |
| X | X | 1 | Output pin – pulsed output handshake protocol.      |



**PACR**

| <u>0</u> | <u>H1 Status Control</u>                                                                                                                                         |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | The H1S status bit is 1 when either the Port B initial or final output latch can accept new data. It is 0 when both latches are full and cannot accept new data. |
| 1        | The H1S status bit is 1 when both of the Port B output latches are empty. It is 0 when at least one latch is full.                                               |

## (7) PACR Mode 3

**PACR**

| <u>5 4 3</u> | <u>H2 Control</u>                                   |
|--------------|-----------------------------------------------------|
| X X 0        | Output pin – interlocked output handshake protocol. |
| X X 1        | Output pin – pulsed output handshake protocol.      |

**PACR**

| <u>0</u> | <u>H1 Status Control</u>                                                                                                                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | The H1S status bit is 1 when either the initial or final output latch of Port A and B can accept new data. It is 0 when both latches are full and cannot accept new data.   |
| 1        | The H1S status bit is 1 when both the initial and final output latches of Ports A and B are empty. It is 0 when either the initial or final latch of Ports A and B is full. |

## ● Port B Control Register (PBCR)

Port B Control Register (PBCR)

| 7              | 6 | 5          | 4 | 3              | 2               | 1              | 0 |
|----------------|---|------------|---|----------------|-----------------|----------------|---|
| Port 8 Submode |   | H4 Control |   | H4 Int. Enable | H3 SVCRQ Enable | H3 Stat. Ctrl. |   |

The Port B Control Register (PBCR) specifies the operation of Port B and the handshake pins H3 and H4. The Port B control register contains five fields; bits 7 and 6 specify the Port B submode; bits 5, 4, and 3 control the operation of the H4 handshake pin and H4S status bit; bit 2 determines whether an interrupt will be generated when the H4S status bit goes to 1; bit 1 determines whether a service request (interrupt request or DMA request) will occur; bit 0 controls the operation of the H3S status bit. The PACR is always readable and writeable. There is never a consequence to reading the register.

All bits are cleared to 0 when the RESET pin is asserted.

When the Port B submode field is relevant in a mode/submode definition, it must not be altered unless the H34 Enable bit in the Port General Control Register is 0. (See Table 4.)

The operation of H3 and H4 and their related status bits is given below, for each of the modes specified by Port General Control Register bits 7 and 6. This description is organized such that for each mode/submode all programmable options of each pin and status bit are given.

Bits 2 and 1 carry the same meaning in each mode/submode, and thus are specified only once.

**PBCR**

| <u>2</u> | <u>H4 Interrupt Enable</u>    |
|----------|-------------------------------|
| 0        | The H4 interrupt is disabled. |
| 1        | The H4 interrupt is enabled.  |

**PBCR**

| <u>1</u> | <u>H3 SVCRQ Enable</u>                         |
|----------|------------------------------------------------|
| 0        | The H3 interrupt and DMA request are disabled. |
| 1        | The H3 interrupt and DMA request are enabled.  |

## (1) PBCR Mode 0 Port B Submode 00

**PBCR**

| <u>5 4 3</u> | <u>H4 Control</u>                                  |
|--------------|----------------------------------------------------|
| 0 X X        | Input pin – status only.                           |
| 1 0 0        | Output pin – always negated.                       |
| 1 0 1        | Output pin – always asserted.                      |
| 1 1 0        | Output pin – interlocked input handshake protocol. |
| 1 1 1        | Output pin – pulse input handshake protocol.       |

**PBCR**

| <u>0</u> | <u>H3 Status Control</u> |
|----------|--------------------------|
| X        | Not used.                |

## (2) PBCR Mode 0 Port B Submode 01

**PBCR**

| <u>5 4 3</u> | <u>H4 Control</u>                                   |
|--------------|-----------------------------------------------------|
| 0 X X        | Input pin – status only.                            |
| 1 0 0        | Output pin – always negated.                        |
| 1 0 1        | Output pin – always asserted.                       |
| 1 1 0        | Output pin – interlocked output handshake protocol. |
| 1 1 1        | Output pin – pulse output handshake protocol.       |

**PBCR**

| <u>0</u> | <u>H3 Status Control</u>                                                                                                                                         |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | The H3S status bit is 1 when either the Port B initial or final output latch can accept new data. It is 0 when both latches are full and cannot accept new data. |
| 1        | The H3S status bit is 1 when both of the Port B output latches are empty. It is 0 when at least one latch is full.                                               |

## (3) PBCR Mode 0 Port B Submode 1X

| <u>5 4 3</u> | <u>H4 Control</u>             |
|--------------|-------------------------------|
| 0 X X        | Input pin – status only.      |
| 1 X 0        | Output pin – always negated.  |
| 1 X 1        | Output pin – always asserted. |

**PBCR**

| <u>0</u> | <u>H3 Status Control</u> |
|----------|--------------------------|
| X        | Not used.                |

## (4) PBCR Mode 1 Port B Submode X0

| <u>5 4 3</u> | <u>H4 Control</u>                                  |
|--------------|----------------------------------------------------|
| 0 X X        | Input pin – status only.                           |
| 1 0 0        | Output pin – always negated.                       |
| 1 0 1        | Output pin – always asserted.                      |
| 1 1 0        | Output pin – interlocked input handshake protocol. |
| 1 1 1        | Output pin – pulsed input handshake protocol.      |

**PBCR**

| <u>0</u> | <u>H3 Status Control</u> |
|----------|--------------------------|
| X        | Not used.                |



**(5) PBCR Mode 1 Port B Submode X1**

| PBCR |   |   | <u>H4 Control</u>                                   |
|------|---|---|-----------------------------------------------------|
| 5    | 4 | 3 |                                                     |
| 0    | X | X | Input pin - status only.                            |
| 1    | 0 | 0 | Output pin - always negated.                        |
| 1    | 0 | 1 | Output pin - always asserted.                       |
| 1    | 1 | 0 | Output pin - interlocked output handshake protocol. |
| 1    | 1 | 1 | Output pin - pulsed output handshake protocol.      |

| PBCR     | H3 Status Control                                                                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>0</u> | The H3S status bit is 1 when either the initial or final output latch of Port A and B can accept new data. It is 0 when both latches are full and cannot accept new data.  |
| 1        | The H3S status bit is 1 when both the initial and final output latches of Port A and B are empty. It is 0 when neither the initial or final latch of Port A and B is full. |

(6) PBCR Mode 2

## (7) PBCR Mode 3

**PBCR**    H3 Status Control

- Port A Data Register (PADR)

The Port A Data Register (PADR) is an address for moving data to and from the Port A pins. The Port A Data Direction Register determines whether each pin is an input (0) or an output (1), and is used in configuring the actual data paths. This is mode dependent and is described with the modes above.

This register is readable and writeable at all times. Depending on the chosen mode/submode, reading or writing may affect the double-buffered handshake mechanism. The Port A Data Register is not affected by the assertion of the **RESET** pin.

- Port B Data Register (PBDR)

The Port B Data Register (PBDR) is an address for moving data to and from the Port B pins. The Port B Data Direction Register determines whether each pin is an input (0) or an output (1), and is used in configuring the actual data paths. This is mode dependent and is described with the modes, above.

This register is readable and writable at all times. Depending on the chosen mode/submode, reading or writing may affect the double-buffered handshake mechanism. The Port B Data Register is not affected by the assertion of the **RESET** pin.

#### ● Port A Alternate Register (PAAR)

The Port A Alternate Register (PAAR) is an alternate address for reading the Port A pins. It is a read-only address and no other PI/T condition is affected. In all modes and the instantaneous pin level is read and no input latching is performed except at the data bus interface (see Bus Interface Connection.) Writes to this address are answered with DTACK, but the data is ignored.

- Port B Alternate Register (PBAR)

The Port B Alternate Register (PBAR) is an alternate address for reading the Port B pins. It is a read-only address and no other PI/T condition is affected. In all modes the instantaneous pin level is read and no input latching is performed except at the data bus interface (see Bus Interface Connection). Writes to this address are answered with DTACK, but the data is ignored.

- Port C Data Register (PCDR)

The Port C Data Register (PCDR) is an address for moving data to and from each of the eight Port C/alternate-function pins. The exact hardware accessed is determined by the type of bus cycle (read or write) and individual conditions affecting each pin. These conditions are (1) whether the pin is used for the Port C or alternate function, and (2) whether the Port C Data Direction Register indicates the input or output direction. The Port C Data Register is single buffered for output pins and not buffered for input pins. These conditions are summarized in Table 3.

The Port C Data Register is not affected by the assertion of the RESET pin.

The operation of the PCDR is independent of the chosen PI/T mode.

**Table 3 PCDR Hardware Accesses**

| Read Port C Data Register                     |                                              |                                    |                                    |
|-----------------------------------------------|----------------------------------------------|------------------------------------|------------------------------------|
| Port C function<br>PCDDR = 0                  | Port C function<br>PCDDR = 1                 | Alternate<br>function<br>PCDDR = 0 | Alternate<br>function<br>PCDDR = 1 |
| pin                                           | Port C<br>output<br>register                 | pin                                | Port C<br>output<br>register       |
| Write Port C Data Register                    |                                              |                                    |                                    |
| Port C function<br>PCDDR = 0                  | Port C function<br>PCDDR = 1                 | Alternate<br>function<br>PCDDR = 0 | Alternate<br>function<br>PCDDR = 1 |
| Port C<br>output register,<br>buffer disabled | Port C<br>output register,<br>buffer enabled | Port C<br>output register          | Port C<br>output register          |

Note that two additional useful benefits result from this structure. First, it is possible to directly read the state of a dual-function pin while used for the non-Port C function. Second, it is possible to generate program controlled transitions on alternate-function pins by switching back to the Port C function, and writing to the PCDR.

This register is readable and writeable at all times.

- Port Status Register (PSR)

## Port Status Register (PSR)

| 7        | 6        | 5        | 4        | 3   | 2   | 1   | 0        |
|----------|----------|----------|----------|-----|-----|-----|----------|
| H4 Level | H3 Level | H2 Level | H1 Level | H4S | H3S | H2S | H1S      |
| High     | Medium   | Medium   | Medium   | Low | Low | Low | Very Low |
| High     | Medium   | Medium   | Medium   | Low | Low | Low | Very Low |

The Port Status Register (PSR) contains information about handshake pin activity. Bits 7-4 show the instantaneous level of the respective handshake pin, and is independent of the handshake pin sense bits in the Port General Control Register. Bit 3-0 are the respective, status bits referred to throughout this data sheet. Their interpretation depends on the programmed mode/submode of the PI/T. For Bits 3-0 a 1 is the active or asserted state.

#### ● Timer Control Register (TCR)

Timer Control Register (TCR)

| 7                     | 6             | 5 | 4                | 3               | 2 | 1 | 0 |
|-----------------------|---------------|---|------------------|-----------------|---|---|---|
| TOUT/TIACK<br>Control | Z.D.<br>Ctrl. | * | Clock<br>Control | Timer<br>Enable |   |   |   |

The Timer Control Register (TCR) determines all operations of the timer. Bits 7-5 configure the PC<sub>3</sub>/TOUT and PC<sub>7</sub>/TIACK pins for Port C, square wave, vectored interrupt, or auto-vectored interrupt operation; bit 4 specifies whether the counter receives data from the Counter Preload Register or continues counting when zero detect is reached; bit 3 is unused and is read as 0; bits 2 and 1 configure the path from the CLK and TIN pins to the counter controller; bit 0 enables the timer. This register is readable and writeable at all times.

All bits are cleared to 0 when the RESET pin is asserted.

**TCR**

- |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p><b>7 6 5</b></p> <p>0 X X      <u><b>TOUT/TIACK Control</b></u></p> <p>0 1 X      The dual-function pin PC<sub>3</sub>/TOUT and PC<sub>7</sub>/TIACK carry the Port C function.</p> <p>0 1 0      The dual-function pin PC<sub>3</sub>/TOUT comes the TOUT function. In the run state it is used as a square wave output and is toggled on zero detect. The TOUT pin is high while in the halt state. The dual-function pin PC<sub>7</sub>/TIACK carries the PC<sub>7</sub> function.</p> <p>1 0 0      The dual-function pin PC<sub>3</sub>/TOUT carries the TOUT function. In the run or halt state it is used as a timer interrupt request output. The timer interrupt is disabled; thus, the pin is always three-stated. The dual-function pin PC<sub>7</sub>/TIACK carries the TIACK function; however, since interrupt request is negated, the PI/T produces no response, i.e., no data or DTACK, to an asserted TIACK. Refer to Time Interrupt Cycle section for details. This combination and the 101 state below support vectored timer interrupts.</p> <p>1 0 1      The dual-function pin PC<sub>3</sub>/TOUT carries the TOUT function and is used as a timer interrupt request output. The timer interrupt is enabled; thus, the pin is low when the timer ZDS status bit is 1. The dual function pin PC<sub>7</sub>/TIACK carries the TIACK function and is used as a timer interrupt acknowledge input. Refer to the Timer Interrupt Acknowledge Cycle section for details. This combination and the 100 state above support vectored timer interrupts.</p> <p>1 1 0      The dual-function pin PC<sub>3</sub>/TOUT carries the TOUT function. In the run or halt state it is used as a timer interrupt request output. The timer interrupt is disabled; thus, the pin is always three-stated. The dual-function pin PC<sub>7</sub>/TIACK carries the PC<sub>7</sub> function.</p> | <p><b>TCR</b></p> <p><b>4</b></p> <p>0      <u><b>Zero Detect Control</b></u></p> <p>The counter is loaded from the Counter Preload Register on the first clock to the 24-bit counter after zero detect, and resumes counting.</p> <p>1      The counter rolls over on zero detect, then continues counting.</p> <p>Bit 3 is unused and is always read as 0.</p> |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**1 1 1** The dual-function pin PC<sub>3</sub>/TOUT carries the TOUT function and is used as a timer interrupt request output. The timer interrupt is enabled; thus, then pin is low when the timer ZDS status bits is 1. The dual-function pin PC<sub>7</sub>/TIACK carries the PC<sub>7</sub> function and autovectored interrupts are supported.

**TCR**

- |                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p><b>4</b></p> <p>0      <u><b>Zero Detect Control</b></u></p> <p>The counter is loaded from the Counter Preload Register on the first clock to the 24-bit counter after zero detect, and resumes counting.</p> <p>1      The counter rolls over on zero detect, then continues counting.</p> | <p><b>TCR</b></p> <p><b>2 1</b></p> <p>0 0      <u><b>Clock Control</b></u></p> <p>The PC<sub>2</sub>/TIN input pin carries the Port C function and the CLK pin and prescaler are used. The prescaler is decremented on the falling transition of the CLK pin; the 24-bit counter is decremented or loaded from the Counter Preload Register when the prescaler rolls over from \$00 to \$1F. The Timer Enable bit determines whether the timer is in the run or halt state.</p> |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**0 1** The PC<sub>2</sub>/TIN pin serves as a timer input and the CLK pin and prescaler are used. The prescaler is decremented on the falling transition of the CLK pin; the 24-bit counter is decremented or loaded from the Counter Preload Registers when the prescaler rolls over from \$00 to \$1F. The timer is in the run state when the Timer Enable bit is 1 and the TIN pin is high; otherwise the timer is in the halt state.

**1 0** The PC<sub>2</sub>/TIN pin serves as a timer input and the prescaler is used. The prescaler is decremented following the rising transition of the TIN pin after syncing with the internal clock. The 24-bit counter is decremented or loaded from the counter preload registers when the prescaler rolls over from \$00 to \$1F. The Timer Enable bit determines whether the timer is in the run or halt state.

**1 1** The PC<sub>2</sub>/TIN pin serves as a timer input and the prescaler is unused. The 24-bit counter is decremented or loaded from the Counter Preload Registers following the rising edge of the TIN pin after syncing with the internal clock. The Timer Enable bit determines whether the timer is in the run or halt state.

**TCR**

- |                                                                           |                                        |
|---------------------------------------------------------------------------|----------------------------------------|
| <p><b>0</b></p> <p>0      <u><b>Timer Enable</b></u></p> <p>Disabled.</p> | <p><b>0</b></p> <p>1      Enabled.</p> |
|---------------------------------------------------------------------------|----------------------------------------|

#### ● Timer Interrupt Vector Register (TIVR)

The timer interrupt vector register contains the 8-bit vector supplied when the timer interrupt acknowledge pin TIACK is asserted. The register is readable and writeable at all times, and the same value is always obtained from a normal read cycle and a timer interrupt acknowledge bus cycle (TIACK). When the RESET pin is asserted the value of \$0F is automatically loaded into the register. Refer to Timer Interrupt Acknowledge Cycle section for more details.



- Counter Preload Register H,M,L (CPRH-L)

Counter Preload Register H,M,L (CPRH-L)

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| Bit 23 | Bit 22 | Bit 21 | Bit 20 | Bit 19 | Bit 18 | Bit 17 | Bit 16 |
| Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9  | Bit 8  |
| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |

CPRH  
CPRM  
CPRL

The Counter Preload Registers (CPRH-L) are a group of three 8-bit registers used for storing data to be transferred to the counter. Each of the registers is individually addressable, or the group may be accessed with the MOVEP.L or the MOVEP.W instructions. The address one less than the address of CPRH is the null register, and is reserved so that zeros are read in the upper 8 bits of the destination data register when a MOVEP.L is used. Data written to this address is ignored.

The registers are readable and writeable at all times. A read cycle proceeds independently of any transfer to the counter, which may be occurring simultaneously.

To insure proper operation of the PI/T Timer, a value of \$000000 may not be stored in the Counter Preload Registers for use with the counter.

The RESET pin does not affect the contents of these registers.

- Count Register H,M,L (CNTRH-L)

Count Register H,M,L (CNTRH-L)

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| Bit 23 | Bit 22 | Bit 21 | Bit 20 | Bit 19 | Bit 18 | Bit 17 | Bit 16 |
| Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9  | Bit 8  |
| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |

CNTRH  
CNTRM  
CNTRL

The count registers (CNTRH-L) are a group of three 8-bit addresses at which the counter can be read. The contents of the counter are not latched during a read bus cycle; thus, the data read at these addresses is not guaranteed if the timer is in the run state. (Bits 2, 1, and 0 of the Timer Control Register specify the state.) Write operations to these addresses result in a normal bus cycle but the data is ignored.

Each of the registers is individually addressable, or the group may be accessed with the MOVEP.L or the MOVEP.W instructions. The address one less than the address of CNTRH is the null register, and is reserved so that zeros are read in the upper 8 bits of the destination data register when a MOVEP.L is used. Data written to this address is ignored.

- Timer Status Register (TSR)

Timer Status Register (TSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|---|---|---|---|---|---|---|-----|
| * | * | * | * | * | * | * | ZDS |

The Timer Status Register (TSR) contains one bit from which the zero detect status can be determined. The ZDS status bit (bit 0) is an edge-sensitive flip-flop that is set to 1 when the 24-bit counter decrements from \$000001 to \$000000. The ZDS status bit is cleared to 0 following the direct clear operation (similar to that of the ports), or when the timer is halted. Note also that when the RESET pin is asserted the timer is disabled, and thus enters the halt state.

This register is always readable without consequence. A write access performs a direct clear operation if bit 0 in the written data is 1. Following that, the ZDS bit is 0.

This register is constructed with a reset dominant S-R flip-flop so that all cleaning conditions prevail over the possible zero detect condition.

Bits 7-1 are unused and are read as 0.



## ■ PORT CONTROL STRUCTURE

The primary focus of most applications will be on Ports A and B, the handshake pins, the port interrupt pins, and the DMA request pin. They are controlled in the following way: the Port General Control Register contains a 2-bit field that specifies a set of four operation modes. These govern the overall operation of the ports and determine their interrelationships.

Some modes require additional information from each port's control register to further define its operation. In each port control register, there is a 2-bit submode field that serves this purpose. Each port mode/submode combination specifies a set of programmable characteristics that fully define the behavior of that port and two of the handshake pins. This structure is summarized in Table 4 and Figure 8.



Figure 8 Port Mode Layout



## ■ PORT GENERAL INFORMATION AND CONVENTIONS

The following paragraphs introduce concepts that are generally applicable to the PI/T ports independent of the chosen mode and submode. For this reason, no particular port or handshake pins are mentioned; the notation H1 (H3) indicates that, depending on the chosen mode and sub-mode, the statement given may be true for either the H1 or H3 handshake pin.

### • Unidirectional vs Bidirectional

Figure 8 shows the configuration of Ports A and B and each of the handshake pins in each port mode and submode. In Modes 0 and 1, a data direction register is associated with each of the ports. These registers contain one bit for each port pin to determine whether that pin is an input or an output. Modes 0 and 1 are, thus, called unidirectional modes because each pin assumes a constant direction, changeable only by a reset condition or a programming change. These modes allow double-buffered data transfers in one direction. This direction, determined by the mode and submode definition, is known as the primary direction. Data transfers in the primary direction are controlled by the handshake pins. Data transfers not in the primary direction are generally unrelated, and single or unbuffered data paths exist.

In Modes 2 and 3 there is no concept of primary direction as in Modes 0 and 1. Except for Port A in Mode 2 (Bit I/O), the data direction registers have no effect. These modes are bidirectional, in that the direction of each transfer (always 8 or 16 bits, double-buffered) is determined dynamically by the state of the handshake pins. Thus, for example, data may be transferred out of the ports, followed very shortly by a transfer into the same port pins. Transfers to and from the ports are independent and may occur in any sequence. Since the in-

stantaneous direction is always determined by the external system, a small amount of arbitration logic may be required.

### • Control of Double-Buffered Data Paths

Generally speaking, the PI/T is a double-buffered device. In the primary direction, double-buffering allows orderly transfers by using the handshake pins in any of several programmable protocols. (When Bit I/O is used, double-buffering is not available and the handshake pins are used as outputs or status/interrupt inputs.)

Use of double-buffering is most beneficial in situations where a peripheral device and the computer system are capable of transferring data at roughly the same speed. Double-buffering allows the fetch operation of the data transmitter to be overlapped with the store operation of the data receiver. Thus, throughput measured in bytes or words-per-second may be greatly enhanced. If there is a large mismatch in transfer capability between the computer and the peripheral, little or no benefit is obtained. In these cases there is no penalty in using double-buffering.

### • Double-Buffered Input Transfers

In all modes, the PI/T supports double-buffered input transfers. Data that meets the port setup and hold times is latched on the asserted edge of H1(H3). H1(H3) is edge-sensitive, and may assume any duty-cycle as long as both high and low minimum times are observed. The PI/T contains a Port Status Register whose H1S(H3S) status bit is set anytime any input data is present in the double-buffered latches that has not been read by the bus master. The action of H2(H4) is programmable; it may indicate whether there is room for more data in the PI/T latches or it may serve other purposes. The

Table 4 Port Mode Control Summary

| Mode 0<br>(Unidirectional 8-Bit mode)                                                                                                                                                                                             |                                                                                                                                                                                                                    | Mode 1<br>(Unidirectional 16-Bit mode)                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                          | Mode 2<br>(Bidirectional 8-Bit mode)                                                                                                |                                                   | Mode 3<br>(Bidirectional 16-Bit mode)               |                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------|---------------------------------------------------|
| Port A                                                                                                                                                                                                                            | Port A – Double-Buffered Data (Most significant)                                                                                                                                                                   | Port A – Bit I/O (with no handshaking pins)                                                                                                                                                                                                                              | Port A – Double-Buffered Data (Most significant)                                                                                                                                                                                                                         | Port B                                                                                                                              | Port B – Double-Buffered Data (Least significant) | Port B – Bidirectional 8-Bit Data (Double-Buffered) | Port B – Double-Buffered Data (Least significant) |
| Submode 00 – Double-Buffered Input<br>H1 – Latches input data<br>H2 – Status/interrupt generating input, general-purpose output, or operation with H1 in the interlocked or pulsed input handshake protocols                      |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                          | Submode XX (not used)<br>H1 – Status/interrupt generating input<br>H2 – Status/interrupt generating input or general-purpose output | Submode XX (not used)                             | Submode XX (not used)                               |                                                   |
| Submode 01 – Double-Buffered Output<br>H1 – Indicates data received by peripheral<br>H2 – Status/interrupt generating input, general-purpose output, or operation with H1 in the interlocked or pulsed output handshake protocols |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                          |                                                                                                                                     |                                                   |                                                     |                                                   |
| Submode 1X – Bit I/O<br>H1 – Status/interrupt generating input<br>H2 – Status/interrupt generating input or general-purpose output                                                                                                |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                          |                                                                                                                                     |                                                   |                                                     |                                                   |
| Port B                                                                                                                                                                                                                            | Port B – Double-Buffered Data (Least significant)                                                                                                                                                                  | Port B – Bidirectional 8-Bit Data (Double-Buffered)                                                                                                                                                                                                                      | Port B – Double-Buffered Data (Least significant)                                                                                                                                                                                                                        |                                                                                                                                     |                                                   |                                                     |                                                   |
| H3 and H4 – Identical to Port A, H1 and H2                                                                                                                                                                                        | Submode X0 – Unidirectional 16-Bit Input<br>H3 – Latches input data<br>H4 – Status/interrupt generating input, general-purpose output, or operation with H3 in the interlocked or pulsed input handshake protocols | Submode XX (not used)<br>H1 – indicates output data received by peripheral<br>H2 – Operation with H1 in the interlocked or pulsed output handshake protocols<br>H3 – Latches input data<br>H4 – Operation with H3 in the interlocked or pulsed input handshake protocols | Submode XX (not used)<br>H1 – Indicates output data received by peripheral<br>H2 – Operation with H1 in the interlocked or pulsed output handshake protocols<br>H3 – Latches input data<br>H4 – Operation with H3 in the interlocked or pulsed input handshake protocols |                                                                                                                                     |                                                   |                                                     |                                                   |



following options are available, depending on the mode.

- (1) H2(H4) may be an edge-sensitive input that is independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is cleared by the direct method (refer to Direct Method of Resetting Status), the RESET pin being asserted, or when the H12 Enable (H34 Enable) bit of the Port General Control Register is 0.
- (2) H2(H4) may be a general purpose output pin that is always negated. The H2S(H4S) status bit is always 0.
- (3) H2(H4) may be a general purpose output pin that is always asserted. The H2S(H4S) status bit is always 0.
- (4) H2(H4) may be an output pin in the interlocked input handshake protocol. It is asserted when the port input latches are ready to accept new data. It is negated asynchronously following the asserted edge of the H1(H3) input.

As soon as the input latches become ready, H2(H4) is again asserted. When the input double-buffered latches are full, H2(H4) remains negated until data is removed. Thus, anytime the H2(H4) output is asserted, new input data may be entered by asserting H1(H3). At other times transi-

tions on H1(H3) are ignored. The H2S(H4S) status bit is always 0. When H12 Enable (H34 Enable) is 0, H2(H4) is held negated.

- (5) H2(H4) may be an output pin in the pulsed input handshake protocol. It is asserted exactly as in the interlocked input protocol, but never remains asserted longer than 4 clock cycles. Typically, a four clock cycle pulse is generated. But in the case that a subsequent H1(H3) asserted edge occurs before termination of the pulse, H2(H4) is negated asynchronously. Thus, anytime after the leading edge of the H2(H4) pulse, new data may be entered in the PI/T double-buffered input latches. The H2S(H4S) status bit is always 0. When H12 Enable (H34 Enable) is 0, H2(H4) is held negated.

A sample timing diagram is shown in Figure 9. The H2(H4) interlocked and pulsed input handshake protocols are shown. The DMAREQ pin is also shown assuming it is enabled. All handshake pin sense bits are assumed to be 0 (refer to Port General Control Register); thus, the pins are in the low state when asserted. Due to the great similarity between modes, this timing diagram is applicable to all double-buffered input transfers.



Figure 9 Double-buffered Input Transfers

#### • Double-Buffered Output Transfers

The PI/T supports double-buffered output transfers in all modes. Data, written by the bus master to the PI/T, is stored in the port's output latch. The peripheral accepts the data by asserting H1(H3), which causes the next data to be moved to the port's output latch as soon as it is available. The function of H2(H4) is programmable; it may indicate whether new data has been moved to the output latch or it may serve other purposes. The H1S(H3S) status bit may be programmed for two interpretations. Normally the status bit is a 1 when there is at least one latch in the double-buffered data path that can accept new data. After writing one byte/word of data to the ports, an interrupt service routine could check this bit to determine if it could store another byte/word; thus, filling both latches. When the bus master is finished, it is often useful to be able to check whether all of the data has been transferred to the peripheral. The H1S(H3S) Status Control bit of the Port A and B Control Registers provide this flexibility. The programmable options of the H2(H4) pin are given below, depending on the mode.

- (1) H2(H4) may be an edge-sensitive input pin independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is reset by the direct method (refer to Direct Method of Resetting Status), the RESET pin being asserted, or when the H12 Enable (H34 Enable) bit of the Port General Control Register is 0.

Status), the RESET pin being asserted, or when the H12 Enable (H34 Enable) bit of the Port General Control Register is 0.

- (2) H2(H4) may be a general-purpose output pin that is always negated. The H2S(H4S) status bit is always 0.
- (3) H2(H4) may be a general-purpose output pin that is always asserted. The H2S(H4S) status bit is always 0.
- (4) H2(H4) may be an output pin in the interlocked output handshake protocol. H2(H4) is asserted two clock cycles after data is transferred to the double-buffered output latches. The data remains stable and H2(H4) remains asserted until the next asserted edge of the H1(H3) input. At that time, H2(H4) is asynchronously negated. As soon as the next data is available, it is transferred to the output latches. When H2(H4) is negated, asserted transitions on H1(H3) have no effect on the data paths. As is explained later, however, in Modes 2 and 3 they do control the three-state output buffers of the bidirectional port(s). The H2S(H4S) status bit is always 0. When H12 Enable (H34 Enable) is 0, H2(H4) is held negated.
- (5) H2(H4) may be an output pin in the pulsed output handshake protocol. It is asserted exactly as in the interlocked output protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock pulse is

generated. But in the case that a subsequent H1(H3) asserted edge occurs before termination of the pulse, H2(H4) is negated asynchronously shortening the pulse. The H2S(H4S) status bit is always 0. When H12 Enable (H34 Enable) is 0 H2(H4) is held negated.

A sample timing diagram is shown in Figure 10. The H2(H4) interlocked and pulsed output handshake protocols are shown. The DMAREQ pin is also shown assuming it is enabled. All handshake pin sense bits are assumed to be 0; thus, the pins are in the low state when asserted. Due to the great similarity between modes, this timing diagram is applicable to all double-buffered output transfer.



Figure 10 Double-buffered Output Transfers

#### • Requesting Bus Master Service

The PI/T has several means of indicating a need for service by a bus master. First, the processor may poll the Port Status Register. It contains a status bit for each handshake pin, plus a level bit that always reflects the instantaneous state of that handshake pin. A status bit is 1 when the PI/T needs servicing, i.e., generally when the bus master needs to read or write data to the ports, or when a handshake pin used as a simple status input has been asserted. The interpretation of these bits is dependent on the chosen mode and submode.

Second, the PI/T may be placed in the processor's interrupt structure. As mentioned previously, the PI/T contains Port A and B Control Registers that configure the handshake pins. Other bits in these registers enable an interrupt associated with each handshake pin. This interrupt is made available through the PCS/PIRQ pin, if the PIRQ function is selected. Three additional conditions are required for PIRQ to be asserted: (1) the handshake pin status bit set, (2) the corresponding interrupt (service request) enable bit is set, (3) and DMA requests are not associated with that data transfer (H1 and H3 only). The conditions from each of the four handshake pins and corresponding status bits are ORed to determine PIRQ.

The third method of requesting service is via the PC4/DMAREQ pin. This pin can be associated with double-buffered transfers in each mode. If it is used as a DMA controller request, it can initiate requests to keep the PI/T's input/output double-buffering empty/full as much as possible. It will not

overrun the DMA controller. The pin is compatible with the HD68450 Direct Memory Access Controller (DMAC).

#### • Vectorized, Prioritized Port Interrupts

Use of HD68000-compatible vectored interrupts with the PI/T requires the PIRQ and PIACK pins. When PIACK is asserted, the PI/T places an 8-bit vector on the data pins D<sub>0</sub>-D<sub>7</sub>. Under normal conditions, this vector corresponds to highest priority, enabled, active port interrupt source with which the DMAREQ pin is not currently associated. The most-significant six bits are provided by the Port Interrupt Vector Register (PIVR), with the lower two bits supplied by prioritization logic according to conditions present when PIACK is asserted. It is important to note that the only effect on the PI/T caused by interrupt acknowledge cycles is that the vector is placed on the data bus. Specifically, no registers, data, status, or other internal states of the PI/T are affected by the cycle.

Several conditions may be present when the PIACK input is asserted to the PI/T. These conditions affect the PI/T's response and the termination of the bus cycle. If the PI/T has no interrupt function selected, or is not asserting PIRQ, the PI/T will make no response to PIACK (DTACK will not be asserted). If the PI/T is asserting PIRQ when PIACK is received, the PI/T will output the contents of the Port Interrupt Vector Register and the prioritization bits. If the PIVR has not been initialized, \$0F will be read from this register. These conditions are summarized in Table 5.

Table 5 Response to Port Interrupt Acknowledge

| Conditions                                | PIRQ negated OR interrupt request function not selected | PIRQ asserted                                         |
|-------------------------------------------|---------------------------------------------------------|-------------------------------------------------------|
| PIVR has not been initialized since RESET | No response from PI/T.<br>No DTACK.                     | PI/T provides \$0F, the Uninitialized Vector.*        |
| PIVR has been initialized since RESET     | No response from PI/T.<br>No DTACK.                     | PI/T provides PIVR contents with prioritization bits. |

\*The uninitialized vector is the value returned from an interrupt vector register before it has been initialized.



The vector table entries for the PI/T appear as a contiguous block of four vector numbers whose common upper six bits are programmed in the PIVR. The following table pairs each interrupt source with the 2-bit value provided by the prioritization logic, when interrupt acknowledge is asserted.

|           |      |
|-----------|------|
| H1 source | — 00 |
| H2 source | — 01 |
| H3 source | — 10 |
| H4 source | — 11 |

#### ● Autovectored Port Interrupts

Autovectored interrupts use only the PIRQ pin. The operation of the PI/T with vectored and autovectored interrupts is identical except that no vectors are supplied and the PC6/PIACK pin can be used as a Port C pin.

#### ● Direct Method of Resetting Status

In certain modes one or more handshake pins can be used as edge-sensitive inputs for sole purpose of setting bits in the Port Status Register. These bits consist of simple flip-flops. They are set (to 1) by the occurrence of the asserted edge of the handshake pin input. Resetting a handshake status bit can be done by writing an 8-bit mask to the Port Status Register. This is called the direct method of resetting. To reset a status bit that is resettable by the direct method, the mask must contain a 1 in the bit position of the Port Status Register corresponding to the desired bit. Other positions must contain 0's. For status bits that are not resettable by the direct method in the chosen mode, the data written to the port status register has no effect. For status bits that are resettable by the direct method in the chosen mode, a 0 in the mask has no effect.

#### ● Handshake Pin Sense Control

The PI/T contains exclusive-OR gates to control the sense of each of the handshake pins, whether used as inputs or outputs. Four bits in the Port General Control Register may be programmed to determine whether the pins are asserted in the low or high voltage state. As with other control registers, these bits are reset to 0 when the RESET pin is asserted, defaulting the asserted level to be low.

#### ● Enabling Ports A and B

Certain functions involved with double-buffered data transfers, the handshake pins, and the status bits, may be disabled by the external system or by the programmer during initialization. The Port General Control Register contains two bits, H12 Enable and H34 Enable, which control these functions. These bits are cleared to the 0 state when the RESET pin is asserted, and the functions are disabled. The functions are the following.

- (1) Independent of other actions by the bus master or peripheral (via the handshake pins), the PI/T's disabled handshake controller is held to the "empty" state, i.e., no data is present in the double-buffered data path.
- (2) When any handshake pin is used to set a simple status flip-flop, unrelated to double-buffered transfers, these flip-flops are held reset to 0. (See Table 4.)
- (3) When H2(H4) is used in an interlocked or pulsed handshake with H1(H3), H2(H4) is held negated, regardless of the chosen mode, submode, and primary direction. Thus, for double-buffered input transfers, the programmer may signal a peripheral when the PI/T is ready to begin transfers by setting the associated handshake enable bit to 1.

#### ● The Port A and B Alternate Registers

In addition to the Port A and B Data Registers, the PI/T contains Port A and B Alternate Registers. These registers are read-only, and simply provide the instantaneous level of each port pin. They have no effect on the operation of the handshake pins, double-buffered transfers, status bits, or any other aspect of the PI/T, and they are mode/submode independent.

### ■ PORT MODES

This section contains information that distinguishes the various port modes and submodes.

#### ● Mode 0 — Unidirectional 8-Bit Mode

In Mode 0, Ports A and B operate independently. Each may be configured in any of its three possible submodes:

- Submode 00 — Double-Buffered Input
- Submode 01 — Double-Buffered Output
- Submode 1X — Bit I/O

Handshake pins H1 and H2 are associated with Port A and configured by programming the Port A Control Register. (The H12 Enable bit of the Port General Control Register, enables Port A transfers.) Handshake pins H3 and H4 are associated with Port B and configured by programming the Port B Control Register. (The H34 Enable bit of the Port General Control Register enables Port B transfers.) The Port A and B Data Direction Registers operate in all three submodes. Along with the submode, they affect the data read and written at the associated data register according to Table 6. They also enable the output buffer associated with each port pin. The DMAREQ pin may be associated with either (not both) Port A or Port B, but does not function if the Bit I/O submode is programmed for the chosen port.



Table 6 Mode 0 Port Data Paths

| Mode         | Read Port A/B Data Register |            | Write Port A/B Data Register |        |
|--------------|-----------------------------|------------|------------------------------|--------|
|              | DDR = 0                     | DDR = 1    | DDR = X                      |        |
| 0 Submode 00 | FIL, D.B.                   | FOL Note 3 | FOL, S.B.                    | Note 1 |
| 0 Submode 01 | Pin                         | FOL Note 3 | IOL/FOL, D.B.                | Note 2 |
| 0 Submode 1X | Pin                         | FOL Note 3 | FOL, S.B.                    | Note 1 |

**Abbreviations:**

|     |                        |      |                           |
|-----|------------------------|------|---------------------------|
| IOL | — Initial Output Latch | S.B. | — Single Buffered         |
| FOL | — Final Output Latch   | D.B. | — Double Buffered         |
| FIL | — Final Input Latch    | DDR  | — Data Direction Register |

**Note 1:** Data is latched in the output data registers (final output latch) and will be single buffered at the pin if the DDR is 1. The output buffers will be turned off if the DDR is 0.

**Note 2:** Data is latched in the double-buffered output data registers. The data in the final output latch will appear on the port pin if the DDR is a 1.

**Note 3:** The output drivers that connect the final output latch to the pins are turned on.

## (1) Port A or B Submode 00 (8-Bit Double-Buffered Input)



Figure 11 Mode 0 Submode 00

In Mode 0, double-buffered input transfers of up to 8-bits are available by programming Submode 00 in the desired port's control register. The operation of H2 and H4 may be selected by programming the Port A and Port B Control Registers, respectively. All five double-buffered input handshake options, previously mentioned in the Port General Information and Conventions section, are available.

For pins used as outputs, the data path consists of single latch driving the output buffer. Data written to the port's data register does not affect the operation of any handshake pin, status bit, or any other aspect of the PI/T. Output pins may be used independently of the input transfer. However, read bus cycles to the data register do remove data from the port. Therefore, care should be taken to avoid processor instructions that perform unwanted read cycles.

Refer to PARALLEL PORTS Double-Buffered Input Transfers for a sample timing diagram. (Figure 9)

## (2) Port A or B Submode 01 (8-Bit Double-Buffered Output)

In Mode 0, double-buffered output transfers of up to 8 bits are available by programming submode 01 in the desired port's control register. The operation of H2 and H4 may be selected by programming the Port A and Port B Control Registers, respectively. All five double-buffered output handshake op-



Figure 12 Mode 0 Submode 01

tions, previously mentioned in the Port General Information and Conventions section, are available.

For pins used as inputs, data written to the associated data register is double-buffered and passed to the initial or final output latch, as usual, but the output buffer is disabled.

Refer to PARALLEL PORTS Double-Buffered Output Transfers for a sample timing diagram (Figure 10)

## (3) Port A or B Submode 1X (Bit I/O)



Figure 13 Mode 0 Submode 1X

In Mode 0, simple Bit I/O is available by programming Submode 1X in the desired port's control register. This submode is intended for applications in which several independent devices must be controlled or monitored. Data written to the

associated data register is single-buffered. If the data direction register bit for that pin is a 1 (output), the output buffer is enabled. If it is 0 (input), data written is still latched, but is not available at the pin. Data read from the data register is the instantaneous value of the pin or what was written to the data register, depending on the contents of the data direction register. H1(H3) is an edge-sensitive status input pin only and it controls no data-related function. The H1S(H3S) status bit is set following the asserted edge of the input waveform. It is reset by the direct method, the RESET pin being asserted, or when the H12 Enable (H34 Enable) bit is 0.

H2(H4) can be programmed as a simple status input (identical to H1(H3)), or as an asserted or negated output. The interlocked or pulsed handshake configurations are not available.

#### • Mode 1 – Unidirectional 16-Bit Mode

In Mode 1, Ports A and B are concatenated to form a single 16-bit port. The Port B Submode field controls the configuration of both ports. The possible submodes are:

- Port B Submode X0 – Double-Buffered Input
- Port B Submode X1 – Double-Buffered Output

Handshake pins H3 and H4, configured by programming the Port B Control Register, are associated with the 16-bit double-buffered transfer. These 16-bit transfers, are enabled by the H34 Enable bit of the Port General Control Register. Handshake pins H1 and H2 may be used as simple status inputs not related to the 16-bit data transfer or H2 may be an output. Enabling of the H1 and H2 handshake pins is done by the H12 Enable bit of the Port General Control Register. The Port A and B Data Direction Registers operate in each sub-mode. Along with the submode, they affect the data read and written at the data register according to Table 7. They also enable the output buffer associated with each port pin. The DMAREQ pin may be associated only with H3.

Mode 1 can provide convenient, high-speed 16-bit transfers. The Port A and B data registers are addressed for compatibility with the HD68000 Move Peripheral (MOVEP) instruction and with the HD68450 DMAC. To take advantage of this, Port A should contain the most-significant byte of data and always be read or written by the bus master first. The interlocked and pulsed handshake protocols are keyed to access to the Port B Data Register in Mode 1. If it is accessed last, the 16-bit double-buffered transfers proceed smoothly.

Table 7 Mode 1 Port Data Paths

| Mode                    | Read Port A/B Register |                              | Write Port A/B Register                              |                                                                    |
|-------------------------|------------------------|------------------------------|------------------------------------------------------|--------------------------------------------------------------------|
|                         | DDR = 0                | DDR = 1                      | DDR = 0                                              | DDR = 1                                                            |
| 1, Port B<br>Submode X0 | FIL, D.B.<br><br>Pin   | FOL<br><br>FOL<br><br>Note 3 | FOL, S.B.<br><br>IOL/FOL.<br><br>D.B.,<br><br>Note 1 | FOL, S.B.<br><br>Note 2<br><br>IOL/FOL.<br><br>D.B.,<br><br>Note 1 |
| 1, Port B<br>Submode X1 |                        |                              |                                                      |                                                                    |

Note 1: Data written to Port A goes to a temporary latch. When the Port B data register is later written, Port A data is transferred to IOL/FOL.

Note 2: Data is latched in the output data registers (final output latch) and will be single buffered at the pin if the DDR is 1. The output buffers will be turned off if the DDR is 0.

Note 3: The output drivers that connect the final output latch to the pins are turned on.

|                            |                               |
|----------------------------|-------------------------------|
| <b>Abbreviations:</b>      | S.B. – Single Buffered        |
| IOL – Initial Output Latch | D.B. – Double Buffered        |
| FOL – Final Output Latch   | DDR – Data Direction Register |
| FIL – Final Input Latch    |                               |

#### (1) Port B Submode X0 (16-Bit Double-Buffered Input)

In Mode 1 Port B Submode X0, double-buffered input transfers of up to 16 bits may be obtained. The level of all 16 pins is asynchronously latched with the asserted edge of H3. The processor may check H3S status bit to determine if new data is present. The DMAREQ pin may be used to signal a DMA controller to empty the input buffers. Regardless of the bus master, Port A data should be read first. (Actually, Port A data need not be read at all.) Port B data should be read last. The operation of the internal handshake controller, the H3S bit, and DMAREQ are keyed to the reading of the Port B

data register. (The HD68450 DMAC can be programmed to perform the exact transfers needed for compatibility with the PI/T.) H4 may be programmed for all five of the handshake options mentioned in the Port General Information and Conventions section.

For pins used as outputs, the data path consists of a single latch driving the output buffer. Data written to the port's data register does not affect the operation of any handshake pin, status bit, or any other aspect of the PI/T. Thus, output pins may be used independently of the input transfer. However, read bus cycles to the Port B Data Register do remove



data, so care should be taken to avoid unwanted read cycles.



Figure 14 Mode 1 Port B Submode X0

#### (2) Port B Submode X1 (16-Bit Double-Buffered Output)



Figure 15 Mode 1 Port B Submode X1

Refer to PARALLEL PORTS Double-Buffered Input Transfers for a sample timing diagram (Figure 9).

In Mode 1 Port B Submode X1, double-buffered output transfers of up to 16 bits may be obtained. Data is written by the bus master (processor or DMA controller) in two bytes. The first byte (most-significant) is written to the Port A Data Register. It is stored in a temporary latch until the next byte is written to the Port B Data Register. Then all 16 bits are transferred to the final output latches of Ports A and B. Both options for interpretation of the H3S status bit, mentioned in Port General Information and Comments section, are available and apply to the 16-bit port as a whole. The DMAREQ pin may be used to signal a DMA controller to transfer another word to the port output latches. (The HD68450 DMAC can be programmed to perform the exact transfers needed for compatibility with the PI/T.) H4 may be programmed for all five of the handshake options mentioned in Port General Information and Comments section.

For pins used as inputs, data written to either data register is double-buffered and passed to the initial or final output latch, as usual, but the output buffer is disabled.

Refer to PARALLEL PORTS Double-Buffered Input/Output Transfer for a sample timing diagram (Figure 10).

#### ● Mode 2 – Bidirectional 8-Bit Mode



Figure 16 Mode 2

In Mode 2, Port A is used for simple bit I/O with no associated handshake pins. Port B is used for bidirectional 8-bit double-buffered transfers. H1 and H2, enabled by the H12 Enable bit in the Port General Control Register, control output transfers, while H3 and H4, enabled by the Port General Control Register bit H34 Enable, control input transfers. The instantaneous direction of the data is determined by the H1 handshake pin. The Port B Data Direction Register is not used. The Port A and Port B submode fields do not affect PI/T operation in Mode 2.

##### (1) Double-Buffered I/O (Port B)

The only aspect of bidirectional double-buffered transfers that differs from the uni-directional modes lies in controlling the Port B output buffers. They are controlled by the level of H1. When H1 is negated, the Port B output buffers (all 8) are enabled and the pins drive the bidirectional bus. Generally, H1 is negated in response to an asserted H2, which indicates that new output data is present in the double-buffered latches. Following acceptance of the data, the peripheral asserts H1, disabling the Port B output buffers. Other than controlling the output buffer, H1 is edge-sensitive as in other modes. Input transfers proceed identically to the double-buffered input protocol described in the Port General Information and Conventions Section. In Mode 2, only the interlocked and pulsed

Table 8 Mode 2 Port B Data Paths

| Mode | Read Port B Data Register | Write Port B Data Register |
|------|---------------------------|----------------------------|
| 2    | FIL, D.B.                 | IOL/FOL, D.B.              |

Abbreviations:

|      |   |                      |
|------|---|----------------------|
| IOL  | — | Initial Output Latch |
| FOL  | — | Final Output Latch   |
| D.B. | — | Double Buffered      |
| FIL  | — | Final Input Latch    |



handshake pin options are available on H2 and H4. The DMAREQ pin may be associated with either input transfers (H3) or output transfers (H1), but not both. Refer to Table 8 for a summary of the Port B Data Register responses in Mode 2.

(2) Bit I/O (Port A)

Mode 2, Port A performs simple bit I/O with no associated handshake pins. This configuration is intended for applications in which several independent devices must be controlled or

monitored. Data written to the Port A data register is single-buffered. If the Port A Data Direction Register bit for that pin is 1 (output), the output buffer is enabled. If it is 0, data written is still latched but not available at the pin. Data read from the data register is either the instantaneous value of the pin or what was written to the data register, depending on the contents of the Port A Data Direction Register. This is summarized in Table 9.

Table 9 Mode 2 Port A Data Paths

| Mode                     | Read Port A Data Register |                               | Write Port A Data Register |           |
|--------------------------|---------------------------|-------------------------------|----------------------------|-----------|
|                          | DDR = 0                   | DDR = 1                       | DDR = 0                    | DDR = 1   |
| 2                        | Pin                       | FOL                           | FOL                        | FOL, S.B. |
| <b>Abbreviations:</b>    |                           |                               |                            |           |
| S.B. — Single Buffered   |                           | DDR — Data Direction Register |                            |           |
| FOL — Final Output Latch |                           |                               |                            |           |

- Mode 3 – Bidirectional 16-Bit Double Buffered I/O



Figure 17 Mode 3

In Mode 3, Ports A and B are used for bidirectional 16-bit double-buffered transfers. H1 and H2 control output transfers, while H3 and H4 control input transfers. (H1 and H2 are enabled by the H12 Enable bit while H3 and H4 are enabled by the H34 Enable bit of the Port General Control Register.) The instantaneous direction of the data is determined by the H1 handshake pin, and thus, the data direction registers are not used. The Port A and Port B submode fields do not affect PI/T operation in Mode 3.

The only aspect of bidirectional double-buffered transfers that differs from the unidirectional modes lies in controlling the Port A and B output buffers. They are controlled by the level of H1. When H1 is negated, the output buffers (all 16) are enabled and the pins drive the bidirectional bus. Generally, H1 is negated in response to an asserted H2, which indicates

that new output data is present in the double-buffered latches. Following acceptance of the data, the peripheral asserts H1, disabling the output buffers. Other than controlling the output buffers, H1 is edge-sensitive as in other modes. Input transfers proceed identically to the double-buffered input protocol described in the Port General Information and Conventions section. Port A and B data is latched with the asserted edge of H3. In Mode 3, only the interlocked and pulsed handshake pin options are available to H2 and H4. The DMAREQ pin may be associated with either input transfers (H3) or output transfers (H1), but not both. H2 indicates when new data is available in the Port B (and implicitly Port A) output latches, but unless the buffer is enabled by H1, the data is not driving the pins.

Mode 3 can provide convenient high-speed 16-bit transfers. The Port A and B Data Registers are addressed for compatibility with the HD68000's Move Peripheral (MOVEP) instruction and with the HD68450 DMA. To take advantage of this, Port A should contain the most-significant data and always be read or written by the bus master first. The interlocked and pulsed handshake protocols are keyed to accesses to the Port B Data Register in Mode 3. If it is accessed last, the 16-bit double-buffered transfer proceed smoothly. Refer to Table 10 for a summary of the Port A and B data paths in Mode 3.

#### ■ DMA REQUEST OPERATION

The Direct Memory Access Request (DMAREQ) pulse can be associated with output or input transfers to keep the initial and final output latches full or initial and final input latches empty respectively. Figure 18 and 19 show all the possible paths in generating DMA requests.



Table 10 Mode 3 Port A and B Data Paths

| Mode | Read Port A and B Data Register | Write Port A and B Data Register |
|------|---------------------------------|----------------------------------|
| 3    | FIL, D.B.                       | IOL/FOL, D.B., Note 1            |

Note 1: Data written to Port A goes to a temporary latch. When the Port B data register is later written, Port A data is transferred to IOL/FOL.

Abbreviations:

|                            |                        |
|----------------------------|------------------------|
| IOL — Initial Output Latch | S.B. — Single Buffered |
| FOL — Final Output Latch   | D.B. — Double Buffered |
| FIL — Final Input Latch    |                        |



Figure 18 DMAREQ Associated with Output Transfers

Figure 19 DMAREQ Associated with Input Transfers

### TIMER

The HD68230 timer can provide several facilities needed by HD68000 operating systems. It can generate periodic interrupts, a square wave, or a single interrupt after a programmed time period. Also, it can be used for elapsed time measurement or as a device watchdog. This section describes the programmable options available, capabilities, and restrictions that apply to the timer.

The PI/T timer contains a 24-bit synchronous down counter that is loaded from three 8-bit Counter Preload Registers. The 24-bit counter may be clocked by the output of a 5-bit (divide-by-32) prescaler or by an external timer input TIN. If the prescaler is used, it may be clocked by the system clock (CLK pin) or by the TIN external input. The counter signals the occurrence of an event primarily through zero detection. (A zero is when the counter of the 24-bit timer is equal to zero.) This sets the zero detect status (ZDS) bit in the Timer Status Register. It may be checked by the processor or may be used to generate a timer interrupt. The ZDS bit is reset by writing a 1 to the Timer Status Register in that bit position.

The general operation of the timer is flexible and easily programmable. The timer is fully configured and controlled by programming the 8-bit Timer Control Register. It controls: (1) the choice between the Port C operation and the timer

operation of three timer pins,

- (2) whether the counter is loaded from the Counter Preload Register or rolls over when zero detect is reached,
- (3) the clock input,
- (4) whether the prescaler is used, and
- (5) whether the timer is enabled.

#### • RUN/HALT Definition:

The overall operation of the timer is described in terms of the run or halt states. The control of the current state is determined by programming the Timer Control Register. When in the halt state, all of the following occur.

- (1) The prior contents of the counter is not altered and is reliably readable via the Count Registers.
- (2) The prescaler is forced to \$1F whether or not it is used.
- (3) The ZDS status bit is forced to 0, regardless of the possible zero contents of the 24-bit counter.

The run state is characterized by:

- (1) The counter is clocked by the source programmed in the Timer Control Register.
- (2) The counter is not reliably readable.
- (3) The prescaler is allowed to decrement if programmed for use.
- (4) The ZDS status bit is set when the 24-bit counter transitions from \$000001 to \$000000.



- Timer Rules**

This section provides a set of rules that allow easy application of the timer.

- (1) When the RESET pin is asserted, all bits of the Timer Control Register go to 0, configuring the dual function pins as Port C inputs.
- (2) The contents of the Counter Preload Registers and counter are not affected by the RESET pin.
- (3) The Count Registers provide a direct read data path from each portion of the 24-bit counter, but data written to their addresses is ignored. (This results in a normal bus cycle.) These registers are readable at any time, but their contents are never latched. Unreliable data may be read when the timer is in the run state.
- (4) The Counter Preload Registers are readable and writable at any time and this occurs independently of any timer operation. No protection mechanisms are provided against ill-timed writes.
- (5) The input frequency to the 24-bit counter from the TIN pin or prescaler output, must be between 0 and the input frequency at CLK pin divided by 32 regardless of the configuration chosen.
- (6) For configurations in which the prescaler is used (with the CLK pin or TIN pin as an input), the contents of the Counter Preload Register (CPR) is transferred to the counter the first time that the prescaler passes from \$00 to \$1F (rolls over) after entering the run state. Thereafter, the counter decrements or is loaded from the Counter Preload Register when the prescaler rolls over.
- (7) For configurations in which the prescaler is not used, the contents of the Counter Preload Registers are transferred to the counter on the first asserted edge of the TIN input after entering the run state. On subsequent asserted edges the counter decrements or is loaded from the Counter Preload Registers.
- (8) The lowest value allowed in the Counter Preload Register for use with the counter is \$000001.

- Timer Interrupt Acknowledge Cycles**

Several conditions may be present when the timer interrupt acknowledge pin (TIACK) is asserted. These conditions affect the PI/T's response and the termination of the bus cycle. (see Table 11)

Table 11 Response to Timer Interrupt Acknowledge

| PC3/TOUT Function                       | Response to Asserted TIACK                          |
|-----------------------------------------|-----------------------------------------------------|
| PC3 – Port C Pin                        | No response.<br>No DTACK.                           |
| TOUT – Square Wave                      | No response.<br>No DTACK.                           |
| TOUT – Negated Timer Interrupt Request  | No response.<br>No DTACK.                           |
| TOUT – Asserted Timer Interrupt Request | Timer Interrupt Vector Contents.<br>DTACK Asserted. |

- TIMER APPLICATIONS SUMMARY**

This section outlines programming of the Timer Control Register for several typical examples.

(1) Periodic Interrupt Generator

| 7                  | 6          | 5 | 4             | 3            | 2 | 1 | 0 |
|--------------------|------------|---|---------------|--------------|---|---|---|
| TOUT/TIACK Control | Z.D. Ctrl. | * | Clock Control | Timer Enable |   |   |   |

1 X 1 0 0 00 or 1X changed

In this configuration the timer generates a periodic interrupt. The TOUT pin is connected to the system's interrupt request circuitry and the TIACK pin may be used as an interrupt acknowledge input to the timer. The TIN pin may be used as a clock input.

The processor loads the Counter Preload Registers and Timer Control Register, and then enables the timer. When the 24-bit counter passes from \$000001 to \$000000 the ZDS status bit is set and the TOUT (interrupt request) pin is asserted. At the next clock to the 24-bit counter it is again loaded with the contents of the CPR's, and thereafter decrements. In normal operation, the processor must direct clear the status bit to negate the interrupt request. (Figure 20)



Figure 20 Periodic Interrupt Generator

(2) Square Wave Generator

| Square Wave Generator |            |   |               |              |   |   |   |
|-----------------------|------------|---|---------------|--------------|---|---|---|
| 7                     | 6          | 5 | 4             | 3            | 2 | 1 | 0 |
| TOUT/TIACK Control    | Z.D. Ctrl. | * | Clock Control | Timer Enable |   |   |   |

0 1 X 0 0 00 or 1X changed

In this configuration the timer produces a square wave at the TOUT pin. The TOUT pin is connected to the user's circuitry and the TIACK pin is not used. The TIN pin may be used as a clock input.

The processor loads the Counter Preload Registers and Timer Control Register, and then enables the timer. When the 24-bit counter passes from \$000001 to \$000000 the ZDS



status bit is set and the TOUT (square wave output) pin is toggled. At the next clock to the 24-bit counter it is again loaded with the contents of the CPRs, and thereafter decrements. In this application there is no need for the processor to direct clear the ZDS status bit; however, it is possible for the processor to sync itself with the square wave by clearing the ZDS status bit, then polling it. The processor may also read the TOUT level at the Port C address.

Note that the PC<sub>3</sub>/TOUT pin functions as PC3 following the negation of RESET. If used in the square wave configuration a pullup resistor may be required to keep a known level prior to programming. Prior to enabling the timer, TOUT is high. (Figure 21)



Figure 21 Square Wave Generator

### (3) Interrupt After Timeout

#### Interrupt After Timeout

| 7                  | 6          | 5 | 4             | 3            | 2        | 1       | 0 |
|--------------------|------------|---|---------------|--------------|----------|---------|---|
| TOUT/TIACK Control | Z.D. Ctrl. | * | Clock Control | Timer Enable |          |         |   |
| 1                  | X          | 1 | 1             | 0            | 00 or 1X | changed |   |

In this configuration the timer generates an interrupt after a programmed time period has expired. The TOUT pin is connected to the system's interrupt request circuitry and the TIACK pin may be an interrupt acknowledge input to the timer. The TIN pin may be used as a clock input.



Figure 22 Interrupt After Timeout

This configuration is similar to the periodic interrupt generator except that the Zero Detect Control bit is set. This forces the counter roll over after Zero Detect is reached, rather than reloading from the CPRs. When the processor takes the interrupt it can halt the timer and read the counter. This allows the processor to measure the delay time from Zero Detect (interrupt request) to entering the service routine. Accurate knowledge of the interrupt latency may be useful in some applications. (Figure 22)

#### • Elapsed Time Measurement

Elapsed time measurement takes several forms; two are described below.

#### (1) System Clock

##### System Clock

| 7                  | 6          | 5 | 4             | 3            | 2 | 1 | 0       |
|--------------------|------------|---|---------------|--------------|---|---|---------|
| TOUT/TIACK Control | Z.D. Ctrl. | * | Clock Control | Timer Enable |   |   |         |
| 0                  | 0          | X | 1             | 0            | 0 | 0 | changed |

This configuration allows time interval measurement by software. No timer pins are used.

The processor loads the Counter Preload Registers (generally with all 1s) and Timer Control Register, and then enables the timer. The counter decrements until the ending event takes place. When it is desired to read the time interval, the processor must halt the timer, then read the counter.

For applications in which the interval could have exceeded that programmable in this timer, interrupts can be counted to provide the equivalent of additional timer bits. At the end, the timer can be halted and read.

#### (2) External Clock

##### External Clock

| 7                  | 6          | 5 | 4             | 3            | 2 | 1 | 0       |
|--------------------|------------|---|---------------|--------------|---|---|---------|
| TOUT/TIACK Control | Z.D. Ctrl. | * | Clock Control | Timer Enable |   |   |         |
| 0                  | 0          | X | 1             | 0            | 1 | X | changed |

This configuration allows measurement (counting) of the number of input pulses occurring in an interval in which the counter is enabled. The TIN input pin provides the input pulses. Generally the TOUT and TIACK pins are not used.

This configuration is identical to the Elapsed Time Measurement/System Clock configuration except that the TIN pin is used to provide the input frequency. It can be connected to a simple oscillator, and the same methods could be used. Alternatively, it could be gated off and on externally and the number of cycles occurring while in the run state can be counted. However, minimum pulse width high and low specifications must be met. (Figure 23)



Figure 23 Elapsed Time Measurement

- Device Watchdog

#### Device Watching

| 7                  | 6          | 5 | 4             | 3            | 2 | 1 | 0 |
|--------------------|------------|---|---------------|--------------|---|---|---|
| TOUT/TIACK Control | Z.D. Ctrl. | * | Clock Control | Timer Enable |   |   |   |

1 X 1 1 0 0 1 changed

This configuration provides the watchdog function needed in many systems. The TIN pin is the timer input whose period at the high (1) level is to be checked. Once allowed by the processor, the TIN input pin controls the run/halt mode. The TOUT pin is connected to external circuitry requiring notification when the TIN pin has been asserted longer than the programmed time. The TIACK pin (interrupt acknowledge) is only needed if the TOUT pin is connected to interrupt circuitry.

The processor loads the Counter Preload Register and Timer Control Register, and then enables the timer. When the TIN input is asserted (1, high) the timer transfers the contents of the Counter Preload Register to the counter and begins counting. If the TIN input is negated before Zero Detect is reached, the TOUT output and the ZDS status bit remain negated. If Zero Detect is reached while the TIN input is still asserted the ZDS status bit is set and the TOUT output is asserted. (The counter rolls over and keeps on counting.)

In either case, when the TIN input is negated the ZDS status bit is 0, the TOUT output is negated, the counting stops, and the prescaler is forced to all 1s. (Figure 24)



Figure 24 Device Watchdog

#### ■ BUS INTERFACE CONNECTION

The PI/T has an asynchronous bus interface, primarily designed for use with the HD68000 microprocessor. With care, however, it can be connected to synchronous microprocessor buses. This section completely describes the PI/T's bus interface, and is intended for the asynchronous bus designer unless otherwise mentioned.

In an asynchronous system the PI/T CLK may operate at a significantly different frequency, either higher or lower, than the bus master and other system components, as long as all bus specifications are met. The HD68230 CLK pin has the same specifications as the HD68000 CLK, and must not be gated off at any time.

The following signals generate normal read and write cycles to the PI/T:  $\overline{CS}$  (Chip Select),  $R/W$  (Read/Write), RS1-RS5 (five Register Select bits),  $D_0-D_7$  (the 8-bit bidirectional data bus), and  $\overline{DTACK}$  (Data Transfer Acknowledge). To generate interrupt acknowledge cycles  $PC_5/\overline{PIACK}$  or  $PC_7/\overline{TIACK}$  is used instead of CS, and the Register Select pins are ignored. No combination of the following pins may be asserted simultaneously:  $\overline{CS}$ ,  $\overline{PIACK}$ , or  $\overline{TIACK}$ .

- Read Cycles Via Chip Select

This category includes all register reads, except port or timer interrupt acknowledge cycles. When  $\overline{CS}$  is asserted, the Register Select and  $R/W$  inputs are latched internally. They must meet small setup and hold time requirements with respect to the asserted edge of  $\overline{CS}$ . (See the AC ELECTRICAL CHARACTERISTICS table.) The PI/T is not protected against aborted (shortened) bus cycles generated by an Address Error or Bus Error exception in which it is addressed.

Certain operations triggered by normal read (or write) bus cycles are not complete within the time allotted to the bus cycle. One example is transfers to/from the double-buffered latches that occur as a result of the bus cycle. If the bus master's CLK is significantly faster than the PI/T's the possibility exists that, following the bus cycle,  $\overline{CS}$  can be negated then re-asserted before completion of these internal operations. In this situation the PI/T does not recognize the re-assertion of  $\overline{CS}$  until these operations are complete. Only at that time does it begin the internal sequencing necessary to react to the asserted  $\overline{CS}$ . Since  $\overline{CS}$  also controls the  $\overline{DTACK}$  response, this "bus cycle recovery time" can be related to the CLK edge on which  $\overline{DTACK}$  is asserted for that cycle. The PI/T will recognize the subsequent assertion of  $\overline{CS}$  three (3) CLK periods after the CLK edge on which  $\overline{DTACK}$  was previously asserted.

The Register Select and  $R/W$  inputs pass through an internal latch that is transparent when the PI/T can recognize a new  $\overline{CS}$  pulse (see above paragraph). Since the internal data bus of the PI/T is continuously enabled for read transfers, the read access time (to the data bus buffers) begins when the Register Selects are stabilized internally. Also, when the PI/T is ready to begin a new bus cycle, the assertion of  $\overline{CS}$  enables the data bus buffers within a short propagation delay. This does not contribute to the overall read access time unless  $\overline{CS}$  is asserted significantly after the Register Select and  $R/W$  inputs are stabilized (as may occur with synchronous bus microprocessors).

In addition to Chip Select's previously mentioned duties, it controls the assertion of  $\overline{DTACK}$  and latching of read data at the data bus interface. Except for controlling input latches and enabling the data bus buffers, all of these functions occur only after  $\overline{CS}$  has been recognized internally and synchronized with the internal clock. Chip Select is recognized on the falling edge of the CLK if the setup time is met,  $\overline{DTACK}$  is asserted



(low) on the next falling edge of the CLK. Read data is latched at the PI/T's data bus interface at the same time DTACK is asserted. It is stable as long as Chip Select remains asserted independent of other external conditions.

From the above discussion it is clear that if the CS setup time prior to the falling edge of the CLK is met, the PI/T can consistently respond to a new read or write bus cycle every four (4) CLK cycles. This fact is especially useful in designing the PI/T's clock in synchronous bus systems not using DTACK. (An extra CLK period is required in interrupt acknowledge cycles, see Read Cycles via Interrupt Acknowledge.)

In asynchronous bus systems in which the PI/T's CLK differs from that of the bus master, generally there is no way to guarantee that the CS setup time with respect to the PI/T CLK is met. Thus, the only way to determine that the PI/T recognized the assertion of CS is to wait for the assertion of DTACK. In this situation, all latched bus inputs to the PI/T must be held stable until DTACK is asserted. These include Register Select, R/W, and write data inputs (see below).

System specifications impose a maximum delay from the trailing (negated) edge of Chip Select to the negated edge of DTACK. As system speeds increase this becomes more difficult to meet with a simple pullup resistor tied to the DTACK line. Therefore, the PI/T provides an internal active pullup device to reduce the rise time, and a level-sensitive circuit that later turns this device off. DTACK is negated asynchronously as fast as possible following the rising edge of Chip Select, then three-stated to avoid interference with the next bus cycle.

The system designer must take care that DTACK is negated and three-stated quickly enough after each bus cycle to avoid interference with the next one. With the HD68000 this necessitates a relatively fast external path from the data strobe to CS going negated.

#### • Write Cycles

In many ways write cycles are similar to normal read cycles (see above). On write cycles, data at the D<sub>0</sub>-D<sub>7</sub> pins must meet the same setup specifications as the Register Select and R/W lines. Like these signals, write data is latched on the asserted edge of CS, and must meet small setup and hold time requirements with respect to that edge. The same bus cycle recovery conditions exist as for normal read cycles. No other differences exist.

#### • Read Cycles Via Interrupt Acknowledge

Special internal operations take place on PI/T interrupt acknowledge cycles. The Port Interrupt Vector Register or the Timer Interrupt Vector Register are implicitly addressed by the assertion of PC<sub>6</sub>/PIACK or PC<sub>7</sub>/TIACK, respectively. The signals are first synchronized with the falling edge of the CLK. One clock period after they are recognized the data bus buffers are enabled and the vector is driven onto the bus. DTACK is asserted after another clock period to allow the vector some setup time prior to DTACK. DTACK is negated, then three-stated as with normal read or write cycle, when PIACK or TIACK is negated.





Figure 25 HD68000 Interface-Example

**■ RESTRICTION ON HD68230 USAGE**

The parallel interface/timer (PI/T) exhibits an anomaly during interrupt acknowledge (IACK) cycles for certain configurations of the part. If the PI/T is configured to have only one interrupt source (either the port or the timer), and pins 36 ( $PC_6/\overline{PIACK}$ ) and 37 ( $PC_6/\overline{TIACK}$ ) are both low during IACK cycles, an incorrect vector number will be placed on the data bus and the interrupt vector register corresponding to the IACK cycles will be changed.

Specifically, if:

the PI/T is programmed to generate a vectored timer interrupt (i.e., pin 33 is programmed as TOUT and pin 37 as TIACK), and pin 36 is programmed to be a general-purpose input or output that is low during TIACK cycles.

or if

the PI/T is programmed to generate a vectored port interrupt (i.e., pin 35 is programmed as PIRQ and pin 36 as PIACK), and pin 37 is programmed to be a general-purpose input or output that is low during PIACK cycles,

then,

during IACK cycles, the PI/T will misinterpret the low signals present on pins 36 and 37 as simultaneously asserted

PIACK and TIACK signals, which is an illegal condition.

There is both a hardware solution and a software solution for this anomaly:

**Hardware:** Insure that whichever of the two pins not programmed as an IACK input will be high during IACK cycles. For example, if pin 37 is used as TIACK and pin 36 is programmed as a  $PC_6$  input, force pin 36 high whenever pin 37 is low. This can be accomplished with either a pullup resistor or external logic.

**Software:** If only timer interrupts are to be used, initialize the PIVR with \$FC and select a vector number for the TIVR that has the two least significant bits clear (i.e., binary xxxxx00). If only port interrupts are to be used, initialize the TIVR with \$FF and select any vector number for the PIVR.

Note that this anomaly will not arise if the PI/T interrupts are autovectored (since no IACK signal will be required) or if the PI/T is programmed to accept both port and timer interrupt acknowledges (since external IACK logic will insure that pins 36 and 37 are never low simultaneously).



# HD63310 S-DPRAM (Smart Dual Port RAM)

## —ADVANCE INFORMATION—

The HD63310 (S-DPRAM) is a high intelligent DPRAM, which provide a communication path between multiprocessor systems.

The HD63310 has 1024 × 8 bit RAM, 62 × 8 bit registers and individual dual I/O ports. The dual ports perform read/write operations independently and simultaneously.

User can select one of the two mode (DPRAM or FIFO mode) by the program. This architecture makes it possible to communicate efficiently according to applications.

### ■ FEATURES

- 2 independent asynchronous bus operation Address/Data bus configurable as multiplexed or non-multiplexed bus.
- Dual port large scale data buffer space
  - Dual port RAM mode: 1024 byte
  - FIFO mode: 2 FIFOs for 1024 byte
- 62 internal registers
  - Semaphore registers which support multi-processing (8 bit)
  - 32 registers which user can use freely
- Access Time  
150 ns/200 ns
- Low power consumption  
2 μm full CMOS circuit

### ■ TYPE OF PRODUCTS

| Type No.    | Access Time |
|-------------|-------------|
| HD63310P-15 | 150 ns      |
| HD63310P-20 | 200 ns      |

HD63310P-15, HD63310P-20



(DP-48)

### ■ PIN ARRANGEMENT



(Top View)



## ■ BLOCK DIAGRAM



## ■ SYSTEM BLOCK DIAGRAM



# HD63450

## Direct Memory Access Controller (CMOS)

The HD63450 is the CMOS Direct Memory Access Controller (DMAC). It is upward compatible with the NMOS DMAC HD68450.

In addition to the NMOS DMAC HD68450 features, the HD63450 performs one or several blocks of data transfer (Oper-and; byte, word, or long word) between memory and peripheral device at high speed. The block transfer restart operation is provided (Multi-Block Transfer with  $\overline{\text{DONE}}$  Mode). The number of operands in a block is determined by a transfer count.

The power dissipation is lowered by the CMOS process.

### ■ FEATURES

- HD68000 Bus Compatible
- 4 independent DMA Channels with Programmable Priority
- Memory-to-Memory, Memory-to-Device, Device-to-Memory Transfers
- Programmable 8-Bit or 16-Bit I/O Device Types
- Auto-Request and External-Request Transfer Modes
- Interface Lines for Requesting, Acknowledging, and Incidental Control of the Peripheral Devices
- Block Transfer Operation
  - In Single-Block:
    - Unchaining Transfer
    - Continue Mode Transfer
    - Array-Chaining and Linked-Array Chaining Transfers
    - Multi-Block Transfer with  $\overline{\text{DONE}}$
  - In Multi-Block:
    - Continue Mode Transfer
    - Array-Chaining and Linked-Array Chaining Transfers
    - Multi-Block Transfer with  $\overline{\text{DONE}}$
- 68000 Bus Exception Processing Support
- 2 Vectored Interrupts for each Channel
- Variable System Bus Bandwidth Rate Utilization
- Fast Transfer Rates: Up to 5.0 Mbytes/sec. at 10.0 MHz
- CMOS + 5 Volts Operation

HD63450-8,  
HD63450-10,  
HD63450-12



(DC-64)

HD63450Y-8,  
HD63450Y-10,  
HD63450Y-12



(PGA-68)

HD63450P-8,  
HD63450P-10,  
HD63450P-12



(DP-64)

HD63450PS-8,  
HD63450PS-10,  
HD63450PS-12



(DP-64S)

HD63450CP-8,  
HD63450CP-10,  
HD63450CP-12



(CP-68)

**■ TYPE OF PRODUCTS**

| Type No.     | Bus Timing | Packaging |
|--------------|------------|-----------|
| HD63450-8    | 8MHz       | DC-64     |
| HD63450-10   | 10MHz      |           |
| HD63450Y-8   | 8MHz       | PGA-68    |
| HD63450Y-10  | 10MHz      |           |
| HD63450P-8   | 8MHz       | DP-64     |
| HD63450P-10  | 10MHz      |           |
| HD63450PS-8  | 8MHz       | DP-64S    |
| HD63450PS-10 | 10MHz      |           |
| HD63450CP-8  | 8MHz       | CP-68     |
| HD63450CP-10 | 10MHz      |           |



**■ PIN ARRANGEMENT****• HD63450, HD63450P, HD63450PS**

(Top View)

**• HD63450Y**

(Bottom View)

| Pin No. | Function                       | Pin No. | Function                         | Pin No. | Function                        | Pin No. | Function                         |
|---------|--------------------------------|---------|----------------------------------|---------|---------------------------------|---------|----------------------------------|
| 1       | N/C                            | 18      | PCL <sub>1</sub>                 | 35      | A <sub>19</sub> /D <sub>1</sub> | 52      | BGACK                            |
| 2       | A <sub>1</sub> /D <sub>5</sub> | 19      | DTACK                            | 36      | A <sub>17</sub> /D <sub>9</sub> | 53      | LDS                              |
| 3       | A <sub>1</sub> /D <sub>3</sub> | 20      | UDS                              | 37      | A <sub>15</sub> /D <sub>7</sub> | 54      | V <sub>SS</sub>                  |
| 4       | A <sub>1</sub> /D <sub>2</sub> | 21      | AS                               | 38      | A <sub>12</sub> /D <sub>4</sub> | 55      | V <sub>CC</sub>                  |
| 5       | A <sub>6</sub> /D <sub>0</sub> | 22      | R/W                              | 39      | A <sub>9</sub> /D <sub>1</sub>  | 56      | DONE                             |
| 6       | A <sub>7</sub>                 | 23      | N/C                              | 40      | V <sub>SS</sub>                 | 57      | IRQ                              |
| 7       | A <sub>6</sub>                 | 24      | CS                               | 41      | V <sub>CC</sub>                 | 58      | ACK <sub>2</sub>                 |
| 8       | A <sub>5</sub>                 | 25      | CLK                              | 42      | A <sub>4</sub>                  | 59      | BEC <sub>2</sub>                 |
| 9       | A <sub>3</sub>                 | 26      | IACK                             | 43      | A <sub>2</sub>                  | 60      | BEC <sub>0</sub>                 |
| 10      | N/C                            | 27      | ACK <sub>3</sub>                 | 44      | BG                              | 61      | FC <sub>0</sub>                  |
| 11      | BR                             | 28      | ACK <sub>0</sub>                 | 45      | OWN                             | 62      | A <sub>21</sub> /D <sub>13</sub> |
| 12      | UAS                            | 29      | BEC <sub>1</sub>                 | 46      | HIBYTE                          | 63      | A <sub>18</sub> /D <sub>10</sub> |
| 13      | DBEN                           | 30      | FC <sub>2</sub>                  | 47      | DDR                             | 64      | A <sub>16</sub> /D <sub>8</sub>  |
| 14      | REQ <sub>3</sub>               | 31      | FC <sub>1</sub>                  | 48      | REQ <sub>1</sub>                | 65      | A <sub>14</sub> /D <sub>6</sub>  |
| 15      | REQ <sub>2</sub>               | 32      | A <sub>23</sub> /D <sub>15</sub> | 49      | PCL <sub>3</sub>                | 66      | A <sub>1</sub>                   |
| 16      | REQ <sub>0</sub>               | 33      | A <sub>22</sub> /D <sub>14</sub> | 50      | PCL <sub>2</sub>                | 67      | DTC                              |
| 17      | PCL <sub>0</sub>               | 34      | A <sub>20</sub> /D <sub>12</sub> | 51      | N/C                             | 68      | ACK <sub>1</sub>                 |

**• HD63450CP**

(Top View)

**HITACHI**

**■ ABSOLUTE MAXIMUM RATINGS**

| Item                        | Symbol            | Value                     | Unit |
|-----------------------------|-------------------|---------------------------|------|
| Supply Voltage              | V <sub>cc</sub> * | -0.3~+7.0                 | V    |
| Input Voltage               | V <sub>in</sub> * | -0.3~V <sub>cc</sub> +0.3 | V    |
| Operating Temperature Range | T <sub>opr</sub>  | 0~+70                     | °C   |
| Storage Temperature         | T <sub>stg</sub>  | -55~+150                  | °C   |

\*With respect to V<sub>ss</sub> (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        | V <sub>cc</sub> * | 4.75 | 5.0 | 5.25            | V    |
| Input Voltage         | V <sub>IH</sub> * | 2.0  |     | V <sub>cc</sub> | V    |
|                       | V <sub>IL</sub> * | -0.3 |     | 0.8             | V    |
| Operating Temperature | T <sub>opr</sub>  | 0    | 25  | 70              | °C   |

\*With respect to V<sub>ss</sub> (SYSTEM GND)**■ ELECTRICAL CHARACTERISTICS****● DC CHARACTERISTICS (V<sub>cc</sub>=5V±5%, V<sub>ss</sub>=0V, T<sub>a</sub>=0~+70°C, unless otherwise noted.)**

| Item                                     | Symbol           | Test Condition                                                                                                                                                                                                                                                                                        | min                     | typ | max             | Unit |
|------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----|-----------------|------|
| Input "High" Voltage                     | V <sub>IH</sub>  |                                                                                                                                                                                                                                                                                                       | 2.0                     |     | V <sub>cc</sub> | V    |
| Input "Low" Voltage                      | V <sub>IL</sub>  |                                                                                                                                                                                                                                                                                                       | V <sub>ss</sub> -0.3    |     | 0.8             | V    |
| Input Leakage Current                    | I <sub>in</sub>  | CS, IACK, BG, CLK,<br>BEC <sub>0</sub> ~BEC <sub>2</sub> ,<br>REQ <sub>0</sub> ~REQ <sub>3</sub>                                                                                                                                                                                                      |                         |     | 10              | μA   |
| Three-State (Off State)<br>Input Current | I <sub>TSI</sub> | A <sub>1</sub> ~A <sub>7</sub> , D <sub>0</sub> ~D <sub>15</sub> /A <sub>8</sub> ~A <sub>23</sub> ,<br>AS, UDS, LDS, R/W, UAS,<br>DTACK, BGACK, OWN, DTC,<br>HIBYTE, DDIR, DBEN,<br>FC <sub>0</sub> ~FC <sub>2</sub> , PCL <sub>0</sub> ~PCL <sub>3</sub>                                             |                         |     | 10              | μA   |
| Open Drain (Off State)<br>Input Current  | I <sub>ODI</sub> | IRQ, DONE                                                                                                                                                                                                                                                                                             |                         |     | 20              | μA   |
| Output "High" Voltage                    | V <sub>OH</sub>  | A <sub>1</sub> ~A <sub>7</sub> , D <sub>0</sub> ~D <sub>15</sub> /A <sub>8</sub> ~A <sub>23</sub> ,<br>AS, UDS, LDS, R/W, UAS,<br>DTACK, BGACK, BR, OWN,<br>DTC, HIBYTE, DDIR, DBEN,<br>ACK <sub>0</sub> ~ACK <sub>3</sub> , PCL <sub>0</sub> ~PCL <sub>3</sub> ,<br>FC <sub>0</sub> ~FC <sub>2</sub> | I <sub>OH</sub> =-400μA | 2A  |                 | V    |
| Output "Low" Voltage                     | V <sub>OL</sub>  | A <sub>1</sub> ~A <sub>7</sub> , FC <sub>0</sub> ~FC <sub>2</sub>                                                                                                                                                                                                                                     | I <sub>OL</sub> =3.2mA  |     | 0.5             |      |
|                                          | V <sub>OL</sub>  | D <sub>0</sub> ~D <sub>15</sub> /A <sub>8</sub> ~A <sub>23</sub> , AS, UDS,<br>LDS, R/W, DTACK, BR,<br>OWN, DTC, HIBYTE, DDIR,<br>DBEN, ACK <sub>0</sub> ~ACK <sub>3</sub> , UAS,<br>PCL <sub>0</sub> ~PCL <sub>3</sub> , BGACK                                                                       | I <sub>OL</sub> =5.3mA  |     | 0.5             | V    |
|                                          | V <sub>OL</sub>  | IRQ, DONE                                                                                                                                                                                                                                                                                             | I <sub>OL</sub> =8.9mA  |     | 0.5             |      |
| Power Dissipation                        | P <sub>D</sub>   | f=8MHz, V <sub>cc</sub> =5.0V<br>T <sub>a</sub> =25°C                                                                                                                                                                                                                                                 |                         | 250 | 400             | mW   |
| Capacitance                              | C <sub>in</sub>  | V <sub>in</sub> =0V<br>T <sub>a</sub> =25°C, f=1MHz                                                                                                                                                                                                                                                   |                         |     | 15              | pF   |





Figure 1 Test Loads

● AC ELECTRICAL SPECIFICATIONS ( $V_{CC}=5V \pm 5\%$ ,  $V_{SS}=0V$ ,  $T_a=0\text{~to~}+70^\circ\text{C}$ , unless otherwise noted.)

| No. | Item                                    | Symbol               | Test Condition | 8MHz    |     | 10MHz   |      | Unit    |  |
|-----|-----------------------------------------|----------------------|----------------|---------|-----|---------|------|---------|--|
|     |                                         |                      |                | Version |     | Version |      |         |  |
|     |                                         |                      |                | min     | max | min     | max  |         |  |
|     | Frequency of Operation                  | f                    |                | 4.0     | 8.0 | 4.0     | 10.0 | MHz     |  |
| 1   | Clock Period                            | t <sub>cyc</sub>     |                | 125     | 250 | 100     | 250  | ns      |  |
| 2   | Clock Width Low                         | t <sub>CL</sub>      |                | 55      | 125 | 45      | 125  | ns      |  |
| 3   | Clock Width High                        | t <sub>CH</sub>      |                | 55      | 125 | 45      | 125  | ns      |  |
| 4   | Clock Fall Time                         | t <sub>CF</sub>      |                |         | 10  |         | 10   | ns      |  |
| 5   | Clock Rise Time                         | t <sub>CR</sub>      |                |         | 10  |         | 10   | ns      |  |
| 6   | Asynchronous Input Setup Time           | t <sub>ASI</sub>     |                | 20      |     | 15      |      | ns      |  |
| 7   | Data in to DBEN Low                     | t <sub>DIDBL</sub>   |                | 0       |     | 0       |      | ns      |  |
| 8   | DTACK Low to Data Invalid               | t <sub>DTLDI</sub>   |                | 0       |     | 0       |      | ns      |  |
| 9   | Address in to AS in Low                 | t <sub>AIASL</sub>   |                | 0       |     | 0       |      | ns      |  |
| 10  | AS, DS in High to Address in Invalid    | t <sub>SIHAIV</sub>  |                | 0       |     | 0       |      | ns      |  |
| 10A | DS in High to CS High                   | t <sub>DSHCSH</sub>  |                |         | 1.0 |         | 1.0  | clk per |  |
| 11  | Clock High to DDIR Low                  | t <sub>CHDRL</sub>   |                |         | 70  |         | 60   | ns      |  |
| 12  | Clock High to DDIR High                 | t <sub>CHDRH</sub>   |                |         | 70  |         | 60   | ns      |  |
| 13  | DS in High to DDIR High Impedance       | t <sub>DHDRZ</sub>   |                |         | 120 |         | 110  | . ns    |  |
| 14  | Clock Low to DBEN Low                   | t <sub>CLDBL</sub>   |                |         | 70  |         | 60   | ns      |  |
| 15  | Clock Low to DBEN High                  | t <sub>CLDBH</sub>   |                |         | 70  |         | 60   | ns      |  |
| 16  | DS in High to DBEN High Impedance       | t <sub>DHDBZ</sub>   |                |         | 120 |         | 110  | ns      |  |
| 17  | Clock High to Data Out Valid (MPU read) | t <sub>CHDM</sub>    |                |         | 180 |         | 160  | ns      |  |
| 18  | DS in High to Data Out Invalid          | t <sub>DHDZn</sub>   |                | 0       | 0   |         |      | ns      |  |
| 19  | DS in High to Data High Impedance       | t <sub>DHDZ</sub>    |                |         | 120 |         | 110  | ns      |  |
| 20  | Clock Low to DTACK Low                  | t <sub>CLDTL</sub>   |                |         | 70  |         | 60   | ns      |  |
| 21  | DS in High to DTACK High                | t <sub>DHDTH</sub>   |                |         | 110 |         | 110  | ns      |  |
| 22  | DTACK Width High                        | t <sub>DTH</sub>     |                | 10      |     | 10      |      | ns      |  |
| 23  | DS in High to DTACK High Impedance      | t <sub>DHDTZ</sub>   |                |         | 180 |         | 160  | ns      |  |
| 24  | DTACK Low to DS in High                 | t <sub>DTLDH</sub>   |                | 0       | 0   |         |      | ns      |  |
| 25  | REQ Width Low                           | t <sub>REQL</sub>    |                | 2.0     | 2.0 |         |      | clk per |  |
| 26  | REQ Low to BR Low                       | t <sub>RELBR</sub>   |                |         | 250 | 200     |      | ns      |  |
| 27  | Clock High to BR Low                    | t <sub>CHBR</sub>    |                |         | 70  | 60      | ns   |         |  |
| 28  | Clock High to BR High                   | t <sub>CHBRH</sub>   |                |         | 70  | 60      | ns   |         |  |
| 29  | BG Low to BGACK Low                     | t <sub>BGLBL</sub>   |                | 4.5     | 4.5 |         |      | clk per |  |
| 30  | BR Low to MPU Cycle End (AS in High)    | t <sub>BRSLASH</sub> |                | 0       | 0   |         |      | ns      |  |

(to be continued)



| No. | Item                                                              | Symbol   | Test Condition | 8MHz    |         | 10MHz |     | Unit     |
|-----|-------------------------------------------------------------------|----------|----------------|---------|---------|-------|-----|----------|
|     |                                                                   |          |                | Version | Version | min   | max |          |
| 31  | MPU Cycle End ( $\overline{AS}$ in High) to BGACK Low             | tASHBL   |                | 4.5     | 5.5     | 4.5   | 5.5 | clk.per. |
| 32  | REQ Low to BGACK Low                                              | tREQLBL  |                | 6.5     |         | 6.5   |     | clk.per. |
| 33  | Clock High to BGACK Low                                           | tCHBL    |                |         | 70      |       | 60  | ns       |
| 34  | Clock High to BGACK High                                          | tCHBH    |                |         | 70      |       | 60  | ns       |
| 35  | Clock Low to BGACK High Impedance                                 | tCLBZ    |                |         | 80      |       | 70  | ns       |
| 36  | Clock High to FC Valid                                            | tCHFCV   |                |         | 100     |       | 90  | ns       |
| 37  | Clock High to Address Valid                                       | tCHAV    |                |         | 120     |       | 110 | ns       |
| 38  | Clock High to Address/FC/Data High Impedance                      | tCHAZX   |                |         | 100     |       | 100 | ns       |
| 39  | Clock High to Address/FC/Data Invalid                             | tCHAZN   |                | 0       | 0       |       |     | ns       |
| 40  | Clock Low to Address High Impedance                               | tCLAZ    |                |         | 100     |       | 90  | ns       |
| 41  | Clock High to UAS Low                                             | tCHUL    |                |         | 70      |       | 60  | ns       |
| 42  | Clock High to UAS High                                            | tCHUH    |                |         | 70      |       | 60  | ns       |
| 43  | Clock Low to UAS High Impedance                                   | tCLUZ    |                |         | 80      |       | 70  | ns       |
| 44  | UAS High to Address Invalid                                       | tUHAI    |                | 30      | 20      |       |     | ns       |
| 45  | Clock High to $\overline{AS}$ , $\overline{DS}$ Low               | tCHSL    |                |         | 60      |       | 55  | ns       |
| 46  | Clock Low to $\overline{DS}$ Low (write)                          | tCLDSL   |                |         | 60      |       | 55  | ns       |
| 47  | Clock Low to $\overline{AS}$ , $\overline{DS}$ High               | tCLSH    |                |         | 70      |       | 60  | ns       |
| 48  | Clock Low to $\overline{AS}$ , $\overline{DS}$ High Impedance     | tCLSZ    |                |         | 80      |       | 70  | ns       |
| 49  | $\overline{AS}$ Width Low                                         | tASL     |                | 255     |         | 195   |     | ns       |
| 50  | $\overline{DS}$ Width Low                                         | tDSL     |                | 190     |         | 145   |     | ns       |
| 51  | $\overline{AS}$ , $\overline{DS}$ Width High                      | tSH      |                | 150     |         | 105   |     | ns       |
| 52  | Address/FC Valid to $\overline{AS}$ , $\overline{DS}$ Low         | tAVSL    |                | 30      | 20      |       |     | ns       |
| 53  | $\overline{AS}$ , $\overline{DS}$ High to Address/FC/Data Invalid | tSHAZ    |                | 30      | 20      |       |     | ns       |
| 54  | Clock High to R/W Low                                             | tCHRL    |                |         | 70      |       | 60  | ns       |
| 55  | Clock High to R/W High                                            | tCHRH    |                |         | 70      |       | 60  | ns       |
| 56  | Clock Low to R/W High Impedance                                   | tCLRZ    |                |         | 80      |       | 70  | ns       |
| 57  | Address/FC Valid to R/W Low                                       | tAVRL    |                |         | 20      | 10    |     | ns       |
| 58  | R/W Low to $\overline{DS}$ Low (write)                            | tTRLSL   |                |         | 120     | 90    |     | ns       |
| 59  | $\overline{DS}$ High to R/W High                                  | tSHRH    |                |         | 40      | 20    |     | ns       |
| 60  | Clock Low to OWN Low                                              | tCOLL    |                |         |         | 70    | 60  | ns       |
| 61  | Clock Low to OWN High                                             | tCLOH    |                |         |         | 70    | 60  | ns       |
| 62  | Clock High to OWN High Impedance                                  | tCHOZ    |                |         |         | 80    | 70  | ns       |
| 63  | OWN Low to BGACK Low                                              | tOLBL    |                |         | 30      | 20    |     | ns       |
| 64  | BGACK High to OWN High                                            | tBHOH    |                |         | 30      | 20    |     | ns       |
| 65  | OWN Low to UAS Low                                                | tOLUL    |                |         | 30      | 20    |     | ns       |
| 66  | Clock High to ACK Low                                             | tCHACL   |                |         |         | 70    | 60  | ns       |
| 67  | Clock Low to ACK Low                                              | tCLACL   |                |         |         | 70    | 60  | ns       |
| 68  | Clock High to ACK High                                            | tCHACH   |                |         |         | 70    | 60  | ns       |
| 69  | ACK Low to $\overline{DS}$ Low                                    | tACLDL   |                |         | 100     | 80    |     | ns       |
| 70  | $\overline{DS}$ High to ACK High                                  | tDOSHACH |                |         | 30      | 20    |     | ns       |
| 71  | Clock High to HIBYTE Low                                          | tCHHIL   |                |         |         | 70    | 60  | ns       |
| 72  | Clock Low to HIBYTE Low                                           | tCLHIL   |                |         |         | 70    | 60  | ns       |
| 73  | Clock High to HIBYTE High                                         | tCHHHH   |                |         |         | 70    | 60  | ns       |
| 74  | Clock Low to HIBYTE High Impedance                                | tCLHIH   |                |         |         | 80    | 70  | ns       |
| 75  | Clock High to DTC Low                                             | tCHDTL   |                |         |         | 70    | 60  | ns       |
| 76  | Clock High to DTC High                                            | tCHDTH   |                |         |         | 70    | 60  | ns       |

Figure1  
~  
Figure8

(to be continued)



| No. | Item                                    | Symbol  | Test Condition | 8MHz    |     | 10MHz   |     | Unit    |  |
|-----|-----------------------------------------|---------|----------------|---------|-----|---------|-----|---------|--|
|     |                                         |         |                | Version |     | Version |     |         |  |
|     |                                         |         |                | min     | max | min     | max |         |  |
| 77  | Clock Low to DTC High Impedance         | tCLDTZ  |                |         | 80  |         | 70  | ns      |  |
| 78  | DTC Width Low                           | tDRLCL  |                | 105     |     | 80      |     | ns      |  |
| 79  | DTC Low to DS High                      | tDLDLH  |                | 30      |     | 20      |     | ns      |  |
| 80  | Clock High to DONE Low                  | tCHDOL  |                |         | 70  |         | 60  | ns      |  |
| 81  | Clock Low to DONE Low                   | tCLDOL  |                |         | 70  |         | 60  | ns      |  |
| 82  | Clock High to DONE High                 | tCHDOH  |                |         | 130 |         | 120 | ns      |  |
| 83  | Clock Low to DDIR High Impedance        | tCLDRZ  |                |         | 80  |         | 70  | ns      |  |
| 84  | Clock Low to DBEN High Impedance        | tCLDBZ  |                |         | 80  |         | 70  | ns      |  |
| 85  | DDIR Low to DBEN Low                    | tDRLBL  |                | 30      |     | 20      |     | ns      |  |
| 86  | DBEN High to DDIR High                  | tDBHDRH |                | 30      |     | 20      |     | ns      |  |
| 87  | DBEN Low to Address/Data High Impedance | tDBLAZ  |                |         | 17  |         | 17  | ns      |  |
| 88  | Clock Low to PCL Low (1/8 clock)        | tCPLL   |                |         | 70  |         | 60  | ns      |  |
| 89  | Clock Low to PCL High (1/8 clock)       | tCLPH   |                |         | 70  |         | 60  | ns      |  |
| 90  | PCL Width Low (1/8 clock)               | tPCLL   |                | 4.0     |     | 4.0     |     | clk per |  |
| 91  | DTACK Low to Data In (setup time)       | tDALDI  |                |         | 150 |         | 115 | ns      |  |
| 92  | DS High to Data Invalid (hold time)     | tSHDI   |                | 0       |     | 0       |     | ns      |  |
| 93  | DS High to DTACK High                   | tSHDAH  |                | 0       | 120 | 0       | 90  | ns      |  |
| 94  | Data Out Valid to DS Low                | tDOSL   |                | 0       |     | 0       |     | ns      |  |
| 95  | Data In to Clock Low (setup time)       | tDIDL   |                | 15      |     | 15      |     | ns      |  |
| 96  | BEC Low to DTACK Low                    | tBEDCAL |                | 50      |     | 50      |     | ns      |  |
| 97  | BEC Width Low                           | tBECL   |                | 2.0     |     | 2.0     |     | clk per |  |
| 98  | Clock High to IRQ Low                   | tCHIRL  |                |         | 70  |         | 60  | ns      |  |
| 99  | Clock High to IRQ High                  | tCHIRH  |                |         | 130 |         | 120 | ns      |  |
| 100 | READY In to DTC Low (Read)              | tRALDTL |                | 145     |     | 120     |     | ns      |  |
| 101 | READY In to DS Low (Write)              | tRALDSL |                | 205     |     | 170     |     | ns      |  |
| 102 | DS High to READY High                   | tDSRAH  |                | 0       | 120 | 0       | 90  | ns      |  |
| 103 | DONE In Low to DTACK Low                | tDOLDAL |                | 50      |     | 50      |     | ns      |  |
| 104 | DS High to DONE In High                 | tDSRDOH |                | 0       | 120 | 0       | 90  | ns      |  |
| 105 | Asynchronous Input Hold Time            | tASIH   |                | 15      |     | 15      |     | ns      |  |

Figure1

~

Figure8





Figure 2 Input Clock Waveform



Figure 3 AC Electrical Waveforms-MPU Read/Write



Figure 4 AC Electrical Waveforms-Bus Arbitration



Figure 5 AC Electrical Waveforms-DMA Read/Write (Single Cycle)





Figure 6 AC Electrical Waveforms-DMA Read/Write (Dual Cycle)



Figure 7 AC Electrical Waveforms-DMA Read/Write (Single Cycle with ACK and READY)





Figure 8 AC Electrical Waveforms-DONE Input

(NOTES for Figure 3 through 8)

- 1) Setup time for the asynchronous inputs **BG**, **BGACK**, **CS**, **iACK**, **AS**, **UDS**, **LDS**, and **R/W** guarantees their recognition at the next falling edge of the clock.  
Setup time for **BEC<sub>0</sub>**~**BEC<sub>2</sub>**, **REQ<sub>0</sub>**~**REQ<sub>3</sub>**, **PCL<sub>0</sub>**~**PCL<sub>3</sub>**, **DTACK**, and **DONE** guarantees their recognition at the next rising edge of the clock
- 2) Timing measurements are referred to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts
- 3) These waveforms should only be referred 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

## ■ INTRODUCTION

The main purpose of a direct memory access (DMA) controller is to perform memory-to-memory, device-to-memory, and memory-to-device data transfers at high speed. The DMAC is required in any system including the device for data input/output like a floppy disk, a hard disk, a display terminal etc..

Figure 9 illustrates a typical system configuration using the DMAC. In this figure, the DMAC transfers blocks of data between the HDC and memory in a quick and efficient manner. Memory-to-memory data transfer is also provided by using data registers in the DMAC. Both 8-bit and 16-bit I/O devices are supportable. 8-/16-/32-bit data can be accessed in the DMA data transfer.

## ■ OPERATION MODES

The HD63450 DMAC operates through the MPU's writing operation into the internal control registers, then the DMAC will be in one of three operating modes:

### 1) MPU mode

This is the state that the DMAC is chip-selected by another bus master in the system (MPU etc.), or that it is asserting the vector number during the interrupt acknowledge cycle.

### 2) DMA mode

This is the state that the DMAC is acting as a bus master to perform an operand transfer. The DMA bus cycle refers to the bus cycle that is executed by the DMAC in the DMA mode.

### 3) IDLE mode

This is the state that the DMAC is reset by an external device. The DMAC is waiting for an access by MPU or an operand transfer request from a peripheral. Many of the bus control signals are three-stated.



Figure 9 Typical System Configuration

### ■ SIGNAL DESCRIPTION

In this data sheet, the state of the signals is described with "active/inactive" or "assert/negate".

Figure 10 illustrates the input and output signals. Each function is described in the following.



Figure 10 Input and Output Signals

#### ● Address/Data Bus (A<sub>8</sub>/Do through A<sub>23</sub>/D<sub>15</sub>)

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

These lines are time multiplexed for address and data bus. The lines DDIR, DBEN, UAS and OWN are used to control the demultiplexing of the data and address lines externally. Demultiplexing is explained in the later section. The bi-directional data bus is used to transfer data between DMAC, MPU, memory and I/O devices.

Address lines are outputs to address memory and I/O devices.

#### ● Address Bus (A<sub>1</sub> through A<sub>7</sub>)

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

In the MPU mode, the DMAC internal registers are accessed with these lines and LDS, UDS. The address map for these registers is shown in Table 1. During a DMA bus cycle, A<sub>1</sub>-A<sub>7</sub> are outputs containing the low order address bits of the location being accessed.

#### ● Function Code (FC<sub>0</sub> through FC<sub>2</sub>)

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

These output signals provide the function codes during DMA bus cycles. They are three-stated except in the DMA bus cycles. They are used to control the HD68000 memories.

#### ● Clock (CLK)

|       |
|-------|
| Input |
|-------|

This is the input clock to the HD63450, and should never be terminated at any time. This clock can be different from the MPU clock since HD63450 operates completely asynchronously.

#### ● Chip Select (CS)

|       |
|-------|
| Input |
|-------|

This input signal is used to chip select the DMAC in "MPU" mode. If the CS input is asserted during a bus cycle which is generated by the DMAC, the DMAC internally terminates the bus cycle and signals an address error. This function protects the DMAC from accessing its own register.

#### ● Address Strobe (AS)

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

In the "MPU mode", this line is an input indicating valid address input, and during the DMA bus cycle it is an output indicating valid address output from the DMAC on the address bus.

The DMAC monitors these input lines during bus arbitration to determine the completion of the bus cycle by the MPU or other bus masters.

#### ● Upper Address Strobe (UAS)

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

This line is an output to latch the upper address lines on the multiplexed data/address lines. It is three-stated except in the "DMA mode".

#### ● Own (OWN)

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

This line is asserted by the DMAC during DMA mode, and is used to control the output of the address line latch. This line may also be used to control the direction of bi-directional buffers when loads on AS, LDS, UDS, R/W and other signals exceed the drive capability. It is three-stated in the "MPU mode" and the "IDLE mode".

#### ● Data Direction (DDIR)

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

This line controls the direction of data through the bi-directional buffer which is used to demultiplex the data/address lines. It is three-stated during the "IDLE mode".

#### ● Data Bus Enable (DBEN)

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

This line controls the output enable line of bi-directional buffers on the multiplexed data/address lines. It is three-stated during the "IDLE mode".

#### ● High Byte (HIBYTE)

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

This line is used when the operand size is byte in the single addressing mode. It is asserted when data is present on the upper eight bits of the data bus. It is used to control the output of bidirectional buffers which connects the upper eight bits of the data bus with the lower eight bits. It is three-stated during the "MPU mode" and the "IDLE mode".



**● Read/Write (R/W)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

This line is an input during the "MPU mode" and an output during the "DMA mode". It is three-stated during the "IDLE mode". It is used to control the direction of data flow.

**● Upper Data Strobe (UDS), Lower Data Strobe (LDS)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

These lines are extensions of the address lines indicating which byte or bytes of data of the addressed word are being addressed. These lines combined corresponds to address line A<sub>0</sub> in table 1.

**● Data Transfer Acknowledge (DTACK)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

In the "MPU mode", this line is an output indicating the completion of Read/Write bus cycle by the MPU.

In the "DMA mode", the DMAC monitors this line to determine when a data transfer has completed. In the event that a bus exception is requested, except for HALT, prior to or concurrent with DTACK, the DTACK response is ignored and the bus exception is honored. In the "IDLE mode", this signal is three-stated.

**● Bus Exception Controls (BEC<sub>0</sub> through BEC<sub>2</sub>)**

|       |
|-------|
| Input |
|-------|

These lines provide an encoded signal input indicating an exceptional condition in the DMA bus cycle. See bus exception section for details.

**● Bus Request (BR)**

|        |
|--------|
| Output |
|--------|

This output line is used to request ownership of the bus by the DMAC.

**● Bus Grant (BG)**

|       |
|-------|
| Input |
|-------|

This line is used to indicate to the DMAC that it is to be the next bus master. The DMAC cannot assume bus ownership until both AS and BGACK become inactive. Once the DMAC acquires the bus, it does not continue to monitor the BG input.

**● Bus Grant Acknowledge (BGACK)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

Bus Grant Acknowledge (BGACK) is a bi-directional control line. As an output, it is generated by the DMAC to indicate that it is the bus master.

As an input, BGACK is monitored by the DMAC, in limited rate auto-request mode, to determine whether or not the current bus master is a DMA device or not. BGACK is also monitored during bus arbitration in order to assume bus ownership.

**● Interrupt Request (IRQ)**

|        |            |
|--------|------------|
| Output | Open drain |
|--------|------------|

This line is used to request an interrupt to the MPU.

**● Interrupt Acknowledge (IACK)**

|       |
|-------|
| Input |
|-------|

This line is an input to the DMAC indicating that the current bus cycle is an interrupt acknowledge cycle by the MPU. The

DMAC responds the interrupt vector of the channel with the highest priority requesting an interrupt. There are two kinds of the interrupt vectors for each channel : normal (NIV) or error (EIV). IACK is not serviced if the DMAC has not generated IRQ.

**● Channel Request (REQ<sub>0</sub> through REQ<sub>3</sub>)**

|       |
|-------|
| Input |
|-------|

These lines are the DMA transfer request inputs from the peripheral devices.

These lines are falling edge sensitive inputs when the request mode is cycle steal. They are low-level sensitive when the request mode is burst.

**● Channel Acknowledge (ACK<sub>0</sub> through ACK<sub>3</sub>)**

|        |
|--------|
| Output |
|--------|

These lines indicate to the I/O device requesting a transfer that the request is acknowledged and the transfer is to be performed. These lines may be used as a part of the enable circuit for bus interface to the peripheral.

**● Peripheral Control Line (PCL<sub>0</sub> through PCL<sub>3</sub>)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
|--------------|----------------|

The four lines (PCL<sub>0</sub>~PCL<sub>3</sub>) are multi-purpose lines which may be individually programmed to be a START output, an Enable Clock input, a READY input, an ABORT input, a STATUS input, or an INTERRUPT input.

REQ<sub>x</sub>, ACK<sub>x</sub>, and PCL<sub>x</sub> are provided for each channel.

**● Done (DONE)**

|              |            |
|--------------|------------|
| Input/Output | Open Drain |
|--------------|------------|

As an output, this line is asserted concurrently with the ACK<sub>x</sub> timing to indicate the last data transfer to the peripheral device. As an input, it allows the peripheral device to request a normal termination of the DMA transfer.

**● Device Transfer Complete (DTC)**

|        |                |
|--------|----------------|
| Output | Three-statable |
|--------|----------------|

This line is asserted when the DMA bus cycle has terminated normally with no exceptions. It may be used to supply the data latch timing to the peripheral device. In this case, data is valid at the falling edge of DTC.



## ■ INTERNAL ORGANIZATION

The DMAC has four independent DMA channels. Each channel has its own set of channel registers. These registers define and control the activity of the DMAC in processing a channel operation.



Figure 11 Internal Registers

### • Register Organization

The internal register addresses are represented in Table 1. Address space not used within the address map is reserved for future expansion. A read from an unused location in the map results in a normal bus cycle with all ones for data. A write to one of these locations results in a normal bus cycle but no write occurs.

Unused bits of the defined registers in Table 1 are read as zeros.

Table 1 Internal Register Addressing Assignments

| Register                   | Address Bits<br>7 6 5 4 3 2 1 0 | Mode         |
|----------------------------|---------------------------------|--------------|
| Channel Status Register    | c c 0 0 0 0 0 0                 | R/W*         |
| Channel Error Register     | c c 0 0 0 0 0 1                 | R            |
| Device Control Register    | c c 0 0 0 1 0 0                 | R/W          |
| Operation Control Register | c c 0 0 0 1 0 1                 | R/W          |
| Sequence Control Register  | c c 0 0 0 1 1 0                 | R/W          |
| Channel Control Register   | c c 0 0 0 1 1 1                 | R/W          |
| Memory Transfer Counter    | c c 0 0 1 0 1 b                 | R/W          |
| Memory Address Register    | c c 0 0 1 1 s s                 | R/W          |
| Device Address Register    | c c 0 1 0 1 s s                 | R/W          |
| Base Transfer Counter      | c c 0 1 1 0 1 b                 | R/W          |
| Base Address Register      | c c 0 1 1 1 s s                 | R/W          |
| Normal Interrupt Vector    | c c 1 0 0 1 0 1                 | R/W          |
| Error Interrupt Vector     | c c 1 0 0 1 1 1                 | R/W          |
| Channel Priority Register  | c c 1 0 1 1 0 1                 | R/W          |
| Memory Function Codes      | c c 1 0 1 0 0 1                 | R/W          |
| Device Function Codes      | c c 1 1 0 0 0 1                 | R/W          |
| Base Function Codes        | c c 1 1 1 0 0 1                 | R/W          |
| General Control Register   | 1 1 1 1 1 1 1 1                 | R/W          |
| cc:                        | ss:                             | b:           |
| 00-Channel #0              | 00-High-order                   | 0-High-order |
| 01-Channel #1              | 01-Upper middle                 | 1-Low-order  |
| 10-Channel #2              | 10-Lower middle                 |              |
| 11-Channel #3              | 11-Low-order                    |              |

\* see Channel Status Register section on page 17

### • Device Control Register (DCR)

The DCR is a device oriented control register. The XRM bits specify whether the channel is in burst or cycle steal request mode. The DTYP bits define what type of device is on the channel. If the DTYP bits are programmed to be a HMCS6800 device, the PCL definition is ignored and the PCL line is an Enable clock input. If the DTYP bits are programmed to be a device with READY, the PCL definition is ignored and the PCL line is a READY input. The DPS bit defines the port size (eight or sixteen bits) of the peripheral device. (A port size is the largest data which the peripheral device can transfer during a DMA bus cycle.) The PCL bits define the function of the PCL line. If the DTYP bits are programmed to be HMCS6800 device, or Device with ACK and READY, these definitions are ignored. The XRM bits are ignored if an auto-request mode (REQG=00 or 01 in Operation Control Register) is selected.



XRM (EXTERNAL REQUEST MODE)

- 00 Burst Transfer Mode
- 01 (undefined, reserved)
- 10 Cycle Steal Mode without Hold
- 11 Cycle Steal Mode with Hold

DTYP (DEVICE TYPE)

- 00 HD6800 compatible device, explicitly addressed (dual addressing mode)
- 01 HD6800 compatible device, explicitly addressed (dual addressing mode)
- 10 Device with ACK, implicitly addressed (single addressing mode)
- 11 Device with ACK and READY, implicitly addressed (single addressing mode)

DPS (DEVICE PORT SIZE)

- 0 8 bit port
- 1 16 bit port

PCL (PERIPHERAL CONTROL LINE)

- 00 Status Input
- 01 Status Input with Interrupt
- 10 1/8 Start Pulse
- 11 Abort Input

Bit 2 Not Used

### • Operation Control Register (OCR)

The OCR is an operation control register. The DIR bit defines the direction of the transfer. The BTD bit defines the execution of the multi-block transfer with DONE. The SIZE bits define the size of the operand. The CHAIN bits define the type of the CHAIN mode. The REQG bits define how requests for transfers are generated.



DIR (DIRECTION)

- 0 Transfer from memory to device (transfer from MAR address to DAR address)
- 1 Transfer from device to memory (transfer from DAR address to MAR address)



BTD (MULTI BLOCK TRANSFER WITH DONE MODE)  
 0 Terminates channel operation after the current DMA bus cycle completion  
 1 Restarts next block transfer after the current DMA bus cycle completion  
 See Page 47 Note 2 for details

SIZE (OPERAND SIZE)  
 00 Byte (8 bits)  
 01 Word (16 bits)  
 10 Long Word (32 bits)  
 11 Byte Transfer without Packing  
 (Port size : 8 bits)

CHAIN (CHAINING OPERATION)  
 00 Chain operation is disabled  
 01 (undefined, reserved)  
 10 Array Chaining  
 11 Linked Array Chaining

REQG (DMA REQUEST GENERATION METHOD)  
 00 Auto-request at transfer rate limited by General Control Register (Limited Rate Auto-Request)  
 01 Auto-request at maximum rate  
 10 REQ line requests an operand transfer  
 11 Auto-request the first operand, external request for subsequent operands  
 See Page 47 Note 2 for details

**Sequence Control Register (SCR)**  
 The SCR is used to define the sequencing of memory and device addresses.

| 7 | 6 | 5 | 4 | 3   | 2   | 1 | 0 |
|---|---|---|---|-----|-----|---|---|
| 0 | 0 | 0 | 0 | MAC | DAC |   |   |

MAC (MEMORY ADDRESS COUNT)  
 00 Memory address register does not count  
 01 Memory address register counts up  
 10 Memory address register counts down  
 11 (undefined, reserved)

DAC (DEVICE ADDRESS COUNT)  
 00 Device address register does not count  
 01 Device address register counts up  
 10 Device address register counts down  
 11 (undefined, reserved)

Bits 7, 6, 5, 4 Not Used

**Channel Control Register (CCR)**  
 The CCR is used to start or terminate the operation of a channel. This register also determines if an interrupt request is to be generated. Setting the STR bit causes immediate activation of the channel; the channel will be ready to accept request immediately. The STR and CNT bits of the register cannot be reset by a write to the register. The SAB bit is used to terminate the operation forcedly. Setting the SAB bit will reset STR and CNT. Setting the HLT bit will halt the channel operation, and clearing the HLT bit will resume the operation. Setting start bit must be done by byte access. Otherwise, timing error occurs.

| 7   | 6   | 5   | 4   | 3   | 2 | 1 | 0 |
|-----|-----|-----|-----|-----|---|---|---|
| STR | CNT | HLT | SAB | INT | 0 | 0 | 0 |

STR (START OPERATION)  
 0 No operation is pending  
 1 Start operation

CNT (CONTINUE OPERATION)  
 0 No continuation is pending  
 1 Continue operation

HLT (HALT OPERATION)  
 0 Operation not halted  
 1 Operation halted

SAB (SOFTWARE ABORT)  
 0 Channel operation not aborted  
 1 Abort channel operation

INT (INTERRUPT ENABLE)  
 0 No interrupts enabled  
 1 Interrupts enabled

Bits 2, 1, 0 Not Used

#### ● Channel Status Register (CSR)

The CSR is a register containing the status of the channel.

| 7  | 6  | 5  | 4  | 3   | 2   | 1   | 0   |
|----|----|----|----|-----|-----|-----|-----|
| CO | BT | ND | ER | ACT | DIT | PCT | PCS |

CO (CHANNEL OPERATION COMPLETE)  
 0 Channel operation incomplete  
 1 Channel operation complete

BT (BLOCK TRANSFER COMPLETE)  
 0 Block transfer incomplete  
 1 Block transfer complete

ND (NORMAL DEVICE TERMINATION)  
 0 No normal device termination by DONE input  
 1 Device terminated operation normally by DONE input

ER (ERROR BIT)  
 0 No errors  
 1 Error as coded in CER

ACT (CHANNEL ACTIVE)  
 0 Channel not active  
 1 Channel active

DIT (DONE INPUT TRANSITION)  
 0 No DONE input transition occurred  
 1 DONE input transition occurred when BTD bit is set

PCT (PCL TRANSITION)  
 0 No PCL transition occurred  
 1 PCL transition occurred

PCS (THE STATE OF THE PCL INPUT LINE)  
 0 PCL "Low"  
 1 PCL "High"



### ● Channel Error Register (CER)

The CER is an error condition status register. The ERR bit of CSR indicates if there is an error or not. Bits 0-4 indicate what type of error has occurred.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|---|---|---|---|---|---|---|------------|
| 0 | 0 | 0 |   |   |   |   | ERROR CODE |

## Error Code

|       |                        |
|-------|------------------------|
| 00000 | No error               |
| 00001 | Configuration error    |
| 00010 | Operation timing error |
| 00101 | Address error in MAR   |
| 00110 | Address error in DAR   |
| 00111 | Address error in BAR   |
| 01001 | Bus error in MAR       |
| 01010 | Bus error in DAR       |
| 01011 | Bus error in BAR       |
| 01101 | Count error in MTC     |
| 01111 | Count error in BTC     |
| 10000 | External abort         |
| 10001 | Software abort         |

Bits 7, 6, 5 Not Used

### ● Channel Priority Register (CPR)

The CPR is used to define the priority level of the channel. Priority level 0 is the highest and priority level 3 is the lowest priority.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
|---|---|---|---|---|---|---|----|
| 0 | 0 | 0 | 0 | 0 | 0 |   | CP |

## CP (CHANNEL PRIORITY)

|    |                  |
|----|------------------|
| 00 | Priority level 0 |
| 01 | Priority level 1 |
| 10 | Priority level 2 |
| 11 | Priority level 3 |

Bit 7 through 2 Not Used

### ● General Control Register (GCR)

The GCR is used to define what portion of the bus cycles is available to the DMAC for limited rate auto-request generation. GCR is also used to specify the hold time for cycle steal mode with hold.

| 7 | 6 | 5 | 4 | 3  | 2  | 1 | 0 |
|---|---|---|---|----|----|---|---|
| 0 | 0 | 0 | 0 | BT | BR |   |   |

## BT (BURST TIME)

The number of DMA clock cycles per burst that the DMAC allows in the auto-request at a limited rate of transfer is controlled by these two bits. The number is  $2^{(BT+4)}$  (two to the BT + 4 power).

| BT | Clock Cycle |
|----|-------------|
| 00 | 16 Clocks   |
| 01 | 32 Clocks   |
| 10 | 64 Clocks   |
| 11 | 128 Clocks  |

### BR (BANDWIDTH RATIO)

The amount of the bandwidth utilized by the auto-request at a limited rate transfer is controlled by these two bits. The ratio is  $2^{(BR+1)}$  (two to the BR+1 power).

| BR | Bandwidth Ratio |
|----|-----------------|
| 00 | 50.00%          |
| 01 | 25.00%          |
| 10 | 12.50%          |
| 11 | 6.25%           |

The hold time for cycle steal mode with hold is defined to be minimum of 1 sample interval and maximum of 2 sample intervals. A sample interval is defined to be  $2^{(BT+BR+5)}$  (two to the BT + BR + 5 power) clock cycles.

Bit 7 through 4 Not Used

### ● Address Registers (MAR, DAR, BAR)

Three 32-bit registers are utilized to implement the Memory Address Register, Device Address Register, and the Base Address Register. Only the least significant twenty-four bits are connected to the address output pins. The content of the MAR is outputted when the memory is accessed in single or dual addressing mode. The content of the DAR is outputted when the peripheral device is accessed. The contents of the BAR is outputted when reading chain information from memory in the Array Chaining Mode or the Linked Array Chaining Mode. It is also used to set the top address of the next block transfer in Continue mode.

### ● Function Code Registers (MFC, DFC, BFC)

The DMAC has three function code register per channel : the Memory Function Code Register (MFC), Device Function Code Register (DFC), and the Base Function Code Register (BFC). The contents of these registers are outputted from FC<sub>0</sub> through FC<sub>2</sub> lines when an address is outputted from MAR, DAR, or BAR, respectively. The BFC is also used to set the MFC for the transfer of the next data block in the Continue mode.

| 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |     |
|---|---|---|---|---|---|-----|-----|-----|
| 0 | 0 | 0 | 0 | 0 | 0 | FC2 | FC1 | FC0 |

Bit 3 through 7 Not Used

### ● Transfer Count Registers (MTC, BTC)

Each channel has two 16-bit counters : the Memory Transfer Counter (MTC) and the Base Transfer Counter (BTC). The MTC counts the number of transfer words in one block, and is decreased by one for every operand transfer.

The BTC is used to count the number of data blocks in the Array Chaining Mode. BTC is also used to set the number of operands to transfer for the next data block in the Continue Mode.

The specifiable number is up to “2<sup>16.1</sup>”.

### ● Interrupt Vector Registers (NIV, EIV)

Each channel has a Normal Interrupt Vector register and an Error Interrupt Vector register.

When an interrupt acknowledge cycle occurs, an interrupt vector is outputted from one of those registers. If the error bit (CSR) is set for the channel with interrupt pending, then content of EIV is outputted, otherwise content of NIV is outputted.



## ■ OPERATION DESCRIPTION

A DMAC channel operation proceeds in three principal phases. During the initialization phase, the MPU sets the channel control registers, supplies the initial address and the number of transfer words, and starts the channel. During the transfer phase, the DMAC accepts requests for data operand transfers, and provides addressing and bus controls for the transfers. The termination phase occurs after the operation is completed.

This section describes DMAC operations. A description of the MPU/DMAC communication is given first. Next, the transfer phase is covered, including how the DMAC recognizes requests and how the DMAC arranges for data transfer. Following this, the initialization phase is described. The termination phase is covered, introducing chaining, error signaling, and bus exceptions. A description of the channel priority scheme rounds out the

section.

## ■ READ/WRITE OF THE DMAC REGISTERS BY MPU

The MPU reads and writes the DMAC internal registers and controls the DMA transfer.

Figure 12 indicates the timing diagram when the MPU reads the contents of the DMAC register. The MPU outputs  $A_1-A_{23}$ ,  $FC_0-FC_2$ , AS, R/W, UDS, and LDS, and accesses the DMAC internal register. The specific internal register is selected by  $A_8-A_{23}$  and  $FC_0-FC_2$ . The DMAC outputs data on the data bus, together with DDIR, DBEN and DTACK. The DDIR and DBEN control the bi-directional buffer on the bus and the DTACK indicates that the data has been sent or received by the DMAC. Read Cycle is eighteen CLKs.



Figure 12 MPU Read from DMAC-Word



Figure 13 MPU Write to DMAC-Word

Figure 13 shows the MPU write cycle. Write cycle is fifteen CLKs.

Note the following points.

- (1) The clock reference shown in this figure is the DMAC input clock.
- (2) The DDIR and the DBEN are three-stated at the beginning which detects CS and the ending of the cycle.
- (3) During the MPU read cycle, the DTACK is asserted after the data is valid on the system bus.
- (4) During the MPU write cycle, the DDIR line will be driven low to direct the data buffers toward to DMAC before the buffers are enabled.

- (5) During the MPU write cycle, the DMAC will latch the data before asserting DTACK. Then it will negate DBEN and DDIR in the proper order.
- (6) After the MPU cycle and the LDS and the UDS are negated by the MPU, the DMAC will put DBEN, DDIR and the address data lines to a high impedance state.
- (7) DTACK will once go "High" and then to a high impedance state after negating LDS and UDS.

#### BUS ARBITRATION

The followings are the description of the bus arbitration. The DMAC must obtain the ownership of the bus in order to transfer data. Figure 14 indicates the DMAC bus arbitration timing. It is completely compatible with that of HD68000 MPU. The DMAC asserts the Bus Grant (BG) to request the bus mastership. The



Figure 14 DMAC Bus Arbitration Timing



MPU recognizes the request and asserts **BG**, then it grants the ownership in the next bus cycle. After the end of the current cycle (**AS** is negated), the MPU relinquishes the bus to the DMAC. The DMAC asserts the bus grant acknowledge (**BGACK**) to indicate that it has the bus ownership. A half clock before **BGACK** is asserted, the DMAC asserts **OWN**. **OWN** is kept asserted for a half clock after **BGACK** is negated at the end of the DMA cycle. **BR** is negated one clock after **BGACK** is asserted.

## ■ DEVICE/DMAC COMMUNICATION

Communication between peripheral devices and the DMAC is accommodated by five signal lines. Each channel has **REQ**, **ACK** and **PCL**, and the last two lines, the **DONE** and **DTC** lines, are shared among the four channels.

### ● Request (**REQ**)

The peripheral devices assert **REQ** to request data transfers. See the "Requests" section for details.

### ● Acknowledge (**ACK**)

This line is used to implicitly address the device which is transferring the data (This device is not selected by address lines). It is also asserted when the content of DAR is outputted during memory-to-memory transfer except for the auto-request mode at a limited rate or at the maximum rate.

### ● Peripheral Control Line (**PCL**)

The function of this line is quite flexible and is determined by the DCR (Device Control Register).

The DTYP bits of the DCR define what type of device is on the channel. If the DTYP bits are programmed to be a HMCS6800 device, the PCL definition is ignored and the **PCL** line is an Enable clock (E clock) input. If the DTYP bits are programmed to be a device with **READY**, the PCL definition is ignored and the **PCL** line is a ready input.

#### (1) **PCL** as a Status Input

The **PCL** line may be programmed as a status input. The status level of this line can be determined by the PCS bit in the CSR, regardless of the PCL function determined by the DCR. If a negative transition occurs and remains stable for a minimum of two clocks, the PCT bit of the CSR is set. This PCT bit is cleared by resetting the DMAC or writing "1" to the PCT bit.

#### (2) **PCL** as an Interrupt

The **PCL** line may be programmed to generate an interrupt on a negative transition. This enables an interrupt which is requested if the PCT bit of the CSR is set. When using this function, it is necessary to reset the PCT bit in the CSR before the PCL bit in the DCR is set to interrupt, in order to avoid assertion of IRQ line at this time.

#### (3) **PCL** as a 1/8 Starting Pulse

The **PCL** line may be programmed to output a 1/8 starting pulse. This active low starting pulse is outputted when a channel is activated, and is "Low" for a period of four clock cycles.

#### (4) **PCL** as an Abort Input

The **PCL** line may be programmed to be a negative transition abort input which terminates an operation by setting the external abort error in CER. It is necessary to reset the PCT bit in the CSR before activating the channel (Setting the ACT bit of CCR) so that the channel operation is not immediately aborted.

#### (5) **PCL** as an Enable Clock (E Clock) Input

If the DTYP bits are programmed to be a HMCS6800 device, the PCL definition is ignored and the **PCL** line is an Enable Clock input. The Enable clock downtime must be as long as five clock cycles, and must be high for a minimum of three DMAC clock

cycles, but need not be synchronous with the DMAC's clock.

### (6) **PCL** as a **READY** Input

If the DTYP bits are programmed to be a device with **READY**, the PCL definition is ignored and the **PCL** line is a **READY** input. The **READY** is an active low input.

### ● DONE (**DONE**)

This line is an active low Input/Output signal with an open drain. It is asserted when the memory transfer count is exhausted in a single block transfer. In the chaining operation, **DONE** is asserted only at the last transfer to the peripheral device of the last data block. In the continuous mode, **DONE** is asserted for each data block. It is asserted and negated in coincident with the **ACK** line for the last data transfer to the peripheral device. It is also outputted in coincident with the **ACK** line of the last bus cycle, in which the address is outputted from the DAR, in the memory-to-memory transfer (dual addressing mode) that uses the **ACK** line.

The DMAC also monitors the state of the **DONE** line during the DMA bus cycle. If the device asserts **DONE** during **ACK** active, the DMAC will terminate the operation after the transfer of the current operand. If **DONE** is asserted on the first byte of 2-byte operation or the first word of long word operation, the DMAC does not terminate the operation before the whole operand transfer is completed. If **DONE** is asserted, then the DMAC terminates the operation by clearing the ACT bit of the CSR, and setting the COC and NDT bits of the CSR. If both the DMAC and the device assert **DONE**, the device termination is not recognized, but the channel operation does terminate. **DONE** is outputted again for the retry exceptions bus cycles.

The case that the multi-block transfer with **DONE** mode is set is described later.

### ● Data Transfer Complete (**DTC**)

**DTC** is an active low signal which is asserted when the actual data transfer is accomplished. It is also asserted in the bus cycle which read a chain information from memory in the Chaining mode. However, if exceptions are generated and the DMA bus cycle terminates, **DTC** is not asserted. **DTC** is asserted one half clock before **LDS** and **UDS** are negated, and negated one half clock after **LDS** and **UDS** are negated.

## ■ REQUESTS

Requests may be externally generated by circuitry in the peripheral device, or internally generated by the auto-request mechanism. The REQG bits of the OCR determine these modes. The DMAC also supports an operation in which the DMAC auto-requests the first transfer and then waits for the peripheral device to request the following transfers.

### ● Auto-request Transfers

The auto-request mechanism provides generation of requests within the DMAC. These requests can be generated at either of two rates: maximum-rate and limited-rate. In the former case, the channel always has a request pending.

The limited rate auto-request functions by monitoring the bus utilization.

#### (1) Limited-rate Auto-request

| TIME →                   |                         |                      |
|--------------------------|-------------------------|----------------------|
| Previous Sample Interval | Current Sample Interval | Next Sample Interval |
|                          | LRAR Interval           |                      |



In the limited-rate auto-request, the DMAC divides time into equal length sample intervals by counting clock cycles. The end of one sample interval makes the beginning of the next. During a sample interval, the DMAC monitors, by means of BGACK pin, the system bus activity of the DMAC and other bus master devices. At the end of the sample interval, decision is made whether or not to perform the channel's data transfer during the next sample interval. Namely, based on the activity of the DMAC or other bus master devices during the current sample interval, the DMAC allows limited-rate auto-requests for some initial portion of the next sample interval.

The length of the sample interval, and the length of the limited-rate auto-request generation period (the limited-rate auto-request interval) are controlled by the BT and BR bits in the GCR. The length in clock cycles of the limited-rate auto-request interval is  $2^{BT+4}$  (2 raised to the BT+4 power). For example, if BT equals 2 and the DMA utilization of the bus was low during the previous sample interval, then the DMAC generates the auto-request transfers during the first 64 clock cycles.

The ratio of the length of the sample interval to the length of the limited-rate auto-request interval is controlled by the BR bits. The ratio of the system bus utilization of the MPU to other bus master devices including the DMAC is  $2^{BR+1}$  (2 raised to the BR +1 power). If the fraction of DMA clock cycles during the sample interval exceeds the programmed utilization level, the DMAC will not allow limited-rate auto-requests during the next sample interval.

For example, if BR equals 3, then at most one out of 16 clock cycles during a sample interval can be used by the DMAC and other bus master devices, and still the DMAC would allow

limited rate auto-request during the next sample interval. Therefore, from the viewpoint of long period, the ratio of the system bus utilization of the MPU to I/O devices including the DMAC is about 16 : 1. The sample interval length is not a direct parameter, but it is equal to  $2^{(BT+BR+5)}$  clock cycles. Thus, the sample interval can be programmed between 32 and 2048 clock cycles.

The DMAC uses the BGACK to differentiate between the MPU bus cycle and DMAC or other bus master devices. If BGACK is active, then the DMAC assumes that the bus is used by a DMAC or other bus master devices. If it is inactive, then the DMAC assumes that it is used by the MPU.

## (2) Maximum-rate Auto-request

If the REQG bits in the OCR indicate auto-request at the maximum rate, the DMAC acquires the bus after the start bit is set and keeps it until the data transfer is completed.

If a request is made by another channel of higher priority, the DMAC services that channel and then resumes the auto-request sequence. If two or more channels are set to equal priority level and maximum rate auto-request, then the channels will rotate in a "round robin" fashion.

If the HMCS68000 compatible device is connected to a channel, the ACK line is held inactive during an auto-request operation. Consequently, any channel may be used for the memory-to-memory transfer with the auto-request function in addition to the operation of data transfer between memory and peripheral device with using the REQ pin. Refer to Figure 15 for the timing of the memory-to-memory transfer. In this mode, the ACK, HIBYTE and DONE outputs are always inactive.



Figure 15 Memory-to-Memory Transfer Read-Write-Read Cycles





Figure 16 Burst Mode Request Timing (Only one channel is active)

#### • External Requests

If the REQG bits of the OCR indicate that the REQ line generates requests, the transfer requests are generated externally. The request line associated with each channel allows the device to externally generate requests for DMA transfers. When the device wants an operand transferred, it makes a request by asserting the request line. The external request mode is determined by the XRM bits of the DCR, which allows both burst and cycle steal request modes. The burst request mode allows a channel to request the transfer of multiple operands using consecutive bus cycles. The cycle steal request mode allows a channel to request the transfer of a single operand. The followings are the description of the burst and the cycle steal modes.

##### (1) Burst Request Recognition

In the burst request mode, the REQ line is an active low input. The level sampled at the rising edge of the clock. Once the burst request is asserted, it needs to be held low until the first DMA bus cycle starts in order to insure at least one data transfer operation. In order to stop the burst mode transfer after the current bus cycle, the REQ line has to be negated one clock before the DTC output clock of this cycle. Refer to Figure 16 or the burst mode timing.

##### (2) Cycle Steal Request Recognition

In the cycle steal request mode, the peripheral device requests the

DMA transfer by generating an falling edge at the REQ line. The REQ line needs to be held "low" for at least 2 clock cycles. In the cycle steal mode, if the REQ line changes from "High" to "Low" between ACK output and one clock before the clock that outputs DTC, then the next DMA transfer is performed without relinquishing the bus. If the bus is not relinquished, then maximum of 5 idle clocks is inserted between bus cycles.

Refer to Figure 17 for the request timing of the cycle steal mode. If the XRM bits specify cycle steal without hold, the DMAC will relinquish the bus. If the XRM bits specify cycle steal with hold, the DMAC will hold the bus and wait for the next REQ input for at least 1 sample interval after the current bus cycle completion. The allowable hold time is up to 2 sample intervals.

Figure 18 shows the request timing in the cycle steal bus hold. If the REQ is inputted during the hold time, the ACK is outputted after a maximum of 7.5 clock cycles from the picked-up clock. On the cycle steal with hold mode, the DMAC will hold the bus even when the transfer count is exhausted and the last data has been transferred. If DMA transfer is requested from other channel during this period, they are executed normally.

##### (3) Request Recognition in Dual-address Transfers

In a following section, dual-address transfers are defined. Dual address transfer is an exception to the request recognition rules



Figure 17 Cycle Steal Mode Request Timing





Figure 18 Cycle Steal Bus Hold Mode Request Timing

in the previous paragraphs. In the cycle steal request mode, when there are two or more transfers between the DMAC and the peripheral device during one operand transfer, the request is not recognized until the last transfer between the DMAC and the I/O device starts.

#### • Mixed Request Generation

A single channel can mix two request generation methods. By programming the REQG bits of the OCR to "11", when the channel is started, the DMAC auto-requests the first transfer. Subsequent requests are then generated externally by the device. The ACK and PCL lines perform their normal functions in this operation.

#### ■ DATA TRANSFERS

All DMAC data transfers are assumed to be between memory and the peripheral device. The word "memory" means a 16-bit HD68000 bus compatible device. By programming the DCR, the characteristics of the peripheral device may be assigned. Each channel can communicate using any of the following protocols.

| DTYP | Device Type               |                     |
|------|---------------------------|---------------------|
| 00   | HD68000 compatible device | { Dual Addressing   |
| 01   | HD6800 compatible device  |                     |
| 10   | Device with ACK           | { Single Addressing |
| 11   | Device with ACK and READY |                     |

#### • Dual Addressing

HD68000 and HD6800 compatible devices may be explicitly addressed. This means that before the peripheral transfers data,

a data register within the device must be addressed. Because the address bus is used to address the peripheral, the data cannot be directly transferred to/from the memory because the memory also requires addressing. Instead, the data is transferred from the source to the DMAC and held in an internal DMAC holding register. A second bus transfer between the DMAC and the destination is then required to complete the operation. Because both the source and destination of the transfer are explicitly addressed, this protocol is called dual addressing.

#### (1) HD68000 Compatible Device Transfers

In this operation, when a request is received, the bus is obtained and the transfer is completed using the protocol as shown in Figures 19 and 20. Figures 21 through 24 show the transfer timings. Figures 21 and 24 show the operation when the memory is the source and the peripheral device is the destination. Figures 22 and 23 show the transfer in the opposite direction. The peripheral device is a 16-bit device in Figures 21 and 22, and a 8-bit device in Figures 23 and 24.

#### (2) HD6800 Compatible Device Transfers

When a channel is programmed to perform HD6800 compatible transfers, the PCL line for that channel is defined as an Enable clock input. The DMAC performs data transfers between itself and the peripheral device using the HD6800 bus protocol, with the ACK output providing the VMA (valid memory address) signal. Figure 25 illustrates this protocol. Refer to Figure 26 for the read cycle timing and Figure 27 for the write cycle timing. In Figure 26, the DMAC latches the data at the falling edge of clock 19, so a latch to hold the data is necessary as shown in the figure.



Figure 19 Word Read Cycle Flowchart HD68000 Type Device



Figure 20 Word Write Cycle Flowchart HD68000 Type Device





Figure 21 Dual Addressing Mode, Read/Write Cycle,  
Destination=16-bit Device, Word Operand



Figure 22 Dual Addressing Mode, Read/Write Cycle,  
Source=16-bit Device, Word Operand

HITACHI



Figure 23 Dual Addressing Mode, Read/Write Cycle,  
Source=8-bit Device, Word Operand



Figure 24 Dual Addressing Mode, Read/Write Cycle,  
Destination=8-bit Device, Word Operand





Figure 25 HD6800 Cycle Flowchart



Figure 26 Dual Addressing Mode, HD6800 Compatible Device, Read Cycle





Figure 27 Dual Addressing Mode, HD6800 Compatible Device, Write Cycle

### (3) An Example of a Dual Address Transfer

This section contains an example of a dual address transfer using Table 2 of Dual-Address Sequencing. The transfer mode of this example is the following.

1. Device Port size=8 bits
2. Operand size=Long Word (32 bits)
3. Memory to Device Transfer
4. Source (Memory) Counts up, Destination (Device) Counts Down

In this mode, a data transfer from the source (memory) is done according to the 6th row of Table 2, since the port size of the memory is always 16 bits. A data transfer to the destination

(device) is done according to the 3rd row of Table 2. Table 3 shows the data transfer sequence.

The port size in Table 2 is not related to the DPS bit of the DCR. The DPS defines the port size of the device only. The DPS is set to "0" in this example as the device port size is 8 bits.

The memory map of this example is shown in Table 4. The operand consists of BYTE A through BYTE D in memory of Table 4. Prior to the transfer, MAR and DAR are set to 00000012 and 00000108 respectively. The operand is transferred to the 8-bit port device according to the order of transfer number in Table 3.

Table 2 Dual-Address Sequencing

| Row No. | Port Size | Operand Size | Operand Part Size     | Operand Part Addresses          | Address Increment |   |           |
|---------|-----------|--------------|-----------------------|---------------------------------|-------------------|---|-----------|
|         |           |              |                       |                                 | +                 | = | -         |
| 1       | 8         | BYTE         | BYTE                  | A                               | +2                | 0 | -2        |
| 2       | 8         | WORD         | BYTE                  | A, A+2                          | +4                | 0 | -4        |
| ③       | 8         | LONG         | BYTE *4               | A, A+2, A+4, A+6<br>*3 *5 *7 *8 | +8                | 0 | -8<br>*10 |
| 4       | 16        | BYTE         | PACK (BYTE or WORD)** | A                               | +P                | 0 | -P        |
| 5       | 16        | WORD         | WORD                  | A                               | +2                | 0 | -2        |
| ⑥       | 16        | LONG         | WORD *2               | A, A+2<br>*1 *6                 | +4<br>*9          | 0 | -4        |

\*Numbers in Table 2 correspond to ones in Tables 3 and 4

\*\*Refer to Address Sequencing on Operand Part Size and PACK



Table 3 An Example of a Data Transfer for One Operand  
SRC: Source (Memory), DST Destination (Device), HR: Holding Register (DMAC Internal Reg.)

| Transfer No. | Data Transfer | Address Output | Data Size on Bus | DMAC Registers after Transfer |                 | Comment                                                                         |
|--------------|---------------|----------------|------------------|-------------------------------|-----------------|---------------------------------------------------------------------------------|
|              |               |                |                  | MAR                           | DAR             |                                                                                 |
| 0            | —             | —              | —                | 00000012                      | 00000108        | Initial Register Setting                                                        |
| 1            | SRC→HR        | 00000012<br>*1 | WORD<br>*2       | 00000014                      | 00000108        | Higher order 16 bits of operand is fetched.                                     |
| 2            | HR →DST       | 00000108<br>*3 | BYTE<br>*4       | 00000014                      | 0000010A        | Higher order 16 bits of operand is transferred.                                 |
| 3            | HR →DST       | 0000010A<br>*5 | BYTE<br>*4       | 00000014                      | 0000010C<br>*10 |                                                                                 |
| 4            | SRC→HR        | 00000014<br>*6 | WORD<br>*2       | 00000016<br>*9                | 0000010C        | Lower order 16 bits of operand is fetched.                                      |
| 5            | HR →DST       | 0000010C<br>*7 | BYTE<br>*4       | 00000016                      | 0000010E        | Lower order 16 bits of operand is transferred.                                  |
| 6            | HR →DST       | 0000010E<br>*8 | BYTE<br>*4       | 00000016                      | 00000110<br>*10 |                                                                                 |
| 6'           | —             | —              | —                | 00000016                      | 00000110        | MAR, DAR are pointing the next operand addresses when the transfer is complete. |

Mode Port size=8, operand size=Long Word, Memory to Device, Source (Memory) Counts Up, Destination (Device) Counts Down

Table 4 Memory Map for the Example of the Data Transfer

| ADDRESS  | ADDRESS      | ADDRESS      | ADDRESS   | ADDRESS      | ADDRESS  |
|----------|--------------|--------------|-----------|--------------|----------|
| 00000010 | 00000011     | 000000106    | 000000107 |              |          |
| 00000012 | BYTE A<br>*1 | BYTE B<br>*1 | 000000108 | BYTE A<br>*3 | 00000109 |
| 00000014 | BYTE C<br>*6 | BYTE D<br>*6 | 00000010A | BYTE B<br>*5 | 0000010B |
| 00000016 |              |              | 00000010C | BYTE C<br>*7 | 0000010D |
|          |              |              | 00000010E | BYTE D<br>*8 | 0000010F |
|          |              |              | 000000110 |              | 00000111 |

Source (Memory)

Destination (Device)

#### ● Single Addressing Mode

Implicitly addressed devices are peripheral devices selected not by address but by ACK. They do not require addressing of data register during data transfer. Transfers between memory and these devices are controlled by the request/acknowledge protocol. Such peripherals require only one bus cycle to transfer data, and the DMAC internal holding register is not used. Because only the memory is addressed during a data transfer and a transfer is done in only one bus cycle, this protocol is called single-addressing.

#### (1) Device with ACK Transfers

Under this protocol, the communication between peripheral device and the DMAC is performed with a two signal REQ/ACK handshake. When a request is generated using the request method programmed in the DMAC's internal control registers, the DMAC obtains the bus and responds with ACK. The DMAC asserts all the bus control signals required for the memory access. Refer to Figure 28 for the flowchart of the data transfer from memory to the device with ACK. Figure 29 shows the flowchart of the data transfer from the device with ACK to memory. Receiving the transfer request, the DMAC obtains the bus. Then the DMAC outputs the memory address and asserts

ACK to inform the I/O device that the transfer request has been acknowledged. When the DMAC accepts DTACK from memory, it asserts DTC and informs the peripheral device of the transfer termination.

Figures 30 and 31 show the transfer timings of the device with ACK: the port size for the former figure is 8-bit and the latter is 16-bit respectively.

When the transfer is from memory to a device, data is valid when DTACK is asserted and remains valid until the data strobes are negated. The assertion of DTC from the DMAC may be used to latch the data as data strobes are not negated half clock period after the assertion of DTC.

When the transfer is from device to memory, data must be valid on the HD68000 bus before the DMAC asserts the data strobes. The data strobes are asserted one clock period after ACK is asserted. When the DMAC obtains the bus and starts a DMA cycle, the three-state of the OWN line is cancelled a half clock earlier than other control lines. If the DMA Cycle terminates and the DMAC relinquishes the bus, all the control signals get three-stated a half clock before OWN. The DDIR and



DBEN lines are not asserted in the single addressing mode. Four-clock cycle is the smallest bus cycle for the transfer from memory to device. Five-clock cycle is the smallest bus cycle for the transfer from device to memory. If the device port size is 8bits, either LDS or UDS is asserted. In the single addressing

mode,  $A_8/D_0 \sim A_{23}/D_{15}$  are outputted for only one and a half clock from the beginning of the DMA bus cycle. Therefore,  $A_8/D_0$  through  $A_{23}/D_{15}$  need to be latched externally just like in the dual addressing mode.



Figure 28 Word from Memory to Device with ACK



Figure 29 Word from Device with ACK to Memory





Figure 30 Single Addressing Mode with 8-Bit Devices as Source and Destination (Read-Write Cycles)



Figure 31 Single Addressing Mode with 16-bit Devices as Source and Destination (Read-Write Cycles)



## (2) Device with ACK and READY Transfers

Under this protocol, the communication between peripheral device and the DMAC is performed using a three signal REQ/ACK/READY handshake. The READY input to the DMAC is provided by the PCL line. The READY line is active low. When a request is generated using the request method programmed in the control registers, the DMAC obtains the bus and asserts ACK to notify the device that the transfer is to take place. The DMAC waits for READY (PCL input), which is a response from the device, in addition to DTACK which is a response from memory.

When the DMAC accepts both signals, it terminates the transfer. Refer to Figures 34 and 35 for the flowcharts of the data transfer between memory and the device with ACK and READY. Refer to Figure 36 for the transfer timing of the 8-bit device. When the data transfer is from memory to a device, data is valid from the assertion of DTACK to the negation of LDS and UDS. DTC is asserted a half clock before LDS and UDS are negated, so this line may be used for latching the data by the peripheral device. In this case, READY (PCL input) indicates that the device has received the data. Both DTACK and READY (PCL input) signals are needed for terminating the DMA cycle.

When the data transfer is from the device to memory, data must be valid on the bus before the DMAC asserts LDS and UDS.

Therefore, READY (PCL input) is used as the signal to indicate that the peripheral device has outputted the data on the bus. When the DMAC detects PCL (READY input), then it asserts LDS and UDS. After asserting LDS and UDS, the DMAC terminates the cycle when DTACK signal from the memory is detected.

As mentioned above, the I/O device and the DMAC communicate each other through three handshake signals in Figure 32.



Figure 32 Device with ACK and READY, and DMAC transfer protocol

Figure 33 shows the timing of transfers between the memory and the device with ACK and READY. The detail is as follows.



Figure 33 Device with ACK and READY Mode Timing



( i ) Data transfer from the memory to the I/O device  
(read cycle)

The DMAC samples both DTACK and READY signals at the rising edge of CLK 5 (Figure 33 ①).

Until both signals are asserted, the DMAC repeats wait cycles and samples those signals at each rising edge of the clock : the DMAC does not proceed to CLK 7 and 8 (Figure 33 ②).

When both DTACK and READY signals are asserted (Figure 33 ③), the DMAC proceeds to CLK 7 and 8, asserts DTC at the rising edge of CLK 7 (Figure 33 ④), and terminates the bus cycle. The bus cycle is 4-clock long when there is no wait cycles.

( ii ) Data transfer from the I/O device to the memory  
(write cycle)

The DMAC samples READY signal at the rising edge of CLK 3 (Figure 33 ①). Until READY signal is asserted, the DMAC repeats wait cycles and samples the signal at each rising edge of the clock : the DMAC does not proceed to CLK 5 and 6 (Figure 33 ②).

When READY signal is asserted (Figure 33 ③), the DMAC proceeds to CLK 5~8, and asserts D<sub>S</sub> at the falling edge of CLK 5 (Figure 33 ⑤).

Table 5 indicates the combinations of port size and operand size of the peripheral devices supported by the DMAC in the single and dual addressing modes. In the single addressing mode, port size and operand size must be the same. In the dual addressing mode, byte operand cannot be used when the port size is sixteen and the REQG bit is 10 or 11.



Figure 34 Word from Memory to Device with ACK and READY



Figure 35 Word from Device with ACK and READY to Memory



Figure 36 Single Addressing Mode with 8-bit Device as Source and Destination with PCL Used as a READY input (Read-Write Cycles)



Table 5 Operation Combinations

| Addressing | Device Type                | Port | Operand |      |           | REQ bits of OCR |
|------------|----------------------------|------|---------|------|-----------|-----------------|
|            |                            |      | Byte    | Word | Long Word |                 |
| Dual       | 68000, 6800                | 8    | ○       | ○    | ○         | 00, 01, 10, 11  |
|            | 68000, 6800                | 16   | ○       | ○    | ○         | 00, 01          |
|            | 68000, 6800                | 16   | ×       | ○    | ○         | 10, 11          |
| Single     | with ACK or<br>ACK & READY | 8    | ○       | ×    | ×         | 00, 01, 10, 11  |
|            |                            | 16   | ×       | ○    | ×         | 00, 01, 10, 11  |

○ : supported    × : not supported

REQG  
 00: Auto request at a limited rate  
 01: Auto request at a maximum rate  
 10: REQ line requests the operand transfer  
 11: First operand is auto requested, and subsequent operands are externally requested.

### • Address Sequencing

The sequence of addresses generated depends upon the port size, whether the addresses are to count up, down or not change and whether the transfer is executed in the single addressing mode or the dual addressing mode. The memory address count method and the peripheral device address count method is programmed using the Memory address count (MAC) bit and the Device address count (DAC) bit in the Sequence Control Register (SCR).

#### (i) Single addressing mode

In the single addressing mode, memory address sequencing is shown in Table 6. If the operand size is byte, the memory address increment is one (1). If the operand size is word, the memory address increment is two (2). If the memory address register does not count, the memory address is unchanged after the transfer.

#### (ii) Dual addressing mode

In the dual addressing mode, the operand size need not match the port size. Thus the transfer of an operand may require several DMA bus cycles. Each DMA bus cycle, between memory and DMAC and between DMAC and the device, is called the operand part and transfers a portion or all of the operand. The addresses of the operand parts are in a linear increasing sequence. The step between the addresses of the operand is two. The size of the operand

part is the minimum of the port size and the operand size. The number of the operand part is the operand size divided by the port size.

In the dual addressing mode, memory is regarded as a device whose port size is 16 bits and the operand size is a byte or a word. When the operand is transferred to the memory from the I/O device whose port size is 8 bits and the operand size is byte, the DMAC reads 2-byte operand one byte at a time from the I/O device and writes 2 bytes at the same time to the memory, or reads one byte from the I/O device and writes one byte to the memory. Thus, when the port size is 8 bits and the operand size is byte, two-operand transfer which is performed at the same time is called PACK. Utilizing the PACK, the DMAC may improve the DMA bus efficiency. However, packing is not performed if the address does not count. When the port size is 8 bits and the operand size is byte (port size : 8 bits, without PACK) with the DMAC in the dual addressing mode, the DMAC repeats the following cycles:

- ① READ BYTE (reads data from the I/O device or the memory)
- ② WRITE BYTE (writes data to the I/O device or the memory)

Table 7 shows the dual addressing sequencing

Table 6 Single Address Sequencing

| Port Size | Operand Size | Memory Address Increment |               |               |
|-----------|--------------|--------------------------|---------------|---------------|
|           |              | + (increment)            | = (unchanged) | - (decrement) |
| 8         | Byte         | +1                       | 0             | -1            |
| 16        | Word         | +2                       | 0             | -2            |

Table 7 Dual Address Sequencing

| Port Size | Operand Size | Part Size | Operand Part Address | Address Increment |   |    |
|-----------|--------------|-----------|----------------------|-------------------|---|----|
|           |              |           |                      | +                 | = | -  |
| 8         | Byte         | Byte      | A                    | +2                | 0 | -2 |
| 8         | Word         | Byte      | A, A+2               | +4                | 0 | -4 |
| 8         | Long         | Byte      | A, A+2, A+4, A+6     | +8                | 0 | -8 |
| 16        | Byte         | Pack      | A                    | +P                | 0 | -P |
| 16        | Word         | Word      | A                    | +2                | 0 | -2 |
| 16        | Long         | Word      | A, A+2               | +4                | 0 | -4 |

P=1 if packing is not done  
 =2 if packing is done

Pack =byte if packing is not done  
 =word if packing is done



## ■ INITIATION AND CONTROL OF CHANNEL OPERATION

### ● Operation Initiation

To initiate the operation of a channel, the STR bit of the CCR is set to start the operation. Setting the STR bit causes the immediate activation of the channel, the channel will be ready to accept requests immediately. The channel initiates the operation by resetting the STR bit and setting the channel active bit in the CSR. Any pending requests are cleared, and the channel is then ready to receive requests for the new operation. If the channel is configured for an illegal operation, the configuration error is signaled, and no channel operation is run. The illegal operations include the selection of any of the options marked “(undefined, reserved)”. If the MTC is set to zero in any mode other than the chaining mode, or BTC is set to zero in the array chaining mode, then the count error is signaled and the channel is not activated. The channel cannot be started if any of the ACT, COC, BTC, NDT or ERR bit is set in the CSR. In this case, the channel signals the operation timing error.

### ● Operation Continuation (Continue Mode)

When the STR bit or the ACT bit in the CSR is set, setting the CNT (Continue) bit in the CCR allows multiple blocks to be transferred as in the chaining modes. The CNT bit is set in order to continue the current channel operation. To set the CNT bit, the initial address of the next block to be transferred, the corresponding function code, and the number of words to be transferred must be previously set to the BAR, BFC and BTC. If the CNT bit is set when either the STR or the ACT bit is not set, the operation timing error is signaled. The configuration error is signaled when the CNT bit is set in the chaining modes.

### ● Operation Halting (Halt)

The CCR has a halt bit which allows suspension of the operation of the channel. If this bit is set, a request may still be generated and recognized, but the DMAC does not attempt to acquire the bus or to make transfers for the halted channel. When this bit is reset, the channel resumes operation and services any request that may have been received while the channel was halted. However, in the burst request mode, the transfer request should be kept asserted until the initiation of the first transfer after clearing the halt bit.

### ● Operation Abort by Software (Software Abort)

Setting the software abort bit (SAB) in the CCR allows the current operation of the channel to be aborted. In this case, the ERR bit and the COC bit in the CSR are set and the ACT bit is reset. The error code for the software abort is set in the CER. The SAB bit is designed to be reset if the ERR bit is reset. When the CCR is read, the SAB always reads as zero(0).

## ■ CHANNEL OPERATION TERMINATION

As part of the transfer of an operand, the DMAC decrements the memory transfer counter(MTC). If the chaining mode is not used and the CNT bit is not set or the last block is transferred in the chaining mode, the operation of the channel is complete when the last operand transfer is completed and the MTC is zero. The DMAC notifies the peripheral device of the channel completion via the DONE output.

However, in the continue mode, DONE is outputted at the termination of every data block transfer. When the channel operation has been completed, the ACT bit of the CSR is cleared, and the COC bit of the CSR is set.

The occurrence of errors, such as the bus error, during the DMA bus cycle also terminates the channel operation. In this case, the ACT bit in the CSR is cleared, the ERR and the COC bits are set, and at the same time the code corresponding to the error that occurred is set in the CER.

### ● Channel Status Register (CSR)

The channel status register contains the status of the channel at the channel operation termination. The register is cleared by writing a one (1) into each bit of the register to be cleared.

#### COC

The channel operation complete (COC) bit is set if the channel operation has completed. The COC bit must be cleared in order to start another channel operation. The COC bit is cleared only by writing a one to this bit or resetting the DMAC.

#### PCS

The peripheral status (PCS) bit reflects the level of the PCL line regardless of its programmed function. If PCL is at “High” level, the PCS bit reads as one. If PCL is at “Low” level, the PCS bit reads as zero. The PCS bit is unaffected by writing to the CSR.

#### PCT

The peripheral control transition (PCT) bit is set, if a falling edge transition has occurred on the PCL line. (The PCL line must remain at “Low” level for at least two clock cycles.) The PCT bit is cleared by writing a one to this bit or resetting the DMAC.

#### BTC

Block transfer complete (BTC) bit is set when the continue (CNT) bit of CCR is set and the memory transfer counter (MTC) is exhausted. The BTC bit must be cleared before the another continuation is attempted (namely, setting the CNT bit again), otherwise an operation timing error occurs. The BTC bit is cleared by writing a one to this bit or resetting the DMAC.

#### NDT

Normal device termination (NDT) bit is set when the peripheral device terminates the channel operation by asserting the DONE line while the peripheral device was being acknowledged. The NDT bit is cleared by writing a one to this bit or resetting the DMAC.

#### ERR

Error (ERR) bit is set if any errors have been signaled. When the ERR bit is set, the code corresponding to the kind of the error that occurred is set in the CER. The ERR bit is cleared by writing a one to this bit or resetting the DMAC.

#### ACT

The active (ACT) bit is asserted after the STR bit has been set and the channel operation has started. This bit remains set until the channel operation is terminated. The ACT bit is unaffected by write operations. This bit is cleared by the termination of the channel or resetting the DMAC.

#### DIT

Done input transition (DIT) bit is set if the DONE input is generated while the multiple block transfer mode with DONE is being set. The DIT bit is cleared by writing a one to this bit or resetting the DMAC.



### • Interrupts

The DMAC can signal the termination of the channel operation by generating an interrupt request. The interrupt request is generated by the following condition.

- ① INT=1  
and
  - ② COC=1 or BTC=1 or ERR=1 or NDT=1 or PCT=1  
(the PCL line is an interrupt input)
- This may be represented as
- $$\overline{IRQ} = \overline{INT} \cdot (\overline{COC} + \overline{BTC} + \overline{ERR} + \overline{NDT} + \overline{PCT})$$
- (\*PCL line is programmed as an interrupt input.)

When the  $\overline{IRQ}$  line is asserted, changing the INT bit from one to zero to one will cause the  $\overline{IRQ}$  output to change from "low" to "high" to "low" again. The  $\overline{IRQ}$  should be negated by clearing the COC, the BTC, the ERR, the NDT and the PCT bits.

If the DMAC receives  $\overline{IACK}$  from the MPU during asserting the  $\overline{IRQ}$ , the DMAC provides an interrupt vector. If multiple channels

have interrupt requests, the determination of which channel presents its interrupt vector is made using the same priority scheme defined for the channel operations.

The bus cycle in which the DMAC provides the interrupt vector when receiving an  $\overline{IACK}$  from the MPU is called the interrupt acknowledge cycle. The interrupt vector returned to the MPU comes from either the normal or the error interrupt vector register. The normal interrupt register is used unless the ERR bit of CSR is set, in which case the error interrupt vector register is used. The content of the interrupt vector register is placed on  $A_8/D_0 \sim A_{15}/D_7$ , and DTACK is asserted to indicate that the vector is on the data bus. If a reset occurs, all interrupt vector registers are set to  $(0000111)_2$ , the value of the uninitialized interrupt vector of the HD68000 MPU. The timing of the interrupt acknowledge cycle is shown in Figure 36. The HD68000 MPU outputs the interrupt level into  $A_1/A_3$  and "1" into  $A_4/A_6$  during the interrupt acknowledge cycle, but the HD63450 DMAC ignores these signals.



Figure 37 MPU  $\overline{IACK}$  Cycle to DMAC

### • Multiple Data Block Transfer Operation

When the memory transfer counter (MTC) is exhausted, the channel operation still continues if the channel is set to the array chaining mode or the linked array chaining mode, and the chain is not exhausted. The channel operation also continues if the continue bit (CNT) of the CCR is set. The DMAC provides the initialization of the memory address register and the memory transfer counter in these cases so that the DMAC can transfer the multiple blocks.

### Continued Operation

The continued operation is described in the Initiation and the Control of the Channel Operation section.

### Array Chaining

This type of chaining uses an array in memory consisting of memory addresses and transfer counts. Each entry in the array is six bytes long and consists of four bytes of address followed by two bytes of transfer count. The beginning address of this array is in the base address register, and the number of entries in the array is in the base transfer counter. Before starting any block transfers, the DMAC fetches the entry currently pointed to by the base address register. The address information is placed in the memory address register, and the count information is placed in the memory transfer counter. As each chaining entry is fetched, the base transfer counter is decremented by one. After the chaining entry is fetched, the base address register is incremented



Figure 38 Transfer Example of the Array Chaining Mode

to point the next entry. When the base transfer counter reaches a terminal count of zero, the chain is exhausted, and the entry just fetched determines the last block of the channel operation.

An example of the array chaining mode operation and the memory format for supporting for array chaining is shown in Figure 38. The array must start at an even address, or the entry fetch results in an address error. If a terminal count is loaded into the memory transfer counter or the base transfer counter, the count error is signaled.

#### Linked Array Chaining

This type of chaining uses a list in memory consisting of memory address, transfer counts, and link addresses. Each entry in the chain list is ten bytes long, and consists of four bytes of memory address, two bytes of transfer count and four bytes of link address. The address of the first entry in the list is in the base address register, and the base transfer counter is unused. Before starting any block transfers, the DMAC fetches the entry currently pointed to by the base address register. The address information is placed in the memory address register, the count information is placed in the memory transfer counter, and the link address replaces the current contents of the base address



register. The channel then begins a new block transfer. As each chaining entry is fetched, the update base address register is examined for the terminal link which has all 32 bits equal to zero. When the new base address is the terminal address, the chain is exhausted, and the entry just fetched determines the last block of the channel operation.

An example of the linked array chaining mode operation and the memory format for supporting it is shown in Figure 39.

In Figure 39, the DMAC transfers data blocks in the order of Block A, Block B, and Block C. In the linked array chaining mode, the BTC is not used. When the DMAC refers to the linked array table, the value of the BFC is outputted as the function code. The values of the function code registers are unchanged by the linked array chaining operation.

This type of chaining allows entries to be easily removed or inserted without having to reorganize data within the chain. Since the end of the chain is indicated by a terminal link, the number of entries in the array need not be specified to the

DMAC.

The linked array table must start at an even address in the linked array chaining mode. Starting the table at an odd address results in an address error. If "0" is initially loaded to the MTC, the count error is signaled. Because the MPU can read all of the DMAC registers, all necessary error recovery information is available to the operating system.

The comparison of both chaining modes is shown in Table 8.

Table 8 Chaining Mode Address/Count Information

| Chaining Mode         | Base Address Register             | Base Transfer Counter                   | Completed When        |
|-----------------------|-----------------------------------|-----------------------------------------|-----------------------|
| Array Chaining        | address of the array table        | number of data blocks being transferred | Base Transfer Count=0 |
| Linked Array Chaining | address of the linked array table | (not used)                              | Linked Address=0      |



Figure 39 Transfer Example of the Linked Array Chaining Mode



### Multi-Block Transfer with DONE Mode

The multi-block transfer with DONE mode is set by setting BTD bit of the OCR. In this mode, data block transfer continues even if the DONE signal is inputted during the DMA bus cycle. If DONE is inputted during the DMA bus cycle when the multi-block transfer is not performed, the DMAC resets ACT bit of the CSR, sets NDT and COC bits, and terminates the DMA operation.

When DONE is inputted from the I/O device during the DMA bus cycle in which ACK is outputted, the DMAC terminates the operand transfer and then the current block transfer. Then, maintaining the bus, the DMAC sets DIT bit of the CSR and reads the data block transfer information from the memory. After that, the DMAC transfers the next block as required.

In the continue mode, if DONE is inputted from the I/O device during the DMA bus cycle in which ACK is outputted, the DMAC terminates the operand transfer and terminates the current block transfer. Then the DMAC shifts the data in BAR, BFC and BTC to MAR, MFC and MTC, waits for the transfer request, and transfers the next block. If the value of BAR, BFC and BTC is the same as that of MAR, MFC and MTC, the DMAC repeats transferring the same block.

As stated above, the multi-block transfer with DONE mode realizes termination (stops the current block transfer) and restart (starts transferring the next block) of the multi-block transfer in the high-speed data transfer system without MPU interposition.

### Bus Exception Conditions

The DMAC has three lines for inputting bus exception conditions called BEC<sub>0</sub>, BEC<sub>1</sub>, and BEC<sub>2</sub>. The priority encoder can be used to generate these signals externally. These lines are encoded as shown in Table 9.

Table 9 BEC Bus Exception Condition

| BEC <sub>2</sub> | BEC <sub>1</sub> | BEC <sub>0</sub> | Exception Condition                               |
|------------------|------------------|------------------|---------------------------------------------------|
| 1                | 1                | 1                | No exception condition                            |
| 1                | 1                | 0                | Halt                                              |
| 1                | 0                | 1                | Bus error                                         |
| 1                | 0                | 0                | Retry                                             |
| 0                | 1                | 1                | Relinquish bus and retry<br>(undefined, reserved) |
| 0                | 1                | 0                | (undefined, reserved)                             |
| 0                | 0                | 1                | (undefined, reserved)                             |
| 0                | 0                | 0                | Reset                                             |

In order to guarantee reliable decoding, the DMAC verifies that the incoming code has been stable for two DMAC clock cycles before acting on it. The DMAC picks up BEC<sub>0</sub>, BEC<sub>2</sub> at the rising edge of the clock. If BEC<sub>0</sub>, BEC<sub>2</sub> is asserted to the undefined code, the operation of the DMAC does not proceed. For example, when the DMAC is waiting for DTACK, inputting DTACK does not result in the termination of the cycle if BEC<sub>0</sub>, BEC<sub>2</sub> is asserted to the undefined code. In addition, when the transfer request is received, BR is not output if the BEC<sub>0</sub>, BEC<sub>2</sub> is not set to code (111).

If exception condition, except for HALT, is inputted during the DMA bus cycle prior to, or in coincidence with DTACK, the DMAC terminates the current channel operation immediately. Here coincident means meeting the same set up requirements for the same sampling edge of the clock. BEC<sub>0</sub>, BEC<sub>2</sub> is ignored in the current DMA bus cycle if it is input after DTACK. If a bus exception condition exists, the DMAC does not generate any bus cycles until it is removed. However, the DMAC still recognizes requests.

### Halt

The timing diagram of halt is shown in Figure 40. This diagram shows halt being generated during a read cycle from the 68000 compatible device in the dual addressing mode. If the halt exception is asserted during a DMA bus cycle, the DMAC does not terminate the bus cycle immediately. The DMAC waits for the assertion of DTACK before terminating the bus cycle so that the bus cycle is completed normally. In the halted state, the DMAC puts all the control signals to high impedance and relinquishes the bus to the MPU. The DMAC does not output the BR until halt exception is negated. When halt exception is negated, the DMAC acquires the bus again and proceeds the DMA operation. In order to insure a halt exception operation, the BEC-lines must be set to halt at least until the assertion of DTC.

If the halt is asserted when the DMAC has the bus but is not executing any bus cycle, the DMAC relinquishes the bus as soon as halt exception is asserted.



Figure 40 Halt Operation



**Bus Error**

The bus error exception is generated by external circuitry to indicate the current transfer cannot be successfully completed and is to be aborted. As soon as the DMAC recognizes the bus error exception, the DMAC immediately terminates the bus cycle and proceeds to the error recovery cycle. In this cycle, the DMAC adjusts the values of the MAR, the DAR, the MTC and the BTC to the values when the bus error exception occurred. 24 clocks are required for the error recovery cycle in the single addressing mode and in the read cycle of the dual addressing mode. 28 clocks are required in the write cycle of the dual addressing mode. If the DMAC does not have any transfer request in the other channels after the error recovery cycle, the DMAC relinquishes the bus.

The diagram of the bus error timing is shown in Figure 41.



Figure 41 Bus Error Operation

**Retry**

The retry exception causes the DMAC to terminate the present operation and retry that operation when retry is removed, and



Figure 42 Retry Operation

thus will not honor any requests until it is removed. However, the DMAC still recognizes requests. The retry timing is shown in Figure 42.

**Relinquish and Retry (R & R)**

The relinquish and retry exception causes the DMAC to relinquish the bus and three-state all bus master controls and when the exception is removed, rearbitrate for the bus to retry the previous operation.

The diagram of the relinquish and retry timing is shown in Figure 43.



Figure 43 Relinquish and Retry Operation

**Reset**

The reset provides a means of resetting and initializing the DMAC. If the DMAC is bus master when the reset is asserted, the DMAC relinquishes the bus. Reset clears GCR, DCR, OCR, SCR, CCR, CSR, CPR, and CER for all channels. The NIV and the EIV are all set to  $(OF)_{16}$ , which is the uninitialized interrupt vector number for the HD68000 MPU. MTC, MAR, DAR, BTC, BAR, MFC, DFC, and BFC are not affected (see Table 10).

In order to insure a reset,  $\overline{BEC_0} \sim \overline{BEC_2}$  must be kept at "Low" level for at least ten clocks.

Table 10 The Value after Resetting

| Register | Value                                              | Comments             |
|----------|----------------------------------------------------|----------------------|
| MAR      | $\times \times \times \times \times \times \times$ |                      |
| DAR      | $\times \times \times \times \times \times \times$ |                      |
| BAR      | $\times \times \times \times \times \times \times$ |                      |
| MFC      | X                                                  |                      |
| DFC      | X                                                  |                      |
| BFC      | X                                                  |                      |
| MTC      | $\times \times \times$                             |                      |
| BTC      | $\times \times \times$                             |                      |
| NIV      | 0 F                                                | uninitialized vector |
| EIV      | 0 F                                                | uninitialized vector |
| CPR      | 0 0                                                |                      |
| DCR      | 0 0                                                |                      |
| OCR      | 0 0                                                |                      |
| SCR      | 0 0                                                |                      |
| CCR      | 0 0                                                |                      |
| CSR      | 0 0 or 0 1                                         | depending on PCL     |
| CER      | 0 0                                                |                      |
| GCR      | 0 0                                                |                      |

$\times$ —indefinite value, or the value before resetting

#### • Error Conditions

When an error is signaled on a channel, all activity on that channel is stopped. The ACT bit of the CSR is cleared, and the COC bit is set. The ERR bit of the CSR is set, and the error code is indicated in the CER. All pending operations are cleared, so that both the STR and CNT bits of CCR are cleared.

Enumerated below are the error signals and their sources.

- (a) Configuration Error—This error occurs if the STR bit is set in the following cases.
  - (i) The CNT bit is set at the same time STR bit in the chaining mode.
  - (ii) DTYP specifies a single addressing mode, and the device port size is not the same as the operand size.
  - (iii) DTYP specifies a dual addressing mode, DPS is 16 bits, SIZE is 8 bits and REQG is "10" or "11".
  - (iv) An undefined configuration is set in the registers. The undefined configurations are: XRM=01, MAC=11, DAC=11, CHAIN=01, and SIZE=11. When the port size is 8 bits, SIZE=11 is not an error in the dual addressing mode.
- (b) Operation Timing Error—An operation timing error occurs in the following cases:
  - (i) When the CNT bit is set after the ACT bit has been set by the DMAC in the chaining mode, or when the STR and the ACT bits are not set.
  - (ii) The STR bit is set when ACT, COC, BTC, NDT or ERR is set.
  - (iii) An attempt to write to the DCR, OCR, SCR, MAR, DAR, MTC, MFC, or DFC is made when the STR bit or the ACT bit is set.
  - (iv) An attempt to set the CNT bit is made when the BTC and the ACT bits are set.
- (c) Address Error—An address error occurs in the following cases :

- (i) An odd address is set for word or long word operands.
- (ii) CS or IACK is asserted during the DMA bus cycle.
- (d) Bus Error—Bus error occurs when a bus error exception is signaled during a DMA bus cycle.
- (e) Count Error—A count error occurs in the following cases :
  - (i) The STR bit is set when zero is set in the MTC and the chaining mode is not used.
  - (ii) The STR bit is set when zero is set in BTC for the array chaining mode.
  - (iii) Zero is loaded from memory or the BTC to the MTC in the chaining modes or the continue mode.
- (f) External Abort—External abort occurs if an abort is asserted by the external circuitry when the PCL line is configured as an abort input and the STR or the ACT bit is set.
- (g) Software Abort—Software abort occurs if the SAB bit is set when the STR or the ACT bit is set.

#### Error Recovery Procedures

If an error occurs during a DMA transfer, appropriate information is available to the operating system (OS) to allow a software failure recovery operation. The operating system must be able to determine how much data was transferred, where the data was transferred to, and what type of error occurred.

The information available to the operating system consists of the present value of the Memory Address, Device Address and Base Address Register, the Memory Transfer and Base Transfer Counters, the channel status register, the channel error register. After the successful completion of any transfer, the memory and device address registers point to the location of the next operand to be transferred and the memory transfer counter contains the number of operands yet to be transferred. If an error occurs during a transfer, that transfer has not completed and the registers contain the values they had before the transfer was attempted. If the channel operation uses chaining, the Base Address Register points to the next chain entry to be serviced, unless the termination occurred while attempting to fetch an entry in the chain. In that case, the Base Address Register points to the entry being fetched. However, in the case of external abort, there are cases in which the previous values are not recovered.

#### Bus Exception Operating Flow

The bus exception operating flow in the case of multiple exception conditions occurring continuously in sequence is shown in Figure 44. Note that the DMAC can receive and execute the next exception condition before completing the current exception operation. For example, if the retry exception occurs, and next the relinquish and retry exception occurs while the DMAC is waiting for the retry condition to be cleared, the DMAC relinquishes the bus and waits for the exception condition to be cleared. If a bus error occurs during this period, the DMAC executes the bus error exception operation.

The flow diagram of the normal operation without exception operation or errors is shown in Figure 45.





Figure 44 Bus Exception Flow Diagram



Figure 45 Flow of Normal Operation Without Exception or Error Condition



### ■ CHANNEL PRIORITIES

Each channel has a priority level, which is determined by the contents of the Channel Priority Register (CPR). The priority of a channel is set by writing one of values (00)<sub>2</sub> through (11)<sub>2</sub>, to CPR, (00)<sub>2</sub> being the highest priority level. When multiple requests are pending at the DMAC, the channel with the highest priority receives first service. The priority of a channel is independent of the device protocol or the request mechanism for

that channel. If there are several requesting channels at the same priority level, a round-robin resolution is used, that is the DMAC does operand transfers in rotation starting from the channel of the lowest address.

Resetting the DMAC sets the priority level of all channels to "(00)<sub>2</sub>", the highest priority level.



Figure 46 An Example of the Demultiplexed Address Data Bus

## ■ APPLICATIONS

Examples of how to interface HD63450 to an HD68000 based system are shown in Figures 46 and 47.

Figure 46 shows an example of how to demultiplex the address/data bus. OWN and UAS are used to control 74LS373 for latching the address. DBEN and DDIR are used to control the bi-

directional buffer 74LS245. These signals are three-stated at active low, which requires pull-up resistors.

Figure 47 shows an example of inter-device connection in the HD68000 system. REQ, ACK, PCL, DTC, and DONE are used to control I/O devices.



Figure 47 An Example of Inter-Device Connection in the HD68000 System

### ■ NOTES FOR USING HD63450

#### (1) I/O device connection in HD6800 mode.

When the DMAC is reading data from the HD6800 type peripheral device, the data is to be latched not at the falling edge of E clock but at that of CLK of DTC assertion. As shown in the figure below, the 74LS373 is externally required to keep this data on the bus of the DMAC.

#### (2) External abort during the DONE input cycle

In case of I/O device-to-Memory transfer under the dual addressing mode, the DONE input occurs during the read cycle of I/O device-to-DMAC registers.

The external abort (PCL) is configured as an external abort input.) will be ignored during the write cycle which subsequently starts after the DMAC enters the DONE input cycle.

In this case, the registers CSR and CER indicate the normal transfer termination informed by the DONE input. When PCT = "1", ERR = "0", and NDT = "1" are set in CSR, an external abort has occurred.

#### (3) Multiple errors in one channel

In case of the sequential multiple errors in one channel, the DMAC indicates only the first one. The error code once set in CER is reserved until the ERR bit is reset.

#### (4) Attention for mounting the DMAC

The thick wiring is recommended to be used to connect the V<sub>ss</sub> pin of the DMAC to the ground of the circuit board.

When using a socket, note that the V<sub>ss</sub> pin should make a good contact with the socket.



Figure 48 An Example of Connection with HD6800 type Peripheral Devices  
(channel 2 and 3 are used)



## ■ PACKAGE DIMENSIONS (Unit: mm (inch))

scale: 1/1

## ● DC-64



scale: 1/1

## ● PGA-68



scale: 1/1

## ● DP-64



## ● DP-64S



## ● PLCC-68



\*Inch value indicated for your reference

# HD68450

## Direct Memory Access Controller (NMOS)

Microprocessor implemented systems are becoming increasingly complex, particularly with the advent of high-performance 16-bit MPU devices with large memory addressing capability. In order to maintain high throughput, large blocks of data must be moved within these systems in a quick, efficient manner with minimum intervention by the MPU itself.

The HD68450 Direct Memory Access Controller (DMAC) is designed specifically to complement the performance and architectural capabilities of the HD68000 MPU by providing the following features:

HD68000 Bus Compatible

4 independent DMA Channels

Memory-to-Memory, Memory-to-Device, Device-to-Memory Transfers

MMU Compatible

Array-Chained and Linked-Array-Chained Operations

On-Chip Registers that allow Complete Software Control by the System MPU

Interface Lines for Requesting, Acknowledging, and Incidental Control of the Peripheral Devices

Variable System Bus Bandwidth Utilization

Programmable Channel Prioritization

2 Vectored interrupts for each Channel

Auto-Request and External-Request Transfer Modes

+5 Volt Operation

The DMAC functions by transferring a series of operands (data) between memory and peripheral device; operand sizes can be byte, word, or long word. A block is a sequence of operations; the number of operands in a block is determined by a transfer count. A single-channel operation may involve the transfer of several blocks of data between memory and device.

| Type No.    | Bus Timing | Packaging |
|-------------|------------|-----------|
| HD68450-8   | 8MHz       | DC-64     |
| HD68450-10  | 10MHz      | DC-64     |
| HD68450Y-8  | 8MHz       | PGA-68    |
| HD68450Y-10 | 10MHz      | PGA-68    |



"Y" stands for Pin Grid Array Package.



**HITACHI**

■ PIN ARRANGEMENT  
● HD68450

|                       |   |                                  |
|-----------------------|---|----------------------------------|
| REQ <sub>3</sub> [1]  | ◎ | DDIR                             |
| REQ <sub>2</sub> [1]  |   | DBEN                             |
| REQ <sub>1</sub> [1]  |   | HIBYTE                           |
| REQ <sub>0</sub> [1]  |   | UAS                              |
| PCL <sub>3</sub> [5]  |   | OWN                              |
| PCL <sub>2</sub> [6]  |   | BR                               |
| PCL <sub>1</sub> [7]  |   | BG                               |
| PCL <sub>0</sub> [8]  |   | A <sub>1</sub>                   |
| BGACK[9]              |   | A <sub>2</sub>                   |
| DTC[10]               |   | A <sub>3</sub>                   |
| DTACK[11]             |   | A <sub>4</sub>                   |
| UDS[12]               |   | A <sub>5</sub>                   |
| LDS[13]               |   | A <sub>6</sub>                   |
| AS[14]                |   | VCC                              |
| R/W[15]               |   | A <sub>7</sub>                   |
| V <sub>SS</sub> [16]  |   | V <sub>SS</sub>                  |
| CS[17]                |   | A <sub>8</sub> /D <sub>0</sub>   |
| V <sub>CC</sub> [18]  |   | A <sub>9</sub> /D <sub>1</sub>   |
| CLK[19]               |   | A <sub>10</sub> /D <sub>2</sub>  |
| IACK[20]              |   | A <sub>11</sub> /D <sub>3</sub>  |
| IRQ[21]               |   | A <sub>12</sub> /D <sub>4</sub>  |
| DONE[22]              |   | A <sub>13</sub> /D <sub>5</sub>  |
| ACK <sub>3</sub> [23] |   | A <sub>14</sub> /D <sub>6</sub>  |
| ACK <sub>2</sub> [24] |   | A <sub>15</sub> /D <sub>7</sub>  |
| ACK <sub>1</sub> [25] |   | A <sub>16</sub> /D <sub>8</sub>  |
| ACK <sub>0</sub> [26] |   | A <sub>17</sub> /D <sub>9</sub>  |
| BEC <sub>2</sub> [27] |   | A <sub>18</sub> /D <sub>10</sub> |
| BEC <sub>1</sub> [28] |   | A <sub>19</sub> /D <sub>11</sub> |
| BEC <sub>0</sub> [29] |   | A <sub>20</sub> /D <sub>12</sub> |
| FC <sub>2</sub> [30]  |   | A <sub>21</sub> /D <sub>13</sub> |
| FC <sub>1</sub> [31]  |   | A <sub>22</sub> /D <sub>14</sub> |
| FC <sub>0</sub> [32]  |   | A <sub>23</sub> /D <sub>15</sub> |

(Top View)

## ● HD68450Y



(Bottom View)

| Pin No. | Function                        | Pin No. | Function                         | Pin No. | Function                        | Pin No. | Function                         |
|---------|---------------------------------|---------|----------------------------------|---------|---------------------------------|---------|----------------------------------|
| 1       | N/C                             | 18      | PCL <sub>1</sub>                 | 35      | A <sub>19</sub> /D <sub>1</sub> | 52      | BGACK                            |
| 2       | A <sub>12</sub> /D <sub>5</sub> | 19      | DTACK                            | 36      | A <sub>17</sub> /D <sub>9</sub> | 53      | LDS                              |
| 3       | A <sub>11</sub> /D <sub>4</sub> | 20      | UDS                              | 37      | A <sub>15</sub> /D <sub>7</sub> | 54      | V <sub>SS</sub>                  |
| 4       | A <sub>10</sub> /D <sub>2</sub> | 21      | AS                               | 38      | A <sub>12</sub> /D <sub>1</sub> | 55      | Vcc                              |
| 5       | A <sub>8</sub> /D <sub>0</sub>  | 22      | R/W                              | 39      | A <sub>6</sub> /D <sub>1</sub>  | 56      | DONE                             |
| 6       | A <sub>7</sub>                  | 23      | N/C                              | 40      | V <sub>SS</sub>                 | 57      | IRQ                              |
| 7       | A <sub>6</sub>                  | 24      | CS                               | 41      | Vcc                             | 58      | ACK <sub>2</sub>                 |
| 8       | A <sub>5</sub>                  | 25      | CLK                              | 42      | A <sub>4</sub>                  | 59      | BEC <sub>2</sub>                 |
| 9       | A <sub>3</sub>                  | 26      | IACK                             | 43      | A <sub>2</sub>                  | 60      | BEC <sub>0</sub>                 |
| 10      | N/C                             | 27      | ACK <sub>3</sub>                 | 44      | BG                              | 61      | FC <sub>0</sub>                  |
| 11      | N/C                             | 28      | ACK <sub>2</sub>                 | 45      | OWN                             | 62      | A <sub>21</sub> /D <sub>13</sub> |
| 12      | BR                              | 29      | BEC <sub>1</sub>                 | 46      | HIBYTE                          | 63      | A <sub>18</sub> /D <sub>10</sub> |
| 13      | DBEN                            | 30      | FC <sub>2</sub>                  | 47      | DDIR                            | 64      | A <sub>16</sub> /D <sub>8</sub>  |
| 14      | REQ <sub>3</sub>                | 31      | FC <sub>1</sub>                  | 48      | REQ <sub>1</sub>                | 65      | A <sub>14</sub> /D <sub>6</sub>  |
| 15      | REQ <sub>2</sub>                | 32      | A <sub>23</sub> /D <sub>15</sub> | 49      | PCL <sub>2</sub>                | 66      | A <sub>1</sub>                   |
| 16      | REQ <sub>0</sub>                | 33      | A <sub>22</sub> /D <sub>14</sub> | 50      | PCL <sub>0</sub>                | 67      | DTC                              |
| 17      | PCL <sub>3</sub>                | 34      | A <sub>20</sub> /D <sub>12</sub> | 51      | N/C                             | 68      | ACK <sub>0</sub>                 |



**■ ABSOLUTE MAXIMUM RATINGS**

| Item                        | Symbol            | Value       | Unit |
|-----------------------------|-------------------|-------------|------|
| Supply Voltage              | V <sub>CC</sub> * | -0.3 ~ +7.0 | V    |
| Input Voltage               | V <sub>in</sub> * | -0.3 ~ +7.0 | V    |
| Operating Temperature Range | T <sub>opr</sub>  | 0 ~ +70     | °C   |
| Storage Temperature         | T <sub>stg</sub>  | -55 ~ +150  | °C   |

\* With respect to V<sub>SS</sub> (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        | V <sub>CC</sub> * | 4.75 | 5.0 | 5.25            | V    |
| Input Voltage         | V <sub>IH</sub> * | 2.0  | —   | V <sub>CC</sub> | V    |
|                       | V <sub>IL</sub> * | -0.3 | —   | 0.8             | V    |
| Operating Temperature | T <sub>opr</sub>  | 0    | 25  | 70              | °C   |

\* With respect to V<sub>SS</sub> (SYSTEM GND)

**■ ELECTRICAL CHARACTERISTICS**

**● DC CHARACTERISTICS (V<sub>CC</sub> = 5V ± 5%, V<sub>SS</sub> = 0V, T<sub>a</sub> = 0 ~ +70°C, unless otherwise noted.)**

| Item                                  | Symbol                                                                                                                                                                                                                                                                                       | Test Condition                                              | min                       | typ | max             | Unit |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------|-----|-----------------|------|
| Input "High" Voltage                  | V <sub>IH</sub>                                                                                                                                                                                                                                                                              |                                                             | 2.0                       | —   | V <sub>CC</sub> | V    |
| Input "Low" Voltage                   | V <sub>IL</sub>                                                                                                                                                                                                                                                                              |                                                             | V <sub>SS</sub> - 0.3     | —   | 0.8             | V    |
| Input Leakage Current                 | I <sub>in</sub>                                                                                                                                                                                                                                                                              |                                                             | —                         | —   | 10              | μA   |
| Three-State (Off State) Input Current | A <sub>1</sub> ~ A <sub>7</sub> , D <sub>0</sub> ~ D <sub>15</sub> /A <sub>8</sub> ~ A <sub>23</sub> , AS, UDS, LDS, R/W, UAS, DTACK, BGACK, OWN, DTC, HIBYTE, DDIR, DBEN, FC <sub>0</sub> ~ FC <sub>2</sub>                                                                                 | I <sub>TSI</sub>                                            | —                         | —   | 10              | μA   |
| Open Drain (Off State) Input Current  | I <sub>RDQ</sub> , DONE                                                                                                                                                                                                                                                                      | I <sub>ODI</sub>                                            | —                         | —   | 20              | μA   |
| Output "High" Voltage                 | A <sub>1</sub> ~ A <sub>7</sub> , D <sub>0</sub> ~ D <sub>15</sub> /A <sub>8</sub> ~ A <sub>23</sub> , AS, UDS, LDS, R/W, UAS, DTACK, BGACK, BR, OWN, DTC, HIBYTE, DDIR, DBEN, ACK <sub>0</sub> ~ ACK <sub>3</sub> , PCL <sub>0</sub> ~ PCL <sub>3</sub> , FC <sub>0</sub> ~ FC <sub>2</sub> | V <sub>OH</sub>                                             | I <sub>OH</sub> = -400 μA | 2.4 | —               | V    |
| Output "Low" Voltage                  | A <sub>1</sub> ~ A <sub>7</sub> , FC <sub>0</sub> ~ FC <sub>2</sub>                                                                                                                                                                                                                          | V <sub>OL</sub>                                             | I <sub>OL</sub> = 3.2 mA  | —   | —               | 0.5  |
|                                       | D <sub>0</sub> ~ D <sub>15</sub> /A <sub>8</sub> ~ A <sub>23</sub> , AS, UDS, LDS, R/W, DTACK, BR, OWN, DTC, HIBYTE, DDIR, DBEN, ACK <sub>0</sub> ~ ACK <sub>3</sub> , UAS, PCL <sub>0</sub> ~ PCL <sub>3</sub> , BGACK                                                                      | V <sub>OL</sub>                                             | I <sub>OL</sub> = 5.3 mA  | —   | —               | 0.5  |
|                                       | I <sub>RDQ</sub> , DONE                                                                                                                                                                                                                                                                      | V <sub>OL</sub>                                             | I <sub>OL</sub> = 8.9 mA  | —   | —               | 0.5  |
| Power Dissipation                     | P <sub>D</sub>                                                                                                                                                                                                                                                                               | f = 8 MHz, V <sub>CC</sub> = 5.0 V<br>T <sub>a</sub> = 25°C | —                         | 1.4 | 2.0             | W    |
| Capacitance                           | C <sub>in</sub>                                                                                                                                                                                                                                                                              | V <sub>in</sub> = 0V,<br>T <sub>a</sub> = 25°C, f = 1 MHz   | —                         | —   | 15              | pF   |





Figure 1 Test Loads

• AC ELECTRICAL SPECIFICATIONS ( $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = 0\sim+70^\circ C$ )

| No  | Item                                              | Symbol               | Test Condition | 8MHz<br>HD68450-8<br>HD68450V-B |     | 10MHz<br>HD68450-10<br>HD68450V-10 |     | Unit    |
|-----|---------------------------------------------------|----------------------|----------------|---------------------------------|-----|------------------------------------|-----|---------|
|     |                                                   |                      |                | min                             | max | min                                | max |         |
| 1   | Frequency of Operation                            | f                    |                | 2                               | 8   | 2                                  | 10  | MHz     |
| 2   | Clock Period                                      | t <sub>cyc</sub>     |                | 126                             | 500 | 100                                | 500 | ns      |
| 3   | Clock Width Low                                   | t <sub>CL</sub>      |                | 55                              | 250 | 45                                 | 250 | ns      |
| 4   | Clock Width High                                  | t <sub>CH</sub>      |                | 55                              | 250 | 45                                 | 250 | ns      |
| 5   | Clock Fall Time                                   | t <sub>CF</sub>      |                | —                               | 10  | —                                  | 10  | ns      |
| 6   | Clock Rise Time                                   | t <sub>CR</sub>      |                | —                               | 10  | —                                  | 10  | ns      |
| 7   | Asynchronous Input Setup Time                     | t <sub>ASI</sub>     |                | 20                              | —   | 15                                 | —   | ns      |
| 8   | Data in to DBEN Low                               | t <sub>IDBL</sub>    |                | 0                               | —   | 0                                  | —   | ns      |
| 9   | DTACK Low to Data Invalid                         | t <sub>DTLDI</sub>   |                | 0                               | —   | 0                                  | —   | ns      |
| 10  | Address in to AS in Low                           | t <sub>AIASL</sub>   |                | 0                               | —   | 0                                  | —   | ns      |
| 10A | AS, DS in High to Address in Invalid              | t <sub>SIHAI</sub>   |                | 0                               | —   | 0                                  | —   | ns      |
| 11  | DS in High to CS High                             | t <sub>DSCHSH</sub>  |                | —                               | 1.0 | —                                  | 1.0 | clk per |
| 12  | Clock High to DDR Low                             | t <sub>CHDRL</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 13  | Clock High to DDR High                            | t <sub>CHDRH</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 14  | DS in High to DDR High Impedance                  | t <sub>DSHDRZ</sub>  |                | —                               | 120 | —                                  | 110 | ns      |
| 15  | Clock Low to DBEN Low                             | t <sub>CLDBL</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 16  | Clock Low to DBEN High                            | t <sub>CLDBH</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 17  | DS in High to DBEN High Impedance                 | t <sub>DSHDBZ</sub>  |                | —                               | 120 | —                                  | 110 | ns      |
| 18  | Clock High to Data Out Valid (MPU read)           | t <sub>CHDVM</sub>   |                | —                               | 180 | —                                  | 160 | ns      |
| 19  | DS in High to Data Out Invalid                    | t <sub>DSHDZn</sub>  |                | 0                               | —   | 0                                  | —   | ns      |
| 20  | DS in High to Data High Impedance                 | t <sub>DSHDZ</sub>   |                | —                               | 120 | —                                  | 110 | ns      |
| 21  | Clock Low to DTACK Low                            | t <sub>CLDTL</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 22  | DTACK Low to DTACK High                           | t <sub>DSHDTH</sub>  |                | —                               | 110 | —                                  | 110 | ns      |
| 23  | DTACK Width High                                  | t <sub>DTH</sub>     |                | 10                              | —   | 10                                 | —   | ns      |
| 24  | DS in High to DTACK High Impedance                | t <sub>DSHTDZ</sub>  |                | —                               | 180 | —                                  | 160 | ns      |
| 25  | DTACK Low to DS in High                           | t <sub>DTLDH</sub>   |                | 0                               | —   | 0                                  | —   | ns      |
| 26  | REQ Width Low                                     | t <sub>REQL</sub>    |                | 2.0                             | —   | 2.0                                | —   | clk per |
| 27  | REQ Low to BR Low                                 | t <sub>REQLBL</sub>  |                | 250                             | —   | 200                                | —   | ns      |
| 28  | Clock High to BR Low                              | t <sub>CHBRL</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 29  | Clock High to BR High                             | t <sub>CHBRH</sub>   |                | —                               | 70  | —                                  | 60  | ns      |
| 30  | BR Low to BGACK Low                               | t <sub>BGLBL</sub>   |                | 4.5                             | —   | 4.5                                | —   | clk per |
| 31  | BR Low to MPU Cycle End (AS in High) to BGACK Low | t <sub>BRFLASH</sub> |                | 0                               | —   | 0                                  | —   | ns      |
| 32  | MPU Cycle End (AS in High) to BGACK Low           | t <sub>ASHBL</sub>   |                | 4.5                             | 5.5 | 4.5                                | 5.5 | clk per |
| 33  | REQ Low to BGACK Low                              | t <sub>REQLBL</sub>  |                | 12.0                            | —   | 12.0                               | —   | clk per |
| 34  | Clock High to BGACK High                          | t <sub>CHBL</sub>    |                | —                               | 70  | —                                  | 60  | ns      |
| 35  | Clock High to BGACK High                          | t <sub>CHBH</sub>    |                | —                               | 70  | —                                  | 60  | ns      |
| 36  | Clock Low to BGACK High Impedance                 | t <sub>CLBZ</sub>    |                | —                               | 80  | —                                  | 70  | ns      |
| 37  | Clock High to FC Valid                            | t <sub>CHFCV</sub>   |                | —                               | 100 | —                                  | 90  | ns      |
| 38  | Clock High to Address/FC/Data High Impedance      | t <sub>CHAZx</sub>   |                | —                               | 120 | —                                  | 110 | ns      |
| 39  | Clock High to Address/FC/Data Invalid             | t <sub>CHAZn</sub>   |                | —                               | 100 | —                                  | 100 | ns      |
| 40  | Clock Low to Address High Impedance               | t <sub>CLAZ</sub>    |                | 0                               | —   | 0                                  | —   | ns      |
| 41  | Clock High to UAS Low                             | t <sub>CHUL</sub>    |                | —                               | 100 | —                                  | 90  | ns      |
| 42  | Clock High to UAS High                            | t <sub>CHUH</sub>    |                | —                               | 70  | —                                  | 60  | ns      |
| 43  | Clock Low to UAS High Impedance                   | t <sub>CLUZ</sub>    |                | —                               | 80  | —                                  | 70  | ns      |
| 44  | UAS High to Address Invalid                       | t <sub>UHAI</sub>    |                | 30                              | —   | 20                                 | —   | ns      |
| 45  | Clock High to AS, DS Low                          | t <sub>CHSL</sub>    |                | —                               | 60  | —                                  | 55  | ns      |
| 46  | Clock Low to DS Low (write)                       | t <sub>CLDSL</sub>   |                | —                               | 60  | —                                  | 55  | ns      |
| 47  | Clock Low to AS, DS High                          | t <sub>CLSH</sub>    |                | —                               | 70  | —                                  | 60  | ns      |
| 48  | Clock Low to AS, DS High Impedance                | t <sub>CLSZ</sub>    |                | —                               | 80  | —                                  | 70  | ns      |
| 49  | AS Width Low                                      | t <sub>ASL</sub>     |                | 255                             | —   | 195                                | —   | ns      |
| 50  | DS Width Low                                      | t <sub>DSL</sub>     |                | 190                             | —   | 145                                | —   | ns      |
| 51  | AS, DS Width High                                 | t <sub>SH</sub>      |                | 150                             | —   | 105                                | —   | ns      |
| 52  | Address/FC Valid to AS, DS Low                    | t <sub>AVSL</sub>    |                | 30                              | —   | 20                                 | —   | ns      |
| 53  | AS, DS High to Address/FC/Data Invalid            | t <sub>SHAZ</sub>    |                | 30                              | —   | 20                                 | —   | ns      |
| 54  | Clock High to R/W Low                             | t <sub>CHRL</sub>    |                | —                               | 70  | —                                  | 60  | ns      |
| 55  | Clock High to R/W High                            | t <sub>CHRH</sub>    |                | —                               | 70  | —                                  | 60  | ns      |

Fig. 1 ~  
Fig. 8

(to be continued)



| No  | Item                                    | Symbol  | Test Condition | 8MHz                    |     | 10MHz                     |     | Unit    |  |
|-----|-----------------------------------------|---------|----------------|-------------------------|-----|---------------------------|-----|---------|--|
|     |                                         |         |                | HD68450-8<br>HD68450V 8 |     | HD68450-10<br>HD68450V 10 |     |         |  |
|     |                                         |         |                | min                     | max | min                       | max |         |  |
| 56  | Clock Low to R/W High Impedance         | tCLRZ   |                | —                       | 80  | —                         | 70  | ns      |  |
| 57  | Address/FC Valid to R/W Low             | tAVRL   |                | 20                      | —   | 10                        | —   | ns      |  |
| 58  | R/W Low to DS Low (write)               | tRLSL   |                | 120                     | —   | 90                        | —   | ns      |  |
| 59  | DS High to R/W High                     | tSHRH   |                | 40                      | —   | 20                        | —   | ns      |  |
| 60  | Clock Low to OWN Low                    | tCOLL   |                | —                       | 70  | —                         | 60  | ns      |  |
| 61  | Clock Low to OWN High                   | tCLOH   |                | —                       | 70  | —                         | 60  | ns      |  |
| 62  | Clock High to OWN High Impedance        | tCHOZ   |                | —                       | 80  | —                         | 70  | ns      |  |
| 63  | OWN Low to BGACK Low                    | tOLBL   |                | 30                      | —   | 20                        | —   | ns      |  |
| 64  | BGACK High to OWN High                  | tBHOH   |                | 30                      | —   | 20                        | —   | ns      |  |
| 65  | OWN Low to UAS Low                      | tOLUL   |                | 30                      | —   | 20                        | —   | ns      |  |
| 66  | Clock High to ACK Low                   | tCHACL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 67  | Clock Low to ACK Low                    | tCLACL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 68  | Clock High to ACK High                  | tCHACH  |                | —                       | 70  | —                         | 60  | ns      |  |
| 69  | ACK Low to DS Low                       | tACLDLS |                | 100                     | —   | 80                        | —   | ns      |  |
| 70  | DS High to ACK High                     | tDSHACH |                | 30                      | —   | 20                        | —   | ns      |  |
| 71  | Clock High to HIBYTE Low                | tCHHIL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 72  | Clock Low to HIBYTE Low                 | tCLHIL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 73  | Clock High to HIBYTE High               | tCHHHI  |                | —                       | 70  | —                         | 60  | ns      |  |
| 74  | Clock Low to HIBYTE High Impedance      | tCLHIZ  |                | —                       | 80  | —                         | 70  | ns      |  |
| 75  | Clock High to DTC Low                   | tCHDTL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 76  | Clock High to DTC High                  | tCHDTH  |                | —                       | 70  | —                         | 60  | ns      |  |
| 77  | Clock Low to DTC High Impedance         | tCLDTZ  |                | —                       | 80  | —                         | 70  | ns      |  |
| 78  | DTC Width Low                           | tDTCL   |                | 105                     | —   | 80                        | —   | ns      |  |
| 79  | DTC Low to DS High                      | tDTLDH  |                | 30                      | —   | 20                        | —   | ns      |  |
| 80  | Clock High to DONE Low                  | tCHDOL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 81  | Clock Low to DONE Low                   | tCLDOL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 82  | Clock High to DONE High                 | tCHDOH  |                | —                       | 130 | —                         | 120 | ns      |  |
| 83  | Clock Low to DDIR High Impedance        | tCLDRZ  |                | —                       | 80  | —                         | 70  | ns      |  |
| 84  | Clock Low to DBEN High Impedance        | tCLDBZ  |                | —                       | 80  | —                         | 70  | ns      |  |
| 85  | DDIR Low to DBEN Low                    | tDLRDBL |                | 30                      | —   | 20                        | —   | ns      |  |
| 86  | DBEN High to DDIR High                  | tDBHORH |                | 30                      | —   | 20                        | —   | ns      |  |
| 87  | DBEN Low to Address/Data High Impedance | tDBLAZ  |                | —                       | 17  | —                         | 17  | ns      |  |
| 88  | Clock Low to PCL Low (1/8 clock)        | tCLPL   |                | —                       | 70  | —                         | 60  | ns      |  |
| 89  | Clock Low to PCL High (1/8 clock)       | tCLPH   |                | —                       | 70  | —                         | 60  | ns      |  |
| 90  | PCL Width Low (1/8 clock)               | tPCLL   |                | 4.0                     | —   | 4.0                       | —   | clk per |  |
| 91  | DTACK Low to Data In (setup time)       | tDALDI  |                | —                       | 150 | —                         | 115 | ns      |  |
| 92  | DS High to Data Invalid (hold time)     | tSHDI   |                | 0                       | —   | 0                         | —   | ns      |  |
| 93  | DS High to DTACK High                   | tSHDAH  |                | 0                       | 120 | 0                         | 90  | ns      |  |
| 94  | Data Out Valid to DS Low                | tDOSL   |                | 0                       | —   | 0                         | —   | ns      |  |
| 95  | Data In to Clock Low (setup time)       | tDICL   |                | 15                      | —   | 15                        | —   | ns      |  |
| 96  | BEC Low to DTACK Low                    | tBEDCAL |                | 50                      | —   | 50                        | —   | ns      |  |
| 97  | BEC Width Low                           | tBECL   |                | 2.0                     | —   | 2.0                       | —   | clk per |  |
| 98  | Clock High to IRQ Low                   | tCHIRL  |                | —                       | 70  | —                         | 60  | ns      |  |
| 99  | Clock High to IRQ High                  | tCHIRH  |                | —                       | 130 | —                         | 120 | ns      |  |
| 100 | READY In to DTC Low (Read)              | tRALDTL |                | 145                     | —   | 120                       | —   | ns      |  |
| 101 | READY In to DS Low (Write)              | tRALDSL |                | 205                     | —   | 170                       | —   | ns      |  |
| 102 | DS High to READY High                   | tDSHRAH |                | 0                       | 120 | 0                         | 90  | ns      |  |
| 103 | DONE In Low to DTACK Low                | tDOLDAL |                | 50                      | —   | 50                        | —   | ns      |  |
| 104 | DS High to DONE In High                 | tDSHDOH |                | 0                       | 120 | 0                         | 90  | ns      |  |
| 105 | Asynchronous Input Hold Time            | tASIH   |                | 15                      | —   | 15                        | —   | ns      |  |

Fig 1 ~  
Fig 8

Figure 2 Input Clock Waveform





Figure 3 AC Electrical Waveforms – MPU Read/Write



Figure 4 AC Electrical Waveforms – Bus Arbitration





\* DTACK is picked up at the rising edge of CLK. This is different from HD68000.

\*\* This timing is not related to DMA Read/Write (Single Cycle) sequence

Figure 5 AC Electrical Waveforms – DMA Read/Write (Single Cycle)





\* Data are latched at the end of clock 7. This timing is the same as HD68000

\*\* This timing is not related to DMA Read/Write (Dual Cycle) sequence. This timing is only applicable when 1/8 clock pulse mode is selected

\*\*\* This timing is applicable when a bus exception occurs

\*\*\*\* If #6 is satisfied for both DTACK and BEC, #96 may be Ons

\*\*\*\*\* If the propagation delay of the external bidirectional buffer LS245 is less than 17nsec, the conflict may occur between the address output of the DMAC and the system data bus. In this case, the output of DBEN must be delayed externally

Figure 6 AC Electrical Waveforms — DMA Read/Write (Dual Cycle)





Figure 7 AC Electrical Waveforms – DMA Read/Write (Single Cycle with PCL)

Figure 8 AC Electrical Waveforms –  $\overline{\text{DONE}}$  Input

(NOTES for Figure 3 through 8)

- 1) Setup time for the asynchronous inputs  $\overline{\text{BG}}$ ,  $\overline{\text{BGACK}}$ ,  $\overline{\text{CS}}$ ,  $\overline{\text{IACK}}$ ,  $\overline{\text{AS}}$ ,  $\overline{\text{UDS}}$ ,  $\overline{\text{LDS}}$ , and  $\overline{\text{R/W}}$  guarantees their recognition at the next falling edge of the clock. Setup time for  $\overline{\text{BEC}_0} \sim \overline{\text{BEC}}_2$ ,  $\overline{\text{REQ}_0} \sim \overline{\text{REQ}}_3$ ,  $\overline{\text{PCL}_0} \sim \overline{\text{PCL}}_3$ ,  $\overline{\text{DTACK}}$ , and  $\overline{\text{DONE}}$  guarantees their recognition at the next rising edge of the clock
- 2) Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts
- 3) 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



### ■ SIGNAL DESCRIPTION

The following section identifies the signals used in the DMAC. In the definitions, "MPU mode" refers to the state when the DMAC is chip selected by MPU. The term "DMA mode" refers to the state when the DMAC assumes ownership of the bus. The DMAC is in the "IDLE mode" at all other times. Moreover, the DMA bus cycle refers to the bus cycle that is executed by the DMAC in the "DMA mode".

NOTE) In this data sheet, the state of the signals is described with these words: active or assert, inactive or negate.

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.



Figure 9 Input and Output Signals

### • Address/Data Bus (A<sub>8</sub>/D<sub>0</sub> through A<sub>23</sub>/D<sub>15</sub>)

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active-high  |                |

These lines are time multiplexed for address and data bus. The lines DDIR, DBEN, UAS and OWN are used to control the demultiplexing of the data and address lines externally. Demultiplexing is explained in the later section. The bi-directional data bus is used to transfer data between DMAC, MPU, memory and I/O devices.

Address lines are outputs to address memory and I/O devices.

### • Address Bus (A<sub>1</sub> through A<sub>7</sub>)

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active-high  |                |

In the MPU mode, the DMAC internal registers are accessed with these lines and LDS, UDS. The address map for these registers is shown in Table 1. During a DMA bus cycle, A<sub>1</sub>-A<sub>7</sub> are outputs containing the low order address bits of the location being accessed.

### • Function Code (FC<sub>0</sub> through FC<sub>2</sub>)

|             |                |
|-------------|----------------|
| Output      | Three-statable |
| Active-high |                |

These output signals provide the function codes during DMA bus cycles. They are three-stated except in the DMA bus cycles. They are used to control the HD68000 memories. [See Attention on Usage, Note (6)]

### • Clock (CLK)

|       |
|-------|
| Input |
|-------|

This is the input clock to the HD68450, and should never be terminated at any time. This clock can be different from the MPU clock since HD68450 operates completely asynchronously.

### • Chip Select (CS)

|            |
|------------|
| Input      |
| Active low |

This input signal is used to chip select the DMAC in "MPU" mode. If the CS input is asserted during a bus cycle which is generated by the DMAC, the DMAC internally terminates the bus cycle and signals an address error. This function protects the DMAC from accessing its own register. [See Attention on Usage, Note (5).]

### • Address Strobe (AS)

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active low   |                |

In the "MPU mode", this line is an input indicating valid address input, and during the DMA bus cycle it is an output indicating valid the address output from the DMAC on the address bus.

The DMAC monitors these input lines during bus arbitration to determine the completion of the bus cycle by the MPU or other bus masters.

### • Upper Address Strobe (UAS)

|            |                |
|------------|----------------|
| Output     | Three-statable |
| Active low |                |

This line is an output to latch the upper address lines on the multiplexed data/address lines. It is three-stated except in the "DMA mode".

### • Own (OWN)

|            |                |
|------------|----------------|
| Output     | Three-statable |
| Active low |                |

This line is asserted by the DMAC during DMA mode, and is used to control the output of the address line latch. This line may also be used to control the direction of bi-directional buffers when loads on AS, LDS, UDS, R/W and other signals exceed the drive capability. It is three-stated in the "MPU mode" and the "IDLE mode".

- **Data Direction (DDIR)**

|                                                               |                |
|---------------------------------------------------------------|----------------|
| Outputs                                                       | Three-statable |
| Active low (when data direction is input to the DMAC)         |                |
| Active high (when the data direction is output from the DMAC) |                |

This line controls the direction of data through the bidirectional buffer which is used to demultiplex the data/address lines. It is three-stated during the "IDLE mode".

- **Data Bus Enable (DBEN)**

|            |                |
|------------|----------------|
| Output     | Three-statable |
| Active low |                |

This line controls the output enable line of bidirectional buffers on the multiplexed data/address lines. It is a three-stated during the "IDLE mode".

- **High Byte (HIBYTE)**

|            |                |
|------------|----------------|
| Output     | Three-statable |
| Active low |                |

This line is used when the operand size is byte in the single addressing mode. It is asserted when data is present on the upper eight bits of the data bus. It is used to control the output of bidirectional buffers which connects the upper eight bits of the data bus with the lower eight bits. It is three-stated during the "MPU mode" and the "IDLE mode".

- **Read/Write (R/W)**

|                    |                |
|--------------------|----------------|
| Input/Output       | Three-statable |
| Active low (write) |                |
| Active high (read) |                |

This line is an input in the "MPU mode" and an output during the "DMA mode". It is three-stated during the "IDLE mode". It is used to control the direction of data flow.

- **Upper Data Strobe (UDS), Lower Data Strobe (LDS)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active low   |                |

These lines are extensions of the address lines indicating which byte or bytes of data of the addressed word are being addressed. These lines combined corresponds to address line A<sub>0</sub> in table 1.

- **Data Transfer Acknowledge (DTACK)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active low   |                |

In the "MPU mode", this line is an output indicating the completion of Read/Write bus cycle by the MPU.

In the "DMA mode", the DMAC monitors this line to determine when a data transfer has completed. In the event that a bus exception is requested, except for HALT, prior to or concurrent with DTACK, the DTACK response is ignored and the bus exception is honored. In the "IDLE mode", this signal is three-stated.

- **Bus Exception Controls (BEC<sub>0</sub> through BEC<sub>2</sub>)**

|            |
|------------|
| Input      |
| Active low |

These lines provide an encoded signal input indicating an exceptional condition in the DMA bus cycle. See bus exception section for details.

- **Bus Request (BR)**

|            |
|------------|
| Output     |
| Active low |

This output line is used to request ownership of the bus by the DMAC. [See Attention on Usage, Notes (8), (9) ]

- **Bus Grant (BG)**

|            |
|------------|
| Input      |
| Active low |

This line is used to indicate to the DMAC that it is to be the next bus master. The DMAC cannot assume bus ownership until both AS and BGACK becomes inactive. Once the DMAC acquires the bus, it does not continue to monitor the BG input.

- **Bus Grant Acknowledge (BGACK)**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active low   |                |

Bus Grant Acknowledge (BGACK) is a bidirectional control line. As an output, it is generated by the DMAC to indicate that it is the bus master.

As an input, BGACK is monitored by the DMAC, in limited rate auto-request mode, to determine whether or not the current bus master is a DMA device or not. BGACK is also monitored during bus arbitration in order to assume bus ownership [See Attention on Usage, Notes (8), (9) ]

- **Interrupt Request (IRQ)**

|            |            |
|------------|------------|
| Output     | Open drain |
| Active low |            |

This line is used to request an interrupt to the MPU.

- **Interrupt Acknowledge (IACK)**

|            |
|------------|
| Input      |
| Active low |

This line is an input to the DMAC indicating that the current bus cycle is an interrupt acknowledge cycle by the MPU. The



DMAC responds the interrupt vector of the channel with the highest priority requesting an interrupt. There are two kinds of the interrupt vectors for each channel: normal (NIV) or error (EIV).  $\overline{IACK}$  is not serviced if the DMAC has not generated IRQ.

- **Channel Request ( $\overline{REQ}_0$  through  $\overline{REQ}_3$ )**

|                            |
|----------------------------|
| Input                      |
| Active low or falling edge |

These lines are the DMA transfer request inputs from the peripheral devices

These lines are falling edge sensitive inputs when the request mode is cycle steal. They are low-level sensitive when the request mode is burst.

- **Channel Acknowledge ( $\overline{ACK}_0$  through  $\overline{ACK}_3$ )**

|            |
|------------|
| Output     |
| Active low |

These lines indicate to the I/O device requesting a transfer that the request is acknowledged and the transfer is to be performed. These lines may be used as a part of the enable circuit for bus interface to the peripheral.

- **Peripheral Control Line ( $\overline{PCL}_0$  through  $\overline{PCL}_3$ )**

|              |                |
|--------------|----------------|
| Input/Output | Three-statable |
| Active low   |                |

The four lines ( $\overline{PCL}_0$  ~  $\overline{PCL}_3$ ) are multi-purpose lines which may be individually programmed to be a START output, an Enable Clock input, a READY input, an ABORT input, a STATUS input, or an INTERRUPT input. [See *Attention on Usage, Note (2)*.]

- **Done ( $\overline{DONE}$ )**

|              |            |
|--------------|------------|
| Input/Output | Open Drain |
| Active low   |            |

As an output, this line is asserted concurrently with the  $\overline{ACK}_X$  timing to indicate the last data transfer to the peripheral device. As an input, it allows the peripheral device to request a normal termination of the DMA transfer. [See *Attention on Usage, Note (2)*.]

- **Device Transfer Complete ( $\overline{DTC}$ )**

|            |                |
|------------|----------------|
| Output     | Three-statable |
| Active low |                |

This line is asserted when the DMA bus cycle has terminated normally with no exceptions. It may be used to supply the data latch timing to the peripheral device. In this case, data is valid at the falling edge of  $\overline{DTC}$ .

## INTERNAL ORGANIZATION

The DMAC has four independent DMA channels. Each channel has its own set of channel registers. These registers define and control the activity of the DMAC in processing a channel operation.



Figure 10 Internal Registers

- **Register Organization**

The internal register addresses are represented in Table 1. Address space not used within the address map is reserved for future expansion. A read from an unused location in the map results in a normal bus cycle with all ones for data. A write to one of these locations results in a normal bus cycle but no write occurs.

Unused bits of the defined registers in Table 1 read as zeros

Table 1 Internal Register Addressing Assignments

| Register                   | Address Bits      | Mode*   |
|----------------------------|-------------------|---------|
| Channel Status Register    | 7 6 5 4 3 2 1 0   | R W*    |
| Channel Error Register     | c c 0 0 0 0 0 0   | 1 R     |
| Device Control Register    | c c 0 0 0 0 1 0   | 0 R W   |
| Operation Control Register | c c 0 0 0 0 1 0   | 0 1 R W |
| Sequence Control Register  | c c 0 0 0 0 1 1   | 1 0 R W |
| Channel Control Register   | c c 0 0 0 0 1 1   | 1 1 R W |
| Memory Transfer Counter    | c c 0 0 0 1 0 1   | b R W   |
| Memory Address Register    | c c 0 0 1 1 1 s s | R W     |
| Device Address Register    | c c 0 1 0 1 0 1 s | R W     |
| Base Transfer Counter      | c c 0 1 1 1 0 1 b | R W     |
| Base Address Register      | c c 0 1 1 1 1 s s | R W     |
| Normal Interrupt Vector    | c c 1 0 0 0 1 1   | 1 R W   |
| Error Interrupt Vector     | c c 1 0 0 0 1 1   | 1 R W   |
| Channel Priority Register  | c c 1 0 1 0 1 0   | 0 1 R W |
| Memory Function Codes      | c c 1 0 1 0 0 0   | 0 1 R W |
| Device Function Codes      | c c 1 1 1 0 0 0   | 0 1 R W |
| Base Function Codes        | c c 1 1 1 1 0 0   | 1 R W   |
| General Control Register   | 1 1 1 1 1 1 1 1   | R W     |

cc 00-Channel #0,01-Channel #1,  
10-Channel #2,11-Channel #3,  
ss 00-high-order, 01-upper middle,  
10-lower middle,11-low-order  
b 0-high-order, 1-low-order  
\* see Channel Status Register Section

- **Device Control Register (DCR)**

The DCR is a device oriented control register. The XRM bits specifies whether the channel is in burst or cycle steal request mode. The DTYP bits define what type of device is on the channel. If the DTYP bits are programmed to be a HD6800 device, the PCL definition is ignored and the PCL line is an Enable clock input. If the DTYP bits are programmed to be a device with READY, the PCL definition is ignored and the PCL line is a READY input. The DPS bit defines the port size (eight or sixteen bits) of peripheral device. (A port size is the largest data which the peripheral device can transfer during a DMA bus cycle.) The PCL bits define the function of the PCL line. If the DTYP bits are programmed to be HD6800 device, or Device with ACK and READY, these definitions are ignored. The XRM bits are ignored if an auto-request mode (REQG =

00 or 01 in Operation Control Register) is selected

| 7   | 6    | 5   | 4 | 3   | 2 | 1 | 0 |
|-----|------|-----|---|-----|---|---|---|
| XRM | DTYP | DPS | 0 | PCL |   |   |   |

#### XRM (EXTERNAL REQUEST MODE)

- 00 Burst Transfer Mode
  - 01 (undefined, reserved)
  - 10 Cycle Steal Mode without Hold
  - 11 Cycle Steal Mode with Hold
- #### DTYP (DEVICE TYPE)
- 00 HD68000 compatible device, explicitly addressed (dual addressing mode)
  - 01 HD6800 compatible device, explicitly addressed (dual addressing mode)
  - 10 Device with ACK, implicitly addressed (single addressing mode)
  - 11 Device with ACK and READY, implicitly addressed (single addressing mode)
- #### DPS (DEVICE PORT SIZE)
- 0 8 bit port
  - 1 16 bit port
- #### PCL (PERIPHERAL CONTROL LINE)
- 00 Status Input
  - 01 Status Input with Interrupt
  - 10 Start Pulse
  - 11 Abort Input
- Bit 2 Not Used

#### • Operation Control Register (OCR)

The OCR is an operation control register. The DIR bit defines the direction of the transfer. The SIZE bits define the size of the operand. The CHAIN bits define the type of the CHAIN mode. The REQG bits define how requests for transfers are generated

| 7   | 6 | 5    | 4     | 3    | 2 | 1 | 0 |
|-----|---|------|-------|------|---|---|---|
| DIR | 0 | SIZE | CHAIN | REQG |   |   |   |

#### DIR (DIRECTION)

- 0 Transfer from memory to device  
(transfer from MAR address to DAR address)
- 1 Transfer from device to memory  
(transfer from DAR address to MAR address)

#### SIZE (OPERAND SIZE)

- 00 Byte (8 bits)
- 01 Word (16 bits)
- 10 Long Word (32 bits)
- 11 See Note Below

#### CHAIN (CHAINING OPERATION)

- 00 Chain operation is disabled
- 01 (undefined, reserved)
- 10 Array Chaining
- 11 Linked Array Chaining

#### REQG (DMA REQUEST GENERATION METHOD)

- 00 Auto-request at transfer rate limited by General Control Register (Limited Rate Auto-Request)
- 01 Auto-request at maximum rate

**NOTE** If the DMAC is set to dual addressing mode, port size 8 bits, external request mode, and the data transfer is from peripheral device to memory, set SIZE = 11 in the Operation Control Register (OCR).

10 REQ line requests an operand transfer

11 Auto-request the first operand, external request for subsequent operands

Bit 6 Not Used

#### • Sequence Control Register (SCR)

The SCR is used to define the sequencing of memory and device addresses

| 7 | 6 | 5 | 4 | 3   | 2 | 1   | 0 |
|---|---|---|---|-----|---|-----|---|
| 0 | 0 | 0 | 0 | MAC |   | DAC |   |

#### MAC (MEMORY ADDRESS COUNT)

- 00 Memory address register does not count
- 01 Memory address register counts up
- 10 Memory address register counts down
- 11 (undefined, reserved)

#### DAC (DEVICE ADDRESS COUNT)

- 00 Device address register does not count
- 01 Device address register counts up
- 10 Device address register counts down
- 11 (undefined, reserved)

Bits 7, 6, 5, 4 Not Used

#### • Channel Control Register (CCR)

The CCR is used to start or terminate the operation of a channel. This register also determines if an interrupt request is to be generated. Setting the STR bit causes immediate activation of the channel, the channel will be ready to accept request immediately. The STR and CNT bits of the register cannot be reset by a write to the register. The SAB bit is used to terminate the operation forcedly. Setting the SAB bit will reset STR and CNT. Setting the HLT bit will halt the channel operation, and clearing the HLT bit will resume the operation. Setting start bit must be done by byte access. Otherwise, timing error occurs.

| 7   | 6   | 5   | 4   | 3   | 2 | 1 | 0 |
|-----|-----|-----|-----|-----|---|---|---|
| STR | CNT | HLT | SAB | INT | 0 | 0 | 0 |

#### STR (START OPERATION)

- 0 No operation is pending
- 1 Start operation

#### CNT (CONTINUE OPERATION)

- 0 No continuation is pending
- 1 Continue operation

#### HLT (HALT OPERATION)

- 0 Operation not halted
- 1 Operation halted

#### SAB (SOFTWARE ABORT)

- 0 Channel operation not aborted
- 1 Abort channel operation

#### INT (INTERRUPT ENABLE)

- 0 No interrupts enabled
- 1 Interrupts enabled

Bits 2, 1, 0 Not Used

#### • Channel Status Register (CSR)

The CSR is a register containing the status of the channel.



| 7               | 6               | 5               | 4               | 3               | 2 | 1   | 0   |
|-----------------|-----------------|-----------------|-----------------|-----------------|---|-----|-----|
| CO <sub>C</sub> | BT <sub>C</sub> | ND <sub>T</sub> | ER <sub>R</sub> | AC <sub>T</sub> | 0 | PCT | PCS |

**CO<sub>C</sub>** (CHANNEL OPERATION COMPLETE)  
 0 Channel operation incomplete  
 1 Channel operation complete  
**BT<sub>C</sub>** (BLOCK TRANSFER COMPLETE)  
 0 Block transfer incomplete  
 1 Block transfer complete  
**ND<sub>T</sub>** (NORMAL DEVICE TERMINATION)  
 0 No normal device termination by DONE input  
 1 Device terminated operation normally by DONE input  
**ER<sub>R</sub>** (ERROR BIT)  
 0 No errors  
 1 Error as coded in CER  
**AC<sub>T</sub>** (CHANNEL ACTIVE)  
 0 Channel not active  
 1 Channel active  
**PCT** (PCL TRANSITION)  
 0 No PCL transition occurred  
 1 PCL transition occurred  
**PCS** (THE STATE OF THE PCL INPUT LINE)  
 0 PCL "Low"  
 1 PCL "High"  
 Bit 2 Not Used

#### ● Channel Error Register (CER)

The CER is an error condition status register. The ER<sub>R</sub> bit of CSR indicates if there is an error or not. Bits 0-4 indicate what type of error occurred. [See *Attention on Usage, Note (3)*.]

| 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |
|---|---|---|---|------------|---|---|---|
| 0 | 0 | 0 |   | ERROR CODE |   |   |   |

Error Code  
 00000 No error  
 00001 Configuration error  
 00010 Operation timing error  
 00101 Address error in MAR  
 00110 Address error in DAR  
 00111 Address error in BAR  
 01001 Bus error in MAR  
 01010 Bus error in DAR  
 01011 Bus error in BAR  
 01101 Count error in MTC  
 01111 Count error in BTC  
 10000 External abort  
 10001 Software abort  
 Bits 7, 6, 5 Not Used

#### ● Channel Priority Register (CPR)

The CPR is used to define the priority level of the channel. Priority level 0 is the highest and priority level 3 is the lowest priority.

| 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
|---|---|---|---|---|---|----|---|
| 0 | 0 | 0 | 0 | 0 | 0 | CP |   |

#### CP (CHANNEL PRIORITY)

00 Priority level 0  
 01 Priority level 1  
 10 Priority level 2  
 11 Priority level 3

Bit 7 through 2 Not Used

#### ● General Control Register (GCR)

The GCR is used to define what portion of the bus cycles is available to the DMAC for limited rate auto-request generation. GCR is also used to specify the hold time for cycle steal mode with hold.

| 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0  |
|---|---|---|---|---|----|---|----|
| 0 | 0 | 0 | 0 |   | BT |   | BR |

#### BT (BURST TIME)

The number of DMA clock cycles per burst that the DMAC allows in the auto-request at a limited rate of transfer is controlled by these two bits. The number is  $2^{(BT+4)}$  (two to the BT+4 power)

#### BR (BANDWIDTH RATIO)

The amount of the bandwidth utilized by the auto-request at a limited rate transfer is controlled by these two bits. The ratio is  $2^{(BR+1)}$  (two to the BR+1 power).

The hold time for cycle steal mode with hold is defined to be minimum of 1 sample interval and maximum of 2 sample intervals. A sample interval is defined to be  $2^{(BT+BR+5)}$  (two to the BT+BR+5 power) clock cycles.

Bits 7 through 4 Not Used

#### ● Address Registers (MAR, DAR, BAR)

Three 32-bit registers are utilized to implement the Memory Address Register, Device Address Register, and the Base Address Register. Only the least significant twenty-four bits are connected to the address output pins. The content of the MAR is outputted when the memory is accessed in single or dual addressing mode. The content of the DAR is outputted when the peripheral device is accessed. The contents of the BAR are outputted when reading chain information from memory in the Array Chaining Mode or the Linked Array Chaining Mode. It is also used to set the top address of the next block transfer in Continue mode.

#### ● Function Code Registers (MFC, DFC, BFC)

The DMAC has three function code registers per channel the Memory Function Code Register (MFC), Device Function Code Register (DFC), and the Base Function Code Register (BFC). The contents of these registers are outputted from FC<sub>0</sub> through FC<sub>2</sub> lines when an address is outputted from MAR, DAR, or BAR, respectively. The BFC is also used to set the MFC for the transfer of the next data block in the Continue mode.

| 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |     |
|---|---|---|---|---|---|-----|-----|-----|
| 0 | 0 | 0 | 0 | 0 | 0 | FC2 | FC1 | FC0 |

Bits 3 through 7 Not Used

#### ● Transfer Count Registers (MTC, BTC)

Each channel has two 16-bit counters: the Memory Transfer Counter (MTC) and the Base Transfer Counter (BTC). The MTC



counts the number of transfer words in one block, and is decreased by one for every operand transfer.

The BTC is used to count the number of data blocks in the Array Chaining Mode. BTC is also used to set the number of operands to transfer for the next data block in the Continue Mode.

#### • Interrupt Vector Registers (NIV, EIV)

Each channel has a Normal Interrupt Vector register and an Error Interrupt Vector register.

When an interrupt acknowledge cycle occurs, an interrupt vector is outputted from one of those registers. If the error bit (CSR) is set for the channel with interrupt pending, then content of EIV is outputted, otherwise content of NIV is outputted.

#### ■ OPERATION DESCRIPTION

A DMAC channel operation proceeds in three principal phases. During the initialization phase, the MPU sets the channel control registers, supply the initial address and the number of transfer words, and starts the channel. During the transfer phase, the DMAC accepts requests for data operand transfers, and provides addressing and bus controls for the transfers. The termination phase occurs after the operation is completed.

This section describes DMAC operations. A description of the MPU/DMAC communication is given first. Next, the transfer phase is covered, including how the DMAC recognizes requests and how the DMAC arranges for data transfer. Following this, the initialization phase is described. The termination phase is covered, introducing chaining, error signaling, and bus exceptions. A description of the channel priority scheme rounds out the section.

#### • Read/Write of the DMAC Registers by MPU

The MPU reads and writes the DMAC internal registers and controls the DMA transfer. Figure 11 indicates the timing diagram when the MPU reads the contents of the DMAC register. The MPU outputs  $A_1-A_{23}$ ,  $FC_0-FC_2$ ,  $\overline{AS}$ ,  $R/W$ ,  $\overline{UDS}$ , and  $\overline{LDS}$ , and accesses the DMAC internal register. The specific internal register is selected by  $A_8-A_{15}$ ,  $\overline{LDS}$  and  $\overline{UDS}$ . The  $\overline{CS}$  and  $IACK$  lines are generated by the external circuit with  $A_8-A_{23}$  and  $FC_0-FC_2$ . The DMAC outputs data on the data bus, together with  $\overline{DDIR}$ ,  $\overline{DBEN}$  and  $\overline{DTACK}$ . The  $\overline{DDIR}$  and  $\overline{DBEN}$  control the bidirectional buffer on the bus and the  $\overline{DTACK}$  indicates that the data has been sent or received by the DMAC. Read Cycle is eighteen CLKs. Figure 12 shows the MPU write cycle. Write cycle is fifteen CLKs.

Note the following points.

- (1) The clock reference shown in this figure is the DMAC input clock.
- (2) The  $\overline{DDIR}$  and the  $\overline{DBEN}$  are three-stated at the beginning which detects  $CS$  and the ending of the cycle.
- (3) During the MPU read cycle, the  $\overline{DTACK}$  is asserted after the data is valid on the system bus.
- (4) During the MPU write cycle, the  $\overline{DDIR}$  line will be driven low to direct the data buffers toward DMAC before the buffers are enabled.
- (5) During the MPU write cycle, the DMAC will latch the data before asserting  $\overline{DTACK}$ . Then it will negate  $\overline{DBEN}$  and  $\overline{DDIR}$  in the proper order.
- (6) After the MPU cycle and the  $\overline{LDS}$  and the  $\overline{UDS}$  are negated by the MPU, the DMAC will put  $\overline{DBEN}$ ,  $\overline{DDIR}$  and the address data lines to a high impedance state.
- (7)  $\overline{DTACK}$  will once go "High" and then to a high impedance state after negating  $\overline{LDS}$  and  $\overline{UDS}$ .



Figure 11 MPU Read from DMAC – Word





Figure 12 MPU Write to DMAC – Word

- **Bus Arbitration**

The following is the description of the bus arbitration. The DMAC must obtain the ownership of the bus in order to transfer data. Figure 13 indicates the DMAC bus arbitration timing. It is completely compatible with that of HD68000 MPU. The DMAC asserts the Bus Grant (BG) to request the bus mastership. The MPU recognizes the request and asserts BG, then it grants the

ownership in the next bus cycle. After the end of the current cycle ( $\overline{AS}$  is negated), the MPU relinquishes the bus to the DMAC. The DMAC asserts the bus grant acknowledge (BGACK) to indicate that it has the bus ownership. A half clock before BGACK is asserted, the DMAC asserts OWN. OWN is kept asserted for a half clock after BGACK is negated at the end of the DMA cycle. BR is negated one clock after BGACK is asserted.



\* This case assumes that no exception condition exists and DMAC isn't accessed by MPU

Figure 13 DMAC Bus Arbitration Timing

#### ● Device/DMAC Communication

Communication between peripheral devices and the DMAC is accommodated by five signal lines. Each channel has REQ, ACK and PCL, and the last two lines the DONE and DTC lines, are shared among the four channels.

##### (1) Request (REQ)

The peripheral devices assert REQ to request data transfers. See the "Requests" section for details.

##### (2) Acknowledge (ACK)

This line is used to implicitly address the device which is transferring the data (This device is not selected by address lines.) It is also asserted when the content of DAR is outputted during memory-to-memory transfer except for the auto-request mode at a limited rate or at the maximum rate.

##### (3) Peripheral Control Line (PCL)

The function of this line is quite flexible and is determined by the DCR (Device Control Register).

The DTYP bits of the DCR define what type of device is on the channel. If the DTYP bits are programmed to be a HMCS6800 device, the PCL definition is ignored and the PCL line is an Enable clock (E clock) input. If the DTYP bits are programmed to be a device with READY, the PCL definition is ignored and the PCL line is a ready input.

##### PCL As a Status Input

The PCL line may be programmed as a status input. The status level of this line can be determined by the PCS bit in the CSR, regardless of the PCL function determined by the DCR. If a negative transition occurs and remains stable for a minimum of two clocks, the PCT bit of the CSR is set. This PCT bit is cleared by resetting the DMAC or the writing "1" to the PCT bit.

##### PCL As an Interrupt

The PCL line may be programmed to generate an interrupt on a negative transition. This enables an interrupt which is requested if the PCT bit of the CSR is set. When using this function, it is necessary to reset the PCT bit in the CSR before the PCL bit in the DCR is set to interrupt, in order to avoid assertion of IRQ line at this time.

##### PCL As a Starting Pulse

The PCL line may be programmed to output a starting pulse. This active low starting pulse is outputted when a channel is activated, and is "Low" for a period of four clock cycles.

##### PCL As an Abort Input

The PCL line may be programmed to be a negative transition above input which terminates an operation by setting the external abort error in CER. It is necessary to reset the PCT bit in the CSR before activating the channel (Setting the ACT bit of CCR) so that the channel operation is not immediately aborted. [See Attention on Usage, Note (2)]

##### PCL As an Enable Clock (E Clock) Input

If the DTYP bits are programmed to be a HD6800 device, the PCL definition is ignored and the PCL line is an Enable Clock input. The Enable clock downtime must be as long as five clock cycles, and must be high for a minimum of three DMAC clock cycles, but need not be synchronous with the DMAC's clock.

##### PCL As a READY Input

If the DTYP bits are programmed to be a device with READY, the PCL definition is ignored and the PCL line is a READY input. The READY is an active low input.

##### (4) DONE (DONE)

This line is an active low Input/Output signal with an open drain. It is asserted when the memory transfer count is exhausted in a single block transfer. In the chaining operation,

DONE is asserted only at the last transfer to the peripheral device of the last data block. In the continue mode, DONE is asserted for each data block. It is asserted and negated in coincident with the ACK line for the last data transfer to the peripheral device. It is also outputted in coincident with the ACK line of the last bus cycle, in which the address is outputted from the DAR, in the memory-to-memory transfer (dual addressing mode) that uses the ACK line.

The DMAC also monitors the state of the DONE line during the DMA bus cycle. If the device asserts DONE during ACK active, the DMAC will terminate the operation after the transfer of the current operand. If DONE is asserted on the first byte of 2 byte operation or the first word of long word operation, the DMAC does not terminate the operation before the whole operand transfer is completed. If DONE is asserted, then the DMAC terminates the operation by clearing the ACT bit of the CSR, and setting the COC and NDT bits of the CSR. If both the DMAC and the device assert DONE, the device termination is not recognized, but the channel operation does terminate. DONE is outputted again for the retry exceptions bus cycles.

##### (5) Data Transfer Complete (DTC)

DTC is an active low signal which is asserted when the actual data transfer is accomplished. It is also asserted in the bus cycle which read a chain information from memory in the Chaining mode. However, if exceptions are generated and the DMA bus cycle terminates, DTC is not asserted. DTC is asserted one half clock before LDS and UDS are negated, and negated one half clock after LDS and UDS are negated.

#### ● Requests

Requests may be externally generated by circuitry in the peripheral device, or internally generated by the auto-request mechanism. The REQG bits of the OCR determine these modes. The DMAC also supports an operation in which the DMAC auto-requests the first transfer and then wait for the peripheral device to request the following transfers.

##### (1) Auto-request Transfers

The auto-request mechanism provides generation of requests within the DMAC. These requests can be generated at either of two rates: maximum-rate and limited-rate. In the former case, the channel always has a request pending.

The limited rate auto-request functions by monitoring the bus utilization.

#### Limited-rate Auto-request

| TIME →                   |                         |                      |
|--------------------------|-------------------------|----------------------|
| Previous Sample Interval | Current Sample Interval | Next Sample Interval |
|                          | LRAR Interval           |                      |

Figure 14 DMAC Sample Intervals

In the limited-rate auto-request the DMAC divides time into equal length sample intervals by counting clock cycles. The end of one sample interval makes the beginning of the next. During a sample interval, the DMAC monitors by means of BGACK pin the system bus activity of the DMAC and other bus master devices. At the end of the sample interval, decision is made whether or not to perform the channel's data transfer during the next sample interval. Namely, based on the activity of the DMAC or other bus master devices during the current sample interval, the DMAC allows limited-rate auto-requests for some initial portion of the next sample interval.

The length of the sample interval, and the portion of the sample interval during which limited-rate auto-requests can be

made (the limited-rate auto-request interval) are controlled by the BT and BR bits in the GCR. The length in clock cycles of the limited-rate auto-request interval is  $2^{(BT+4)}$  (2 raised to the BT + 4 power). For example, if BT equals 2 and the DMA utilization of the bus was low during the previous sample interval, then the DMAC generates the auto-request transfers during the first 64 clock cycles.

The ratio of the length of the sample interval to the length of the limited-rate auto-request interval is controlled by the BR bits. The ratio of the system bus utilization of the MPU to other bus master devices including the DMAC is  $2^{(BR+1)}$  (2 raised to the BR + 1 power). If the fraction of DMA clock cycles during the sample interval exceeds the programmed utilization level, the DMAC will not allow limited-rate auto-requests during the next sample interval.

For example, if BR equals 3, then at most one out of 16 clock cycles during a sample interval can be used by the DMAC and other bus master devices, and still the DMAC would allow limited rate auto-request during the next sample interval. Therefore, from the viewpoint of long period, the ratio of the system bus utilization of the MPU to I/O devices including the DMAC is about 16.1. The sample interval length is not a direct parameter, but it is equal to  $2^{(BT+BR+5)}$  clock cycles. Thus, the sample interval can be programmed between 32 and 2048 clock

cycles.

The DMAC uses the BGACK to differentiate between the MPU bus cycle and DMAC or other bus master devices. If BGACK is active, then the DMAC assumes that the bus is used by a DMAC or other bus master devices. If it is inactive, then the DMAC assumes that it is used by the MPU.

#### Maximum-rate Auto-request

If the REQG bits in the OCR indicate auto-request at the maximum rate, the DMAC acquires the bus after the start bit is set and keeps it until the data transfer is completed.

If a request is made by another channel of higher priority, the DMAC services that channel and then resumes the auto-request sequence. If two or more channels are set to equal priority level and maximum rate auto-request, then the channels will rotate in a "round robin" fashion.

If the HD68000 compatible device is connected to a channel, the ACK line is held inactive during an auto-request operation. Consequently, any channel may be used for the memory-to-memory transfer with the auto-request function in addition to the operation of data transfer between memory and peripheral device with using the REQ pin. Refer to Figure 15 for the timing of the memory-to-memory transfer. In this mode, the ACK, HIBYTE and DONE outputs are always inactive.



Figure 15 Memory-to-Memory Transfer  
Read-Write-Read Cycles

## (2) External Requests

If the REQ bits of the OCR indicate that the REQ line generates requests, the transfer requests are generated externally. The request line associated with each channel allows the device to externally generate requests for DMA transfers. When the device wants an operand transferred, it makes a request by asserting the request line. The external request mode is determined by the XRM bits of the DCR, which allows both burst and cycle steal request modes. The burst request mode allows a channel to request the transfer of multiple operands using consecutive bus cycles. The cycle steal request mode allows a channel to request the transfer of a single operand. The

following are the description of the burst and the cycle steal modes.

### Burst Request Recognition

In the burst request mode, the REQ line is an active low input. The level sampled at the rising edge of the clock. Once the burst request is asserted, it needs to be held low until the first DMA bus cycle starts in order to insure at least one data transfer operation. In order to stop the burst mode transfer after the current bus cycle, the REQ line has to be negated one clock before the DTC output clock of this cycle. Refer to Figure 16 or the burst mode timing.



Figure 16 Burst Mode Request Timing  
(Only one channel is active)

### Cycle Steal Request Recognition

In the cycle steal request mode, the peripheral device requests the DMA transfer by generating an falling edge at the REQ line. The REQ line needs to be held "low" for at least 2 clock cycles. In the cycle steal mode, if the REQ line changes from "High" to "Low" between ACK output and one clock before the clock that outputs DTC, then the next DMA transfer is performed without relinquishing the bus. If the bus is not relinquished, then maximum of 5 idle clocks is inserted between bus cycles. Refer to Figure 17 for the request timing of the cycle steal mode. If the XRM bits specify cycle steal without hold, the DMAC will relinquish the bus. If the XRM bits specify cycle steal with hold, the DMAC will retain ownership. The bus is not given up for arbitration until the channel opera-

tion terminates or until the device pauses. The device is determined to have paused if it does not make any requests during the next full sample interval. The sample interval counter is free running and is not reset or modified by this mode of operation. The sample interval counter is the same counter that is used for Limited Rate Auto Request and is programmed via the GCR. Figure 18 shows the request timing in the cycle steal bus hold. If the REQ is inputted during the hold time, the ACK is outputted after a maximum of 7.5 clock cycles from the picked-up clock. On the cycle steal with hold mode, the DMAC will hold the bus even when the transfer count is exhausted and the last data has been transferred. If DMA transfer is requested from other channels during this period, they are executed normally.



Figure 17 Cycle Steal Mode Request Timing





Figure 18 Cycle Steal Bus Hold Mode Request Timing

#### Request Recognition in Dual-address Transfers

In a following section dual-address transfers are defined. Dual address transfer is an exception to the request recognition rules in the previous paragraphs. In the cycle steal request mode, when there are two or more than transfers between the DMAC and the peripheral device during one operand transfer, the request is not recognized until the last transfer between the DMAC and the I/O device starts.

#### (3) Mixed Request Generation

A single channel can mix the two request generation methods. By programming the REQG bits of the OCR to "11", when the channel is started, the DMAC auto-requests the first transfer. Subsequent requests are then generated externally by the device. The ACK and PCL lines perform their normal functions in this operation.

#### • Data Transfers

All DMAC data transfers are assumed to be between memory and the peripheral device. The word "memory" means a 16-bit HD68000 bus compatible device. By programming the DCR, the characteristics of the peripheral device may be assigned. Each channel can communicate using any of the following protocols

#### (1) Dual Addressing

HD68000 and HD6800 compatible devices may be explicitly addressed. This means that before the peripheral transfers data, a data register within the device must be addressed. Because the address bus is used to address the peripheral, the data cannot be directly transferred to/from the memory because the memory also requires addressing. Instead, the data is transferred from the source to the DMAC and held in an internal DMAC holding register. A second bus transfer between the DMAC and the destination is then required to complete the operation. Because both the source and destination of the transfer are explicitly addressed, this protocol is called dual-addressed.

#### HD68000 Compatible Device Transfers

In this operation, when a request is received, the bus is obtained and the transfer is completed using the protocol as shown in Figures 19 and 20. Figures 21 through 24 show the transfer timings. Figure 21 and 24 show the operation when the memory is the source and the peripheral device is the destination. Figures 22 and 23 show the transfer in the opposite direction. The peripheral device is a 16-bit device in Figures 21 and 22, and a 8-bit device in Figures 23 and 24.

| DTYP | Device Type               |                   |
|------|---------------------------|-------------------|
| 00   | HD68000 compatible device |                   |
| 01   | HD6800 compatible device  | }                 |
| 10   | Device with ACK           |                   |
| 11   | Device with ACK and READY | }                 |
|      |                           | Dual Addressing   |
|      |                           | Single Addressing |



Figure 19 Word Read Cycle Flowchart HD68000 Type Device



Figure 20 Word Write Cycle Flowchart HD68000 Type Device



**Figure 21** Dual Addressing Mode, Read/Write Cycle, Destination = 16-bit Device, Word Operand



**Figure 22 Dual Addressing Mode, Read/Write Cycle,  
Source = 16-bit Device, Word Operand**



Figure 23 Dual Addressing Mode, Read/Write Cycle  
Source = 8-bit Device, Word Operand



Figure 24 Dual Addressing Mode, Read/Write Cycle,  
Destination = 8-bit Device, Word Operand



**HD6800 Compatible Device Transfers**

When a channel is programmed to perform HD6800 compatible transfers, the PCL line for that channel is defined as an Enable clock input. The DMAC performs data transfers between itself and the peripheral device using the HD6800 bus protocol, with the ACK output providing the VMA (valid memory address) signal. Figure 25

illustrates this protocol. Refer to Figure 26 for the read cycle timing and Figure 27 for the write cycle timing. In Figure 26, the DMAC latches the data at the falling edge of clock 19, so a latch to hold the data is necessary as shown in Figure 47.



Figure 25 HD6800 Cycle Flowchart



Figure 26 Dual Addressing Mode, HD6800 Compatible Device, Read Cycle



Figure 27 Dual Addressing Mode, HD6800 Compatible Device, Write Cycle

## (2) Single Addressing Mode

Implicitly addressed devices are peripheral devices selected not by address but by ACK. They do not require addressing of data register during data transfer. Transfers between memory and these devices are controlled by the request/acknowledge protocol. Such peripherals require only one bus cycle to transfer data, and the DMAC internal holding register is not used. Because only the memory is addressed during a data transfer and a transfer done in only one bus cycle, this protocol is called single-address.

### Device with ACK Transfers

Under this protocol, the communication between peripheral device and the DMAC is performed with a two signal REQ/ACK handshake. When a request is generated using the request method programmed in the DMAC's internal control registers, the DMAC obtains the bus and responds with ACK. The DMAC asserts all the bus control signals required for the memory access. Refer to Figure 28 for the flowchart of the data transfer from memory to the device with ACK. Figure 29 shows the flowchart of the data transfer from the device with ACK to memory. When a request is generated using the request method programmed in the control registers, the DMAC obtains the bus and responds with acknowledgement. The DMAC asserts all HD68000 bus control signals needed for the transfer. When the DMAC accepts DTACK from memory, it asserts DTC and informs the

peripheral device of the transfer termination. Figure 30 and 31 show the transfer timings of the device with ACK the port size for the former figure is 8-bit and the latter is 16-bit respectively.

When the transfer is from memory to a device, data is valid when DTACK is asserted and remains valid until the data strobes are negated. The assertion of DTC from the DMAC may be used to latch the data.

When the transfer is from device to memory, data must be valid on the HD68000 bus before the DMAC asserts the data strobes. The data strobes are asserted one clock period after ACK is asserted. When the DMAC obtains the bus and starts a DMA cycle, the tri-state of the OWN line is cancelled a half clock earlier than other control lines. If the DMA Cycle terminates and the DMAC relinquishes the bus, all the control signals get tri-stated a half clock before OWN. The DDIR and DBEN lines are not asserted in the single addressing mode. Four clocks cycle is the smallest bus cycle for the transfer from memory to device. Five clocks cycle is the smallest bus cycle for the transfer from device to memory. If the device port size is 8-bit, either LDS or UDS is asserted. In the single addressing mode, A<sub>8</sub>-A<sub>23</sub> are outputted for only one and a half clock from the beginning of the DMA bus cycle. Therefore A<sub>8</sub> through A<sub>23</sub> needs to be latched externally just like in the dual addressing mode.



Figure 28 Word from Memory to Device with  $\overline{ACK}$ Figure 29 Word from Device with  $\overline{ACK}$  to Memory



Figure 30 Single Addressing Mode with 16-Bit Devices as Source and Destination (Read-Write Cycles)



Figure 31 Single Addressing Mode with 8-Bit Device as Source and Destination (Read-Write Cycles)



**Device with ACK and READY Transfers**

Under this protocol, the communication between peripheral device and the DMAC is performed using a three signal REQ/ACK/READY handshake. The READY input to the DMAC is provided by the PCL line. The READY line is active low. When a request is generated using the request method programmed in the control registers, the DMAC obtains the bus and asserts ACK to notify the device that the transfer is to take place. The DMAC waits for READY (PCL input), which is a response from the device, in addition to DTACK which is a response from memory.

When the DMAC accepts both signals, it terminates the transfer. Refer to Figures 33 and 34 for the flowcharts of the data transfer between memory and the device with ACK and READY. Refer to Figure 35 for the transfer timing of the 8-bit device. When the data transfer is from memory to a device, data is valid from the assertion of DTACK to the negation of LDS and UDS. DTC is asserted a half clock before LDS and UDS are negated, so this line may be used for latching the data by the peripheral device. In this case, READY (PCL input) indicates that the device has received the data. Both DTACK and READY (PCL input) signals are needed for terminating the DMA cycle.

When the data transfer is from the device to memory, data must be valid on the bus before the DMAC asserts LDS and UDS. Therefore, READY (PCL input) is used as the signal to indicate that the peripheral device has outputted the data on the bus. When the DMAC detects PCL (READY input), then it

asserts LDS and UDS. After asserting LDS and UDS, the DMAC terminates the cycle when DTACK signal from the memory is detected.

When Array Chain or Link Array Chain is set in Device with ACK and READY Transfer mode, READY input is also necessary during DMA bus cycles for reading the chain information from memory. The circuit as shown in Figure 32 may be used in order to generate READY input when reading the chain information from memory.



Figure 32 READY Circuit When Array or Link Array Chain is set for Device with ACK and READY



Figure 33 Word from Memory to Device with ACK and READY





Figure 34 Word from Device with ACK and READY to Memory



Figure 35 Single Addressing Mode with 8-Bit Devices as Source and Destination with PCL Used as a READY Input (Read-Write Cycles)



**Operands and Addressing**

Three factors enter into how the actual data is handled: port size, operand size and address sequencing.

**Port Size**

The DCR is used to program the device port size.

| DPS | Device Port Size |
|-----|------------------|
| 0   | 8 bit port       |
| 1   | 16 bit port      |

The port size is the number of bits of data which the device can transfer in a single bus cycle. During a DMAC bus cycle, a 16-bit port transfers 16 bits of data on  $D_0 \sim D_{15}$ , while an 8-bit port transfers 8 bits of data, either on  $D_0 \sim D_7$  or on  $D_8 \sim D_{15}$ . The memory is always assumed to have a port size of 16.

**Operand Size**

OCR is used to program the operand size.

| SIZE | Operand Size          |
|------|-----------------------|
| 00   | Byte                  |
| 01   | Word                  |
| 10   | Long word             |
| 11   | (undefined, reserved) |

The operand size is the number of bits of data to be transferred to honor a single request. Multiple bus cycles may be required to transfer the operand through the device port. A byte operand consists of 8 bits of data, a word operand consists of 16 bits of data, a long word operand consists of 32 bits of data. The transfer counter counts the number of operands transferred.

Table 2 indicates the combinations supported by the DMAC about the peripheral devices with different port size and operand sizes in the single and dual addressing mode. In the single addressing mode, port size and operand size must be the same. In the dual addressing mode, byte operand cannot be used when the port size is sixteen and the REQG bit is 10 or 11.

Table 2 Operation Combinations

| Addressing | Device Type                | Port | Operand |      |           | REQG bits of OCR |
|------------|----------------------------|------|---------|------|-----------|------------------|
|            |                            |      | Byte    | Word | Long Word |                  |
| Dual       | 68000, 6800                | 8    | ○       | ○    | ○         | 00, 01, 10, 11   |
|            | 68000, 6800                | 16   | ○       | ○    | ○         | 00, 01           |
|            | 68000, 6800                | 16   | X       | ○    | ○         | 10, 11           |
| Single     | with ACK or<br>ACK & READY | 8    | ○       | X    | X         | 00, 01, 10, 11   |
|            |                            | 16   | X       | ○    | X         | 00, 01, 10, 11   |

○ ; enable X ; disable

**(3) Address Sequencing**

The sequence of addresses generated depends upon the port size, operand size, whether the addresses are to count up, down or not change and whether the transfer is executed in the single addressing mode or the dual addressing mode. The memory address count method and the peripheral device address count method is programmed using the Memory address count (MAC) bit and the Device address count (DAC) bit in the Sequence Control Register (SCR).

## (i) Single addressing mode

In the single addressing mode, memory address sequenc-

ing is shown in Table 3. If the operand size is byte, the memory address increment is one (1). If the operand size is word, the memory address increment is two (2). If the memory address register does not count, the memory address is unchanged after the transfer. If the memory address counts up, the increment is added to the memory address, if the memory address counts down, the increment is subtracted from the memory address. The memory address is changed after the operand is transferred.

Table 3 Single Address Sequencing

| Port Size | Operand Size | Memory Address Increment |               |               |
|-----------|--------------|--------------------------|---------------|---------------|
|           |              | + (increment)            | = (unchanged) | - (decrement) |
| 8         | Byte         | +1                       | 0             | -1            |
| 16        | Word         | +2                       | 0             | -2            |



## (ii) Dual addressing mode

In the dual addressing mode, the operand size need not match the port size. Thus the transfer of an operand may require several DMA bus cycles. Each DMA bus cycle, between memory and DMAC and between DMAC and the device, is called the operand part and transfers a portion or all of the operand. The addresses of the operand parts are in a linear increasing sequence. The step between the addresses of the operand is two. The size of the operand parts is the minimum of the port size and the operand size. The number of the operand part is the operand size divided by the port size. In the dual addressing mode, memory is regarded as a device whose port size is 16-bits.

If the port size is 16 bits, the operand size is byte, and the

request generation method is auto request or auto request at a limited rate, the DMAC packs consecutive transfers. This means that word transfers are made from the associated address with an address increment of two (2). If the initial source address location contains a single byte, the first transfer is a byte transfer to the internal DMAC holding register, and subsequent transfers from the source are word transfers. If the initial destination location contains a single byte, the first transfer is a byte transfer from the internal DMAC holding register, and any remaining byte remains in the holding register. Likewise, if either the final source or destination location contains a single byte, only a byte transfer is done. Packing is not performed if the address does not count, each byte is transferred by a separate access to the same location. The dual address sequencing is shown in Table 4. [See Attention on Usage, Note (4).]

Table 4 Dual Address Sequencing

| Port Size | Operand Size | Part Size | Operand Part Address | Address Increment |   |    |
|-----------|--------------|-----------|----------------------|-------------------|---|----|
|           |              |           |                      | +                 | = | -  |
| 8         | Byte         | Byte      | A                    | +2                | 0 | -2 |
| 8         | Word         | Byte      | A, A+2               | +4                | 0 | -4 |
| 8         | Long         | Byte      | A, A+2, A+4, A+6     | +8                | 0 | -8 |
| 16        | Byte         | Pack      | A                    | +P                | 0 | -P |
| 16        | Word         | Word      | A                    | +2                | 0 | -2 |
| 16        | Long         | Word      | A, A+2               | +4                | 0 | -4 |

P = 1 if packing is not done

= 2 if packing is done

Pack = byte if packing is not done

= word if packing is done

## An Example of a Dual Address Transfer

This section contains an example of a dual address transfer using Table 4 of Dual-Address Sequencing. The table is reproduced here as Table 5. The transfer mode of this example is the following

- 1 Device Port size = 8 bits
- 2 Operand size = Long Word (32 bits)
- 3 Memory to Device Transfer
4. Source (Memory) Counts up, Destination (Device) Counts Down
- 5 Memory Transfer Counter = 2

In this mode, a data transfer from the source (memory) is done according to the 6th row of Table 5, since the port size of the memory is always 16 bits. A data transfer to the destination (device) is done according to the 3rd row of Table 5. Table 6 shows the data transfer sequence.

The memory map of this example is shown in Table 7. The operand consists of BYTE A through BYTE D in memory of Table 7. Prior to the transfer, MAR and DAR are set to 00000012 and 00000108 respectively. The operand is transferred to the 8 bit port device according to the order of transfer number in Table 6.

Table 5 Dual-Address Sequencing (Table 4)

| Row No. | Port Size | Operand Size | Operand Part Size     | Operand Part Addresses          | Address Increment |   |           |
|---------|-----------|--------------|-----------------------|---------------------------------|-------------------|---|-----------|
|         |           |              |                       |                                 | +                 | = | -         |
| 1       | 8         | BYTE         | BYTE                  | A                               | +2                | 0 | -2        |
| 2       | 8         | WORD         | BYTE                  | A, A+2                          | +4                | 0 | -4        |
| (3)     | 8         | LONG         | BYTE *4               | A, A+2, A+4, A+6<br>*3 *5 *7 *8 | +8                | 0 | -8<br>*10 |
| 4       | 16        | BYTE         | PACK (BYTE or WORD)** | A                               | +P                | 0 | -P        |
| 5       | 16        | WORD         | WORD                  | A                               | +2                | 0 | -2        |
| (6)     | 16        | LONG         | WORD *2               | A, A+2<br>*1 *6                 | +4<br>*9          | 0 | -4        |

\* Numbers in Table 5 correspond to ones in Table 6 and 7

\*\* Refer to Address Sequencing on Operand Part Size and PACK.



Table 6 An Example of a Data Transfer for One Operand

SRC: Source (Memory), DST Destination (Device), HR: Holding Register (DMAC Internal Reg.)

| Transfer No. | Data Transfer | Address Output | Data Size on Bus | DMAC Registers after Transfer |                 | Comment                                                                         |
|--------------|---------------|----------------|------------------|-------------------------------|-----------------|---------------------------------------------------------------------------------|
|              |               |                |                  | MAR                           | DAR             |                                                                                 |
| 0            | —             | —              | —                | 00000012                      | 00000108        | Initial Register Setting                                                        |
| 1            | SRC → HR      | 00000012<br>*1 | WORD<br>*2       | 00000014                      | 00000108        | Higher order 16 bits of operand is fetched.                                     |
| 2            | HR → DST      | 00000108<br>*3 | BYTE<br>*4       | 00000014                      | 0000010A        | Higher order 16 bits of operand is transferred.                                 |
| 3            | HR → DST      | 0000010A<br>*5 | BYTE<br>*4       | 00000014                      | 0000010C<br>*10 |                                                                                 |
| 4            | SRC → HR      | 00000014<br>*6 | WORD<br>*2       | 00000016<br>*9                | 0000010C        | Lower order 16 bits of operand is fetched                                       |
| 5            | HR → DST      | 0000010C<br>*7 | BYTE<br>*4       | 00000016                      | 0000010E        | Lower order 16 bits of operand is transferred.                                  |
| 6            | HR → DST      | 0000010E<br>*8 | BYTE<br>*4       | 00000016                      | 00000110<br>*10 |                                                                                 |
| 6'           | —             | —              | —                | 00000016                      | 00000110        | MAR, DAR are pointing the next operand addresses when the transfer is complete. |

Mode: Port size = 8, Operand size = Long Word, Memory to Device, Source (Memory) Counts Up, Destination (Device) Counts Down

Table 7 Memory Map for the Example of the Data Transfer



#### • Initiation and Control of Channel Operation

##### (1) Operation Initiation

To initiate the operation of a channel the STR bit of the CCR is set to start the operation. Setting the STR bit causes the immediate activation of the channel, the channel will be ready to accept requests immediately. The channel initiates the operation by resetting the STR bit and setting the channel active bit in the CSR. Any pending requests are cleared, and the channel is then ready to receive requests for the new operation. If the channel is configured for an illegal operation, the configuration error is signaled, and no channel operation is run. The illegal operations include the selection of any of the options marked "(undefined, reserved)". If the MTC is set to zero in any operation or BTC is set to zero in the array chaining mode, then the count error is signaled and the channel is not activated. The channel cannot be started if any of the ACT, COC, BTC, NDT or ERR bits is set in the CSR. In this case, the channel signals the operation timing error.

##### (2) Operation Continuation (Continue Mode)

The continue bit (CNT) allows multiple blocks to be transferred in unchained operations. The CNT bit is set in order to continue the current channel operation. If an attempt is made to continue a chained operation, a configuration error is signaled. The base address register and base transfer counter should have been previously initialized.

The continue bit may be set as the channel is started or while the channel is still active. The operation timing error bit is signaled if a continuation is otherwise attempted.

When the memory transfer counter is exhausted and the continue bit of the CCR is set, the DMAC performs a continuation of the channel operation. The base address, base function code, and base transfer count registers are copied into the memory address, memory function code, and memory transfer count registers. The block transfer complete (BTC) bit of the CSR is set, the continue bit is reset, and the channel begins a new block transfer. If the memory transfer counter is loaded with a terminal count, the count error is signaled.

##### (3) Operation Halting (Halt)

The CCR has a halt bit which allows suspension of the operation of the channel. If this bit is set, a request may still be generated and recognized, but the DMAC does not attempt to acquire the bus or to make transfers for the halted channel. When this bit is reset, the channel resumes operation and services any request that may have been received while the channel was halted. However, in the burst request mode, the transfer request should be kept asserted until the initiation of the first transfer after clearing the halt bit.

#### (4) Operation Abort by Software (Software Abort)

Setting the software abort bit (SAB) in the CCR allows the current operation of the channel to be aborted. In this case, the ERR bit and the COC bit in the CSR are set and the ACT bit is reset. The error code for the software abort is set in the CER. The SAB bit is designed to be reset if the ERR bit is reset. When the CCR is read, the SAB always reads as zero(0).

#### (5) Interrupt Enable

The CCR has an interrupt enable bit (INT) which allows the channel to request interrupts. If INT is set, the channel can request interrupts. If it is clear, the channel will not request interrupts.

##### • Channel Operation Termination

As part of the transfer of an operand, the DMAC decrements the memory transfer counter (MTC). If the chaining mode is not used and the CNT bit is not set or the last block is transferred in the chaining mode, the operation of the channel is complete when the last operand transfer is completed and the MTC is zero. The DMAC notifies the peripheral device of the channel completion via the DONE output.

However, in the continue mode, DONE is outputted at the termination of every data block transfer. When the channel operation has been completed, the ACT bit of the CSR is cleared, and the COC bit of the CSR is set.

The occurrence of errors, such as the bus error, during the DMA bus cycle also terminates the channel operation. In this case, the ACT bit in the CSR is cleared, the ERR and the COC bits are set, and at the same time the code corresponding to the error that occurred is set in the CER.

#### (1) Channel Status Register (CSR)

The channel status register contains the status of the channel. The register, except for ACT and PCS bits, is cleared by writing a one (1) into each bit of the register to be cleared. Those bits positions which contain a zero (0) in the write data remain unaffected. ACT and PCS bits are unaffected by the write operation.

##### COC

The channel operation complete (COC) bit is set if the channel operation has completed. The COC bit must be cleared in order to start another channel operation. The COC bit is cleared only by writing a one to this bit or resetting the DMAC.

##### PCS

The peripheral status (PCS) bit reflects the level of the PCL line regardless of its programmed function. If PCL is at "High" level, the PCS bit reads as one. If PCL is at "Low" level, the PCS bit reads as zero. The PCS bit is unaffected by writing to the CSR.

##### PCT

The peripheral control transition (PCT) bit is set, if a falling edge transition has occurred on the PCL line. (The PCL line must remain at "low" level for at least two clock cycles.) The PCT bit is cleared by writing a one to this bit or resetting the DMAC.

##### BTC

Block transfer complete (BTC) bit is set when the continue (CNT) bit of CCR is set and the memory transfer counter (MTC) is exhausted. The BTC bit must be cleared before the another continuation is attempted (namely, setting the CNT bit again), otherwise an operation timing error occurs. The BTC bit is cleared by writing a one to this bit or resetting the DMAC.

##### NDT

Normal device termination (NDT) bit is set when the peripheral device terminates the channel operation by asserting the DONE line while the peripheral device was being acknowledged. The NDT bit is cleared by writing a one to this bit or resetting the DMAC.

##### ERR

Error (ERR) bit is set if any errors have been signaled. When the ERR bit is set, the code corresponding to the kind of the error that occurred is set in the CER. The ERR bit is cleared by writing a one to this bit or resetting the DMAC.

##### ACT

Active (ACT) bit is asserted after the STR bit has been set and the channel operation has started. This bit is remains set until the channel operation is terminated. The ACT bit is unaffected by write operations. This bit is cleared by the termination of the channel or resetting the DMAC.

#### (2) Interrupts

The DMAC can signal the termination of the channel operation by generating an interrupt request. The INT bit of the CCR determines if an interrupt can be generated. The interrupt request is generated by the following condition.

$$\textcircled{1} \text{ INT} = 1$$

and

$$\textcircled{2} \text{ COC} = 1 \text{ or } \text{BTC} = 1 \text{ or } \text{ERR} = 1 \text{ or } \text{NDT} = 1 \text{ or } \text{PCT} = 1$$

(the PCL line is an interrupt input)

This may be represented as

$$\overline{\text{IRQ}} = \text{INT} \cdot (\text{COC} + \text{BTC} + \text{ERR} + \text{NDT} + \text{PCT}^*)$$

(\*PCL line is programmed as an interrupt input.)

When the IRQ line is asserted, changing the INT bit from one to zero to one will cause the IRQ output to change from "low" to "high" to "low" again. The IRQ should be negated by clearing the COC, the BTC, the ERR, the NDT and the PCT bits.

If the DMAC receives IACK from the MPU during asserting the IRQ, the DMAC provides an interrupt vector. If multiple channels have interrupt requests, the determination of which channel presents its interrupt vector is made using the same priority scheme defined for the channel operations.

The bus cycle in which the DMAC provides the interrupt vector when receiving an IACK from the MPU is called the interrupt acknowledge cycle. The interrupt vector returned to the MPU comes from either the normal or the error interrupt vector register. The normal interrupt register is used unless the ERR bit of CSR is set, in which case the error interrupt vector register is used. The content of the interrupt vector register is placed on  $D_0 \sim D_7$ , and DTACK is asserted to indicate that the vector is on the data bus. If a reset occurs, all interrupt vector registers are set to \$0F (binary 00001111), the value of the uninitialized interrupt vector. The timing of the interrupt acknowledge cycle is shown in Figure 36. The HD68000 MPU outputs the interrupt level into  $A_1 \sim A_3$  and  $A_4 \sim A_7$  is held "high" during the interrupt acknowledge cycle, but the HD68450 DMAC ignores these signals.





Figure 36 MPU IACK Cycle to DMAC

**(3) Multiple Data Block Transfer Operation**

When the memory transfer counter (MTC) is exhausted, the channel operation still continues if the channel is set to the array chaining mode or the linked array chaining mode and the chain is not exhausted. The channel operation also contains if the continue bit (CNT) of the CCR is set. The DMAC provides the initialization of the memory address register and the memory transfer counter in these cases so that the DMAC can transfer the multiple blocks.

**Continued Operation**

The continued operation is described in the Initiation and the Control of the Channel Operation section.

**Array Chaining**

This type of chaining uses an array in memory consisting of memory addresses and transfer counts. Each entry in the array is six bytes long and consists of four bytes of address followed by two bytes of transfer count. The beginning address of this array is in the base address register, and the number of entries in the array is in the base transfer counter. Before starting any block transfers, the DMAC fetches the entry currently pointed

to by the base address register. The address information is placed in the memory address register, and the count information is placed in the memory transfer counter. As each chaining entry is fetched, the base transfer counter is decremented by one. After the chaining entry is fetched, the base address register is incremented to point the next entry. When the base transfer counter reaches a terminal count of zero, the chain is exhausted, and the entry just fetched determines the last block of the channel operation.

An example of the array chaining mode operation and the memory format for supporting array chaining is shown in Figure 37. The array must start at an even address, or the entry fetch results is an address error. If a terminal count is loaded into the memory transfer counter or the base transfer counter, the count error is signaled. Since the base registers may be read by the MPU, appropriate error recovery information is available should the DMAC encounter an error anywhere in the chain. Contents of the BFC is outputted as the function code when the DMAC is accessing the memory using the base address register. The value of the function code registers are unchanged in the array chaining operation.



Figure 37 Transfer Example of the Array Chaining Mode

#### Linked Array Chaining

This type of chaining uses a list in memory consisting of memory address, transfer counts, and link addresses. Each entry in the chain list is ten bytes long, and consists of four bytes of memory address, two bytes of transfer count and four bytes of link address. The address of the first entry in the list is in the base address register, and the base transfer counter is unused. Before starting any block transfers, the DMAC fetches the entry currently pointed to by the base address register. The address information is placed in the memory address register, the count information is placed in the memory transfer counter,

and the link address replaces the current contents of the base address register. The channel then begins a new block transfer. As each chaining entry is fetched, the update base address register is examined for the terminal link which has all 32 bits equal to zero. When the new base address is the terminal address, the chain is exhausted, and the entry just fetched determines the last block of the channel operation.

An example of the linked array chaining mode operation and the memory format for supporting it is shown in Figure 38.

In Figure 38, the DMAC transfers data blocks in the order of Block A, Block B, and Block C. In the linked array chaining





Figure 38 Transfer Example of the Linked Array Chaining Mode

mode, the BTC is not used. When the DMAC refers to the linked array table, the value of the BFC is outputted as the function code. The values of the function code registers are unchanged by the linked array chaining operation.

This type of chaining allows entries to be easily removed or inserted without having to reorganize data within the chain. Since the end of the chain is indicated by a terminal link, the number of entries in the array need not be specified to the DMAc.

The linked array table must start at an even address in the linked array chaining mode. Starting the table at an odd address results in an address error. If "0" is initially loaded to the MTC, the count error is signaled. Because the MPU can read all of the DMAC registers, all necessary error recovery information is available to the operating system.

The comparison of both chaining modes is shown in Table 8.

Table 8 Chaining Mode Address/Count Information

| Chaining Mode         | Base Address Register             | Base Transfer Counter                   | Completed When          |
|-----------------------|-----------------------------------|-----------------------------------------|-------------------------|
| Array Chaining        | address of the array table        | number of data blocks being transferred | Base Transfer Count = 0 |
| Linked Array Chaining | address of the linked array table | (unused)                                | Linked Address = 0      |

#### (4) Bus Exception Conditions

The DMAC has three lines for inputting bus exception conditions called  $\overline{BEC}_0$ ,  $\overline{BEC}_1$ , and  $\overline{BEC}_2$ . The priority encoder can be used to generate these signals externally. These lines are encoded as shown in Table 9.

Table 9

| $\overline{BEC}_2$ | $\overline{BEC}_1$ | $\overline{BEC}_0$ | Exception Condition      |
|--------------------|--------------------|--------------------|--------------------------|
| 1                  | 1                  | 1                  | No exception condition   |
| 1                  | 1                  | 0                  | Halt                     |
| 1                  | 0                  | 1                  | Bus error                |
| 1                  | 0                  | 0                  | Retry                    |
| 0                  | 1                  | 1                  | Relinquish bus and retry |
| 0                  | 1                  | 0                  | (undefined, reserved)    |
| 0                  | 0                  | 1                  | (undefined, reserved)    |
| 0                  | 0                  | 0                  | Reset                    |

In order to guarantee reliable decoding, the DMAC verifies that the incoming code has been stable for two DMAC clock cycles before acting on it. The DMAC picks up  $\overline{BEC}_0$ - $\overline{BEC}_2$  at the rising edge of the clock. If  $\overline{BEC}_0$ - $\overline{BEC}_2$  is asserted to the undefined code, the operation of the DMAC does not proceed. For example, when the DMAC is waiting for DTACK, inputting DTACK does not result in the termination of the cycle if  $\overline{BEC}_0$ - $\overline{BEC}_2$  is asserted to the undefined code. In addition, when the transfer request is received,  $\overline{BR}$  is not asserted if the  $\overline{BEC}_0$ - $\overline{BEC}_2$  is not set to no exception condition.

If exception condition, except for HALT, is inputted during the DMA bus cycle prior to, or in coincidence with DTACK, the DMAC terminates the current channel operation immediately. Here coincident means meeting the same set up requirements for the same sampling edge of the clock. If a bus exception condition exists, the DMAC does not generate any bus cycles until it is removed. However, the DMAC still recognizes requests.

#### Halt

The timing diagram of halt is shown in Figure 39. This diagram shows halt being generated during a read cycle from the 68000 compatible device in the dual addressing mode. If the halt exception is asserted during a DMA bus cycle, the DMAC does not terminate the bus cycle immediately. The DMAC waits for the assertion of DTACK before terminating the bus cycle so that the bus cycle is completed normally. In the halted state, the DMAC puts all the control signals to high impedance and relinquishes the bus to the MPU. The DMAC does not output the BR until halt exception is negated. When halt exception is negated, the DMAC acquires the bus again and proceeds the DMA operation. In order to insure a halt exception operation, the  $\overline{BEC}$  lines must be set to halt at least until the assertion of DTCK.

If the DMAC has the bus, but is not executing any bus cycle, the DMAC relinquishes the bus as soon as halt exception is asserted.





Figure 39 Halt Operation

**Bus Error**

The bus error exception is generated by external circuitry to indicate the current transfer cannot be successfully completed and is to be aborted. The recognition of this exception during a DMAC bus cycle signals the internal bus error condition for the channel for which the current bus cycle is being run. As soon as the DMAC recognizes the bus error exception, the DMAC immediately terminates the bus cycle and proceeds to the error recovery cycle. In this cycle, the DMAC adjusts the

values of the MAR, the DAR, the MTC and the BTC to the values when the bus error exception occurred. 25 clocks are required for the error recovery cycle in the single addressing mode and in the read cycle of the dual addressing mode. 29 clocks are required in the write cycle of the dual addressing mode. If the DMAC does not have any transfer request in the other channels after the error recovery cycle, the DMAC relinquishes the bus.

The diagram of the bus error timing is shown in Figure 40.



- \*  $\overline{\text{BEC}_0} \cdot \overline{\text{BEC}_2} = (101)$
- \*\* In the single addressing mode and in the read cycle of the dual addressing mode: 25 clocks  
In the write cycle of the dual addressing mode: 29 clocks
- \*\*\* The DMAC keeps the bus because the other channels have requests pending. If other channels do not have requests, the DMAC relinquishes the bus after the error recovery cycle.

Figure 40 Bus Error Operation

**Retry**

The retry exception causes the DMAC to terminate the present operation and retry that operation when retry is re-

moved, and thus will not honor any requests until it is removed. However, the DMAC still recognizes requests. The retry timing is shown in Figure 41.





Figure 41 Retry Operation

**Relinquish and Retry (R&R)**

The relinquish and retry exception causes the DMAC to relinquish the bus and three-state all bus master controls and when the exception is removed, rearbitrate for the bus to retry

the previous operation.

The diagram of the relinquish and retry timing is shown in Figure 42.





\* BEC<sub>0</sub>-BEC<sub>2</sub> = (110)

Figure 42 Relinquish and Retry Operation

#### Reset

The reset provides a means of resetting and initializing the DMAC. If the DMAC is bus master, when the reset is asserted, the DMAC relinquishes the bus. Reset clears GCR, DCR, OCR, SCR, CCR, CSR, CPR, and CER for all channels. The NIV and the EIV are all set to (OF)<sub>16</sub>, which is the uninitialized interrupt vector number for the HD68000 MPU. MTC, MAR, DAR, BTC, BAR, MFC, DFC, and BFC are not affected. In order to insure a reset, BEC<sub>0</sub> ~ BEC<sub>2</sub> must be kept at "Low" level for at least ten clocks.

#### (5) Error Conditions

When an error is signaled on a channel, all activity on that channel is stopped. The ACT bit of the CSR is cleared, and the COC bit is set. The ERR bit of the CSR is set, and the error code is indicated in the CER. All pending operations are cleared, so that both the STR and CNT bits of CCR are cleared.

Enumerated below are the error signals and their sources.

- (a) Configuration Error — This error occurs if the STR bit is set in the following cases.
  - (i) the CNT bit is set at the same time STR bit in the chaining mode.
  - (ii) DTYP specifies a single addressing mode, and the device port size is not the same as the operand size.

(iii) DTYP specifies a dual addressing mode, DPS is 16 bits, SIZE is 8 bits and REQ is "10" or "11".

(iv) an undefined configuration is set in the registers. The undefined configurations are: XRM = 01, MAC = 11, DAC = 11, CHAIN = 01, and SIZE = 11.

(b) Operation Timing Error — An operation timing error occurs in the following cases:

- (i) when the CNT bit is set after the ACT bit has been set by the DMAC in the chaining mode, or when the STR and the ACT bits are not set.
- (ii) the STR bit is set when ACT, COC, BTC, NDT or ERR is set
- (iii) an attempt to write to the DCR, OCR, SCR, MAR, DAR, MTC, MFC, or DFC is made when the STR bit or the ACT bit is set.
- (iv) an attempt to set the CNT bit is made when the BTC and the ACT bits are set.

(c) Address Error — An address error occurs in the following cases:

- (i) an odd address is set for word or long word operands.

(ii) CS or IACK is asserted during the DMA bus cycle.

(d) Bus Error — Bus error occurs when a bus exception



- tion is signaled during a DMA bus cycle.
- (e) Count Error — A count error occurs in the following cases:
- The STR bit is set when zero is set in the MTC and the MTC and the chaining mode is not used.
  - the STR bit is set when zero is set in BTC for the array chaining mode.
  - zero is loaded from memory to the BTC or the MTC in the chaining modes or the continue mode
- (f) External Abort — External abort occurs if an abort is asserted by the external circuitry when the PCL line is configured as an abort input and the STR or the ACT bit is set.
- (g) Software abort — Software abort occurs if the SAB bit is set when the STR or the ACT bit is set.

#### Error Recovery Procedures

If an error occurs during a DMA transfer, appropriate information is available to the operating system (OS) to allow a software failure recovery operation. The operating system must be able to determine how much data was transferred, where the data was transferred to, and what type of error occurred.

The information available to the operating system consists of the present value of the Memory Address, Device Address and Base Address Registers, the Memory Transfer and Base Transfer Counters, the channel status register, the channel error register,

and the channel control register. After the successful completion of any transfer, the memory and device address registers points to the location of the next operand to be transferred and the memory transfer counter contains the number of operands yet to be transferred. If an error occurs during a transfer, that transfer has not completed and the registers contain the values they had before the transfer was attempted. If the channel operation uses chaining, the Base Address Register points to the next chain entry to be serviced, unless the termination occurred while attempting to fetch an entry in the chain. In that case, the Base Address Register points to the entry being fetched. However, in the case of external abort, there are cases in which the previous values are not recovered.

#### Bus Exception Operating Flow

The bus exception operating flow in the case of multiple exception conditions occurring continuously in sequence is shown in Figure 43. Note that the DMAC can receive and execute the next exception condition. For example, if the retry exception occurs, and next the relinquish and retry exception occurs while the DMAC is waiting for the retry condition to be cleared, the DMAC relinquishes the bus and waits for the exception condition to be cleared. If a bus error occurs during this period, the DMAC executes the bus error exception operation.

The flow diagram of the normal operation without exception operation or errors is shown in Figure 44.



Figure 43 Bus Exception Flow Diagram





Figure 44 Flow of Normal Operation Without Exception or Error Condition

#### • Channel Priorities

Each channel has a priority level, which is determined by the contents of the Channel Priority Register (CPR). The priority of a channel is a number from 0 to 3, with 0 being the highest priority level. When multiple requests are pending at the DMAC, the channel with the highest priority receives first service. The priority of a channel is independent of the device protocol or the request mechanism for that channel. If there are several requesting channels at the highest priority level, a round-robin resolution is used, that is, as long as these channels continue to have requests, the DMAC does operand transfers in rotation.

Resetting the DMAC puts the priority level of all channels to "0", the highest priority level.

#### ■ APPLICATIONS INFORMATION

Examples of how to interface HD68450 to a HD68000 based system are shown in Figure 45 and Figure 46.

Figure 45 shows an example of how to demultiplex the address/data bus.  $\bar{OWN}$  and  $\bar{UAS}$  are used to control 74LS373 for latching the address.  $\bar{DBEN}$  and  $\bar{DDIR}$  are used to control the bi-directional buffer 74LS245.

Figure 46 shows an example of inter-device connection in the HD68000 system.



Figure 45 An Example of the Demultiplexed Address Data Bus





The address bus and the system control bus in each device are omitted in this Figure.

Figure 46 An Example of Inter-device Connection in the HD68000 System

#### ■ ATTENTION ON USAGE

(1) How to interface various 6800 type peripheral devices to the DMAC based system.

When the DMAC is reading data from the 6800 device, the

DMAC latches the data when  $\overline{DT\bar{C}}$  is asserted and not at the falling edge of E clock. The 74LS373 need to be provided externally as shown in Figure 47 so that the data from the 6800 device can be held on the bus for a large period of time until the DMAC can latch the correct data.



**Figure 47 An Example of Connection with 6800 type Peripheral Devices  
(channel 2 and 3 are used)**

(2) When "external abort" is inputted during the DONE input cycle

When the transfer direction is from the peripheral device to memory and PCL signal is set to the external abort input mode in the dual addressing mode, the external abort will be ignored during the subsequent write cycle from the DMAC's internal holding register to memory if DONE is inputted during the read cycle from the peripheral device to the DMAC's internal holding register.

In this case, the channel status register (CSR) and the channel error register (CER) show the normal termination caused by DONE Input. The user is able to examine the PCT bit and the ERR bit in order to detect the external abort inputted at the timing described above. If PCT = 1, ERR = 0, and NDT = 1, then an external abort has occurred.

### (3) Multiple Errors

The DMAC will log the first error encountered in the channel error register (CER). If an error is pending in the error register and another error is encountered the second error will not be logged. Even though the second error is not logged in the CER, it will still be recognized internally and the channel will not start.

**(4) Relinquish & Retry Exception During Dual Address Mode Operation**

When the following two conditions occur simultaneously, incorrect data is outputted by the DMAC at the write cycle immediately following the negation of the relinquish & retry (R&R) exception.

- (a) R&R is asserted at the write cycle in the dual address mode.
  - (b) MPU access to the DMAC's internal register is done after the DMAC relinquishes the bus due to R&R exception.

When the R&R exception occurs during the write cycle of the dual addressing mode, and the MPU accesses the DMAC's register, then the DMAC's proper operation sequence should be the following (refer to the Fig. 48):



Fig. 48

- (1) Data is read by the DMAC during the read cycle
- (2) Data read at (1) is outputted at the write cycle
- (3) R&R exception is asserted during the write cycle
- (4) DMAC relinquishes the bus
- (5) MPU accesses the DMAC and it is completed normally
- (6) When R&R exception is negated, the DMAC obtains the bus and write cycle is done to output the data read at (1).

But instead, incorrect data is outputted at (6). This is because the data read at (1), which is held internally by the DMAC, is destroyed at (5) when the MPU accesses the DMAC. Avoid occurrence of the above condition. For example:

- (1) Assert R&R exception only during the read cycle when using dual addressing mode.
  - (2) If the R&R exception occurred at the write cycle of the dual addressing mode, avoid accessing the DMAC's registers.
  - (3) Use HALT exception instead of R&R exception to access the DMAC's internal registers
- (5) CS Negation Timing

When the LDS, UDS high to CS high timing (chip select negation delay) is over 1 clock and the MPU access is long word (32-bit data), then the data stored in the lower word of the register accessed is destroyed and becomes all zeros. In other words, the data in the lower word of the read access is lost and cleared to all zeros. This does not always occur, but on occasional basis due to the asynchronous input timing of the CS signal.

Please observe the timing specification shown in Fig. 49.



Fig. 49

#### (6) Unused Function Code (FC<sub>0</sub>–FC<sub>2</sub>) Lines

When the FC<sub>0</sub>, FC<sub>1</sub>, and FC<sub>2</sub> lines are not used, please keep these lines "high" by using a pull-up resistor. If these lines are left unconnected, the HD68450 DMAC may not operate

properly.

#### (7) Vss Wiring

The use of thick wiring is recommended between Vss of the HD68450 and the ground of the circuit board. When a socket is used to install the DMAC on the board, please make sure that the contact of the Vss pins are made well.

#### (8) Bus arbitration—BR Negation on MPU's CS.

If the MPU asserts DMAC's CS when the DMAC has its BR asserted, then the DMAC negates its BR. This is shown as follows:



#### (9) BR negation before BGACK assertion

When the MPU sets the START bit of the DMAC, and a different channel is already active in the limited-rate auto-request mode, the following bus arbitration timing may occur.



In this timing, the BR is negated too early, e.g. before the BGACK is asserted. This will cause bus contention between the DMAC and the MPU. For the description of these problems, please contact the sales office.

 **HITACHI**

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

403

# HD63463

## HDC (Hard Disk Controller)

### DESCRIPTION

The HD63463 (HDC: Hard Disk Controller) is a CMOS device developed for use as a peripheral LSI for the 16-bit microprocessor HD68000 (MPU: Microprocessing Unit). The HDC connects the host system and the Winchester type hard disk device with or without HD68450 (DMAC: Direct Memory Access Controller).

### FEATURES

- Two types of disk interface, ST506/ST412/ST412HP and SMD
- Choice of data bus width — 16 or 8 bits
- Serial data transfer rate — max 20 Mbit/s [NRZ], max 10 Mbit/s [MFM]
- Step rate — max 1.1 MHz
- Internal data buffer (256 bytes x 2)
- Zero-sector interleave access
- Programmed I/O access
- Automatic error correction
- Zero pattern detector/generator, address mark detector/generator, write precompensation logic, etc internally provided
- 22 high-level function commands
- 25 error codes
- External circuit diagnosis command
- Low power dissipation — typ 250 mW

### TYPE OF PRODUCTS

| Type No.   | Clock Frequency (MHz) |       | Package |
|------------|-----------------------|-------|---------|
|            | Host                  | Drive |         |
| HD63463-6  | 6.0                   | 15.0  | DC-48   |
| HD63463-8  | 8.0                   | 20.0  |         |
| HD63463P6  | 6.0                   | 15.0  | DP-48   |
| HD63463P8  | 8.0                   | 20.0  |         |
| HD63463CP6 | 6.0                   | 15.0  | CP-52   |
| HD63463CP8 | 8.0                   | 20.0  |         |



**PIN ARRANGEMENT**

DC-48, DP-48

|                 | ST506 Interface | SMD Interface                            |
|-----------------|-----------------|------------------------------------------|
| V <sub>CC</sub> |                 |                                          |
| R <sub>ES</sub> | READY (I)       | BUSL/H (O)                               |
| DREQ            | SEEK (O)        | BUSR/W (O)                               |
| TRQ             | HSEL2 (O)       | TAG5 (O)                                 |
| DONE            | HSEL1 (O)       | UTAG (O)                                 |
| RS              | HSEL0 (O)       | TAG3 (O)                                 |
| DTACK           | USEL1 (O)       | TAG2 (O)                                 |
| R/W             | USEL0 (O)       | TAG1 (O)                                 |
| CS              | USELD (I)       | USELD (I)                                |
| DACK            | SCP (I)         | SEC (I)                                  |
| D <sub>0</sub>  | IDX/TRKO (I)    | IDX (I)                                  |
| D <sub>1</sub>  | LCT/DIR (O)     | BUS <sub>4</sub> /BUS <sub>5</sub> (I/O) |
| D <sub>2</sub>  | WFLT (I)        | BUS <sub>3</sub> /BUS <sub>4</sub> (I/O) |
| CLK             | LATE/STEP (O)   | BUS <sub>2</sub> /BUS <sub>3</sub> (I/O) |
| V <sub>SS</sub> | EARLY/RGATE (O) | BUS <sub>1</sub> /BUS <sub>6</sub> (I/O) |
| D <sub>3</sub>  | WGATE (O)       | BUS <sub>0</sub> /BUS <sub>5</sub> (I/O) |
| D <sub>4</sub>  | V <sub>SS</sub> |                                          |
| D <sub>5</sub>  | SYNC (O)        | SKEND (I)                                |
| D <sub>6</sub>  | RCLK (I)        | RCLK (I)                                 |
| D <sub>7</sub>  | WCLK (I)        | WCLK (I)                                 |
| D <sub>8</sub>  | RWDATA (I/O)    | RWDATA (I/O)                             |
| D <sub>9</sub>  | D <sub>15</sub> |                                          |
| D <sub>10</sub> | D <sub>14</sub> |                                          |
| D <sub>11</sub> | D <sub>13</sub> |                                          |
|                 | D <sub>12</sub> |                                          |

(Top View)

CP-52



(Top View)

| Pin No. | ST506 Interface       | SMD Interface | Pin No. | ST506 Interface | SMD Interface                            |
|---------|-----------------------|---------------|---------|-----------------|------------------------------------------|
| 1       | V <sub>CC</sub>       |               | 27      |                 | V <sub>CC</sub>                          |
| 2       | V <sub>CC</sub>       |               | 28      |                 | D <sub>12</sub> (I/O)                    |
| 3       | R <sub>ES</sub> (I)   |               | 29      |                 | D <sub>13</sub> (I/O)                    |
| 4       | DREQ (O)              |               | 30      |                 | D <sub>14</sub> (I/O)                    |
| 5       | TRQ (O)               |               | 31      |                 | D <sub>15</sub> (I/O)                    |
| 6       | DONE (I)              |               | 32      | RWDATA (I/O)    | RWDATA (I/O)                             |
| 7       | RS (I)                |               | 33      | WCLK (I)        | WCLK (I)                                 |
| 8       | DTACK (O)             |               | 34      | RCLK (I)        | RCLK (I)                                 |
| 9       | R/W (I)               |               | 35      | SYNC (O)        | SKEND (I)                                |
| 10      | CS (I)                |               | 36      |                 | V <sub>SS</sub>                          |
| 11      | DACK (I)              |               | 37      |                 | V <sub>SS</sub>                          |
| 12      | D <sub>0</sub> (I/O)  |               | 38      | WGATE (O)       | BUS <sub>0</sub> /BUS <sub>5</sub> (I/O) |
| 13      | D <sub>1</sub> (I/O)  |               | 39      | EARLY/RGATE (O) | BUS <sub>1</sub> /BUS <sub>6</sub> (I/O) |
| 14      | D <sub>2</sub> (I/O)  |               | 40      | LATE/STEP (O)   | BUS <sub>2</sub> /BUS <sub>3</sub> (I/O) |
| 15      | CLK (I)               |               | 41      | WFLT (I)        | BUS <sub>3</sub> /BUS <sub>8</sub> (I/O) |
| 16      | V <sub>SS</sub>       |               | 42      | LCT/DIR (O)     | BUS <sub>4</sub> /BUS <sub>9</sub> (I/O) |
| 17      | V <sub>SS</sub>       |               | 43      | IDX/TRKO (I)    | IDX (I)                                  |
| 18      | D <sub>3</sub> (I/O)  |               | 44      | SCP (I)         | SEC (I)                                  |
| 19      | D <sub>4</sub> (I/O)  |               | 45      | USELD (I)       | USELD (I)                                |
| 20      | D <sub>5</sub> (I/O)  |               | 46      | USEL0 (O)       | TAG1 (O)                                 |
| 21      | D <sub>6</sub> (I/O)  |               | 47      | USEL1 (O)       | TAG2 (O)                                 |
| 22      | D <sub>7</sub> (I/O)  |               | 48      | HSEL0 (O)       | TAG3 (O)                                 |
| 23      | D <sub>8</sub> (I/O)  |               | 49      | HSEL1 (O)       | UTAG (O)                                 |
| 24      | D <sub>9</sub> (I/O)  |               | 50      | HSEL2 (O)       | TAG5 (O)                                 |
| 25      | D <sub>10</sub> (I/O) |               | 51      | SEEK (O)        | BUSR/W (O)                               |
| 26      | D <sub>11</sub> (I/O) |               | 52      | READY (I)       | BUSL/H (O)                               |



## SIGNAL LINES



Figure 1 Input/Output Signals

## MAJOR FUNCTIONS OF HDC

|                     |                             |                                                            |                                   |
|---------------------|-----------------------------|------------------------------------------------------------|-----------------------------------|
| Drive Interface     | ST506*                      | Number of Heads                                            | Max 8                             |
|                     |                             | Number of Drives                                           | Max 4                             |
|                     |                             | Write Precompensation                                      | Controlled                        |
|                     |                             | High-Speed Seek                                            | Step rate min 875 ns (CLK: 8 MHz) |
|                     | Storage Module Drive (SMD)  | Number of Heads                                            | Max 32                            |
|                     |                             | Number of Drives                                           | Max 8                             |
|                     |                             | Track Offset                                               | Controlled                        |
|                     |                             | Data Strobe                                                | Controlled                        |
|                     | Serial Data Format          | NRZ or MFM (selectable)                                    |                                   |
|                     | Serial Data Transfer Rate   | Max 20 Mbps (NRZ), max 10 Mbps (MFM)                       |                                   |
|                     | Multiple Sector Access      | Multiple sector, multiple track                            |                                   |
|                     | Parallel Seek               | Possible                                                   |                                   |
|                     | Diagnosis                   | External circuit diagnosis                                 |                                   |
| Disk Format         | Data Length                 | 256, 512, 1024, 2048, or 4096 bytes (selectable)           |                                   |
|                     | Number of Sectors           | Max 255 (hard sector), max 128 (soft sector)               |                                   |
|                     | Number of Cylinders         | Max 1024                                                   |                                   |
|                     | Sector Format               | Hard sector or soft sector (selectable)                    |                                   |
| Error Processing    | Processing Code             | 16-bit CRC (error detection), 2 types                      |                                   |
|                     |                             | 32-bit ECC (error detection or correction)                 |                                   |
|                     | Error Correction Capability | Automatic correction of single burst error (up to 11 bits) |                                   |
| On-Chip Data Buffer | Capacity                    | 256 bytes x 2                                              |                                   |
|                     | Data Transfer               | Simultaneous transfer on host side and drive side          |                                   |
|                     | Addressing                  | Stack type (pointer can be updated)                        |                                   |
| Host Interface      | Operation Cycle Time        | Max 8 MHz                                                  |                                   |
|                     | Data Bus Width              | 16 or 8 bits (selectable)                                  |                                   |
|                     | DMA Transfer                | Burst or cycle steal mode (selectable)                     |                                   |
|                     | Programmed I/O              | Possible                                                   |                                   |
| Commands            | Seek                        | 2 commands                                                 |                                   |
|                     | Disk Read/Write             | 8 commands                                                 |                                   |
|                     | Data Buffer                 | 4 commands                                                 |                                   |
|                     | Drive Check                 | 2 commands                                                 |                                   |
|                     | Others                      | 6 commands                                                 |                                   |

\*ST506/ST412/ST412HP is referred to as "ST506" in this document.



## HARDWARE DESCRIPTION

### SYSTEM CONFIGURATION

An HDC-based system configuration is illustrated in figure 2. The HDC is used to connect more than one hard disk drives (also called "drive" in this manual) to the host system. The host system consists of the MPU (Microprocessing Unit), the main memory and the DMAC (Direct Memory Access Controller). The HDC requires minimum number of external circuits that

are connected to the host system including the HD68000 (MPU) and the HD68450 (DMAC).

If the host system does not require a high throughput, then the DMAC is not necessary. A few additional external circuits allow the HDC to be connected to another host system other than the HD68000.

The HDC may control either up to four ST506 drives or up to eight SMD drives.



Figure 2 System Configuration Example

**SIGNAL LINES**

The input/output signal lines of the HDC are shown in figure 1 which covers both ST506 and SMD drive interface.

Each signal is described in the following tables and descriptions.

**Host Interface**

| Category                               | Signal                           | I/O |
|----------------------------------------|----------------------------------|-----|
| Clock, Reset                           | CLK                              | I   |
|                                        | <u>RES</u>                       | I   |
| DMA Control<br>(HD68450<br>Compatible) | DREQ                             | O   |
|                                        | DACK                             | I   |
|                                        | DONE                             | I   |
| Interrupt Request                      | <u>IRQ</u>                       | O   |
| Bus Control<br>(HD68000<br>Compatible) | CS                               | I   |
|                                        | RS                               | I   |
|                                        | R/W                              | I   |
|                                        | DTACK                            | O   |
| Data Bus (HD68000<br>Compatible)       | D <sub>0</sub> – D <sub>15</sub> | I/O |

**CLK** – Clock signal from the host system.

**RES** – Reset signal from the host system.

**DREQ** – Asserted when a DMA data transfer is requested to the DMAC. Receiving this signal, the DMAC obtains the bus master ship from the MPU.

**DACK** – Transfer acknowledge signal from the DMAC. Receiving this signal, the HDC transfers data through the host bus in the DMA mode. When RES signal is at “0”, HDC data bus configuration change from 16 bits to 8 bits when DACK = 0.

**DONE** – Receiving this signal from the DMAC, the DMA data transfer through the host bus stops immediately.

**IRQ** – Interrupt request signal sent to the MPU (open drain output).

**CS** – Chip select signal generated by decoding address, address strobe, and data strobe of the host.

**RS** – Register select signal of the HDC. It selects registers when set to “0”, data buffers when set to “1”.

**R/W** – Signal that indicates the data transfer direction.

**DTACK** – Acknowledge signal that indicates the end of data transfer in the host bus. The host waits until the HDC asserts this signal to terminate the transfer.

**D<sub>0</sub>–D<sub>15</sub>** – 16-bit bi-directional data bus. When used as an 8-bit data bus, D<sub>8</sub>–D<sub>15</sub> must be open.

**ST506 Interface**

| Category       | Signal      | I/O |
|----------------|-------------|-----|
| Control Output | SEEK        | O   |
|                | LCT/DIR     | O   |
|                | LATE/STEP   | O   |
|                | EARLY/RGATE | O   |
|                | WGATE       | O   |
|                | SYNC        | O   |
|                | HSEL0–HSEL2 | O   |
|                | USEL0–USEL1 | O   |
| Control Input  | READY       | I   |
|                | WFLT        | I   |
|                | SCP         | I   |
|                | IDX/TRK0    | I   |
|                | USELD       | I   |
| Drive Clock    | RCLK        | I   |
|                | WCLK        | I   |
| Drive Data     | RWDATA      | I/O |

**SEEK** – Used to decode multiplexed signals. SEEK signal remains high during the head positioning operation of the HDC.

**LCT/DIR** – When SEEK is at “1”, this signal indicates the head direction: the head moves toward the spindle if the LCT/DIR signal is at “1”. When SEEK is at “0”, write current is reduced if this signal is at “1”.

**LATE/STEP** – When SEEK is at “1”, this signal serves as step pulses output for head positioning. When SEEK is at “0”, this signal requests write precompensation (LATE).

**EARLY/RGATE** – When the WGATE signal is at “1”, this signal requires write precompensation (EARLY). Otherwise, it serves as a read gate signal that requests reading data from the drive.

**WGATE** – Write gate signal that requests writing data to the drive.

**SYNC** – Signal to select the loop gain of the external data separator. SYNC is at “1” when RGATE is at “1” and one byte of \$00 is detected in the disk data. SYNC is at “0” when RGATE is at “0”.

**HSEL0–HSEL2** – 3-bit signal that selects up to eight heads in the drive.

**USEL0–USEL1** – 2-bit signal that selects one of four drives.

**READY** – Signal indicating that the selected drive is ready.



**WFLT** — Signal indicating that the drive has detected a fault which may cause a write error.

**SCP** — Signal indicating that head positioning (seek operation) has been completed in the drive.

**IDX/TRKO** — When SEEK is at "1", this signal indicates that the head in the drive is positioned at the outermost track (track 0). When SEEK is at "0", this signal serves as an index signal that indicates the beginning of a track.

**USELD** — Response signal from the drive indicating that the drive is selected.

**RCLK** — Disk read clock from the external data separator. Its frequency is twice the serial transfer rate.

**WCLK** — Disk write clock from the external oscillator. Its frequency is twice the serial transfer rate.

**RWDATA** — Disk read/write serial data is input/output as modified frequency modulation code. This pin is normally in read state.

#### SMD Interface

| Category          | Signal                                                                     | I/O |
|-------------------|----------------------------------------------------------------------------|-----|
| Drive Bus Control | BUSL/H                                                                     | O   |
|                   | BUSR/W                                                                     | O   |
| Drive Bus         | BUS <sub>0</sub> /BUS <sub>5</sub> —<br>BUS <sub>4</sub> /BUS <sub>9</sub> | I/O |
| Tag               | TAG5                                                                       | O   |
|                   | TAG3                                                                       | O   |
|                   | TAG2                                                                       | O   |
|                   | TAG1                                                                       | O   |
|                   | UTAG                                                                       | O   |
| Control Input     | IDX                                                                        | I   |
|                   | SEC                                                                        | I   |
|                   | USELD                                                                      | I   |
|                   | SKEND                                                                      | I   |
| Drive Clock       | RCLK                                                                       | I   |
|                   | WCLK                                                                       | I   |
| Drive Data        | RWDATA                                                                     | I/O |

**BUSL/H** — When this signal is at high, lower 5 bits of 10-bit drive bus are being transferred.

**BUSR/W** — When this signal is at high, BUS<sub>0</sub>/BUS<sub>5</sub>—BUS<sub>4</sub>/BUS<sub>9</sub> are in input state.

**BUS<sub>0</sub>/BUS<sub>5</sub>—BUS<sub>4</sub>/BUS<sub>9</sub>** — 5-bit bi-directional bus that is used to control the drive. When the data is output from 10-bit drive bus, the high-order 5 bits are output first and then the low-order 5 bits. When the data is input to the bus, higher 3 bits of the 8-bit status are fetched first, then the lower 5 bits.

**TAG5** — Together with TAG2, used as a status input select signal.

**TAG3** — Tag signal indicating that the drive bus contains information such as disk read/write instruction.

**TAG2** — Tag signal indicating that the drive bus contains the address for head selection. When drive status is read from the drive bus, TAG2 and TAG5 are decoded to select the status.

**TAG1** — Tag signal indicating that the drive bus contains the destination cylinder address.

**UTAG** — Tag signal indicating that the drive bus contains a 3-bit drive number.

**IDX** — Index signal indicating the beginning of a track.

**SEC** — Signal indicating the beginning of a sector.

**USELD** — Response signal from the drive indicating that the drive is selected.

**SKEND** — Signal that is generated when the servo circuit in the disk drive terminates seek operation and the head is placed on the track.

**RCLK** — Disk read clock from the drive. Its frequency is the same as the serial data transfer rate.

**WCLK** — Disk write clock from the drive. Its frequency is the same as the serial data transfer rate.

**RWDATA** — Disk read/write serial data that is input/output as Non-Return to Zero code.

#### HOST INTERFACE

The HDC can be directly connected to the HD68000 (MPU) and the HD68450 (DMAC), so that the HDC data is transferred asynchronously with the host system. The HDC data bus is 16-bit wide, in addition, an 8-bit configuration is available by asserting the DACK signal externally during reset. The minimum access time that is required for communication between the HDC and the MPU, or between the HDC and the DMAC is listed in Table 1 (wait cycles are not included).

Table 1 Host Interface Minimum Access Time

| Transfer Direction           | Data Bus | 8-Bit Data Bus<br>(cycles) | 16-Bit Data Bus<br>(cycles) |
|------------------------------|----------|----------------------------|-----------------------------|
| MPU read<br>(HDC to MPU)     | 3        | 4                          |                             |
| MPU write<br>(MPU to HDC)    | 3        | 3                          |                             |
| DMA write<br>(memory to HDC) | 3        | 3                          |                             |
| DMA read<br>(HDC to memory)  | 3        | 4                          |                             |



**DRIVE INTERFACE**

The HDC can interface with two different types of drives. DIF mode of the Operation Mode register 0 (OM0) selects the drive interface. ST506 interface is selected when DIF is at "0", and

SMD interface when DIF is at "1". The external circuits required for HDC drive interface vary according to which interface is used. Figures 3 and 4 show the interface circuits which connect ST506 device and SMD device respectively.



Figure 3 ST506 Interface Circuit





Figure 4 SMD Interface Circuit

**SOFTWARE INTERFACE**

The HDC is furnished with 22 commands, which are classified into 6 categories; specification, head positioning, disk access, data transfer, drive check, and others.

Table 2 List of Commands

| Category         | Command                       | Mnemonic |
|------------------|-------------------------------|----------|
| Specifications   | Specify                       | SPC      |
| Head Positioning | Recalibrate                   | RCLB     |
|                  | Seek                          | SEK      |
| Disk Access      | Read Data                     | RD       |
|                  | Read Erroneous Data           | RED      |
|                  | Read ID                       | RID      |
|                  | Read ID Skew<br>(Note 1)      | RIS      |
|                  | Find ID                       | FID      |
|                  | Check Data                    | CKD      |
|                  | Compare Data                  | CMPD     |
|                  | Write Data                    | WD       |
|                  | Write Format                  | WFM      |
| Data Transfer    | Write Format Skew<br>(Note 1) | WFS      |
|                  | Memory to Buffer              | MTB      |
|                  | Buffer to Memory              | BTM      |
|                  | Open Buffer Write             | OPBW     |
| Drive Check      | Open Buffer Read              | OPBR     |
|                  | Polling                       | POL      |
| Others           | Check Drive                   | CKV      |
|                  | Abort                         | ABT      |
|                  | Check ECC                     | CKE      |
|                  | Polling Disable               | POD      |
|                  | Recall                        | RCAL     |
|                  | Test                          | TST      |

(Note 1) Valid only for the hard sector. Disabled for the soft sector.

**Specify** — Specifies the HDC's operation mode, data transfer mode, etc.

**Recalibrate** — Moves the drive head to the outermost track (track 0).

**Seek** — Moves the drive head onto a track specified by the Next Cylinder Address.

**Read Data** — Reads the data of specified sectors and stores it in the data buffer.

**Read Erroneous Data** — Reads disk data and stores it in the data buffer no matter a CRC error occurs or not in ID area.

**Read ID** — Reads ID areas from specified number of sectors.

**Read ID Skew** — Reads ID area of a sector formatted by Write Format Skew command.

**Find ID** — Reads ID areas and stores the data in data buffers. ID area containing a CRC error is skipped reading, and the subsequent ID area without any CRC error is searched for.

**Check Data** — Checks if there is any ECC or CRC error in DATA area of specified sectors. No data is transferred to data buffers or to the main memory while checking.

**Compare Data** — Compares the data in data buffers and the data read from specified sectors.

**Write Data** — Writes the data stored in data buffers into DATA area of specified sectors.

**Write Format** — For the hard sector, formats a specified number of sectors starting with a specified physical sector address. For the soft sector, formats a track.

**Write Format Skew** — Formats a sector specified by a physical sector address by skewing ID area by 64 bytes.

**Memory to Buffer** — Transfers data from the main memory to the data buffer by DMA transfer.

**Buffer to Memory** — Transfers data stored in the data buffer to the main memory by DMA transfer.

**Open Buffer Write** — Provides initialization of pointer to write data into the data buffer starting from an address specified by Pointer Offset. The data buffer is written in the PIO mode after the command execution ends.

**Open Buffer Read** — Provides initialization to read the data stored in the data buffer from an address specified by Pointer Offset. The data buffer is read in the PIO mode after the command execution ends.

**Polling** — Monitors drive status including seek end.

**Check Drive** — Sets result parameters indicating status of a specified drive to Parameter Block.

**Abort** — Stops all operations being executed by the HDC.

**Check ECC** — For ECC errors occurred during RD and RED command execution, reports result parameters indicating addresses and patterns of erroneous data.

**Polling Disable** — Stops Polling command execution.

**Recall** — Clears all bits of the status register and sets a buffer pointer to the start address of parameter block so that command parameters can be accepted.

**Test** — Makes the output pins of the HDC's drive interface three-stated.



Table 3 Command Code, Interrupt Request, and DMA Data Transfer

| Command Name        | Command Code |       | Interrupt Factor Bits |     |     | DMA Transfer |         |
|---------------------|--------------|-------|-----------------------|-----|-----|--------------|---------|
|                     | Binary       | HEX   | CED                   | SED | DER | DTM = 0      | DTM = 1 |
| Specify             | 1110 1000    | E8    |                       |     |     |              |         |
| Recalibrate         | 1100 1000    | C8    | ○                     | ○   | ○   |              |         |
| Seek                | 1100 0000    | C0    | ○                     | ○   | ○   |              |         |
| Read Data           | 0100 0000    | 40    | ○                     | ○   | ○   |              | ○       |
| Read Erroneous Data | 0111 0000    | 70    | ○                     | ○   | ○   |              | ○       |
| Read ID             | 0110 0000    | 60    | ○                     | ○   | ○   |              |         |
| Read ID Skew        | 0110 1000    | 68    |                       |     |     |              | ○       |
| Find ID             | 0110 0001    | 61    | ○                     | ○   | ○   |              | ○       |
| Check Data          | 0100 1000    | 48    | ○                     | ○   | ○   |              |         |
| Compare Data        | 1000 1000    | 88    | ○                     | ○   | ○   |              | ○       |
| Write Data          | 1000 0111    | 87    | ○                     | ○   | ○   |              | ○       |
| Write Format        | 1010 0011    | A3    | ○                     | ○   | ○   |              |         |
| Write Format Skew   | 1010 1011    | AB    |                       |     |     |              | ○       |
| Memory to Buffer    | 1001 0000    | 90    | ○                     |     |     | ○            | ○       |
| Buffer to Memory    | 0101 0000    | 50    | ○                     |     |     | ○            | ○       |
| Open Buffer Read    | 0011 0000    | 30    |                       |     |     |              |         |
| Open Buffer Write   | 0011 1000    | 38    |                       |     |     |              |         |
| Polling             | 0001 0000    | 10    |                       | ○   | ○   |              |         |
| Check Drive         | 0010 1000    | 28    |                       |     | ○   |              |         |
| Abort               | 1111 ****    | F0-FF | ○                     |     |     |              |         |
| Check ECC           | 0010 0000    | 20    |                       |     |     |              |         |
| Test                | 1110 0000    | E0    |                       |     |     |              |         |
| Polling Disable     | 0001 1000    | 18    |                       | ○   | ○   |              |         |
| Recall              | 0000 1000    | 08    |                       |     |     |              |         |
| Inhibited           | 1101 ****    | D0-DF |                       |     |     |              |         |

DMA: Direct Memory Access  
DTM: Data Transfer Mode

\*: don't care

○: Set at the end of command execution.

○: DMA transfer is performed.

## PROGRAMMING MODEL

Figure 5 shows the internal configuration of the HDC and a programming model. The HDC internally provides an 8-bit STR (Status register), an 8-bit CMR (Command register), a 16-byte PB (Parameter Block) and two 256-byte data buffers (DBUF0 and DBUF1). The data can be written to/read from PB, DBUF0 and DBUF1 by externally accessing DTR (Data Transfer register). Their address are specified by a pointer, and is incremented for each access. Internal processors set pointer value, or select one of PB, DBUF0 and DBUF1 to be connected to DTR. These internal processors are initialized by writing a command from the MPU to CMR. The result of command execution is reflected in the STR.

At the beginning of the command execution, internal processors read command parameters in PB written by the MPU and determine the command operation mode. At the end of the command execution, the MPU reads result parameters in PB written by internal processors.

When the HDC writes data to a disk, the host system sends disk write data to DBUF, then internal processors write the contents of DBUF into the disk. When the HDC reads data from a disk, internal processors read the contents of the disk and stores them into DBUF, then the host system reads data from DBUF. The MPU can access STR, CMR, and DTR while the DMAC can access only DTR in the single addressing mode.



When used in 8-bit mode, the HDC requires 2-byte address space. One byte (RS (Register Select signal) = 0) is an 8-bit read only STR or an 8-bit write only CMR. Another byte (RS = 1) is an 8-bit DTR.

When used in a 16-bit mode, the HDC requires 2-word address space. One word (RS = 0) consists of an 8-bit CMR and an 8-bit read only STR. Another word (RS = 1) serves as a 16-bit DTR.



Figure 5 Internal Configuration and Programming Model



When the HDC is either in idle state or command execution end state, the MPU can access PB by accessing DTR. While the HDC is executing a command (during data transfer), DBUFO or DBUF1 can be accessed by accessing DTR. Before accessing DBUFO or DBUF1, the MPU must issue a command to open the buffer.

#### STATUS REGISTER

The bit configuration of the Status register is shown in the figure below, and each bit is described in Table 4.



Table 4 Status Register Bit Description

| Bit | Abbr. | Bit Name                    | Set "1" Condition       | Reset "0" Condition                                                     | Interrupt Source Bit | Description                                                                                                                                                                   |
|-----|-------|-----------------------------|-------------------------|-------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | BSY   | Busy                        | Command acknowledged    | Command execution end (except for POL command)                          |                      | While HDC is executing a command, BSY bit is set to "1".                                                                                                                      |
| 6   | CPR   | Command Parameter Reception | Command execution       | RCAL command received                                                   |                      | With this bit reset to "0", command parameters can be written.                                                                                                                |
| 5   | CED   | Command End                 | Command execution end   | RCAL command received                                                   | ○                    | Set to "1" when command shown in table 3 ends. When this bit is set, HDC asserts IRQ signal.                                                                                  |
| 4   | SED   | Seek End                    | Drive seek end detected | RCAL command received                                                   | ○                    | If detecting drive seek end during execution of command shown in table 3, HDC sets "1" in this bit at the end of command execution.                                           |
| 3   | DER   | Drive Error                 | Drive error detected    | RCAL command received                                                   | ○                    | If detecting drive error during execution of command shown in table 3, HDC sets "1" in this bit at the end of command execution.                                              |
| 2   | ABN   | Abnormal End                | Error detected          | RCAL command received                                                   |                      | If acknowledging errors such as illegal command, drive faults, data over/under run, the HDC sets "1" to ABN at the end of command execution. The SSB contains the error code. |
| 1   | POL   | Polling                     | POL command received    | POD command received, seek operation end detected, drive error detected |                      | Set to "1" during execution of POL command.                                                                                                                                   |
| 0   |       |                             |                         |                                                                         |                      | Blank bit, always set to "0".                                                                                                                                                 |

O: An interrupt is generated when this bit is set.

### HDC CONTROL PROCEDURE

The MPU's procedure to control the HDC is shown in figure 6. To control the HDC, the MPU must read STR of the HDC. The MPU may issue command parameters to PB in the HDC only when both BSY and CPR bits are cleared.

This enables the HDC to change its status from idle state to command wait state. Although a data buffer pointer does not indicate the start address of PB under command wait state, STR has the same contents as in the idle state. It is impossible to distinguish these two internal HDC states externally.

After this, the MPU issues a command. The HDC executes a command after setting BSY bit to "1". At the end of command execution, result parameters are stored in PB, the CPR bit is set to "1", and BSY bit is cleared. Under this condition, the MPU reads result parameters from PB. Issuing Recall command after this enables the HDC state to change from command execution end state to idle state.

Some commands do not require either or both of the command parameter and result parameter. For some commands, the CED bit, SED bit, or DER bit is set to "1", which enables the HDC to generate an interrupt request to the MPU.

In the DMA (direct memory access) mode, data transfer takes place between the main memory and the HDC when a disk access command is received. For this reason, the MPU must initialize the DMAC before issuing a disk access command to the HDC. Data such as system memory address and number of transfer words are written into the DMAC register.

When the MPU writes data into internal control register in the DMAC, the DMAC state changes from the idle state to transfer request wait state. Upon reception of a transfer request signal (DREQ) from the HDC, the DMAC transfers data to/from the HDC and system memory until specified number of words are transferred. The DMAC may generate an interrupt request to the MPU when the transfer is completed.



Figure 6 HDC Control Procedure



**COMMAND PARAMETERS**

Command parameters are listed in Table 5. Command parameters used by the HDC to control ST506 type hard disk drive

are listed in the upper row of each command, and those for the SMD type in the lower row.

Table 5 Command Parameter (byte organization)

| Commands                                   | Parameters<br>(Upper row: ST506<br>Lower row: SMD)                                                                                     |
|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Specify                                    | OM0 OM1 OM2 CUL TO/NCH NCL NH NS SH/RL GPL1 GPL2 GPL3 LCCH LCCL<br>PCCH PCCL<br>OM0 OM1 OM2 CUL TO/NCH NCL NH NS SH/RL GPL1 GPL2 RGTLT |
| Recalibrate                                | US \$00<br>US \$00                                                                                                                     |
| Seek                                       | US \$00 NCAH NCAL<br>US \$00 NCAH NCAL                                                                                                 |
| Read Data                                  | US PHA LCAH LCAL LHA LSA SCNTL<br>US PHA \$00 FLAG LCAH LCAL LHA LSA SCNTL                                                             |
| Read Erroneous Data                        | US PHA SCNTL SCNTL<br>US PHA \$00 PSA SCNTL SCNTL                                                                                      |
| Read ID<br>Read ID Skew (Note 1)           | US PHA \$00 OFFSET \$00 SCNTL<br>US PHA \$00 PSA \$00 SCNTL                                                                            |
| Find ID                                    | US PHA \$00 OFFSET \$00 SCNTL<br>US PHA \$00 PSA \$00 SCNTL                                                                            |
| Check Data                                 | US PHA LCAH LCAL LHA LSA SCNTL SCNTL<br>US PHA \$00 FLAG LCAH LCAL LHA LSA SCNTL SCNTL                                                 |
| Compare Data                               | US PHA LCAH LCAL LHA LSA SCNTL SCNTL<br>US PHA \$00 FLAG LCAH LCAL LHA LSA SCNTL SCNTL                                                 |
| Write Data                                 | US PHA LCAH LCAL LHA LSA SCNTL SCNTL<br>US PHA \$00 FLAG LCAH LCAL LHA LSA SCNTL SCNTL                                                 |
| Write Format<br>Write Format Skew (Note 1) | US PHA SCNTL SCNTL<br>US PHA \$00 PSA SCNTL SCNTL                                                                                      |
| Memory to Buffer                           | POFFH POFFL<br>POFFH POFFL                                                                                                             |
| Buffer to Memory                           | POFFH POFFL<br>POFFH POFFL                                                                                                             |
| Open Buffer Read                           | POFFH POFFL<br>POFFH POFFL                                                                                                             |
| Open Buffer Write                          | POFFH POFFL<br>POFFH POFFL                                                                                                             |
| Polling                                    | None                                                                                                                                   |
| Check Drive                                | US \$00<br>US \$00                                                                                                                     |
| Abort                                      | None                                                                                                                                   |
| Check ECC                                  | None                                                                                                                                   |
| Test                                       | None                                                                                                                                   |
| Polling Disable                            | None                                                                                                                                   |
| Recall                                     | None                                                                                                                                   |

(Note 1) Read ID Skew and Write Format Skew are valid only for SMD interface.



**SPECIFY COMMAND PARAMETERS**

Parameters of SPC command may be used to specify the HDC operation mode and the disk format. Parameters are listed in Table 6. Contents of these parameters are different according to which type of drive is used: either ST506 or SMD. Each parameter is described in Tables 7 and 8. Table 7 lists parameters which

are specified by a bit, and Table 8 lists parameters which are specified by 3-16 bits.

The HDC supports soft sector format (in ST506 interface) and hard sector format (in SMD interface) which are shown in Figure 7.

Table 6 Specify Command Parameter Organization

|       | Bit 7           | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |  |  |  |  |  |
|-------|-----------------|------|------|------|------|------|------|------|--|--|--|--|--|--|
| OM0   | SECT            | MOD  | DIF  | PADP | ECD  | CRCP | CRCI | ACOR |  |  |  |  |  |  |
| OM1   | DTM             | BRST | CEDM | SEDM | DERM | 0    | AMEX | PSK  |  |  |  |  |  |  |
| OM2   | SL (ST506)      |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | CUL             |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | TO              |      |      |      |      |      | NCH  |      |  |  |  |  |  |  |
|       | NCL             |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | NH              |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | NS              |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | SH              |      |      |      | RL   |      |      |      |  |  |  |  |  |  |
|       | GPL1            |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | GPL2            |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | GPL3            |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | LCC High (LCCH) |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | LCC Low (LCCL)  |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | PCC High (PCCH) |      |      |      |      |      |      |      |  |  |  |  |  |  |
|       | PCC Low (PCCL)  |      |      |      |      |      |      |      |  |  |  |  |  |  |
| (SMD) | O               | O    | O    | O    | SOFM | SOFP | STBL | STBE |  |  |  |  |  |  |



Table 7 Specify Command Parameters (a)

| Abbreviation | Name                 |              |                             | ST506 | SMD |
|--------------|----------------------|--------------|-----------------------------|-------|-----|
|              |                      | 0            | 1                           |       |     |
| SECT         | Sector Organization  | Soft Sector  | Hard Sector                 | 0     | 1   |
| MOD          | Data Modulation      | MFM          | NRZ                         | 0     | 1   |
| DIF          | Drive Interface      | ST506        | SMD                         | 0     | 1   |
| PADP         | PAD Pattern          | \$00         | \$4E                        | *     | 0   |
| ECD          | Error Check Code     | CRC          | ECC                         | *     | *   |
| CRCP         | CRC Polynomial       | $X^{16} + 1$ | $X^{16} + X^{12} + X^5 + 1$ | *     | *   |
| CRCI         | CRC Initial Value    | \$0000       | \$FFFF                      | *     | *   |
| ACOR         | Automatic Correction | Disabled     | Enabled                     | *     | *   |
| DTM          | Data Transfer Mode   | PIO          | DMA                         | *     | *   |
| BRST         | DMA Burst Mode       | Cycle Steal  | Burst                       | *     | *   |
| CEDM         | Command End Mask     | Unmasked     | Masked                      | *     | *   |
| SEDM         | Seek End Mask        | Unmasked     | Masked                      | *     | *   |
| DERM         | Drive Error Mask     | Unmasked     | Masked                      | *     | *   |
| AMEX         | Address Mark Exclude | Included     | Not Included                | *     | *   |
| PSK          | Parallel Seek        | Normal       | Parallel                    | *     | 1   |
| SOFM         | Servo Offset Minus   | Normal       | Minus                       | None  | *   |
| SOFP         | Servo Offset Plus    | Normal       | Plus                        | None  | *   |
| STBL         | Strobe Late          | Normal       | Late                        | None  | *   |
| STBE         | Strobe Early         | Normal       | Early                       | None  | *   |

\* Either 0 or 1

Table 8 Specify Command Parameters (b)

| Abbreviation | Name                     | ST506    | SMD           |
|--------------|--------------------------|----------|---------------|
| SL           | Step Pulse Low           | 8 bits   | None          |
| CUL          | Connecting Unit List     | 4 bits   | 8 bits        |
| TO           | Read/Write Time-over     | 6 bits   | 6 bits        |
| NC           | Number of Cylinders      | 10 bits  | 10 bits       |
| NH           | Number of Heads          | 3 bits   | 5 bits        |
| NS           | Number of Sectors        | 8 bits   | 8 bits        |
| SH           | Step Pulse High          | 5 bits   | None          |
| RL           | Record Length            | 3 bits   | 3 bits        |
| GPL1         | Gap Length 1 (8 bits)    | GAP1     | HEAD SCAT     |
| GPL2         | Gap Length 2 (8 bits)    | PLO SYNC | PLO SYNC      |
| GPL3         | Gap Length 3 (8 bits)    | GAP3     | RGATE Latency |
| LCC          | Low Current Cylinder     | 16 bits  | None          |
| PCC          | Precompensation Cylinder | 16 bits  | None          |





Figure 7 Disk Format

**OM0 (Operation Mode 0)**

## (1) SECT (Sector Format) bit

This bit specifies the format of the drive to be connected to the HDC. There are two drive formats available: hard sector and soft sector.

|                              |
|------------------------------|
| SECT = 1: Hard Sector Format |
| SECT = 0: Soft Sector Format |

## (2) MOD (Modulation) bit

This bit specifies modulation mode for data written to/read from the drive.

|                                   |
|-----------------------------------|
| MOD = 1: NRZ (Non Return to Zero) |
| MOD = 0: MEM (Modified FM)        |

## (3) DIF (Drive Interface) bit

This bit specifies the type of drive interface: either ST506 or SMD. The pin function of the HDC changes according to the interface type.

|                          |
|--------------------------|
| DIF = 1: SMD Interface   |
| DIF = 0: ST506 Interface |

In SMD interface, the HDC performs seek instruction, head specification, drive status check, etc to the drive through 5-bit bi-directional buffer BUS<sub>0</sub>/BUS<sub>5</sub>—BUS<sub>4</sub>/BUS<sub>9</sub>.

In ST506 interface, the HDC makes the drive perform seek operation by issuing step pulses.

## (4) PADP (PAD Pattern) bit

This bit specifies the data pattern of PAD area that follows ID and DATA areas. The value of the PADP bit gives the data pattern of PAD area that is written into the drive by WFM or WD command execution.

|          | Hard Sector | Soft Sector |
|----------|-------------|-------------|
| PADP = 1 | Prohibited  | \$4E        |
| PADP = 0 | \$00        | \$00        |

## (5) ECD (Error Check Code) bit

This bit specifies the error check code which is added to the end of the DATA area. CRC code is always specified for the ID area regardless of ECD bit.

|                                             |
|---------------------------------------------|
| ECD = 1: ECC (Error Correction Code)        |
| ECD = 0: CRC (Cyclic Redundancy Check Code) |

ECC enables error detection and correction. A 4-byte ECC code is added to the end of DATA area. A generation polynomial G(x) of ECC is as follows (the initial value is fixed to "00").

$$\begin{aligned}G(x) &= (x^{21} + 1)(x^{11} + x^2 + 1) \\&= x^{32} + x^{23} + x^{21} + x^{11} + x^2 + 1\end{aligned}$$

CRC enables error detection, but not error correction. A 2-byte CRC code is added to the end of DATA area. A generation polynomial G(x) of CRC is specified by the CRCP bit.

## (6) CRCP (CRC Polynominal) bit

This bit determines the polynomial G(x) that generates CRC of ID and DATA areas when ECD = 0.

|                                                                         |
|-------------------------------------------------------------------------|
| CRCP = 1: G(x) = x <sup>16</sup> + x <sup>12</sup> + x <sup>5</sup> + 1 |
|-------------------------------------------------------------------------|

|                                      |
|--------------------------------------|
| CRCP = 0: G(x) = x <sup>16</sup> + 1 |
|--------------------------------------|

## (7) CRCI (CRC Initial) bit

This bit sets the initial value of CRC.

|                                  |
|----------------------------------|
| CRCI = 1: Initial value = \$FFFF |
|----------------------------------|

|                                  |
|----------------------------------|
| CRCI = 0: Initial value = \$0000 |
|----------------------------------|

## (8) ACOR (Automatic Correction) bit

This bit selects whether or not the HDC will automatically correct an error detected in DATA area during RD command execution.

|                                              |
|----------------------------------------------|
| ACOR = 1: Automatic correction is performed. |
|----------------------------------------------|

|                                                  |
|--------------------------------------------------|
| ACOR = 0: Automatic correction is not performed. |
|--------------------------------------------------|

Automatic correction mode is valid when ECC is specified as the error check code of DATA area and the sector length is 256 bytes (RL = \$01, ECD = 1). For any other cases specify "0" to the ACOR bit.

**OM1 (Operation Mode 1)**

## (1) DTM (Data Transfer Mode) bit

This bit is used to specify data transfer operation between the HDC and the main memory during the execution of the following commands:

| RD   | RED | RID |
|------|-----|-----|
| RIS  | FID | WD  |
| CMPD | WFM | WFS |

These commands normally perform transfer between drive and memory via HDC data buffers. However, it is possible to cease transfer between the HDC and memory during these command execution by utilizing DTM bit.

|                   |
|-------------------|
| DTM = 1: DMA mode |
|-------------------|

|                   |
|-------------------|
| DTM = 0: PIO mode |
|-------------------|

In DMA mode, the HDC performs transfer between drive and memory via HDC data buffer. In this case, DMA transfer is performed between the HDC and memory, and transfer mode is specified by BRST bit.

In PIO mode, the HDC performs transfer between drive and the HDC. In this case, transfer between the HDC and main



memory must be supported by the host system using one of four buffer access commands of the HDC: MTB, BTM, OPBR, and OPBW.

(2) BRST (DMA Burst) bit

This bit specifies DMA transfer mode of buffer access commands and drive access commands which perform transfer between the HDC and the main memory.

**BRST = 1:** Burst mode

**BRST = 0:** Cycle Steal mode

(3) CEDM, SEDM, DERM bits

CEDM (Command End Mask), SEDM (Seek End Mask), and DERM (Drive Error Mask) bits specify whether the  $\overline{IRQ}$  signal is to be asserted or not. CEDM, SEDM, and DERM correspond to CED (Command End), SED (Seek End), and DER (Drive Error) bits in STR (Status register).

**1:**  $\overline{IRQ}$  is masked (not asserted).

**0:**  $\overline{IRQ}$  is not masked (asserted).

| Mask bit | Corresponding bits in STR |       |
|----------|---------------------------|-------|
| CEDM     | CED                       | bit 5 |
| SEDM     | SED                       | bit 4 |
| DERM     | DER                       | bit 3 |

(4) AMEX (Address Mark Excluded) bit

This bit specifies whether or not the byte-synchronization pattern marking the beginning of ID area or DATA area (AM in soft sector, SYNCPAT in hard sector) is to be included in the CRC or ECC error detection span. The AMEX bit affects the byte length of ID PAD area and DATA PAD area.

|          | AM or SYNCPAT | PAD Length |
|----------|---------------|------------|
| AMEX = 1 | Excluded      | 2 bytes    |
| AMEX = 0 | Included      | 3 bytes    |

(5) PSK (Parallel Seek) bit

This bit specifies seek operation mode, and is valid only in ST506 interface (in SMD interface, PSK must be fixed to "1"). The HDC specifies step pulse issue timing by utilizing the value of OM2, SH, and PSK bits.

**PSK = 0:** Normal Seek mode

**PSK = 1:** Parallel Seek mode

In Normal Seek mode, the HDC issues step pulses in long cycle (0.1–32 ms). SEK and RCLB command execution ends when the HDC issues step pulses and then detects seek end.

In Parallel Seek mode, the HDC issues step pulses in short cycle (0.5–115  $\mu$ s). SEK and RCLB command execution ends when the HDC issues step pulses. Since the HDC does not check the seek end, parallel seek operation in multiple drives is realized by issuing SEK or RCLB command to these drives. Seek end is to be checked by using POL command.

**OM2 (Operation Mode 2)**

This 8-bit register specifies step pulse low width in ST506 interface, and specifies drive control output signal during disk read command execution in SMD interface.

In ST506 interface, OM2 indicates SL which specifies step pulse low width (STPL: Step Pulse Low). Low-speed seek mode (Normal Seek mode) is selected when PSK = 0, and high-speed seek mode (Parallel Seek mode) is selected when PSK = 1. Highest seek speed is realized when PSK = 1 and SL = \$FF. The relation between step pulse low width and SL is shown in the following Table (see Step Pulse High/Record Length register to specify step pulse high width).

|                     |   |   |   |   |   |   |   |
|---------------------|---|---|---|---|---|---|---|
| 7                   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Step Pulse Low (SL) |   |   |   |   |   |   |   |

| Seek Mode               | SL                                      | STPL (step pulse low)                                                                |
|-------------------------|-----------------------------------------|--------------------------------------------------------------------------------------|
| Normal seek (PSK = 0)   | SL = \$00                               | STPL = 988 CLK                                                                       |
|                         | \$01 $\leq$ SL $\leq$ \$FE<br>(1) (254) | STPL = (SL - 1) $\times$ 1280 + 2364 CLK<br>(2364 CLK $\leq$ STPL $\leq$ 326204 CLK) |
|                         | SL = \$FF                               | Disabled                                                                             |
| Parallel seek (PSK = 1) | SL = \$00                               | STPL = 27CLK                                                                         |
|                         | \$01 $\leq$ SL $\leq$ \$FE<br>(1) (254) | STPL = SL $\times$ 6 + 28 CLK<br>(34CLK $\leq$ STPL $\leq$ 1152 CLK)                 |
|                         | SL = \$FF                               | STPL = 5CLK                                                                          |





In SMD interface, OM2 specifies drive control output signal from the HDC during data read command execution. In data write command (all the commands that assert WGATE signal) and SEK, RCLB command execution, outputs of drive control signals are low regardless of the contents of OM2. Bits 4–7 in OM2 are to be set to "0".

- SOFM bit: With SOFM = 1, the drive head is offset from the normal position away from the spindle.
- SOFP bit: With SOFP = 1, the drive head is offset from the normal position towards the spindle.
- STBL bit: With STBL = 1, the data from the drive PLO data separator is strobed later than usual.
- STBE bit: With STBE = 1, the data from the drive PLO data separator is strobed earlier than usual.

| 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|---|---|---|---|------|------|------|------|
| 0 | 0 | 0 | 0 | SOFM | SOFP | STBL | STBE |

Servo Offset Plus  
Servo Offset Minus  
Strobe Early  
Strobe Late

#### CUL (Connecting Unit List)

This register stores bit-map information indicating which drive is connected to the HDC.

In ST506 interface, bits 0–3 correspond to drives 0–3 respectively. To connect a drive, write "1" into the corresponding bit (up to 4 drives can be connected).

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 |   |   |   |   |

Drive Unit 3  
Drive Unit 2  
Drive Unit 1  
Drive Unit 0

In SMD interface, bits 0–7 correspond to drives 0–7 respectively. To connect a drive, write "1" into the corresponding bit (up to 8 drives can be connected).



#### TO/NCH, NCL (Read/Write Time Over, Number of Cylinders High/Low)

NCH and NCL registers specify the number of cylinders in disk drive, and time-over during disk access command execution.

##### (1) TO (Read/Write Time Over)

The high-order 6 bits in TO/NCH are used to assign the ID search time: time-over ( $t_{over}$ ). According to the value of TO, the HDC sets time-over period as follows.

$$\$01 \leq TO \leq \$3F \quad (TO = \$00 \text{ is prohibited.})$$

$$TO \times 8 \times 10^4 \text{ CLK} \leq t_{over} \leq (TO + 1) \times 8 \times 10^4 \text{ CLK}$$

##### (2) NC (Number of Cylinders)

The low-order 2 bits of TO/NCH and 8 bits of NCL specify the number of cylinders (NC). NC is 1023 at a maximum. Its value is number of cylinders minus 1.

The HDC uses NC to issue NC + 10 step pulses during RCLB command execution (ST506 interface), or to check whether or not the command parameter NCA (Next Cylinder Address) exceeds NC during SEK command execution.



#### NH (Number of Heads)

This register indicates the number of heads. Its value is to be number of drive heads minus 1.

In disk access command execution, the HDC checks whether or not PHA (Physical Head Address) specified by command parameters exceeds NH. When PHA exceeds NH, the HDC sets IPH (Invalid Physical Head Address) to result parameter SSB (Sense Status Byte) and abnormally terminates the execution.

To select a head during multiple track operation in disk access command execution, the HDC checks whether PHA exceeds NH or not. When PHA exceeds NH, the HDC sets IPH to SSB and abnormally terminates the execution.

|                 |   |   |   |   |   |   |   |
|-----------------|---|---|---|---|---|---|---|
| 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Number of Heads |   |   |   |   |   |   |   |

In ST506 interface, up to 8 heads can be selected ( $\$00 \leq NH \leq \$07$ ). Bits 3–7 must be fixed to "0".

|   |   |   |   |   |       |       |       |
|---|---|---|---|---|-------|-------|-------|
| 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
| 0 | 0 | 0 | 0 | 0 | $2^2$ | $2^1$ | $2^0$ |

In SMD interface, up to 32 heads can be selected ( $\$00 \leq NH \leq \$1F$ ). Bits 5–7 must be fixed to "0".

|   |   |   |       |       |       |       |       |
|---|---|---|-------|-------|-------|-------|-------|
| 7 | 6 | 5 | 4     | 3     | 2     | 1     | 0     |
| 0 | 0 | 0 | $2^4$ | $2^3$ | $2^2$ | $2^1$ | $2^0$ |

#### NS (Number of Sectors)

This register indicates the number of sectors. Its value is number of sectors/track minus 1 ( $\$00 \leq NS \leq \$FE$ ).

In data read/write command execution, the HDC checks whether LSA (Logical Sector Address) exceeds NS or not.

In multiple sector operation in data read/write command execution, the HDC checks whether LSA exceeds NS or not each time LSA is incremented after one sector operation. If LSA exceeds NS, the HDC sets "0" to LSA, increments LHA and PHA, and compares NH and PHA. If NH exceeds PHA, the HDC executes multiple track operation. If PHA exceeds NH, the HDC sets IPH (Invalid Physical Head Address) to result parameter SSB and abnormally terminates the execution.

|                   |   |   |   |   |   |   |   |
|-------------------|---|---|---|---|---|---|---|
| 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Number of Sectors |   |   |   |   |   |   |   |

#### SH/RL (Step Pulse High/Record Length)

|                      |   |   |   |                    |   |   |   |
|----------------------|---|---|---|--------------------|---|---|---|
| 7                    | 6 | 5 | 4 | 3                  | 2 | 1 | 0 |
| Step Pulse High (SH) |   |   |   | Record Length (RL) |   |   |   |

#### (1) SH (Step Pulse High)

The high-order 5-bit SH/RL indicates step pulse high width (STPH: Step Pulse High) in ST506 interface.

STPH is fixed to 2CLK in highest speed seek mode (PSK = 1 and SL = \$FF). Otherwise, SH sets STPH regardless of the PSK bit. The relation between STPH and SH is shown in the following table. SH is ignored when maximum speed seek mode is selected in ST506 interface.

In SMD interface, the high-order 5 bits are to be fixed to "0".



| SH               | STPH (step pulse high)                                    |
|------------------|-----------------------------------------------------------|
| SH = *           | STPH = 2 CLK (Note 1)                                     |
| * : don't care   |                                                           |
| SH = \$00        | STPH = 3 CLK                                              |
| \$01 ≤ SH ≤ \$1F | STPH = SH × 3 + 1 CLK<br>(1) (31) (4 CLK ≤ STPH ≤ 94 CLK) |

(Note 1) Highest-speed seek mode (PSK = 1, SL = \$FF)

#### (2) RL (Record Length)

The low-order 3-bit SH/RL indicates record length per sector.

| RL    |       |       | Record Length |
|-------|-------|-------|---------------|
| Bit 2 | Bit 1 | Bit 0 |               |
| 0     | 0     | 0     | Inhibited     |
| 0     | 0     | 1     | 256 bytes     |
| 0     | 1     | 0     | 512 bytes     |
| 0     | 1     | 1     | 1024 bytes    |
| 1     | 0     | 0     | 2048 bytes    |
| 1     | 0     | 1     | 4096 bytes    |
| 1     | 1     | 0     | Inhibited     |
| 1     | 1     | 1     | Inhibited     |

#### GPL1, 2 (Gap Length 1, 2)

These registers specify the length of gap and SYNC area in the sector during WD and WFM command execution.

GPL1 specifies the length of gap areas (GAP1 in soft sector, HEAD SCAT in hard sector) that follow an index or a sector pulse by byte. It is used for WFM command execution. These areas are formatted 6 bytes longer than the value set to GPL1 during the command execution. [ $\$00 \leq GPL1 \leq \$FF$ ]

|              |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|
| 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Gap Length 1 |   |   |   |   |   |   |   |

GPL2 specifies the length of SYNC area located at the beginning of ID and DATA areas by byte. It is used for WD and WFM commands. This area is formatted 3 bytes longer than the value set to GPL2 during the command execution. [ $\$08 \leq \text{GPL2} \leq \$FF$ ]

|              |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|
| 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Gap Length 2 |   |   |   |   |   |   |   |

#### GPL3/RGTLT (Gap Length 3, Read Gate Latency)

GPL3/RGTLT specifies the length of GAP3 for the soft sector and read gate latency delay for the hard sector by byte.

GPL3 specifies the length of GAP3 located at the end of a sector in soft sector format by byte. It is used for WFM command. This area is formatted 3 bytes longer than the value set to GPL3. [ $\$09 \leq \text{GPL3} \leq \$FF$ ]

|              |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|
| 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Gap Length 3 |   |   |   |   |   |   |   |

RGTLT specifies the time period between the detection of an index or a sector pulse and the assertion of RGATE in unit of byte. It is used for disk read commands. RGATE is asserted 5 bytes later than the value set to RGTLT. RGTLT must be set to assert RGATE at the beginning of or before PLO SYNC area in the ID field. During RIS command execution, 64 bytes are added to the amount of latency automatically. [ $\$00 \leq \text{RGTLT} \leq \$FF$ ]

|               |   |   |   |   |   |   |   |
|---------------|---|---|---|---|---|---|---|
| 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RGATE Latency |   |   |   |   |   |   |   |

#### LCHH, LCCL (Low Current Cylinder High/Low)

For the inner cylinders of the drive, it is necessary to reduce write current during WFM and WD command execution. These registers specify address of the outermost cylinder from where write current is reduced. This is valid only in ST506 interface. When a disk write command is executed to any cylinder whose address is equal to or greater than LCC, the HDC asserts the LCT pin to high. [ $\$0000 \leq \text{LCC} \leq \text{NC}$  (Number of Cylinders)]

|                           |    |    |    |    |    |   |   |
|---------------------------|----|----|----|----|----|---|---|
| 15                        | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Low Current Cylinder High |    |    |    |    |    |   |   |

|                          |   |   |   |   |   |   |   |
|--------------------------|---|---|---|---|---|---|---|
| 7                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Low Current Cylinder Low |   |   |   |   |   |   |   |

#### PCC (Precompensation Cylinder)

This register specifies the address of the outermost cylinder from where compensation of the bit data timing is required. This is valid only in ST506 interface. When a disk write command is executed to any cylinder whose address is equal to or greater than PCC, either EARLY or LATE signal is generated in accordance with the bit data timing. [ $\$0000 \leq \text{PCC} \leq \text{NC}$ ]

|                                |    |    |    |    |    |   |   |
|--------------------------------|----|----|----|----|----|---|---|
| 15                             | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Pre-compensation Cylinder High |    |    |    |    |    |   |   |

|                               |   |   |   |   |   |   |   |
|-------------------------------|---|---|---|---|---|---|---|
| 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Pre-compensation Cylinder Low |   |   |   |   |   |   |   |

#### OTHER COMMAND PARAMETERS

The following describes command parameters other than SPC command parameters in alphabetical order.

##### (1) FLAG

This parameter is used to specify the FLAG byte of ID area of a hard sector that the HDC will access. If the FLAG given by the command parameter does not match the FLAG read from ID area of the disk, the HDC will not access the sector.

##### (2) LCA (Logical Cylinder Address)

This parameter is used to specify the logical cylinder address of ID area (16 bits: the high-order 8 bits for LCAH and the low-order 8 bits for LCAL) of a sector that the HDC will access. If LCA given by the command parameter does not match LCA read from ID area, the HDC will not access the sector. In soft sector format, it is prohibited to specify \$F8 to the high-order 8 bits (LCAH).

##### (3) LHA (Logical Head Address)

LHA is used to specify the logical head address of ID area of a sector that the HDC will access. If LHA given by the command parameter does not match the LHA read from ID area, the HDC will not access that sector. In multiple track operation, LHA is automatically incremented by one. Since LHA is logical, it may exceed the number specified by the parameter NH (number of heads).

##### (4) LSA (Logical Sector Address)

LSA is used to specify the logical sector address of ID area that the HDC will access. If LSA given by the command parameter does not match LSA read from ID area, the HDC will not access the sector. In multiple sector operation, LSA is automatically incremented by one. Since LSA is compared with the control register NS (number of sectors) for switching of heads, the LSA must not exceed the NS.

##### (5) NCA (Next Cylinder Address)

This parameter is used to specify the physical address (10 bits) of a cylinder to which the head will move when a SEK command is issued. The outermost cylinder address is \$0000. The high-order 8 bits of NCA are used for NCAH and the low-order 8 bits for NCAL. The high-order 6 bits of NCAH must be fixed to "0". If NCA exceeds NC, com-

- mand execution abnormally terminates.
- (6) **OFFSET**  
OFFSET specifies how many sectors to be skipped reading after an index pulse. Then the HDC reads ID fields, and stores them into the data buffer.
- (7) **PHA (Physical Head Address)**  
The MPU specifies PHA when issuing a disk access command. Unlike LHA, PHA is physical, and the bit status of PHA is directly output as HSEL signals. The high-order 5 bits of PHA must be fixed to "0" for ST506 interface, and the high-order 3 bits for SMD interface. In multiple track operation, PHA is automatically incremented by one within the HDC if another head switching is required. If PHA exceeds the value given by NH, the command execution will abnormally terminate.
- (8) **POFF (Pointer Offset)**  
The MPU specifies a transfer start address (16 bits) when issuing a command for accessing the data buffer. The MSB of the high-order 8 bits (POFFH) selects one of two data buffers, and the remaining 7 bits must be fixed to "0". The low-order 8 bits (POFFL) specifies a transfer start address of the selected data buffer (256 bytes). For the 16-bit data bus, POFF is limited to an even address only.
- (9) **PSA (Physical Sector Address)**  
This parameter is used to specify a physical address of a hard sector at which the execution of RID, RIS, FID, WFM, or WFS starts. If PSA is \$00, the sector following an index pulse is specified.
- (10) **SCNT (Sector Count)**  
This parameter is used to specify the number of sectors (16 bits) that the HDC will continuously access in a disk access command execution. Upper 8 bits are SCNTH, and lower 8 bits are SCNTL. Up to 1024 sectors are specified in ST506 interface (128 sectors x 8 heads), and up to 8160 sectors are specifiable in SMD interface (255 sectors x 32 heads). For commands relating to the ID (RID and WFM), they perform no multiple track operation. In addition, maximum number of sectors that can be formatted at a time by WFM command is 128 for soft sector, and 102 for hard sector.
- (11) **US (Unit Select)**  
The MPU specifies the address (8 bits) of a target drive when issuing a head positioning, disk access or drive check command. The contents of US are directly output from USEL signals. The high-order 6 bits of US must be fixed to "0" for ST506 interface, and the high-order 5 bits for SMD interface. US is the high-order 8 bits of a 16-bit word, and the low-order 8 bits of the word are PHA or \$00. It is not necessary to issue \$00 to the low-order 8 bits when CKV or RCLB command is issued.

#### RESULT PARAMETERS

Result parameters are listed in Table 9. In this table, result parameters used by the HDC to control ST506 type hard disk drive are found in the upper row of each command, and those for SMD type in the lower row.



Table 9 Result Parameters (Byte-organized)

| Command                    | Parameter                                                              | (Upper row: ST506)<br>(Lower row: SMD)                         |
|----------------------------|------------------------------------------------------------------------|----------------------------------------------------------------|
| Recalibrate                | \$00 SSB US VUL<br>\$00 SSB US VUL                                     |                                                                |
| Specify                    | (\$00 SSB)<br>(\$00 SSB)                                               |                                                                |
| Seek                       | \$00 SSB US VUL<br>\$00 SSB US VUL                                     |                                                                |
| Read Data                  | \$00 SSB US PHA<br>\$00 SSB US PHA \$00 FLAG                           | LCAH LCAL LHA LSA SCNTH SCNTL<br>LCAH LCAL LHA LSA SCNTH SCNTL |
| Read Erroneous Data        | \$00 SSB US PHA<br>\$00 SSB US PHA \$00 PSA                            | SCNTH SCNTL<br>SCNTH SCNTL                                     |
| Read ID                    | \$00 SSB US PHA                                                        | \$00 SCNTL                                                     |
| Read ID Skew (Note 1)      | \$00 SSB US PHA \$00 PSA                                               | \$00 SCNTL                                                     |
| Find ID                    | \$00 SSB US PHA<br>\$00 SSB US PHA \$00 PSA                            | \$00 SCNTL<br>\$00 SCNTL                                       |
| Check Data                 | \$00 SSB US PHA<br>\$00 SSB US PHA \$00 FLAG                           | LCAH LCAL LHA LSA SCNTH SCNTL<br>LCAH LCAL LHA LSA SCNTH SCNTL |
| Compare Data               | \$00 SSB US PHA<br>\$00 SSB US PHA \$00 FLAG                           | LCAH LCAL LHA LSA SCNTH SCNTL<br>LCAH LCAL LHA LSA SCNTH SCNTL |
| Write Data                 | \$00 SSB US PHA<br>\$00 SSB US PHA \$00 FLAG                           | LCAH LCAL LHA LSA SCNTH SCNTL<br>LCAH LCAL LHA LSA SCNTH SCNTL |
| Write Format               | \$00 SSB US PHA                                                        | SCNTH SCNTL                                                    |
| Write Format Skew (Note 1) | \$00 SSB US PHA \$00 PSA                                               | SCNTH SCNTL                                                    |
| Memory to Buffer           | (\$00 SSB)<br>(\$00 SSB)                                               |                                                                |
| Buffer to Memory           | (\$00 SSB)<br>(\$00 SSB)                                               |                                                                |
| Open Buffer Read           | (\$00 SSB)<br>(\$00 SSB)                                               |                                                                |
| Open Buffer Write          | (\$00 SSB)<br>(\$00 SSB)                                               |                                                                |
| Polling                    | \$00 SSB US VUL<br>\$00 SSB US VUL                                     |                                                                |
| Check Drive                | \$00 SSB US \$00 DST0 \$00<br>\$00 SSB US \$00 DST0 DST1 DST2 DST3     |                                                                |
| Abort                      | \$00 SSB<br>\$00 SSB                                                   |                                                                |
| Check ECC                  | \$00 SSB EA0 EA1 EP0 EP1 EP2 \$00<br>\$00 SSB EA0 EA1 EP0 EP1 EP2 \$00 |                                                                |
| Test                       | (\$00 SSB)<br>(\$00 SSB)                                               |                                                                |
| Polling Disable            | (\$00 SSB US VUL)<br>(\$00 SSB US VUL)                                 |                                                                |
| Recall                     | (\$00 SSB US VUL)<br>(\$00 SSB US VUL)                                 |                                                                |

(Note 1) Read ID Skew and Write Format Skew are valid only for SMD.

(Note 2) Parenthesized parameters are reported when a command is issued under the illegal condition.



**DST (Drive Status)**

Table 10 Drive List (DST)

| Bit   |      | 7     | 6   | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|------|-------|-----|-------|-------|-------|-------|-------|-------|
| ST506 | DST0 | READY | SCP | TRK0  | 0     | WFLT  | 0     | 0     | 0     |
| SMD   | DST0 | *     | *   | *     | WPRT  | FLT   | SKERR | OCYL  | URDY  |
|       | DST1 | *     | *   | SELER | WERR3 | WERR2 | WERR1 | SERR2 | SERR1 |
|       | DST2 | *     | *   | SAD32 | SAD16 | SAD8  | SAD 4 | SAD 2 | SAD 1 |
|       | DST3 | *     | *   | DTP32 | DTP16 | DTP8  | DTP4  | DTP2  | DTP1  |

\* Depends on the state of BUS<sub>1</sub>/BUS<sub>6</sub> – BUS<sub>4</sub>/BUS<sub>9</sub>.

Each bit of DST indicates drive interface input signal level. DST0 (1 byte) is reported in ST506 interface, and DST0–3 (4 bytes) are reported in SMD interface.

In ST506 interface, the WFLT bit in DST0 indicates the signal level of WFLT pin. Even if WFLT signal is momentarily asserted, the internal latch memorizes this and reflects its state on WFLT bit. When WFLT signal is negated, the latch read operation by the HDC clears this latch.

In SMD interface, the HDC reads 8 bits by 4 words of the drive status signal which is selected by signals TAG2 and TAG5.

| TAG2 | TAG5 | Status |
|------|------|--------|
| 0    | 0    | DST0   |
| 0    | 1    | DST1   |
| 1    | 0    | DST2   |
| 1    | 1    | DST3   |

Following (1) through (5) are read during CKV command execution and checked during disk access command execution. DST1 through DST3 are referred to during CKV command execution.

Status that each bit in DST1–3 indicates may vary according to the drive connected to the HDC. Following descriptions indicate DST bit function when the HDC is connected to a Hitachi 8" disk drive, DK-812S.

## (1) URDY (Unit Ready)

This bit indicates that a selected drive is in ready state.

## (2) OCYL (On Cylinder)

This bit indicates that a head is positioned correctly on a track.

## (3) SKERR (Seek Error)

This bit indicates that errors have been detected in a drive during seek operation.

## (4) FLT (Fault)

This bit indicates that errors relevant to disk access have been detected in the drive. Result parameter DST1 indicates what type of error has occurred. See (6) through

(11) for DST bits indicating error status.

## (5) WPRT (Write Protected)

This bit indicates that a selected drive is write protected.

## (6) SERR1 (Status Error 1)

## (7) SERR2 (Status Error 2)

## (8) WERR1 (Write Error 1)

## (9) WERR2 (Write Error 2)

## (10) WERR3 (Write Error 3)

## (11) SELER (Select Error)

## (12) SAD1–32 (Sector Address)

## (13) DTP1–32 (Drive Type)

**EA (Error Address)**

Reports the start address (16 bits) of a byte from where the burst error that is detected during CKE command execution exists. The high-order 8 bits are EA0, and the low-order 8 bits are EA1. As the HDC corrects up to 11 bits of burst error, the MPU corrects contiguous 3 bytes starting from a byte specified by EA. EA = \$0000 indicates a start address of sector data.

**EP (Error Pattern)**

Reports EP0, EP1, and EP2 as the pattern required for error correction as a result of CKE command execution. The MPU exclusive-OR 3-byte data containing errors with EP0, EP1, and EP2.

**FLAG (Flag)**

Reports the same value as FLAG specified by command parameters.

**LCA (Logical Cylinder Address)**

Reports the same value as LCA specified by command parameters.

**LHA (Logical Head Address)**

Bit organization of LHA is the same as that of the command parameter LHA. In multiple track operation, LHA is incremented by one each time access to one track ends.



**LSA (Logical Sector Address)**

Bit organization of LSA is the same as that of the command parameter LSA. In multiple sector operation, LSA is incremented by one each time access to one sector ends.

**PHA (Physical Head Address)**

Bit organization of PHA is the same as that of the command parameter PHA. In multiple track operation, PHA is incremented by one each time access to one track ends.

**PSA (Physical Sector Address)**

Bit organization of PSA is the same as that of the command parameter PSA. In multiple sector operation, PSA is incremented by one each time access to one sector ends.

**SCNT (Sector Count)**

Bit organization of SCNT is the same as that of the command parameter SCNT. In multiple sector operation, SCNT is decremented by one each time access to one sector ends. When

SCNT reaches "0", command execution normally terminates.

**SSB (Sense Status Byte)**

This is the area where 8-bit error code is set (\$00 is set for normal termination). There are 25 error codes which notify what kind of error has occurred during the command execution (See Tables 11-14).

**US (Unit Select)**

Reports the same value as US specified by command parameters.

**VUL (Valid Unit List)**

VUL is a bit-mapped list which gives the address of a drive that is ready to accept a head positioning or a disk access command. Its bit organization is the same as that of CUL. This bit is set when seek operation in the drive is terminated, or when SPC command is executed. This bit is reset when seek operation starts, when drive error occurs, or when the bit in CUL corresponding to the drive is not set to "1".

Table 11 Error Codes Relevant to Host Interface

| Mnemonic | Name            | Error Code | Contents                                                                                                    |
|----------|-----------------|------------|-------------------------------------------------------------------------------------------------------------|
| ABT      | Command Aborted | 04         | ABT command has been accepted.                                                                              |
| IVC      | Invalid Command | 08         | An invalid command has been accepted.                                                                       |
| PER      | Parameter Error | 0C         | The command parameter has not been stored in an appropriate area in PB.                                     |
| NIN      | Not Initialized | 10         | Head positioning, disk access, and drive check commands have been accepted, before SPC command is executed. |
| RTS      | Rejected Test   | 14         | The TST command is received after SPC command has been received.                                            |

Table 12 Error Codes Relevant to Drives

| Mnemonic | Name        | Error Code | Contents                                                                       |
|----------|-------------|------------|--------------------------------------------------------------------------------|
| NUS      | No USELD    | 18         | USELD signal for a selected drive has not been returned.                       |
| WFL      | Write Fault | 1C         | WFLT signal (ST506 interface) or FLT signal (SMD interface) has been detected. |
| NRY      | Not Ready   | 20         | READY signal has been negated.                                                 |

Table 13 Error Codes Relevant to Head Positioning Commands

| Mnemonic | Name              | Error Code | Contents                                                                                                    |
|----------|-------------------|------------|-------------------------------------------------------------------------------------------------------------|
| NSC      | No SCP            | 24         | SCP signal (ST506 interface) or the SKEND signal (SMD interface) has not been returned in a certain period. |
| ISE      | In Seek           | 28         | SEK, or a disk access command has been issued for a drive in seek operation.                                |
| INC      | Invalid NCA       | 2C         | NCA (Next Cylinder Address) greater than NC (number of cylinders) has been specified.                       |
| ISR      | Invalid Step Rate | 30         | The highest-speed seek has been specified in the normal seek mode.                                          |
| SKE      | Seek Error        | 34         | SEK or a disk access command has been issued to a drive which is in seek error state (SMD only).            |



Table 14 Error Codes Relevant to Disk Read/Write Commands

| Mnemonic | Name                   | Error Code | Contents                                                                                                                |
|----------|------------------------|------------|-------------------------------------------------------------------------------------------------------------------------|
| OVR      | Over Run               | 38         | A transfer between the main memory and data buffers has not caught up with a transfer between a drive and data buffers. |
| IPH      | Invalid PHA            | 3C         | PHA (Physical Head Address) greater than NH (Number of Heads) has been specified.                                       |
| DEE      | DATA Field ECC Error   | 40         | A data error has been detected by ECC (Error Correction Code).                                                          |
| DCE      | DATA Field CRC Error   | 44         | A CRC (Cyclic Redundancy Check Code) error has occurred in DATA area.                                                   |
| ECR      | Error Corrected        | 48         | An ECC error detected in DATA area has been automatically corrected.                                                    |
| DFE      | DATA Field Fatal Error | 4C         | A fatal ECC error has occurred in DATA area.                                                                            |
| NDA      | No DATA AM             | 60         | The address mark in DATA area has not been detected.                                                                    |
| NHT      | Not Hit                | 50         | In CMPD command execution, data from the host and disk data have not coincided with each other.                         |
| ICE      | ID Field CRC Error     | 54         | A CRC error in ID area has been detected in RID command execution in SMD interface.                                     |
| TOV      | Time Over              | 58         | ID has not been found in the period specified by TO (Time Over).                                                        |
| NIA      | No ID AM               | 5C         | The ID area that begins with improper address mark has been detected.                                                   |
| NWR      | Not Writable           | 64         | WD command has been issued to a drive where the write protect signal is asserted (SMD interface)                        |

## CONTROL SEQUENCE FOR ST506 TYPE DRIVE

### DISK READ

The ID search timing for RD or WD command execution is shown in Figure 27. (a) is the timing where AM is found. SYNC signal is negated 4-bit period (on the basis of disk data) after CRC pattern of ID area is completed. After reading CRC, the HDC switches the clock in the satellite processor from RCLK to WCLK and then negates SYNC signal.

RCLK and WCLK clock signals are independent each other. To remove the hazard during switching, the switching signal and the clock signal must be synchronized. Therefore, SYNC is normally negated 4-bit period after reading CRC to switch the clock in the satellite processor from RCLK to WCLK.

RGATE signal is usually negated 4-bit period after SYNC signal is negated, and then asserted again one to two-byte period later to read SYNC area preceding DATA area. RGATE is asserted for 1-byte period when the AMEX bit is set to "1" during SPC command execution, and for 2-byte period when set to "0".

When AM is not found as shown in (b), the HDC searches for AM again by negating both SYNC and RGATE signals. RGATE signal is usually negated 4-bit period after SYNC signal is negated, and is negated for 2-byte period.

As the MFM is specified during SPC command execution, the frequency of clock signals synchronizing with disk data (such as RCLK, WCLK) is doubled compared to the data transfer rate.

Therefore, "4-bit period" or "1-byte period" description is formally expressed as "8 WCLK cycles" or "16 WCLK cycles" respectively.

After reading DATA area and ECC or CRC area by RD command execution, RGATE and SYNC signals are negated in the same timing as they are negated after reading ID CRC area (see Figure 27 (a)).

### DISK WRITE

The timing of WGATE signal for WD command execution is shown in Figure 28. The HDC negates RGATE signal after reading ID area. Then WGATE signal is asserted 1 or 2-byte period after RGATE is negated (2-byte when AMEX specified by SPC command is at "0", 1-byte when AMEX is at "1"). WGATE signal is negated immediately after PAD of DATA field ends.

The relation between IDX signal and WGATE signal during WFM command execution is shown in Figure 29. WGATE signal rises almost simultaneously with IDX signal (refer to electrical characteristics), and falls 3-byte or 4-byte period after IDX signal rises. The condition of EARLY and LATE signal generation is shown in Figure 8.

### HEAD POSITIONING

The relation between DIR, STEP, and SEEK signals is shown in Figure 30. The unit is the number of CLK cycles ( $t_{cyc}$ ).

When 8 MHz clock signal is supplied to CLK, STEP signal is output at least 33.8  $\mu$ s after DIR signal becomes valid.





Figure 8 Write Precompensation

## CONTROL SEQUENCE FOR SMD TYPE DRIVE

### DRIVE SELECTION, STATUS CHECK, FAULT CLEAR

The HDC performs drive selection, status check, and Fault Clear, for all disk control command execution. Figure 35 shows the drive selection timing. The drive receives BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub> from the HDC and latches them using UTAG signal. If the drive judges that its own drive number is specified, it returns USELD signal within 9 CLK after the detection of UTAG signal. Figure 36 shows the drive status check sequence. The HDC changes the direction of BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub> before reading the status. Then the HDC sets BUSL/H signal to high, therefore, the external circuit of the HDC can supply drive status signal to the HDC during this period. At this time, BUSL/H is in high, and lower 5 bits are input to the HDC.

The HDC resets FLT after reading the drive status which includes Fault, and the timing is shown in Figure 37. To set the high-order 5 bits of BUS outputs to low, the HDC sets BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub> to low, and asserts TAG3 signal with maintaining BUSL/H in low. In external circuits of the HDC, BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub> is latched by using TAG3 signal as a strobe signal. If BUSL/H is in low, external circuits must be used not to supply TAG3 signal of the HDC to the drive. Then, the HDC outputs the low-order 5-bit information to BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub>, sets BUSL/H signal to high, and asserts

TAG3 signal. The external circuits provide the drive with above mentioned 5-bit latch outputs, the low-order 5-bit outputs on BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub>, and TAG3. In Fault Clear, BUSL/H signal is in high, and only BUS<sub>4</sub>/BUS<sub>9</sub> is in high.

Head selection is performed by disk access commands. Figure 40 shows the head selection timing. Upper 5 bits are in low, and the head address is supplied from the low-order 5 bits of BUS. At this time, TAG2 signal is used as a strobe signal.

Further, in the execution of disk access command group, the HDC asserts TAG3 and generates RGATE or WGATE signal. Figures 41, 42 and 43 show the total sequence. When TAG3 is asserted, the high-order 5 bits of BUS output Strobe Early/Late and RTZ (it is not used for disk access). Then, the HDC outputs the low-order 5 bits. Servo offset is specified in figure 42. When TAG3 is asserted along with BUS<sub>2</sub>/BUS<sub>7</sub> or BUS<sub>3</sub>/BUS<sub>8</sub>, servo offset is performed in the drive. Therefore, the head is moved and the HDC waits until SKEND signal is returned from the drive. Then, the HDC asserts BUS<sub>1</sub>/BUS<sub>6</sub> and supplies RGATE signal to the drive to perform the read operation.

Figure 43 shows assert/negate timing of RGATE and WGATE signals which correspond to the disk format. During disk access command or ID read command execution, RGATE signal is

asserted after a time period corresponding to byte count of disk data has elapsed since IDX or SEC signal is detected. After reading CRC, the HDC itself switches the clock to WCLK signal, then negates RGATE signal with a typical delay time equivalent to 8 bits of disk data.

To read the data field, the HDC asserts RGATE again with a dwell time of 1–2 bytes period. RGATE is negated for 1-byte period when AMEX bit is set to “1” during SPC command execution, and 2-byte period when AMEX bit is set to “0”. The HDC negates RGATE signal 8-bit period after reading CRC or ECC in data field.

To write the DATA field, the HDC reads ID area and asserts WGATE signal 1–2 bytes period after RGATE signal is negated. WGATE signal is to be negated when DATA PAD ends. During WFM command execution, WGATE signal rises in the same timing as IDX signal, and is negated 3–4 bytes period after IDX or SEC signal is detected.

Figure 38 shows the execution timing of RCLB command. RTZ instruction is supplied to the drive through BUS<sub>1</sub>/BUS<sub>6</sub> and TAG3. Figure 39 shows the execution timing of SEK command. 10-bit cylinder address is output through BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub>, 5 bits at a time. Strobe signal is TAG1 at this time.

Figures 44, 45, 46 and 47 shows the execution timing of CKV command. The HDC reads 8-bit drive status through BUS<sub>0</sub>/BUS<sub>5</sub>–BUS<sub>4</sub>/BUS<sub>9</sub>, 3 bits first and then 5 bits. Then the HDC reads status four times by switching TAG2 and TAG5 signals. Switching order is: [TAG2 = 0, TAG5 = 1], [TAG2 = 0, TAG5 = 1], [TAG2 = 1, TAG5 = 0], [TAG2 = 1, TAG5 = 1].

## COMMON CONTROL

The control which is common to both ST506 and SMD interfaces is described in this section.

### AUTOMATIC CORRECTION

In SPC command execution, the HDC operates in automatic correction mode if the host sets both ECD and ACOR bits in OMO to “1”. If a sector with correctable errors is detected, the erroneous data is corrected in data buffers. Automatic correction is normally performed only when the sector length is 256 bytes. Specification of the automatic correction mode is prohibited when the sector length is longer than 512 bytes because it causes the erroneous operation of the HDC.

If DTM (Data Transfer Mode) bit in OMO is set to “1” as well as ECD and ACOR bits during SPC command execution, the HDC transfers the corrected data to the main memory in DMA mode after the automatic correction. Then, the command execution abnormally terminates. When DTM = 0, the command execution abnormally terminates after the automatic correction and data transfer is not performed. If the HDC finds the data uncorrectable, the command execution abnormally terminates without data transfer regardless of the state of DTM bit.

### CORRECTION BY HOST

The host corrects erroneous data detected during RD command execution when it sets ECD and ACOR bits in OMO to “1” and “0” respectively. When ECD bit is set to “1”, the host corrects erroneous data detected during RED command execution if necessary, regardless of the status of ACOR bit. The command

execution abnormally terminates when erroneous data is detected during any command execution. Then \$40 is set to SSB when an error is correctable, \$4C when not correctable.

When DTM = 1, the HDC sends 1-sector data including an error during RD or RED command execution and then abnormally terminates the command execution. After confirming that \$40 is set to SSB, the host issues CKE command to the HDC.

When DTM = 0, the HDC abnormally terminates the command execution after 1-sector data including an error is stored in the data buffer during RD or RED command execution. After confirming that \$40 is set to SSB, the host issues BTM command to the HDC after DMAC's initialization, or, issues OPBR command and reads data buffers using move and load instructions and then stores buffer data to the main memory. Then, the host issues CKE command to the HDC.

Receiving CKE command, the HDC calculates an error address (EA) and an error pattern (EP), and then sends result parameters to the host. The erroneous data exists in three contiguous bytes of the corresponding sector in main memory. EA indicates start address of this 3-byte area (\$0000 indicates a start address of sector data). The host exclusive-OR the 3-byte area and EP to correct erroneous data.

The host judges CKE command execution end from status change of BSY bit from “1” to “0”. When SSB is \$4C, CKE command issue is prohibited as it causes the erroneous operation of the HDC. Even if errors are reported to be correctable (SSB = \$40) during RD or RED command execution and the host issues CKE command, these errors may turn out to be not correctable after CKE command execution.

### DMA DATA TRANSFER

In DMA data transfer, the HDC selects one of two modes: Burst mode and Cycle Steal mode. DMA transfer mode is specified by BRST (burst) bit which is a command parameter of SPC command.

In Burst mode (BRST = 1), the HDC maintains DREQ signal at low level until data transfer is terminated. DREQ signal is negated when DONE signal is input synchronously with DACK signal, or when DMA transfer of data in 256-byte internal data buffer is finished.

In Cycle Steal mode (BRST = 0), the HDC asserts DREQ signal until DACK signal is asserted. The HDC negates DREQ signal when DACK signal assertion is detected. DREQ signal will be reasserted if DACK is negated and the HDC has the transfer request. The DMA transfer conditions of Cycle Steal mode are the same as those of Burst mode.

### DATA TRANSFER IN HOST INTERFACE

#### DMA Data Transfer in Disk Access

DMA data transfer mode, either Burst mode or Cycle Steal mode, is selected by BRST bit specified by SPC command. Figure 9 shows DMA data transfer sequence during RD and RED command execution. For 256-byte sector, (a) shows the case that the host computer reads the disk data from data buffers (DBUFO and DBUF1) by DMA at a high speed. The capacity of two data buffers is 256 bytes for each.



If data buffers are not provided, most of high-speed host bus is occupied by transferring drive data during low-speed reading of drive data.

Internal data buffers can separate high-speed host bus timing and low-speed drive data timing, which effectively shorten drive data transfer time in host bus. Therefore, host system throughput is notably improved. The data transfer from data buffers to the main memory is performed only when the HDC is reading ID area or DATA area of the disk, but is exceptional when data in the last sector is transferred to the main memory during the multiple sector operation.

Figure 9 (b) shows the low-speed DMA transfer of the host in 256-byte sector organization. According to the figure, DBUFO receives data of the sector 1, and DBUF1 receives that of the sector  $i+1$ . While DBUF1 is receiving the data of sector  $i+1$ , the data transfer from DBUFO to the main memory cannot be finished because the host cannot operate promptly. Therefore, being unable to receive the data of  $i+2$ , DBUFO waits until the disk makes one rotation (all data of DBUFO is sent to the main

manner, no data overrun occurs even if operation speed of the host is slow. Therefore, an interleave format is not required.

Figure 9 (c) indicates the sequence in 512-byte sector organization. Capacity of buffers is 256 bytes for each, and each buffer stores disk data and transfers the data to the main memory alternately. Therefore, buffers effectively operates in toggle fashion even if sector length exceeds 256 bytes, and host system throughput is improved. If operation speed of the host is too slow, data overrun may occur because data buffer cannot be emptied to receive disk data. The data transfer from data buffer to main memory must be terminated while the HDC is accessing disk data in ID or DATA area.

If the HDC receives DONE signal from the DMAC during RD or RED command execution, the HDC immediately terminates DMA data transfer. Disk reading operation continues until the HDC finishes reading the sector which has been read when DONE signal is applied.



Figure 9 DMA Data Transfer in Read Data and Read Erroneous Data Command Execution

DMA data transfer during WD and CMPD command execution is shown in Figure 10. This figure differs from Figure 9 (a) in data transfer direction, DMA transfer order, and access method of first and last sectors. In Figure 10, the host is fast and sector length is 256 bytes. When the host is slow and sector length is 256 bytes, or when sector length is 512 bytes or more, data transfer sequence is the same as Figure 9.

When the HDC receives DONE signal from the DMAC during WD command execution, the HDC immediately terminates DMA data transfer. Then all data stored in DBUF0 and DBUF1 are written to DATA area of the sector. If there is any room in DATA area after writing buffer data, the old data in buffers is written to DATA area. After DATA area is filled with buffer data, command execution terminates.

When the HDC receives DONE signal from the DMAC during CMPD command execution, the HDC immediately terminates DMA data transfer. However, the data of the sector which has been accessed when DONE is received, is used for comparison with disk data, further, the reading operation continues until reading of the sector is finished. Therefore, \$50 (Not Hit) is set to SSB in most cases when reading of the sector is finished, and then the command execution abnormally terminates.

DMA data transfer during RID or FID command execution is performed as follows (see Figure 11). When DBUF0 is filled with ID information, DBUF1 receives the succeeding ID information. DMA data transfer is not performed unless all the ID information is stored in data buffer. After DBUF0 with/without DBUF1 finishes accepting ID information from specified number of sectors, data are sent to the main memory by DMA. DMA data transfer continues until 512-byte transfer is finished.

DMA data transfer can be stopped when the DMAC sends DONE to the HDC. Therefore, the host can store only the necessary ID information to the main memory by setting the number of ID areas to be read, to the DMAC.

DMA data transfer during WFM command execution is shown in Figure 12. The HDC starts formatting operation when both DBUF1 and DBUF1 are filled with ID information from the host. The HDC writes data buffer data to the ID area of a specified sector, and writes fixed pattern to other areas such as DATA area. When DBUF0 becomes empty during formatting operation, DBUF1 becomes the source in turn. When the DMAC issues DONE signal to the HDC, the HDC stops data transfer to data buffers and starts formatting. Therefore, the host can write only the necessary ID information to data buffer by setting data of how many ID areas to be transferred, to the DMAC.



Figure 10 DMA Data Transfer in Write Data, Compare Data Command Execution  
(Sector Length = 256 bytes)



Figure 11 DMA Transfer in Read ID, Find ID Command Execution





Figure 12 DMA Data Transfer in Write Format Command Execution

#### DMA Data Transfer by Data Transfer Commands

Accepting data transfer commands, the HDC can perform DMA data transfer between the main memory and data buffers without disk access. Either Burst mode or Cycle Steal mode is selected by the BRST bit of SPC command parameter. There are two commands available, BTM and MTB.

Selection of either DBUFO or DBUF1, and access start address of each buffer (address 0 to 250 are specifiable), are specified by POFF (Pointer Offset). POFF is set to the data buffer pointer by command execution.

Data buffer pointer is incremented each time the DMAC accesses data buffer (+2 for 16-bit bus mode, +1 for 8-bit bus mode). Data buffer data is not guaranteed if data buffer pointer exceeds address 255. Receiving DONE signal from the DMAC, the command execution immediately terminates normally, and the CED bit in STR is set to "1". Receiving above data transfer commands, the HDC requests transfer by issuing DREQ signal to the DMAC within 150 CLK cycles.

#### Data Buffer Access by PIO

The host MPU can access data buffers by move or load/store instruction (Programmed I/O). In this case, the host issues OPBR or OPBW command prior to PIO access. Receiving these commands, the HDC sets BSY bit in STR to "1". Then the HDC sets data buffer pointer, sets BSY bit to "0", and terminates the command execution. It takes up to 100 CLK cycles from the command reception to BSY bit clear. Before issuing above commands, POFF must be specified by command parameters. POFF specifies either DBUFO or DBUF1 to be accessed, and access start address (specifiable range is address 0 to 255).

The host issues move instruction to the HDC after confirming that BSY = 0. Data buffer pointer is incremented each time the HDC receives move instruction (+2 for 16-bit bus mode, +1 for 8-bit bus mode). If the pointer exceeds address 255 during data transfer in PIO mode, the buffer data is not guaranteed. The host must issue RCAL command to close the buffer.

#### Notes on Data Buffer

| Sector Length<br>(Byte)                 | 256 | 512 | 1024 | 2048 | 4096 |
|-----------------------------------------|-----|-----|------|------|------|
| Item                                    |     |     |      |      |      |
| High Speed DMA<br>(0-sector interleave) | ○   | ○   | ○    | ○    | ○    |
| PIO                                     | ○   | ○   |      |      |      |
| Low Speed DMA<br>(free from over-run)   | ○   |     |      |      |      |
| Automatic<br>Correction                 | ○   |     |      |      |      |

○ : Provided

#### Others

**Recall command** — After the host issues RCAL command, the HDC finishes the operation within up to 40 CLK cycles and clears all bits in STR.

**Test command** — After the host issues TST command, the HDC makes drive output pins floated within 60 CLK cycles. To cancel this state, RES signal is to be externally supplied.

**Specify command** — After the host issues SPC command, the HDC makes the drive interface pins fitted for either STS06 or SMD, and clears BSY bit within 250 cycles.

**Abort command** — After the host issues ABT command, the HDC negates all drive output pins within up to 180 CLK cycles, terminates all operation within 300 CLK cycles, and clears BSY bit. Receiving this command, the HDC clears all internal flip-flops, but the value of the control register which has been set by SPC command still remains.

**Reset** — Reset is not a command, but after receiving RES signal, the HDC terminates initialization within up to 150 CLK cycles and clears BSY bit.

**ABSOLUTE MAXIMUM RATINGS**

| Item                   | Symbol               | Value                        | Unit |
|------------------------|----------------------|------------------------------|------|
| Supply Voltage         | V <sub>CC</sub> *1   | -0.3 – +7.0                  | V    |
| Input Voltage          | V <sub>in</sub> *1   | -0.3 – V <sub>CC</sub> + 0.3 | V    |
| Output Current per Pin | I <sub>o</sub>   *2  | 5                            | mA   |
| Total Output Current   | ΣI <sub>o</sub>   *3 | 80                           | mA   |
| Operating Temperature  | T <sub>opr</sub>     | 0 – +70                      | °C   |
| Storage Temperature    | T <sub>stg</sub>     | -55 – +150                   | °C   |

\*1 This value is in reference to V<sub>SS</sub> = 0V.

\*2 The allowable output current is the maximum current that may be drawn from, or flow out to, one output terminal or one input/output common terminal.

\*3 The total allowable output current is the total sum of currents that may be drawn from, or flow out to, output terminals or input/output common terminals.

(Note) Using an LSI beyond its maximum ratings may result in its permanent destruction. LSI's should usually be used under recommended operating conditions. Exceeding any of these conditions may adversely affect its reliability.

**RECOMMENDED OPERATING CONDITIONS**

| Item                     | Symbol            | Min  | Typ | Max             | Unit |
|--------------------------|-------------------|------|-----|-----------------|------|
| Supply Voltage           | V <sub>CC</sub> * | 4.75 | 5.0 | 5.25            | V    |
| Input Low Level Voltage  | V <sub>IL</sub> * | 0    | —   | 0.8             | V    |
| Input High Level Voltage | V <sub>IH</sub> * | 2.2  | —   | V <sub>CC</sub> | V    |
| Operating Temperature    | T <sub>opr</sub>  | 0    | 25  | 70              | °C   |

\* This value is in reference to V<sub>SS</sub> = 0V.



**ELECTRICAL CHARACTERISTICS**DC CHARACTERISTICS ( $V_{CC} = 5.0V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = 0 - 70^\circ C$ , unless otherwise noted)

| Item                                     |                                                                                                   | Symbol                                                                                                                                                                                                                    | 6 MHz Version |          | 8 MHz Version |          | Unit    | Test Condition        |  |  |
|------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------|---------------|----------|---------|-----------------------|--|--|
|                                          |                                                                                                   |                                                                                                                                                                                                                           | HD63463-6     |          | HD63463-8     |          |         |                       |  |  |
|                                          |                                                                                                   |                                                                                                                                                                                                                           | min           | max      | min           | max      |         |                       |  |  |
| Input High Level Voltage                 | All Inputs                                                                                        | $V_{IH}$                                                                                                                                                                                                                  | 2.2           | $V_{CC}$ | 2.2           | $V_{CC}$ | V       |                       |  |  |
| Input Low Level Voltage                  | All Inputs                                                                                        | $V_{IL}$                                                                                                                                                                                                                  | -0.3          | 0.8      | -0.3          | 0.8      | V       |                       |  |  |
| Input Leak Current                       | R/W, $\bar{CS}$ ,<br>RS, $\bar{RES}$<br>$\bar{DACK}$ ,<br>CLK<br>DONE                             | $I_{IN}$                                                                                                                                                                                                                  | -2.5          | 2.5      | -2.5          | 2.5      | $\mu A$ | $V_{in} = 0 - V_{CC}$ |  |  |
|                                          | ST506                                                                                             | SMD                                                                                                                                                                                                                       |               |          |               |          |         |                       |  |  |
|                                          | IDX/<br>TRKO<br>SCP<br>USELD<br>WCLK<br>RCLK                                                      | IDX<br>SEC<br>USELD<br>WCLK<br>RCLK                                                                                                                                                                                       |               |          |               |          |         |                       |  |  |
| Three State<br>(Off State) Input Current | RWDATA<br>SYNC*1<br>WGATE*2<br>EARLY/<br>RGATE*1<br>LATE/<br>STEP*1<br>WFLT<br>LCT/DIR*1<br>READY | RWDATA<br>SKEND<br>BUS <sub>0</sub> /BUS <sub>5</sub><br>BUS <sub>1</sub> /BUS <sub>6</sub><br>BUS <sub>2</sub> /BUS <sub>7</sub><br>BUS <sub>3</sub> /BUS <sub>8</sub><br>BUS <sub>4</sub> /BUS <sub>9</sub><br>BUSL/H*1 | $I_{TSI}$     | -10      | 10            | -10      | 10      | $\mu A$               |  |  |
|                                          | $D_0 - D_{15}$                                                                                    |                                                                                                                                                                                                                           |               |          |               |          |         |                       |  |  |
| Output High Level Voltage                | All Outputs                                                                                       | $V_{OH}$                                                                                                                                                                                                                  | $V_{CC}-1.0$  | -        | $V_{CC}-1.0$  | -        | V       | $I_{OH} = -400 \mu A$ |  |  |
| Output Low Level Voltage                 |                                                                                                   | $V_{OL}$                                                                                                                                                                                                                  | -             | 0.5      | -             | 0.5      | V       | $I_{OL} = 2.2 mA$     |  |  |
| Output Leak Current<br>(Off State)       | IRQ                                                                                               | $I_{LOH}$                                                                                                                                                                                                                 | -             | 10       | -             | 10       | $\mu A$ | $V_{OH} = V_{CC}$     |  |  |

(to be continued)

\*1 These signals are defined when HDC is in Test mode or when drive interface is not specified. Otherwise, these signals are not defined since these are switched to output signals.

\*2 This signal is defined when HDC is in test mode, otherwise this signal is not defined.



| Item                | Symbol          | 6 MHz Version                      |     | 8 MHz Version |     | Unit | Test Condition                                                                                                            |  |  |
|---------------------|-----------------|------------------------------------|-----|---------------|-----|------|---------------------------------------------------------------------------------------------------------------------------|--|--|
|                     |                 | HD63463-6                          |     | HD63463-8     |     |      |                                                                                                                           |  |  |
|                     |                 | min                                | max | min           | max |      |                                                                                                                           |  |  |
| Signal Capacity     | RES             | $C_{pin}$                          | —   | 17            | —   | 17   | $V_{in} = 0\text{ V}$<br>$T_a = 25^\circ\text{C}$<br>$f = 1.0\text{ MHz}$                                                 |  |  |
|                     | DONE            |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | RS              |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | R/W             |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | CS              |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | DACK            |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | $D_0 - D_{15}$  |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | CLK             |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | IRQ             |                                    |     |               |     |      |                                                                                                                           |  |  |
|                     | ST506           | SMD                                |     |               |     |      |                                                                                                                           |  |  |
| Current Consumption | RWDATA          | RWDATA                             |     |               |     |      |                                                                                                                           |  |  |
|                     | WCLK            | WCLK                               |     |               |     |      |                                                                                                                           |  |  |
|                     | RCLK            | RCLK                               |     |               |     |      |                                                                                                                           |  |  |
|                     | —               | SKEND                              |     |               |     |      |                                                                                                                           |  |  |
|                     | —               | BUS <sub>0</sub> /BUS <sub>5</sub> |     |               |     |      |                                                                                                                           |  |  |
|                     | —               | BUS <sub>1</sub> /BUS <sub>6</sub> |     |               |     |      |                                                                                                                           |  |  |
|                     | —               | BUS <sub>2</sub> /BUS <sub>7</sub> |     |               |     |      |                                                                                                                           |  |  |
|                     | WFLT            | BUS <sub>3</sub> /BUS <sub>8</sub> |     |               |     |      |                                                                                                                           |  |  |
|                     | —               | BUS <sub>4</sub> /BUS <sub>9</sub> |     |               |     |      |                                                                                                                           |  |  |
|                     | IDX/TRK0        | IDX                                |     |               |     |      |                                                                                                                           |  |  |
| Current Consumption | SCP             | SEC                                |     |               |     |      |                                                                                                                           |  |  |
|                     | USELD           | USELD                              |     |               |     |      |                                                                                                                           |  |  |
| Current Consumption | READY           | —                                  |     |               |     |      |                                                                                                                           |  |  |
|                     | I <sub>CC</sub> | —                                  | 65  | —             | 80  | mA   | <ul style="list-style-type: none"> <li>Data bus in read/write operation</li> <li>Command execution in progress</li> </ul> |  |  |



**AC CHARACTERISTICS (V<sub>CC</sub> = 5V ± 5%, V<sub>SS</sub> = 0V, Ta = 0 – 70°C, unless otherwise noted.)****Clock Timing**

| No. | Item                               | Symbol | 6MHz Version |     | 8MHz Version |     | Unit | Test Condition |  |  |
|-----|------------------------------------|--------|--------------|-----|--------------|-----|------|----------------|--|--|
|     |                                    |        | HD63463-6    |     | HD63463-8    |     |      |                |  |  |
|     |                                    |        | min          | max | min          | max |      |                |  |  |
| 1   | Clock Cycle time                   | tCYC   | 167          | 500 | 125          | 500 | ns   | See Figure 15  |  |  |
| 2   | Clock Low Level Pulse Width        | tPWCL  | 75           | 250 | 55           | 250 | ns   |                |  |  |
| 3   | Clock High Level Pulse Width       | tPWCH  | 75           | 250 | 55           | 250 | ns   |                |  |  |
| 4   | Clock Rise Time                    | tCR    | —            | 10  | —            | 10  | ns   |                |  |  |
| 5   | Clock Fall Time                    | tCF    | —            | 10  | —            | 10  | ns   |                |  |  |
| 6   | Write Clock Cycle time             | tWCYC  | 62.5         | 250 | 50           | 250 | ns   |                |  |  |
| 7   | Write Clock Low Level Pulse Width  | tPWCL  | 25           | 115 | 20           | 115 | ns   |                |  |  |
| 8   | Write Clock High Level Pulse Width | tWCH   | 25           | 115 | 20           | 115 | ns   |                |  |  |
| 9   | Write Clock Rise Time              | tWCR   | —            | 10  | —            | 10  | ns   |                |  |  |
| 10  | Write Clock Fall Time              | tWCF   | —            | 10  | —            | 10  | ns   |                |  |  |
| 11  | Read Clock Cycle Time              | tRCYC  | 62.5         | 250 | 50           | 250 | ns   |                |  |  |
| 12  | Read Clock Low Level Pulse Width   | tRCL   | 25           | 115 | 20           | 115 | ns   |                |  |  |
| 13  | Read Clock High Level Pulse Width  | tRCH   | 25           | 115 | 20           | 115 | ns   |                |  |  |
| 14  | Read Clock Rise Time               | tRCR   | —            | 10  | —            | 10  | ns   |                |  |  |
| 15  | Read Clock Fall Time               | tRCF   | —            | 10  | —            | 10  | ns   |                |  |  |



**Data Bus Configuration and IRQ**

| No. | Item                           | Symbol  | 6MHz Version |     | 8MHz Version |     | Unit             | Test Condition |  |  |
|-----|--------------------------------|---------|--------------|-----|--------------|-----|------------------|----------------|--|--|
|     |                                |         | HD63463-6    |     | HD63463-8    |     |                  |                |  |  |
|     |                                |         | min          | max | min          | max |                  |                |  |  |
| 21  | <u>RES Input Pulse Width</u>   | tRES    | 10           | —   | 10           | —   | t <sub>cyc</sub> | See Figure 16  |  |  |
| 22  | <u>DACK Setup Time for RES</u> | tDACKSR | 100          | —   | 100          | —   | ns               |                |  |  |
| 23  | <u>DACK Hold Time For RES</u>  | tDACKHR | 0            | 80  | 0            | 50  | ns               |                |  |  |
| 24  | <u>IRQ Delay Time1</u>         | tIRD1   | —            | 200 | —            | 150 | ns               | See Figure 17  |  |  |
| 26  | <u>RES Rise Time</u>           | tRESR   | —            | 10  | —            | 10  | μs               | See Figure 16  |  |  |



## MPU Interface

| No. | Item                              | Symbol | 6MHz Version |     | 8MHz Version |     | Unit | Test Condition           |  |  |
|-----|-----------------------------------|--------|--------------|-----|--------------|-----|------|--------------------------|--|--|
|     |                                   |        | HD63463-6    |     | HD63463-8    |     |      |                          |  |  |
|     |                                   |        | min          | max | min          | max |      |                          |  |  |
| 31  | R/W Setup Time<br>for CS Assert   | tRWS   | 60           | —   | 50           | —   | ns   | See Figures<br>18 and 19 |  |  |
| 32  | R/W Hold Time                     | tRWH   | 0            | —   | 0            | —   | ns   |                          |  |  |
| 33  | RS Setup Time<br>for CS Assert    | tRSS   | 60           | —   | 50           | —   | ns   |                          |  |  |
| 34  | RS Hold Time                      | tRSH   | 0            | —   | 0            | —   | ns   |                          |  |  |
| 35  | CS Setup Time                     | tCSS   | 40           | —   | 40           | —   | ns   |                          |  |  |
| 36  | CS Negate Hold Time               | tCSNH  | 40           | —   | 40           | —   | ns   |                          |  |  |
| 37  | CS Negate Width                   | tCSNW  | 80           | —   | 80           | —   | ns   |                          |  |  |
| 38  | Write Data<br>Setup Time          | tWDS   | 60           | —   | 40           | —   | ns   |                          |  |  |
| 39  | Write Data<br>Hold Time           | tWDH   | 10           | —   | 10           | —   | ns   |                          |  |  |
| 40  | DTACK Delay Time                  | tDTKZL | —            | 85  | —            | 80  | ns   |                          |  |  |
| 41  | DTACK Hold Time                   | tDTKLH | —            | 60  | —            | 60  | ns   |                          |  |  |
| 43  | Data Bus 3 State<br>Recovery Time | tDBR   | 0            | —   | 0            | —   | ns   |                          |  |  |
| 44  | Read Data<br>Access Time          | tRDAC  | —            | 80  | —            | 70  | ns   |                          |  |  |
| 45  | Read Data<br>Hold Time            | tRDH   | 10           | —   | 10           | —   | ns   |                          |  |  |
| 46  | CS Fall Time                      | tCSF   | —            | 1   | —            | 1   | tcyc |                          |  |  |
| 47  | CS Rise Time                      | tCSR   | —            | 1   | —            | 1   | tcyc |                          |  |  |



**DMA Interface**

| No. | Item                                              | Symbol  | 6MHz Version |     | 8MHz Version |     | Unit | Test Condition           |  |  |
|-----|---------------------------------------------------|---------|--------------|-----|--------------|-----|------|--------------------------|--|--|
|     |                                                   |         | HD63463-6    |     | HD63463-8    |     |      |                          |  |  |
|     |                                                   |         | min          | max | min          | max |      |                          |  |  |
| 50  | DREQ Assert<br>Delay Time 1                       | tDRAD1  | —            | 80  | —            | 80  | ns   | See Figures<br>20 and 21 |  |  |
| 51  | DREQ Negate<br>Delay Time 1<br>(Cycle Steal Mode) | tDRND1  | —            | 80  | —            | 80  | ns   |                          |  |  |
| 52  | DREQ Assert<br>Delay Time 2<br>(Cycle Steal Mode) | tDRAD2  | —            | 80  | —            | 80  | ns   |                          |  |  |
| 53  | DREQ Negate<br>Delay Time 2                       | tDRND2  | —            | 80  | —            | 80  | ns   |                          |  |  |
| 54  | DREQ Negate<br>Delay Time 3<br>(DONE Assert)      | tDRND3  | —            | 80  | —            | 80  | ns   |                          |  |  |
| 55  | DMA R/W Setup<br>Time                             | tDRWS   | 60           | —   | 50           | —   | ns   |                          |  |  |
| 56  | DMA R/W<br>Hold Time                              | tDRWH   | 0            | —   | 0            | —   | ns   |                          |  |  |
| 57  | DACK Setup Time                                   | tDACKS  | 40           | —   | 40           | —   | ns   |                          |  |  |
| 58  | DACK Negate Hold<br>Time                          | tDACKHN | 40           | —   | 40           | —   | ns   |                          |  |  |
| 59  | DACK Negate Width                                 | tDAKNW  | 80           | —   | 80           | —   | ns   |                          |  |  |
| 60  | DMA Write Data<br>Setup Time                      | tDWDS   | 60           | —   | 40           | —   | ns   |                          |  |  |
| 61  | DMA Write Data<br>Hold Time                       | tDWDH   | 10           | —   | 10           | —   | ns   |                          |  |  |
| 62  | DMA DTACK Delay<br>Time                           | tDDTZL  | —            | 85  | —            | 80  | ns   |                          |  |  |
| 63  | DMA DTACK Hold<br>Time                            | tDDTLH  | —            | 60  | —            | 60  | ns   |                          |  |  |

(to be continued)



| No. | Item                                     | Symbol | 6MHz Version |     | 8MHz Version |     | Unit | Test Condition           |  |  |
|-----|------------------------------------------|--------|--------------|-----|--------------|-----|------|--------------------------|--|--|
|     |                                          |        | HD63463-6    |     | HD63463-8    |     |      |                          |  |  |
|     |                                          |        | min          | max | min          | max |      |                          |  |  |
| 65  | DONE Input<br>Pulse Width                | tPWDN  | 1.5          | —   | 1.5          | —   | tcyc | See Figures<br>20 and 21 |  |  |
| 66  | DMA Data Bus<br>3 State<br>Recovery Time | tDDBR  | 0            | —   | 0            | —   | ns   |                          |  |  |
| 67  | DMA Read Data<br>Access Time             | tDRDAC | —            | 80  | —            | 70  | ns   |                          |  |  |
| 68  | DMA Read Data<br>Hold Time               | tDRDH  | 10           | —   | 10           | —   | ns   |                          |  |  |
| 69  | DACK Fall Time                           | tDACKF | —            | 1   | —            | 1   | tcyc |                          |  |  |
| 70  | DACK Rise Time                           | tDACKR | —            | 1   | —            | 1   | tcyc |                          |  |  |



## ST506 Interface CE

| No. | Item                                   | Symbol  | 6MHz Version     |                   | 8MHz Version     |                   | Unit | Test Condition |  |  |
|-----|----------------------------------------|---------|------------------|-------------------|------------------|-------------------|------|----------------|--|--|
|     |                                        |         | HD63463-6        |                   | HD63463-8        |                   |      |                |  |  |
|     |                                        |         | min              | max               | min              | max               |      |                |  |  |
| 110 | USELD Setup Time (for USEL)            | tUSLDS  | —                | 5                 | —                | 5                 | tcyc | See Figure 22  |  |  |
| 111 | WGATE Delay Time for Index             | tWGTIDX | —                | 150               | —                | 100               | ns   | See Figure 23  |  |  |
| 112 | WFLT Pulse Width                       | tWFLT   | 2                | —                 | 2                | —                 | tcyc |                |  |  |
| 113 | Index Pulse Width                      | tIDXW   | 8tcyc<br>24twcyc | —<br>—            | 8tcyc<br>24twcyc | —<br>—            | —    |                |  |  |
| 114 | WGATE Delay Time                       | tWGTD   | —                | 130               | —                | 125               | ns   |                |  |  |
| 116 | Write Data Delay Time                  | tWDD    | —                | 130               | —                | 125               | ns   |                |  |  |
| 118 | LATE/EARLY Delay Time                  | tELD    | —                | 130               | —                | 125               | ns   |                |  |  |
| 120 | LATE/EARLY Setup Time (for Write Data) | tWDS    | 0                | —                 | 0                | —                 | ns   |                |  |  |
| 121 | RGATE Delay Time                       | tRGTD   | —                | 130               | —                | 125               | ns   |                |  |  |
| 123 | SYNC Delay Time                        | tSYND   | —                | 130               | —                | 125               | ns   |                |  |  |
| 125 | Read Data Setup Time                   | tRDS    | 20               | —                 | 15               | —                 | ns   | See Figure 25  |  |  |
| 126 | Read Data Hold Time                    | tRDH    | 20               | —                 | 15               | —                 | ns   |                |  |  |
| 127 | USELD-DIR Time                         | tUS-DIR | 70               | —                 | 70               | —                 | tcyc |                |  |  |
| 128 | STEP-USEL Time                         | tSTPUS  | 80               | —                 | 80               | —                 | tcyc |                |  |  |
| 129 | DIR-STEP Time                          | tDIRSTP | 270              | —                 | 270              | —                 | tcyc | See Figure 26  |  |  |
| 130 | STP-DIR Time                           | tSTPDIR | 80               | —                 | 80               | —                 | tcyc |                |  |  |
| 131 | SEEK-USEL Time                         | tSEKUS  | 1                | —                 | 1                | —                 | tcyc |                |  |  |
| 132 | SCP Wait Time                          | tSCP    | —                | $1.0 \times 10^7$ | —                | $1.0 \times 10^7$ | tcyc |                |  |  |

(Note 1) The index pulse width must satisfy min 8 tcyc and min 24 twcyc.



**SMD Interface**

| No. | Item                         | Symbol  | 6MHz Version     |                   | 8MHz Version     |        | Unit | Test Condition            |  |  |
|-----|------------------------------|---------|------------------|-------------------|------------------|--------|------|---------------------------|--|--|
|     |                              |         | HD63463-6        |                   | HD63463-8        |        |      |                           |  |  |
|     |                              |         | min              | max               | min              | max    |      |                           |  |  |
| 150 | Index Pulse Width            | tIDXW   | 8tcyc<br>12twcyc | 50tcyc<br>12twcyc | 8tcyc<br>12twcyc | 50tcyc | —    | (Note 2)<br>See Figure 32 |  |  |
| 151 | USELD Setup Time             | tUSLDS  | —                | 7                 | —                | 7      | tcyc | See Figure 31             |  |  |
| 152 | Sector Pulse Width           | tPWSET  | 8tcyc<br>12twcyc | 50tcyc<br>12twcyc | 8tcyc<br>12twcyc | 50tcyc | —    | (Note 2)<br>See Figure 32 |  |  |
| 153 | WGATE Delay Time for SEC/IDX | tWGTSEC | —                | 150               | —                | 125    | ns   | See Figure 32             |  |  |
| 156 | REGATE Delay Time            | tRGTD   | —                | 130               | —                | 125    | ns   | See Figure 33             |  |  |
| 158 | Read Data Setup Time         | tRDS    | 20               | —                 | 15               | —      | ns   |                           |  |  |
| 159 | Read Data Hold Time          | tRDH    | 20               | —                 | 15               | —      | ns   |                           |  |  |
| 165 | WGATE Delay Time             | tWGTD   | —                | 130               | —                | 125    | ns   |                           |  |  |
| 169 | Write Data Delay Time        | tWDD    | —                | 130               | —                | 125    | ns   | See Figure 34             |  |  |

(Note 2) The index sector pulse width must satisfy min 8 tcyc and min 12 twcyc.



Figure 13 Test Load Circuit A



Figure 14 Test Load Circuit B



Figure 15 CLOCK





Figure 16 RES - DTACK Input Timing (Data Bus Width Selection)



Figure 17 TRO Output Timing

Figure 18 MPU Read Cycle  
HDC → MPU



**Figure 19 MPU Write Cycle  
MPU → HDC  
(8 or 16-bit data bus)**

$n = \min 7$  (16-bit data bus)  
 $n = \min 5$  (8-bit data bus)



Figure 20 DMA Read Cycle  
HDC → Memory



Figure 21 DMA Write Cycle  
Memory → HDC



Figure 22 USEL, USELD Timing (ST506)



Figure 23 WFLT, IDX, WGATE Timing (ST506)



Figure 24 Write Operation (ST506)



Figure 25 Read Operation (ST506)



Figure 26 Head Positioning Operation (ST506)



Figure 27 ID Search Timing Chart (ST506)



Figure 28 Write Data Timing (ST506)





Figure 29 Write Format Timing (ST506)



Figure 30 Seek, Recalibrate Command Execution Timing (ST506)



Figure 31 UTAG, USELD Timing (SMD)



Figure 32 IDX/SEC, WGATE Timing (SMD)





Figure 33 Read Operation (SMD)



Figure 34 Write Operation (SMD)



Figure 35 Drive Select Operation (SMD)



Figure 36 Drive Check Operation (SMD)



Figure 37 Fault Clear Operation (SMD)



BUSL/H = low

| Pin                                | Output Signal Name | Abbreviation | Level |
|------------------------------------|--------------------|--------------|-------|
| BUS <sub>4</sub> /BUS <sub>9</sub> | Reserve            | O            | low   |
| BUS <sub>3</sub> /BUS <sub>8</sub> | Strobe Late        | STBL         | low   |
| BUS <sub>2</sub> /BUS <sub>7</sub> | Strobe Early       | STBE         | low   |
| BUS <sub>1</sub> /BUS <sub>6</sub> | Return to Zero     | RTZ          | high  |
| BUS <sub>0</sub> /BUS <sub>5</sub> | Reserve            | O            | low   |

BUSL/H = high

| Pin                                | Output Signal Name | Abbreviation | Level |
|------------------------------------|--------------------|--------------|-------|
| BUS <sub>4</sub> /BUS <sub>9</sub> | Fault Clear        | FCLR         | low   |
| BUS <sub>3</sub> /BUS <sub>8</sub> | Servo Offset Minus | SOFM         | low   |
| BUS <sub>2</sub> /BUS <sub>7</sub> | Servo Offset Plus  | SOFP         | low   |
| BUS <sub>1</sub> /BUS <sub>6</sub> | Read Gate          | RGATE        | low   |
| BUS <sub>0</sub> /BUS <sub>5</sub> | Write Gate         | WGATE        | low   |

(Note) On Cylinder and Seek Error are checked by Polling command.

Figure 38 Recalibrate Command Execution Timing (SMD)



Figure 39 Seek Command Execution Timing (SMD)



Figure 40 Head Selection Operation (SMD)



Figure 41 Read/Write Operation (1) (SMD)



Figure 42 Read/Write Operation (2) (SMD)



Figure 43 Read/Write Operation (3) (SMD)



Figure 44 Sense Drive Operation (1) (SMD)



Figure 45 Check Drive Status (2) (SMD)



Figure 46 Check Drive Status (3) (SMD)



Figure 47 Check Drive Status (4) (SMD)



Figure 48 Timing Requirement during Power-On.

# HD63484

## ACRTC (Advanced CRT Controller)

The Advanced CRT Controller (ACRTC) is a CMOS VLSI microcomputer peripheral device capable of controlling raster-scan CRTs to display both graphics and characters. The ACRTC is a new generation CRT controller that is based on a bit-mapped technology. It executes high-level drawing commands, like Line, Ellipse, Paint, Pattern, and Copy, issued by the MPU in X-Y coordinates, and performs address translation to draw into frame memory. It can draw in up to 64K colors, on 3 split screens and an independent window, and perform area clipping and hitting. It has more display control functions than an HD6845S (CRTC).

The ACRTC controls a CRTC in one of three modes; character only, graphic only and multiplexed character/graphic modes. Therefore, the ACRTC has many applications, from character only display devices to large full-graphic systems.

The ACRTC can reduce CPU software overhead and enhance system throughput.

### ■ FEATURES

- High-speed graphics
  - Drawing rate: Maximum 500 ns/pixel (Color drawing)
  - Commands: Dot, Line, Rectangle, Poly-line, Polygon, Circle, Ellipse, Paint, Copy, etc.
  - Colors: 16 bits/word
    - 1, 2, 4, 8, 16 bits/pixel (5 types) monochrome to max. 64k colors.
  - Pattern RAM (32 bytes)
  - Conversion of logical X-Y coordinates into physical address.
  - Color operation and conditional drawing
  - Drawing area control for hardware clipping and hitting
- Large frame-memory space
  - Maximum 2M bytes graphic memory and 128k bytes character memory separated from the MPU memory
  - Maximum resolution 4096 x 4096 (1 bit/pixel mode)
- CRT display controls
  - Split screens (3 displays and 1 window)
  - Zooming up (1 to 16 times)
  - Scroll (Vertical and horizontal)
- Interleaved Access mode for flashless display and superimposition
- External synchronization between ACRTCs or between the ACRTC and external device (ex. TV system or other controller)
- DMA interface
- Two programmable cursors
- Three scan modes
  - Non-interlaced
  - Interlace sync.
  - Interlace sync. and video
- 256 characters/line, 32 rasters/line, 4096 rasters/screen

### ■ TYPE OF PRODUCTS

| Product type | Clock Frequency (2CLK) | Package             |
|--------------|------------------------|---------------------|
| HD63484-8    | 8 MHz                  | DC-64               |
| HD63484-98   | 9.8 MHz                | 64 Pin Ceramic DIP  |
| HD63484P-8   | 8 MHz                  | DP-64               |
| HD63484P-98  | 9.8 MHz                | 64 Pin Ceramic DIP  |
| HD63484CP-8  | 8 MHz                  | CP-68               |
| HD63484CP-98 | 9.8 MHz                | 64 Pin Ceramic PLCC |
| HD63484Y-8   | 8 MHz                  | PGA-68              |
| HD63484Y-98  | 9.8 MHz                | 64 Pin Ceramic PGA  |



■ PIN ARRANGEMENT (Top View)  
● HD63484, HD63484P

• HD63484CP



(Top View)



(Top View)

#### ■ ABSOLUTE MAXIMUM RATINGS

| Item                           | Symbol               | Rating                | Unit |
|--------------------------------|----------------------|-----------------------|------|
| Supply Voltage                 | $V_{CC}^*$           | -0.3 to +7.0          | V    |
| Input Voltage                  | $V_{in}^*$           | -0.3 to $V_{CC}$ +0.3 | V    |
| Allowable Output Current       | $ I_O ^{**}$         | 5                     | mA   |
| Total Allowable Output Current | $ \Sigma I_O ^{***}$ | 120                   | mA   |
| Operating Temperature          | $T_{opr}$            | 0 to +70              | °C   |
| Storage Temperature            | $T_{sta}$            | -55 to +150           | °C   |

\* This value is in reference to  $V_{SS} = 0V$

- This value is in reference to  $V_{SS} = 0V$
- The allowable output current is the maximum current that may be drawn from, or flow out to, one output terminal or one input/output common terminal.

\*\*\* The total allowable output current is the total sum of currents that may be drawn from, or flow out to, output terminals or input/output common terminals.

(Note) Using an LSI beyond its maximum ratings may result in its permanent destruction. LSIs should usually be used under recommended operating conditions. Exceeding any of these conditions may adversely affect its reliability.

#### ■ RECOMMENDED OPERATING CONDITIONS

| Item                       | Symbol      | Min  | Typ | Max      | Unit |
|----------------------------|-------------|------|-----|----------|------|
| Supply Voltage             | $V_{CC}$ *  | 4.75 | 5.0 | 5.25     | V    |
| Input "Low" Level Voltage  | $V_{IL}$ *  | 0    | —   | 0.7      | V    |
| Input "High" Level Voltage | $V_{IH}$ ** | 2.2  | —   | $V_{CC}$ | V    |
| Operating Temperature      | $T_{opr}$   | 0    | 25  | 70       | °C   |

\*This value is in reference to  $V_{SS} = 0V$

## ■ TIMING MEASUREMENT

The timing measurement point for the output "low" level is defined at 0.8V throughout this specification.

The output "low" level at stable condition (DC characteristics) is defined at 0.5V.

The output "high" level is defined at  $V_{CC}=2.0V$ .





### ■ Electrical Characteristics

• DC Characteristics ( $V_{CC} = 5.0V \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = 0$  to  $70^{\circ}C$  unless otherwise noted)

| Item                                  | Symbol                                                                                                                                     | Measuring Condition | 8 MHz Version                                                                                  |                  | 9.8 MHz Version |                  | Unit |         |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------------|------------------|-----------------|------------------|------|---------|
|                                       |                                                                                                                                            |                     | Min                                                                                            | Max              | Min             | Max              |      |         |
| Input "high" level voltage            | All Inputs                                                                                                                                 | $V_{IH}$            | 2.2                                                                                            | $V_{CC}$         | 2.4             | $V_{CC}$         | V    |         |
| Input "low" level voltage             | All Inputs                                                                                                                                 | $V_{IL}$            | -0.3                                                                                           | 0.7              | -0.3            | 0.7              | V    |         |
| Input leak current                    | R/W, CS, RS, RES, DACK, 2CLK, LPSTB                                                                                                        | $I_{IN}$            | $V_{in} = 0$ to $V_{CC}$                                                                       | -2.5             | 2.5             | -2.5             | 2.5  | $\mu A$ |
| Three state (off state) input current | $D_0$ – $D_{15}$ , EXSYNC, MAD <sub>0</sub> –MAD <sub>15</sub>                                                                             | $I_{TSI}$           | $V_{in} + 0.4$ to $V_{CC}$                                                                     | -10              | 10              | -10              | 10   | $\mu A$ |
| Output "high" level voltage           | $D_0$ – $D_{15}$ , MAD <sub>0</sub> –MAD <sub>15</sub> , CUD1, CUD2, DREQ, DTACK, HSYNC, VSYNC, EXSYNC,                                    | $V_{OH}$            | $I_{OH} + -400 \mu A$                                                                          | $V_{CC}$<br>-1.0 | —               | $V_{CC}$<br>-1.0 | —    | V       |
| Output "low" level voltage            | DISP1, DISP2, CHR, MRD, DRAW, AS, MCYC, MA <sub>16</sub> /RA <sub>0</sub> –MA <sub>19</sub> /RA <sub>3</sub> , RA <sub>4</sub> , IRQ, DONE | $V_{OL}$            | $I_{OL} = 2.2$ mA                                                                              | —                | 0.5             | —                | 0.5  | V       |
| Output leak current (off state)       | IRQ, DONE                                                                                                                                  | $I_{LOD}$           | $V_{OH} = V_{CC}$                                                                              | —                | 10              | —                | 10   | $\mu A$ |
| Input capacity                        | $D_0$ – $D_{15}$ , EXSYNC, MAD <sub>0</sub> –MAD <sub>15</sub>                                                                             | $C_{in}$            | $V_{in} = 0$ V<br>$T_A = 25^{\circ}C$<br>$f = 1.0$ mHz                                         | —                | 17              | —                | 17   | pF      |
|                                       | R/W, CS, RS, RES, DACK, 2CLK, LPSTB                                                                                                        |                     | $V_{in} = 0$ V<br>$T_A = 25^{\circ}C$<br>$f = 1.0$ mHz                                         | —                | 17              | —                | 17   | pF      |
| Output capacity                       | IRQ, DONE                                                                                                                                  | $C_{out}$           | $V_{in} = OV$<br>$T_A = 25^{\circ}C$<br>$f = 1.0$ mHz                                          | —                | 15              | —                | 15   | pF      |
| Current consumption                   |                                                                                                                                            | $I_{CC}$            | • Chip not selected<br>• Display in progress                                                   | —                | 100             | —                | 120  | mA      |
|                                       |                                                                                                                                            |                     | • Data bus in read/write operation<br>• Display in progress<br>• Command execution in progress | —                | 100             | —                | 120  | mA      |

- AC Characteristics ( $V_{CC} = 5.0 \pm 5\%$ ,  $V_{SS} = 0V$ ,  $T_a = 0$  to  $70^\circ C$  unless otherwise noted)
- Clock Timing

| No. | Item                           | Symbol            | Reference Figure Number | 8 MHz Version |      | 9.8 MHz Version |      | Unit |
|-----|--------------------------------|-------------------|-------------------------|---------------|------|-----------------|------|------|
|     |                                |                   |                         | Min           | Max  | Min             | Max  |      |
| 1   | Operation Frequency of 2 CLK   | f                 | 1                       | 1             | 8    | 1               | 9.8  | MHz  |
|     | Clock Cycle Time               | t <sub>CYC</sub>  |                         | 125           | 1000 | 102             | 1000 | ns   |
|     | Clock "High" Level Pulse Width | t <sub>PWCH</sub> |                         | 55            | 500  | 46              | 500  | ns   |
|     | Clock "Low" Level Pulse Width  | t <sub>PWCL</sub> |                         | 55            | 500  | 46              | 500  | ns   |
|     | Clock Rise Time                | t <sub>Cr</sub>   |                         | —             | 10   | —               | 5    | ns   |
|     | Clock Fall Time                | t <sub>Cf</sub>   |                         | —             | 10   | —               | 5    | ns   |

#### MPU Read/Write Cycle Timing

| No. | Item                             | Symbol             | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit |
|-----|----------------------------------|--------------------|-------------------------|---------------|-----|-----------------|-----|------|
|     |                                  |                    |                         | Min           | Max | Min             | Max |      |
| 2-4 | R/W Setup Time                   | t <sub>RWS</sub>   | 2-4                     | 50            | —   | 50              | —   | ns   |
|     | R/W Hold Time                    | t <sub>RWH</sub>   |                         | 0             | —   | 0               | —   | ns   |
|     | RS Setup Time                    | t <sub>RSS</sub>   |                         | 50            | —   | 50              | —   | ns   |
|     | RS Hold Time                     | t <sub>RSH</sub>   |                         | 0             | —   | 0               | —   | ns   |
|     | CS Setup Time                    | t <sub>CS</sub>    |                         | 40            | —   | 40              | —   | ns   |
|     | CS "High" Level Width            | t <sub>WCSH</sub>  |                         | 60            | —   | 60              | —   | ns   |
| 12  |                                  |                    |                         |               |     |                 |     |      |
| 13  | Read Wait Time                   | t <sub>RWAI</sub>  | 2, 4                    | 0             | —   | 0               | —   | ns   |
| 14  | Read Data Access Time            | t <sub>RDAC</sub>  |                         | —             | 80  | —               | 80  | ns   |
| 15  | Read Data Hold Time              | t <sub>RDH</sub>   |                         | 10            | —   | 10              | —   | ns   |
| 16  | Read Data Turn Off Time          | t <sub>RDZ</sub>   |                         | —             | 60  | —               | 60  | ns   |
| 17  | DTACK Delay Time (Z to L)        | t <sub>DTKZL</sub> | 2-4                     | —             | 70  | —               | 70  | ns   |
| 18  | DTACK Delay Time (D to L)        | t <sub>DTKDL</sub> | 2, 4                    | 0             | —   | 0               | —   | ns   |
| 19  | DTACK Release Time (L to H)      | t <sub>DTKLH</sub> | 2-4                     | —             | 80  | —               | 80  | ns   |
| 20  | DTACK Turn Off Time (H to Z)     | t <sub>DTKZ</sub>  |                         | —             | 100 | —               | 100 | ns   |
| 21  | Data Bus 3 State Recovery Time 1 | t <sub>DBRT1</sub> | 2, 4                    | 0             | —   | 0               | —   | ns   |
| 22  | Write Wait Time                  | t <sub>WWAI</sub>  | 3, 4                    | 0             | —   | 0               | —   | ns   |
| 23  | Write Data Setup Time            | t <sub>WDS</sub>   |                         | 40            | —   | 40              | —   | ns   |
| 24  | Write Data Hold Time             | t <sub>WDH</sub>   |                         | 10            | —   | 10              | —   | ns   |



## DMA Read/Write Cycle Timing

| No. | Item                               | Symbol      | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit |
|-----|------------------------------------|-------------|-------------------------|---------------|-----|-----------------|-----|------|
|     |                                    |             |                         | Min           | Max | Min             | Max |      |
| 25  | DREQ Delay Time 1                  | $t_{DRQD1}$ | 5-8                     | —             | 110 | —               | 110 | ns   |
| 26  | DREQ Delay Time 2                  | $t_{DRQD2}$ |                         | —             | 70  | —               | 70  | ns   |
| 27  | DMA R/W Setup Time                 | $t_{DMRWS}$ |                         | 50            | —   | 50              | —   | ns   |
| 28  | DMA R/W Hold Time                  | $t_{DMRWH}$ |                         | 0             | —   | 0               | —   | ns   |
| 29  | DACK Setup Time                    | $t_{DAKS}$  |                         | 40            | —   | 40              | —   | ns   |
| 30  | DACK "High" Level Width            | $t_{WDAKH}$ |                         | 60            | —   | 60              | —   | ns   |
| 31  |                                    |             |                         |               |     |                 |     |      |
| 32  | DMA Read Wait Time                 | $t_{DRW}$   | 5, 6                    | 0             | —   | 0               | —   | ns   |
| 33  | DMA Read Data Access Time          | $t_{DRDAC}$ |                         | —             | 80  | —               | 80  | ns   |
| 34  | DMA Read Data Hold Time            | $t_{DRDH}$  |                         | 10            | —   | 10              | —   | ns   |
| 35  | DMA Read Data Turn Off Time        | $t_{DRDZ}$  |                         | —             | 60  | —               | 60  | ns   |
| 36  | DMA DTACK Delay Time (Z to L)      | $t_{DDTDL}$ | 5-8                     | —             | 70  | —               | 70  | ns   |
| 37  | DMA DTACK Delay Time (D to L)      | $t_{DDTDL}$ | 5, 6                    | 0             | —   | 0               | —   | ns   |
| 38  | DMA DTACK Release Time (L to H)    | $t_{DDTLH}$ | 5-8                     | —             | 80  | —               | 80  | ns   |
| 39  | DMA DTACK Turn Off Time (H to Z)   | $t_{DDTHZ}$ |                         | —             | 100 | —               | 100 | ns   |
| 40  | DONE Output Delay Time             | $t_{DND}$   |                         | —             | 70  | —               | 70  | ns   |
| 41  | DONE Output Turn Off Time (L to Z) | $t_{DNLZ}$  |                         | —             | 80  | —               | 80  | ns   |
| 42  | Data Bus 3 State Recovery Time 2   | $t_{DBRT2}$ | 5, 6                    | 0             | —   | 0               | —   | ns   |
| 43  | DONE Input Pulse Width             | $t_{DNPW}$  | 5, 8                    | 2             | —   | 2               | —   | Clk. |
| 44  | DMA Write Wait Time                | $t_{DWW}$   | 7-8                     | 0             | —   | 0               | —   | ns   |
| 45  | DMA Write Data Setup Time          | $t_{DWDS}$  |                         | 40            | —   | 40              | —   | ns   |
| 46  | DMA Write Data Hold Time           | $t_{DWDH}$  |                         | 10            | —   | 10              | —   | ns   |
| 47  |                                    |             |                         |               |     |                 |     |      |



## Frame Memory Read/Write Cycle Timing

| No. | Item                                  | Symbol      | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit |
|-----|---------------------------------------|-------------|-------------------------|---------------|-----|-----------------|-----|------|
|     |                                       |             |                         | Min           | Max | Min             | Max |      |
| 48  | AS "Low" Level Pulse Width            | $t_{PWASL}$ | 9-12                    | 25            | —   | 20              | —   | ns   |
| 49  | Memory Address Hold Time 2            | $t_{MAH2}$  |                         | 10            | —   | 5               | —   | ns   |
| 50  | AS Delay Time 1                       | $t_{ASD1}$  |                         | —             | 60  | —               | 50  | ns   |
| 51  | AS Delay Time 2                       | $t_{ASD2}$  |                         | 5             | 65  | 5               | 40  | ns   |
| 52  | Memory Address Delay Time             | $t_{MAD}$   |                         | 15            | 70  | 10              | 50  | ns   |
| 53  | Memory Address Hold Time 1            | $t_{MAH1}$  |                         | 25            | —   | 15              | —   | ns   |
| 54  | Memory Address Turn Off Time (A to Z) | $t_{MAAZ}$  | 9, 10, 12               | —             | 50  | —               | 35  | ns   |
| 55  | Memory Read Data Setup Time           | $t_{MRDS}$  | 10                      | 35            | —   | 30              | —   | ns   |
| 56  | Memory Read Data Hold Time            | $t_{MRDH}$  |                         | 10            | —   | 0               | —   | ns   |
| 57  | MA/RA Delay Time                      | $t_{MARAD}$ | 9-12                    | —             | 80  | —               | 60  | ns   |
| 58  | MA/RA Hold Time                       | $t_{MARAH}$ | 9-11                    | 10            | —   | 5               | —   | ns   |
| 59  | MCYC Delay Time                       | $t_{MCYCD}$ | 9-13                    | 5             | 60  | 5               | 40  | ns   |
| 60  | MRD Delay Time                        | $t_{MRDD}$  | 9-12                    | —             | 70  | —               | 50  | ns   |
| 61  | MRD Hold Time                         | $t_{MRH}$   |                         | 10            | —   | 5               | —   | ns   |
| 62  | DRAW Delay Time                       | $t_{DRWD}$  |                         | —             | 70  | —               | 50  | ns   |
| 63  | DRAW Hold Time                        | $t_{DRWH}$  |                         | 10            | —   | 5               | —   | ns   |
| 64  | Memory Write Data Delay Time          | $t_{MWDD}$  | 11                      | —             | 70  | —               | 50  | ns   |
| 65  | Memory Write Data Hold Time           | $t_{MWDH}$  |                         | 10            | —   | 5               | —   | ns   |
| 110 | Memory Address Setup Time 1           | $t_{MAS1}$  | 9-12                    | 10            | —   | 10              | —   | ns   |
| 112 | Memory Address Setup Time 2           | $t_{MAS2}$  | 9-12                    | 10            | —   | 10              | —   | ns   |

NOTE 1) Characteristic of No. 52 is defined independently of 2CLK operation frequency (f) and timing of No. 51 and No. 110.



**Display Control Signal Output Timing**

| No. | Item                     | Symbol     | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit |
|-----|--------------------------|------------|-------------------------|---------------|-----|-----------------|-----|------|
|     |                          |            |                         | Min           | Max | Min             | Max |      |
| 67  | HSYNC Delay Time         | $t_{HSD}$  | 12-14<br>13             | —             | 70  | —               | 50  | ns   |
| 68  | VSYNC Delay Time         | $t_{VSD}$  |                         | —             | 70  | —               | 50  | ns   |
| 69  | DISP1, DISP2 Delay Time  | $t_{DSPD}$ |                         | —             | 70  | —               | 50  | ns   |
| 70  | CUD1, CUD2 Delay time    | $t_{CUDD}$ |                         | —             | 70  | —               | 50  | ns   |
| 71  | EXSYNC Output Delay Time | $t_{EXD}$  |                         | 20            | 70  | 15              | 50  | ns   |
| 72  | CHR Delay Time           | $t_{CHD}$  |                         | —             | 70  | —               | 50  | ns   |
| 73  |                          |            |                         |               |     |                 |     |      |
| 74  |                          |            |                         |               |     |                 |     |      |

**EXSYNC Input timing**

| No. | Item                     | Symbol     | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit      |
|-----|--------------------------|------------|-------------------------|---------------|-----|-----------------|-----|-----------|
|     |                          |            |                         | Min           | Max | Min             | Max |           |
| 75  | EXSYNC Input Pulse Width | $t_{EXSW}$ | 14                      | 3             | —   | 3               | —   | $t_{cyc}$ |
| 76  | EXSYNC Input Setup Time  | $t_{EXS}$  |                         | 50            | —   | 30              | —   | ns        |
| 77  | EXSYNC Input Hold Time   | $t_{EXH}$  |                         | 15            | —   | 10              | —   | ns        |

**LPSTB Input Timing**

| No. | Item                     | Symbol     | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit      |
|-----|--------------------------|------------|-------------------------|---------------|-----|-----------------|-----|-----------|
|     |                          |            |                         | Min           | Max | Min             | Max |           |
| 78  | LPSTB Uncertain Time 1   | $t_{LPD1}$ | 15, 16                  | 70            | —   | 45              | —   | ns        |
| 79  | LPSTB Uncertain Time 2   | $t_{LPD2}$ |                         | 10            | —   | 10              | —   | ns        |
| 80  | LPSTB Input Hold Time    | $t_{LPH}$  |                         | 10            | —   | 10              | —   | ns        |
| 81  | LPSTB Input Inhibit Time | $t_{LPI}$  |                         | 4             | —   | 4               | —   | $t_{cyc}$ |

**RES Input and DACK Input Timing**

| No. | Item                    | Symbol      | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit      |
|-----|-------------------------|-------------|-------------------------|---------------|-----|-----------------|-----|-----------|
|     |                         |             |                         | Min           | Max | Min             | Max |           |
| 82  | DACK Setup Time for RES | $t_{DAKSR}$ | 17                      | 100           | —   | 100             | —   | ns        |
| 83  | DACK Hold Time for RES  | $t_{DAKHR}$ |                         | 0             | —   | 0               | —   | ns        |
| 84  | RES Impulse Pulse Width | $t_{RES}$   |                         | 10            | —   | 10              | —   | $t_{cyc}$ |



**IRQ Output, Video Attributes Output Cycle Timing**

| No. | Item             | Symbol      | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit |
|-----|------------------|-------------|-------------------------|---------------|-----|-----------------|-----|------|
|     |                  |             |                         | Min           | Max | Min             | Max |      |
| 85  | IRQ Delay Time 1 | $t_{IRQ1}$  | 18, 19                  | —             | 150 | —               | 150 | ns   |
| 86  | IRQ Delay Time 2 | $t_{IRQ2}$  |                         | —             | 500 | —               | 500 | ns   |
| 87  | ATR Delay Time 1 | $t_{ATRD1}$ | 12                      | —             | 80  | —               | 60  | ns   |
| 88  | ATR Hold Time 1  | $t_{ATRH1}$ |                         | 10            | —   | 5               | —   | ns   |
| 89  |                  |             |                         |               |     |                 |     |      |
| 90  | ATR Delay Time 2 | $t_{ATRD2}$ | 12                      | —             | 80  | —               | 60  | ns   |
| 91  | ATR Hold Time 2  | $t_{ATRH2}$ |                         | 10            | —   | 5               | —   | ns   |

**MPU Read/Write Cycle Timing (synchronous bus),  
DMA Read/Write Cycle Timing (synchronous bus)**

| No. | Item                    | Symbol       | Reference Figure Number | 8 MHz Version |     | 9.8 MHz Version |     | Unit      |
|-----|-------------------------|--------------|-------------------------|---------------|-----|-----------------|-----|-----------|
|     |                         |              |                         | Min           | Max | Min             | Max |           |
| 100 | CS Cycle Time           | $t_{CSC}$    | 2, 3                    | 4             | —   | 4               | —   | $t_{cyc}$ |
| 101 | CS "Low" Level Width    | $t_{WCSL}$   |                         | 2             | —   | 2               | —   | $t_{cyc}$ |
| 102 | CS "High" Level Width   | $t_{WCSH}$   | 6, 8                    | 2             | —   | 2               | —   | $t_{cyc}$ |
| 103 |                         |              |                         |               |     |                 |     |           |
| 104 | DACK Cycle Time         | $t_{DACKC}$  | 6, 8                    | 4             | —   | 4               | —   | $t_{cyc}$ |
| 105 | DACK "Low" Level Width  | $t_{WDACKL}$ |                         | 2             | —   | 2               | —   | $t_{cyc}$ |
| 106 | DACK "High" Level Width | $t_{WDACKH}$ |                         | 2             | —   | 2               | —   | $t_{cyc}$ |



Figure 1 2CLK Waveform





Figure 2 MPU Read Cycle Timing (MPU → ACRTC)



Figure 3 MPU Write Cycle Timing (MPU → ACRTC)



(Note) When the MPU read cycle immediately follows the MPU write cycle execution, DTACK and the read data responses delay (by 3 tcy) even though spec ⑩2 is satisfied.

Figure 4 MPU Read/Write Cycle Timing (MPU ↔ ACRTC)



Figure 5 DMA Read Cycle Timing (System Memory  $\leftarrow$  ACRTC)



(Note) DACK "high" level width must satisfy spec (30). Unless satisfying spec (106),  
 DTACK and the read data delay to the succeeding cycle  
 When the ACRTC is used with the synchronous bus timing, specifications (104), (105)  
 and (106) must be satisfied

\* DONE needs to be asserted "Low" while  
 DACK remains "Low". DONE "Low" width  
 must satisfy spec. (43).

**Figure 6 DMA Read Cycle Timing (System Memory → ACRTC): Burst Mode**



**Figure 7 DMA Write Cycle Timing (System Memory → ACRTC)**



(Note) DACK "high" level width must satisfy spec (30). Unless satisfying spec (106).  
DTACK response delays to the succeeding cycle.

When the ACRTC is used with the synchronous bus timing, specifications (104), (105) and (106) must be satisfied.

\* DONE needs to be asserted "Low" while DACK remains "low".  
DONE "low" width must satisfy spec (43)

Figure 8 DMA Write Cycle Timing (System Memory → ACRTC): Burst Mode



Figure 9 Display Cycle Timing

Figure 10 Frame Memory Read Cycle Timing  
(ACRTC → Frame Memory)



**Figure 11 Frame Memory Write Cycle Timing  
(ACRTC → Frame Memory)**



**Figure 12 Frame Memory Refresh/Video Attribute Output Cycle Timing**





Figure 13 Display Control Signal Output Timing



Figure 14 EXSYNC Input Timing



**Figure 15 LPSTB Input Timing (Single Access Mode)****Figure 16 LPSTB Input Timing (Dual Access Mode)**



**Figure 17** RES Input and DACK Input Timing  
(System Reset and 16-bit/8-bit Selection)



**Figure 18** IRQ Output Timing



This is an IRQ output timing example. In this case, IRQ is generated by status flag RFF (Read FIFO Full).

When issuing read commands (RD) which transfer data exceeding Read FIFO space (8 words), the FIFO becomes full, and the command execution pauses (RFF: set, IRQ: generated). By reading out 1-word data, spare occurs in the FIFO, and the ACRTC resets RFF flag and then negates IRQ, while on the other hand the ACRTC resumes the internal operation (command execution) to fill the FIFO, and sets RFF flag and then asserts IRQ again.

In this case, the timing from IRQ negate to assert is 3 cycles (tcyc).

**Figure 19** IRQ Output Timing (Example: Read FIFO Full interrupt Enable)



Figure 20 Test Load Circuit A



Figure 21 Test Load Circuit B

### Power on Sequence

(Note)

When turning power on, 2CLK and  $\overline{\text{RES}}$  timings must be as shown in figure E22. The delay time from Vcc rising to 2CLK rising ( $t_{2CH}$ ) must be under 100 ms, and that from Vcc rising to  $\overline{\text{RES}}$  rising ( $t_{REH}$ ) must be above 100 ms.



Figure 22 Power On Sequence



### Ringing Noise and Damping Resistor

If excessive ringing noise occurs on CRT data bus (figure E23), damping resistors may be required for the data bus as shown in figure E24.



Figure 23 Ringing Noise



Figure 24 Damping Resistor

### Note for Designing Power Supply Circuit



Figure 25 Note for Designing Power Supply Circuit

When designing Vcc and Vss pattern of the circuit board, locate capacitors nearest to each power supply pin (Vcc and Vss).

### ■ SYSTEM CONFIGURATION

Existing CRTCs provide a single bus interface to the frame buffer which must be shared with the host MPU. However, the refresh of large frame buffers and the requirement to access the frame buffer for drawing operations can quickly saturate this shared bus bandwidth.

As shown in figure 26, the ACRTC uses separate host MPU and frame buffer bus interfaces. This allows the ACRTC full access to the frame buffer for display refresh, DRAM refresh, and drawing operations while minimizing the ACRTC's usage of the MPU system bus. Thus, overall system performance is maximized. A related benefit is that a large frame buffer (2M byte for each ACRTC) is useable even if the host MPU has a smaller address space or segment size restriction.

The ACRTC can utilize an external DMA controller. This increases system throughput when large amounts of command, parameter, and data information must be transferred to the ACRTC. Also, advanced DMAC features, such as the HD68450 DMAC's 'chaining' modes, can be used to develop powerful graphics system architectures.

However, more cost sensitive or less performance sensitive applications do not require a DMAC. The interface to the ACRTC can be handled completely under MPU software control.

While both ACRTC bus interfaces (Host MPU and Frame Buffer) are 16-bit data paths for maximum performance, the ACRTC also offers an 8-bit MPU mode for easy connection to popular 8-bit bus structures.



Figure 26 System Configuration,

### ■ INTERNAL FUNCTIONS

#### • BLOCK DIAGRAM

The ACRTC consists of five major functional blocks. These functional blocks operate in parallel to achieve maximum performance. Two of the blocks perform the external bus interface for the host MPU and CRT respectively.

#### ○ MPU Interface

Manages the asynchronous host MPU interface including the programmable interrupt control unit and DMA handshaking control unit.

#### ○ CRT Interface

Manages the frame buffer bus and CRT timing input and output control signals. Also, either display refresh address or drawing address outputs is selected.

The other three blocks are separately microprogrammed processors which operate in parallel to perform the major functions of drawing, display control and timing.

#### ○ Drawing Processor

Interprets commands and command parameters issued by the host bus (MPU and/or DMAC) and performs the drawing operations on the frame buffer memory. This processor is responsible for the execution of ACRTC drawing algorithms and conversion of logical pixel X-Y addresses to physical frame buffer addresses.

Communication with the host bus is via separate 16 byte read and write FIFOs.

#### ○ Display Processor

Manages frame buffer refresh addressing based on the user programmed specification of display screen organization. Combines and displays as many as 4 independent screen segments (3 horizontal splits and 1 window) using an internal high speed address calculation unit. Controls display refresh address outputs based on Graphic (physical frame buffer address) or Character (physical frame buffer address + row address) display modes.

#### ○ Timing Processor

Generates the CRT synchronization signals and other timing signals used internally by the ACRTC.

The ACRTC's software visible registers are similarly partitioned and reside in the appropriate internal processor depending on function. The registers in the Display and Timing processors are loaded with basic display parameters during system initialization. During operation, the host primarily communicates with the ACRTC's Drawing processor via the on-chip FIFOs.

### ● SIGNAL DESCRIPTION

Following is a brief description of the ACRTC pin functions organized as MPU Interface, DMAC Interface, CRT Interface and Power Supply.

#### MPU Interface

##### RES (Input)

Hardware reset input to the ACRTC.

##### D<sub>0</sub>-D<sub>15</sub> (Input/Output)

The bidirectional data bus for communication with the host MPU or DMAC. In 8 bit data bus mode, D<sub>0</sub>-D<sub>7</sub> are used.

##### R/W (Input)

Controls the direction of host ↔ ACRTC transfers.

##### CS (Input)

Enables data transfers between the host and the ACRTC.

##### RS (Input)

Selects the ACRTC register to be accessed and is normally connected to the least significant bit of the host address bus.

##### DTACK (Output)

Provides asynchronous bus cycle timing and is compatible with the HD68000 MPU DTACK input.

##### IRQ (Output)

Generates interrupt service requests to the host MPU.

#### DMAC Interface

##### DREQ (Output)

Generates DMA service requests to the host DMAC.

##### DACK (Input)

Receives DMA acknowledge timing from the host DMAC.

##### DONE (Input/Output)

Terminates DMA transfer and is compatible with the HD68450 DMAC DONE signal.

#### CRT Interface

##### 2CLK (Input)

Basic ACRTC operating clock derived from the dot clock.

##### MAD<sub>0</sub>-MAD<sub>15</sub> (Input/Output)

Multiplexed frame buffer address/data bus.

##### AS (Output)

Address strobe for demultiplexing the frame buffer address/data bus (MAD<sub>0</sub>-MAD<sub>15</sub>).

##### MA<sub>16</sub>/RA<sub>0</sub>-MA<sub>15</sub>/RA<sub>3</sub> (Output)

The high order address bits for graphic screens and the raster address outputs for character screens.

##### RA<sub>4</sub> (Output)

Provides the high order raster address bit (up to 32 rasters) for character screens.

**CHR (Output)**

Indicates whether a graphic or character screen is being accessed.

**MCYC (Output)**

Frame buffer memory access timing — one half the frequency of 2CLK.

**MRD (Output)**

Frame Buffer data bus direction control.

**DRAW (Output)**

Differentiates between drawing cycles and CRT display refresh cycles.

**DISP1, DISP2 (Output)**

Programmable display enable timing used to selectively enable, disable and blank logical screens.

**CUD1, CUD2 (Output)**

Provides cursor timing determined by ACRTC programmed parameters such as cursor definition, cursor mode, cursor address, etc.

**VSYNC (Output)**

CRT device vertical synchronization pulse.

**HSYNC (Output)**

CRT device horizontal synchronization pulse.

**EXSYNC (Input/Output)**

For synchronization between multiple ACRTCs and other video signal generating devices.

**LPSTB (Input)**

Connection to an external light pen.



Figure 27 Block Diagram



**Video Attributes**

The ACRTC outputs 20 bits of video attributes (Figure 28) on  $MAD_0$ – $MAD_{15}$  and  $MA_{16}$ – $MA_{19}$ / $RA_0$ – $MA_{19}$ / $RA_3$ . These attributes are output at the last cycle prior to the rising edge of HSYNC and should be latched externally. Thus, video attributes can be set on a raster by raster basis.



Figure 28 Video Attributes

**Attribute Code (ATC0–ATC7:  $MAD_0$ – $MAD_7$ )**

These are user-defined attributes. The programmed contents of the Attribute Control bits (ATR) of the Display Control Register (DCR) are output on these lines.

Note) The data written into ATR can be externally used after the completion of current raster scanning.

**Attribute Code (ATC0–ATC7) Application**

The following shows some application examples.

- (1) Amount of horizontal dot shift for window smooth scroll.
- (2) Horizontal width of crosshair cursor and the amount of horizontal dot shift (including Block cursor).
- (3) Frame buffer specification in blocks (used for the base register).
- (4) Back ground screen color or character color code.
- (5) Display screen selection during screen blink (used with SPL).
- (6) Interrupt vector address storage.
- (7) Polarity selection of horizontal/vertical synchronization signal.
- (8) Blinking signal for indicator lights.
- (9) Code storage (max. 8 bit), selection signal, etc.

**Horizontal Scroll Dot (HSD0–HSD3:  $MAD_8$ – $MAD_{11}$ )**

These are used in conjunction with external circuitry to implement smooth horizontal scroll. These lines contain the en-

coded start dot address which is used to control the external shift register load timing and data. HSD usually corresponds to the start dot address of the background screens. However, if the window smooth scroll (WSS) bit of OMR (Operation Mode Register) is set to 1, HSD outputs the start dot address of the window screen segment.

Note) HSD outputs the valid value only within the specified raster area. Changing the register contents during the scanning does not cause any external effects, because the value loaded at the beginning of the area is reserved.

**Horizontal Zoom Factor (HZ0–HZ3:  $MAD_{12}$ – $MAD_{15}$ )**

These lines output the encoded (1–16) horizontal zoom factor as stored in the Zoom Factor Register (ZFR). Horizontal zoom is accomplished by the ACRTC repeating a single display address and using the HZ outputs to control the external shift register clock. Horizontal zoom can only be applied to the Base screen.

**Split Screen Code (SPL1–SPL2:  $MA_{16}$ – $MA_{17}$ )**

These lines present the encoded information showing the split screen currently being displayed by the ACRTC.

| SPL2 | SPL1 |                          |
|------|------|--------------------------|
| 0    | 0    | Out of background screen |
| 0    | 1    | Base Screen              |
| 1    | 0    | Upper Screen             |
| 1    | 1    | Lower Screen             |

Even if the split screen display is prohibited, SPL is output if the area is specified.

**Blink (BLINK1–BLINK2:  $MA_{18}$ – $MA_{19}$ )**

The lines alternate from high to low periodically as defined in the Blink Control Register (BCR). The blink frequency is specified in units of 4 field times. A field is defined as the period between successive VSYNC pulses. These lines are used to implement character and screen blinking.

**• ADDRESS SPACE**

The ACRTC allows the host to issue commands using logical X-Y coordinate addressing. The ACRTC converts these to physical linear word addresses with bit field offsets in the frame buffer.

Figure 26 shows the relationship between a logical X-Y screen address and the frame buffer memory, organized as sequential 16 bit words. The host may specify that a logical pixel consists of 1, 2, 4, 8 or 16 physical bits in the frame buffer. In the example, 4 bits per logical pixel is used allowing 16 colors or tones to be selected.

Up to four logical screens (Upper, Base, Lower, and Window) are mapped into the ACRTC physical address space. The host specifies a logical screen physical start address, logical screen physical memory width (number of memory words per raster), logical pixel physical memory width (number of bits per pixel) and the logical origin physical address. Then, logical pixel X-Y addresses issued by the host or by the ACRTC Drawing processor are converted to physical frame buffer addresses. The ACRTC also performs bit extraction and masking to map logical pixel operations (in the example, 4 bits) to 16-bit word frame buffer accesses.



Figure 29 Logical/Physical Addressing



Figure 30 Programming Model

Table 1 Programming Model (Hardware Access, Direct Access Registers)

| CS | RS | RW | Reg No | Register Name             | Abbre        | DATA (H) |       |       |     |           |       |     |     | DATA (L) |         |       |     |           |                   |       |     |           |       |       |  |  |  |  |  |  |  |
|----|----|----|--------|---------------------------|--------------|----------|-------|-------|-----|-----------|-------|-----|-----|----------|---------|-------|-----|-----------|-------------------|-------|-----|-----------|-------|-------|--|--|--|--|--|--|--|
|    |    |    |        |                           |              | 15       | 14    | 13    | 12  | 11        | 10    | 9   | 8   | 7        | 6       | 5     | 4   | 3         | 2                 | 1     | 0   |           |       |       |  |  |  |  |  |  |  |
| 1  | -  | -  | -      | -                         | -            | -----    |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     |           |       |       |  |  |  |  |  |  |  |
| 0  | 0  | 0  | AR     | Address Register          | AR           | -----    |       |       |     |           |       |     |     | Address  |         |       |     |           |                   |       |     |           |       |       |  |  |  |  |  |  |  |
| 0  | 0  | 1  | SR     | Status Register           | SR           | -----    |       |       |     |           |       |     |     | CER      | ARD     | CED   | LPD | RFF       | RFR               | WFR   | WFE |           |       |       |  |  |  |  |  |  |  |
| 1  | 1  | 0  | r00    | FIFO Entry                | FE           | -----    |       |       |     |           |       |     |     | F E      |         |       |     |           |                   |       |     |           |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r02    | Command Control           | CCR          | ABT      | PSE   | DDM   | CDM | DRC       | GBM   |     | CRE | ARE      | CEE     | LPE   | RFE | RRE       | WRE               | WEE   |     |           |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r04    | Operation Mode            | OMR          | M/S      | STR   | ACP   | WSS | CSK       | DSK   | RAM | GAI | ACM      | RSM     | ----- |     |           |                   |       |     |           |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r06    | Display Control           | DCR          | DSP      | SE1   | SEO   | SE2 | SE3       | A T R |     |     |          |         |       |     |           | -----             |       |     |           |       |       |  |  |  |  |  |  |  |
|    | -  | -  | r08    | (undefined)               | -            | -----    |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r80    | Raster Count              | RCR          | -----    |       |       |     |           |       |     |     | R C      |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r82    | Horizontal Sync           | HSR          | H C      |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     | H S W     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r84    | Horizontal Display        | HDR          | H D S    |       |       |     |           |       |     |     | H D W    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r86    | Vertical Sync             | VSR          | -----    |       |       |     |           |       |     |     | V C      |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r88    | Vertical Display          | VDR          | V D S    |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     | V S W     |       |       |  |  |  |  |  |  |  |
| 0  | 1  | 0  | r8A    | -                         | -            | -----    |       |       |     |           |       |     |     | S P 1    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r8C    | Split Screen Width        | SSW          | -----    |       |       |     |           |       |     |     | S P 0    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r8E    | -                         | -            | -----    |       |       |     |           |       |     |     | S P 2    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r90    | Blink Control             | BCR          | BON1     |       |       |     | BOFF1     |       |     |     | BON2     |         |       |     | BOFF2     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r92    | Horizontal Window Display | HWR          | H W S    |       |       |     |           |       |     |     | H W W    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r94    | -                         | -            | -----    |       |       |     |           |       |     |     | V W S    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r96    | Vertical Window Display   | VWR          | -----    |       |       |     |           |       |     |     | V W W    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r98    | -                         | -            | -----    |       |       |     |           |       |     |     | C X E    |         |       |     |           |                   |       |     | C X S     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | r9A    | Graphic Cursor            | GCR          | -----    |       |       |     |           |       |     |     | C Y S    |         |       |     |           |                   |       |     | C Y E     |       |       |  |  |  |  |  |  |  |
|    | -  | -  | r9C    | -                         | -            | -----    |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
| 0  | 1  | 0  | rC0    | Raster Addr 0             | RAR0         | -----    |       |       |     |           |       |     |     | L R A 0  |         |       |     | F R A 0   |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rC2    | Upper Memory Width 0      | MWRO         | CHR      |       |       |     | -----     |       |     |     | M W 0    |         |       |     | -----     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rC4    | Screen                    | Start Addr.0 | SAR0     | ----- |       |     |           |       |     |     |          | S D A 0 |       |     |           | S A O H / S R A O |       |     |           | ----- |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rC6    | -                         | -            | -----    |       |       |     |           |       |     |     | S A O L  |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rC8    | Raster Addr 1             | RAR1         | -----    |       |       |     |           |       |     |     | L R A 1  |         |       |     | F R A 1   |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rC4    | Base Memory Width 1       | MWR1         | CHR      |       |       |     | -----     |       |     |     | M W 1    |         |       |     | -----     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rCC    | Screen                    | Start Addr 1 | SAR1     | ----- |       |     |           |       |     |     |          | S D A 1 |       |     |           | S A 1 L           |       |     |           | ----- |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rD0    | -                         | -            | -----    |       |       |     |           |       |     |     | L R A 2  |         |       |     | F R A 2   |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rD2    | Lower Memory Width 2      | MWR2         | CHR      |       |       |     | -----     |       |     |     | M W 2    |         |       |     | -----     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rD4    | Screen                    | Start Addr 2 | SAR2     | ----- |       |     |           |       |     |     |          | S D A 2 |       |     |           | S A 2 L           |       |     |           | ----- |       |  |  |  |  |  |  |  |
| 1  | 1  | 0  | rD8    | Raster Addr 3             | RAR3         | -----    |       |       |     |           |       |     |     | L R A 3  |         |       |     | F R A 3   |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rDA    | Window Memory Width 3     | MWR3         | CHR      |       |       |     | -----     |       |     |     | M W 3    |         |       |     | -----     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rDC    | Screen                    | Start Addr 3 | SAR3     | ----- |       |     |           |       |     |     |          | S D A 3 |       |     |           | S A 3 H / S R A 3 |       |     |           | ----- |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rDE    | -                         | -            | -----    |       |       |     |           |       |     |     | S A 3 L  |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rE0    | Block Cursor 1            | BCUR1        | B C W 1  |       |       |     | B C S R 1 |       |     |     | B C A 1  |         |       |     | B C E R 1 |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rE2    | -                         | -            | -----    |       |       |     |           |       |     |     | B C W 2  |         |       |     | B C S R 2 |                   |       |     | B C E R 2 |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rE4    | Block Cursor 2            | BCUR2        | -----    |       |       |     |           |       |     |     | B C A 2  |         |       |     | -----     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rE6    | -                         | -            | -----    |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rE8    | Cursor Definition         | CDR          | C M      | CON1  | COFF1 |     | -----     |       |     |     | CON2     |         |       |     | COFF2     |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | 1  | 0  | rEA    | Zoom Factor               | ZFR          | H Z F    | V Z F | ----- |     |           |       |     |     |          |         | ----- |     |           |                   | ----- |     |           |       | ----- |  |  |  |  |  |  |  |
|    | 1  | 0  | rEE    | Light Pen Address         | LPAR         | -----    |       |       |     |           |       |     |     | CHR      |         |       |     | L P A H   |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |
|    | -  | -  | rF0    | (undefined)               | -            | -----    |       |       |     |           |       |     |     | -----    |         |       |     |           |                   |       |     | -----     |       |       |  |  |  |  |  |  |  |

|         |                                     |               |                                                                       |
|---------|-------------------------------------|---------------|-----------------------------------------------------------------------|
| ABT     | : Abort                             | SP0, SP1, SP2 | : Split Screen 0 Width, Split Screen 1 Width,<br>Split Screen 2 Width |
| ACM     | : Access Mode                       | BON1, BON2    | : Blink ON 1, Blink ON 2                                              |
| ACP     | : Access Priority                   | BOFF1, BOFF2  | : Blink OFF 1, Blink OFF 2                                            |
| Address | : Control register number           | HWS           | : Horizontal Window Start                                             |
| ARD     | : Area Detect                       | HWW           | : Horizontal Window Width                                             |
| ARE     | : Area Detect Interrupt Enable      | VWS           | : Vertical Window Start                                               |
| ATR     | : Attribute Control                 | VWW           | : Vertical Window Width                                               |
| CDM     | : Command DMA Mode                  | CXS, CYS      | : Cursor X Start, Cursor Y Start                                      |
| CED     | : Command End                       | CXE, CYE      | : Cursor X End, Cursor Y End                                          |
| CEE     | : Command End Interrupt Enable      | FRA           | : First Raster Address                                                |
| CER     | : Command Error                     | LRA           | : Last Raster Address                                                 |
| CRE     | : Command Error Interrupt Enable    | CHR           | : Character                                                           |
| CSK     | : Cursor Display Skew               | MW            | : Memory Width                                                        |
| DDM     | : Data DMA Mode                     | SDA           | : Start Dot Address                                                   |
| DRC     | : DMA Request Control               | SAH/SRA       | : Start Address "High"/Start Raster Address                           |
| DSK     | : DISP Skew                         | SAL           | : Start Address "Low"                                                 |
| DSP     | : DISP Signal Control               | BCW1, BCW2    | : Block Cursor Width 1, Block Cursor Width 2                          |
| FE      | : FIFO Entry                        | BCSR1, BCSR2  | : Block Cursor Start Raster 1, Block Cursor Start<br>Raster 2         |
| GAI     | : Graphic Address Increment Mode    | BCER1, BCER2  | : Block Cursor End Raster 1, Block Cursor End<br>Raster 2             |
| GBM     | : Graphic Bit Mode                  | BCA1, BCA2    | : Block Cursor Address 1, Block Cursor Address 2                      |
| HC      | : Horizontal Cycle                  | CM            | : Cursor Mode                                                         |
| HDS     | : Horizontal Display Start          | CON1, CON2    | : Cursor ON 1, Cursor ON 2                                            |
| HDW     | : Horizontal Display Width          | COFF1, COFF2  | : Cursor OFF 1, Cursor OFF 2                                          |
| HSW     | : Horizontal Sync Width             | HZF, VZF      | : Horizontal Zoom Factor, Vertical Zoom Factor                        |
| LPD     | : Light Pen Strobe Detect           | LPAH          | : Light Pen Address "High"                                            |
| LPE     | : Light Pen Strobe Interrupt Enable | LPAL          | : Light Pen Address "Low"                                             |
| M/S     | : Master/Slave                      |               |                                                                       |
| PSE     | : Pause                             |               |                                                                       |
| RAM     | : RAM Mode                          |               |                                                                       |
| RC      | : Raster Count                      |               |                                                                       |
| RFE     | : Read FIFO Full Interrupt Enable   |               |                                                                       |
| RFF     | : Read FIFO Full                    |               |                                                                       |
| RFR     | : Read FIFO Ready                   |               |                                                                       |
| RRE     | : Read FIFO Ready Interrupt Enable  |               |                                                                       |
| RSR     | : Raster Scan Mode                  |               |                                                                       |
| SE0     | : Split Enable 0                    |               |                                                                       |
| SE1     | : Split Enable 1                    |               |                                                                       |
| SE2     | : Split Enable 2                    |               |                                                                       |
| SE3     | : Split Enable 3                    |               |                                                                       |
| STR     | : Start                             |               |                                                                       |
| VC      | : Vertical Cycle                    |               |                                                                       |
| VDS     | : Vertical Display Start            |               |                                                                       |
| VSW     | : Vertical Sync. Width              |               |                                                                       |
| WEE     | : Write FIFO Empty Interrupt Enable |               |                                                                       |
| WFE     | : Write FIFO Empty                  |               |                                                                       |
| WFR     | : Write FIFO Ready                  |               |                                                                       |
| WRE     | : Write FIFO Ready Interrupt Enable |               |                                                                       |
| WSS     | : Window Smooth Scroll              |               |                                                                       |



Table 1 (cont.) Programming Model (Drawing Parameter Registers)

| Register No       | Read/Write | Name of Register    | Abbr | Data (H) |    |      |    |      |      |      |      | Data (L) |   |   |   |   |   |   |   |
|-------------------|------------|---------------------|------|----------|----|------|----|------|------|------|------|----------|---|---|---|---|---|---|---|
|                   |            |                     |      | 15       | 14 | 13   | 12 | 11   | 10   | 9    | 8    | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Pr00              | R/W        | Color 0             | CLO  |          |    |      |    |      |      |      |      |          |   |   |   |   |   |   |   |
| Pr01              | R/W        | Color 1             | CL1  |          |    |      |    |      |      |      |      |          |   |   |   |   |   |   |   |
| Pr02              | R/W        | Color Comparison    | CCMP |          |    |      |    |      |      |      |      |          |   |   |   |   |   |   |   |
| Pr03              | R/W        | Edge Color          | EDG  |          |    |      |    |      |      |      |      |          |   |   |   |   |   |   |   |
| Pr04              | R/W        | Mask                | MASK |          |    |      |    |      |      |      |      |          |   |   |   |   |   |   |   |
| Pr05<br>↓<br>Pr07 | R/W        | Pattern RAM Control | PRC  | PPY      |    | PZCY |    | PPX  |      | PZCX |      |          |   |   |   |   |   |   |   |
| Pr08<br>↓<br>Pr0B | R/W        |                     |      | PSY      |    |      |    | PSX  |      |      |      |          |   |   |   |   |   |   |   |
| Pr0C<br>Pr0D      | R/W        |                     |      | PEY      |    | PZY  |    | PEX  |      | PZX  |      |          |   |   |   |   |   |   |   |
| Pr0E<br>Pr0F      | —          | ...                 | —    |          |    |      |    |      |      |      | XMIN |          |   |   |   |   |   |   |   |
| Pr10<br>Pr11      | R          | Drawing Pointer     | DP   | DN       |    |      |    | RWPL |      |      | YMIN |          |   |   |   |   |   |   |   |
| Pr12<br>Pr13      | R          |                     |      | DN       |    |      |    |      | DPAH |      | XMAX |          |   |   |   |   |   |   |   |
| Pr14<br>Pr15      | —          | .....               | —    | DN       |    |      |    | DPAL |      | DPD  | YMAX |          |   |   |   |   |   |   |   |
|                   |            |                     |      |          |    |      |    |      |      |      | X    |          |   |   |   |   |   |   |   |
|                   |            |                     |      |          |    |      |    |      |      |      | Y    |          |   |   |   |   |   |   |   |
|                   |            |                     |      |          |    |      |    |      |      |      | —    |          |   |   |   |   |   |   |   |
|                   |            |                     |      |          |    |      |    |      |      |      | —    |          |   |   |   |   |   |   |   |

■ Always set to "0"

.. . Set two's complements for negative values of X and Y axis.

#### DRAWING PARAMETER REGISTER

- R : Register which can be read by Read Parameter Register Command (RPR)
- W : Register which can be written into by Write Parameter Register Command (WPR)
- : Access is not allowed
- CLO : Defines the color data used for the drawing when logical drawing data=0
- CL1 : Defines the color data used for the drawing when logical drawing data=1
- CCMP : Defines the comparative color of the drawing operation
- EDG : Defines the edge color
- MASK : Defines the bit pattern used to mask bits upon which data transfer should not be performed
- PSX, PSY : Pattern Start Point
- PEX, PEY : Pattern End Point
- PPX, PPY : Pattern Scan Start Point
- PZX, PZY : Pattern Zoom
- PZCX, PZCY : Pattern Zoom Count
- XMIN, YMIN : Start point of Area definition
- XMAX, YMAX : End point of Area definition
- DN : Screen Number
- RWPH : High-order 8 bit of Read Write Pointer Address
- RWPL : Loworder 12 bit of Read Write Pointer Address
- DPAH : High-order 8 bit of Drawing Pointer Address
- DPAL : Loworder 12 bit of Drawing Pointer Address
- DPD : Drawing Pointer Dot Address
- X, Y : Position indicated by Current Pointer on X-Y coordinate



## • REGISTERS

The ACRTC has over two hundred bytes of accessible registers. These are organized as Hardware, Directly and FIFO accessible.

### ○ Hardware Accessible

The ACRTC is connected to the host MPU as a standard peripheral which occupies two word locations of the host address space. The RS (Register Select) pin selects one of these two locations. When RS is low, reads access the Status Register and writes access the Address Register.

The Status Register summarizes the ACRTC state and is used by the MPU to monitor the overall operation of the ACRTC. The Address Register is used to program the ACRTC with the address of the specific directly accessible register which the MPU wishes to access.

### ○ Directly Accessible

These registers are accessed by prior loading of the Address Register with the chosen register address. Then, when the MPU accesses the ACRTC with RS=1, the chosen register is accessed.

The FIFO entry enables access to FIFO accessible registers using the ACRTC read and write FIFOs.

The Command Control Register controls overall ACRTC operation such as aborting or pausing commands, defining DMA protocols, enabling/disabling interrupt sources, etc.

The Operation Mode Register defines basic parameters of ACRTC operation such as frame buffer access mode, display or drawing priority, cursor and display timing skew factors, raster scan mode, etc.

The Display Control Register independently enables and disables each of the four ACRTC logical display screens (Base, Upper, Lower and Window). Also, this register contains the 8 bits of user definable video attributes.

The Timing Control RAM contains registers which define ACRTC timing. This includes timing specification for CRT control signals (e.g. HSYNC, VSYNC), logical display screen size and display period, blink timing, etc.

The Display Control RAM contains registers which define logical screen display parameters such as start addresses, raster addresses and memory width. Also included are the cursor(s) definition, zoom factor and light pen registers.

### ○ FIFO Accessible

For high performance drawing, key Drawing Processor registers are coupled to the host via the ACRTCs separate 16 byte read and write FIFOs.

ACRTC commands are sent from the MPU via the write FIFO to the Command register. As the ACRTC completes command execution, the next command is automatically fetched from the FIFO into the Command register.

The Pattern RAM is used to define drawing and painting 'patterns'. The Pattern RAM is accessed using the ACRTCs Read Pattern RAM (RPTN) and Write Pattern RAM (WPTN) register access commands.

The Drawing Parameter Registers define detailed parameters of the drawing process, such as color control, area control (hitting/clipping), and Pattern RAM pointers. The Drawing Parameter Registers are accessed using the ACRTCs Read Parameter Register (RPR) and Write Parameter Register (WPR) register access commands.

## ■ COMMANDS

The ACRTC has 38 commands classified into three groups — REGISTER ACCESS, DATA TRANSFER, and GRAPHIC DRAWING.

Five REGISTER ACCESS commands allow access to Drawing processor Drawing Parameter Registers and the Pattern RAM.

Ten DATA TRANSFER commands are used to move data between the host system memory and the frame buffer, or within the frame buffer.

Twenty three GRAPHIC DRAWING commands cause the

ACRTC to perform drawing operations. Parameters for these commands are specified using logical X-Y addressing.

All the above commands, parameters and data are transferred via the ACRTC read and write FIFOs.

Assuming the ACRTC has been properly initialized, the MPU must perform two steps to cause graphic drawing.

First, the MPU must specify certain drawing parameters which define a number of details associated with the drawing process. For example, to draw a figure or paint an area, the MPU must specify the drawing or painting 'pattern' by initializing the ACRTC Pattern RAM and related pointers. Also, if clipping and hitting control are desired, the MPU specifies the 'area' to be monitored during drawing by initializing area definition registers. Other drawing parameters include color, edge definition, etc.

After the drawing parameters have been specified, the MPU issues a graphic drawing command and any required command parameters, such as the CRCL (Circle) command with a radius parameter. The ACRTC then performs the specified drawing operation by reading, modifying, and rewriting the contents of the frame buffer.

## • COMMAND FORMAT

ACRTC commands consist of a 16-bit operation code, optionally followed by 1 or more 16-bit parameters. When 8 bit MPU mode is used, commands, parameters and data are sent to and from the ACRTC in the order of high byte, low byte.

### (a) 16 bit interface

For a 16-bit interface, first move the 16-bit operation code and then move the necessary 16-bit parameters one by one.



Figure 31(a) 16-bit Interface Command Format

### (b) 8 bit interface

For a 8-bit interface, first move the operation code's high byte followed by low byte. Then move those of parameters in the same order.



Figure 31(b) 8-bit Interface Command Format

**Program Transfer**

Program transfer occurs when the MPU specifies the FIFO entry address and then writes commands/parameters to the write FIFO under program control (RS = high, R/W, CS = low). The MPU writes are normally synchronized with ACRTC FIFO status by software polling or interrupts.

- Software Polling (WFR, WFE interrupts disabled)
  - a) MPU program checks the SR (Status Register) for Write FIFO Ready (WFR) flag = 1, and then writes 1-word op-code/parameters.
  - b) MPU program checks the SR (Status Register) for Write FIFO Empty (WFE) flag = 1, and then writes 1- to 8-word op-code/parameters.
- Interrupt Driven (WFR, WFE interrupts enabled)
  - a) MPU WFR interrupt service routine writes 1-word op-code/parameters.
  - b) MPU WFE interrupt service routine writes 1- to 8-word op-code/parameters.

In the specific case of Register Access Commands and an initially empty write FIFO, MPU writes need not be synchronized to the write FIFO status. The ACRTC can fetch and execute these commands faster than the MPU can issue them.

**Command DMA Transfer**

Commands and parameters can be transferred from MPU system memory using an external DMAC. The MPU initiates and terminates Command DMA Transfer mode under software control (CDM bit of CCR). Command DMA can also be terminated by assertion of the ACRTC DONE signal. DONE is treated as an input in Command DMA Transfer Mode.

Using Command DMA Transfer, the ACRTC will issue cycle stealing DMA requests to the DMAC when the write FIFO is empty. The DMA data is automatically sent from system memory to the ACRTC write FIFO regardless of the contents of the Address Register.

- Note 1) Make sure that the write FIFO is empty and all the commands are terminated before starting the Command DMA Transfer.
- Note 2) The Data DMA Command cannot be executed in the Command DMA Transfer Mode.

Table 2-1 ACRTC Command Table

| TYPE                    | MNEMONIC | COMMAND NAME              | OPERATION CODE                  | PARAMETER                                                                    | # (words)                                       | OPERATION CYCLES *1)      |                      |
|-------------------------|----------|---------------------------|---------------------------------|------------------------------------------------------------------------------|-------------------------------------------------|---------------------------|----------------------|
| Register Access Command | ORG      | Origin                    | 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 | DPH DPL                                                                      | 3                                               | 8                         |                      |
|                         | WPR      | Write Parameter Register  | 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 | RN                                                                           | 2                                               | 6                         |                      |
|                         | RPR      | Read Parameter Register   | 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 | RN                                                                           | 1                                               | 6                         |                      |
|                         | WPTN     | Write Pattern RAM         | 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 | PRA                                                                          | n D <sub>1</sub> , ..., D <sub>n</sub>          | n+2 4n+8                  |                      |
| Data Transfer Command   | RPTN     | Read Pattern RAM          | 0 0 0 1 1 1 0 0 0 0 0 0 0 0 0 0 | PRA                                                                          | n                                               | 4n+10                     |                      |
|                         | DRD      | DMA Read                  | 0 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 | AX AY                                                                        | 3                                               | (4x+8)y+12[x+y/8]+(62~68) |                      |
|                         | DWT      | DMA Write                 | 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 | AX AY                                                                        | 3                                               | (4x+8)y+16[x+y/8]+34      |                      |
|                         | DMOD     | DMA Modify                | 0 0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 | MM                                                                           | AX AY                                           | 3                         | (4x+8)y+16[x+y/8]+34 |
|                         | RD       | Read                      | 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 |                                                                              |                                                 | 1 12                      |                      |
|                         | WT       | Write                     | 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 | D                                                                            | 2                                               | 8                         |                      |
|                         | MOD      | Modify                    | 0 1 0 0 1 1 0 0 0 0 0 0 0 0 0 0 | MM                                                                           | D                                               | 2 8                       |                      |
|                         | CLR      | Clear                     | 0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0 |                                                                              | D AX AY                                         | 4 (2x+8)y+12              |                      |
|                         | SCLR     | Selective Clear           | 0 1 0 1 1 1 0 0 0 0 0 0 0 0 0 0 | MM                                                                           | D AX AY                                         | 4 (4x+6)y+12              |                      |
|                         | CPY      | Copy                      | 0 1 1 0 S: DSD                  | 0 0 0 0 0 0 0 0 0 0                                                          | SAH SAL AX AY                                   | 5 (6x+10)y+12             |                      |
| Graphic Command         | SCPY     | Selective Copy            | 0 1 1 1 S: DSD                  | 0 0 0 0 0 0 0 0 0 0                                                          | MM SAH SAL AX AY                                | 5 (6x+10)y+12             |                      |
|                         | AMOVE    | Absolute Move             | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | X Y                                                                          | 3                                               | 56                        |                      |
|                         | RMOVE    | Relative Move             | 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 | dX dY                                                                        | 3                                               | 56                        |                      |
|                         | ALINE    | Absolute Line             | 1 0 0 0 1 0 0 0 0 AREA:COL:OPM  | X Y                                                                          | 3                                               | P·L+18                    |                      |
|                         | RLINE    | Relative Line             | 1 0 0 0 1 1 0 0 0 AREA:COL:OPM  | dX dY                                                                        | 3                                               | P·L+18                    |                      |
|                         | ARCT     | Absolute Rectangle        | 1 0 0 1 0 0 0 0 0 AREA:COL:OPM  | X Y                                                                          | 3                                               | 2P(A+B)+54                |                      |
|                         | RRCT     | Relative Rectangle        | 1 0 0 1 0 1 0 0 0 AREA:COL:OPM  | dX dY                                                                        | 3                                               | 2P(A+B)+54                |                      |
|                         | APLL     | Absolute Polyline         | 1 0 0 1 1 0 0 0 AREA:COL:OPM    | n X <sub>1</sub> , Y <sub>1</sub> , ..., X <sub>n</sub> , Y <sub>n</sub>     | 2n+2 $\Sigma [P \cdot L + 16] + 8$              |                           |                      |
|                         | RPLL     | Relative Polyline         | 1 0 0 1 1 1 0 0 0 AREA:COL:OPM  | n dX <sub>1</sub> , dY <sub>1</sub> , ..., dX <sub>n</sub> , dY <sub>n</sub> | 2n+2 $\Sigma [P \cdot L + 16] + 8$              |                           |                      |
|                         | APLG     | Absolute Polygon          | 1 0 1 0 0 0 0 0 AREA:COL:OPM    | n X <sub>1</sub> , Y <sub>1</sub> , ..., X <sub>n</sub> , Y <sub>n</sub>     | 2n+2 $\Sigma [P \cdot L + 16] + P \cdot L + 20$ |                           |                      |
|                         | RPLC     | Relative Polygon          | 1 0 1 0 1 0 0 0 AREA:COL:OPM    | n dX <sub>1</sub> , dY <sub>1</sub> , ..., dX <sub>n</sub> , dY <sub>n</sub> | 2n+2 $\Sigma [P \cdot L + 16] + P \cdot L + 20$ |                           |                      |
|                         | CRCL     | Circle                    | 1 0 1 0 1 0 0 C: AREA:COL:OPM   | r                                                                            | 2 8d+66                                         |                           |                      |
|                         | ELPS     | Ellipse                   | 1 0 1 0 1 1 0 C: AREA:COL:OPM   | a b dX                                                                       | 4 10d+90                                        |                           |                      |
|                         | AARC     | Absolute Arc              | 1 0 1 1 0 0 0 C: AREA:COL:OPM   | Xc Yc Xe Ye                                                                  | 5 8d+18                                         |                           |                      |
|                         | RARC     | Relative Arc              | 1 0 1 1 1 0 0 C: AREA:COL:OPM   | dXc dYc dXe dYe                                                              | 5 8d+18                                         |                           |                      |
|                         | AEARC    | Absolute Ellipse Arc      | 1 0 1 1 1 0 0 C: AREA:COL:OPM   | a b Xc Yc Xe Ye                                                              | 7 10d+96                                        |                           |                      |
|                         | REARC    | Relative Ellipse Arc      | 1 0 1 1 1 1 0 C: AREA:COL:OPM   | a b dXc dYc dXe dYe                                                          | 7 10d+96                                        |                           |                      |
|                         | AFRCT    | Absolute Filled Rectangle | 1 1 0 0 0 0 0 0 AREA:COL:OPM    | X Y                                                                          | 3 (P·A+B)+18                                    |                           |                      |
|                         | RFRCT    | Relative Filled Rectangle | 1 1 0 0 0 1 0 0 AREA:COL:OPM    | dX dY                                                                        | 3 (P·A+B)+18                                    |                           |                      |
|                         | PAINT    | Paint                     | 1 1 0 0 1 0 0 E: AREA:0 0 0 0   |                                                                              | 1 (18A+102)B-58 *2)                             |                           |                      |
|                         | DOT      | Dot                       | 1 1 0 0 1 1 0 0 AREA:COL:OPM    |                                                                              | 1 8                                             |                           |                      |
|                         | PTN      | Pattern                   | 1 1 0 1 S: SD                   | AREA:COL:OPM SZ                                                              | 2 (P·A+10)B+20                                  |                           |                      |
|                         | AGCPY    | Absolute Graphic Copy     | 1 1 1 0 S: DSD                  | AREA:0 0 OPM                                                                 | Xs Ys DX DY 5 ((P+2)A+10)B+70                   |                           |                      |
|                         | RGCPY    | Relative Graphic Copy     | 1 1 1 1 S: DSD                  | AREA:0 0 OPM                                                                 | dXs dYs DX DY 5 ((P+2)A+10)B+70                 |                           |                      |

Note \*1) Unit of operation cycle is 2 clock cycle (2CLK)

Note \*2) Operation cycle of PAINT is variable. The operation cycle on table 2 is applicable to rectangular figures.



## COMMAND ABBREVIATIONS

## (a) Register Access Command

RN : Register number of the drawing parameter register (\$0-\$13)  
 PRA : Pattern RAM address at which Read/Write operation starts (\$0-\$F)  
 DPH : Drawing pointer register High word (figure 32(a))  
 DPL : Drawing pointer register Low word (figure 32(a))  
 DPAN : Higher 8 bits of Drawing Pointer address  
 DPAL : Lower 12 bits of Drawing Pointer address  
 DPD : Dot position in the memory address  
 D, D<sub>1</sub>, ..., D<sub>n</sub> : Write data  
 n : Number of Read/Write data  
 [↑] : Round up

## (b) Data Transfer Command

MM : Modify mode (Description on page 36)  
 S : Source scan direction (Table 2-3)  
 DDS : Destination scan direction (Table 2-4)

AX : Number of word in X-axis direction -1  
 AY : Number of word in Y-axis direction -1  
 D : Write data  
 SAH : Source Start Address High word (figure 32(b))  
 SAL : Source Start Address Low word (figure 32(b))  
 x : Number of word in X-axis direction  
 y : Number of word in Y-axis direction  
 ↑ : Rounding up

## (c) Graphic Drawing Command

AREA : Area mode (Description on page 38)  
 COL : Color mode (Description on page 38)  
 OPM : Operation mode (Description on page 36)  
 C : Circling direction (Table 2-5)  
 E : Definition of edge color (Table 2-6)  
 SL : Slant (Table 2-7)  
 SD : Scan direction (Table 2-7)  
 S : Source scan direction (Table 2-8)  
 DDS : Destination scan direction (Table 2-9)

X, X<sub>1</sub>, ..., X<sub>n</sub> : Absolute X-address from the origin point  
 Y, Y<sub>1</sub>, ..., Y<sub>n</sub> : Absolute Y-address from the origin point  
 dX : Relative X-address from the current pointer  
 dY : Relative Y-address from the current pointer  
 n : Number of nodes  
 dX<sub>1</sub>, ..., dX<sub>n</sub> : Relative X-address from each node  
 dY<sub>1</sub>, ..., dY<sub>n</sub> : Relative Y-address from each node  
 r : Dot number on radius  
 a, b : Ratio of squared dX and dY of ellips a = (dX)<sup>2</sup> / (dY)<sup>2</sup>  
 DX : X-direction dot number  
 DY : Y-direction dot number  
 Xc : Absolute X-address of the center point of arc/ellipse  
 Yc : Absolute Y-address of the center point of arc/ellipse  
 dXc : Relative X-address from the current pointer to the center point of arc/ellipse  
 dYc : Relative Y-address from the current pointer to the center point of arc/ellipse  
 Xe : Absolute X-address of the end point of arc/ellipse  
 Ye : Absolute Y-address of the end point of arc/ellipse  
 dXe : Relative X-address from the current pointer to the end point of arc/ellipse  
 dYe : Relative Y-address from the current pointer to the end point of arc/ellipse  
 Xs : Absolute X-address of the start dot position in source area  
 Ys : Absolute Y-address of the start dot position in source area  
 dXs : Relative X-address from the current pointer to the start dot position in source area  
 dYs : Relative Y-address from the current pointer to the start dot position in source area  
 P : Operation cycles p=4 cycles at OPM=000-011, p=6 cycles at OPM=100-111  
 L, Lo : Dot number on straight line  
 d : Total dot number  
 A : Scan main direction dot number  
 B : Scan sub direction dot number  
 SZ : Pattern Size S<sub>Zy</sub>, S<sub>Zx</sub>

|     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| DPH | DN | 0  | 0  | 0  | 0  | 0  | 0 |   |   |   |   |   |   |   |   | DPAH |
| DPL |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DPAL |

Table 2-2 DN Screen Number

Figure 32(a) Drawing Pointer

| DN | Screen No     |
|----|---------------|
| 00 | Upper Screen  |
| 01 | Base Screen   |
| 10 | Lower Screen  |
| 11 | Window Screen |

Table 2-3 S Source Scan Direction

| S=0 |  | S=1 |  |
|-----|--|-----|--|
|     |  |     |  |

■ source area start address  
 □ source area end address



Table 2-4 DSD Destination Scan Direction



| SAH and SAL |       |    |    |    |    |   |   |       |   |   |   |   |   |   |   |   |   |   |  |  |  |
|-------------|-------|----|----|----|----|---|---|-------|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 15          | 14    | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |  |  |  |
| SAH         | 0     | 0  | 0  | 0  | 0  | 0 | 0 | (SAH) |   |   |   |   |   |   |   |   |   |   |  |  |  |
| SAL         | (SAL) |    |    |    |    |   |   |       |   |   |   |   |   |   | 0 | 0 | 0 | 0 |  |  |  |

Figure 32(b) Source Start Address

Table 2-5 C Circling Direction

| C | Direction        |
|---|------------------|
| 0 | Counterclockwise |
| 1 | Clockwise        |

Table 2-6 E Definition of Edge Color

| E | Definition                                                    |
|---|---------------------------------------------------------------|
| 0 | Edge color is defined by the data in the edge color register. |
| 1 | Edge color is defined by the data excluding the above.        |

Table 2-7 SL Slant, SD Scan Direction



Table 2-8 S Source Scan Direction



Table 2-9 DSD Destination Scan Direction



- REGISTER ACCESS COMMANDS**

Registers associated with the Drawing processor (Pattern RAM and Drawing Parameter Registers) are accessed through the read and write FIFOs using the Register Access Commands.

- DATA TRANSFER COMMANDS**

Data Transfer Commands are used to move blocks of data between the MPU system memory and the ACRTC frame buffer or within the frame buffer itself. Before issuing these commands, a physical 20 bit frame buffer address must be specified in the RWP (Read Write Pointer) Drawing Parameter Register.

Table 3-1 Register Access Commands

| Command | Function                                                                                          |
|---------|---------------------------------------------------------------------------------------------------|
| ORG     | Initialize the relation between the origin point in the X-Y coordinates and the physical address. |
| WPR     | Write into the parameter register                                                                 |
| RPR     | Read the parameter register                                                                       |
| WPTN    | Write into the pattern RAM                                                                        |
| RPTN    | Read the pattern RAM                                                                              |

Table 4-1 Data Transfer Commands

| Command | Function                                                                                                                                                                                                       |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DRD     | Transfer data, by DMA transfer, from the frame buffer to the MPU system memory.                                                                                                                                |
| DWT     | Transfer data, by DMA transfer, from the MPU system memory to the frame buffer.                                                                                                                                |
| DMOD    | Transfer data, by DMA transfer, from the MPU system to the frame buffer subject to logical modification (bit maskable).                                                                                        |
| RD      | Read one word of data from the frame buffer specified by the read/write pointer (RWP), and load the word into Read FIFO.                                                                                       |
| WT      | Write one word of data to the frame buffer specified by the read/write pointer (RWP).                                                                                                                          |
| MOD     | Perform logical operation on one word in the frame buffer specified by the read/write pointer (RWP) (bit maskable)                                                                                             |
| CLR     | Clear a rectangular area of the frame buffer with a data in the command parameter.                                                                                                                             |
| SCLR    | Initialize a rectangular area of the frame buffer with 1-word data subject to logical operation (bit maskable).                                                                                                |
| CPY     | Copy frame buffer data from one area (source area) to another area (destination area) specified by the read/write pointer (RWP).                                                                               |
| SCPY    | Copy frame buffer data from one area (source area) to another area (destination area) subject to logical modification by word. The source and destination areas must reside on the same screen (bit maskable). |



Figure 33 Data Transfer Command Format

**Modify Mode**

The DMOD, MOD, SCLR and SCPY commands allow 4 types of bit level logical operations to be applied to frame buffer data. The modify mode is encoded in the lower two bits (MM) of these op-codes. The bit positions within each frame buffer word to be modified are selectable using the mask register (MASK). Bits set to 1 are modifiable, ones to 0 are masked and not modifiable.

Table 4-2 Modify Mode

| MM  | Modify Mode                                                                       |
|-----|-----------------------------------------------------------------------------------|
| 0 0 | REPLACE frame buffer data with command parameter data.                            |
| 0 1 | OR frame buffer data with command parameter data and rewrite to the frame buffer  |
| 1 0 | AND frame buffer data with command parameter data and rewrite to the frame buffer |
| 1 1 | EOR frame buffer data with command parameter data and rewrite to the frame buffer |

- **GRAPHIC DRAWING COMMANDS**

The ACRTC has 23 graphic drawing commands (table 5-1). Graphic drawing is performed by modifying the contents of the frame buffer based upon microcoded drawing algorithms in the ACRTC drawing processor.

Most coordinate parameters for graphic drawing commands are specified using logical pixel X-Y addressing. The complex task of translating a logical pixel address to a linear frame buffer word address, and further selecting the appropriate sub-field of the word (for example, a given logical pixel in 4 bits per logical pixel mode might reside in bits 8-11 of a frame buffer word) is performed at high speed by ACRTC hardware.

Many instructions allow specification of X-Y coordinates with either absolute or relative X-Y coordinates (e.g. ALINE and RLINE). In both cases, two's complement numbers are used to represent positive and negative values.

- Absolute Coordinate Specification

The screen address ( $X, Y$ ) is specified in units of logical pixels relative to an origin point defined with the ORG command (figure 34).

- Relative Coordinate Specification

The screen address ( $dX, dY$ ) is specified in units of logical pixels relative to the current drawing pointer (CP) position (figure 35).

A graphic drawing command consists of a 16-bit op-code and optionally 0 to 64k 16-bit parameters.

The 16-bit op-code consists of an 8-bit command code, an AREA Mode specifier (3 bits), a Color Mode specifier (2 bits) and an Operation Mode specifier (3 bits).

The Area Mode allows versatile clipping and hitting detection. A drawing area can be defined, and should drawing operations attempt to enter or leave that area, a number of programmable actions can be taken by the ACRTC.

The Color Mode determines whether the Pattern RAM is used indirectly to select Color Registers or is directly used as the color information.

The Operation Mode defines one of eight logical operations to be performed between the frame buffer read data and the color data in the Pattern RAM to determine the drawing data to be re-written into the frame buffer.



Figure 34 Absolute Coordinate Specification



Figure 35 Relative Coordinate Specification

Table 5-1 Graphic Drawing Commands

| Command | Function                                                                                                                                                                       |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AMOVE   | Move the Current Pointer (CP) to an absolute logical pixel X-Y address.                                                                                                        |
| RMOVE   | Move the Current Pointer (CP) to a relative logical pixel X-Y address.                                                                                                         |
| ALINE   | Draw a straight line from the Current Pointer (CP) to a command specified end point of the absolute coordinates.                                                               |
| RLINE   | Draw a straight line from the Current Pointer (CP) to a command specified end point of the relative coordinates                                                                |
| ARCT    | Draw a rectangle defined by the Current Pointer (CP) and a command specified diagonal point of the absolute coordinates                                                        |
| RRCT    | Draw a rectangle defined by the Current Pointer (CP) and a command specified diagonal point of the relative coordinates.                                                       |
| APLL    | Draw a polyline (multiple contiguous segments) from the Current Pointer (CP) through command specified points of the absolute coordinates                                      |
| RPLL    | Draw a polyline (multiple contiguous segments) from the Current Pointer (CP) through command specified points of the relative coordinates                                      |
| APLG    | Draw a polygon which connects the start pointer (CP) and command specified points of the absolute coordinates.                                                                 |
| RPLG    | Draw a polygon which connects the start pointer (CP) and command specified points of the relative coordinates.                                                                 |
| CRCL    | Draw a circle of the radius R placing the Current Pointer (CP) at the center.                                                                                                  |
| ELPS    | Draw a ellipse whose shape is specified by command parameters, placing the Current Pointer (CP) at the center.                                                                 |
| AARC    | Draw an arc by using the Current Pointer (CP) as a start point with an end point and a center point of the absolute coordinates.                                               |
| RARC    | Draw an arc by using the Current Pointer (CP) as a start point with an end point and a center point of the relative coordinates.                                               |
| AEARC   | Draw an ellipse arc by using the Current Pointer (CP) as a start point with an end point and a center point of the absolute coordinates.                                       |
| REARC   | Draw an ellipse arc by using the Current Pointer (CP) as a start point with an end point and a center point of the relative coordinates                                        |
| AFRCT   | Paint a rectangular area specified by the Current Pointer (CP) and command parameters (absolute coordinates) according to a figure pattern stored in the Pattern RAM (Tiling). |
| RFRCT   | Paint a rectangular area specified by the Current Point (CP) and command parameters (relative coordinates) according to a figure pattern stored in the Pattern RAM (Tiling).   |
| PAINT   | Paint a closed area surrounded by edge color using a figure pattern stored in the Pattern RAM (Tiling).                                                                        |
| DOT     | Mark a dot on the coordinates where the Current Point (CP) indicates.                                                                                                          |
| PTN     | Draw a graphic pattern defined in the Pattern RAM onto a rectangular area specified by the Current Pointer (CP) and by the pattern size (rotation angle: 45°)                  |
| AGCPY   | Copy a rectangular area specified by the absolute coordinates to the address specified by the Current Pointer (CP) (rotation angle: 90°/mirror turnover).                      |
| RGCPY   | Copy a rectangular area specified by the relative coordinates to the address specified by the Current Pointer (CP) (rotation angle: 90°/mirror turnover).                      |





Figure 36 Graphic Drawing Command Format

**Operation Mode**

The Operation Mode (OPM bits) of the Graphic Drawing Command specify the logical drawing condition.

Figure 37 shows examples of a drawing pattern applied with various OPM modes.

Table 5-2 Operation Mode

| OPM   | Operation Mode                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0 0 | REPLACE:<br>Replaces the frame buffer data with the color data.                                                                                                                                                                                                                                                                                                                                 |
| 0 0 1 | OR:<br>ORs the frame buffer data with the color data. The result is rewritten to the frame buffer.                                                                                                                                                                                                                                                                                              |
| 0 1 0 | AND:<br>ANDs the frame buffer data with the color data. The result is rewritten to the frame buffer.                                                                                                                                                                                                                                                                                            |
| 0 1 1 | EOR:<br>EORs the frame buffer data with the color data. The result is rewritten to the frame buffer.                                                                                                                                                                                                                                                                                            |
| 1 0 0 | CONDITIONAL REPLACE (Read Data=CCMP):<br>When the frame buffer data at the drawing position is equal to the comparison color (CCMP), the frame buffer data is replaced with the color data.                                                                                                                                                                                                     |
| 1 0 1 | CONDITIONAL REPLACE (Read Data≠CCMP):<br>When the frame buffer data at the drawing position is not equal to the comparison color (CCMP), the frame buffer data is replaced with the color data.                                                                                                                                                                                                 |
| 1 1 0 | CONDITIONAL REPLACE (Read Data<CL):<br>When the frame buffer data at the drawing position is less than the color register data (CL), the frame buffer data is replaced with the color data.                                                                                                                                                                                                     |
| 1 1 1 | CONDITIONAL REPLACE (Read Data≥CL):<br>When the frame buffer data at the drawing position is greater than or equal to the color register data (CL), the frame buffer data is replaced with the color data.<br>Note) In case that the read data = CL, and CL is used for the color data to be drawn, replacement cannot be identified, because replaced data is the same color as the read data. |

Note 1) The color data is generally the color register data (CL) which is either CLO or CL1 selected by the pattern pointer. But in case of COL=11, pattern RAM data directly becomes the color data, and in graphic copy commands (AGCPY and RGCPY), it is the source area data.

Note 2) The same color should be set to both CLO and CL1 (CLO=CL1) when using a graphic copy command at OPM=110 or 111, or when using COL=11 at OPM=110 or 111.





Figure 37 Operation Mode Examples

**Color Mode**

The Color Mode (COL bits) specifies the source of the drawing color data as directly or indirectly (using the Color Registers) determined by the contents of the Pattern RAM.

Table 5-3 Color Mode

| COL | Color Mode                                                                                                 |
|-----|------------------------------------------------------------------------------------------------------------|
| 0 0 | When Pattern RAM data = 0, Color Register 0 is used<br>When Pattern RAM data = 1, Color Register 1 is used |
| 0 1 | When Pattern RAM data = 0, drawing is suppressed.<br>When Pattern RAM data = 1, Color Register 1 is used   |
| 1 0 | When Pattern RAM data = 0, Color Register 0 is used<br>When Pattern RAM data = 1, drawing is suppressed.   |
| 1 1 | Pattern RAM contents are directly used as color data                                                       |

The Color Mode chooses the source for color information based on the contents (0 or 1) of a particular bit in the 16 bit by 16 bit (32 byte) Pattern RAM. A sub-pattern is specified by programming the Pattern RAM Control Register (PRC) with the



Figure 38 Pattern RAM

start (PSX, PSY) and end (PEX, PEY) points which define the diagonal of the sub-pattern. Furthermore, a specific starting point for Pattern RAM scanning is specified by PPX and PPY.

Normally, the color register (CL0 or CL1) should be loaded with one color data based on the number of bits per pixel. For example, if 4 bits/pixel are used, the 4 bit color pattern (e.g. 0001) should be repeated four times in the color register, i.e.

Color Register = 

|   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|---|---|---|---|---|---|---|---|---|---|---|---|

In this way, color changes due to changing dot address are avoided.

Table 5-4 Drawing Area Mode

| AREA  | Drawing Area Mode                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0 0 0 | Drawing is executed without Area checking.                                                                                            |
| 0 0 1 | When attempting to exit the Area, drawing is stopped after setting ABT (Abort Bit).                                                   |
| 0 1 0 | Drawing suppressed outside the Area (Drawing operation continues and the ARD flag is not set outside the Area)                        |
| 0 1 1 | Drawing suppressed outside the Area (Drawing operation continues and the ARD flag is set at every drawing operation outside the Area) |
| 1 0 0 | Same as AREA = 0 0 0.                                                                                                                 |
| 1 0 1 | When attempting to enter the Area, drawing is stopped after setting ABT (Abort Bit).                                                  |
| 1 1 0 | Drawing suppressed inside the Area (Drawing operation continues and the ARD flag is not set inside the Area).                         |
| 1 1 1 | Drawing suppressed inside the Area (Drawing operation continues and the ARD flag is set at every drawing operation inside the Area)   |

#### Area Mode

Prior to drawing, a drawing area may be defined (Area Definition Register). Then, during Graphics Drawing operation the ACRTC will check if the drawing point is attempting to enter or exit the defined drawing area. Based on eight Area Modes, the ACRTC will take appropriate action for clipping or hitting.

#### ■ SYSTEM INTERFACE

##### • BASIC CLOCK

The ACRTC basic clock is 2CLK. 2CLK controls all primary ACRTC display and logic timing parameters.

2CLK, along with the specification of number of bits per logical pixel, the Graphic Address Increment mode, and the Display Access mode, also determines the video data rate.

The basic clock must be input with its cycle, max. and min. of "High" and "Low" level width as shown in the AC characteristics.

In any case, be careful not to stop the basic clock, fixing it at "High", "Low", or open, which can destroy the LSI.

#### • CRT INTERFACE

##### Frame Buffer Access

###### (1) Access Modes

The three ACRTC display memory access modes are Single, Interleaved and Superimposed.

###### (a) Single Access Mode

A display (or drawing) cycle is defined as two cycles of 2CLK. During the first 2CLK cycle, the frame buffer display or drawing address is output. During the second 2CLK cycle, the frame buffer data is read (display cycles and/or drawing cycles) or written (drawing cycles).

In this mode, display and drawing cycles contend for access to the frame buffer. The ACRTC allows the priority to be defined as display priority or drawing priority. If display has priority, drawing cycles are only allowed to occur during horizontal/vertical flyback period. So, a 'flashless' display is obtained at the expense of slower drawing. If drawing has priority, drawing may occur during display, so high speed drawing is obtained. However the display may flash.

###### (b) Interleaved Access Mode (Dual Access Mode 0)

In this mode, display cycles and drawing cycles are interleaved. A display/drawing cycle is defined as four cycles of 2CLK. During the first 2CLK cycle, the frame buffer display address is output. During the second 2CLK cycle, the display data is read from the frame buffer. During the third 2CLK cycle, the frame buffer drawing address is output. During the fourth 2CLK cycle, the drawing data is read or written.

Since there is no contention between display and drawing cycles, a 'flashless' display is obtained while maintaining full drawing speed. However, for a given configuration, frame buffer memory access time must be twice as fast as an equivalent Single Access Mode configuration.

###### (c) Superimposed Access Mode (Dual Access Mode 1)

In this mode, two separate logical screens are accessed during each display cycle. The display cycle is defined as four 2CLK cycles. During the first 2CLK cycle, the Background (Upper, Base, or Lower) screen frame buffer address is output. During the second 2CLK cycle, the Background screen display data is read. During the third 2CLK cycle, the window screen frame buffer address or the drawing frame buffer address is output. During the fourth 2CLK cycle, the window screen display or drawing data is read (display or drawing) or written (drawing). Note that the third and fourth cycles can be used for drawing (similar to Interleaved mode) when these cycles are not used for Window display.





## SA (SINGLE ACCESS MODE)



Figure 39 Single Access Mode Timing

**DAO (INTERLEAVED ACCESS MODE)**
**Display Cycle**

**Display Cycle (x2 Zoomed)**

**Drawing Cycle**


Figure 40 Interleaved Access Mode Timing



## DA1 (SUPERIMPOSED ACCESS MODE)



Figure 41 Superimposed Access Mode Timing



Figure 42 Horizontal Scan Sequence

## (2) Graphic Address Increment Mode (GAI)

During display operation, the ACRTC can be programmed to control the graphic display address in seven ways including increment by 1, 2, 4, 8 and 16\* words, 1 word every two display cycles and no increment.

Setting GAI to increment by 2, 4, 8 or 16 words per display cycle achieves linear increases in the video data rate i.e. for a given configuration setting GAI to 2, 4, 8 or 16 words will achieve 2, 4, 8 or 16 times the video data rate corresponding to  $GAI = 1$ . This allows increasing the number of bits/logical pixel and logical pixel resolution while meeting the 2CLK maximum frequency constraint.

Table 6 shows the summary relationship between 2CLK, Display Access Mode, Graphic Address Increment, number of bits/logical pixel, memory access time and video data rate. The frame buffer cycle frequency ( $F_c$ ) is shown by the following equation where:

$$\begin{aligned} F_v &= \text{Dot Clock} \\ N &= \text{Number of bits/logical pixel} \\ D &= \text{Display Access Mode} \\ &\quad 1 \text{ for Single Access Mode} \\ &\quad 2 \text{ for Interleaved and Superimposed Access Modes} \\ A &= \text{Graphic Address Increment (1/2, 1, 2, 4, 8, 16)} \\ F_c &= (F_v \times N \times D) / (A \times 16) \end{aligned}$$

Table 6 Graphic Address Increment Modes

| Number of Bits/Pixel | Access Mode<br>Memory Cycle | Dot Rate |      | 16 MHz |      | 32 MHz |      | 64 MHz |      | 128 MHz |    |
|----------------------|-----------------------------|----------|------|--------|------|--------|------|--------|------|---------|----|
|                      |                             | SA       | DA   | SA     | DA   | SA     | DA   | SA     | DA   | SA      | DA |
| 1                    | 250 ns                      | —        | +1/2 | +1/2   | +1   | +1     | +2   | +2     | +4   |         |    |
|                      | 500 ns                      | +1/2     | +1   | +1     | +2   | +2     | +4   | +4     | +8   |         |    |
| 2                    | 250 ns                      | +1/2     | +1   | +1     | +2   | +2     | +4   | +4     | +8   |         |    |
|                      | 500 ns                      | +1       | +2   | +2     | +4   | +4     | +8   | +8     | +16* |         |    |
| 4                    | 250 ns                      | +1       | +2   | +2     | +4   | +4     | +8   | +8     | +16* |         |    |
|                      | 500 ns                      | +2       | +4   | +4     | +8   | +8     | +16* | +16*   | —    |         |    |
| 8                    | 250 ns                      | +2       | +4   | +4     | +8   | +8     | +16* | +16*   | +16* |         |    |
|                      | 500 ns                      | +4       | +8   | +8     | +16* | +16*   | —    | —      | —    |         |    |
| 16                   | 250 ns                      | +4       | +8   | +8     | +16* | +16*   | —    | —      | —    |         |    |
|                      | 500 ns                      | +8       | +16* | +16*   | —    | —      | —    | —      | —    |         |    |

## Dynamic RAM Refresh

When dynamic RAMs (DRAMs) are used for the frame buffer memory, the ACRTC can automatically provide DRAM refresh addressing.

The ACRTC maintains an 8 bit DRAM refresh counter which is decremented on each frame buffer access. During HSYNC low, the ACRTC will output the sequential refresh addresses on MAD. The refresh address assignment depends on Graphic Address Increment (GAI) mode as shown in Table 7.

The ACRTC provides "0" output on the remaining address line of MAD and MA/RA.

DRAM refresh cycle timing must be factored into the determination of HSYNC low pulse width (HSW — specified in units of frame buffer memory cycles).

If the horizontal scan rate is  $F_h$  (kHz), number of DRAM refresh cycles is  $N$  and the DRAM refresh cycle time is  $T_r$  (msec) then horizontal sync width (HSW) is specified by the following equation:

$$HSW \geq N / (T_r \times F_h)$$

For example, if the scan rate is 15.75 kHz and the DRAMS

have 128 refresh cycles of 2 ms, HSW must be greater than or equal to 5.

$$HSW \geq 128 / (2 \times 15.75) = 4.06$$

Table 7 GAI and DRAM Refresh Addressing

| Graphic Address Increment Mode | Refresh Address Output Terminal     |
|--------------------------------|-------------------------------------|
| +0 (GAI=101)                   | MAD <sub>0</sub> ~MAD <sub>7</sub>  |
| +1 (GAI=000)                   | MAD <sub>0</sub> ~MAD <sub>7</sub>  |
| +2 (GAI=001)                   | MAD <sub>1</sub> ~MAD <sub>8</sub>  |
| +4 (GAI=010)                   | MAD <sub>2</sub> ~MAD <sub>9</sub>  |
| +8 (GAI=011)                   | MAD <sub>3</sub> ~MAD <sub>10</sub> |
| +16 (GAI=100)*                 | MAD <sub>4</sub> ~MAD <sub>11</sub> |
| +1/2 (GAI=111)<br>110          | MAD <sub>0</sub> ~MAD <sub>7</sub>  |





Figure 43 DRAM Refresh Timing

#### External Synchronization

The ACRTC EXSYNC pin allows synchronization of multiple ACRTCs or other video signal generators. The ACRTC may be programmed as a single Master device, or as one of a number of Slave devices.

To synchronize multiple ACRTCs, simply connect all the EXSYNC pins together.

For synchronizing to other video signals, the connection scheme depends on the raster scan mode. In Non-Interlace mode, EXSYNC corresponds to VSYNC. In Interlace modes, EXSYNC corresponds to VSYNC of the odd field.

Note 1) The ACRTC performs the synchronization every time it accepts the pulse input from EXSYNC in the slave mode.

It is recommended that the synchronous pulse should be input from EXSYNC only when the synchronization gap between the synchronous signal of the master device and that of ACRTC in the slave mode (Hsync and Vsync are output also in the slave mode.).

Note 2) The ACRTC needs to be controlled not to draw during EXSYNC input.



Figure 44 External Synchronization

#### • MPU INTERFACE MPU Bus Cycle

The ACRTC interfaces to the MPU as an 8 or 16 bit peripheral as configured during RES.

An MPU bus cycle is initiated when CS is asserted (following the assertion of RS and R/W). The ACRTC responds to CS low by asserting DTACK low to complete the data transfer. DTACK will be returned to the MPU in between 1 and 1.5 2CLK cycles.

MPU WAIT states will be added in the following two cases.

(a) If the ACRTC 2CLK input is much slower than the MPU clock, continuous ACRTC accesses may be delayed due to internal processing of the previous bus cycle.

Note) CS "High" width must not be less than two 2CLK cycles.

(b) If a read cycle immediately follows a write cycle, a WAIT state may occur due to ACRTC preparation for bus 'turn-around'. However, MPUs (for example 68000) normally have no instruction which lets a read cycle follow a write cycle immediately.

For connection to synchronous bus interface MPUs, DTACK can simply be left open assuming the system design guarantees that WAIT states cannot occur as described above. If WAIT states may occur, DTACK can be used with external logic to synthesize a READY signal.

#### DMA Transfer

The ACRTC can interface with an external DMA controller using three handshake signals, DMA Request (DREQ), DMA Acknowledge (DACK) and DMA Done (DONE).

The ACRTC uses the external DMAC for two types of transfers, Command/Parameter DMA and Data DMA. For both types, DMA transfers use the ACRTC read and write FIFOs.

##### (1) Command/Parameter DMA

The MPU initiates this mode by setting bit 12 (CDM) in the ACRTC Command Control Register to 1. Then, the ACRTC will automatically request DMA transfer for commands and their associated parameters as long as the write FIFO has space. Only cycle steal request mode (DREQ pulses low for each data transfer) can be used. Command/Parameter DMA is terminated when the MPU resets bit 12 in CCR to 0 or the external DONE input is asserted.

##### (2) Data DMA

Data DMA is used to move data between the MPU system



memory and the ACRTC frame buffer.

The MPU sets-up the transfer by specifying the frame buffer transfer address (and other parameters of the transfer, such as 'on-the-fly' logical operations) to the ACRTC. Next, when the MPU issues a Data Transfer Command to the ACRTC, the ACRTC will request DMA transfer to and from system memory. The ACRTC will request DMA, automatically monitoring FIFO status, until the DMA Transfer Command is completed.

Data DMA request mode can be cycle steal (as in Command/Parameter DMA) or burst mode in which DREQ is a low level control output to the DMAC which allows multiple data transfers during each acquisition of the MPU bus.

#### Interrupts

The ACRTC recognizes eight separate conditions which can generate an interrupt including command error detection, command end, drawing edge detection, light pen strobe and four FIFO status conditions. Each condition has an associated mask bit for enabling/disabling the associated interrupt. The ACRTC removes the interrupt request when the MPU performs appropriate interrupt service by reading or writing to the ACRTC.

- DISPLAY FUNCTION
- SCREEN DISPLAY CONTROL

#### Logical Display Screens

The ACRTC allows division of the frame buffer into four separate logical screens.

| Screen Number | Screen Name   | Screen Group Name  |
|---------------|---------------|--------------------|
| 0             | Upper Screen  |                    |
| 1             | Base Screen   | Background Screens |
| 2             | Lower Screen  |                    |
| 3             | Window Screen |                    |

In the simplest case, only the Base screen parameters must be defined. Other screens may be selectively enabled, disabled and blanked under software control.

The Background (Upper, Base and Lower) screens partition the display into three horizontal splits whose positions are fully

programmable. A typical application might use the Base screen for the bulk of user interaction, using the Lower screen for a 'status line(s)' and the Upper screen for 'pull-down menu(s)'.

The Window screen is unique, since the ACRTC usually gives the Window screen higher priority than Background screens. Thus, when the Window, whose size and position is fully programmable, overlaps a Background screen, the Window screen is displayed. The exception is the ACRTC Superimposed Access Mode, in which the Window has the same display priority as Background screens. In this case, the Window and Background screen are 'superimposed' on the display.



Figure 45 Screen Combination Examples

#### Frame Memory Setup

The ACRTC can have two types of independent frame memories, 2M byte frame buffer and 128k byte refresh memory, and CHR signal controls which memory to be accessed.

For the frame memory, memory width is defined by setting up Memory Width Register (MWR), and horizontal display width is independently defined by Horizontal Display Register (HDR). Therefore the frame memory area can be specified bigger than display area as shown in Figure 46.



Figure 46 Frame Memory and Display Screen Area



**Display Control**

Figure 47 shows the relation between the frame memory and the display screens.

Each screen has its own memory width, start address, vertical display width, and attribution of frame memory (character/graphic), and those are specified by the control registers.



Figure 47 Frame Memory and Display Screens

Figure 48 shows the relation between the control registers and the display screens. Registers for horizontal display control are set in units of memory cycles, and registers for vertical display

control are set in units of rasters.

Note a display width specified by \* marked register is:  
 $(\text{Display width}) = (\text{Setup value}) + 1 \text{ memory cycles}$



Figure 48 Display Screen Specification



Figure 49 Display Scan Sequence (Horizontal and Vertical)

**Graphic/Character Address Spaces**

The ACRTC controls two separate logical address spaces. The CHR pin allows external decoding if physically separate frame memories are desired.

Each of the four logical screens (Upper, Base, Lower and Window) is programmed as residing in the Graphics address space or the Character address space.

ACRTC accesses to Graphics screens are treated as bit mapped using a 20 bit frame buffer address, with an address space of one megaword (1M by 16 bit).

ACRTC accesses to Character screens are treated as character generator mapped. In this case, a 64k word address space is used and 5 bits of raster address are output to an external character generator.

Multiple logical screens defined as Character can be externally decoded to use separate character generators or different addresses within a combined character generator. Also, each Character screen may be defined with separate line spacing, separate cursors, etc.

**• CURSOR CONTROL**

The ACRTC has two Block Cursor Registers and a Graphic Cursor Register.



Figure 50 Character Screen Raster Addressing

A Block cursor is used with Character screens. The cursor start and ending raster addresses are fully programmable. Also, the cursor width can be defined as one to eight memory cycles.

A Graphic cursor is defined by specifying the start/end memory cycle in the X dimension and the start/end raster in the Y dimension.

The Graphic cursor can be output on character and Graphic screens.

The ACRTC provides two separate cursor outputs,  $\overline{CUD1}$  and  $\overline{CUD2}$ . These are combined with two character cursor registers and a graphic cursor register to provide three cursor modes.

- (1) Block Mode  
Two Block cursors are output on  $\overline{CUD1}$  and  $\overline{CUD2}$  respectively.
- (2) Graphic Mode  
The Graphic cursor is output on  $\overline{CUD1}$ . Using an external cursor pattern memory allows a graphic cursor of various shapes. Two Block cursors are multiplexed on  $\overline{CUD2}$ .
- (3) Crosshair Mode  
The horizontal and vertical components of the Graphic cursor are output on  $\overline{CUD1}$  and  $\overline{CUD2}$  respectively. This allows simple generation of a crosshair cursor control signal.



Figure 51 Two Separate Block Cursors



Figure 52 Block Cursor Examples





Figure 53 Graphic Cursor



Figure 54 Crosshair Cursor

#### • SCROLLING

##### Vertical Scroll

Each logical screen performs independent vertical scroll. On Character Screens, vertical smooth scroll is accomplished using the programmable Start Raster Address (SRA). Line by line scroll is accomplished by increasing or decreasing the screen start address by one unit of horizontal memory width.

On Graphics screens, vertical smooth scroll is accomplished by increasing or decreasing the screen start address by one unit of horizontal memory width.

##### Horizontal Scroll

Horizontal scroll can be performed in units of characters for Character screens and units of words (multi logical pixels) for Graphic screens by increasing or decreasing the screen start address by 1.

For smooth horizontal scroll, the ACRTC has dot shift video attributes which can be used with an external circuit which conditions shift register load/clocking.

Since this dot shift information is output each raster, horizontal smooth scroll is limited to either the Background screens or the Window screen at any given time. However, horizontal scroll is independent for each of the Background screens (Upper, Base, Lower).





Figure 55 Scrolling by SAR (Start Address Register) Rewrite



Figure 56 Horizontal Smooth Scroll – Background Screen



Figure 57 Horizontal Smooth Scroll — Window Screen (WSS=1)

#### • RASTER SCAN MODES

The ACRTC has three software selectable raster scan modes — Non-Interlace, Interlace Sync and Interlace Sync & Video. In Non-Interlace mode a frame consists of one field. In the Interlace modes, a frame consists of two fields, the even and odd fields.

The Interlace modes allow increasing screen resolution while avoiding limits imposed by the CRT display device, such as maximum horizontal scan frequency or maximum video dot rate.

Interlace Sync mode simply repeats each raster address for both the even and odd fields. This is useful for increasing the

quality of a displayed figure when using an interlaced CRT device such as a Television Set with RF modulator.

Interlace Sync & Video mode displays alternate even and odd rasters on alternate even and odd fields. For a given number of rasters/character, this mode allows twice as many characters to be displayed in the vertical direction as Non-Interlace mode.

Note that for Interlace modes, the refresh frequency for a given dot on the screen is one-half that of the Non-Interlace mode. Interlace modes normally require the use of a CRT with a more persistent phosphor to avoid a flickering display.



Figure 58 Raster Scan Modes





Figure 59 Raster Scan Timing

- **ZOOMING**

The ACRTC supports a zoom function for the Base screen (Screen 1). Note that ACRTC zooming is performed by controlling the CRT timing signals. The contents of the frame buffer area being zoomed are not changed.

The ACRTC allows specification of zoom factors (1 to 16) independently in the X and Y directions.

For horizontal zoom, the programmed zoom factor is output as video attributes. An external circuit uses this factor to condition the external shift register clock to accomplish horizontal zooming.

For vertical zoom, no external circuit is required. The ACRTC will scan a single raster multiple times to accomplish vertical zooming.



Figure 60 Zooming



### ● LIGHT PEN

The ACRTC provides a 20 bit Light Pen Address Register and a Light Pen Strobe (LPSTB) input pin for connection with a light pen.

A light pen strobe pulse will occur when the CRT electron beam passes under the light pen during display refresh. When this pulse occurs, the contents of the ACRTC display refresh address counter will be latched into the Light Pen Address Register along with a logical screen (Character or Graphic screen) descriptor. Also, an ACRTC status flag indicating light pen activity is set, generating an optional (maskable) MPU interrupt. Note that for Superimposed access mode, when the light pen strobe occurs in an area in which the Window overlaps a Background screen, the Background screen address will be latched. And even for all access mode, the Drawing address will never be latched.

Various system and ACRTC delays will cause the latched address to differ slightly from the actual light pen position. The light pen address can be corrected using software, based upon system specific delays. Or, if the application does not require the highest light pen pointing resolution, software can "bound" the light pen address by specifying a range of values associated with a given area of the screen.

## ■ NOTES ON SYSTEM DESIGNING

### ● GND IMPEDANCE

#### Problem Description

In case that load capacitance on frame memory address/data bus (MAD) and GND impedance are large, noise may occur on output signals especially at the following timings:

- 1) Starting of address output on  $MAD_0$ – $MAD_{15}$  (plus  $MA_{16}/RA_0$ – $MA_{19}/RA_3$ )
- 2)  $MAD_0$ – $MAD_{15}$  turning high impedance after address output
- 3) Starting and finishing of drawing data output on  $MAD_0$ – $MAD_{15}$
- 4) Starting and finishing of video attributes output on  $MAD_0$ – $MAD_{15}$  (plus  $MA_{16}/RA_0$ – $MA_{19}/RA_3$ )

The noise generally occurs sharply on "Low" leveled output signals as shown in Figure 61 and Figure 64. This problem is caused by GND impedance, as MAD bus and output signal lines are sharing GND line in side the LSI as shown in figure 62. Depending on impedance of the GND line, the GND level is influenced by excessive discharge on internal GND line which occurs when MAD state changes from high impedance to "Low" level, from "High" level to "Low" level, or from "High" level to high impedance.

In case that load capacitance on bi-directional host system data bus and GND impedance are large, noise may occur on output signals at data turnings. However, the level of this noise is much lower than that of the former case, because the GNDs for the data bus and output signal lines are almost separated to minimize the noise.

Note the level of the noise increases depending on the load capacitance. So the load capacitance should be less than the condition in Figure 20.

#### Problem Analysis

Figure 63 shows the relations between the noise voltage and parameters:  $V_{CC}$ , GND impedance, load capacitance on MAD, and number of MAD lines which cause discharge. As level of

noise depends on these parameters and output signal pins, it is required to check the condition of the system. Following output signal pins tend to have remarkable noise:

$MA_{16}/RA_0$ – $MA_{19}/RA_3$ ,  $RA_4$ ,  $CHR$ ,  $MRD$ ,  $DRAW$ ,  $DISP1$ ,  $DISP2$ , and others

A typical waveform of the noise is shown in Figure 64, and the noise voltage in the worst case is shown in Figure 65.

#### Countermeasures

In case of having the noise, please take measures for designing the system as follows:

- 1) Latch  $MA_{16}/RA_0$ – $MA_{19}/RA_3$  and  $RA_4$  by  $\overline{AS}$  as shown in Figure 66.
- 2) Latch output signals other than MA/RA by 2CLK rising or falling, or by other timings as shown in Figure 67. Latch timing should be determined in consideration of the noise timing and clock timing/other timings.
- 3) Insert Schmitt trigger circuit in output signal lines which have little noise as shown in Figure 68. For taking this measure instead of former measures, please check the condition of each output signal line, such as noise level and pulse width.

Following are measures to reduce the discharge into the internal GND line and the noise level.

- 1) Reduce the load capacitance on MAD bus. If it is large, bus buffer is necessary.
- 2) Keep supply voltage ( $V_{CC}$ ) as low as possible.
- 3) Insert damping resistors into  $MAD_0$ – $MAD_{15}$  as shown in Figure 24. The damping resistors are 50–100Ω, and should be located as near pins as possible. Figure 69 shows the effect of the damping resistors. This is also a measure against ringing problem (Figure 23).

#### Relational Notes

Rush current occurs at switching of output signals.

Level of this transient depends on load capacitance of external circuit, clock frequency, impedance of  $V_{CC}$  and GND, etc. It is required to design the system in consideration of measures against noise caused by the transient.

- (1) Notes on power supply circuit  
Keep impedance of  $V_{CC}$  and GND as little as possible to minimize voltage change as follows.  
1) Use a multilayer board (more than 4 layers with internal  $V_{CC}$  and GND).  
2) Keep  $V_{CC}$  and GND lines wide for a doublelayer board.  
3) Insert bypass capacitors as shown in Figure 25.  
4) Keep no voltage difference between each  $V_{CC}$  pin, and between each GND pin. (Remark GND voltage for a doublelayer board)
- (2) Notes on buses  
Transient occurs at switching of MAD bus and/or host system data bus (about hundreds mA). Followings are measures to reduce the transient.  
1) Minimize the load capacitance on  $MAD_0$ – $MAD_{15}$  and  $D_0$ – $D_{15}$  by reducing fan out, inserting bus buffers, or shortening the buses.  
2) Insert damping resistors (50–100Ω) in buses near LSI pins as shown in Figure 24.





Figure 61 Noise on the "Low" Leveled Output Signals Caused by MAD Change



Figure 62 Internal Circuit





Figure 63 Relations Between the Noise Voltage and Parameter



Figure 64 Typical Waveform of the Noise



Figure 65 Relation Between the Noise and MAD Load Capacitance



Figure 66 Countermeasure ①



Figure 67 Countermeasure ②



Figure 68 Countermeasure ③



Figure 69 Noise Reduction By Damping Resistors

**HITACHI**

# HD63485

## Description

The HD63485 LSI belongs to the ACRTC (advanced CRT controller) family. It provides memory access control to frame buffers for graphic display and drawing. Incorporating bus driver circuits and a DRAM (dynamic RAM) interface, the GMIC allows direct connection to DRAMs with no external circuits. Its main function includes address data latch, DRAM row and column address multiplexing, supplying  $\overline{\text{RAS}}$ ,  $\overline{\text{CAS}}$ ,  $\overline{\text{OE}}$ ,  $\overline{\text{WE}}$ , and other signals, and generating the 2CLK signal for the ACRTC. Using the Hi-BiCMOS process, the HD63485 achieves high speed memory access with low power dissipation.

## Type of Products

| Part No.     | Speed | Package                               |
|--------------|-------|---------------------------------------|
| HD63485PS-32 | 32MHz | 64-pin Plastic Shrink DIP<br>(DP-64S) |
| HD63485PS-48 | 48MHz |                                       |
| HD63485PS-64 | 64MHz |                                       |
| HD63485CP-32 | 32MHz | 68-pin PLCC                           |
| HD63485CP-48 | 48MHz | (CP-68)                               |
| HD63485CP-64 | 64MHz |                                       |

## Features

- Drives frame buffer memory directly ( $I_{OL} = 24 \text{ mA}$  max)
- Generates DRAM signal: row and column addresses,  $\overline{\text{RAS}}$ ,  $\overline{\text{CAS}}$ ,  $\overline{\text{OE}}$ ,  $\overline{\text{WE}}$ , etc
- High-speed dot rate input (64 MHz max)
- Direct ACRTC interface
- Generates horizontal scrolling control signals
- Generates load signals for horizontal smooth scrolling
- Programmable address increment mode
- Generates 2CLK signal
- TTL-compatible input/output
- Single +5 V power supply
- Low power dissipation



## Pin Description

Figure 1 shows the pin arrangement for the 64-pin shrink-type DIP and the 68-pin PLCC packages. Pins marked with \* are bus drivers, which can

handle a maximum output current  $I_{OL}$  of 24mA. Table 1 describes the pins.



**Figure 1.** Pin arrangement

**Power Supply (V<sub>ss</sub>, V<sub>cc</sub>)**

V<sub>ss</sub> and V<sub>cc</sub> are the GMIC power supply pins. V<sub>cc</sub> pins are +5 V±5 % supply pins. V<sub>ss</sub> are the ground

pins. Be sure to connect all four V<sub>ss</sub> pins to ground and both V<sub>cc</sub> pins to the power supply.

**Table 1. Pin Description**

| <b>Signal</b>   | <b>Pin Number</b>            | <b>DIP-64 PLCC-68</b> | <b>I/O</b> | <b>Description</b>                  |
|-----------------|------------------------------|-----------------------|------------|-------------------------------------|
| V <sub>cc</sub> | 32,64                        | 34,68                 |            | +5 V power supply                   |
| V <sub>ss</sub> | 16,17, 17,18,<br>48,49 51,52 |                       |            | Ground                              |
| CDM1,<br>CDM0   | 34,35                        | 36,37                 | I          | Clock division ratio                |
| DAM             | 63                           | 67                    | I          | Dual access mode                    |
| IM1,<br>IMO     | 59,60                        | 63,64                 | I          | Increment mode                      |
| WSS             | 62                           | 66                    | I          | Window smooth scroll                |
| DOTCK           | 33                           | 35                    | I          | Dot clock                           |
| TEST            | 57                           | 62                    | I          | Test                                |
| 2CLKOUT         | 61                           | 65                    | O          | Clock                               |
| MCYC            | 10                           | 11                    | I          | Memory cycle                        |
| DRAW            | 8                            | 8                     | I          | Draw                                |
| MRD             | 7                            | 7                     | I          | Memory read                         |
| AS              | 9                            | 10                    | I          | Address strobe                      |
| MA18-<br>MA0    | 30-18,                       | 33-28,<br>6-1         | I          | Memory address bus<br>25-19,<br>6-1 |
| H SYNC          | 37                           | 39                    | I          | Horizontal sync                     |
| RAS             | 51                           | 54                    | O          | Row address strobe                  |
| CAS             | 52                           | 55                    | O          | Column address<br>strobe            |
| WE3-WE0         | 53-56                        | 56-59                 | O          | Write enable                        |
| OE              | 15                           | 16                    | O          | Output enable                       |
| FA7-FA0         | 41-47,                       | 44-50,<br>50          | O          | Frame buffer<br>address<br>53       |
| ADRA-<br>ADRC   | 11-13                        | 12-14                 | O          | Address                             |
| SCKE            | 36                           | 38                    | O          | Shift clock enable                  |
| SLDB,<br>SLDW   | 38,                          | 39 40,                | O          | Shift load signals<br>41            |



## Program Pins

**Clock Division Ratio (CDM1, CDM0):** The CDM1 and CDM0 inputs determine the division ratio used to generate 2CLKOUT for the ACRTC from the DOTCK input. See Table 2.

**Dual Access Mode (DAM):** The DAM input sets the access mode as shown in Table 3.

**Increment Mode (IM 1, IM 0):** The IM 1 and IM 0 inputs determine the addresses sent from memory addresses (MA 18-MA 0) as the frame buffer output (FA 7-FA 0) to accommodate different DRAM types. Table 4 shows the memory address outputs corresponding to the IM 1 and IM 0 settings. Note that the frame buffer addresses (FA 7-FA 0) have multiplexed memory address outputs.

IM inputs are closely related to the graphic address increment (GAI) of the ACRTC (see ACRTC User's Manual).

**Window Smooth Scroll (WSS):** When the WSS input is low (0), each base screen can be scrolled in single access mode, dual access mode 0, and dual access mode 1. The SLDB signal contains the

scrolling data.

When the WSS input is high (1), the window screen can be smooth scrolled in dual access mode 1. The SLDW signal contains the scrolling data.

## Operation Control Signals

**Dot Clock (DOTCK):** The DOTCK input must be the same clock that is supplied to the shift register for video signal generation. Dot clock frequency is determined by the horizontal display resolution (pixel count) and the display period of one horizontal scan.

**Test (TEST):** The TEST input is used for manufacturing operational testing. It must be fixed low when the GMIC is mounted in a system.

## ACRTC Interface Signals

**Clock (2CLK):** The 2CLKOUT clock output is a basic clock for the ACRTC's internal operation. The GMIC generates 2CLKOUT by dividing the high-speed dot clock by the ratio determined by the CDM 1 and CDM 0 inputs.

**Table 2. Clock Division Ratio**

| CDM 1 | CDM 0 | Division Ratio |
|-------|-------|----------------|
| 0     | 0     | Not allowed    |
| 0     | 1     | Divide by 4    |
| 1     | 0     | Divide by 8    |
| 1     | 1     | Divide by 16   |

**Table 3. Access Modes**

| DAM | Access Mode        |
|-----|--------------------|
| 0   | Single access mode |
| 1   | Dual access mode   |

**Table 4. Increment Mode**

| IM 1 | IM 0 | Increment Mode | Address Output to FA 7-FA 0                                            | Address Output to ADRC-ADRA                            |
|------|------|----------------|------------------------------------------------------------------------|--------------------------------------------------------|
| 0    | 0    | +1             | MA <sub>15</sub> -MA <sub>8</sub> , MA <sub>7</sub> -MA <sub>0</sub>   | MA <sub>18</sub> , MA <sub>17</sub> , MA <sub>16</sub> |
| 0    | 1    | +2             | MA <sub>16</sub> -MA <sub>9</sub> , MA <sub>8</sub> -MA <sub>1</sub>   | MA <sub>0</sub> , MA <sub>17</sub> , MA <sub>18</sub>  |
| 1    | 0    | +4             | MA <sub>17</sub> -MA <sub>10</sub> , MA <sub>9</sub> -MA <sub>2</sub>  | MA <sub>0</sub> , MA <sub>1</sub> , MA <sub>18</sub>   |
| 1    | 1    | +8             | MA <sub>18</sub> -MA <sub>11</sub> , MA <sub>10</sub> -MA <sub>3</sub> | MA <sub>0</sub> , MA <sub>1</sub> , MA <sub>2</sub>    |



**Memory Cycle (MCYC):** The MCYC input indicates the ACRTC's frame buffer access timing. MCYC is low when the ACRTC is in the address cycle, and high when the ACRTC is in the data cycle.

**Draw (DRAW):** The DRAW input indicates whether the ACRTC memory cycle is a drawing cycle. DRAW is low during drawing cycle, and high otherwise. The GMIC uses DRAW to recognize display cycles, and also to generate DRAM control signals (WE 3-WE 0).

**Memory Read (MRD):** The MRD input controls data transfer between frame buffers and the ACRTC. The ACRTC pulls MRD high when it reads data from the frame buffer, and low when it writes data.

The only exception is when the ACRTC is in superimpose display mode (dual access mode 1). In superimpose display mode, the ACRTC inputs a low level and reads data from a frame buffer in order to indicate that the display cycle is for a superimposed screen (window screen).

**Address Strobe (AS):** The AS input is a latch timing signal for the memory address sent from the ACRTC. Additionally, AS indicates whether memory is begin accessed. For example, for horizontal zooming, the SLDB signal is provided at a lower frequency, corresponding to the lower frequency of AS.

**Memory Address Bus (MA<sub>18</sub>-MA<sub>0</sub>):** The MA<sub>18</sub>-MA<sub>0</sub> inputs are address signals for frame buffer access, provided by the ACRTC.

**Horizontal Sync (HSYNC):** The HSYNC input is a DRAM refresh cycle control signal to horizontally synchronize CRT displays. The GMIC performs RAS only refresh when HSYNC is low and DRAW is high when AS pulses are input.

Setting HSYNC low informs the GMIC of the end of a raster display. Usually, the ACRTC's HSYNC output supplies this input.

### Frame Buffer Access Signals

**Row Address Strobe (RAS):** The GMIC outputs the DRAMs' RAS timing signal on the RAS output.

**Column Address Strobe (CAS):** The GMIC outputs the DRAMs' CAS timing signal on the CAS output.

**Write Enable (WE 3-WE 0):** The GMIC outputs the DRAM's WE timing signals on the WE outputs. Since WE 3-WE 0 are controlled by the increment mode (IM 1, IM 0) and by the lower two bits of the address (MA 1, MA 0), the GMIC can directly control up to four memory banks. Up to eight memory banks can be controlled by externally decoding the address (ADRC) and WE 3-WE 0.

WE 3-WE 0 are bus driver that can handle a maximum output current I<sub>OL</sub> of 24 mA.

**Output Enable (OE):** The GMIC outputs the DRAMs' output timing signal on the OE output. OE is a bus driver that can handle a maximum output current I<sub>OL</sub> of 24 mA.

**Frame Buffer Address (FA 7-FA 0):** The GMIC outputs the multiplexed DRAM address on FA 7-FA 0. How the address is multiplexed depends on the increment mode (table 4). FA 7-FA 0 are bus drivers that can handle a maximum output current I<sub>OL</sub> of 24 mA.

**Address (ADRA-ADRC):** The GMIC latches three address bits other than those delivered on the FA 7-FA 0 bits and outputs them on ADRA-ADRC in one memory cycle.

### GVAC Control Signals

**Shift Clock Enable (SCKE):** The SCKE output controls the GVACs' video signal generation shift register. It outputs a control signal for zooming according to the horizontal zoom signal (attribute control signal) from the ACRTC. The GVAC performs horizontal zoom by halting the clock when SCKE is low.

**Shift Load Signals (SLDB, SLDW):** The SLDB and SLDW outputs are load signals for the display data of the video signal generation shift register. The SLDB output is used for single access mode, dual access mode 0, and dual access mode 1. The SLDW output controls the window screen in dual access mode 1.



## Functional Description

Figure 2 is a block diagram of the HD63485.



Figure 2. GMIC Block Diagram



## 2CLK Generator

The 2CLK generator generates 2CLKOUT for the ACRTC and itself by dividing the external DOTCK signal. The ratio of DOTCK to 2CLKOUT is set externally by the CDM 1 and CDM 0 inputs.

## Attribute Latch

The attribute latch temporarily stores the attribute codes input from the ACRTC on MA 18-MA 0 used for horizontal zoom (HZ 3-HZ 0) and horizontal scroll dot (HSD 3-HSD 0).

## Zoom Control

Zoom control generates the SCKE signal from DOTCK to control the GVAC clock for horizontal display zooming.

## Scroll Control

Scroll control generates shift load signals (SLDB, SLDW) which control video signal generation for the GVAC.

## Address Shifter

The address shifter stores memory addresses (MA 18-MA 0) sent from the ACRTC. It supplies them to the RAM address section according to the timesharing mode selected by the graphic increment mode (IM 1, IM 0).

## ADRA-ADRC Latches

The ADRA-ADRC latches store the lower or upper address bits which are not supplied to FA 7-FA 0 from the memory address sent from the ACRTC. It outputs them for the whole memory cycle.

## RAM Address Selection

The RAM address selection circuits output the timeshared row and column addresses to the frame buffers according to the RAS and CAS timing.

## DRAM Control and WE Control

The DRAM and WE control circuits generate RAS, CAS, OE, and WE signals for frame buffer access from the ACRTC output signals.



## System Description

### Applications

The GMIC provides communications between the ACRTC and frame buffers. It contains control circuits for generating signals necessary for the ACRTC to access a frame buffer. In addition it generates basic signals for operating the ACRTC and control signals for the GVAC (Graphic Video Attribute Controller), which generates the video signals for a CRT display.

The GMIC's operation mode can be controlled by its program pins. This makes the GMIC suitable for a wide range of operations, from small, low-speed systems to large, high-speed systems, and it allows it to flexibly change to suit system specification changes.

Figure 3 shows a graphic system configuration using an ACRTC, GMIC, and GVACs. Using a GMIC for interface to the frame buffers and GVACs for CRT video signal generation creates a flexible, high-performance graphic system with a minimum component count.

### System Configuration

The typical graphic system application for the GMIC and GVAC shown in figure 3 uses two GVACs, but the number of GVACs used can be changed to accommodate CRT resolution and color/grey scale per pixel for various applications.

The GMIC receives memory addresses ( $MAD_{15}$ - $MAD_0$ ,  $MA_{18}$ - $MA_{16}$ ), address strobe ( $\overline{AS}$ ), memory cycle (MCYC), draw ( $\overline{DRAW}$ ), memory read (MRD), and other ACRTC outputs, and generates control signals for the frame buffers. The frame buffers are generally constructed from DRAM, since graphic systems require large memory capacity frame buffers. The GMIC therefore uses a DRAM-compatible multiplexing system. Through this multiplexing, the GMIC delivers address outputs and control signals such as RAS, CAS, WE, and  $\overline{OE}$ , acting as a direct interface between the ACRTC and the frame buffers. Furthermore, the GMIC generates a basic clock signal for the ACRTC (2CLK) by dividing the high-speed dot clock. It also generates control signals for the GVAC.



Figure 3. System Application Example

## Operation

### Basic Clock

Timing for signals to and from the GMIC is based on the dot clock (DOTCK) supplied to the GMIC and the clock output (2CLKOUT) generated by the GMIC. 2CLKOUT is generated by dividing the DOTCK input by the ratio selected by the CDM 1 and CDM 0 inputs. Figure 4 shows the relation between DOTCK and 2CLKOUT. The frequency of DOTCK depends on the speed and resolution of the CRT display. DOTCK (in MHz) equals the horizontal resolution (pixels/raster line) by the horizontal display raster scan period ( $\mu$ s per raster).

$$f_{\text{DOTCK}} = [\text{Horizontal resolution (pixels/raster)}] / [\text{Horizontal display period} (\mu\text{s})] \text{ (MHz)}$$

The dot clock dividing mode should be chosen considering the frame buffer cycle time and the speed of the ACRTC used. For high-speed drawing, a smaller division ratio should be used to supply a

higher frequency chock to the ACRTC. For applications using low-speed frame buffers and external circuits, larger division ratios should be selected to supply a lower frequency clock to the ACRTC.

Note: The maximum DOTCK frequency is sometimes limited by the DOTCK division ratio. If the division ratio is 8 or 16, the maximum frequency is allowed, but if a division ratio of 4 is used, the DOTCK frequency is limited to 32 MHz.

### Frame Buffer Control

The GMIC is designed for use with DRAM frame buffer memories. Therefore, the GMIC generates DRAM access signals RAS, CAS, WE, and OE. Also, it outputs row and column addresses to the RAM, timeshared according to RAS and CAS.

Table 5 shows the GMIC frame buffer access modes. The memory cycles are roughly divided into six types. They are distinguished by the ACRTC's



Figure 4. DOTCK Division



output signals (**AS**, **HSYNC**, **DRAW**, **MRD**).  
Figure 5 shows **RAS** only refresh cycle timing.

Figure 6 and 7 show read and write cycle timing,  
respectively.

**Table 5. Memory Cycles**

| <b>AS</b> | <b>HSYNC</b> | <b>DRAW</b> | <b>MRD</b> | <b>Cycle Mode</b>         | <b>Memory Cycle</b> |
|-----------|--------------|-------------|------------|---------------------------|---------------------|
| Low pulse | Low          | High        | High       | Refresh cycle             | RAS only refresh    |
|           |              | Low         | Low        | Drawing write cycle       | Memory write        |
|           |              | Low         | High       | Drawing read cycle        | Memory read         |
|           | High         | High        | Low        | Window screen cycle       | Memory read         |
|           |              | High        | High       | Background screen display | Memory read         |
| High      | High         | High        | High       |                           | No access           |

Note: The GMIC performs a frame buffer refresh during a horizontal sync period (**HSYNC**=low), with **DRAW** high and **AS** pulse applied. During a refresh cycle, only **RAS** is output. **CAS** and **OE** are not output.



**Figure 5. RAS Only Refresh Timing**





Figure 6. Read Cycly Timing



Figure 7. Write Cycle Timing

Table 6 shows the relation between frame buffer addresses (FA7-FA0) and memory address ( $MA_{18}-MA_0$ ), as determined by the increment mode (IM1, IM0). FA pins provide multiplexed addresses for DRAM, and the remaining address bits are output at ADRA-ADRC. The GMIC has four increment modes: +1, +2, +4, and +8. This mode should be set the same as the ACRTC's GAI (graphic address increment) mode. GAI mode is a bit set according to the frame buffer, which sets the increment mode for display address output for a graphic address.

Graphic drawing data is processed on a single word (16 bit) basis. The ACRTC sets the bit count per pixel by the graphic bit mode (GBM) in its command control register, which is more suitable for multicolor/grey scale systems. However, if one word is definitely read from a frame buffer during each display cycle, four pixels per word can be displayed when GBM is set to 4 bits per pixel. To

implement a CRT display having a 1 bit per pixel resolution (16 pixels/word), an input clock four times faster must be supplied to the ACRTC. For more multicolor/grey scale systems, an ever faster clock is required.

On the other hand, if several words are read from a frame buffer during each display cycle, and the CRT can have a higher resolution without speeding up the ACRTC input clock. For example, in the +4 increment mode, when GBM is set to 4 bits/pixel, 4 words (64 bits) containing 16 pixels can be read in one display cycle.

For one word (16 bits) read during one display cycle, the GAI must be set to 000.

When 32/64/128 bits are required during one display cycle for a high-resolution or multicolor/grey scale system, GAI must be set to 001/010/011

**Table 6. Frame Buffer and Memory Addresses**

| <b>Frame Address</b> | <b>+1 Mode</b> |            | <b>+2 Mode</b> |            | <b>+3 Mode</b> |            | <b>+4 Mode</b> |            |
|----------------------|----------------|------------|----------------|------------|----------------|------------|----------------|------------|
|                      | <b>Row</b>     | <b>Col</b> | <b>Row</b>     | <b>Col</b> | <b>Row</b>     | <b>Col</b> | <b>Row</b>     | <b>Col</b> |
| FA0                  | MA0            | MA8        | MA1            | MA9        | MA2            | MA10       | MA3            | MA11       |
| FA1                  | MA1            | MA9        | MA2            | MA10       | MA3            | MA11       | MA4            | MA12       |
| FA2                  | MA2            | MA10       | MA3            | MA11       | MA4            | MA12       | MA5            | MA13       |
| FA3                  | MA3            | MA11       | MA4            | MA12       | MA5            | MA13       | MA6            | MA14       |
| FA4                  | MA4            | MA12       | MA5            | MA13       | MA6            | MA14       | MA7            | MA15       |
| FA5                  | MA5            | MA13       | MA6            | MA14       | MA7            | MA15       | MA8            | MA16       |
| FA6                  | MA6            | MA14       | MA7            | MA15       | MA8            | MA16       | MA9            | MA17       |
| FA7                  | MA7            | MA15       | MA8            | MA16       | MA9            | MA17       | MA10           | MA18       |
| ADRA                 | MA16           |            | MA0            |            | MA0            |            | MA0            |            |
| ADRB                 | MA17           |            | MA17           |            | MA1            |            | MA1            |            |
| ADRC                 | MA18           |            | MA18           |            | MA18           |            | MA2            |            |

**Table 7. WE Output Timing**

| <b>Increment<br/>Mode</b> | <b>DRAW</b> | <b>Input</b> |            |            |            |            | <b>Output</b> |            |            |            |
|---------------------------|-------------|--------------|------------|------------|------------|------------|---------------|------------|------------|------------|
|                           |             | <b>MRD</b>   | <b>MA1</b> | <b>MA0</b> | <b>IM1</b> | <b>IM0</b> | <b>WE3</b>    | <b>WE2</b> | <b>WE1</b> | <b>WE0</b> |
| <b>H</b>                  | x           | x            | x          | x          | x          | x          | H             | H          | H          | H          |
|                           | L           | H            | x          | x          | x          | x          | H             | H          | H          | H          |
| <b>+1</b>                 | <b>L</b>    | L            | x          | x          | 0          | 0          | L             | L          | L          | L          |
|                           | <b>L</b>    | L            | x          | 0          | 0          | 1          | H             | L          | H          | L          |
| <b>+4/+8</b>              | <b>L</b>    | L            | x          | 1          | 0          | 1          | L             | H          | L          | H          |
|                           | <b>L</b>    | L            | 0          | 0          | 1          | x          | H             | H          | H          | L          |
|                           | <b>L</b>    | L            | 0          | 1          | 1          | x          | H             | H          | L          | H          |
|                           | <b>L</b>    | L            | 1          | 0          | 1          | x          | H             | L          | H          | H          |
|                           | <b>L</b>    | L            | 1          | 1          | 1          | x          | L             | H          | H          | H          |



respectively.

Table 7 shows the output condition of the write enable signals WE3-WE0. The four write enable signals can directly control up to four memory banks. The WE output is determined by DRAW, MA0, IM1, and IM0.

### **Video Shifter Shift Load Signals (SLDB, SLDW)**

SLDB and SLDW load timing signals control the timing of display data input from a frame buffer to the video signal generation shift register (parallel-to-serial conversion circuit). SLDB is used for base screen in single access mode, dual access mode 0, and dual access mode 1. SLDW is used for window screens in dual access mode 1.

**Relation of Access Mode and WSS to SLDB and SLDW:** Table 8 shows the relationship between access modes, WSS, and SLDB and SLDW. When WSS=0 in single access or dual access mode 0, SLDB output timing can be varied according to the amount of scrolling for one display cycle. SLDW is not output.

When WSS=0 in dual access mode 1 for the base screen, SLDB output timing can be varied to accommodate smooth scrolling according to the horizontal scroll dot attribute control signals (HSD3-HSD0) supplied by the ACRTC. The

SLDW signal is asserted for one period of the last dot clock during a display cycle. Its output cannot be varied for scrolling.

When WSS=1, for the window in dual access mode 1, SLDB signal is asserted and fixed for one period of the last dot clock of one display cycle, where as SLDW timing can be varied according to scrolling amount in one display cycle.

**Amount of Scrolling and Output Timing :** Figure 8 shows the output timing of the shift load signals (SLDB, SLDW) for different amounts of scrolling. With increased scrolling, the load signal is output earlier by one dot clock.

Figure 9, 10, and 11 show SLDB and SLDW timing for single access, dual access mode 0, and dual access mode 1, respectively. Figure 12, 13, and 14 show SLDB timing for double and triple zooming.

Table 9 shows the attribute codes set for the ACRTC and the corresponding scrolling amounts. Table 10 shows the relationship between the GMIC dot clock division ratios and GVAC shift register lengths in corresponding access modes. Display colors are determined by the shift register length and amount of display data simultaneously read set in the ACRTC's GAI. The single and dual access modes are described in the ACRTC User's Manual, Section 3.2 CRT Interface.

**Table 8. WSS, Access Mode, Shift Load Signals**

| <b>WSS</b> | <b>Access Mode</b>              | <b>SLDB</b>                   | <b>SLDW</b>                   |
|------------|---------------------------------|-------------------------------|-------------------------------|
| 0          | Single access,<br>Dual access 0 | Scrolling amount is permitted | No output                     |
|            | Dual access 1,<br>Base screen   | Scrolling amount is permitted | Scrolling impossible          |
| 1          | Dual access 1,<br>Base screen   | Scrolling impossible          | Scrolling amount is permitted |



**Figure 8. Shift Load (SLDB, SLDW) Output Timing**



**Table 9. ACRTC Attribute Codes and Scrolling Amounts**

| <b>Shift Bit Length</b> | <b>HSD5</b> | <b>HSD4</b> | <b>HSD3</b> | <b>HSD2</b> | <b>HSD1</b> | <b>HSD0</b> | <b>Scroll Dot Count</b> |
|-------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------------------|
| 16 bits                 | x           | x           | 0           | 0           | 0           | 0           | 0                       |
|                         | x           | x           | 0           | 0           | 0           | 1           | 1                       |
|                         | x           | x           | 0           | 0           | 1           | 0           | 2                       |
|                         |             |             |             |             |             |             |                         |
|                         | x           | x           | 1           | 1           | 1           | 0           | 14                      |
|                         | x           | x           | 1           | 1           | 1           | 1           | 15                      |
| 32 bits                 | x           | 0           | 0           | 0           | 0           | 0           | 0                       |
|                         | x           | 0           | 0           | 0           | 0           | 1           | 1                       |
|                         | x           | 0           | 0           | 0           | 1           | 0           | 2                       |
|                         |             |             |             |             |             |             |                         |
|                         | x           | 1           | 1           | 1           | 1           | 0           | 30                      |
|                         | x           | 1           | 1           | 1           | 1           | 1           | 31                      |
| 64 bits                 | 0           | 0           | 0           | 0           | 0           | 0           | 0                       |
|                         | 0           | 0           | 0           | 0           | 0           | 1           | 1                       |
|                         | 0           | 0           | 0           | 0           | 1           | 0           | 2                       |
|                         |             |             |             |             |             |             |                         |
|                         | 1           | 1           | 1           | 1           | 1           | 0           | 62                      |
|                         | 1           | 1           | 1           | 1           | 1           | 1           | 63                      |

Note: The attribute code from the ACRTC supplies HSD3-HSD0, and memory address MA1 and MA0 supply HSD5 and HSD4. If these memory address bits are used (MA1 for 64-bit shifts, MA0 for 32-bit shifts), they must not be changed during one horizontal period.

**Table 10. GMIC Division Ratio and GVAC Shift Lengths**

| <b>Division Ratio</b> | <b>Single Access</b> | <b>Dual Access</b>  |
|-----------------------|----------------------|---------------------|
| Divide by 4           | 8 dot shift          | 16 dot shift        |
| Divide by 8           | 16 dot shift         | 32 dot shift        |
| Divide by 16          | 32 dot shift         | 64 dot shift (note) |

Note: This mode cannot be used directly because the maximum shift register length is 32 dots.





Figure 9. SLDB Timing (Single Access Mode)



Figure 10. SLDB Timing (Dual Access Mode 0)

 **HITACHI**

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

547

Figure 11. SLDB and SLDW Timing (Dual Access Mode 1)



Figure 12. Zoom Display Timing (Single Access Mode, Triple Zoom)



Figure 13. Zoom Display Timing (Dual Access Mode 0, Double Zoom)



Figure 14. Zoom Display Timing (Dual Access Mode 1, Double Zoom)

**Driving Priority Mode :** In the ACRTC drawing priority mode, drawing memory access takes priority over display memory access. In this mode, when display data is provided in the same manner as in the 32-bit shift mode but the system does not enter a display cycle, and a total output of 32 bits is completed, low-level output are provided until the next display cycle.

#### Shift Clock Enable (SCKE)

Shift clock enable (SCKE) is a control signal for the GVAC video signal generation shift register. GVAC drives the shift register on the falling edge of the dot clock. The SCKE control signal decreases the dot clock frequency to set the zoom scale. Figure 15 shows triple zoom (HZ=0011) timing. Table 11 shows attribute codes and corresponding zoom scales.

Table 11. Attribute Codes and Zoom Scales

| HZ3 | HZ2 | HZ1 | HZ0 | Zoom scale |
|-----|-----|-----|-----|------------|
| 0   | 0   | 0   | 0   | 1          |
| 0   | 0   | 0   | 1   | 2          |
| 0   | 0   | 1   | 0   | 3          |
| 0   | 0   | 1   | 1   | 4          |
| 0   | 1   | 0   | 0   | 5          |
| 0   | 1   | 0   | 1   | 6          |
| 0   | 1   | 1   | 0   | 7          |
| 0   | 1   | 1   | 1   | 8          |
| 1   | 0   | 0   | 0   | 9          |
| 1   | 0   | 0   | 1   | 10         |
| 1   | 0   | 1   | 0   | 11         |
| 1   | 0   | 1   | 1   | 12         |
| 1   | 1   | 0   | 0   | 13         |
| 1   | 1   | 0   | 1   | 14         |
| 1   | 1   | 1   | 0   | 15         |
| 1   | 1   | 1   | 1   | 16         |



Figure 15. Triple Zoom Timing



### Attribute Control Signals

The GMIC receives attribute code control signals for horizontal zooming and horizontal smooth scrolling from the ACRTC. Figure 16 shows attribute control output timing, and figure 17 shows the corresponding output pins.

The GMIC can control horizontal smooth scrolling of up to a 63-dot shift. However, the ACRTC outputs a 4-bit code (HSD3-HSD0), directly supporting up to a 15-dot shift. Therefore, the GMIC latches the lower 2 bits of the display address (MA0, MA1) output every display cycle into its internal register in order to control a 63-dot shift.



Figure 16. DRAM Refresh and Attribute Control Data Output (Single Access Mode)





Figure 17. Attribute Control Signal Output Pins

**Absolute Maximum Ratings (All voltages referenced to Vss = 0 V)**

| Item                  | Symbol | Rating             | Unit |
|-----------------------|--------|--------------------|------|
| Supply voltage        | Vcc    | – 0.3 to + 7.0     | V    |
| Input voltage         | Vin    | – 0.3 to Vcc + 0.3 | V    |
| Output voltage        | Vout   | 5.5                | V    |
| Operating temperature | Topr   | 0 to + 70          | °C   |
| Storage temperature   | Tstr   | – 55 to + 150      | °C   |

Notes: Using an LSI beyond its maximum ratings may result in its permanent destruction. LSIs should usually be operated under the recommended operating conditions. Exceeding any of these conditions may adversely affect its reliability.

**Recommended Operating Conditions (All voltages referenced to Vss = 0 V)**

| Item                  | Symbol | Min  | Typ  | Max  | Unit |
|-----------------------|--------|------|------|------|------|
| Supply voltage        | Vcc    | 4.75 | 5.00 | 5.25 | V    |
| Input voltage low     | VIL    | 0    | —    | 0.7  | V    |
| Input voltage high    | VIH    | 2.2  | —    | Vcc  | V    |
| Operating temperature | Topr   | 0    | 25   | 70   | °C   |



## Electrical Characteristics

**DC Characteristics (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0 V, T<sub>a</sub> = 0°C to 70°C unless otherwise noted)**

| Item                         | Symbol                                                          | Min             | Max             | Unit | Test Condition                                         |
|------------------------------|-----------------------------------------------------------------|-----------------|-----------------|------|--------------------------------------------------------|
| Input voltage high           | V <sub>IH</sub>                                                 | 2.2             | V <sub>CC</sub> | V    |                                                        |
| Input voltage low            | V <sub>IL</sub>                                                 | -0.3            | 0.7             | V    |                                                        |
| Input clamp voltage          | V <sub>I</sub>                                                  |                 | -1.5            | V    | V <sub>CC</sub> = 4.75 V,<br>I <sub>in</sub> = -18 mA  |
| Output voltage high          | ADRA-ADRC, SLD <sub>B</sub> ,<br>SLDW, DSPCYC, SCKE,<br>2CLKOUT | V <sub>OH</sub> | 2.7             | V    | V <sub>CC</sub> = 4.75 V,<br>I <sub>OH</sub> = -400 mA |
|                              | WE3-WE0, FA7-FA0,<br>RAS, CAS, OE                               | V <sub>OH</sub> | 2.0             | V    | V <sub>CC</sub> = 4.75 V,<br>I <sub>OH</sub> = -15 mA  |
| Output voltage low           | ADRA-ADRC, SLD <sub>B</sub> ,<br>SLDW, DSPCYC, SCKE<br>2CLKOUT  | V <sub>OL</sub> | 0.5             | V    | V <sub>CC</sub> = 4.75 V,<br>I <sub>OL</sub> = 8 mA    |
|                              | WE3-WE0, FA7-FA0,<br>RAS, CAS, OE                               | V <sub>OL</sub> | 0.5             | V    | V <sub>CC</sub> = 4.75 V,<br>I <sub>OL</sub> = 24 mA   |
| Input current high           | I <sub>IH</sub>                                                 | 20              | μA              |      | V <sub>CC</sub> = 5.25 V,<br>V <sub>I</sub> = 2.7 V    |
| Input current low            | I <sub>IL</sub>                                                 | -400            | μA              |      | V <sub>CC</sub> = 5.25 V,<br>V <sub>I</sub> = 0.4 V    |
| Output short circuit current | I <sub>OS</sub>                                                 | -40             | -120            | mA   | V <sub>CC</sub> = 5.25 V                               |
| Current consumption          | I <sub>CC</sub>                                                 | 160             | mA              |      | V <sub>CC</sub> = 5.25 V                               |
| Input capacitance            | C <sub>in</sub>                                                 | 10              | pF              |      |                                                        |



AC Characteristics ( $V_{CC} = 5.0 \text{ V} \pm 5\%$ ,  $V_{SS} = 0 \text{ V}$ ,  $T_a = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ )

| No | Item                         | Symbol             | 32 MHz               |     | 48 MHz               |     | 64 MHz               |     | Unit | Figure     |
|----|------------------------------|--------------------|----------------------|-----|----------------------|-----|----------------------|-----|------|------------|
|    |                              |                    | Min                  | Max | Min                  | Max | Min                  | Max |      |            |
|    | DOTCK operation frequency    | f                  |                      | 32  |                      | 48  |                      | 64  | MHz  |            |
| ①  | DOTCK cycle time             | t <sub>c</sub>     | 31.3                 |     | 20.8                 |     | 15.6                 |     | ns   | 18         |
| ②  | DOTCK high level pulse width | t <sub>HW</sub>    | 12                   |     | 9                    |     | 6                    |     | ns   |            |
| ③  | DOTCK low level pulse width  | t <sub>LW</sub>    | 12                   |     | 9                    |     | 6                    |     | ns   |            |
| ④  | DOTCK rise time              | t <sub>R</sub>     |                      | 5   |                      | 5   |                      | 5   | ns   |            |
| ⑤  | DOTCK fall time              | t <sub>F</sub>     |                      | 5   |                      | 5   |                      | 5   | ns   |            |
| ⑥  | 2CLKOUT delay                | t <sub>2CLKD</sub> | 24                   |     | 17                   |     | 14                   | ns  |      | 19         |
| ⑦  | MCYC setup time              | t <sub>MCYCS</sub> | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | ns   | 20-23      |
| ⑧  | MCYC hold time               | t <sub>MCYCH</sub> | 0                    |     | 0                    |     | 0                    |     | ns   |            |
| ⑨  | HSYNC setup time             | t <sub>HSS</sub>   | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | ns   | 20-22      |
| ⑩  | HSYNC hold time              | t <sub>HSH</sub>   | 0                    |     | 0                    |     | 0                    |     | ns   | 23         |
| ⑪  | MRD setup time               | t <sub>MRDS</sub>  | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | ns   | 20-22      |
| ⑫  | MRD hold time                | t <sub>MRDH</sub>  | 5                    |     | 5                    |     | 5                    |     | ns   | 20, 21, 23 |
| ⑬  | DRAW setup time              | t <sub>DRAWS</sub> | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | t <sub>c</sub> + 20  |     | ns   | 20-22      |
| ⑭  | DRAW hold time               | t <sub>DRAWH</sub> | 5                    |     | 5                    |     | 5                    |     | ns   | 20, 21, 23 |
| ⑮  | AS setup time (CDM = 01)     | t <sub>ASS</sub>   | t <sub>c</sub> + 25  |     | t <sub>c</sub> + 25  |     | t <sub>c</sub> + 25  |     | ns   | 20-23      |
|    | AS setup time (CMD = 10)     | t <sub>ASS</sub>   | 2t <sub>c</sub> + 25 |     | 2t <sub>c</sub> + 25 |     | 2t <sub>c</sub> + 25 |     | ns   |            |
|    | AS setup time (CDM = 11)     | t <sub>ASS</sub>   | 4t <sub>c</sub> + 25 |     | 4t <sub>c</sub> + 25 |     | 4t <sub>c</sub> + 25 |     | ns   |            |
| ⑯  | AS pulse width               | t <sub>ASW</sub>   | 25                   |     | 25                   |     | 25                   |     | ns   |            |
| ⑰  | Memory address setup time    | t <sub>MAS</sub>   | 10                   |     | 10                   |     | 10                   |     | ns   | 20-23      |
| ⑱  | Memory address hold time     | t <sub>MAH</sub>   | 5                    |     | 5                    |     | 5                    |     | ns   |            |
| ⑲  | Attribute code setup time    | t <sub>ACS</sub>   | 20                   |     | 20                   |     | 20                   |     | ns   | 23         |
| ⑳  | Attribute code hold time     | t <sub>ACH</sub>   | 5                    |     | 5                    |     | 5                    |     | ns   |            |



## AC Characteristics (cont)

| No | Item                                    | Symbol             | 32 MHz      |     | 48 MHz      |     | 64 MHz      |     | Unit | Figure |
|----|-----------------------------------------|--------------------|-------------|-----|-------------|-----|-------------|-----|------|--------|
|    |                                         |                    | Min         | Max | Min         | Max | Min         | Max |      |        |
| ⑪  | RAS setup time<br>(CDM = 01)            | t <sub>RSS</sub>   | tc –<br>20  |     | tc –<br>20  |     | tc –<br>20  |     | ns   | 20-23  |
|    | RAS setup time<br>(CDM = 10)            | t <sub>RSS</sub>   | 2tc –<br>20 |     | 2tc –<br>20 |     | 2tc –<br>20 |     | ns   |        |
|    | RAS setup time<br>(CDM = 11)            | t <sub>RSS</sub>   | 4tc –<br>20 |     | 4tc –<br>20 |     | 4tc –<br>20 |     | ns   |        |
| ⑫  | RAS hold time                           | t <sub>RSH</sub>   | 3           |     | 3           |     | 3           |     | ns   |        |
| ⑬  | CAS delay time<br>(CDM = 01)            | t <sub>CASD</sub>  | tc –<br>7   |     | tc –<br>7   |     | tc –<br>7   |     | ns   | 20, 21 |
|    | CAS delay time<br>(CDM = 10)            | t <sub>CASD</sub>  | 2tc –<br>7  |     | 2tc –<br>7  |     | 2tc –<br>7  |     | ns   |        |
|    | CAS delay time<br>(CDM = 11)            | t <sub>CASD</sub>  | 4tc –<br>7  |     | 4tc –<br>7  |     | 4tc –<br>7  |     | ns   |        |
| ⑭A | CAS delay time<br>from 2CLK             | t <sub>CASDH</sub> |             | 20  |             | 20  |             | 15  | ns   |        |
| ⑯  | CAS hold time                           | t <sub>CASH</sub>  | 3           |     | 3           |     | 3           |     | ns   |        |
| ⑮  | Memory address<br>setup time (CDM = 01) | t <sub>MASC</sub>  | tc +<br>25  |     | tc +<br>25  |     | tc +<br>25  |     | ns   | 20-23  |
|    | Memory address<br>setup time (CDM = 10) | t <sub>MASC</sub>  | 2tc +<br>25 |     | 2tc +<br>25 |     | 2tc +<br>25 |     | ns   |        |
|    | Memory address<br>setup time (CDM = 11) | t <sub>MASC</sub>  | 4tc +<br>25 |     | 4tc +<br>25 |     | 4tc +<br>25 |     | ns   |        |
| ⑯  | Row address<br>setup time               | t <sub>RA</sub>    | 0           |     | 0           |     | 0           |     | ns   |        |
| ⑰  | Row address hold time<br>(CDM = 01)     | t <sub>RAH</sub>   | tc/2<br>– 2 |     | tc/2<br>– 2 |     | tc/2<br>– 2 |     | ns   |        |
|    | Row address hold time<br>(CDM = 10)     | t <sub>RAH</sub>   | tc<br>– 2   |     | tc<br>– 2   |     | tc<br>– 2   |     | ns   |        |
|    | Row address hold time<br>(CDM = 11)     | t <sub>RAH</sub>   | 2tc<br>– 2  |     | 2tc<br>– 2  |     | 2tc<br>– 2  |     | ns   |        |
| ⑱  | Column address<br>setup time            | t <sub>CAS</sub>   | 0           |     | 0           |     | 0           |     | ns   | 20, 21 |
| ⑲  | Column address<br>hold time             | t <sub>CAH</sub>   | 0           |     | 0           |     | 0           |     | ns   |        |

**AC Characteristics (cont)**

| No | Item                        | Symbol | 32 MHz |     | 48 MHz |     | 64 MHz |     | Unit | Figure |
|----|-----------------------------|--------|--------|-----|--------|-----|--------|-----|------|--------|
|    |                             |        | Min    | Max | Min    | Max | Min    | Max |      |        |
| ⑩  | OE delay time               | toED   |        | 20  |        | 20  |        | 20  | ns   | 20     |
| ⑪  | OE hold time                | toEH   | 3      |     | 3      |     | 3      |     | ns   |        |
| ⑫  | WE delay time               | tWED   | 5      | 30  | 5      | 30  | 5      | 30  | ns   | 21     |
| ⑬  | WE hold time                | tWEH   | 3      |     | 3      |     | 3      |     | ns   |        |
| ⑭  | Address delay time          | tAD    |        | 30  |        | 30  |        | 30  | ns   |        |
| ⑮  | Address hold time           | tAH    | 0      |     | 0      |     | 0      |     | ns   |        |
| ⑯  | SCKE delay time             | tsCKD  | 3      | 22  | 3      | 15  | 3      | 12  | ns   | 18     |
| ⑰  | SLD delay time              | tsLDD  | 5      | 24  | 5      | 17  | 5      | 17  | ns   |        |
| ⑱  | DSPCYC delay time from AS   | tpSPDA |        | 40  |        | 40  |        | 40  | ns   | 20     |
| ⑲A | DSPCYC delay time from DRAW | tpSPDD |        | 20  |        | 20  |        | 20  | ns   |        |
| ⑲  | DSPCYC hold time            | tpSPH  | 5      |     | 5      |     | 5      |     | ns   |        |





Figure 18. Clock



Figure 19. 2CLKOUT





**Figure 20. Memory Read Cycle (Drawing Read and Display)**



Figure 21. Memory Write Cycle



Figure 22. Refresh Cycle



Figure 23. Attribute Cycle





| Signal                             | CL(pF) |
|------------------------------------|--------|
| $\overline{SLDB}, \overline{SLDW}$ | 40     |
| SCKE                               | 40     |
| 2CLKOUT                            | 40     |
| $\overline{RAS}$                   | 240    |
| $\overline{CAS}$                   | 240    |
| $\overline{OE}$                    | 240    |
| $WE0 \sim WE3$                     | 120    |
| FA0 ~ FA7                          | 160    |
| ADRA ~ ADRC                        | 120    |
| DSPCYC                             | 40     |

Note: All diodes are 1S2074's or the equivalent

Figure 24. Test Load Circuit



Figure 25. Input/Output waveforms



## Package Dimensions

Unit: mm(inches)

DP-64S



CP-68



Note) Inch valve indicated for your reference.

 HITACHI

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

565

**Reference Literature**

| <b>Product</b> | <b>Data Sheet</b> | <b>User's Manual</b> | <b>Application Note</b>                                                 | <b>Others</b> |
|----------------|-------------------|----------------------|-------------------------------------------------------------------------|---------------|
| HD63484 ACRTC  | ID #U149          | ID #U75              | Introduction to ACRTC<br>Applications, Circuits<br>and Software ID #U90 | —             |
| HD63486 GVAC   | ID #U176          | —                    | —                                                                       | —             |



# HD63486

---

## Graphic Video Attribute Controller (Hi-Bi CMOS)

### Description

The HD63486 LSI belongs to the ACRTC (Advanced CRT Controller) family. It converts frame buffer data to serial video signals. It contains a shift register for parallel-to-serial conversion and the peripheral video control circuits necessary to generate high-speed video signals.

The programmable bit length of the shift register makes the GVAC suitable for multicolor graphics and monochrome grey scale applications. Additionally, multiple GVAC's can be operated in parallel to further expand the field of applications. The GVAC's functions include horizontal smooth scrolling and horizontal zoom using control signals from the GMIC (Graphic Memory Interface Controller). Using the Hi-BiCMOS™ process, the HD63486 achieves high-speed video signal generation with low power dissipation.

### Type of Products

| Part No.     | Speed  | Package                               |
|--------------|--------|---------------------------------------|
| HD63486PS-32 | 32 MHz | 64-pin Plastic Shrink DIP<br>(DP-64S) |
| HD63486PS-48 | 48 MHz |                                       |
| HD63486PS-64 | 64 MHz |                                       |
| HD63486CP-32 | 32 MHz | 68-pin PLCC<br>(CP-68)                |
| HD63486CP-48 | 48 MHz |                                       |
| HD63486CP-64 | 64 MHz |                                       |

### Features

- Internal shift register for video signal control, programmable as :
  - Four 8-bit shift registers
  - Two 16-bit shift registers
  - One 32-bit shift register
- High speed video signal generation (64 MHz dot rate)
- Multiple GVAC parallel operation
- Internal bidirectional data bus buffer for frame buffers
- Zooming and horizontal smooth scrolling (requires GMIC signals or equivalent)
- Direct ACRTC interface
- TTL-compatible input/output
- Single + 5 V power supply
- Low power dissipation



## Pin Description

Figure 1 shows the pin arrangement for the 64-pin plastic shrink-type DIP and the 68-pin PLCC packages. Table 1 describes the pins.



Figure 1. Pin Arrangement

## Power Supply (Vcc, Vss)

V<sub>ss</sub> and V<sub>cc</sub> are the GVAC power supply pins. V<sub>cc</sub> pins are + 5 V ± 5% supply pins. V<sub>ss</sub> are the ground pins. Be sure to connect all four V<sub>ss</sub> pins to ground and both V<sub>cc</sub> pins to the power supply.

## ACRTC Signals

**Clock (2CLK):** The 2CLK input must be the same as the 2CLK input to the ACRTC. It is usually supplied by the GMIC 2CLKOUT output. 2CLK is used for data transfer between the ACRTC and frame buffers and as a timing signal for display data input.

**Memory Cycle (MCYC):** The MCYC input specifies frame buffer access by the ACRTC. It must be low when the ACRTC is in address cycle, and high when the ACRTC is in data cycle. MCYC controls the data buffers. It is usually supplied by the ACRTC's MCYC output.

**Memory Read (MRD):** The MRD input controls the direction of transfers between the ACRTC and

frame buffers. When MRD is high, the GVACs transfer data from the frame buffers to the ACRTC. When MRD is low, the GVACs transfer data from the ACRTC to the frame buffers. MRD must be held high during a display read data cycle. Only during a display cycle for superimposed screen data (dual access mode 1) does the ACRTC input MRD low. This signal is usually supplied by the MRD output.

**Display (DISP):** The  $\overline{\text{DISP}}$  input is a composite signal indicating the screen's horizontal and vertical display period. Display timing output (DISPI) is input when the ACRTC's DSP (display signal control) bit is set to 1. For superimposed display (dual access mode 1),  $\overline{\text{DISP1}}$  must be input to a GVAC for background screens, while  $\overline{\text{DISP2}}$  must be input the window screen from the ACRTC.

**Data Bus (D<sub>7</sub>-D<sub>0</sub>):** D<sub>7</sub>-D<sub>0</sub> are the 8-bit data input/output for data transfer between the ACRTC and frame buffers. Usually, D<sub>7</sub>-D<sub>0</sub> are connected to 8 bits of the memory address data bus (MAD<sub>15</sub>-MAD<sub>0</sub>) according to the operation mode selected by the MOD1, MOD0 inputs.

Table 1. Pin Description

| Pin Number                            |                           |                           |     |                    |
|---------------------------------------|---------------------------|---------------------------|-----|--------------------|
| Signal                                | DIP-64                    | PLCC-68                   | I/O | Description        |
| Vcc                                   | 32, 64                    | 34, 68                    |     | +5 V power supply  |
| Vss                                   | 16, 17,<br>48, 49         | 17, 18,<br>51, 52         |     | Ground             |
| 2CLK                                  | 4                         | 5                         | I   | Clock              |
| MCYC                                  | 3                         | 4                         | I   | Memory Cycle       |
| MRD                                   | 1                         | 2                         | I   | Memory Read        |
| DISP                                  | 24                        | 26                        | I   | Display            |
| D <sub>7</sub> -D <sub>0</sub>        | 15-8                      | 16-9                      | I/O | Data Bus           |
| MOD1,<br>MOD0                         | 28, 27                    | 30, 29                    | I   | Operation Mode     |
| AM                                    | 22                        | 24                        | I   | Access Mode        |
| DSPCYC                                | 2                         | 3                         | I   | Display Cycle      |
| SEL2-<br>SELO                         | 7-5                       | 8-6                       | I   | Select             |
| SCKE                                  | 25                        | 27                        | I   | Shift Clock Enable |
| SLD                                   | 26                        | 28                        | I   | Shift Load         |
| FD <sub>31</sub> -<br>FD <sub>0</sub> | 29-31,<br>33-47,<br>50-63 | 31-33,<br>36-50,<br>54-67 | I/O | Frame Buffer Data  |
| DOTCK                                 | 23                        | 25                        | I   | Dot Clock          |
| VIDEOA-<br>VIDEOB                     | 21-18                     | 23-20                     | O   | Video Outputs      |



**Operation Mode (MOD1, MOD0):** The MOD1 and MOD0 inputs specify the length of the GVAC's internal video signal shift register and the operation mode for the control data bus data multiplexing between the ACRTC and the frame buffers. The operation mode setting is closely related to the ACRTC's graphic address increment mode (GAI), the graphic bit mode (GBM) which specifies the number of bits per pixel, and the frame buffer's access mode (ACM). These settings determine the shift length of one display cycle, and thus the settings for MOD1 and MOD0. The GMIC's clock division mode (CDM1, CDM0) is also related to MOD1 and MOD0. Table 2 shows how GVAC's operation mode is related to the ACRTC and GMIC settings. Other settings are allowed in a graphic system with ACRTC, GMIC, GVAC, and additional circuits. For a description of GBM, GAI, and ACM, see the ACRTC User's Manual. For a description of CDM and DAM, see the GMIC Data Sheet.

**Access Mode (AM):** The AM input sets the GVACs to superimposed display mode. When the ACRTC's access mode (ACM) set to dual access mode 1 (11), AM switches between two GVACs for background and superimposed screens. In single access mode and dual access mode 0, AM must be set low. In dual access mode 1, AM should be set low for a background screen GVAC, and high for a superimposed screen GVAC.

### GMIC Interface Signals

**Display Cycle (DSPCYC):** The DSPCYC input indicates whether a display cycle has been entered. DSPCYC set low signifies a nondisplay cycle, during which data is transferred between frame buffers and the ACRTC. DSPCYC set high indicates a display cycle, during which data from the frame buffers is transferred to the GVACs. The display cycle signal (DSPCYC) output from the GMIC is used for this input.

**Select (SEL2-SEL0):** The SEL2-SEL0 inputs are the lower three bits of the address specifying a particular word is the frame buffers to be transferred to the ACRTC. Since SEL2-SEL0 control the address bus connection between frame buffers and the ACRTC, it must be valid during a data cycle when MCYC is set high. The address outputs (ADRA-ADR<sub>C</sub>) from the GMIC usually supply these signals.

**Shift Clock Enable (SCKE):** The SCKE input specifies the timing for driving the GVAC's parallel-to-serial converter (shift register) for generating video signals (VIDEOA-VIDEOD). The GVAC's perform serial-to-parallel conversion by shifting one bit of display data every shift clock cycle. Using SCKE, the GVACs generate a lower frequency shift clock. Extending one shift clock cycle this way allows zooming. The SCKE output from the GMIC supplies this input.

Table 2. Operation Mode and GVAC, ACRTC, and GMIC Settings

| GVAC | ACRTC      |             |            | GMIC       |            | Bits/<br>Pixel | Shift<br>Length | Max Dot<br>Rate(MHz) |
|------|------------|-------------|------------|------------|------------|----------------|-----------------|----------------------|
|      | MOD<br>0 1 | GBM<br>1098 | GAI<br>654 | ACM<br>3 2 | CDM<br>1 0 |                |                 |                      |
| 0 0  | 0 1 0      | 0 1 0       | 0 0        |            | 1 0 0      | 4              | 16              | 64                   |
|      |            |             | 0 1        |            |            |                |                 |                      |
|      |            |             | 1 0        |            | 0 1 1      |                |                 |                      |
|      |            |             | 1 1        |            |            |                |                 |                      |
| 0 1  | 0 1 0      | 0 1 1       | 0 0        |            | 1 1 0      | 4              | 32              | 64                   |
|      |            |             | 0 1        |            |            |                |                 |                      |
|      |            |             | 1 0        |            | 1 0 1      |                |                 |                      |
|      |            |             | 1 1        |            |            |                |                 |                      |
| 1 0  | 0 1 1      | 0 1 0       | 0 0        |            | 0 1 0      | 8              | 8               | 64                   |
|      |            |             | 0 1        |            |            |                |                 |                      |
| 1 1  | 0 1 1      | 0 1 1       | 0 0        |            | 1 0 0      | 8              | 16              | 32                   |
|      |            |             | 0 1        |            |            |                |                 |                      |
|      |            |             | 1 0        |            | 0 1 1      |                |                 |                      |
|      |            |             | 1 1        |            |            |                |                 |                      |



For systems with a superimpose function, SCKE must be held high for the superimposed window's GVAC (AM input high).

**Shift Load (SLD):** The  $\overline{SLD}$  input specifies the timing in which display data temporarily stored in the GVACs is supplied to the shift register. SLD is asserted for one period of the dot clock. Horizontal scrolling is implemented by shifting  $\overline{SLD}$  on a dot clock basis during a single display cycle. SLD must be asserted once during each display cycle (shift length). SLD is usually input from the GMIC SLDB output for background screen GVACs (AM input low), and  $\overline{SLDW}$  for window screen GVACs (AM input high).

#### Frame Buffer Data (FD<sub>31</sub>-FD<sub>0</sub>)

The 32-bit FD<sub>31</sub>-FD<sub>0</sub> frame buffer data I/O bus transfers data between the ACRTC and frame buffers and inputs display data from the frame

buffers. The 32 bits are read simultaneously from the frame buffer, and FD<sub>31</sub>-FD<sub>0</sub> can be directly connected to the frame buffer data I/O pins.

#### CRT Display Interface

**Dot Clock (DOTCK):** The DOTCK input is the basic video signal generating clock. The DOTCK frequency is determined by the CRT horizontal resolution (pixel count) and the horizontal scan display period. This clock is usually the same signal applied to the GMIC DOTCK input.

**Video Outputs (VIDEOA-VIDEOD):** VIDEOA-VIDEOD are the four bits output from the GVAC's parallel-to-serial conversion shift register. They are supplied during a display period specified by the display signal ( $\overline{DISP}$ ). Which outputs are usable depends on the operation mode (MOD1, MOD0) input. Table 3 shows the usable video signals and corresponding MOD1 and MOD0 signals.

**Table 3. Operation Mode and Video Outputs**

| Mode |      | Video Output |           |           |           | Bits/<br>Pixel |    | Shift Length |
|------|------|--------------|-----------|-----------|-----------|----------------|----|--------------|
| MOD1 | MODO | VIDEOA       | VIDEOB    | VIDEOC    | VIDEOD    |                |    |              |
| 0    | 0    | Avail        | Not avail | Avail     | Not avail | 4              | 16 |              |
| 0    | 1    | Avail        | Not avail | Not avail | Not avail | 4              | 32 |              |
| 1    | 0    | Avail        | Avail     | Avail     | Avail     | 8              | 8  |              |
| 1    | 1    | Avail        | Not avail | Avail     | Not avail | 8              | 16 |              |



## Functional Description

Figure 2 is a block diagram of the GVAC.



Figure 2. GVAC Block Diagram



## Frame Memory Data Buffer

The 32-bit bidirectional frame memory data buffer consists of input and output buffers to transfer data to and from the frame buffers in response to data transfer requests from the ACRTC.

The three-state output buffer is enabled only during a memory write cycle by memory cycle (MCYC) and memory read (MRD) signals from the ACRTC, and display cycle (DSPCYC) from the GMIC. A 32-bit output buffer to be enabled is selected by select signals (SEL2-SEL0) from the GMIC and the operation mode (MOD1, MOD0) set externally.

The input buffer reads data from the frame buffers.

## Data Buffers

The 8-bit input/output buffer transfers data between the ACRTC and frame buffers.

The output buffer is a three-state buffer which is enabled during a frame buffer read cycle by memory cycle (MCYC) and memory read (MRD) signals from the ACRTC, and display cycle (DSPCYC) from the GMIC.

The input buffer supplies drawing data from the ACRTC to the frame buffers.

## Data Multiplexer

The data multiplexer is a direct connection between the frame buffers and the data buffer's data bus which leads to the ACRTC's and frame buffer's data bus. The bus connection is controlled

by select signals (SEL2-SEL0) and the operation mode (MOD1, MOD0) set externally to enable transfer between the ACRTC and frame buffers.

## Latch

The latch recognizes a display data read cycle by memory cycle (MCYC) and memory read (MRD) signals from the ACRTC, and clock (2CLK) and display cycle (DSPCYC) from the GMIC, and the access mode (AM) input. During a display data read cycle, the latch temporarily stores 32-bit display data input from a frame memory data buffer. It sends the stored data to the shift register for parallel-to-serial conversion.

## Shift Register

The 32-bit shift register performs parallel-to-serial conversion on display data stored in the latch to provide video signal output. When the latch receives the shift load (SLDB, SLDW) and shift clock enable (SCKE) signals from the GMIC, it feeds the display data it has stored to the shift register. The shift register supplies one bit of display data every dot clock cycle while SCKE is asserted. When the ACRTC's display cycle signal (DISP) is negated, the shift register does not output a video signal.

When the GMIC shifts the timing of the shift load (SLDB, SLDW) output on a dot clock basis, the GVAC performs horizontal smooth scrolling. When the GMIC extends the shift clock enable signal (SCKE) based on the dot clock, it performs horizontal zoom.



## System Description

### Applications

The GVAC internal circuits perform three major functions :

- Converting parallel display data read from the frame buffers by the ACRTC to serial from and delivering them to the CRT as video signals
- Transferring data between the ACRTC and frame buffers
- Zooming and horizontal smooth scrolling according to signals from the GMIC

Furthermore, the GVACs' operation mode can be set according to the ACRTC's operation mode by the program input signals. This programmability makes the GVAC suitable for a wide range of applications, from slow, small systems to fast, large systems. It also permits the GVACs to accommodate system specification changes.

Figure 3 shows a graphic system configuration using an ACRTC, GMIC and GVACs. With the GMIC used for interfacing with frame buffers and the GVACs generating the video signals, a flexible, high-performance graphic system is constructed with a minimum number of parts.

### System Configuration

The system example in figure 3 uses two GVACs, but the number of GVACs can be varied to meet different CRT resolution and color per pixel (or grey scale) applications.

The GVACs recognize a display data read cycle by decoding ACRTC output signals such as memory cycle (MCYC) and memory read (MRD) and GMIC output signals such as display cycle (DSPCYC). In the display data read cycle, the GVACs latch display data from the frame buffers. They pass the display data to the internal shift register for parallel-to-serial conversion when they receive the shift load signal (SLDB or SLDW) from the GMIC. The GVACs perform successive parallel-to-serial conversion synchronously with the dot clock when they receive the shift clock enable (SCKE) output from the GMIC. This generates the video signals.

A GVAC can receive 32-bit display data ( $FD_{31}-FD_0$ ) from one frame buffer. Furthermore, it provides a connection from the ACRTC's data bus ( $D_7-D_0$ ) to the frame buffers data bus ( $FD_{31}-FD_0$ ), enabling direct data transfer between the two. The GVACs also implement horizontal smooth scrolling and zooming, controlled by the shift load (SLDB, SLDW) and shift clock enable (SCKE) signals from the GMIC.



Figure 3. System Application Example



## Operation

### Data Transfer

The GVACs contain control circuits for bidirectional transfer between the ACRTC and frame buffers. To transfer data, the GVACs receive the ACRTC's memory cycle (MCYC) and memory read (MRD) signals, and the GMIC's display cycle (DSPCYC). From these signals, the GVACs recognize a drawing data transfer cycle. Connection between the ACRTC's data bus and the frame buffer's data bus is controlled by the select signals (SEL2-SEL0) from the GMIC and the operation mode (MOD1, MOD0) inputs.

The GVACs recognize a nondisplay cycle when DSPCYC is low. In nondisplay cycles, the data transfer direction is determined by the memory read signal (MRD). MRD high signifies a read cycle to transfer data from frame buffers to the ACRTC. MRD low signifies a write cycle to transfer data from the ACRTC to the frame buffers. Timing for the data transfer is determined by the

MCYC input. When MCYC is high, frame buffers or the ACRTC three-state output buffers are enabled for transfer.

**Drawing Write Cycle :** The GVACs recognize a drawing write cycle when both DSPCYC and MRD are low. Figure 4 shows the timing for a drawing write cycle.

When MCYC is high during this cycle, the GVACs enable the frame memory data buffer, and output data from the ACRTC one word at a time to the frame buffers, based on the operation mode (MOD1, MOD0) inputs and the select signals (SEL2-SEL0) from the GMIC. Table 4 shows the connections between FD and D pins when MOD1 and MOD0 are set to 00. When SEL2-SEL0 are set to 000 D<sub>0</sub>-D<sub>3</sub> from the ACRTC are output to FD<sub>0</sub>-FD<sub>3</sub>, D<sub>4</sub>-D<sub>7</sub> are output to FD<sub>16</sub>-FD<sub>19</sub>, and the other FD pins are high-impedance. Table 5-7 show the relation of D to FD in other modes.



**Figure 4. Drawing Write Cycle**  
(ACRTC [MAD] → [D] GVAC [FD] → Frame buffers)



**Table 4. Connection Between D and FD Pins, Drawing Cycle, MOD1, MOD0 = 00 (4 Bits/Pixel, 16-Bit Shift Mode)**

| <b>SEL2-SELO</b> | <b>D0</b>        | <b>D1</b>        | <b>D2</b>        | <b>D3</b>        | <b>D4</b>        | <b>D5</b>        | <b>D6</b>        | <b>D7</b>        |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| 000              | FD <sub>0</sub>  | FD <sub>1</sub>  | FD <sub>2</sub>  | FD <sub>3</sub>  | FD <sub>16</sub> | FD <sub>17</sub> | FD <sub>18</sub> | FD <sub>19</sub> |
| 001              | FD <sub>4</sub>  | FD <sub>5</sub>  | FD <sub>6</sub>  | FD <sub>7</sub>  | FD <sub>20</sub> | FD <sub>21</sub> | FD <sub>22</sub> | FD <sub>23</sub> |
| 010              | FD <sub>8</sub>  | FD <sub>9</sub>  | FD <sub>10</sub> | FD <sub>11</sub> | FD <sub>24</sub> | FD <sub>25</sub> | FD <sub>26</sub> | FD <sub>27</sub> |
| 011              | FD <sub>12</sub> | FD <sub>13</sub> | FD <sub>14</sub> | FD <sub>15</sub> | FD <sub>28</sub> | FD <sub>29</sub> | FD <sub>30</sub> | FD <sub>31</sub> |
| 100-111          |                  |                  |                  |                  | Not used         |                  |                  |                  |

Note: All other FD pins high impedance.

**Table 5. Connection Between D and FD Pins, Drawing Cycle, MOD1, MOD0 = 01 (4 Bits/Pixel, 32-Bit Shift Mode)**

| <b>SEL2-SELO</b> | <b>D0</b>        | <b>D1</b>        | <b>D2</b>        | <b>D3</b>        | <b>D4</b> | <b>D5</b> | <b>D6</b> | <b>D7</b> |
|------------------|------------------|------------------|------------------|------------------|-----------|-----------|-----------|-----------|
| 000              | FD <sub>0</sub>  | FD <sub>1</sub>  | FD <sub>2</sub>  | FD <sub>3</sub>  | NC        | NC        | NC        | NC        |
| 001              | FD <sub>4</sub>  | FD <sub>5</sub>  | FD <sub>6</sub>  | FD <sub>7</sub>  | NC        | NC        | NC        | NC        |
| 010              | FD <sub>8</sub>  | FD <sub>9</sub>  | FD <sub>10</sub> | FD <sub>11</sub> | NC        | NC        | NC        | NC        |
| 011              | FD <sub>12</sub> | FD <sub>13</sub> | FD <sub>14</sub> | FD <sub>15</sub> | NC        | NC        | NC        | NC        |
| 100              | FD <sub>16</sub> | FD <sub>17</sub> | FD <sub>18</sub> | FD <sub>19</sub> | NC        | NC        | NC        | NC        |
| 101              | FD <sub>20</sub> | FD <sub>21</sub> | FD <sub>22</sub> | FD <sub>23</sub> | NC        | NC        | NC        | NC        |
| 110              | FD <sub>24</sub> | FD <sub>25</sub> | FD <sub>26</sub> | FD <sub>27</sub> | NC        | NC        | NC        | NC        |
| 111              | FD <sub>28</sub> | FD <sub>29</sub> | FD <sub>30</sub> | FD <sub>31</sub> | NC        | NC        | NC        | NC        |

Note: All other FD pins high impedance.

NC = No connection

**Table 6. Connection Between D and FD Pins, Drawing Cycle, MOD1, MOD0 = 10 (8 Bits/Pixel, 8-Bit Shift Mode)**

| <b>SEL2-SELO</b> | <b>D0</b>       | <b>D1</b>       | <b>D2</b>        | <b>D3</b>        | <b>D4</b>        | <b>D5</b>        | <b>D6</b>        | <b>D7</b>        |
|------------------|-----------------|-----------------|------------------|------------------|------------------|------------------|------------------|------------------|
| 000              | FD <sub>0</sub> | FD <sub>1</sub> | FD <sub>8</sub>  | FD <sub>9</sub>  | FD <sub>16</sub> | FD <sub>17</sub> | FD <sub>24</sub> | FD <sub>25</sub> |
| 001              | FD <sub>2</sub> | FD <sub>3</sub> | FD <sub>10</sub> | FD <sub>11</sub> | FD <sub>18</sub> | FD <sub>19</sub> | FD <sub>26</sub> | FD <sub>27</sub> |
| 010              | FD <sub>4</sub> | FD <sub>5</sub> | FD <sub>12</sub> | FD <sub>13</sub> | FD <sub>20</sub> | FD <sub>21</sub> | FD <sub>28</sub> | FD <sub>29</sub> |
| 011              | FD <sub>6</sub> | FD <sub>7</sub> | FD <sub>14</sub> | FD <sub>15</sub> | FD <sub>22</sub> | FD <sub>23</sub> | FD <sub>30</sub> | FD <sub>31</sub> |
| 100-111          |                 |                 |                  |                  | Not used         |                  |                  |                  |

Note: All other FD pins high impedance.

**Table 7. Connection Between D and FD Pins, Drawing Cycle, MOD, MOD = 11 (8 Bits/Pixel, 16-Bit Shift Mode)**

| <b>SEL2-SELO</b> | <b>D0</b>        | <b>D1</b>        | <b>D2</b> | <b>D3</b> | <b>D4</b>        | <b>D5</b>        | <b>D6</b> | <b>D7</b> |
|------------------|------------------|------------------|-----------|-----------|------------------|------------------|-----------|-----------|
| 000              | FD <sub>0</sub>  | FD <sub>1</sub>  | NC        | NC        | FD <sub>16</sub> | FD <sub>17</sub> | NC        | NC        |
| 001              | FD <sub>2</sub>  | FD <sub>3</sub>  | NC        | NC        | FD <sub>18</sub> | FD <sub>19</sub> | NC        | NC        |
| 010              | FD <sub>4</sub>  | FD <sub>5</sub>  | NC        | NC        | FD <sub>20</sub> | FD <sub>21</sub> | NC        | NC        |
| 011              | FD <sub>6</sub>  | FD <sub>7</sub>  | NC        | NC        | FD <sub>22</sub> | FD <sub>23</sub> | NC        | NC        |
| 100              | FD <sub>8</sub>  | FD <sub>9</sub>  | NC        | NC        | FD <sub>24</sub> | FD <sub>25</sub> | NC        | NC        |
| 101              | FD <sub>10</sub> | FD <sub>11</sub> | NC        | NC        | FD <sub>26</sub> | FD <sub>27</sub> | NC        | NC        |
| 110              | FD <sub>12</sub> | FD <sub>13</sub> | NC        | NC        | FD <sub>28</sub> | FD <sub>29</sub> | NC        | NC        |
| 111              | FD <sub>14</sub> | FD <sub>15</sub> | NC        | NC        | FD <sub>30</sub> | FD <sub>31</sub> | NC        | NC        |

Note: All other FD pins high impedance.

NC = No connection



**Drawing Read Cycle :** The GVACs recognize a drawing read cycle when DSPCYC is low and MRD is high. Figure 5 shows the timing for a drawing read cycle.

When MCYC is high during this cycle, the GVACs enable the data buffer ( $D_7-D_0$ ) for the ACRTC and output a word from the frame buffers selected by the operation mode (MOD1, MOD0) inputs and the select signals (SEL2-SEL0) from the GMIC. Table 4 shows the connections between FD and D pins when MOD1 and MOD0 are set to 00. When SEL2-SEL0 are set to 000, data from  $FD_0-FD_3$  from the ACRTC are output to  $D_0-D_3$ , data from  $FD_{16}-FD_{19}$  are output to  $D_4-D_7$ , and the other FD pins cannot

be used. Table 5-7 show the relation of D to FD in other modes. D pins which are not connected (NC) must be held high by pull-up resistors.

### GVAC Connections

The GVACs allow three shift modes to be selected externally through the operation mode pins (MOD1, MOD0). The number of GVACs used is determined by the selected shift mode, graphic bit mode (GBM) which sets ACRTC bits per pixel, and graphic address increment mode (GAI) which sets the number of display data bit read from the frame buffers simultaneously (Table 8).



**Figure 5. Drawing Read Cycle**  
(Frame buffer → [FD] GVAC [D] → ACRTC [MAD])



Table 8. Number of GVAC's

| A C R T C     |              | G V A C      |                |               |              |                 |                    |
|---------------|--------------|--------------|----------------|---------------|--------------|-----------------|--------------------|
| G B M<br>1098 | G A I<br>654 | M O D<br>1 0 | Bits/<br>Pixel | Words<br>Read | Bits<br>Read | Shift<br>Length | Number of<br>GVACs |
| 0 0 0         | 0 0 0        | 0 0          | 1              | 1             | 16           | 16              | 1 (2)*             |
|               | 0 0 1        | 0 1          | 1              | 2             | 32           | 32              | 2 (4)*             |
| 0 0 1         | 0 0 0        | 1 0          | 2              | 1             | 16           | 8               | 1 (2)*             |
|               | 0 0 1        | 0 0          | 2              | 2             | 32           | 16              | 1 (2)*             |
|               | 0 1 0        | 0 1          | 2              | 4             | 64           | 32              | 2 (4)*             |
| 0 1 0         | 0 0 1        | 1 0          | 4              | 2             | 32           | 8               | 1 (2)*             |
|               | 0 1 0        | 0 0          | 4              | 4             | 64           | 16              | 2 (4)              |
|               | 0 1 1        | 0 1          | 4              | 8             | 128          | 32              | 4 (8)              |
| 0 1 1         | 0 1 0        | 1 0          | 8              | 4             | 64           | 8               | 2 (4)              |
|               | 0 1 1        | 1 1          | 8              | 8             | 128          | 16              | 4 (8)              |
| 1 0 0         | 0 1 1        | 1 0          | 16             | 8             | 128          | 8               | 4 (8)*             |

Notes: 1. \*Indicates that data transfers between frame buffers and the ACRTC requires external circuits since the GVACs to ACRTC data transfer function cannot be used directly.

2. Parenthesized values are the number of GVACs required for superimpose mode (dual access mode 1) applications.



Figure 6. FD Pin Connection (MOD1, MOD0 = 00)



## Data Connections

Figure 6 illustrates the data pin connection with MOD1, MOD0 set to 00. In this mode, one pixel consists of 4 bits, and four words (64 bits) are read from the frame buffers at one time.

### ACRTC and GVAC Connection

**ACRTC Display Data Bit Configuration :** The ACRTC handles display data on a pixel basis, the ACRTC's minimum unit. The ACRTC transfers data on a word (16-bit) basis. One memory word can consist of one or more pixels. The ACRTC's graphic bit mode (GBM) selects one of five types of pixel count. The GVAC's directly support data transfers of 4 bits or 8 bits per pixel. In 4 bit/pixel mode, 16 colors or shades of grey can be implemented at one time. In 8 bit/pixel mode, 256 colors or 256 shades of grey can be realized. Figure 7 shows pixel data processed by the ACRTC depending on operation mode pin 1 (MOD1). For details on the graphic bit mode, see the ACRTC User's Manual, 5.5.6 Graphic Bit Mode.

**GVAC and Graphic Data:** The GVAC's must be connected to handle data on a one-pixel bit plane basis. Table 9 shows the relationship between operation mode 1 (MOD1), pixel number, bit plane number, and ACRTC data.

**Connection Between GVACs and ACRTC :** The connection to the ACRTC depends on the operation mode (MOD1, MOD0). Table 10 shows the connection with MOD1, MOD0 = 00. In this mode, each pixel is four bits. GVAC1 handles bit planes 0 and 1, and GVAC2 handles bit planes 2 and 3. The connection between the ACRTC and GVAC's is determined by bit plane number and pixel number for one word from the ACRTC. In Table 9, for example, ACRTC pin MAD0 corresponds to bit plane 0 for pixel number 0. From table 10, therefore, bit plane number 0 for GVAC1 is connected to pin D<sub>0</sub> for pixel number 1. Connection to the ACRTC in other modes are shown in Table 11-13.

Table 9. Pixel Number and Plane Number

|      |  | MAD           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|--|---------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| MOD1 |  | ACRTC         | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0    |  | Pixel No.     | 3  |    | 2  |    | 1  |    | 0 |   | 1 |   | 0 |   | 0 |   | 0 |   |
|      |  | Bit Plane No. | 3  | 2  | 1  | 0  | 3  | 2  | 1 | 0 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |
| 1    |  | Pixel No.     | 1  |    | 0  |    | 0  |    | 0 |   | 0 |   | 0 |   | 0 |   | 0 |   |
|      |  | Bit Plane No. | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |



Figure 7. Pixel Data and MOD1



**Table 10. ACRTC and GVAC Pin Connection, MOD1, MOD0 = 00 (4 Bits/Pixel, 16-Bit Shift Mode)**

| Connection     | MAD            |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|                | 15             | 14             | 13             | 12             | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
| Pin Connection | D <sub>7</sub> | D <sub>3</sub> | D <sub>7</sub> | D <sub>3</sub> | D <sub>6</sub> | D <sub>6</sub> | D <sub>6</sub> | D <sub>2</sub> | D <sub>5</sub> | D <sub>1</sub> | D <sub>5</sub> | D <sub>1</sub> | D <sub>4</sub> | D <sub>0</sub> | D <sub>4</sub> | D <sub>0</sub> |
| GVAC           | 2              | 2              | 1              | 1              | 2              | 2              | 1              | 1              | 2              | 2              | 1              | 1              | 2              | 2              | 1              | 1              |
| Pixel Number   | 3              | 3              | 3              | 3              | 2              | 2              | 2              | 2              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              |
| Bit Plane      | 3              | 2              | 1              | 0              | 3              | 2              | 1              | 0              | 3              | 2              | 1              | 0              | 3              | 2              | 1              | 0              |
| Frame Buffer   | 3              | 3              | 3              | 3              | 2              | 2              | 2              | 2              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              |
| Pixel Number   |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |

**Table 11. ACRTC and GVAC Pin Connection, MOD1, MOD0 = 01 (4 Bits/Pixel, 32-Bit Shift Mode)**

| Connection     | MAD            |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|                | 15             | 14             | 13             | 12             | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
| Pin Connection | D <sub>3</sub> | D <sub>3</sub> | D <sub>3</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>2</sub> | D <sub>2</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>1</sub> | D <sub>1</sub> | D <sub>1</sub> | D <sub>0</sub> | D <sub>0</sub> | D <sub>0</sub> | D <sub>0</sub> |
| GVAC           | 4              | 3              | 2              | 1              | 4              | 3              | 2              | 1              | 4              | 3              | 2              | 1              | 4              | 3              | 2              | 1              |
| Pixel Number   | 3              | 3              | 3              | 3              | 2              | 2              | 2              | 2              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              |
| Bit Plane      | 3              | 2              | 1              | 0              | 3              | 2              | 1              | 0              | 3              | 2              | 1              | 0              | 3              | 2              | 1              | 0              |
| Frame Buffer   | 3              | 3              | 3              | 3              | 2              | 2              | 2              | 2              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              |
| Pixel Number   |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |

Note: D<sub>7</sub>-D<sub>0</sub> cannot be used in this mode**Table 12. ACRTC and GVAC Pin Connection, MOD1, MOD0 = 10 (8 Bits/Pixel, 8-Bit Shift Mode)**

| Connection     | MAD            |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|                | 15             | 14             | 13             | 12             | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
| Pin Connection | D <sub>7</sub> | D <sub>5</sub> | D <sub>3</sub> | D <sub>1</sub> | D <sub>7</sub> | D <sub>5</sub> | D <sub>3</sub> | D <sub>1</sub> | D <sub>6</sub> | D <sub>4</sub> | D <sub>2</sub> | D <sub>0</sub> | D <sub>6</sub> | D <sub>4</sub> | D <sub>2</sub> | D <sub>0</sub> |
| GVAC           | 2              | 2              | 2              | 2              | 1              | 1              | 1              | 1              | 2              | 2              | 2              | 2              | 1              | 1              | 1              | 1              |
| Pixel Number   | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| Bit Plane      | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
| Frame Buffer   | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| Pixel Number   |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |

**Table 13. ACRTC and GVAC Pin Connection, MOD1, MOD0 = 11 (8-Bits/Pixel, 16-Bit Shift Mode)**

| Connection     | MAD            |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|                | 15             | 14             | 13             | 12             | 11             | 10             | 9              | 8              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
| Pin Connection | D <sub>5</sub> | D <sub>1</sub> | D <sub>4</sub> | D <sub>0</sub> |
| GVAC           | 4              | 4              | 3              | 3              | 2              | 2              | 1              | 1              | 4              | 4              | 4              | 3              | 3              | 2              | 2              | 1              |
| Pixel Number   | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| Bit Plane      | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
| Frame Buffer   | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| Pixel Number   |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |                |

Note: D<sub>7</sub>, D<sub>6</sub>, D<sub>3</sub>, D<sub>2</sub> cannot be used in this mode

**Connection Between Frame Buffers and GVACs:** Like the connection to the ACRTC, the data connection to the frame buffers is made on the basis of a bit plane consisting of one word, sequentially from the lower pixel address. Table 14 shows pixel number for the frame buffer's word (16 bits) vs bit plane number for one pixel in relation to operation mode 1 (MOD1).

Table 15 shows the connection between the GVACs

and frame buffers with MOD1, MOD0 = 00. In this mode, the ACRTC's graphic address increment (GAI) is set to +4 mode, and 4-word data is simultaneously read from the frame buffers. GVAC1 handles bit planes 0 and 1, and GVAC2 handles bit planes 2 and 3. For example, pin FD<sub>0</sub> of GVAC1 is connected to a data pin of pixel number 0 of the n + 0 address of bit plane number 0. Connections in other modes are shown in tables 16-18.

**Table 14. One-Word Frame Buffer Pixel Number and Corresponding Bit Plane Number**

| MOD1 |               | One word of frame buffer |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|---------------|--------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|      |               | Pixel Number             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|      |               | 15                       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0    | Bit Plane No. | 3                        | 2  | 1  | 0  | 3  | 2  | 1 | 0 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |
|      | Pixel No.     |                          |    | 3  |    |    |    | 2 |   |   |   | 1 |   |   |   |   | 0 |
| 1    | Bit Plane No. | 7                        | 6  | 5  | 4  | 3  | 2  | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|      | Pixel No.     |                          |    |    |    | 1  |    |   |   |   |   |   |   | 0 |   |   |   |

**Table 15. GVAC and Frame Buffer Pin Connection, MOD1, MOD0 = 00 (4 Bits/Pixel, 16-Bit Shift Mode)**

|      |               |                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|---------------|-------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| GVAC |               | F                                                                       | F | F | F | F | F | F | F | F | F | F | F | F | F | F | F |
|      |               | D                                                                       | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D |
|      | Bit Plane No. | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1    | Bit Plane No. | 1                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 0 |
|      | Pixel No.     | 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Word Address  | n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+0     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 2    | Bit Plane No. | 3                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 2 |
|      | Pixel No.     | 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Word Address  | n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+0     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

**Table 16. GVAC and Frame Buffer Pin Connection, MOD1, MOD0 = 01 (4 Bits/Pixel, 32-Bit Shift Mode)**

|      |               |                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|---------------|-------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| GVAC |               | F                                                                       | F | F | F | F | F | F | F | F | F | F | F | F | F | F | F |
|      |               | D                                                                       | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D |
|      | Bit Plane No. | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1    | Bit Plane No. | 0                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Pixel No.     | 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Word Address  | n+7 n+6 n+5 n+4 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+0     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 2    | Bit Plane No. | 1                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Pixel No.     | 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Word Address  | n+7 n+6 n+5 n+4 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+0     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 3    | Bit Plane No. | 2                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Pixel No.     | 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Word Address  | n+7 n+6 n+5 n+4 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+0     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 4    | Bit Plane No. | 3                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Pixel No.     | 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      | Word Address  | n+7 n+6 n+5 n+4 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+3 n+2 n+1 n+0 n+0     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |



## Video Signal Generation

A GVAC performs parallel-to-serial conversion on 32-bit data read from frame buffers using the shift register, and produces 4-bit video signals (VIDEOA - VIDEOD).

The GVAC recognizes the cycle in which display data is read from frame buffers by memory cycle (MCYC) and memory read (MRD) signals from the ACRTC, display cycle (DSPCYC) from GMIC, and access mode (AM) signal externally set. The GVAC then latches 32-bit data supplied from FD<sub>0</sub>-FD<sub>31</sub> pins.

The latched display data is fed to the shift register on the falling edge of the dot clock (DOTCK) when the shift load (SLD) input is asserted. This data is then shifted on the falling edge of the dot clock (DOTCK) when shift clock enable (SCKE) is asserted.

As seen in figure 8, 32-bit display data is output sequentially to four video signal pins one bit by one bit per dot clock (DOTCK).

- VIDEOA : 32 bits of  $FD_0$ - $FD_{31}$
  - VIDEOB : 24 bits of  $FD_8$ - $FD_{31}$
  - VIDEOC : 16 bits of  $FD_{16}$ - $FD_{31}$
  - VIDEOD : 8 bits of  $FD_{24}$ - $FD_{31}$

Using the display timing signal (**DISP**) from the ACRTC, 4-bit shift register output data can be masked. That is, while **DISP** is asserted, shift register output is provided as video signals, and while it is negated, shift register output is held low, and video signals are not output. The required number of dot cycles per display cycle is the same as the shift length value set by the operation mode (**MOD1**, **MOD0**).

Table 19 shows the dot clock cycle count per display cycle vs operation mode (MOD1, MOD0).

**Table 17. GVAC and Frame Buffer Pin Connection, MOD1, MOD0 = 10 (8 Bits/Pixel, 8-Bit Shift Mode)**

**Table 18. GVAC and Frame Buffer Pin Connection, MOD1, MOD0 = 11 (8 Bits/Pixel, 16-Bit Shift Mode)**



Figure 9, 10 and 11 show ACRTC frame buffer access vs video outputs in single access mode, dual access mode 0, and dual access mode 1. Superimposed display in dual access mode 1 requires that the window smooth scroll input (WSS) be high.

The GVAC provides display data output sequentially from four video outputs VIDEOA-VIDEOD synchronously with the dot clock while the shift clock enable input (SCKE) is asserted. Figure 12 shows the video signals output in GMIC divide-by-16 mode, GVAC's MOD1, MOD0 = 01, 32-

bit shift mode. When shift load (SLD) is asserted, display data ( $FD_{31}-FD_0$ ) is sent to the shift register at the rising edge of the dot clock (DOTCK) to provide the sequential outputs. That is, video output A (VIDEOA) receives sequential outputs starting with  $FD_0$ , and the other video pins receive display data likewise. Figure 13 shows the video signals output in GMIC divide-by-4 mode, GVAC in 16-bit shift mode, and the ACRTC set in dual access mode 0. Figure 14 shows video outputs in the 8-bit shift mode, with the other conditions the same as in figure 13.

**Table 19. Shift Length and Shift Clock**

| MOD1 | MODO | Shift Length | Dot Clocks/<br>Display Cycle |
|------|------|--------------|------------------------------|
| 0    | 0    | 16           | 16                           |
| 0    | 1    | 32           | 32                           |
| 1    | 0    | 8            | 8                            |
| 1    | 1    | 16           | 16                           |



**Figure 8. Video Signal Generation**





Figure 9. Video Output Timing (Single Access Mode)



Figure 10. Video Output Timing (Dual Access Mode 0)





Figure 11. Video Output Timing (Dual Access Mode 1)



Figure 12. Video Signal Output (32-Dot Shift)



Figure 13. Video Signal Output (16-Dot Shift)



Figure 14. Video Signal Output (8-Dot Shift)

## Horizontal Smooth Scrolling

The GVAC performs horizontal smooth scrolling when the assertion period of the shift load signal (SLD) is shifted on a dot clock basis. Table 20 shows horizontal smooth scroll dot count vs shift amount for the shift load signal (SLD) in units of one dot clock cycle. Smooth scrolling is easily implemented by specifying the ACRTC's horizontal smooth scroll dot (HSD) and sending the GMIC's SLDB/SLDW signal to the GVAC. HSD and SLDB/SLDW are discussed in the ACRTC User's Manual, and GMIC Data Sheet respectively.

Figure 15-18 illustrate video signal outputs for smooth scrolling vs frame buffer access in each mode. Video output start timing for display data is shifted corresponding to the shifted assertion of the HSD input. This video signal output is ANDed with the display timing signal ( $\overline{DISP}$ ) and two-memory-cycle delayed (a signal indicating the output enable

period for the video pins). Therefore, the video output signal of display data read from frame buffers by the first display amount. In the last display cycle of a raster, accessed display data output bits corresponding to the scrolling amount are displayed, and the remaining bits are removed.

## Horizontal Zoom

Video signals for zooming are obtained when the period of the shift clock corresponding to the dot clock is extended by the shift clock enable (SCKE) input. The ACRTC specifies the zoom scale (HZ3-HZ0), and the GMIC outputs the SCKE control signal according to the specified zoom scale. SCKE is sent to the GVACs to implement zooming. Figures 15-17 show zoom display timing for each mode. In figure 15, quadruple zoom is performed by applying the shift clock enable (SCKE) once during the four-cycle dot clock (DOTCK).

**Table 20. Horizontal Smooth Scroll Amount and SLD Cycle Count**

| MOD |   | Dot count for horizontal smooth scroll |   |   |   |   |   |   |   |                |   |    |    |    |    |    | Shift length |    |
|-----|---|----------------------------------------|---|---|---|---|---|---|---|----------------|---|----|----|----|----|----|--------------|----|
| 1   | 0 | 0                                      | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 | 13 | 14 | 15           | 16 |
| 0   | 0 | 0                                      | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 | 13 | 14 | 15           | 32 |
| 0   | 1 | 0                                      | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 | 13 | 14 | 15           | 8  |
| 1   | 0 | 0                                      | 1 | 2 | 3 | 4 | 5 | 6 | 7 | Cannot be used |   |    |    |    |    |    |              | 16 |
| 1   | 1 | 0                                      | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 | 13 | 14 | 15           | 16 |

| MOD |   | Dot count for horizontal smooth scroll |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Shift length |   |
|-----|---|----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|---|
| 1   | 0 | 16                                     | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31           | 6 |
| 0   | 0 | Cannot be used                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 32           |   |
| 0   | 1 | 16                                     | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31           | 8 |
| 1   | 0 | Cannot be used                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 16           |   |
| 1   | 1 | Cannot be used                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |   |



Figure 15. Zoom Display Timing (Single Access Mode, Quadruple Zoom)



Figure 16. Zoom Display Timing (Dual Access Mode 0, Double Zoom)





Figure 17. Zoom Display Timing (Dual Access Mode 1, Double Zoom)

**Absolute Maximum Ratings** (All voltages referenced to V<sub>ss</sub> = 0 V)

| Item                  | Symbol           | Rating                       | Unit |
|-----------------------|------------------|------------------------------|------|
| Supply voltage        | V <sub>CC</sub>  | -0.3 to +7.0                 | V    |
| Input voltage         | 'V <sub>in</sub> | -0.3 to V <sub>CC</sub> +0.3 | V    |
| Output voltage        | V <sub>out</sub> | 5.5                          | V    |
| Operating temperature | T <sub>opr</sub> | 0 to +70                     | °C   |
| Storage temperature   | T <sub>str</sub> | -55 to +150                  | °C   |

Notes: Using an LSI beyond its maximum ratings may result in its permanent destruction. LSIs should usually be operated under the recommended operating conditions. Exceeding any of these conditions may adversely affect its reliability

**Recommended Operating Conditions** (All voltages referenced to V<sub>ss</sub> = 0 V)

| Item                  | Symbol           | Min  | Typ  | Max             | Unit |
|-----------------------|------------------|------|------|-----------------|------|
| Supply voltage        | V <sub>CC</sub>  | 4.75 | 5.00 | 5.25            | V    |
| Input voltage low     | V <sub>IL</sub>  | 0    | —    | 0.7             | V    |
| Input voltage high    | V <sub>IH</sub>  | 2.2  | —    | V <sub>CC</sub> | V    |
| Operating temperature | T <sub>opr</sub> | 0    | 25   | 70              | °C   |



## Electrical Characteristics

**DC Characteristics (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0 V, T<sub>a</sub> = 0°C to +70°C, unless otherwise noted)**

| Item                         | Symbol                                                                | Min              | Max             | Unit | Test Condition                                      |
|------------------------------|-----------------------------------------------------------------------|------------------|-----------------|------|-----------------------------------------------------|
| Input voltage high           | V <sub>IH</sub>                                                       | 2.2              | V <sub>CC</sub> | V    |                                                     |
| Input voltage low            | V <sub>IL</sub>                                                       | -0.3             | 0.7             | V    |                                                     |
| Input clamp voltage          | V <sub>I</sub>                                                        |                  | -1.5            | V    | V <sub>CC</sub> = 4.75 V, I <sub>in</sub> = -18 mA  |
| Output voltage high          | V <sub>OH</sub>                                                       | 2.7              |                 | V    | V <sub>CC</sub> = 4.75 V, I <sub>OH</sub> = -400 mA |
| Output voltage low           | V <sub>OL</sub>                                                       |                  | 0.5             | V    | V <sub>CC</sub> = 4.75 V, I <sub>OL</sub> = 8 mA    |
| Input current high           | I <sub>IH</sub>                                                       |                  | 20              | μA   | V <sub>CC</sub> = 5.25 V, V <sub>I</sub> = 2.7 V    |
| Input current low            | I <sub>IL</sub>                                                       |                  | -400            | μA   | V <sub>CC</sub> = 5.25 V, V <sub>I</sub> = 0.4 V    |
| Output short circuit current | I <sub>OS</sub>                                                       | -40              | -120            | mA   | V <sub>CC</sub> = 5.25 V                            |
| Current consumption          | I <sub>CC</sub>                                                       |                  | 160             | mA   | V <sub>CC</sub> = 5.25 V                            |
| Input capacitance            | C <sub>IN</sub>                                                       |                  | 10              | pF   |                                                     |
| Off-state output current     | D <sub>7</sub> -D <sub>0</sub> ,<br>FD <sub>31</sub> -FD <sub>0</sub> | I <sub>OZH</sub> | 20              | μA   | V <sub>CC</sub> = 5.25 V, V <sub>O</sub> = 2.7 V    |
|                              |                                                                       | I <sub>OZL</sub> | -20             | μA   | V <sub>CC</sub> = 5.25 V, V <sub>O</sub> = 0.4 V    |

**AC Characteristics (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0 V, T<sub>a</sub> = 0°C to +70°C)**

| No | Item                         | Symbol             | 32 MHz |     | 48 MHz |     | 64 MHz |     | Unit | Figure |
|----|------------------------------|--------------------|--------|-----|--------|-----|--------|-----|------|--------|
|    |                              |                    | Min    | Max | Min    | Max | Min    | Max |      |        |
| ①  | DOTCK operation frequency    | f                  |        | 32  |        | 48  |        | 64  | MHz  | 18     |
|    | DOTCK cycle time             | t <sub>c</sub>     | 31.3   |     | 20.8   |     | 15.6   |     | ns   |        |
|    | DOTCK high level pulse width | t <sub>HW</sub>    | 12     |     | 9      |     | 6      |     | ns   |        |
|    | DOTCK low level pulse width  | t <sub>LW</sub>    | 12     |     | 9      |     | 6      |     | ns   |        |
|    | DOTCK rise time              | t <sub>R</sub>     |        | 5   |        | 5   |        | 5   | ns   |        |
|    | DOTCK fall time              | t <sub>F</sub>     |        | 5   |        | 5   |        | 5   | ns   |        |
|    | SCKE setup time              | t <sub>SCKS</sub>  | 6      |     | 2      |     | 0      |     | ns   |        |
|    | SCKE hold time               | t <sub>SCKH</sub>  | 5      |     | 5      |     | 5      |     | ns   |        |
|    | SLD setup time               | t <sub>SLDS</sub>  | 6      |     | 2      |     | 0      |     | ns   |        |
|    | SLD hold time                | t <sub>SLDH</sub>  | 3      |     | 3      |     | 3      |     | ns   |        |
|    | VIDEO delay time             | t <sub>VD</sub>    | 3      | 24  | 3      | 17  | 3      | 14  | ns   |        |
|    | 2CLK setup time              | t <sub>2CKS</sub>  | 6      |     | 2      |     | 0      |     | ns   | 19-21  |
|    | MCYC setup time              | t <sub>MCYCS</sub> | 30     |     | 30     |     | 30     |     | ns   |        |
|    | MCYC hold time               | t <sub>MCYCH</sub> | 0      |     | 0      |     | 0      |     | ns   |        |
| ⑯  | FD three!state recovery time | t <sub>FDTR</sub>  | 5      |     | 5      |     | 5      |     | ns   | 20     |
|    | FD setup time                | t <sub>FDTS</sub>  | 30     |     | 30     |     | 30     |     | ns   | 21     |
|    | FD hold time                 | t <sub>FDTH</sub>  | 5      |     | 5      |     | 5      |     | ns   |        |



## AC Characteristics (cont)

| No | Item                         | Symbol      | 32 MHz |     | 48 MHz |     | 64 MHz |     | Unit | Figure |
|----|------------------------------|-------------|--------|-----|--------|-----|--------|-----|------|--------|
|    |                              |             | Min    | Max | Min    | Max | Min    | Max |      |        |
| ⑯  | D three state recovery time  | $t_{DR}$    | 5      |     | 5      |     | 5      |     | ns   | 19     |
| ⑰  | D hold time                  | $t_{DH}$    | 5      |     | 5      |     | 5      |     | ns   |        |
| ⑲  | FD delay time from D         | $t_{FDLY}$  |        | 30  |        | 30  |        | 18  | ns   | 20     |
| ⑳  | D delay time from FD         | $t_{DDLY}$  |        | 30  |        | 30  |        | 18  | ns   | 19     |
| ㉑  | SEL setup time               | $t_{SELS}$  | 10     |     | 10     |     | 10     |     | ns   | 19, 20 |
| ㉒  | SEL hold time                | $t_{SELH}$  | 5      |     | 5      |     | 5      |     | ns   |        |
| ㉓  | DSPCYC setup time            | $t_{DSPS}$  | 20     |     | 20     |     | 20     |     | ns   | 19-21  |
| ㉔  | DSPCYC hold time             | $t_{DSPH}$  | 5      |     | 5      |     | 5      |     | ns   |        |
| ㉕  | MRD setup                    | $t_{MRDS}$  | 20     |     | 20     |     | 20     |     | ns   |        |
| ㉖  | MRD hold time                | $t_{MRDH}$  | 10     |     | 10     |     | 10     |     | ns   |        |
| ㉗  | $\overline{DISP}$ setup time | $t_{DISPS}$ | 20     |     | 20     |     | 20     |     | ns   | 21     |



Figure 18. Dot Clock



Figure 19. Read Cycle



Figure 20. Write Cycle





Figure 21. Display Cycle



Figure 22. Test Load Circuit





Figure 23. Input/Output waveforms

**HITACHI**

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

597

## Package Dimensions

Unit: mm(inches)



Note) Inch value indicated for your reference.



**Reference Literature**

| <b>Product</b> | <b>Data Sheet</b> | <b>User's Manual</b> | <b>Application Note</b>                                                 | <b>Others</b> |
|----------------|-------------------|----------------------|-------------------------------------------------------------------------|---------------|
| HD63484 ACRTC  | ID #U149          | ID #U75              | Introduction to ACRTC<br>Applications, Circuits<br>and Software ID #U90 | —             |
| HD63485 GMIC   | ID #U175          | —                    | —                                                                       | —             |



# HD68562

## DUSCC (Dual Universal Serial Communications Controller)

### — ADVANCE INFORMATION —

The HD68562 Dual Universal Serial Communications Controller (DUSCC) transforms parallel data which is transferred from central processing unit into serial data. It is a single chip MOS-LSI communications device designed to be a foundation of universal high-performance data-communication subsystems, particularly for the 68000 family microprocessors.

The DUSCC provides two independent, multi-protocol, full duplex receiver/transmitter channels in a single package. Since the DUSCC supports a wide range of protocols, it handles data communications with the minimum intervention, usually just a few commands from its host processor. The controller's data rate is maximum 4M bits/s which meets the requirement of the presently most powerful systems. A high-speed, high-performance communication system is realized with minimum external logic at low cost through a variety of functions provided by the chip: 16-bit multi-function counter/timer, a digital phase locked loop (DPLL), a parity/CRC generator and checker, and baud rate generator.

The DUSCC is useful for communication between host computer and terminals, electric mail, VIDEOTEX, local area network (LAN), communications network among personal computers, etc.

#### ■ FEATURES

- Channel data rate: 4M bps maximum
- Receiver/Transmitter: Two channels, dual full-duplex synchronous/asynchronous
- Multi-protocol BOP (Bit Oriented Protocol)  
operation: BCP (Byte Controlled Protocol)  
COP (Character Oriented Protocol)  
ASYNC (Asynchronous)
- High data transfer efficiency: Four-character receiver/transmitter FIFOs
- Parity and FCS (Frame Check Sequence): VRC, LRC-8, CRC-16, CRC-CCITT
- Programmable data encoding/decoding: NRZ, NRZI, FM0, FM1, Manchester
- DMA interface: Compatible with Hitachi HD68450/HD-63450 DMAC and other DMA controllers
- Multi-function programmable 16-bit C/T: Baud rate generator, etc.
- Clock oscillator: On-chip oscillator for crystal
- Power supply: Single +5V

HD68562



(DC-48)

#### ■ PIN ARRANGEMENT



## ■ MAJOR FUNCTIONS OF DUSCC

| Item                        | FUNCTION                                                                                                                                               |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Maximum operating frequency | 4 MHz                                                                                                                                                  |
| Maximum data transfer rate  | 4 Mbits/s                                                                                                                                              |
| Data length                 | 5-8 bits                                                                                                                                               |
| Bus interface               | Compatible with HD68000 (8 bits bus)                                                                                                                   |
| FIFO                        | 4 bytes for each receiver/transmitter                                                                                                                  |
| Number of channels          | 2 channels                                                                                                                                             |
| Error check                 | Parity, framing, over run, under run, FCS                                                                                                              |
| Channel mode                | Half-duplex, full-duplex, auto-echo, local loopback                                                                                                    |
| Data transfer mode          | Pollled, interrupt, DMA, wait                                                                                                                          |
| Protocol operation          | ASYNC : 5-8 bits plus optional parity<br>COP : BISYNC, X.21<br>BCP : DDCMP<br>BOP : HDLC/ADCCP, SDLC, SDLC Loop, Link Level, X.75 Link Level           |
| Baud rate generator         | Built-in                                                                                                                                               |
| Selection of baud rate      | (1) 16 fixed rates: 50 to 38.4K baud.<br>(2) Optional baud rate by timer.                                                                              |
| Encoding/Decoding           | NRZ, NRZI, FM0, FM1, Manchester                                                                                                                        |
| Digital phase locked loop   | Built-in                                                                                                                                               |
| DMA interface               | Compatible with HD68450/HD63450<br>Half or full duplex operation<br>Single or dual address data transfer                                               |
| Interrupt capabilities      | (1) Daisy chain option<br>(2) Vector output (fixed or modified by status)<br>(3) Maskable interrupt conditions<br>(4) Programmable internal priorities |
| Model control               | RTS, CTS, DCD<br>Four general purpose I/O pins per channel                                                                                             |
| 16-bit counter timer        | Built-in                                                                                                                                               |
| Oscillator                  | Built-in                                                                                                                                               |
| Package                     | Ceramic DIP 48-pin                                                                                                                                     |
| Power supply                | 5V ± 10% Ta = 0 to 70°C                                                                                                                                |
| Power dissipation           | Typ. 1 W                                                                                                                                               |



■ INTERNAL BLOCK DIAGRAM



Figure 1 DUSCC Block Diagram

■ SYSTEM CONFIGURATION



Figure 2 System Configuration Example

 **HITACHI**

# HD63645F/HD64645F LCD Timing Controller (LCTC)

## Description

The HD63645F/HD64645F LCTC is a control LSI for large size dot matrix liquid crystal displays. The LCTC is software compatible with the HD6845 CRTC, since its programming method of internal registers and memory addresses is based on the CRTC. A display system can be easily converted from a CRT to an LCD.

The LCTC offers a variety of functions and performance features such as vertical and horizontal scrolling, and various types of character attribute functions such as reverse video, blinking, nondisplay (white or black), and an OR function for simple superimposition of character and graphic displays. The LCTC also provides DRAM refresh address output.

A compact LCD system with a large screen can be configured by connecting the LCTC with the HD61104 (column driver) and the HD61105 (common driver) by utilizing 4-bit  $\times$  2 data outputs. Power dissipation has been lowered by adopting the CMOS process.

## Features

- Software compatible with the HD6845 CRTC
- Programmable screen size :
  - Up to 1024 dots (height)
  - Up to 4096 dots (width)
- High-speed data transfer :
  - Up to 20 Mbits/sec in character mode
  - Up to 40 Mbits/sec in graphic mode
- Selectable single or dual screen configuration
- Programmable multiplexing duty ratio : static to 1/512 duty cycle
- Programmable character font :
  - 1-32 dots (height)
  - 8 dots (width)
- Versatile character attributes : reverse video, blinking, nondisplay (white), nondisplay (black)
- OR function : superimposing characters and graphics display
- Cursor with programmable height, blink rate, display position, and on/off switch
- Vertical smooth scrolling and horizontal scrolling by the character
- Versatile display modes programmable by mode register or external pins : display on/off, graphic or character, normal or wide, attributes, and blink enable
- Refresh address output for dynamic RAM

## Pin Arrangement



- 4- or 8-bit parallel data transfer between LCTC and LCD driver
- Recommended LCD driver : HD61104 (column) and HD61105 (common)
- CPU interface : 68 family (HD63645F), 80 family (HD64645F)
- CMOS process
- Single +5 V  $\pm$  10%
- 80-pin flat plastic package (FP-80)

## Type of Products

| Type No. | Bus Timing | Bus Interface | Package    |
|----------|------------|---------------|------------|
| HD63645F | 2 MHz      | 68 System     | 80-pin FPP |
| HD64645F | 4 MHz      | 80 System     | 80-pin FPP |



**Pin Description**

| <b>Symbol</b>                    | <b>Pin Number</b> | <b>Name</b>                | <b>I/O</b> |
|----------------------------------|-------------------|----------------------------|------------|
| Vcc1, Vcc2                       | 17, 32            | Vcc                        | —          |
| GND1, GND2                       | 37, 59            | Ground                     | —          |
| LU0-LU3                          | 22-25             | LCD Up Panel Data 0-3      | 0          |
| LD0-LD3                          | 18-21             | LCD Down Panel Data 0-3    | 0          |
| CL1                              | 28                | Clock One                  | 0          |
| CL2                              | 29                | Clock Two                  | 0          |
| FLM                              | 27                | First Line Marker          | 0          |
| M                                | 26                | M                          | 0          |
| MA0-MA15                         | 65-80             | Memory Address 0-15        | 0          |
| RA0-RA4                          | 60-64             | Raster Address 0-4         | 0          |
| MD0-MD7                          | 1-8               | Memory Data 0-7            | I          |
| MD8-MD15                         | 9-16              | Memory Data 8-15           | I          |
| DB <sub>0</sub> -DB <sub>7</sub> | 43-50             | Data Bus 0-7               | I/O        |
| CS                               | 39                | Chip Select                | I          |
| E                                | 41                | Enable (HD63645F Only)     | I          |
| R/W                              | 42                | Read/Write (HD63645F Only) | I          |
| WR                               | 41                | Write (HD64645F Only)      | I          |
| RD                               | 42                | Read (HD64645F Only)       | I          |
| RS                               | 40                | Register Select            | I          |
| RES                              | 38                | Reset                      | I          |
| DCLK                             | 33                | D Clock                    | I          |
| MCLK                             | 34                | M Clock                    | 0          |
| DISPTMG                          | 35                | Display Timing             | 0          |
| CUDISP                           | 36                | Cursor Display             | 0          |
| SK0                              | 30                | Skew 0                     | I          |
| SK1                              | 31                | Skew 1                     | I          |
| ON/OFF                           | 53                | On/Off                     | I          |
| BLE                              | 51                | Blink Enable               | I          |
| AT                               | 57                | Attribute                  | I          |
| G/C                              | 58                | Graphic/Character          | I          |
| WIDE                             | 54                | Wide                       | I          |
| LS                               | 56                | Large Screen               | I          |
| D/S                              | 55                | Dual/Single                | I          |
| MODE                             | 52                | Mode                       | I          |



## Pin Functions

### Power Supply (V<sub>cc1</sub>, 2, GND)

**Power Supply Pin (+5 V):** Connect V<sub>cc1</sub> and V<sub>cc2</sub> with +5 V power supply circuit.

**Ground Pin (0 V):** Connect GND1 and GND2 with 0 V.

### LCD Interface

**LCD Up Panel Data (LU0-LU3), LCD Down Panel Data (LD0-LD3):** LU0-LU3 and LD0-LD3 output LCD data as shown in table 1.

**Clock One (CL1):** CL1 supplies timing clocks for display data latch.

**Clock Two (CL2):** CL2 supplies timing clock for display data shift.

**First Line Marker (FLM):** FLM supplies first line marker.

**M (M):** M converts liquid crystal drive output to AC.

### Memory Interface

**Memory Address (MA0-MA15):** MA0-MA15 supply the display memory address.

**Raster Address (RA0-RA4):** RA0-RA4 supply the raster address.

**Memory Data (MD0-MD7):** MD0-MD7 receive the character dot data and bit-mapped data.

**Memory Data (MD8-MD15) :** MD8-MD15 receive attribute code data and bit-mapped data.

### MPU Interface

**Data Bus (DB0-DB7):** DB0-DB7 send/receive data as a three-state I/O common bus.

**Chip Select (CS):** CS selects a chip. Low level

enables MPU read/write of the LCTC internal registers.

**Enable (E) :** E receives an enable clock. (HD63645F only).

**Read/Write (R/W):** R/W enables MPU read of the LCTC internal registers when R/W is high, and MPU write when low. (HD63634F only).

**Write (WR):** WR receives MPU write signal. (HD64645F Only)

**Read (RD):** RD receives MPU read signal. (HD64645F Only)

**Register Select (RS):** RS selects registers. (Refer to table 5.)

**Reset (RES):** RES performs external reset of the LCTC. Low level of RES stops and zero-clears the LCTC internal counter. No register contents are affected.

### Timing Signal

**D Clock (DCLK):** DCLK inputs the system clock.

**M Clock (MCLK):** MCLK indicates memory cycle ; DCLK is divided by four.

**Display Timing (DISPTMG):** DISPTMG high indicates that the LCTC is reading display data.

**Cursor Display (CUDISP):** CUDISP supplies cursor display timing ; connect with MD12 in character mode.

**Skew 0 (SK0)/Skew 1 (SK1):** SK0 and SK1 control skew timing. Refer to table 2.

### Mode Select

The mode select pins ON/OFF, BLE, AT, G/C, and WIDE are ORed with the mode register (R22) to determine the mode.

Table 1. LCD Up Panel Data and LCD Down Panel Data

| Pin name | Single Screen |             | Dual Screen                  |
|----------|---------------|-------------|------------------------------|
|          | 4-Bit Data    | 8-Bit Data  |                              |
| LU0-LU3  | Data output   | Data output | Data output for upper screen |
| LD0-LD3  | Disconnected  | Data output | Data output for lower screen |



**On/Off (ON/OFF):** ON/OFF switches display on and off. (High = display on).

**Blink Enable (BLE):** BLE high level enables attribute code “blinking” (MD13) and provides normal/blank blinking of specified characters for 32 frames each.

**Attribute (AT):** AT controls character attribute functions.

**Graphic/Character (G/C):** G/C switches between graphic and character display mode (graphic display when high).

**Wide (WIDE):** WIDE switches between normal

and wide display mode (high = wide display, low = normal display).

**Large Screen (LS):** LS controls a large screen. LS high provides a data transfer rate of 40 Mbits/s for a graphic display. Also used to specify 8-bit LCD interface mode. For more details, refer to page 26.

**Dual/Single (D/S):** D/S switches between single and dual screen display (dual screen display when high).

**Mode (MODE):** MODE controls easy mode. MODE high sets duty ratio, maximum number of rasters, cursor start/end rasters, etc. (Refer to table 9.)

**Table 2. Skew Signals**

| SK0 | SK1 | Skew Function         |
|-----|-----|-----------------------|
| 0   | 0   | No skew               |
| 1   | 0   | 1-character time skew |
| 0   | 1   | 2-character time skew |
| 1   | 1   | Inhibited combination |



## Function Overview

### LCD and CRT Display Systems

Figure 1 shows a system using both LCD and CRT displays.

### Main Features of HD63645F/HD64645F

Main features of the LCTC are :

- High-resolution liquid crystal display screen control (up to  $720 \times 512$  dots)
- Software compatible with HD6845 (CRTC)
- Built-in character attribute control circuit

Table 3 shows how the LCTC can be used.

**Table 3. Functions, Application, and Configuration**

| Classification | Item                 | Description                                                                                                                                                                                                                                                                                                                               |
|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Functions      | Screen Format        | Programmable horizontal scanning cycle by the character clock period<br>Programmable multiplexing duty ratio from static up to 1/512<br>Programmable number of displayed characters per character row<br>Programmable number of rasters per character row (number of vertical dots within a character row + space between character rows) |
|                | Cursor Control       | Programmable cursor display position, corresponding to RAM address<br>Programmable cursor height by setting display start/end rasters<br>Programmable blink rate, 1/32 or 1/64 frame rate                                                                                                                                                 |
|                | Memory Rewriting     | Time for rewriting memory set either by specifying number of horizontal total characters or by cycle steal utilizing MCLK                                                                                                                                                                                                                 |
|                | Memory Addressing    | 16-bit memory address output, up to 64 kbytes x 2 memory accessible<br>DRAM refresh address output                                                                                                                                                                                                                                        |
|                | Paging and Scrolling | Paging by updating start address<br>Horizontal scrolling by the character, by setting horizontal virtual screen width<br>Vertical smooth scrolling by updating display start raster                                                                                                                                                       |
|                | Character Attributes | Reverse video, blinking, nondisplay (white or black) character attributes                                                                                                                                                                                                                                                                 |
| Application    | CRTC Compatible      | Facilitates system replacement of CRT display with LCD.                                                                                                                                                                                                                                                                                   |
|                | OR Function          | Enables superimposing display of character screen and graphic screen                                                                                                                                                                                                                                                                      |
| Configuration  | LCTC Configuration   | Single 5 V power supply<br>I/O TTL compatible except <u>RES</u> , MODE, SK0, SK1<br>Bus connectable with HMCS 6800 family (HD63645F)<br>Bus connectable with 80 family (HD64645F)<br>CMOS process<br>Internal logic fully static<br>80-pin flat plastic package                                                                           |





Figure 1. LCD and CRT Displays

## Internal Block Diagram

Figure 2 is a block diagram of the LCTC.



Figure 2. LCTC Block Diagram



## System Block Configuration Examples

Figure 3 is a block diagram of a character/graphic display system. Figure 4 shows two examples using

LCD drivers.



**Figure 3. Character/Graphic Display System Example**



Figure 4. LCD Driver Examples



## Registers

Table 4 shows the register mapping. Table 5 describes the function. Table 6 shows the differ-

ences between CRTC and LCTC registers.

Table 4. Registers Mapping

| CS | RS | 4 | 3 | 2 | 1 | 0 | Address                             | Program Unit           | Symbol | R/W | Data Bit |   |   |   |            |     |      |     |    |
|----|----|---|---|---|---|---|-------------------------------------|------------------------|--------|-----|----------|---|---|---|------------|-----|------|-----|----|
|    |    |   |   |   |   |   | No.                                 |                        |        |     | 7        | 6 | 5 | 4 | 3          | 2   | 1    | 0   |    |
| 1  | —  | — | — | — | — | — | Invalid                             | —                      | —      | —   |          |   |   |   |            |     |      |     |    |
| 0  | 0  | — | — | — | — | — | AR Address Register                 | —                      | —      | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 0 | 0 | 0 | 0 | R0 Horizontal Total Characters      | Character <sup>3</sup> | Nht    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 0 | 0 | 1 | 0 | R1 Horizontal Displayed Characters  | Character              | Nhr    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 0 | 0 | 1 | R9 Maximum Raster Address           | Raster                 | Nr     | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 0 | 1 | 0 | R10 Cursor Start Raster             | Raster <sup>4</sup>    | Ncs    | W   | B        | P |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 0 | 1 | 1 | R11 Cursor End Raster               | Raster                 | Nce    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 1 | 0 | 0 | R12 Start Address (H)               | Memory Address         | —      | R/W |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 1 | 0 | 1 | R13 Start Address (L)               | Memory Address         | —      | R/W |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 1 | 1 | 0 | R14 Cursor Address (H)              | Memory Address         | —      | R/W |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 0 | 1 | 1 | 1 | 1 | R15 Cursor Address (L)              | Memory Address         | —      | R/W |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 1 | 0 | 0 | 0 | 0 | R18 Horizontal Virtual Screen Width | Character              | Nir    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 1 | 0 | 0 | 1 | 1 | R19 Multiplexing Duty Ratio (H)     | Raster <sup>3</sup>    | Ndh    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 1 | 0 | 1 | 0 | 0 | R20 Multiplexing Duty Ratio (L)     | Raster <sup>3</sup>    | Ndl    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 1 | 0 | 1 | 0 | 1 | R21 Display Start Raster            | Raster                 | Nsr    | W   |          |   |   |   |            |     |      |     |    |
| 0  | 1  | 1 | 0 | 1 | 1 | 0 | R22 Mode Register                   | —Note <sup>5</sup>     | —      | W   |          |   |   |   | ON/<br>OFF | G/C | WIDE | BLE | AT |

- Notes:
1. [ ] : Invalid data bits
  2. R/W indicates whether write access or read access is enabled to/from each register.  
W: Only write accessible  
R/W: Both read and write accessible
  3. The "value to be specified less 1" should be programmed in these registers (R0, R19, and R20).
  4. Data bits 5 and 6 of cursor start register control the cursor status as shown below.  
(For more details, refer to page 27).

| B | P | Cursor Blink Mode             |
|---|---|-------------------------------|
| 0 | 0 | Cursor on; without blinking   |
| 0 | 1 | Cursor off                    |
| 1 | 0 | Blinking once every 32 frames |
| 1 | 1 | Blinking once every 64 frames |

5. The OR of mode pin status and mode register data determines the mode.
6. Registers R2-R8, R16, and R17 are not assigned for the LCTC. Programming to these registers, will be ignored.



**Table 5. Internal Register Description**

| <b>Reg.<br/>No.</b> | <b>Register Name</b>            | <b>Size (Bits)</b> | <b>Description</b>                                                                            |
|---------------------|---------------------------------|--------------------|-----------------------------------------------------------------------------------------------|
| AR                  | Address Register                | 5                  | Specifies the internal control registers (R0, R1, R9-R15, R18-R22) address to be accessed     |
| R0                  | Horizontal Total Characters     | 8                  | Specifies the horizontal scanning period                                                      |
| R1                  | Horizontal Displayed Characters | 8                  | Specifies the number of displayed characters per character row                                |
| R9                  | Maximum Raster Address          | 5                  | Specifies the number of rasters per character row, including the space between character rows |
| R10                 | Cursor Start Raster             | 5+2                | Specifies the cursor start raster address and its blink mode                                  |
| R11                 | Cursor End Raster               | 5                  | Specifies the cursor end raster address                                                       |
| R12                 | Start Address (H)               | 16                 | Specify the display start address                                                             |
| R13                 | Start Address (L)               |                    |                                                                                               |
| R14                 | Cursor Address (H)              | 16                 | Specify the cursor display address                                                            |
| R15                 | Cursor Address (L)              |                    |                                                                                               |
| R18                 | Horizontal Virtual Screen Width | 8                  | Specifies the length of one row in memory space for horizontal scrolling                      |
| R19                 | Multiplexing Duty Ratio (H)     | 9                  | Specify the number of rasters for one screen                                                  |
| R20                 | Multiplexing Duty Ratio (L)     |                    |                                                                                               |
| R21                 | Display Start Raster            | 5                  | Specifies the display start raster within a character row for smooth scrolling                |
| R22                 | Mode Register                   | 5                  | Controls the display mode                                                                     |

\*For more details of registers, refer to "[Internal Registers](#)".



**Table 6. Internal Register Comparison between LCTC and CRTC**

| <b>Reg.</b> | <b>LCTC HD63645F/HD64645F</b>   | <b>Comparison</b>             | <b>CRTC HD6845</b>              |
|-------------|---------------------------------|-------------------------------|---------------------------------|
| AR          | Address Register                | Equivalent to CRTC            | Address Register                |
| R0          | Horizontal Total Characters     |                               | Horizontal Total Characters     |
| R1          | Horizontal Displayed Characters |                               | Horizontal Displayed Characters |
| R2          |                                 | Particular to CRTC;           | Horizontal Sync Position        |
| R3          |                                 | unnecessary for LCTC          | Sync Width                      |
| R4          |                                 |                               | Vertical Total Characters       |
| R5          |                                 |                               | Vertical Total Adjust           |
| R6          |                                 |                               | Vertical Displayed Characters   |
| R7          |                                 |                               | Vertical Sync Position          |
| R8          |                                 |                               | Interlace and Skew              |
| R9          | Maximum Raster Address          | Equivalent to CRTC            | Maximum Raster Address          |
| R10         | Cursor Start Raster             |                               | Cursor Start Raster             |
| R11         | Cursor End Raster               |                               | Cursor End Raster               |
| R12         | Start Address (H)               |                               | Start Address (H)               |
| R13         | Start Address (L)               |                               | Start Address (L)               |
| R14         | Cursor Address (H)              |                               | Cursor (H)                      |
| R15         | Cursor Address (L)              |                               | Cursor (L)                      |
| R16         |                                 | Particular to CRTC;           | Light Pen (H)                   |
| R17         |                                 | unnecessary for LCTC          | Light Pen (L)                   |
| R18         | Horizontal Virtual Screen Width | Additional registers for LCTC |                                 |
| R19         | Multiplexing Duty Ratio (H)     |                               |                                 |
| R20         | Multiplexing Duty Ratio (L)     |                               |                                 |
| R21         | Display Start Raster            |                               |                                 |
| R22         | Mode Register                   |                               |                                 |



## Functional Description

### Programmable Screen Format

Figure 5 illustrates the relation between LCD dis-

play screen and registers. Figure 6 shows a timing chart of signals output from the LCTC in mode 5 as an example.



Figure 5. Relation between Display Screen and Registers





Figure 6. LCTC Timing Chart (In Mode 5 : Single Screen, 4-Bit Transfer, Normal Character Display)

### CURSOR CONTROL

The following cursor functions (figure 7) can be controlled by programming specific registers.

- Cursor display position

- Cursor height
- Cursor blink mode

A cursor can be displayed only in character mode. Also, CUDISP pin must be connected to MD12 pin to display a cursor.



Figure 7. Cursor Display



## Character Mode and Graphic Mode

The LCTC supports two types of display modes; character mode and graphic mode. Graphic mode 2 is provided to utilize software for system using the CRTC (HD6845).

The display mode is controlled by an OR between the mode select pins (D/S, G/C, LS, WIDE, AT) and mode register (R22).

**Character Mode** : Character mode displays characters by using CG-ROM. The display data supplied from memory is accessed in 8-bit units. A variety of character attribute functions are provided, such as reverse video, blinking, nondisplay (white or black), etc., by storing the attribute data in attribute RAM (A-RAM).

Figure 8 illustrates the relation between character

display screen and memory contents.

**Graphic Mode 1** : Graphic Mode 1 directly displays data stored in graphic memory buffer. The display data supplied from memory is accessed in 16-bit units. Character attribute functions or wide mode are not provided. Figure 9 illustrates the relation between graphic display screen and memory contents.

**Graphic Mode 2** : Graphic mode 2 utilizes software for the system using the CRTC (HD6845). The display data supplied from memory is accessed in 16-bit units. Character attribute functions or wide mode are not provided. The same memory addresses are output repeatedly a number of times specified by maximum raster register (R9). The raster address is output in the same way as character mode.



Figure 8. Relation between Character Screen and Memory Contents

## Horizontal Virtual Screen Width

Horizontal virtual screen width can be specified by the character in addition to the number of horizontal displayed characters (figure 10).

The display screen can be scrolled in any direction

by the character, by setting the horizontal virtual screen width and updating the start address. This function is enabled by programming the horizontal virtual screen width register (R18).

Figure 11 shows an example.



Figure 9. Relation between Graphic Screen and Memory Contents



Figure 10. Horizontal Virtual Screen Width





Figure 11. Example of Horizontal Scroll by Setting Horizontal Virtual Screen Width

## **Smooth Scroll**

Vertical smooth scrolling (figure 12) is performed by updating the display start raster, as specified by the start raster register (R21). This function is offered only in character mode.

## Wide Display

The character to be displayed can be doubled in width, by supplying the same data twice (figure 13). This function is offered only in character mode, and controlled either by bit 2 of the mode register (R22) or by the WIDE pin.



Figure 12. Example of Smooth Scroll by Setting Display Start Raster Address



**Figure 13.** Example of Wide Display

## Attribute Functions

A variety of character attribute functions such as reverse video, blinking, nondisplay (white) or nondisplay (black) can be implemented by storing the attribute data in A-RAM (attribute RAM). Figure 14 shows a display example using each attribute function.

The attribute functions are offered only in character mode, and controlled either by bit 0 of the mode register (R22) or the AT pin. As shown in figure 15, a character attribute can be specified by placing the character code on MD0-MD7, and the attribute code on MD11-MD15. MD8-MD10 are invalid.



Figure 14. Display Example Using Attribute Functions

| MD Input | 15                  | 14                  | 13       | 12     | 11            | 10-8  | 7-0            |
|----------|---------------------|---------------------|----------|--------|---------------|-------|----------------|
| Function | Non-display (black) | Non-display (white) | Blinking | Cursor | Reverse video | * * * | Character Code |

\*: Invalid

Figure 15. Attribute Code



### OR Function — Superimposing Characters and Graphics

The OR function (figure 16) generates the OR of the data entered into MD0-MD7 (e.g. character data) and the data into MD8-MD15 (e.g. graphic

data) in the LCTC and transfers this data as 1 byte.

This function is offered only in character mode, and controlled by bit 0 of the mode register (R22) or by the AT pin. Any attribute functions are disabled when using the OR function.



Figure 16. OR Function

### DRAM Refresh Address Output Function

The LCTC outputs the address for DRAM refresh while CL1 is high, as shown in figure 17. The 16 refresh addresses per scanned line are output 16 times, from \$00-\$FF.

### Skew Function

The LCTC can specify the skew (delay) for CUDISP, DISPTMG, CL2 outputs and MD inputs.

If buffer memory and character generator ROM cannot be accessed within one horizontal character

display period, the access is retarded to the next cycle by inserting a latch to memory address output and buffer memory output. The skew function retards the CUDISP, DISPTMG, CL2 outputs, and MD inputs in the LCTC to match phase with the display data signal.

By utilizing this function, a low-speed memory can be used as a buffer RAM or a character generator ROM.

This function is controlled by pins SK0 and SK1 as shown in table 7.

**Table 7. Skew Function**

| SK0 | SK1 | Skew Function         |
|-----|-----|-----------------------|
| 0   | 0   | No skew               |
| 1   | 0   | 1 character time skew |
| 0   | 1   | 2 character time skew |
| 1   | 1   | Inhibited combination |



**Figure 17. DRAM Refresh Address Output**

**Easy Mode**

This mode utilizes software for systems using the CRTC (HD6845). By setting MODE pin to high, the

display mode and screen format are fixed as shown in table 8. With this mode, software for a CRT screen can be utilized in a system using the LCTC, without changing the BIOS.

**Table 8. Fixed Values in Easy Mode**

| <b>Reg. No.</b> | <b>Register Name</b>            | <b>Fixed Value (decimal)</b> |
|-----------------|---------------------------------|------------------------------|
| R9              | Maximum raster address          | 7                            |
| R10             | Cursor start raster             | 6                            |
| R11             | Cursor end raster               | 7                            |
| R18             | Horizontal virtual screen width | Same value as (R1)           |
| R19             | Multiplexing duty ratio (H)     | 99 (in dual screen mode)     |
| R20             | Multiplexing duty ratio (L)     | 199 (in single screen mode)  |
| R21             | Display start raster            | 0                            |
| R22             | Mode register                   | 0                            |



## System Configuration and Mode Setting

### LCD System Configuration

The screen configuration, single or dual, must be specified when using the LCD system (figure 18).

Using the single screen configuration, you can construct an LCD system with lower cost than a dual screen system, since the required number of column drivers is smaller and the manufacturing process for mounting them is simpler. However, there are some limitations, such as duty ratio, breakdown voltage of a driver, and display quality of the liquid crystal, in single screen configuration. Thus, a dual screen configuration may be more suitable to an application.

The LCTC also offers an 8-bit LCD data transfer function to support an LCD screen with a smaller interval of signal input terminals. For a general size LCD screen, such as  $640 \times 200$  single, or  $640 \times 400$  dual, the usual 4-bit LCD data transfer is satisfactory.

### Hardware Configuration and Mode Setting

The LCTC supports the following hardware configurations :

- Single or dual screen configuration
  - 4-or 8-bit LCD data transfer
- and the following screen format :
- Character, graphic 1, or graphic 2 display
  - Normal or wide display (only in character mode)
  - OR or attribute display (only in character mode)

Also, the LCTC supports up to 40 Mbits/s of large screen mode (mode 13) for large screen display. This mode is provided only in graphic 1 mode.

Table 9 shows the mode selection method according to hardware configuration and screen format. Table 10 shows how they are specified.



Figure 18. Hardware Configuration According to Screen Format

**Table 9. Mode Selection**

| Hardware Configuration |                      |             | Screen Format     |             |              |                                    |          |
|------------------------|----------------------|-------------|-------------------|-------------|--------------|------------------------------------|----------|
| LCD Data Transfer      | Screen Configuration | Screen Size | Character/Graphic | Normal/Wide | Attribute/OR | Maximum data transfer speed (MBPS) | Mode No. |
| 4-bit                  | Single               | Normal      | Character         | Normal      | AT<br>OR     | 20                                 | 5        |
|                        |                      |             |                   |             | Wide         | AT<br>OR                           | 10       |
|                        |                      |             |                   |             | Graphic 1    | 20                                 | 7        |
|                        |                      |             |                   |             | Graphic 2    | 20                                 | 8        |
|                        |                      | Normal      | Character         | Normal      | AT<br>OR     | 20                                 | 1        |
|                        |                      |             |                   |             | Wide         | AT<br>OR                           | 10       |
|                        |                      |             |                   |             | Graphic 1    | 20                                 | 3        |
|                        |                      |             |                   |             | Graphic 2    | 20                                 | 4        |
|                        |                      | Large       | Graphic 1         |             |              | 40                                 | 13       |
| 8-bit                  | Single               | Normal      | Character         | Normal      | AT<br>OR     | 20                                 | 9        |
|                        |                      |             |                   |             | Wide         | AT<br>OR                           | 10       |
|                        |                      |             |                   |             | Graphic 1    | 20                                 | 11       |
|                        |                      |             |                   |             | Graphic 2    | 20                                 | 12       |

Note: Maximum data transfer speed indicates amount of the data read out of a memory. Thus, the data transfer speed sent to the LCD driver in wide function is 20 Mbps.



**Mode List****Table 10. Mode List**

| No. | Mode Name                    | Pin Name |      |    |   |   | Screen Config. | Graphic/Character | Data Transfer | Wide Display | Attribute |
|-----|------------------------------|----------|------|----|---|---|----------------|-------------------|---------------|--------------|-----------|
| D/S | G/C                          | LS       | WIDE | AT |   |   |                |                   |               |              |           |
| 1   | Dual-screen character        | 1        | 0    | 0  | 0 | 0 | Dual screen    | Character         | 4-bit<br>× 2  | Normal       | OR        |
|     |                              | 1        | 0    | 0  | 0 | 1 |                |                   |               |              | AT        |
| 2   | Dual-screen wide character   | 1        | 0    | 0  | 1 | 0 |                |                   |               | Wide         | OR        |
|     |                              | 1        | 0    | 0  | 1 | 1 |                |                   |               |              | AT        |
| 3   | Dual-screen graphic 1        | 1        | 1    | 0  | 0 | 1 |                | Graphic           |               |              |           |
| 4   | Dual-screen graphic 2        | 1        | 1    | 0  | 0 | 0 |                |                   |               |              |           |
| 5   | Single-screen character      | 0        | 0    | 0  | 0 | 0 | Single screen  | Character         | 4-bit         | Normal       | OR        |
|     |                              | 0        | 0    | 0  | 0 | 1 |                |                   |               |              | AT        |
| 6   | Single-screen wide character | 0        | 0    | 0  | 1 | 0 |                |                   |               | Wide         | OR        |
|     |                              | 0        | 0    | 0  | 1 | 1 |                |                   |               |              | AT        |
| 7   | Single-screen graphic 1      | 0        | 1    | 0  | 0 | 1 |                | Graphic           |               |              |           |
| 8   | Single-screen graphic 2      | 0        | 1    | 0  | 0 | 0 |                |                   |               |              |           |
| 9   | 8-bit character              | 0        | 0    | 1  | 0 | 0 |                | Character         | 8-bit         | Normal       | OR        |
|     |                              | 0        | 0    | 1  | 0 | 1 |                |                   |               |              | AT        |
| 10  | 8-bit wide character         | 0        | 0    | 1  | 1 | 0 |                |                   |               | Wide         | OR        |
|     |                              | 0        | 0    | 1  | 1 | 1 |                |                   |               |              | AT        |
| 11  | 8-bit graphic 1              | 0        | 1    | 1  | 0 | 1 |                | Graphic           |               |              |           |
| 12  | 8-bit graphic 2              | 0        | 1    | 1  | 0 | 0 |                |                   |               |              |           |
| 13  | Large screen                 | 1        | 1    | 1  | 0 | 1 | Dual screen    |                   | 4-bit<br>× 2  |              |           |

The LCTC display mode is determined by pins D/S (pin 55), G/C (pin 58), LS (pin 56), WIDE (pin 54), and AT (pin 57). As for G/C, WIDE, and AT, the OR is taken between data bits 0, 2, and 3 of the mode register (R22). The display mode can be controlled by either one of the external pins or the data bits of R22.

Note: The above 5 pins have 32 status combinations (high and low). Any combinations other than the above are inhibited, because they may cause malfunctions. If you set an inhibited combination, set the right combination again.



## Internal Registers

The HD63645F/HD64645F has one address register and fourteen data registers. In order to select one out of fourteen data registers, the address of the data register to be selected must be written into the address register. The MPU can transfer data to/from the data register corresponding to the written address.

To be software compatible with the CRTC (HD6845), registers R2-R8, R16, and R17, which are not necessary for an LCD are defined as invalid for the LCTC.

### Address Register (AR)

AR register (figure 19) specifies one out of 14 data registers. Address data is written into the address register when RS is low. If no register corresponding to a specified address exists, the address data is invalid.

### Horizontal Total Characters Register (R0)

R0 register (figure 20) specifies a horizontal scanning period. The total number of horizontal characters less 1 must be programmed into this 8-bit register in character units. The "Nht" indicates the horizontal scanning period including the period when the CPU occupies memory (total number of horizontal characters minus the number of horizontal displayed characters). Its unit is, then, converted from time into the number of characters. This value is to be specified according to the specification of the LCD system to be used.

### Horizontal Displayed Characters Register (R1)

R1 register (figure 21) specifies the number of characters displayed per row. The horizontal char-

acter pitches are 8 bits for normal character display and 16 dots for wide character display and graphic display.

The "Nhd" must be less than the total number of horizontal characters.

### Maximum Raster Address Register (R9)

R9 register (figure 22) specifies the number of rasters per row in characters mode, consisting of 5 bits. The programmable range is 0 (1 raster/row) to 31 (32 rasters/row).

### Cursor Start Raster Register (R10)

R10 register (figure 23) specifies the cursor start raster address and its blink mode. Refer to table 11.



32- or 64-frame

### Cursor End Raster Register (R11)

R11 register (figure 24) specifies the cursor end raster address.

### Start Address Register (H/L) (R12/R13)

R12/R13 register (figure 25) specifies a buffer memory read start address. Updating this register facilitates paging and scrolling. R14/R15 register can be read and written to/from the MPU.

| Data Bit         |   |   |   |   |   |   |   | Program Unit | R/W |
|------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 | —            |     |
| Register address |   |   |   |   |   |   |   | W            |     |

Figure 19. Address Register

| Data Bit |   |   |   |   |   |   |   | Program Unit               | R/W       |   |
|----------|---|---|---|---|---|---|---|----------------------------|-----------|---|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Nhd (Displayed characters) | Character | W |

Figure 21. Horizontal Displayed Characters Register

| Data Bit                   |   |   |   |   |   |   |   | Program Unit | R/W    |
|----------------------------|---|---|---|---|---|---|---|--------------|--------|
| 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Character    | W      |
| Nht (Total characters - 1) |   |   |   |   |   |   |   | Nr           | Raster |

Figure 20. Horizontal Total Characters Register

| Data Bit |   |   |   |   |   |   |   | Program Unit | R/W    |   |
|----------|---|---|---|---|---|---|---|--------------|--------|---|
| 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Nr           | Raster | W |

Figure 22. Maximum Raster Address Register



**Cursor Address Register (H/L) (R14/R15)**

R14/R15 register (figure 26) specifies a cursor display address. Cursor display requires setting R10 and R11, and CUDISP should be connected with MD12 (in character mode). This register can be read from and written to the MPU.

**Horizontal Virtual Screen Width Register (R18)**

R18 register (figure 27) specifies the memory width to determine the start address of the next row. By using this register, memory width can be specified larger than the number of horizontal displayed characters. Updating the display start address facilitates scrolling in any direction within a memory space.

The start address of the next row is that of the previous row plus Nir. If a larger memory width than display width is unnecessary, Nir should be set equal to the number of horizontal displayed characters.

**Multiplexing Duty Ratio Register (H/L) (R19/R20)**

R19/R20 register (figure 28) specifies the number of vertical dots of the display screen. The programmed value differs according to the LCD screen configuration.

In single screen configuration :

$$\text{Programmed value} = \frac{\text{Number of vertical dots}}{2} - 1.$$

In dual screen configuration :

$$\text{Programmed value} = \frac{\text{Number of vertical dots}}{2} - 1.$$

**Display Start Raster Register (R21)**

R21 register (figure 29) specifies the start raster of the character row displayed on the top of the screen. The programmed value should be equal or less than the maximum raster address. Updating

**Table 11 Cursor Blink Mode**

| B | P | CURSOR BLINK MODE             |
|---|---|-------------------------------|
| 0 | 0 | Cursor on; without blinking   |
| 0 | 1 | Cursor off                    |
| 1 | 0 | Blinking once every 32 frames |
| 1 | 1 | Blinking once every 64 frames |

| Data Bit                 |   |   |   |   |   |   |   | Program Unit | R/W |
|--------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |              |     |
| Memory address (H) (R14) |   |   |   |   |   |   |   | Memory       | R/W |
| Memory address (L) (R15) |   |   |   |   |   |   |   | address      |     |

| Data Bit |   |   |                      |   |   |   |   | Program Unit | R/W |
|----------|---|---|----------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                    | 3 | 2 | 1 | 0 |              |     |
| —        | B | P | Ncs (Raster address) |   |   |   |   | Raster       | W   |
|          |   |   |                      |   |   |   |   |              |     |

**Figure 23. Cursor Start Raster Register**

| Data Bit |   |   |                      |   |   |   |   | Program Unit | R/W |
|----------|---|---|----------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                    | 3 | 2 | 1 | 0 |              |     |
| —        | — | — | Nce (Raster address) |   |   |   |   | Raster       | W   |
|          |   |   |                      |   |   |   |   |              |     |

**Figure 24. Cursor End Raster Register**

| Data Bit                 |   |   |   |   |   |   |   | Program Unit | R/W |
|--------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |              |     |
| Memory address (H) (R12) |   |   |   |   |   |   |   | Memory       | R/W |
| Memory address (L) (R13) |   |   |   |   |   |   |   | address      |     |

**Figure 25. Start Address Register****Figure 26. Cursor Address Register**

| Data Bit |   |   |                                      |   |   |   |   | Program Unit | R/W |
|----------|---|---|--------------------------------------|---|---|---|---|--------------|-----|
| 7        | 6 | 5 | 4                                    | 3 | 2 | 1 | 0 |              |     |
| —        | — | — | Nir (No. of chars. of virtual width) |   |   |   |   | Character    | W   |
|          |   |   |                                      |   |   |   |   |              |     |

**Figure 27. Horizontal Virtual Screen Width Register**

| Data Bit                          |   |   |   |   |   |   |   | Program Unit | R/W |
|-----------------------------------|---|---|---|---|---|---|---|--------------|-----|
| 7                                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |              |     |
| —                                 | — | — | — | — | — | — | — | Raster       | W   |
| NdI (Number of rasters - 1) (R20) |   |   |   |   |   |   |   |              |     |

\* : Number of rasters

**Figure 28. Multiplexing Duty Ratio Register**

this register allows smooth scrolling in character mode.

#### Mode register (R22)

| Data Bit |   |   |                |   |   |   |   | Program Unit | R/W |  |
|----------|---|---|----------------|---|---|---|---|--------------|-----|--|
| 7        | 6 | 5 | 4              | 3 | 2 | 1 | 0 |              |     |  |
| —        | — | — | Raster address |   |   |   |   |              |     |  |

Figure 29. Display Start Raster Register

The OR of the data bits of R22 (figure 30) register and the external terminals of the same name determines a particular mode. (figure 31)

| Data Bit |   |   |                        |   |   |   |   | Program Unit | R/W |  |
|----------|---|---|------------------------|---|---|---|---|--------------|-----|--|
| 7        | 6 | 5 | 4                      | 3 | 2 | 1 | 0 |              |     |  |
| —        | — | — | ON/OFF G/C WIDE BLE AT |   |   |   |   |              |     |  |

Figure 30. Mode Register



- Notes:
1. AT (valid only when G/C is low (character mode))  
AT = High: Attribute functions enabled, OR function disabled  
AT = Low: OR function enabled, attribute functions disabled.
  2. BLE (valid only when G/C is low (character mode))  
BLE = High: Blinking enable on the character specified by attribute RAM  
BLE = Low: No blinking
  3. WIDE (valid only when G/C is low (character mode))  
WIDE = High: Wide display enabled  
WIDE = Low: Normal display
  4. G/C  
G/C = High: Graphic 1 display (when AT = Low) or Graphic 2 display (when AT = High)  
G/C = Low: Character display
  5. ON/OFF  
ON/OFF = High: Display on state  
ON/OFF = Low: Display off state

Figure 31. Correspondence between Mode Register and External Pins



## Reset

**RES** pin determines the internal state of LSI counters and the like. This pin does not affect register contents nor does it basically control output terminals.

"Reset" is defined as follows (Figure 32) :

- At reset: the time when **RES** goes low
- During reset: the period while **RES** remains low
- After reset: the period on and after the **RES** transition from low to high

**RES** pin should be pulled high by users during operation.

### Reset State of Pins

**RES** pin does not basically control output pins, and operates regardless of other input pins.

- (1) Preserves states before reset :  
LU0-LU3, LD0-LD3, FLM, CL1, RA0-RA4
- (2) Fixed at high level :  
MLCK
- (3) Preserves states before reset or fixed at low

level according to the timing when the reset signal is input :

DISPTMG, CUDISP, MA0-MA15

- (4) Fixed at high or low according to mode :  
CL2
- (5) Unaffected :  
 $DB_0 - DB_7$

### Reset State of Registers

**RES** pin does not affect register contents. Therefore, registers can be read or written even during a reset state ; their contents will be preserved regardless of reset until they are rewritten to.

### Notes for HD63645F/HD64645F

- (1) The HD63645F/HD64645F are CMOS LSIs, and it should be noted that input pins must not be left disconnected, etc.
- (2) At power-on, the state of internal registers becomes undefined. The LSI operation is undefined until all internal registers have been programmed.



Figure 32. Reset Definition

## Absolute Maximum Ratings

| Item                  | Symbol           | Value                          | Note |
|-----------------------|------------------|--------------------------------|------|
| Supply voltage        | V <sub>CC</sub>  | -0.3 to +7.0 V                 | 2    |
| Terminal voltage      | V <sub>IN</sub>  | -0.3 to V <sub>CC</sub> +0.3 V | 2    |
| Operating temperature | T <sub>OPR</sub> | -20°C to +75°C                 |      |
| Storage temperature   | T <sub>STG</sub> | -55°C to +125°C                |      |

Notes: 1 Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions (V<sub>CC</sub> = 5.0 V ±10%, GND = 0 V, T<sub>a</sub> = -20°C to +75°C) If these conditions are exceeded, it could affect reliability of LSI.

2 Width respect to GROUND (GND = 0 V)

## Electrical Characteristics

**DC characteristics (V<sub>CC</sub> = 5.0 V ±10%, GND = 0 V, T<sub>a</sub> = -20°C to +75°C, unless otherwise noted.)**

| Item                                    | Symbol                                             | Min              | Typ                  | Max                  | Unit | Test Condition            |
|-----------------------------------------|----------------------------------------------------|------------------|----------------------|----------------------|------|---------------------------|
| Input high voltage                      | RES, MODE, SK0, SK1                                | V <sub>IH</sub>  | V <sub>CC</sub> -0.5 | V <sub>CC</sub> +0.3 | V    |                           |
|                                         | DCLK, ON/OFF                                       |                  | 2.2                  | V <sub>CC</sub> +0.3 | V    |                           |
|                                         | All others                                         |                  | 2.0                  | V <sub>CC</sub> +0.3 | V    |                           |
| Input low voltage                       | All others                                         | V <sub>IL</sub>  | -0.3                 | 0.8                  | V    |                           |
| Output high voltage                     | TTL Interface <sup>1</sup>                         | V <sub>OH</sub>  | 2.4                  |                      | V    | I <sub>OH</sub> = -400 μA |
|                                         | CMOS Interface <sup>1</sup>                        |                  | V <sub>CC</sub> -0.8 |                      | V    | I <sub>OH</sub> = -400 μA |
| Output low voltage                      | TTL Interface                                      | V <sub>OL</sub>  |                      | 0.4                  | V    | I <sub>OL</sub> = 1.6 mA  |
|                                         | CMOS Interface                                     |                  |                      | 0.8                  | V    | I <sub>OL</sub> = 400 μA  |
| Input leakage current                   | All inputs except DB <sub>0</sub> -DB <sub>7</sub> | I <sub>IL</sub>  | -2.5                 | +2.5                 | μA   |                           |
| Three state (off-state) leakage current | DB <sub>0</sub> -DB <sub>7</sub>                   | I <sub>TSL</sub> | -10                  | +10                  | μA   |                           |
| Current dissipation <sup>2</sup>        |                                                    | I <sub>CC</sub>  |                      | 10                   | mA   |                           |

Notes: 1 TTL Interface; MA0-MA15, RA0-RA4, DISPTMG, CUDISP, DB0-DB7, MCLK  
C-MOS Interface, LU0-LU3, LD0-LD3, CL1, CL2, M, FLM

2 Input/output current is excluded. When input is at the intermediate level with CMOS, excessive current flows through the input circuit to power supply. Input level must be fixed at high or low to avoid this condition.

3. If the capacity loads of LU0-LU3 and LD0-LD3 exceed the rating, noise over 0.8 V may be produced on CUDISP, DISPTMG, MCLK, FLM and M. In case the loads of LU0-LU3 and LD0-LD3 are larger than the ratings, supply signals to the LCD module through buffers



## AC Characteristics

CPU Interface (HD63645F — 68 family)

| Item                                               | Symbol            | Min | Typ | Max | Unit | Figure |
|----------------------------------------------------|-------------------|-----|-----|-----|------|--------|
| Enable cycle time                                  | t <sub>CYCE</sub> | 500 |     |     | ns   | 33     |
| Enable pulse width (high)                          | P <sub>WEH</sub>  | 220 |     |     | ns   |        |
| Enable pulse width (low)                           | P <sub>WEL</sub>  | 220 |     |     | ns   |        |
| Enable rise time                                   | t <sub>Er</sub>   |     | 25  |     | ns   |        |
| Enable fall time                                   | t <sub>Ef</sub>   |     | 25  |     | ns   |        |
| CS, RS, R/W setup time                             | t <sub>AS</sub>   | 70  |     |     | ns   |        |
| CS, RS, R/W hold time                              | t <sub>AH</sub>   | 10  |     |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> setup time        | t <sub>DS</sub>   | 60  |     |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> hold time         | t <sub>DHW</sub>  | 10  |     |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> output delay time | t <sub>DDR</sub>  |     |     | 150 | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> output hold time  | t <sub>DHR</sub>  | 20  |     |     | ns   |        |



Figure 33. CPU Interface (HD63645F)

**CPU Interface (HD64645F — 80 family)**

| Item                                               | Symbol | Min | Typ | Max | Unit | Figure |
|----------------------------------------------------|--------|-----|-----|-----|------|--------|
| RD high level width                                | tWRDH  | 190 |     |     | ns   | 34     |
| RD low level width                                 | tWRDL  | 190 |     |     | ns   |        |
| WR high level width                                | tWWDH  | 190 |     |     | ns   |        |
| WR low level width                                 | tWWDL  | 190 |     |     | ns   |        |
| CS, RS setup time                                  | tAS    | 0   |     |     | ns   |        |
| CS, RS hold time                                   | tAH    | 0   |     |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> setup time        | tdSW   | 60  |     |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> hold time         | tdHW   | 0   |     |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> output delay time | tDDR   |     | 150 |     | ns   |        |
| DB <sub>0</sub> -DB <sub>7</sub> output hold time  | tDHR   | 20  |     |     | ns   |        |

**Figure 34. CPU Interface (HD64645F)**

**AC Characteristics (Cont)****Memory Interface**

| Item                  | Symbol | Min | Typ | Max | Unit | Figure |
|-----------------------|--------|-----|-----|-----|------|--------|
| DCLK cycle time       | tCYCD  | 100 |     |     | ns   | 35     |
| DCLK high level width | tWDH   | 30  |     |     | ns   |        |
| DCLK low level width  | tWDL   | 30  |     |     | ns   |        |
| DCLK rise time        | tDr    |     |     | 20  | ns   |        |
| DCLK fall time        | tDf    |     |     | 20  | ns   |        |
| MCLK delay time       | tDMD   |     |     | 70  | ns   |        |
| MCLK rise time        | tMr    |     |     | 30  | ns   |        |
| MCLK fall time        | tMf    |     |     | 30  | ns   |        |
| MA0-MA15 delay time   | tMAD   |     |     | 150 | ns   |        |
| MA0-MA15 hold time    | tMAH   | 10  |     |     | ns   |        |
| RA0-RA4 delay time    | tRAD   |     |     | 150 | ns   |        |
| RA0-RA4 hold time     | tRAH   | 10  |     |     | ns   |        |
| DISPTMG delay time    | tDTD   |     |     | 150 | ns   |        |
| DISPTMG hold time     | tDTH   | 10  |     |     | ns   |        |
| CUDISP delay time     | tCDD   |     |     | 150 | ns   |        |
| CUDISP hold time      | tCDH   | 10  |     |     | ns   |        |
| CL1 delay time        | tCL1D  |     |     | 150 | ns   |        |
| CL1 hold time         | tCL1H  | 10  |     |     | ns   |        |
| CL1 rise time         | tCL1r  |     |     | 50  | ns   |        |
| CL1 fall time         | tCL1f  |     |     | 50  | ns   |        |
| MD0-MD15 setup time   | tMDS   | 80  |     |     | ns   |        |
| MD0-MD15 hold time    | tMDH   | 15  |     |     | ns   |        |





Figure 35. Memory Interface



**AC Characteristics (Cont)****LCD Interface**

| Item                    | Symbol      | Min | Typ | Max | Unit | Figure |
|-------------------------|-------------|-----|-----|-----|------|--------|
| Display data setup time | $t_{LDS}$   | 50  |     |     | ns   | 36     |
| Display data hold time  | $t_{LDH}$   | 100 |     |     | ns   |        |
| CL2 high level width    | $t_{WCL2H}$ | 100 |     |     | ns   |        |
| CL2 low level width     | $t_{WCL2L}$ | 100 |     |     | ns   |        |
| FLM setup time          | $t_{FS}$    | 500 |     |     | ns   |        |
| FLM hold time           | $t_{FH}$    | 300 |     |     | ns   |        |
| CL1 rise time           | $t_{CL1r}$  |     | 50  |     | ns   |        |
| CL1 fall time           | $t_{CL1f}$  |     | 50  |     | ns   |        |
| CL2 rise time           | $t_{CL2r}$  |     | 50  |     | ns   |        |
| CL2 fall time           | $t_{CL2f}$  |     | 50  |     | ns   |        |

Note: At fCL2 = 3 MHz



Figure 36. LCD Interface

## AC Characteristics

### TTL Load

| Terminal                           | $R_L$          | $R$           | $C$    | Remarks                |
|------------------------------------|----------------|---------------|--------|------------------------|
| DB <sub>0</sub> -DB <sub>7</sub>   | 2.4 k $\Omega$ | 11 k $\Omega$ | 130 pF | tr, tf : Not specified |
| MA0-MA15, RA0-RA4, DISPTMG, CUDISP | 2.4 k $\Omega$ | 11 k $\Omega$ | 40 pF  |                        |
| MCLK                               | 2.4 k $\Omega$ | 11 k $\Omega$ | 30 pF  | tr, tf : Specified     |



### Capacity Load

| Terminal            | $C$    | Remarks                |
|---------------------|--------|------------------------|
| CL2                 | 150 pF | tr, tf : Specified     |
| CL1                 | 200 pF |                        |
| LU0-LU3, LD0-LD3, M | 150 pF | tr, tf : Not specified |
| FLM                 | 50 pF  |                        |



## Package Dimensions

Unit: mm (inches)

FP-80



Note: Inch value indicated for your reference.



# HD64941

## ACI (Asynchronous Communications Interface)

### -ADVANCE INFORMATION-

The HD64941 (ACI) is a universal asynchronous data communications controller chip that interfaces directly to most 8-bit microprocessors and may be used in a polled or interrupt-driven system environment. The HD64941 accepts programmed instructions from the microprocessor while supporting asynchronous serial data communications in full- or half-duplex mode.

The HD64941 serializes parallel data characters received from the microprocessor for transmission. Simultaneously, it can receive serial data and convert it into parallel data characters for input to the microcomputer.

The HD64941 contains a baud rate generator which can be programmed to either accept an external clock or to generate internal transmit or receive clocks. Sixteen different baud rates can be selected under program control when operating in the internal clock mode.

#### ■ FEATURES

- 5- to 8-bit characters plus parity
- 1, 1½ or 2 stop bits transmitted
- Odd, even or no parity
- Parity, overrun and framing error detection
- Line break detection and generation
- False start bit detection
- Automatic serial echo mode (echoplex)
- Local or remote maintenance loopback mode
- Baud rate:
  - DC to 1M bps (1 x clock)
  - DC to 62.5k bps (16 x clock)
  - DC to 15.625k bps (64 x clock)
- Internal or external baud rate clock
- 16 internal rates
- Double-buffered transmitter and receiver
- Single +5V power supply
- Signetics SCN2641 compatible

HD64941



(DP-24N)

#### ■ PIN ARRANGEMENT



## ■ BLOCK DIAGRAM



Figure 1 ACI Block Diagram

## ■ APPLICATIONS

- Intelligent terminals
- Network processors
- Front-end processors
- Remote data concentrators
- Serial peripherals



Figure 2 Asynchronous Interface to CRT Terminal



Figure 3 Asynchronous Interface to Telephone Lines



# HD146818

## RTC(Real Time Clock Plus RAM)

The HD146818 is a HMCS6800 peripheral CMOS device which combines three unique features: a complete time-of-day clock with alarm and one hundred calendar, a programmable periodic interrupt and square-wave generator, and 50 bytes of Low-power static RAM.

This device includes HD6801, HD6301 multiplexed bus interface circuit and 8085's multiplexed bus interface as well, so it can be directly connected to HD6801, HD6301 and 8085.

The Real-Time Clock plus RAM has two distinct uses. First, it is designed as battery powered CMOS part including all the common battery backed-up functions such as RAM, time, and calendar. Secondly, the HD146818 may be used with a CMOS microprocessor to relieve the software of timekeeping workload and to extend the available RAM of an MPU such as the HD6301.

### ■ FEATURES

- Time-of-Day Clock and Calendar
  - Counts Seconds, Minutes, and Hours of the Day
  - Counts Days of Week, Date, Month, and Year
- Binary or BCD Representation of Time, Calendar, and Alarm
- 12- or 24 Hour Clock with AM and PM in 12-Hour Mode
- Automatic End of Month Recognition
- Automatic Leap Year Compensation
- Interfaced with Software as 64 RAM Locations
  - 14 Bytes of Clock and Control Register
  - 50 Bytes of General Purpose RAM
- Three Interrupt are Separately Software Maskable and Testable
  - Time-of-Day Alarm, Once-per-Second to Once-per-Day
  - Periodic Rates from 30.5 $\mu$ s to 500ms
  - End-of-Clock Update Cycle
- Programmable Square-Wave Output Signal
- Three Time Base Input Options
  - 4.194304 MHz
  - 1.048576 MHz
  - 32.768 kHz
- Clock Output May be used as Microprocessor Clock Input
  - At Time Base Frequency  $\div 4$  or  $\div 1$
- Multiplexed Bus Interface Circuit of HD6801, HD6301 and 8085
- Low-Power, High-Speed, High-Density CMOS
- Battery Backed-up Operation
- Motorola MC146818 Compatible
- HD146818A in Development



### ■ PIN ARRANGEMENT



(Top View)

### ■ ABSOLUTE MAXIMUM RATINGS

| Item                  | Symbol            | Value       | Unit |
|-----------------------|-------------------|-------------|------|
| Supply Voltage        | V <sub>cc</sub> * | -0.3 ~ +7.0 | V    |
| Input Voltage         | V <sub>in</sub> * | -0.3 ~ +7.0 | V    |
| Operating Temperature | T <sub>opr</sub>  | 0 ~ +70     | °C   |
| Storage Temperature   | T <sub>stg</sub>  | -55 ~ +150  | °C   |

\* With respect to V<sub>ss</sub> (SYSTEM GND)

(NOTE) Permanent LSI damage may occur if maximum rating are exceeded. Normal operation should be under recommended operating condition. If these conditions are exceeded, it could affect reliability of LSI.



## ■ RECOMENDED OPERATING CONDITIONS

| Item                  | Symbol     | min          | typ | max      | Unit |
|-----------------------|------------|--------------|-----|----------|------|
| Supply Voltage        | $V_{CC}$ * | 4.5          | 5.0 | 5.25     | V    |
| Input Voltage         | $V_{IL}$ * | -0.3         | -   | 0.7      | V    |
|                       | $V_{IH}$ * | $V_{CC}-1.0$ | -   | $V_{CC}$ | V    |
| Operating Temperature | $T_{opr}$  | 0            | 25  | 70       | °C   |

\* With respect to  $V_{SS}$  (SYSTEM GND)

(NOTE) Refer to Battery Backed-up Electrical characteristics.

## ■ ELECTRICAL CHARACTERISTICS

- DC CHARACTERISTICS ( $V_{CC} = 4.5 \sim 5.25V$ ,  $V_{SS} = 0V$ ,  $T_a = 0 \sim +70^{\circ}C$ , unless otherwise noted.)

| Item                                      | Symbol                                                               | Test Condition | min                         | typ          | max      | Unit    |    |
|-------------------------------------------|----------------------------------------------------------------------|----------------|-----------------------------|--------------|----------|---------|----|
| Input "High" Voltage                      | $AD_0 \sim AD_7$ , $\overline{CE}$ , AS, R/W, DS, CKFS, PS           | $V_{IH}$       | $V_{CC}-2.0$                | -            | $V_{CC}$ | V       |    |
|                                           | $\overline{RES}$                                                     |                | $V_{CC}-1.0$                | -            | $V_{CC}$ |         |    |
|                                           | $OSC_1$                                                              |                | $V_{CC}-1.0$                | -            | $V_{CC}$ |         |    |
| Input "Low" Voltage                       | $AD_0 \sim AD_7$ , $\overline{CE}$ , AS, R/W, DS, CKFS, PS           | $V_{IL}$       | -0.3                        | -            | 0.7      | V       |    |
|                                           | $\overline{RES}$                                                     |                | -0.3                        | -            | 0.8      |         |    |
|                                           | $OSC_1$                                                              |                | -0.3                        | -            | 0.8      |         |    |
| Input Leakage Current                     | $OSC_1$ , $\overline{CE}$ , AS, R/W, DS, $\overline{RES}$ , CKFS, PS | $ I_{in} $     | -                           | -            | 2.5      | $\mu A$ |    |
| Three-state (off state) Input Current     | $AD_0 \sim AD_7$                                                     | $ I_{TSI} $    | -                           | -            | 10       | $\mu A$ |    |
| Output Leakage Current                    | $\overline{IRQ}$                                                     | $I_{LOH}$      | -                           | -            | 10       | $\mu A$ |    |
| Output "High" Voltage                     | $AD_0 \sim AD_7$                                                     | $V_{OH}$       | $I_{OH} = -1.6 \text{ mA}$  | 4.1          | -        | -       | V  |
|                                           | SQW, CKOUT                                                           |                | $I_{OH} < -10 \mu A$        | $V_{CC}-0.1$ | -        | -       | V  |
|                                           | $AD_0 \sim AD_7$                                                     |                | $I_{OL} = 1.6 \text{ mA}$   | $V_{OL}$     | -        | -       | V  |
| Output "Low" Voltage                      | SQW, CKOUT                                                           |                | $I_{OL} = 1.6 \text{ mA}$   |              | -        | -       | V  |
|                                           | $AD_0 \sim AD_7$                                                     |                | $I_{OL} = 1.6 \text{ mA}$   |              | -        | -       | V  |
|                                           | CKOUT                                                                |                | $I_{OL} = 1.6 \text{ mA}$   |              | -        | -       | V  |
| Input Capacitance                         | $AD_0 \sim AD_7$                                                     | $C_{in}$       | -                           | -            | 12.5     | pF      |    |
|                                           | All inputs except $AD_0 \sim AD_7$                                   |                | -                           | -            | 12.5     | pF      |    |
|                                           | SQW, CKOUT, $\overline{IRQ}$                                         |                | -                           | -            | 12.5     | pF      |    |
| Supply Current (MPU Read/Write operating) | $f_{osc} = 4 \text{ MHz}$                                            | $I_{CC}^*$     | $V_{CC} = 5.0V$             | -            | -        | 10      | mA |
|                                           | $f_{osc} = 1 \text{ MHz}$                                            |                | SQW: disable                | -            | -        | 7       |    |
|                                           | $f_{osc} = 32 \text{ kHz}$                                           |                | CKOUT = $f_{osc}$ (No Load) | -            | -        | 5       |    |
|                                           | $f_{osc} = 4 \text{ MHz}$                                            |                | $t_{cyc} = 1 \mu s$         | -            | -        | 5       |    |
|                                           | $f_{osc} = 1 \text{ MHz}$                                            |                | Circuit: Fig. 11            | -            | -        | 2       |    |
|                                           | $f_{osc} = 32 \text{ kHz}$                                           |                | Parameter: Table 1          | -            | 300      | 500     |    |
|                                           | $f_{osc} = 4 \text{ MHz}$                                            |                | -                           | -            | 100      | $\mu A$ |    |
| Supply Current (MPU Read/Write operating) | $f_{osc} = 1 \text{ MHz}$                                            | $I_{CC}^*$     | $V_{CC} = 5.0V$             | -            | -        | 10      | mA |
|                                           | $f_{osc} = 32 \text{ kHz}$                                           |                | SQW: disable                | -            | -        | 7       |    |
|                                           | $f_{osc} = 4 \text{ MHz}$                                            |                | CKOUT = $f_{osc}$ (No Load) | -            | -        | 5       |    |
|                                           | $f_{osc} = 1 \text{ MHz}$                                            |                | $OSC_2$ : open              | -            | -        | 4       |    |
|                                           | $f_{osc} = 32 \text{ kHz}$                                           |                | $t_{cyc} = 1 \mu s$         | -            | -        | 1       |    |
|                                           | $f_{osc} = 4 \text{ MHz}$                                            |                | Circuit: Fig. 17            | -            | 60       | 100     |    |
| Supply Current (MPU not operating)        | $f_{osc} = 1 \text{ MHz}$                                            | $I_{CC}^*$     | $V_{CC} = 5.0V$             | -            | -        | 10      | mA |
|                                           | $f_{osc} = 32 \text{ kHz}$                                           |                | SQW: disable                | -            | -        | 7       |    |
|                                           | $f_{osc} = 4 \text{ MHz}$                                            |                | CKOUT = $f_{osc}$ (No Load) | -            | -        | 5       |    |
|                                           | $f_{osc} = 1 \text{ MHz}$                                            |                | $OSC_2$ : open              | -            | -        | 4       |    |
|                                           | $f_{osc} = 32 \text{ kHz}$                                           |                | $t_{cyc} = 1 \mu s$         | -            | -        | 1       |    |
|                                           | $f_{osc} = 4 \text{ MHz}$                                            |                | Circuit: Fig. 17            | -            | 60       | 100     |    |

\* Supply current of HD146818 is defined as the value when the time-base frequency to be used is programmed into Register A. When power is turned on, these bits are unfixed, so there is a case that current more than the above specification may flow.

Please never fail to set the time-base frequency after turning on power supply.

\*\*  $V_{IH \ min} = V_{CC}-0.2V$

$V_{IL \ max} = V_{SS}+0.2V$



- AC CHARACTERISTICS ( $V_{CC} = 4.5 \sim 5.25V$ ,  $V_{SS} = 0V$ ,  $T_a = 0 \sim +70^\circ C$ , unless otherwise noted.)
- BUS TIMING

| Item                                                           | Symbol      | min | typ | max | Unit |
|----------------------------------------------------------------|-------------|-----|-----|-----|------|
| Cycle Time                                                     | $t_{cyc}$   | 953 | —   | —   | ns   |
| Pulse Width, AS/ALE "High"                                     | $t_{PWAH}$  | 100 | —   | —   | ns   |
| AS Rise Time                                                   | $t_{ASr}$   | —   | —   | 30  | ns   |
| AS Fall Time                                                   | $t_{ASf}$   | —   | —   | 30  | ns   |
| Delay Time DS/E to AS/ALE Rise                                 | $t_{ASD}$   | 40  | —   | —   | ns   |
| DS Rise Time                                                   | $t_{DSr}$   | —   | —   | 30  | ns   |
| DS Fall Time                                                   | $t_{DSf}$   | —   | —   | 30  | ns   |
| Pulse Width, DS/E Low or $\overline{RD}/\overline{WR}$ "High"  | $t_{PWDH}$  | 325 | —   | —   | ns   |
| Pulse Width, DS/E High or $\overline{RD}/\overline{WR}$ "Low"  | $t_{PWDSL}$ | 300 | —   | —   | ns   |
| Delay Time, AS/ALE to DS/E Rise                                | $t_{ASDS}$  | 90  | —   | —   | ns   |
| Address Setup Time ( $R/\overline{W}$ )                        | $t_{AS1}$   | 15  | —   | —   | ns   |
| Address Setup Time ( $\overline{CE}$ )                         | $t_{AS2}$   | 55  | —   | —   | ns   |
| Address Hold Time ( $R/\overline{W}, \overline{CE}$ )          | $t_{AH}$    | 10  | —   | —   | ns   |
| Muxed Address Valid Time to AS/ALE Fall                        | $t_{ASL}$   | 50  | —   | —   | ns   |
| Muxed Address Hold Time                                        | $t_{AHL}$   | 20  | —   | —   | ns   |
| Peripheral Data Setup Time                                     | $t_{DSW}$   | 195 | —   | —   | ns   |
| Write Data Hold Time                                           | $t_{DHW}$   | 0   | —   | —   | ns   |
| Peripheral Output Data Delay Time From DS/E or $\overline{RD}$ | $t_{DDR}$   | —   | —   | 220 | ns   |
| Read Data Hold Time                                            | $t_{DHR}$   | 10  | —   | —   | ns   |
| Input Rise and Fall Time                                       | $t_r, t_f$  | —   | —   | 30  | ns   |

## CONTROL SIGNAL TIMING

| Item                              | Symbol     | min | typ | max  | Unit    |
|-----------------------------------|------------|-----|-----|------|---------|
| Oscillator Startup                | $t_{RC}$   | —   | —   | 100  | ms      |
| 32 kHz                            |            | —   | —   | 1000 |         |
| Reset Pulse Width                 | $t_{RWL}$  | 5.0 | —   | —    | $\mu s$ |
| Reset Delay Time                  | $t_{RLH}$  | 5.0 | —   | —    | $\mu s$ |
| Power Sense Pulse Width           | $t_{PWL}$  | 5.0 | —   | —    | $\mu s$ |
| Power Sense Delay Time            | $t_{PLH}$  | 5.0 | —   | —    | $\mu s$ |
| $\overline{IRQ}$ Release from DS  | $t_{IRDS}$ | —   | —   | 2.0  | $\mu s$ |
| $\overline{IRQ}$ Release from RES | $t_{IRR}$  | —   | —   | 2.0  | $\mu s$ |
| VRT Bit Delay                     | $t_{VRTD}$ | —   | —   | 2.0  | $\mu s$ |





(NOTE)  $V_{IH} = V_{OH} = V_{CC} - 2.0V$   
 $V_{IL} = 0.7V$   
 $V_{OL} = 0.5V$

Figure 1 Bus Read, Write Timing (6801 Family)





Figure 2 Read Timing (8085 Family)



Figure 3 Write Timing (8085 Family)

Figure 4  $\overline{\text{IRQ}}$  Release Delay (from DS)Figure 5  $\overline{\text{IRQ}}$  Release Delay (from  $\overline{\text{RES}}$ )

\* The VRT bit is set to a "1" by reading control register #D. There is no additional way to clear the VRT bit.

Figure 6 VRT Bit Clear Timing

Figure 7  $\overline{\text{RES}}$  Release Delay



Figure 8 Test Load

## ■ BATTERY BACKED-UP OPERATION

## ● DEFINITION OF BATTERY BACKED-UP OPERATION

Active functions

(1) Clock function

(2) Retention of RAM data

(3) RES, IRQ, CKFS, CKOUT, PS, SQW functions

Inactive functions

(1) Data bus read/write operation

● BATTERY BACKED-UP ELECTRICAL CHARACTERISTICS ( $V_{SS} = 0\text{V}$ ,  $T_a = 0 \sim +70^\circ\text{C}$ , unless otherwise noted.)

| Item                                 | Symbol              | Test Condition                                                    |                             | min                  | typ | max       | Unit          |
|--------------------------------------|---------------------|-------------------------------------------------------------------|-----------------------------|----------------------|-----|-----------|---------------|
| Supply Voltage                       | $V_{CCL}$           |                                                                   |                             | 2.7                  | —   | 4.5       | V             |
| Supply Current                       | Crystal Oscillation | $V_{CCL} = 3.0\text{V}$<br>SQW : disable<br>CKOUT: fosc (No load) | 4MHz                        | —                    | —   | 600       | $\mu\text{A}$ |
|                                      |                     | 1MHz                                                              | —                           | —                    | —   | 350       | $\mu\text{A}$ |
|                                      | External Clock      | 32kHz                                                             | —                           | 50                   | 100 | 100       | $\mu\text{A}$ |
|                                      |                     | $V_{CCL} = 3.0\text{V}$<br>SQW : disable<br>CKOUT: fosc (No load) | 4MHz                        | —                    | —   | 500       | $\mu\text{A}$ |
| Battery Backed-up Transit Setup Time | $t_{CE}$            | Fig. 9                                                            | 1MHz                        | —                    | —   | 150       | $\mu\text{A}$ |
| Operation Recovery Time              | $t_R$               |                                                                   | 32kHz                       | —                    | —   | 70        | $\mu\text{A}$ |
| Supply Voltage Fall Time             | $t_{PF}$            |                                                                   | —                           | 0                    | —   | —         | ns            |
| Supply Voltage Rise Time             | $t_{PR}$            |                                                                   | —                           | $t_{cyc}$            | —   | —         | ns            |
| Input "High" Voltage                 | $V_{IHL}$           | $V_{CCL} = 2.7\text{V} \sim 3.5\text{V}$                          | $\overline{CE}, PS$<br>CKFS | $0.7 \times V_{CCL}$ | —   | $V_{CCL}$ | V             |
|                                      |                     | $V_{CCL} = 3.5\text{V} \sim 4.5\text{V}$                          | RES                         | $0.8 \times V_{CCL}$ | —   | $V_{CCL}$ | V             |
|                                      |                     | OSC <sub>1</sub>                                                  | OSC <sub>1</sub>            | $0.8 \times V_{CCL}$ | —   | $V_{CCL}$ | V             |
|                                      |                     | CKFS, PS                                                          | —0.3                        | —                    | 0.5 | —         | V             |
| Input "Low" Voltage                  | $V_{ILL}$           | RES                                                               | —0.3                        | —                    | 0.5 | —         | V             |
|                                      |                     | OSC <sub>1</sub>                                                  | —0.3                        | —                    | 0.5 | —         | V             |
|                                      |                     | CKFS, PS                                                          | 0.8 $\times V_{CCL}$        | —                    | —   | —         | V             |
| Output "High" Voltage                | $V_{OHL}$           | $I_{OH} = -800\mu\text{A}$                                        | SQW, CKOUT                  | —                    | —   | —         | V             |
| Output "Low" Voltage                 | $V_{OLL}$           | $I_{OL} = 800\mu\text{A}$                                         | SQW, CKOUT                  | —                    | —   | 0.5       | V             |
|                                      |                     |                                                                   | IRQ                         | —                    | —   | 0.5       | V             |

\* The time-base frequency to be used needs to be chosen in Register A.



Figure 9 Battery Backed-up Timing



Figure 10 Block Diagram



### ■ CRYSTAL OSCILLATION CIRCUIT

The on-chip oscillator is designed for a parallel resonant crystal at 4.194304 MHz or 1.048576 MHz or 32.768 kHz frequencies. The crystal connections are shown in Figure 11.



Figure 11 Crystal Oscillator Connection

### ■ 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, load capacity  $C_{in}$ ,  $C_{out}$ ,  $C_L$  and  $R_f$ ,  $R_s$  must be placed near the LSI as much as possible.  
[Normal oscillation may be disturbed when external noise is induced to pin 2 and 3.]

Table 1 Oscillator Circuit Parameters

| Parameter \ fosc | 4.194304 MHz      | 1.048576 MHz       | 32.768 kHz          |
|------------------|-------------------|--------------------|---------------------|
| $R_s$            | —                 | —                  | 150 k $\Omega$      |
| $R_f$            | 150 k $\Omega$    | 150 k $\Omega$     | 5.6 M $\Omega$      |
| $C_{in}$         | 22 pF             | 33 pF              | 15 pF               |
| $C_{out}$        | 22 pF             | 33 pF              | 33 pF               |
| $C_L$            | —                 | —                  | 33 pF               |
| $C_I$            | 80 $\Omega$ (max) | 700 $\Omega$ (max) | 40 k $\Omega$ (max) |

(NOTE) 1.  $R_s$ ,  $C_L$  are used for 32.768 kHz only.  
2. Capacitance ( $C_{in}$ ) should be adjusted to accurate frequency. Parameters listed above are applied to the supply current measurement (See table of DC CHARACTERISTICS).  
3.  $C_I$ : Crystal Impedance

(2) Pin 3 signal line should be wired apart from pin 4 signal line as much as possible. Don't wire them in parallel, or normal oscillation may be disturbed when this signal is feedbacked to OSC<sub>1</sub>.

(3) A signal line or a power source line must not cross or go near the oscillation circuit line as shown in the right figure to prevent the induction from these lines and perform the correct oscillation. The resistance among OSC<sub>1</sub>, OSC<sub>2</sub> and other pins should be over 10M $\Omega$ .

The following design must be avoided.



Figure 12 Note for Board Design of the Oscillation Circuit

**■ INTERFACE CIRCUIT FOR HD6801, HD6301 AND 8085 PROCESSOR**

HD146818 has a new interface circuit which permits the HD146818 to be directly interfaced with many type of multiplexed bus microprocessor such as HD6801, HD6301 and 8085 etc.



Figure 13 Functional Diagram of the Bus Control Circuit

**■ ADDRESS MAP**

Figure 14 shows the address map of the HD146818. The memory consists of 50 general purpose RAM bytes, 10 RAM bytes which normally contain the time, calendar, and alarm data, and four control and status bytes. All 64 bytes are directly readable and writable by the processor program except Registers C and D which are read only. Bit 7 of Register A and the seconds byte are also read only. Bit 7, of the second byte, always reads "0". The contents of the four control and status registers are described in the Register section.

**● Time, Calendar, and Alarm Locations**

The processor program obtains time and calendar information by reading the appropriate locations. The program

may initialize the time, calendar, and alarm by writing to these RAM locations. The contents of the 10 time, calendar, and alarm byte may be either binary or binary-coded decimal (BCD).

Before initializing the internal registers, the SET bit in Register B should be set to a "1" to prevent time/calendar updates from occurring. The program initializes the 10 locations in the selected format (binary or BCD), then indicates the format in the data mode (DM) bit of Register B. All 10 time, calendar, and alarm bytes must use the same data mode, either binary or BCD. The SET bit may now be cleared to allow updates. Once initialized the real-time clock makes all updates in the selected data mode. The data mode cannot be changed without reinitializing the 10 data bytes.



Figure 14 Address Map



Table 2 shows the binary and BCD formats of the 10 time, calendar, and alarm locations. The 24/12 bit in Register B establishes whether the hour locations represent 1-to-12 or 0-to-23. The 24/12 bit cannot be changed without reinitializing the hour locations. When the 12-hour format is selected the high-order bit of the hours byte represents PM when it is a "1".

The time, calendar, and alarm bytes are not always accessible by the processor program. Once-per-second the 10 bytes are switched to the update logic to be advanced by one second and to check for an alarm condition. If any of the 10 bytes are read at this time, the data outputs are undefined. The update lockout time is 248  $\mu$ s at the 4.194304 MHz and 1.048567 MHz time bases and 1948  $\mu$ s for the 32.768 kHz time base. The Update Cycle section shows how to accommodate

the update cycle in the processor program.

The three alarm bytes may be used in two ways. When the program inserts an alarm time in the appropriate hours, minutes, and seconds alarm locations, the alarm interrupt is initiated at the specified time each day if the alarm enable bit is "1". The alternate usage is to insert a "don't care" state in one or more of three alarm bytes. The "don't care" code is any hexadecimal byte from C0 to FF. That is, the two most-significant bits of each byte, when set to "1", create a "don't care" situation. An alarm interrupt each hour is created with a "don't care" code in the hours alarm location. Similarly, an alarm is generated every minute with "don't care" codes in the hours and minutes alarm bytes. The "don't care" codes in all three alarm bytes create an interrupt every second.

Table 2 Time, Calendar, and Alarm Data Modes

| Address Location | Function                      | Decimal Range | Range                                |                                      | Example*         |               |
|------------------|-------------------------------|---------------|--------------------------------------|--------------------------------------|------------------|---------------|
|                  |                               |               | Binary Data Mode                     | BCD Data Mode                        | Binary Data Mode | BCD Data Mode |
| 0                | Seconds                       | 0~59          | \$00~\$3B                            | \$00~\$59                            | 15               | 21            |
| 1                | Seconds Alarm                 | 0~59          | \$00~\$3B                            | \$00~\$59                            | 15               | 21            |
| 2                | Minutes                       | 0~59          | \$00~\$3B                            | \$00~\$59                            | 3A               | 58            |
| 3                | Minutes Alarm                 | 0~59          | \$00~\$3B                            | \$00~\$59                            | 3A               | 58            |
| 4                | Hours<br>(12 Hour Mode)       | 1~12          | \$01~\$0C (AM) and<br>\$81~\$8C (PM) | \$01~\$12 (AM) and<br>\$81~\$92 (PM) | 05               | 05            |
|                  | Hours<br>(24 Hour Mode)       | 0~23          | \$00~\$17                            | \$00~\$23                            | 05               | 05            |
| 5                | Hours Alarm<br>(12 Hour Mode) | 1~12          | \$01~\$0C (AM) and<br>\$81~\$8C (PM) | \$01~\$12 (AM) and<br>\$81~\$92 (PM) | 05               | 05            |
|                  | Hours Alarm<br>(24 Hour Mode) | 0~23          | \$00~\$17                            | \$00~\$23                            | 05               | 05            |
| 6                | Day of the Week<br>Sunday = 1 | 1~7           | \$01~\$07                            | \$01~\$07                            | 05               | 05            |
| 7                | Day of the Month              | 1~31          | \$01~\$1F                            | \$01~\$31                            | 0F               | 15            |
| 8                | Month                         | 1~12          | \$01~\$0C                            | \$01~\$12                            | 02               | 02            |
| 9                | Year                          | 0~99**        | \$00~\$63                            | \$00~\$99                            | 4F               | 79            |

\* Example: 5:58:21 Thursday 15th February 1979

\*\* Set the lower two digits of year in AD. If this number is multiple of 4, update applied to leap year is excuted.

#### • Static CMOS RAM

The 50 general purpose RAM bytes are not dedicated within the HD146818. They can be used by the processor program, and are fully available during the update cycle.

When time and calendar information must use battery back-up, very frequently there is other non-volatile data that must be retained when main power is removed. The 50 user RAM bytes serve the need for low-power CMOS battery-backed storage, and extend the RAM available to the program.

When further CMOS RAM is needed, additional HD146818s may be included in the system. The time/calendar functions may be disabled by holding the dividers, in Register A, in the reset state by setting the SET bit in Register B or by removing the oscillator. Holding the dividers in reset prevents interrupts or SQW output from operating while setting the SET bit allows these functions to occur. With the dividers clear, the available user RAM is extended to 59 bytes. Bit 7 of Register A, Registers C and D, and the high-order bit of the seconds byte cannot effectively be used as general purpose RAM.

#### ■ INTERRUPTS

The RTC plus RAM includes three separate fully automatic sources of interrupts to the processor. The alarm interrupt may be programmed to occur at rates from once-per-second to one-a-day. The periodic interrupt may be selected for rates from half-a-second to 30.517  $\mu$ s. The update-ended interrupt may be used to indicate to the program that an up-date cycle is completed. Each of these independent interrupt conditions are described in greater detail in other sections.

The processor program selects which interrupts, if any, it wishes to receive. Three bits in Register B enable the three interrupts. Writing a "1" to a interrupt-enable bit permits that interrupt to be initiated when the event occurs. A "0" in the interrupt-enable bit prohibits the  $\overline{IRQ}$  pin from being asserted due to the interrupt cause.

If an interrupt flag is already set when the interrupt becomes enabled, the  $\overline{IRQ}$  pin is immediately activated, though the interrupt initiating the event may have occurred much earlier. Thus, there are cases where the program should clear such



earlier initiated interrupts before first enabling new interrupts.

When an interrupt event occurs a flag bit is set to a "1" in Register C. Each of the three interrupt sources have separate flag bits in Register C, which are set independent of the state of the corresponding enable bits in Register B. The flag bit may be used with or without enabling the corresponding enable bits.

In the software scanned case, the program does not enable the interrupt. The "interrupt" flag bit becomes a status bit, which the software interrogates, when it wishes. When the software detects that the flag is set, it is an indication to software that the "interrupt" event occurred since the bit was last read.

However, there is one precaution. The flag bits in Register C are cleared (record of the interrupt event is erased) when Register C is read. Double latching is included with Register C so the bits which are set are stable throughout the read cycle. All bits which are high when read by the program are cleared, and new interrupts (on any bits) are held until after the read cycle. One, two, or three flag bits may be found to be set when Register C is read. The program should inspect all utilized flag bits every time Register C is read to insure that no interrupts are lost.

The second flag bit usage method is with fully enabled interrupts. When an interrupt-flag bit is set and the corresponding interrupt-enable bit is also set, the  $\overline{\text{IRQ}}$  pin is asserted "Low".  $\overline{\text{IRQ}}$  is asserted as long as at least one of the three interrupt sources has its flag and enable bits both set. The

$\overline{\text{IRQF}}$  bit in Register C is a "1" whenever the  $\overline{\text{IRQ}}$  pin is being driven "Low".

The processor program can determine that the RTC initiated the interrupt by reading Register C. A "1" in bit 7 ( $\overline{\text{IRQF}}$  bit) indicates that one or more interrupts have been initiated by the part. The act of reading Register C clears all the then-active flag bits, plus the  $\overline{\text{IRQF}}$  bit. When the program finds  $\overline{\text{IRQF}}$  set, it should look at each of the individual flag bits in the same byte which have the corresponding interrupt-mask bits set and service each interrupt which is set. Again, more than one interrupt-flag bit may be set.

#### ■ DIVIDER STAGES

The HD146818 has 22 binary-divider stages following the time base as shown in Figure 10. The output of the dividers is a 1 Hz signal to the update-cycle logic. The dividers are controlled by three divider bus (DV2, DV1, and DV0) in Register A.

#### • Divider Control

The divider-control bits have three uses, as shown in Table 3. Three usable operating time bases may be selected (4.194304 MHz, 1.048576 MHz, or 32.768 kHz). The divider chain may be held reset, which allows precision setting of the time. When the divider is changed from reset to an operating time base, the first update cycle is one second later. The divider-control bits are also used to facilitate testing the HD146818.

Table 3 Divider Configurations

| Time-Base Frequency | Divider Bits Register A |     |     | Operation Mode | Divider Reset | Bypass First N-Divider Bits |
|---------------------|-------------------------|-----|-----|----------------|---------------|-----------------------------|
|                     | DV2                     | DV1 | DV0 |                |               |                             |
| 4.194304 MHz        | 0                       | 0   | 0   | Yes            | —             | N = 0                       |
| 1.048576 MHz        | 0                       | 0   | 1   | Yes            | —             | N = 2                       |
| 32.768 kHz          | 0                       | 1   | 0   | Yes            | —             | N = 7                       |
| Any                 | 1                       | 1   | 0   | No             | Yes           | —                           |
| Any                 | 1                       | 1   | 1   | No             | Yes           | —                           |

(NOTE) Other combinations of divider bits are used for test purposes only.

#### • Square-Wave Output Selection

Fifteen of the 22 divider taps are made available to a 1-of-15 selector as shown in Figure 10. The first purpose of selecting a divider tap is to generate a square-wave output signal in the SQW pin. Four bits in Register A establish the square-wave frequency as listed in Table 4. The SQW frequency selection shares the 1-of-15 selector with periodic interrupts.

Once the frequency is selected, the output of the SQW pin may be turned on and off under program control with the square-wave enable (SQWE) bit in Register B. Altering the divider, square-wave output selection bits, or the SQW output-enable bit may generate an asymmetrical waveform at the time of execution. The square-wave output pin has a number of potential uses. For example, it can serve as a frequency standard for external use, a frequency synthesizer, or could be used to generate one or more audio tones under program control.

#### • Periodic Interrupt Selection

The periodic interrupt allows the  $\overline{\text{IRQ}}$  pin to be triggered from once every 500 ms to once every 30.517  $\mu\text{s}$ . The periodic interrupt is separate from the alarm interrupt which may be output from once-per-second to once-per-day.

Table 4 shows that the periodic interrupt rate is selected with the same Register A bits which select the square-wave frequency. Changing one also changes the other. But each function may be separately enabled so that a program could switch between the two features or use both. The SQW pin is enabled by the SQWE bit. Similarly the periodic interrupt is enabled by the PIE bit in Register B.

Periodic interrupt is usable by practically all real-time systems. It can be used to scan for all forms of input from contact closures to serial receive bits or bytes. It can be used in multiplexing displays or with software counters to measure inputs, create output intervals, or await the next needed software function.



Table 4 Periodic Interrupt Rate and Square Wave Output Frequency

| Rate Select Control Register 1 |   |   |   | 4.194304 or 1.048576 MHz Time Base |                      | 32.768 kHz Time Base             |                      |
|--------------------------------|---|---|---|------------------------------------|----------------------|----------------------------------|----------------------|
|                                |   |   |   | Periodic Interrupt Rate $t_{PI}$   | SQW Output Frequency | Periodic Interrupt Rate $t_{PI}$ | SQW Output Frequency |
| 0                              | 0 | 0 | 0 | None                               | None                 | None                             | None                 |
| 0                              | 0 | 0 | 1 | 30.517 $\mu$ s                     | 32.768 kHz           | 3.90625 ms                       | 256 Hz               |
| 0                              | 0 | 1 | 0 | 61.035 $\mu$ s                     | 16.384 kHz           | 7.8125 ms                        | 128 Hz               |
| 0                              | 0 | 1 | 1 | 122.070 $\mu$ s                    | 8.192 kHz            | 122.070 $\mu$ s                  | 8.192 kHz            |
| 0                              | 1 | 0 | 0 | 244.141 $\mu$ s                    | 4.096 kHz            | 244.141 $\mu$ s                  | 4.096 kHz            |
| 0                              | 1 | 0 | 1 | 488.281 $\mu$ s                    | 2.048 kHz            | 488.281 $\mu$ s                  | 2.048 kHz            |
| 0                              | 1 | 1 | 0 | 976.562 $\mu$ s                    | 1.024 kHz            | 976.562 $\mu$ s                  | 1.024 kHz            |
| 0                              | 1 | 1 | 1 | 1.953125 ms                        | 512 Hz               | 1.953125 ms                      | 512 Hz               |
| 1                              | 0 | 0 | 0 | 3.90625 ms                         | 256 Hz               | 3.90625 ms                       | 256 Hz               |
| 1                              | 0 | 0 | 1 | 7.8125 ms                          | 128 Hz               | 7.8125 ms                        | 128 Hz               |
| 1                              | 0 | 1 | 0 | 15.625 ms                          | 64 Hz                | 15.625 ms                        | 64 Hz                |
| 1                              | 0 | 1 | 1 | 31.25 ms                           | 32 Hz                | 31.25 ms                         | 32 Hz                |
| 1                              | 1 | 0 | 0 | 62.5 ms                            | 16 Hz                | 62.5 ms                          | 16 Hz                |
| 1                              | 1 | 0 | 1 | 125 ms                             | 8 Hz                 | 125 ms                           | 8 Hz                 |
| 1                              | 1 | 1 | 0 | 250 ms                             | 4 Hz                 | 250 ms                           | 4 Hz                 |
| 1                              | 1 | 1 | 1 | 500 ms                             | 2 Hz                 | 500 ms                           | 2 Hz                 |

#### Initialization of the Time and the Start Sequence

The first update of the time occurs about 500ms later after the SET bit of control register B is reset. So keep followings in mind when initializing and adjusting the time.

#### Procedure of time initialization

- (1) Set the SET bit of control register B. (SET = "1")
- (2) Set "1" into all the DVO, 1, 2 bits of control register A. (DVO = DV1 = DV2 = "1")
- (3) Set the time and calendar to each RAM.
- (4) Set the frequency in use into DVO, 1 and DV2.
- (5) Reset the SET bit. (SET = "0")



Figure 15 Time Initialization and the First Update

#### Restriction on Time-of-day and Calendar Initialization

There is a case in HD146818 (RTC) that update is not executed correctly if time of day and calendar shown below are initialized. Therefore, initialize the RTC without using time of

day shown below.

| Calendar, Time of day & Status after Update                                                                                                             | Examples                             |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| If 29th 23:59:59 in all the months is initialized, update to 1st in the next month is executed. (Jan. – Dec. However except for Feb. 29th in leap year) | Mar. 29th<br>→ Apr. 1st              |
| If 30th 23:59:59 in Apr., June, Sept., and Nov. is initialized, update to 31st in each month is executed.                                               | Apr. 30th<br>→ Apr. 31st             |
| If Feb. 28th 23:59:59 (not in leap year) is initialized, update to Feb. 29th is executed.                                                               | Feb. 28th, 1983<br>→ Feb. 29th, 1983 |
| If Feb. 28th 23:59:58 (in leap year) is initialized, update to Mar. 1st is executed.                                                                    | Feb. 28th, 1984<br>→ Mar. 1st, 1984  |

#### UPDATE CYCLE

The HD146818 executes an update cycle once-per-second, assuming one of the proper time bases is in place, the divider is not clear, and the SET bit in Register B is clear. The SET bit in the "1" state permits the program to initialize the time and calendar bytes by stopping an existing update and preventing a new one from occurring.

The primary function of the update cycle is to increment the seconds byte, check for overflow, increment the minutes byte when appropriate and so forth through to the year of the century byte. The update cycle also compares each alarm byte with the corresponding time byte and issues an alarm if a match or if a "don't care" code (11XXXXXX) is present in all three positions.

With a 4.194304 MHz or 1.048576 MHz time base the up-

date cycle takes 248  $\mu$ s while a 32.768 kHz time base update cycle takes 1984  $\mu$ s. During the update cycle, the time, calendar, and alarm bytes are not accessible by the processor program. The HD146818 protects the program from reading transitional data. This protection is provided by switching the time, calendar, and alarm portion of the RAM off the microprocessor bus during the entire update cycle. If the processor reads these RAM locations before the update is complete the output will be undefined. The update in progress (UIP) status bit is set during the interval.

A program which randomly accesses the time and date information finds data unavailable statistically once every 4032 attempts. Three methods of accommodating nonavailability during update are usable by the program. In discussing the three methods it is assumed that at random points user programs are able to call a subroutine to obtain the time of day.

The first method of avoiding the update cycle uses the update-ended interrupt. If enabled, an interrupt occurs after every update cycle which indicates that over 999 ms are available to read valid time and date information. During this time a display could be updated or the information could be transferred to continuously available RAM. Before leaving the interrupt service routine, the IRQF bit in Register C should be cleared.

The second method uses the update-in-progress bit (UIP) in Register A to determine if the update cycle is in progress or not. The UIP bit will pulse once-per-second. Statistically, the UIP bit will indicate that time and date information is unavailable once every 2032 attempts. After the UIP bit goes "1", the update cycle begins 244  $\mu$ s later. Therefore, if a "0" is read on the UIP bit, the user has at least 244  $\mu$ s before the time/calendar data will be changed. If a "1" is read in the UIP bit, the time/calendar data may not be valid. The user should avoid interrupt service routines that would cause the

time needed to read valid time/calendar data to exceed 244  $\mu$ s.

The third method uses a periodic interrupt to determine if an update cycle is in progress. The UIP bit in Register A is set "1" between the setting of the PF bit in Register C (see Figure 16). Periodic interrupts that occur at a rate of greater than  $t_{BUC} + t_{UC}$  allow valid time and date information to be read at each occurrence of the periodic interrupt. The reads should be completed within  $(t_{PI} \div 2) + t_{BUC}$  to insure that data is not read during the update cycle.

#### ■ POWER-DOWN CONSIDERATIONS

In most systems, the HD146818 must continue to keep time when system power is removed. In such systems, a conversion from system power to an alternate power supply, usually a battery, must be made. During the transition from system to battery power, the designer of a battery backed-up RTC system must protect data integrity, minimize power consumption, and ensure hardware reliability according to the specification described in the section regarding Battery Backed-up operation.

The chip enable ( $\overline{CE}$ ) pin controls all bus inputs ( $R/\overline{W}$ , DS, AS,  $AD_0 \sim AD_7$ ).  $\overline{CE}$ , when negated, disallows any unintended modification of the RTC data by the bus.  $\overline{CE}$  also reduces power consumption by reducing the number of transitions seen internally.

Power consumption may be further reduced by removing resistive and capacitive loads from the clock out (CKOUT) pin and the squarewave (SQW) pin.

During and after the power source conversion, the  $V_{IN}$  maximum specification must never be exceeded. Failure to meet the  $V_{IN}$  maximum specification can cause a virtual SCR to appear which may result in excessive current drain and destruction of the part.



Figure 16. Update-Ended and Periodic Interrupt Relationship



## ■ SIGNAL DESCRIPTIONS

The block diagram in Figure 10, shows the pin connection with the major internal functions of the HD146818 Real-Time Clock plus RAM. The following paragraphs describe the function of each pin.

### ● V<sub>CC</sub>, V<sub>SS</sub>

DC power is provided to the part on these two pins, V<sub>CC</sub> being the most positive voltage. The minimum and maximum voltages are listed in the Electrical Characteristics tables.

### ● OSC<sub>1</sub>, OSC<sub>2</sub> – Time Base

|       |              |
|-------|--------------|
| Input | Pin No. 2, 3 |
|-------|--------------|

The time base for the time functions may be an external signal or the crystal oscillator. External square waves at 4.194304 MHz, 1.048576 MHz, or 32.768 kHz may be connected to OSC<sub>1</sub> as shown in Figure 17. The time-base frequency to be used is chosen in Register A.



Figure 17 External Time-Base Connection

The on-chip oscillator is designed for a parallel resonant crystal at 4.194304 MHz or 1.048576 MHz or 32.768 kHz frequencies. The crystal connections are shown in Figure 11.

### ● CKOUT – Clock Out

|        |            |
|--------|------------|
| Output | Pin No. 21 |
|--------|------------|

The CKOUT pin is an output at the time-base frequency divided by 1 or 4. A major use for CKOUT is as the input clock to the microprocessor; thereby saving the cost of a second crystal. The frequency of CKOUT depends upon the time-base frequency and the state of the CKFS pin as shown in Table 5.

### ● CKFS – Clock Out Frequency Select

|       |            |
|-------|------------|
| Input | Pin No. 20 |
|-------|------------|

The CKOUT pin is an output at the time-base frequency divided by 1 or 4. CKFS tied to V<sub>CC</sub> causes CKOUT to be the same frequency as the time base at the OSC<sub>1</sub> pin. When CKFS is at V<sub>SS</sub>, CKOUT is the OSC<sub>1</sub> time-base frequency divided

by four. Table 5 summarizes the effect of CKFS.

Table 5 Clock Output Frequencies

| Time Base<br>(OSC <sub>1</sub> )<br>Frequency | Clock Frequency<br>Select Pin<br>(CKFS) | Clock Frequency<br>Output Pin<br>(CKOUT) |
|-----------------------------------------------|-----------------------------------------|------------------------------------------|
| 4.194304 MHz                                  | "High"                                  | 4.194304 MHz                             |
| 4.194304 MHz                                  | "Low"                                   | 1.048576 MHz                             |
| 1.048576 MHz                                  | "High"                                  | 1.048576 MHz                             |
| 1.048576 MHz                                  | "Low"                                   | 262.144 kHz                              |
| 32.768 kHz                                    | "High"                                  | 32.768 kHz                               |
| 32.768 kHz                                    | "Low"                                   | 8.192 kHz                                |

### ● SQW – Square Wave

|        |            |
|--------|------------|
| Output | Pin No. 23 |
|--------|------------|

The SQW pin can output a signal one of 15 of the 22 internal-divider stages. The frequency and output enable of the SQW may be altered by programming Register A, as shown in Table 4. The SQW signal may be turned on and off using a bit in Register B.

### ● AD<sub>0</sub> ~ AD<sub>7</sub> – Multiplexed Bidirectional Address/Data Bus

|              |                |
|--------------|----------------|
| Input/Output | Pin No. 4 ~ 11 |
|--------------|----------------|

Multiplexed bus processors save pins by presenting the address during the first portion of the bus cycle and using the same pins during the second portion for data. Address-then-data multiplexing does not slow the access time of the HD146818 since the bus reversal from address to data is occurring during the internal RAM access time.

The address must be valid just prior to the fall of AS/ALE at which time the HD146818 latches the address from AD<sub>0</sub> to AD<sub>5</sub>. Valid write data must be presented and held stable during the latter portion of the DS or WR pulses. In a read cycle, the HD146818 outputs 8 bits of data during the latter portion of the DS or RD pulses, then ceases driving the bus (returns the output drivers to three-state) when DS falls in the HD6801, HD6301 case or RD rises in the other case.

### ● AS – Multiplexed Address Strobe

|       |            |
|-------|------------|
| Input | Pin No. 14 |
|-------|------------|

A positive going multiplexed address strobe pulse serves to demultiplex the bus. The falling edge of AS or ALE causes the address to be latched within the HD146818. The bus control circuit in the HD146818 also latches the state of the DS pin with the falling edge of AS or ALE.

### ● DS – Data Strobe or Read

|       |            |
|-------|------------|
| Input | Pin No. 17 |
|-------|------------|

The DS pin has two interpretations via the bus control circuit. When emanating from 6801 family type processor,

DS is a positive pulse during the latter portion of the bus cycle, and is variously called DS (data strobe), E (enable), and  $\phi_2$  ( $\phi_2$  clock). During read cycles, DS signifies the time that the RTC is to drive the bidirectional bus. In write cycles, the trailing edge of DS causes the Real-Time Clock plus RAM to latch the written data.

The second interpretation of DS is that of  $\overline{RD}$ ,  $\overline{MEMR}$ , or  $\overline{I/OR}$  emanating from the 8085 type processor. In this case, DS identifies the time period when the real-time clock plus RAM drives the bus with read data. This interpretation of DS is also the same as an output-enable signal on a typical memory.

The bus control circuit, within the HD146818, latches the state of the DS pin on the falling edge of AS/ALE. When 6801 mode, DS must be "Low" during AS/ALE, which is the case with 6801 family multiplexed bus processors. To insure the 8085 mode of this circuit the DS pin must remain "High" during the time AS/ALE is "High".

- $\overline{R/W}$  – Read/Write

|       |            |
|-------|------------|
| Input | Pin No. 15 |
|-------|------------|

The bus control circuit treats the  $\overline{R/W}$  pin in one of two ways. When 6801 family type processor is connected,  $\overline{R/W}$  is a level which indicates whether the current cycle is a read or write. A read cycle is indicated with a "High" level on  $\overline{R/W}$  while DS is "High", whereas a write cycle is a "Low" on  $\overline{R/W}$  during DS

The second interpretation of  $\overline{R/W}$  is as a negative write pulse,  $\overline{WR}$ ,  $\overline{MEMW}$ , and  $\overline{I/Ow}$  from 8085 type processors. This circuit in this mode gives  $\overline{R/W}$  pin the same meaning as the write ( $\overline{W}$ ) pulse on many generic RAMs.

- $\overline{CE}$  – Chip Enable

|       |            |
|-------|------------|
| Input | Pin No. 13 |
|-------|------------|

The chip-enable ( $\overline{CE}$ ) signal must be asserted ("Low") for a bus cycle in which the HD146818 is to be accessed.  $\overline{CE}$  is not latched and must be stable during DS and AS (in the 6801 case) and during  $\overline{RD}$  and  $\overline{WR}$  (in the 8085 case). Bus cycles which take place without asserting  $\overline{CE}$  cause no actions to take place within the HD146818. When  $\overline{CE}$  is "High", the multiplexed bus output is in a high-impedance state.

When  $\overline{CE}$  is "High", all address, data, DS, and  $\overline{R/W}$  inputs from the processor are disconnected within the HD146818. This permits the HD146818 to be isolated from a powered-down processor. When  $\overline{CE}$  is held "High", an unpowered device cannot receive power through the input pins from the real-time clock power source. Battery power consumption can thus be reduced by using a pullup resistor or active clamp on  $\overline{CE}$  when the main power is off.

- $\overline{IRQ}$  – Interrupt Request

|        |            |
|--------|------------|
| Output | Pin No. 19 |
|--------|------------|

The  $\overline{IRQ}$  pin is an active "Low" output of the HD146818 that may be used as an interrupt input to a processor. The  $\overline{IRQ}$  output remains "Low" as long as the status bit causing the

interrupt is present and the corresponding interrupt-enable bit is set. To clear the  $\overline{IRQ}$  pin, the processor program normally reads Register C. The  $\overline{RES}$  pin also clears pending interrupts.

When no interrupt conditions are present, the  $\overline{IRQ}$  level is in the high-impedance state. Multiple interrupting devices may thus be connected to an  $\overline{IRQ}$  bus with one pullup at the processor.

- $\overline{RES}$  – Reset

|       |            |
|-------|------------|
| Input | Pin No. 18 |
|-------|------------|

The  $\overline{RES}$  pin does not affect the clock, calendar, or RAM functions. On powerup, the  $\overline{RES}$  pin must be held "Low" for the specified time,  $t_{PLH}$ , in order to allow the power supply to stabilize. Figure 18 shows a typical representation of the  $\overline{RES}$  pin circuit.

When  $\overline{RES}$  is "Low" the following occurs:

- Periodic Interrupt Enable (PIE) bit is cleared to "0".
- Alarm Interrupt Enable (AIE) bit is cleared to "0".
- Update ended interrupt Enable (UIE) bit is cleared to "0".
- Update ended Interrupt Flag (UF) bit is cleared to "0".
- Interrupt Request status Flag (IRQF) bit is cleared to "0".
- Periodic Interrupt Flag (PF) bit is cleared to "0".
- Alarm Interrupt Flag (AF) bit is cleared to "0".
- $\overline{IRQ}$  pin is in high-impedance state, and
- Square Wave output Enable (SQWE) bit is cleared to "0".

- PS – Power Sense

|       |            |
|-------|------------|
| Input | Pin No. 22 |
|-------|------------|

The power-sense pin is used in the control of the valid RAM and time (VRT) bit in Register C. When the PS pin is "Low" the VRT bit is cleared to "0".

During powerup, the PS pin must be externally held "Low" for the specified time,  $t_{PLH}$ . As power is applied the VRT bit remains "Low" indicating that the contents of the RAM, time registers, and calendar are not guaranteed. When normal opera-



(NOTE) If the RTC is isolated from the MPU or MCU power by a diode drop, care must be taken to meet  $V_{IN}$  requirements.

Figure 18 Typical Powerup Delay Circuit for RES



tion commences PS should be permitted to go "High". Output signal from external power sence circuit will be connected to this input.

#### ■ REGISTERS

The HD146818 has four registers which are accessible to the processor program. The four registers are also fully accessible during the update cycle.

#### ● Register A (\$0A)

| MSB |     |     |     |     |     |     |     | LSB |     |     |     |      |    |       |     | Read/Write Register |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|----|-------|-----|---------------------|
| b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  | SET | PIE | AIE | UIE | SQWE | DM | 24/12 | DSE |                     |
| UIP | DV2 | DV1 | DV0 | RS3 | RS2 | RS1 | RS0 |     |     |     |     |      |    |       |     |                     |

**UIP** — The update in progress (UIP) bit is a status flag that may be monitored by the program. When UIP is a "1" the update cycle is in progress or will soon begin. When UIP is a "0" the update cycle is not in progress and will not be for at least 244  $\mu$ s (for all time bases). This is detailed in Table 6. The time, calendar, and alarm information in RAM is fully available to the program when the UIP bit is zero — it is not in transition. The UIP bit is a read-only bit, and is not affected by Reset. Writing the SET bit in Register B to a "1" inhibit any update cycle and then clear the UIP status bit.

Table 6 Update Cycle Times

| UIP Bit | Time Base (OSC <sub>1</sub> ) | Update Cycle Time (t <sub>UC</sub> ) | Minimum Time Before Update Cycle (t <sub>BUC</sub> ) |
|---------|-------------------------------|--------------------------------------|------------------------------------------------------|
| 1       | 4.194304 MHz                  | 248 $\mu$ s                          | —                                                    |
| 1       | 1.048576 MHz                  | 248 $\mu$ s                          | —                                                    |
| 1       | 32.768 kHz                    | 1984 $\mu$ s                         | —                                                    |
| 0       | 4.194304 MHz                  | —                                    | 244 $\mu$ s                                          |
| 0       | 1.048576 MHz                  | —                                    | 244 $\mu$ s                                          |
| 0       | 32.768 kHz                    | —                                    | 244 $\mu$ s                                          |

**DV2, DV1, DVO** — Three bits are used to permit the program to select various conditions of the 22-stage divider chain. The divider selection bits identify which of the three time-base frequencies is in use. Table 3 shows that time bases of 4.194304 MHz, 1.048576 MHz, and 32.768 kHz may be used. The divider selection bits are also used to reset the divider chain. When the time/calendar is first initialized, the program may start the divider at the precise time stored in the RAM. When the divider reset is removed the first update cycle begins half a second later. These three read/write bits are never modified by the RTC and are not affected by RES.

**RS3, RS2, RS1, RSO** — The four rate selection bits select one of 15 taps on the 22-stage divider, or disable the divider output. The tap selected may be used to generate an output square wave (SQW pin) and/or a periodic interrupt. The program may do one of the following: 1) enable the interrupt with the PIE bit, 2) enable the SQW output pin with the SQWE bit, 3) enable both at the same time at the same rate, or 4) enable neither. Table 4 lists the periodic interrupt rates and the square-wave frequencies that may be chosen with the RS bits. These four bits are read/write bits which are not affected by RES and are never changed by the RTC.

#### ● Register B (\$0B)

| MSB |     |     |     |      |    |       |     | LSB |     |     |     |      |    |       |     | Read/Write Register |
|-----|-----|-----|-----|------|----|-------|-----|-----|-----|-----|-----|------|----|-------|-----|---------------------|
| b7  | b6  | b5  | b4  | b3   | b2 | b1    | b0  | SET | PIE | AIE | UIE | SQWE | DM | 24/12 | DSE |                     |
| SET | PIE | AIE | UIE | SQWE | DM | 24/12 | DSE |     |     |     |     |      |    |       |     |                     |

**SET** — When the SET bit is a "0", the update cycle functions normally by advancing the counts once-per-second. When the SET bit is written to a "1", any update cycle in progress is aborted and the program may initialize the time and calendar bytes without an update occurring in the midst of initializing. SET is a read/write bit which is not modified by RES or internal functions of the HD146818.

**PIE** — The periodic interrupt enable (PIE) bit is a read/write bit which allows the periodic-interrupt flag (PF) bit to cause the IRQ pin to be driven "Low". A program writes a "1" to the PIE bit in order to receive periodic interrupts at the rate specified by the RS3, RS2, RS1, and RSO bits in Control Register A. A "0" in PIE blocks IRQ from being initiated by a periodic interrupt, but the periodic flag (PF) bit is still at the periodic rate. PIE is not modified by any internal HD146818 functions, but is cleared to "0" by a RES.

**AIE** — The alarm interrupt enable (AIE) bit is a read/write bit which when set to a "1" permits the alarm flag (AF) to assert IRQ. An alarm interrupt occurs for each second that the three time bytes equal the three alarm bytes (including a "don't care" alarm code of binary 11XXXXXX). When the AIE bit is a "0", the AF bit does not initiate an IRQ signal. The RES pin clears AIE to "0". The internal functions do not affect the AIE bit.

**UIE** — The UIE (update-ended interrupt enable) bit is a read/write bit which enables the update-end flag (UF) bit to assert IRQ. The RES pin going "Low" or the SET bit going "1" clears the UIE bit.

**SQWE** — When the square-wave enable (SQWE) bit is set to a "1" by the program, a square-wave signal at the frequency specified in the rate selection bits (RS3 to RSO) appears on the SQW pin. When the SQWE bit is set to a "0" the SQW pin is held "Low". The state of SQWE is cleared by the RES pin. SQWE is a read/write bit.

**DM** — The data mode (DM) bit indicates whether time and calendar updates are to use binary or BCD formats. The DM bit is written by the processor program and may be read by the program, but is not modified by any internal functions or RES. A "1" in DM signifies binary data, while a "0" in DM specifies binary-coded-decimal (BCD) data.

**24/12** — The 24/12 control bit establishes the format of the hours bytes as either the 24-hour mode (a "1") or the 12-hour mode (a "0"). This is a read/write bit, which is affected only by the software.

**DSE** — The daylight savings enable (DSE) bit is a read/write bit which allows the program to enable two special updates (when DSE is a "1"). On the last Sunday in April the time increments from 1:59:59 AM to 3:00:00 AM. On the last Sunday in October when the time first reaches 1:59:59 AM it changes to 1:00:00 AM. These special updates do not occur when the DSE bit is a "0". DSE is not changed by any internal operations or reset.



● Register C (\$0C)

|      |     |    |    |    |    |    |    | Read-Only |
|------|-----|----|----|----|----|----|----|-----------|
| b7   | b6  | b5 | b4 | b3 | b2 | b1 | b0 | Register  |
| MSB  | LSB |    |    |    |    |    |    |           |
| IRQF | PF  | AF | UF | 0  | 0  | 0  | 0  |           |

**IRQF** – The interrupt request flag (IRQF) is set to a “1” when one or more of the following are true:

$$PF = PIE = "1"$$

$$AF = AIE = "1"$$

$$UF = UIE = "1"$$

i.e.,  $IRQF = PF \cdot PIE + AF \cdot AIE + UF \cdot UIE$

Any time the IRQF bit is a “1”, the  $\overline{IRQ}$  pin is driven “Low”. All flag bits are cleared after Register C is read by the program or when the  $\overline{RES}$  pin is low. A program write to Register C does not modify any of the flag bits.

**PF** – The periodic interrupt flag (PF) is a read-only bit which is set to a “1” when a particular edge is detected on the selected tap of the divider chain. The RS3 to RSO bits establish the periodic rate. PF is set to a “1” independent of the state of the PIE bit. PF being a “1” initiates an  $\overline{IRQ}$  signal and the IRQF bit when PIE is also a “1”. The PF bit is cleared by a  $\overline{RES}$  or a software read of Register C.

**AF** – A “1” in the AF (alarm interrupt flag) bit indicates that the current time has matched the alarm time. A “1” in the AF causes the  $\overline{IRQ}$  pin to go “Low”, and a “1” to appear in the IRQF bit, when the AIE bit also is a “1”. A  $\overline{RES}$  or a read of Register C clears AF.

**UF** – The update-ended interrupt flag (UF) bit is set after each update cycle. When the UIE bit is a “1”, the “1” in UF causes the IRQF bit to be a “1”, asserting  $\overline{IRQ}$ . UF is cleared by a Register C read or a  $\overline{RES}$ .

**b3 to b0** – The unused bits of Status Register C are read as “0’s”. They can not be written.

● Register D (\$0D)

|     |     |    |    |    |    |    |    | Read Only |
|-----|-----|----|----|----|----|----|----|-----------|
| b7  | b6  | b5 | b4 | b3 | b2 | b1 | b0 | Register  |
| MSB | LSB |    |    |    |    |    |    |           |
| VRT | 0   | 0  | 0  | 0  | 0  | 0  | 0  |           |

**VRT** – The valid RAM and time (VRT) bit indicates the condition of the contents of the RAM, provided the power sense (PS) pin is satisfactorily connected. A “0” appears in the VRT bit when the power-sense pin is “Low”. The processor program can set the VRT bit when the time and calendar are initialized to indicate that the RAM and time are valid. The VRT is a read-only bit which is not modified by the  $\overline{RES}$  pin. The VRT bit can only be set by reading the Register D. For setting this bit, PS signal needs to be “High” level.

**b6 to b0** – The remaining bits of Register D are unused. They cannot be written, but are always read as “0’s”.

■ NOTE FOR USE

Input Signal, which is not necessary for user's application, should be used fixed to “High” or “Low” level. This is applicable to the following signal pins.

CKFS, PS



**RESTRICTION ON HD146818 USAGE (1)**

The daylight saving function can not be performed on the HD146818P (X type). So do not use this function for the system design.

. < Type number > HD146818P (X type . . . . Marked as follows)

**< Restriction on usage >**

Please set "0" to DSE bit (Daylight Saving Enable bit) on initializing the control register B.  
DSE = "1" is prohibited.

**RESTRICTION ON HD146818 USAGE (2)**

Access to HD146818 needs to be performed under following conditions.

- (i) Chip-enable ( $\overline{CE}$ ) must be asserted to active "Low" level only when MPU performs read/write operation from/into internal RAM (Time and Calendar RAM, Control register, User RAM).
- (ii) User RAM and control register must be accessed in less than 1/4 frequency shown below.  
(Example: After one access, non-access cycles more than three cycles are necessary to be inserted.)

[Example 1]



[Example 2]



As shown in the above [example 2], when HD146818 is accessed continuously, continuous access must not be executed over fifty times.

- (iii) The application that User RAM is used for program area should be avoided. (Inhibit continuous access.)
- (iv) Minimize the noise by inserting noise bypass condenser between power supply and ground pin ( $V_{CC}-V_{SS}$ ).  
(Insert noise bypass condenser as near HD146818 as possible.)

**RESTRICTION ON HD146818 USAGE (3)**

Chip-enable ( $\overline{CE}$ ) must be stable between falling edge of DS and rising edge of AS shown below. (Address decoder hazard needs to be externally suppressed in this period.)



---

# HITACHI AMERICA, LTD.

## SEMICONDUCTOR AND IC DIVISION

---

### HEADQUARTERS

Hitachi, Ltd.  
New Marunouchi Bldg., 5-1,  
Marunouchi 1-chome  
Chiyoda-ku, Tokyo 100, Japan  
Tel: Tokyo (03) 212-1111  
Telex: J22395, J22432, J24491,  
J26375 (HITACHY)  
Cable: HITACHY TOKYO

### U.S. SALES OFFICE

Hitachi America, Ltd.  
Semiconductor and IC Division  
2210 O'Toole Avenue  
San Jose, CA 95131  
Tel: 408-435-8300  
Telex: 17-1581  
Twx: 910-338-2103  
Fax: 408-435-2748  
Fax: 408-435-2749  
Fax: 408-435-2782

---

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

#### SOUTH CENTRAL REGION

Hitachi America, Ltd.  
Two Lincoln Centre, Suite 865  
5420 LBJ Freeway  
Dallas, TX 75240  
214/991-4510

#### NORTH CENTRAL REGION

Hitachi America, Ltd.  
500 Park Blvd., Suite 415  
Itasca, IL 60143  
312/773-4864

#### NORTHWEST REGION

Hitachi America, Ltd.  
2210 O'Toole Avenue  
San Jose, CA 95131  
408/435-2200

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

### DISTRICT OFFICES

- Hitachi America, Ltd.  
3800 W. 80th Street, Suite 1050  
Bloomington, MN 55431  
612/896-3444
- Hitachi America, Ltd.  
80 Washington St., Suite 302  
Poughkeepsie, NY 12601  
914/485-3400
- Hitachi America, Ltd.  
6 Parklane Blvd., #558  
Dearborn, MI 48126  
313/271-4410
- 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

## **NOTES**

## **NOTES**

## **NOTES**



**HITACHI®**

We make things possible

Hitachi America, Ltd.  
Semiconductor and IC Division  
2210 O'Toole Avenue, San Jose, CA 95131  
1-408-435-8300

---