



OSBORNE & ASSOCIATES INC.

AN INTRODUCTION  
TO MICROCOMPUTERS  
VOLUME 2

SOME REAL MICROPROCESSORS

*September 1978*

*Contains descriptions of individual  
microprocessors and support devices used  
only with the parent microprocessor*



By Adam Osborne  
With Jerry Kane

# **AN INTRODUCTION TO MICROCOMPUTERS VOLUME 2**

## **SOME REAL MICROPROCESSORS**

**By Adam Osborne  
With Jerry Kane**

**Osborne & Associates, Inc.  
Berkeley, California**

Library of Congress Catalogue Card Number 76-374891

ISBN 0-931988-15-2

Copyright © 1975, 1976, 1977, 1978 by Adam Osborne and Associates, Incorporated

All rights reserved. Printed in the United States of America. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form, or by any means, electronic, mechanical, photocopying, recording or otherwise, without the prior written permission of the publishers. Original bound volume of AN INTRODUCTION TO MICROCOMPUTERS series published in 1975.

**Published By  
Adam Osborne & Associates, Inc.  
P.O. Box 2036  
Berkeley, California, U.S.A. 94702**

**DISTRIBUTORS OF OSBORNE & ASSOCIATES, INC. PUBLICATIONS**

**For information on translations and on book distributors outside of the United States of America,  
please call or write:**

**Osborne & Associates, Inc.**  
P.O. Box 2036  
Berkeley, California 94702  
United States of America  
(415) 548-2805  
TWX 910-366-7277



## **CONTRIBUTING AUTHORS**

The following persons have contributed in the writing of sections of this book in addition to its principal authors:

Susanna Jacobson  
Osborne & Associates, Inc.  
Curt Ingraham  
Osborne & Associates, Inc.



# TABLE OF CONTENTS

| CHAPTER |                                                                    | PAGE       |
|---------|--------------------------------------------------------------------|------------|
| 1       | <b>4-Bit Microprocessors and the TMS1000 Series Microcomputers</b> | <b>1-1</b> |
|         | TMS1000 Programmable Registers                                     | 1-3        |
|         | TMS1000 Memory Addressing Mode                                     | 1-5        |
|         | TMS1000 Status Flags                                               | 1-5        |
|         | TMS1000 Input and Output Logic                                     | 1-5        |
|         | TMS1000 Series Microcomputer Pins and Signals                      | 1-6        |
|         | TMS1000 Series Microcomputer Instruction Execution                 | 1-10       |
|         | TMS1000 Series Microcomputer Instruction Set                       | 1-10       |
|         | The Benchmark Program                                              | 1-10       |
|         | Data Sheets                                                        | 1-D1       |
| 2       | <b>The Mostek 3870 (and Fairchild F8)</b>                          | <b>2-1</b> |
|         | The 3870 One-Chip Microcomputer                                    | 2-3        |
|         | 3870/F8 Programmable Registers                                     | 2-5        |
|         | 3870 Memory Addressing Modes                                       | 2-6        |
|         | 3870/F8 Status Flags                                               | 2-9        |
|         | 3870 Pins and Signals                                              | 2-9        |
|         | 3870 Instruction Timing and Execution                              | 2-11       |
|         | 3870 I/O Ports                                                     | 2-11       |
|         | 3870 Interrupt Logic                                               | 2-13       |
|         | Timer/Counter Logic                                                | 2-15       |
|         | The 3870 Control Code                                              | 2-17       |
|         | The 3870/F8 Instruction Set                                        | 2-19       |
|         | The 3870 Benchmark Program                                         | 2-26       |
|         | The 3850 CPU                                                       | 2-29       |
|         | F8 Programmable Registers and Status Flags                         | 2-31       |
|         | F8 Addressing Modes                                                | 2-31       |
|         | F8 Clock Circuits                                                  | 2-32       |
|         | F8 CPU Pins and Signals                                            | 2-34       |
|         | F8 Timing and Instruction Execution                                | 2-35       |
|         | F8 I/O Ports                                                       | 2-37       |
|         | A Summary of F8 Interrupt Processing                               | 2-37       |
|         | The F8 Instruction Set                                             | 2-37       |
|         | The Benchmark Program                                              | 2-38       |
|         | The 3851 Program Storage Unit (PSU)                                | 2-39       |
|         | The 3851 PSU Read-Only Memory                                      | 2-40       |
|         | 3851 PSU Input/Output Logic                                        | 2-41       |
|         | 3851 PSU Interrupt Logic                                           | 2-42       |
|         | 3851 PSU Programmable Timer Logic                                  | 2-45       |
|         | 3851 PSU Data Transfer Timing                                      | 2-45       |
|         | Using the 3851 PSU in Non-F8 Configurations                        | 2-45       |
|         | The 3861 and 3871 Parallel I/O (PIO) Devices                       | 2-47       |
|         | The 3856 and 3857 16K Programmable Storage Units (16K PSU)         | 2-47       |
|         | Additional F8 Support Devices                                      | 2-49       |
|         | The 3852 Dynamic Memory Interface (DMI)                            | 2-49       |
|         | The 3854 Direct Memory Access (DMA) Device                         | 2-53       |
|         | The 3853 Static Memory Interface (SMI)                             | 2-54       |
|         | Data Sheets                                                        | 2-D1       |
| 3       | <b>The National Semiconductor SC/MP</b>                            | <b>3-1</b> |
|         | SC/MP Programmable Registers                                       | 3-3        |
|         | Addressing Modes                                                   | 3-4        |
|         | SC/MP Status Register                                              | 3-5        |
|         | SC/MP CPU Signals and Pin Assignments                              | 3-5        |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>   |                                                              | <b>PAGE</b> |
|------------------|--------------------------------------------------------------|-------------|
| <b>3 (Cont.)</b> | SC/MP Timing and Instruction Execution                       | 3-7         |
|                  | SC/MP Bus Access Logic                                       | 3-8         |
|                  | SC/MP Input/Output Operations                                | 3-10        |
|                  | The SC/MP Halt State                                         | 3-13        |
|                  | SC/MP Interrupt Processing                                   | 3-14        |
|                  | SC/MP DMA and Multiprocessor Operations                      | 3-17        |
|                  | The SC/MP Reset Operation                                    | 3-21        |
|                  | SC/MP Serial Input/Output Operations                         | 3-21        |
|                  | The SC/MP Instruction Set                                    | 3-22        |
|                  | The Benchmark Program                                        | 3-28        |
|                  | Support Devices for the SC/MP CPU                            | 3-29        |
|                  | Using Other Microcomputer Support Devices with the SC/MP CPU | 3-31        |
|                  | Data Sheets                                                  | 3-D1        |
| <b>4</b>         | <b>The 8080A</b>                                             | <b>4-1</b>  |
|                  | The 8080A CPU                                                | 4-3         |
|                  | 8080A Programmable Registers                                 | 4-3         |
|                  | 8080A Addressing Modes                                       | 4-4         |
|                  | 8080A Status                                                 | 4-5         |
|                  | 8080A CPU Pins and Signals                                   | 4-6         |
|                  | 8080A Timing and Instruction Execution                       | 4-7         |
|                  | Clock Signals                                                | 4-8         |
|                  | Instruction Fetch Sequence                                   | 4-12        |
|                  | A Memory Read or Write Operation                             | 4-12        |
|                  | Separate Stack Memory Modules                                | 4-12        |
|                  | The Wait State                                               | 4-13        |
|                  | The Wait, Hold and Halt States                               | 4-16        |
|                  | The Hold State                                               | 4-17        |
|                  | The Halt State and Instruction                               | 4-19        |
|                  | The Reset Operation                                          | 4-19        |
|                  | External Interrupts                                          | 4-21        |
|                  | External Interrupts During the Halt State                    | 4-24        |
|                  | Wait and Hold Conditions Following an Interrupt              | 4-24        |
|                  | The 8080A Instruction Set                                    | 4-24        |
|                  | The Benchmark Program                                        | 4-25        |
|                  | Instruction Execution Times and Codes                        | 4-33        |
|                  | Support Devices that may be Used with the 8080A              | 4-46        |
|                  | The 8224 Clock Generator and Driver                          | 4-46        |
|                  | The 8224 Clock Generator Pins and Signals                    | 4-46        |
|                  | The 8228 and 8238 System Controller and Bus Driver           | 4-48        |
|                  | Bus Driver Logic                                             | 4-48        |
|                  | Control Signal Logic                                         | 4-49        |
|                  | 8228 System Controller Pins and Signals                      | 4-49        |
|                  | The 8259 Priority Interrupt Control Unit (PICU)              | 4-52        |
|                  | 8259 PICU Pins and Signals                                   | 4-52        |
|                  | The 8259 PICU Interrupt Acknowledge Vector                   | 4-54        |
|                  | 8259 PICU Priority Arbitration Options                       | 4-57        |
|                  | How Interrupt Requests and Priority Status are Recorded      | 4-60        |
|                  | Programming the 8259 PICU                                    | 4-62        |
|                  | The TMS 5501 Multifunction Input/Output Controller           | 4-67        |
|                  | TMS 5501 Device Pins and Signals                             | 4-67        |
|                  | TMS 5501 Device Access                                       | 4-70        |
|                  | TMS 5501 Interrupt Handling                                  | 4-74        |
|                  | TMS 5501 Parallel I/O Operations                             | 4-75        |
|                  | TMS 5501 Serial I/O Operation                                | 4-75        |
|                  | TMS 5501 Interval Timers                                     | 4-76        |
|                  | Data Sheets                                                  | 4-D1        |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b> |                                                                 | <b>PAGE</b> |
|----------------|-----------------------------------------------------------------|-------------|
| 5              | <b>The 8085</b>                                                 | 5-1         |
|                | The 8085A CPU                                                   | 5-2         |
|                | 8085A Programmable Registers                                    | 5-3         |
|                | 8085A Addressing Modes                                          | 5-3         |
|                | 8085A Status                                                    | 5-3         |
|                | 8085A CPU Pins and Signals                                      | 5-3         |
|                | A Comparison of 8085A and 8080A Signals                         | 5-7         |
|                | 8085A Timing and Instruction Execution                          | 5-7         |
|                | The Clock Signals                                               | 5-8         |
|                | Memory Access Sequences                                         | 5-9         |
|                | Bus Idle Machine Cycles                                         | 5-18        |
|                | The Wait State                                                  | 5-20        |
|                | The SID and SOD Signals                                         | 5-21        |
|                | The Hold State                                                  | 5-24        |
|                | The Halt State and Instruction                                  | 5-26        |
|                | External Interrupts                                             | 5-28        |
|                | The Reset Operation                                             | 5-32        |
|                | The 8085A Instruction Set                                       | 5-34        |
|                | 8085A Microprocessor Support Devices                            | 5-35        |
|                | The 8155/8156 Static Read/Write Memory with I/O Ports and Timer | 5-35        |
|                | 8155/8156 Device Pins and Signals                               | 5-35        |
|                | 8155/8156 Parallel Input/Output                                 | 5-38        |
|                | 8155/8156 Device Addressing                                     | 5-39        |
|                | The 8155/8156 Counter/Timer                                     | 5-41        |
|                | 8155/8156 Control and Status Registers                          | 5-43        |
|                | 8155/8156 Device Programming                                    | 5-43        |
|                | The 8355 Read-Only Memory with I/O                              | 5-45        |
|                | 8355 Device Pins and Signals                                    | 5-45        |
|                | 8355 Ready Logic                                                | 5-49        |
|                | 8355 I/O Logic                                                  | 5-50        |
|                | The 8755A Erasable Programmable Read-Only Memory with I/O       | 5-51        |
|                | Data Sheets                                                     | 5-D1        |
| 6              | <b>The 8048 Microcomputer Devices</b>                           | 6-1         |
|                | The 8048, 8748, 8049, 8749 and 8035 Microcomputers              | 6-2         |
|                | An 8048 and 8049 Functional Overview                            | 6-3         |
|                | 8048, 8748, and 8035 Microcomputer Programmable Registers       | 6-7         |
|                | 8048 Series Addressing Modes                                    | 6-8         |
|                | A Program Memory Map                                            | 6-12        |
|                | 8048 Series Status                                              | 6-13        |
|                | 8048 Series Microcomputer Operating Modes                       | 6-14        |
|                | 8048 Series Microcomputer Pins and Signals                      | 6-15        |
|                | 8048 Series Timing and Instruction Execution                    | 6-18        |
|                | Internal Execution Mode                                         | 6-18        |
|                | External Memory Access Mode                                     | 6-20        |
|                | Debug Mode                                                      | 6-23        |
|                | Single Stepping                                                 | 6-23        |
|                | Programming Mode                                                | 6-24        |
|                | Verification Mode                                               | 6-26        |
|                | Input/Output Programming                                        | 6-26        |
|                | Hold State                                                      | 6-26        |
|                | Counter/Timer Operations                                        | 6-27        |
|                | Internal and External Interrupts                                | 6-27        |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>   |                                                          | <b>PAGE</b> |
|------------------|----------------------------------------------------------|-------------|
| <b>6 (Cont.)</b> | The 8048 Microcomputer Series Instruction Set            | 6-32        |
|                  | The Benchmark Program                                    | 6-32        |
|                  | The 8041 Slave Microcomputer                             | 6-41        |
|                  | An 8041 Functional Overview                              | 6-42        |
|                  | 8041 Data Bus Logic                                      | 6-43        |
|                  | 8041 I/O Ports One and Two                               | 6-44        |
|                  | 8041 and 8741 Programmable Registers                     | 6-44        |
|                  | 8041 and 8741 Addressing Modes                           | 6-44        |
|                  | 8041 and 8741 Status                                     | 6-45        |
|                  | 8041 and 8741 Slave Microcomputer Operating Modes        | 6-45        |
|                  | 8041 and 8741 Pins and Signals                           | 6-45        |
|                  | 8041 Series Timing and Instruction Execution             | 6-46        |
|                  | 8741 Single Stepping and Programming Mode                | 6-46        |
|                  | 8041 Input/Output Programming                            | 6-46        |
|                  | 8041 Counter/Timer Operations                            | 6-47        |
|                  | 8041 Interrupt Logic                                     | 6-47        |
|                  | Programming 8048-8041 Data Transfers                     | 6-47        |
|                  | The 8041/8741 Instruction Set                            | 6-49        |
|                  | The 8021 Single-Chip Microcomputer                       | 6-51        |
|                  | An 8021 Functional Overview                              | 6-51        |
|                  | 8021 I/O Port Pins                                       | 6-51        |
|                  | The T1 Pin                                               | 6-51        |
|                  | The 8021 Reset Input                                     | 6-52        |
|                  | The 8021 Clock Inputs                                    | 6-53        |
|                  | The 8021 Timer/Counter                                   | 6-53        |
|                  | 8021 Scratchpad Memory and Programming                   | 6-53        |
|                  | The 8243 Input/Output Expander                           | 6-53        |
|                  | 8243 Input/Output Expander Pins and Signals              | 6-53        |
|                  | 8243 Input/Output Expander Operations                    | 6-55        |
|                  | Data Sheets                                              | 6-D1        |
| <b>7</b>         | <b>Zilog Z80</b>                                         | <b>7-1</b>  |
|                  | The Z80 CPU                                              | 7-1         |
|                  | A Summary of Z80/8080A Differences                       | 7-1         |
|                  | Z80 Programmable Registers                               | 7-5         |
|                  | Z80 Addressing Modes                                     | 7-6         |
|                  | Z80 Status                                               | 7-7         |
|                  | Z80 CPU Pins and Signals                                 | 7-7         |
|                  | Z80-8080A Signal Compatibility                           | 7-9         |
|                  | Z80 Timing and Instruction Execution                     | 7-11        |
|                  | Instruction Fetch Execution Sequences                    | 7-12        |
|                  | A Memory Read Operation                                  | 7-13        |
|                  | Memory Write Operation                                   | 7-13        |
|                  | The Wait State                                           | 7-14        |
|                  | Input or Output Generation                               | 7-14        |
|                  | Bus Requests                                             | 7-15        |
|                  | External Interrupts                                      | 7-16        |
|                  | The Halt Instruction                                     | 7-19        |
|                  | The Z80 Instruction Set                                  | 7-38        |
|                  | Input/Output Instructions                                | 7-38        |
|                  | Primary Memory Reference Instructions                    | 7-39        |
|                  | Block Transfer and Search Instructions                   | 7-39        |
|                  | Secondary Memory Reference (Memory Operate) Instructions | 7-41        |
|                  | Immediate Instructions                                   | 7-41        |
|                  | Jump Instructions                                        | 7-41        |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>   |                                                                 | <b>PAGE</b> |
|------------------|-----------------------------------------------------------------|-------------|
| <b>7 (Cont.)</b> |                                                                 |             |
|                  | Subroutine Call and Return Instructions                         | 7-41        |
|                  | Immediate Operate Instructions                                  | 7-41        |
|                  | Jump-on-Condition Instructions                                  | 7-41        |
|                  | Register-Register Move Instructions                             | 7-42        |
|                  | Register-Register Operate Instructions                          | 7-42        |
|                  | Register Operate Instructions                                   | 7-42        |
|                  | Bit Manipulation Instructions                                   | 7-42        |
|                  | Stack Instructions                                              | 7-43        |
|                  | Interrupt Instructions                                          | 7-43        |
|                  | Status and Miscellaneous Instructions                           | 7-44        |
|                  | The Benchmark Program                                           | 7-44        |
|                  | Support Devices that may be Used with the Z80                   | 7-44        |
|                  | The Z80 Parallel I/O Interface (PIO)                            | 7-45        |
|                  | Z80 PIO Pins and Signals                                        | 7-46        |
|                  | Z80 PIO Operating Modes                                         | 7-49        |
|                  | Z80 PIO Interrupt Servicing                                     | 7-51        |
|                  | Programming the Z80 PIO                                         | 7-52        |
|                  | The Z80 Clock Timer Circuit (CTC)                               | 7-54        |
|                  | Z80 CTC Functional Organization                                 | 7-54        |
|                  | Z80 CTC Pins and Signals                                        | 7-55        |
|                  | Z80 CTC Operating Modes                                         | 7-57        |
|                  | Z80 CTC Interrupt Logic                                         | 7-60        |
|                  | Programming the Z80 CTC                                         | 7-60        |
|                  | Data Sheets                                                     | 7-D1        |
| <b>9</b>         | <b>The Motorola MC6800</b>                                      | <b>9-1</b>  |
|                  | The MC6800 CPU                                                  | 9-3         |
|                  | The MC6800 Programmable Registers                               | 9-3         |
|                  | MC6800 Memory Addressing Modes                                  | 9-3         |
|                  | MC6800 Status Flags                                             | 9-5         |
|                  | MC6800 CPU Pins and Signals                                     | 9-6         |
|                  | MC6800 Timing and Instruction Execution                         | 9-7         |
|                  | The Hold State, the Halt State and Direct Memory Access         | 9-10        |
|                  | Interrupt Processing, Reset and the Wait State                  | 9-12        |
|                  | The MC6800 Instruction Set                                      | 9-16        |
|                  | The Benchmark Program                                           | 9-17        |
|                  | MC6800 Summary of Cycle by Cycle Operation                      | 9-25        |
|                  | Support Devices that may be Used with the MC6800                | 9-31        |
|                  | The MC6802 CPU with Read/Write Memory                           | 9-33        |
|                  | The MC6870 Two Phase Clocks                                     | 9-39        |
|                  | The MC6870A Clock Device                                        | 9-41        |
|                  | The MC6871A Clock Device                                        | 9-41        |
|                  | The MC6871B Clock Device                                        | 9-43        |
|                  | The MC6875 Clock Device                                         | 9-44        |
|                  | Some Standard Clock Signal Interface Logic                      | 9-44        |
|                  | The MC6820 and MCS6520 Peripheral Interface Adapter (PIA)       | 9-45        |
|                  | The MC6820 PIA Pins and Signals                                 | 9-45        |
|                  | MC6820 Operations                                               | 9-48        |
|                  | The MC6850 Asynchronous Communications Interface Adapter (ACIA) | 9-55        |
|                  | The MC6850 ACIA Pins and Signals                                | 9-55        |
|                  | MC6850 Data Transfer and Control Operations                     | 9-57        |
|                  | MC6850 ACIA Control Codes and Status Flags                      | 9-59        |
|                  | The MC6852 Synchronous Serial Data Adapter (SSDA)               | 9-61        |
|                  | MC6852 SSDA Pins and Signals                                    | 9-61        |
|                  | MC6852 Data Transfer and Control Operations                     | 9-63        |
|                  | MC6852 Status Register                                          | 9-65        |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>   |                                                                          | <b>PAGE</b> |
|------------------|--------------------------------------------------------------------------|-------------|
| <b>9 (Cont.)</b> |                                                                          |             |
|                  | The MC6852 Control Registers                                             | 9-66        |
|                  | Programming the MC6852                                                   | 9-70        |
|                  | The MC8507 (or MC6828) Priority Interrupt Controller (PIC)               | 9-71        |
|                  | MC6828 Pins and Signals                                                  | 9-72        |
|                  | The Interrupt Acknowledge Process                                        | 9-74        |
|                  | Interrupt Priorities                                                     | 9-75        |
|                  | Interrupt Inhibit Logic                                                  | 9-77        |
|                  | The MC6840 Programmable Counter/Timer                                    | 9-78        |
|                  | The MC6840 Counter/Timer Pins and Signals                                | 9-78        |
|                  | MC6840 Addressing                                                        | 9-82        |
|                  | MC6840 Counter/Timer Programmable Options                                | 9-94        |
|                  | The MC6844 Direct Memory Access Controller                               | 9-106       |
|                  | MC6844 DMA Controller Pins and Signals                                   | 9-107       |
|                  | MC6844 Addressable Registers                                             | 9-109       |
|                  | MC6844 DMA Transfer Modes                                                | 9-110       |
|                  | MC6844 DMAC Three-State Control, Cycle Stealing Mode                     | 9-111       |
|                  | MC6844 DMAC Halt Modes                                                   | 9-113       |
|                  | Comparing MC6844 DMAC Modes                                              | 9-116       |
|                  | Using an MC6844 DMAC with Mixed Modes                                    | 9-116       |
|                  | The MC6844 Control Registers and Operating Options                       | 9-116       |
|                  | Resetting the MC6844 DMAC                                                | 9-122       |
|                  | Programming the MC6844 DMAC                                              | 9-122       |
|                  | The MC6846 Multifunction Support Device                                  | 9-124       |
|                  | MC6846 Multifunction Device Pins and Signals                             | 9-124       |
|                  | MC6846 Counter/Timer Logic                                               | 9-127       |
|                  | MC6846 I/O Port Logic                                                    | 9-128       |
|                  | MC6846 Device Reset                                                      | 9-129       |
|                  | Data Sheets                                                              | 9-D1        |
| <b>10</b>        |                                                                          |             |
|                  | <b>The MOS Technology MCS6500</b>                                        | <b>10-1</b> |
|                  | The MCS6500 Series CPUs                                                  | 10-2        |
|                  | MCS6500 Series CPU Programmable Registers                                | 10-3        |
|                  | MCS6500 Memory Addressing Modes                                          | 10-4        |
|                  | MCS6500 Status Flags                                                     | 10-6        |
|                  | MCS6500 CPU Pins and Signals                                             | 10-7        |
|                  | MCS6500 Timing and Instruction Execution                                 | 10-13       |
|                  | Interrupt Processing and System Reset                                    | 10-15       |
|                  | MCS6500 CPU Clock Logic                                                  | 10-15       |
|                  | MCS6500 CPU Interface Logic                                              | 10-15       |
|                  | The MCS6500 Instruction Set                                              | 10-16       |
|                  | The Benchmark Program                                                    | 10-16       |
|                  | Support Devices that may be Used with the MCS6500 Series Microprocessors | 10-27       |
|                  | The MCS6522 Peripheral Interface Adapter                                 | 10-29       |
|                  | MCS6522 PIA Pins and Signals                                             | 10-30       |
|                  | MCS6522 Parallel Data Transfer Operations                                | 10-33       |
|                  | MCS6522 Interval Timer Logic                                             | 10-36       |
|                  | MCS6522 Shifter Logic                                                    | 10-42       |
|                  | MCS6522 Interrupt Logic                                                  | 10-46       |
|                  | The MCS6530 Multifunction Support Logic Device                           | 10-47       |
|                  | MCS6530 Multifunction Device Pins and Signals                            | 10-47       |
|                  | MCS6530 Parallel Data Transfer Operations                                | 10-51       |
|                  | MCS6530 Interval Timer and Interrupt Logic                               | 10-51       |
|                  | The MCS6532 Multifunction Support Logic Device                           | 10-53       |
|                  | MCS6532 Multifunction Device Pins and Signals                            | 10-54       |
|                  | MCS6532 Logic Functions                                                  | 10-55       |
|                  | Data Sheets                                                              | 10-D1       |

## TABLE OF CONTENTS (Continued)

| CHAPTER |                                                                | PAGE        |
|---------|----------------------------------------------------------------|-------------|
| 11      | <b>The Signetics 2650A</b>                                     | <b>11-1</b> |
|         | The 2650A CPU Logic                                            | 11-1        |
|         | 2650A Programmable Registers                                   | 11-3        |
|         | The 2650A Memory Addressing Modes                              | 11-4        |
|         | The 2650A Status Flags                                         | 11-8        |
|         | The 2650A CPU Pins and Signals                                 | 11-10       |
|         | Interfacing Memory to the 2650A Microcomputer                  | 11-12       |
|         | Interfacing I/O Devices to the 2650A Microcomputer             | 11-12       |
|         | The 2650A Microcomputer Instruction Process                    | 11-12       |
|         | 2650A Microcomputer Direct Memory Access                       | 11-14       |
|         | The 2650A Microcomputer Instruction Set                        | 11-14       |
|         | The 2650A Benchmark Program                                    | 11-15       |
|         | Support Devices that may be Used with the 2650A Microprocessor | 11-23       |
|         | Data Sheets                                                    | 11-D1       |
| 12      | <b>The RCA COSMAC</b>                                          | <b>12-1</b> |
|         | The COSMAC CPU                                                 | 12-2        |
|         | COSMAC Programmable Registers                                  | 12-2        |
|         | COSMAC Memory Addressing Modes                                 | 12-4        |
|         | COSMAC Status Flags                                            | 12-5        |
|         | COSMAC CPU Pins and Signals                                    | 12-5        |
|         | COSMAC Timing and Instruction Execution                        | 12-8        |
|         | COSMAC Memory Read Timing                                      | 12-11       |
|         | COSMAC Memory Write Instruction Timing                         | 12-11       |
|         | COSMAC Data Input, Data Output, and Direct Memory Access       | 12-12       |
|         | A Summary of COSMAC Interrupt Processing                       | 12-17       |
|         | The COSMAC Instruction Set                                     | 12-17       |
|         | The Benchmark Program                                          | 12-23       |
|         | Using COSMAC with Other Microprocessor Support Devices         | 12-32       |
|         | The CDP1852 Parallel I/O Port                                  | 12-33       |
|         | CDP1852 Pins and Signals                                       | 12-33       |
|         | CDP1852 Operations Overview                                    | 12-33       |
|         | CDP1852 Input Operations                                       | 12-34       |
|         | CDP1852 Output Operations                                      | 12-37       |
|         | Data Sheets                                                    | 12-D1       |
| 13      | <b>IM6100 Microcomputer Devices</b>                            | <b>13-1</b> |
|         | The IM6100 CPU                                                 | 13-2        |
|         | IM6100 Programmable Registers                                  | 13-3        |
|         | IM6100 Memory Space                                            | 13-3        |
|         | IM6100 Memory Addressing Modes                                 | 13-3        |
|         | IM6100 Status Flags                                            | 13-6        |
|         | IM6100 CPU Pins and Signals                                    | 13-6        |
|         | IM6100 Timing and Instruction Execution                        | 13-9        |
|         | IM6100 No Operation Machine Cycle                              | 13-10       |
|         | IM6100 Data Input Machine Cycle                                | 13-10       |
|         | IM6100 Data Output Machine Cycle                               | 13-10       |
|         | IM6100 Address Demultiplexing                                  | 13-11       |
|         | IM6100 Memory Read Machine Cycle Timing                        | 13-13       |
|         | IM6100 Memory Write Machine Cycle                              | 13-14       |
|         | IM6100 Input/Output Timing                                     | 13-18       |
|         | IM6100 Wait State                                              | 13-22       |
|         | IM6100 Hold and Halt Conditions                                | 13-23       |
|         | IM6100 Direct Memory Access                                    | 13-26       |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>    |                                                                | <b>PAGE</b> |
|-------------------|----------------------------------------------------------------|-------------|
| <b>13 (Cont.)</b> | The IM6100 Reset                                               | 13-29       |
|                   | IM6100 Interrupt Logic                                         | 13-29       |
|                   | IM6100 Control Panel Logic                                     | 13-33       |
|                   | External Control Signal Priorities                             | 13-37       |
|                   | IM6100 Instruction Set                                         | 13-37       |
|                   | The IM6100 Benchmark Program                                   | 13-38       |
|                   | Some Special IM6100 Hardware Considerations                    | 13-47       |
|                   | Implementing a Hardware Stack                                  | 13-47       |
|                   | Support Devices that may be Used with the IM6100               | 13-51       |
|                   | The IM6101 Parallel Interface Element (PIE)                    | 13-53       |
|                   | IM6101 Parallel Interface Element Pins and Signals             | 13-55       |
|                   | IM6101 Functional Logic                                        | 13-56       |
|                   | IM6101 Interrupt Handling Logic                                | 13-62       |
|                   | The IM6102 MEDIC                                               | 13-64       |
|                   | IM6102 MEDIC Pins and Signals                                  | 13-65       |
|                   | The IM6100-IM6102 Interface                                    | 13-69       |
|                   | IM6102 Extended Memory Control                                 | 13-69       |
|                   | IM6102 Extended Memory Programming Considerations              | 13-77       |
|                   | IM6102 Extended Memory Interrupt Considerations                | 13-78       |
|                   | IM6102 Dynamic Memory Refresh and Direct Memory Access Logic   | 13-79       |
|                   | IM6102 Programmable Real-Time Clock Logic                      | 13-83       |
|                   | IM6102 MEDIC Instructions                                      | 13-85       |
|                   | Data Sheets                                                    | 13-D1       |
| <b>14</b>         | <b>The 8X300 (or SMS300)</b>                                   | <b>14-1</b> |
|                   | The 8X300 Microcontroller                                      | 14-1        |
|                   | 8X300 Addressable Registers                                    | 14-3        |
|                   | 8X300 Status Flags                                             | 14-4        |
|                   | 8X300 Memory Addressing                                        | 14-4        |
|                   | 8X300 Pins and Signals                                         | 14-5        |
|                   | 8X300 Instruction Execution and Timing                         | 14-6        |
|                   | The 8X300 Instruction Set                                      | 14-9        |
|                   | The 8X300 Benchmark Program                                    | 14-17       |
|                   | The 8T32, 8T33, 8T35, and 8T36 Interface Vector Byte (IV Byte) | 14-21       |
|                   | 8T32/3/5/6 IV Byte Pins and Signals                            | 14-21       |
|                   | 8T32/3/5/6 IV Byte Operation                                   | 14-23       |
|                   | 8T32/3/5/6 IV Byte Addresses                                   | 14-24       |
|                   | The 8T39 and 8T58 Bus Expanders                                | 14-26       |
|                   | Data Sheets                                                    | 14-D1       |
| <b>15</b>         | <b>The National Semiconductor PACE and INS8900</b>             | <b>15-1</b> |
|                   | PACE and INS8900 Microcomputer System Overviews                | 15-2        |
|                   | INS8900 Programmable Registers                                 | 15-4        |
|                   | INS8900 Stack                                                  | 15-5        |
|                   | INS8900 and PACE Addressing Modes                              | 15-6        |
|                   | INS8900 and PACE Status and Control Flags                      | 15-9        |
|                   | INS8900 and PACE CPU Pins and Signals                          | 15-10       |
|                   | INS8900 and PACE Timing and Instruction Execution              | 15-11       |
|                   | The Initialization Operation                                   | 15-14       |
|                   | The Halt State and Processor Stall Operations                  | 15-14       |
|                   | Direct Memory Access Operations                                | 15-15       |
|                   | The INS8900 and PACE Interrupt System                          | 15-19       |
|                   | The INS8900 and PACE Instruction Set                           | 15-24       |
|                   | The Benchmark Program                                          | 15-33       |
|                   | The PACE DP8302 System Timing Element (STE)                    | 15-35       |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>    |                                                                        | <b>PAGE</b> |
|-------------------|------------------------------------------------------------------------|-------------|
| <b>15 (Cont.)</b> | The PACE Bidirectional Transceiver Element (BTE)                       | 15-36       |
|                   | Using Other Microcomputer Support Devices with the PACE and INS8900    | 15-38       |
|                   | Data Sheets                                                            | 15-D1       |
| <b>16</b>         | <b>The General Instrument CP1600</b>                                   | <b>16-1</b> |
|                   | The CP1600 Microcomputer System Overview                               | 16-1        |
|                   | CP1600 Programmable Registers                                          | 16-3        |
|                   | CP1600 Memory Addressing Mode                                          | 16-3        |
|                   | CP1600 Status and Control Flags                                        | 16-6        |
|                   | CP1600 CPU Pins and Signals                                            | 16-6        |
|                   | CP1600 Instruction Timing and Execution                                | 16-10       |
|                   | CP1600 Memory Access Timing                                            | 16-10       |
|                   | The CP1600 Wait State                                                  | 16-12       |
|                   | The CP1600 Halt State                                                  | 16-12       |
|                   | CP1600 Initialization Sequence                                         | 16-13       |
|                   | CP1600 DMA Logic                                                       | 16-13       |
|                   | The CP1600 Interrupt Logic                                             | 16-15       |
|                   | The CP1600 Instruction Set                                             | 16-16       |
|                   | The Benchmark Program                                                  | 16-25       |
|                   | Support Devices that may be Used with the CP1600                       | 16-27       |
|                   | The CP1680 Input/Output Buffer (IOB)                                   | 16-30       |
|                   | CP1680 IOB Pins and Signals                                            | 16-30       |
|                   | CP1680 Addressable Registers                                           | 16-31       |
|                   | The CP1680 Control Register                                            | 16-32       |
|                   | CP1680 Data Transfer Operations                                        | 16-33       |
|                   | The CP1680 Interval Timer                                              | 16-36       |
|                   | CP1680 Interrupt Logic                                                 | 16-37       |
|                   | Data Sheets                                                            | 16-D1       |
| <b>17</b>         | <b>The General Instrument 1650 Series Microcomputers</b>               | <b>17-1</b> |
|                   | A 1650 Functional Overview                                             | 17-1        |
|                   | 1650 Series Microcomputer Programmable Registers                       | 17-4        |
|                   | 1650 Series Microcomputer Memory Addressing Modes                      | 17-6        |
|                   | 1650 Series Microcomputer Pins and Signals                             | 17-6        |
|                   | 1650 Series Microcomputer Instruction Set                              | 17-8        |
|                   | The 1650 Benchmark Program                                             | 17-9        |
|                   | Data Sheets                                                            | 17-D1       |
| <b>18</b>         | <b>The Texas Instruments TMS 9900, TMS 9980, and TMS 9440 Products</b> | <b>18-1</b> |
|                   | The TMS 9900 Microprocessor                                            | 18-2        |
|                   | A TMS 9900 Functional Overview                                         | 18-2        |
|                   | TMS 9900 Programmable Registers                                        | 18-3        |
|                   | TMS 9900 Memory Addressing Modes                                       | 18-6        |
|                   | TMS 9900 I/O Addressing                                                | 18-8        |
|                   | TMS 9900 CPU Pins and Signals                                          | 18-13       |
|                   | TMS 9900 Timing and Instruction Execution                              | 18-15       |
|                   | Memory Access Operations                                               | 18-15       |
|                   | Memory Select Logic                                                    | 18-19       |
|                   | TMS 9900 I/O Instruction Timing                                        | 18-20       |
|                   | The Wait State                                                         | 18-23       |
|                   | The Hold State                                                         | 18-25       |
|                   | The Halt State                                                         | 18-25       |
|                   | TMS 9900 Interrupt Processing Logic                                    | 18-26       |
|                   | The TMS 9900 Reset                                                     | 18-34       |
|                   | The TMS 9900 Load Operation                                            | 18-34       |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>    |                                                                     | <b>PAGE</b> |
|-------------------|---------------------------------------------------------------------|-------------|
| <b>18 (Cont.)</b> |                                                                     |             |
|                   | The TMS 9900 Instruction Set                                        | 18-35       |
|                   | The Benchmark Program                                               | 18-42       |
|                   | The TMS 9980A and the TMS 9981 Microprocessors                      | 18-44       |
|                   | TMS 9980 Series Microprocessor Pins and Signals                     | 18-45       |
|                   | TMS 9980 Series Microprocessor Timing and Instruction Execution     | 18-49       |
|                   | TMS 9980 Series Interrupt Logic                                     | 18-49       |
|                   | The TMS 9980 Series Instruction Set                                 | 18-52       |
|                   | The TMS 9940 Single-Chip Microcomputers                             | 18-52       |
|                   | TMS 9940 Registers and Read/Write Memory                            | 18-54       |
|                   | TMS 9940 CPU Pins and Signal Assignments                            | 18-56       |
|                   | TMS 9940 General Purpose Flags                                      | 18-65       |
|                   | TMS 9940 Timer/Event Counter Logic                                  | 18-65       |
|                   | TMS 9940 Interrupt Logic                                            | 18-65       |
|                   | TMS 9940 Reset                                                      | 18-65       |
|                   | Programming a TMS 9940E Erasable Programmable Read-Only Memory      | 18-66       |
|                   | Loading a Program into TMS 9940 Read/Write Memory                   | 18-66       |
|                   | The TMS 9940 Instruction Set                                        | 18-66       |
|                   | The TIM 9904 Four-Phase Clock Generator/Driver                      | 18-67       |
|                   | The TMS 9901 Programmable System Interface (PSI)                    | 18-70       |
|                   | TMS 9901 Pins and Signals                                           | 18-73       |
|                   | TMS 9901 PSI Interrupt Logic                                        | 18-76       |
|                   | TMS 9901 Data Input and Output                                      | 18-78       |
|                   | TMS 9901 Real-Time Clock Logic                                      | 18-80       |
|                   | TMS 9901 Reset Logic                                                | 18-81       |
|                   | Data Sheets                                                         | 18-D1       |
| <b>19</b>         | <b>Single Chip Nova Minicomputer Central Processing Units</b>       | <b>19-1</b> |
|                   | A Product Overview                                                  | 19-2        |
|                   | Nova Programmable Registers                                         | 19-4        |
|                   | Nova Memory Addressing Modes                                        | 19-5        |
|                   | Nova Status Flags                                                   | 19-10       |
|                   | MicroNova and 9440 CPU Pins and Signals                             | 19-10       |
|                   | CPU Logic and Instruction Execution                                 | 19-17       |
|                   | Arithmetic/Logic Instructions                                       | 19-17       |
|                   | Memory Reference Instructions                                       | 19-20       |
|                   | Input/Output Instructions                                           | 19-20       |
|                   | A Nova Summary                                                      | 19-22       |
|                   | 9440 Timing and Instruction Execution                               | 19-23       |
|                   | MicroNova and 9440 Interrupt Processing                             | 19-27       |
|                   | MicroNova and 9440 Direct Memory Access Logic                       | 19-31       |
|                   | The MicroNova and 9440 Instruction Sets                             | 19-32       |
|                   | The Benchmark Program                                               | 19-32       |
|                   | Data Sheets                                                         | 19-D1       |
| <b>20</b>         | <b>The Intel 8086</b>                                               | <b>20-1</b> |
|                   | The 8086 CPU                                                        | 20-3        |
|                   | 8086 Programmable Registers and Addressing Modes                    | 20-3        |
|                   | 8086 Status                                                         | 20-17       |
|                   | 8086 CPU Pins and Signals                                           | 20-19       |
|                   | 8086 Timing and Instruction Execution                               | 20-25       |
|                   | 8086 Bus Cycles                                                     | 20-26       |
|                   | 8086 Instruction Queue                                              | 20-27       |
|                   | 8086 Memory and I/O Device Read Bus Cycle for Simple Configurations | 20-30       |
|                   | 8086 Memory or I/O Device Write Bus Cycle for Minimum Mode          | 20-31       |
|                   | 8086 Read and Write Bus Cycles for Maximum Mode                     | 20-32       |

## TABLE OF CONTENTS (Continued)

| <b>CHAPTER</b>    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>PAGE</b>                                                                                                                                                                                                 |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>20 (Cont.)</b> | The 8086 Wait State<br>The 8086 Hold State<br>The 8086 Halt State<br>The 8086 Lock<br>The 8086 Processor Wait for Test State<br>The 8086 Processor Escape<br>The 8086 Reset Operation<br>8086 Interrupt Processing<br>Single Stepping Mode<br>The 8086 Instruction Set<br>8086-8080A Instruction Compatibility<br>The Benchmark Program<br>Instruction Execution Times and Codes<br>The Intel 8284 Clock Generator/Driver<br>8284 Clock Generator/Driver Pins and Signals<br>The Intel 8288 Bus Controller<br>8288 Bus Controller Signals and Pin Assignments<br>The 8282/8283 8-Bit Input/Output Port<br>The 8282/8283 Input/Output Port Pins and Signal Assignments<br>The 8286/8287 8-Bit Bidirectional Bus Transceivers<br>8286 and 8287 Bidirectional Bus Transceiver Pins and Signal Assignments<br>Some 8086 Microprocessor Bus Configurations<br>Data Sheets | 20-34<br>20-34<br>20-36<br>20-37<br>20-38<br>20-38<br>20-38<br>20-38<br>20-41<br>20-41<br>20-48<br>20-48<br>20-67<br>20-77<br>20-77<br>20-80<br>20-80<br>20-83<br>20-83<br>20-85<br>20-85<br>20-86<br>20-D1 |
| <b>22</b>         | <b>2900 Series and 6700 Series Chip Slice Products</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>22-1</b>                                                                                                                                                                                                 |
|                   | The 2901/6701 Arithmetic and Logic Unit (ALU)<br>The 2909 Microprogram Sequencer<br>The 2902 Carry Look Ahead<br>Data Sheets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 22-2<br>22-5<br>22-8<br>22-D1                                                                                                                                                                               |
| <b>23</b>         | <b>The MC10800 Series Chip Slice Logic</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>23-1</b>                                                                                                                                                                                                 |
|                   | The MC10800 Arithmetic and Logic Unit Slice<br>The MC10801 Microprogram Control Unit<br>The MC10802 Timing Device<br>The MC10803 Memory Interface Device<br>Data Sheets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 23-3<br>23-5<br>23-6<br>23-6<br>23-D1                                                                                                                                                                       |
| <b>24</b>         | <b>The Hewlett Packard MC2</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>24-1</b>                                                                                                                                                                                                 |
|                   | An MC2 System Overview<br>MC2 Programmable Registers and Status<br>MC2 Memory Addressing Modes<br>Hardware Aspects of the MC2<br>The MC2 Instruction Set<br>The Benchmark Program                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 24-1<br>24-2<br>24-4<br>24-4<br>24-5<br>24-6                                                                                                                                                                |
| <b>25</b>         | <b>Selecting a Microcomputer</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>25-1</b>                                                                                                                                                                                                 |
|                   | Designing Logic with Microcomputers — A Sequence of Events<br>Microcomputer Development Hardware<br>Microcomputer System Software<br>An Economic Example<br>A Look at the Future                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 25-2<br>25-3<br>25-5<br>25-9<br>25-10                                                                                                                                                                       |



## LIST OF FIGURES

| <b>FIGURE</b>                                                                                                                                  | <b>PAGE</b> |
|------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 1-1 Logic of the TMS1000 Series Microcomputer                                                                                                  | 1-2         |
| 1-2 TMS1000 and MC141000 Microcomputer Signals and Pin Assignments                                                                             | 1-6         |
| 1-3 TMS1200 and MC141200 Microcomputer Signals and Pin Assignments                                                                             | 1-7         |
| 1-4 TMS1070 Microcomputer Signals and Pin Assignments                                                                                          | 1-7         |
| 1-5 TMS1270 Microcomputer Signals and Pin Assignments                                                                                          | 1-8         |
| 1-6 TMS1100 Microcomputer Signals and Pin Assignments                                                                                          | 1-8         |
| 1-7 TMS1300 Microcomputer Signals and Pin Assignments                                                                                          | 1-9         |
| 2-1 A Fairchild/Mostek F8 Microcomputer System                                                                                                 | 2-2         |
| 2-2 Logic of the Fairchild/Mostek 3870 Microcomputer                                                                                           | 2-4         |
| 2-3 3870 Microcomputer Signals and Pin Assignments                                                                                             | 2-9         |
| 2-4 Instructions That Move Data Between the Scratchpad and Various Registers                                                                   | 2-26        |
| 2-5 Logic of the Fairchild F8 3850 CPU                                                                                                         | 2-30        |
| 2-6 Fairchild 3850 CPU Signals and Pin Assignments                                                                                             | 2-34        |
| 2-7 Logic of the Fairchild F8 3851, 3856, and 3857 Programmable Storage Unit                                                                   | 2-39        |
| 2-8 3851 PSU Signals and Pin Assignments                                                                                                       | 2-40        |
| 2-9 Conceptual Logic to Include a 3851 PSU in a Non-F8 Microcomputer System                                                                    | 2-46        |
| 2-10 3856 PSU Signals and Pin Assignments                                                                                                      | 2-48        |
| 2-11 3857 PSU Signals and Pin Assignments                                                                                                      | 2-49        |
| 2-12 Logic of the Fairchild F8 3852 Dynamic Memory Interface (DMI), and of the 3854 Direct Memory Access (DMA) Devices                         | 2-50        |
| 2-13 3852 DMI Signals and Pin Assignments                                                                                                      | 2-52        |
| 2-14 3854 DMA Signals and Pin Assignments                                                                                                      | 2-54        |
| 2-15 Logic of the F8 3853 Static Memory Interface (SMI) Device                                                                                 | 2-55        |
| 2-16 3853 SMI Signals and Pin Assignments                                                                                                      | 2-56        |
| 3-1 Logic of the SC/MP Microcomputer                                                                                                           | 3-2         |
| 3-2 SC/MP CPU Signals and Pin Assignments                                                                                                      | 3-6         |
| 3-3 SC/MP Bus Access Logic Processing Sequence                                                                                                 | 3-9         |
| 3-4 Bus Utilization of Each SC/MP Instruction                                                                                                  | 3-11        |
| 3-5 SC/MP Data Input Cycle                                                                                                                     | 3-12        |
| 3-6 SC/MP Data Output Cycle                                                                                                                    | 3-12        |
| 3-7 NHOLD Signal Used to Lengthen SC/MP I/O Operation                                                                                          | 3-13        |
| 3-8 Circuit to Cause Programmed Halt for SC/MP CPU                                                                                             | 3-13        |
| 3-9 SC/MP Interrupt Instruction Fetch Process                                                                                                  | 3-14        |
| 3-10 Using SC/MP in a System with Direct Memory Access                                                                                         | 3-17        |
| 3-11 One Method of Initializing an SC/MP Multiprocessor System                                                                                 | 3-20        |
| 3-12 Forcing the Halt State in an SC/MP Multiprocessor System                                                                                  | 3-20        |
| 3-13 An SC/MP System Showing Typical Support Devices that may be Required                                                                      | 3-29        |
| 3-14 SC/MP Data Lines Buffered Using 8216 Devices                                                                                              | 3-30        |
| 4-1 The 8080A CPU, 8224 Clock and 8228 System Controller Forming a Three-Device Microprocessor                                                 | 4-4         |
| 4-2 8080A CPU Signals and Pin Assignments                                                                                                      | 4-8         |
| 4-3 A Machine Cycle Consisting of Five Clock Periods                                                                                           | 4-8         |
| 4-4 Status Output During T <sub>2</sub> of Every Machine Cycle                                                                                 | 4-10        |
| 4-5 8080A Instruction Fetch Sequence                                                                                                           | 4-13        |
| 4-6 8080A Memory Write Timing                                                                                                                  | 4-14        |
| 4-7 The 8080A CPU Operating With Fast Memory and No Wait State                                                                                 | 4-15        |
| 4-8 The 8080A CPU Operating With Slow Memory and a Normal Wait State                                                                           | 4-16        |
| 4-9A Floating of Data and Address Busses at Φ <sub>2</sub> in T <sub>3</sub> , for READ Operation Being Completed Prior to Onset of Hold State | 4-17        |
| 4-9B Floating of Data and Address Busses at Φ <sub>2</sub> in T <sub>4</sub> , for a WRITE, or Any Non-READ Operation (R/WO=False)             | 4-18        |
| 4-10A Floating of Data and Address Busses for READ Operation in a Three Clock Period Machine Cycle                                             | 4-18        |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b> | <b>PAGE</b>                                                                                                                                                          |      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 4-10B         | Floating of Data and Address Busses at $\Phi_2$ in T <sub>1</sub> , for WRITE or Any Non-READ Operation Being Completed Prior to Onset of Hold State                 | 4-18 |
| 4-11          | Interrupt Initiation Sequence                                                                                                                                        | 4-20 |
| 4-12          | Signal Sequences and Timing for Instructions: STC, CMC, CMA, NOP, RLC, RRC, RAL, RAR, XCHG, EI, DI, DAA, ADD R, ADC R, SUB R, SBB R, ANA R, XRA R, ORA R, CMP R      | 4-33 |
| 4-13          | Signal Sequences and Timing for Instructions: INR, DCR, MOV REG REG, SPHL, PCHL, DCX, INX                                                                            | 4-34 |
| 4-14          | Signal Sequences and Timing for Instructions: DCR, INR, MVI M                                                                                                        | 4-34 |
| 4-15          | Signal Sequences and Timing for Instructions: LDAX, MOV REG M, ADI, ACI, SUI, SBI, ANI, XRI, ORI, CPI, MVI R, ADD M, ADC M, SUB M, SBB M, ANA M, XRA M, ORA M, CMP M | 4-35 |
| 4-16          | Signal Sequences and Timing for Instructions: STAX, MOV M REG                                                                                                        | 4-35 |
| 4-17          | Signal Sequences and Timing for Instructions: LHLD                                                                                                                   | 4-36 |
| 4-18          | Signal Sequences and Timing for Instructions: PUSH, RST                                                                                                              | 4-36 |
| 4-19          | Signal Sequences and Timing for Instructions: POP, RET                                                                                                               | 4-37 |
| 4-20          | Signal Sequences and Timing for Instructions: DAD                                                                                                                    | 4-38 |
| 4-21          | Signal Sequences and Timing for Instructions: XTHL                                                                                                                   | 4-38 |
| 4-22          | Signal Sequences and Timing for Instructions: LXI, JMP, JNZ, JZ, JNC, JC, JPO, JPE, JP, JM                                                                           | 4-39 |
| 4-23          | Signal Sequences and Timing for Instructions: STA                                                                                                                    | 4-39 |
| 4-24          | Signal Sequences and Timing for Instructions: LDA                                                                                                                    | 4-40 |
| 4-25          | Signal Sequences and Timing for Instructions: SHLD                                                                                                                   | 4-40 |
| 4-26          | Signal Sequences and Timing for Instructions: CALL, CNZ, CZ, CNC, CC, CPO, CPE, CP, CM                                                                               | 4-41 |
| 4-27          | Signal Sequences and Timing for Instructions: RNZ, RZ, RNC, RC, RPO, RPE, RP, RM                                                                                     | 4-42 |
| 4-28          | Signal Sequences and Timing for Instructions: IN                                                                                                                     | 4-43 |
| 4-29          | Signal Sequences and Timing for Instructions: OUT                                                                                                                    | 4-44 |
| 4-30          | Signal Sequences and Timing for Instructions: HLT                                                                                                                    | 4-45 |
| 4-31          | 8224 Clock Generator Signals and Pin Assignments                                                                                                                     | 4-47 |
| 4-32          | 8228 System Controller Signals and Pin Assignments                                                                                                                   | 4-49 |
| 4-33          | A Standard, Three Device 8080A Microcomputer System                                                                                                                  | 4-51 |
| 4-34          | Timing for Control Signals Output by the 8228 System Controller                                                                                                      | 4-51 |
| 4-35          | 8259 Priority Interrupt Control Unit Signals and Pin Assignments                                                                                                     | 4-53 |
| 4-36          | A System With One PICU                                                                                                                                               | 4-54 |
| 4-37          | A System With Three PICUs -One Master and Two Slaves                                                                                                                 | 4-56 |
| 4-38          | Logic of the TMS 5501 Multifunction Input/Output Controller                                                                                                          | 4-68 |
| 4-39          | TMS 5501 Multifunction Input/Output Controller Signals and Pin Assignments                                                                                           | 4-69 |
| 5-1           | Logic of the 8085A Microprocessor                                                                                                                                    | 5-2  |
| 5-2           | 8085A CPU Signals and Pin Assignments                                                                                                                                | 5-4  |
| 5-3           | A Comparison of 8085A and 8080A/8224/8228 Signal Interface                                                                                                           | 5-6  |
| 5-4           | A Four Clock Period Instruction Fetch Machine Cycle                                                                                                                  | 5-9  |
| 5-5           | A Six Clock Period Instruction Fetch Machine Cycle                                                                                                                   | 5-10 |
| 5-6           | A Memory Read Machine Cycle Following an Instruction Fetch                                                                                                           | 5-15 |
| 5-7           | An I/O Read Machine Cycle Following an Instruction Fetch                                                                                                             | 5-16 |
| 5-8           | A Memory Write Machine Cycle Following an Instruction Fetch                                                                                                          | 5-17 |
| 5-9           | An I/O Write Machine Cycle Following an Instruction Fetch                                                                                                            | 5-18 |
| 5-10          | A Bus Idle Machine Cycle Following an Instruction Fetch During Execution of a DAD Instruction                                                                        | 5-19 |
| 5-11          | Wait States Occurring in a Memory Read Machine Cycle                                                                                                                 | 5-20 |
| 5-12          | A RIM Instruction Followed by a SIM Instruction                                                                                                                      | 5-23 |
| 5-13          | A Hold State Following a Single Machine Cycle Instruction Execution                                                                                                  | 5-23 |
| 5-14          | A Halt Instruction and a Halt State Terminated by an Interrupt Request                                                                                               | 5-26 |
| 5-15          | Hold States Occurring Within a Halt State                                                                                                                            | 5-27 |
| 5-16          | An Interrupt Being Acknowledged Using a Single Byte Instruction                                                                                                      | 5-28 |
| 5-17          | A Bus Idle Instruction Fetch Machine Cycle                                                                                                                           | 5-30 |
| 5-18          | Power On and RESET IN Timing for the 8085A                                                                                                                           | 5-31 |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b> |                                                                                                 | <b>PAGE</b> |
|---------------|-------------------------------------------------------------------------------------------------|-------------|
| 5-19          | Logic of the 8155 and 8156 Multifunction Devices                                                | 5-36        |
| 5-20          | Logic Functions of the 8155/8156 Device                                                         | 5-37        |
| 5-21          | 8155/8156 Multifunction Device Signals and Pin Assignments                                      | 5-37        |
| 5-22          | An 8155 Device Connected to an 8085A CPU Bus                                                    | 5-38        |
| 5-23          | Logic of the 8355 and 8755 Multifunction Devices                                                | 5-46        |
| 5-24          | Logic Functions of the 8355 Device                                                              | 5-47        |
| 5-25          | 8355 Multifunction Device Signals and Pin Assignments                                           | 5-48        |
| 5-26          | An 8085A-8155/8156-8355 Microcomputer System                                                    | 5-48        |
| 5-27          | 8755A Multifunction Device Signals and Pin Assignments                                          | 5-52        |
| 6-1           | Logic of the 8048 Series Microcomputers                                                         | 6-3         |
| 6-2           | Functional Logic of the 8048, 8049, 8748, 8749, and 8035 Microcomputers                         | 6-4         |
| 6-3           | 8048 I/O Ports 1 and 2 Pin Logic                                                                | 6-6         |
| 6-4           | 8048 Series Microcomputers' Memory Addressing                                                   | 6-9         |
| 6-5           | 8048, 8748 and 8035 Microcomputer Pins and Signals                                              | 6-16        |
| 6-6           | Execution of 8048 Single Machine Cycle Instructions Without any External Access                 | 6-19        |
| 6-7           | An 8048 Series External Instruction Fetch                                                       | 6-19        |
| 6-8           | An 8048 Series External Data Read or Write                                                      | 6-20        |
| 6-9           | An 8048-8355 Configuration                                                                      | 6-21        |
| 6-10          | Demultiplexing DB0-DB7 to Create Separate Address and Data Busses                               | 6-21        |
| 6-11          | An 8048 Single Step Circuit                                                                     | 6-24        |
| 6-12          | 8748 EPROM Programming and Verification Timing                                                  | 6-25        |
| 6-13          | An Eight-Device Daisy Chained Interrupt Request/Acknowledge Scheme                              | 6-29        |
| 6-14          | A Low Chip Implementation of an Eight-Device Daisy Chained Interrupt Request/Acknowledge Scheme | 6-31        |
| 6-15          | A Comparison of 8048 and 8041 Functional Logic                                                  | 6-42        |
| 6-16          | 8041 and 8741 Microcomputer Pins and Signals                                                    | 6-45        |
| 6-17          | A Comparison of 8048 and 8021 Functional Logic                                                  | 6-50        |
| 6-18          | 8021 Microcomputer Pins and Signals                                                             | 6-52        |
| 6-19          | Logic of the 8243 Input/Output Expander                                                         | 6-54        |
| 6-20          | Input/Output Expander Pins and Signals                                                          | 6-55        |
| 6-21          | Functional Diagram of the 8243 Input/Output Expander                                            | 6-56        |
| 6-22          | An 8243/8048 Configuration with External Logic Read and Write Strobes                           | 6-57        |
| 6-23          | Timing for Data Output to an 8243 Port Via an MOVD, ORLD, or ANLD Instruction                   | 6-58        |
| 6-24          | Timing for Data Input from an 8243 Port                                                         | 6-58        |
| 7-1           | Logic Functions of the Z80 CPU                                                                  | 7-2         |
| 7-2           | The Standard 8080A Three-Chip System and Z80 Signal Equivalents                                 | 7-3         |
| 7-3           | Z80 Programmable Registers                                                                      | 7-5         |
| 7-4           | Z80 CPU Signals and Pin Assignments                                                             | 7-8         |
| 7-5           | Z80 Instruction Fetch Sequence                                                                  | 7-12        |
| 7-6           | Z80 Memory Read Timing                                                                          | 7-13        |
| 7-7           | Z80 Memory Write Timing                                                                         | 7-13        |
| 7-8           | Z80 Wait State Timing                                                                           | 7-14        |
| 7-9           | Z80 Input or Output Cycles                                                                      | 7-15        |
| 7-10          | Z80 Input or Output Cycles with Wait States                                                     | 7-15        |
| 7-11          | Z80 Bus Timing                                                                                  | 7-16        |
| 7-12          | Z80 Response to a Maskable Interrupt Request                                                    | 7-16        |
| 7-13          | Wait States During Z80 Response to a Maskable Interrupt Request                                 | 7-18        |
| 7-14          | Z80 Response to a Nonmaskable Interrupt Request                                                 | 7-19        |
| 7-15          | Z80 Halt Instruction Timing                                                                     | 7-19        |
| 7-16          | Logic Functions of the Z80 PIO                                                                  | 7-46        |
| 7-17          | Z80 PIO Signals and Pin Assignments                                                             | 7-48        |
| 7-18          | Mode 0 (Output) Timing                                                                          | 7-50        |
| 7-19          | Mode 1 (Input) Timing                                                                           | 7-51        |
| 7-20          | Port A, Mode 2 (Bidirectional) Timing                                                           | 7-51        |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b> |                                                                                                          | <b>PAGE</b> |
|---------------|----------------------------------------------------------------------------------------------------------|-------------|
| 7-21          | Interrupt Acknowledge Timing                                                                             | 7-52        |
| 7-22          | Z80-CTC Signals and Pin Assignments                                                                      | 7-56        |
| 7-23          | Z80-CTC Control Code Interpretation                                                                      | 7-61        |
| 9-1           | Logic of the MC6800 CPU Device                                                                           | 9-4         |
| 9-2           | MC6800 CPU Signals and Pin Assignments                                                                   | 9-5         |
| 9-3           | A Standard MC6800 Read Machine Cycle                                                                     | 9-8         |
| 9-4           | A Standard MC6800 Write Machine Cycle                                                                    | 9-8         |
| 9-5           | TSC Floating the Address Bus                                                                             | 9-10        |
| 9-6           | TSC Floating the Address and Data Busses When DBE is Tied to $\Phi_2$                                    | 9-11        |
| 9-7           | System Bus Floating During the Halt State                                                                | 9-12        |
| 9-8           | MC6800 Interrupt Acknowledge Sequence                                                                    | 9-14        |
| 9-9           | The Reset Sequence                                                                                       | 9-15        |
| 9-10          | MC6800 Wait Instruction Execution Sequence                                                               | 9-16        |
| 9-11          | Use of 8080A Support Devices With MC6800 CPU                                                             | 9-32        |
| 9-12          | Timing for 8080A Support Devices Used With an MC6800 CPU                                                 | 9-33        |
| 9-13          | Logic of the MC6802 CPU Device                                                                           | 9-34        |
| 9-14          | MC6802 CPU Signals and Pin Assignments                                                                   | 9-35        |
| 9-15          | MC6870A Clock Device Pins and Signals                                                                    | 9-39        |
| 9-16          | MC6871A Clock Device Pins and Signals                                                                    | 9-40        |
| 9-17          | MC6871B Clock Device Pins and Signals                                                                    | 9-40        |
| 9-18          | MC6875 Clock Device Pins and Signals                                                                     | 9-41        |
| 9-19          | Logic of the MC6820 PIA                                                                                  | 9-46        |
| 9-20          | MC6820 PIA Signals and Pin Assignments                                                                   | 9-47        |
| 9-21          | Functional Block Diagram for the MC6820 PIA                                                              | 9-48        |
| 9-22          | I/O Port A Control Register Interpretation                                                               | 9-52        |
| 9-23          | I/O Port B Control Register Interpretation                                                               | 9-52        |
| 9-24          | Logic of the MC6850 ACIA or MC6852 SSDA Devices                                                          | 9-56        |
| 9-25          | MC6850 ACIA Signals and Pin Assignments                                                                  | 9-57        |
| 9-26          | MC6852 SSDA Signals and Pin Assignments                                                                  | 9-62        |
| 9-27          | Data Flows Within an MC6852 SSDA                                                                         | 9-64        |
| 9-28          | Logic of the MC6828 Priority Interrupt Controller                                                        | 9-71        |
| 9-29          | MC6828 Signals and Pin Assignments                                                                       | 9-72        |
| 9-30          | MC6840 Counter/Timer Signals and Pin Assignments                                                         | 9-79        |
| 9-31          | Logic of the MC6844 DMA Controller                                                                       | 9-107       |
| 9-32          | MC6844 DMA Controller Signals and Pin Assignments                                                        | 9-108       |
| 9-33          | Timing for Three-State Control. Cycle Stealing Direct Memory Access with the MC6844                      | 9-111       |
| 9-34          | An MC6844 DMAC Connected for Three-State Control. Cycle Stealing Direct Memory Access                    | 9-112       |
| 9-35          | Timing for Halt. Cycle Stealing Direct Memory Access with the MC6844                                     | 9-114       |
| 9-36          | An MC6844 DMAC Connected for Halt. Cycle Stealing or Halt Burst Direct Memory Access                     | 9-115       |
| 9-37          | Logic for MC6844 DMAC with Channel 3 Chained to Channel 0 and Data Flowing into Alternate Memory Buffers | 9-120       |
| 9-38          | Logic of the MC6846 Multifunction Device                                                                 | 9-125       |
| 9-39          | MC6846 Multifunction Device Signals and Pin Assignments                                                  | 9-126       |
| 10-1          | Logic of MCS6500 Series CPU Devices                                                                      | 10-3        |
| 10-2          | MCS6502 Signals and Pin Assignments                                                                      | 10-8        |
| 10-3          | MCS6503 Signals and Pin Assignments                                                                      | 10-8        |
| 10-4          | MCS6504 Signals and Pin Assignments                                                                      | 10-9        |
| 10-5          | MCS6505 Signals and Pin Assignments                                                                      | 10-9        |
| 10-6          | MCS6506 Signals and Pin Assignments                                                                      | 10-10       |
| 10-7          | MCS6512 Signals and Pin Assignments                                                                      | 10-10       |
| 10-8          | MCS6513 Signals and Pin Assignments                                                                      | 10-11       |
| 10-9          | MCS6514 Signals and Pin Assignments                                                                      | 10-11       |
| 10-10         | MCS6515 Signals and Pin Assignments                                                                      | 10-12       |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b> |                                                                                                                                | <b>PAGE</b> |
|---------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|
| 10-11         | Time Base Generation for MCS650X CPU Input Clocks                                                                              | 10-17       |
| 10-12         | Logic of the MCS6522 PIA                                                                                                       | 10-29       |
| 10-13         | MCS6522 PIA Signals and Pin Assignments                                                                                        | 10-31       |
| 10-14         | Auxiliary Control Register Bit Assignments                                                                                     | 10-32       |
| 10-15         | Peripheral Control Register Bit Assignments                                                                                    | 10-34       |
| 10-16         | Logic of the MCS6530 and MCS6532 Multifunction Support Devices                                                                 | 10-48       |
| 10-17         | Logic Provided by the MCS6530 Multifunction Device                                                                             | 10-49       |
| 10-18         | MCS6530 Multifunction Device Signals and Pin Assignments                                                                       | 10-50       |
| 10-19         | Logic Provided by the MCS6532 Multifunction Device                                                                             | 10-53       |
| 10-20         | MCS6532 Multifunction Device Signals and Pin Assignments                                                                       | 10-54       |
| 11-1          | Logic of the 2650A Microcomputer CPU                                                                                           | 11-2        |
| 11-2          | 2650A CPU Signals and Pin Assignments                                                                                          | 11-9        |
| 11-3          | How Control Signals Identify Address and Data Bus Use for the 2650A Microcomputer                                              | 11-13       |
| 11-4          | 2650A-8080A Signal Equivalents                                                                                                 | 11-24       |
| 11-5          | 2650A-MC6800 Signal Equivalents                                                                                                | 11-24       |
| 11-6          | An 8251 USART Accessed by a 2650A as an I/O Device                                                                             | 11-25       |
| 11-7          | An 8251 USART Accessed by a 2650A as a Memory Device                                                                           | 11-25       |
| 11-8          | An 8255 PPI Accessed by a 2650A as an I/O Device                                                                               | 11-26       |
| 11-9          | An 8255 PPI Accessed by a 2650A as a Memory Device                                                                             | 11-26       |
| 11-10         | Vectored Interrupt Using the 8214 PICU with a 2650A CPU                                                                        | 11-27       |
| 11-11         | Synchronization Circuits in a 2650A-MC68XX Interface                                                                           | 11-28       |
| 11-12         | An MC6850 ACIA Connected to a 2650A                                                                                            | 11-29       |
| 11-13         | An MC6820 PIA Connected to a 2650A                                                                                             | 11-29       |
| 11-14         | Important Timing Considerations When Interfacing a 2650A CPU with MC68XX Series Devices                                        | 11-30       |
| 12-1          | Logic of the CDP1802 COSMAC CPU and the CDP1852 I/O Port                                                                       | 12-3        |
| 12-2          | CDP1802 COSMAC CPU Signals and Pin Assignments                                                                                 | 12-6        |
| 12-3          | COSMAC Machine Cycle Timing                                                                                                    | 12-8        |
| 12-4          | COSMAC Memory Read Instruction Timing                                                                                          | 12-10       |
| 12-5          | COSMAC Memory Write Instruction Timing                                                                                         | 12-11       |
| 12-6          | COSMAC DMA-IN Machine Cycle                                                                                                    | 12-12       |
| 12-7          | COSMAC DMA-OUT Machine Cycle                                                                                                   | 12-13       |
| 12-8          | COSMAC I/O Data Input Instruction Execution Timing                                                                             | 12-15       |
| 12-9          | COSMAC I/O Data Output Instruction Execution Timing                                                                            | 12-16       |
| 12-10         | CDP1852 I/O Port Pins and Signals                                                                                              | 12-32       |
| 12-11         | CDP1852 I/O Port in Input Mode with Programmed Input                                                                           | 12-35       |
| 12-12         | CDP1852 I/O Port in Input Mode with DMA Input                                                                                  | 12-36       |
| 12-13         | CDP1852 I/O Port in Output Mode with Programmed Output                                                                         | 12-38       |
| 12-14         | CDP1852 I/O Port in Output Mode with DMA Output                                                                                | 12-39       |
| 13-1          | Logic of the IM6100 CPU and the IM6101 Parallel Interface Element                                                              | 13-2        |
| 13-2          | IM6100 CPU Signals and Pin Assignments                                                                                         | 13-7        |
| 13-3          | IM6100 Machine Cycles and Clock Periods                                                                                        | 13-8        |
| 13-4          | IM6100 Data Input Machine Cycle Timing                                                                                         | 13-10       |
| 13-5          | IM6100 Data Output Machine Cycle Timing                                                                                        | 13-11       |
| 13-6          | IM6100 Memory Read Machine Cycle Timing                                                                                        | 13-12       |
| 13-7          | IM6100 Instruction Fetch Machine Cycle                                                                                         | 13-12       |
| 13-8          | Machine Cycle Timing for Memory Read from Indirectly Addressed Location                                                        | 13-13       |
| 13-9          | IM6100 Memory Write Machine Cycle Timing                                                                                       | 13-14       |
| 13-10         | Machine Cycle Timing for Memory Write to Indirectly Addressed Location                                                         | 13-15       |
| 13-11         | Auto-Increment Machine Cycle for an IM6100 Memory Reference Instruction that Specifies Indirect Addressing with Auto-Increment | 13-15       |
| 13-12         | IM6100 DCA Instruction Timing with Indirect Addressing                                                                         | 13-16       |
| 13-13         | IM6100 DCA Instruction Timing with Indirect Addressing and Auto-Increment                                                      | 13-17       |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b>                                                                                                    | <b>PAGE</b> |
|------------------------------------------------------------------------------------------------------------------|-------------|
| 13-14 IM6100 I/O Data Input Machine Cycle                                                                        | 13-18       |
| 13-15 IM6100 I/O Data Output Machine Cycle                                                                       | 13-19       |
| 13-16 IM6100 I/O Instruction Timing                                                                              | 13-21       |
| 13-17 Wait States within an IM6100 Data Input Machine Cycle                                                      | 13-22       |
| 13-18 Wait States within an IM6100 Data Output Machine Cycle                                                     | 13-23       |
| 13-19 An IM6100 Halt State Initiated by Execution of a HLT Instruction                                           | 13-24       |
| 13-20 An IM6100 Halt State Initiated and Terminated by the RUN/HLT Input                                         | 13-25       |
| 13-21 IM6100 DMA Initiation Timing                                                                               | 13-27       |
| 13-22 IM6100 DMA Termination Timing                                                                              | 13-28       |
| 13-22a IM6100 Interrupt Acknowledge Timing                                                                       | 13-30       |
| 13-23 Logic and Instruction Sequence for an IM6100 Vectored Interrupt Acknowledge                                | 13-32       |
| 13-24 IM6100 OSR Instruction Timing                                                                              | 13-34       |
| 13-25 IM6100 DCA Instruction in Control Panel Memory-Timing with Indirect Addressing                             | 13-36       |
| 13-26 IM6100 Jump-to-Subroutine Instruction Timing with Indirect Addressing                                      | 13-48       |
| 13-27 IM6100 Jump-to-Subroutine Instruction Timing with Stack Access Logic                                       | 13-49       |
| 13-28 Using an External Stack Memory to Avoid IM6100 JMS ROM Problems                                            | 13-50       |
| 13-29 IM6100 System Bus Converted to an 8080A-Compatible System Bus                                              | 13-52       |
| 13-30 IM6101 Parallel Interface Element Signals and Pin Assignments                                              | 13-54       |
| 13-31 Logic of the IM6101 PIE                                                                                    | 13-55       |
| 13-32 An IM6101 I/O Read Instruction's Timing                                                                    | 13-59       |
| 13-33 An IM6101 I/O Write Instruction's Timing                                                                   | 13-60       |
| 13-34 Logic of the IM6102 MEDIC                                                                                  | 13-65       |
| 13-35 IM6102 MEDIC Signals and Pin Assignments                                                                   | 13-66       |
| 13-36 An IM6100 Microcomputer System that Includes an IM6102 MEDIC and IM6101 PIE Device                         | 13-68       |
| 13-37 IM6102 Extended Memory Addressing Registers and Data Paths                                                 | 13-71       |
| 13-38 IM6100 DCA Instruction Timing with Direct Addressing Using Extended Memory Addressing                      | 13-73       |
| 13-39 IM6100 DCA Instruction Timing with Indirect Addressing Using Extended Memory Addressing                    | 13-75       |
| 13-40 IM6100 DCA Instruction Timing with Indirect Addressing and Auto-Increment Using Extended Memory Addressing | 13-76       |
| 13-41 IM6102 DMA Read Timing                                                                                     | 13-80       |
| 13-42 IM6102 DMA Write Timing                                                                                    | 13-81       |
| 14-1 Logic of the 8X300 Microcontroller and 8T32/3/5/6                                                           | 14-2        |
| 14-2 A Logic Overview of the 8X300 Microcontroller                                                               | 14-3        |
| 14-3 8X300 Microcontroller Signals and Pin Assignments                                                           | 14-5        |
| 14-4 An 8X300 Register-to-Register Instruction's Execution                                                       | 14-11       |
| 14-5 An 8X300 IV Byte-to-Register Instruction's Execution                                                        | 14-12       |
| 14-6 An 8X300 Register-to-IV Byte Instruction's Execution                                                        | 14-13       |
| 14-7 An 8X300 IV Byte-to-IV Byte Instruction's Execution                                                         | 14-14       |
| 14-8 8T32/3/5/6 Interface Vector Byte Signals and Pin Assignments                                                | 14-21       |
| 14-9 8T32/3/5/6 IV Byte Control Signals and Interfaces                                                           | 14-22       |
| 14-10 8T32/3/5/6 IV Byte Address Programming Pulse                                                               | 14-24       |
| 14-11 8T32/3/5/6 IV Byte Protect Programming Pulse                                                               | 14-25       |
| 14-12 8T39 and 8T38 Bus Expander Signals and Pin Assignments                                                     | 14-26       |
| 15-1 A National Semiconductor PACE Microcomputer System                                                          | 15-3        |
| 15-2 A National Semiconductor INS8900 Microcomputer System                                                       | 15-4        |
| 15-3 Logic of the INS8900 Microprocessor                                                                         | 15-5        |
| 15-4 INS8900 and PACE CPU Signals and Pin Assignments                                                            | 15-10       |
| 15-5 INS8900 and PACE Data Input Timing                                                                          | 15-12       |
| 15-6 INS8900 and PACE Data Output Timing                                                                         | 15-13       |
| 15-7 Using the EXTEND Signal to Lengthen I/O Cycles                                                              | 15-13       |
| 15-8 INS8900 and PACE Initialization Timing                                                                      | 15-14       |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b> |                                                                                            | <b>PAGE</b> |
|---------------|--------------------------------------------------------------------------------------------|-------------|
| 15-9          | Terminating INS8900 or PACE Halt State                                                     | 15-15       |
| 15-10         | Timing Diagram for Processor Stall Using NHALT and CONTIN Signals                          | 15-16       |
| 15-11         | Using PACE EXTEND Signal for Cycle-Stealing DMA                                            | 15-17       |
| 15-12         | Idealized Circuit for Cycle-Stealing DMA During INS8900 and PACE Internal Machine Cycles   | 15-18       |
| 15-13         | Timing for Cycle-Stealing DMA During INS8900 and PACE Internal Machine Cycle               | 15-19       |
| 15-14         | Internal View of INS8900 and PACE Interrupt System                                         | 15-20       |
| 15-15         | Initiating INS8900 and PACE Level 0 Interrupt Using NHALT and CONTIN Signals               | 15-23       |
| 15-16         | Circuit to Prevent Conflicts Between PACE Level 0 Interrupts and Lower Priority Interrupts | 15-25       |
| 15-17         | DP8302 System Timing Element (STE) Pins and Signals                                        | 15-35       |
| 15-18         | Circuit to Generate Substrate Bias Voltage ( $V_{BB}$ ) for PACE CPU                       | 15-36       |
| 15-19         | BTE Signals and Pin Assignments                                                            | 15-36       |
| 15-20         | Signal Connections to Control BTE in a DMA System                                          | 15-37       |
| 16-1          | Logic of the CP1600 CPU and CP1680 I/O Buffer                                              | 16-2        |
| 16-2          | CP1600 CPU Signals and Pin Assignments                                                     | 16-7        |
| 16-3          | CP1600 Machine Cycles and Bus Timing                                                       | 16-9        |
| 16-4          | CP1600 Instruction Fetch Timing                                                            | 16-9        |
| 16-5          | CP1600 Timing for Memory Read Instruction with Implied Memory Addressing                   | 16-10       |
| 16-6          | CP1600 Timing for Memory Write Instruction with Implied Memory Addressing                  | 16-11       |
| 16-7          | CP1600 Wait State Timing                                                                   | 16-12       |
| 16-8          | CP1600 DMA Timing                                                                          | 16-14       |
| 16-9          | CP1600 Interrupt Service Routine Initialization                                            | 16-14       |
| 16-10         | CP1600 Timing for TCI Instruction's Execution                                              | 16-15       |
| 16-11         | CP1600 to 8080A Bus Conversion                                                             | 16-26       |
| 16-12         | CP1600 IOB Signals and Pin Assignments                                                     | 16-28       |
| 16-13         | A CP1600-CP1680 Microcomputer Configuration                                                | 16-29       |
| 16-14         | PD1680 Handshaking with Data Input                                                         | 16-34       |
| 16-15         | PD1680 Handshaking for Data Output                                                         | 16-35       |
| 17-1          | Logic of the 1650 Series Microcomputers                                                    | 17-2        |
| 17-2          | 1650 Functional Logic                                                                      | 17-3        |
| 17-3          | 1650 Series Microcomputer Bidirectional I/O Port Pin Logic                                 | 17-4        |
| 17-4          | 1650 Microcomputer Signals and Pin Assignments                                             | 17-7        |
| 18-1          | Logic of the TMS 9900 CPU                                                                  | 18-2        |
| 18-2          | TMS 9900 Signals and Pin Assignments                                                       | 18-14       |
| 18-3          | TMS 9900 Clock Periods and Timing Signals as Generated by the TIM 9904                     | 18-16       |
| 18-4          | A TMS 9900 Memory Read Machine Cycle                                                       | 18-16       |
| 18-5          | A TMS 9900 Memory Write Machine Cycle                                                      | 18-17       |
| 18-6          | Two TMS 9900 Output-to-CRU Machine Cycles                                                  | 18-21       |
| 18-7          | Two TMS 9900 Input-from-CRU Machine Cycles                                                 | 18-22       |
| 18-8          | TMS 9900 System Bus Utilization During I/O Operations                                      | 18-24       |
| 18-9          | The TMS 9900 Wait State                                                                    | 18-24       |
| 18-10         | TMS 9900 Hold State Timing                                                                 | 18-25       |
| 18-11         | TMS 9900 Memory Map                                                                        | 18-28       |
| 18-12         | A TMS 9900 Interrupt Acknowledge Pulse Generated Using an SBO Instruction                  | 18-33       |
| 18-13         | TMS 9900 Interrupt Acknowledge Generated by Decoding Valid Addresses                       | 18-33       |
| 18-14         | Logic of the TMS 9980A and TMS 9981 Microprocessors                                        | 18-46       |
| 18-15         | TMS 9980A Signals and Pin Assignments                                                      | 18-47       |
| 18-16         | TMS 9981 Signals and Pin Assignments                                                       | 18-48       |
| 18-17         | TMS 9980 Memory Map                                                                        | 18-51       |
| 18-18         | Some TMS 9980A/TMS 9981 Interrupt Interfaces                                               | 18-52       |
| 18-19         | Logic of the TMS 9940 Single-Chip Microcomputers                                           | 18-53       |
| 18-20         | TMS 9940 Memory Map                                                                        | 18-54       |

## LIST OF FIGURES (Continued)

| <b>FIGURE</b> |                                                                                                | <b>PAGE</b> |
|---------------|------------------------------------------------------------------------------------------------|-------------|
| 18-21         | TMS 9940 Microcomputer Signals and Pin Assignments                                             | 18-58       |
| 18-22         | Handshaking Logic in a TMS 9940 Multi-Microcomputer Network Communicating via the TD Data Line | 18-62       |
| 18-23         | TIM 9904 Signals and Pin Assignments                                                           | 18-68       |
| 18-24         | Logic of the TMS 9901 Programmable System Interface                                            | 18-71       |
| 18-25         | TMS 9901 Programmable System Interface Signals and Pin Assignments                             | 18-72       |
| 18-26         | TMS 9901 PSI General Data Flows and CRU Bit Assignments                                        | 18-75       |
| 19-1          | Logic of the Data General MicroNova and the Fairchild 9440                                     | 19-3        |
| 19-2          | MicroNova CPU Signals and Pin Assignments                                                      | 19-13       |
| 19-3          | 9440 CPU Signals and Pin Assignments                                                           | 19-14       |
| 19-4          | The Nova Arithmetic and Logic Unit                                                             | 19-16       |
| 19-5          | Arithmetic/Logic Instruction Object Code Interpretation                                        | 19-16       |
| 19-6          | Load and Store Instruction Object Codes                                                        | 19-19       |
| 19-7          | Jump and Modify Memory Instruction Object Codes                                                | 19-19       |
| 19-8          | General Input/Output Instruction Object Code Interpretation                                    | 19-20       |
| 19-9          | Input/Output Skip Instruction Object Code Interpretation                                       | 19-21       |
| 19-10         | CPU Device 3F16 Input/Output Instruction Object Code Interpretation                            | 19-21       |
| 19-11         | CPU Device 1 Input/Output Instruction Object Code Interpretation                               | 19-22       |
| 19-12         | 9440 Memory Read/Instruction Fetch Timing                                                      | 19-23       |
| 19-13         | 9440 Memory Write Timing                                                                       | 19-24       |
| 19-14         | 9440 I/O Data Input Timing                                                                     | 19-26       |
| 19-15         | 9440 I/O Data Output Timing                                                                    | 19-26       |
| 19-16         | 9440 Interrupt Acknowledge Instruction Execution Timing                                        | 19-30       |
| 19-17         | 9440 Mask Out Instruction Execution Timing                                                     | 19-31       |
| 20-1          | Logic of the Intel 8086 CPU                                                                    | 20-4        |
| 20-2          | 8086 Programmable Registers                                                                    | 20-5        |
| 20-3          | 8086 Pins and Signal Assignments                                                               | 20-19       |
| 20-4          | Two 8086 Bus Cycles                                                                            | 20-26       |
| 20-5          | 8086 Memory Read Bus Cycle for a Minimum Mode System ( $MN/MX=+5V$ )                           | 20-30       |
| 20-6          | 8086 Memory Write Bus Cycle for a Minimum Mode System ( $MN/MX=+5V$ )                          | 20-32       |
| 20-7          | 8086 Memory or I/O Read Bus Cycle for a Maximum Mode System ( $MN/MX=0V$ )                     | 20-33       |
| 20-8          | 8086 Memory or I/O Write Bus Cycle for a Maximum Mode System ( $MN/MX=0V$ )                    | 20-33       |
| 20-9          | The 8086 READY Input and Wait States                                                           | 20-34       |
| 20-10         | 8086 HALT Instruction and Bus Cycle Timing for a Complex Bus Configuration                     | 20-36       |
| 20-11         | 8086 Interrupt Vector                                                                          | 20-39       |
| 20-12         | Logic of the 8284 Clock Generator and Driver                                                   | 20-76       |
| 20-13         | 8284 Clock Generator and Driver Pins and Signal Assignments                                    | 20-76       |
| 20-14         | Normal 8284 Clock Generator Circuit                                                            | 20-78       |
| 20-15         | Clock Synchronization Logic in a Multi-CPU 8086 Configuration                                  | 20-79       |
| 20-16         | 8288 Bus Controller Pins and Signal Assignments                                                | 20-80       |
| 20-17         | 8282 and 8283 Input/Output Port Pins and Signal Assignments                                    | 20-84       |
| 20-18         | 8286 and 8287 Bidirectional Bus Transceiver Pins and Signal Assignments                        | 20-85       |
| 20-19         | Generating a System Bus for a Simple 8086 Configuration                                        | 20-86       |
| 20-20         | Generating a System Bus in an 8086 Microcomputer System Using an 8288 Bus Controller           | 20-88       |
| 22-1          | The 2901/6701 Arithmetic and Logic Unit                                                        | 22-2        |
| 22-2          | 2901 ALU Logic                                                                                 | 22-3        |
| 22-3          | 2909 Microprogram Sequencer Block Diagram                                                      | 22-6        |
| 22-4          | Four 2901s in a 16-Bit CPU Using the 2902 for Carry Look Ahead                                 | 22-9        |
| 23-1          | MC10800 Series Devices in a Central Processing Unit Configuration                              | 23-1        |
| 23-2          | The MC10800 ALU Slice Functional Diagram                                                       | 23-2        |
| 23-3          | MC10803 Memory Interface Device Block Diagram                                                  | 23-6        |

## **LIST OF FIGURES (Continued)**

| <b>FIGURE</b> |                                                        | <b>PAGE</b> |
|---------------|--------------------------------------------------------|-------------|
| 24-1          | Logic of the Hewlett Packard MC2 Microprocessor        | 24-2        |
| 24-2          | CPU and I/O Device Registers' Organization for the MC2 | 24-4        |
| 25-1          | System Software Modules                                | 25-6        |



## LIST OF TABLES

| <b>TABLE</b> |                                                                                                            | <b>PAGE</b> |
|--------------|------------------------------------------------------------------------------------------------------------|-------------|
| 1-1          | TMS1000 Series Microcomputer Summary                                                                       | 1-1         |
| 1-2          | TMS1000 Series Instruction Set Summary                                                                     | 1-12        |
| 2-1          | 3870/F8 Instruction Set Summary                                                                            | 2-21        |
| 2-2          | Timing and ROMC States for F8 Instruction Set                                                              | 2-27        |
| 2-3          | 3870/F8 Instruction Set Object Codes                                                                       | 2-29        |
| 2-4          | ROMC Signals and What They Imply                                                                           | 2-33        |
| 2-5          | Relationship Between Programmable Timer Contents and Effective Timer Counts                                | 2-44        |
| 2-6          | A Summary of Differences Between 3851, 3856, and 3857 PSUs                                                 | 2-47        |
| 3-1          | Status and Address Output via the Data Lines at the Beginning of an I/O Cycle                              | 3-8         |
| 3-2          | Statuses Output on the Data Bus for Various Types of Machine Cycles                                        | 3-8         |
| 3-3          | SC/MP Instruction Execution Times                                                                          | 3-11        |
| 3-4          | SC/MP Instruction Set Summary                                                                              | 3-24        |
| 3-5          | SC/MP Instruction Set Object Codes and Execution Times                                                     | 3-27        |
| 4-1          | Devices of the 8080A Microcomputer Family                                                                  | 4-2         |
| 4-2          | Statuses Output via the Data Lines During the Second Clock Cycle of an 8080A Machine Cycle                 | 4-11        |
| 4-3          | Statuses Output on the Data Bus for Various Types of Machine Cycle                                         | 4-11        |
| 4-4          | A Summary of 8080A/9080A Microcomputer Instruction Set                                                     | 4-27        |
| 4-5          | A Summary of Instruction Object Codes and Execution Cycles                                                 | 4-32        |
| 4-6          | A Summary of 8259 PICU Operations                                                                          | 4-66        |
| 4-7          | TMS 5501 Address Interpretations                                                                           | 4-70        |
| 4-8          | TMS 5501 Interrupt Logic and Priorities                                                                    | 4-74        |
| 5-1          | A Summary of 8085A Instruction Object Codes and Execution Cycles                                           | 5-32        |
| 5-2          | 8155/8156 Device Port C Pin Options                                                                        | 5-38        |
| 6-1          | A Summary of 8048 Series Microcomputers                                                                    | 6-2         |
| 6-2          | A Summary of 8048 Microcomputer Instruction Set                                                            | 6-35        |
| 6-3          | 8048 Series Instruction Set Object Codes                                                                   | 6-41        |
| 7-1          | Comparisons of Z80 and 8080A Instruction Execution Cycles                                                  | 7-4         |
| 7-2          | A Summary of the Z80 Instruction Set                                                                       | 7-22        |
| 7-3          | A Summary of Instruction Object Codes and Execution Cycles with 8080A Mnemonics for Identical Instructions | 7-33        |
| 7-4          | Z80 PIO Interpretation of Control Signals                                                                  | 7-45        |
| 7-5          | Z80 PIO Select Logic                                                                                       | 7-47        |
| 7-6          | Z80 PIO and 8255 Mode Equivalences                                                                         | 7-49        |
| 9-1          | A Summary of the MC6800 Instruction Set                                                                    | 9-19        |
| 9-2          | Operation Summary                                                                                          | 9-26        |
| 9-3          | MC6800 Instruction Set Object Codes                                                                        | 9-30        |
| 9-4          | MC6820 Operating Modes                                                                                     | 9-49        |
| 9-5          | Addressing MC6820 Internal Registers                                                                       | 9-49        |
| 9-6          | MC6852 Status Register Bit Set/Reset Conditions                                                            | 9-67        |
| 9-7          | MC6852 Interrupt Summary                                                                                   | 9-68        |
| 9-8          | MC6828 Address Vectors Created for Eight Priority Interrupt Requests                                       | 9-74        |
| 9-9          | MC6828 Interrupt Masks - Their Creation and Interpretation                                                 | 9-78        |
| 9-10         | MC6840 Addressable Locations                                                                               | 9-82        |
| 9-11         | A Summary of MC6840 Options and Control Register Settings                                                  | 9-99        |
| 9-12         | MC6844 DMA Register Addresses                                                                              | 9-110       |
| 9-13         | MC6844 DMA Modes' Response Times and Transfer Rates                                                        | 9-116       |
| 9-14         | MC6846 I/O Addressable Locations                                                                           | 9-124       |

## LIST OF TABLES (Continued)

| <b>TABLE</b> |                                                                                            | <b>PAGE</b> |
|--------------|--------------------------------------------------------------------------------------------|-------------|
| 10-1         | A Comparison of MCS6500 Series and the MC6800 CPU Devices                                  | 10-2        |
| 10-2         | A Summary of the MCS6500 Microcomputer Instruction Set                                     | 10-20       |
| 10-3         | Summary of MCS6500 Object Codes, with MC6800 Mnemonics                                     | 10-26       |
| 10-4         | Addressing MCS6522 Internal Registers                                                      | 10-33       |
| 10-5         | Summary of I/O Port A Handshaking Control Signals                                          | 10-37       |
| 10-6         | A Summary of MCS6522 Interrupt Setting and Resetting                                       | 10-47       |
| 10-7         | Addressing the MCS6530 Multifunction Support Logic Device                                  | 10-52       |
| 10-8         | Addressing the MCS6532 Multifunction Support Logic Device                                  | 10-55       |
| 11-1         | Summary of Signetics 2650A Instruction Set                                                 | 11-17       |
| 11-2         | Signetics 2650A Instruction Object Codes                                                   | 11-22       |
| 12-1         | COSMAC Instruction Set Summary                                                             | 12-26       |
| 12-2         | COSMAC Instruction Set Object Codes                                                        | 12-31       |
| 13-1         | IM6100 External Signal Sampling Priorities                                                 | 13-37       |
| 13-2         | IM6100 Instruction Set Summary                                                             | 13-40       |
| 13-3         | IM6100 Instruction Set Object Codes                                                        | 13-46       |
| 13-4         | IM6101 Interpretation of I/O Instruction Control Bits 3-0                                  | 13-57       |
| 13-5         | IM6102 MEDIC Pins that should be Tied to Power or Ground when Certain Functions are Unused | 13-67       |
| 13-6         | IM6102 MEDIC I/O Instructions                                                              | 13-87       |
| 14-1         | 8X300 Source and Destination Object Code Interpretations                                   | 14-10       |
| 14-2         | 8X300 Instruction Set                                                                      | 14-18       |
| 14-3         | 8X300 Instruction Set Object Codes                                                         | 14-20       |
| 14-4         | Interface Vector Byte Options                                                              | 14-21       |
| 14-5         | Specifications for Signals Illustrated in Figures 14-10 and 14-11                          | 14-24       |
| 14-6         | 8T39 Bus Expander Addresses and IV Byte Addresses That May Be Connected                    | 14-27       |
| 15-1         | INS8900 and PACE Instruction Set Summary                                                   | 15-27       |
| 15-2         | INS8900 and PACE Instruction Set Object Codes                                              | 15-31       |
| 15-3         | Branch Conditions for INS8900 and PACE BOC Instruction                                     | 15-33       |
| 15-4         | PACE BTE Truth Table                                                                       | 15-37       |
| 15-5         | Comparing INS8900 System Busses to 8080A System Busses                                     | 15-44       |
| 16-1         | CP1600 Bus Control Signals                                                                 | 16-8        |
| 16-2         | CP1600 Instruction Set Summary                                                             | 16-18       |
| 16-3         | CP1600 Branch Conditions and Corresponding Codes                                           | 16-23       |
| 16-4         | CP1600 Instruction Set Object Codes                                                        | 16-24       |
| 17-1         | 1650 Series One-Chip Microcomputer Options                                                 | 17-1        |
| 17-2         | 1650 Series Microcomputer Register Designations                                            | 17-5        |
| 17-3         | A Summary of the 1650 Series Microcomputer Instruction Set                                 | 17-11       |
| 17-4         | Mnemonics Recognized by the 1650 Assembler for Special Cases of General Instructions       | 17-14       |
| 17-5         | 1650 Instruction Set Object Codes                                                          | 17-15       |
| 18-1         | High-Order Address Bus Line Used by TMS 9900 I/O Instructions                              | 18-23       |
| 18-2         | TMS 9900 Instruction Set Summary                                                           | 18-38       |
| 18-3         | TMS 9900 Instruction Set Object Codes                                                      | 18-43       |
| 18-4         | A Summary of Differences Between the TMS 9900 and TMS 9980 Series Microprocessors          | 18-45       |
| 18-5         | A Summary of Differences Between the TMS 9980A and TMS 9981 Microprocessors                | 18-50       |
| 18-6         | TMS 9980 Interrupts                                                                        | 18-59       |
| 18-7         | TMS 9940 CRU Bit Address Assignments                                                       | 18-59       |
| 18-8         | TMS 9940 CRU Bits Whose Functions are Determined Under Program Control                     | 18-60       |

## **LIST OF TABLES (Continued)**

| TABLE |                                                                                                       | PAGE  |
|-------|-------------------------------------------------------------------------------------------------------|-------|
| 19-1  | Nova System Bus Signals                                                                               | 19-11 |
| 19-2  | MicroNova and 9440 Instruction Set Summary                                                            | 19-35 |
| 19-3  | MicroNova and 9440 Instruction Set Object Codes                                                       | 19-40 |
| 20-1  | A Summary of Intel 8086 Memory Addressing Options                                                     | 20-10 |
| 20-2  | 8086 Branch-on-Condition Instructions                                                                 | 20-47 |
| 20-3  | A Summary of Intel 8086 Memory Addressing Options Identified by the EA<br>Abbreviations in Table 20-3 | 20-50 |
| 20-4  | The 8086 Instruction Set Summary                                                                      | 20-51 |
| 20-5  | A Summary of 8086 Instruction Object Codes and Execution Cycles                                       | 20-68 |
| 20-6  | 8080A to 8086 Instruction Mapping                                                                     | 20-74 |
| 20-7  | Effect of IOB, CEN, and AEN on Control Signals Output by the 8288 Bus Controller                      | 20-82 |
| 22-1  | 2901 ALU Function Control                                                                             | 22-3  |
| 22-2  | ALU Source Operand Control                                                                            | 22-3  |
| 22-3  | ALU Destination Control                                                                               | 22-7  |
| 23-1  | MC10800 ALU Logical Operations                                                                        | 23-3  |
| 23-2  | MC10800 Arithmetic Operations                                                                         | 23-4  |
| 24-1  | A Summary of the MC2 Instruction Set                                                                  | 24-8  |
| 25-1  | Some Typical Microcomputer Based Product and Development Costs                                        | 25-10 |
| 25-2  | Unit Prices for Microcomputer Based Products                                                          | 25-10 |



# QUICK INDEX

| INDEX    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PAGE                                                                                                                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>A</b> | Address/Data Lines, Demultiplexing in the INS8900<br>After Sales Service<br>ALE Differences in 8085 and 8085A<br>ALE Generation in 8085 and 8085A<br>AMD 9080A Status Difference<br>Assembler<br>Assembler/Editor Combined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 15-38<br>25-1<br>5-5<br>5-18<br>4-6<br>25-5<br>25-5                                                                                                                                                           |
| <b>B</b> | Bidirectional Transceiver Element (BTE)<br>BTE Mode Control Signals<br>Buffering SC/MP Busses<br>Bus Interface Unit (BIU), 8086                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 15-2<br>15-37<br>13-29<br>20-25                                                                                                                                                                               |
| <b>C</b> | CALL Instruction, 8080A Interrupt Response Using<br>Chip Slice Logic, Carry Status and Overflow in<br>Chip Slice Logic, Sign Status in<br>Chip Slice Logic, Zero Status in<br>Context Switch, TMS 9900<br>Context Switch, TMS 9900 Backward<br>Context Switch, TMS 9900 Forward<br>CONTIN and NHALT Signals are Malfunctional<br>Continuing Engineering Costs<br>COSMAC Input/Output Programs<br>COSMAC Instruction Machine Cycle<br>COSMAC Interrupt Service Routine Programs<br>COSMAC Negative Set-up Time<br>COSMAC Nested Subroutine<br>COSMAC Timing Variations<br>Cost, Variable Contributing Factors<br>Costs, Variable<br>CPU Initiated DMA Block Data Transfers<br>CP1600 Direct Addressing<br>CP1600 Implied Addressing<br>CP1600 I/O Port Pin Characteristics<br>CP1600 PCIT Signal<br>CP1600 Stack Addressing<br>Cycle-Stealing DMA During INS8900 and PACE Internal Machine Cycles<br>Cycle-Stealing DMA in PACE and INS8900 Systems | 4-54<br>22-5<br>25-5<br>22-5<br>18-5<br>18-6<br>18-6<br>15-15<br>25-1<br>12-23<br>12-9<br>12-23<br>12-9<br>12-22<br>12-8<br>25-1<br>25-2<br>15-16<br>16-3<br>16-4<br>16-30<br>16-13<br>16-5<br>15-18<br>15-17 |
| <b>D</b> | Debug<br>Demultiplexing the INS8900 Address/Data Lines<br>Demultiplexing the SC/MP Data Bus<br>DEND/IQ Signal, MC6844 DMAC<br>DGRNT, DMAC, TxSTB, TxAKA and TxAKB Signals, MC6844<br>DGRNT, TxRON, and DQRT Signals, MC6844 DMAC<br>DMA and Multiprocessor Logic of the SC/MP<br>DMA Block Data Transfers Initiated by CPU<br>DMA Block Data Transfers Initiated by External Logic in PACE and INS8900 Systems<br>DMA Control Signals in IM6102<br>DMA, Cycle-Stealing, During INS8900 and PACE Internal Machine Cycles<br>DMA, Cycle-Stealing, in PACE and INS8900 Systems<br>DMA Modes in IM6102<br>DMA Priority Arbitration, MC6844 Fixed<br>DMA Programming in IM6102<br>DMA Registers in IM6102<br>DMAC, DGRNT, TxSTB, TxAKA, and TxAKB Signals, MC6844<br>DQRT, DGRNT, and TxRON Signals, MC6844 DMAC<br>DRQH Signal, MC6844 DMAC                                                                                                            | 25-8<br>15-38<br>3-30<br>9-113<br>9-114<br>9-112<br>3-1<br>15-16<br>15-17<br>13-79<br>15-18<br>15-17<br>13-83<br>9-116<br>13-83<br>13-79<br>9-114<br>9-112<br>9-114                                           |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                                      |                                            | <b>PAGE</b> |
|-------------------------------------------------------------------|--------------------------------------------|-------------|
| <b>E (Cont.)</b>                                                  |                                            |             |
| Editor                                                            |                                            | 25-5        |
| Editor/Assembler Combined                                         |                                            | 25-5        |
| Enabling and Disabling INS8900 and PACE Interrupts                |                                            | 15-21       |
| Execution Unit (EU), 8086                                         |                                            | 20-25       |
| Extend Used to Suspend INS8900 and PACE I/O During DMA Operations |                                            | 15-17       |
| Extended Memory, Base Page in IM6100                              |                                            | 13-70       |
| <b>F</b>                                                          |                                            |             |
| Fairchild F8 Device Set, The                                      |                                            | 2-1         |
| Fixed Cost Contributing Factors                                   |                                            | 25-1        |
| Fixed Costs                                                       |                                            | 25-2        |
| Floating INS8900 and PACE System Busses                           |                                            | 15-15       |
| F8 Device Set, The Fairchild                                      |                                            | 2-1         |
| F8 Direct Memory Access                                           |                                            | 2-53        |
| F8 DMI Memory Refresh                                             |                                            | 2-52        |
| F8/3870 Accumulator                                               |                                            | 2-5         |
| F8/3870 Data Counters                                             |                                            | 2-6         |
| F8/3870 Program Counter                                           |                                            | 2-6         |
| F8/3870 Scratchpad                                                |                                            | 2-6         |
| F8/3870 Stack Register                                            |                                            | 2-6         |
| <b>G</b>                                                          | Generating the PACE Substrate Bias Voltage | 15-35       |
| <b>H</b>                                                          | Halt State in 8085 and 8085A               | 5-24        |
|                                                                   | Hold State in 8085 and 8085A               | 5-24        |
| <b>I</b>                                                          |                                            |             |
| IM6100 Base Page in Extended Memory                               |                                            | 13-70       |
| IM6100 Bit Numbering                                              |                                            | 13-7        |
| IM6100 Clock Period Assignments                                   |                                            | 13-10       |
| IM6100 Control Panel Switch Register                              |                                            | 13-33       |
| IM6100 Extended Memory Jump                                       |                                            | 13-77       |
| IM6100 Extended Memory Subroutine Accesses                        |                                            | 13-77       |
| IM6100-IM6102 Interrupt Acknowledge                               |                                            | 13-70       |
| IM6100-IM6102 Reset Bootstrap                                     |                                            | 13-70       |
| IM6100 Indirect Addressing with Auto-Increment Timing             |                                            | 13-14       |
| IM6100 Indirectly Addressed Memory Read Cycle                     |                                            | 13-13       |
| IM6100 Indirectly Addressed Memory Write Cycle                    |                                            | 13-14       |
| IM6100 Instruction Fetch Machine Cycle                            |                                            | 13-13       |
| IM6100 Interrupt Processing Instructions                          |                                            | 13-31       |
| IM6100 Memory Fields                                              |                                            | 13-70       |
| IM6100 Subroutines in Read-Only Memory                            |                                            | 13-5        |
| IM6100 Vectored Interrupt Acknowledge                             |                                            | 13-32       |
| IM6101 Control Registers                                          |                                            | 13-58       |
| IM6101 FLAG Instructions                                          |                                            | 13-61       |
| IM6101 FLAG Outputs                                               |                                            | 13-58       |
| IM6101 Interrupt Acknowledge                                      |                                            | 13-70       |
| IM6101 I/O Instructions                                           |                                            | 13-58       |
| IM6101 Programming                                                |                                            | 13-56       |
| IM6101 Read Instruction                                           |                                            | 13-58       |
| IM6101 Reset Bootstrap                                            |                                            | 13-70       |
| IM6101 Select Logic                                               |                                            | 13-56       |
| IM6101 Sense Inputs                                               |                                            | 13-58       |
| IM6101 Sense Interrupt Priority                                   |                                            | 13-63       |
| IM6101 SKIP Instructions                                          |                                            | 13-61       |
| IM6101 Write Operation                                            |                                            | 13-58       |
| IM6102 Data Field Register                                        |                                            | 13-70       |
| IM6102 DMA Control Signals                                        |                                            | 13-79       |
| IM6102 DMA Modes                                                  |                                            | 13-83       |
| IM6102 DMA Programming                                            |                                            | 13-83       |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                                                   |  | <b>PAGE</b> |
|--------------------------------------------------------------------------------|--|-------------|
| <b>I (Cont.)</b>                                                               |  |             |
| IM6102 DMA Registers                                                           |  | 13-79       |
| IM6102 Extended Memory Addressing Registers                                    |  | 13-70       |
| IM6102 Instruction Buffer Register                                             |  | 13-71       |
| IM6102 Instruction Field Register                                              |  | 13-70       |
| IM6102 Interrupt Acknowledge                                                   |  | 13-70       |
| IM6102 Interrupt Vector Register                                               |  | 13-78       |
| IM6102 Jump Across Memory Fields                                               |  | 13-72       |
| IM6102 Reset Bootstrap                                                         |  | 13-70       |
| INS8900 and PACE CPU Registers During Interrupts, Saving                       |  | 15-22       |
| INS8900 and PACE, Cycle-Stealing DMA during Internal Machine Cycles            |  | 15-18       |
| INS8900 and PACE Data Input Cycle                                              |  | 15-12       |
| INS8900 and PACE Data Output Cycle                                             |  | 15-13       |
| INS8900 and PACE Direct Addressing Options                                     |  | 15-24       |
| INS8900 and PACE Direct Indexed Addressing                                     |  | 15-7        |
| INS8900 and PACE Execution Speed                                               |  | 15-1        |
| INS8900 and PACE Extend Signal for Slow I/O Operations                         |  | 15-13       |
| INS8900 and PACE, Extend Used to Suspend I/O During DMA Operations             |  | 15-17       |
| INS8900 and PACE, Floating System Busses                                       |  | 15-15       |
| INS8900 and PACE Halt State                                                    |  | 15-14       |
| INS8900 and PACE Interrupt Acknowledge and Return from Interrupt               |  | 15-21       |
| INS8900 and PACE Interrupt Pointers                                            |  | 15-21       |
| INS8900 and PACE Interrupt Priorities                                          |  | 15-21       |
| INS8900 and PACE Interrupt Response                                            |  | 15-21       |
| INS8900 and PACE Interrupts, Enabling and Disabling                            |  | 15-21       |
| INS8900 and PACE Level 0 Interrupt Response                                    |  | 15-22       |
| INS8900 and PACE Logic Level                                                   |  | 15-2        |
| INS8900 and PACE Machine Cycle                                                 |  | 15-12       |
| INS8900 and PACE Machine Cycle Types                                           |  | 15-12       |
| INS8900 and PACE Non-Maskable (Level 0) Interrupt                              |  | 15-22       |
| INS8900 and PACE Power Supply                                                  |  | 15-1        |
| INS8900 and PACE Processor Stall                                               |  | 15-15       |
| INS8900 and PACE Signal Differences                                            |  | 15-10       |
| INS8900 and PACE Split Base Page                                               |  | 15-16       |
| INS8900 and PACE Split Base Page to Address I/O                                |  | 15-7        |
| INS8900 and PACE Stack Interrupts                                              |  | 15-5,22     |
| INS8900 and PACE Systems, Cycle-Stealing DMA in                                |  | 15-17       |
| INS8900 and PACE Systems, DMA Block Data Transfers Initiated by External Logic |  | 15-17       |
| INS8900 and 8080A System Busses Compared                                       |  | 15-43       |
| INS8900 Control Signal Polarity Considerations                                 |  | 15-39       |
| INS8900, Demultiplexing the Address/Data Lines                                 |  | 15-38       |
| INS8900 System, The 8212 Used as a Simple Input Port in an                     |  | 15-39       |
| INS8900 System, The 8212 Used as an Output Port in an                          |  | 15-41       |
| INS8900 System, 8255 PPI Devices Used in an                                    |  | 15-42       |
| INS8900 Systems, The 8251 USART and 8253 Programmable Counter/Timer Used in    |  | 15-43       |
| INS8900, Two 8255 Devices Used for 16-Bit I/O Ports with                       |  | 15-43       |
| INS8900, 6800 Support Devices Compatible with                                  |  | 15-44       |
| INS8900, 8212 Used for Input with Handshaking in                               |  | 15-40       |
| Interrupt Differences in 8085 and 8085A                                        |  | 5-28        |
| Interrupts During an MC6800 HALT                                               |  | 9-38        |
| IRQ/DEND Signal, MC6844 DMAC                                                   |  | 9-113       |
| <b>L</b>                                                                       |  |             |
| Label Table                                                                    |  | 25-8        |
| Level 0 and Processor Stall Interrupt Similarities                             |  | 15-15       |
| Linking Loader                                                                 |  | 25-8        |

## QUICK INDEX (Continued)

### **INDEX**

| <b>INDEX</b>                                                   | <b>PAGE</b> |
|----------------------------------------------------------------|-------------|
| <b>M</b>                                                       |             |
| MCS6500 Slow Memory Interface                                  | 10-15       |
| MCS6500 Wait State                                             | 10-14       |
| MCS6522 Addressing                                             | 10-31       |
| MCS6522 Interval Timer 1                                       | 10-39       |
| MCS6522 Interval Timer 1 Free Running Mode                     | 10-41       |
| MCS6522 Interval Timer 1 One-Shot Mode                         | 10-40       |
| MCS6522 Interval Timer 2                                       | 10-41       |
| MCS6522 I/O Port A Data Transfer                               | 10-33       |
| MCS6522 I/O Port B Data Transfer                               | 10-35       |
| MCS6530 Addressing Logic                                       | 10-48       |
| MCS6532 Addressing                                             | 10-54       |
| MC6800 Bus State Controls                                      | 9-6         |
| MC6800 Clock Signals                                           | 9-7         |
| MC6800 Enable Signal Generation                                | 9-44        |
| MC6800 HALT, Interrupts During an                              | 9-38        |
| MC6800 Internal Operations Machine Cycle                       | 9-9         |
| MC6800 Interrupt Priorities                                    | 9-13        |
| MC6800 Machine Cycle                                           | 9-7         |
| MC6800 Machine Cycle Types                                     | 9-7         |
| MC6800 Non-Maskable Interrupt                                  | 9-13        |
| MC6800 Normal External Interrupts                              | 9-13        |
| MC6800 Read Machine Cycle                                      | 9-7         |
| MC6800 Reset                                                   | 9-13        |
| MC6800 Reset During Power-up                                   | 9-15        |
| MC6800 Reset Operation                                         | 9-15        |
| MC6800 Software Interrupt                                      | 9-13        |
| MC6800 Stretching Address Timing                               | 9-42        |
| MC6800 SWI Instruction                                         | 9-13        |
| MC6800 Synchronous HALT Generation                             | 9-45        |
| MC6800 Use of WAIT for DMA                                     | 9-16        |
| MC6800 WAI Instruction                                         | 9-16        |
| MC6800 Wait State                                              | 9-16        |
| MC6800 Wait State with Slow Memory                             | 9-9         |
| MC6800 Write Machine Cycle                                     | 9-8         |
| MC6820 Automatic Handshaking                                   | 9-53        |
| MC6820 Control Codes                                           | 9-51        |
| MC6820 Interrupt Logic                                         | 9-51        |
| MC6820 Registers Addressing                                    | 9-49        |
| MC6840 Continuous Mode                                         | 9-100       |
| MC6840 Continuous Mode with 0 Initial Value                    | 9-103       |
| MC6840 Continuous 8-Bit Counting Square Wave Option            | 9-103       |
| MC6840 Control Registers                                       | 9-94        |
| MC6840 Counter/Timer Initialization                            | 9-79        |
| MC6840 Divide-by-Eight Clock                                   | 9-95        |
| MC6840 Divide-by-Eight Mode                                    | 9-103       |
| MC6840 Event Counting                                          | 9-104       |
| MC6840 External Signal Timing                                  | 9-80        |
| MC6840 Frequency Comparison and Pulse Width Measurement Mode 5 | 9-105       |
| MC6840 Hardware Initialization                                 | 9-102       |
| MC6840 Interrupt Enable                                        | 9-96        |
| MC6840 One-Shot Mode                                           | 9-104       |
| MC6840 Output Signal Enable                                    | 9-97        |
| MC6840 Programmed Initialization                               | 9-94        |
| MC6840 Status Register                                         | 9-97        |
| MC6840 8-Bit Counting Mode                                     | 9-96        |
| MC6840 16-Bit Counting Mode                                    | 9-95        |
| MC6844 Channel Control Registers                               | 9-119       |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                       |            | <b>PAGE</b> |
|----------------------------------------------------|------------|-------------|
| <b>M (Cont.)</b>                                   |            |             |
| MC6844 Data Chaining                               | 9-119      |             |
| MC6844 Data Chaining Control Register              | 9-117      |             |
| MC6844 DMAC Address Bus                            | 9-109      |             |
| MC6844 DMAC Data Bus                               | 9-109      |             |
| MC6844 DMAC Device Select                          | 9-109      |             |
| MC6844 DMAC, DGRNT, TxSTB, TxAKA and TxAKB Signals | 9-114      |             |
| MC6844 DMAC DRQH Signal                            | 9-114      |             |
| MC6844 DMAC Four-Channel Mode                      | 9-118      |             |
| MC6844 DMAC IRQ/DEND Signal                        | 9-113      |             |
| MC6844 DMAC Two-Channel Mode                       | 9-117      |             |
| MC6844 DMAC TxAKA and TxAKB Signals                | 9-113      |             |
| MC6844 DMAC, TxRON, DQRT, and DGRNT Signals        | 9-112      |             |
| MC6844 DMAC TxR0-TxR3 Signals                      | 9-114      |             |
| MC6844 DMAC TxSTB Signal                           | 9-113, 115 |             |
| MC6844 DMAC Φ2 DMA Clock                           | 9-112      |             |
| MC6844 Enable/Priority Control Register            | 9-116      |             |
| MC6844 Fixed DMAPriority Arbitration               | 9-116      |             |
| MC6844 Interrupt Control Register                  | 9-121      |             |
| MC6844 Rotating Data Priority Arbitration          | 9-117      |             |
| MC6846 Composite Status Register                   | 9-129      |             |
| MC6850 Control Register                            | 9-59       |             |
| MC6850 Interrupt Logic                             | 9-59       |             |
| MC6850 MODEM Control Signals                       | 9-58       |             |
| MC6850 Serial I/O Control Logic                    | 9-59       |             |
| MC6850 Serial I/O Data and Control Signals         | 9-58       |             |
| MC6850 System Reset                                | 9-59       |             |
| MC6852 Interrupt Logic                             | 9-70       |             |
| MC6852 Reset Operation                             | 9-70       |             |
| MC6852 Serialization Sequence                      | 9-63       |             |
| MC6852 Triple Data Buffers                         | 9-65       |             |
| Microcomputer Development Systems, Simple          | 25-4       |             |
| Microcomputer Development Systems, Simulating      | 25-4       |             |
| MicroNova I/O Bus                                  | 19-12      |             |
| MicroNova Memory Bus                               | 19-12      |             |
| MODEM Control Signals                              | 9-58       |             |
| Monitor                                            | 25-5       |             |
| Motorola A and B Series Parts                      | 9-2        |             |
| Multiple Device Selects and Bus Loading (8085A)    | 5-11       |             |
| Multi-8086 Clock Signals, Synchronizing            | 20-79      |             |
| <b>N</b>                                           |            |             |
| NEC 8080A External Interrupt Differences           | 4-24       |             |
| NEC 8080A Hold Differences                         | 4-17       |             |
| NEC 8080A Instruction Execution Time Differences   | 4-33       |             |
| NEC 8080A Instruction Set Differences              | 4-24       |             |
| NEC 8080A Interrupt Acknowledge Differences        | 4-24       |             |
| NHALT and CONTIN Signals are Multifunctional       | 15-15      |             |
| Nova Direct Memory Addressing                      | 19-6       |             |
| Nova Indirect Indexed Addressing                   | 19-8       |             |
| Nova Indirect Page Zero Addressing                 | 19-6       |             |
| Nova Indirect Program Relative Addressing          | 19-7       |             |
| Nova I/O Device Address Space                      | 19-22      |             |
| Nova I/O Device Addressing                         | 19-9       |             |
| Nova I/O Device Busy and Done Status               | 19-20      |             |
| Nova I/O Device Registers                          | 19-21      |             |
| Nova Multiple Indirect Addressing                  | 19-9       |             |
| <b>O</b>                                           |            |             |
| Object Programs, Relocatable                       | 25-7       |             |
| Overflow and Carry Status in Chip Slice Logic      | 22-5       |             |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                                                  | <b>PAGE</b> |
|-------------------------------------------------------------------------------|-------------|
| <b>P</b>                                                                      |             |
| PACE Address Latches and Decoders                                             | 15-2        |
| PACE and INS8900, Cycle-Stealing DMA during Internal Machine Cycles           | 15-18       |
| PACE and INS8900 Data Input Cycle                                             | 15-12       |
| PACE and INS8900 Data Output Cycle                                            | 15-13       |
| PACE and INS8900 Direct Addressing Options                                    | 15-24       |
| PACE and INS8900 Direct Indexed Addressing                                    | 15-7        |
| PACE and INS8900 Execution Speed                                              | 15-1        |
| PACE and INS8900, Extend Used to Suspend I/O During DMA Operations            | 15-17       |
| PACE and INS8900, Floating System Busses                                      | 15-15       |
| PACE and INS8900 Halt State                                                   | 15-14       |
| PACE and INS8900 Interrupt Acknowledge and Return from Interrupt              | 15-21       |
| PACE and INS8900 Interrupt Pointers                                           | 15-21       |
| PACE and INS8900 Interrupt Priorities                                         | 15-21       |
| PACE and INS8900 Interrupt Response                                           | 15-21       |
| PACE and INS8900 Interrupts, Enabling and Disabling                           | 15-21       |
| PACE and INS8900 Logic Level                                                  | 15-2        |
| PACE and INS8900 Machine Cycle                                                | 15-12       |
| PACE and INS8900 Machine Cycle Types                                          | 15-12       |
| PACE and INS8900 Non-Maskable (Level 0) Interrupt                             | 15-22       |
| PACE and INS8900 Power Supply                                                 | 15-1        |
| PACE and INS8900 Processor Stall                                              | 15-15       |
| PACE and INS8900 Signal Differences                                           | 15-10       |
| PACE and INS8900 Signal for Slow Operations                                   | 15-13       |
| PACE and INS8900 Split Base Page                                              | 15-16       |
| PACE and INS8900 Split Base Page to Address I/O                               | 15-7        |
| PACE and INS8900 Stack Interrupts                                             | 15-5, 22    |
| PACE and INS8900 Systems Cycle-Stealing DMA                                   | 15-17       |
| PACE and INS8900 Systems DMA Block Data Transfers Initiated by External Logic | 15-17       |
| PACE Clock Signals                                                            | 15-11       |
| PACE CPU and INS8900 Registers during Interrupts, Saving                      | 15-22       |
| PACE DP8302 STE Clock Frequency                                               | 15-35       |
| PACE Level 0 Interrupt Problems                                               | 15-24       |
| PACE Level 0 Interrupt, Return from                                           | 15-23       |
| PACE MILE Used in an SC/MP System, The                                        | 3-31        |
| PACE Stack Interrupt Problems                                                 | 15-22       |
| Preventing Simultaneous Selection of I/O and Memory on an 8085A               | 5-12        |
| Preventing Transient Selection on an 8085A                                    | 5-12        |
| Processor Stall and Level 0 Interrupt Similarities                            | 15-15       |
| Program Linking                                                               | 25-8        |
| PSU Address Space                                                             | 2-40        |
| <b>R</b>                                                                      |             |
| Read-Only Memory, IM6100 Subroutines in                                       | 15-5        |
| Relocatable Loader                                                            | 25-7        |
| Relocatable Object Programs                                                   | 25-7        |
| Relocating Assembler                                                          | 25-7        |
| Reset, 8048, 8748, and 8035                                                   | 6-17        |
| Return from PACE Level 0 Interrupt                                            | 15-23       |
| ROMC State                                                                    | 2-35        |
| <b>S</b>                                                                      |             |
| Saving INS8900 and PACE CPU Registers During Interrupts                       | 15-22       |
| SC/MP and SC/MP-II                                                            | 3-3         |
| SC/MP and SC/MP-II, Signal Differences Between                                | 3-5         |
| SC/MP Bus Access Control Signals                                              | 3-6         |
| SC/MP Bus-Sharing Control Signals                                             | 3-17        |
| SC/MP Busses, Buffering                                                       | 3-29        |
| SC/MP Control Techniques in Multiprocessor Applications                       | 3-19        |
| SC/MP Data Bus Definition Signals                                             | 3-7         |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                                           |  | <b>PAGE</b> |
|------------------------------------------------------------------------|--|-------------|
| <b>S (Cont.)</b>                                                       |  |             |
| SC/MP Data Bus, Demultiplexing the                                     |  | 3-30        |
| SC/MP Data Input Cycle                                                 |  | 3-12        |
| SC/MP Data Output Cycle                                                |  | 3-12        |
| SC/MP DMA and Multiprocessor Logic                                     |  | 3-1         |
| SC/MP ENOUT Signal Used to Establish Access Priorities                 |  | 3-10        |
| SC/MP Instruction Execution Speed                                      |  | 3-3         |
| SC/MP I/O Cycle Status Information                                     |  | 3-7         |
| SC/MP I/O Cycle, Suspension of an                                      |  | 3-9         |
| SC/MP I/O with Bus Access Logic Continuously Enabled                   |  | 3-10        |
| SC/MP Logic Level                                                      |  | 3-3         |
| SC/MP Memory Pages                                                     |  | 3-3         |
| SC/MP in Multiprocessor Systems                                        |  | 3-18        |
| SC/MP NHOLD Signal for Slow I/O Operations                             |  | 3-13        |
| SC/MP (P-Channel) and SC/MP-II (N-Channel), Signal Differences Between |  | 3-5         |
| SC/MP Return-from-Interrupt Technique                                  |  | 3-15        |
| SC/MP Serial I/O                                                       |  | 3-1         |
| SC/MP System, The PACE MILE Used in an                                 |  | 3-31        |
| SC/MP System, The 8212 Used as an Output Port in an                    |  | 3-33        |
| SC/MP Systems, The 8212 I/O Port Used in                               |  | 3-32        |
| SC/MP Timing Control Signals                                           |  | 3-7         |
| SC/MP-II (N-Channel) and SC/MP (P-Channel), Signal Differences Between |  | 3-5         |
| Select Problem with 8085                                               |  | 5-14        |
| Service, After Sales                                                   |  | 25-1        |
| Sign Status in Chip Slice Logic                                        |  | 22-5        |
| Simple Microcomputer Development Systems                               |  | 25-4        |
| Simulating Microcomputer Development Systems                           |  | 25-4        |
| Standard Memory Devices Connected to an 8048 Series Microcomputer      |  | 6-22        |
| Subroutine Library                                                     |  | 25-8        |
| Suspension of an SC/MP I/O Cycle                                       |  | 3-9         |
| Synchronizing Multi-8086 Clock Signals                                 |  | 20-79       |
| System Timing Element                                                  |  | 15-2        |
| <b>T</b>                                                               |  |             |
| TMS 1000 Subroutines                                                   |  | 1-4         |
| TMS 5501 Nonstandard Features                                          |  | 4-75        |
| TMS 5501 Output Signal Inversion                                       |  | 4-69        |
| TMS 5501 Reset                                                         |  | 4-73        |
| TMS 5501 Wait State                                                    |  | 4-70        |
| TMS 9900 Backward Context Switch                                       |  | 18-6        |
| TMS 9900 Context Switch                                                |  | 18-5        |
| TMS 9900 Direct Addressing                                             |  | 18-6        |
| TMS 9900 Forward Context Switch                                        |  | 18-6        |
| TMS 9900 Implied Addressing                                            |  | 18-7        |
| TMS 9900 Indexed Addressing                                            |  | 18-6        |
| TMS 9900 Instruction Execution Sequences                               |  | 18-18       |
| TMS 9900 Internal Operations Machine Cycle                             |  | 18-15       |
| TMS 9900 Interrupt Vector Map                                          |  | 18-27       |
| TMS 9900 Memory Addresses                                              |  | 18-3        |
| TMS 9900 Multiple Interrupt Hardware Considerations                    |  | 18-30       |
| TMS 9900 Nested Interrupt Priorities                                   |  | 18-29       |
| TMS 9900 Program Memory Addressing                                     |  | 18-8        |
| TMS 9940 CRU Bit Utilization                                           |  | 18-59       |
| TMS 9940 CRU I/O Expansion Mode                                        |  | 18-60       |
| TMS 9940 HOLD Logic                                                    |  | 18-64       |
| TMS 9940 IDLE Logic                                                    |  | 18-64       |
| TMS 9940 Multiprocessor System Interface                               |  | 18-61       |
| TMS 9940 Simple CRU I/O Mode                                           |  | 18-59       |
| TMS 9940 Sync Mode                                                     |  | 18-64       |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                            |                                               | <b>PAGE</b> |
|---------------------------------------------------------|-----------------------------------------------|-------------|
| <b>T (Cont.)</b>                                        |                                               |             |
| TMS 9980 Series Clock Logic                             |                                               | 18-49       |
| Transient Selection, Preventing on an 8085A             |                                               | 5-12        |
| TTL Level PACE Bus                                      |                                               | 15-2        |
| Two 8255 Devices Used for 16-Bit I/O Ports with INS8900 |                                               | 15-43       |
| TxAKA and TxAKB Signals, MC6844 DMAC                    |                                               | 9-113       |
| TxAKA, TxAKB, DMAC, DGRNT, and TxSTB Signals, MC6844    |                                               | 9-114       |
| TxAKB and TxAKA Signals, MC6844 DMAC                    |                                               | 9-113       |
| TxRON, DQRT and DGRNT Signals, MC6844 DMAC              |                                               | 9-112       |
| TxR0-TxR3 Signals, MC6844 DMAC                          |                                               | 9-114       |
| TxR1 Signal, MC6844 DMAC                                |                                               | 9-114       |
| TxR2 Signal, MC6844 DMAC                                |                                               | 9-114       |
| TxR3 Signal, MC6844 DMAC                                |                                               | 9-114       |
| TxSTB Signal, MC6844 D                                  |                                               | 9-113       |
| TxSTB Signal, MC6844 DMAC                               |                                               | 9-115       |
| TxSTB, TxAKA, TxAKB, DMAC, and DGRNT Signals, MC6844    |                                               | 9-114       |
| <b>U</b>                                                | Utilities                                     | 25-8        |
| <b>V</b>                                                | Variable Cost Contributing Factors            | 25-1        |
|                                                         | Variable Costs                                | 25-2        |
| <b>W</b>                                                | Wait States during 8085 Interrupt Acknowledge | 5-29        |
| <b>Z</b>                                                |                                               |             |
| Zero Status in Chip Slice Logic                         |                                               | 22-5        |
| Z80 Bus Control Signals                                 |                                               | 7-9         |
| Z80 CPU Control Signals                                 |                                               | 7-9         |
| Z80 Indexed Addressing                                  |                                               | 7-6         |
| Z80 LSI Technology                                      |                                               | 7-1         |
| Z80 System Control Signals                              |                                               | 7-7         |
| Z80 Wait States During Interrupt Acknowledge            |                                               | 7-18        |
| 1650 Accumulator                                        |                                               | 17-4        |
| 1650 Counter/Timer Logic                                |                                               | 17-7        |
| 1650 I/O Pin Logic                                      |                                               | 17-3        |
| 1650 I/O Port Registers                                 |                                               | 17-3        |
| 1650 Program Counter                                    |                                               | 17-4        |
| 1650 Program Memory                                     |                                               | 17-3        |
| 1650 Stack                                              | 17-6                                          |             |
| 1650 Status Register                                    |                                               | 17-5        |
| 1650 Timing                                             |                                               | 17-8        |
| 1650 Vxx Power Supply                                   |                                               | 17-8        |
| 2650A Accumulator                                       |                                               | 11-3        |
| 2650A Branch Instruction Addressing                     |                                               | 11-7        |
| 2650A Bus Access Control Signals                        |                                               | 11-11       |
| 2650A Bus Contents Identification Signals               |                                               | 11-11       |
| 2650A CPU Execution Control Signals                     |                                               | 11-11       |
| 2650A Extended Addressing Options                       |                                               | 11-6        |
| 2650A External Device Control Signals                   |                                               | 11-12       |
| 2650A Index Registers                                   |                                               | 11-3        |
| 2650A Interrupt Control Signals                         |                                               | 11-12       |
| 2650A Memory Page Selection                             |                                               | 11-8        |
| 2650A Memory Pages                                      |                                               | 11-3        |
| 2650A Program Counter                                   |                                               | 11-3        |
| 2650A Program Relative Addressing Options               |                                               | 11-4        |
| 2650A Stack                                             |                                               | 11-4        |
| 2901 ALU Operations Specification                       |                                               | 24-4        |
| 2901 ALU Source Specification                           |                                               | 22-4        |

## QUICK INDEX (Continued)

| INDEX                                                              | PAGE      |
|--------------------------------------------------------------------|-----------|
| 3870 Clock Logic                                                   | 2-10      |
| 3870 Direct Scratchpad Addressing                                  | 2-7       |
| 3870 Event Counter Mode                                            | 2-17      |
| 3870 Expansion                                                     | 2-3       |
| 3870 Implied Scratchpad Addressing                                 | 2-7       |
| 3870 Interrupt Disable                                             | 2-13      |
| 3870 Interval Timer Mode                                           | 2-16      |
| 3870 Memory Addressing                                             | 2-6       |
| 3870 Pulse Width Measurement Mode                                  | 2-16      |
| 3870 r Scratchpad Addressing                                       | 2-8       |
| 3870 Reset                                                         | 2-10      |
| 3870 Scratchpad Memory Addressing                                  | 2-6       |
| 3870/F8 Accumulator                                                | 2-5       |
| 3870/F8 Data Counters                                              | 2-6       |
| 3870/F8 Program Counter                                            | 2-6       |
| 3870/F8 Scratchpad                                                 | 2-6       |
| 3870/F8 Stack Register                                             | 2-6       |
| <br>6800 Support Devices Not Compatible with INS8900               | <br>15-44 |
| 8T32 IV Byte Access Logic                                          | 14-23     |
| 8T32 IV Byte Addressing                                            | 14-4      |
| 8T32 IV Bytes                                                      | 14-4      |
| 8T33 IV Byte Access Logic                                          | 14-23     |
| 8T33 IV Byte Addressing                                            | 14-4      |
| 8T33 IV Bytes                                                      | 14-4      |
| 8T35 IV Byte Access Logic                                          | 14-23     |
| 8T35 IV Byte Addressing                                            | 14-4      |
| 8T35 IV Bytes                                                      | 14-4      |
| 8T36 IV Byte Access Logic                                          | 14-23     |
| 8T36 IV Byte Addressing                                            | 14-4      |
| 8T36 IV Bytes                                                      | 14-4      |
| 8X300 Data and I/O Addressing                                      | 14-4      |
| 8X300 Program Memory Addressing                                    | 14-4      |
| 8X300 Rotate and Mask Logic                                        | 14-7      |
| 8X300 Shift and Merge Logic                                        | 14-8      |
| 8035, 8048, and 8748 Reset                                         | 6-17      |
| 8041 Buffer Status Register                                        | 6-44      |
| 8048 and 8748 Debug Mode                                           | 6-15      |
| 8048 Series External Memory Access Mode                            | 6-14      |
| 8048 Series Internal Execution Mode                                | 6-14      |
| 8048 Series I/O Port Pin Logic                                     | 6-5       |
| 8048 Series I/O Ports                                              | 6-5       |
| 8048 Series Machine Cycles and Clock Periods                       | 6-18      |
| 8048 Series Memory Spaces                                          | 6-8       |
| 8048 Series Microcomputer, Standard Memory Devices Connected to an | 6-22      |
| 8048 Series Microcomputer, 8355 or 8755 Connected to an            | 6-22      |
| 8048 Series Program Memory Addressing                              | 6-8       |
| 8048 Series Single Stepping                                        | 6-15      |
| 8048 Series Verify Mode                                            | 6-15      |
| 8048 Wait State                                                    | 6-20      |
| 8048, 8748, and 8035 Reset                                         | 6-17      |
| 8049 Series Microcomputers                                         | 6-3       |
| 8080A and INS8900 System Busses Compared                           | 15-43     |
| 8080A and 8086 Registers' Compatibility                            | 20-3      |
| 8080A Carry Status Borrow Logic                                    | 4-5       |
| 8080A Carry Status Nomenclature                                    | 4-26      |

## QUICK INDEX (Continued)

| INDEX                                                            | PAGE  |
|------------------------------------------------------------------|-------|
| 8080A Clock Periods                                              | 4-7   |
| 8080A Data Bus Definition Signals                                | 4-7   |
| 8080A Direct Addressing                                          | 4-5   |
| 8080A Implied Addressing                                         | 4-4   |
| 8080A Instruction Status                                         | 4-10  |
| 8080A Interrupt Control Signals                                  | 4-7   |
| 8080A Interrupt Response Using CALL Instruction                  | 4-54  |
| 8080A Machine Cycles                                             | 4-7   |
| 8080A Slow Memories                                              | 4-13  |
| 8080A Timing Control Signals                                     | 4-6   |
| 8080A Wait State Request Logic                                   | 4-14  |
| 8085 and 8085A                                                   | 5-1   |
| 8085 and 8085A, ALE Differences in                               | 5-5   |
| 8085 and 8085A, ALE Generation in                                | 5-18  |
| 8085 and 8085A, Halt State in                                    | 5-24  |
| 8085 and 8085A, Hold State in                                    | 5-24  |
| 8085 and 8085A, Interrupt Differences in                         | 5-28  |
| 8085 Interrupt Acknowledge                                       | 5-29  |
| 8085 Interrupt Acknowledge, Wait States During                   | 5-29  |
| 8085 I/O Write Timing                                            | 5-16  |
| 8085 Memory Read Timing                                          | 5-15  |
| 8085 Memory Write Timing                                         | 5-16  |
| 8085 Multibyte Acknowledge                                       | 5-29  |
| 8085, Select Problem with                                        | 5-14  |
| 8085A and 8085                                                   | 5-1   |
| 8085A and 8085, Halt State in                                    | 5-24  |
| 8085A and 8085, Interrupt Differences in                         | 5-28  |
| 8085A Bus Control Signals                                        | 5-5   |
| 8085A Bus Idle Machine Cycle                                     | 5-18  |
| 8085A Clock Periods                                              | 5-8   |
| 8085A Control Signals                                            | 5-5   |
| 8085A Data Bus Definition Signals                                | 5-5   |
| 8085A Device Select Logic                                        | 5-10  |
| 8085A Hold Within a Halt State                                   | 5-27  |
| 8085A Interrupt Acknowledge                                      | 5-29  |
| 8085A Interrupt Signals                                          | 5-5   |
| 8085A Machine Cycles                                             | 5-7   |
| 8085A Multibyte Acknowledge                                      | 5-29  |
| 8085A Multiple Device Selects and Bus Loading                    | 5-11  |
| 8085A, Preventing Simultaneous Selection of I/O and Memory on an | 5-12  |
| 8085A, Preventing Transient Selection on an                      | 5-12  |
| 8085A Reset Signals                                              | 5-5   |
| 8085A RIM after TRAP                                             | 5-31  |
| 8085A Serial I/O                                                 | 5-5   |
| 8085A TRAP Interrupt                                             | 5-31  |
| 8086 and 8080A Registers' Compatibility                          | 20-3  |
| 8086 AX Register                                                 | 20-3  |
| 8086 Base Relative Indexed Addressing                            | 20-13 |
| 8086 BCD Addition                                                | 20-43 |
| 8086 BCD Division                                                | 20-45 |
| 8086 BCD Multiplication                                          | 20-45 |
| 8086 BCD Subtraction                                             | 20-43 |
| 8086 Bus Interface Unit (BIU)                                    | 20-25 |
| 8086 BX Register                                                 | 20-3  |
| 8086 Code Segment Register and Program Counter                   | 20-7  |
| 8086 Complex Control Signals                                     | 20-24 |
| 8086 CX Register                                                 | 20-5  |

## QUICK INDEX (Continued)

| <b>INDEX</b>                                                                | <b>PAGE</b> |
|-----------------------------------------------------------------------------|-------------|
| 8086 Data Memory Base Relative Addressing                                   | 20-13       |
| 8086 Data Segment and Stack Segment Registers                               | 20-9        |
| 8086 Direct Indexed Addressing                                              | 20-12       |
| 8086 Direct Memory Addressing                                               | 20-11       |
| 8086 DX Register                                                            | 20-5        |
| 8086 Execution Unit (EU)                                                    | 20-25       |
| 8086 External Memory Addressing                                             | 20-20       |
| 8086 Extra Segment, Source Index and Destination Index Registers            | 20-8        |
| 8086 HOLD in Maximum Mode System                                            | 20-35       |
| 8086 HOLD in Minimum Mode System                                            | 20-35       |
| 8086 Implied Memory Addressing                                              | 20-12       |
| 8086 Indirect Addressing                                                    | 20-17       |
| 8086 Instruction Queue                                                      | 20-25       |
| 8086 Interrupt Return                                                       | 20-41       |
| 8086 Interrupt Vector Table                                                 | 20-39       |
| 8086 I/O Port Addressing                                                    | 20-17       |
| 8086 Maskable Interrupt                                                     | 20-39,40    |
| 8086 Non-Maskable Interrupt                                                 | 20-39,40    |
| 8086 Program Relative Addressing                                            | 20-17       |
| 8086 Reset                                                                  | 20-23,79    |
| 8086 Segment Registers                                                      | 20-6        |
| 8086 Simple Control Signals                                                 | 20-24       |
| 8086 Single Instruction Time Identified                                     | 20-38       |
| 8086 Software Interrupts                                                    | 20-38,40    |
| 8086 Stack Segment and Stack Pointer Registers                              | 20-8        |
| 8155 Device Reset                                                           | 5-38        |
| 8155/8156 I/O Mode 0                                                        | 5-38        |
| 8155/8156 I/O Mode 1                                                        | 5-38        |
| 8155/8156 I/O Port Addresses                                                | 5-40        |
| 8155/8156 Timer Mode 0                                                      | 5-42        |
| 8156/8155 I/O Mode 0                                                        | 5-38        |
| 8156/8155 I/O Mode 1                                                        | 5-38        |
| 8156/8155 I/O Port Addresses                                                | 5-40        |
| 8212 I/O Port Used in SC/MP Systems, The                                    | 3-32        |
| 8212 Used as a Simple Input Port in an INS8900 System, The                  | 15-39       |
| 8212 Used as an Output Port in an INS8900 System, The                       | 15-41       |
| 8212 Used as an Output Port in an SC/MP System, The                         | 3-33        |
| 8212 Used in an INS8900 System for Input with Handshaking, The              | 15-40       |
| 8224 Clock Signals                                                          | 4-46        |
| 8243 Reset                                                                  | 6-53        |
| 8251 USART and 8253 Programmable Counter/Timer Used in INS8900 Systems, The | 15-43       |
| 8253 Programmable Counter/Timer and 8251 USART Used in INS8900 Systems      | 15-43       |
| 8255 Devices Used for 16-Bit I/O Ports with INS8900                         | 15-43       |
| 8255 PPI Devices Used in an INS8900 System                                  | 15-42       |
| 8259 PICU Interrupt Mask                                                    | 4-63        |
| 8259 PICU Interrupt Masking                                                 | 4-59        |
| 8259 PICU Interrupt Service Routine Priorities                              | 4-57        |
| 8259 PICU Polling                                                           | 4-59        |
| 8259 PICU Rotating Interrupt Priorities                                     | 4-58        |
| 8284 Wait State Logic                                                       | 20-79       |
| 8288 Advanced Write Control Signals                                         | 20-81       |
| 8288 Bus Controller Interrupt Signals                                       | 20-82       |
| 8288 Bus Controller Memory Protect                                          | 20-82       |
| 8288 I/O Bus Mode                                                           | 20-81       |
| 8355 or 8755 Connected to an 8048 Series Microcomputer                      | 6-22        |
| 8748 and 8048 Debug Mode                                                    | 6-15        |
| 8748 Programming Mode                                                       | 6-15        |

## **QUICK INDEX (Continued)**

| <b>INDEX</b>                                           | <b>PAGE</b> |
|--------------------------------------------------------|-------------|
| 8748, 8048, and 8035 Reset                             | 6-17        |
| 8755 and 8755A                                         | 5-51        |
| 8755 or 8355 Connected to an 8048 Series Microcomputer | 6-22        |
| 8755A and 8755                                         | 5-51        |
| 9080A AMD Status Difference                            | 4-6         |
| 9440 Instruction Fetch                                 | 19-23       |
| 9440 Memory Read                                       | 19-23       |
| 9440 System Bus                                        | 19-14       |

# INTRODUCTION

This is the first of two volumes that replace An Introduction to Microcomputers: Volume 2 — Some Real Products. This volume describes microprocessors and dedicated support devices. Volume 3 describes general support devices.

We define a "dedicated" support device as one best used with its parent microprocessor. We define a "general" support device as one which can be used with any microprocessor.

Unfortunately, categorizing support devices as "dedicated" or "general" is not always straightforward. Certainly IM6100 and TMS9900 support devices have CPU interfaces which are peculiar to the parent microprocessor, so using them with other microprocessors makes little sense. Most MC6800 microprocessor support devices are also considered dedicated because they use the MC6800 clock signal. This clock signal is automatically generated by an MC6800 microprocessor or its clock device. It can be derived quite inexpensively in other microcomputer systems; nevertheless, we include MC6800 support devices in Volume 2, because in our opinion the added clock logic is not compensated for by any performance capabilities over and above those which you would find in a competing device that did not require the added clock logic.

When reading Volumes 2 and 3, therefore, you should bear in mind that we have had to be subjective when deciding whether some parts should be described in Volume 2 or Volume 3. Do not automatically use support parts described in Volume 2 without checking equivalent parts described in Volume 3. Conversely, there may be instances where your application is better served by a support device described in Volume 2. In general, you can look upon Volume 3 support devices as CPU-independent, while Volume 2 devices are CPU-dependent.

In order to cope with the rapid evolution of new parts, Volumes 2 and 3 have been printed loose-leaf. Each volume will have six updates per year, appearing at bimonthly intervals. For Volume 2, updates will appear in November, January, March, May, July and September. Each September the entire book will be reprinted, including the past year's updates. If you have inserted your updates, you will not need to buy a new book next year. For your convenience, an order form may be found at the back of this book.

## SIGNAL CONVENTIONS

Signals may be active high, active low or active in two states. An active high signal is one which, in the high state, causes events to occur, while in the low state has no significance. A signal that is active low causes events to occur when in the low state, but has no significance in the high state. A signal that has two active states will cause two different types of events to occur, depending upon whether the signal is high or low; this signal has no inactive state. Within this book a signal that is active low has a bar placed over the signal name. For example, WR identifies a "write strobe" signal which is pulsed low when data is ready for external logic to receive. A signal that is active high or has two active states has no bar over the signal name.

## TIMING DIAGRAM CONVENTIONS

Timing diagrams play an important part in the description of any microprocessor or support device. Timing diagrams are therefore used extensively in this book. All timing diagrams observe the following conventions:

- 1) A low signal level is equivalent to no voltage. A high signal level is equivalent to voltage present:



- 2) A single signal making a low-to-high transition is illustrated like this:



- 3) A single signal making a high-to-low transition is illustrated like this:



- 4) When two or more parallel signals exist, the notation:



states that one or more of the parallel signals change level, but the transition (high-to-low or low-to-high) is unspecified.

- 5) A three-state single signal is shown floating thus:



- 6) A three-state bus containing two or more signals is shown floating thus:



- 7) When one signal condition triggers other signal changes, an arrow indicates the relationship as follows:



Thus a signal making a low-to-high transition would be illustrated triggering another signal making a high-to-low transition as follows:



A signal making a high-to-low transition triggering a bus change of state would be illustrated as follows:



- 8) When two or more conditions must exist in order to trigger another logic event, the following illustration is used:



Thus a low-to-high transition of one signal occurring while another signal is low would be illustrated triggering a third event as follows:



- 9) When a single triggering condition causes two or more events to occur, the following illustration is used:



Thus a low-to-high transition of one signal triggering changes in two other signal levels would be illustrated as follows:



- 10) All signal level changes are shown as square waves. Thus rise and fall times are ignored. These times are given in the data sheets which appear at the end of every chapter.

## INSTRUCTION SET CONVENTIONS

**Every microcomputer instruction set is described with two tables. One table identifies the operations which occur when the instruction set is executed, while the second table defines object codes and instruction times.**

**Because of the wide differences that exist between one instruction set and another, we have elected not to use a single set of codes and symbols to describe the operations for all instructions in all instruction sets. We believe any type of universal convention is likely to confuse rather than clarify; therefore each instruction set table is preceded by a list of symbols as used within that table alone.**

**A short benchmark program is given to illustrate each instruction set. Some comments regarding benchmark programs in general are, however, in order. We are not attempting to highlight strengths or weaknesses of different devices, nor does this book make any attempt at comparative analyses, since the criteria which make one microcomputer better than another are simply too dependent on the application.**

## **ATTENTION WRITERS**

Osborne & Associates is seeking qualified contributors to future updates of Volumes 2 and 3. Qualified contributors must have an excellent technical background, they must be able to write clearly, and they must be unaffiliated with any manufacturer of semiconductor devices. Faculty at universities are particularly welcome as contributors.

A contributor, when selected, will be assigned a specific category of parts to keep updated. Keeping parts updated will include describing new parts in the category as they appear, and improving the description of parts that are already covered.

If you would like to become a contributor to Volume 2 and/or Volume 3, please write stating your qualifications and the categories of parts that you believe you could cover competently. If possible, send us a sample of your work; we suggest two or three pages of a part description following the format presented in these books as closely as possible. Send material to:

**OSBORNE & ASSOCIATES, INC.**  
**P.O. Box 2036**  
**Berkeley, California 94702**  
**Attention: Volume 2/3 Contributors**

# Chapter 1

## 4-BIT MICROPROCESSORS AND THE TMS1000 SERIES MICROCOMPUTERS

The earliest microprocessors were all 4-bit devices; that is to say, data was operated on in 4-bit units, frequently referred to as "nibbles". **Early microprocessors were 4-bit devices simply because the concept of an LSI CPU was ambitious enough; starting with an 8-bit CPU would have been foolhardy.**

But LSI technology has advanced so rapidly that there is an inconsequential difference between the cost of manufacturing an 8-bit CPU chip as against a 4-bit chip. Manufacturers attempted to maintain an artificial price differential between their 4-bit and 8-bit CPUs in order to prolong the life of the 4-bit product; but the pressure of competition has all but extinguished these price differentials—with the result that the 4-bit microprocessor is a dying product. Price is the only advantage that 4-bit microprocessors offer when compared to the more capable 8-bit microprocessor.

Early 4-bit microcomputers included such devices as the Intel 4004 and 4040 and the National Semiconductor IMP-4. These early 4-bit microcomputers require package counts that exceed typical 8-bit microcomputers that are now available; therefore **the economics of today dictate that the Intel 4004, the Intel 4040 and the IMP-4 offer less capability for more money.** Only the most unusual application could be more economically implemented using one of these three 4-bit microcomputers, rather than a simple 8-bit device such as the 3870, COSMAC, 8048, or one of the 38-pin MCS6500 series CPUs. **We consider the Intel 4004, the Intel 4040 and the IMP-4 to be obsolete devices; therefore they are not described.**

It is interesting to note that even though these three 4-bit microcomputers are obsolete, they will continue to have a significant market for many years to come, based on products that were designed around them before they became obsolete. The fact that they are obsolete simply means that, were you to design a new product today, you would be better off using one of the simple 8-bit microcomputers. That does not mean it would be economical to redesign a product that already exists, simply to take advantage of more recent microcomputer developments. The cost of re-engineering around a new microcomputer will likely overwhelm any savings that may accrue.

**The TMS1000 series microcomputer devices, initially manufactured by Texas Instruments, are still economically very viable—even though they are 4-bit devices. This is because the TMS1000 is a one-chip microcomputer. ROM, RAM, CPU and I/O logic are all provided within a single package. The low cost associated with the single-chip TMS1000 microcomputer package makes this the product of choice for a large number of simple applications that can be accommodated within the logical confines of the TMS1000.**

**In reality, the TMS1000 is a family of six 4-bit microcomputers whose differences are summarized in Table 1-1. The various microcomputers are sufficiently similar for us to describe them together. PMOS and CMOS versions are now available. Some CMOS versions manufactured by Motorola have the part number MC141000.**

Table 1-1. TMS1000 Series Microcomputer Summary

|                           | TMS<br>1000  | TMS<br>1200  | TMS<br>1070  | TMS<br>1270  | TMS<br>1100  | TMS<br>1300  | TMS<br>1000C | TMS<br>1200C | MC<br>141000                 | MC<br>141200                 |
|---------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|------------------------------|------------------------------|
| Package Pin Count         | 28           | 40           | 28           | 40           | 28           | 40           | 28           | 40           | 28                           | 40                           |
| ROM Program Bytes*        | 1024         | 1024         | 1024         | 1024         | 2048         | 2048         | 1024         | 1024         | 1024                         | 1024                         |
| RAM Data Nibbles**        | 64           | 64           | 64           | 64           | 128          | 128          | 64           | 64           | 64                           | 64                           |
| R Signal Outputs          | 11           | 13           | 11           | 13           | 11           | 16           | 10           | 16           | 11                           | 16                           |
| O Data Outputs            | 8            | 8            | 8            | 10           | 8            | 8            | 8            | 8            | 8                            | 8                            |
| Maximum Rated Voltage     | 20           | 20           | 35           | 35           | 20           | 20           | 6            | 6            | 6.5                          | 6.5                          |
| Typical Power Dissipation | 15V/<br>90mW | 15V/<br>90mW | 15V/<br>90mW | 15V/<br>90mW | 15V/<br>90mW | 15V/<br>90mW | 5V/<br>15mW  | 5V/<br>5mW   | 5V/<br>2.5mW<br>3V/<br>0.5mW | 5V/<br>2.5mW<br>3V/<br>0.5mW |

\*A Byte is eight bits    \*\*A Nibble is four bits

Figure 1-1 illustrates that part of our general microcomputer system logic which is implemented by the TMS1000 series microcomputers. This figure is deceptive, since it would be hard to compare the primitive I/O capabilities of the TMS1000 with a device such as the 8255 Programmable Peripheral Interface device, which is described in Volume III. Nevertheless, Figure 1-1 does indicate the logic which is provided by a TMS1000 series microcomputer, albeit in a primitive form.



Figure 1-1. Logic of the TMS1000 Series Microcomputer

**The fact that the TMS1000 series microcomputers are single-chip devices has a number of secondary, non-obvious implications.** Most important of all, there are no such things as support devices. The 1024 or 2048 bytes of ROM represent the exact amount of program memory which will be present; there can be neither more nor less. Similarly, the 64 or 128 nibbles of RAM cannot be expanded. Direct memory access logic is not present — and its presence would make very little sense anyway; with the small total ROM and RAM memory available, there simply is not the opportunity to transfer blocks of data long enough to warrant bypassing the CPU.

Interrupts, similarly, would be of marginal value to a TMS1000 microcomputer. Given the small amount of program memory available and the very low cost of the package, it would be hard to justify the complexities of interrupt logic, simply to have the microcomputer perform more than one task.

All devices of the TMS1000 microcomputer family are implemented using PMOS technology. Selected CMOS parts are also available.

A single -15V power supply is required for PMOS parts. CMOS parts use power supplies in the range +3V to +6.5V.

The fastest clock frequency which can drive a TMS1000 series microcomputer has a 2.5 microsecond cycle time. All instructions execute in six clock cycles, or 15 microseconds; but beware of making direct execution speed comparisons between the TMS1000 and the 8-bit microcomputers which are described next. A TMS1000 program will usually be considerably longer than the 8-bit microcomputer equivalent because the TMS1000 instruction set is more primitive; but this is not always true. It is possible for the TMS1000 instruction set to equal or surpass many 8-bit microprocessors, in terms of instruction efficiency, for certain control applications.

The prime manufacturer of the TMS1000 is:

TEXAS INSTRUMENTS, INC.  
P.O. Box 1443  
Houston, Texas 77001

A second source for CMOS parts with MC14xxxx part numbers (see Table 1-1) is:

MOTOROLA INCORPORATED  
CMOS Products Division  
3501 Ed Bluestein Blvd.  
Austin, Texas 78721

## TMS1000 PROGRAMMABLE REGISTERS

TMS1000 programmable registers may be illustrated as follows:



Apart from being only four bits wide, **the Accumulator is a typical primary Accumulator.** It is the principal source and destination for data that is being operated on.

Taken together, the X and Y registers constitute a 6- or 7-bit Data Counter which addresses the 64 or 128 nibbles of RAM. The X register is two or three bits wide and the Y register is four bits wide. Since the X and Y registers are indeed separate and distinct registers, RAM is effectively divided into four or eight pages, each of which is 16-nibbles long. A four-page RAM may be illustrated as follows:



**The Y register, in addition, serves as a secondary Accumulator and an output Address register.** We will describe its use as an output Address register shortly.

Those TMS1000 series microcomputers that provide 128 nibbles of RAM have a 3-bit X register. RAM is then divided into eight 16-nibble pages.

**The Program Counter and Page Address register, taken together, constitute a 10-bit Program Counter.** They are, in reality, separate and distinct registers, with the result that program memory is divided into sixteen 64-byte pages.

**Those TMS1000 microcomputers that provide 2048 bytes of program memory have an additional 1-bit flag, referred to as Chapter Logic, which is used to select one of two alternate 1024-byte ROM chapters.**

**The Subroutine Return register is simply a buffer for the Program Counter register. Similarly, the Page Buffer register is a simple buffer for the Page Address register.** These two buffer registers allow the TMS1000 a single level of subroutine call logic. **When a subroutine is called,** the contents of the Page Address and Page Buffer registers are exchanged. the Program Counter register contents are moved to the Subroutine Return register, and a new value provided by the subroutine Call instruction is loaded into the Program Counter. This may be illustrated as follows:



**TMS1000 SUBROUTINES**

## TMS1000 MEMORY ADDRESSING MODE

**TMS1000 microcomputers have separate and distinct program and data memories.** There are no instructions capable of writing into program memory, and data memory cannot contain instruction object codes.

**Data memory is accessed using implied addressing.** The X and Y registers combine to serve as a Data Counter; we have just described this use of the X and Y registers.

**Only subroutine Call instructions and Branch instructions address program memory. These instructions address program memory using variations of absolute, paged direct addressing.**

We have already illustrated the addressing logic of a subroutine call.

A Branch instruction loads the Program Counter with a new address, which is provided by the instruction, just as a Call instruction does. If the Branch instruction occurs in a subroutine — that is, in the sequence between a subroutine Call instruction and a subroutine Return instruction — the Page Address register will not be affected. However, execution of a Branch instruction outside a subroutine will load the Page Address register from the Page Buffer register. The two types of program branches may be illustrated as follows:



## TMS1000 STATUS FLAGS

**The TMS1000 series microcomputers have a single status flag which combines to serve as a Carry status and a simple logic decision status. All Branch and subroutine Call instructions are conditional;** the Branch or subroutine Call occurs only if the status flag is 1.

The unique feature of the status flag as compared to most status logic is that its passive level is high (1). **If an instruction causes the status flag to be reset to 0, it will revert to 1 after a single instruction cycle:**



Instructions that test the condition of the status flag must directly follow the instruction which modifies the level of the status flag.

## TMS1000 INPUT AND OUTPUT LOGIC

**The only data input to a TMS1000 series microcomputer occurs as 4-bit nibbles, referred to in Texas Instruments literature as K inputs.** Instructions that access the K inputs simply input whatever signal levels exist at the time of the access.

**TMS1000 series microcomputers output data referred to as O outputs, and control signals referred to as R outputs.**

There are eight data or O outputs; but they are created in an unusual way. O output logic receives, as inputs, the contents of the Accumulator, plus the status flag. These five data bits create the eight O output signals according to a matrix which you must define when you order the TMS1000 microcomputer. This may be illustrated as follows:



As the illustration above would imply, the five inputs select 32 of the possible 256 signal combinations which can be output via the eight O outputs.

The control R outputs are treated as 11, 13 or 16 single control signals. Refer to Table 1-1, which identifies the number of R output signals available with each of the TMS1000 series microcomputers. **You can set or reset R output signals individually. The Y register is used to identify the individual R signal which is being set or reset.**

### TMS1000 SERIES MICROCOMPUTER PINS AND SIGNALS

**Figures 1-2 through 1-7 illustrate the pins and signals of the TMS1000 series microcomputers.** Note that the TMS1000 and TMS1100 microcomputers have identical pins and signals. Since signals are consistent for the entire family of microcomputers, they will be described together.

**The four data inputs are provided by K1, K2, K4 and K8.** We would name these signals D10, D11, D12 and D13 to be consistent with common microcomputer terminology; however, Texas Instruments literature uses the signal names K1, K2, K4 and K8 to represent the binary level of each signal.



Figure 1-2. TMS1000 and MC141000 Microcomputer Signals and Pin Assignments



Figure 1-3. TMS1200 and MC141200 Microcomputer Signals and Pin Assignments



Figure 1-4. TMS1070 Microcomputer Signals and Pin Assignments



| Pin Name                          | Description      | Type   |
|-----------------------------------|------------------|--------|
| K1, K2, K4, K8                    | Data input       | Input  |
| O0 - O9                           | Data output      | Output |
| R0 - R12                          | Control output   | Output |
| OSC1, OSC2                        | Timing           | Input  |
| INIT                              | Power on reset   | Input  |
| V <sub>DD</sub> , V <sub>SS</sub> | Power and Ground |        |

Figure 1-5. TMS1270 Microcomputer Signals and Pin Assignments



| Pin Name                          | Description      | Type   |
|-----------------------------------|------------------|--------|
| K1, K2, K4; K8                    | Data input       | Input  |
| O0 - O7                           | Data output      | Output |
| R0 - R10                          | Control output   | Output |
| OSC1, OSC2                        | Timing           | Input  |
| INIT                              | Power on reset   | Input  |
| V <sub>DD</sub> , V <sub>SS</sub> | Power and Ground |        |

Figure 1-6. TMS1100 Microcomputer Signals and Pin Assignments



| Pin Name                          | Description      | Type   |
|-----------------------------------|------------------|--------|
| K1, K2, K4, K8                    | Data input       | Input  |
| O0 - O7                           | Data output      | Output |
| R0 - R15                          | Control output   | Output |
| OSC1, OSC2                        | Timing           | Input  |
| INIT                              | Power on reset   | Input  |
| V <sub>DD</sub> , V <sub>SS</sub> | Power and Ground |        |

Figure 1-7. TMS1300 Microcomputer Signals and Pin Assignments

The O outputs are provided by O0 - O7, or, in the case of the TMS1270, O0 - O9.

The R outputs occur at R0 - R15, or some smaller number of R outputs, depending on the microcomputer.

**OSC1 and OSC2 are timing inputs and outputs.** A number of timing options are provided. All TMS1000 series microcomputers contain internal clock logic which you can access in conjunction with an external RC circuit as follows:



You can also input an externally created clock signal at OSC1, in which case OSC2 must be connected to ground (V<sub>SS</sub>). When you have more than one TMS1000 series microcomputer in a configuration, it is a good idea to synchronize the many microcomputers by driving them with a single clock signal.

**INIT is a power on reset signal.** Following power on, INIT should be input high (V<sub>SS</sub>) for at least six consecutive clock cycles. The Reset operation stores binary ones in the Page Address register and the Page Buffer register. The O outputs, the R outputs and the Program Counter are all zeroed. Thus, the first instruction executed will have the hexadecimal address 3C016.



## TMS1000 SERIES MICROCOMPUTER INSTRUCTION EXECUTION

No microcomputer described in this book has simpler instruction execution timing than the TMS1000 series. All instructions generate one byte of object code. There are no two- or three-byte object codes. Similarly, every instruction executes in a single machine cycle, as timed by the system clock.

## TMS1000 SERIES MICROCOMPUTER INSTRUCTION SET

There are variations in the instruction sets of the different microcomputers in the TMS1000 series. However, the different instruction sets are similar enough for us to describe them all in Table 1-2. As compared to similar tables for other microcomputers in this book, Table 1-2 has an additional column which identifies the instructions which are available with each of the TMS1000 series microcomputers.

Within the confines of a single-chip microcomputer, the instruction set defined in Table 1-2 is both powerful and effective. It would be easy to point out instruction set features which, from a programmer's point of view, are undesirable; however, the TMS1000 series microcomputers are oriented to digital logic. The TMS1000 is not a product that gets programmed; rather, its instruction set is a means of defining an optional portion of the ROM mask. Within this context, the instruction set is very adequate. Note that, since you are dealing with a single-chip microcomputer, there is nothing to prevent you from redefining the Control Unit and thus creating your own instruction set.

## THE BENCHMARK PROGRAM

The benchmark program we are using throughout this book in order to exercise the various microcomputer instruction sets is essentially meaningless in any TMS1000 application. Given 64, or at most, 128 nibbles of RAM, the whole concept of moving data among tables is meaningless. We therefore simplify the problem and look upon IOBUF as external logic. Instead of reading from IOBUF, we will input K data. We will assume that each block of K data is preceded by a nibble which defines the number of data nibbles to follow:



Thus, each block of data that is input must be fifteen nibbles or less in length.

|      |      |                                                       |
|------|------|-------------------------------------------------------|
| LDX  | TBHI | LOAD TABLE PAGE ADDRESS                               |
| TKA  |      | INPUT FIRST K NIBBLE. IT EQUALS DATA NIBBLE TO FOLLOW |
| TAY  |      | MOVE TO Y. XY NOW ADDRESSES END OF TABLE              |
| LOOP | TKA  | INPUT NEXT DATA NIBBLE                                |
|      | TAM  | SAVE IN MEMORY                                        |
|      | DYN  | DECREMENT Y                                           |
|      | BR   | LOOP IF Y NOT 0, RETURN FOR NEXT NIBBLE               |

Symbols are used in Table 1-2 as follows:

Registers:

- A - Accumulator
- X,Y - Data Counter. Y also serves as an output address.
- PC - Program Counter
- PA - Page Address register
- CF - Chapter Flag (one bit)
- SR - Subroutine Return register
- PB - Page Buffer

Statuses:

- ST - The Status Flag
- C - The status flag reflects a Carry. That is, it is set if there is a Carry from the most significant bit (MSB), and reset otherwise.
- NE - The status flag reflects "not equal". That is, it is set if the compared bits are not equal, and reset if they are equal.

## Inputs and Outputs:

- K - the four input lines
- O - the five-bit Output register
- R - the control outputs

bb Two bits in the object code which specify one of the four bits of a RAM location:



- b Operand which specifies one bit of a RAM location
- data 2, 3, or 4 bits of immediate data
- label Destination of Branch instruction (6 bits of direct address in the object code)
- $R([Y])$  The control output line specified by the contents of the Y register.
- x One bit of immediate data or direct address in the object code.
- $[X](MSB)$  The most significant bit of the X register
- $[[X,Y]]$  The contents of the RAM location addressed by the contents of the Data Counter.
- $[[X,Y]](b)$  The specified bit of the RAM location addressed by the contents of the Data Counter.
- $[ ]$  Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If K or R is enclosed within the brackets, then the data at the inputs or control outputs is specified.
- $\overleftarrow{-}$  Data is transferred in the direction of the arrow.
- $\overleftrightarrow{-}$  Data is exchanged between the two locations designated on either side of the arrow.

Where two object codes are given, the first is the code used in the TMS1000, TMS1200, TMS1070, and TMS1270, while the second is the object code used in the TMS1100 and TMS1300.

X in one of the rightmost three columns means that the instruction is implemented on the designated TMS1000 device.

Table 1-2. TMS1000 Series Instruction Set Summary

| TYPE                                           | MNEMONIC | OPERAND | STATUSES |    | OPERATION PERFORMED                                                                                                                                                                 | OBJECT CODE | TMS1000 | TMS1100 | MC141000 |
|------------------------------------------------|----------|---------|----------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------|---------|----------|
|                                                |          |         | C        | NE |                                                                                                                                                                                     |             | TMS1200 | TMS1300 | MC141200 |
| I/O                                            | KNEZ     |         |          | X  | If $[K] \neq 0$ , ST — 1<br>Set status only if data on input lines is not 0.<br>$[K] \leftarrow [A]$                                                                                | 09          | X       |         | X        |
|                                                | TKA      |         |          |    | Load Accumulator with data on input lines.                                                                                                                                          | 0E          |         | X       | X        |
|                                                | SETR     |         |          |    | $R([Y]) \leftarrow 1$<br>Set R output addressed by contents of Y.                                                                                                                   | 08          | X       | X       | X        |
|                                                | RSTR     |         |          |    | $R([Y]) \leftarrow 0$<br>Reset R output addressed by contents of Y.                                                                                                                 | 0D          | X       | X       | X        |
|                                                | TDO      |         |          |    | $[O] \leftarrow ([A], ST)$<br>Transfer data from Accumulator and status flag to the O outputs.                                                                                      | 0C          | X       | X       | X        |
|                                                | CLO      |         |          |    | $[O] \leftarrow 00_{16}$<br>Clear the O Output register.                                                                                                                            | 0A          | X       | X       | X        |
| PRIMARY MEMORY REFERENCE                       | TAM      |         |          |    | $[A] \rightarrow [[X,Y]]$<br>Store Accumulator to RAM location addressed by contents of XY Data Counter.                                                                            | 03          | X       |         | X        |
|                                                | TMY      |         |          |    | $[[X,Y]] \rightarrow [Y]$<br>Load Register Y from RAM.                                                                                                                              | 27          |         | X       | X        |
|                                                | TMA      |         |          |    | $[[X,Y]] \rightarrow [A]$<br>Load Accumulator from RAM.                                                                                                                             | 22          | X       | X       | X        |
|                                                | XMA      |         |          |    | $[[X,Y]] \leftarrow [A]$<br>Exchange contents of RAM location addressed by Data Counter XY with those of Accumulator.                                                               | 21          | X       | X       | X        |
|                                                |          |         |          |    |                                                                                                                                                                                     | 2E          | X       |         |          |
| PRIMARY MEMORY REFERENCE WITH REGISTER OPERATE | TAMIY    |         |          |    | $[A] \rightarrow [[X,Y]]; [Y] \leftarrow [Y] + 1$<br>Store Accumulator to RAM and increment contents of Y register.                                                                 | 03          | X       |         | X        |
|                                                | TAMIYC   |         | X        |    | $[A] \rightarrow [[X,Y]]; [Y] \leftarrow [Y] + 1; ST \leftarrow C$<br>Store Accumulator to RAM and increment contents of Y register. Set status flag only if there is a carry.      | 25          |         | X       |          |
|                                                | TAMDYN   |         | X        |    | $[A] \rightarrow [[X,Y]]; [Y] \leftarrow [Y] - 1; ST \leftarrow C$<br>Store Accumulator to RAM and decrement contents of Y register. Set status flag only if there is no borrow.    | 24          |         | X       |          |
|                                                | TAMZA    |         |          |    | $[A] \rightarrow [[X,Y]]; [A] \leftarrow 0$<br>Store Accumulator to RAM and then clear Accumulator.                                                                                 | 04          | X       | X       | X        |
|                                                |          |         |          |    |                                                                                                                                                                                     | 26          |         | X       | X        |
| SECONDARY MEMORY REFERENCE (MEMORY OPERATE)    | AMAAC    |         | X        |    | $[A] \rightarrow [[X,Y]] + [A]; ST \leftarrow C$<br>Add contents of RAM location to those of Accumulator. Set status flag only if there is a carry.                                 | 25          | X       |         | X        |
|                                                | SAMAN    |         | X        |    | $[A] \rightarrow [[X,Y]] - [A]; ST \leftarrow C$<br>Subtract Accumulator contents from those of RAM location. Set status flag only if there is no borrow.                           | 06          |         | X       | X        |
|                                                | IMAC     |         | X        |    | $[A] \rightarrow [[X,Y]] + 1; ST \leftarrow C$<br>Load contents of RAM location to Accumulator and increment. Set status flag only if there is a carry. RAM contents are unchanged. | 27          | X       | X       | X        |
|                                                |          |         |          |    |                                                                                                                                                                                     | 3C          |         | X       |          |
|                                                |          |         |          |    |                                                                                                                                                                                     | 28          | X       |         |          |
|                                                |          |         |          |    |                                                                                                                                                                                     | 3E          |         | X       |          |

Table 1-2. TMS1000 Series Instruction Set Summary (Continued)

| TYPE                                                          | MNEMONIC | OPERAND | STATUSES |    | OPERATION PERFORMED                                                                                                                                          | OBJECT CODE | TMS1000<br>TMS1200<br>TMS1070<br>TMS1270 | TMS1100<br>TMS1300 | MC141000<br>MC141200 |
|---------------------------------------------------------------|----------|---------|----------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------|--------------------|----------------------|
|                                                               |          |         | C        | NE |                                                                                                                                                              |             |                                          |                    |                      |
| SECONDARY MEMORY REFERENCE<br>(MEMORY OPERATE)<br>(CONTINUED) | DMAN     |         | X        |    | [A]—[[X,Y]]-1; ST — C<br>Load contents of RAM location to Accumulator and decrement. Set status flag only if there is no borrow. RAM contents are unchanged. | 2A<br>07    | X                                        | X                  | X                    |
|                                                               | ALEM     |         | X        |    | If [A] ≤ [[X,Y]], ST — 1<br>Set status flag only if Accumulator contents are less than or equal to those of RAM location addressed by Data Counter XY.       | 29<br>01    | X                                        | X                  | X                    |
|                                                               | MNEA     |         | X        |    | If [[X,Y]] ≠ [A], ST — 1<br>Set status flag only if contents of RAM location are not equal to those of Accumulator.                                          | 00          |                                          | X                  |                      |
|                                                               | MNEZ     |         | X        |    | If [[X,Y]] ≠ 0, ST — 1<br>Set status flag only if contents of RAM location are not equal to zero.                                                            | 26<br>3F    | X                                        | X                  | X                    |
|                                                               | SBIT     | b       |          |    | [[X,Y]](b) — 1<br>Set specified bit of RAM location addressed by contents of Data Counter XY.                                                                | 001100bb    | X                                        | X                  | X                    |
|                                                               | RBIT     | b       |          |    | [[X,Y]](b) — 0<br>Reset specified bit of RAM location addressed by contents of Data Counter XY.                                                              | 001101bb    | X                                        | X                  | X                    |
|                                                               | TBIT1    | b       | X        |    | ST — [[X,Y]](b)<br>Test specified bit of RAM location and set status flag only if the bit is set.                                                            | 001110bb    | X                                        | X                  | X                    |
| IMMEDIATE                                                     | TCY      | data    |          |    | [Y]—data<br>Load Register Y immediate.                                                                                                                       | 0100xxxx    | X                                        | X                  | X                    |
|                                                               | TCMIY    | data    |          |    | [[X,Y]]—data; [Y]—[Y]+1<br>Load RAM location immediate and increment contents of Register Y.                                                                 | 0110xxxx    | X                                        | X                  | X                    |
|                                                               | LDX      | data    |          |    | [X]—data<br>Load Register X immediate.                                                                                                                       | 001111xx    | X                                        |                    |                      |
|                                                               | LDP      | data    |          |    | [PB]—data<br>Load Page Buffer register immediate.                                                                                                            | 00101xxx    | X                                        | X                  | X                    |
| IMMEDIATE OPERATE                                             | ALEC     | data    | X        |    | If [A] ≤ data, ST — 1<br>Set status flag only if Accumulator contents are less than or equal to immediate data.                                              | 0111xxxx    | X                                        |                    | X                    |
|                                                               | YNEC     | data    | X        |    | If [Y] ≠ data, ST — 1<br>Set status flag only if contents of Register Y are not equal to immediate data.                                                     | 0101xxxx    | X                                        | X                  | X                    |
|                                                               | A2AAC    |         | X        |    | [A]—[A]+2; ST — C<br>Add 2 to Accumulator contents. Set status flag only if there is a carry.                                                                | 78          |                                          | X                  |                      |
|                                                               | A3AAC    |         | X        |    | [A]—[A]+3; ST — C<br>Add 3 to Accumulator contents. Set status flag only if there is a carry.                                                                | 74          |                                          | X                  |                      |
|                                                               | A4AAC    |         | X        |    | [A]—[A]+4; ST — C<br>Add 4 to Accumulator contents. Set status flag only if there is a carry.                                                                | 7C          |                                          | X                  |                      |
|                                                               | A5AAC    |         | X        |    | [A]—[A]+5; ST — C<br>Add 5 to Accumulator contents. Set status flag only if there is a carry.                                                                | 72          |                                          | X                  |                      |
|                                                               | A6AAC    |         | X        |    | [A]—[A]+6; ST — C<br>Add 6 to Accumulator contents. Set status flag only if there is a carry.                                                                | 06          | X                                        | X                  | X                    |
|                                                               | A7AAC    |         | X        |    | [A]—[A]+7; ST — C<br>Add 7 to Accumulator contents. Set status flag only if there is a carry.                                                                | 7A<br>76    |                                          | X                  |                      |

Table 1-2. TMS1000 Series Instruction Set Summary (Continued)

| TYPE                             | MNEMONIC | OPERAND | STATUSES |    | OPERATION PERFORMED                                                                                                                                                                                                                                                                  | OBJECT CODE | TMS1000<br>TMS1200<br>TMS1070<br>TMS1270 | TMS1100<br>TMS1300 | MC141000<br>MC141200 |
|----------------------------------|----------|---------|----------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------|--------------------|----------------------|
|                                  |          |         | C        | NE |                                                                                                                                                                                                                                                                                      |             |                                          |                    |                      |
| IMMEDIATE OPERATE<br>(CONTINUED) | A8AAC    |         | X        |    | [A]—[A]+8; ST — C<br>Add 8 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                        | 01          | X                                        |                    | X                    |
|                                  | A9AAC    |         | X        |    | [A]—[A]+9; ST — C<br>Add 9 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                        | 7E          |                                          | X                  | X                    |
|                                  | A10AAC   |         | X        |    | [A]—[A]+10; ST — C<br>Add 10 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                      | 71          |                                          |                    |                      |
|                                  | A11AAC   |         | X        |    | [A]—[A]+11; ST — C<br>Add 11 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                      | 05          | X                                        | X                  |                      |
|                                  | A12AAC   |         | X        |    | [A]—[A]+12; ST — C<br>Add 12 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                      | 79          |                                          | X                  |                      |
|                                  | A13AAC   |         | X        |    | [A]—[A]+13; ST — C<br>Add 13 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                      | 75          |                                          | X                  |                      |
|                                  | A14AAC   |         | X        |    | [A]—[A]+14; ST — C<br>Add 14 to Accumulator contents. Set status flag only if there is a carry.                                                                                                                                                                                      | 7D          |                                          | X                  |                      |
| JUMP                             | RETN     |         |          |    | [PC]—[SR], [PA]—[PB]<br>Return from subroutine.                                                                                                                                                                                                                                      | 73          |                                          | X                  | X                    |
| BRANCH ON<br>CONDITION           | BR       | label   |          |    | If ST = 1, then [PC]— label;<br>outside subroutine, [PA]— [PB]                                                                                                                                                                                                                       | 0F          | X                                        | X                  | X                    |
|                                  | CALL     | label   |          |    | Branch if status flag is set.<br>If ST = 1, then [SR]—[PC]+1, [PB]— [PA], [PC]— label<br>Call subroutine if status flag is set. A subroutine call within a subroutine will act as<br>a branch, and load the Page Buffer from the Page Address register:<br>[PC]— LABEL<br>[PB]— [PA] | 10xxxxxx    | X                                        | X                  | X                    |
| REGISTER-<br>REGISTER<br>MOVE    | TAY      |         |          |    | [A]—[Y]<br>Transfer Accumulator contents to Register Y.                                                                                                                                                                                                                              | 24          | X                                        |                    | X                    |
|                                  | TYA      |         |          |    | [Y]—[A]<br>Transfer Register Y contents to Accumulator.                                                                                                                                                                                                                              | 20          |                                          | X                  | X                    |
| REGISTER-<br>REGISTER<br>OPERATE | YNEA     |         | X        |    | If [Y] ≠ [A], ST — 1<br>Set status flag only if contents of Y register are not equal to those of Accumula-<br>tor.                                                                                                                                                                   | 23          | X                                        | X                  | X                    |
| REGISTER<br>OPERATE              | CLA      |         |          |    | [A]—0<br>Clear Accumulator.                                                                                                                                                                                                                                                          | 02          | X                                        | X                  | X                    |
|                                  | IA       |         |          |    | [A]—[A]+1<br>Increment Accumulator. No status affected.                                                                                                                                                                                                                              | 2F          |                                          |                    |                      |
|                                  | IAC      |         | X        |    | [A]—[A]+1; ST — C<br>Increment Accumulator. Set status flag only if there is a carry.                                                                                                                                                                                                | 7F          | X                                        | X                  | X                    |
|                                  |          |         |          |    |                                                                                                                                                                                                                                                                                      | OE          |                                          |                    |                      |
|                                  |          |         |          |    |                                                                                                                                                                                                                                                                                      | 70          |                                          | X                  |                      |

Table 1-2. TMS1000 Series Instruction Set Summary (Continued)

| TYPE                            | MNEMONIC | OPERAND | STATUSES |    | OPERATION PERFORMED                                                                                                | OBJECT CODE | TMS1000 | TMS1100 | MC141000 |
|---------------------------------|----------|---------|----------|----|--------------------------------------------------------------------------------------------------------------------|-------------|---------|---------|----------|
|                                 |          |         | C        | NE |                                                                                                                    |             | TMS1200 | TMS1070 | MC141200 |
| REGISTER OPERATE<br>(CONTINUED) | DAN      |         | X        |    | [A]—[A]-1; ST — C<br>Decrement Accumulator. Set status flag only if there is no borrow.                            | 07          | X       |         | X        |
|                                 | IYC      |         | X        |    | [Y]—[Y]+1; ST — C<br>Increment Register Y. Set status flag only if there is a carry.                               | 77<br>2B    | X       | X       | X        |
|                                 | DYN      |         | X        |    | [Y]—[Y]-1; ST — C<br>Decrement Register Y. Set status flag only if there is no borrow.                             | 05<br>2C    | X       | X       | X        |
|                                 | CPAIZ    |         | X        |    | [A]—[A]+1; if [A] = 0, ST — 1<br>Negate Accumulator contents (twos complement). Set status only if result is zero. | 04<br>2D    | X       | X       | X        |
|                                 | COMX     |         |          |    | [X]—[X]<br>Complement <u>contents</u> of X register (ones complement).                                             | 00          | X       |         | X        |
|                                 | COMX     |         |          |    | [X](MSB) — [X](MSB)<br>Complement most significant bit of X register.                                              | 09          |         | X       |          |
|                                 | COMC     |         |          |    | CF — CF<br>Complement Chapter flag.                                                                                | 0B          |         | X       |          |

## **DATA SHEETS**

This section contains specific electrical and timing data for the TMS 1000 series microcomputer.

# TMS 1000/1200 AND TMS 1100/1300

## ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)\*

|                                                     |       |       |       |                |
|-----------------------------------------------------|-------|-------|-------|----------------|
| Voltage applied to any device terminal (see Note 1) | ..... | ..... | ..... | -20 V          |
| Supply voltage, $V_{DD}$                            | ..... | ..... | ..... | -20 V to 0.3 V |
| Data input voltage                                  | ..... | ..... | ..... | -20 V to 0.3 V |
| Clock input voltage                                 | ..... | ..... | ..... | -20 V to 0.3 V |
| Average output current (see Note 2): O outputs      | ..... | ..... | ..... | -24 mA         |
| R outputs                                           | ..... | ..... | ..... | -14 mA         |
| Peak output current: O outputs                      | ..... | ..... | ..... | -48 mA         |
| R outputs                                           | ..... | ..... | ..... | -28 mA         |
| Continuous power dissipation: TMS 1000/1100 NL      | ..... | ..... | ..... | 400 mW         |
| TMS 1200/1300 NL                                    | ..... | ..... | ..... | 600 mW         |
| Operating free-air temperature range                | ..... | ..... | ..... | 0°C to 70°C    |
| Storage temperature range                           | ..... | ..... | ..... | -55°C to 150°C |

\*Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| PARAMETER                                                         |               | MIN      | NOM | MAX   | UNIT |
|-------------------------------------------------------------------|---------------|----------|-----|-------|------|
| Supply voltage, $V_{DD}$ (see Note 3)                             |               | -14      | -15 | -17.5 | V    |
| High-level input voltage, $V_{IH}$ (see Note 4)                   | K             | -1.3     | -1  | 0.3   | V    |
|                                                                   | INIT or Clock | -1.3     | -1  | 0.3   |      |
| Low-level input voltage, $V_{IL}$ (see Note 4)                    | K             | $V_{DD}$ | -4  |       | V    |
|                                                                   | INIT or Clock | $V_{DD}$ | -15 | -8    |      |
| Clock cycle time, $t_c(\phi)$                                     |               | 2.5      | 3   | 10    | μs   |
| Instruction cycle time, $t_c$                                     |               | 15       | 60  |       | μs   |
| Pulse width, clock high, $t_w(\phi H)$                            |               | 1        |     |       | μs   |
| Pulse width, clock low, $t_w(\phi L)$                             |               | 1        |     |       | μs   |
| Sum of rise time and pulse width, clock high, $t_r + t_w(\phi H)$ |               | 1.25     |     |       | μs   |
| Sum of fall time and pulse width, clock low, $t_f + t_w(\phi L)$  |               | 1.25     |     |       | μs   |
| Oscillator frequency, $f_{osc}$                                   |               | 100      | 400 |       | kHz  |
| Operating free-air temperature, $T_A$                             |               | 0        | 70  |       | °C   |

- NOTES: 1. Unless otherwise noted, all voltages are with respect to  $V_{SS}$ .  
 2. These average values apply for any 100-ms period.  
 3. Ripple must not exceed 0.2 volts peak-to-peak in the operating frequency range.  
 4. The algebraic convention where the most-positive (least-negative) limit is designated as maximum is used in this specification for logic voltage levels only.



NOTE: Timing points are 90% (high) and 10% (low).

FIGURE 7 – EXTERNALLY DRIVEN CLOCK INPUT WAVEFORM

**TMS 1000/1200 AND TMS 1100/1300**

ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE  
(UNLESS OTHERWISE NOTED)

| PARAMETER                       |                                                                           | TEST CONDITIONS         | MIN                                                | TYP†  | MAX  | UNIT |     |
|---------------------------------|---------------------------------------------------------------------------|-------------------------|----------------------------------------------------|-------|------|------|-----|
| I <sub>I</sub>                  | Input current, K inputs                                                   | V <sub>I</sub> = 0 V    | 50                                                 | 300   | 500  | µA   |     |
| V <sub>OH</sub><br>(see Note 1) | O outputs                                                                 | I <sub>O</sub> = -10 mA | -1.1‡                                              | -0.6‡ |      | V    |     |
|                                 | R outputs                                                                 | I <sub>O</sub> = -2 mA  | -0.75                                              | -0.4  |      |      |     |
| I <sub>OL</sub>                 | Low-level output current                                                  |                         | V <sub>OL</sub> = V <sub>DD</sub>                  |       | -100 | µA   |     |
| I <sub>DD(av)</sub>             | Average supply current from V <sub>DD</sub><br>TMS 1000/1200 (see Note 2) |                         | All outputs open                                   |       | -6   | -10  | mA  |
| I <sub>DD(av)</sub>             | Average supply current from V <sub>DD</sub><br>TMS1100/1300 (see Note 2)  |                         | All outputs open                                   |       | -7   | -11  | mA  |
| P <sub>(AV)</sub>               | Average power dissipation<br>TMS 1000/1200 (see Note 2)                   |                         | All outputs open                                   |       | 90   | 175  | mW  |
| P <sub>(AV)</sub>               | Average power dissipation<br>TMS1100/1300 (see Note 2)                    |                         | All outputs open                                   |       | 105  | 193  | mW  |
| f <sub>osc</sub>                | Internal oscillator frequency                                             |                         | R <sub>ext</sub> = 50 kΩ, C <sub>ext</sub> = 47 pF | 250   | 300  | 350  | kHz |
| C <sub>i</sub>                  | Small-signal input capacitance, K inputs                                  |                         | V <sub>I</sub> = 0, f = 1 kHz                      |       | 10   |      | pF  |
| C <sub>i(φ)</sub>               | Input capacitance, clock input                                            |                         | V <sub>I</sub> = 0, f = 100 kHz                    |       | 25   |      | pF  |

†All typical values are at V<sub>DD</sub> = -15 V, T<sub>A</sub> = 25°C.

‡Parts with V<sub>OH</sub> of -2 V minimum, -1.3 V typical, are available if requested.

NOTES: 1. The algebraic convention where the most-positive (least-negative) limit is designated as maximum is used in this specification for logic voltage levels only.  
2. Values are given for the open-drain O and R output configurations. Pull-down resistors are optionally available on all outputs and increase I<sub>DD</sub> (see Section 4.4).

**SCHEMATICS OF INPUTS AND OUTPUTS**

The O outputs have nominally 60 Ω on-state impedance; however, upon request a 130-Ω buffer can be mask programmed (see note [‡] section 4.3).

The value of the pull-down resistors is mask alterable and provides the following nominal short-circuit output currents (outputs shorted to V<sub>SS</sub>):

O outputs: 100, 200, 300, 500, or 900 µA

R outputs: 100, 150, or 200 µA.

# TMS 1000/1200 AND TMS 1100/1300

## INTERNAL OR EXTERNAL CLOCK

If the internal oscillator is used, the OSC1 and OSC2 terminals are shorted together and tied to an external resistor to V<sub>DD</sub> and a capacitor to V<sub>SS</sub>. If an external clock is desired, the clock source may be connected to OSC1 and OSC2 shorted to V<sub>SS</sub>.

### CONNECTION FOR INTERNAL OSCILLATOR



TYPICAL INTERNAL OSCILLATOR FREQUENCY



### TYPICAL BUFFER CHARACTERISTICS

#### O OUTPUTS

##### HIGH-LEVEL OUTPUT CURRENT

vs

##### HIGH-LEVEL OUTPUT VOLTAGE



#### R OUTPUTS

##### HIGH-LEVEL OUTPUT CURRENT

vs

##### HIGH-LEVEL OUTPUT VOLTAGE



**TMS 1070/1270****ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE  
(UNLESS OTHERWISE NOTED)\***

|                                                                  |           |           |                |
|------------------------------------------------------------------|-----------|-----------|----------------|
| Voltage applied to any device terminal (see Note 1)              | . . . . . | . . . . . | -20 V          |
| Supply voltage, $V_{DD}$                                         | . . . . . | . . . . . | -20 V to 0.3 V |
| Data input and output voltage with $V_{DD}$ applied (see Note 2) | . . . . . | . . . . . | -35 V to 0.3 V |
| Clock input and INIT input voltage                               | . . . . . | . . . . . | -20 V to 0.3 V |
| Average output current (see Note 3): O outputs                   | . . . . . | . . . . . | -2.5 mA        |
| R outputs                                                        | . . . . . | . . . . . | -12 mA         |
| Peak output current: O outputs                                   | . . . . . | . . . . . | -5 mA          |
| R outputs                                                        | . . . . . | . . . . . | -24 mA         |
| Continuous power dissipation: TMS 1070 NL                        | . . . . . | . . . . . | 400 mW         |
| TMS 1270 NL                                                      | . . . . . | . . . . . | 600 mW         |
| Operating free-air temperature range                             | . . . . . | . . . . . | 0°C to 70°C    |
| Storage temperature range                                        | . . . . . | . . . . . | -55°C to 150°C |

\*Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

**RECOMMENDED OPERATING CONDITIONS**

| PARAMETER                                                         |                | MIN      | NOM | MAX   | UNIT |
|-------------------------------------------------------------------|----------------|----------|-----|-------|------|
| Supply voltage, $V_{DD}$ (see Note 4)                             |                | -14      | -15 | -17.5 | V    |
| High-level input voltage, $V_{IH}$ (see Note 5)                   | K              | -6       | 0.3 |       | V    |
|                                                                   | INIT or Clock  | -1.3     | -1  | 0.3   |      |
| Low-level input voltage, $V_{IL}$ (see Note 5)                    | K (See Note 2) | -35      | -8  |       | V    |
|                                                                   | INIT or Clock  | $V_{DD}$ | -15 | -8    |      |
| Clock cycle time, $t_C(\phi)$                                     |                | 2.5      | 3   | 10    | μs   |
| Instruction cycle time, $t_C$                                     |                | 15       | 60  |       | μs   |
| Pulse width, clock high, $t_W(\phi H)$                            |                | 1        |     |       | μs   |
| Pulse width, clock low, $t_W(\phi L)$                             |                | 1        |     |       | μs   |
| Sum of rise time and pulse width, clock high, $t_R + t_W(\phi H)$ |                | 1.25     |     |       | μs   |
| Sum of fall time and pulse width, clock low, $t_F + t_W(\phi L)$  |                | 1.25     |     |       | μs   |
| Oscillator frequency, $f_{osc}$                                   |                | 100      | 400 |       | kHz  |
| Operating free-air temperature, $T_A$                             |                | 0        | 70  |       | °C   |

- NOTES: 1. Unless otherwise noted, all voltages are with respect to  $V_{SS}$ .  
 2.  $V_{DD}$  must be within the recommended operating conditions specified in 5.4.  
 3. These average values apply for any 100-ms period.  
 4. Ripple must not exceed 0.2 volts peak-to-peak in the operating frequency range.  
 5. The algebraic convention where the most-positive (least-negative) limit is designated as maximum is used in this specification for logic voltage levels only.

**ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE  
(UNLESS OTHERWISE NOTED)**

| PARAMETER                                          | TEST CONDITIONS                      | MIN            | TYP† | MAX   | UNIT |
|----------------------------------------------------|--------------------------------------|----------------|------|-------|------|
| $I_I$ Input current, K inputs                      | $V_I = 0$ V                          | 40             | 100  | 300   | μA   |
| $V_{OH}$ High-level output voltage<br>(see Note 1) | O outputs                            | $I_O = -1$ mA  | -1   | -0.5  | V    |
|                                                    | R outputs                            | $I_O = -10$ mA | -4.5 | -2.25 |      |
| $I_{OL}$ Low-level output current                  | $V_{OL} = V_{DD}$                    |                |      | -100  | μA   |
| $I_{DD(av)}$ Average supply current from $V_{DD}$  | All outputs open                     |                | -6   | -10   | mA   |
| $P(AV)$ Average power dissipation                  | All outputs open                     |                | 90   | 175   | mW   |
| $f_{osc}$ Internal oscillator frequency            | $R_{ext} = 50$ kΩ, $C_{ext} = 47$ pF | 250            | 300  | 350   | kHz  |
| $C_i$ Small-signal input capacitance, K inputs     | $V_I = 0$ V, $f = 1$ kHz             |                | 10   |       | pF   |
| $C_i(\phi)$ Input capacitance, clock input         | $V_I = 0$ V, $f = 100$ kHz           |                | 25   |       | pF   |

†All typical values are at  $V_{DD} = -15$  V,  $T_A = 25^\circ\text{C}$ .

NOTE 1: The algebraic convention where the most-positive (least-negative) limit is designated as maximum is used in this specification for logic voltage levels only.

## Chapter 2

# THE MOSTEK 3870 (AND FAIRCHILD F8)

The F8 has had a profound impact on the microcomputer industry. When it first appeared, the F8 was discussed as an off-beat product with a strange set of chips and a ridiculous instruction set. The chip set was strange because logic was organized with the goal of minimizing chip counts; in contrast, microprocessors such as the 8080A and 6800 were designed with logic distributed functionally on chips - one traditional CPU logic function per chip. The F8 instruction set is indeed strange, and in some cases quite limiting, but it reflects the simple chip design of the F8 CPU.

Many microprocessors are now going into consumer products. In this marketplace, the two-chip F8 system provided by a 3850 CPU and a 3851 PSU gained an early dominant position. Other microprocessors available when the F8 was introduced required seven or more chips to provide the same capabilities as the two-chip F8. The economics of consumer product volumes rendered the inefficiencies of the F8 instruction set inconsequential; as a result, in 1977 the F8 was the world's leading microprocessor in terms of CPU sales.

In recognition of the F8 success story, most microprocessor manufacturers have introduced one-chip and two-chip microcomputer systems.

Since the F8 3850 CPU/3851 PSU configuration was the world's first two-chip 8-bit microcomputer system, the F8 was the easiest 8-bit microprocessor to convert into a one-chip microcomputer. Fairchild, the F8 prime source, and Mostek, the F8 second source, both designed one-chip microcomputers around the F8. Fairchild designed the 3859, which was a simple combination of the 3850 CPU and 3851 PSU on a single chip. Mostek developed a more ambitious one-chip microcomputer, the 3870. Mostek developed the 3870 ahead of the Fairchild 3859; therefore, Fairchild dropped the 3859 and became a second source for the 3870. Thus, the original F8 second source, Mostek, is now the new prime source, while the original prime source, Fairchild, is now a second source.

The majority of F8 customers have small configurations which convert readily to the 3870. This being the case, the 3870 is the F8 product being actively marketed, while the old F8 chip set is now manufactured to meet the needs of existing customers and to represent a possible expansion for any customer whose application will no longer fit within the confines of the 3870. In this chapter, therefore, we begin by examining the 3870 in detail. Descriptions of the F8 CPU and its support devices follow.

These are the F8 devices described:

- The 3850 CPU.
- The 3851 Programmable Storage Unit (PSU), which provides read-only memory plus various additional logic functions.
- The 3852 Dynamic Memory Interface (DMI), which primarily provides interface logic for dynamic or static read-write memory.
- The 3853 Static Memory Interface (SMI), which primarily provides interface logic for static read/write memory.
- The 3854 Direct Memory Access (DMA), which, in conjunction with the 3852 DMI, implements Direct Memory Access logic.
- The 3856 and 3857 16K Programmable Storage Units (PSU 16), which are variations of the 3851 PSU but provide more read-only memory.
- The 3861 PIO, which provides the additional logic functions of the 3851 PSU but has no read-only memory.
- The 3871 PIO, which is equivalent to the 3861 PIO but has logic characteristics identical to the 3870.

THE FAIRCHILD  
F8 DEVICE SET

Some additional 3870 series products are planned for delivery in late 1978 and early 1979.

The 3872 is identical to the 3870, except that program memory is doubled from 2048 to 4096 bytes. The 4096 bytes of program memory are configured as 4032 bytes of read-only memory and 64 bytes of read/write memory. Thus, the 3872 will have 128 bytes of read/write memory, of which 64 are in the scratchpad and an additional 64 are in external memory.

The 3873, which will probably be available in early 1979, is equivalent to a 3870 with one serial I/O channel added.

The 3876, which will probably be available in late 1978, is equivalent to a 3870 with 64 bytes of additional read/write memory; that is to say, in addition to the 2048 bytes of program memory there will be 64 bytes of scratchpad memory and an additional 64 bytes of external read/write memory. This additional 64 bytes of external read/write memory will have a low power standby option, allowing you to maintain data in these 64 bytes while power has been removed from the rest of the device.

#### **Figure 2-1 illustrates logic associated with individual F8 devices, and the 3870 one-chip microcomputer.**

All devices of the F8 family require +5V and +12V power supplies. The 3870, however, uses a single +5V power supply.

Using a 500 ns clock, instruction cycle time is 2  $\mu$ sec. Instruction execution times range from 1 to 6.5 instruction cycles, or 2 to 13  $\mu$ sec.

N-channel isoplanar MOS technology is used for the F8.

N-channel ion injection technology is used for the 3870.



Figure 2-1. A Fairchild/Mostek F8 Microcomputer System

The principal manufacturer for the F8 is:

FAIRCHILD SEMICONDUCTOR  
464 Ellis Street  
Mountain View, CA 94040

The second source is:

MOSTEK, INC.  
P.O. Box 169  
Carrollton, TX 75006

The principal manufacturer for the 3870 is:

MOSTEK, INC.  
P.O. Box 169  
Carrollton, TX 75006

Second sources are:

FAIRCHILD SEMICONDUCTOR  
464 Ellis Street  
Mountain View, CA 94040  
  
MOTOROLA, INC.  
Semiconductor Products Division  
3501 Ed Bluestein Blvd.  
Austin, TX 78721

## THE 3870 ONE-CHIP MICROCOMPUTER

Functions implemented on the 3870 microcomputer are illustrated in Figure 2-2.

Some caution must be exercised when looking at Figure 2-2: functions shown as present should not always be considered equal to larger systems. For example, read/write memory and memory addressing are shown as completely present; however, only 64 bytes of read/write memory are provided, with no possibility of expansion. I/O ports and interface logic are shown as provided, but the 3870 itself has only four I/O ports. Programmable timers and interrupt handling logic are shown as present, yet only one interrupt request line is available and only one programmable timer is present -- again with no possibility for expansion.

There is, in fact, a sharp contrast between the expansion philosophy of the 3870 as compared to the Intel 8048. The 3870 is simply not expandable; if your application overflows the 3870 you can keep your programs, but you must revert to the F8 chip set. In contrast, the 8048 is expandable, albeit in a somewhat clumsy fashion. Thus, when an application overflows a 3870, you can keep your programs but you must throw away your 3870 chips. When an application overflows the 8048, you can keep the 8048 already in hand, using expansion capabilities to support new functions.

3870  
EXPANSION



Figure 2-2. Logic of the Fairchild/Mostek 3870 Microcomputer

## 3870/F8 PROGRAMMABLE REGISTERS

These are the programmable registers of the 3870 and F8:



There is one 8-bit Accumulator, which may be likened to the Primary Accumulator (A0) of our hypothetical microcomputer. Wherever there is a choice, this Accumulator is the usual source or destination for data operations associated with any instruction's execution.

**3870/F8  
ACCUMULATOR**

**The 64-byte scratchpad may be viewed either as a small read-write memory, or as 64 8-bit secondary Accumulators.** The first 11 scratchpad bytes may be accessed directly, as though they were secondary Accumulators. Remaining RAM bytes can only be accessed using a form of implied memory addressing, where a 6-bit register (identified as the ISAR register) must provide the address of the byte being accessed. The ISAR register is in every way identical to a 6-bit Data Counter.

3870/F8  
SCRATCHPAD

**Data Counter DC0 is an implied addressing register,** as described for our hypothetical microcomputer.

3870/F8 DATA  
COUNTERS

**Data Counter DC1 is simply a buffer for the contents of Data Counter DC0.** Implied addressing via Data Counter DC1 is not allowed. The only instruction that accesses Data Counter DC1 is an instruction which will exchange the contents of Data Counters DC0 and DC1.

**Program Counter PC0 serves the same function in a 3870 or F8 system as it does in our hypothetical microcomputer.**

3870/F8 PROGRAM  
COUNTER

**The Stack register (PC1) is, in reality, a buffer for Program Counter PC0;** the Stack register does not address an area in read-write memory, and there are no Push or Pop instructions as described in Volume I, Chapter 6. Interrupts and Jump-to-Subroutine instructions save the contents of Program Counter PC0 in Stack register PC1, before loading a new address into Program Counter PC0:



The classical Stack can be implemented in a 3870 or F8 system, but a short program needs to be written to do this.

**Read-only memory is always addressed using implied addressing, with auto-increment, via Data Counter DC0. No other memory addressing modes are provided.**

MEMORY  
ADDRESSING

There are a number of instructions which load immediate data into Data Counter DC0; data may also be transferred between Data Counter DC0 and scratchpad bytes, and it is possible to add the contents of the Accumulator to Data Counter DC0.

**In order to understand scratchpad addressing, one has to view it as representing neither 64 Accumulators nor 64 bytes of read-write memory, but rather as something between the two.**

SCRATCHPAD  
MEMORY  
ADDRESSING

## 3870 MEMORY ADDRESSING MODES

**The 3870 microcomputer has two separate and distinct memories:**

- 1) There is the 64-byte scratchpad, which is the only read/write memory available.
- 2) There are 2048 bytes of read-only memory, which must contain all programs, but may also contain constant data.

**We will refer to addressing of the 64-byte scratchpad as "scratchpad addressing", while "memory addressing" refers to the 2048 read-only memory bytes.**

It is important to note that the scratchpad and the read-only memory have separate and distinct address spaces. Scratchpad locations have addresses in the range 0 through 63<sub>10</sub>, while read-only memory locations have addresses in the range 0 through 2047<sub>10</sub>. Thus, addresses 0 through 63<sub>10</sub> can access both a scratchpad byte and a read-only memory location; however, this will never cause confusion since separate and distinct instructions access scratchpad as against read-only memory. Since no one instruction can access both scratchpad and read-only memory, there is no possibility for confusion.

Instructions which access scratchpad memory use the four low-order object code bits to identify Scratchpad Addressing mode, as follows:



**There are a number of register-register instructions that operate on the Accumulator and on one of the first 12 scratchpad bytes, using object codes as follows:**



**This type of object code treats the first 12 scratchpad bytes as secondary Accumulators.**

**Any scratchpad byte may be addressed via the ISAR register using implied addressing;** that is to say, the 6-bit number in the ISAR (which can have a value in the range 0 through 63) identifies the one scratchpad byte which will be accessed by the next scratchpad referencing instruction.

The ISAR register provides implied addressing, and implied addressing with auto-increment or auto-decrement; however, only the low-order three bits of the ISAR register are involved in the auto-increment or auto-decrement operation:

**DIRECT SCRATCHPAD ADDRESSING**

**IMPLIED SCRATCHPAD ADDRESSING**



F8 scratchpad bytes may therefore be accessed as contiguous 8-byte buffers, with wraparound auto-increment or auto-decrement within each 8-byte buffer.

**Instructions shown in Table 2-2 use the symbol r in the operand to represent scratchpad addressing.** This is what the symbol r represents:

**r SCRATCHPAD ADDRESSING**

- If r is a number between 0 and 11, one of scratchpad bytes 0 through 11 is addressed directly.
- If r is S, implied addressing via ISAR is specified.
- If r is I, implied addressing via ISAR, with auto-increment of the low-order three implied address bits, is specified.
- If r is D, implied addressing via ISAR, with auto-decrement of the low-order three address bits, is specified.

Given the various ways in which scratchpad memory can be addressed, this is the most effective way of configuring scratchpad:



Treat scratchpad bytes 0 through 8 as nine secondary Accumulators; access these bytes using direct scratchpad addressing.

Wherever possible, use scratchpad bytes 9 through F only as buffers for their associated registers; when accessing these bytes, use the specific instructions which transfer data between these scratchpad bytes and their associated registers.

Although you can address scratchpad bytes 9, A, and B by using direct addressing, do not do so when these scratchpad bytes are being used as buffers for the Status registers (W) and Data Counter (DC0).

While indirect addressing via ISAR can access any scratchpad byte, you should avoid addressing scratchpad bytes 0 through F in this fashion. Wherever possible, use ISAR only to address scratch bytes 10<sub>16</sub> through 3F<sub>16</sub>; divide this area into 8-byte buffers as illustrated. Because I addressing auto-increments only the three low-order ISAR bits, this form of scratchpad byte addressing will wrap around within one 8-byte buffer, as follows:

| ISAR |   |   |   |   |   |  |  |
|------|---|---|---|---|---|--|--|
| X    | X | X | 0 | 0 | 0 |  |  |
| X    | X | X | 0 | 0 | 1 |  |  |
| X    | X | X | 0 | 1 | 0 |  |  |
| X    | X | X | 0 | 1 | 1 |  |  |
| X    | X | X | 1 | 0 | 0 |  |  |
| X    | X | X | 1 | 0 | 1 |  |  |
| X    | X | X | 1 | 1 | 0 |  |  |
| X    | X | X | 1 | 1 | 1 |  |  |
| X    | X | X | 0 | 0 | 0 |  |  |
| X    | X | X | 0 | 0 | 1 |  |  |
| etc. |   |   |   |   |   |  |  |

Similarly, D implied addressing via ISAR will wrap around within eight scratchpad byte divisions, as follows:

| ISAR |   |   |   |   |   |  |  |
|------|---|---|---|---|---|--|--|
| X    | X | X | 0 | 0 | 0 |  |  |
| X    | X | X | 1 | 1 | 1 |  |  |
| X    | X | X | 1 | 1 | 0 |  |  |
| X    | X | X | 1 | 0 | 1 |  |  |
| X    | X | X | 1 | 0 | 0 |  |  |
| X    | X | X | 0 | 1 | 1 |  |  |
| X    | X | X | 0 | 1 | 0 |  |  |
| X    | X | X | 0 | 0 | 1 |  |  |
| X    | X | X | 0 | 0 | 0 |  |  |
| X    | X | X | 1 | 1 | 1 |  |  |
| etc. |   |   |   |   |   |  |  |

## 3870/F8 STATUS FLAGS

The Status register, also called the W register, holds five status flags, as follows:



The O, Z, C and S status flags are identical to the flags with equivalent symbols, as described in Volume I, Chapter 6 for our hypothetical microcomputer.

The Interrupt Control bit is treated as a fifth status; this status will not be modified by arithmetic or logic operations, but it will be transferred, as a unit with the other four status flags, to or from Scratchpad byte 0.

## 3870 PINS AND SIGNALS

3870 pins and signals are illustrated in Figure 2-3.



Figure 2-3. 3870 Microcomputer Signals and Pin Assignments

32 of the 40 signals implement four 8-bit I/O ports, which are addressed as I/O Ports 0, 1, 4 and 5.

**Pins P00 through P07 implement I/O Port 0.**

**Pins P10 through P17 implement I/O Port 1.**

**Pins P40 through P47 implement I/O Port 4.**

**Pins P50 through P57 implement I/O Port 5.**

I/O port characteristics are described following signal definitions.

**STROBE** is a handshaking control signal associated with I/O Port 4. Whenever data is output to I/O Port 4, STROBE is pulsed low for approximately three clock periods.

External interrupt requests are input via EXT INT.

**RESET** is a master reset input. When it is grounded, the following events occur:

- 1) Program Counter contents (PC0) are pushed onto the Stack register (PC1).
- 2) The ICB bit of the Status register is reset to 0; this disables all interrupts.
- 3) I/O Port 4 and 5 pins all output +5V. Reset does not affect I/O Port 0 and 1 pins.
- 4) Other internal registers are not affected.

**3870  
RESET**

The TEST input is used to test hardware. Normally the TEST pin is connected to ground, or it is left unconnected. When a voltage between 2V and 2.6V is connected to TEST, I/O Ports 4 and 5 become output and input connections to the internal Data Bus, as follows:



When a voltage level between +6V and +7V is applied to the TEST pin, I/O Ports 4 and 5 are connected to the internal Data Bus as illustrated above; but, in addition, internal program memory is disconnected from the Data Bus. This allows instruction codes to be entered via I/O Port 5.

**The TEST pin should be used for test purposes only. Do not use TEST during normal 3870 operations.** You cannot, for example, use TEST as a means of transferring data between the Data Bus and external logic via I/O Ports 4 and 5. Also, you cannot use TEST to supercede internal program memory with an external program memory. This is because timing associated with the test conditions differs markedly from normal instruction execution timing.

**XTL1 and XTL2 are clock signal inputs.** These two clock signal inputs can be used in one of four ways.

**3870 CLOCK  
LOGIC**

**If XTL1 and XTL2 are both grounded, then an internal oscillator within the 3870 generates the clock signal.** Internal oscillator frequencies ranging between 1.7MHz and 4MHz are allowed.

**An external crystal may be connected across XTL1 and XTL2;** in this case the external crystal determines clock frequency. Any frequency in the range 1 MHz to 4 MHz is allowed. There are internal 20 pF capacitors between XTL1 and ground and XTL2 and ground; therefore, external capacitors are not required. This may be illustrated as follows:



If an external clock signal is used, then it should be applied to pin XTL2, and pin XTL1 should be left open.

The internal clock signal generated will have a frequency that is half of the external clock signal frequency. For example, in order to generate a 1 MHz internal clock signal, a 2 MHz external clock signal must be applied to pin XTL2.

It is also possible to generate the internal 3870 clock signal using resistor capacitor (RC) or inductor capacitor (LC) circuits. The RC mode may be illustrated as follows:



$$\begin{aligned} R &= 4K\Omega \text{ Minimum} \\ \text{Capacitance} &= 20.5 \text{ pF} + 2.5 \text{ pF} + C \\ \text{Minimum frequency} &= 1/(1.1 RC + 65 \text{ ns}) \\ \text{Maximum frequency} &= 1/(RC + 15 \text{ ns}) \end{aligned}$$

The external capacitor C is optional, since there is a 20.5 pF internal capacitor.

The LC mode may be illustrated as follows:



$$\begin{aligned} \text{Inductor } L &= 0.1 \text{ mH (minimum)} \\ \text{Inductor quality } Q &= (Q) = 40 \\ \text{If the external capacitor (C) is present, it must be } 30 \text{ pF or less.} \\ \text{Capacitance} &= 10 \text{ pF} \pm 1.3 \text{ pF} + C \\ \text{Frequency} &= 1/(2 \pi \sqrt{LC}) \end{aligned}$$

## 3870 INSTRUCTION TIMING AND EXECUTION

All 3870 instructions execute as a sequence of "long" and "short" machine cycles. A long machine cycle lasts six clock periods. A short machine cycle lasts four clock periods. For each 3870 instruction, Table 2-2 identifies the sequence of long and short machine cycles via which the instruction executes. By referring to this table, you can compute instruction execution times as a function of clock frequency.

Note that Table 2-2 refers to ROMC states. ROMC states have no meaning when you are using a 3870; however, they constitute five signals output by the 3850 CPU in an F8 configuration, as described later in this chapter. Since Table 2-2 applies to both the 3870 and the F8, ROMC states are identified.

### 3870 I/O PORTS

The 3870 has four 8-bit I/O ports, which we defined when describing 3870 pins and signals. I/O ports are addressed via port numbers 0, 1, 4, and 5. I/O port addresses 6 and 7 are also reserved by the 3870; I/O Port 6 is used to output control codes and to input interrupt status. I/O Port 7 is used to access interval timer logic.

0, 1, 4, 5, 6, and 7 are the only I/O port addresses which have any meaning within a 3870. Output instructions that address any other I/O port act as "no operation" instructions. Input instructions that address any other port will clear the Accumulator. Nevertheless, the 3870 instruction set, as defined in Table 2-1, includes both long-form and short-form I/O instructions, allowing any I/O port to be accessed with addresses in the range 0 through 255. This permits the 3870 instruction set to be completely compatible with the full F8 instruction set -- a necessity if 3870 programs are to be transportable to larger F8 configurations.

**Every one of the 3870 I/O port pins is truly bidirectional. Logic associated with each pin may be illustrated as follows:**



**The pin logic illustrated above is present in the 3870 microcomputer and the 3871 PIO only; other devices have the F8 I/O pin characteristics.**

If you do not understand digital logic, then you will not understand the illustration above, but that is not particularly important. The above illustration explains exactly how bidirectional I/O port pin logic works. From a programmer's point of view, this simply translates into the fact that you can freely input and output data without worrying about prior I/O port contents. However, **all I/O port pins have inverted logic**. This means that when you write 1 to an I/O port pin a 0 voltage will be generated, while a +5V voltage will be generated if you output 0 to the pin. Conversely, external logic will cause your program to input 1 if it grounds a pin, while it will cause your program to input 0 if it applies +5V to the pin.

**The output buffer portion of I/O port pin logic determines the pin characteristics. Standard TTL logic is provided by the standard output buffer, which may be illustrated as follows:**



You can buy 3870 devices with different output buffers at I/O Ports 4 and 5, but not at I/O Ports 0 and 1. I/O Ports 0 and 1 pins can only have the standard output buffer illustrated above. **There are two optional output buffer designs available for pins of I/O Ports 4 and 5.** A direct drive output is similar to the standard output, but it sources more current. Logic is illustrated as follows:



The other option is an open drain output, which may be illustrated as follows:



The open drain output allows you to tie pins together; you can then wire-AND two or more pins when data is output. Consider the following configurations:



If all outputs are high, then the wire-AND will be high; however, if any one of the three outputs goes low, then the wire-AND resulting from all three outputs will also go low.

### 3870 INTERRUPT LOGIC

External logic can input an interrupt request to the 3870 via the EXT INT signal.

Interrupt requests may also be generated internally by timer/counter logic.

There are two levels of interrupt enable/disable logic within the 3870. There is a Control register (described later in this chapter) which has bits 0 and 1 set aside to selectively enable or disable external interrupts and timer/counter interrupts, respectively. If one or both of these interrupts are enabled, then any interrupt request is still subject to master ena-

**3870  
INTERRUPT  
DISABLE**

ble/disable logic, which is specified by the Interrupt Control bit of the Status register (bit 4 of the W register). This may be illustrated as follows:



**A timer/counter interrupt request is latched.** If timer/counter interrupt logic has been disabled via Control register bit 1, then an interrupt request will be held until timer/counter interrupts are subsequently enabled; the interrupt request will then occur.

**External interrupt requests are not latched.** An external interrupt request will only occur if the EXT INT signal makes an active transition while external interrupts have been enabled by Control register bit 0.

**Any interrupt request that reaches Status register logic will be latched.** Thus, if Status register bit 4 is 0 when either an external interrupt request or a timer/counter interrupt request occurs, then the interrupt request will be held pending until Status register bit 4 is subsequently set to 1.

**A reset or power-on operation disables all interrupts; the Status and Control registers are cleared.**

**Timer/counter interrupt requests have priority over external interrupt requests.** Thus, if a timer/counter interrupt request and external interrupt request occur simultaneously and both are enabled, then the timer/counter interrupt request will be acknowledged.

**When any interrupt request is acknowledged, further interrupts are disabled via the Status register;** however, interrupt enable/disable logic associated with the Control register is not affected. Thus, an external interrupt request will be held pending for the duration of a timer/counter interrupt service routine's execution. However, the external interrupt request will be removed if, at any time while it is held pending, external interrupts are specifically disabled via bit 0 of the Control register.

If a timer/counter interrupt request is generated while an external interrupt service routine is being executed, then Status register interrupt disable logic will prevent the timer/counter interrupt request from interrupting the external interrupt service routine. However, the timer/counter interrupt request will be held pending until interrupts are subsequently enabled at the Status register. If for any reason timer/counter interrupts have been specifically disabled via Control register bit 1, then any subsequent timer/counter interrupt request will be delayed until timer/counter interrupt logic is specifically enabled via bit 1 of the Control register.

When an interrupt request is acknowledged, the Program Counter (PC0) contents are saved on the Stack register (PC1). For a Timer interrupt request, a new value, 02016, is loaded into the Program Counter:



When an external interrupt request is acknowledged, Program Counter (PC0) contents are saved in the Stack register (PC1), then the new value 0A0<sub>16</sub> is loaded into the Program Counter (PC0). Thus, interrupt service routines for timer and external interrupts must originate at memory locations 020<sub>16</sub> and 0A0<sub>16</sub>, respectively.

Since a reset or power-on clears the Program Counter, the beginning of program memory must be allocated thus:



## TIMER/COUNTER LOGIC

**3870 timer/counter logic represents a significant enhancement over prior F8 logic.**

**3870 timer/event counter logic consists of an 8-bit binary Counter register together with a Buffer register and associated logic. The two registers are accessed as I/O Port 7. Data output to I/O Port 7 is written into the Counter register and the Buffer register. Data input from Port 7 is read from the Counter register only. This may be illustrated as follows:**



The scheme illustrated above allows timer/counter logic to operate in a "free running" mode. Whenever the contents of the Counter register decrement to 0, the new Counter register contents are taken from the Buffer register, and a timer interrupt request occurs. This may be illustrated as follows:

| Counter Register<br>Contents | Buffer Register<br>Contents |
|------------------------------|-----------------------------|
| 02                           | xx                          |
| 01                           | xx                          |
| 00                           | xx                          |
| xx                           | xx                          |
| xx-1                         | xx                          |
| xx-2                         | xx                          |
| etc.                         | etc.                        |

→ Timer interrupt request

You can read Counter register contents at any time, even while the timer/counter is operating, by inputting from I/O Port 7; Counter register contents will be input.

**Timer/counter logic can be operated in Interval Timer mode, in Pulse Width Measurement mode, or in Event Counter mode. The contents of a Control register (which is accessed as I/O Port 6) determine the mode in which timer/counter logic will operate. We will describe the Control register after discussing timer/counter operating modes.**

**In Interval Timer mode, timer/counter logic is used to compute time intervals. In order to compute a time interval, the timer/counter register contents are decremented at fixed "decrement" intervals.** The decrement interval is equal to a number of clock periods, as specified by the control code. The decrement interval may range between a low of two clock periods and a high of 400 clock periods. If, for example, a 500 nanosecond clock is employed and the decrement interval is 100 clock periods, then the Counter register contents will be decremented once every 50 microseconds. If the initial value output to I/O Port 7 is 20010 (C816), then in Interval Timer mode, timer/counter logic will time out once every 10 milliseconds.

**3870  
INTERVAL  
TIMER MODE**

$$\text{Time interval} = 0.5 \times 100 \times 200 \text{ microseconds}$$

The time delays which can be generated using timer/counter logic in Interval Timer mode are given by the following equation:

$$\text{Time interval} = \text{Reset value} \times \text{Decrement time interval}$$

The reset value is the value written out to I/O Port 7; it may have any value in the range 0 through 255. 0 is in fact equivalent to a count of 256, since the decrement ends with a Timer interrupt request when Counter register contents decrement from 1 to 0.

**In Interval Timer mode, timer/counter logic operates as follows:**

- 1) An initial value must be output to I/O Port 7. This becomes the reset value.
- 2) Using an appropriate control code, you select Interval Timer mode and options. The control code also starts and stops timer/counter logic in Interval Timer mode.
- 3) Once started by an appropriate control code, the Counter register continuously decrements, reloads, and redecrements.
- 4) In order to stop the timer/counter when operating in Interval Timer mode, you must output an appropriate control code.

Each time the Counter register decrements to 0, a timer interrupt request is generated. If timer interrupt requests are enabled, then the interrupt request will be acknowledged; if timer interrupt requests are disabled, the interrupt request will be latched and will be held pending until timer interrupt requests are subsequently enabled.

If interrupts are enabled when timer/counter logic times out in Interval Timer mode, there will be a small time delay before the interrupt is acknowledged; no interrupt can be acknowledged until the conclusion of the currently executing instruction, plus the next instruction if it is privileged. (Privileged instructions are instructions which cannot be interrupted; they are identified in Table 2-I.) In the worst case, it is possible for 49 clock periods to elapse between the timer/counter timing out and a timer interrupt being acknowledged; on the average, between 24 and 30 clock periods will separate these two events. If long delays between a time-out and interrupt acknowledge are not acceptable, then you must avoid executing privileged instructions while timer/counter logic is operating in Interval Timer mode.

**In Pulse Width Measurement mode, timer/counter logic measures the duration of a pulse which is input on the EXT INT pin.** Under program control, you can measure a low pulse:

**3870  
PULSE WIDTH  
MEASUREMENT  
MODE**



or you can measure a high pulse:



Stop and start logic represents the only difference between Pulse Width Measurement mode and Interval Timer mode. As illustrated above, it is EXT INT signal transitions that start and stop timer/counter logic in Pulse Width mode. In addition, you can use control codes to stop timer/counter logic in Pulse Width mode.

An external interrupt request occurs at the trailing edge of the EXT INT pulse. This external interrupt request will be acknowledged only if external interrupts have been enabled. If external interrupts are disabled, no interrupt request occurs. That is to say, if external interrupts are enabled at some point after the end of a pulse, no interrupt request will be pending.

Within the pulse itself, timer/counter decrement logic works exactly as described for Interval Timer mode. The Counter register contents are decremented once each decrement interval; the decrement interval is defined in Interval Timer mode. If the timer/counter does not time-out within the pulse width, then on the trailing edge of the pulse the timer/counter is stopped. By inputting from I/O Port 7, you read the contents of the Counter register at the trailing edge of the pulse; the difference between this input value and the initial reset value can be used to compute the pulse duration, as follows:

$$\text{Pulse duration} = (\text{Initial reset value} - \text{final Counter register contents}) \times \text{decrement time interval}$$

For example, suppose the initial reset value output to I/O Port 7 is 100<sub>10</sub> (64<sub>16</sub>), while the final value input from I/O Port 7 is 16<sub>10</sub> (10<sub>16</sub>); if the control code has set timer/counter logic to decrement once every 100 microseconds, then the pulse width must be 8.4 milliseconds:

$$\text{Pulse width} = (100 - 16) \times 100 \text{ microseconds}$$

If the Counter register does time-out within a pulse, then a timer interrupt request occurs, the Buffer register contents are loaded into the Counter register, and decrementing restarts. Program logic must respond to the timer interrupt request by incrementing a scratchpad counter; the total pulse time is computed as follows:

$$\begin{aligned} \text{Pulse duration} &= (\text{Initial reset value} - \text{final Counter register contents}) \\ &\quad \times \text{decrement time interval} \\ &\quad \times \text{initial reset value} \times \text{decrement time interval} \\ &\quad \times \text{scratchpad counter contents} \end{aligned}$$

Suppose, for example, that the initial reset value output to I/O Port 7 is 200<sub>10</sub> (C8<sub>16</sub>), and that the Counter register has timed out three times within the pulse width; the scratchpad counter will now contain 3. If the final value input from I/O Port 7 is 53<sub>10</sub> (35<sub>16</sub>) and the decrement time interval specified by the control code is 50 microseconds, then the total pulse timer interval is 37.35 milliseconds:

$$\begin{aligned} \text{Pulse interval} &= (200 - 53) \times 50 + 200 \times 3 \times 50 \\ &= 37,350 \text{ microseconds} \end{aligned}$$

**In Event Counter mode, the Counter register contents are decremented on "active" transitions of the EXT INT input.** An "active" transition on this signal may be high-to-low or low-to-high, as selected by the control code.

3870  
EVENT  
COUNTER  
MODE

In the Event Counter mode, when the Counter register decrements to 0 a timer interrupt request is latched, as described for the Interval Timer mode. Thus, if the timer interrupts are enabled, the interrupt request will be acknowledged following execution of the next non-privileged instruction; if timer interrupts are disabled, the interrupt request will be held until interrupt requests are re-enabled. Active transitions on the EXT INT signal, while decrementing the Counter register contents, also cause interrupt requests to occur if external interrupts are enabled. Since it would be pointless to have an external interrupt request occur on every decrement, external interrupts are normally disabled in Event Counter mode.

## THE 3870 CONTROL CODE

**Operation of 3870 timer/counter logic and interrupt logic is controlled via an 8-bit control code which must be output to I/O Port 6. I/O Port 6 is a write-only location. When you input from I/O Port 6, you do not read the contents of the Control register; rather, the level on the EXT INT pin appears at bit 7 of the Accumulator. This may be illustrated as follows:**



If you need to read the control code after writing it out, then you must keep a copy of it in one of the scratchpad bytes.

Control code bits are assigned as follows:



**Bits 0 and 1 are used to selectively enable or disable interrupt requests. External interrupt requests occur via active transitions on the EXT INT input signal; timer/counter interrupt requests are generated within timer/counter logic. You have the option of enabling both external interrupts and timer/counter interrupts; you can enable one but not the other, or you can disable both.**

Recall that timer/counter interrupt requests are latched; if timer/counter interrupt logic is disabled (control code bit 1 is 0) when the timer/counter interrupt request occurs, then the interrupt request will remain pending until timer/counter interrupts are subsequently enabled (control code bit 1 is 1), or until the 3870 is reset. A reset removes the latched interrupt request. External interrupts are not latched; an external interrupt request will be generated only as EXT INT makes an active transition while control code bit 0 is 1. A timer/counter interrupt request occurs whenever the timer/counter register decrements from 1 to 0, as previously described.

**An external interrupt request occurs whenever an "active" transition is sensed on the EXT INT pin. Bit 2 of the control code determines what an "active" transition of EXT INT will consist of.** If bit 2 is 0, then a low level on EXT INT is considered active, and high-to-low transition causes an external interrupt request. If bit 2 of the control code is 1, then a high level on EXT INT is considered active and a low-to-high signal transition will cause an external interrupt request.

Control code bit 3 is the start/stop bit. This bit must be used to start and stop timer/counter logic when operating in Interval Timer mode or Event Counter mode. When timer/counter logic is operating in Pulse Width Measurement mode, then leading and trailing edges of an active EXT INT pulse start and stop timer/counter logic; within a pulse, however, the start/stop bit of the Control code can be used to stop and then restart timer/counter logic.

In Interval Timer mode or Pulse Width mode, bits 5, 6 and 7 select the decrement time interval. The important point to note is that bits 5, 6 and 7 are cumulative. Thus, you have seven pre-scalar options shown with the control code.

In Interval Timer mode or in Pulse Width mode, the Counter register contents are decremented once every decrement time interval. A decrement time interval is equal to the internal clock pulse time multiplied by the pre-scalar. Assuming a 500 nanosecond internal clock pulse width, 010 in Control register bits 7, 6 and 5 would generate a decrement time interval of 2.5 microseconds. A decrement time interval of 50 microseconds would be generated by 110 in Control register bits 7, 6 and 5.

## THE 3870/F8 INSTRUCTION SET

**Table 2-1 summarizes the 3870/F8 instruction set; instructions are grouped into categories that conform with our hypothetical microcomputer instruction set, as described in Volume I, Chapter 7.**

With reference to Table 2-1, refer to the addressing modes description for an explanation of "r", which occurs in the operand column to represent some of the scratchpad addressing options.

One of the more confusing aspects of 3870/F8 programming is understanding the ways in which data may be moved between different registers; this information is therefore summarized in Figure 2-4.

The following symbols are used in Table 2-1:

|       |                                                                                                                                         |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| A     | The Accumulator                                                                                                                         |
| addr  | A 16-bit memory address                                                                                                                 |
| C     | Carry status                                                                                                                            |
| data3 | A 3-bit binary data unit                                                                                                                |
| data4 | A 4-bit binary data unit                                                                                                                |
| data5 | A 5-bit binary data unit                                                                                                                |
| DC0   | Data Counter register                                                                                                                   |
| DC1   | Data Counter buffer                                                                                                                     |
| dpchr | Scratchpad Data or Program Counter Half Registers. These are KU (Register 12), KL (Register 13), QU (Register 14) and QL (Register 15). |
| disp  | An 8-bit signed binary address displacement                                                                                             |
| FMASK | A 4-bit mask composed of a portion of the Status register (W):                                                                          |



|      |                                                           |
|------|-----------------------------------------------------------|
| H    | Scratchpad Data Counter Register H (Registers 10 and 11). |
| I    | The Interrupt Control Bit in the Status register (W).     |
| ISAR | Indirect Scratchpad Address Register                      |
| J    | Scratchpad Register 9                                     |
| K    | Scratchpad Registers 12 and 13                            |
| O    | Overflow status                                           |
| p4   | A 4-bit I/O port number                                   |
| p8   | An 8-bit I/O port number                                  |
| PC0  | Program Counter                                           |
| PC1  | Stack register                                            |
| Q    | Scratchpad Registers 14 and 15                            |

Any of the following operands and Scratchpad addressing modes:

- R direct address of bytes 0 through 11
- S implied addressing via ISAR
- I implied addressing via ISAR, with auto-increment of the low-order three ISAR bits
- D implied addressing via ISAR, with auto-decrement of the low-order three ISAR bits

**S** Sign status

**sr** The register specified by the r argument

**TMASK** A 3-bit mask composed of a portion of the Status register (W):



**W** The CPU Status register

**Z** Zero status

**x<y,z>** Bits y through z of the quantity x. For example, A <3,0> represents the low-order four bits of the Accumulator; addr <15,8> represents the high-order eight bits of a 16-bit memory address

**[]** Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If an I/O port number is enclosed within the brackets, then the I/O port contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.

**[[ ]]** Implied memory addressing: the contents of the memory location or register designated by the contents of a register

**Λ** Logical AND

**∨** Logical OR

**⊕** Logical Exclusive OR

**→** Data is transferred in the direction of the arrow

**↔** Data is exchanged between the two locations designated on either side of the arrow

Under the heading of STATUSES in Table 2-1, an X indicates statuses which are modified in the course of the instructions' execution. If there is no X, it means that the status maintains the value it had before the instruction was executed. A 0 or 1 means the status is cleared or set, respectively.

Table 2-1. 3870/F8 Instruction Set Summary

| TYPE                     | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                                      |
|--------------------------|----------|------------|-------|----------|---|---|---|--|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          |          |            |       | C        | Z | S | O |  |                                                                                                                                                          |
| OI                       | INS      | P4         | 1     | 0        | X | X | 0 |  | [A]—[P4]<br>Input to Accumulator from I/O port.                                                                                                          |
|                          | IN       | P8         | 2     | 0        | X | X | 0 |  | [A]—[P8]<br>Input to Accumulator from I/O port.                                                                                                          |
|                          | OUTS     | P4         | 1     |          |   |   |   |  | [P4]—[A]<br>Output to I/O port from Accumulator.                                                                                                         |
|                          | OUT      | P8         | 2     |          |   |   |   |  | [P8]—[A]<br>Output to I/O port from Accumulator.                                                                                                         |
| PRIMARY MEMORY REFERENCE | LM       |            | 1     |          |   |   |   |  | [A]—[[DC0]], [DC0]—[DC0]+1<br>Load the Accumulator via DC0 and auto-increment DC0.                                                                       |
|                          | ST       |            | 1     |          |   |   |   |  | [[DC0]]—[A], [DC0]—[DC0+1]<br>Store the Accumulator via DC0 and auto-increment DC0.                                                                      |
|                          | LR       | A,r        | 1     |          |   |   |   |  | [A]—[SR]<br>Load the contents of the specified register, SR, into the Accumulator. Increment or decrement ISAR if specified by r.                        |
|                          | LR       | A,DPCHR    | 1     |          |   |   |   |  | [A]—[DPCHR]<br>Load Accumulator with the contents of the specified DPCHR.                                                                                |
|                          | LR       | r,A        |       |          |   |   |   |  | [SR]—[A]<br>Load the contents of the Accumulator into the specified register. Increment or decrement ISAR if specified by r.                             |
|                          | LR       | DPCHR,A    | 1     |          |   |   |   |  | [DPCHR]—[A]<br>Load the contents of the Accumulator into the specified DPCHR.                                                                            |
|                          | LR       | DC0,H      | 1     |          |   |   |   |  | [DC0]—[H]<br>Load the contents of Scratchpad registers 10 and 11 into DC0.                                                                               |
|                          | LR       | DC0,Q      | 1     |          |   |   |   |  | [DC0]—[Q]<br>Load the contents of Scratchpad registers 14 and 15 into DC0.                                                                               |
|                          | LR       | H,DC0      | 1     |          |   |   |   |  | [H]—[DC0]<br>Load the contents of DC0 into Scratchpad registers 10 and 11.                                                                               |
|                          | LR       | Q,DC0      | 1     |          |   |   |   |  | [Q]—[DC0]<br>Load the contents of DC0 into Scratchpad registers 14 and 15.                                                                               |
|                          | LR       | PC1,K      | 1     |          |   |   |   |  | [PC1]—[K]<br>Load the contents of Register K into the Stack register.                                                                                    |
|                          | LR       | K,PC1      | 1     |          |   |   |   |  | [K]—[PC1]<br>Load the contents of the Stack register into Register K.                                                                                    |
|                          | LR       | PC0,Q      | 1     |          |   |   |   |  | [PC0]—[Q]<br>Load the contents of Register Q into the Program Counter.                                                                                   |
|                          | PK       |            | 1     |          |   |   |   |  | [PC1]—[PC0], [PC0]—[Q]<br>Save the contents of the Program Counter in the Stack register, then load the contents of Register Q into the Program Counter. |

Table 2-1. 3870/F8 Instruction Set Summary (Continued)

| TYPE                                               | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                                                                                       |
|----------------------------------------------------|----------|------------|-------|----------|---|---|---|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    |          |            |       | C        | Z | S | O |  |                                                                                                                                                                                                           |
| SECONDARY MEMORY REFERENCE<br>(SCRATCHPAD OPERATE) | AS       | r          | 1     | X        | X | X | X |  | [A]—[A]+[SR]<br>Add binary the contents of the specified register to the contents of the Accumulator. Increment or decrement ISAR if specified by r.                                                      |
|                                                    | ASD      | r          | 1     | X        | X | X | X |  | [A]—[A]+[SR]<br>Add decimal the contents of the specified register to the contents of the Accumulator; that is, both numbers are assumed to be BCD digits. Increment or decrement ISAR if specified by r. |
|                                                    | NS       | r          | 1     | 0        | X | X | 0 |  | [A]—[A]Λ [SR]<br>AND the contents of the specified register with the contents of the Accumulator. Increment or decrement ISAR if specified by r.                                                          |
|                                                    | XS       | r          | 1     | 0        | X | X | 0 |  | [A]—[A]∨[SR]<br>Exclusive-OR the contents of the specified register with the contents of the Accumulator. Increment or decrement the ISAR if specified by r.                                              |
|                                                    | DS       | r          | 1     | X        | X | X | X |  | [SR]—[SR]-1<br>Decrement the specified register. Increment or decrement ISAR if specified by r.                                                                                                           |
| SECONDARY MEMORY REFERENCE<br>(MEMORY OPERATE)     | AM       |            | 1     | X        | X | X | X |  | [A]—[A]+[[DC0]], [DC0]—[DC0]+1<br>Add Accumulator contents to the contents of the memory location addressed by DC0. Increment DC0.                                                                        |
|                                                    | AMD      |            | 1     | X        | X | X | X |  | [A]—[A]+[[DC0]], [DC0]—[DC0]+1<br>Decimal add Accumulator contents to the contents of the memory location addressed by DC0. Increment DC0.                                                                |
|                                                    | NM       |            | 1     | 0        | X | X | 0 |  | [A]—[A]Λ[[DC0]], [DC0]—[DC0]+1<br>AND Accumulator contents with the contents of the memory location addressed by DC0. Increment DC0.                                                                      |
|                                                    | OM       |            | 1     | 0        | X | X | 0 |  | [A]—[A]∨[[DC0]], [DC0]—[DC0]+1<br>OR Accumulator contents with the contents of the memory location addressed by DC0. Increment DC0.                                                                       |
|                                                    | XM       |            | 1     | 0        | X | X | 0 |  | [A]—[A]∨[[DC0]], [DC0]—[DC0]+1<br>Exclusive-OR Accumulator contents with the contents of the memory location addressed by DC0. Increment DC0.                                                             |
|                                                    | CM       |            | 1     | X        | X | X | X |  | [[DC0]]-[A], [DC0]—[DC0]+1<br>Subtract the contents of the Accumulator from the contents of the memory location addressed by DC0. Only the status flags are affected. Increment DC0.                      |
| IMMEDIATE                                          | LISU     | DATA3      | 1     |          |   |   |   |  | [ISAR<5,3>]—DATA3<br>Load immediate into the upper three bits of the ISAR.                                                                                                                                |
|                                                    | LISL     | DATA3      | 1     |          |   |   |   |  | [ISAR<2,0>]—DATA3<br>Load immediate into the lower three bits of the ISAR.                                                                                                                                |
|                                                    | DCI      | ADDR       | 3     |          |   |   |   |  | [[DC0]]—ADDR<br>Load immediate data into the DC0.                                                                                                                                                         |
|                                                    | LIS      | DATA4      | 1     |          |   |   |   |  | [A<3,0>]—DATA4<br>Load immediate data into the lower four bits of the Accumulator. Clear the high four bits of the Accumulator.                                                                           |
|                                                    | LI       | DATA8      | 2     |          |   |   |   |  | [A]—DATA8<br>Load immediate data into Accumulator.                                                                                                                                                        |

Table 2-1. 3870/F8 Instruction Set Summary (Continued)

| TYPE                | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  |  | OPERATION PERFORMED                                                                                                                                                 |
|---------------------|----------|------------|-------|----------|---|---|---|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |          |            |       | C        | Z | S | O |  |  |                                                                                                                                                                     |
| IMMEDIATE OPERATE   | AI       | DATA8      | 2     | X        | X | X | X |  |  | [A] ← [A] + DATA8<br>Add immediate to Accumulator:                                                                                                                  |
|                     | NI       | DATA8      | 2     | 0        | X | X | 0 |  |  | [A] ← [A] AND DATA8<br>AND immediate with Accumulator.                                                                                                              |
|                     | OI       | DATA8      | 2     | 0        | X | X | 0 |  |  | [A] ← [A] OR DATA8<br>OR immediate with Accumulator.                                                                                                                |
|                     | XI       | DATA8      | 2     | 0        | X | X | 0 |  |  | [A] ← [A] XOR DATA8<br>Exclusive-OR immediate with Accumulator.                                                                                                     |
|                     | CI       | DATA8      | 2     | X        | X | X | X |  |  | DATA8 - [A]<br>Compare immediate: subtract Accumulator contents from immediate data, but only the status flags are affected.                                        |
| JUMP                | PI       | ADDR       | 3     |          |   |   |   |  |  | [PC1] ← [PC0], [PC0] ← ADDR<br>Save Program Counter in Stack register, then load immediate address into Program Counter.                                            |
|                     | BR       | DISP       | 2     |          |   |   |   |  |  | [PC0] ← [PC0] + DISP<br>Add immediate displacement to contents of Program Counter.                                                                                  |
|                     | JMP      | ADDR       | 3     |          |   |   |   |  |  | [PC0] ← ADDR, [A] ← ADDR <15,8><br>Load immediate address into Program Counter. Load the high order byte of the address into the Accumulator.                       |
| BRANCH ON CONDITION | BT       | DATA3,DISP | 2     |          |   |   |   |  |  | If DATA3 V TMASK ≠ 0 then [PC0] ← [PC0] + DISP<br>OR the 3 bits of immediate data with the current TMASK. If any resulting bit is a 1, add the displacement to PC0. |
|                     | BF       | DATA4,DISP | 2     |          |   |   |   |  |  | If DATA4 = FMASK, then [PC0] ← [PC0] + DISP<br>If the 4 bits of immediate data are equal to FMASK, add the displacement to PC0.                                     |
|                     | BP       | DISP       | 2     |          |   |   |   |  |  | If [S] = 1 then [PC0] ← [PC0] + DISP<br>Branch relative if the Sign bit is set.                                                                                     |
|                     | BC       | DISP       | 2     |          |   |   |   |  |  | If [C] = 1 then [PC0] ← [PC0] + DISP<br>Branch relative if the Carry bit is set.                                                                                    |
|                     | BZ       | DISP       | 2     |          |   |   |   |  |  | If [Z] = 1 then [PC0] ← [PC0] + DISP<br>Branch relative if the Zero bit is set.                                                                                     |
|                     | BM       | DISP       | 2     |          |   |   |   |  |  | If [S] = 0 then [PC0] ← [PC0] + DISP<br>Branch relative if the Sign bit is reset.                                                                                   |
|                     | BNC      | DISP       | 2     |          |   |   |   |  |  | If [C] = 0 then [PC0] ← [PC0] + DISP<br>Branch relative if the Carry bit is reset.                                                                                  |
|                     | BNZ      | DISP       | 2     |          |   |   |   |  |  | If [Z] = 0 then [PC0] ← [PC0] + DISP<br>Branch relative if the Zero bit is reset.                                                                                   |
|                     | BNO      | DISP       | 2     |          |   |   |   |  |  | If [O] = 0 then [PC0] ← [PC0] + DISP<br>Branch relative if the Overflow bit is reset.                                                                               |
|                     | BR7      | DISP       | 2     |          |   |   |   |  |  | If [ISAR<2,0>] = 7 then [PC0] ← [PC0] + DISP<br>If the low three bits of the ISAR are not all 1s, branch relative.                                                  |

Table 2-1. 3870/F8 Instruction Set Summary (Continued)

| TYPE                   | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                                                                    |
|------------------------|----------|------------|-------|----------|---|---|---|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |          |            |       | C        | Z | S | O |  |                                                                                                                                                                                        |
| REGISTER-REGISTER MOVE | XDC      |            | 1     |          |   |   |   |  | [DC0] → [DC1]<br>Exchange the contents of DC0 with the contents of DC1.                                                                                                                |
|                        | LR       | A,IS       | 1     |          |   |   |   |  | [A] → [ISAR]<br>Load the contents of ISAR into the Accumulator.                                                                                                                        |
|                        | LR       | IS,A       | 1     |          |   |   |   |  | [ISAR] → [A]<br>Load the contents of the Accumulator into the ISAR.                                                                                                                    |
|                        | POP      |            | 1     |          |   |   |   |  | [PC0] → [PC1]<br>Load the contents of the Stack register into the Program Counter.                                                                                                     |
| REGISTER OPERATE       | ADC      |            | 1     | 0        | X | 1 | 0 |  | [DC0] → [DC0] + [A]<br>Add the contents of DC0 to the contents of the Accumulator, which is treated as a signed binary number. Store the result in DC0.                                |
|                        | SR       | 1          | 1     | 0        | X | 1 | 0 |  | <br>Shift the contents of the Accumulator right one bit. The most significant bit becomes a 0.       |
|                        | SR       | 4          | 1     | 0        | X | 1 | 0 |  | <br>Shift the contents of the Accumulator right four bits. The most significant four bits become 0s. |
|                        | SL       | 1          | 1     | 0        | X | X | 0 |  | <br>Shift the contents of the Accumulator left one bit. The least significant bit becomes a 0.       |
|                        | SL       | 4          | 1     | 0        | X | X | 0 |  | <br>Shift the contents of the Accumulator left four bits. The least significant four bits become 0s. |
|                        | COM      |            | 1     | 0        | X | X | 0 |  | [A] → [Ā]<br>Complement Accumulator contents.                                                                                                                                         |
|                        | LNK      |            | 1     | X        | X | X | X |  | [A] → [A] + C<br>Add the Carry to the contents of the Accumulator.                                                                                                                     |
|                        | INC      |            | 1     | X        | X | X | X |  | [A] → [A] + 1<br>Increment the contents of the Accumulator.                                                                                                                            |
|                        | CLR      |            | 1     |          |   |   |   |  | [A] → 0<br>Clear the Accumulator.                                                                                                                                                      |

Table 2-1. 3870/F8 Instruction Set Summary (Continued)

| TYPE      | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                 |
|-----------|----------|------------|-------|----------|---|---|---|--|-------------------------------------------------------------------------------------|
|           |          |            |       | C        | Z | S | O |  |                                                                                     |
| INTERRUPT | DI       |            | 1     |          |   |   |   |  | [I]—0<br>Set the interrupt enable bit in the Status register, W, to 0.              |
|           | EI       |            | 1     |          |   |   |   |  | [I]—1<br>Set the interrupt enable bit in the Status register, W, to 1.              |
| STATUS    | LR       | W,J        | 1     |          |   |   |   |  | [W]—[J]<br>Move the contents of Scratchpad register 9 into the Status register, W.  |
|           | LR       | J,W        | 1     |          |   |   |   |  | [J]—[W]<br>Move the contents of the Status register, W, into Scratchpad register 9. |
|           | NOP      |            | 1     |          |   |   |   |  | No operation is performed. This is not a Halt.                                      |

## THE 3870 BENCHMARK PROGRAM

The fact that the 3870 has just 64 bytes of read/write memory makes the benchmark program used in this book somewhat meaningless. We will therefore substitute a program similar to the one given in Chapter 1 for the TMS1000. A block of data is to be input via I/O Port 0. The first byte of data identifies the length of the data block to follow: this data block must be less than 48 bytes in length so that it will fit into scratchpad memory starting at scratchpad byte 1016. Here is the necessary program:

|      |      |                               |                              |
|------|------|-------------------------------|------------------------------|
| INS  | 0    | INPUT FIRST BLOCK LENGTH BYTE |                              |
| LR   | 0,A  | SAVE IN SCRATCHPAD BYTE 0     |                              |
| LISU | 1    | INITIALIZE ISAR               |                              |
| LISL | 0    |                               |                              |
| LOOP | INS  | 0 INPUT DATA BYTE             |                              |
|      | LR   | S,A                           | SAVE IN NEXT SCRATCHPAD BYTE |
|      | LR   | A,IS                          | INCREMENT ALL SIX ISAR BITS  |
|      | INC  |                               |                              |
|      | LR   | IS,A                          |                              |
| DS   | 0    | DECREMENT SCRATCHPAD BYTE 0   |                              |
| BNZ  | LOOP | RETURN IF NOT ZERO            |                              |



Figure 2-4. Instructions That Move Data Between the Scratchpad and Various Registers

Table 2-2. Timing and ROMC States for F8 Instruction Set

| MNEMONIC     | OPERAND(S)   | CYCLE | ROMC STATE | MNEMONIC | OPERAND(S)   | CYCLE | ROMC STATE |
|--------------|--------------|-------|------------|----------|--------------|-------|------------|
| ADC          |              | L     | A          | LISU     | DATA3        | S     | 0          |
| AI           | DATA8        | S     | 0          | LM       |              | L     | 2          |
|              |              | L     | 3          |          |              | S     | 0          |
| AM           |              | S     | 0          | LNK      |              | S     | 0          |
|              |              | L     | 2          | LR       | AJS          | S     | 0          |
| AMD          |              | S     | 0          | LR       | A,KL         | S     | 0          |
|              |              | L     | 2          | LR       | A,KU         | S     | 0          |
| AS           | r            | S     | 0          | LR       | A,QL         | S     | 0          |
| ASD          | r            | S     | 1C         | LR       | A,QU         | S     | 0          |
|              |              | S     | 0          | LR       | A,r          | S     | 0          |
| BF Branch    | DATA4,DISP   | S     | 1C         | LR       | DC0,H        | L     | 16         |
|              |              | L     | 1          |          |              | L     | 19         |
|              |              | S     | 0          |          |              | S     | 0          |
| No Branch    |              | S     | 1C         | LR       | DC0,Q        | L     | 16         |
| BR7          | DISP         | S     | 3          |          |              | L     | 19         |
| No Branch    |              | S     | 0          | LR       | H,DC0        | L     | 6          |
| Branch       |              | L     | 1          |          |              | S     | 0          |
| BT No Branch | DATA3,DISP   | S     | 1C         | LR       | IS,A         | S     | 0          |
|              |              | S     | 3          | LR       | J,W          | S     | 0          |
|              |              | S     | 0          | LR       | K,P          | L     | 7          |
| Branch       |              | L     | 1          |          |              | S     | 0          |
| CI           | DATA8        | S     | 0          | LR       | KL,A         | S     | 0          |
|              |              | L     | 3          | LR       | KU,A         | S     | 0          |
| CM           |              | S     | 0          | LR       | P,K          | L     | 15         |
|              |              | L     | 2          |          |              | S     | 18         |
| COM DCI      | ADDR         | S     | 0          | LR       | PC0,Q        | L     | 0          |
|              |              | L     | 11         |          |              | S     | 6          |
|              |              | S     | 3          | LR       | Q,DC0        | L     | 9          |
|              |              | L     | E          |          |              | S     | 0          |
| DI           |              | S     | 3          | LR       | QL,A         | S     | 0          |
|              |              | S     | 0          | LR       | QU,A         | S     | 0          |
| DS           | r            | S     | 1C         | LR       | r,A          | S     | 0          |
| EI           |              | S     | 0          | LR       | W,J          | S     | 1C         |
| IN           | P8           | L     | 0          | NI       | DATA8        | S     | 0          |
|              |              | S     | 1C         |          |              | L     | 3          |
| INC          |              | L     | 0          | NM       |              | S     | 0          |
| INS          | 0 or 1       | S     | 0          | NS       |              | L     | 2          |
|              |              | S     | 1C         | OI       | DATA8        | S     | 0          |
| INS          | 2 through 15 | L     | 0          | OM       |              | S     | 3          |
| (INTERRUPT)  |              | S     | 1C         | OUT      | P8           | L     | 0          |
|              |              | L     | 08         |          |              | S     | 1          |
|              |              | S     | 13         | OUTS     | 0 or 1       | S     | 0          |
| JMP          | ADDR         | L     | 0          |          |              | L     | 1C         |
|              |              | S     | 3          | OUTS     | 2 through 15 | S     | 0          |
|              |              | L     | C          |          | ADDR         | L     | 3          |
| LI           | DATA8        | S     | 0          |          |              | S     | D          |
| LIS          | DATA4        | S     | 0          |          |              | L     | C          |
| LISL         | DATA3        | S     | 0          |          |              | S     | 14         |
|              |              |       |            |          |              |       | 0          |

Table 2-2. Timing and ROMC States for F8 Instruction Set (Continued)

| MNEMONIC | OPERAND(S) | CYCLE                 | ROMC STATE              |
|----------|------------|-----------------------|-------------------------|
| PK       |            | L<br>L<br>S<br>S<br>S | 12<br>14<br>0<br>4<br>0 |
| POP      |            | S<br>S<br>S           | 0<br>0<br>1C            |
| (RESET)  |            | S<br>L                | 8<br>0                  |
| SL       | 1          | S                     | 0                       |
| SL       | 4          | S                     | 0                       |
| SR       | 1          | S                     | 0                       |
| SR       | 4          | S                     | 0                       |
| ST       |            | L<br>S                | 5<br>0                  |
| XI       | DATA8      | L<br>S                | 3<br>0                  |
| XM       |            | L<br>S                | 2<br>0                  |
| XS       | r          | S                     | 0                       |

The following symbols are used in Table 2-3:

aaaa Four bits choosing the register addressing mode:  
 0000-1011 Registers 0 - B directly addressed

1100 ISAR addresses the register

1101 ISAR addresses the register. Increment low three bits of ISAR.

1110 ISAR addresses the register. Decrement low three bits of ISAR.

1111 NOP. No operation is performed if aaaa=F16.

cc Two bits choosing a Scratchpad register:

00-KU Scratchpad Register 12

01-KL Scratchpad Register 13

10-QU Scratchpad Register 14

11-QL Scratchpad Register 15

d One bit of immediate data.

eeee A 4-bit port number.

qqqq A 16-bit address.

rr An 8-bit signed displacement.

ss An 8-bit port number.

yy One byte (8 bits) of immediate data.

When two numbers are given in the "Machine Cycles" column (for example, 3/3.5), the first is the execution time if no branch is taken, and the second is execution time if the branch is taken.

Table 2-3. 3870/F8 Instruction Set Object Code

| INSTRUCTION   | OBJECT CODE    | BYTES | MACHINE CYCLES | INSTRUCTION | OBJECT CODE | BYTES | MACHINE CYCLES |
|---------------|----------------|-------|----------------|-------------|-------------|-------|----------------|
| ADC           | 8E             | 1     | 2.5            | LNK         | 19          | 1     | 1              |
| AI DATA8      | 24 YY          | 2     | 2.5            | LR A,DPCHR  | 000000cc    | 1     | 1              |
| AM            | 88             | 1     | 2.5            | LR A,IS     | 0A          | 1     | 1              |
| AMD           | 89             | 1     | 2.5            | LR A,r      | 010aaaa     | 1     | 1              |
| AS r          | 1100aaaa       | 1     | 1              | LR DC,H     | 10          | 1     | 4              |
| ASD r         | 1101aaaa       | 1     | 2              | LR DC,Q     | 0F          | 1     | 4              |
| BC DISP       | 82 RR          | 2     | 3/3.5          | LR DPCHR,A  | 000001cc    | 1     | 1              |
| BF DATA4,DISP | 1001dddd<br>RR | 2     | 3/3.5          | LR H,DC     | 11          | 1     | 4              |
| BM DISP       | 91 RR          | 2     | 3/3.5          | LR IS,A     | 0B          | 1     | 1              |
| BNC DISP      | 92 RR          | 2     | 3/3.5          | LR J,W      | 1E          | 1     | 1              |
| BNO DISP      | 98 RR          | 2     | 3/3.5          | LR K,PC1    | 08          | 1     | 4              |
| BNZ DISP      | 94 RR          | 2     | 3/3.5          | LR PC0,Q    | 0D          | 1     | 4              |
| BP DISP       | 81 RR          | 2     | 3/3.5          | LR PC1,K    | 09          | 1     | 4              |
| BR DISP       | 90 RR          | 2     | 3.5            | LR Q,DC     | 0E          | 1     | 4              |
| BR7 DISP      | 8F RR          | 2     | 3/3.5          | LR r,A      | 0101aaaa    | 1     | 1              |
| BT DATA3,DISP | 10000ddd<br>RR | 2     | 3/3.5          | LR W,J      | 1D          | 1     | 2              |
| BZ DISP       | B4             | 2     | 3/3.5          | NI DATA8    | 21 YY       | 2     | 2.5            |
| CI DATA8      | 25 YY          | 2     | 2.5            | NM          | 8A          | 1     | 2.5            |
| CLR           | 70             | 1     | 1              | NOP         | 2B          | 1     | 1              |
| CM            | 8D             | 1     | 2.5            | NS r        | 1111aaaa    | 1     | 1              |
| COM           | 18             | 1     | 1              | OI DATA8    | 22 YY       | 2     | 2.5            |
| DCI ADDR      | 2A QQQQ        | 3     | 6              | OM          | 8B          | 1     | 2.5            |
| DI            | 1A             | 1     | 2              | OUT P8      | 27 SS       | 2     | 4              |
| DS r          | 0011aaaa       | 1     | 1.5            | OUTS P4     | 1011eeee    | 1     | 4              |
| EI            | 1B             | 1     | 2              | PI ADDR     | 28 QQQQ     | 3     | 6.5            |
| IN P8         | 26 SS          | 2     | 4              | PK          | 0C          | 1     | 4              |
| INC           | 1F             | 1     | 1              | POP         | 1C          | 1     | 2              |
| INS P4        | 1010eeee       | 1     | 4              | SL 1        | 13          | 1     | 1              |
| JMP ADDR      | 29 QQQQ        | 3     | 5.5            | SL 4        | 15          | 1     | 1              |
| LI DATA8      | 20 YY          | 2     | 2.5            | SR 1        | 12          | 1     | 1              |
| LIS DATA4     | 0111dddd       | 1     | 1              | SR 4        | 14          | 1     | 1              |
| LISL DATA3    | 01101ddd       | 1     | 1              | ST          | 17          | 1     | 2.5            |
| LISU DATA3    | 01100ddd       | 1     | 1              | XDC         | 2C          | 1     | 2              |
| LM            | 16             | 1     | 2.5            | XI DATA8    | 23 YY       | 2     | 2.5            |
|               |                |       |                | XM          | 8C          | 1     | 2.5            |
|               |                |       |                | XS r        | 1110aaaa    | 1     | 1              |

## THE 3850 CPU

Beginning with the 3850 CPU, we are going to describe the individual devices of the F8 microcomputer system. The 3850 CPU and the 3851 PSU descriptions depend on the preceding 3870 discussion for a frame of reference. That is to say, these two F8 devices are described as variations of the 3870, rather than as stand-alone devices.

Functions implemented on the 3850 CPU are illustrated in Figure 2-5.

These are the functions which one would expect to find on a CPU chip, and which are on the 3850 CPU:

- The Arithmetic and Logic Unit
- The Control Unit and Instruction register
- Logic needed to interface the System Bus with the control signals which are input and output by the CPU
- Accumulator register

There is no memory addressing logic, and there are no memory addressing registers on the 3850 CPU. Stack Pointer, Program Counter and Data Counter registers are all maintained on memory chips and memory interface chips.

With the F8 scheme, memory addressing logic will be duplicated if more than one memory device is present in an F8 microcomputer system. We will discuss shortly how potential contention problems are resolved under these circumstances.



Figure 2-5. Logic of the Fairchild F8 3850 CPU

**Two advantages accrue from having no memory address logic on the CPU chip:**

- 1) No address lines are needed on the System Bus, so neither the CPU nor connecting devices need 16 address pins. These 16 pins are used instead to implement two 8-bit I/O ports at each device.
- 2) The real estate on the CPU chip which would have been used by Address registers and memory addressing logic is available for other purposes; it is used to implement 64 bytes of read/write memory.

**Having I/O ports and read/write memory on the CPU chip paves the way for some very low-cost small microcomputer configurations;** for example, the 3850 CPU and the 3851 PSU form a two-device microcomputer system, with all of the necessary prerequisites for reasonable performance. Until the advent of the 3870 single-chip microcomputer, this two-chip configuration represented the lowest cost 8-bit microcomputer on the market.

**The disadvantage of removing memory addressing logic from the CPU chip is that standard memory devices can no longer connect directly to the System Bus.** This bus has no address lines; therefore, separate logic devices must create the interface needed by standard memories. In the F8 system this is done by the 3852 DMI and the 3853 SMI devices.

**Clock signal generation logic is also part of the 3850 CPU.** This is now standard among microcomputers.

## F8 PROGRAMMABLE REGISTERS AND STATUS FLAGS

F8 programmable registers and status flags are identical to the 3870. For details, refer to the earlier discussion.

### F8 ADDRESSING MODES

3870 and F8 addressing modes are identical, both for scratchpad memory and for external program memory. But memory addressing logic is implemented on F8 memory devices, not on the 3850 CPU.

Every 3851 PSU contains its own Program Counter (PC0), Stack register (PS1), and Data Counter (DC0). The 3851 PSU has no Data Counter buffer (DC1).

The 3852 DMI and 3853 SMI devices contain all four Address registers: PC0, PC1, DC0 and DC1.

**Since Address registers are present on every PSU, DMI or SMI device in an F8 microcomputer system, these registers will be duplicated in any F8 system that contains more than a minimum amount of memory.** So long as the microcomputer system has been correctly configured, this presents no problem. Every memory device contains identical connections to the common System Bus, and instructions that modify the contents of any Address register do so identically for all memory devices. For example, if there are three memory devices, and therefore three Program Counters in an F8 system, every Program Counter is incremented identically after a byte of object code is fetched. This being the case, Address registers on different memory devices will always contain identical address information.

**Every F8 device that contains memory addressing logic also contains a memory address mask which you must define when ordering the device.** This mask identifies the device's addressed space. Thus, a memory device will only respond to memory accesses within its address space. **So long as no two devices have overlapping address spaces** (and if they do, that is a logic design error) **there is no chance for memory contentions to arise.** In order to illustrate this point, consider the very simple example of an F8 configuration that contains two 3851 PSUs. Each 3851 PSU contains 1024 bytes of read-only memory. Let us assume that 3851 PSU #1 responds to memory addresses in the range 0000<sub>16</sub> through 03FF<sub>16</sub>, while PSU #2 responds to memory addresses in the range 0400<sub>16</sub> through 07FF<sub>16</sub>. This may be illustrated as follows:



Any memory reference instruction will identify a memory address as the contents of either the Program Counter (PC0) or the Data Counter (DC0). When this address is in the range 0000<sub>16</sub> through 03FF<sub>16</sub>, PSU #1 will respond but PSU #2 will not. If this address is in the range 0400<sub>16</sub> through 07FF<sub>16</sub>, then PSU #2 will respond but PSU #1 will not. A memory address of 0800<sub>16</sub> or more will result in neither PSU responding.

There is one circumstance under which memory addressing contentions can arise. Since the 3851 PSU does not contain a DC1 register, it does not respond to the XDC instruction which exchanges the contents of the DC0 and DC1 registers. Therefore, in an F8 configuration that contains 3851 PSUs together with 3852 DMI and/or 3853 SMI devices, execution of an XDC instruction will result in 3851 PSU DC0 registers containing different information from 3852 DMI or 3853 SMI DC0 registers. If an external data memory reference instruction is now executed, it is possible for a 3851 PSU and 3852 DMI or 3853 SMI device to simultaneously consider itself selected. For example, consider an F8 configuration which contains a 3851 PSU and 3853 SMI. Suppose the 3851 PSU mask causes it to respond to addresses in the range 0000<sub>16</sub> through 03FF<sub>16</sub>, while the 3853 SMI responds to all other memory addresses. Now, if Data Counter DC0 contains 02A3<sub>16</sub> while the Data Counter buffer (DC1) contains 0A7F<sub>16</sub>, then, following execution of an XDC in-

struction, nothing will happen to the contents of the 3851 PSU DCO register; however, the 3853 SMI DCO register will contain 0A7F16. Any instruction that accesses data memory via DCO will now cause both the 3851 PSU and the 3853 SMI to consider themselves selected.

In F8 configurations that include the 3851 PSU together with 3852 DMI or 3853 SMI devices, the best way of avoiding memory addressing problems is to not use the XDC instruction. If you do use the XDC instruction, you must be particularly careful to ensure that DCO is never within a 3851 PSU's address space when the XDC instruction is executed.

## F8 CLOCK CIRCUITS

**Three ways of generating an F8 system clock have been advertised; these are the RC mode, Crystal mode, and External mode. Only Crystal mode has worked consistently in practice.**

**Using the Crystal mode, a crystal in the 1 to 2 MHz range connects across the XTLX and XTLY pins; along with two capacitors (C<sub>1</sub> and C<sub>2</sub>), which provide a highly precise clock frequency:**



The external crystal (and capacitors), together with internal circuitry, combine to form a parallel resonant crystal oscillator. The two capacitors should be approximately 15pF. The crystal should have these characteristics:

- Frequency: 1 to 2 MHz
- Mode of Oscillation: Fundamental
- Operating Temperature Range: 0 to 70°C
- Equivalent Resistance: 1 to 1.5 MHz ~ 475 Ω  
1.5 to 2 MHz ~ 350 Ω
- Resonance: Parallel
- Drive Level: 10mW
- Load Capacity: ~ 15pF
- Frequency Tolerance: Per customer's requirements
- Holder (case) Style:

You can use an external clock to synchronize an F8 system with external logic. The clock signal must be input to the 3850 XTLY pin as follows:



Table 2-4. ROMC Signals and What They Imply

| ROMC<br>4 3 2 1 0 | HEX | CYCLE LENGTH | FUNCTION                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0 0 0 0         | 00  | S,L          | Instruction Fetch. The device whose address space includes the contents of the PC0 register must place on the Data Bus the op code addressed by PC0. Then all devices increment the contents of PC0.                                                                                                                                                           |
| 0 0 0 0 1         | 01  | L            | The device whose address space includes the contents of the PC0 register must place on the Data Bus the contents of the memory location addressed by PC0. Then all devices add the 8-bit value on the Data Bus, as a signed binary number, to PC0.                                                                                                             |
| 0 0 0 1 0         | 02  | L            | The device whose DC0 addresses a memory word within the address space of that device must place on the Data Bus the contents of the memory location addressed by DC0. Then all devices increment DC0.                                                                                                                                                          |
| 0 0 0 1 1         | 03  | L,S          | Similar to 00, except that it is used for Immediate Operand fetches (using PC0) instead of instruction fetches.                                                                                                                                                                                                                                                |
| 0 0 1 0 0         | 04  | S            | Copy the contents of PC1 into PC0.                                                                                                                                                                                                                                                                                                                             |
| 0 0 1 0 1         | 05  | L            | Store the Data Bus contents or write bus contents into the memory location pointed to by DC0. Increment DC0.                                                                                                                                                                                                                                                   |
| 0 0 1 1 0         | 06  | L            | Place the high order byte of DC0 on the Data Bus.                                                                                                                                                                                                                                                                                                              |
| 0 0 1 1 1         | 07  | L            | Place the high order byte of PC1 on the Data Bus.                                                                                                                                                                                                                                                                                                              |
| 0 1 0 0 0         | 08  | L            | All devices copy the contents of PC0 into PC1. The CPU outputs zero on the Data Bus in this ROMC state. Load the Data Bus into both halves of PC0 thus clearing the register.                                                                                                                                                                                  |
| 0 1 0 0 1         | 09  | L            | The device whose address space includes the contents of the DC0 register must place the low order byte of DC0 onto the Data Bus.                                                                                                                                                                                                                               |
| 0 1 0 1 0         | 0A  | L            | All devices add the 8-bit value on the Data Bus, treated as a signed binary number, to the Data Counter.                                                                                                                                                                                                                                                       |
| 0 1 0 1 1         | 0B  | L            | The device whose address space includes the value in PC1 must place the low order byte of PC1 on the Data Bus.                                                                                                                                                                                                                                                 |
| 0 1 1 0 0         | 0C  | L            | The device whose address space includes the contents of the PC0 register must place the contents of the memory word addressed by PC0 onto the Data Bus. Then all devices move the value which has just been placed on the Data Bus into the low order byte of PC0.                                                                                             |
| 0 1 1 0 1         | 0D  | S            | All devices store in PC1 the current contents of PC0, incremented by 1. PC0 is unaltered.                                                                                                                                                                                                                                                                      |
| 0 1 1 1 0         | 0E  | L            | The device whose address space includes the contents of PC0 must place the contents of the word addressed by PC0 onto the Data Bus. The value on the Data Bus is then moved to the low order byte of DC0 by all devices.                                                                                                                                       |
| 0 1 1 1 1         | 0F  | L            | The interrupting device with highest priority must place the low order byte of the interrupt vector on the Data Bus. All devices must copy the contents of PC0 into PC1. All devices must move the contents of the Data Bus into the low order byte of PC0.                                                                                                    |
| 1 0 0 0 0         | 10  | L            | Inhibit any modification to the interrupt priority logic.                                                                                                                                                                                                                                                                                                      |
| 1 0 0 0 1         | 11  | L            | The device whose memory space includes the contents of PC0 must place the contents of the addressed memory word on the Data Bus. All devices must then move the contents of the Data Bus to the upper byte of DC0.                                                                                                                                             |
| 1 0 0 1 0         | 12  | L            | All devices copy the contents of PC0 into PC1. All devices then move the contents of the Data Bus into the low order byte of PC0.                                                                                                                                                                                                                              |
| 1 0 0 1 1         | 13  | L            | The interrupting device with highest priority must move the high order half of the interrupt vector onto the Data Bus. All devices must move the contents of the Data Bus into the high order byte of PC0. The interrupting device will reset its interrupt circuitry (so that it is no longer requesting CPU servicing and can respond to another interrupt). |
| 1 0 1 0 0         | 14  | L            | All devices move the contents of the Data Bus into the high order byte of PC0.                                                                                                                                                                                                                                                                                 |
| 1 0 1 0 1         | 15  | L            | All devices move the contents of the Data Bus into the high order byte of PC1.                                                                                                                                                                                                                                                                                 |
| 1 0 1 1 0         | 16  | L            | All devices move the contents of the Data Bus into the high order byte of DC0.                                                                                                                                                                                                                                                                                 |
| 1 0 1 1 1         | 17  | L            | All devices move the contents of the Data Bus into the low order byte of PC0.                                                                                                                                                                                                                                                                                  |
| 1 1 0 0 0         | 18  | L            | All devices move the contents of the Data Bus into the low order byte of PC1.                                                                                                                                                                                                                                                                                  |
| 1 1 0 0 1         | 19  | L            | All devices move the contents of the Data Bus into the low order byte of DC0.                                                                                                                                                                                                                                                                                  |
| 1 1 0 1 0         | 1A  | L            | During the prior cycle an I/O port timer or interrupt control register was addressed. The device containing the addressed port must move the current contents of the Data Bus into the addressed port.                                                                                                                                                         |
| 1 1 0 1 1         | 1B  | L            | During the prior cycle the Data Bus specified the address of an I/O port. The device containing the addressed I/O port must place the contents of the I/O port on the Data Bus. (Note that the contents of timer and interrupt control registers cannot be read back onto the Data Bus.)                                                                       |
| 1 1 1 0 0         | 1C  | L or S       | None.                                                                                                                                                                                                                                                                                                                                                          |
| 1 1 1 0 1         | 1D  | S            | Devices with DC0 and DC1 registers must switch registers. Devices without a DC1 register perform no operation.                                                                                                                                                                                                                                                 |
| 1 1 1 1 0         | 1E  | L            | The device whose address space includes the contents of PC0 must place the low order byte of PC0 onto the Data Bus.                                                                                                                                                                                                                                            |
| 1 1 1 1 1         | 1F  | L            | The device whose address space includes the contents of PC0 must place the high order byte of PC0 on the Data Bus.                                                                                                                                                                                                                                             |

## F8 CPU PINS AND SIGNALS

3850 CPU pins and signals are illustrated in Figure 2-6. A description of these signals is useful as a guide to the way in which the F8 microcomputer system works.



Figure 2-6. Fairchild 3850 CPU Signals and Pin Assignments

**The Data Bus lines (DB0 - DB7) and the control lines (ROMC0 - ROMC4) provide the heart of all data and control information flow.**

The Data Bus lines are common, bidirectional lines, and are the only conduit for data to be transmitted between devices of an F8 microcomputer system.

**A lack of address lines on the System Bus usually means that data and addresses must be multiplexed on a single set of eight lines — which slows down all memory reference operations; they must now proceed in three serial increments, rather than in one parallel increment. In the F8 System Bus, multiplexing is rarely needed, since addresses originate within memory devices, or memory interface devices, whence they are transmitted directly to memory.** In other words, the only time addresses are ever transmitted on the Data Bus is when they are being transmitted as data.

Refer to Figure 2-1. Suppose a memory reference instruction needs to access a byte of dynamic RAM. ROMC control signals (described in the next paragraph) specify that the memory byte whose address is implied by the Data Counter (DC0) is to be referenced. Every memory device receives the ROMC control signals, but only the 3852 DMI finds that its address space includes the Data Counter implied address; therefore, only the 3852 DMI will respond to the memory reference instruction. The 3852 DMI then outputs an address directly to dynamic RAM; this address is not transmitted

via the System Bus. If the memory reference instruction requires data to be input to or output from dynamic RAM, the data transfer occurs directly between the System Bus and Dynamic RAM, bypassing the 3852 DMI entirely.

### ROMC STATE

Since the 3851 PSU, the 3852 DMI and the 3853 SMI devices all contain Address registers and address generation logic, they also contain rudimentary Arithmetic and Logic Units equivalent to very primitive CPUs. These primitive CPUs are driven by 5-bit instructions called ROMC states. **ROMC states are output by the 3850 CPU via five control lines, ROMC0 - ROMC4.** Each five-bit combination of ROMC signal states identifies one of 32 possible operations which the memory devices may have to perform to accomplish one step of an instruction's execution. For example, ROMC state 00000 causes the contents of memory bytes addressed by the Program Counter to be transmitted to the CPU; this is the "instruction fetch" ROMC state. Table 2-4 summarizes the interpretation of ROMC states.

**Φ and WRITE** are two timing signals output by the 3850 CPU to synchronize events within the rest of the F8 system.

The EXT RES line disables interrupts and loads a 0 address into all Program Counters, causing program execution to restart with the instruction code stored in external memory byte 0.

**INT REQ and ICB** are signals used for overall interrupt control. INT REQ is the master line on which all interrupt requests are transmitted to the 3850 CPU. ICB is output low by the CPU if interrupts are enabled, and it is output high by the CPU if interrupts are disabled.

The two I/O ports which are part of the 3850 CPU device use pins I/O00 - I/O07 and I/O10 - I/O17, respectively.

RC, XTLX and XTLY are the three pins used for clock inputs.

## F8 TIMING AND INSTRUCTION EXECUTION

All instructions are executed in cycles, which are timed by the trailing edge of WRITE.

There are two types of instruction cycle, the short cycle which is four Φ clock periods long, and the long cycle which is six Φ clock periods long. The long cycle is sometimes referred to as 1.5 cycles. WRITE high appears only at the end of an instruction cycle. Timing may be illustrated as follows:



The simplest instructions of the F8 instruction set execute in one short cycle. The most complex instruction (PI) requires two short cycles plus three long cycles.

**Table 2-2 summarizes the sequence in which short (S) and long (L) machine cycles are executed for each F8 instruction. ROMC states defining operations performed during each machine cycle are summarized in Table 2-4.**

The trailing edge of the WRITE pulse triggers the next ROMC state to be output on the ROMC0 - ROMC4 lines:



For any instruction that only accesses the Accumulator or scratchpad memory, no further System Bus activity is required, since all subsequent operations will occur within the F8 CPU. This inactivity on the System Bus is used to overlap the last (or only) machine cycle of one instruction with the instruction fetch for the next instruction. For instructions that execute in a single machine cycle, accessing only logic within the 3850 CPU, timing may be illustrated as follows:



Instructions that do access external memory or I/O ports will always terminate with a machine cycle that does not cause any System Bus activity; the next instruction is fetched during this machine cycle. This may be illustrated as follows:



If for any reason data is to be transferred via the Data Bus during a machine cycle, then the data appears on the Data Bus at some time which depends on the data source or destination. For details, see the data sheets at the end of this chapter. There are no accompanying control signals since none are needed; the ROMC state identifies events which are occurring. Timing for any machine cycle that involves data transfer via the Data Bus may be illustrated as follows:



## F8 I/O PORTS

Logic associated with each F8 I/O port pin may be illustrated as follows:



The characteristics of F8 I/O port pins differ markedly from the 3870. The only point of similarity is the fact that both have inverse logic: when you output a 1-bit, 0V is output to external logic; when you write a 0-bit, a +5V voltage is output to external logic. Conversely, external logic must input 0V for a 1 input bit and +5V for a 0 input bit.

On reset or power up, F8 I/O port pins are indeterminate. You must therefore start every Reset instruction sequence with instructions that initialize all I/O port pins. In contrast, the 3870 clears I/O Port 4 and 5 pins on reset; this generates +5V outputs since logic is inverted.

When using 3870 or F8 I/O ports, the following restrictions apply:

- 1) You must write 0 to every I/O port pin that is to receive data input. This is because external logic cannot write a 0 to any I/O port pin that previously had a 1 bit output by the CPU.
- 2) The CPU cannot output a 0 bit (+5V output) to an I/O port pin if the pin is connected to external logic that is inputting a 1 bit (0V input).

## A SUMMARY OF F8 INTERRUPT PROCESSING

The interrupt handling capabilities of the F8 system are described with the 3851 PSU and 3853 SMI devices. Although many different interrupt priority arbitration schemes could be implemented, the simplest scheme would be to daisy chain 3851 PSUs, terminating the daisy chain with a 3853 SMI if present.

As soon as an interrupt is acknowledged, the contents of Program Counters (PC0) are saved in Stack registers (PC1); then an interrupt vector address is loaded into the Program Counters. This address is a permanent mask option for PSUs, with the exception of bit 7, which discriminates between timer interrupts and external interrupts. The interrupt address vector is completely programmable for the 3853 SMI, again with the exception of bit 7, which discriminates between timer interrupts and external device interrupts.

Post-interrupt housekeeping operations must be handled via an appropriate program. Defining just what this program consists of is not simple; an F8 system has only the Accumulator and Status register which must be saved, but at the other extreme, it has the entire scratchpad which could be saved.

## THE F8 INSTRUCTION SET

The F8 and 3870 instruction sets are identical; for details see Table 2-1 and associated text.

## THE BENCHMARK PROGRAM

Now consider our benchmark program; for the F8 it looks like this:

|      |       |                                      |
|------|-------|--------------------------------------|
| DCI  | TABLE | LOAD TABLE BASE ADDRESS              |
| LM   |       | LOAD DISPLACEMENT TO FIRST FREE BYTE |
| ADC  |       | ADD TO BASE ADDRESS                  |
| XDC  |       | SAVE THIS ADDRESS IN DC1             |
| DCI  | IOBUF | LOAD I/O BUFFER BASE ADDRESS         |
| LOOP | LM    | LOAD NEXT BYTE FROM I/O BUFFER       |
| XDC  |       | SWITCH ADDRESSES                     |
| ST   |       | STORE IN NEXT BYTE OF TABLE          |
| XDC  |       | SWITCH ADDRESSES                     |
| DS   | 0     | DECREMENT I/O BUFFER LENGTH          |
| BNZ  | LOOP  | RETURN IF NOT END                    |
| LR   | H,DC  | IF END, STORE SECOND BYTE OF CURRENT |
| LR   | A,HL  | TABLE ADDRESS AS DISPLACEMENT TO     |
| DCI  | TABLE | FIRST FREE BYTE                      |
| ST   |       |                                      |

The benchmark program above makes the following assumptions:

- 1) The I/O buffer can be located anywhere in read/write memory.
- 2) The number of occupied bytes in the I/O buffer is maintained in scratchpad byte 0. Thus, decrementing scratchpad byte 0 to zero provides the I/O buffer length.
- 3) The permanent data table beginning memory address has all 0s for the low-order eight bits:

The table is not more than 256 bytes long, and the displacement to the first free byte is stored in the first byte of the table. Since the table beginning address has 0s in the low-order eight bits, the displacement to the first free byte also becomes the low-order eight bits of the first free byte address:



All of the above assumptions are valid — and, depending upon the application, may also be realistic. Removing any of the above assumptions will make the F8 program longer, by removing one of the inherent strengths of the F8 instruction set.

## THE 3851 PROGRAM STORAGE UNIT (PSU)

The 3851 PSU has been the principal read-only memory program storage device in small F8 microcomputer systems. In addition to providing 1024 bytes of read-only memory, the 3851 PSU has two 8-bit I/O ports, a programmable timer, and interrupt logic.

The 3851 PSU can also be used in non-F8 microcomputer systems. The most important and non-obvious advantage of including a 3851 PSU in a non-F8 microcomputer system is the fact that 3851 PSU memory will lie outside of the microcomputer address space. This is because the 3851 PSU relies on its own memory addressing logic, which exists independent of and parallel to any other memory addressing logic.

Figure 2-7 illustrates functions provided by the 3851 PSU. Device pins and signals are given in Figure 2-8. Pins and signals which are unique to the 3851 PSU are described as part of the general 3851 PSU discussion.



Figure 2-7. Logic of the Fairchild F8 3851, 3856 and 3857 Programmable Storage Unit



Figure 2-8. 3851 PSU Signals and Pin Assignments

## THE 3851 PSU READ-ONLY MEMORY

Every 3851 PSU has 1024 bytes of read-only memory, plus memory addressing logic. The read-only memory must be defined when the chip is created.

3851 PSU memory addressing logic consists of a Program Counter (PC0), a Data Counter (DC0), and a Stack register (PC1), which is in fact a buffer for the Program Counter.

There is also a 6-bit page select mask, which must be specified when the chip is created; the page select represents the high-order six bits of the memory address for all ROM bytes of the PSU. As such, the page select defines the PSU's address space.

**PSU  
ADDRESS  
SPACE**

When a ROMC state output by the 3850 CPU, and received by the 3851 PSU, identifies a memory reference operation, the ROMC state also identifies whether the memory address is to be found in PC0 or in DC0. In response to this ROMC state, PSU memory addressing logic will compare its 6-bit page select mask with the high-order six bits of the specified Address register's contents:



If there is coincidence, the 3851 PSU will respond to the memory reference operation; if there is no coincidence, the 3851 PSU addressing logic modifies the contents of Address registers, as might be required by the ROMC state, but it does not respond to the actual memory reference instruction.

## 3851 PSU INPUT/OUTPUT LOGIC

**Every 3851 PSU has four I/O port addresses assigned to it. These four I/O ports have addresses which are specified via a 6-bit I/O port address mask,** which you must define when you order a 3851 PSU. This mask is interpreted as the 6 high-order bits of an 8-bit I/O port address. These are the four addressable I/O ports:

|                        |                                           |
|------------------------|-------------------------------------------|
| I/O port address mask: | XXXXXX                                    |
|                        | XXXXXX00      I/O Port A                  |
|                        | XXXXXX01      I/O Port B                  |
|                        | XXXXXX10      Interrupt control port      |
|                        | XXXXXX11      Programmable Timer register |

Suppose the 6-bit I/O port mask is specified as  $000011_2$ . I/O Ports OC<sub>16</sub>, OD<sub>16</sub>, OE<sub>16</sub> and OF<sub>16</sub> will then be selected. An I/O port mask of 000000 is illegal, since I/O port addresses 0 and 1 are reserved for the two 3850 CPU I/O ports.

**The two 8-bit I/O ports of a 3851 PSU are identical to the 3850 CPU I/O ports** which we have already described, except for one detail: **there are three optional I/O port pin logic configurations available with a 3851 PSU.**

The first option is the standard configuration which we described for the 3850 CPU I/O port pins.

The second option is open drain configuration, which may be illustrated as follows:



This open drain configuration allows you to wire-OR outputs from a number of pins.

The third option is a driver pull-up configuration designed specifically to drive LED displays. This configuration may be illustrated as follows:



### 3851 PSU INTERRUPT LOGIC

The 3851 PSU can receive external interrupt requests or interrupt requests from its programmable timer. These two sets of interrupt logic can be selectively enabled or disabled via a control code written to the interrupt control I/O port. This control code is interpreted as follows:

I/O Port No: X X X X X X 1 0



External interrupt request logic may be illustrated as follows:



An external interrupt request is generated by external logic pulling EXT INT low. The interrupt request will be passed on to the CPU by outputting INT REQ low, providing these two conditions are met:

- 1) External interrupts have been enabled via the interrupt control code (01 in the two low-order bits).
- 2) The PRI IN signal is low.

If EXT INT is low and external interrupts are enabled, an interrupt is being requested; whether or not it is acknowledged, PRI OUT is output high. The combination of the PRI IN and PRI OUT signals is designed to implement daisy chain interrupt priority logic, which may be illustrated as follows:



When an active interrupt request occurs at one device, outputting PRI OUT high disables external interrupt logic at all lower priority devices in the daisy chain.

**An interval timer interrupt request is generated when the programmable timer I/O port decrements to zero.** This interrupt request will be acknowledged if programmable timer interrupts have been enabled via the interrupt control I/O port (11 in the two low-order bits).

There is no priority arbitration between external interrupts and programmable timer interrupts, since one or the other but not both can be enabled at any time.

**When the CPU acknowledges an interrupt request, the 3851 PSU responds by saving Program Counter (PC0) contents in the Stack register (PC1), then loading an interrupt service routine starting address into the Program Counter (PC0). This interrupt service routine starting address is a mask option which you must specify when ordering the 3851 PSU. One bit of the interrupt address vector (it is bit 7) is set aside to identify the interrupt request as external or as coming from the programmable timer.** This may be illustrated as follows:



The actual interrupt response sequence consists of five machine cycles, during which ROMC states are output in the order 10<sub>16</sub>, 1C<sub>16</sub>, 0F<sub>16</sub>, 13<sub>16</sub>, 00<sub>16</sub>. Table 2-4 identifies functions performed in response to each ROMC state.

Table 2-5. Relationship Between Programmable Timer Contents and Effective Timer Counts

| TIMER CONTENTS | TIMER COUNTS | TIMER CONTENTS | TIMER COUNTS | TIMER CONTENTS | TIMER COUNTS | TIMER CONTENTS | TIMER COUNTS | TIMER CONTENTS | TIMER COUNTS |
|----------------|--------------|----------------|--------------|----------------|--------------|----------------|--------------|----------------|--------------|
| FE             | 254          | F5             | 203          | BC             | 152          | 62             | 101          | 2A             | 50           |
| FD             | 253          | EA             | 202          | 79             | 151          | C4             | 100          | 55             | 49           |
| FB             | 252          | D4             | 201          | F2             | 150          | 88             | 99           | AA             | 48           |
| F7             | 251          | A9             | 200          | E4             | 149          | 11             | 98           | 54             | 47           |
| EE             | 250          | 52             | 199          | C9             | 148          | 22             | 97           | A8             | 46           |
| DC             | 249          | A4             | 198          | 93             | 147          | 44             | 96           | 50             | 45           |
| B8             | 248          | 49             | 197          | 27             | 146          | 89             | 95           | A0             | 44           |
| 71             | 247          | 92             | 196          | 4E             | 145          | 13             | 94           | 41             | 43           |
| E3             | 246          | 25             | 195          | 9C             | 144          | 26             | 93           | 83             | 42           |
| C7             | 245          | 4A             | 194          | 38             | 143          | 4C             | 92           | 06             | 41           |
| 8E             | 244          | 94             | 193          | 70             | 142          | 98             | 91           | 0D             | 40           |
| 1D             | 243          | 29             | 192          | E1             | 141          | 30             | 90           | 1A             | 39           |
| 3B             | 242          | 53             | 191          | C3             | 140          | 61             | 89           | 35             | 38           |
| 76             | 241          | A6             | 190          | 86             | 139          | C2             | 88           | 6B             | 37           |
| ED             | 240          | 4D             | 189          | OC             | 138          | 84             | 87           | D7             | 36           |
| DA             | 239          | 9A             | 188          | 18             | 137          | 08             | 86           | AF             | 35           |
| B4             | 238          | 34             | 187          | 31             | 136          | 10             | 85           | 5E             | 34           |
| 68             | 237          | 69             | 186          | 63             | 135          | 20             | 84           | BD             | 33           |
| D1             | 236          | D3             | 185          | C6             | 134          | 40             | 83           | 7B             | 32           |
| A3             | 235          | A7             | 184          | 8C             | 133          | 81             | 82           | F6             | 31           |
| 47             | 234          | 4F             | 183          | 19             | 132          | 02             | 81           | EC             | 30           |
| 8F             | 233          | 9E             | 182          | 33             | 131          | 05             | 80           | D8             | 29           |
| 1F             | 232          | 3C             | 181          | 67             | 130          | 0B             | 79           | B0             | 28           |
| 3F             | 231          | 78             | 180          | CE             | 129          | 16             | 78           | 60             | 27           |
| 7E             | 230          | F0             | 179          | 9D             | 128          | 2C             | 77           | C0             | 26           |
| FC             | 229          | E0             | 178          | 3A             | 127          | 59             | 76           | 80             | 25           |
| F9             | 228          | C1             | 177          | 74             | 126          | B3             | 75           | 00             | 24           |
| F3             | 227          | 82             | 176          | E9             | 125          | 66             | 74           | 01             | 23           |
| E6             | 226          | 04             | 175          | D2             | 124          | CC             | 73           | 03             | 22           |
| CD             | 225          | 09             | 174          | A5             | 123          | 99             | 72           | 07             | 21           |
| 9B             | 224          | 12             | 173          | 4B             | 122          | 32             | 71           | 0F             | 20           |
| 36             | 223          | 24             | 172          | 96             | 121          | 65             | 70           | 1E             | 19           |
| 6D             | 222          | 48             | 171          | 2D             | 120          | CA             | 69           | 3D             | 18           |
| DB             | 221          | 90             | 170          | 5B             | 119          | 95             | 68           | 7A             | 17           |
| B6             | 220          | 21             | 169          | B7             | 118          | 2B             | 67           | F4             | 16           |
| 6C             | 219          | 42             | 168          | 6E             | 117          | 57             | 66           | E8             | 15           |
| D9             | 218          | 85             | 167          | DD             | 116          | AE             | 65           | D0             | 14           |
| B2             | 217          | 0A             | 166          | BA             | 115          | 5C             | 64           | A1             | 13           |
| 64             | 216          | 14             | 165          | 75             | 114          | B9             | 63           | 43             | 12           |
| C8             | 215          | 28             | 164          | EB             | 113          | 73             | 62           | 87             | 11           |
| 91             | 214          | 51             | 163          | D6             | 112          | E7             | 61           | 0E             | 10           |
| 23             | 213          | A2             | 162          | AD             | 111          | CF             | 60           | 1C             | 9            |
| 46             | 212          | 45             | 161          | 5A             | 110          | 9F             | 59           | 39             | 8            |
| 8D             | 211          | 8B             | 160          | B5             | 109          | 3E             | 58           | 72             | 7            |
| 1B             | 210          | 17             | 159          | 6A             | 108          | 7C             | 57           | E5             | 6            |
| 37             | 209          | 2E             | 158          | D5             | 107          | F8             | 56           | CB             | 5            |
| 6F             | 208          | 5D             | 157          | AB             | 106          | F1             | 55           | 97             | 4            |
| DF             | 207          | BB             | 156          | 56             | 105          | E2             | 54           | 2F             | 3            |
| BE             | 206          | 77             | 155          | AC             | 104          | C5             | 53           | 5F             | 2            |
| 7D             | 205          | EF             | 154          | 58             | 103          | 8A             | 52           | BF             | 1            |
| FA             | 204          | DE             | 153          | B1             | 102          | 15             | 51           | 7F             | 0            |

Timer counts are decimal numbers

Timer contents are hexadecimal numbers

## 3851 PSU PROGRAMMABLE TIMER LOGIC

The 3851 PSU has a single programmable timer which is addressed as the fourth I/O port (XXXXXX11<sub>2</sub>). This timer is free running unless it contains the value FF16. The value FF16 stops the timer.

The interval timer is a polynomial shift register. Table 2-5 gives the correlation between timer counts and timer register contents.

The programmable timer decrements once every 31 clock periods. Using a 500 nanosecond clock, therefore, the timer register will decrement once every 15.5 microseconds.

In order to generate any specific time interval, you must load an initial value into the programmable timer register by outputting the appropriate timer contents to the programmable timer I/O port address. For example, in order to have an initial value of 100<sub>16</sub>, you must load the programmable timer I/O port with the value C416. Loading the programmable timer with the initial value 2816 will generate an initial count of 16410. These correlations can be read off Table 2-5.

Once the programmable timer times out, it reloads the value FE16, representing 25410 counts, and starts to decrement again.

## 3851 PSU DATA TRANSFER TIMING

When data is input to the 3851 PSU from the Data Bus, no control signals are needed since the ROMC state signals identify the presence of data on the Data Bus. When data is output by the 3851 PSU, however, the control output DBDR is low. Timing may be illustrated as follows:



The purpose of the low DBDR signal is to prevent Data Bus contentions from ever arising. This is also a very useful signal in non-F8 microcomputer systems that include a 3851 PSU, since it can be used as a data read strobe.

## USING THE 3851 PSU IN NON-F8 CONFIGURATIONS

The 3851 PSU is easily included in non-F8 microcomputer configurations. The trick is to generate ROMC states as memory addresses. A ROMC state of 1C idles the 3851 PSU. Appropriate logic is illustrated in Figure 2-9.

Let us consider some examples. For simplicity, we will use 8080A assembly language mnemonics and assume that the 3851 PSU is selected by addresses FFED16 through FFFF16. This is how data input and data output via 3851 PSU I/O ports could be implemented, in conjunction with the logic of Figure 2-9:

| F8 Instructions |      | ROMC States | 8080A Instructions |        |
|-----------------|------|-------------|--------------------|--------|
| IN              | PORT | 03          | MVI                | A.PORT |
|                 |      | 1B          | STA                | OFFE3H |
|                 |      | 00          | LDA                | OFFFBH |
| OUT             | PORT | 03          | MVI                | A.PORT |
|                 |      | 1A          | LXI                | OFFFAH |
|                 |      |             | MVI                | B.DATA |
|                 |      |             | STA                | OFFE3H |
|                 |      |             | MOV                | M.B.   |



Figure 2-9. Conceptual Logic to Include a 3851 PSU in a Non-F8 Microcomputer System

**Possibly the most useful application for a 3851 PSU in some other microcomputer system would be to implement lookup tables.** The 1024 bytes of read-only memory could store data tables of that size. The Program Counter and Data Counter are active Address registers which can be used to identify the location which must be looked up.

By way of illustration, consider a decimal multiplication table look-up program. 100 bytes of read-only memory could be set aside to store the product of any two single decimal digits. This may be illustrated as follows:

Memory location: 00---09 10 11 12---19 20 21 22---29 30 31 etc.

Contents: 00---00 00 01 02---09 00 02 04---18 00 03 etc.

Now, in order to compute any decimal multiplication, the two decimal digits are loaded into the eight low-order Data Counter bits; the contents of the memory location addressed by the Data Counter are then read. Again assuming that the 3851 PSU is selected by memory addresses FFE16 through FFFF16, and using 8080A assembly language mnemonics in conjunction with Figure 2-9, appropriate instructions may be illustrated as follows:

| ROMC States | 8080A Instructions |
|-------------|--------------------|
| 19          | MVI 46H            |
| 02          | STA 0FFF9H         |
|             | LDA OFFE2H         |

19

02

MVI 46H

STA 0FFF9H

LDA OFFE2H

These instructions seek 4 x 6; 24 will be returned to the Accumulator.

These are just some conceptual examples of how the 3851 PSU can be used in non-F8 configurations. Clearly, the specific microprocessor being used to drive the 3851 PSU will have a significant influence on the exact interface used and the 3851 logic capabilities which are or are not accessible.

## THE 3861 AND 3871 PARALLEL I/O (PIO) DEVICES

The 3861 PIO contains the I/O ports, programmable timer, and interrupt logic of the 3861 PSU. This device contains no memory; it is otherwise identical to the 3861 PSU. Figure 2-8 provides 3861 PIO signals and pin assignments.

The 3871 has the I/O ports, timer/counter and interrupt logic of the 3870 single-chip microcomputer. 3871 PIO signals and pin assignments are identical to the 3861 PSU illustrated in Figure 2-8, with the exception that the 3870 STROBE signal associated with I/O Port 4 is output at pin 12.

## THE 3856 AND 3857 16K PROGRAMMABLE STORAGE UNITS (16K PSU)

These two devices are enhancements of and replacements for the 3851 PSU which we have just described. Superficially, Figure 2-7 represents the logic implemented on all three PSUs — the 3851, 3856 and 3857. Table 2-6 summarizes the differences between the devices. These are the most significant features of the 3856 and 3857 PSUs:

- 1) RESET sets all I/O port pins and address lines to zero. In the 3851, PSU RESET leaves I/O port pins indeterminate — and this has caused problems in many applications.
- 2) The interval timers of the 3856 and 3857 PSUs are binary decrementers rather than polynomial shifters — with the result that you can read timer contents directly and determine lapsed times. Also, a programmable option allows you to measure pulse widths being input to the PSU.
- 3) The 3857 PSU uses the 16 pins of the two 8-bit I/O ports for 16 address lines, so that additional ROM or RAM can be interfaced directly to a 3857 PSU — without requiring a 3852 DMI or 3853 SMI, as was the case with the 3851 PSU.
- 4) The 3856 and 3857 PSUs both provide 2K bytes of ROM for program storage; this is twice the program memory available on the 3851 PSU. This significantly increases the scope of two-device F8 microcomputer systems.

Figures 2-10 and 2-11 illustrate the pins and signals of the 3856 and 3857 16K PSUs respectively.

Table 2-6. A Summary of Differences Between 3851, 3856 and 3857 PSUs

| FUNCTION                 | 3851 PSU                               | 3856 PSU                                         | 3857 PSU                                         |
|--------------------------|----------------------------------------|--------------------------------------------------|--------------------------------------------------|
| ROM                      | 1024 bytes                             | 2048 bytes                                       | 2048 bytes                                       |
| I/O Ports                | 2 x 8 bits                             | 2 x 8 bits                                       | None                                             |
| Address lines            | None                                   | None                                             | 16                                               |
| Interrupt signals        | Priority in and Priority out           | Priority in and Priority out                     | Priority in only. Must be end of daisy chain.    |
| Interrupt options        | Enable timer or external, but not both | Enable timer and/or external                     | Enable timer and/or external                     |
| Timer register           |                                        |                                                  |                                                  |
| Timer decrement interval | 8-bit Polynomial<br>31 clock cycles    | 8-bit Count down<br>2, 8, 32 or 128 clock cycles | 8-bit Count down<br>2, 8, 32 or 128 clock cycles |
| Timer stop/start control | No                                     | Yes                                              | Yes                                              |
| Timer readback           | No                                     | Yes                                              | Yes                                              |
| Timer read pulse width?  | No                                     | Yes                                              | Yes                                              |
| RESET zero I/O ports?    | No                                     | Yes                                              | No I/O ports                                     |



| Pin Name                                            | Description           | Type                    |
|-----------------------------------------------------|-----------------------|-------------------------|
| I/O A0 - I/O A7                                     | I/O Port A            | Input/Output            |
| I/O B0 - I/O B7                                     | I/O Port B            | Input/Output            |
| STROBE                                              | STROBE for I/O Port A | Output                  |
| DB0 - DB7                                           | Data Bus              | Tristate, Bidirectional |
| ROMCO – ROMC4                                       | Control Lines         | Input                   |
| φ, WRITE                                            | Clock Lines           | Input                   |
| EXT INT                                             | External Interrupt    | Input                   |
| PRI IN                                              | Priority In           | Input                   |
| PRI OUT                                             | Priority Out          | Output                  |
| INT REQ.                                            | Interrupt Request     | Output                  |
| DBDR                                                | Data Bus Drive        | Output                  |
| V <sub>SS</sub> , V <sub>DD</sub> , V <sub>GG</sub> | Power Supply Lines    |                         |

Figure 2-10. 3856 PSU Signals and Pin Assignments



| Pin Name                                            | Description         | Type                    |
|-----------------------------------------------------|---------------------|-------------------------|
| ADDR00 - ADDR15                                     | Address Lines       | Output                  |
| CPU READ                                            | Memory Read Enable  | Output                  |
| RAM-WRITE                                           | Memory Write Signal | Output                  |
| DB0 - DB7                                           | Data Bus            | Tristate, Bidirectional |
| ROMC0 - ROMC4                                       | Control Lines       | Input                   |
| Φ, WRITE                                            | Clock Lines         | Input                   |
| EXT INT                                             | External Interrupt  | Input                   |
| PRI IN                                              | Priority In         | Input                   |
| INT REQ                                             | Interrupt Request   | Output                  |
| DBDR                                                | Data Bus Drive      | Output                  |
| V <sub>SS</sub> , V <sub>DD</sub> , V <sub>GG</sub> | Power Supply Lines  |                         |

Figure 2-11. 3857 PSU Signals and Pin Assignments

## ADDITIONAL F8 SUPPORT DEVICES

There are three additional F8 support devices: the 3852 Dynamic Memory Interface, the 3853 Static Memory Interface, and the 3854 Direct Memory Access device. We are going to summarize these devices rather than give complete descriptions, since these devices are infrequently used.

Only F8 configurations with a substantial amount of memory use these devices — and there are very few such F8 configurations; however, in every case there are better alternatives. For example, the 3854 Direct Memory Access device should not be used to implement direct memory access logic in non-F8 configurations: the Z80 DMA device is clearly superior. In fact, signal peculiarities and timing problems associated with the 3852 DMI, 3853 SMI and 3854 DMA devices make them unattractive components in non-F8 configurations.

If you do need to use the 3852 DMI, the 3853 SMI, or the 3854 DMA devices, you will have to refer to vendor literature, since the discussion which follows provides performance summaries only — not product detail.

### THE 3852 DYNAMIC MEMORY INTERFACE (DMI)

Primarily, this device contains the necessary address generation and memory refresh logic needed to include dynamic read/write memory in an F8 system.

Because of the way in which the F8 microcomputer system is organized, however, memory refresh and direct memory access logic are closely related. That is why, in Figure 2-12, a small part of the direct memory access control logic is shown as being implemented on the 3852 DMI chip.



Figure 2-12. Logic of the Fairchild F8 3852 Dynamic Memory Interface (DMI), and of the 3854 Direct Memory Access (DMA) Devices

Figure 2-13 illustrates pins and signals of the 3852 DMI.

**Conceptually, memory addressing logic of the 3852 DMI is very similar to 3857 PSU memory addressing logic; there are, however, some differences between the 3852 DMI memory addressing and the 3851 or 3856 PSU:**

- 1) The 3852 DMI contains two Data Counters, DC0 and DC1. The presence of the auxiliary Data Counter (DC1) has no immediate impact on memory addressing logic within the 3852 DMI. However, as we discussed earlier, its presence in an F8 system that also includes a 3851 PSU calls for programming caution.
- 2) Data and address flows surrounding a 3852 DMI are totally unlike the 3851 or 3856 PSU. In the case of these PSUs, addresses are transmitted entirely within the logic of the PSU; the only communication needed between a PSU and the CPU is via the eight Data Bus lines of the System Bus. The DMI, on the other hand, generates a 16-bit address, which it outputs directly to the read/write memory which it is controlling.

These address pins are equivalent to 3857 PSU address pins — that is, the address pins which a CPU would have, if the CPU contained memory addressing logic for the microcomputer system. In other words, the 3852 DMI creates the address lines and control signals, which, so far as the read/write memory is concerned, are lacking on the F8 System Bus. The F8 System Bus does, however, contain data lines needed by the read/write memory to actually transmit data to or from the CPU.

Data and address flows around the 3852 DMI may be illustrated as follows:



- 3) Unlike the 3851, 3856 or 3857 PSU, the 3852 DMI has no on-chip logic to determine address space for read/write memory which the DMI is controlling. Address space determination is made by logic in between the DMI and the read/write memory. Typically, selected high-order address lines output by the DMI are gated through elementary Boolean logic components to create the master enable signal used to strobe attached read/write memory. This is illustrated above.



Figure 2-13. 3852 DMI Signals and Pin Assignments

The process of refreshing dynamic memory and implementing direct memory access are integrally related in an F8 system.

The presence of a separate DMI interface device means that there can be a limited overlap between a memory reference operation which was initiated by the CPU and a memory reference operation that is not initiated by the CPU.

F8 DMI  
MEMORY  
REFRESH

Two types of memory reference operations are not initiated by the CPU: memory refresh and direct memory access.

Let us consider how a direct memory access may follow a CPU-initiated memory read operation. These are the events which occur:

- 1) Upon receiving an appropriate ROMC state from the CPU, the 3852 DMI outputs a 16-bit memory address, together with a read strobe; these outputs from the 3852 DMI are received by read/write memory.
- 2) Read/write memory responds by placing data directly on the Data Bus. The data must remain stable on the Data Bus until the CPU has had time to read the data.

- 3) While data is stable on the Data Bus, DMA logic may apply a new memory address to read/write memory. Following the arrival of address and control signals at read/write memory, there is a fixed time delay before read/write memory responds by placing data on the Data Bus. This time delay can overlap with time when prior data must be stable on the Data Bus. This may be illustrated as follows:

**F8 DIRECT  
MEMORY  
ACCESS**



**DMI logic outputs control signals which identify the way in which each memory access period is being used;** there are three possibilities:

- 1) Memory is communicating with the F8 System Bus.
- 2) Memory is not communicating with the System Bus, but since it is dynamic memory it is being refreshed.
- 3) Memory is not communicating with the System Bus and is available for external access.

Cases 2 or 3 above may follow case 1 in separate memory access periods of the same instruction cycle.

### THE 3854 DIRECT MEMORY ACCESS (DMA) DEVICE

This device receives memory access period identification signals output by the 3852 DMI. Based on the direct memory access requirements specified by the currently executing program, the DMA device accesses read/write memory, during available memory access periods, as defined by the 3852 DMI. Figure 2-14 illustrates 3854 DMA pins and signals.

**These are the variables which must be specified for a direct memory access operation:**

- 1) The beginning address for the memory buffer into which data must be written, or out of which data must be read.
- 2) The length of the buffer.
- 3) Whether data is to be written or read out of the buffer.

Once a direct memory access operation has been initiated, it proceeds in parallel with other events occurring within the F8 microcomputer system, using memory access periods which are defined by the 3852 DMI as available for direct memory access. In other words, direct memory access operations in no way slow down program execution that may be occurring in parallel.

**DMA data transfer may be high-speed or low-speed.** Low-speed DMA transfer means that each DMA access is enabled by a signal from the external device, stating that it is ready to transmit or receive data. High-speed access assumes that the external device will always be ready to transmit or receive data; therefore, every single available memory access period is utilized.

As a direct memory access operation proceeds, after each access the memory address is incremented and the buffer length is decremented. Memory address, buffer length and DMA controls are stored in buffers which the CPU accesses as though they were I/O ports. The contents of these I/O ports may be written into, or read at any time. **This means that the F8 DMA system allows total flexibility for every type of programmable DMA operation;** these include such things as stopping a DMA operation temporarily, or interrogating a DMA operation to determine how far it has progressed.

**Indefinite DMA transfer may also be specified.** In this case, no buffer length is given; rather, the DMA operation will proceed until stopped.



Figure 2-14. 3854 DMA Signals and Pin Assignments

## THE 3853 STATIC MEMORY INTERFACE (SMI)

The 3853 SMI provides interface logic for static read/write memory, that is, for memory which does not need to be refreshed. Logic implemented on this device is illustrated in Figure 2-15, and is a simple combination of functions which have already been described for the 3851 PSU and for the 3852 DMI. Figure 2-16 illustrates 3853 SMI pins and signals.

The description of memory interface logic which was given for the 3852 DMI applies also for the 3853 SMI. The 3853 SMI, however, does not identify memory access periods, and cannot be used to implement direct memory access.

Because the 3853 SMI does not have memory refresh or direct memory access support logic, there is unused real estate on the SMI chip. The real estate is used to implement a programmable timer and interrupt processing logic, as described for the 3851 PSU. There are, however, two small differences between interrupt logic as implemented on the PSU and the SMI devices; they are:

- 1) The 3853 SMI interrupt address vector is not a permanent mask option as it is on the PSU; rather, it is programmable.
- 2) The 3853 SMI has no priority output line, which means that in a daisy chain interrupt configuration it must have lowest priority; that is, it must come at the end of the daisy chain.



Figure 2-15. Logic of the F8 3853 Static Memory Interface (SMI) Device



| Pin Name                                            | Description             | Type          |
|-----------------------------------------------------|-------------------------|---------------|
| DB0 - DB7                                           | Data Bus Lines          | Bidirectional |
| ADDR0 - ADDR15                                      | Address Lines           | Output        |
| Φ, WRITE                                            | Clock Lines             | Input         |
| INT REQ                                             | Interrupt Request       | Output        |
| PRI IN                                              | Priority In Line        | Input         |
| RAM WRITE                                           | Write Line              | Output        |
| EXT INT                                             | External Interrupt Line | Input         |
| REGDR                                               | Register Drive Line     | Output        |
| CPU READ                                            | CPU Read Line           | Output        |
| ROMC0 - ROMC4                                       | Control Lines           | Input         |
| V <sub>SS</sub> , V <sub>DD</sub> , V <sub>GG</sub> | Power Supply Lines      |               |

Figure 2-16. 3853 SMI Signals and Pin Assignments

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- 3870 One-Chip Microcomputer
- 3850 CPU
- 3851 PSU
- 3852 DMI
- 3853 SMI
- 3854 DMA
- 3856 2K PSU
- 3861 PIO

## 3870

### ELECTRICAL SPECIFICATIONS

#### ABSOLUTE MAXIMUM RATINGS\*

|                                                     |           |                 |
|-----------------------------------------------------|-----------|-----------------|
| Temperature Under Bias . . . . .                    | . . . . . | 0°C to 70°C     |
| Storage Temperature . . . . .                       | . . . . . | -65°C to +150°C |
| Voltage On Any Pin With Respect To Ground . . . . . | . . . . . | -1.0V to +7V    |
| Power Dissipation . . . . .                         | . . . . . | 1.0W            |

#### DC CHARACTERISTICS

TA = 0°C to 70°C, VCC = 5V ± 10%

| SYMBOL            | PARAMETER                                                         | MIN  | MAX  | UNIT | TEST CONDITIONS                         |
|-------------------|-------------------------------------------------------------------|------|------|------|-----------------------------------------|
| I <sub>CC</sub>   | Power Supply Current                                              |      | TBD  | mA   | Outputs Open                            |
| P <sub>D</sub>    | Power Dissipation                                                 |      | TBD  | mW   | Outputs Open                            |
| V <sub>IHEX</sub> | External Clock Input High Level                                   | 2.4  | 5.8  | V    |                                         |
| V <sub>ILO</sub>  | External Clock Input Low Level                                    | -0.3 | 0.6  | V    |                                         |
| I <sub>IHEX</sub> | External Clock Input High Current                                 |      | 100  | μA   | V <sub>IHEX</sub> = 2.4V                |
| I <sub>ILO</sub>  | External Clock Input Low Current                                  |      | -100 | μA   | V <sub>ILO</sub> = 0.6V                 |
| V <sub>IH</sub>   | Input High Level                                                  | 2.0  | 5.8  | V    |                                         |
| V <sub>IL</sub>   | Input Low Level                                                   | -0.3 | 0.8  | V    |                                         |
| I <sub>IH</sub>   | Input High Current (except open drain and direct drive I/O ports) |      | 100  | μA   | V <sub>IH</sub> = 2.4V internal pull-up |
| I <sub>IL</sub>   | Input Low Current (except open drain and direct drive ports)      |      | -1.6 | mA   | V <sub>IL</sub> = 0.4V                  |
| I <sub>LOD</sub>  | Leakage Current (open drain ports)                                |      | 10   | μA   | Pull-down device off                    |
| I <sub>OH</sub>   | Output High Current (except open drain and direct drive ports)    | -100 |      | μA   | V <sub>OH</sub> = 2.4V                  |
| I <sub>OHD</sub>  | Output Drive Current (direct drive ports)                         | -1.5 | -8   | mA   | V <sub>OH</sub> = 0.7V to 1.5V          |
| I <sub>OL</sub>   | Output Low Current                                                | 1.8  |      | mA   | V <sub>OL</sub> = 0.4V                  |
| I <sub>OHS</sub>  | Output High Current (STROBE Output)                               | -300 |      | μA   | V <sub>OH</sub> = 2.4V                  |
| I <sub>OLS</sub>  | Output Low Current (STROBE Output)                                | 5.0  |      | mA   | V <sub>OL</sub> = 0.4V                  |

\*Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**3870****AC CHARACTERISTICS** $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = +5\text{V} \pm 10\%$ 

| SIGNAL         | SYMBOL                         | PARAMETER                        | MIN                                                                                     | MAX  | UNIT | COMMENTS                                |
|----------------|--------------------------------|----------------------------------|-----------------------------------------------------------------------------------------|------|------|-----------------------------------------|
| XTL 1<br>XTL 2 | t <sub>0(XTL)</sub>            | Time Base Period, Crystal Mode   | 250                                                                                     | 1000 | ns   | 4MHz-1MHz                               |
|                | t <sub>0(LC)</sub>             | Time Base Period, LC Mode        | 250                                                                                     | 1000 | ns   | 4MHz-1MHz                               |
|                | t <sub>0(RC)</sub>             | Time Base Period, RC Mode        | 250                                                                                     | 2000 | ns   | 4MHz-500kHz                             |
|                | t <sub>0(INT)</sub>            | Time Base Period, Internal Mode  | 250                                                                                     | 590  | ns   | 4MHz-1.7MHz                             |
|                | t <sub>0(EX)</sub>             | Time Base Period, External Mode  | 250                                                                                     | 2500 | ns   | 4MHz-400kHz                             |
|                | t <sub>EX(H)</sub>             | External Clock Pulse Width, High | 90                                                                                      | 2000 | ns   |                                         |
|                | t <sub>EX(L)</sub>             | External Clock Pulse Width, Low  | 90                                                                                      | 2000 | ns   |                                         |
| $\Phi$         | t <sub><math>\Phi</math></sub> | Internal $\Phi$ Clock Period     | 2t <sub>0</sub>                                                                         | typ. | ns   | 0.5 $\mu\text{s}$ @ 4MHz ext. time base |
| STROBE         | t <sub>I/O-S</sub>             | Port Output to STROBE Delay      | 3t <sub><math>\Phi</math></sub> -1000 min.<br>3t <sub><math>\Phi</math></sub> +250 max. | ns   |      | Note 1                                  |
|                | t <sub>SL</sub>                | STROBE Pulse Width, Low          | 8t <sub><math>\Phi</math></sub> -250 min.<br>12t <sub><math>\Phi</math></sub> +250 max. | ns   |      |                                         |
| RESET          | t <sub>RH</sub>                | RESET Hold Time, Low             | 6t <sub><math>\Phi</math></sub> +750 min.                                               | ns   |      |                                         |
| EXT INT        | t <sub>EH</sub>                | EXT INT Hold Time, Active State  | 6t <sub><math>\Phi</math></sub> +750 min.                                               | ns   |      | Note 2                                  |

- NOTES:
1. Load is 50pF plus 1 standard TTL input.
  2. Specification is applicable when the timer is in the Interval Timer Mode. See "Timer Characteristics" for EXT INT requirements when in the Pulse Width Measurement Mode or the Event Counter Mode.
  3. The AC Timing Diagrams are given in Figure 5.

**CAPACITANCE** $T_A = 25^\circ\text{C}$ ,  $f = 2\text{MHz}$ 

| SYMBOL           | PARAMETER                                    | MIN | MAX | UNIT | TEST CONDITION                  |
|------------------|----------------------------------------------|-----|-----|------|---------------------------------|
| C <sub>IN</sub>  | Input Capacitance: I/O Ports, RESET, EXT INT |     | 7   | pF   | Unmeasured pins returned to GND |
| C <sub>XTL</sub> | Input Capacitance: XTL 1, XTL 2              | 18  | 23  | pF   |                                 |

**TIMER CHARACTERISTICS**

Definitions:

Error = Indicated time value - actual time value

$tpsc = t\Phi \times \text{Prescale Value}$

**Interval Timer Mode:**

|                                                              |                                 |
|--------------------------------------------------------------|---------------------------------|
| Single interval error, free running (Note 3) . . . . .       | $\pm 6t\Phi$                    |
| Cumulative interval error, free running (Note 3) . . . . .   | 0                               |
| Error between two Timer reads (Note 2) . . . . .             | $\pm (tpsc + t\Phi)$            |
| Start Timer to stop Timer error (Notes 1,4) . . . . .        | $+t\Phi$ to $-(tpsc + t\Phi)$   |
| Start Timer to read Timer error (Notes 1,2) . . . . .        | $-5t\Phi$ to $-(tpsc + 7t\Phi)$ |
| Start Timer to interrupt request error (Notes 1,3) . . . . . | $-2t\Phi$ to $-8t\Phi$          |
| Load Timer to stop Timer error (Note 1) . . . . .            | $+t\Phi$ to $-(tpsc + 2t\Phi)$  |
| Load Timer to read Timer error (Notes 1,2) . . . . .         | $-5t\Phi$ to $-(tpsc + 8t\Phi)$ |
| Load Timer to interrupt request error (Notes 1,3) . . . . .  | $-2t\Phi$ to $-9t\Phi$          |

**Pulse Width Measurement Mode:**

|                                              |                                |
|----------------------------------------------|--------------------------------|
| Measurement accuracy (Note 4) . . . . .      | $+t\Phi$ to $-(tpsc + 2t\Phi)$ |
| Minimum pulse width of EXT INT pin . . . . . | $.2t\Phi$                      |

**Event Counter Mode:**

|                                                |           |
|------------------------------------------------|-----------|
| Minimum active time of EXT INT pin . . . . .   | $.2t\Phi$ |
| Minimum inactive time of EXT INT pin . . . . . | $.2t\Phi$ |

**Notes:**

1. All times which entail loading, starting, or stopping the Timer are referenced from the end of the last machine cycle of the OUT or OUTS instruction.
2. All times which entail reading the Timer are referenced from the end of the last machine cycle of the IN or INS instruction.
3. All times which entail the generation of an interrupt request are referenced from the start of the machine cycle in which the appropriate interrupt request latch is set. Additional time may elapse if the interrupt request occurs during a privileged or multicycle instruction.
4. Error may be cumulative if operation is repetitively performed.



Note: All measurements are referenced to  $V_{IL}$  max.,  $V_{IH}$  min.,  $V_{OL}$  max., or  $V_{OH}$  min.

FIGURE 5. AC TIMING DIAGRAMS

## 2.2.2 Electrical Specifications

*Absolute maximum ratings (above which useful life may be impaired)*

|                       |                                                |
|-----------------------|------------------------------------------------|
| $V_{GG}$              | +15V to -0.3V                                  |
| $V_{DD}$              | +7V to -0.3V                                   |
| RC, XTLX and XTYL     | +15V to -0.3V (RC with<br>5KΩ series resistor) |
| All other inputs      | +7V to -0.3V                                   |
| Storage temperature   | -55°C to +150°C                                |
| Operating temperature | 0°C to +70°C                                   |

**Note:** All voltages with respect to  $V_{SS}$ .

*DC Characteristics:*  $V_{SS} = 0V$ ,  $V_{DD} = +5V \pm 5\%$ ,  
 $V_{GG} = +12V \pm 5\%$ ,  $T_A = 0^\circ C$   
to  $+70^\circ C$

## SUPPLY CURRENTS

| SYMBOL   | PARAMETER        | MIN. | Typ. | MAX. | UNITS | TEST CONDITIONS                           |
|----------|------------------|------|------|------|-------|-------------------------------------------|
| $I_{DD}$ | $V_{DD}$ Current |      | 45   | 75   | mA    | $f = 2 \text{ MHz}$ ,<br>Outputs unloaded |
| $I_{GG}$ | $V_{GG}$ Current |      | 12   | 30   | mA    | $f = 2 \text{ MHz}$ ,<br>Outputs unloaded |

Data sheets on pages 2-D6 through 2-D33 reprinted by permission of Fairchild Camera and Instrument Corporation.

| SIGNAL               | SYMBOL                                                               | PARAMETER                                                                                                                            | MIN.                                      | MAX.                                                   | UNITS                                                  | TEST CONDITIONS                                                                                                           |
|----------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| $\Phi$ , WRITE       | $V_{OH}$<br>$V_{OL}$<br>$V_{OH}$                                     | Output High Voltage<br>Output Low Voltage<br>Output High Voltage                                                                     | 4.4<br>$V_{SS}$<br>2.9                    | $V_{DD}$<br>0.4                                        | Volts<br>Volts<br>Volts                                | $I_{OH} = -50 \mu A$<br>$I_{OL} = 1.6 mA$<br>$I_{OH} = -100 \mu A$                                                        |
| XTLY                 | $V_{IH}$<br>$V_{IL}$<br>$I_{IH}$<br>$I_{IL}$                         | Input High Voltage<br>Input Low Voltage<br>Input High Current<br>Input Low Current                                                   | 4.5<br>$V_{SS}$<br>5<br>-10               | $V_{GG}$<br>0.8<br>50<br>-120                          | Volts<br>Volts<br>$\mu A$<br>$\mu A$                   | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$                                                                                    |
| ROMCO<br>⋮<br>ROMC4  | $V_{OH}$<br>$V_{OL}$                                                 | Output High Voltage<br>Output Low Voltage                                                                                            | 3.9<br>$V_{SS}$                           | $V_{DD}$<br>0.4                                        | Volts<br>Volts                                         | $I_{OH} = -100 \mu A$<br>$I_{OL} = 1.6 mA$                                                                                |
| DB0<br>⋮<br>DB7      | $V_{IH}$<br>$V_{IL}$<br>$V_{OH}$<br>$V_{OL}$<br>$I_{IH}$<br>$I_{IL}$ | Input High Voltage<br>Input Low Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Current<br>Input Low Current      | 2.9<br>$V_{SS}$<br>3.9<br>$V_{SS}$        | $V_{DD}$<br>0.8<br>$V_{DD}$<br>0.4<br>3<br>-3          | Volts<br>Volts<br>Volts<br>Volts<br>$\mu A$<br>$\mu A$ | $I_{OH} = -100 \mu A$<br>$I_{OL} = 1.6 mA$<br>$V_{IN} = 7V$ 3-State mode<br>$V_{IN} = V_{SS}$ , 3-State mode              |
| I/O 0<br>⋮<br>I/O 17 | $V_{OH}$<br>$V_{OH}$<br>$V_{OL}$<br>$V_{IH}$<br>$V_{IL}$<br>$I_{IL}$ | Output High Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Voltage (1)<br>Input Low Voltage<br>Input Low Current | 3.9<br>2.9<br>$V_{SS}$<br>2.9<br>$V_{SS}$ | $V_{DD}$<br>$V_{DD}$<br>0.4<br>$V_{DD}$<br>0.8<br>-1.6 | Volts<br>Volts<br>Volts<br>Volts<br>Volts<br>mA        | $I_{OH} = -30 \mu A$<br>$I_{OH} = -150 \mu A$<br>$I_{OL} = 1.6 mA$<br>Internal pull-up to $V_{DD}$<br>$V_{IN} = 0.4V$ (2) |
| EXT RES              | $V_{IH}$<br>$V_{IL}$<br>$I_{IL}$                                     | Input High Voltage<br>Input Low Voltage<br>Input Low Current                                                                         | 3.5<br>$V_{SS}$<br>-0.1                   | $V_{DD}$<br>0.8<br>-1.0                                | Volts<br>Volts<br>mA                                   | Internal pull-up to $V_{DD}$<br>$V_{IN} = V_{SS}$                                                                         |
| INT REQ              | $V_{IH}$<br>$V_{IL}$<br>$I_{IL}$                                     | Input High Voltage<br>Input Low Voltage<br>Input Low Current                                                                         | 3.5<br>$V_{SS}$<br>-0.1                   | $V_{DD}$<br>0.8<br>-1.0                                | Volts<br>Volts<br>mA                                   | Internal pull-up to $V_{DD}$<br>$V_{IN} = V_{SS}$                                                                         |
| ICB                  | $V_{OH}$<br>$V_{OH}$<br>$V_{OL}$                                     | Output High Voltage<br>Output High Voltage<br>Output Low Voltage                                                                     | 3.9<br>2.9<br>$V_{SS}$                    | $V_{DD}$<br>$V_{DD}$<br>0.4                            | Volts<br>Volts<br>Volts                                | $I_{OH} = -10 \mu A$<br>$I_{OH} = -100 \mu A$<br>$I_{OL} = 100 \mu A$                                                     |

(1) Hysteresis input circuit provides additional 0.3V noise immunity while internal pull-up provides TTL compatibility.

(2) Measured while F8 port is outputting a high level.

**Note:**

Positive current is defined as conventional current flowing into the pin referenced.

(3) Guaranteed but not tested.

## 3850 CPU

Table 2-4. A Summary of 3850 CPU Signal AC Characteristics

AC Characteristics:  $V_{SS} = 0V$ ,  $V_{DD} = +5V \pm 5\%$ ,  $V_{GG} = +12V \pm 5\%$ ,  $T_A = 0^\circ C$  to  $+70^\circ C$ 

Symbols in this table are used by all figures in Section 2.

| SYMBOL     | PARAMETER                       | MIN.        | TYP.        | MAX.         | UNITS   | TEST CONDITIONS                     |
|------------|---------------------------------|-------------|-------------|--------------|---------|-------------------------------------|
| $P_x^*$    | External Input Period           | 0.5         |             | 10           | $\mu S$ |                                     |
| $PW_x^*$   | External Pulse Width            | 200         | $P_x-200$   |              | nS      | $t_r, t_f \leq 30 nS$               |
| $tx_1$     | Ext. to $\Phi^-$ to - Delay     |             |             | 250          | nS      | $CL = 100 pF$                       |
| $tx_2$     | Ext. to $\Phi^+$ to + Delay     |             |             | 250          | nS      | $CL = 100 pF$                       |
| $P\Phi$    | $\Phi$ Period                   | 0.5         |             | 10           | $\mu S$ |                                     |
| $PW_1$     | $\Phi$ Pulse Width              | 180         | $P\Phi-180$ |              | nS      | $t_r, t_f = 50 nS; CL = 100 pF$     |
| $td_1$     | $\Phi$ to WRITE + Delay         |             | 150         | 250          | nS      | $CL = 100 pF$                       |
| $td_2$     | $\Phi$ to WRITE - Delay         |             | 150         | 250          | nS      | $CL = 100 pF$                       |
| $PW_2$     | WRITE Pulse Width               | $P\Phi-100$ |             | $P\Phi$      | nS      | $t_r, t_f = 50 nS typ; CL = 100 pF$ |
| $PW_S$     | WRITE Period; Short             |             | 4P $\Phi$   |              |         |                                     |
| $PW_L$     | WRITE Period; Long              |             | 6P $\Phi$   |              |         |                                     |
| $td_3$     | WRITE to ROMC Delay             | 80          | 300         | 550          | nS      | $CL = 100 pF$                       |
| $td_4^*$   | WRITE to $\overline{ICB}$ Delay |             |             | 350          | nS      | $CL = 50 pF$                        |
| $td_5$     | WRITE to INT REQ Delay          |             |             | 430 (2)      | nS      | $CL = 100 pF$                       |
| $t_{sx}^*$ | EXT RES set-up time             | 1.0         |             |              | $\mu S$ | $CL = 20 pF$                        |
| $t_{su}^*$ | I/O set-up time                 | 300         |             |              | nS      |                                     |
| $t_h^*$    | I/O hold time                   | 50          |             |              | nS      |                                     |
| $t_o^*$    | I/O Output Delay                |             |             | 2.5          | $\mu S$ | $CL = 50 pF$                        |
| $tdb_1^*$  | WRITE to Data Bus Stable        |             | 0.6         | 1.3          | $\mu S$ | $CL = 100 pF$                       |
| $tdb_2$    | WRITE to Data Bus Stable        | 2P $\Phi$   |             | $2P\Phi+1.0$ | $\mu S$ | $CL = 100 pF$                       |
| $tdb_3^*$  | Data Bus Set-up                 | 200         |             |              | nS      |                                     |
| $tdb_4^*$  | Data Bus Set-up                 | 500         |             |              | nS      |                                     |
| $tdb_5$    | Data Bus Set-up                 | 500         |             |              | nS      |                                     |
| $tdb_6^*$  | Data Bus Set-up                 | 500         |             |              | nS      |                                     |

\*The parameters which are starred in the table above represent those which are most frequently of importance when interfacing to an F8 system. These encompass I/O timing, external timing generation and possible external RAM timing. The remaining parameters are typically those that are only relevant between F8 chips and not normally of concern to the user.

- (1) Input and output capacitance is 3 to 5 pf typical on all pins except  $V_{DD}$ ,  $V_{GG}$ , and  $V_{SS}$ .
- (2) If INTREQ is being supplied asynchronously, it can be pulled down at any time except during a fetch cycle that has been preceded by a non-privileged instruction. In that case INTREQ must go down according to the requirements of  $td_5$ .



Figure 2-8. Timing Signal Specifications



SYMBOLS ARE DEFINED BY TABLE 2-4  
Figure 2-9. ROMC Signals Output by 3850 CPU

### 3850 CPU



Symbols are defined in Table 2-4

Figure 2-10A. A Short Cycle Instruction Fetch



Symbols are defined in Table 2-4

Figure 2-10B. A Long Cycle Instruction Fetch (During DS Only)



1. Timing for CPU outputting data onto the data bus.

Delay tdb<sub>1</sub> is the delay when data is coming from the accumulator.

Delay tdb<sub>2</sub> is the delay when data is coming from the scratchpad (or from a memory device).

Delay tdb<sub>0</sub> is the delay for the CPU to stop driving the data bus.

2. There are four possible cases when inputting data to the CPU, via the data bus lines: they depend on the data path and the destination in the CPU, as follows:

tdb<sub>3</sub>; Destination – IR (instruction Fetch) – See Figure 2-10 for details.

tdb<sub>4</sub>; Destination – Accumulator (with ALU operation – AM)

tdb<sub>5</sub>; Destination – Scratchpad (LR K,P etc.)

tdb<sub>6</sub>; Destination – Accumulator (no ALU operation – LM)

In each case a stable data hold time of 50 nS from the WRITE reference point is required.

Symbols are defined in Table 2-4

*Figure 2-11. Memory Reference Timing*



- (1) This represents the timing for data at the I/O pin during the execution of the INS instruction, i.e., the CPU is inputting.
- (2) This represents the timing for data being output by the CPU at the I/O pin.

Symbols are defined in Table 2-4

Figure 2-13. Timing for Data Input or Output at I/O Port Pins



- (1)  $\overline{ICB}$  will go from a 1 to a 0 following the execution of the EI instruction and will go from a 0 to 1 following either the execution of the DI instruction or the CPU's acknowledgement of an interrupt.
- (2) This is an input to the CPU chip and is generated by a PSU or 3853 MI chip. The open drain outputs of these chips are all wire "ANDed" together on this line with the pull-up being located on the CPU chip. For a 0 to 1 transition the delay is measured to 2.0V.

Symbols are defined in Table 2-4

Figure 2-14. Interrupt Signals Timing

**3851 PSU****3.2.5 Electrical Specifications**

*Absolute Maximum Ratings (Above which useful life may be impaired)*

|                            |                    |
|----------------------------|--------------------|
| V <sub>GG</sub>            | +15V to -0.3V      |
| V <sub>DD</sub>            | +7V to -0.3V       |
| I/O Port Open Drain Option | +15V to -0.3V      |
| External Interrupt Input   | -600 µA to +225 µA |
| All other inputs & outputs | +7V to -0.3V       |
| Storage Temperature        | -55°C to +150°C    |
| Operating Temperature      | 0°C to +70°C       |

**Note:** All voltages with respect to V<sub>SS</sub>.

*DC Characteristics:* V<sub>SS</sub> = 0V, V<sub>DD</sub> = +5V ± 5%,  
 V<sub>GG</sub> = +12V ± 5%,  
 TA = 0°C to +70°C

**SUPPLY CURRENTS**

| SYMBOL          | PARAMETER               | MIN. | TYP. | MAX. | UNITS | TEST CONDITIONS                   |
|-----------------|-------------------------|------|------|------|-------|-----------------------------------|
| I <sub>DD</sub> | V <sub>DD</sub> Current |      | 28   | 60   | mA    | f = 2 MHz,<br>Outputs<br>Unloaded |
| I <sub>GG</sub> | V <sub>GG</sub> Current |      | 10   | 30   | mA    | f = 2 MHz,<br>Outputs<br>Unloaded |

## 3851 PSU

Table 3-2. A Summary of 3851 PSU Signal Characteristics

| SIGNAL                                              | SYMBOL                                                                                                                           | PARAMETER                                                                                                                                           | MIN.                                                          | MAX.                                                                             | UNITS                                                                                                                           | TEST CONDITIONS                                                                                                                                                                                           |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA BUS (DB0-DB7)                                  | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>IH</sub><br>I <sub>OL</sub>                   | Input High Voltage<br>Input Low Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Current<br>Input Low Current                     | 2.9<br>V <sub>SS</sub><br>3.9<br>V <sub>SS</sub>              | V <sub>DD</sub><br>0.8<br>V <sub>DD</sub><br>0.4<br>1<br>-1                      | Volts<br>Volts<br>Volts<br>Volts<br>$\mu$ A<br>$\mu$ A                                                                          | I <sub>OH</sub> = -100 $\mu$ A<br>I <sub>OL</sub> = 1.6 mA<br>V <sub>IN</sub> = V <sub>DD</sub> , 3-State mode<br>V <sub>IN</sub> = V <sub>SS</sub> , 3-State mode                                        |
| CLOCK LINES ( $\phi$ , WRITE)                       | V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub>                                                                             | Input High Voltage<br>Input Low Voltage<br>Leakage Current                                                                                          | 4.0<br>V <sub>SS</sub>                                        | V <sub>DD</sub><br>0.8<br>3                                                      | Volts<br>Volts<br>$\mu$ A                                                                                                       | V <sub>IN</sub> = V <sub>DD</sub>                                                                                                                                                                         |
| PRIORITY IN AND CONTROL LINES (PRI IN, ROMC0-ROMC4) | V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub>                                                                             | Input High Voltage<br>Input Low Voltage<br>Leakage Current                                                                                          | 3.5<br>V <sub>SS</sub>                                        | V <sub>DD</sub><br>0.8<br>3                                                      | Volts<br>Volts<br>$\mu$ A                                                                                                       | V <sub>IN</sub> = V <sub>DD</sub>                                                                                                                                                                         |
| PRIORITY OUT (PRI OUT)                              | V <sub>OH</sub><br>V <sub>OL</sub>                                                                                               | Output High Voltage<br>Output Low Voltage                                                                                                           | 3.9<br>V <sub>SS</sub>                                        | V <sub>DD</sub><br>0.4                                                           | Volts<br>Volts                                                                                                                  | I <sub>OH</sub> = -100 $\mu$ A<br>I <sub>OL</sub> = 100 $\mu$ A                                                                                                                                           |
| INTERRUPT REQUEST (INT REQ)                         | V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>L</sub>                                                                             | Output High Voltage<br>Output Low Voltage<br>Leakage Current                                                                                        | V <sub>SS</sub>                                               | 0.4<br>3                                                                         | Volts<br>Volts<br>$\mu$ A                                                                                                       | Open Drain Output [1]<br>I <sub>OL</sub> = 1 mA<br>V <sub>IN</sub> = V <sub>DD</sub>                                                                                                                      |
| DATA BUS DRIVE (DBDR)                               | V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>L</sub>                                                                             | Output High Voltage<br>Output Low Voltage<br>Leakage Current                                                                                        | V <sub>SS</sub>                                               | 0.4<br>3                                                                         | Volts<br>$\mu$ A                                                                                                                | External Pull-up<br>I <sub>OL</sub> = 2 mA<br>V <sub>IN</sub> = V <sub>DD</sub>                                                                                                                           |
| EXTERNAL INTERRUPT (EXT INT)                        | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IC</sub><br>I <sub>IH</sub><br>I <sub>IL</sub><br>I <sub>IL</sub>                   | Input High Voltage<br>Input Low Voltage<br>Input Clamp Voltage<br>Input High Current<br>Input Low Current<br>Input Low Current                      | 3.5<br>0.8<br>15<br>10<br>-225<br>-500                        | Volts<br>Volts<br>Volts<br>$\mu$ A<br>$\mu$ A<br>$\mu$ A                         | I <sub>IH</sub> = 185 $\mu$ A<br>V <sub>IN</sub> = V <sub>DD</sub><br>V <sub>IN</sub> = 2V<br>V <sub>IN</sub> = V <sub>SS</sub> |                                                                                                                                                                                                           |
| I/O PORT OPTION A (STANDARD PULL-UP)                | V <sub>OH</sub><br>V <sub>OH</sub><br>V <sub>OL</sub><br>V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub><br>I <sub>IL</sub> | Output High Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Voltage<br>Input Low Voltage<br>Leakage Current<br>Input Low Current | 3.9(5)<br>2.9<br>V <sub>SS</sub><br>2.9(3)<br>V <sub>SS</sub> | V <sub>DD</sub><br>V <sub>DD</sub><br>0.4<br>V <sub>DD</sub><br>0.8<br>1<br>-1.6 | Volts<br>Volts<br>Volts<br>Volts<br>Volts<br>$\mu$ A<br>mA                                                                      | I <sub>OH</sub> = -30 $\mu$ A<br>I <sub>OH</sub> = -150 $\mu$ A<br>I <sub>OL</sub> = 1.6 mA<br>Internal Pull-up to V <sub>DD</sub> [3]<br>V <sub>IN</sub> = V <sub>DD</sub><br>V <sub>IN</sub> = 0.4V [4] |
| I/O PORT OPTION B (OPEN DRAIN)                      | V <sub>OH</sub><br>V <sub>OL</sub><br>V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>IL</sub>                                      | Output High Voltage<br>Output Low Voltage<br>Input High Voltage<br>Input Low Voltage<br>Leakage Current                                             | V <sub>SS</sub><br>2.9(3)<br>V <sub>SS</sub>                  | 0.4<br>V <sub>DD</sub><br>0.8<br>2                                               | Volts<br>Volts<br>Volts<br>$\mu$ A                                                                                              | External Pull-up<br>I <sub>OL</sub> = 2 mA<br>[3]<br>V <sub>IN</sub> = + 12V                                                                                                                              |

**3851 PSU***Table 3-2. A Summary of 3851 PSU Signal Characteristics (Continued)*

| SIGNAL                             | SYMBOL                             | PARAMETER                                 | MIN.                    | MAX.                   | UNITS          | TEST CONDITIONS                                     |
|------------------------------------|------------------------------------|-------------------------------------------|-------------------------|------------------------|----------------|-----------------------------------------------------|
| I/O PORT OPTION C (DRIVER PULL-UP) | V <sub>OH</sub><br>V <sub>OL</sub> | Output High Voltage<br>Output Low Voltage | 3.75<br>V <sub>SS</sub> | V <sub>DD</sub><br>0.4 | Volts<br>Volts | I <sub>OH</sub> = -1 mA<br>I <sub>OL</sub> = 1.6 mA |

**Notes:**

1. Pull-up resistor to V<sub>DD</sub> on CPU.
2. Positive current is defined as conventional current flowing into the pin referenced.
3. Hysteresis input circuit provides additional 0.3V noise immunity while internal/external pull-up provides TTL compatibility.
4. Measured while I/O port is outputting a high level.
5. Guaranteed but not tested.

*Table 3-3. A Summary of 3851 PSU Signal AC Characteristics*

AC Characteristics: V<sub>SS</sub> = 0V, V<sub>DD</sub> = +5V ± 5%, V<sub>GG</sub> = +12V ± 5%, T<sub>A</sub> = 0°C to +70°C

Symbols in this table are used by all figures in Section 3.

| SYMBOL           | PARAMETER                 | MIN.                                    | TYP.                  | MAX.                                    | UNITS | TEST CONDITIONS                                           |
|------------------|---------------------------|-----------------------------------------|-----------------------|-----------------------------------------|-------|-----------------------------------------------------------|
| P <sub>φ</sub>   | φ Period                  | 0.5                                     |                       | 10                                      | μS    |                                                           |
| PW <sub>1</sub>  | φ Pulse Width             | 180                                     |                       | P <sub>φ</sub> -180                     | nS    | t <sub>r</sub> , t <sub>f</sub> = 50 nS typ.              |
| td <sub>1</sub>  | φ to WRITE + Delay        |                                         |                       | 250                                     | nS    | C <sub>L</sub> = 100 pf                                   |
| td <sub>2</sub>  | φ to WRITE-Delay          |                                         |                       | 250                                     | nS    | C <sub>L</sub> = 100 pf                                   |
| td <sub>4</sub>  | WRITE to DB Input Delay   |                                         |                       | 2P <sub>φ</sub> + 1.0                   | μS    |                                                           |
| PW <sub>2</sub>  | WRITE Pulse Width         | P <sub>φ</sub> -100                     |                       | P <sub>φ</sub>                          | nS    | t <sub>r</sub> , t <sub>f</sub> = 50 nS typ.              |
| PW <sub>S</sub>  | WRITE Period; Short       |                                         | 4P <sub>φ</sub>       |                                         |       |                                                           |
| PWL              | WRITE Period; Long        |                                         | 6P <sub>φ</sub>       |                                         |       |                                                           |
| td <sub>3</sub>  | WRITE to ROMC Delay       |                                         |                       | 550                                     | nS    |                                                           |
| td <sub>7</sub>  | WRITE to DB Output Delay  | 2P <sub>φ</sub> + 100 - td <sub>2</sub> | 2P <sub>φ</sub> + 200 | 2P <sub>φ</sub> + 850 - td <sub>2</sub> | nS    | C <sub>L</sub> = 100 pf                                   |
| td <sub>8</sub>  | WRITE to DBDR—Delay       |                                         | 200                   |                                         | nS    | Open Drain                                                |
| tr <sub>1</sub>  | WRITE to DBDR + Delay     |                                         |                       | 430                                     | nS    | C <sub>L</sub> = 100 pf [1]                               |
| tr <sub>2</sub>  | WRITE to INT REQ—Delay    |                                         |                       | 430                                     | nS    | C <sub>L</sub> = 100 pf [3]                               |
| tp <sub>1</sub>  | PRI IN to INT REQ + Delay |                                         | 200                   |                                         | nS    | C <sub>L</sub> = 100 pf [2]                               |
| tpd <sub>1</sub> | PRI IN to PRI OUT—Delay   |                                         |                       | 300                                     | nS    | C <sub>L</sub> = 50 pf                                    |
| tpd <sub>2</sub> | PRI IN to PRI OUT + Delay |                                         |                       | 300                                     | nS    | C <sub>L</sub> = 50 pf                                    |
| tpd <sub>3</sub> | WRITE to PRI OUT + Delay  |                                         |                       | 600                                     | nS    | C <sub>L</sub> = 50 pf                                    |
| tpd <sub>4</sub> | WRITE to PRI OUT — Delay  |                                         |                       | 600                                     | nS    | C <sub>L</sub> = 50 pf                                    |
| t <sub>sp</sub>  | WRITE to Output Stable    |                                         |                       | 1.0 (3)                                 | μS    | C <sub>L</sub> = 50 pf, Standard Pull-up                  |
| td <sub>9</sub>  | WRITE to Output Stable    |                                         |                       | 1.0 (3)                                 | μS    | C <sub>L</sub> = 50 pf,                                   |
| td <sub>p</sub>  | WRITE to Output Stable    |                                         | 200                   | 400                                     | nS    | R <sub>L</sub> = 12.5 KΩ to V <sub>DD</sub> plus TTL load |
| t <sub>su</sub>  | I/O Setup Time            | 1.3                                     |                       |                                         | μS    | C <sub>L</sub> = 50 pf, Driver Pull-up                    |
| t <sub>h</sub>   | I/O Hold Time             | 0                                       |                       |                                         | nS    |                                                           |
| t <sub>ext</sub> | EXT INT Setup Time        | 400                                     |                       |                                         | nS    |                                                           |

**Notes:**

1. Assume Priority In was enabled (PRI IN = 0) in previous F8 cycle before interrupt is detected in the PSU.
2. PSU has interrupt pending before priority in is enabled.
3. Assume pin tied to INT REQ input of the 3850 CPU.
4. The parameters which are shaded in the table above represent those which are most frequently of importance when interfacing to an F8 system. Unshaded parameters are typically those that are relevant only between F8 chips and not normally of concern to the user.
5. Input and output capacitance is 3 to 5 pf typical on all pins except V<sub>DD</sub>, V<sub>GG</sub>, and V<sub>SS</sub>.

## 3851 PSU



SYMBOLS ARE DEFINED IN TABLE 3-3

Figure 3-3. 3851 PSU Data Bus Timing



SYMBOLS ARE DEFINED IN TABLE 3-3

1. The set-up and hold times specified are with respect to the end of the second long cycle during execution of the three-cycle IN or INS instruction.
2. All delay times are specified with respect to the end of the second long cycle during execution of the three cycle OUT or OUTS instruction.

Figure 3-7. Timing at PSU I/O Ports

## 3851 PSU

© ADAM OSBORNE & ASSOCIATES, INCORPORATED



NOTE: TIMING MEASUREMENTS ARE MADE AT VALID LOGIC LEVEL OF THE SIGNALS  
REFERENCED UNLESS OTHERWISE NOTED.

SYMBOLS ARE DEFINED IN TABLE 3-3

Figure 3-13. Interrupt Logic Signals' Timing

## 3852 DMI

Table 4-2. Summary of 3852 DMI Signal Characteristics

| SIGNAL                                              | SYMBOL                                                                                                         | PARAMETER                                                                                                                               | MIN.                                                                   | MAX.                                                         | UNITS                                        | TEST CONDITIONS                                                                                                                                               |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA BUS<br>(DB0-DB7)                               | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>IH</sub><br>I <sub>IL</sub> | Input High Voltage<br>Input Low Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Current<br>Input Low Current         | 2.9<br>V <sub>SS</sub><br>3.9<br>V <sub>SS</sub><br>3<br>-3            | V <sub>DD</sub><br>0.8<br>V <sub>DD</sub><br>0.4<br>μA<br>μA | Volts<br>Volts<br>Volts<br>Volts<br>μA<br>μA | I <sub>OH</sub> = -100 μA<br>I <sub>OL</sub> = 1.6 mA<br>V <sub>IN</sub> = V <sub>DD</sub> , 3-State mode<br>V <sub>IN</sub> = V <sub>SS</sub> , 3-State mode |
| ADDRESS LINES<br>(ADDR0-ADDR15)<br>AND<br>RAM WRITE | V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>L</sub><br>I <sub>L</sub>                                         | Output High Voltage<br>Output Low Voltage<br>Leakage Current<br>Leakage Current                                                         | 4.0<br>V <sub>SS</sub><br>3<br>-3                                      | V <sub>DD</sub><br>0.4<br>μA<br>μA                           | Volts<br>Volts<br>μA<br>μA                   | I <sub>OH</sub> = -1 mA<br>I <sub>OL</sub> = 3.2 mA<br>V <sub>IN</sub> = V <sub>DD</sub> , 3-State mode<br>V <sub>IN</sub> = V <sub>SS</sub> , 3-State mode   |
| CLOCK<br>(Φ, WRITE)                                 | V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub>                                                           | Input High Voltage<br>Input Low Voltage<br>Leakage Current                                                                              | 4.0<br>V <sub>SS</sub><br>3                                            | V <sub>DD</sub><br>0.8<br>μA                                 | Volts<br>Volts<br>μA                         | V <sub>IN</sub> = V <sub>DD</sub>                                                                                                                             |
| MEMIDDLE,<br>CYCLE REQ,<br>CPU READ                 | V <sub>OH</sub><br>V <sub>OL</sub>                                                                             | Output High Voltage<br>Output Low Voltage                                                                                               | 3.9<br>V <sub>SS</sub>                                                 | V <sub>DD</sub><br>0.4                                       | Volts<br>Volts                               | I <sub>OH</sub> = -1 mA<br>I <sub>OL</sub> = 2 mA                                                                                                             |
| CONTROL LINES<br>(ROMC0-ROMC4)                      | V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub>                                                           | Input High Voltage<br>Input Low Voltage<br>Leakage Current                                                                              | 3.5<br>V <sub>SS</sub>                                                 | V <sub>DD</sub><br>0.8<br>3                                  | Volts<br>Volts<br>μA                         | V <sub>IN</sub> = 6V                                                                                                                                          |
| REGDR,<br>CPU SLOT                                  | V <sub>OH</sub><br>V <sub>OL</sub><br>V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>IL</sub><br>I <sub>L</sub>  | Output High Voltage<br>Output Low Voltage<br>Input High Voltage<br>Input Low Voltage<br>Input Low Current<br>(REGDR)<br>Leakage Current | 3.9<br>V <sub>SS</sub><br>3.5<br>V <sub>SS</sub><br>-3.5<br>-14.0<br>3 | V <sub>DD</sub><br>0.4<br>V <sub>DD</sub><br>0.8<br>mA<br>μA | Volts<br>Volts<br>Volts<br>Volts<br>mA<br>μA | I <sub>OH</sub> = -300 μA<br>I <sub>OL</sub> = 2 mA<br>Internal Pull-up<br>V <sub>IN</sub> = 0.4V & Device<br>outputting a logic "1"<br>V <sub>IN</sub> = 6V  |

## 3852 DMI

Table 4-3. 3852 DMI Output Signals Timing Summary

| SYMBOL           | PARAMETER                                          | MIN.                           | TYP.      | MAX.                           | UNITS   | NOTES    |
|------------------|----------------------------------------------------|--------------------------------|-----------|--------------------------------|---------|----------|
| P $\Phi$         | $\Phi$ clock period                                | 0.5                            |           | 10                             | $\mu$ S | Fig. 2-9 |
| td <sub>2</sub>  | $\Phi$ to WRITE - Delay                            |                                |           | 250                            | nS      |          |
| tad <sub>1</sub> | Address delay if PC0                               | 50                             | 300       | 500                            | nS      | 3        |
| tad <sub>2</sub> | Address delay to high Z (short cycle with DMA on)  | tcs <sub>2</sub> +50           |           | tcs <sub>2</sub> +200          | nS      | 3        |
| tad <sub>3</sub> | Address delay to refresh (short cycle with REF on) | tcs <sub>2</sub> +50           |           | tcs <sub>2</sub> +400          | nS      | 3        |
| tad <sub>4</sub> | Address delay if DC                                | 2P $\Phi$ +50-td <sub>2</sub>  |           | 2P $\Phi$ +400-td <sub>2</sub> | nS      | 3        |
| tad <sub>5</sub> | Address delay to high Z (long cycle with DMA on)   | tcs <sub>3</sub> +50           |           | tcs <sub>3</sub> +200          | nS      | 3        |
| tad <sub>6</sub> | Address delay to refresh (long cycle with REF on)  | tcs <sub>3</sub> +50           |           | tcs <sub>3</sub> +400          | nS      | 3        |
| tcr <sub>1</sub> | CPU READ - Delay                                   | 50                             | 250       | 450                            | nS      | 1        |
| tcr <sub>2</sub> | CPU READ + Delay                                   | 2P $\Phi$ +50-td <sub>2</sub>  |           | 2P $\Phi$ +400-td <sub>2</sub> | nS      | 1        |
| tcs <sub>1</sub> | CPU SLOT + Delay                                   | 80-td <sub>2</sub>             |           | 320-td <sub>2</sub>            | nS      | 1        |
| tcs <sub>2</sub> | CPU SLOT - Delay (PC0 access)                      | 2P $\Phi$ +60-td <sub>2</sub>  |           | 2P $\Phi$ +420-td <sub>2</sub> | nS      | 1        |
| tcs <sub>3</sub> | CPU SLOT - Delay (DC access)                       | 4P $\Phi$ +60-td <sub>2</sub>  |           | 2P $\Phi$ +420-td <sub>2</sub> | nS      | 1        |
| tm <sub>1</sub>  | MEMIDLE + Delay (PC0 access)                       | 2P $\Phi$ +50-td <sub>2</sub>  |           | 4P $\Phi$ +400-td <sub>2</sub> | nS      | 1        |
| tm <sub>2</sub>  | MEMIDLE - Delay (PC0 access)                       | 4P $\Phi$ +50-td <sub>2</sub>  |           | 4P $\Phi$ +350-td <sub>2</sub> | nS      | 1        |
| tm <sub>3</sub>  | MEMIDLE + Delay (DC access)                        | 4P $\Phi$ +50-td <sub>2</sub>  |           | 4P $\Phi$ +400-td <sub>2</sub> | nS      | 1        |
| tm <sub>4</sub>  | MEMIDLE - Delay (DC access)                        | 6P $\Phi$ +50-td <sub>2</sub>  |           | 6P $\Phi$ +350-td <sub>2</sub> | nS      | 1        |
| tcy <sub>1</sub> | WRITE to CYCLE REQ - Delay                         | 80-td <sub>2</sub>             |           | 400-td <sub>2</sub>            | nS      | 1, 4     |
| tcy <sub>2</sub> | WRITE to CYCLE REQ + Delay                         | P $\Phi$ +80-td <sub>2</sub>   |           | P $\Phi$ +400-td <sub>2</sub>  | nS      | 1, 4     |
| tcy <sub>3</sub> | CYCLE REQ + to + Edge Delay                        |                                | 2P $\Phi$ |                                |         | 1, 4     |
| tcy <sub>4</sub> | CYCLE REQ - to - Edge Delay                        |                                | 2P $\Phi$ |                                |         | 1, 4     |
| twr <sub>1</sub> | RAM WRITE - Delay                                  | 4P $\Phi$ +50-td <sub>2</sub>  |           | 4P $\Phi$ +450-td <sub>2</sub> | nS      | 3        |
| twr <sub>2</sub> | RAM WRITE + Delay                                  | 5P $\Phi$ +50-td <sub>2</sub>  |           | 5P $\Phi$ +300-td <sub>2</sub> | nS      | 3        |
| twr <sub>3</sub> | RAM WRITE Pulse Width                              | 350                            |           | P $\Phi$                       | nS      | 3        |
| twr <sub>4</sub> | RAM WRITE to High Z Delay                          | tcs <sub>2</sub> +40           |           | tcs <sub>2</sub> +200          | nS      | 3        |
| trg <sub>1</sub> | REGDR - Delay                                      | 70                             | 300       | 500                            | nS      | 1        |
| trg <sub>2</sub> | REGDR + Delay                                      | 2P $\Phi$ +80-td <sub>2</sub>  |           | 2P $\Phi$ +500-td <sub>2</sub> | nS      | 1        |
| td <sub>4</sub>  | WRITE to Data Bus Input Delay                      |                                |           | 2P $\Phi$ +1000                | nS      |          |
| td <sub>7</sub>  | WRITE to Data Bus Output Delay                     | 2P $\Phi$ +100-td <sub>2</sub> |           | 2P $\Phi$ +850-td <sub>2</sub> | nS      | 2        |

## Notes:

1. C<sub>L</sub> = 50 pf.
2. C<sub>L</sub> = 100 pf.
3. C<sub>L</sub> = 500 pf.
4. CYCLE REQ is a divide-by-2 of  $\Phi$  for all instructions except the STORE instruction.
5. On a given chip, the timing for all signals will tend to track. For example, if CPU SLOT for a particular chip is fairly slow and its timing falls out near the MAX delay value specified, then the timing for all signals on that chip will tend to be out near the MAX delay values. Likewise for a fast chip whose signals fall near the MIN values. This is a result of the fact that processing parameters (which affect device speed) are quite uniform over small physical areas on the surface of a wafer.
6. Input and output capacitance is 3 to 5 pf typical on all pins except V<sub>DD</sub>, V<sub>GG</sub>, and V<sub>SS</sub>.

## 3852 DMI



Figure 4-4. Timing Characteristics for 3852 DMI Output Signals

**3852 DMI/3853 SMI****4.2.2 DC Electrical Specifications**

*Absolute Maximum Ratings* (Above which useful life may be impaired).

|                            |                 |
|----------------------------|-----------------|
| V <sub>GG</sub>            | +15V to -0.3V   |
| V <sub>DD</sub>            | +7V to -0.3V    |
| All other inputs & outputs | +7V to -0.3V    |
| Storage Temperature        | -55°C to +150°C |
| Operating Temperature      | 0°C to +70°C    |

Note: All voltages with respect to V<sub>SS</sub>.

*DC Characteristics:* V<sub>SS</sub> = 0V, V<sub>DD</sub> = +5V ± 5%,  
V<sub>GG</sub> = +12V ± 5%,  
T<sub>A</sub> = 0°C to +70°C

**SUPPLY CURRENTS**

| SYMBOL          | PARAMETER               | MIN. | TYP. | MAX. | UNITS | TEST CONDITIONS                |
|-----------------|-------------------------|------|------|------|-------|--------------------------------|
| I <sub>DD</sub> | V <sub>DD</sub> Current |      | 35   | 70   | mA    | f = 2 MHz,<br>Outputs unloaded |
| I <sub>GG</sub> | V <sub>GG</sub> Current |      | 13   | 30   | mA    | f = 2 MHz,<br>Outputs unloaded |

Table 5-2. 3853 SMI Output Signals Timing Summary

| SYMBOL           | PARAMETER                 | MIN.                    | TYP. | MAX.                    | UNITS | NOTES    |
|------------------|---------------------------|-------------------------|------|-------------------------|-------|----------|
| PΦ               | Φ clock period            | 0.5                     |      | 10                      | μS    | Fig. 2-9 |
| td <sub>2</sub>  | Φ to WRITE - Delay        |                         |      | 250                     | nS    | 2        |
| tad <sub>1</sub> | Address delay if PC0      | 50                      | 300  | 500                     | nS    | 3        |
| tad <sub>4</sub> | Address delay if DCO      | 2PΦ+50-td <sub>2</sub>  |      | 2PΦ+400-td <sub>2</sub> | nS    | 3        |
| tcr <sub>1</sub> | CPU READ - Delay          | 50                      | 250  | 450                     | nS    | 1        |
| tcr <sub>2</sub> | CPU READ + Delay          | 2PΦ+50-td <sub>2</sub>  |      | 2PΦ+400-td <sub>2</sub> | nS    | 1        |
| twr <sub>1</sub> | RAM WRITE - Delay         | 4PΦ+50-td <sub>2</sub>  |      | 4PΦ+450-td <sub>2</sub> | nS    | 3        |
| twr <sub>2</sub> | RAM WRITE + Delay         | 5PΦ+50-td <sub>2</sub>  |      | 5PΦ+300-td <sub>2</sub> | nS    | 3        |
| twr <sub>3</sub> | RAM WRITE Pulse           | 350                     |      | PΦ                      | nS    | 3        |
| trg <sub>1</sub> | REGDR - Delay             | 70                      | 300  | 500                     | nS    | 1        |
| trg <sub>2</sub> | REGDR + Delay             | 2PΦ+80-td <sub>2</sub>  |      | 2PΦ+500-td <sub>2</sub> | nS    | 1        |
| td <sub>4</sub>  | WRITE to Data Bus         |                         |      | 2PΦ+1000                | nS    |          |
|                  | Input Delay               |                         |      |                         |       |          |
| td <sub>7</sub>  | WRITE to Data Bus         | 2PΦ+100-td <sub>2</sub> |      | 2PΦ+850-td <sub>2</sub> | nS    | 2        |
|                  | Output Delay              |                         |      |                         |       |          |
| tr <sub>1</sub>  | WRITE to INT REQ - Delay  |                         |      | 430                     | nS    | 2, 6     |
| tpr <sub>1</sub> | PRI IN to INT REQ - Delay |                         | 200  | 240                     | nS    | 2, 7     |
| t <sub>ex</sub>  | EXT INT Set-up Time       | 400                     |      |                         | nS    |          |

**Notes:**

1. C<sub>L</sub> = 50 pf.
2. C<sub>L</sub> = 100 pf.
3. C<sub>L</sub> = 500 pf.
4. On a given chip, the timing for all signals will tend to track. For example, if CPU SLOT for a particular chip is fairly slow and its timing falls out near the MAX delay value specified, then the timing for all signals on that chip will tend to be out near the MAX delay values. Likewise for a fast chip whose signals fall out near the MIN values. This is a result of the fact that processing parameters (which affect device speed) are quite uniform.
5. Input and output capacitance is 3 to 5 pf typical on all pins except V<sub>DD</sub>, V<sub>GG</sub>, and V<sub>SS</sub>.
6. Assume Priority In was enabled (PRI IN = 0) in previous F8 cycle before interrupt is detected in the PSU.
7. PSU has interrupt pending before priority in is enabled.

## 3853 SMI



Figure 5-4. 3853 Signal Timing

**3854 DMA***Table 6-3. Summary of 3854 DMA Signal Characteristics***ELECTRICAL SPECIFICATIONS***Absolute Maximum Ratings (Above which useful life may be impaired)*

|                            |                 |
|----------------------------|-----------------|
| $V_{GG}$                   | +15V to -0.3V   |
| $V_{DD}$                   | +7V to -0.3V    |
| All other Inputs & Outputs | +7V to -0.3V    |
| Storage Temperature        | -55°C to +150°C |
| Operating Temperature      | 0°C to +70°C    |

Note: All voltages with respect to  $V_{SS}$ .DC CHARACTERISTICS:  $V_{SS} = 0V$ ,  $V_{DD} = +5V \pm 5\%$ ,  $V_{GG} = +12V \pm 5\%$ ,  $T_A = 0$  to  $+70^\circ C$ **SUPPLY CURRENTS**

| SYMBOL   | PARAMETER        | MIN. | TYP. | MAX. | UNITS | TEST CONDITIONS               |
|----------|------------------|------|------|------|-------|-------------------------------|
| $I_{DD}$ | $V_{DD}$ Current |      | 20   | 40   | mA    | $f = 2$ MHz, Outputs Unloaded |
| $I_{GG}$ | $V_{GG}$ Current |      | 15   | 28   | mA    | $f = 2$ MHz, Outputs Unloaded |

| SIGNAL                                                        | SYMBOL   | PARAMETER           | MIN.     | MAX.     | UNITS   | TEST CONDITIONS                                           |
|---------------------------------------------------------------|----------|---------------------|----------|----------|---------|-----------------------------------------------------------|
| DATA BUS (DB0-DB7)                                            | $V_{IH}$ | Input High Voltage  | 3.5      | $V_{DD}$ | Volts   |                                                           |
|                                                               | $V_{IL}$ | Input Low Voltage   | $V_{SS}$ | 0.8      | Volts   |                                                           |
|                                                               | $V_{OH}$ | Output High Voltage | 3.9      | $V_{DD}$ | Volts   |                                                           |
|                                                               | $V_{OL}$ | Output Low Voltage  | $V_{SS}$ | 0.4      | Volts   |                                                           |
|                                                               | $I_{IH}$ | Input High Current  |          | 1        | $\mu A$ | $I_{OH} = -100 \mu A$                                     |
|                                                               | $I_{IL}$ | Input Low Current   |          | -1       | $\mu A$ | $I_{OL} = 1.6 \text{ mA}$<br>$V_{IN} = 6V$ , 3-State mode |
| ADDRESS LINES<br>(ADDR0-ADDR15)                               | $V_{OH}$ | Output High Voltage | 4.0      | $V_{DD}$ | Volts   | $V_{IN} = V_{SS}$ , 3-State mode                          |
|                                                               | $V_{OL}$ | Output Low Voltage  | $V_{SS}$ | 0.4      | Volts   | $I_{OH} = -1 \text{ mA}$                                  |
|                                                               | $I_L$    | Leakage Current     |          | 1        | $\mu A$ | $I_{OL} = 3.2 \text{ mA}$<br>$V_{IN} = 6V$ , 3-State mode |
| ENABLE, DIRECTION<br>DWS (DMA WRITE<br>SLOT), XFER,<br>STROBE | $V_{OH}$ | Output High Voltage | 3.9      | $V_{DD}$ | Volts   | $I_{OH} = -100 \mu A$                                     |
|                                                               | $V_{OL}$ | Output Low Voltage  | $V_{SS}$ | 0.4      | Volts   | $I_{OL} = 2 \text{ mA}$                                   |
|                                                               | $I_L$    | Leakage Current     |          | 1        | $\mu A$ | $V_{IN} = 6V$                                             |

| SIGNAL                        | SYMBOL   | PARAMETER          | MIN.     | MAX.     | UNITS   | TEST CONDITIONS |
|-------------------------------|----------|--------------------|----------|----------|---------|-----------------|
| MEM IDLE, XFER REQ            | $V_{IH}$ | Input High Voltage | 3.5      | $V_{DD}$ | Volts   |                 |
|                               | $V_{IL}$ | Input Low Voltage  | $V_{SS}$ | 0.8      | Volts   |                 |
|                               | $I_L$    | Leakage Current    |          | 1        | $\mu A$ | $V_{IN} = 6V$   |
| LOAD REG, READ<br>REG, P1, P2 | $V_{IH}$ | Input High Voltage | 3.5      | $V_{DD}$ | Volts   |                 |
|                               | $V_{IL}$ | Input Low Voltage  | $V_{SS}$ | 0.8      | Volts   |                 |
|                               | $I_L$    | Leakage Current    | 0        | 1        | $\mu A$ | $V_{IN} = 6V$   |
| WRITE, $\Phi$                 | $V_{IH}$ | Input High Voltage | 4.0      | $V_{DD}$ | Volts   |                 |
|                               | $V_{IL}$ | Input Low Voltage  | $V_{SS}$ | 0.8      | Volts   |                 |
|                               | $I_L$    | Leakage Current    | 0        | 1        | $\mu A$ | $V_{IN} = 6V$   |

Note:

Positive current is defined as conventional current flowing into the pin referenced.

## 3854 DMA

Table 6-4: 3854 DMA Device Signals Summary

| SYMBOL           | PARAMETER                           | MIN.   | TYP. | MAX.   | UNITS | NOTES                           |
|------------------|-------------------------------------|--------|------|--------|-------|---------------------------------|
| PΦ               | Φ Clock Period                      | 0.5    |      | 10     | μS    | Note 1                          |
| PW <sub>1</sub>  | Φ Pulse Width                       | 180    |      | PΦ-180 | nS    | $t_r, t_f = 50 \text{ nS typ.}$ |
| td <sub>1</sub>  | Φ to WRITE + Delay                  | 60     |      | 300    | nS    | Note 1                          |
| td <sub>2</sub>  | Φ to WRITE - Delay                  | 60     |      | 250    | nS    | Note 1                          |
| PW <sub>2</sub>  | WRITE Pulse Width                   | PΦ-100 |      | PΦ     | nS    | $t_r, t_f = 50 \text{ nS typ.}$ |
| td <sub>3</sub>  | WRITE to READ/LOAD REG Delay        |        |      | 600    | nS    |                                 |
| td <sub>4</sub>  | DB Input Set-up Time                |        |      | 300    | nS    |                                 |
| td <sub>6</sub>  | XFER REQ to MEM IDLE Set-up         | 200    |      |        | nS    |                                 |
| td <sub>7</sub>  | MEM IDLE to ADDR True               | 50     | 200  | 500    | nS    | $C_L = 500 \text{ pf}$          |
| td <sub>7'</sub> | MEM IDLE to ADDR 3-State            | 30     |      | 250    | nS    | $C_L = 500 \text{ pf}$          |
| td <sub>8</sub>  | READ REG to DB Output               | 40     |      | 300    | nS    | $C_L = 100 \text{ pf}$          |
| td <sub>9</sub>  | WRITE to ENABLE & DIRECTION + Delay |        |      | 450    | nS    | $C_L = 50 \text{ pf}$           |
| td <sub>9'</sub> | MEM IDLE to ENABLE - Delay          |        |      | 400    | nS    | $C_L = 50 \text{ pf}$           |
| td <sub>10</sub> | MEM IDLE to XFER & DWS + Delay      |        |      | 300    | nS    | $C_L = 50 \text{ pf}$           |
| td <sub>10</sub> | MEM IDLE to XFER & DWS - Delay      |        |      | 300    | nS    | $C_L = 50 \text{ pf}$           |
| td <sub>11</sub> | Φ to STROBE + Delay                 | 30     |      | 200    | nS    | $C_L = 50 \text{ pf}$           |
| td <sub>11</sub> | Φ to STROBE - Delay                 | 30     |      | 200    | nS    | $C_L = 50 \text{ pf}$           |

## Notes:

1. These specifications are those of Φ and WRITE as supplied by the 3850 CPU.
2. Input and output capacitance is 3 to 5 pf typical on all pins except V<sub>DD</sub>, V<sub>GG</sub>, and V<sub>SS</sub>.

### 3854 DMA



Figure 6-5. 3854 DMA Device Signals and Timing

## 3856 2K PSU

### ABSOLUTE MAXIMUM RATINGS (Note 1)

|                                  |               |
|----------------------------------|---------------|
| Supply Voltage $V_{GG}$          | +15 to -0.3 V |
| Supply Voltage $V_{DD}$          | +7 to -0.3 V  |
| I/O Port Open Drain Option       | +15 to -0.3 V |
| Other I/O Port Options           | +7 to -0.3 V  |
| All Inputs and Outputs           | +7 to -0.3 V  |
| Storage Temperature              | -55 to +150°C |
| Temperature (Ambient) Under Bias | 0 to +70°C    |

NOTE 1. Above which useful life may be impaired. All voltages measured with respect to  $V_{SS}$ .

### SUPPLY CURRENTS

| SYMBOL   | PARAMETER        | TYP | MAX | UNITS | TEST CONDITIONS                |
|----------|------------------|-----|-----|-------|--------------------------------|
| $I_{DD}$ | $V_{DD}$ Current | 75  | 125 | mA    | f = 2 MHz,<br>Outputs unloaded |
| $I_{GG}$ | $V_{GG}$ Current | 30  | 45  | mA    | f = 2 MHz,<br>Outputs unloaded |

### TYPICAL THERMAL RESISTANCE VALUES

|          |                                     |                      |
|----------|-------------------------------------|----------------------|
| PLASTIC: | $\theta_{JA}$ (Junction to ambient) | = 60°C/W (Still Air) |
|          | $\theta_{JC}$ (Junction to case)    | = 42°C/W             |
| CERAMIC: | $\theta_{JA}$ (Junction to ambient) | = 48°C/W (Still Air) |
|          | $\theta_{JC}$ (Junction to case)    | = 33°C/W             |

TABLE 1. 3856 PSU SIGNAL DC CHARACTERISTICS

DC ELECTRICAL CHARACTERISTICS:  $V_{SS} = 0$  V,  $V_{DD} = +5.0$  V  $\pm 5\%$ ,  $V_{GG} = +12$  V  $\pm 5\%$ ,  $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$  unless otherwise noted.

| SYMBOL   | PARAMETER           | SIGNAL                                                                          | MIN      | MAX           | UNITS         | TEST CONDITIONS                  |
|----------|---------------------|---------------------------------------------------------------------------------|----------|---------------|---------------|----------------------------------|
| $V_{IH}$ | Input HIGH Voltage  | Data Bus (DB <sub>0</sub> -DB <sub>7</sub> )                                    | 2.9      | $V_{DD}$      | V             |                                  |
| $V_{IL}$ | Input LOW Voltage   |                                                                                 | $V_{SS}$ | 0.8           | V             |                                  |
| $V_{OH}$ | Output HIGH Voltage |                                                                                 | 3.9      | $V_{DD}$      | V             | $I_{OH} = -100 \mu\text{A}$      |
| $V_{OL}$ | Output LOW Voltage  |                                                                                 | $V_{SS}$ | 0.4           | V             | $I_{OL} = 1.6 \text{ mA}$        |
| $I_{IH}$ | Input HIGH Current  |                                                                                 | 3.0      | $\mu\text{A}$ |               | $V_{IN} = V_{DD}$ , 3-State Mode |
| $I_{OL}$ | Input LOW Current   |                                                                                 | -3.0     | $\mu\text{A}$ |               | $V_{IN} = V_{SS}$ , 3-State Mode |
| $V_{IH}$ | Input HIGH Voltage  | Clock Lines ( $\phi$ , Write)                                                   | 4.0      | $V_{DD}$      | V             |                                  |
| $V_{IL}$ | Input LOW Voltage   |                                                                                 | $V_{SS}$ | 0.8           | V             |                                  |
| $I_L$    | Leakage Current     |                                                                                 | 3.0      | $\mu\text{A}$ |               | $V_{IN} = V_{DD}$                |
| $V_{IH}$ | Input HIGH Voltage  | Priority In and Control Lines (PRI IN, ROM C <sub>0</sub> -ROM C <sub>4</sub> ) | 3.5      | $V_{DD}$      | V             |                                  |
| $V_{IL}$ | Input LOW Voltage   |                                                                                 | $V_{SS}$ | 0.8           | V             |                                  |
| $I_L$    | Leakage Current     |                                                                                 | 3.0      | $\mu\text{A}$ |               | $V_{IN} = V_{DD}$                |
| $V_{OH}$ | Output HIGH Voltage | Priority Out (PRI OUT)                                                          | 3.9      | $V_{DD}$      | V             | $I_{OH} = -100 \mu\text{A}$      |
| $V_{OL}$ | Output LOW Voltage  |                                                                                 | $V_{SS}$ | 0.4           | V             | $I_{OL} = 100 \mu\text{A}$       |
| $V_{OH}$ | Output HIGH Voltage | Interrupt Request (INT REQ)                                                     | $V_{SS}$ | 0.4           | V             | Open Drain Output (Note 1)       |
| $V_{OL}$ | Output LOW Voltage  |                                                                                 |          | 3.0           | $\mu\text{A}$ | $I_{OL} = 1.0 \text{ mA}$        |
| $I_L$    | Leakage Current     |                                                                                 |          | 3.0           | $\mu\text{A}$ | $V_{IN} = V_{DD}$                |
| $V_{OH}$ | Output HIGH Voltage | Data Bus Drive (DBDR)                                                           | $V_{SS}$ | 0.4           | V             | External Pull-up                 |
| $V_{OL}$ | Output LOW Voltage  |                                                                                 |          | 3.0           | $\mu\text{A}$ | $I_{OL} = 2.0 \text{ mA}$        |
| $I_L$    | Leakage Current     |                                                                                 |          | 3.0           | $\mu\text{A}$ | $V_{IN} = V_{DD}$                |

## 3856 2K PSU

**TABLE 1. 3856 PSU SIGNAL DC CHARACTERISTICS:**  $V_{SS} = 0V$ ,  $V_{DD} = +5.0V \pm 5\%$ ,  $V_{GG} = +12V \pm 5\%$ ,  $T_A = 0^\circ C$  to  $+70^\circ C$  unless otherwise noted.

| SYMBOL                                                               | PARAMETER                                                                                                                        | SIGNAL                                  | MIN                                               | MAX                                                  | UNITS                 | TEST CONDITIONS                                                                                                                                           |
|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------|------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| $V_{OH}$<br>$V_{OL}$                                                 | Input HIGH Voltage<br>Output LOW Voltage                                                                                         | Strobe                                  | 3.9<br>$V_{SS}$<br>0.4                            | $V_{DD}$<br>V<br>V                                   | V<br>mA               | $I_{OH} = 1.0 \text{ mA}$<br>$I_{OL} = 2.0 \text{ mA}$                                                                                                    |
| $V_{IH}$<br>$V_{IL}$<br>$I_{IL}$                                     | Input HIGH Voltage<br>Input LOW Voltage<br>Input LOW Current                                                                     | External Interrupt (EXT INT)            | 2.9<br>$V_{SS}$<br>0.8<br>-1.6                    | $V_{DD}$<br>V<br>V                                   | V<br>mA               | $I_{IN} = -130 \mu A$ (Internal Pull-up)<br>$V_{IN} = 0.4 V$                                                                                              |
| $V_{OH}$<br>$V_{OH}$<br>$V_{OL}$<br>$V_{IH}$<br>$V_{IL}$<br>$I_{IL}$ | Output HIGH Voltage<br>Output HIGH Voltage<br>Output LOW Voltage<br>Input HIGH Voltage<br>Input LOW Voltage<br>Input LOW Current | I/O Port Option A<br>(Standard Pull-Up) | 3.9<br>2.9<br>$V_{SS}$<br>2.9<br>$V_{SS}$<br>-1.6 | $V_{DD}$<br>$V_{DD}$<br>0.4<br>$V_{DD}$<br>0.8<br>mA | V<br>V<br>V<br>V<br>V | $I_{OH} = -30 \mu A$ , Note 5<br>$I_{OH} = -150 \mu A$<br>$I_{OL} = 1.6 \text{ mA}$<br>Internal Pull-up to $V_{DD}$ , Note 3<br>$V_{IN} = 0.4 V$ , Note 4 |
| $V_{OH}$<br>$V_{OL}$<br>$V_{IH}$<br>$V_{IL}$                         | Output HIGH Voltage<br>Output LOW Voltage<br>Input HIGH Voltage<br>Input LOW Voltage                                             | I/O Port Option B<br>(Open Drain)       | $V_{SS}$<br>2.9<br>$V_{SS}$                       | 0.4<br>$V_{DD}$<br>0.8                               | V<br>V<br>V           | External Pull-up<br>$I_{OL} = 2.0 \text{ mA}$ , Note 3                                                                                                    |
| $V_{OH}$<br>$V_{OL}$                                                 | Output HIGH Voltage<br>Output LOW Voltage                                                                                        | I/O Port Option C<br>(Driver Pull-Up)   | 4.0<br>$V_{SS}$                                   | $V_{DD}$<br>0.4                                      | V<br>V                | $I_{OH} = -1.0 \text{ mA}$<br>$I_{OL} = 2.0 \text{ mA}$                                                                                                   |

## NOTES:

1. Pull-up resistor to  $V_{DD}$  on CPU.
2. Positive current is defined as conventional current flowing into the pin referenced.
3. Hysteresis input circuit provides additional 0.3 V noise immunity while internal/external pull-up provides TTL compatibility.
4. Measured while I/O port is outputting a high level.
5. Guaranteed, but not tested.

**TABLE 2. 3856 PSU SIGNAL AC CHARACTERISTICS**  
**A ELETTRICAL CHARACTERISTICS:**  $V_{SS} = 0V$ ,  $V_{DD} = +5.0V \pm 5\%$ ,  $V_{GG} = +12V \pm 5\%$ ,  $T_A = 0^\circ C$  to  $+70^\circ C$  unless otherwise noted.

| SYMBOL         | PARAMETER                 | MIN                    | TYP             | MAX                    | UNITS   | TEST CONDITIONS                                    |
|----------------|---------------------------|------------------------|-----------------|------------------------|---------|----------------------------------------------------|
| $P_\phi$       | $\phi$ Period             | 0.5                    |                 | 10                     | $\mu s$ |                                                    |
| $PW_1$         | $\phi$ Pulse Width        | 180                    |                 | $P_\phi - 180$         | ns      | $t_r, t_f = 50 \text{ ns Typ}$                     |
| $td_1, td_2$   | $\phi$ to Write + Delay   |                        |                 | 250                    | ns      | $C_L = 100 \text{ pF}$                             |
| $td_4$         | Write to DB Input Delay   |                        |                 | $2P_\phi + 1.0$        | $\mu s$ |                                                    |
| $PW_2$         | Write Pulse Width         | $P_\phi - 100$         | $4P_\phi$       | $P_\phi$               | ns      | $t_r, t_f = 50 \text{ ns Typ}$                     |
| $PWs$          | Write Period; Short       |                        |                 |                        | ns      |                                                    |
| $PWL$          | Write Period; Long        |                        |                 |                        | ns      |                                                    |
| $td_3$         | Write to ROMC Delay       |                        |                 | 550                    | ns      |                                                    |
| $td_7$         | Write to DB Output Delay  | $2P_\phi + 100 - td_2$ | $2P_\phi + 200$ | $2P_\phi + 850 - td_2$ | ns      | $C_L = 100 \text{ pF}$                             |
| $td_8$         | Write to DBDR - Delay     |                        |                 |                        | ns      | Open Drain                                         |
| $tr_1$         | Write to DBDR + Delay     |                        |                 | 200                    | ns      | $C_L = 100 \text{ pF}$ , Note 1                    |
| $tpr_1$        | Write to INT Req - Delay  |                        |                 | 430                    | ns      | $C_L = 100 \text{ pF}$ , Note 2                    |
| $tpd_1, tpd_2$ | PRI In to INT Req - Delay |                        |                 | 200                    | ns      | $C_L = 50 \text{ pF}$                              |
| $tpd_3, tpd_4$ | PRI In to PRI Out Delay   |                        |                 | 800                    | ns      | $C_L = 50 \text{ pF}$                              |
| $t_{sp}$       | Write to PRI Out Delay    |                        |                 | 600                    | ns      | $C_L = 50 \text{ pF}$                              |
| $t_{od}$       | Write to Output Stable    |                        |                 | 1.0                    | $\mu s$ | $C_L = 50 \text{ pF}$ , Standard Pull-up<br>Note 3 |
| $t_{od}$       | Write to Output Stable    |                        |                 |                        | $\mu s$ | $C_L = 50 \text{ pF}, R_L = 12.5 \text{ k}\Omega$  |
| $t_{dp}$       | Write to Output Stable    |                        | 200             | 400                    | ns      | Open Drain, Note 5                                 |
| $t_{su}$       | I/O Set-up Time           | 1.3                    |                 |                        | $\mu s$ | $C_L = 50 \text{ pF}$ , Driver Pull-up             |
| $t_h$          | I/O Hold Time             | 0                      |                 |                        | ns      |                                                    |
| $t_{ax}$       | Ext Int Set-up Time       | 400                    |                 |                        | ns      |                                                    |
| $t_{sB_1}$     | Write to Strobe + Delay   |                        |                 | $5P_\phi + 300$        | ns      | $C_L = 50 \text{ pF}$                              |
| $t_{sB_2}$     | Write to Strobe - Delay   |                        |                 | $6P_\phi + 410$        | ns      | $C_L = 50 \text{ pF}$                              |

## NOTES:

1. Assume Priority In was enabled ( $PRI IN = 0$ ) in previous F8 cycle before interrupt is detected in the PSU.
2. PSU has interrupt pending before priority in is enabled.
3. Assume pin tied to INT REQ input of the 3850 CPU.
4. The parameters which are shaded in the table above represent those which are most frequently of importance when interfacing to an F8 system. Unshaded parameters are typically those that are relevant only between F8 chips and not normally of concern to the user.
5. Input and output capacitance is 3 to 5 of typical on all pins except  $V_{DD}$ ,  $V_{CC}$  and  $V_{SS}$ .

## 3856 2K PSU



Fig. 2 DATA BUS TIMING



Fig. 3 INTERRUPT LOGIC SIGNALS I/O STROBE

NOTES: 1. Timing measurements are made at valid logic level to valid logic level of the signals referenced unless otherwise noted.

2. Symbols are defined in Table 2.

## 3856 2K PSU/3861 PIO

I/O operations that use the two PSU I/O ports execute in three instruction cycles. During the first cycle, the port address is transmitted to the Data Bus. During the second cycle, data is either sent from the Accumulator to the I/O latch or enabled from the I/O pin to the Accumulator depending on whether the instruction is an output or an input. At the falling edge or Write (marking the end of the second cycle and beginning of the third cycle) the data is strobed into either the Latch (OUTS) or the Accumulator (INS) respectively. The third cycle is then used by the CPU for its next instruction fetch. Figure 4 indicates I/O timing.

Data Bus timing associated with execution of I/O instructions does not differ from Data Bus timing associated with any other data transfer to, or from the PSU. However, timing at the I/O port itself depends on which port option is being used. Figures 5a, 5b, and 5c illustrate the three ports options. Figure 4 illustrates timing for the three cases.



Fig. 4 TIMING AT PSU I/O PORTS

- (1.) The set-up and hold times specified are with respect to the end of the second long cycle during execution of the three cycle IN or INS instruction.
- (2.) All delay times are specified with respect to the end of the second long cycle during execution of the three cycle OUT or OUTS instruction.

### 7.2.2 Electrical Specifications

*Absolute Maximum Ratings (Above which useful life may be impaired)*

|                            |                              |
|----------------------------|------------------------------|
| $V_{GG}$                   | +15V to -0.3V                |
| $V_{DD}$                   | +7V to -0.3V                 |
| External Interrupt Input   | -600 $\mu$ A to +225 $\mu$ A |
| All other Inputs & Outputs | +7V to -0.3V                 |
| Storage Temperature        | -55°C to +150°C              |
| Operating Temperature      | 0°C to +70°C                 |

### SUPPLY CURRENTS

| SYMBOL   | PARAMETER        | MIN. | TYP. | MAX. | UNITS | TEST CONDITIONS                     |
|----------|------------------|------|------|------|-------|-------------------------------------|
| $I_{DD}$ | $V_{DD}$ Current |      | 30   | 70   | mA    | $f = 2$ MHz,<br>Outputs<br>Unloaded |
| $I_{GG}$ | $V_{GG}$ Current |      | 10   | 18   | mA    | $f = 2$ MHz,<br>Outputs<br>Unloaded |

Supply currents measured with  $V_{DD} = +5V \pm 5\%$ ,  $V_{GG} = +12V \pm 5\%$ ,  $T_A = 0^\circ C$  to  $+70^\circ C$ . All other electrical specifications are in Table 7-4. All voltages measured with respect to  $V_{SS}$ .

# 3861 PIO

Table 7-4. A Summary of 3861 P/O Signal Characteristics

| SIGNAL                                                        | SYMBOL                                                                                                         | PARAMETER                                                                                                                       | MIN.                                                         | MAX.                                                                        | UNITS                                                    | TEST CONDITIONS                                                                                                                                                                            |
|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA BUS<br>(DB0-DB7)                                         | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>IH</sub><br>I <sub>OL</sub> | Input High Voltage<br>Input Low Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Current<br>Input Low Current | 3.5<br>V <sub>SS</sub><br>3.9<br>V <sub>SS</sub>             | V <sub>DD</sub><br>0.8<br>V <sub>DD</sub><br>0.4<br>1<br>-1                 | Volts<br>Volts<br>Volts<br>Volts<br>$\mu$ A<br>$\mu$ A   | I <sub>OH</sub> = -100 $\mu$ A<br>I <sub>OL</sub> = 1.6 mA<br>V <sub>IN</sub> = 6V, 3-State mode<br>V <sub>IN</sub> = V <sub>SS</sub> , 3-State mode                                       |
| CLOCK LINES<br>( $\Phi$ , WRITE)                              | V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub>                                                           | Input High Voltage<br>Input Low Voltage<br>Leakage Current                                                                      | 4.0<br>V <sub>SS</sub><br>1                                  | V <sub>DD</sub><br>0.8<br>1                                                 | Volts<br>Volts<br>$\mu$ A                                | V <sub>IN</sub> = 6V                                                                                                                                                                       |
| PRIORITY IN AND<br>CONTROL LINES<br>(PRI IN, ROMCO-<br>ROMC4) | V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>L</sub>                                                           | Input High Voltage<br>Input Low Voltage<br>Leakage Current                                                                      | 3.5<br>V <sub>SS</sub>                                       | V <sub>DD</sub><br>0.8<br>1                                                 | Volts<br>Volts<br>$\mu$ A                                | V <sub>IN</sub> = 6V                                                                                                                                                                       |
| PRIORITY OUT<br>(PRI OUT̄)                                    | V <sub>OH</sub><br>V <sub>OL</sub>                                                                             | Output High Voltage<br>Output Low Voltage                                                                                       | 3.9<br>V <sub>SS</sub>                                       | V <sub>DD</sub><br>0.4                                                      | Volts<br>Volts                                           | I <sub>OH</sub> = -100 $\mu$ A<br>I <sub>OL</sub> = 100 $\mu$ A                                                                                                                            |
| INTERRUPT<br>REQUEST<br>(INT REQ)                             | V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>L</sub>                                                           | Output High Voltage<br>Output Low Voltage<br>Leakage Current                                                                    | V <sub>SS</sub>                                              | 0.4<br>1                                                                    | Volts<br>Volts<br>$\mu$ A                                | Open Drain Output [1]<br>I <sub>OL</sub> = 1 mA<br>V <sub>IN</sub> = 6V                                                                                                                    |
| DATA BUS DRIVE<br>(DBDR̄)                                     | V <sub>OH</sub><br>V <sub>OL</sub><br>I <sub>L</sub>                                                           | Output High Voltage<br>Output Low Voltage<br>Leakage Current                                                                    | V <sub>SS</sub>                                              | 0.4<br>1                                                                    | Volts<br>$\mu$ A                                         | External Pull-up<br>I <sub>OL</sub> = 2 mA<br>V <sub>IN</sub> = 6V                                                                                                                         |
| EXTERNAL<br>INTERRUPT<br>(EXT INT)                            | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IC</sub><br>I <sub>IH</sub><br>I <sub>IL</sub><br>I <sub>IL</sub> | Input High Voltage<br>Input Low Voltage<br>Input Clamp Voltage<br>Input High Current<br>Input Low Current<br>Input Low Current  | 3.5<br>1.2<br>15<br>10<br>-225<br>-150                       | 1.2<br>15<br>Volts<br>Volts<br>Volts<br>$\mu$ A<br>$\mu$ A<br>$\mu$ A       | Volts<br>Volts<br>Volts<br>$\mu$ A<br>$\mu$ A<br>$\mu$ A | I <sub>IH</sub> = 185 $\mu$ A<br>V <sub>IN</sub> = V <sub>DD</sub><br>V <sub>IN</sub> = 2V<br>V <sub>IN</sub> = V <sub>SS</sub>                                                            |
| I/O PORT<br>(STANDARD<br>PULL-UP)                             | V <sub>OH</sub><br>V <sub>OH</sub><br>V <sub>OL</sub><br>V <sub>IH</sub><br>V <sub>IL</sub><br>I <sub>IL</sub> | Output High Voltage<br>Output High Voltage<br>Output Low Voltage<br>Input High Voltage<br>Input Low Voltage<br>Leakage Current  | 3.9<br>2.9<br>V <sub>SS</sub><br>2.9<br>V <sub>SS</sub><br>1 | V <sub>DD</sub><br>V <sub>DD</sub><br>0.4<br>V <sub>DD</sub><br>0.8<br>-1.6 | Volts<br>Volts<br>Volts<br>Volts<br>Volts<br>$\mu$ A     | I <sub>OH</sub> = -30 $\mu$ A<br>I <sub>OH</sub> = -100 $\mu$ A<br>I <sub>OL</sub> = 2 mA<br>Internal Pull-up to V <sub>DD</sub> [3]<br>V <sub>IN</sub> = 6V<br>V <sub>IN</sub> = 0.4V [4] |

**Notes:**

1. Pull-up resistor to V<sub>DD</sub> on CPU.
2. Positive current is defined as conventional current flowing into the pin referenced.
3. Hysteresis input circuit provides additional 0.3V noise immunity while internal/external pull-up provides TTL compatibility.
4. Measured while I/O port is outputting a high level.
5. V<sub>SS</sub> = 0V, V<sub>DD</sub> = +5V  $\pm$  5%, V<sub>GG</sub> = +12V  $\pm$  5%, T<sub>A</sub> = 0°C to +70°C.
6. Output device off.

**3861 PIO***Table 7-5. A Summary of 3861 PIO Signal AC Characteristics*AC Characteristics:  $V_{SS} = 0V$ ,  $V_{CC} = +5V \pm 5\%$ ,  $T_A = 0^\circ C$  to  $+70^\circ C$ 

Symbols in this table are used by all figures in Section 7.

| SYMBOL            | PARAMETER                 | MIN.                           | TYP.           | MAX.                           | UNITS   | TEST CONDITIONS                          |
|-------------------|---------------------------|--------------------------------|----------------|--------------------------------|---------|------------------------------------------|
| P $\phi$          | $\phi$ Period             | 0.5                            |                | 10                             | $\mu S$ |                                          |
| PW <sub>1</sub>   | $\phi$ Pulse Width        | 180                            |                | P $\phi$ -180                  | nS      |                                          |
| td <sub>1</sub>   | $\phi$ to WRITE + Delay   | 60                             |                | 250                            | nS      |                                          |
| td <sub>2</sub>   | $\phi$ to WRITE - Delay   | 60                             |                | 225                            | nS      |                                          |
| td <sub>4</sub>   | WRITE to DB Input Delay   |                                |                | 2P $\phi$ +1.0                 | $\mu S$ |                                          |
| PW <sub>2</sub>   | WRITE Pulse Width         | P $\phi$ -100                  |                | P $\phi$                       | nS      |                                          |
| PW <sub>S</sub>   | WRITE Period; Short       |                                | 4P $\phi$      |                                |         |                                          |
| PW <sub>L</sub>   | WRITE Period; Long        |                                | 6P $\phi$      |                                |         |                                          |
| td <sub>3</sub>   | WRITE to ROMC Delay       |                                |                | 550                            | nS      |                                          |
| td <sub>7</sub>   | WRITE to DB Output Delay  | 2P $\phi$ +100-td <sub>2</sub> | 2P $\phi$ +200 | 2P $\phi$ +850-td <sub>2</sub> | nS      | C <sub>L</sub> = 100 pf                  |
| td <sub>8</sub> , | WRITE to DBDR - Delay     |                                |                | 200                            | nS      | Open Drain                               |
| tr <sub>1</sub>   | WRITE to INT REQ - Delay  |                                |                | 430                            | nS      | C <sub>L</sub> = 100 pf [1]              |
| tr <sub>2</sub>   | WRITE to INT REQ + Delay  |                                |                | 430                            | nS      | C <sub>L</sub> = 100 pf [3]              |
| tpr <sub>1</sub>  | PRI IN to INT REQ - Delay |                                |                | 240                            | nS      | C <sub>L</sub> = 100 pf [2]              |
| tpr <sub>2</sub>  | PRI IN to INT REQ + Delay |                                |                | 240                            | nS      | C <sub>L</sub> = 100 pf                  |
| tpd <sub>1</sub>  | PRI IN to PRI OUT - Delay |                                |                | 300                            | nS      | C <sub>L</sub> = 50 pf                   |
| tpd <sub>2</sub>  | PRI IN to PRI OUT + Delay |                                |                | 365                            | nS      | C <sub>L</sub> = 50 pf                   |
| tpd <sub>3</sub>  | WRITE to PRI OUT + Delay  |                                |                | 700                            | nS      | C <sub>L</sub> = 50 pf                   |
| tpd <sub>4</sub>  | WRITE to PRI OUT - Delay  |                                |                | 640                            | nS      | C <sub>L</sub> = 50 pf                   |
| *t <sub>sp</sub>  | WRITE to Output Stable    |                                |                | 2.5                            | $\mu S$ | C <sub>L</sub> = 50 pf, Standard Pull-up |
| *t <sub>su</sub>  | I/O Set-up Time           | 1.3                            |                |                                | $\mu S$ |                                          |
| *t <sub>h</sub>   | I/O Hold Time             | 0                              |                |                                | nS      |                                          |
| *t <sub>ex</sub>  | EXT INT Set-up Time       | 400                            |                |                                | nS      |                                          |

## Notes:

- Assume Priority In was enabled (PRI IN = 0) in previous F8 cycle before interrupt is detected in the PIO.
- PSU has interrupt pending before priority is enabled.
- Assume pin tied to INT REQ input of the 3850 CPU.
- The parameters which are starred in the table above represent those which are most frequently of importance when interfacing to an F8 system. Other parameters are typically those that are relevant only between F8 chips and not normally of concern to the user.
- Input and output capacitance is 3 to 5 pf typical on all pins except V<sub>DD</sub>, V<sub>GG</sub>, and V<sub>SS</sub>.

## 3861 PIO



Figure 7-3. 3861 PIO Data Bus Timing



SYMBOLS USED ARE DEFINED IN TABLE 7-5

### Notes:

1. Data from the I/O port is strobed into the accumulator of the CPU at the end of the second instruction cycle during execution of an IN or INS instruction.
2. During an OUT or OUTS instruction, data is strobed into the port latch at the end of the second instruction cycle; thus the cycle shown is the second cycle within the execution of the instruction.
3. Input and output capacitance of 3 to 5 pf typical on all pins except  $V_{DD}$ ,  $V_{GG}$ , and  $V_{SS}$ .

Figure 7-4. Timing at PIO I/O Ports

## 3861 PIO



SYMBOLS ARE DEFINED IN TABLE 7-5

**Note:**

Timing measurements are made at valid logic level to valid logic level of the signals referenced unless otherwise noted.

*Figure 7-6. Interrupt Logic Signals's Timing*

# Chapter 3

## THE NATIONAL SEMICONDUCTOR SC/MP

SC/MP is a low-cost microprocessor that has been designed to operate easily in multi-microprocessor configurations. The most interesting characteristic of SC/MP is its bus interface logic. Most microprocessors are designed to always operate as bus master in any microcomputer system. SC/MP, in contrast, has the bus interface logic of a support device; it does not assume that it has any more right to a System Bus than any other device. Bus request/acknowledge logic coupled with bus access priority logic makes SC/MP the slave microprocessor of choice in any multi-microprocessor application.

The very open bus interface logic of SC/MP results in it having no special support devices; it shares the support devices of other National Semiconductor microprocessors. These support devices are described in Volume III.

The prime source is:

NATIONAL SEMICONDUCTOR INC.  
2900 Semiconductor Drive  
Santa Clara, CA 95050

The authorized second source for SC/MP is:

SIGNETICS  
811 East Arques Avenue  
Sunnyvale, CA 94043

Although Signetics is authorized as an SC/MP second source, they are not yet manufacturing SC/MP and are not likely to do so until late 1978.

**Figure 3-1 conceptually illustrates the logic functions which are implemented on the SC/MP chip. One of the weaknesses of Figure 3-1, and the equivalent figures for the other microcomputers, is that the way in which logic functions are implemented cannot be identified. SC/MP, for example, implements non-CPU logic at a very elementary level, well suited for simple applications only.**

Nonetheless, Figure 3-1 does reveal a few of the rather unusual capabilities provided by SC/MP. Notice that Serial-to-Parallel Interface Logic is shown as implemented by the SC/MP chip. SC/MP has two serial I/O device pins, one for serial binary input data, the other for serial binary output data. The assembly and disassembly of serial-to-parallel data is accomplished by one SC/MP instruction.

SC/MP  
SERIAL I/O

**Figure 3-1 also shows Programmable Timer logic as being implemented by the SC/MP chip. This is barely justifiable — the SC/MP instruction set includes a Delay instruction that is used to generate timed durations ranging from 13 to 131,593 microcycles. Note, however, that during this delay interval the CPU can be performing no other actions: the CPU is, in effect, operating solely as a programmable timer. This is obviously quite different from having a separate logic device that performs this timer function within a system. Once again, this points out the weakness of a generalized representation such as Figure 3-1.**

One other area of non-CPU logic shown as being implemented by SC/MP further illustrates this point. A portion of the Direct Memory Access (DMA) logic is provided by SC/MP using a few signals to control bus access. A significant amount of external logic would still be required to obtain an operational DMA system. Therefore, Figure 3-1 can be misleading because it cannot indicate the way in which the CPU implements a particular function. In this particular case there is also a significant area of non-CPU logic provided by SC/MP that is nowhere indicated by Figure 3-1: The signals that can be used for DMA are primarily intended to simplify the design of multiprocessor systems. This is a very unusual logic function for a CPU to provide and therefore is not even suggested in Figure 3-1. But for SC/MP, the inclusion of this multiprocessor-oriented logic makes a lot of sense: its low cost and modest performance make it a likely candidate for multiprocessor systems.

SC/MP DMA  
AND  
MULTIPROCESSOR  
LOGIC



Figure 3-1. Logic of the SC/MP Microcomputer

There are two versions of the SC/MP CPU: the original version uses P-channel silicon-gate MOS/LSI technology and its part number is ISP-8A/500; the new version (SC/MP-II) uses N-channel technology and its part number is ISP-8A/600. The two versions are functionally equivalent and fully compatible in terms of object code and pin configuration. (A few minor signal level conversions are required for complete signal compatibility: see Figure 3-3.) The SC/MP-II provides some significant advantages over the original version — it is twice as fast and uses only one-fourth the power of the original P-channel version. Additionally, while SC/MP requires two power sources (a +5 volt and a -7 volt supply), SC/MP-II needs only a single +5 volt supply. Throughout this chapter, we will simply refer to the CPU as SC/MP: all the descriptions apply to both versions of the CPU unless we specifically mention SC/MP-II.

**SC/MP  
AND  
SC/MP-II**

Both versions of the SC/MP CPU have an on-chip clock oscillator and can use a capacitor, crystal, or TTL clock input to drive the clock. The P-channel SC/MP can run at a maximum frequency of 1 megahertz, which results in instruction execution times in the range of 10 to 50 microseconds. SC/MP-II can operate at frequencies up to 4 megahertz with resulting instruction execution times in the range of 5 to 25 microseconds. Notice that although the input frequency for SC/MP-II can be four times that of SC/MP, the instruction execution time for SC/MP-II is twice as fast (not four times as fast): this is because of internal differences in the way the on-chip clock oscillator uses the timing inputs.

**SC/MP  
INSTRUCTION  
EXECUTION  
SPEED**

Both versions of SC/MP provide TTL-compatible input and output signals.

**SC/MP  
LOGIC LEVEL**

### SC/MP PROGRAMMABLE REGISTERS

SC/MP has an 8-bit Accumulator, an 8-bit Extension register, a 16-bit Program Counter, three 16-bit Pointer registers, and an 8-bit Status register. These programmable registers are illustrated as follows:



The Accumulator is a single, primary Accumulator, as described for our hypothetical microcomputer.

The Extension register is used to assemble or disassemble serial-to-parallel data for serial data input and output. This register is also used as a buffer for the Accumulator.

The Program Counter is 16 bits wide; therefore up to 65,536 bytes of memory may be addressed in the normal course of events. The four high-order bits of the Program Counter represent page select bits; therefore the memory of an SC/MP system is divided into 16 pages of 4096 words each.

**SC/MP  
MEMORY  
PAGES**

Notice that the Program Counter is shown as Pointer Register 0; this is done because some instructions move data between Pointer registers including the Program Counter. There is one other unusual fact about the SC/MP Program Counter: the four most significant bits (the page select bits) of the Program Counter are never incremented during the instruction fetch sequence. Instead, when the last address of a page is reached, the Program Counter "wraps-around" to the first address of the current page. For example, if the Program Counter contains 2FFF<sub>16</sub>, when it is incremented the new contents of the Program Counter will be 2000<sub>16</sub> instead of 3000<sub>16</sub>. The page select bits of the Program Counter can only be changed by executing an instruction that loads a new value into the most significant bits of the Program Counter.

Note that the four high-order address bits are not output on separate address pins; instead they are output on the data lines at the beginning of an input/output cycle and must be demultiplexed by external logic in order to generate page select signals.

The three Pointer registers are also used as Index registers or Stack Pointers. Typically, you would assign a specific function to each register. For example, the following assignments might be used:

- P1 - ROM Pointer
- P2 - Stack Pointer
- P3 - Subroutine Pointer

These arbitrary assignments also reveal several interesting facts about the architecture of SC/MP. First, the SC/MP CPU does not provide an on-chip stack; instead, a stack can be maintained in memory using one of the Pointer registers as a Stack Pointer. Secondly, the SC/MP instruction set does not include a Jump-to-Subroutine instruction: one of the Pointer registers must be used to hold subroutine addresses which can then be swapped with the Program Counter. We will discuss this in detail when we describe the SC/MP instruction set.

## ADDRESSING MODES

The SC/MP memory reference instructions use program-relative direct addressing, indexed addressing, and auto-indexed addressing. All memory reference instructions are two-byte instructions and have the following object code format:



Program relative and indexed addressing are as described in Volume I, Chapter 6. We will just re-emphasize here that all addressing in SC/MP is paged and uses the wrap-around technique — that is, there is no carry from the low order 12 bits of an address into the most significant 4 bits of an address. We mentioned this earlier when we discussed the Program Counter, and it also applies to indexed addressing. Thus, if the sum of the Index register (that is, one of the Pointer registers) and the second object code byte contents (displacement) is more than FFF<sub>16</sub>, the Carry bit will be discarded. This may be illustrated as follows:



Remember, all arithmetic operations during address formation, regardless of the addressing mode, obey this wrap-around technique: there is never a carry from bit 11 into bit 12.

The auto-indexing mode of addressing provided by SC/MP instructions is actually an auto-increment/auto-decrement operation. When auto-indexing is specified, the displacement, as a signed binary number, is added to the contents of a Pointer register in order to compute an effective address. If the displacement is less than zero, the Pointer register is decremented by the displacement before the memory access. If the displacement is equal to or greater than zero, then the contents of the Pointer register is the effective address and the Pointer register contents are incremented by the displacement after the memory access. This method of auto-increment and auto-decrement addressing is the same as that described in Volume I with one significant difference: SC/MP allows an address to be incremented or decremented by any value in the range 0 - 127 instead of just by a value of one.

## SC/MP STATUS REGISTER

SC/MP has a programmable 8-bit Status register which may be illustrated as follows:



Circled numbers represent device pin numbers to which bits of the Status register are connected.

The Carry (CY), Link (L) and Overflow (OV) status bits are typical microcomputer status bits as were described in Volume I, Chapter 7.

The two sense bits, SB and SA, are tied to SC/MP device pins. These two bits directly reflect the state of the logic signals applied to the device pins and thus can be used to detect external events. Although there are no SC/MP instructions that allow you to directly jump or branch on the condition of one of these bits, a sequence of masking and testing instructions can be used to accomplish the same effect, albeit more slowly. **The SA and SB bits are read-only bits. Instructions may read the status of these two bits, but only incoming signals may change their condition.** For example, an instruction that moves the contents of the Accumulator to the Status register may modify any of the other status bits, but bits 4 and 5 will not change. **The SA bit serves a dual function. If the Interrupt Enable (IE) bit is set to one, the SA input serves as the interrupt input.** We will discuss interrupt processing later in this chapter.

F0, F1 and F2 are control flags that are tied to SC/MP device pins. The state of these three flags may be changed under program control and may be used to control external devices. When the state of any of these flags is changed, it is immediately reflected by a change in the signal level at the associated device pin.

## SC/MP CPU SIGNALS AND PIN ASSIGNMENTS

Figure 3-2 illustrates the SC/MP pins and signals. A description of these signals is useful as a guide to the way in which an SC/MP microcomputer system works.

The 12 address lines AD00 - AD11 output memory and I/O device addresses. These are tristate lines, and may be floated, giving external logic control of the Address Bus. The four most significant address bits (AD12 - AD15) are time multiplexed on the data lines.

The eight Data Bus lines DB0 - DB7 are multiplexed, bidirectional data lines through which 8-bit data units are input and output, and on which statuses and address bits are output at the beginning of any input/output cycle. Statuses on Data Bus lines DB4 - DB7 identify the type or purpose of the input/output cycle. The address bits on Data Bus lines DB0 - DB3 are the four most significant address bits (AD12 - AD15) which must be used to generate page select signals for memory or peripheral devices. Table 3-1 describes the status and address information that is output on the Data Bus. Like the address lines, the data lines are tristate.

SENSEA, SENSEB, FLAG0, 1, and 2 are pin connections for the similarly named Status register bits described earlier.

SIN and SOUT are used in combination with the SIO instruction for serial input of data to the Extension register and serial output of data from the Extension register.

The remaining signals (excluding clock, power and ground) may be divided into bus access, Data Bus definition, and timing control signals.

You will notice that some of the SC/MP pins in Figure 3-2 have two sets of signal names: the names enclosed in parentheses reflect the nomenclature used with SC/MP-II. Aside from the clock and power signals which we shall discuss separately, the only difference between SC/MP and SC/MP-II is in the polarity of bus access signals: Bus Request (BREQ/NBREQ), Enable In (ENIN/NENIN), and Enable Out (ENOUT/NENOUT). The "N" prefix to each of the SC/MP-II signals indicates that these signals are negative-true — as opposed to the positive- (or logic "1") true signals for the P-channel SC/MP. **In the descriptions that follow, we will use P-channel SC/MP nomenclature.** If you are using the N-channel SC/MP-II version, you must simply invert these signals.

**SIGNAL  
DIFFERENCES  
BETWEEN SC/MP  
(P-CHANNEL)  
AND SC/MP-II  
(N-CHANNEL)**



| PIN NAME†                                               | DESCRIPTION                   | TYPE                    |
|---------------------------------------------------------|-------------------------------|-------------------------|
| X1,X2                                                   | Crystal/Capacitor Connections | Input                   |
| *DB0 - DB7                                              | Data Bus                      | Bidirectional, Tristate |
| *AD00 - AD11                                            | Address Lines                 | Output, Tristate        |
| *SENSEA,SENSEB                                          | External Status Input         | Input                   |
| *FLAG0,1,2                                              | Flags                         | Output                  |
| *NRST                                                   | Reset                         | Input                   |
| *CONT                                                   | Halt/Continue                 | Input                   |
| *BREQ (NBREQ)                                           | Bus Request/Busy              | Bidirectional           |
| *ENIN (NENIN)                                           | Data Bus Enable               | Input                   |
| *ENOUT (NENOUT)                                         | CPU Bus Access Status         | Output                  |
| *NADS                                                   | Address on Data Bus           | Output                  |
| *NRDS                                                   | Data Input Strobe             | Output, Tristate        |
| *NWDS                                                   | Data Output Strobe            | Output, Tristate        |
| *NHOLD                                                  | Clock Delay                   | Input                   |
| SIN                                                     | Serial Data In                | Input                   |
| SOUT                                                    | Serial Data Out               | Output                  |
| V <sub>GG</sub> -V <sub>SS</sub> (V <sub>CC</sub> -GND) | Power and Ground              |                         |

\*These signals connect to the System Bus.

† Signals in parenthesis are SC/MP-II signal names.

Figure 3-2. SC/MP CPU Signals and Pin Assignments

**Before the SC/MP CPU can begin any input/output operation, it must gain access to the System Busses.** This approach reflects the design philosophy behind SC/MP. It is a relatively low-cost, low-performance CPU and the designers anticipated that it would frequently be used in multiprocessor systems or in systems utilizing Direct Memory Access. Accordingly, three signals are provided to control access to the System Busses.

**BREQ is used as a bus busy input indicating that some other device is using the System Busses; as an output, BREQ is a bus request which is output when the System Busses are free and SC/MP requires access to the busses.**

**ENIN is a control signal which is input to the CPU by external logic. When ENIN is low, the CPU is denied access to the System Busses and the SC/MP address and data lines are held in tristate mode.**

**SC/MP  
BUS ACCESS  
CONTROL  
SIGNALS**

**ENOUT is the CPU's output response to ENIN.** When output high, ENOUT indicates that ENIN is high; therefore, the CPU can gain access to the System Busses, but it has not done so. If ENOUT is low, it indicates either that ENIN is low, therefore the CPU is being denied access to the System Busses or, if ENIN is high, then it indicates that the CPU is using the System Busses.

**When the CPU has gained access to the System Busses, three signals identify the way in which the CPU is using the Data Bus.**

**SC/MP DATA BUS DEFINITION SIGNALS**

**NADS** is output to indicate that a valid address has been output on the address lines and that the low-order four bits of the Data Bus contain the high-order four bits of a 16-bit address. NADS also indicates that status information is being output on the high-order four bits of the Data Bus.

**NRDS**, when output by the CPU, indicates that the CPU wishes to receive data on the Data Bus.

**NWDS**, when output by the CPU, indicates that data is being output by the CPU on the Data Bus. NWDS may be used by external logic as a write strobe.

**SC/MP TIMING CONTROL SIGNALS**

**There are three signals which control CPU timing.**

**NRST** is a system reset signal. When input low, it aborts any in-process operations. When returned high, all programmable registers are cleared, and program execution begins with the instruction fetched from memory location 000116.

**CONT** may be input to stop the CPU between instructions. When CONT is input low, all CPU operations are halted after the current instruction execution has been completed. The CPU remains halted until CONT goes high.

**NHOLD** is an input signal used during input/output operations to lengthen the allowed time interval for devices to respond to CPU access requests.

## SC/MP TIMING AND INSTRUCTION EXECUTION

**The SC/MP timing for instruction execution is very simple. Instruction execution times are expressed in terms of microcycles.** A typical instruction is executed in 10 microcycles; one (the first) or more of these microcycles is an input/output cycle. The length of a microcycle depends on the frequency of the clock inputs to the CPU: with the P-channel SC/MP, the minimum microcycle length is 2 microseconds; for SC/MP-II, the N-channel version, minimum microcycle length is 1 microsecond. Thus, typical instruction execution time is 20 microseconds for the P-channel SC/MP, and 10 microseconds for SC/MP-II. **All microcycles, whether internal machine cycles or input/output cycles, are of the same length: the only variance occurs when the NHOLD signal is used to stretch an input or output cycle.**

**There are basically only three types of SC/MP machine (or micro) cycles: data input (read) cycles, data output (write) cycles, and internal microcycles.** The execution of each instruction is merely a concatenation of these three types of microcycles.

SC/MP does, however, output some status information at the beginning of every input or output cycle; this status information provides a more precise definition of the events that will occur during that microcycle. Table 3-1 lists the information which may be output on the Data Bus at the beginning of an I/O cycle (when NADS is low). Table 3-2 defines the status information for non-I/O cycles.

**SC/MP I/O CYCLE STATUS INFORMATION**

Table 3-1. Status and Address Output via the Data Lines at the Beginning of an I/O Cycle

| SYMBOLS | DATA BUS BIT | DEFINITION                                                                                                                                                                                                                                                    |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| H-Flag  | 7            | Indicates that a Halt instruction has been executed.                                                                                                                                                                                                          |
| D-Flag  | 6            | Indicates that a Delay instruction has been executed and that a delay cycle is starting.                                                                                                                                                                      |
| I-Flag  | 5            | Indicates that the CPU is in the fetch cycle for the first byte of an instruction.                                                                                                                                                                            |
| R-Flag  | 4            | When high, indicates that the I/O cycle is a read cycle and that input data should be placed on the Data Bus when NRDS is active. When low, indicates that the I/O cycle is a write cycle and that the Data Bus will contain output data when NWDS is active. |
| AD15    | 3            |                                                                                                                                                                                                                                                               |
| AD14    | 2            | The four most significant bits of a 16-bit address.                                                                                                                                                                                                           |
| AD13    | 1            | Can be used as page select signals.                                                                                                                                                                                                                           |
| AD12    | 0            |                                                                                                                                                                                                                                                               |

Table 3-2. Statuses Output on the Data Bus for Various Types of Machine Cycles

| Status Information | Data Bus Bit | TYPE OF MACHINE CYCLE |                  |                   |                   |                     |
|--------------------|--------------|-----------------------|------------------|-------------------|-------------------|---------------------|
|                    |              | Instruction Fetch     | Halt Instruction | Delay Instruction | Data Input (Read) | Data Output (Write) |
| H-Flag             | 7            | 0                     | 1                | 0                 | 0                 | 0                   |
| D-Flag             | 6            | 0                     | 0                | 1                 | 0                 | 0                   |
| I-Flag             | 5            | 1                     | 1                | 0                 | 0                 | 0                   |
| R-Flag             | 4            | 1                     | 1                | 1                 | 1                 | 0                   |

## SC/MP BUS ACCESS LOGIC

Since the SC/MP CPU must gain access to the System Busses before it can perform an input or output cycle, we will describe the bus access logic before discussing input/output cycles.

Figure 3-3 illustrates the bus access logic processing sequence that occurs whenever the SC/MP CPU is going to perform an input/output cycle.

First, the bidirectional BREQ line is tested. If the BREQ input is high, it indicates that the System Bus is currently in use: the CPU holds the outputs of the address and data lines, and the NRDS and NWDS signals in the high-impedance (tristate) mode.

When the BREQ input signal is low (or goes low) it indicates that the System Bus is free, and the CPU then outputs a logic "1" on the BREQ line. This informs external devices (for example, other SC/MP CPUs or a DMA controller) that a request for bus access has been initiated.

The CPU next tests the state of the ENIN input line. ENIN is essentially the "bus grant" signal: if it is low, it indicates the Bus Request (BREQ) is denied and the CPU remains in an idle state with its output held in the high impedance mode. When the ENIN input is high (or goes high) it indicates that the CPU's bus request has been granted and the I/O cycle can now be initiated.

When the I/O cycle has been completed, the CPU sets the BREQ output low to indicate that it has finished using the System Bus and that its outputs are once again in the high impedance mode.



Figure 3-3. SC/MP Bus Access Logic Processing Sequence

**There are a couple of aspects of the bus access sequence which are not revealed by Figure 3-3.**

**First, the SC/MP CPU has the rather unusual capability of suspending an I/O operation after it has already begun.** If the ENIN input line goes low while the CPU has access to the bus, the SC/MP address and data lines will go to the high impedance state, thus relinquishing access to the System Busses. The BREQ output signal will remain high and, when the ENIN input line subsequently goes high once more, the input/output cycle which had been suspended will begin again.

**SUSPENSION  
OF AN SC/MP  
I/O CYCLE**

This ability to suspend an I/O cycle might be quite useful in a system where bus access is granted on a priority basis. In such a system, it is conceivable that one or more of the system devices (another CPU, for example) might have overriding priorities and require immediate access to the System Busses. The SC/MP bus access logic we've just described allows this to be accomplished with no difficulty whatsoever. **There is, however, one gray area in this I/O-suspend**

**function.** If an SC/MP I/O cycle is nearly complete, it would seem to be more efficient to go ahead and complete the cycle rather than suspending it and then restarting the entire cycle later. This is precisely what SC/MP does. Unfortunately, the SC/MP literature does not tell us where this "point-of-no-return" lies within an I/O cycle. One would assume, or at least hope that this point is prior to the time when NRDS or NWDS is sent out. These signals are the read and write strobe signals; if they were repeated when an I/O cycle was restarted, the same data might be read or written twice — a potentially vexing situation. However, you are at least assured that if ENIN goes low while SC/MP is performing an I/O cycle, the cycle will be performed — either by continuing to completion or by being restarted when the System Busses are again available.

If you refer back to Figure 3-3 once again, you will notice that there is no mention of the third SC/MP bus access control signal — ENOUT. This is not an oversight — it is simply due to the fact that the ENOUT signal performs a rather specialized function which is not necessary to an understanding of the SC/MP bus access logic. **The primary function of the ENOUT output signal is as an enabling signal in systems where a "daisy chain" technique is used to establish priorities for bus access.** We will defer a discussion of this use of ENOUT until later in this chapter when we discuss the use of SC/MP in multiprocessor and DMA systems.

SC/MP ENOUT  
SIGNAL USED  
TO ESTABLISH  
ACCESS PRIORITIES

If the SC/MP CPU is used in a single-processor, non-DMA system then there is no need for the built-in bus access logic. In these cases, which may in fact be in the majority, the bus access signals should be connected so that the SC/MP CPU is always guaranteed immediate access to the System Busses. This is easily accomplished by making the following connections:

SC/MP I/O  
WITH BUS  
ACCESS LOGIC  
CONTINUOUSLY  
ENABLED

|          | SIGNAL                   | CONNECT TO                                                     |
|----------|--------------------------|----------------------------------------------------------------|
| SC/MP    | BREQ<br>ENIN<br>ENOUT    | VGG through a pull-down resistor.<br>VSS<br>Leave unterminated |
| SC/MP-II | NBREQ<br>NENIN<br>NENOUT | VCC via external resistor.<br>Ground<br>Leave unterminated     |

In the descriptions of SC/MP input/output operations that follow, we will always assume that the SC/MP CPU has already been granted access to the System Busses, and that this access is not interrupted (or suspended).

## SC/MP INPUT/OUTPUT OPERATIONS

Once the SC/MP CPU has control of the System Busses, an actual input or output cycle can begin. As we mentioned earlier in this chapter, the execution of any SC/MP instruction includes some combinations of input/output cycles and internal machine cycles. Figure 3-4 illustrates the bus utilization required for each of the SC/MP instructions, and also reveals an interesting, non-obvious fact about SC/MP input/output operations. Observe that each bus utilization interval is shown as being two microcycles in duration. This is true because each input/output operation effectively requires two microcycles. The CPU spends a portion of the first microcycle gaining access to the System Bus and placing address and status information on the address and data lines. The actual data transfer (read or write) occurs during the second microcycle. This can be confusing if you are designing a DMA or multiprocessor system: the actual time that the bus is available is a great deal less than you would expect if you based your computations solely on the number of read and write cycles required for each instruction. To make this more clear, refer to Table 3-3, which lists the read cycles, write cycles, and total microcycles required for execution of each SC/MP instruction. If you total up each of the columns from this table, you come up with the following figures:

$$\begin{aligned} \text{Total Read Cycles} &= 79 \\ \text{Total Write Cycles} &= 3 \\ \text{Total Input/Output Cycles} &= 82 \\ \text{Total Microcycles} &= 466 \end{aligned}$$

Based on these figures, it would appear that bus utilization is less than 20% (82/466). However, since the CPU maintains control of the bus for approximately two microcycles each time a read or write cycle is performed, the actual bus utilization is quite a bit greater than you would have expected. For precise timing parameters refer to the data sheets at the end of this chapter. Keep in mind that bus utilization computations should be based not only on these data sheets, but also on the actual program being used, since bus utilization is directly related to the composition of instructions which comprise your program — these calculations can differ significantly from any theoretical calculations based solely on a CPU's complete instruction set.

Now, having discussed those areas of SC/MP bus access and utilization which might be confusing, let us proceed to examine the actual data input/output operations — we will find that these SC/MP operations are quite straightforward.



Figure 3-4. Bus Utilization of Each SC/MP Instruction

Table 3-3. SC/MP Instruction Execution Times

| INSTRUCTION | READ CYCLES | WRITE CYCLES | TOTAL MICROCYCLES |
|-------------|-------------|--------------|-------------------|
| ADD         | 3           | 0            | 19                |
| ADE         | 1           | 0            | 7                 |
| ADI         | 2           | 0            | 11                |
| AND         | 3           | 0            | 18                |
| ANE         | 1           | 0            | 6                 |
| ANI         | 2           | 0            | 10                |
| CAD         | 3           | 0            | 20                |
| CAE         | 1           | 0            | 8                 |
| CAI         | 2           | 0            | 12                |
| CAS         | 1           | 0            | 6                 |
| CCL         | 1           | 0            | 5                 |
| CSA         | 1           | 0            | 5                 |
| DAD         | 3           | 0            | 23                |
| DAE         | 1           | 0            | 11                |
| DAI         | 2           | 0            | 15                |
| DINT        | 1           | 0            | 6                 |
| DLD         | 3           | 1            | 22                |
| DLY         | 2           | 0            | 13 - 131593       |
| HALT        | 2           | 0            | 8                 |
| IEN         | 1           | 0            | 6                 |
| ILD         | 3           | 1            | 22                |
| JMP         | 2           | 0            | 11                |
| JNZ         | 2           | 0            | 9, 11 for Jump    |

| INSTRUCTION | READ CYCLES | WRITE CYCLES | TOTAL MICROCYCLES |
|-------------|-------------|--------------|-------------------|
| JP          | 2           | 0            | 9, 11 for Jump    |
| JZ          | 2           | 0            | 9, 11 for Jump    |
| LD          | 3           | 0            | 18                |
| LDE         | 1           | 0            | 6                 |
| LDI         | 2           | 0            | 10                |
| NOP         | 1           | 0            | 5                 |
| OR          | 3           | 0            | 18                |
| ORE         | 1           | 0            | 6                 |
| ORI         | 2           | 0            | 10                |
| RR          | 1           | 0            | 5                 |
| RRL         | 1           | 0            | 5                 |
| SCL         | 1           | 0            | 5                 |
| SIO         | 1           | 0            | 5                 |
| SR          | 1           | 0            | 5                 |
| SRL         | 1           | 0            | 5                 |
| ST          | 2           | 1            | 18                |
| XAE         | 1           | 0            | 7                 |
| XOR         | 3           | 0            | 18                |
| XPAH        | 1           | 0            | 8                 |
| XPAL        | 1           | 0            | 8                 |
| XPPC        | 1           | 0            | 7                 |
| XRE         | 1           | 0            | 6                 |
| XRI         | 2           | 0            | 10                |

Note: If slow memory is being used, the appropriate delay should be added for each read or write cycle.

**Figure 3-5 illustrates the timing for a standard SC/MP data input cycle.** This timing applies regardless of whether the input cycle is to access data from memory or peripheral devices and also applies to instruction fetch operations.

### SC/MP DATA INPUT CYCLE

Once the CPU has gained access to the System Busses, **the input cycle begins by presenting address and statuses on the address and data lines.** When the NADS signal is sent out, the least significant 12 bits of address data are valid on the SC/MP address lines, and the SC/MP data lines are outputting status information and the most significant 4 bits of address information. Table 3-1 defines the information that is output on the data lines while NADS is true. When these address bits and/or status bits need to be latched, either the leading or trailing edge of NADS can be used as a clock signal.



Figure 3-5. SC/MP Data Input Cycle

Shortly after the trailing edge of NADS, the Data Bus is floated and the Read Data Strobe (NRDS) signal is output. Valid input data is expected prior to the trailing edge of NRDS.

The SC/MP data output cycle begins in the same way as the data input cycle. The only difference is that immediately after the status/address information is output on the data lines, the write or output data is placed on the data lines. As shown in Figure 3-6, the NWDS signal is sent out to indicate when valid output data is present. Either the leading or trailing edge of NWDS could be used to latch the output data into external data latches.

### SC/MP DATA OUTPUT CYCLE



Figure 3-6. SC/MP Data Output Cycle

The data input/output cycles just described allow approximately one microcycle for external logic to respond. If additional access time is required, the NHOLD input signal to the CPU can be used to lengthen an input/output cycle. The NHOLD signal can be set low any time prior to the trailing edge of NRDS or NWDS as shown in Figure 3-7; this causes the trailing edge of NRDS or NWDS to be delayed until after NHOLD has been returned high. On data input cycles, the time until valid input data must be presented is simply delayed. On data output cycles, the valid output data is maintained on the data lines by the CPU until the delayed trailing edge of NWDS.

### SC/MP NHOLD SIGNAL FOR SLOW I/O OPERATIONS



Figure 3-7. NHOLD Signal Used to Lengthen SC/MP I/O Operation

The NHOLD signal causes the I/O cycle to be lengthened in increments of 1/2 microcycle. There is no limit on the duration of the NHOLD signal.

### THE SC/MP HALT STATE

The SC/MP Halt state differs from those described for other microprocessors in this book in one significant and unusual way — execution of the SC/MP Halt instruction does not cause the CPU to enter the Halt state. Instead, when SC/MP executes a Halt instruction, it simply outputs the H-Flag status on data line 7 (DB7) when NADS is true.

In order to actually place the CPU in the Halt state the CONT input signal to the CPU must be forced low.

You can use external logic to force CONT low either in response to the H-Flag or completely asynchronously: whenever a low is applied to the CONT input, the CPU enters the Halt state upon completion of the current instruction. Figure 3-8 shows a circuit that can be used to force the CPU into the Halt state when a Halt instruction is executed. When DB7 is output high while NADS is true, it indicates the Halt instruction has been executed: this combination of events is used to generate a low-going pulse (NHALT) which is applied to the clear (CLR) input of a D flip-flop. The Q output of the flip-flop is applied to the CONT input signal to the CPU. Thus, whenever a Halt instruction is executed, the CPU will be forced into the Halt mode. CPU operation is resumed when the start switch S1 is momentarily closed to the NO contacts. This causes a positive-going clock pulse that sets the D flip-flop and returns the CONT input to the CPU high.



Figure 3-8. Circuit to Cause Programmed Halt for SC/MP CPU

While the SC/MP CPU is in the Halt state, the address and data lines are floated. The CPU remains in the Halt state until the CONT input is returned high. There is one exception to this rule: if an interrupt request is detected while in the Halt state, the CPU responds to the interrupt by executing a single instruction. Thus, you could use the first instruction of your interrupt service routine to reset the external CONT input signal, and thereby terminate the Halt state.

## SC/MP INTERRUPT PROCESSING

The SENSEA input signal to the SC/MP CPU serves as the interrupt request line if bit 3 of the CPU's Status register is set to "1". Bit 3 of the Status register is the Interrupt Enable (IE) flag and can be set using the Interrupt Enable (IEN) instruction.

When interrupts are enabled, the SENSEA input line is tested at the beginning of every instruction fetch operation as shown in Figure 3-9. If SENSEA is high, the IE flag is reset, and the contents of the Program Counter are exchanged with the contents of Pointer Register 3. In other words, Pointer Register 3 must contain the beginning address of your interrupt service routine. The return address, that is, the address at which program execution must continue after the interrupt request has been serviced, is now held in Pointer Register 3. Thus, the return-from-interrupt sequence would be to set the IE flag high and then once again exchange the contents of the Program Counter and Pointer Register 3 to resume the main program.

Let us examine some of the special requirements and limitations of this interrupt processing sequence. First, before enabling interrupts you must load Pointer Register 3 (P3) with the beginning address of your interrupt service routine. Notice that the contents of P3 should actually be one less than the beginning address of the first instruction since the new contents of the Program Counter will be incremented prior to fetching the instruction.



Figure 3-9. SC/MP Interrupt Instruction Fetch Process

Next, if you compare the interrupt response of SC/MP to those of most other microcomputers or to our hypothetical microcomputer described in Volume I, you will notice that the following two steps are missing:

- 1) There is no interrupt acknowledge signal.
- 2) None of the SC/MP register contents are saved.

In an SC/MP system, both of these functions are left up to your interrupt service routine. For example, you might provide an interrupt acknowledge indication using one of the CPU Flag outputs or by outputting a specially defined address. If it is necessary to save the contents of the SC/MP registers, this must also be done by your program using a software stack or a predefined area of read/write memory. You must also provide the instructions necessary to restore the contents of any "saved" registers since, as we shall discuss next, the return-from-interrupt sequence used by SC/MP is also quite primitive.

The final unusual aspect of the SC/MP interrupt system is that there is no Return-From-Interrupt instruction. Instead, as we mentioned earlier, the last instruction of your interrupt service routine must be an XPPC P3 instruction which restores the original contents of the Program Counter by exchanging the contents of PC and P3. This might seem quite straightforward, but it will require some special programming considerations.

**SC/MP RETURN-FROM-INTERRUPT TECHNIQUE**

The XPPC P3 instruction, which we just mentioned, restores the correct value to the Program Counter—but what about P3? Remember that P3 is always supposed to point to the beginning address (minus 1) of your interrupt service routine (if interrupts are enabled). Yet, the interrupt response sequence we just described loaded the contents of P3 into the Program Counter (PC) and then incremented the PC. And, as our interrupt service routine is executed, the contents of PC will be incremented each time an instruction is executed. Thus, when we complete the interrupt service routine and again exchange the contents of PC and P3, we will be loading P3 (our service routine pointer) with a value that has been altered. So, the problem is—how do we perform an interrupt service routine and ensure that P3 will contain the correct pointer value upon completion of the service routine?

The solution to this quandary requires a closer examination of interrupt service routines. A typical interrupt service routine might consist of three primary segments. One segment would be the entry point to the routine and would include such things as register save operations: let us call this segment "S1". The second segment would be the instruction sequence which actually services the device which requested the interrupt: we will call this segment "S2". The final segment would restore registers and other system elements to their 'pre-interrupt' values, and then return control to the main (interrupted) program: we will call this segment "S3". Thus, the entire interrupt recognition/response/return sequence might be represented as follows:

(We will use arbitrary addresses to simplify our discussion.)



This sequence causes a proper return to the interrupted program but, as we have discussed, does not leave us with our desired pointer value (053F in this example) in P3. The solution requires us to rearrange the segments of our interrupt service routine as follows:



Now, our entry point for the interrupt service routine is still 0540, so we load P3 with a pointer of 053F as before. However, by rearranging the segments and adding a Jump instruction at the end of the second segment (S2), we can have the last instruction of our interrupt service routine located at 053F. When this instruction (XPPC P3) is executed the following operation occurs:



We have now returned control to the main program and we have also restored the contents of P3 to the required pointer value to allow servicing of subsequent interrupts.

**One final point: the CPU's interrupt processing sequence resets the Interrupt Enable (IE) flag to zero. To allow subsequent interrupts to be serviced, your service routine must set the IE flag to "1".** This would typically be the next to last instruction of your interrupt service routine. So the sequence of instructions would be:

|      |                                      |
|------|--------------------------------------|
| IEN  | SET IE FLAG TO 1                     |
| XPPC | RETURN TO MAIN PROGRAM               |
| P3   | FIRST INSTRUCTION OF SERVICE ROUTINE |

## SC/MP DMA AND MULTIPROCESSOR OPERATIONS

Because the SC/MP CPU is a low-cost, low-performance microprocessor, its designers anticipated that it would frequently be used in systems which include other devices of equal or greater intelligence and processing power. Accordingly, **logic is provided on the CPU which provides a simple yet effective method of operating in systems where the System Busses are shared.** The logic required to implement a shared-bus system is essentially the same regardless of whether the purpose is to allow another device (such as a high-speed peripheral) to perform a DMA operation or if it is required because there is more than one CPU operating in the system. There are a few rather subtle differences between the techniques used, and we shall point these out as we proceed with our discussion.

As we have already described, **three SC/MP signals are dedicated to bus-sharing activities:** BREQ is an input/output signal which serves both as a bus-request and bus-busy signal, ENIN is effectively a bus-grant input signal, and ENOUT is an output signal that can be used to establish priorities in daisy chained configurations. Let us begin by seeing how SC/MP might operate in a system which includes a DMA controller.

### SC/MP BUS-SHARING CONTROL SIGNALS

**The DMA logic provided by the SC/MP CPU is nearly the inverse of that provided by other microcomputers in this book.** Most CPUs assume that they always have control of the System Busses. If another system device requires access to the System Busses, it makes a request to a DMA controller which, in turn, inputs a signal to the CPU requesting that the CPU yield control of the busses. When the CPU has no need for the bus, it outputs an acknowledgement signal to the DMA controller which then sends a bus-grant signal to the requesting device. **The SC/MP CPU, however, competes for the System Busses just as any other system device:** it never assumes that it has control of the busses. Thus, there are really no special considerations that need be accounted for when designing DMA logic for systems that include the SC/MP CPU. The DMA controller can treat the CPU as simply another device (no different from a peripheral device, although the CPU might be assigned to a higher priority) that requires access to the System Busses. Therefore, a typical DMA application would only require the use of the SC/MP BREQ and ENIN signals as shown in Figure 3-10.



Figure 3-10. Using SC/MP in a System with Direct Memory Access

Now let us look at how the SC/MP bus-sharing logic might be used in a multiprocessor system. It is in such a system that the CPU's bus-sharing logic can be most appreciated. First, let us restate the rules which govern the conditions of the SC/MP ENOUT output signal.

- 1) ENOUT is always low while SC/MP is actually using the System Busses; that is, while the ENIN input and BREQ output are both high.
- 2) When SC/MP is not using the System Busses (either BREQ output or ENIN input low), ENOUT is held in the same state as the ENIN input.

The effect of these rules may not be immediately obvious. To see how they function to simplify bus-sharing, let us construct a simple multiprocessor system consisting of two SC/MP CPUs and some memory.



**There are three possible situations that can exist with this configuration.**

- 1) If one of the CPUs is currently using the bus, it is outputting a high on the BREQ line. This automatically prevents the other CPU from vying for the bus until the BREQ line goes low upon completion of the bus access by the first CPU.
- 2) If neither CPU is currently using the bus, the BREQ line is low. If one of the CPUs requires bus access, it can now output a high on the BREQ line. Once again, this will prevent the other CPU from subsequently vying for the bus.

Thus far there would seem to be no need for any control signals except the bidirectional BREQ line. However, it is when the third possible situation is encountered that the ENIN and ENOUT signals are needed.

- 3) If both CPUs require bus access at the same time, each will test the BREQ line and, finding it low, will output a high on BREQ. This simultaneous occurrence of requests for bus access is resolved by using the ENIN and ENOUT signals. The operation of these bus access signals to resolve this situation can be illustrated as follows:



When the BREQ line goes high it applies a high input to the ENIN1 input of SC/MP #1. Since BREQ1 is also high at this time, SC/MP #1 now has access to the bus and it outputs a low on ENOUT1. This is applied to the ENIN2 input to SC/MP #2 and thus denies bus access by SC/MP #2. Notice that SC/MP #2 holds its BREQ2 output signal high even though its request has not yet been granted. When SC/MP #1 has finished its bus access, the BREQ1 output returns low. However, since the BREQ2 output is still high, ENIN1 remains high. This condition of BREQ1 low and ENIN1 high causes the ENOUT1 signal to go high, thus enabling SC/MP #2.

**This arrangement allows the first CPU in a daisy-chain string to have the highest priority for bus access and also automatically allows any other CPU to gain immediate access to the busses whenever they become available.**

Now that we have described the way in which the bus-sharing logic of the SC/MP CPU can be used in a multiprocessor system, let us continue just a bit further and describe a few more common considerations that you must deal with if you are designing a multiprocessor system. We will limit this discussion primarily to hardware and control considerations since programming in a multiprocessor system can become quite complex and is beyond the scope of this book. However, the techniques we will describe here are the first step towards simplifying the programming for such a system.

#### SC/MP CONTROL TECHNIQUES IN MULTIPROCESSOR APPLICATIONS

**The first operation that you must deal with in any microcomputer system is initialization of the system. This operation requires some additional thought when designing a multiprocessor system.** Typically, one CPU will be the primary or controlling CPU: how do you ensure that this CPU has control of the system when power is first applied?

**Figure 3-11 illustrates an easy method of establishing system control upon initialization.** The system reset signal (NRST), which is generated at power-up, is applied to SC/MP #1. The FLAG1 output from SC/MP #1 is then applied to the NRST input of SC/MP #2. Since the FLAG1 line is connected to a bit in the CPU's Status register which is set to zero on power-up, SC/MP #2 will be held in a reset condition until SC/MP #1 executes an instruction which sets that bit (and thus, the FLAG1 output line) high.

Of course, this method requires the FLAG1 output from SC/MP #1 to be dedicated to this initialization operation. If this is a problem, you could use two separate initialization circuits with, for example, the RC time constant for the SC/MP #2 circuitry being greater than that of the circuitry for SC/MP #1. This approach, however, does not provide the positive control of the first method we described.



Figure 3-11. One Method of Initializing an SC/MP Multiprocessor System

Once the multiprocessor system has been initialized and is running, the bus-sharing logic that we've already described will resolve contentions between the CPUs as far as access to System Busses is concerned. However, **there might be situations where we want to assure that one of the CPUs will be guaranteed immediate and extended access to the System Busses. This can also be accomplished quite easily with SC/MP as illustrated in Figure 3-12.**



Figure 3-12. Forcing the Halt State in an SC/MP Multiprocessor System

In this illustration the FLAG 1 output of SC/MP #2 is inverted and applied to the CONT input of SC/MP #1. Now, if the F1 bit in the Status register of SC/MP #2 is set to "1", SC/MP #1 will be forced into the Halt state and is effectively removed from the system until the F1 bit is reset under program control.

## THE SC/MP RESET OPERATION

An NRST low signal input to the SC/MP CPU initializes the microprocessor. While NRST is low, any in-process operations are automatically aborted and the CPU's strobes and address and data lines are floated. NRST must be held low for a minimum of two microcycles. After NRST goes high again, this is what happens:

- 1) All of the programmable registers are cleared.
- 2) The first instruction is fetched from memory location 000116.
- 3) The Bus Request (BREQ) for this first input/output operation occurs within 6-1/2 microcycles after NRST goes high.

The NRST signal can be used at any time to reset the CPU, and must be used following power-up since SC/MP may power up in a random condition. After power has first been applied to the CPU, you should allow approximately 100 milliseconds for the oscillator and internal clocks to stabilize before applying the NRST signal.

## SC/MP SERIAL INPUT/OUTPUT OPERATIONS

The SC/MP CPU not only has two of its 40 pins designated primarily for serial input/output operations, it also dedicates one instruction from its rather limited instruction set solely to serial I/O. Allocation of this amount of a CPU's resources for this purpose would seem unwarranted with most microprocessors; however, keep in mind that SC/MP is a very low-cost device and intended primarily for use in slow-speed applications. It is quite likely that SC/MP will frequently be used to transfer data serially, so it is therefore not only reasonable but advantageous to provide straightforward methods of performing these operations. Let us look now at how this is done with SC/MP.

In our description of SC/MP's programmable registers, we described the Extension (E) register as an 8-bit register. When the E register is used for serial I/O, it is actually a 9-bit register with connections to two of the device pins as shown in the figure below.



When the SC/MP SIO (Serial Input/Output) instruction is executed, the contents of the Extension register are shifted right one bit position: the previous contents of bit 0 are loaded into the output latch and output on the SOUT pin, and the level (1 or 0) present at the SIN pin is loaded into bit 7 of the Extension register. The Extension register can be loaded from, and its contents can be transferred to the Accumulator. A typical serial output operation would thus consist of:

- 1) Loading the Accumulator with the data byte that is to be transmitted.
- 2) Transferring the contents of the Accumulator into the Extension register.
- 3) Performing eight SIO instructions to shift the contents of the Extension register into the output latch and out onto the SOUT pin.

Of course, this sequence does not cover all the programming requirements for serial data transfers. For example, your program must provide some method of timing the bit transmission. This is easily accomplished with SC/MP by using the Delay (DLY) instruction, which can generate variable time delays ranging from 13 to 131,593 microcycles. For asynchronous operations, one of the SC/MP Flags which are connected to device pins can be pulsed each time a new bit is shifted out (or in) and one of the sense conditions inputs (SENSEA or SENSEB) can be tested to detect bit received/ready.

## THE SC/MP INSTRUCTION SET

Table 3-4 lists the SC/MP instruction set.

Memory reference instructions are shown as having either full or limited addressing capability. Full addressing capability is identified in the operand as follows:



Thus, the real options associated with full addressing capability are:

- DISP Direct, program relative addressing
- DISP(X) Direct, indexed addressing
- @DISP(X) Auto-increment or auto-decrement addressing

Limited addressing capabilities do not include the auto-increment and auto-decrement feature. The operand field for instructions with limited addressing capability is shown as follows:



The serial I/O instruction inputs serial data via the high-order bit of the Extension register, and/or outputs serial data via the low-order bit of the Extension register.

The serial I/O instruction works as a one-bit right shift of the Extension register contents, with bit 0 being shifted to the SOUT pin and the SIN pin being shifted into bit 7. This has been illustrated along with the logic description.

It is worth noting that SC/MP has no Jump-to-Subroutine instruction; rather, the XPPC instruction is used to exchange the contents of the Program Counter with the contents of a Pointer register. In very simple applications (and those are the applications for which SC/MP is intended) this is a very effective scheme. Providing subroutines are not nested, a subroutine's beginning address may be stored in a Pointer register, then execution of XPPC moves the subroutine's starting address to the Program Counter, thereby executing the subroutine — but at the same time, the Program Counter contents are stored in the Pointer register, thus preserving the return address. At the conclusion of the subroutine, execution of another XPPC instruction is all that is needed to return from the subroutine. The only penalty paid is that one Pointer register is out of service while the subroutine is being executed. If all Pointer registers are used by the subroutine, or if subroutines are nested, then the return address which is stored in the Pointer register must be saved in memory. In these more complicated applications, one of the Pointer registers will probably be used as a Stack Pointer, and addresses will be saved on the Stack.

This type of subroutine access, while it may appear primitive to a minicomputer programmer, is very effective in simple microcomputer applications.

The following symbols are used in Table 3-4.

- AC Accumulator
- C Carry status
- DATA An 8-bit binary data unit
- DISP An 8-bit signed binary displacement
- E The Extension register

|          |                                                                                                                                                                                                                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EA       | Effective address, determined by the instruction. Options are:<br>DISP EA is [PC] + DISP<br>DISP(X) EA is [X] + DISP<br>@DISP(X) EA is [X] if DISP $\geq 0$ .<br>EA is [X] + DISP if DISP $< 0$ ;<br>in both cases [X] $\leftarrow$ [X] + DISP after EA is calculated.                  |
| E<i>     | The ith bit of the Extension register                                                                                                                                                                                                                                                   |
| IE       | Interrupt Enable                                                                                                                                                                                                                                                                        |
| O        | Overflow status                                                                                                                                                                                                                                                                         |
| PC       | Program Counter                                                                                                                                                                                                                                                                         |
| X        | One of the three Pointer registers                                                                                                                                                                                                                                                      |
| SIN      | Serial Input pin                                                                                                                                                                                                                                                                        |
| SOUT     | Serial Output pin                                                                                                                                                                                                                                                                       |
| SR       | Status register                                                                                                                                                                                                                                                                         |
| Z        | Zero status                                                                                                                                                                                                                                                                             |
| @        | Auto-increment flag                                                                                                                                                                                                                                                                     |
| X<y,z>   | Bits y through z of a Pointer register. For example, P3<7,0> represents the low-order byte of Pointer register P3.                                                                                                                                                                      |
| @DISP(X) | This designates the available addressing modes for the SC/MP, as described above. In all three of the addressing modes, if -128 is specified for DISP, the contents of the Extension register are used instead of DISP.                                                                 |
| [ ]      | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified. |
| [[ ]]    | Implied memory addressing; the contents of the memory location designated by the contents of a register.                                                                                                                                                                                |
| Λ        | Logical AND                                                                                                                                                                                                                                                                             |
| ∨        | Logical OR                                                                                                                                                                                                                                                                              |
| ⊻        | Logical Exclusive-OR                                                                                                                                                                                                                                                                    |
| ←        | Data is transferred in the direction of the arrow.                                                                                                                                                                                                                                      |
| ↔        | Data is exchanged between the two locations designated on either side of the arrow.                                                                                                                                                                                                     |

Under the heading of STATUSES in Table 3-4, an X indicates statuses which are modified in the course of the instruction's execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

Table 3-4. SC/MP Instruction Set Summary

| TYPE                                                | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |  |  |  | OPERATION PERFORMED                                                                                                                                                                                                                 |
|-----------------------------------------------------|----------|------------|-------|----------|---|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                     |          |            |       | C        | O |  |  |  |                                                                                                                                                                                                                                     |
| I/O                                                 | SIO      |            | 1     |          |   |  |  |  | [E <i-1>] → [E <i>]<br>SOUT ← [E0]<br>[E7] ← SIN<br>Shift the Extension register right one bit. Shift bit 0 of the Extension register to the output pin SOUT. Shift the data at input pin SIN into bit 7 of the Extension register. |
| PRIMARY<br>MEMORY REF<br>AND I/O                    | LD       | @ DISP(X)  | 2     |          |   |  |  |  | [AC] ← [EA]<br>Load Accumulator from addressed memory location.                                                                                                                                                                     |
| SECONDARY MEMORY<br>REFERENCE<br>AND MEMORY OPERATE | ST       | @ DISP(X)  | 2     |          |   |  |  |  | [EA] ← [AC]<br>Store Accumulator contents in addressed memory location.                                                                                                                                                             |
|                                                     | ADD      | @ DISP(X)  | 2     | X        | X |  |  |  | [AC] ← [AC] + [EA] + [C]<br>Add binary to Accumulator the addressed memory location's contents with Carry.                                                                                                                          |
|                                                     | DAD      | @ DISP(X)  | 2     | X        |   |  |  |  | [AC] ← [AC] + [EA] + [C]<br>Add decimal to Accumulator the addressed memory location's contents with Carry.                                                                                                                         |
|                                                     | CAD      | @ DISP(X)  | 2     | X        | X |  |  |  | [AC] ← [AC] + [EA] + [C]<br>Add complement of addressed memory location's contents with Carry to Accumulator.                                                                                                                       |
|                                                     | AND      | @ DISP(X)  | 2     |          |   |  |  |  | [AC] ← [AC] ∧ [EA]<br>AND Accumulator with addressed memory location's contents.                                                                                                                                                    |
|                                                     | OR       | @ DISP(X)  | 2     |          |   |  |  |  | [AC] ← [AC] ∨ [EA]<br>OR Accumulator with addressed memory location's contents.                                                                                                                                                     |
|                                                     | XOR      | @ DISP(X)  | 2     |          |   |  |  |  | [AC] ← [AC] ⊕ [EA]<br>Exclusive-OR Accumulator with addressed memory location's contents.                                                                                                                                           |
|                                                     | ILD      | @ DISP(X)  | 2     |          |   |  |  |  | [EA] ← [EA] + 1; [AC] ← [EA]<br>Increment addressed memory location's contents, then load into Accumulator.                                                                                                                         |
| IMMEDIATE<br>OPERATE                                | DLD      | @ DISP(X)  | 2     |          |   |  |  |  | [EA] ← [EA] - 1; [AC] ← [EA]<br>Decrement addressed memory location's contents, then load into Accumulator.                                                                                                                         |
|                                                     | LDI      | DATA       | 2     |          |   |  |  |  | [AC] — DATA<br>Load immediate into Accumulator.                                                                                                                                                                                     |
| IMMEDIATE OPERATE                                   | ADI      | DATA       | 2     | X        | X |  |  |  | [AC] ← [AC] + DATA + [C]<br>Add binary immediate. Add Carry to result.                                                                                                                                                              |
|                                                     | DAI      | DATA       | 2     | X        |   |  |  |  | [AC] ← [AC] + DATA + [C]<br>Decimal add immediate. Add Carry to result.                                                                                                                                                             |
|                                                     | CAI      | DATA       | 2     | X        | X |  |  |  | [AC] ← [AC] + DATA + [C]<br>Add the contents of the Accumulator to the complement of the immediate data value. Add Carry to result.                                                                                                 |
|                                                     | ANI      | DATA       | 2     |          |   |  |  |  | [AC] ← [AC] ∧ DATA<br>AND immediate.                                                                                                                                                                                                |

Table 3-4. SC/MP Instruction Set Summary (Continued)

| TYPE                             | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |  |  |  | OPERATION PERFORMED                                                                                                                                   |
|----------------------------------|----------|------------|-------|----------|---|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  |          |            |       | C        | O |  |  |  |                                                                                                                                                       |
| IMMEDIATE OPERATE<br>(CONTINUED) | ORI      | DATA       | 2     |          |   |  |  |  | [AC]—[AC] V DATA<br>OR immediate.<br>[AC]—[AC] V DATA<br>Exclusive-OR immediate.                                                                      |
|                                  | XRI      | DATA       | 2     |          |   |  |  |  |                                                                                                                                                       |
| JUMP                             | JMP      | DISP(X)    | 2     |          |   |  |  |  | [PC]—EA<br>Unconditional jump to effective address.                                                                                                   |
| JUMP ON<br>CONDITION             | JP       | DISP(X)    | 2     |          |   |  |  |  | If [AC] $\geq 0$ ; [PC] — EA<br>If the Accumulator contents are greater than 0, jump to effective address.                                            |
|                                  | JZ       | DISP(X)    | 2     |          |   |  |  |  | If [AC] = 0; [PC] — EA<br>If the Accumulator contents equal 0, jmp to effective address.                                                              |
|                                  | JNZ      | DISP(X)    | 2     |          |   |  |  |  | If [AC] = 0; [PC] — EA<br>If the Accumulator contents are not 0, jump to effective address.                                                           |
| REGISTER-REGISTER MOVE           | LDE      |            | 1     |          |   |  |  |  | [AC]—[E]<br>Load the contents of the Extension register into the Accumulator.                                                                         |
|                                  | XPAL     | X          | 1     |          |   |  |  |  | [AC]—>[X <7,0>]<br>Exchange the contents of the Accumulator with the low order byte of the specified Pointer register.                                |
|                                  | XPAH     | X          | 1     |          |   |  |  |  | [AC]—>[X <15,8>]<br>Exchange the contents of the Accumulator with the high order byte of the specified Pointer register.                              |
|                                  | XPPC     | X          | 1     |          |   |  |  |  | [PC]—>[X]<br>Exchange the contents of the Program Counter with those of the specified Pointer register.                                               |
|                                  | XAE      |            | 1     |          |   |  |  |  | [AC]—>[E]<br>Exchange the contents of the Accumulator with those of the Extension register.                                                           |
| REGISTER-REGISTER OPERATE        | ADE      |            | 1     | X        | X |  |  |  | [AC]—[AC] + [E] + [C]<br>Add binary the contents of the Accumulator and the contents of the Extension register. Add Carry to this result.             |
|                                  | DAE      |            | 1     | X        |   |  |  |  | [AC]—[AC] + [E] + [C]<br>Add decimal the contents of the Extension register to those of the Accumulator. Add Carry to this result.                    |
|                                  | CAE      |            | 1     | X        | X |  |  |  | [AC]—[AC] + [Ē] + [C]<br>Add binary the contents of the Accumulator and the complement of the Extension register contents. Add Carry to this result. |
|                                  | ANE      |            | 1     |          |   |  |  |  | [AC]—[AC] $\wedge$ [E]<br>AND the contents of the Accumulator with those of the Extension register.                                                   |

Table 3-4. SC/MP Instruction Set Summary (Continued)

| TYPE                                     | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |  |  |  |  | OPERATION PERFORMED                                                                                                                                                                                                              |
|------------------------------------------|----------|------------|-------|----------|---|--|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          |          |            |       | C        | O |  |  |  |  |                                                                                                                                                                                                                                  |
| REGISTER-REGISTER OPERATE<br>(CONTINUED) | ORE      |            | 1     |          |   |  |  |  |  | [AC]—[AC] V [E]<br>OR the contents of the Accumulator with those of the Extension register.                                                                                                                                      |
|                                          | XRE      |            | 1     |          |   |  |  |  |  | [AC]—[AC] V [E]<br>Exclusive-OR the contents of the Accumulator with those of the Extension register.                                                                                                                            |
| REGISTER OPERATE                         | SR       |            | 1     |          |   |  |  |  |  | <br>Shift Accumulator contents right one bit. The high order bit becomes a 0. The low order bit is lost.                                      |
|                                          | SRL      |            | 1     |          |   |  |  |  |  | <br>Shift Accumulator contents right one bit. The Carry bit is shifted into the high order bit of the Accumulator. The low order bit is lost. |
|                                          | RR       |            | 1     |          |   |  |  |  |  | <br>Rotate Accumulator contents right one bit. Rotate the low order bit of the Accumulator into the high order bit.                           |
|                                          | RRL      |            | 1     |          |   |  |  |  |  | <br>Rotate Accumulator contents right through Carry.                                                                                          |
| INTERRUPT                                | DINT     |            | 1     |          |   |  |  |  |  | [IE]—0<br>Disable interrupts.                                                                                                                                                                                                    |
|                                          | IEN      |            | 1     |          |   |  |  |  |  | [IE]—1<br>Enable interrupts.                                                                                                                                                                                                     |
| STATUS                                   | CCL      |            | 1     | 0        |   |  |  |  |  | [C]—0<br>Clear Carry.                                                                                                                                                                                                            |
|                                          | SCL      |            | 1     | 1        |   |  |  |  |  | [C]—1<br>Set Carry.                                                                                                                                                                                                              |
|                                          | CSA      |            | 1     |          |   |  |  |  |  | [AC]—[SR]<br>Load the contents of the Status register into the Accumulator.                                                                                                                                                      |
|                                          | CAS      |            | 1     |          |   |  |  |  |  | [SR]—[AC]<br>Load the contents of the Accumulator into the Status register.                                                                                                                                                      |
|                                          | HALT     |            | 1     |          |   |  |  |  |  | Pulse the H-Flag                                                                                                                                                                                                                 |
|                                          | NOP      |            | 1     |          |   |  |  |  |  | No Operation.                                                                                                                                                                                                                    |
|                                          | DLY      | DATA       | 1     |          |   |  |  |  |  | Delays CPU for a number of cycles equal to:<br>$13 + 2(\text{AC}) + 2\text{DATA} + 2^9\text{DATA}$                                                                                                                               |

The following symbols are used in Table 3-5:

aa Two binary digits designating the Pointer register:

- 00 Program Counter
- 01 Pointer Register 1
- 10 Pointer Register 2
- 11 Pointer Register 3

m One binary digit specifying address mode:

- 0 Program Relative or Indexed
- 1 Immediate or Auto-increment or Auto-decrement

PP Two hexadecimal digits representing an 8-bit, signed displacement

QQ Two hexadecimal digits representing 8 bits of immediate data

Where two numbers are given — for example, 9/11, the first is execution time when no jump is taken; the second is execution time when there is a jump.

Table 3-5. SC/MP Instruction Set Object Codes and Execution Times

| INSTRUCTION  | OBJECT CODE    | BYTES | MACHINE CYCLES |
|--------------|----------------|-------|----------------|
| ADD @DISP(X) | 11110maa<br>PP | 2     | 19             |
| ADE          | 70             | 1     | 7              |
| ADI DATA     | F4             |       |                |
|              | QQ             |       |                |
| AND @DISP(X) | 11010maa<br>PP | 2     | 18             |
| ANE          | 50             | 1     | 6              |
| ANI DATA     | D4             | 2     | 10             |
|              | QQ             |       |                |
| CAD DISP(X)  | 11111maa<br>PP | 2     | 20             |
| CAE          | 78             | 1     | 8              |
| CAI DATA     | FC             | 2     | 12             |
|              | QQ             |       |                |
| CAS          | 07             | 1     | 6              |
| CCL          | 02             | 1     | 5              |
| CSA          | 06             | 1     | 5              |
| DAD @DISP(X) | 11101maa       | 2     | 23             |
| DAE          | 68             | 1     | 11             |
| DAI DATA     | EC             | 2     | 15             |
|              | QQ             |       |                |
| DINT         | 04             | 1     | 6              |
| DLY DATA     | 101110aa<br>PP | 2     | 22             |
| DLY DISP     | 4F<br>PP       | 2     | 13-131, 593*   |
| HALT         | 00             | 1     | 8              |
| IEN          | 05             | 1     | 6              |
| ILD DISP(X)  | 101010aa<br>PP | 2     | 22             |
| JMP DISP(X)  | 100000aa<br>PP | 2     | 11             |

\*Delay time depends on the value of DATA.

| INSTRUCTION  | OBJECT CODE    | BYTES | MACHINE CYCLES |
|--------------|----------------|-------|----------------|
| JNZ DISP(X)  | 100011aa<br>PP | 2     | 9/11           |
| JP DISP(X)   | 100001aa<br>PP | 2     | 9/11           |
| JZ DISP(X)   | 100010aa<br>PP | 2     | 9/11           |
| LD @DISP(X)  | 11000maa<br>PP | 2     | 18             |
| LDE          | 40             | 1     | 6              |
| LDI DATA     | C4             | 2     | 10             |
|              | QQ             |       |                |
| NOP          | 08             | 1     | 5-10           |
| OR @DISP(X)  | 11011maa<br>PP | 2     | 18             |
| ORE          | 58             | 1     | 6              |
| ORI DATA     | DC             | 2     | 10             |
|              | QQ             |       |                |
| RR           | 1E             | 1     | 5              |
| RRL          | 1F             | 1     | 5              |
| SCL          | 03             | 1     | 5              |
| SIO          | 19             | 1     | 5              |
| SR           | 1C             | 1     | 5              |
| SRL          | 1D             | 1     | 5              |
| ST @DISP(X)  | 11001maa<br>PP | 2     | 18             |
| XAE          | 01             | 1     | 7              |
| XOR @DISP(X) | 11100maa<br>PP | 2     | 18             |
| XPAH X       | 001101aa       | 1     | 8              |
| XPAL X       | 001100aa       | 1     | 8              |
| XPPC X       | 001111aa       | 1     | 7              |
| XRE          | 60             | 1     | 6              |
| XRI DATA     | E4<br>QQ       | 2     | 10             |

## THE BENCHMARK PROGRAM

For SC/MP, the benchmark program looks like this:

|      |             |                                                  |
|------|-------------|--------------------------------------------------|
| LD   | TABLE(P3)   | LOAD HIGH BYTE OF FIRST FREE TABLE BYTE          |
| XPAH | P1          | ADDRESS MOVE TO PR1 HIGH-ORDER BYTE              |
| LD   | TABLE+1(P3) | REPEAT FOR LOW-ORDER BYTE                        |
| XPAL | P1          |                                                  |
| LDI  | IOHI        | LOAD HIGH BYTE OF I/O BUFFER BASE ADDRESS        |
| XPAH | P2          | MOVE TO PR2 HIGH-ORDER BYTE                      |
| LDI  | IOLO        | REPEAT FOR LOW-ORDER BYTE                        |
| XPAL | P2          |                                                  |
| LOOP | LD @0(P2)   | LOAD NEXT BYTE FROM I/O BUFFER<br>AUTO-INCREMENT |
| ST   | @0(P1)      | STORE IN NEXT FREE TABLE BYTE                    |
| DLD  | IOCNT(P3)   | DECREMENT I/O BUFFER COUNT AND LOAD              |
| JNZ  | LOOP        | RETURN TO LOOP IF NOT ZERO                       |
| XPAL | P1          | LOAD LOW-ORDER TABLE ADDRESS INTO A              |
| ST   | TABLE+1(P3) | SAVE IN FIRST FREE TABLE BYTE ADDRESS            |

The SC/MP benchmark program makes the following assumptions.

The address of the first free table byte is not stored at the beginning of the table; rather, it is stored in two bytes of a data area, addressed by Pointer Register 3, plus a displacement. The addresses of these two bytes are given by the displacement TABLE and TABLE+1.

It is assumed that TABLE begins at a memory address with 0s for the low order eight binary digits (as for the F8 benchmark program); therefore, the contents of the data area byte with address TABLE+1(PC3) becomes the displacement to the first free byte of TABLE. Assuming that TABLE has a maximum length of 256 bytes, it is only necessary at the end of the data move operation to store a new byte address into TABLE+1, in order to update the address of the first free table byte. This scheme is illustrated below.

The I/O buffer beginning address is stored in two immediate instructions, which load the two halves of the I/O buffer beginning address into the Accumulator; each half is then exchanged into a Pointer register.

The SC/MP benchmark program assumptions may be illustrated as follows:



## SUPPORT DEVICES FOR THE SC/MP CPU

**SC/MP support devices are general-purpose and are therefore described in Volume III. You may also use standard off-the-shelf buffers, bidirectional drivers, RAM and ROM to implement any supporting functions needed.** Figure 3-13 illustrates an SC/MP system and the type of supporting devices that might be needed. Notice that the buffers, latches and I/O ports are all indicated by dotted lines. We have done this because it is quite feasible that some SC/MP systems might consist only of the CPU and a small amount of memory. In such a system, there would not necessarily be any need for buffering the SC/MP input/output lines, nor demultiplexing status and page-select bits from the Data Bus. Many systems, however, will require some of the supporting devices indicated by Figure 3-13. In the remainder of this chapter we will briefly describe how some of the commonly required support functions for SC/MP can be implemented using both standard off-the-shelf devices and devices from other microcomputer families.



Figure 3-13. An SC/MP System Showing Typical Support Devices that may be Required

As we mentioned earlier, the SC/MP output lines can each drive one TTL load. Some systems, especially those which utilize low-power external devices, may not require any buffering. **When buffering is needed, it can be provided using standard logic devices. The only area that requires any special attention is when you are buffering the data lines: since these lines are used both for input and output of data, you must provide bidirectional control of these buffering devices.** Figure 3-14 shows one easy method of implementing bidirectional buffers for the SC/MP data lines using 8216 bidirectional bus drivers. (The 8216 is a support device from the 8080 family and is described in Chapter 4.) The SC/MP NRDS signal is inverted and used to provide directional control of the buffers. When the SC/MP is performing a read operation, NRDS is output low: this causes the contents of the system Data Bus to be gated through the buffers and onto the SC/MP data lines. At all other times, NRDS is high and whatever is on the SC/MP data lines is passed onto the system Data Bus.

BUFFERING  
SC/MP  
BUSSES

If you need to use the four most significant address bits (AD12 - AD15) for page select functions or if you are going to make use of the I/O cycle status information that SC/MP outputs; you must demultiplex this information from the SC/MP data lines. The most straightforward way of doing this is to use D-type flip-flops or data registers with the SC/MP NADS signal as the clock pulse. Here are some standard 7400 family devices that might be used:

- 7475 Double 2-Bit Gated Latches with Q and  $\bar{Q}$  Outputs
- 7477 Double 2-Bit Gated Latches with Q Output Only
- 74100 Double 4-Bit Gated Latches
- 74166 Dual 4-Bit Gated Latches with Clear
- 74174 Hex D-Type Flip-Flops with Common Clock and Clear
- 74176 Quad D-Type Flip-Flops with Common Clock and Clear

**DEMULTIPLEXING  
THE SC/MP  
DATA BUS**

Some of these devices require that the NADS signal be inverted to provide the necessary clocking signal. Remember, though, that the SC/MP address and status information is valid during both the leading edge (high-to-low transition) and trailing edge (low-to-high transition) of NADS: this generally simplifies the demultiplexing operation.

**Another method of demultiplexing the address bits from the data lines is to use address decoding devices that are clocked by the NADS signal and provide latched outputs. These latched outputs can then be used as the page select signals (or device select signals) during I/O cycles.**



Figure 3-14. SC/MP Data Lines Buffered Using 8216 Devices.

## **USING OTHER MICROCOMPUTER SUPPORT DEVICES WITH THE SC/MP CPU**

There is nothing to prevent SC/MP from using support devices from other microcomputer "families". We have already shown one simple example — the use of 8216 bidirectional bus drivers to buffer the SC/MP data lines. The SC/MP CPU provides numerous control signals which allow general-purpose microcomputer support devices to be included in an SC/MP system. We will now describe a couple of specific examples of how this can be done — these examples will serve as guidelines for interfacing SC/MP to other support devices.

The Microprocessor Interface Latch Element (MILE) is a support device from the PACE microcomputer family and is described in detail in Volume III. The MILE can be used to provide an 8-bit, bidirectional I/O port in an SC/MP system as shown in the figure below.

## **THE PACE MILE USED IN AN SC/MP SYSTEM**



The chip select ( $\overline{CS}$ ) signal must be derived from the Address Bus and could consist of a single address line, a page select signal, or the output of address decoding logic. Remember that the SC/MP CPU does not differentiate between memory and I/O devices: it treats the MILE simply as a memory location.

Directional control of the MILE is provided by the SC/MP read strobe (NRDS) and write strobe (NWDS) signals. NRDS is connected to the MILE's DOUT2 input signal: when NRDS and CS are both low, the contents of the MILE's data latches are gated out onto the SC/MP data lines for input to the CPU. The SC/MP NWDS signal is connected to the MILE's DIN2 input: when NWDS and CS are both low, the data output on the SC/MP data lines is latched into the MILE.

In the figure above, the MILE's DIN1 and DOUT1 signals are continuously enabled by connecting them to +5V. An alternate method of using these two signals would be to connect them to address lines in order to simplify the address decoding requirements of the SC/MP system as shown in the figure below.

In this example, data transfers between the MILE and SC/MP are enabled when address bit 11 (AD11) is a zero and AD10 is a one. This figure also shows the two handshaking signals (STD and STP) provided by the MILE. These signals can be applied to the SENSEA or SENSEB inputs to SC/MP to implement simple I/O handshaking schemes.



**THE 8212  
I/O PORT  
USED IN  
SC/MP  
SYSTEMS**

The 8212 I/O port from the 8080A microcomputer family is a device similar to the MILE: the only difference is that while the MILE can operate bidirectionally, the 8212 is unidirectional. The signal connections required to use the 8212 with SC/MP are quite simple:



The connections shown here use the 8212 as an input port with handshaking logic provided. When the external logic latches data into the 8212 using the STB signal, the INT signal goes low; this signal can be applied to the SC/MP SENSEA or SENSEB input to inform the CPU that input data is ready. SC/MP would then execute a service routine program that would include an instruction to read data from the input port. This instruction would send out the input port's address, thus generating the DS2 signal, and then gate the latched data onto the CPU data lines when the NRDS signal is generated. When the latched data is read out of the 8212, the INT signal returns high to complete the transaction. This sequence is summarized by the following timing diagram:



Using the 8212 as an output port in an SC/MP system requires a simple reversal of the connections we described in the preceding example.

**THE 8212 USED  
AS AN OUTPUT  
PORT IN AN  
SC/MP SYSTEM**



With this arrangement, data from the CPU will be loaded into the 8212 latches when the required address is generated to apply a high to DS2 and SC/MP outputs the NWDS strobe signal. Data that is latched into the 8212 is immediately gated out onto DO0 - DO7 and presented to external logic.

We will conclude our discussion of support devices that may be used with SC/MP with the following observation. The MILE and 8212 devices, which we have used as examples, are both relatively simple support devices. However, more complex general-purpose support devices are usually no more difficult to interface to an SC/MP CPU. In fact, the interface is often simpler, from a hardware point of view, because such things as mode control are handled by software.

## **DATA SHEETS**

This section contains specific electrical and timing data for both the SC/MP and SC/MP II (INS8060).

**applications****absolute maximum ratings**

|                                    |                          |                                          |                                                 |
|------------------------------------|--------------------------|------------------------------------------|-------------------------------------------------|
| ■ Test Systems and Instrumentation | ■ Process Controllers    | Voltage at Any Pin                       | $V_{SS} + 0.3\text{V}$ to $V_{SS} - 20\text{V}$ |
| ■ Machine Tool Control             | ■ Terminals              | Operating Temperature Range              | $0^\circ\text{C}$ to $+70^\circ\text{C}$        |
| ■ Small Business Machines          | ■ Traffic Controls       | Storage Temperature Range                | $-65^\circ\text{C}$ to $+150^\circ\text{C}$     |
| ■ Word Processing Systems          | ■ Laboratory Controllers | Lead Temperature (Soldering, 10 seconds) | $300^\circ\text{C}$                             |
| ■ Educational Systems              | ■ Sophisticated Games    |                                          |                                                 |
| ■ Multiprocessor Systems           | ■ Automotive             |                                          |                                                 |

**electrical characteristics** ( $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{SS} = +5\text{V} \pm 5\%$ ,  $V_{GG} = -7\text{V} \pm 5\%$ )

| Parameter                                                                         | Conditions                                                                                             | Min.                                                                                                                                 | Typ.*     | Max.           | Units      |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------|------------|
| <b>INPUT SPECIFICATIONS</b>                                                       |                                                                                                        |                                                                                                                                      |           |                |            |
| ENIN, NHOLD, NRST, SENSE A,<br>SENSE B, SIN, DB0-DB7<br>(TTL Compatible) (Note 2) |                                                                                                        |                                                                                                                                      |           |                |            |
| Logic "1" Input Voltage                                                           |                                                                                                        | $V_{SS} - 1$                                                                                                                         |           | $V_{SS} + 0.3$ | V          |
| Logic "0" Input Voltage                                                           |                                                                                                        | $V_{SS} - 10$                                                                                                                        |           | 0.8            | V          |
| Pullup Transistor "ON" Resistance<br>(Note 2)                                     | $V_{IN} = (V_{SS} - 1)\text{V}$                                                                        |                                                                                                                                      | 7.5       | 12             | k $\Omega$ |
| Logic "0" Input Current                                                           | $V_{IN} = 0\text{V}$                                                                                   |                                                                                                                                      |           | -1.6           | mA         |
| BREQ (Note 3)                                                                     |                                                                                                        |                                                                                                                                      |           |                |            |
| Logic "1" Input Voltage                                                           |                                                                                                        | $V_{SS} - 1$                                                                                                                         |           | $V_{SS} + 0.3$ | V          |
| Logic "0" Input Voltage                                                           |                                                                                                        |                                                                                                                                      |           | 0.8            | V          |
| X1, X2 (Note 4)                                                                   |                                                                                                        |                                                                                                                                      |           |                |            |
| Logic "1" Input Voltage                                                           |                                                                                                        | 3.0                                                                                                                                  |           | $V_{SS} + 0.3$ | V          |
| Logic "0" Input Voltage                                                           |                                                                                                        |                                                                                                                                      |           | 0.4            | V          |
| Logic "1" Input Current                                                           | $V_{IN} = 3.0\text{V}$                                                                                 |                                                                                                                                      |           | 5.0            | mA         |
| Logic "0" Input Current                                                           | $V_{IN} = 0.4\text{V}$                                                                                 | -5.5                                                                                                                                 |           |                | mA         |
| Input Capacitance<br>(All pins except V <sub>GG</sub> and V <sub>SS</sub> )       |                                                                                                        |                                                                                                                                      |           | 10             | pF         |
| Supply Current<br>$I_{GG}$<br>$I_{SS}$                                            | See Typical Plot of<br>Normalized $I_{GG}$ [and<br>$I_{SS}$ ] Versus Ambient<br>Temperature on page 6. | $T_A = 0^\circ\text{C}$ , loads on all outputs:<br>$I_{SINK} = 1.6\text{mA}$<br>(See diagram, Simulated<br>Current Load, on page 6.) | 100<br>90 | 135<br>125     | mA<br>mA   |

**OUTPUT SPECIFICATIONS**

|                           |                                                               |                     |      |          |               |
|---------------------------|---------------------------------------------------------------|---------------------|------|----------|---------------|
| BREQ (Note 3)             |                                                               |                     |      |          |               |
| Logic "1" Output Current  | $V_{OUT} = (V_{SS} - 1)\text{V}$                              | -2.0                |      |          | mA            |
| Logic "0" Output Current  | $V_{GG} \leq V_{OUT} \leq V_{SS}$                             |                     |      | $\pm 10$ | $\mu\text{A}$ |
| External Load Capacitance |                                                               |                     |      | 50       | pF            |
| All Other Outputs         |                                                               |                     |      |          |               |
| Logic "1" Output Voltage  | $ I_{OUT}  = -80\mu\text{A}$<br>$ I_{OUT}  = -200\mu\text{A}$ | $V_{SS} - 1$<br>2.4 |      |          | V<br>V        |
| Logic "0" Output Voltage  | $ I_{OUT}  = 1.6\text{mA}$                                    |                     |      | 0.4      | V             |
| Logic "0" Output Current  | $V_{OUT} = -0.5\text{V}$                                      |                     |      | 4.0      | mA            |
| Logic "0" Output Voltage  | $ I_{OUT}  = 0\text{mA}$ (unloaded)                           | -3.0                | -0.7 |          | V             |

\*Typical parameters correspond to nominal supply voltage at  $25^\circ\text{C}$ .

## SC/MP

**electrical characteristics** ( $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{SS} = +5\text{V} \pm 5\%$ ,  $V_{GG} = -7\text{V} \pm 5\%$ ) (continued)

| Parameter                                              | Conditions                                                 | Min.             | Typ.*    | Max.             | Units         |
|--------------------------------------------------------|------------------------------------------------------------|------------------|----------|------------------|---------------|
| TIMING SPECIFICATIONS (Note 5)                         |                                                            |                  |          |                  |               |
| $T_x$ (Notes 4 and 6)                                  |                                                            | 1.0              |          | 10.0             | $\mu\text{s}$ |
|                                                        | 820pF $\pm 10\%$ across $X_1$ & $X_2$                      | 1.0              |          | 4.0              | $\mu\text{s}$ |
| $f_{res}$                                              | crystal with equivalent series resistance $\leq 600\Omega$ | 900              |          | 1000             | kHz           |
| Address and Input/Output Status (See figures 5 and 6.) |                                                            |                  |          |                  |               |
| $T_{D1}$ (ADS)                                         |                                                            | $(3T_x/2) - 150$ | $3T_x/2$ | $(3T_x/2) + 200$ | ns            |
| $T_W$ (ADS)                                            |                                                            | $(T_x/2) - 250$  |          |                  | ns            |
| $T_S$ (ADDR)                                           |                                                            | $(T_x/2) - 300$  |          |                  | ns            |
| $T_H$ (ADDR)                                           |                                                            | 30               | 50       |                  | ns            |
| $T_S$ (STAT)                                           |                                                            | $(T_x/2) - 300$  |          |                  | ns            |
| $T_H$ (STAT)                                           |                                                            | 30               | 50       |                  | ns            |
| Data Input Cycle (See figure 5.)                       |                                                            |                  |          |                  |               |
| $T_D$ (RDS)                                            |                                                            | -80              | -50      |                  | ns            |
| $T_W$ (RDS)                                            |                                                            | $(3T_x/2) - 400$ |          |                  | ns            |
| $T_S$ (RD)                                             |                                                            | 300              |          |                  | ns            |
| $T_H$ (RD)                                             |                                                            | 0                |          |                  | ns            |
| $T_{ACC}$ (RD)                                         |                                                            | $2T_x - 400$     |          |                  | ns            |
| Data Output Cycle (See figure 6.)                      |                                                            |                  |          |                  |               |
| $T_D$ (WDS)                                            |                                                            | $T_x - 250$      |          |                  | ns            |
| $T_W$ (WDS)                                            |                                                            | $T_x - 250$      |          |                  | ns            |
| $T_S$ (WD)                                             |                                                            | $(T_x/2) - 300$  |          |                  | ns            |
| $T_H$ (WD)                                             |                                                            | 60               | 100      |                  | ns            |
| Input/Output Cycle Extend (See figure 7.)              |                                                            |                  |          |                  |               |
| $T_S$ (HOLD)                                           |                                                            | 300              |          |                  | ns            |
| $T_{D1}$ (HOLD)                                        |                                                            |                  |          | 300              | ns            |
| $T_{D2}$ (HOLD)                                        |                                                            |                  |          | 500              | ns            |
| $T_W$ (HOLD)                                           |                                                            |                  |          | $\infty$         | ns            |
| Bus Access (See figure 4.)                             |                                                            |                  |          |                  |               |
| $T_D$ (ENOUT)                                          |                                                            |                  |          | 300              | ns            |
| $T_{D2}$ (ADS)                                         |                                                            | $(T_x/2) - 350$  |          | $T_x + 500$      | ns            |
| OUTPUT LOAD CAPACITANCE                                |                                                            |                  |          |                  |               |
| External Load Capacitance                              |                                                            |                  |          | 75               | pF            |

Note 1: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under electrical characteristics.

Note 2: Pullup transistors provided on chip for TTL compatibility.

Note 3: BREQ is an input/output signal that requires an external resistor to  $V_{GG}$  or ground.

Note 4:  $X_1$  and  $X_2$  are master timing inputs that are normally connected to a 1-megahertz crystal or an external capacitor to control the frequency of the on-chip oscillator.

A hermetically sealed quartz crystal is recommended. The crystal must be a series-resonant type and its equivalent series resistance must not exceed 600 ohms. Suppression of third harmonic oscillations may be required depending on the characteristics of the crystal. Typically, a 500-picofarad capacitor across pin  $X_1$  or  $X_2$  and an AC ground minimizes third harmonic effects.

If use of an external oscillator is desired, the circuit shown in figure 3 or an equivalent may be used.

Note 5: All times measured from valid Logic "0" or Logic "1" level.

Note 6:  $T_x$  is the time period for one clock cycle of the on-chip or external oscillator. Refer to paragraph titled Timing Control for detailed definition.

\*Typical parameters correspond to nominal supply voltage at  $25^\circ\text{C}$ .

## SC/MP

### DRIVERS AND RECEIVERS

Equivalent circuits for SC/MP drivers and receivers are shown below. All inputs have static charge protection circuits consisting of an RC filter and voltage clamp. These devices still should be handled with care, as the protection circuits can be destroyed by excessive static charge.



SC/MP Driver and Receiver Equivalent Circuits

### SUPPLY CURRENT DATA

Below are the two diagrams referenced from the parametric specification for the supply current, page 2.



\*INCLUDES JIG CAPACITANCE.

Simulated Current Load



TYPICAL PLOT OF NORMALIZED  $ICG$  (AND  $ISS$ )  
VERSUS AMBIENT TEMPERATURE  
DC POWER =  $ICG \cdot V_{GG} + ISS \cdot V_{SS}$

### BREQ, ENIN, and ENOUT Timing



Note 1: ENOUT goes high to indicate that SC/MP was granted access to bus (ENIN high) but is not using bus.

Note 2: ENOUT goes low in response to low ENIN input.

Note 3: SC/MP generates bus request; bus access not granted because ENIN low.

Note 4: ENIN goes high. Bus access now granted and input/output cycle actually initiated. If ENIN is set high while SC/MP has access to the bus, the address and data ports will go to the high-impedance (TRI-STATE<sup>®</sup>) state, but BREQ will remain high. When ENIN is subsequently set high, the input/output cycle will begin again.

Note 5: I/O cycle completed. ENOUT goes high to indicate that SC/MP granted access to bus but not using bus. If ENIN had been set low before completion of input/output cycle, ENOUT would have remained low.

Note 6: ENOUT goes low to indicate that system busses are available for use by highest-priority requestor.

FIGURE 4. Bus Access Control

## SC/MP



Note: Timing is valid when ENIN is wired high or is set high before BREQ is set high by SC/MP; see figure 4 for NADS timing when ENIN is set high after BREQ.

FIGURE 5. SC/MP Data Input Timing



FIGURE 6. SC/MP Data Output Timing

## SC/MP AND INS8060-SC/MP II



FIGURE 7. Extended Input/Output Timing

### Applications

- Test Systems and Instrumentation
- Machine Tool Control
- Small Business Machines
- Word Processing Systems
- Educational Systems
- Multiprocessor Systems
- Process Controllers
- Terminals
- Traffic Controls
- Laboratory Controllers
- Sophisticated Games
- Automotive

### Absolute Maximum Ratings (Note 1)

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Voltage at Any Pin . . . . .                       | -0.5V to +7.0V  |
| Operating Temperature Range . . . . .              | 0°C to +70°C    |
| Storage Temperature Range . . . . .                | -65°C to +150°C |
| Lead Temperature (Soldering, 10 seconds) . . . . . | 300°C           |

### DC Electrical Characteristics ( $T_A = 0^\circ\text{C}$ to $+70^\circ\text{C}$ , $VCC = +5\text{V} \pm 5\%$ )

| Parameter                                               | Conditions                                   | Min.         | Max.     | Units         |
|---------------------------------------------------------|----------------------------------------------|--------------|----------|---------------|
| <b>INPUT SPECIFICATIONS</b>                             |                                              |              |          |               |
| All Input Pins Except $V_{CC}$ and GND                  |                                              | 2.0          | $V_{CC}$ | V             |
| Logic "1" Input Voltage                                 |                                              | -0.5         | 0.8      | V             |
| Logic "0" Input Voltage                                 |                                              |              | 10       | pF            |
| Input Capacitance<br>(All pins except $V_{CC}$ and GND) |                                              |              |          |               |
| Supply Current<br>$I_{CC}$                              | $T_A = 25^\circ\text{C}$<br>outputs unloaded |              | 45       | mA            |
|                                                         | $T_A = 0^\circ\text{C}$<br>outputs unloaded  |              | 50       | mA            |
| <b>OUTPUT SPECIFICATIONS</b>                            |                                              |              |          |               |
| "TRI-STATE®" Pins (NWDS, NRDs, DB0 - DB7, AD00 - AD11)  |                                              |              |          |               |
| Logic "1" Output Voltage                                | $I_{OUT} = -100\mu\text{A}$                  | 2.4          |          | V             |
| Logic "0" Output Voltage                                | $I_{OUT} = 2.0\text{mA}$                     |              | 0.4      | V             |
| NADS, FLAG 0 - 2, SOUT, NENOUT                          |                                              |              |          |               |
| Logic "1" Output Voltage                                | $I_{OUT} = -100\mu\text{A}$                  | $V_{CC} - 1$ |          | V             |
| Logic "1" Output Voltage                                | $I_{OUT} = -1\text{mA}$                      | 1.5          |          | V             |
| Logic "0" Output Voltage                                | $I_{OUT} = 2.0\text{mA}$                     |              | 0.4      | V             |
| NBREQ (Note 2)                                          |                                              |              |          |               |
| Logic "0" Output Voltage                                | $I_{OUT} = 2.0\text{mA}$                     |              | 0.4      | V             |
| Logic "1" Output Current                                | $0 \leq V_{OUT} \leq V_{CC}$                 |              | $\pm 10$ | $\mu\text{A}$ |
| XOUT                                                    |                                              |              |          |               |
| Logic "1" Output Voltage                                | $I_{OUT} = -100\mu\text{A}$                  | 2.4          |          | V             |
| Logic "0" Output Voltage                                | $I_{OUT} = 1.6\text{mA}$                     |              | 0.4      | V             |

## INS8060-SC/MP II

AC Electrical Characteristics [ $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{CC} = +5\text{V} \pm 5\%$ , 1 TTL Load (Note 3)]

| Parameter                                                | Conditions                                                         | Min.            | Max.     | Units         |
|----------------------------------------------------------|--------------------------------------------------------------------|-----------------|----------|---------------|
| $f_X$                                                    |                                                                    | 0.1             | 4.0      | MHz           |
|                                                          | $R = 240\Omega \pm 5\%$ (figure 2B)<br>$C = 300\text{pF} \pm 10\%$ | 2.0             | 4.0      | MHz           |
| $T_C$ (Note 4)                                           |                                                                    | 500             |          | ns            |
| Microcycle                                               |                                                                    | 1               |          | $\mu\text{s}$ |
| External Clock Input (see figure 2A)                     |                                                                    |                 |          |               |
| $T_{W0}$                                                 |                                                                    | 120             |          | ns            |
| $T_{W1}$                                                 |                                                                    | 120             |          | ns            |
| XOUT/ADS Timing Relationship<br>(see figure 3)           |                                                                    |                 |          |               |
| $T_H$ (ADS)                                              |                                                                    | 100             | 225      | ns            |
| Address and Input/Output Status<br>(see figures 5 and 6) |                                                                    |                 |          |               |
| $T_{D1}$ (ADS)                                           |                                                                    |                 | $3T_C/2$ | ns            |
| $T_W$ (ADS)                                              |                                                                    | $(T_C/2) - 50$  |          | ns            |
| $T_S$ (ADDR)                                             |                                                                    | $(T_C/2) - 165$ |          | ns            |
| $T_H$ (ADDR)                                             |                                                                    | 50              |          | ns            |
| $T_S$ (STAT)                                             |                                                                    | $(T_C/2) - 150$ |          | ns            |
| $T_H$ (STAT)                                             |                                                                    | 50              |          | ns            |
| $T_H$ (NBREQ)                                            |                                                                    | 0               |          | ns            |
| Data Input Cycle (see figure 5)                          |                                                                    |                 |          |               |
| $T_D$ (RDS)                                              |                                                                    | 0               |          | ns            |
| $T_W$ (RDS)                                              |                                                                    | $T_C + 50$      |          | ns            |
| $T_S$ (RD)                                               |                                                                    | 175             |          | ns            |
| $T_H$ (RD)                                               |                                                                    | 0               |          | ns            |
| $T_{ACC}$ (RD)                                           |                                                                    | $2T_C - 200$    |          | ns            |
| Data Output Cycle (see figure 6)                         |                                                                    |                 |          |               |
| $T_D$ (WDS)                                              |                                                                    | $T_C - 50$      |          | ns            |
| $T_W$ (WDS)                                              |                                                                    | $T_C$           |          | ns            |
| $T_S$ (WD)                                               |                                                                    | $(T_C/2) - 200$ |          | ns            |
| $T_H$ (WD)                                               |                                                                    | 100             |          | ns            |
| Input/Output Cycle Extend<br>(see figure 7)              |                                                                    |                 |          |               |
| $T_S$ (HOLD)                                             |                                                                    | 200             |          | ns            |
| $T_{D1}$ (HOLD)                                          |                                                                    | 130             | 275      | ns            |
| $T_{D2}$ (HOLD)                                          |                                                                    |                 | 350      | ns            |
| $T_W$ (HOLD)                                             |                                                                    |                 | $\infty$ | ns            |
| $T_H$ (HOLD)                                             |                                                                    | 0               |          | ns            |
| Bus Access (see figure 4)                                |                                                                    |                 |          |               |
| $T_D$ (NENOUT)                                           |                                                                    |                 | 150      | ns            |
| $T_{D2}$ (ADS)                                           |                                                                    | $T_C/2$         | $3T_C/2$ | ns            |
| $T_H$ (NENIN)                                            |                                                                    | 0               |          | ns            |
| Output Load Capacitance                                  |                                                                    |                 |          |               |
| XOUT                                                     |                                                                    |                 | 30       | $\text{pF}$   |
| All Other Output Pins                                    |                                                                    |                 | .75      | $\text{pF}$   |

Note 1: Maximum ratings indicate limits beyond which damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under electrical characteristics.

Note 2: NBREQ is an input/output signal that requires an external resistor to  $V_{CC}$ .

Note 3: All times measured from valid Logic "0" level = 0.8 V or valid Logic "1" level = 2.0 V.

Note 4:  $T_C$  is the time period for two clock cycles of the on-chip or external oscillator ( $T_C = 2/f_X$ ). Refer to paragraph titled Timing Control for detailed definition.

Note 5: All times measured with a 50% duty cycle on the external clock.

## INS8060-SC/MP II

The time interval of a microcycle is four times the period of the oscillator; that is:

$$\text{period of one microcycle} = 2T_C$$

$$T_C = 2\left(\frac{1}{f_{osc}}\right) = 2\left(\frac{1}{f_{res}}\right) = 2\left(\frac{1}{f_{XIN}}\right)$$

where:

$T_C$  = time period for two cycles of on-chip or external oscillator

$f_{osc}$  = frequency of on-chip oscillator

$f_{res}$  = resonant frequency of crystal connected between XIN and XOUT pins

$f_{XIN}$  = frequency of external clock applied to XIN pin

### A. External Clock Input



### B. Resistor-Capacitor Feedback Network



FIGURE 2. Frequency Control Networks for On-Chip Oscillator

### C. Crystal with Low-Pass Filter (Above 1MHz)



Suggested values for Crystal with Low-Pass Filter Network.

| Crystal | R <sub>P</sub> | C <sub>1</sub> | R <sub>1</sub> |
|---------|----------------|----------------|----------------|
| 2MHz    | 100kΩ          | 56pF           | 1kΩ            |
| 3.58MHz | 100kΩ          | 27pF           | 1kΩ            |
| 4MHz    | 100kΩ          | 27pF           | 1kΩ            |

XTAL is parallel resonant with maximum series resonance equal to 1kΩ.

### D. Crystal with Low-Pass Filter (1MHz or Below)



FIGURE 3. XOUT/NADS Timing Relationship

## INS8060-SC/MP II



B. NBREQ, NENIN, and NENOUT Timing

Note 1: NENOUT is always high while SC/MP is actually using bus; that is, NENIN input and NBREQ output are low.

Note 2: When SC/MP is not using bus (NBREQ output or NENIN input high), NENOUT is held in same state as NENIN input.

Note 3: NENOUT goes low to indicate that SC/MP was granted access to bus (NENIN low) but is not using bus.

Note 4: NENOUT goes high in response to high NENIN input.

Note 5: SC/MP generates bus request; bus access not granted because NENIN high.

Note 6: NENIN goes low. Bus access now granted and input/output cycle actually initiated. If NENIN is set high while SC/MP has access to the bus, the address and data ports will go to the high-impedance (Tri-State®) state, but NBREQ will remain low. When NENIN is subsequently set low, the input/output cycle will begin again.

Note 7: Input/output cycle completed. NENOUT goes low to indicate that SC/MP granted access to bus but not using bus. If NENIN had been set high before completion of input/output cycle, NENOUT would have remained high.

FIGURE 4. Bus Access Control

## INS8060-SC/MP II



Note: Timing is valid when NENIN is low before NBREQ is set low by SC/MP; see figure 4 for NADS timing when NENIN is set low after NBREQ.

FIGURE 5. SC/MP Data Input Timing



FIGURE 6. Data Output Timing

## INS8060-SC/MP II



**Note 1:** In order to extend the input/output cycle, NHOLD must remain low until the point where NRDS/NWDS would have made a low-to-high transition with NHOLD inactive. Dashed line indicates the trailing edge of NRDS/NWDS when NHOLD is not active.

FIGURE 7. NHOLD Timing

## Chapter 4 THE 8080A

The 8080A is the most widely known of the microcomputers described in this book; as such, it becomes the frame of reference in many peoples' minds as to what a microcomputer should be.

The 8080A CPU is the direct descendant of the 8008, which was developed to Datapoint's specification for a device that would provide intelligent terminal data processing logic.

It should be borne in mind that the 8080A was designed as an enhancement of the 8008, at a time when no definable microcomputer user public had established itself; therefore, many of the design features in the 8080A can be looked upon as astute shots in the dark. The success of this microcomputer is due either to the farsighted genius of its designers, or to the fact that the power of most microcomputers so overwhelms the needs of microcomputer applications, that CPU design becomes almost irrelevant when compared to product costs and product availability.

An enhanced version of the 8080A, the 8085, is now available. The 8085 is described along with its support devices in Chapter 5. Note that in many cases it will be possible to use 8080A support devices with the 8085 CPU. You are unlikely to use 8085 support devices with the 8080A; if your design is new enough to be looking at the 8085 support devices, then in all probability you would be using the 8085 CPU in preference to the 8080A.

There is also a family of one-chip microcomputers currently available from Intel only — the 8048 family. Where the 8085 is an enhancement of the 8080 with many similarities, the 8048 is a somewhat different product. The 8048 devices are described in Chapter 6.

The 8080A has more support devices than any other microprocessor on the market today. A few of these support devices are specific to the 8080A; however, the majority of them are used just as easily with almost any microprocessor. Only devices specific to the 8080A are described in this chapter; devices that can be used with any microprocessor are described in Volume III. The following is a list of 8080A support devices; a • at the left margin identifies a device described in this chapter, while an \* in the left margin identifies a device which is described in Volume III.

- The 8080A/9080A CPU
- The 8224 System Clock Generator and Driver. This device generates timing signals for the entire 8080A microcomputer system.
- The 8228 System Controller (SC). This device demultiplexes the data lines of the 8080A CPU which are used for bidirectional data transfer and to output control and status signals.
- The 8251 and 8251A Serial I/O Communication Interface, which provides a variety of synchronous and asynchronous serial data communication options.
- The 8273 SDLC Protocol Serial I/O Controller.
- The  $\mu$ PD379 and the  $\mu$ PD369. These devices provide synchronous and asynchronous serial I/O interfaces, respectively.
- The 8255 and 8255A Parallel I/O interfaces, which provide programmable parallel I/O communication with external devices.
- The 8212 Input/Output port, which can be used as an address buffer/decoder, a priority interrupt arbitrator, or an I/O peripheral interface.
- The 8257 Direct Memory Access control device, which enables data to be transferred between memory and external logic, bypassing the CPU.
- The 8253 Programmable Timer, which is accessed as an I/O device to create delays and timed pulses.
- The 8259 Priority Interrupt Control Unit, which arbitrates priority among eight interrupts and creates appropriate CALL instructions in response to an interrupt acknowledge.
- The 8214 priority interrupt device, which allows a number of interrupt requests to be received and processed under program control.
- The TMS 5501 Multifunction I/O Controller, which provides a variety of support logic functions.

- \* The 8205, 8216 and 8226 address buffer decoders, which provide the logic needed to decode address spaces out of the 8080A address lines.
- \* The 8271 Programmable Floppy Disk Controller. This device provides a good deal of the logic needed to interface a floppy disk to a microprocessor.
- \* The 8275 Programmable CRT Controller. This device provides a great deal of the logic needed to interface industry standard CRT terminals to a microprocessor.

**Table 4-1 lists the sources for each of the products described.** Device numbers in each column are the individual manufacturers' device numbers, which may differ for the same device.

Table 4-1. Devices of the 8080A Microcomputer Family

| DEVICE   | AMD      | INTEL   | NEC     | TI                         | NS      | SIGNETICS*** |
|----------|----------|---------|---------|----------------------------|---------|--------------|
| 8080A    | 9080A**  | 8080A   | 8080A   | TMS 8080A                  | 8080A   | 8080A        |
| 8224     | 8224     | 8224    | 8224    | SN74LS424                  | 8224    | 8224         |
| 8228     | 8228/38  | 8228/38 | 8228/38 | SN74S428                   | 8228/38 | 8228/38      |
| 8251     | 9551*    | 8251    | 8251    | $\mu$ PD379<br>$\mu$ PD369 |         |              |
| 8255     | 9555*    | 8255    | 8255    |                            | 8255    |              |
| 8214     |          | 8214    | 8214    |                            |         |              |
| 8216/26  | 8216/26  |         | 8216    |                            |         |              |
| 8205     | 25LS138* | 8205    |         |                            |         |              |
| 8212     | 8212     | 8212    | 8212    | SN74S412                   |         |              |
| 8253     |          | 8253    | 8253    |                            |         |              |
| 8259     |          | 8259    | 8259    |                            |         |              |
| 8257     |          | 8257    | 8257    |                            |         |              |
| TMS 5501 |          |         |         | TMS 5501                   |         |              |

\* Some parameters vary, but pin-for-pin compatible

\*\* Five CPU options are available offering clock speeds as fast as 250 ns, and wide temperature ranges

\*\*\* Signetics second sources National Semiconductor products

Companies manufacturing these microcomputer devices are:

INTEL CORPORATION  
3065 Bowers Avenue  
Santa Clara, CA 95051

ADVANCED MICRO DEVICES  
901 Thompson Place  
Sunnyvale, CA 94086

TEXAS INSTRUMENTS INC  
P.O. Box 1444  
Houston, TX 77001

NEC MICROCOMPUTERS INC  
5 Militia Drive  
Lexington, MA 02173

NATIONAL SEMICONDUCTOR CORP  
2900 Semiconductor Drive  
Santa Clara, CA 95050

SIGNETICS  
811 East Arques Avenue  
Sunnyvale, CA 94043

SIEMENS A.G.  
Components Group  
Balanstrasse 73, D8000  
Munich 80, West Germany

**Siemens is manufacturing the 8080A family of devices in Europe with the active support of Intel. AMD is an authorized second source; however, most of their products were developed prior to the second source agreement. All other 8080A manufacturers are unauthorized. In consequence, some differences exist between Intel**

**and second source parts; differences are in some cases designed by the second source manufacturer, while in other cases differences are accidents. Differences we know about are described.**

The 8080A uses three levels of power supply: +5V, +12V and -5V.

Using a 500 ns clock, instruction execution times range from 2 to 9  $\mu$ sec.

All 8080A devices have TTL compatible signals.

## THE 8080A CPU

**Of the 8080A devices available on the market, the NEC 8080A is the only one that differs significantly from the Intel 8080A.** The NEC 8080A is advertised as "an upward enhancement". Some of the NEC 8080A upward enhancements result in programs written for Intel 8080A not executing correctly on the NEC 8080A; therefore you should check carefully for incompatibilities when using the NEC 8080A. **NEC now manufactures an exact 8080A reproduction as well;** be sure you select the correct product if you buy from NEC.

Most differences between Intel and second source 8080A devices pertain to maximum clock frequency, environmental constraints and electrical characteristics. For details see the data sheets at the end of this chapter.

**Functions implemented on the 8080A CPU are illustrated in Figure 4-1; they represent "typical" CPU logic.** The 8080A has an Arithmetic and Logic Unit, Control Unit, Accumulator and registers.

N-Channel, silicon gate MOS technology is used by all 8080A manufacturers.

**The two most noticeable features of the 8080A CPU are the exclusion of clock logic and bus interface logic from the CPU chip.**

The need for a separate clock logic chip simply reflects the fact that the 8080A was a relatively early microprocessor. Other microprocessors developed at the same time also required external clock logic.

Bus interface logic must also be provided externally since the 8080A outputs an inadequate set of control signals. These control signals are augmented by instruction status information output on the Data Bus. External bus interface logic must combine the control signals with the instruction status signals to create an adequate Control Bus.

These characteristics of the 8080A CPU are described in detail on the following pages.

**The 8085 CPU incorporates clock logic and bus interface logic onto the CPU chip.**

## 8080A PROGRAMMABLE REGISTERS

The 8080A has seven 8-bit programmable registers, a 16-bit Stack Pointer, and a 16-bit Program Counter. These may be illustrated as follows:



The A register is an 8-bit primary Accumulator. The remaining six Accumulator registers may be treated as six individual, 8-bit secondary Accumulators, or else they may be treated as three, 16-bit Data Counters, which we will refer to as BC, DE, and HL registers. The 16-bit HL register is the primary Data Counter, and provides the implied memory address for most memory reference instructions; a limited number of memory reference instructions use the BC and DE registers as Data Counters.

The 8080A uses a memory Stack, addressed by the Stack Pointer.



Figure 4-1. The 8080A CPU, 8224 Clock and 8228 System Controller.  
Forming a Three-Device Microprocessor

## 8080A ADDRESSING MODES

The memory addressing used by the 8080A is very straightforward: direct addressing and implied addressing are provided.

The most frequently used memory addressing mode is implied addressing, via the HL register. This was the only memory addressing mode available on the predecessor microcomputer, the 8008.

**8080A  
IMPLIED  
ADDRESSING**

Register-register Move, and Register-register Operate instructions allocate three bits to specify one of eight registers; since there are only seven registers, the eighth code becomes a memory reference specification, using implied addressing via the HL register, as follows:



With one exception, direct addressing is the only addressing mode provided for Jump and Branch instructions; the exception is the instruction with the mnemonic PCHL, which provides a jump using implied addressing. Direct addressing is also available for a limited number of memory reference instructions. All direct addressing instructions are three bytes long; a two-byte (16-bit) direct address is always specified.

**8080A  
DIRECT  
ADDRESSING**

## 8080A STATUS

The 8080A has a Status register with the following status flags:

- Zero (Z)
- Sign (S)
- Parity (P)
- Carry (C)
- Auxiliary Carry (AC)
- SUB, present in the NEC 8080A only

These status flags may be accessed by some instructions as a single Program Status Word (PSW). PSW bits are assigned as follows:



Instructions that access register pairs treat PSW and the Accumulator as a register pair.

The 8080A uses its Sign status as described for the hypothetical microcomputer in Volume I, Chapter 7.

**The Carry status is not completely standard.** When an addition instruction is executed, any carry out of the high-order bit causes the Carry status to be set to 1, while no carry causes the Carry status to be reset to 0. This is standard Carry logic, also known as Add Carry logic. When a subtraction instruction is executed, however, the Carry logic is inverted.

**CARRY  
STATUS  
BORROW  
LOGIC**

A subtraction is actually the twos complement addition of the subtrahend to the minuend. The use of the Carry status is different: if there is a carry out of the high-order bit, then the Carry status is reset to 0; if there is no carry out of the high-order bit, then the Carry status is set to 1. This philosophy is known as Borrow Carry logic and is used only during subtraction operations. Here are illustrations of the two philosophies:



In a CPU which uses Add Carry logic, the twos complement of the low-order subtrahend byte is added to the minuend low-order byte. However, the ones complements of higher order subtrahend bytes are added to minuend bytes when the CPU executes a "Subtract with Carry". This logic adds the unaltered Carry status. This is equivalent to initially assuming that there is no carry from the lower order byte; if there is a carry from the lower order byte, then the ones complement addition is incremented.

In a CPU which uses Borrow Carry logic, the twos complement of every subtrahend byte is added to every minuend byte, irrespective of whether we are dealing with the low-order or any other subtrahend byte. This is equivalent to assuming that there will always be a carry from the lower order byte — hence the twos complement add. If there is no carry, the sum must be decremented. When a lower order byte borrows from the next high-order byte, there will be no carry; therefore, no carry causes the Carry status to be set to 1. However, the "Subtract-with-Carry" instruction subtracts the 1 Carry status from the result rather than adding it.

**The Auxiliary Carry status is set and reset by the NEC 8080A following execution of any subtract instruction** to correctly indicate whether a borrow from bit 4 occurred during the subtraction. The Intel 8080A uses the Auxiliary Carry at all times to indicate a carry out of bit 3 following addition. **The AMD 9080A always clears the Auxiliary Carry status following execution of a Boolean instruction;** the Intel 8080A sometimes does and sometimes does not.

**AMD 9080A STATUS DIFFERENCE**

## 8080A CPU PINS AND SIGNALS

8080A CPU pins and signals are illustrated in Figure 4-2.

**The 16 address lines A0 - A15 output memory and I/O device addresses.** These are tristate lines, and may be floated, giving external logic control of the Address Bus.

**The eight Data Bus lines D0 - D7 are multiplexed, bidirectional data lines via which 8-bit data units are input and output, and on which statuses are output during the first clock period of any machine cycle;** statuses on the Data Bus identify events which are to occur during the balance of the machine cycle, as described in Table 4-2. Like the address lines, the data lines are tristate.

**Remaining signals (excluding power and ground) may be divided into timing control, Data Bus definition, and interrupt control signals.**

These are the timing control signals:

**A device which cannot respond to a CPU access request within the allowed time interval extends the time interval by pulling the READY input control low.** In response to READY low, the 8080A enters a Wait state, during which the CPU inserts an integral number of clock periods; **WAIT is output high, and all operations are suspended within the CPU,** but the address remains stable on the Address Bus.

**8080A TIMING CONTROL SIGNALS**

**CPU logic can be stopped between the end of one instruction's execution, and the beginning of the next, by putting a high level on HOLD.** This causes the CPU to float the Data and Address Busses, allowing external logic to access these busses, usually to perform direct memory access operations.

**The CPU responds to a HOLD request by outputting a Hold Acknowledge, HLDA, high;** this signal can be used by external logic to identify the beginning of the time when the CPU has actually floated external busses, and external logic can take control of the microcomputer system.

**RESET is a typical reset signal;** if held high for a minimum of three clock periods, it will zero the contents of all registers (excluding the status flags which maintain previous values), thus causing program execution to start with the instruction stored at memory location 0000.

**Two signals identify the condition of the Data Bus:**

**When DBIN is output high, data from an addressed memory location, or I/O port, must be placed on the Data Bus; DBIN may be used as a data input strobe.**

**WR is output low when data on the Data Bus is stable; WR may be used as a write strobe.**

**The two interrupt control lines are INT and INTE.** An external device requests an interrupt by inputting INT high. The CPU uses INTE to indicate whether interrupts are enabled or disabled.

**8080A  
DATA BUS  
DEFINITION  
SIGNALS**

**8080A  
INTERRUPT  
CONTROL  
SIGNALS**

## 8080A TIMING AND INSTRUCTION EXECUTION

An 8080A instruction's execution is timed by a complex sequence of MACHINE CYCLES each of which is subdivided into CLOCK PERIODS.

An instruction's execution may require from 1 to 5 machine cycles. Machine cycles are labeled MC1, MC2, MC3, MC4 and MC5.

A machine cycle is made up of 3, 4, or 5 clock periods; the first machine cycle of an instruction must have 4 or 5 clock periods. Clock periods are labeled T1, T2, T3, T4, T5:

**8080A  
MACHINE  
CYCLES**

**8080A  
CLOCK  
PERIODS**



Where MC is shaded, the entire machine cycle is optional. Where T is shaded, the clock period is optional within its machine cycle.



Figure 4-2. 8080A CPU Signals and Pin Assignments

## CLOCK SIGNALS

Two clocks,  $\Phi_1$  and  $\Phi_2$ , provide the CPU with its timing.

**Figure 4-3 illustrates the way in which clock signals  $\Phi_1$  and  $\Phi_2$  are used to generate a machine cycle consisting of five clock periods. A SYNC pulse identifies the first clock period of every machine cycle.**



Figure 4-3. A Machine Cycle Consisting of Five Clock Periods

A 9-segment clock is specified for the 8080A where the  $\Phi_1$  and  $\Phi_2$  signals are generated out of 9 segments as follows:



The following alternative segmentations will also work:



Irrespective of the segmentation used, note that the total clock period time must remain the same. For example, suppose you have a 500 nanosecond clock; individual segments must be timed as follows:

|                                          |       |      |       |       |        |        |
|------------------------------------------|-------|------|-------|-------|--------|--------|
| Number of Segments                       | 9     | 8    | 7     | 6     | 5      | 4      |
| Duration of one segment<br>(nanoseconds) | 55.55 | 62.5 | 71.43 | 83.33 | 100.00 | 125.00 |

In summary, therefore, a clock period will normally have 9 segments, but may have 4, 5, 6, 7 or 8 segments.

Note that **the only time you ever need to know about clock segmentation is when you are creating your own clock signals**. If you use the 8224 Clock Signal Generator (described later in this chapter) you can ignore clock signal segmentation.

**Clock periods T<sub>1</sub>, T<sub>2</sub> and T<sub>3</sub> of each machine cycle are used (with one exception) for memory reference operations. During periods T<sub>4</sub> and T<sub>5</sub> functions internal to the CPU are executed. These two clock periods can be used by external logic for a limited number of approved operations that do not involve the CPU:**



**The first three clock periods of the first machine cycle are always used to fetch an instruction from memory**, and load it into the Instruction register. The first machine cycle always has at least four clock periods, with the Program Counter being incremented during T<sub>4</sub>:



The CPU identifies the operations that will occur during **every machine cycle** by outputting status information on the Data Bus during clock period T<sub>2</sub>. External logic uses SYNC and the  $\Phi_1$  pulse at the start of T<sub>2</sub> to read status off the Data Bus. Timing is illustrated in Figure 4-4.

**8080A  
INSTRUCTION  
STATUS**

If you are using an 8228 System Controller, it will decode status output on the Data Bus during T<sub>2</sub>. By combining this status information with the three control signals: WR, DBIN and HLDA, the 8228 System Controller is able to generate a set of bus control signals which will interface industry standard memory devices and external logic.

If you are not using an 8228 System Controller, then you must provide external logic that decodes the Data Bus during  $\Phi_1$  of T<sub>2</sub>. Your external logic must generate control signals which will be active during subsequent clock periods, at which time the Data Bus no longer holds status information.



Figure 4-4. Status Output During T<sub>2</sub> of Every Machine Cycle

Table 4-2 defines the statuses which may be output during clock period T<sub>2</sub>. Table 4-3 defines the way in which statuses should be interpreted to identify the various possible types of machine cycles.

Table 4-2. Statuses Output Via the Data Lines During the Second Clock Cycle of an 8080A Machine Cycle

| SYMBOLS | DATA BUS BIT | DEFINITION                                                                                                                                                                                                                |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HLTA    | D3           | Acknowledge signal for Halt instruction                                                                                                                                                                                   |
| INTA*   | D0           | Acknowledge signal for INTERRUPT request. Signal should be used to gate a Restart instruction onto the Data Bus when DBIN is active.                                                                                      |
| INP*    | D6           | Indicates that the Address Bus contains the address of an input device and the input device should be placed on the Data Bus when DBIN is active.                                                                         |
| OUT     | D4           | Indicates that the Address Bus contains the address of an output device and the Data Bus will contain the output data when WR is active.                                                                                  |
| MEMR*   | D7           | Designates that the Data Bus will be used for memory read data.                                                                                                                                                           |
| M1      | D5           | Provides a signal to indicate that the CPU is in the fetch cycle for the first byte of an instruction.                                                                                                                    |
| STACK   | D2           | Indicates that the Address Bus holds the pushdown stack address from the Stack Pointer.                                                                                                                                   |
| WO      | D1           | Indicates that the operation in the current machine cycle will be a WRITE memory or OUTPUT function ( $\overline{WO} = 0$ ). Otherwise a READ memory, INPUT operation, or interrupt or Halt acknowledge will be executed. |

\*These three status bits can be used to control the flow of data onto the 8080A Data Bus.

Table 4-3. Statuses Output on the Data Bus for Various Types of Machine Cycle

| DATA BUS BIT | STATUS INFORMATION | TYPE OF MACHINE CYCLE |             |              |            |             |            |              |                       |                  |                                  |
|--------------|--------------------|-----------------------|-------------|--------------|------------|-------------|------------|--------------|-----------------------|------------------|----------------------------------|
|              |                    | INSTRUCTION FETCH     | MEMORY READ | MEMORY WRITE | STACK READ | STACK WRITE | INPUT READ | OUTPUT WRITE | INTERRUPT ACKNOWLEDGE | HALT ACKNOWLEDGE | INTERRUPT ACKNOWLEDGE WHILE HALT |
| D0           | INTA               | 0                     | 0           | 0            | 0          | 0           | 0          | 0            | 1*                    | 0                | 1                                |
| D1           | WO                 | 1                     | 1           | 0            | 1          | 0           | 1          | 0            | 1                     | 1                | 1                                |
| D2           | STACK              | 0                     | 0           | 0            | 1          | 1           | 0          | 0            | 0                     | 0                | 0                                |
| D3           | HLTA               | 0                     | 0           | 0            | 0          | 0           | 0          | 0            | 0                     | 1                | 1 (0)                            |
| D4           | OUT                | 0                     | 0           | 0            | 0          | 0           | 0          | 1            | 0                     | 0                | 0                                |
| D5           | M1                 | 1                     | 0           | 0            | 0          | 0           | 0          | 0            | 1                     | 0                | 1                                |
| D6           | INP                | 0                     | 0           | 0            | 0          | 0           | 1          | 0            | 0                     | 0                | 0                                |
| D7           | MEMR               | 1                     | 1           | 0            | 1          | 0           | 0          | 0            | 0                     | 1 (0)            | 0                                |

(0) Identifies status outputs of the NEC 8080A which differ from those of the Intel 8080A.

- This status is output as 0 by the NEC 8080A during a Call instruction being executed within the interrupt acknowledge process.

## INSTRUCTION FETCH SEQUENCE

Instruction fetch timing is illustrated in Figure 4-5; events occur as follows:

- Period T<sub>1</sub> The leading edge of  $\Phi_2$  triggers the SYNC high pulse, identifying period T<sub>1</sub>. WAIT is low, since the CPU is not in the Wait state. WR remains high since this is an instruction fetch cycle; data is not being written to memory. The leading edge of  $\Phi_2$  is used to set selected Data Bus lines high, providing external logic with status information as follows:  
RI/WO (D1) The CPU is expecting data input.  
M1 (D5) This is an instruction fetch period.  
MEMR (D7) Data input is expected from memory.  
The leading edge of  $\Phi_2$  is used to set the required memory address on the address lines A<sub>0</sub> to A<sub>15</sub>.
- Period T<sub>2</sub> External logic uses the  $\Phi_1$  pulse of time period T<sub>2</sub> to read status off the Data Bus. The read status strobe may be created as follows:



Remember, if you are using an 8228 System Controller, it reads and decodes status for you. Immediately after status has been output on the Data Bus, the Data Bus is free to receive the instruction object code. The address for the instruction object code will be on the Address Bus; this address appears on the Address Bus during T<sub>1</sub>, beginning with the rising edge of  $\Phi_2$ . The fact that status has been output and the Data Bus is free to receive the instruction object code is indicated by DBIN being pulsed high. The DBIN high pulse begins with the rising edge of  $\Phi_2$  in T<sub>2</sub> and lasts exactly one clock period.

- Period T<sub>3</sub> While DBIN is high, external logic must place the addressed instruction code on the Data Bus. The CPU will store this data in the Instruction register—whence the Control Unit interprets it as an instruction code. The Data Bus is floated at  $\Phi_2$  during T<sub>3</sub>. This means that the Data Bus has been disconnected from the CPU and can be used in any way by logic external to the CPU.

- Period T<sub>4</sub> The Address Bus is floated at  $\Phi_2$  during T<sub>4</sub>.

**The 8080A uses 1, 2 and 3 byte instructions. Each byte of a multibyte instruction requires its own instruction fetch.** Exact timing for multibyte instructions is given later in this chapter, after the 8080A instruction set has been described.

## A MEMORY READ OR WRITE OPERATION

So far as external logic is concerned, there is no difference between "read from memory" timing and instruction fetch timing — except that the M1 status (D5 on the Data Bus) is high during an instruction fetch only. **Figure 4-5** therefore applies to a memory read operation also.

Since a memory read operation is executed during time periods T<sub>1</sub>, T<sub>2</sub> and T<sub>3</sub> of a machine cycle, the presence of a memory read operation in an instruction's execution sequence will add one machine cycle to instruction execution time.

**Figure 4-6 shows timing and signal sequences for a memory write operation. The signal sequences are identical to the instruction fetch sequence with the exception that DBIN remains low during T<sub>2</sub> and T<sub>3</sub>, and different status signals are output on the Data Bus during T<sub>1</sub>.**

## SEPARATE STACK MEMORY MODULES

**One 8080A CPU can access two memory modules with overlapping memory addresses: a stack memory module and a nonstack memory module.** Overlapping memory addresses can be used by the two memory modules, since Stack status (D2 high at  $\Phi_1$  in T<sub>2</sub>) can be used to select the stack memory, while lack of Stack status (D2 low at  $\Phi_1$  in T<sub>2</sub>) can be used to select nonstack memory. External logic must decode the address as referencing stack or non-stack memory.

Note that the 8228 System Controller does not generate a STACK control signal. Nevertheless, if you wish, you may implement separate stack and nonstack memory, with overlapping addresses; this requires your own status decode logic to isolate the Stack status. Such logic is quite simple, and may be illustrated as follows:



The only disadvantage associated with having a separate stack memory is that nonstack instructions cannot reference the stack memory.



Figure 4-5. 8080A Instruction Fetch Sequence

## THE WAIT STATE

A Wait state may occur between clock periods T<sub>2</sub> and T<sub>3</sub>. The Wait state frees external logic or memory from having to operate at CPU speed. Wait state timing is illustrated in Figure 4-7 and Figure 4-8.

If READY is low during Φ2 of T<sub>2</sub>, the 8080A CPU will enter the Wait state following T<sub>2</sub>. The Wait state consists of any number of clock periods during which the CPU performs no operations and maintains the levels of all output signals. The Wait state ends when READY is input high. The CPU samples READY during every Φ2 pulse within the Wait state; the Wait state will therefore end with the Φ1 pulse which follows a Φ2 pulse during which READY is sensed high.

**8080A  
SLOW  
MEMORIES**

**Memory interface logic in any 8080A microcomputer system must be designed to anticipate that every memory access either will, or will not require a Wait state.**

If memory is as fast as the 8080A CPU, then READY will normally be held high, in anticipation of no Wait state. In Figures 4-7 and 4-8 a broken line is used to represent this "READY normally high" case. Memory interface logic will pull READY low in order to insert one or more Wait machine cycles only in special circumstances; memory interface logic has until  $\Phi_2$  of T2 to pull READY low.



Figure 4-6. 8080A Memory Write Timing

If memory is slower than the 8080A CPU, then READY will normally be held low in anticipation of one or more Wait machine cycles occurring between T<sub>2</sub> and T<sub>3</sub>. In the special circumstance where no Wait state is needed, memory interface logic has until  $\Phi_2$  of T<sub>2</sub> to set READY high.

Note that  $\overline{WR}$ , if active, will be held low for the entire duration of a Wait state. This is because if  $\overline{WR}$  is to be set low, the transition occurs at  $\Phi_1$  of T<sub>2</sub> and lasts until  $\Phi_1$  of T<sub>4</sub> — a period which completely encompasses the Wait state.

**Relatively simple logic can be used to add a Wait state to a machine cycle.** Consider the following scheme:

**8080A WAIT STATE REQUEST LOGIC**



Our goal, using the logic above, is to create a low READY pulse, which is one clock period wide, whenever MEMR makes a high-to-low transition.



Consider the sequence of signal transitions in the logic we have illustrated above. At each  $\Phi_1$  clock pulse, transitions will occur as follows:



It requires  $\overline{Q_1}$  and  $Q_2$  to be high simultaneously for READY to be low; and that condition exists for a single clock pulse. Observe that you can use READY to trigger a one-shot in order to create a low READY input of any duration.



Figure 4-7. The 8080A CPU Operating With Fast Memory and No Wait State



Figure 4-8. The 8080A CPU Operating With Slow Memory and a Normal Wait State

### THE WAIT, HOLD AND HALT STATES

We have discussed the Wait state within an 8080A microcomputer system, now we have to look at two further states during which instructions are not executed: the Hold and the Halt states.

The fact that there are three states within which instructions are not being executed is frequently a source of confusion to 8080A users. Let us, therefore, clearly identify the differences between these three states before continuing a discussion of the Hold and Halt states.

As we have already seen, the Wait state consists of one or more clock periods which are inserted within a machine cycle, giving external logic time to respond to a memory access. Thus, the Wait state consists of an indeterminate number of clock periods which occur within a machine cycle and extend the duration of that machine cycle.

The purpose of the Hold state is to float the System busses so that external logic can perform direct memory access operations. Conceptually, therefore, a Hold condition consists of any number of clock periods, occurring in between two machine cycles which define the termination of one instruction's execution and the initiation of the next instruction's execution:



The Hold state may be looked upon as a period of time during which the CPU goes into a state of suspended animation.

The Halt state results from the execution of a Halt instruction. The System Bus is not floated during a Halt state. During the Halt state, the CPU simply marks time. The purpose of a Halt state is to define those time intervals when there is nothing for the CPU to do; now when the CPU has nothing to do, it is only logical to assume that the CPU cannot know how long it will be before it has something useful to do. Typically a Halt condition will end when some external logic demands the service of the CPU. One method that external logic uses to demand CPU service is the interrupt request. The 8080A therefore requires an interrupt request to terminate the Halt state.

Let us now look at the Hold and Halt states in more detail.

## THE HOLD STATE

**The Hold state allows external logic to stop the CPU.**

**The Hold state is similar to the Wait state. During both states, signals output by the CPU are held constant; but the Data and Address Busses are floated in the Hold state only, not in the Wait state.**

**The Hold and Wait states are also initiated in different ways and they serve different functions.**

The Wait state is initiated if external operations will not be completed during T<sub>3</sub>. The purpose of the Wait state is to allow the CPU to operate with slow memories or external logic, therefore a Wait always occurs between clock periods T<sub>2</sub> and T<sub>3</sub>.

A Hold state is initiated by the hold request input signal HOLD. The CPU acknowledges the onset of the Hold state by outputting HLDA high. If a HOLD is requested during a read or input operation (RI/W<sub>O</sub> (D1) high in T<sub>2</sub>), then HLDA is set high by the leading edge of  $\Phi_1$  in T<sub>3</sub>. If a HOLD is requested during a write or output operation, then HLDA is set high by the leading edge of  $\Phi_1$  in the cycle following T<sub>3</sub>.

Note that even though HOLD is acknowledged and the Hold state is initiated in T<sub>3</sub> during a read memory or input data machine cycle, logic must still hold data steady on the Data Bus until the leading edge of  $\Phi_2$  in T<sub>3</sub>. This is because operations internal to the CPU will be executed normally during a HOLD. Operations internal to the CPU will only cease if the Hold state lasts for more cycles than would normally be present before the onset of the next T<sub>1</sub> cycle.

HOLD low will cause the end of the Hold state. HOLD low must coincide with the leading edge of  $\Phi_1$  or  $\Phi_2$ , and will terminate the Hold state at the  $\Phi_1$  pulse of the next machine cycle's T<sub>1</sub> clock period. The 8080A CPU will signal the end of the Hold state with HLDA false.

During the Hold state, the Data Bus and the Address Bus are floated. Floating begins at  $\Phi_2$  in T<sub>3</sub> for a read operation and at  $\Phi_2$  in the clock period following T<sub>3</sub> otherwise.

Figures 4-9 and 4-10 illustrate some variations on the Hold state.

**The NEC 8080A and the Intel 8080A differ when a Hold is requested during a DAD instruction's execution.** The NEC 8080A initiates the Hold as though a read operation was occurring, while the Intel 8080A initiates the Hold operation as though a write operation was occurring.

**NEC 8080A  
HOLD  
DIFFERENCES**



Figure 4-9A. Floating of Data and Address Busses at  $\Phi_2$  in T<sub>3</sub>, for READ Operation Being Completed Prior to Onset of Hold State



Figure 4-9B. Floating of Data and Address Busses at  $\Phi_2$  in  $T_4$ , for a WRITE, or Any Non-READ Operation ( $R/I/WO=False$ )



Figure 4-10A. Floating of Data and Address Busses for READ Operation in a Three Clock Period Machine Cycle



Figure 4-10B. Floating of Data and Address Busses at  $\Phi_2$  in  $T_1$ , for WRITE or Any Non-READ Operation Being Completed Prior to Onset of Hold State

## THE HALT STATE AND INSTRUCTION

The Halt state is similar to the Wait state, except that it is initiated by a Halt instruction.

The Halt state is not initiated by READY low, although READY low is a necessary requirement for the onset of the Halt state. This means that READY high cannot be used to terminate a Halt state. Instead, an interrupt request (INT high) must be used to terminate the Halt state.

Note that if interrupts have been inhibited, the interrupt request (INT high) will never be acknowledged, and the only way to get out of a Halt state is to power down, then power up the CPU.

An anomaly of the Halt state is that the Data and Address Busses may be floated by entering the Hold state after entering the Halt state; that is, you can move into, and out of the Hold state while in the Halt state.

If the Hold state is entered after the Halt state, then the Hold state must be exited by setting HOLD low before exiting the Halt state.

During a HALT, a hold request signaled by HOLD will not be acknowledged if an interrupt has been requested (INT high) but not acknowledged (INTE high); i.e., the CPU will not enter the Hold state in the time between an interrupt being requested and acknowledged. Once the interrupt has been acknowledged (INTE low), the CPU may enter the Hold state.

Figure 4-30 illustrates signal sequences and timing for the Halt instruction (and state).

## THE RESET OPERATION

A RESET high signal input to the 8080A CPU will clear the Program Counter and disable interrupts.

To properly perform the reset operation, RESET should be held high for at least three clock periods. During these three clock periods, reset operations are executed in the following sequence:

- 1) The Program Counter is cleared.
- 2) All interrupt requests are disabled.
- 3) Internal interrupt acknowledge logic (associated with signal INTE) is cleared.
- 4) Internal hold acknowledge logic (associated with signal HLDA) is cleared.

For as long as RESET is high, all 8080A CPU operations will be suspended.

When RESET is reset low, instruction execution will resume with a T<sub>1</sub> clock period at the next Φ1 pulse. Since the Program Counter contains 0000, the first instruction executed following RESET will be the instruction stored in memory location 0000<sub>16</sub>.

Interrupts remain disabled when program execution resumes.

When you power up any 8080A system you must simultaneously reset it. Powering up does not reset or change anything within the 8080A. If you power up without resetting, then registers, including the Program Counter, will contain undefined data; thus program execution will immediately and erroneously begin at some random location of memory.

Here are two possible reset on power up logic implementations:

First a simple logic sequence:



Next a more complex, and more reliable one:



Figure 4-11. Interrupt Initiation Sequence

## EXTERNAL INTERRUPTS

External logic may request an interrupt at any time by setting the INT input high. An interrupt request will only be acknowledged if interrupts have been enabled. Normally the EI (Enable Interrupts) and DI (Disable Interrupts) instructions are executed to enable and disable interrupts; however, interrupts are automatically disabled by the CPU during the RESET condition, and following an interrupt acknowledge.

The 8080A CPU outputs INTE high when interrupts have been enabled, and low when interrupts are disabled. If interrupts are enabled, then the 8080A CPU will acknowledge an interrupt request during the next T<sub>1</sub> clock period, on the rising edge of Φ2. At this time INTE is set low to reflect the fact that an interrupt acknowledge automatically disables interrupts. Timing is illustrated in Figure 4-11.

The 8080A CPU informs external logic that an interrupt has been acknowledged by outputting this status on the Data Bus:

D0 - INTA  
D1 - RI/V/O  
D5 - M1

INTA is the principal interrupt acknowledge status; it is converted into a separate interrupt acknowledge control signal by the 8228 System Controller.

Once an interrupt has been acknowledged, the 8080A CPU enters an instruction fetch sequence — but with two differences:

- 1) Program Counter increment logic is suppressed.
- 2) Different statuses are output on the Data Bus during T<sub>2</sub>. The statuses output on the Data Bus during various machine cycles are summarized in Table 4-3.

The different statuses output during T<sub>2</sub> of a normal, or a post-interrupt acknowledge instruction fetch are very important.

During a normal instruction fetch sequence, MEMR is output true on D7.

During the instruction fetch sequence which follows an interrupt acknowledge, MEMR is not output true on D7, but INTA is output true on D0.

Thus, external logic can differentiate between a normal instruction fetch and the instruction fetch sequence which follows an interrupt acknowledge.

It is very important that external logic be able to differentiate between a normal instruction fetch and an interrupt acknowledge instruction fetch. When the interrupt is acknowledged, the Program Counter is addressing an instruction which will not get executed until the interrupt service routine has completed execution:



Therefore the first instruction executed following the interrupt acknowledge must save the Program Counter contents. The last instruction executed within the interrupt service routine restores the Program Counter contents. During the instruction fetch which follows an interrupt acknowledge, the Program Counter increment logic is suppressed, because the 8080A CPU expects the object code for the first interrupt service routine instruction to be supplied by the interrupting device instead of memory:



The object code provided by external logic during the instruction fetch which follows the interrupt acknowledge must be the object code for an instruction which will save the Program Counter contents for subsequent retrieval. There is only one instruction which will do this and that is a subroutine CALL instruction. Recall from Volume I that the subroutine CALL instruction will save the current Program Counter contents on the Stack, then will load a new starting address into the Program Counter. Thus, a subroutine CALL instruction satisfies the logical requirements for interrupt service routine initiation.

**The normal way of terminating a subroutine is via a Return instruction.** This instruction loads the Program Counter from the top of the Stack. The Return instruction will, therefore, satisfy the logical requirements for interrupt service routine termination.

There are two types of 8080A subroutine CALL instruction: the RESTART (RST) and the CALL. **The RST instruction is a one-byte subroutine CALL with the following object code:**



Therefore RST n instructions are equivalent to subroutine CALL instructions, with program execution branching as follows:

| Subroutine                         |
|------------------------------------|
| RST 0 branch to 0000 <sub>16</sub> |
| RST 1 branch to 0008 <sub>16</sub> |
| RST 2 branch to 0010 <sub>16</sub> |
| RST 3 branch to 0018 <sub>16</sub> |
| RST 4 branch to 0020 <sub>16</sub> |
| RST 5 branch to 0028 <sub>16</sub> |
| RST 6 branch to 0030 <sub>16</sub> |
| RST 7 branch to 0038 <sub>16</sub> |

The CALL instruction is a typical three-byte, direct memory addressing subroutine call:



The address of the instruction following the subroutine call (nnnn+3) is saved on the Stack, to be retrieved subsequently by a Return instruction. The second and third CALL instruction object code bytes provide the address of the subroutine's first instruction; this address (ppqq) therefore is loaded into the Program Counter.

**What is not clearly understood by many 8080A users is that external logic can respond to an interrupt acknowledge by inserting either an RST or a subroutine CALL instruction.**

**Responding to an interrupt acknowledge by inserting an RST instruction is very straightforward.** The INTA status output during T<sub>2</sub> can be used to select external logic as the source of an object code, while the lack of an MEMR status can be used to suppress the normal instruction fetch which would occur from program memory. Thus, a simple 8-bit I/O buffer will generate a Restart instruction as follows:



**With a little more effort, external logic can be designed to provide a subroutine CALL instruction's object code following the interrupt acknowledge.** Providing the INTA status is used to suppress normal program memory accesses for the next three machine cycles, logic associated with the external interrupt request can supply the three consecutive object code bytes of a normal subroutine CALL instruction.

In a configuration that includes an 8228 System Controller, if the first object code byte received following INTA output is a CALL (CD<sub>16</sub>), then the 8228 System Controller outputs two more INTA statuses for the next two machine cycles. Now external logic can use INTA as a signal which disables normal memory accesses, selecting external logic instead. For more details, see the 8228 System Controller description given later in this chapter.

If your configuration does not include an 8228 System Controller, then external logic must be quite complex if it responds to an interrupt acknowledge with a CALL instruction. These are the operations external logic must perform:

- 1) In response to INTA true, suppress normal memory references and transmit the code CD<sub>16</sub> to the CPU. This code must be transmitted at the proper time, as an instruction code on the Data Bus.
- 2) Suppress normal memory accesses for the next two clock periods. Remember, there is no INTA true for these two periods.
- 3) During the next two clock periods, transmit the low order half, then the high order half of the interrupt service routine starting address. These two address bytes must be provided out of external logic, and their timing on the Data Bus must conform exactly to the second and third bytes of a CALL instruction.

If your configuration includes an 8259 Priority Interrupt Control Unit, then this device takes care of all logic associated with responding to an interrupt acknowledge with a CALL; the 8259 is described later in this chapter.

**The NEC 8080A does not handle the INTA signal in the same way as the Intel 8080A.** In response to a Call instruction executed during an interrupt acknowledge, the NEC 8080A outputs INTA true for three machine cycles; in an Intel 8080A system an 8228 System Controller must be present for this to occur. The NEC 8080A D0 status output also differs at this time; see Table 4-3 for details.

**NEC 8080A  
INTERRUPT  
ACKNOWLEDGE  
DIFFERENCES**

The NEC 8080A responds to Restart instructions following an interrupt acknowledge in the same way as the Intel 8080A.

## EXTERNAL INTERRUPTS DURING THE HALT STATE

**With all 8080A devices except the NEC 8080A, interrupt acknowledge logic during a Halt state is as illustrated in Figure 4-11. For the NEC 8080A, however, the interrupt acknowledge sequence differs slightly during the Halt state only.** INTE is reset low by the NEC 8080A on the rising edge of  $\Phi_2$  in clock period  $T_2$ ; this is one clock period later than illustrated in Figure 4-11. Note that this difference in NEC 8080A response applies only to the interrupt acknowledge process occurring within a Halt state.

**NEC 8080A  
EXTERNAL  
INTERRUPT  
DIFFERENCES**

## WAIT AND HOLD CONDITIONS FOLLOWING AN INTERRUPT

An interrupt cannot be acknowledged during a WAIT or HOLD condition. However, either of these conditions may occur following the interrupt acknowledge. For example, if there is insufficient time between  $\Phi_1$  in  $T_2$  and  $\Phi_2$  in  $T_2$  for external logic to fetch the required RST or CALL instruction, more time may be acquired by using the READY signal to generate a Wait state, as with any instruction's execution.

# THE 8080A INSTRUCTION SET

**Table 4-4 summarizes the 8080A instruction set; there is a significant departure in instruction set philosophy from the hypothetical microcomputer described in Volume I.**

The 8080A is most efficiently programmed by making extensive use of the Stack and of subroutines. By providing a variety of Jump-to-Subroutine on Condition, and Return-from-Subroutine on Condition instructions, the 8080A allows the execution of subroutines to become an integral part of programmed logic sequences.

Observe that the 8080A has a number of 16-bit instructions; that is, instructions that operate on the 16-bit contents of the BC, DE or HL registers. These include 16-bit increment and decrement, 16-bit add, and 16-bit data moves.

The 16-bit instruction XTHL is particularly useful, since by allowing the top two Stack bytes to be exchanged with the HL registers, an easy method is provided for switching addresses.

The DAA instruction modifies the A register contents to generate a binary coded decimal equivalent of the original binary value. If carries out of bit 3 or bit 7 result, these are reported in the Auxiliary Carry and Carry statuses, respectively. See Volume I for a discussion of the decimal adjust operation.

**There are a few differences between NEC 8080A and Intel 8080A instruction execution.**

For binary subtraction and BCD arithmetic the NEC 8080A performs operations in what is theoretically the "correct" fashion — which differs from the actual implementation of the Intel 8080A. Specifically, the NEC 8080A has a Subtract status (SUB) which is set after any addition is performed. Only the NEC 8080A has a Subtract status.

**NEC 8080A  
INSTRUCTION  
SET  
DIFFERENCES**

The NEC 8080A correctly sets and resets the Auxiliary Carry status (AC) during subtract operations, identifying any borrow by the low order digit as follows:

Borrow here sets AC

$$\begin{array}{r} \text{Y} \\ - \text{Z} \\ \hline \text{X} \end{array}$$

Bit No.

X, Y and Z represent any binary digits.

Decimal subtraction for the Intel 8080A and NEC 8080A may be illustrated as follows, assuming the contents of Register B are to be subtracted from the contents of Register C:

| INTEL 8080A | NEC 8080A |
|-------------|-----------|
| MVI A,99H   | MOV A,B   |
| SUB C       | SUB C     |
| ADD B       | DAA       |
| DAA         |           |

In the instruction sequence illustrated above for the Intel 8080A, you cannot use the Subtract instruction directly since it works for binary arithmetic only. You must create the nine's complement of the subtrahend by subtracting it from 99. Then you add the minuend to the nine's complement of the subtrahend. Finally you decimal adjust the result.

In the case of the NEC 8080A you may use the Subtract instruction for either binary or BCD data.

For a complete discussion of decimal subtraction using the Intel 8080A, see 8080 Programming for Logic Design, Chapter 7.

**The Carry and Auxiliary Carry statuses are also treated differently by the NEC and Intel 8080A. When Boolean instructions are executed by the Intel 8080A, the Carry status (C) is always reset; the Auxiliary Carry status (AC) is sometimes reset. The NEC 8080A leaves the Carry and Auxiliary Carry statuses alone when executing Boolean instructions.**

**When the AMD 9080A executes Boolean instructions it always clears both the Carry and Auxiliary Carry statuses.**

## THE BENCHMARK PROGRAM

Our benchmark program is coded for the 8080A as follows:

```

LHLD TABLE    ;LOAD ADDRESS OF FIRST FREE TABLE BYTE IN HL
LXI D,IOBUF   ;LOAD STARTING ADDRESS OF IOBUF IN DE
LDA IOCNT    ;LOAD I/O BUFFER LENGTH
MOV B,A      ;SAVE IN B
LOOP LDAX D   ;LOAD NEXT I/O BYTE
INX D        ;INCREMENT BUFFER ADDRESS
MOV M,A      ;STORE IN TABLE
INX H        ;INCREMENT TABLE ADDRESS
DCR B        ;DECREMENT BYTE COUNT
JNZ LOOP     ;RETURN FOR MORE BYTES
SHLD TABLE   ;AT END, RESTORE ADDRESS OF FIRST FREE TABLE BYTE

```

**The 8080A makes very few assumptions regarding the benchmark program.**

The address of the first free byte in the data table is assumed to be stored in the first two bytes of the data table — addressed by the label TABLE. The immediate addressing instruction LHLD loads the contents of the first two bytes of the data table into the H and L registers. At the end of the program, the incremented table address is restored with the direct addressing instruction SHLD.

Since the I/O buffer starting address does not change, an Immediate instruction is used to load this address into the DE registers.

Since the number of occupied bytes in the I/O buffer may change, a direct addressing instruction, LDA, is used to load this buffer length into the Accumulator. It is then moved to the B register, since the Accumulator is used to transfer data within the program loop.

The 8080A program makes no assumptions regarding the location of either the I/O buffer, or the data table, but it does assume that the table is not more than 256 bytes long.

**These are the abbreviations used in Table 4-4:**

|   |                 |                                                |
|---|-----------------|------------------------------------------------|
| A | The Accumulator |                                                |
| B | The B register  | These are sometimes treated as a register pair |
| C | The C register  |                                                |
| D | The D register  | These are sometimes treated as a register pair |
| E | The E register  |                                                |

|     |                                                                              |                                                        |
|-----|------------------------------------------------------------------------------|--------------------------------------------------------|
| H   | The H register                                                               | This register pair provides the implied memory address |
| L   | The L register                                                               |                                                        |
| C   | Carry status. In Table 4-4 C refers to Carry status, not to the C register.  |                                                        |
| AC  | Auxiliary Carry status                                                       |                                                        |
| Z   | Zero status                                                                  |                                                        |
| S   | Sign status                                                                  |                                                        |
| P   | Parity status                                                                |                                                        |
| SUB | Subtract status (present in the NEC 8080A only)                              |                                                        |
| I   | The Instruction register                                                     |                                                        |
| I2  | Second object code byte                                                      |                                                        |
| I3  | Third object code byte                                                       |                                                        |
| PC  | The Program Counter                                                          |                                                        |
| SP  | The Stack Pointer                                                            |                                                        |
| PSW | The Program Status Word, which has bits assigned to status flags as follows: |                                                        |



|        |                                                                     |
|--------|---------------------------------------------------------------------|
| DATA   | 8-bit immediate data                                                |
| DATA16 | 16-bit immediate data                                               |
| DEV    | An I/O device                                                       |
| REG    | Register A, B, C, D, E, H or L                                      |
| s      | Source register                                                     |
| d      | Destination register                                                |
| M      | Memory, address implied by HL                                       |
| LABEL  | A 16-bit address, specifying an instruction label                   |
| RP     | A register pair: B for BC, D for DE, H for HL, SP for Stack Pointer |
| PORT   | An I/O port, identified by a number between 0 and FF16              |
| ADDR   | A 16-bit address, specifying a data memory byte                     |
| [ ]    | Contents of location identified within brackets                     |
| [[ ]]  | Memory byte addressed by location identified within brackets        |
| [ ]    | Complement of the contents of                                       |
| ←      | Move data in direction of arrow                                     |
| ↔      | Exchange contents of locations on either side of arrow              |
| +      | Add                                                                 |
| -      | Subtract                                                            |
| Λ      | AND                                                                 |
| ∨      | OR                                                                  |
| ≠      | XOR                                                                 |

**The letter C is used to identify Carry status.** Although C also identifies one of the 8080A registers, registers are always referenced generically in Table 4-4.

|                                                    |
|----------------------------------------------------|
| <b>8080A<br/>CARRY<br/>STATUS<br/>NOMENCLATURE</b> |
|----------------------------------------------------|

Table 4-4. A Summary of 8080A/9080A Microcomputer Instruction Set

| TYPE                                              | MNEMONIC | OPERAND(S) | BYTES | STATUSES |      |   |   |   |      | OPERATION PERFORMED                                                                                                  |
|---------------------------------------------------|----------|------------|-------|----------|------|---|---|---|------|----------------------------------------------------------------------------------------------------------------------|
|                                                   |          |            |       | C        | AC   | Z | S | P | SUB* |                                                                                                                      |
| I/O                                               | IN       | DEV        | 2     |          |      |   |   |   |      | [A]—[DEV]<br>Input to A from device DEV (DEV = 0 to 255)                                                             |
|                                                   | OUT      | DEV        | 2     |          |      |   |   |   |      | [DEV]—[A]<br>Output from A to device DEV (DEV = 0 to 255)                                                            |
| PRIMARY<br>MEMORY REFERENCE                       | LDAX     | RP         | 1     |          |      |   |   |   |      | [A]—[[RP]]<br>Load A using address implied by BC (RP = B) or DE (RP = D)<br>[[RP]]—[A]                               |
|                                                   | STAX     | RP         | 1     |          |      |   |   |   |      | Store A using implied addressing as for LDAX<br>[REG]—[[H,L]]                                                        |
|                                                   | MOV      | REG,M      | 1     |          |      |   |   |   |      | Load any register using address implied by HL<br>[[H,L]]—[REG]                                                       |
|                                                   | MOV      | M,REG      | 1     |          |      |   |   |   |      | Store any register using address implied by HL<br>[A]—[ADDR], i.e., [A]—[[I3, I2]]                                   |
|                                                   | LDA      | ADDR       | 3     |          |      |   |   |   |      | Load A, use direct addressing<br>[ADDR]—[A], i.e. [[I3, I2]]—[A]                                                     |
|                                                   | STA      | ADDR       | 3     |          |      |   |   |   |      | Store A, use direct addressing<br>[L]—[ADDR], [H]—[ADDR + 1], i.e., [L]—[[I3, I2]], [H]—[[I3, I2] + 1]               |
|                                                   | LHLD     | ADDR       | 3     |          |      |   |   |   |      | Load H and L registers, use direct addressing<br>[ADDR]—[L], [ADDR + 1]—[H] i.e., [[I3, I2]]—[L], [[I3, I2] + 1]—[H] |
|                                                   | SHLD     | ADDR       | 3     |          |      |   |   |   |      | Store H and L registers, use direct addressing                                                                       |
| SECONDARY<br>MEMORY REFERENCE<br>(MEMORY OPERATE) | ADD      | M          | 1     | X        | X    | X | X | X | 0    | [A]—[A] + [[H,L]]<br>Add to A                                                                                        |
|                                                   | ADC      | M          | 1     | X        | X    | X | X | X | 0    | [A]—[A] + [[H,L]] + [C]<br>Add with Carry to A                                                                       |
|                                                   | SUB      | M          | 1     | X        | X    | X | X | X | 1    | [A]—[A] - [[H,L]]<br>Subtract from A                                                                                 |
|                                                   | SBB      | M          | 1     | X        | X    | X | X | X | 1    | [A]—[A] - [[H,L]] - [C]<br>Subtract from A with borrow                                                               |
|                                                   | ANA      | M          | 1     | 0**      | Xt** | X | X | X |      | [A]—[A] ^ [H,L]<br>AND with A                                                                                        |
|                                                   | XRA      | M          | 1     | 0**      | 0t** | X | X | X |      | [A]—[A] ⊕ [[H,L]]<br>Exclusive-OR with A                                                                             |
|                                                   | ORA      | M          | 1     | 0**      | 0†** | X | X | X |      | [A]—[A] V [[H,L]]<br>OR with A                                                                                       |
|                                                   | CMP      | M          | 1     | X        | X    | X | X | X | 1    | [A] - [[H,L]]. Discard result but set flags.<br>Compare with A                                                       |
|                                                   | INR      | M          | 1     |          | X**  | X | X | X | 0    | [[H,L]]—[[H,L]] + 1<br>Increment memory                                                                              |
|                                                   | DCR      | M          | 1     |          | X**  | X | X | X | 1    | [[H,L]]—[[H,L]]-1<br>Decrement memory                                                                                |

Table 4-4. A Summary of 8080A/9080A Microcomputer Instruction Set (Continued)

| TYPE                                                | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |   |   |      | OPERATION PERFORMED                                                                                                         |
|-----------------------------------------------------|----------|------------|-------|----------|----|---|---|---|------|-----------------------------------------------------------------------------------------------------------------------------|
|                                                     |          |            |       | C        | AC | Z | S | P | SUB* |                                                                                                                             |
| IMMEDIATE                                           | LXI      | RP,DATA16  | 3     |          |    |   |   |   |      | [RP] ← DATA16<br>Load 16-bit immediate data into BC (RP = B), DE (RP = D),<br>HL (RP = H) or SP (RP = SP)<br>[[H,L]] ← DATA |
|                                                     | MVI      | M,DATA     | 2     |          |    |   |   |   |      | Load 8-bit immediate data into memory location with address implied by HL<br>[REG] ← DATA                                   |
|                                                     | MVI      | REG,DATA   | 2     |          |    |   |   |   |      | Load 8-bit immediate data into any register                                                                                 |
| JUMP                                                | JMP      | ADDR       | 3     |          |    |   |   |   |      | [PC] ← ADDR<br>Jump to instruction with label ADDR                                                                          |
|                                                     | PCHL     |            | 1     |          |    |   |   |   |      | [PC] ← [H,L]<br>Jump to instruction at location implied by HL                                                               |
| SUBROUTINE CALL AND RETURN<br>(IMMEDIATE AND STACK) | CALL     | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine starting at ADDR                                            |
|                                                     | CC       | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if C = 1                                                    |
|                                                     | CNC      | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if C = 0                                                    |
|                                                     | CZ       | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if Z = 1                                                    |
|                                                     | CNZ      | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if Z = 0                                                    |
|                                                     | CP       | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if S = 0                                                    |
|                                                     | CM       | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if S = 1                                                    |
|                                                     | CPE      | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if even parity                                              |
|                                                     | CPO      | ADDR       | 3     |          |    |   |   |   |      | [[SP]] ← [PC], [PC] ← ADDR, [SP] ← [SP]-2<br>Jump to subroutine if odd parity                                               |
|                                                     | RET      |            | 1     |          |    |   |   |   |      | [PC] ← [[SP]], [SP] ← [SP]+2<br>Return from subroutine                                                                      |
|                                                     | RC       |            | 1     |          |    |   |   |   |      | [PC] ← [[SP]], [SP] ← [SP]+2<br>Return from subroutine if C = 1                                                             |
|                                                     | RNC      |            | 1     |          |    |   |   |   |      | [PC] ← [[SP]], [SP] ← [SP]+2<br>Return from subroutine if C = 0                                                             |
|                                                     | RZ       |            | 1     |          |    |   |   |   |      | [PC] ← [[SP]], [SP] ← [SP]+2<br>Return from subroutine if Z = 1                                                             |
|                                                     | RNZ      |            | 1     |          |    |   |   |   |      | [PC] ← [[SP]], [SP] ← [SP]+2<br>Return from subroutine if Z = 0                                                             |
|                                                     | RM       |            | 1     |          |    |   |   |   |      | [PC] ← [[SP]], [SP] ← [SP]+2<br>Return from subroutine if S = 1                                                             |

Table 4-4. A Summary of 8080A/9080A Microcomputer Instruction Set (Continued)

| TYPE                                                         | MNEMONIC | OPERAND(S) | BYTES | STATUSES |     |   |   |   |      | OPERATION PERFORMED                                               |
|--------------------------------------------------------------|----------|------------|-------|----------|-----|---|---|---|------|-------------------------------------------------------------------|
|                                                              |          |            |       | C        | AC  | Z | S | P | SUB* |                                                                   |
| SUBROUTINE CALL AND RETURN (IMMEDIATE AND STACK) (CONTINUED) | RP       |            | 1     |          |     |   |   |   |      | [PC]—[[SP]], [SP]—[SP]+2<br>Return from subroutine if S = 0       |
|                                                              | RPE      |            | 1     |          |     |   |   |   |      | [PC]—[[SP]], [SP]—[SP]+2<br>Return from subroutine if even parity |
|                                                              | RPO      |            | 1     |          |     |   |   |   |      | [PC]—[[SP]], [SP]—[SP]+2<br>Return from subroutine if odd parity  |
| IMMEDIATE OPERATE                                            | ADI      | DATA       | 2     | X        | X   | X | X | X | 0    | [A]—[A]+DATA<br>Add immediate to A                                |
|                                                              | ACI      | DATA       | 2     | X        | X   | X | X | X | 0    | [A]—[A]+DATA+[C]<br>Add with carry immediate to A                 |
|                                                              | SUI      | DATA       | 2     | X        | X   | X | X | X | 1    | [A]—[A]-DATA<br>Subtract immediate from A                         |
|                                                              | SBI      | DATA       | 2     | X        | X   | X | X | X | 1    | [A]—[A]-DATA-[C]<br>Subtract immediate with borrow from A         |
|                                                              | ANI      | DATA       | 2     | 0**      | X†  | X | X | X |      | [A]—[A] ^ DATA<br>AND immediate with A                            |
|                                                              | XRI      | DATA       | 2     | 0**      | 0** | X | X | X |      | [A]—[A] ⊕ DATA<br>Exclusive-OR immediate with A                   |
|                                                              | ORI      | DATA       | 2     | 0**      | 0** | X | X | X |      | [A]—[A] V DATA<br>OR immediate with A                             |
|                                                              | CPI      | DATA       | 2     | X        | X   | X | X | X |      | Compare immediate with A                                          |
|                                                              |          |            |       |          |     |   |   |   |      |                                                                   |
| JUMP ON CONDITION                                            | JC       | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump if C = 1                                        |
|                                                              | JNC      | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump if C = 0                                        |
|                                                              | JZ       | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump if Z = 1                                        |
|                                                              | JNZ      | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump if Z = 0                                        |
|                                                              | JP       | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump if S = 0                                        |
|                                                              | JM       | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump if S = 1                                        |
|                                                              | JPE      | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump on even parity                                  |
|                                                              | JPO      | ADDR       | 3     |          |     |   |   |   |      | [PC]—ADDR<br>Jump on odd parity                                   |

Table 4-4. A Summary of 8080A/9080A Microcomputer Instruction Set (Continued)

| TYPE                      | MNEMONIC | OPERAND(S) | BYTES | STATUSES |      |   |   |   |      | OPERATION PERFORMED                                                                                                      |
|---------------------------|----------|------------|-------|----------|------|---|---|---|------|--------------------------------------------------------------------------------------------------------------------------|
|                           |          |            |       | C        | AC   | Z | S | P | SUB* |                                                                                                                          |
| REG-REG MOVE              | MOV      | ds         | 1     |          |      |   |   |   |      | [REG]—[REG]<br>Move any register (s) to any register (d)                                                                 |
|                           | XCHG     |            | 1     |          |      |   |   |   |      | [D]—[H], [E]—[L]<br>Exchange DE with HL                                                                                  |
|                           | SPHL     |            | 1     |          |      |   |   |   |      | [SP]—[HL]<br>Transfer HL to SP                                                                                           |
| REGISTER-REGISTER OPERATE | ADD      | REG        | 1     | X        | X    | X | X | X | 0    | [A]—[A] + [REG]<br>Add any register to A                                                                                 |
|                           | ADC      | REG        | 1     | X        | X    | X | X | X | 0    | [A]—[A] + [REG] + [C]<br>Add with Carry any register to A                                                                |
|                           | SUB      | REG        | 1     | X        | X    | X | X | X | 1    | [A]—[A] - [REG]<br>Subtract any register from A                                                                          |
|                           | SBB      | REG        | 1     | X        | X    | X | X | X | 1    | [A]—[A] - [REG] - [C]<br>Subtract any register with borrow from A                                                        |
|                           | ANA      | REG        | 1     | 0**      | 0†   | X | X | X |      | [A]—[A] $\wedge$ [REG]<br>AND any register with A                                                                        |
|                           | XRA      | REG        | 1     | 0**      | 0†** | X | X | X |      | [A]—[A] $\vee$ [REG]<br>Exclusive-OR any register with A                                                                 |
|                           | ORA      | REG        | 1     | 0**      | 0†** | X | X | X |      | [A]—[A] V [REG]<br>OR any register with A                                                                                |
|                           | CMP      | REG        | 1     | X        | X    | X | X | X | 1    | [A] - [REG]. Discard result but set flags.<br>Compare any register with A                                                |
|                           | DAD      | RP         | 1     | X        |      |   |   |   | 0    | [H,L]—[H,L] + [RP]<br>Add to HL                                                                                          |
|                           |          |            |       |          |      |   |   |   |      |                                                                                                                          |
| REGISTER OPERATE          | INR      | REG        | 1     |          | X**  | X | X | X | 0    | [REG]—[REG]+1<br>Increment any register                                                                                  |
|                           | DCR      | REG        | 1     |          | X**  | X | X | X | 1    | [REG]—[REG]-1<br>Decrement any register                                                                                  |
|                           | CMA      |            | 1     |          |      |   |   |   |      | [A]—[A]<br>Complement A                                                                                                  |
|                           | DAA      |            | 1     | X        | X**  | X | X | X |      | Decimal adjust A                                                                                                         |
|                           | RLC      |            | 1     | X        |      |   |   |   |      | <br>Rotate A left with branch carry   |
|                           | RRC      |            | 1     | X        |      |   |   |   |      | <br>Rotate A right with branch carry |

Table 4-4. A Summary of 8080A/9080A Microcomputer Instruction Set (Continued)

| TYPE                            | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |   |   |      | OPERATION PERFORMED                                                                                            |
|---------------------------------|----------|------------|-------|----------|----|---|---|---|------|----------------------------------------------------------------------------------------------------------------|
|                                 |          |            |       | C        | AC | Z | S | P | SUB* |                                                                                                                |
| REGISTER OPERATE<br>(CONTINUED) | RAL      |            | 1     | X        |    |   |   |   |      |                              |
|                                 | RAR      |            | 1     | X        |    |   |   |   |      |                              |
|                                 | INX      | RP         | 1     |          |    |   |   |   |      | $[RP] \leftarrow [RP] + 1$<br>Increment RP, RP = BC, DE, HL or SP <sup>A</sup>                                 |
|                                 | DCX      | RP         | 1     |          |    |   |   |   |      | $[RP] \leftarrow [RP] - 1$<br>Decrement RP                                                                     |
| STACK                           | PUSH     | RP         | 1     |          |    |   |   |   |      | $\{ [SP] \leftarrow [RP], [SP] \leftarrow [SP] - 2 \}$<br>Push RP contents onto stack } RP = BC, DE, HL or PSW |
|                                 | POP      | RP         | 1     |          |    |   |   |   |      | $[RP] \leftarrow [SP], [SP] \leftarrow [SP] + 2$<br>Pop stack into RP                                          |
|                                 | XTHL     |            | 1     |          |    |   |   |   |      | $[HL] \leftarrow [SP]$<br>Exchange HL with top of stack                                                        |
| INTERRUPT                       | EI       |            | 1     |          |    |   |   |   |      | Enable interrupts                                                                                              |
|                                 | DI       |            | 1     |          |    |   |   |   |      | Disable interrupts                                                                                             |
|                                 | RST      | N          | 1     |          |    |   |   |   |      | Restart at addresses 8+N. N = 0 through 7.                                                                     |
| STATUS                          | STC      |            | 1     | 1        |    |   |   |   |      | $[C] \leftarrow 1$<br>Set Carry                                                                                |
|                                 | CMC      |            | 1     | X        |    |   |   |   |      | $[C] \leftarrow \neg [C]$<br>Complement Carry                                                                  |
|                                 | NOP      |            | 1     |          |    |   |   |   |      | No operation                                                                                                   |
|                                 | HLT      |            | 1     |          |    |   |   |   |      | Halt                                                                                                           |

Statuses:

|       |                       |
|-------|-----------------------|
| C     | = Carry               |
| AC    | = Carry out of bit 3  |
| Z     | = Zero                |
| S     | = Sign                |
| P     | = Parity              |
| X     | = Status set or reset |
| 0     | = Status reset        |
| 1     | = Status Set          |
| Blank | = Status unchanged    |

\* SUB status is present in NEC 8080A only

\*\* NEC 8080A does not modify these status flags

† The AMD 9080A always resets AC to 0 for all Boolean instructions. The Intel 8085 sets AC to 1 for all AND instructions, and resets AC to 0 for all other Boolean instructions.

Table 4-5. A Summary of Instruction Object Codes  
and Execution Cycles

| INSTRUCTION   | OBJECT CODE | BYTES | CLOCK PERIODS | FIGURE | INSTRUCTION | OBJECT CODE | BYTES | CLOCK PERIODS | FIGURE |
|---------------|-------------|-------|---------------|--------|-------------|-------------|-------|---------------|--------|
| LXI RP,DATA16 | 00XX0001    | 3     | 10            | 4-22   | ACI DATA    | CE YY       | 2     | 7             | 4-15   |
|               | YYYY        |       |               |        | 'ADC REG    | 10001XXX    | 1     | 4             | 4-12   |
| MOV REG,REG   | 01dddsss    | 1     | 5(4)*         | 4-13   | ADC M       | 8E          | 1     | 7             | 4-15   |
| MOV M,REG     | 01110sss    | 1     | 7             | 4-16   | ADD REG     | 10000XXX    | 1     | 4             | 4-12   |
| MOV REG,M     | 01ddd110    | 1     | 7             | 4-15   | ADD M       | 86          | 1     | 7             | 4-15   |
| MVI REG,DATA  | 00ddd110    | 2     | 7             | 4-15   | ADI DATA    | C6 YY       | 2     | 7             | 4-15   |
|               | YY          |       |               |        | ANA REG     | 10100XXX    | 1     | 4             | 4-12   |
| MVI M,DATA    | 36 YY       | 2     | 10            | 4-14   | ANA M       | A6          | 1     | 7             | 4-15   |
| NOP           | 00          | 1     | 4             | 4-12   | ANI DATA    | E6 YY       | 2     | 7             | 4-15   |
| ORA REG       | 10110XXX    | 1     | 4             | 4-12   | CALL LABEL  | CD ppqq     | 3     | 17            | 4-26   |
| ORA M         | B6          | 1     | 7             | 4-15   | CC LABEL    | DC ppqq     | 3     | 11/17         | 4-26   |
| ORI DATA      | F6 YY       | 2     | 7             | 4-15   | CM LABEL    | FC ppqq     | 3     | 11/17         | 4-26   |
| OUT PORT      | D3 YY       | 2     | 10            | 4-29   | CMA         | 2F          | 1     | 4             | 4-12   |
| PCHL          | E9          | 1     | 5             | 4-13   | CMC         | 3F          | 1     | 4             | 4-12   |
| POP RP        | 11XX0001    | 1     | 10            | 4-19   | CMP REG     | 1011XXX     | 1     | 4             | 4-12   |
| PUSH RP       | 11XX1011    | 1     | 11            | 4-18   | CMP M       | BE          | 1     | 7             | 4-15   |
| RAL           | 17          | 1     | 4             | 4-12   | CNC LABEL   | D4 ppqq     | 3     | 11/17         | 4-26   |
| RAR           | 1F          | 1     | 4             | 4-12   | CNZ LABEL   | C4 ppqq     | 3     | 11/17         | 4-26   |
| RC            | D8          | 1     | 5/11          | 4-27   | CP LABEL    | F4 ppqq     | 3     | 11/17         | 4-26   |
| RET           | C9          | 1     | 10(11)*       | 4-19   | CPE LABEL   | EC ppqq     | 3     | 11/17         | 4-26   |
| RLC           | 07          | 1     | 4             | 4-12   | CPI DATA    | FE YY       | 2     | 7             | 4-15   |
| RM            | F8          | 1     | 5/11          | 4-27   | CPO LABEL   | E4 ppqq     | 3     | 11/17         | 4-26   |
| RNC           | D0          | 1     | 5/11          | 4-27   | CZ LABEL    | CC ppqq     | 3     | 11/17         | 4-26   |
| RNZ           | C0          | 1     | 5/11          | 4-27   | DAA         | 27          | 1     | 4             | 4-12   |
| RP            | F0          | 1     | 5/11          | 4-27   | DAD RP      | 00XX1001    | 1     | 10(11)*       | 4-20   |
| RPE           | E8          | 1     | 5/11          | 4-27   | DCR REG     | 00XXX101    | 1     | 5             | 4-13   |
| RPO           | E0          | 1     | 5/11          | 4-27   | DCR M       | 35          | 1     | 10            | 4-14   |
| RRC           | OF          | 1     | 4             | 4-12   | DCX RP      | 00XX1011    | 1     | 5             | 4-13   |
| RST N         | 11XXX111    | 1     | 11            | 4-18   | DI          | F3          | 1     | 4             | 4-12   |
| RZ            | C8          | 1     | 5/11          | 4-27   | EI          | FB          | 1     | 4             | 4-12   |
| SBB REG       | 10011XXX    | 1     | 4             | 4-12   | HLT         | 76          | 1     | 7             | 4-30   |
| SBB M         | 9E          | 1     | 7             | 4-15   | IN PORT     | DB YY       | 2     | 10            | 4-28   |
| SBI DATA      | DE YY       | 2     | 7             | 4-15   | INR REG     | 00XXX100    | 1     | 5             | 4-13   |
| SHLD ADDR     | 22 ppqq     | 3     | 16            | 4-25   | INR M       | 34          | 1     | 10            | 4-14   |
| SPHL          | F9          | 1     | 5(4)*         | 4-13   | INX RP      | 00XX0011    | 1     | 5             | 4-13   |
| STA ADDR      | 32 ppqq     | 3     | 13            | 4-23   | JC LABEL    | DA ppqq     | 3     | 10            | 4-22   |
| STAX RP       | 000X0010    | 1     | 7             | 4-16   | JM LABEL    | FA ppqq     | 3     | 10            | 4-22   |
| STC           | 37          | 1     | 4             | 4-12   | JMP LABEL   | C3 ppqq     | 3     | 10            | 4-22   |
| SUB REG       | 10010XXX    | 1     | 4             | 4-12   | JNC LABEL   | D2 ppqq     | 3     | 10            | 4-22   |
| SUB M         | 96          | 1     | 7             | 4-15   | JNZ LABEL   | C2 ppqq     | 3     | 10            | 4-22   |
| SUI DATA      | D6 YY       | 2     | 7             | 4-15   | JP LABEL    | F2 ppqq     | 3     | 10            | 4-22   |
| XCHG          | EB          |       | 4             | 4-12   | JPE LABEL   | EA ppqq     | 3     | 10            | 4-22   |
| XRA REG       | 10101XXX    | 1     | 4             | 4-12   | JPO LABEL   | E2 ppqq     | 3     | 10            | 4-22   |
| XRA M         | AE          | 1     | 7             | 4-15   | JZ LABEL    | CA ppqq     | 3     | 10            | 4-22   |
| XRI DATA      | EE YY       | 2     | 7             | 4-15   | LDA ADDR    | 3A ppqq     | 3     | 13            | 4-24   |
| XTHL          | E3          | 1     | 18(17)*       | 4-21   | LDAX RP     | 000X1010    | 1     | 7             | 4-15   |
|               |             |       |               |        | LHLD ADDR   | 2A ppqq     | 3     | 16            | 4-17   |

ppqq represents four hexadecimal digit memory address

YY represents two hexadecimal data digits

YYYY represents four hexadecimal data digits

X represents an optional binary digit

ddd represents optional binary digits identifying a destination register

sss represents optional binary digits identifying a source register

\* The NEC 8080A has five instructions with unique execution times, defined above by

(N)\* where N is the number of NEC 8080A instruction cycles.

## INSTRUCTION EXECUTION TIMES AND CODES

Table 4-5 lists instructions in alphabetic order, showing object codes and execution times, expressed as machine cycles.

Where two instruction cycles are shown, the first is for "condition not met" whereas the second is for "condition met".

Detailed timing for instructions is provided by Figures 4-12 through 4-30. Table 4-5 identifies the timing diagram that applies to each instruction.

Instruction object codes are represented as two hexadecimal digits for instructions without variations.

Instruction object codes are represented as eight binary digits for instructions with variations; the binary digit representation of variations is then identifiable.

The NEC 8080A has four instructions with execution times that differ from the Intel 8080A. These four instructions are the Register Move (MOV), the Return (RET), the 16-bit Add (DAD), and the Exchange instructions XTHL and SPHL.

|             |
|-------------|
| NEC 8080A   |
| INSTRUCTION |
| EXECUTION   |
| TIME        |
| DIFFERENCES |



Figure 4-12. Signal Sequences and Timing for Instructions:  
STC, CMC, CMA, NOP, RLC, RRC, RAL, RAR, XCHG, EI,  
DI, DAA, ADD R, ADC R, SUB R, SBB R, ANA R, XRA R, ORA R, CMP R



Figure 4-13. Signal Sequences and Timing for Instructions:  
INR, DCR, MOV REG REG, SPHL, PCHL, DCX, INX



Figure 4-14. Signal Sequences and Timing for Instructions:  
DCR, INR, MVI M



Figure 4-15. Signal Sequences and Timing for Instructions:  
LDAX, MOV REG M, ADI, ACI, SUI, SBI, ANI, XRI, ORI, CPI, MVI R, ADD M,  
ADC M, SUB M, SBB M, ANA M, XRA M, ORA M, CMP M



Figure 4-16. Signal Sequences and Timing for Instructions:  
STAX, MOV M REG



Figure 4-17. Signal Sequences and Timing for Instructions:  
LHLD



Figure 4-18. Signal Sequences and Timing for Instructions:  
PUSH, RST



Figure 4-19. Signal Sequences and Timing for Instructions:  
POP, RET



Figure 4-20. Signal Sequences and Timing for Instructions:  
DAD



Figure 4-21. Signal Sequences and Timing for Instructions:  
XTHL



Figure 4-22. Signal Sequences and Timing for Instructions:  
LXI, JMP, JNZ, JZ, JNC, JC, JPO, JPE, JP, JM



Figure 4-23. Signal Sequences and Timing for Instructions:  
STA



Figure 4-24. Signal Sequences and Timing for Instructions:  
LDA



Figure 4-25. Signal Sequences and Timing for Instructions:  
SHLD



Figure 4-26. Signal Sequences and Timing for Instructions:  
CALL, CNZ, CZ, CNC, CC, CPO, CPE, CP, CM



Figure 4-27. Signal Sequences and Timing for Instructions:  
RNZ, RZ, RNC, RC, RPO, RPE, RP, RM



Figure 4-28. Signal Sequences and Timing for Instructions:  
IN



Figure 4-29. Signal Sequences and Timing for Instructions:  
OUT



Figure 4-30. Signal Sequences and Timing for Instructions:  
HLT

## SUPPORT DEVICES THAT MAY BE USED WITH THE 8080A

Of the microprocessors described in this book, none have a wider variety of support devices than the 8080A. These support devices are described in the rest of Chapter 4 and in Volume III. Most of the devices described were originally developed by Intel, although a few were not. Note that the 8224 Clock Generator and the 8228 System Controller devices are used so routinely with the 8080A that they frequently are looked upon as a three-chip CPU. An exception to this three-chip concept is the TMS 5501 made by Texas Instruments; it cannot be used with an 8228 System Controller.

A number of general-purpose support devices are described in Volume III. These are support devices that may be used with any microprocessor and are specific to none.

One generalization that can be made regarding 8080A support devices is that the 8080A is so well endowed with support logic that it will rarely make much sense to use another microprocessor's support part in preference.

It is very difficult to use 6800 support devices with the 8080A because 6800 support devices require a synchronizing strobe signal which is difficult to generate within an 8080A system.

## THE 8224 CLOCK GENERATOR AND DRIVER

The primary purpose of this device is to provide the 8080A CPU with its required  $\Phi_1$  and  $\Phi_2$  clock signals. Coincidentally, the 8080A READY and RESET inputs are created, with correct synchronization. Recall that these two signals must be synchronized with  $\Phi_2$ .

Logic implemented on the 8224 Clock Generator corresponds generally to the block labeled "Clock Logic" in Figure 4-1. To be completely accurate, however, a small portion of the Bus Interface Logic should also be illustrated as provided by the 8224 device.

### 8224 CLOCK GENERATOR PINS AND SIGNALS

8224 pins and signals are illustrated in Figure 4-31. Figure 4-33 illustrates the 8224 connected to an 8080A CPU and an 8228 System Controller.

Signals may be divided between timing logic and control logic.

Clock frequency is controlled by a crystal connected to the XTAL1 and XTAL2 pins. Crystal frequency must be exactly nine times the required clock frequency. The fastest clock period supported today is 250 nanoseconds, provided by the AMD 9080A. 500 nanosecond clock periods are standard. Since crystal frequency has to be nine times the clock frequency, the usual 500 nanosecond clock will require an 18 MHz frequency crystal.

8224  
CLOCK  
SIGNALS

If an overtone mode crystal is employed, then it must be supported by an external LC network, connected to the TANK input. This is standard clock logic practice; microprocessor clock logic represents no special case, therefore we will not discuss overtone-mode crystals further.



| PIN NAME                              | DESCRIPTION                     | TYPE   |
|---------------------------------------|---------------------------------|--------|
| RESET                                 | Control signal output to 8080A  | Output |
| RESIN                                 | Reset logic input               | Input  |
| RDYIN                                 | Ready logic input               | Input  |
| READY                                 | Control signal output to 8080A  | Output |
| SYNC                                  | Control signal input from 8080A | Input  |
| Φ2 (TTL)                              | TTL level duplicate of Φ2       | Output |
| STSTB                                 | Sync signal output to 8228      | Output |
| XTAL1,XTAL2                           | External crystal connections    | Input  |
| TANK                                  | Overtone crystal extra input    | Input  |
| OSC                                   | Crystal oscillator waveform     | Output |
| Φ1, Φ2                                | Clock signals to 8080A          | Output |
| V <sub>CC</sub> ,V <sub>DD</sub> ,GND | Power and Ground                |        |

Figure 4-31. 8224 Clock Generator Signals and Pin Assignments

The principal clock signals output are  $\Phi_1$  and  $\Phi_2$ , as required by the 8080A CPU. These two clock signals are derived from a divide-by-nine counter that defines  $\Phi_1$  and  $\Phi_2$  as follows:



Two additional timing signals are output:

The crystal oscillator frequency is output as OSC.

A TTL level duplicate of  $\Phi_2$  is also output for general use within the microcomputer system.

The RESET input signal required by the 8080A CPU is usually generated by special external logic to provide sharp signal edges and synchronization with the  $\Phi_2$  clock pulse. Consider one common use of RESET — to detect power failure. A vague input may have to be converted into a crisp RESET as follows:



The 8224 Clock Generator will accept a sloppy input, as illustrated above by RESIN, and in response will create a sharp RESET output that conforms to the requirements of the 8080A CPU. A Schmitt trigger within the logic of the 8224 clock chip creates the appropriate reset logic level change when RESIN falls below a threshold level.

RESET is also frequently connected to manually operated switches; this allows the microcomputer system to be reset by human intervention. The following simple circuit creates the appropriate RESIN input to the 8224 Clock Generator so that either power failure or an external switch may reset the CPU:



READY logic accepts an asynchronous RDYIN signal and creates a synchronous READY input to the 8080A CPU:



One further signal created by the 8224 Clock Generator is the status strobe signal STSTB, which is required by the 8228 System Controller. This signal is of very little interest to a user since it simply accepts an 8080A SYNC output and converts it into the required 8228 STSTB input.

When comparing the 8080A microcomputer system with other devices, it would be inaccurate to dismiss the 8224 Clock Generator simply as an additional device — which must be added to an 8080A system, supplying logic which is commonly found on competing CPU chips. Do not forget the reset logic capability provided by the 8224 Clock Generator.

It can be argued that the 8080A CPU creates an artificial restriction — that RESET and READY inputs must be synchronized with  $\Phi_2$ ; therefore the fact that the 8224 does this for you, simply eliminates a self imposed problem that should never have been there in the first place. This reasoning has merit, but the ability of the 8224 to receive a ragged RESIN input is a valuable feature that should not be overlooked.

## THE 8228 AND 8238 SYSTEM CONTROLLER AND BUS DRIVER

The 8228 System Controller consists of a bidirectional bus driver, plus control signal generation logic. The 8238 System Controller advances I/O and MEMW to give large memories more time to respond to a memory write.

### BUS DRIVER LOGIC

A large number of memory and I/O devices may be connected directly to the 8228 bidirectional Data Bus; such connections to the 8080A Data Bus would not be feasible. Remember, memory devices leak current even when they are not selected; therefore, even the passive load of unselected memory devices connected directly to an 8080A CPU will leak more current than is available.

**When comparing the 8080A microcomputer system with an alternate microcomputer system, you should look carefully at the fan out provided by the alternate CPU.**

If the alternate CPU busses need to be buffered, then the 8228 System Controller becomes the equivalent 8080A system device; as such it does not represent an economic liability.

If the alternate CPU busses do not need to be buffered, then the 8228 System Controller represents an additional device, peculiar to the 8080A system.

## CONTROL SIGNAL LOGIC

The 8228 combines the three 8080A control signals: WR, DBIN and HLDA, with the statuses output on the Data Bus during T<sub>2</sub> in order to generate bus control signals as follows:

MEMR status on D7 true, with DBIN true generates MEMR true

OUT status on D4 false, with WR true generates MEMW true

INP status on D6 true, with DBIN true generates I/OR true

OUT status on D4 true, with WR true generates I/OW true

INTA status on D0 true generates INTA true



Figure 4-32. 8228 System Controller Signals and Pin Assignments

## 8228 SYSTEM CONTROLLER PINS AND SIGNALS

**8228 pins and signals are illustrated in Figure 4-32.**

**D0 through D7** represent the bidirectional Data Bus connection between the 8228 System Controller and the 8080A CPU; it is referred to as the "Processor Data Bus".

**DB0 through DB7** represent the high fan out, bidirectional Data Bus accessed by external logic; it is referred to as the "System Data Bus".

WR, DBIN and HLDA represent the control signals of the same name that are output by the 8080A CPU.

All control bus signals use active low logic and may be defined as follows:

MEMR — a read from memory strobe

MEMW — a write to memory strobe

I/OR — a read from external I/O strobe

I/OW — a write to external I/O strobe

INTA — interrupt acknowledge

Control signal timing is given in Figure 4-34.

The interrupt acknowledge signal INTA has two special features which need to be explained. This signal may be tied to a +12 Volt power supply through a 1K Ohm resistor, in which case 8228 logic assumes that there is only one possible interrupting source within the microcomputer system. Now the 8228 will automatically insert the object code for an RST 7 instruction in response to the interrupt acknowledge. This means that external logic does not need to supply the first post-interrupt instruction's object code. Of course, this means that all interrupt service routines effectively begin with the execution of an RST 7 instruction.

If external logic responds to the INTA low pulse by supplying the first byte of a CALL instruction's object code (11001101), then the 8228 System Controller will automatically generate two more INTA low pulses for the next two machine cycles. See Figure 4-34 for INTA pulse timing within the machine cycle. Now external logic can use the INTA pulse as a memory deselect and an interrupt acknowledge logic select. Here is a very general illustration of external logic that responds to an interrupt acknowledge by supplying the CPU with a three-byte CALL instruction's object code:





Figure 4-33. A Standard, Three Device 8080A Microcomputer System



Figure 4-34: Timing for Control Signals Output by the 8228 System Controller

Recall that the NEC 8080A generates three INTA low output pulses in response to a Call instruction object code being returned during the interrupt acknowledge process. But the NEC 8228 System Controller does not assume that these three low INTA pulses will occur. Thus **the NEC 8228 System Controller may be used with an NEC 8080A or any other 8080A**. In every case the NEC 8228 will generate three low INTA output pulses when external logic responds to an interrupt acknowledge by providing a Call instruction object code.

The status strobe STSTB which is output by the 8224 Clock Generator is a variation of the SYNC output from the 8080A CPU. STSTB synchronizes the 8228 System Controller and is of no other concern to an 8080A user.

**BUSEN is an external input to the 8228 System Controller.** This is a very useful signal because it allows external logic to float the Data Bus. When this signal is input low, the bidirectional bus driver logic of the 8228 System Controller presents a high impedance to the external Data Bus, thus allowing external logic to gain access to this bus.

Figure 4-33 illustrates the way in which the 8080A CPU normally combines with the 8224 Clock Generator and the 8228 System Controller. These three devices are frequently looked upon as a single entity.

## THE 8259 PRIORITY INTERRUPT CONTROL UNIT (PICU)

This is a very flexible, programmable interrupt handling device; it provides a CALL instruction's object code in response to three interrupt acknowledge (INTA) signals; the 8228 System Controller responds to an interrupt acknowledge in this fashion, as described earlier in this chapter. Therefore the 8259 PICU should be looked upon as a companion to the three-chip (8080A, 8224, 8228) microprocessor system.

The 8259 PICU cannot be used with non-8080A systems.

A single 8259 PICU with an 8080A microcomputer system will handle up to eight external interrupts, providing a variety of programmable interrupt priority arbitration schemes.

Alternatively, an 8080A microcomputer system may have a single 8259 PICU designated as a master, controlling up to eight additional 8259 PICUs designated as slaves. This allows a maximum of 64 levels of interrupt priority. Priority arbitration schemes may be set independently for the master and for each slave, resulting in a bewildering profusion of priority arbitration possibilities.

Use extreme caution before including master and slave PICUs within an 8080A microcomputer system. When an application is implemented around a microprocessor with the general speed and performance characteristics of an 8080A, then it is usually more efficient to handle numerous external request lines using multiple CPU configurations and/or programmed polling techniques, rather than interrupts.

The 8259 PICU is fabricated using NMOS technology; it is packaged in a 28-pin plastic DIP. All outputs are TTL compatible.

With reference to the standard logic functions' illustration used throughout this book, the box marked "Interrupt Priority Arbitration" represents the functions implemented by the 8259 PICU. But it is hard to equate the large number of options provided by the 8259 PICU with the interrupt logic provided by other microcomputer systems. An application that needs the 8259 PICU would certainly not be satisfied by Interrupt Priority control logic provided by almost any other device described in this book.

### 8259 PICU PINS AND SIGNALS

8259 PICU pins and signals are illustrated in Figure 4-35; we will summarize these signals, then discuss how the PICU is used.

From the programmer's point of view, the 8259 PICU will be accessed either as two I/O ports, or as two memory locations. CS is a typical chip select and A0 identifies one of two I/O ports or memory locations. The way you, as a programmer, must interpret the function of each 8259 PICU I/O port or memory location depends on an intricate logical sequence.

The two 8259 addressable locations are accessed via the Data Bus (D0 - D7).

IOR and IOW are standard read and write control signals. If the 8259 PICU is being accessed as two I/O ports, then these two signals will be connected to the IOR and IOW controls output by the 8228 System Controller; on the other hand, if the 8259 PICU is being accessed as two memory locations, then IOR and IOW must be connected to the MEMR and MEMW controls output by the 8228 System Controller.

External devices requesting interrupt service have their request signals connected to IRO - IR7. A high level on any one of these signals will be interpreted as an interrupt request. An interrupt request is passed on to the CPU via the INT signal. This is illustrated in Figure 4-36.

**In a configuration that includes master and slave 8259 PICUs** external logic will connect to the interrupt request signals (I<sub>R0</sub> - I<sub>R7</sub>) of the slave PICUs only. The INT outputs of the slave PICUs will be connected to the interrupt requests (I<sub>R0</sub> - I<sub>R7</sub>) of the master PICU. This is illustrated in Figure 4-37.

When more than one 8259 PICU is present in a system, **SP identifies the master and slave units**. SP high defines the master, while SP low forces an 8259 PICU to operate as a slave. **SP also determines the sense of the three cascade lines (C<sub>0</sub>, C<sub>1</sub>, C<sub>2</sub>)**; these are output lines from the master and input lines to a slave.

**The 8080A CPU provides the standard interrupt acknowledge via INTA.** This interrupt acknowledge will be received by all 8259 PICUs in the system, master or slave.

**In a system that includes a master 8259 PICU only, the three bytes of a CALL instruction's object code are output via the Data Bus in response to the three INTA control signals arriving from the 8228 System Controller.** The second and third bytes of the CALL instruction's object code provide an address which is unique to the selected interrupt request.

**In a configuration that includes master and slave 8259 PICUs, the master PICU outputs the first byte of a CALL instruction's object code; the master also outputs a value between 000 and 111 via the three cascade lines (C<sub>0</sub> - C<sub>2</sub>).** This three-bit binary value identifies the interrupt request level being acknowledged — and therefore the slave PICU being selected. The selected slave PICU **provides the second and third bytes of the CALL instruction's object code in response to the second and third INTA pulses output by the 8228 System Controller.** Thus the slave PICU identifies the interrupt request level it is acknowledging.

The interrupt acknowledge logic of the 8259 PICU is referred to as "Vectoring". Let us examine 8259 vectoring in more detail.



Figure 4-35. 8259 Priority Interrupt Control Unit Signals And Pin Assignments



Figure 4-36. A System With One PICU

### THE 8259 PICU INTERRUPT ACKNOWLEDGE VECTOR

**Vectoring** is a general term used to identify an interrupt acknowledge sequence which results in the immediate identification of the interrupting external source. With a non-vectorized interrupt acknowledge, the CPU must execute some instruction sequence whose sole purpose is to identify the source of the interrupt — and that assumes more than one possible external interrupting source.

Recall that when an interrupt request is acknowledged by a three-device 8080A microprocessor system, the 8228 System Controller outputs a low pulse on the INTA control line. External logic must interpret the low INTA pulse as a signal to bypass normal instruction fetch logic, and provide the object code for the first instruction to be executed following the interrupt acknowledge. (If this is new to you, refer to our discussion of the 8080A and 8228 devices.) If a CALL instruction's object code (CD<sub>16</sub>) is returned to the 8228 System Controller, then low INTA pulses are output for

**8080A  
INTERRUPT  
RESPONSE  
USING CALL  
INSTRUCTION**

the next two machine cycles — thus making it easy for external logic to fetch all three bytes of a CALL instruction's object code. The 8259 PICU uses this 8228 logic to supply a three-byte CALL instruction's object code as the first instruction executed following an interrupt acknowledge. But a CALL instruction's object code is interpreted thus:



There are two ways in which the 8259 PICU can compute the address portion of the CALL instruction object code (bytes 2 and 3). These are the two options:

Option 1  
XXXXXXXXXXXXXXYYYY00

Option 2  
XXXXXXXXXXXXYYY000

X represents binary digits which are defined, under program control, to be a constant portion of the Call address.  
Y represents binary digits which identify the interrupt priority level (000 through 111).

Since the CALL is the first instruction executed following an interrupt acknowledge, it causes program logic to branch to a memory location which is uniquely set aside for a single external interrupting source. **Suppose you have selected CALL instruction Option 1, as illustrated above.** You would then set aside an area of memory for a jump table, as follows:



Memory addresses have been selected arbitrarily in the illustration above.

Program logic does not have to determine the source of an interrupt. You simply origin separate interrupt service routines at starting addresses specified by the Jump instructions in the jump table. This may be illustrated as follows:



The illustration above arbitrarily assumes that the interrupt request arriving at IR2 has its service routine originated at 0E0016. In this example, the address vector provided by the 8259 is 380816:



Figure 4-37. A System With Three PICUs — One Master And Two Slaves

At memory location 38081<sub>16</sub>, the object code for the instruction:

JMP ADDR2

takes us directly to the required interrupt service routine.

## 8259 PICU PRIORITY ARBITRATION OPTIONS

**Priority arbitration logic** is used to determine which interrupt request will be acknowledged when two or more interrupt requests exist simultaneously. The 8259 PICU allows interrupt priorities to be specified at two levels — which need to be clearly separated and identified.

As discussed in Volume I — Basic Concepts, interrupt priority arbitration usually applies to simultaneous interrupt requests; at the instant an interrupt is acknowledged, if **more than one external requesting source is requesting an interrupt, priority arbitration logic decides which single interrupt request will be acknowledged**. Once an interrupt has been acknowledged, priority arbitration has nothing to do with whether the interrupt service routine can itself be interrupted, or by whom.

**The 8259 PICU extends interrupt priorities to the service routines themselves.** Once an interrupt has been acknowledged, its service routine can only be interrupted by a higher priority interrupt.

If you are unsure of the difference between interrupt priority arbitration at the point when interrupts are acknowledged, as against priority arbitration for the entire duration of an interrupt service routine, then refer to Volume I — Basic Concepts, where this subject is covered thoroughly.

Let us now look at the various priority arbitration options provided by the 8259 PICU.

**The Fully Nested Mode is the default case.** Interrupt priorities are set sequentially from 0 (highest) to 7 (lowest).

As we will describe shortly, the **8259 PICU must be initialized by an appropriate instruction sequence** before it can be used in any way. **Upon completing programmed initialization, Fully Nested Mode is the priority arbitration option in force.** It takes additional instructions to specify any other priority arbitration option.

In Fully Nested Mode, interrupt priorities will never change. An interrupt request arriving at an IR line will never be acknowledged if an interrupt request exists at a higher priority line, or if an interrupt service routine is being executed in response to a higher priority interrupt request. Conversely, once an interrupt has been acknowledged, the interrupt service routine which is subsequently executed may be interrupted only by a higher priority interrupt. It makes no difference whether interrupts have, or have not been disabled, the 8259 PICU will ignore all interrupt requests at priority levels below that of an interrupt service routine currently being executed. For example, suppose interrupts are being requested simultaneously at levels 2 and 5. The level 2 interrupt will be acknowledged and its interrupt service routine will be executed. While the level 2 interrupt is being executed, the level 5 interrupt request will be denied by the 8259 PICU, whether or not interrupts have been disabled at the CPU. However, if an interrupt request arrives at priority level 1, the PICU will acknowledge this interrupt request, and will allow the level 2 interrupt service routine to be interrupted. This may be illustrated as follows:

**8259 PICU  
INTERRUPT  
SERVICE  
ROUTINE  
PRIORITIES**



It is very important to understand that the 8259 PICU extends interrupt priority logic beyond the interrupt acknowledge, to the interrupt service routine itself. Standard priority arbitration logic does not extend to the interrupt service routine. Thus, in the standard case if interrupts were being requested at priorities 2 and 5, then the priority level 2 request would be acknowledged, but the priority level 2 interrupt service routine could be interrupted by the level 5 interrupt request, unless all interrupts were disabled at the CPU — in which case an interrupt request at level 1 would also be denied.

If you do not want to extend interrupt priorities to the interrupt service routines, you can output a Special Mask Mode command (which we will describe shortly) to selectively enable interrupt requests of lower priority than the currently executing interrupt service routine.

**Rotating Priority, Mode A is the next option.** This differs from the Fully Nested Priority Mode, which we just described, in that after being serviced, a request is immediately relegated to lowest priority. This may be illustrated as follows:

**8259 PICU  
ROTATING  
INTERRUPT  
PRIORITIES**

| Priorities assigned to IR lines |        |     |      |     |     |      |     |         |
|---------------------------------|--------|-----|------|-----|-----|------|-----|---------|
|                                 | Lowest | 6   | 5    | 4   | 3   | 2    | 1   | Highest |
| Before first acknowledge        | IR7    | IR6 | IR5* | IR4 | IR3 | IR2* | IR1 | IR0     |
| After first acknowledge         | IR2    | IR1 | IR0  | IR7 | IR6 | IR5* | IR4 | IR3     |
| After second acknowledge        | IR5    | IR4 | IR3  | IR2 | IR1 | IR0  | IR7 | IR6     |

\* identifies active interrupt requests.

In a microcomputer system that makes heavy use of interrupts, Rotating Run in Priority Mode A may be a necessary replacement for the default Fully Nested Priority Mode. In the default case, the lowest priority levels may get little or no service if there is heavy interrupt traffic. In an application that does not have a well defined hierarchy of interrupt priorities, a rotation of priorities, as illustrated above, is superior — because it has the effect of giving every priority level equal service.

Rotating Priority Mode A is implemented as a sequence of single programmed events. The microprocessor outputs an appropriate Control code to the 8259 PICU upon completing every interrupt service routine. Thus Rotating Priority Mode A is not a permanently specified PICU condition; each rotation represents a single response to a single Control code — unconnected to previous or future priority selections. For the moment, however, it is not necessary that you understand the programming techniques employed when selecting 8259 interrupt priority modes; that is a subject we will cover after completing the description of all available priority options.

**Rotating Priority Mode B gives you some flexibility in determining future priorities.** Now under program control you can fix the next division between top and bottom priorities at any time. This may be illustrated as follows:

| Priority assigned to IR lines        |        |     |     |     |     |     |     |         |
|--------------------------------------|--------|-----|-----|-----|-----|-----|-----|---------|
|                                      | Lowest | 6   | 5   | 4   | 3   | 2   | 1   | Highest |
| Before first acknowledge             | IR7    | IR6 | IR5 | IR4 | IR3 | IR2 | IR1 | IR0     |
| After first acknowledge              | IR5    | IR4 | IR3 | IR2 | IR1 | IR0 | IR7 | IR6     |
| IR5 is defined as<br>lowest priority |        |     |     |     |     |     |     |         |
| After next acknowledge               | IR3    | IR2 | IR1 | IR0 | IR7 | IR6 | IR5 | IR4     |
| IR3 is defined as<br>lowest priority |        |     |     |     |     |     |     |         |
| etc.                                 |        |     |     |     |     |     |     | etc.    |

Rotating Priority Mode B allows program logic to determine subsequent interrupt priorities based upon transient system conditions. Rotating Priority Mode B rotates priorities any number of positions to the right, much as you might rotate the bits of an Accumulator.

Like Rotating Priority Mode A, Rotating Priority Mode B depends on the microprocessor outputting an appropriate Control code to the 8259 PICU. However, in Rotating Priority Mode A, rotation can be done only at the conclusion of an interrupt service routine, whereas in Rotating Priority Mode B, priorities can be changed at any time.

**Two mask modes allow individual priorities to be selectively disabled. A Simple Mask Mode allows the microprocessor to output an 8-bit mask, where 1 bits will cause corresponding interrupt request lines to be disabled.** For example, the mask value CA16 will disable interrupt lines IR7, IR6, IR3 and IR1:

**8259 PICU  
INTERRUPT  
MASKING**



**A Special Mask Mode** is also provided; it **allows you to enable interrupts at a lower priority level than that of the currently executing interrupt service routine.** By writing a 1 to the appropriate bit of the Mask register, an interrupt level can be disabled while its interrupt service routine is executing. Even though the level is masked, all lower level interrupts will remain disabled until the conclusion of the service routine. Once the current level is masked, however, entering Special Mask Mode will enable all unmasked lower priority interrupt levels. Thus a request can interrupt a service routine operating on a higher priority level.

Masks may be superimposed on Rotating Priority Mode A or Mode B without restriction. This allows you to selectively enable and disable individual interrupt request lines, then rotate priorities for the enabled lines. Special Mask Mode also allows you to selectively enable interrupts of lower priority than a currently executing interrupt service routine.

**Polled Mode bypasses priority arbitration altogether. If you select Polled Mode, then you must poll the 8259 PICU.** You will interpret the polled data as follows:

**8259 PICU  
POLLING**



In a configuration that includes master and slave 8259 PICUs, you will first read status from the master PICU. Upon detecting a 1 bit in bit 7, you will poll the slave PICU which is identified by bits 2, 1 and 0 of the master's polled data. The slave poll identifies the highest priority interrupt request. This may be illustrated as follows:



Suppose the \* represents interrupt requests. The master poll would return:



The polling program must now poll slave 1; it will read:



In Polled Mode, the 8259 PICU is not being used as an interrupt processing device at all. In effect, interrupt requests are reduced to status flags, which will be processed by the CPU when it is ready to do so. External logic is no longer able to force the CPU to suspend current program execution; thus the key concept of an interrupt is missing.

**While it may not immediately appear obvious, using the 8259 PICU in Polled Mode is possibly one of the most effective ways of utilizing this device.** A point we have frequently made, both in Volume I and in Volume II, is that the average microprocessor is simply too slow to efficiently handle random, nested interrupts in a traditional minicomputer fashion. It is faster and more efficient to poll status on a round-robin basis, branching to appropriate subroutines upon detecting a status flag via which external logic has requested service. A detailed discussion of this point may be found in the book 8080 Programming For Logic Design.

## HOW INTERRUPT REQUESTS AND PRIORITY STATUS ARE RECORDED

Internal to the 8259 PICU there are two registers: an **Interrupt Request (IR)** register and an **Interrupt Status (IS)** register.

The **Interrupt Request and Interrupt Status registers** may be looked upon as receiving external interrupt request status in a cascaded fashion as follows:



Any active interrupt request appearing on the interrupt request lines IR0 - IR7 will set corresponding bits of the Interrupt Request register. When any interrupt is acknowledged, the acknowledged interrupt's bit in the Interrupt Status register is set; simultaneously, all bits of the Interrupt Request register are reset. This may be illustrated as follows:



In order to reset any bit of the Interrupt Status register you must issue a specific "End-Of-Interrupt" instruction which we will describe shortly.

You may therefore look upon the Interrupt Request register as identifying active, but unacknowledged interrupt requests. Notice that Interrupt Request status is not preserved across an acknowledge. This means external logic must hold its Interrupt Request true until it has been selected and acknowledged.

You may look upon the Interrupt Status register as identifying the interrupt requests which are currently being serviced. If you do not nest interrupts, then only one bit of the Interrupt Status register will be set at any time. If you do nest interrupts, then more than one bit of the Interrupt Status register may be set — for the interrupt request being serviced currently and for any interrupt requests which were being serviced, but were themselves interrupted. But remember you can misuse the Interrupt Status register. If you do not end interrupt service routines by outputting an "End-Of-Interrupt" command to the 8259 PICU, then bits of the Interrupt Status register will remain set after the appropriate interrupt has been serviced.

If you use a mask to inhibit interrupt levels, then the inhibit logic will prevent bits of the Interrupt Request and Interrupt Status register from being set for the inhibited interrupt levels.

The Interrupt Request (IR) register stores a 1 bit at every requesting level; it may be visualized as a simple reflection of IR input signals:



The Interrupt Status (IS) register reflects the status of current interrupt priority arbitration logic. Whenever an interrupt is acknowledged, the IS bit corresponding to the interrupt level is set. This bit is reset by the End-Of-Interrupt (EOI) instruction at the end of the interrupt service routine. We will tell you how to issue an EOI instruction shortly.

Suppose the 8259 PICU is operating in the default mode: fully nested interrupts, no mask bits set. An interrupt request is made at level 4. When this interrupt is acknowledged, bit 4 of the IS register is set:



and interrupts at levels 5, 6 and 7 are disabled, since they are of lower priority than level 4. While the level 4 request is being serviced, a request is made at level 1. Since level 1 has higher priority, it will be acknowledged, interrupting the level 4 service routine. IS will look like this:



Now interrupt levels 2 through 7 are disabled. At the conclusion of the level 1 service routine, EOI will reset bit 1:



thus enabling interrupt levels 2 and 3 — and level 4, whose service routine can now continue. On the next EOI, assuming no further interruptions, bit 4 of IS will be reset, at which time levels 5, 6 and 7 will again be enabled.

In priority modes other than the Fully Nested Mode (Rotating Priorities A and B and Special Mask Mode) the 8259 PICU cannot be depended on to reset the correct IS bit when it receives the usual EOI. Therefore, it is sent a special EOI which specifies which level's service routine is ending — and therefore which IS bit is to be reset.

## PROGRAMMING THE 8259 PICU

As we have already stated, the 8259 PICU appears to the programmer as two I/O ports, or memory locations. However, there are a number of ways in which data written to, or read from either location may be interpreted. Let us begin by defining these interpretations; then we will explain the sequence in which Control codes should be written, and statuses read, in order to access the many capabilities of the 8259 PICU.

Control codes output to the lower I/O port or memory address ( $A_0 = 0$ ) may be interpreted in one of three ways, labeled Initialization Control Word 1 (ICW1) and Operation Control Words 2 and 3 (OCW2 and OCW3):



When reading from the lower address ( $A_0 = 0$ ), the condition of the most recently issued OCW3 bits 0 and 1 determine what will be read. If these two bits were 01, the Interrupt Request register (IR) is read; if these two bits are 11, the Interrupt Status register (IS) is read.

**Control codes output to the higher I/O port or memory address ( $A_0 = 1$ ) may also be interpreted in one of three ways.** After an ICW1 control has been output to the lower address ( $A_0 = 0$ ), either one, or two Control codes must be output to the higher address ( $A_0 = 1$ ). If ICW1, bit 1 is 1, a second Control code (ICW2) must be output to the higher address ( $A_0 = 1$ ) of the master 8259 PICU, and to every slave 8259 PICU, that may be present. This is the format of ICW2:



If ICW1, bit 1 is 0, ICW2, as illustrated above, must be output — and it must be followed by a second Control code (ICW3), output to the higher address ( $A_0 = 1$ ) of the master 8259 PICU, and then to each slave 8259 PICU. The master 8259 will interpret ICW3 as follows:



A slave 8259 will interpret ICW3 as follows:



A system with a single 8259, therefore, has ICW1, then ICW2 output to it.

A system with master and slave 8259 devices must have ICW1, ICW2 and ICW3 output to the master, then ICW1, ICW2 and ICW3 output to each slave.

**After the initiation sequence has been completed, when reading or writing to the higher I/O port address ( $A_0 = 1$ ), the Interrupt Mask register is accessed. Writing a 1 into any bit position will disable corresponding IR line requests. 0 bits enable interrupt requests at corresponding IR lines. When you return to the initiation sequence, the higher I/O port address again accesses ICW2 or ICW3.**

8259 PICU  
INTERRUPT  
MASK

We will now examine the normal sequence in which the 8259 PICU will be programmed. Programming logic may be defined as follows:



Using arbitrary data, the initiation sequence for a single 8259 PICU system may be illustrated as follows:

```
MVI    PICUL,12H      ;WRITE OUT ICW1
MVI    PICUH,40H      ;WRITE OUT ICW2
```

The labels PICUL and PICUH address the lower and higher 8259 PICU addressable locations, respectively.

The two instructions above assume that the 8259 PICU is being addressed as memory. The two immediate data bytes specify an interrupt address vector beginning at location 4000<sub>16</sub>, incrementing eight bytes with each priority level.

Now consider a configuration where there is a master PICU and three slave PICUs connected to IR0, IR1 and IR2. Here is the initiating instruction sequence required:

```
;INITIALIZE MASTER PICU
  MVI    PICUL,14H      ;WRITE OUT ICW1
  MVI    PICUH,40H      ;WRITE OUT ICW2
  MVI    PICUH,07H      ;IDENTIFY SLAVES TO MASTER
;INITIALIZE FIRST SLAVE PICU
  MVI    SPCL1,10H      ;WRITE OUT ICW1
  MVI    SPCH1,48H      ;WRITE OUT ICW2
  MVI    SPCH1,0         ;IDENTIFY PRIORITY TO SLAVE
;INITIALIZE SECOND SLAVE PICU
  MVI    SPCL2,30H      ;WRITE OUT ICW1
  MVI    SPCH2,48H      ;WRITE OUT ICW2
  MVI    SPCH2,1         ;IDENTIFY PRIORITY TO SLAVE
;INITIALIZE THIRD SLAVE PICU
  MVI    SPCL3,52H      ;WRITE OUT ICW1
  MVI    SPCH3,48H      ;WRITE OUT ICW2
  MVI    SPCH3,2         ;IDENTIFY PRIORITY TO SLAVE
```

Since there is a single master, and three slaves, there must be four sets of initiating instructions.

First, we initiate the master. Again, the interrupt address vector is originated at 4000<sub>16</sub>. This origin and the specification that four bytes will separate each vector will be used when interrupts are requested on levels to which no slave 8259 PICUs are connected. In this case the value 07<sub>16</sub> is output indicating that IR0, IR1 and IR2 have connected slaves.

Slave initiation is straightforward. The first slave PICU has labels SPCL1 and SPCH1, representing the lower and higher addressable locations. SPCL2 and SPCH2 are second slave PICU labels, while SPCL3 and SPCH3 are third slave PICU labels.

All three slave PICUs specify a four-byte displacement between interrupt address vectors. Initial origins of 4800<sub>16</sub>, 4820<sub>16</sub> and 4840<sub>16</sub> are specified for slave 1, 2 and 3, respectively. Notice that the second byte written out to the high order address SPCH1, SPCH2 or SPCH3 identifies the slave's priority.

**Once 8259 PICUs have been initiated, programmable features are controlled by outputting appropriate Control codes and inputting appropriate status. Every interrupt service program must end by outputting an "End-Of-Interrupt" Control code to the 8259 PICU. Any form of "End-Of-Interrupt" Control code will do. Otherwise, there is no well defined sequence in which controls and status should be used.**

Table 4-6. A Summary of 8259 PICU Operations

| OPERATION                                                                                               | INSTRUCTION SEQUENCE                                                                 |
|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| Select Fully Nested Mode                                                                                | None. This is selected after initiation.                                             |
| Issue simple End Of Interrupt command                                                                   | Output 2016 (OCW2) to PICUL.                                                         |
| Rotate Priorities Mode A with End Of Interrupt                                                          | Output A016 (OCW2) to PICUL.                                                         |
| Rotate Priorities Mode B without End Of Interrupt                                                       | Output Cn16 (OCW2) to PICUL. n is the new lowest priority.                           |
| Rotate Priorities Mode B with End Of Interrupt                                                          | Output En16 (OCW2) to PICUL. n is the new lowest priority.                           |
| Output an interrupt mask                                                                                | Output mask byte to PICUL any time after initiation sequence.                        |
| Read interrupt mask                                                                                     | Input PICUH.                                                                         |
| Enter special mask mode                                                                                 | Output OCW3 to PICUL with 6816 in lower 7 bits.                                      |
| Exit special mask mode                                                                                  | Output OCW3 to PICUL with 4816 in lower 7 bits.                                      |
| Specify Polled Mode                                                                                     | Output OCW3 to PICUL with 0C16 in lower 7 bits.                                      |
| Poll any PICU                                                                                           | Output OCW3 to PICUL with 011 in bits 4, 3, 2, then immediately read from PICUL.     |
| Read IR Status                                                                                          | Output OCW3 to PICUL with 0A16 in lower 7 bits. Then read from PICUL.                |
| Read IS Status                                                                                          | Output OCW3 to PICUL with 0B16 in lower 7 bits. Then read from PICUL.                |
| Reset an IS status bit                                                                                  | Output 6N16 (OCW2) to PICUL if End Of Interrupt. N is the IS status bit to be reset. |
| PICUL identifies the PICU lower address (A0 = 0).<br>PICUH identifies the PICU higher address (A0 = 1). |                                                                                      |

Here is an example of the end of an interrupt service routine:

```
MVI    PICUL,20H      ;SIMPLE END OF INTERRUPT
RET          ;RETURN TO INTERRUPTED SEQUENCE
```

The simplest "End-Of-Interrupt" (EOI) is sent as OCW3. This command will reset the highest set bit in the IS register. Notice that we thus assume that this interrupt occurred in Fully Nested Priority Mode, where the highest bit corresponds to the highest priority level.

In other priority schemes, however, the interrupt level being serviced may not correspond to the highest set bit of the IS register. Suppose the interrupt handling scheme is Rotating Priority Mode B with level 2 the lowest priority and a level 0 request being serviced:



A request at level 4 (\*) will interrupt the level 0 routine. The IS register would look like this:



A simple EOI in the level 4 service routine will now reset bit 0 — which is wrong. The following instruction sequence will reset the correct IS bit and return:

```
MVI    PICUL,64H      :END LEVEL 4 INTERRUPT
RET              :RETURN TO INTERRUPTED SEQUENCE
```

Since we are rotating priorities, the following would be preferable:

```
MVI    PICUL,E4      :END LEVEL 4 INTERRUPT AND MAKE
                      :LEVEL 4 LOWEST PRIORITY
RET              :RETURN TO INTERRUPTED SEQUENCE
```

The priorities and IS register now look like this:



Either of the suggested EOI instructions would allow the level 0 routine to resume.

## THE TMS 5501 MULTIFUNCTION INPUT/OUTPUT CONTROLLER

This is a multifunction peripheral logic device built by Texas Instruments only. It is designed to work with 8080 or 8080A CPUs. The TMS 5501 does not use the 8228 System Controller; it decodes the Data Bus during the SYNC pulse.

The TMS 5501 provides many of the functions provided by the 8255 PPI, 8251 USART, 8253 Programmable Timer/Counter and 8259 Priority Interrupt Control Unit. In each case, the TMS 5501 has simpler logic, with fewer options; but for a very large number of applications, TMS 5501 features will be more than adequate.

Here are the TMS 5501 features provided:

- 1) Two external interrupt request lines.
- 2) An 8-bit, parallel input port.
- 3) An 8-bit, parallel output port.
- 4) A single, asynchronous serial I/O channel without handshaking.
- 5) Five programmable timers, each of which times out with an interrupt request after an interval that may range from 64 microseconds to 16.32 milliseconds.

Figure 4-38 illustrates those logic functions in our standard microcomputer system illustration which have been implemented by the TMS 5501.

The TMS 5501 is fabricated using N-channel silicon gate technology and is packaged as a 40-pin DIP.

### TMS 5501 DEVICE PINS AND SIGNALS

Figure 4-39 illustrates TMS 5501 device pins and signals. We will begin by summarizing these signals.

There are three data busses. D0 - D7 are the bidirectional Data Bus pins via which data is transferred between the TMS 5501 and the CPU. X10 - X17 are the pins via which external logic inputs 8-bit parallel data to the TMS 5501. X00 - X07 are the eight pins via which the TMS 5501 outputs 8-bit parallel data to external logic. Notice that X0 lines are negative-true whereas X1 lines are positive-true. Optionally X17 may be used for low priority external interrupt requests.



Figure 4-38. Logic of the TMS 5501 Multifunction Input/Output Controller



| PIN NAME                                                              | DESCRIPTION                              | TYPE          |
|-----------------------------------------------------------------------|------------------------------------------|---------------|
| D0 - D7                                                               | Data Bus to CPU                          | Bidirectional |
| X10 - X17                                                             | Data Bus from external logic             | Input         |
| X00 - X07                                                             | Data Bus to external logic               | Output        |
| XMT                                                                   | Transmit serial data line                | Output        |
| RCV                                                                   | Receive serial data line                 | Input         |
| SENS                                                                  | External interrupt sense                 | Input         |
| INT                                                                   | Interrupt request                        | Output        |
| CE                                                                    | Chip Select                              | Input         |
| A0 - A3                                                               | Address Select                           | Input         |
| SYNC                                                                  | Synchronizing signal (SYNC) from 8080A   | Input         |
| Φ1, Φ2                                                                | Clock inputs, same as to 8080A           | Input         |
| V <sub>BB</sub> , V <sub>CC</sub> , V <sub>DD</sub> , V <sub>SS</sub> | Power supply (-5V, +5V, +12V) and Ground |               |

Figure 4-39. TMS 5501 Multifunction Input/Output Controller Signals and Pin Assignments

**Do not miss the significance of XO negative logic; whatever you write to the TMS 5501 for parallel output will be complemented. XO signals are the inverse of the output buffer contents.**

**Serial I/O data uses the XMT and RCV pins.** XMT is used to transmit serial data, whereas RCV is used to receive serial data. Note that RCV is a negative-true signal, whereas XMT is a positive-true signal.

**External logic may request interrupt service either via the SENS input or via the X17 input.** A low-to-high transition on either signal constitutes an interrupt request. SENS is always part of external-interrupt request logic; X17 must be programmed for this purpose — in which case the eight XI pins cannot be used to input 8-bit parallel data.

**Logic internal to the TMS 5501 may also generate interrupt requests.** Whatever the source of the interrupt request, it is passed on to the CPU via the INT interrupt request signal.

**The TMS 5501 is accessed either as 16 I/O ports or 16 memory locations.** Addressing logic consists of a chip select (CE) and four address select inputs (A0, A1, A2 and A3).

**The TMS 5501 receives the SYNC timing pulse, and this requires special mention.** While SYNC is high, the TMS 5501 decodes status off the Data Bus, therefore the 8228 System Controller is not needed.

**Additional signals required by the TMS 5501 are the two 8080A clock signals Φ1 and Φ2.** Slight clock signal variations will confuse serial I/O logic which computes baud rates internally.

**TMS 5501  
OUTPUT  
SIGNAL  
INVERSION**

A feature of the TMS 5501 which you must note carefully is that it cannot handle Wait states. Any  $T_W$  clock periods in a machine cycle will cause the TMS 5501 to malfunction.

**TMS 5501  
WAIT STATE**

There is a further unlikely ramification of the TMS 5501 inability to handle Wait states. If you are accessing the TMS 5501 as 16 memory locations, then you cannot have a Halt instruction's object code in the memory location immediately preceding the 16 TMS 5501 addresses. If you do, the Halt instruction will execute, following which the Address Bus will contain the address of the next sequential memory location—which now is a TMS 5501 address. Thus, the TMS 5501 becomes selected. But the TMS 5501 logic cannot cope with a sequence of undefined clock periods, which is exactly what will happen following a Halt instruction's execution. The net effect is that following a Halt, the TMS 5501 receiver buffer loaded flag will be inadvertently cleared.

Always make sure that the memory address directly preceding the 16 addresses assigned to a TMS 5501 remains unused.

### TMS 5501 DEVICE ACCESS

Some of the 16 I/O port or memory addresses via which the TMS 5501 device is accessed are equivalent to memory locations, but others are command identifiers. Table 4-7 defines the manner in which addresses are interpreted.

You will find the TMS 5501 far easier to use if you address it as 16 memory locations, because that will give you access to memory referencing instructions.

When creating TMS 5501 select logic, any of the select schemes described earlier in this chapter will do—with one addition. **Include READY as part of the select logic;** if READY is low, a Wait state will follow, and that will cause the TMS 5501 to malfunction. By making READY high a necessary component of device select logic, you can avoid this problem.

In the following discussion of individual TMS 5501 capabilities, we will use programming examples to show the effectiveness of including the TMS 5501 device within your memory rather than I/O space.

Table 4-7. TMS 5501 Address Interpretations

| A3 | A2 | A1 | A0 | FUNCTION                                                                   |
|----|----|----|----|----------------------------------------------------------------------------|
| 0  | 0  | 0  | 0  | Read assembled serial input data byte out of Receiver Buffer               |
| 0  | 0  | 0  | 1  | Read parallel data input via X10 - X17                                     |
| 0  | 0  | 1  | 0  | Read RST instruction code, as a data byte, when polling interrupt requests |
| 0  | 0  | 1  | 1  | Read Status register contents to the CPU                                   |
| 0  | 1  | 0  | 0  | Write command code to the TMS 5501                                         |
| 0  | 1  | 0  | 1  | Load serial I/O Control register, specifying baud rate and stop bits       |
| 0  | 1  | 1  | 0  | Write data byte to serial transmit logic                                   |
| 0  | 1  | 1  | 1  | Write data byte to parallel output port                                    |
| 1  | 0  | 0  | 0  | Write out interrupt mask byte to selectively enable and disable interrupts |
| 1  | 0  | 0  | 1  | Write initial count to Interval Timer 1                                    |
| 1  | 0  | 1  | 0  | Write initial count to Interval Timer 2                                    |
| 1  | 0  | 1  | 1  | Write initial count to Interval Timer 3                                    |
| 1  | 1  | 0  | 0  | Write initial count to Interval Timer 4                                    |
| 1  | 1  | 0  | 1  | Write initial count to Interval Timer 5                                    |
| 1  | 1  | 1  | 0  | No Operation                                                               |
| 1  | 1  | 1  | 1  | No Operation                                                               |

**TMS 5501 addressable locations 3, 4 and 5 are used for status and controls which generally apply to serial I/O and interrupt processing.** We will define how these ports are used now, in advance of our discussion of TMS 5501 serial I/O and interrupt processing capabilities.

Locations 3 and 5 apply to serial I/O logic. Location 3 is a Status register whose bits are interpreted as follows:



#### Bits 0 and 1 are standard framing and overrun error indicators.

If a framing error is detected, Status register bit 0 will be set to 1 and will remain 1 until assembly of the next complete serial data character has been completed.

If Receiver Buffer contents are not read while the next serial character is being input and assembled, an overrun error will be reported in bit 1 of the Status register. This error indicator will be cleared as soon as the Status register contents are read, or when a reset command is output. Remember, you have the time it takes to receive and assemble one character in which to read the previous character out of the Receiver Buffer. This is because receive logic includes a double buffer. A character is assembled in a Receiver register; when completely assembled, it is shifted to a Receiver Buffer and the next character is assembled in the Receiver register:



**Status bits 2, 3, 6 and 7 monitor the condition of the serial data input signal.** During a break, that is, when no valid serial data is being input, status bit 2 will be high. As soon as a start bit has been detected, status bit 2 will be reset low and status bit 7 will be set high. When the first valid data bit is detected, status bit 6 is also set high. When the received character has been assembled in the Receiver Buffer, and may be read by the CPU, status bits 7 and 6 are reset and status bit 3 is set. This may be illustrated as follows:



**Status bit 4 applies to serial transmit logic.** As soon as the Transmitter Buffer is ready to receive another byte of data, status bit 4 will be set high. It will remain high until new data has been loaded into the Transmitter Buffer.

Transmit logic, like receive logic, is double-buffered. A byte of data is held in a Transmitter register while being output serially; meanwhile, the next data byte may be loaded into a Transmitter Buffer. Transmitter Buffer contents are automatically shifted to the Transmitter register when serial output of a data byte is complete. This may be illustrated as follows:



Status bit 4 is high from the instant Transmitter Buffer contents are shifted into the Transmitter register, until a new data byte is written into the Transmitter buffer.

**Status bit 5 is set whenever the TMS 5501 has an unacknowledged interrupt request.** While this status bit is very important in serial I/O operations, it also may have application elsewhere; this bit therefore may be looked upon as an exception within the Status register, in that it is the only status flag that does not apply strictly to serial I/O operations.

**TMS 5501 addressable location 5 is also dedicated to serial I/O.** Into this location you must load a control byte which selects baud rate, and the number of stop bits. Register contents will be interpreted as follows:



If more than one of bits 0 through 6 are high, then the highest indicated baud rate will be selected. If no baud rate bit is high, then all serial transmit and receive logic will be inhibited.

TMS 5501 addressable location 4 is a general command register. Its contents will be interpreted as follows:



If your system does not require interrupts from the TMS 5501, you can set bit 5 high to derive a TTL compatible clock from the INT output.

If the TMS 5501 device is reset by outputting 1 to bit 0, then the following events will occur:

**TMS 5501  
RESET**

- 1) Serial receive logic enters the Hunt mode. Status bits 2, 3, 6 and 7 are all reset; however, reset will not clear the Receive Buffer contents.
- 2) Serial transmit logic will output a high marking signal. Status bit 4 will be set high indicating that transmit logic is ready to receive another data byte.
- 3) The interrupt mask register is cleared with the exception of the Transmit Buffer interrupt, which is enabled. (Interrupt levels and interrupt masking are described shortly.)
- 4) All interval timers are halted.

The Reset has no effect on any of the following:

- Parallel input and output port contents
- Interrupt acknowledge enable
- Interrupt Mask register contents
- Baud rate register contents
- Serial Transmit or Receive Buffer contents

**Control command bit 1 determines whether serial transmit logic will mark or space when not transmitting data.** A 1 in bit 1 will cause serial transmit logic to mark (output high) while a 0 in bit 1 will cause transmit logic to space (output low).

If Reset conflicts with the break specification, then Reset will override and transmit logic will mark, irrespective of the break bit specification.

The TMS 5501 can receive an interrupt request from one of nine different sources. Using the eight Restart instructions, each interrupt request is assigned one of eight priorities. For this to be possible, two interrupt sources share the lowest priority interrupt level (RST 7); these two sources are an external request arriving via XI7 and the Interval Timer 5 time out interrupt request. **You use bit 2 of the control command to select which requesting source will be active at any time as the lowest priority interrupt.**

**Bit 3 of the control command is a master enable/disable for TMS 5501 interrupt logic.** If this bit is output as 0, then TMS 5501 interrupt acknowledge logic is disabled — and that effectively disables the entire interrupt processing system. Observe that with interrupt acknowledge logic disabled you can still use polling techniques in lieu of interrupt processing.

Table 4-8. TMS 5501 Interrupt Logic and Priorities

| Interrupt<br>and Mask<br>Bit | Data Bus<br>Status |    |    | RST<br>Instruction | Interrupting Source                                                                                    |
|------------------------------|--------------------|----|----|--------------------|--------------------------------------------------------------------------------------------------------|
|                              | D5                 | D4 | D3 |                    |                                                                                                        |
| 0 (highest)                  | 0                  | 0  | 0  | RST 0              | Interval Timer 1                                                                                       |
| 1                            | 0                  | 0  | 1  | RST 1              | Interval Timer 2                                                                                       |
| 2                            | 0                  | 1  | 0  | RST 2              | External SENS interrupt request                                                                        |
| 3                            | 0                  | 1  | 1  | RST 3              | Interval Timer 3                                                                                       |
| 4                            | 1                  | 0  | 0  | RST 4              | Serial I/O Receiver Buffer full                                                                        |
| 5                            | 1                  | 0  | 1  | RST 5              | Serial I/O Transmitter Buffer full                                                                     |
| 6                            | 1                  | 1  | 0  | RST 6              | Interval Timer 4                                                                                       |
| 7 (lowest)                   | 1                  | 1  | 1  | RST 7              | Interval Timer 5, or external XI7<br>interrupt request, whichever has<br>been selected by command code |

## TMS 5501 INTERRUPT HANDLING

The TMS 5501 responds to nine different interrupt requests, with priorities as defined in Table 4-8.

When an interrupt is acknowledged, INT is output high by the TMS 5501. If the TMS 5501 INT output is connected to the 8080A INT input, then the 8080A will acknowledge the interrupt by outputting D1 high at SYNC high. The TMS 5501 responds to this acknowledgement by placing an RST instruction's object code on the Data Bus, as required by standard 8080A timing. This is an utterly standard 8080A interrupt request/acknowledge sequence.

Interrupts may be selectively disabled by writing a mask to TMS 5501 Register 8; see Table 4-7. A 0 bit will disable an interrupt; mask bits are related to priorities as follows:



Note that TMS 5501 interrupt priorities apply to the request/acknowledge sequence only—which is the standard passive interrupt priority arbitration sequence used in most microcomputer applications. Once an interrupt is acknowledged and is being serviced by an interrupt service routine, it is up to the programmer to disable all interrupts, or selected interrupts, if the interrupt service routine is not itself to get interrupted. If, for example, an interrupt were to be acknowledged at priority 3 (Interval Timer 3), in the normal course of events the 8080A CPU will disable all interrupts upon acknowledging any interrupt. Therefore the Interval Timer 3 interrupt service routine will deny any other interrupt request, whatever its priority, until the Interval Timer 3 service routine completes execution. If the Interval Timer 3 interrupt service routine were to immediately enable all interrupts, then any other interrupt request would be acknowledged, irrespective of priority.

If you want to ensure that only higher priority requests interrupt the Timer 3 service routine, then the Timer 3 service routine must begin by outputting a mask to disable all lower level interrupts at the TMS 5501; then it must enable all interrupts at the CPU. Here is the necessary instruction sequence:

```
MVI    TMS8,07H      ;OUTPUT MASK TO REGISTER 8 OF TMS 5501
EI           ;ENABLE INTERRUPTS
```

The mask output in this case has the value 07, since mask bits 0, 1 and 2 only must be set to 1, enabling the highest three interrupt priority levels.

**Let us now look at the nonstandard features associated with TMS 5501 interrupt handling logic.** First of all, so long as there is an unacknowledged interrupt request, Status register bit 5 is set to 1; next the RST instruction object code for the highest level interrupt request is stored in TMS 5501 Register 2. This allows you to bypass normal interrupt processing logic and poll the TMS 5501 instead.

### TMS 5501 NONSTANDARD FEATURES

In order to bypass interrupt logic, simply disconnect the TMS 5501 INT output from the 8080A INT input. You can still identify interrupt requests occurring within the TMS 5501 by reading the TMS 5501 Status register. If bit 5 of the Status register is 1, then one or more interrupt requests are active within the TMS 5501. In order to determine which is the highest level active interrupt request, read the contents of TMS 5501 memory location 2. The RST instruction object code corresponding to the highest priority interrupt request will have been assembled in this location. Bits 3, 4 and 5 of the RST instruction object code identify the priority level. Thus you can determine which of the eight priority levels was the highest active interrupt request. Here is a typical polling sequence:

```
;ASSUME THAT THE TMS 5501 ADDRESS SPACE CONSISTS OF 16 MEMORY.  
;LOCATIONS FROM 8000 THROUGH 800F. TMS5 IS THE SYMBOL ASSIGNED  
;TO THE BASE ADDRESS  
TMS5 EQU 8000H
```

```
;TEST STATUS REGISTER FOR INTERRUPT PENDING  
LDA TMS5+3 ;LOAD STATUS TO ACCUMULATOR  
ANI 20H ;ISOLATE BIT 5  
JNZ TMS5+2 ;IF NOT ZERO, AN INTERRUPT HAS BEEN  
;REQUESTED
```

It is worth spending a minute looking at the three-instruction sequence illustrated above. The TMS 5501 Status register contents are loaded into the Accumulator by the LDA instruction. The next instruction isolates bit 5. If bit 5 is 1, then an interrupt has been requested, and the next instruction, a JNZ, branches program execution to a memory location within the TMS 5501 itself. Will that work? Indeed, it will. The label TMS5+2 addresses TMS 5501 Register 2, which contains an RST instruction's object code; this is the object code which would have been output in response to a normal interrupt acknowledge. What the JNZ instruction does is cause this RST instruction's object code to be executed next; and that is precisely the logic sequence which a normal interrupt response would have implemented.

Notice that the very simple method we have illustrated for polling on status only works if the TMS 5501 can be addressed as memory locations rather than I/O ports.

### TMS 5501 PARALLEL I/O OPERATIONS

**It is very easy to handle simple parallel I/O, without handshaking, using the TMS 5501.** This is equivalent to 8255 Mode 0 operation. TMS 5501 address 1 accesses the parallel 8-bit input port, while address 7 accesses a parallel 8-bit output port (see Table 4-7). Assuming that the TMS 5501 is addressed as memory, input and output operations are handled using any memory reference instructions.

**A very limited amount of parallel I/O handshaking is available.** The SENS interrupt input signal can be used by external logic either to indicate that it has read output data, or to indicate that it has transmitted input data. However, the TMS 5501 device itself has no control signals which can be used to prompt external logic; that is to say, the TMS 5501 has no signal equivalent to the 8255 OBF control. When comparing the parallel I/O capabilities of the TMS 5501 with the 8255, therefore, we conclude that 8255 Mode 0 operations can be duplicated without problems, but neither Mode 1 nor Mode 2 parallel I/O operations with handshaking can be duplicated. Only a primitive level of parallel I/O with handshaking exists within the TMS 5501 and even this exists at the expense of external interrupt logic.

### TMS 5501 SERIAL I/O OPERATION

**A significant asynchronous, serial I/O capability is provided by the TMS 5501. Synchronous serial I/O is not supported.**

**There are very significant differences between the implementation of asynchronous serial I/O by the TMS 5501, as compared to the 8251 USART.**

The TMS 5501 has separate serial transmit and receive pins (XMT and RCV), but it has no accompanying handshaking control signals; instead 5th and 6th priority interrupts identify Receiver Buffer full and Transmit Buffer full, respectively. Bits 2, 3, 6 and 7 of the Status register (addressable location 3) identify the condition of a serial receive data stream.

When using the TMS 5501, you have to continuously read in the contents of the Status register and test the condition of appropriate status bits in order to implement standard serial receive logic; however, in the end you can implement the same serial receive logic as is provided automatically by the 8251 USART. Here is the relationship between the TMS 5501 and the 8251 USART controls:

| 8251 USART | TMS 5501 EQUIVALENT   |
|------------|-----------------------|
| TxRDY      | Status register bit 4 |
| TxE        | None                  |
| TxC        | Baud Rate register    |
| RxRDY      | Status register bit 3 |
| RxC        | Baud Rate register    |
| SYNDET     | None                  |

Probably the most significant difference between TMS 5501 and 8251 USART control is the fact that TMS 5501 baud rate is programmed by outputting an appropriate Control code, while it is clocked by rate signals input to the 8251 USART. The TMS 5501 advantage is that the TMS 5501 does not need external baud rate clock generation logic; however there must be a very precise synchronization between the TMS 5501 and whatever external logic it is communicating with. Minor timing differences are no problem when using an 8251 USART since a clock signal can accompany the serial data stream. Minor timing differences can be intolerable when using the TMS 5501; a small difference between TMS 5501 baud rate and external clock signals can generate very significant errors.

## **TMS 5501 INTERVAL TIMERS**

The TMS 5501 has five programmable Interval Timers. Each timer can be loaded with an initial count ranging from 01 (lowest) through FF16 (highest). Each Timer will decrement one count every 64 microseconds. As soon as a programmable timer counts out to zero, it requests an interrupt. In our discussion of TMS 5501 interrupt logic, we have defined the priority levels assigned to the various Interval Timers. Notice that Interval Timer priorities have been spread across the range of priority levels. By using Interval Timer 1 or 2, you can be sure of precise time intervals, since an interrupt request will be acknowledged with little or no delay. Timers 4 and 5, being the lowest priority, can be used to generate less precise time intervals. It is conceivable that interrupt requests originating at these two timers might have to wait a significant amount of time before being serviced — if there is any degree of interrupt traffic within the microcomputer system.

### **Loading a 0 value into an Interval Timer causes an immediate interrupt request.**

When a nonzero value is loaded into an Interval Timer, it starts to count down immediately. If a new value is loaded into an Interval Timer while it is halfway through counting out, then the new value will be accepted; it will override the previous value and subsequently will be decremented. Therefore the Interval Timers are retriggerable.

Once an Interval Timer counts out, it halts.

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- 8080A CPU
- 8224 Clock Device
- 8228 System Controller
- 8259 PIC
- TMS 5501 I/O Controller

## ABSOLUTE MAXIMUM RATINGS\*

|                                                           |                 |
|-----------------------------------------------------------|-----------------|
| Temperature Under Bias . . . . .                          | 0°C to +70°C    |
| Storage Temperature . . . . .                             | -65°C to +150°C |
| All Input or Output Voltages                              |                 |
| With Respect to $V_{BB}$ . . . . .                        | -0.3V to +20V   |
| $V_{CC}$ , $V_{DD}$ and $V_{SS}$ With Respect to $V_{BB}$ | -0.3V to +20V   |
| Power Dissipation . . . . .                               | 1.5W            |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_A = 0^\circ C$  to  $70^\circ C$ ,  $V_{DD} = +12V \pm 5\%$ ,  $V_{CC} = +5V \pm 5\%$ ,  $V_{BB} = -5V \pm 5\%$ ,  $V_{SS} = 0V$ , Unless Otherwise Noted.

| Symbol       | Parameter                                | Min.       | Typ. | Max.         | Unit          | Test Condition                                                                 |
|--------------|------------------------------------------|------------|------|--------------|---------------|--------------------------------------------------------------------------------|
| $V_{ILC}$    | Clock Input Low Voltage                  | $V_{SS}-1$ |      | $V_{SS}+0.8$ | V             |                                                                                |
| $V_{IHC}$    | Clock Input High Voltage                 | 9.0        |      | $V_{DD}+1$   | V             |                                                                                |
| $V_{IL}$     | Input Low Voltage                        | $V_{SS}-1$ |      | $V_{SS}+0.8$ | V             |                                                                                |
| $V_{IH}$     | Input High Voltage                       | 3.3        |      | $V_{CC}+1$   | V             |                                                                                |
| $V_{OL}$     | Output Low Voltage                       |            |      | 0.45         | V             |                                                                                |
| $V_{OH}$     | Output High Voltage                      | 3.7        |      |              | V             |                                                                                |
| $I_{DD(AV)}$ | Avg. Power Supply Current ( $V_{DD}$ )   |            | 40   | 70           | mA            | $I_{OL} = 1.9mA$ on all outputs,<br>$I_{OH} = -150\mu A$ .                     |
| $I_{CC(AV)}$ | Avg. Power Supply Current ( $V_{CC}$ )   |            | 60   | 80           | mA            | Operation<br>$T_{CY} = .48 \mu sec$                                            |
| $I_{BB(AV)}$ | Avg. Power Supply Current ( $V_{BB}$ )   |            | .01  | 1            | mA            |                                                                                |
| $I_{IL}$     | Input Leakage                            |            |      | $\pm 10$     | $\mu A$       | $V_{SS} \leq V_{IN} \leq V_{CC}$                                               |
| $I_{CL}$     | Clock Leakage                            |            |      | $\pm 10$     | $\mu A$       | $V_{SS} \leq V_{CLOCK} \leq V_{DD}$                                            |
| $I_{DL(2)}$  | Data Bus Leakage in Input Mode           |            |      | -100<br>-2.0 | $\mu A$<br>mA | $V_{SS} \leq V_{IN} \leq V_{SS}+0.8V$<br>$V_{SS}+0.8V \leq V_{IN} \leq V_{CC}$ |
| $I_{FL}$     | Address and Data Bus Leakage During HOLD |            |      | +10<br>-100  | $\mu A$       | $V_{ADDR/DATA} = V_{CC}$<br>$V_{ADDR/DATA} = V_{SS} + 0.45V$                   |

## CAPACITANCE

$T_A = 25^\circ C$     $V_{CC} = V_{DD} = V_{SS} = 0V$ ,  $V_{BB} = -5V$

| Symbol    | Parameter          | Typ. | Max. | Unit | Test Condition       |
|-----------|--------------------|------|------|------|----------------------|
| $C_\phi$  | Clock Capacitance  | 17   | 25   | pf   | $f_c = 1 MHz$        |
| $C_{IN}$  | Input Capacitance  | 6    | 10   | pf   | Unmeasured Pins      |
| $C_{OUT}$ | Output Capacitance | 10   | 20   | pf   | Returned to $V_{SS}$ |

## NOTES:

1. The RESET signal must be active for a minimum of 3 clock cycles.
2. When DBIN is high and  $V_{IN} > V_{IH}$  an internal active pull up will be switched onto the Data Bus.
3.  $\Delta I_{\text{supply}} / \Delta T_A = -0.45\% / ^\circ C$ .



Figure 2. Typical Supply Current vs. Temperature, Normalized<sup>[3]</sup>



Figure 3. Data Bus Characteristic During DBIN

# 8080A/8080A-1/8080A-2

## A.C. CHARACTERISTICS (8080A)

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{DD} = +12V \pm 5\%$ ,  $V_{CC} = +5V \pm 5\%$ ,  $V_{BB} = -5V \pm 5\%$ ,  $V_{SS} = 0V$ , Unless Otherwise Noted

| Symbol         | Parameter                                                            | Min. | Max.     | -1 Min. | -1 Max.  | -2 Min. | -2 Max.  | Unit            | Test Condition         |
|----------------|----------------------------------------------------------------------|------|----------|---------|----------|---------|----------|-----------------|------------------------|
| $t_{CY}^{[3]}$ | Clock Period                                                         | 0.48 | 2.0      | 0.32    | 2.0      | 0.38    | 2.0      | $\mu\text{sec}$ |                        |
| $t_{r, f}$     | Clock Rise and Fall Time                                             | 0    | 50       | 0       | 25       | 0       | 50       | nsec            |                        |
| $t_{\phi 1}$   | $\phi_1$ Pulse Width                                                 | 60   |          | 50      |          | 60      |          | nsec            |                        |
| $t_{\phi 2}$   | $\phi_2$ Pulse Width                                                 | 220  |          | 145     |          | 175     |          | nsec            |                        |
| $t_{D1}$       | Delay $\phi_1$ to $\phi_2$                                           | 0    |          | 0       |          | 0       |          | nsec            |                        |
| $t_{D2}$       | Delay $\phi_2$ to $\phi_1$                                           | 70   |          | 60      |          | 70      |          | nsec            |                        |
| $t_{D3}$       | Delay $\phi_1$ to $\phi_2$ Leading Edges                             | 80   |          | 60      |          | 70      |          | nsec            |                        |
| $t_{DA}^{[2]}$ | Address Output Delay From $\phi_2$                                   |      | 200      |         | 150      |         | 175      | nsec            | $C_L = 100 \text{ pF}$ |
| $t_{DD}^{[2]}$ | Data Output Delay From $\phi_2$                                      |      | 220      |         | 180      |         | 200      | nsec            | $C_L = 50 \text{ pF}$  |
| $t_{DC}^{[2]}$ | Signal Output Delay From $\phi_2$ or $\phi_2$ (SYNC, WR, WAIT, HLDA) |      | 120      |         | 110      |         | 120      | nsec            |                        |
| $t_{DF}^{[2]}$ | DBIN Delay From $\phi_2$                                             | 25   | 140      | 25      | 130      | 25      | 140      | nsec            |                        |
| $t_{DI}^{[1]}$ | Delay for Input Bus to Enter Input Mode                              |      | $t_{DF}$ |         | $t_{DF}$ |         | $t_{DF}$ | nsec            |                        |
| $t_{DS1}$      | Data Setup Time During $\phi_1$ and DBIN                             | 30   |          | 10      |          | 20      |          | nsec            |                        |

## WAVEFORMS

(Note: Timing measurements are made at the following reference voltages: CLOCK "1" = 8.0V  
"0" = 1.0V; INPUTS "1" = 3.3V, "0" = 0.8V; OUTPUTS "1" = 2.0V, "0" = 0.8V.)



# 8080A/8080A-1/8080A-2

## A.C. CHARACTERISTICS (8080A)

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{DD} = +12V \pm 5\%$ ,  $V_{CC} = +5V \pm 5\%$ ,  $V_{BB} = -5V \pm 5\%$ ,  $V_{SS} = 0V$ , Unless Otherwise Noted

| Symbol         | Parameter                                         | Min. | Max. | -1 Min. | -1 Max. | -2 Min. | -2 Max. | Unit | Test Condition |
|----------------|---------------------------------------------------|------|------|---------|---------|---------|---------|------|----------------|
| $t_{DS2}$      | Data Setup Time to $\phi_2$ During DBIN           | 150  |      | 120     |         | 130     |         | nsec |                |
| $t_{DH}^{[1]}$ | Data Hold time From $\phi_2$ During DBIN          | [1]  |      | [1]     |         | [1]     |         | nsec |                |
| $t_{IE}^{[2]}$ | INTE Output Delay From $\phi_2$                   |      | 200  |         | 200     |         | 200     | nsec |                |
| $t_{RS}$       | READY Setup Time During $\phi_2$                  | 120  |      | 90      |         | 90      |         | nsec |                |
| $t_{HS}$       | HOLD Setup Time to $\phi_2$                       | 140  |      | 120     |         | 120     |         | nsec |                |
| $t_{IS}$       | INT Setup Time During $\phi_2$                    | 120  |      | 100     |         | 100     |         | nsec |                |
| $t_H$          | Hold Time From $\phi_2$ (READY, INT, HOLD)        | 0    |      | 0       |         | 0       |         | nsec |                |
| $t_{FD}$       | Delay to Float During Hold (Address and Data Bus) |      | 120  |         | 120     |         | 120     | nsec |                |
| $t_{AW}^{[2]}$ | Address Stable Prior to WR                        | [5]  |      | [5]     |         | [5]     |         | nsec |                |
| $t_{DW}^{[2]}$ | Output Data Stable Prior to WR                    | [6]  |      | [6]     |         | [6]     |         | nsec |                |
| $t_{WD}^{[2]}$ | Output Data Stable From WR                        | [7]  |      | [7]     |         | [7]     |         | nsec |                |
| $t_{WA}^{[2]}$ | Address Stable From WR                            | [7]  |      | [7]     |         | [7]     |         | nsec |                |
| $t_{HF}^{[2]}$ | HLDA to Float Delay                               | [8]  |      | [8]     |         | [8]     |         | nsec |                |
| $t_{WF}^{[2]}$ | WR to Float Delay                                 | [9]  |      | [9]     |         | [9]     |         | nsec |                |
| $t_{AH}^{[2]}$ | Address Hold Time After DBIN During HLDA          | -20  |      | -20     |         | -20     |         | nsec |                |

$C_L = 50 \text{ pF}$

$C_L = 100 \text{ pF}$ : Address, Data  
 $C_L = 50 \text{ pF}$ : WR, HLDA, DBIN



NOTES: (Parenthesis gives -1, -2 specifications, respectively)

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured.  
 $t_{DH} = 50 \text{ ns}$  or  $t_{DF}$ , whichever is less.
2. Load Circuit:



$$3. t_{CY} = t_{D3} + t_{\phi 2} + t_{\phi 2} + t_{\phi 2} + t_{D2} + t_{\phi 1} \geq 480 \text{ ns} (-1.320 \text{ ns}, -2.380 \text{ ns}).$$

TYPICAL  $\Delta$  OUTPUT DELAY VS.  $\Delta$  CAPACITANCE



4. The following are relevant when interfacing the 8080A to devices having  $V_{IH} = 3.3V$ .
  - a) Maximum output rise time from .8V to 3.3V = 100ns @  $C_L = \text{SPEC}$ .
  - b) Output delay when measured to 3.0V = SPEC +60ns @  $C_L = \text{SPEC}$ .
  - c) If  $C_L \neq \text{SPEC}$ , add .6ns/pF if  $C_L > C_{SPEC}$ , subtract .3ns/pF (from modified delay) if  $C_L < C_{SPEC}$ .
5.  $t_{AW} = 2 t_{CY} - t_{D3} - t_{\phi 2} - 140 \text{ ns} (-1.110 \text{ ns}, -2.130 \text{ ns})$ .
6.  $t_{DW} = t_{CY} - t_{D3} - t_{\phi 2} - 170 \text{ ns} (-1.150 \text{ ns}, -2.170 \text{ ns})$ .
7. If no HLDA,  $t_{WD} = t_{WA} = t_{D3} + t_{\phi 2} + 10\text{ns}$ . If HLDA,  $t_{WD} = t_{WA} = t_{WF}$ .
8.  $t_{HF} = t_{D3} + t_{\phi 2} - 50\text{ns}$ .
9.  $t_{WF} = t_{D3} + t_{\phi 2} - 10\text{ns}$ .
10. Data in must be stable for this period during DBIN-T3. Both  $t_{DS1}$  and  $t_{DS2}$  must be satisfied.
11. Ready signal must be stable for this period during T2 or  $t_{CY}$ . (Must be externally synchronized.)
12. Hold signal must be stable for this period during T2 or  $t_{WF}$  when entering hold mode, and during T3, T4, T5 and  $t_{WF}$  when in hold mode. (External synchronization is not required.)
13. Interrupt signal must be stable during this period of the fast clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.)
14. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

**ABSOLUTE MAXIMUM RATINGS\***

|                                           |                 |
|-------------------------------------------|-----------------|
| Temperature Under Bias . . . . .          | 0°C to 70°C     |
| Storage Temperature . . . . .             | -65°C to 150°C  |
| Supply Voltage, V <sub>CC</sub> . . . . . | -0.5V to +7V    |
| Supply Voltage, V <sub>DD</sub> . . . . . | -0.5V to +13.5V |
| Input Voltage . . . . .                   | -1.5V to +7V    |
| Output Current . . . . .                  | .100mA          |

**\*COMMENT:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. CHARACTERISTICS**

T<sub>A</sub> = 0°C to 70°C; V<sub>CC</sub> = +5.0V ±5%; V<sub>DD</sub> = +12V ±5%.

| Symbol                         | Parameter                                                                                     | Limits     |      |      | Units | Test Conditions                                                                    |
|--------------------------------|-----------------------------------------------------------------------------------------------|------------|------|------|-------|------------------------------------------------------------------------------------|
|                                |                                                                                               | Min.       | Typ. | Max. |       |                                                                                    |
| I <sub>F</sub>                 | Input Current Loading                                                                         |            |      | -.25 | mA    | V <sub>F</sub> = .45V                                                              |
| I <sub>R</sub>                 | Input Leakage Current                                                                         |            |      | 10   | µA    | V <sub>R</sub> = 5.25V                                                             |
| V <sub>C</sub>                 | Input Forward Clamp Voltage                                                                   |            |      | 1.0  | V     | I <sub>C</sub> = -5mA                                                              |
| V <sub>IL</sub>                | Input "Low" Voltage                                                                           |            |      | .8   | V     | V <sub>CC</sub> = 5.0V                                                             |
| V <sub>IH</sub>                | Input "High" Voltage                                                                          | 2.6<br>2.0 |      |      | V     | Reset Input<br>All Other Inputs                                                    |
| V <sub>IH-V<sub>IL</sub></sub> | RESIN Input Hysteresis                                                                        | .25        |      |      | V     | V <sub>CC</sub> = 5.0V                                                             |
| V <sub>OL</sub>                | Output "Low" Voltage                                                                          |            |      | .45  | V     | (φ <sub>1</sub> , φ <sub>2</sub> ), Ready, Reset, STSTB<br>I <sub>OL</sub> = 2.5mA |
|                                |                                                                                               |            |      | .45  | V     | All Other Outputs<br>I <sub>OL</sub> = 15mA                                        |
| V <sub>OH</sub>                | Output "High" Voltage<br>φ <sub>1</sub> , φ <sub>2</sub><br>READY, RESET<br>All Other Outputs | 9.4        |      |      | V     | I <sub>OH</sub> = -100µA                                                           |
|                                |                                                                                               | 3.6        |      |      | V     | I <sub>OH</sub> = -100µA                                                           |
|                                |                                                                                               | 2.4        |      |      | V     | I <sub>OH</sub> = -1mA                                                             |
| I <sub>SC</sub> <sup>[1]</sup> | Output Short Circuit Current<br>(All Low Voltage Outputs Only)                                | -10        |      | -60  | mA    | V <sub>O</sub> = 0V<br>V <sub>CC</sub> = 5.0V                                      |
| I <sub>CC</sub>                | Power Supply Current                                                                          |            |      | 115  | mA    |                                                                                    |
| I <sub>DD</sub>                | Power Supply Current                                                                          |            |      | 12   | mA    |                                                                                    |

Note: 1. Caution, φ<sub>1</sub> and φ<sub>2</sub> output drivers do not have short circuit protection

**Crystal Requirements**

Tolerance: .005% at 0°C -70°C

Resonance: Series (Fundamental)\*

Load Capacitance: 20-35pF

Equivalent Resistance: 75-20 ohms

Power Dissipation (Typ.): 4mW

\*With tank circuit use 3rd overtone mode.

## A.C. CHARACTERISTICS

$V_{CC} = +5.0V \pm 5\%$ ;  $V_{DD} = +12.0V \pm 5\%$ ;  $T_A = 0^\circ C$  to  $70^\circ C$

| Symbol        | Parameter                                | Limits                  |                 |                         | Units | Test Conditions                                                |
|---------------|------------------------------------------|-------------------------|-----------------|-------------------------|-------|----------------------------------------------------------------|
|               |                                          | Min.                    | Typ.            | Max.                    |       |                                                                |
| $t_{\phi 1}$  | $\phi_1$ Pulse Width                     | $\frac{2tcy}{9} - 20ns$ |                 |                         | ns    | $C_L = 20pF$ to $50pF$                                         |
| $t_{\phi 2}$  | $\phi_2$ Pulse Width                     | $\frac{5tcy}{9} - 35ns$ |                 |                         |       |                                                                |
| $t_{D1}$      | $\phi_1$ to $\phi_2$ Delay               | 0                       |                 |                         |       |                                                                |
| $t_{D2}$      | $\phi_2$ to $\phi_1$ Delay               | $\frac{2tcy}{9} - 14ns$ |                 |                         |       |                                                                |
| $t_{D3}$      | $\phi_1$ to $\phi_2$ Delay               | $\frac{2tcy}{9}$        |                 | $\frac{2tcy}{9} + 20ns$ |       |                                                                |
| $t_R$         | $\phi_1$ and $\phi_2$ Rise Time          |                         |                 | 20                      |       |                                                                |
| $t_F$         | $\phi_1$ and $\phi_2$ Fall Time          |                         |                 | 20                      |       |                                                                |
| $t_{D\phi 2}$ | $\phi_2$ to $\phi_2$ (TTL) Delay         | -5                      |                 | +15                     | ns    | $\phi_2$ TTL, $CL=30pF$<br>$R_1=300\Omega$<br>$R_2=600\Omega$  |
| $t_{DSS}$     | $\phi_2$ to $\overline{STSTB}$ Delay     | $\frac{6tcy}{9} - 30ns$ |                 | $\frac{6tcy}{9}$        |       | $STSTB, CL=15pF$<br>$R_1 = 2K$<br>$R_2 = 4K$                   |
| $t_{PW}$      | $STSTB$ Pulse Width                      | $\frac{tcy}{9} - 15ns$  |                 |                         |       |                                                                |
| $t_{DRS}$     | RDYIN Setup Time to Status Strobe        | $50ns - \frac{4tcy}{9}$ |                 |                         |       |                                                                |
| $t_{DRH}$     | RDYIN Hold Time After $\overline{STSTB}$ | $\frac{4tcy}{9}$        |                 |                         |       |                                                                |
| $t_{DR}$      | RDYIN or RESIN to $\phi_2$ Delay         | $\frac{4tcy}{9} - 25ns$ |                 |                         |       | Ready & Reset<br>$CL=10pF$<br>$R_1=2K$<br>$R_2=4K$             |
| $t_{CLK}$     | CLK Period                               |                         | $\frac{tcy}{9}$ |                         |       |                                                                |
| $f_{max}$     | Maximum Oscillating Frequency            |                         |                 | 27                      | MHz   |                                                                |
| $C_{in}$      | Input Capacitance                        |                         |                 | 8                       | pF    | $V_{CC}=+5.0V$<br>$V_{DD}=+12V$<br>$V_{BIAS}=2.5V$<br>$f=1MHz$ |



# 8224

## WAVEFORMS



VOLTAGE MEASUREMENT POINTS:  $\phi_1, \phi_2$  Logic "0" = 1.0V, Logic "1" = 8.0V. All other signals measured at 1.5V.

### EXAMPLE:

#### A.C. CHARACTERISTICS (For $t_{CY} = 488.28 \text{ ns}$ )

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ;  $V_{DD} = +5V \pm 5\%$ ;  $V_{DD} = +12V \pm 5\%$ .

| Symbol        | Parameter                                            | Limits |      |        | Units | Test Conditions                                                                                                     |
|---------------|------------------------------------------------------|--------|------|--------|-------|---------------------------------------------------------------------------------------------------------------------|
|               |                                                      | Min.   | Typ. | Max.   |       |                                                                                                                     |
| $t_{\phi 1}$  | $\phi_1$ Pulse Width                                 | 89     |      |        | ns    | $t_{CY}=488.28\text{ns}$                                                                                            |
| $t_{\phi 2}$  | $\phi_2$ Pulse Width                                 | 236    |      |        | ns    |                                                                                                                     |
| $t_{D1}$      | Delay $\phi_1$ to $\phi_2$                           | 0      |      |        | ns    |                                                                                                                     |
| $t_{D2}$      | Delay $\phi_2$ to $\phi_1$                           | 95     |      |        | ns    |                                                                                                                     |
| $t_{D3}$      | Delay $\phi_1$ to $\phi_2$ Leading Edges             | 109    |      | 129    | ns    | $\phi_1 \& \phi_2$ Loaded to $C_L = 20$ to $50\text{pF}$                                                            |
| $t_r$         | Output Rise Time                                     |        |      | 20     | ns    |                                                                                                                     |
| $t_f$         | Output Fall Time                                     |        |      | 20     | ns    |                                                                                                                     |
| $t_{DSS}$     | $\phi_2$ to $\bar{S}\bar{T}\bar{S}\bar{T}$ Delay     | 296    |      | 326    | ns    |                                                                                                                     |
| $t_{D\phi 2}$ | $\phi_2$ to $\phi_2$ (TTL) Delay                     | -5     |      | +15    | ns    |                                                                                                                     |
| $t_{PW}$      | Status Strobe Pulse Width                            | 40     |      |        | ns    |                                                                                                                     |
| $t_{DRS}$     | RDYIN Setup Time to $\bar{S}\bar{T}\bar{S}\bar{T}$   | -167   |      |        | ns    |                                                                                                                     |
| $t_{DRH}$     | RDYIN Hold Time after $\bar{S}\bar{T}\bar{S}\bar{T}$ | 217    |      |        | ns    |                                                                                                                     |
| $t_{DR}$      | READY or RESET to $\phi_2$ Delay                     | 192    |      |        | ns    |                                                                                                                     |
| $f_{MAX}$     | Oscillator Frequency                                 |        |      | 18.432 | MHz   | Ready & Reset Loaded to $2\text{mA}/10\text{pF}$<br>All measurements referenced to 1.5V unless specified otherwise. |

**ABSOLUTE MAXIMUM RATINGS\***

|                                           |                |
|-------------------------------------------|----------------|
| Temperature Under Bias . . . . .          | -0°C to 70°C   |
| Storage Temperature . . . . .             | -65°C to 150°C |
| Supply Voltage, V <sub>CC</sub> . . . . . | -0.5V to +7V   |
| Input Voltage . . . . .                   | -1.5V to +7V   |
| Output Current . . . . .                  | 100mA          |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. CHARACTERISTICS** T<sub>A</sub> = 0°C to 70°C; V<sub>CC</sub> = 5V ±5%.

| Symbol              | Parameter                                                                               | Limits |         |      | Unit | Test Conditions                                 |
|---------------------|-----------------------------------------------------------------------------------------|--------|---------|------|------|-------------------------------------------------|
|                     |                                                                                         | Min.   | Typ.[1] | Max. |      |                                                 |
| V <sub>C</sub>      | Input Clamp Voltage, All Inputs                                                         |        | .75     | -1.0 | V    | V <sub>CC</sub> =4.75V; I <sub>C</sub> =-5mA    |
| I <sub>F</sub>      | Input Load Current,<br>STSTB                                                            |        |         | 500  | μA   | V <sub>CC</sub> =5.25V<br>V <sub>F</sub> =0.45V |
|                     | D <sub>2</sub> & D <sub>6</sub>                                                         |        |         | 750  | μA   |                                                 |
|                     | D <sub>0</sub> , D <sub>1</sub> , D <sub>4</sub> ; D <sub>5</sub> ,<br>& D <sub>7</sub> |        |         | 250  | μA   |                                                 |
|                     | All Other Inputs                                                                        |        |         | 250  | μA   |                                                 |
| I <sub>R</sub>      | Input Leakage Current<br>STSTB                                                          |        |         | 100  | μA   | V <sub>CC</sub> =5.25V<br>V <sub>R</sub> =5.25V |
|                     | DB <sub>0</sub> -DB <sub>7</sub>                                                        |        |         | 20   | μA   |                                                 |
|                     | All Other Inputs                                                                        |        |         | 100  | μA   |                                                 |
| V <sub>TH</sub>     | Input Threshold Voltage, All Inputs                                                     | 0.8    |         | 2.0  | V    | V <sub>CC</sub> =5V                             |
| I <sub>CC</sub>     | Power Supply Current                                                                    |        | 140     | 190  | mA   | V <sub>CC</sub> =5.25V                          |
| V <sub>OL</sub>     | Output Low Voltage,<br>D <sub>0</sub> -D <sub>7</sub>                                   |        |         | .45  | V    | V <sub>CC</sub> =4.75V; I <sub>OL</sub> =2mA    |
|                     | All Other Outputs                                                                       |        |         | .45  | V    | I <sub>OL</sub> = 10mA                          |
| V <sub>OH</sub>     | Output High Voltage,<br>D <sub>0</sub> -D <sub>7</sub>                                  | 3.6    | 3.8     |      | V    | V <sub>CC</sub> =4.75V; I <sub>OH</sub> =-10μA  |
|                     | All Other Outputs                                                                       | 2.4    |         |      | V    | I <sub>OH</sub> = -1mA                          |
| I <sub>OS</sub>     | Short Circuit Current, All Outputs                                                      | 15     |         | 90   | mA   | V <sub>CC</sub> =5V                             |
| I <sub>O(off)</sub> | Off State Output Current,<br>All Control Outputs                                        |        |         | 100  | μA   | V <sub>CC</sub> =5.25V; V <sub>O</sub> =5.25    |
|                     |                                                                                         |        |         | -100 | μA   | V <sub>O</sub> =-45V                            |
| I <sub>INT</sub>    | INTA Current                                                                            |        |         | 5    | mA   | (See Figure below)                              |

Note 1: Typical values are for T<sub>A</sub> = 25°C and nominal supply voltages.

## 8228/8238

## WAVEFORMS



VOLTAGE MEASUREMENT POINTS: D<sub>0</sub>-D<sub>7</sub> (when outputs) Logic "0" = 0.8V, Logic "1" = 3.0V. All other signals measured at 1.5V.

\*ADVANCED IOW/MEMW FOR 8238 ONLY.

A.C. CHARACTERISTICS  $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ;  $V_{CC} = 5\text{V} \pm 5\%$ .

| Symbol          | Parameter                                                                                                      | Limits |      | Units | Condition            |
|-----------------|----------------------------------------------------------------------------------------------------------------|--------|------|-------|----------------------|
|                 |                                                                                                                | Min.   | Max. |       |                      |
| t <sub>PW</sub> | Width of Status Strobe                                                                                         | 22     |      | ns    |                      |
| t <sub>SS</sub> | Setup Time, Status Inputs D <sub>0</sub> -D <sub>7</sub>                                                       | 8      |      | ns    |                      |
| t <sub>SH</sub> | Hold Time, Status Inputs D <sub>0</sub> -D <sub>7</sub>                                                        | 5      |      | ns    |                      |
| t <sub>DC</sub> | Delay from <b>STSTB</b> to any Control Signal                                                                  | 20     | 60   | ns    | $C_L = 100\text{pF}$ |
| t <sub>RR</sub> | Delay from DBIN to Control Outputs                                                                             | 30     |      | ns    | $C_L = 100\text{pF}$ |
| t <sub>RE</sub> | Delay from DBIN to Enable/Disable 8080 Bus                                                                     | 45     |      | ns    | $C_L = 25\text{pF}$  |
| t <sub>RD</sub> | Delay from System Bus to 8080 Bus during Read                                                                  | 30     |      | ns    | $C_L = 25\text{pF}$  |
| t <sub>WR</sub> | Delay from WR to Control Outputs                                                                               | 5      | 45   | ns    | $C_L = 100\text{pF}$ |
| t <sub>WE</sub> | Delay to Enable System Bus DB <sub>0</sub> -DB <sub>7</sub> after <b>STSTB</b>                                 | 30     |      | ns    | $C_L = 100\text{pF}$ |
| t <sub>WD</sub> | Delay from 8080 Bus D <sub>0</sub> -D <sub>7</sub> to System Bus DB <sub>0</sub> -DB <sub>7</sub> during Write | 5      | 40   | ns    | $C_L = 100\text{pF}$ |
| t <sub>E</sub>  | Delay from System Bus Enable to System Bus DB <sub>0</sub> -DB <sub>7</sub>                                    | 30     |      | ns    | $C_L = 100\text{pF}$ |
| t <sub>HD</sub> | HLDA to Read Status Outputs                                                                                    | 25     |      | ns    |                      |
| t <sub>DS</sub> | Setup Time, System Bus Inputs to HLDA                                                                          | 10     |      | ns    |                      |
| t <sub>DH</sub> | Hold Time, System Bus Inputs to HLDA                                                                           | 20     |      | ns    | $C_L = 100\text{pF}$ |

# 8228/8238 AND 8259/8259-5

## CAPACITANCE

This parameter is periodically sampled and not 100% tested.

| Symbol    | Parameter                             | Limits |         |      | Unit |
|-----------|---------------------------------------|--------|---------|------|------|
|           |                                       | Min.   | Typ.[1] | Max. |      |
| $C_{IN}$  | Input Capacitance                     |        | 8       | 12   | pF   |
| $C_{OUT}$ | Output Capacitance<br>Control Signals |        | 7       | 15   | pF   |
| I/O       | I/O Capacitance<br>(D or DB)          |        | 8       | 15   | pF   |

**Test Conditions:** NS:  $V_{BIAS} = 2.5V$ ,  $V_{CC} = 5.0V$ ,  $T_A = 25^\circ C$ ,  $f = 1MHz$ .

Note 2: For  $D_0-D_7$ :  $R_1 = 4K\Omega$ ,  $R_2 = \infty\Omega$ ,  $C_L = 25pF$ . For all other outputs:  $R_1 = 500\Omega$ ,  $R_2 = 1K\Omega$ ,  $C_L = 100pF$ .



Figure 1. INTA Test Circuit (for RST 7)

## ABSOLUTE MAXIMUM RATINGS\*

|                                              |       |                 |
|----------------------------------------------|-------|-----------------|
| Ambient Temperature Under Bias               | ..... | 0°C to 70°C     |
| Storage Temperature                          | ..... | -65°C to +150°C |
| Voltage On Any Pin<br>With Respect to Ground | ..... | -0.5V to +7V    |
| Power Dissipation                            | ..... | 1 Watt          |

### \*COMMENT:

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## D.C. CHARACTERISTICS

( $T_A = 0^\circ C$  to  $70^\circ C$ ;  $V_{CC} = 5V \pm 5\%$ )

| SYMBOL           | PARAMETER                                 | MIN. | MAX.           | UNITS         | TEST CONDITIONS               |
|------------------|-------------------------------------------|------|----------------|---------------|-------------------------------|
| $V_{IL}$         | Input Low Voltage                         | -.5  | .8             | V             |                               |
| $V_{IH}$         | Input High Voltage                        | 2.0  | $V_{CC} + .5V$ | V             |                               |
| $V_{OL}$         | Output Low Voltage                        |      | .45            | V             | $I_{OL} = 2 \text{ mA}$       |
| $V_{OH}$         | Output High Voltage                       | 2.4  |                | V             | $I_{OH} = -400 \mu\text{A}$   |
| $V_{OH-INT}$     | Interrupt Output High Voltage             | 2.4  |                | V             | $I_{OH} = -400 \mu\text{A}$   |
|                  |                                           | 3.5  |                | V             | $I_{OH} = -50 \mu\text{A}$    |
| $I_{IL(IR_0-7)}$ | Input Leakage Current<br>for $IR_0-7$     |      | -300           | $\mu\text{A}$ | $V_{IN} = 0V$                 |
|                  |                                           |      | 10             | $\mu\text{A}$ | $V_{IN} = V_{CC}$             |
| $I_{IL}$         | Input Leakage Current<br>for Other Inputs |      | 10             | $\mu\text{A}$ | $V_{IN} = V_{CC}$ to 0V       |
| $I_{OFL}$        | Output Float Leakage                      |      | $\pm 10$       | $\mu\text{A}$ | $V_{OUT} = 0.45V$ to $V_{CC}$ |
| $I_{cc}$         | $V_{CC}$ Supply Current                   |      | 100            | mA            |                               |

## CAPACITANCE

$T_A = 25^\circ C$ ;  $V_{CC} = GND = 0V$

| SYMBOL    | PARAMETER         | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS                      |
|-----------|-------------------|------|------|------|------|--------------------------------------|
| $C_{IN}$  | Input Capacitance |      |      | 10   | pF   | $f_c = 1 \text{ MHz}$                |
| $C_{I/O}$ | I/O Capacitance   |      |      | 20   | pF   | Unmeasured pins returned to $V_{SS}$ |

**8259/8259-5****A.C. CHARACTERISTICS**

(TA = 0°C to 70°C; VCC = +5V ±5%, GND = 0V)

**Bus Parameters**

Read:

| SYMBOL | PARAMETER                      | 8259 |      | 8259-5 |      | UNIT |
|--------|--------------------------------|------|------|--------|------|------|
|        |                                | MIN. | MAX. | MIN.   | MAX. |      |
| tAR    | CS/A0 Stable Before RD or INTA | 50   |      | 50     |      | ns   |
| tRA    | CS/A0 Stable After RD or INTA  | 5    |      | 30     |      | ns   |
| tRR    | RD Pulse Width                 | 420  |      | 300    |      | ns   |
| tRD    | Data Valid From RD/INTA(1)     |      | 300  |        | 200  | ns   |
| tDF    | Data Float After RD/INTA       | 20   | 200  | 20     | 100  | ns   |

Write:

| SYMBOL | PARAMETER               | 8259 |      | 8259-5 |      | UNIT |
|--------|-------------------------|------|------|--------|------|------|
|        |                         | MIN. | MAX. | MIN.   | MAX. |      |
| tAW    | A0 Stable Before WR     | 50   |      | 50     |      | ns   |
| tWA    | A0 Stable After WR      | 20   |      | 30     |      | ns   |
| tWW    | WR Pulse Width          | 400  |      | 300    |      | ns   |
| tDW    | Data Valid to WR (T.E.) | 300  |      | 250    |      | ns   |
| tWD    | Data Valid After WR     | 40   |      | 30     |      | ns   |

**Other Timings:**

| SYMBOL | PARAMETER                        | 8259 |      | 8259-5 |      | UNIT |
|--------|----------------------------------|------|------|--------|------|------|
|        |                                  | MIN. | MAX. | MIN.   | MAX. |      |
| tIW    | Width of Interrupt Request Pulse | 100  |      | 100    |      | ns   |
| tINT   | INT ↑ After IR ↑                 | 400  |      | 350    |      | ns   |
| tIC    | Cascade Line Stable After INTA ↑ | 400  |      | 400    |      | ns   |

Note 1: 8259: CL = 100pF, 8259-5: CL = 150pF.

**Input Waveforms for A.C. Tests**

## WAVEFORMS

### Read Timing



### Write Timing



### Other Timing



Note: Interrupt Request must remain "HIGH" (at least) until leading edge of first INTA.

### Read Status/Poll Mode



# TMS 5501

## TMS 5501 ELECTRICAL AND MECHANICAL SPECIFICATIONS

### ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)\*

|                                            |       |       |       |                |
|--------------------------------------------|-------|-------|-------|----------------|
| Supply voltage, $V_{CC}$ (see Note 1)      | ..... | ..... | ..... | -0.3 V to 20 V |
| Supply voltage, $V_{DD}$ (see Note 1)      | ..... | ..... | ..... | -0.3 V to 20 V |
| Supply voltage, $V_{SS}$ (see Note 1)      | ..... | ..... | ..... | -0.3 V to 20 V |
| All input and output voltages (see Note 1) | ..... | ..... | ..... | -0.3 V to 20 V |
| Continuous power dissipation               | ..... | ..... | ..... | 1.1 W          |
| Operating free-air temperature range       | ..... | ..... | ..... | 0°C to 70°C    |
| Storage temperature range                  | ..... | ..... | ..... | -65°C to 150°C |

\*Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

NOTE 1: Under absolute maximum ratings voltage values are with respect to the normally most negative supply voltage,  $V_{BB}$  (substrate). Throughout the remainder of this data sheet, voltage values are with respect to  $V_{SS}$  unless otherwise noted.

### RECOMMENDED OPERATING CONDITIONS

|                                                                           | MIN   | NOM | MAX        | UNIT |
|---------------------------------------------------------------------------|-------|-----|------------|------|
| Supply voltage, $V_{BB}$                                                  | -4.75 | -5  | -5.25      | V    |
| Supply voltage, $V_{CC}$                                                  | 4.75  | 5   | 5.25       | V    |
| Supply voltage, $V_{DD}$                                                  | 11.4  | 12  | 12.6       | V    |
| Supply voltage, $V_{SS}$                                                  | 0     |     |            | V    |
| High-level input voltage, $V_{IH}$ (all inputs except clocks)             | 3.3   |     | $V_{CC}+1$ | V    |
| High-level clock input voltage, $V_{IH(\phi)}$                            | 9     |     | $V_{DD}+1$ | V    |
| Low-level input voltage, $V_{IL}$ (all inputs except clocks) (see Note 2) | -1    |     | 0.8        | V    |
| Low-level clock input voltage, $V_{IL(\phi)}$ (see Note 2)                | -1    |     | 0.8        | V    |
| Operating free-air temperature, $T_A$                                     | 0     |     | 70         | °C   |

NOTE 2: The algebraic convention where the most negative limit is designated as minimum is used in this specification for logic voltage levels only.

Data sheets on pages D-13 through D-16 are reproduced by permission of Texas Instruments Incorporated.

# TMS 5501

## ELECTRICAL CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS (UNLESS OTHERWISE NOTED)

| PARAMETER                                                        | TEST CONDITIONS                                                         | MIN | MAX      | UNIT          |
|------------------------------------------------------------------|-------------------------------------------------------------------------|-----|----------|---------------|
| $I_I$<br>Input current (any input except<br>clocks and data bus) | $V_I = 0 \text{ V to } V_{CC}$                                          |     | $\pm 10$ | $\mu\text{A}$ |
| $I_{I(\phi)}$<br>Clock input current                             | $V_{I(\phi)} = 0 \text{ V to } V_{DD}$                                  |     | $\pm 10$ | $\mu\text{A}$ |
| $I_{I(DB)}$<br>Input current, data bus                           | $V_{I(DB)} = 0 \text{ V to } V_{CC}$ ,<br>CE at 0 V                     |     | -50      | $\mu\text{A}$ |
| $V_{OH}$<br>High-level output voltage                            | $I_{OH} = 400 \mu\text{A}$                                              | 3.7 |          | V             |
| $V_{OL}$<br>Low-level output voltage                             | $I_{OL} = 1.7 \text{ mA}$                                               |     | 0.45     | V             |
| $I_{BB(av)}$<br>Average supply current from $V_{BB}$             | Operating at $t_c(\phi) = 480 \text{ ns}$ ,<br>$T_A = 25^\circ\text{C}$ |     | -1       |               |
| $I_{CC(av)}$<br>Average supply current from $V_{CC}$             |                                                                         | 100 |          | mA            |
| $I_{DD(av)}$<br>Average supply current from $V_{DD}$             |                                                                         | 40  |          |               |
| $C_i$<br>Capacitance, any input except clock                     | $V_{CC} = V_{DD} = V_{SS} = 0 \text{ V}$ ,                              |     | 10       |               |
| $C_{I(\phi)}$<br>Clock input capacitance                         | $V_{BB} = -4.75 \text{ to } -5.25 \text{ V}$ ,<br>$f = 1 \text{ MHz}$ , |     | 75       | pF            |
| $C_o$<br>Output capacitance                                      | All other pins at 0 V                                                   |     | 20       |               |

## TIMING REQUIREMENTS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS

|                       |                                                                        | MIN | MAX  | UNIT |
|-----------------------|------------------------------------------------------------------------|-----|------|------|
| $t_{c(\phi)}$         | Clock cycle time                                                       | 480 | 2000 | ns   |
| $t_{r(\phi)}$         | Clock rise time                                                        | 5   | 50   | ns   |
| $t_{f(\phi)}$         | Clock fall time                                                        | 5   | 50   | ns   |
| $t_{w(\phi 1)}$       | Pulse width, clock 1 high                                              | 60  |      | ns   |
| $t_{w(\phi 2)}$       | Pulse width, clock 2 high                                              | 200 | 300  | ns   |
| $t_d(\phi 1L-\phi 2)$ | Delay time, clock 1 low to clock 2                                     | 0   |      | ns   |
| $t_d(\phi 2-\phi 1)$  | Delay time, clock 2 to clock 1                                         | 70  |      | ns   |
| $t_d(\phi 1H-\phi 2)$ | Delay time, clock 1 high to clock 2 (time between leading edges)       | 80  |      | ns   |
| $t_{su(ad)}$          | Address setup time                                                     | 50  |      | ns   |
| $t_{su(CE)}$          | Chip-enable setup time                                                 | 50  |      | ns   |
| $t_{su(da)}$          | Data setup time                                                        | 50  |      | ns   |
| $t_{su(sync)}$        | Sync setup time                                                        | 50  |      | ns   |
| $t_{su(XI)}$          | External input setup time                                              | 50  |      | ns   |
| $t_h(ad)$             | Address hold time                                                      | 0   |      | ns   |
| $t_h(CE)$             | Chip-enable hold time                                                  | 10  |      | ns   |
| $t_h(da)$             | Data hold time                                                         | 10  |      | ns   |
| $t_h(sync)$           | Sync hold time                                                         | 10  |      | ns   |
| $t_h(XI)$             | External input hold time                                               | 40  |      | ns   |
| $t_w(sens H)$         | Pulse width, sensor input high                                         | 500 |      | ns   |
| $t_w(sens L)$         | Pulse width, sensor input low                                          | 500 |      | ns   |
| $t_d(sens-int)$       | Delay time, sensor to interrupt (time between leading edges)           |     | 2000 | ns   |
| $t_d(rst-int)$        | Delay time, RST instruction to interrupt (time between trailing edges) |     | 500  | ns   |

**TMS 5501**

**SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED  
OPERATING CONDITIONS (SEE FIGURES 6 AND 7)**

| PARAMETER                                                          | TEST CONDITIONS                                   | MIN | MAX | UNIT |
|--------------------------------------------------------------------|---------------------------------------------------|-----|-----|------|
| $t_{PZX}$ Data bus output enable time                              | $C_L = 100 \text{ pF}, R_L = 1.3 \text{ k}\Omega$ | 200 | ns  |      |
| $t_{PXZ}$ Data bus output disable time to high-impedance state     |                                                   | 180 | ns  |      |
| $t_{PD}$ External data output propagation delay time from $\phi_2$ |                                                   | 200 | ns  |      |



$C_L$  includes probe and jig capacitance

**LOAD CIRCUIT**

NOTE: For  $\phi_1$  or  $\phi_2$  inputs, high and low timing points are 90% and 10% of  $V_{IH}(\phi)$ . All other timing points are the 50% level.

**FIGURE 6—READ CYCLE TIMING**

## TMS 5501



NOTE: For  $\phi 1$  and  $\phi 2$  inputs, high and low timing points are 90% and 10% of  $V_{IH}(\phi)$ . All other timing points are the 50% level.

FIGURE 7—WRITE CYCLE TIMING



NOTES: 1. The RST instruction occurs during the output data valid time of the read cycle.  
2. All timing points are 50% of  $V_{IH}$ .

FIGURE 8—SENSOR/INTERRUPT TIMING

# Chapter 5

## THE 8085

The 8085A is Intel's enhancement of the 8080A — just as the Z80 is Zilog's enhancement of the 8080A. The Z80 is described in Chapter 7.

Intel is the developer of the 8085A; Intel is also the principal manufacturer of the 8080A. But the individuals at Zilog who developed the Z80 were previously employed by Intel, at which time they developed the 8080A from the 8008. The Z80 and the 8085A therefore have equal claim to be the legitimate descendent of the 8080A.

The 8085A provides the same logic as the 8080A, 8224 and 8228 three-chip CPU. The 8085A has the following additional enhancements:

- 1) The 8085A requires a single +5V power supply.
- 2) The 8085A uses a single clock signal.
- 3) The 8085A has a primitive on-chip serial I/O capability which may also be used to input status and output control signals.
- 4) The 8085A has interrupt request pins with hardware-generated interrupt vectoring.
- 5) The 8085A operates with a standard 320 nanosecond clock as against the standard 500 nanosecond clock of the 8080A. But recall that there are versions of the 8080A that operate with a 250 nanosecond clock.

The 8085A instruction set is almost identical to the 8080A instruction set; in contrast, the Z80 has a massively expanded instruction set. The large Z80 instruction set has been criticized for its complexity, but one could argue that since the Z80 also provides the complete 8080A instruction set, anyone who does not want to use the additional instructions can simply ignore them.

The 8085A multiplexes its Data Bus with the low-order Address Bus lines. Such multiplexing demands custom support devices, or external demultiplexing logic.

Figure 5-3 and associated text provide a direct comparison of 8085A and 8080A signal interfaces.

In addition to the 8085A microprocessor, support devices described in this chapter include:

- The 8155/8156 static RAM with I/O ports and timer. This device provides 256 bytes of static read/write memory.
- The 8355 ROM with I/O ports. This device provides 2048 bytes of read-only memory plus I/O logic.
- The 8755A EPROM with I/O ports. This device provides 2048 bytes of erasable programmable read-only memory with I/O logic.

The 8085A is a new version of an earlier device, the 8085. In most respects the two parts are identical — however, there are some important differences, which we will note throughout this chapter. Where we note no difference, the discussion applies to both the 8085 and the 8085A.

8085 AND  
8085A

Standard 8080A support devices described in Chapter 4 and in Volume III cannot be used with the 8085A unless the 8085A is operating with a 500 ns clock. If you are using the 8085A with a 320 ns clock, you must use the special -5 series of support parts.

The 8085A prime source is:

INTEL CORPORATION  
3065 Bowers Avenue  
Santa Clara, California 95051

The 8085A second source is:

ADVANCED MICRO DEVICES  
901 Thompson Place  
Sunnyvale, California 94086

The 8085A uses a single +5V power supply; it is packaged as a 40-pin DIP.

Using a 320 nanosecond clock, instruction execution times range from 1.3 microseconds to 5.7 microseconds.

All 8085A devices have TTL compatible signals.



Figure 5-1. Logic of the 8085A Microprocessor

## THE 8085A CPU

**Functions implemented on the 8085A CPU are illustrated in Figure 5-1; they represent typical CPU logic.** The 8085A has an Arithmetic and Logic Unit, a Control Unit, Accumulators and registers.

Clock logic is on the 8085A CPU chip; only an external crystal or RC network is needed.

Bus interface logic which was excluded on the 8080A is provided by the 8085A.

N-channel silicon gate technology is used by all 8085A devices.

## 8085A PROGRAMMABLE REGISTERS

The 8085A programmable registers are identical to the 8080A programmable registers. They may be illustrated as follows:



For a discussion of 8085A programmable registers refer to the 8080A CPU description given in Chapter 4.

## 8085A ADDRESSING MODES

The 8085A uses exactly the same memory addressing modes as the 8080A. Direct and implied memory addressing are available. See the 8080A addressing modes description given in Chapter 4 for details.

## 8085A STATUS

The 8085A has the same set of status flags as the 8080A; status flags are stored in the same bits of the Program Status Words. The five status flags provided are:

- Zero (Z)
- Sign (S)
- Parity (P)
- Carry (C)
- Auxiliary Carry (AC)

Status flags are assigned to bits of the Program Status Words as follows:



For a discussion of status flags refer to the 8080A status description given in Chapter 4.

## 8085A CPU PINS AND SIGNALS

8085A CPU pins and signals are illustrated in Figure 5-2.

Whereas the internal architecture and the instruction sets of the 8080A and the 8085A are very similar, pins and signals are not. We will therefore begin by describing 8085A signals without reference to, or comparison with, the 8080A; then we will compare the two interfaces.

**The Address and Data Busses of the 8085A are multiplexed.** Pins A8 - A15 are output-only lines which carry the high-order byte of memory addresses. AD0 - AD7 are bidirectional lines which output the low-order byte of memory addresses; AD0 - AD7 also serve as a bidirectional Data Bus.



| PIN NAME                        | DESCRIPTION                          | TYPE                    |
|---------------------------------|--------------------------------------|-------------------------|
| AD0 - AD7                       | Address/Data Bus                     | Bidirectional, tristate |
| A8 - A15                        | Address Bus                          | Output, tristate        |
| ALE                             | Address Latch Enable                 | Output*                 |
| RD                              | Read Control                         | Output, tristate        |
| WR                              | Write Control                        | Output, tristate        |
| IO/M                            | I/O or Memory Indicator              | Output, tristate        |
| S0, S1                          | Bus State Indicators                 | Output                  |
| READY                           | Wait State Request                   | Input                   |
| SID                             | Serial Data Input                    | Input                   |
| SOD                             | Serial Data Output                   | Output                  |
| HOLD                            | Hold Request                         | Input                   |
| HLDA                            | Hold Acknowledge                     | Output                  |
| INTR                            | Interrupt Request                    | Input                   |
| TRAP                            | Non-maskable Interrupt Request       | Input                   |
| RST 5.5                         | Hardware vectored interrupt requests | Input                   |
| RST 6.5                         |                                      | Input                   |
| RST 7.5                         |                                      | Input                   |
| INTA                            | Interrupt Acknowledge                | Output                  |
| RESET IN                        | System Reset                         | Input                   |
| RESET OUT                       | Peripherals Reset                    | Output                  |
| X1, X2                          | Crystal or RC Connections            | Input                   |
| CLK                             | Clock Signal                         | Output                  |
| V <sub>CC</sub> V <sub>SS</sub> | Power, Ground                        |                         |

\*This output is tristate on the 8085, but not on the 8085A

Figure 5-2. 8085A CPU Signals and Pin Assignments

**ALE** is an address latch enable signal which pulses high when address data is being output on AD0 - AD7. You may use the falling edge of ALE to strobe the address off AD0 - AD7 into external latches if you are demultiplexing AD0 - AD7 into separate Address and Data Busses. **ALE** is a tristate output on the 8085, an earlier version of the 8085A.

**ALE DIFFERENCE  
IN 8085 AND  
8085A**

Five control signals control memory and I/O accesses.

**RD** is pulsed low for a memory or I/O read operation.

**8085A  
CONTROL  
SIGNALS**

**WR** is pulsed low for a memory or I/O write operation.

**IO/M** is output high in conjunction with **RD** or **WR** for an I/O access.

**IO/M** is output low in conjunction with **RD** or **WR** for a memory read or write operation.

**8085A  
DATA BUS  
DEFINITION  
SIGNALS**

The state of the System Bus is further defined by the S0 and S1 status signals as follows:

| S1 | S0 | OPERATION SPECIFIED |
|----|----|---------------------|
| 0  | 0  | Halt                |
| 0  | 1  | Memory or I/O write |
| 1  | 0  | Memory or I/O read  |
| 1  | 1  | Instruction fetch   |

External logic that does not have sufficient time to respond to an access can gain additional time by using the READY input signal. The READY input can be used to insert Wait state clock periods in any machine cycle. Timing and logic associated with Wait states is described later in this chapter.

**8085A  
SERIAL I/O**

Two signals allow a primitive serial I/O capability. The high-order Accumulator bit may be output via SOD. The signal level at SID may be input to the high-order bit of the Accumulator. SID and SOD may also be used to input status and to output control signals.

**8085A BUS  
CONTROL  
SIGNALS**  
**8085A  
INTERRUPT  
SIGNALS**

Two signals allow external logic to take control of the System Bus.

**HOLD**, when input high, floats the Address Bus plus the **RD**, **WR**, **IO/M** and **ALE** control signals. **HLDA** is output high to acknowledge this Hold condition.

There are six signals associated with interrupt logic. Interrupts may be requested via INTR, RST 5.5, RST 6.5, RST 7.5 and TRAP. An interrupt request made via INTR is acknowledged via the **INTA** output.

INTR is the general purpose interrupt request used by external logic; it is equivalent to the 8080A INTR signal.

**8085A  
RESET  
SIGNALS**

TRAP is a non-maskable, highest priority interrupt request. TRAP is used for catastrophic failure interrupts.

RST 5.5, RST 6.5 and RST 7.5 are three interrupt request signals supported by hardware-implemented vectoring.

Interrupt capabilities of the 8085A are described in detail later in this chapter.

There are two signals associated with 8085A Reset logic.

**RESET IN** is the Reset input signal. This signal need not be synchronized with the clock. **RESET OUT** is a Reset signal output by the 8085A for use throughout the rest of the 8085A microcomputer system.

**X1** and **X2** connect an external crystal or RC network to drive clock logic internal to the 8085A. A crystal will be connected as follows:



An RC network will be connected as follows:



You can apply a clock signal directly to X1:



**The input frequency must be twice the operating frequency.** Thus, to obtain a 320 nanosecond clock, or 3.125 MHz, the input frequency must be 6.25 MHz.

Slave 8085A devices in a multiple CPU system will usually be driven directly by a clock signal.

A TTL level clock signal (CLK) is output by the 8085A. It may be used to drive slave CPUs, or for any other synchronization purpose within the microcomputer system. The frequency of CLK is the operating frequency of the 8085A; that is, the CLK frequency is half the input frequency.



Figure 5-3. A Comparison of 8085A and 8080A/8224/8228 Signal Interface

## A COMPARISON OF 8085A AND 8080A SIGNALS

No attempt has been made to maintain any kind of pin compatibility between the 8085A and the 8080A. Nevertheless, as illustrated in Figure 5-3, it is relatively simple to derive equivalent system busses when using the 8085A or 8080A. But look at Figure 5-3 with an element of caution. Many logical combinations of 8085A signals are shown reproducing 8080A signals; in reality you will never generate such logical combinations — a point which will become clear as the chapter proceeds. The purpose of Figure 5-3 is to illustrate the equivalence of the system busses generated by the 8085A and the 8080A without indicating that creation of equivalent busses is desirable.

The 8080A signals which are shown as having direct 8085A equivalents are either obvious, or will become so after you have read this chapter.

What is more interesting is to look at the 8080A signals which no longer exist and the new 8085A signals which have been added.

### **Let us first look at the signals which have been dropped.**

There are the surplus power supplies -5V and +12V, plus the secondary power supplies required by the 8224 Clock Generator and the 8228 System Controller. Elimination of these signals is self-evident.

INTE is an 8080A signal that indicates to external logic when interrupts have or have not been enabled internally by the 8080A. This signal is not very useful, since external logic cannot use the information it provides. Apart from illuminating an appropriate indicator on a minicomputer-like control panel, the INT signal of the 8080A serves little useful purpose.

WAIT is a signal which is output high by the 8080A while Wait states are being inserted within a machine cycle. There is little that external logic can do with this signal, therefore its elimination in the 8085A carries no penalty.

BUSEN is a control input to the 8228 System Controller; it causes the 8228 to float its output signals. This signal is no longer required in the 8085A since the Hold state floats all equivalent 8085A output signals — with the exception of INTA, which does not need to be floated.

The 8224 Clock Generator outputs two synchronizing clock signals — OSC and Φ2 (TTL). Φ2 (TTL) is approximately reproduced by CLK; OSC has no equivalent 8085A signal.

The TANK input to the 8224 Clock Generator allows overtones of the external crystal to be used. No such signal exists with the 8085A — which simply means that you have to use the primary frequency of any crystal connected across the X1 and X2 inputs.

**Seven new signals have been added to the 8085A; it would have been possible to provide separate Data and Address Busses by eliminating these seven signals, plus the ALE control signal whose presence is a direct consequence of having multiplexed Data and Address Busses. Intel has chosen to provide the seven new signals, paying the price of having multiplexed Data and Address Busses.**

### **Let us examine the new signals.**

RST 5.5, RST 6.5, RST 7.5 and TRAP represent additional interrupt request inputs. TRAP is a non-maskable, high priority interrupt; the other three interrupt requests are supported by hardware-implemented vectoring.

RESET OUT is a Reset signal output by the 8085A; it may be used to reset support devices around the 8085A.

SID and SOD are control signals which provide a primitive serial input and output capability. These signals can also be used as a general purpose status input (SID) and a control output (SOD).

## 8085A TIMING AND INSTRUCTION EXECUTION

**An 8085A instruction's execution is timed by a sequence of machine cycles, each of which is divided into clock periods.**

An instruction is executed in from one to five machine cycles labeled MC1, MC2, MC3, MC4 and MC5.

**8085A  
MACHINE CYCLES**

**8085A  
CLOCK  
PERIODS**

| MC1            |                |                |                | MC2            |                |                | MC3            |                |                | MC4            |                |                | MC5            |                |  |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|
| T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> |  |

Where MC is shaded, the entire machine cycle is optional. Where T is shaded, the clock period is optional within its machine cycle.

8085A machine cycles and clock periods are very similar to those of the 8080A. You will find in Table 5-1 that the number of clock periods required to execute 8085A instructions is equal to the number of clock periods required by the 8080A to execute the same instructions, or differs by one clock period only.

## THE CLOCK SIGNALS

The 8085A times its machine cycles using this simple clock signal:



Although the 8085A has no SYNC signal to identify the start of a new machine cycle, you can use the 8085A ALE signal for the same purpose. This signal is output true during the first clock period of every machine cycle — at which time the AD0 - AD7 lines are outputting address data. In addition, you can identify the first (instruction fetch) cycle of any instruction's execution. S0 and S1 will both be output high during an instruction fetch machine cycle. Clock periods and machine cycles may therefore be identified as follows:



## MEMORY ACCESS SEQUENCES

So far as external logic is concerned, there is very little difference between an instruction fetch, a memory read, and a memory write. We will therefore examine timing for these operations together.



Figure 5-4. A Four Clock Period Instruction Fetch Machine Cycle

Let us first consider an instruction fetch. Timing is illustrated in Figure 5-4 for a four clock period machine cycle, and in Figure 5-5 for a six clock period machine cycle.

The most important aspect of the instruction fetch machine cycle is the fact that it will have either four or six clock periods, as against three for all subsequent machine cycles. The instruction fetch machine cycle must have at least four clock periods, since the fourth clock period is needed to decode the instruction object code which has been fetched. If the instruction requires no subsequent memory accesses, then a fifth and sixth clock period may be needed to perform the internal operation specified by the fetched instruction. If additional memory accesses will be required, then the fourth clock period of the first machine cycle is sufficient.

At the end of the first clock period, ADO - AD7 is floated transiently; then it is turned around to act as a Data Input Bus. RD is pulsed low to strobe data onto the Data Bus.

The memory read must occur within three clock periods. Since this is an instruction fetch machine cycle, the CPU will place the input in the Instruction register. If external logic requires more time to respond to the memory access, then it can generate additional Wait clock periods. We will describe the 8085A Wait state shortly.

During the fourth clock period of the instruction fetch machine cycle the instruction object code is interpreted by logic of the 8085A CPU. Fifth and sixth clock periods will be required by some instructions to execute required internal operations.



Figure 5-5. A Six Clock Period Instruction Fetch Machine Cycle

During the fourth and subsequent clock periods, AD0 - AD7 is floated and A8 - A15 contains unspecified data.

The fact that AD0 - AD7 and A8 - A15 are unknown data during the fourth and subsequent clock periods of an instruction fetch machine cycle must be taken into account when you create memory select and I/O device select logic.

In Figures 5-4 and 5-5 S0 and S1 are both high, identifying this as an instruction fetch machine cycle. IO/M is low since the instruction object code is to be fetched from memory. An instruction fetch is thus equivalent to a memory read.

The address of the memory location to be accessed is fetched from the Program Counter (PC) and is output on AD0 - AD7 (low-order byte) and A8 - A15 (high-order byte). The low-order byte of this memory address is stable on AD0 - AD7 during the first clock period. ALE is pulsed high at this time. The trailing edge of ALE is designed to act as a strobe signal which external logic can use to latch the low-order address byte off AD0 - AD7. If you are using one of the 8085A support devices (the 8155, the 8156 the 8344 or the or the 8755A), then the low-order byte

8085A  
DEVICE  
SELECT  
LOGIC

of the memory address is latched off the ADO - AD7 lines for you. If you are using standard memory devices, then you must demultiplex ADO - AD7. Any simple latched buffer can be used for this purpose; here is an example of the 8212 I/O port being used as a demultiplexer:



You might argue that there is no harm done if memory or I/O devices select themselves when the System Bus is supposed to be idle; if neither the read nor write strobe is present, data transfer between the System Bus and the selected device cannot occur.

Unfortunately, the problem is not so simple.

It is possible for more than one memory or I/O device to consider itself selected while the bus is idle; this may occur under the following conditions:

- 1) If I/O devices are being selected as I/O ports, then the Address Bus lines may select an I/O port while simultaneously selecting a memory device.
- 2) In microcomputer systems that use only a small portion of the total allowed memory — and most microcomputer systems fall into this category — memory select logic need not decode unique memory addresses. Here is an example of two 4096-byte memory modules, each of which uses a single line of the Address Bus in order to create device selects:



#### MULTIPLE DEVICE SELECTS AND BUS LOADING

Memory module 1 will be assigned the address space 8000<sub>16</sub> through 8FFF<sub>16</sub>. Memory module 2 will be assigned the address space 4000<sub>16</sub> through 4FFF<sub>16</sub>. In reality a variety of other addresses will select memory modules 1 or 2. Addresses C000<sub>16</sub> through CFFF<sub>16</sub> will select memory modules 1 and 2.

A correctly written program will keep either A15 or A14 low; but while the System Bus is floating, both address lines could be high — in which case both memory modules will become selected.

While signal levels on the Address Bus are changing state, memory and I/O devices may be transiently selected. Transient selection may occur during T1 as well as during T4, T5 and T6. Transient selection may leave more than one memory or I/O device simultaneously selected for short periods of time.

**If more than one memory or I/O device is simultaneously selected, excessive loads may be placed on the System Bus:** At best, these excessive loads will cause devices connected to the System Bus to temporarily malfunction; at worst, device failures may result.

**It is very important to prevent devices from being spuriously selected.**

If you use ROM devices with multiple chip select inputs, you can prevent transient memory selection by connecting the 8085A RD output to one of the select (or enable) inputs. This will ensure that the device responds only when a valid address is on the System Bus; therefore only one ROM device will be selected at a time. Refer to Volume III for information on memory devices.

The simplest way of preventing memory and I/O device selection is to use IO/M, RD and WR as contributors to device select logic:

**PREVENTING  
TRANSIENT  
SELECTION**

**PREVENTING  
SIMULTANEOUS  
SELECTION  
OF I/O AND  
MEMORY**



Timing for the memory select illustrated above may be illustrated as follows:



I/O device select logic timing differs only in the level of IO/M.

!O/M distinguishes between memory and I/O devices. When  $\overline{RD}$  or  $\overline{WR}$  is low, memory or I/O device addresses must be valid. Thus the logic illustrated above will guarantee that spurious memory and I/O device selects never occur.

But there is a problem associated with the solution illustrated; memory and I/O devices do not receive a valid select signal until early in the second clock period. This is unfortunate, since valid addresses are available early in the first clock period. Delaying memory select logic until the second clock period may require Wait states to be added between clock periods 2 and 3 — and that unnecessarily slows down CPU operations. If execution speed is not a problem to you, then the simple select logic illustrated above will do. **If execution speed is a problem, then you must replace:**



In the simple select logic with alternative logic that may be defined as follows:



The required S output may be generated using two flip-flops as follows:



If your system contains an 8085, rather than an 8085A, the first S output after a Reset will occur before the address lines are valid. Since ALE is tristate in the 8085, a falling edge occurs when Reset goes off; at this time the address lines may still be floating. One solution is to connect the first J input above to the Q output of the following D flip-flop:

SELECT  
PROBLEM  
WITH 8085



The flip-flop above prevents S from going high until after the first rising edge of ALE.



Figure 5-6. A Memory Read Machine Cycle Following an Instruction Fetch

Let us now consider a **memory read operation**; timing is illustrated in Figure 5-6. So far as external logic is concerned, the only difference between a memory read and an instruction fetch is the S0 and S1 signal levels; they are both high for an instruction fetch, but S0 is low during a memory read. Also, the instruction fetch has four or six clock periods, while the memory read has three; but the extra instruction fetch clock periods occur after the memory access is completed. Therefore, so far as external logic is concerned, the extra clock periods of the instruction fetch machine cycle are irrelevant.

**8085  
MEMORY  
READ TIMING**



Figure 5-7. An I/O Read Machine Cycle Following an Instruction Fetch

**Figure 5-7 illustrates I/O read timing.** Only the  $\overline{IO/M}$  signal level in Figure 5-7 differs from Figure 5-6.

**Memory write timing, illustrated in Figure 5-8, is very similar to memory read timing.** The principal difference is that during a memory write  $\overline{WR}$  is output low, whereas during a memory read  $\overline{RD}$  is output low. Also, during a memory write operation S1 is output low while S0 is output high.

An I/O write operation is illustrated in Figure 5-9. As compared to Figure 5-8,  $\overline{IO/M}$  is high in Figure 5-9 during the write machine cycle; there are no other timing differences.

|                                         |
|-----------------------------------------|
| <b>8085 I/O<br/>READ TIMING</b>         |
| <b>8085<br/>MEMORY<br/>WRITE TIMING</b> |
| <b>8085 I/O<br/>WRITE TIMING</b>        |



Figure 5-8. A Memory Write machine cycle following an Instruction Fetch



Figure 5-9. An I/O Write Machine Cycle Following an Instruction Fetch

## BUS IDLE MACHINE CYCLES

**During a Bus Idle machine cycle no control signals change state on the System Bus.**

**There are three types of Bus Idle machine cycles:**

- 1) An instruction fetch Bus Idle machine cycle. The 8085A CPU acknowledges an interrupt from TRAP, RST 5.5, RST 6.5, and RST 7.5 by generating a Restart instruction internally. No external instruction fetch operations occur; however, logic internal to the CPU requires time to create the instruction object code. Therefore a Bus Idle instruction fetch machine cycle is executed. Timing is illustrated in Figure 5-17.
- 2) The instruction execute Bus Idle machine cycle. Only the DAD instruction uses this machine cycle. The DAD instruction adds the contents of two CPU registers to two other CPU registers. It takes six clock periods for logic internal to the 8085 CPU to complete these operations. The six clock periods are generated via two instruction execute Bus Idle machine cycles. Timing is illustrated in Figure 5-10.

Figure 5-10 shows a difference in operations between The 8085A and the earlier version, the 8085. **During an instruction execute Bus Idle machine cycle, the 8085A does not generate a high pulse on ALE. The 8085, however, pulses ALE high during every T1 of every machine cycle — including instruction execute Bus Idle machine cycles.**

- 3) The Halt Bus Idle machine cycle. Following execution of a Halt instruction an indeterminate number of Bus Idle machine cycles are executed for the duration of the Halt condition. Timing is illustrated in Figure 5-14.

**8085A  
BUS IDLE  
MACHINE  
CYCLE**

**ALE GENERATION  
IN 8085 AND  
8085A**

**The condition of the IO/M, S0 and S1 signals during a Bus Idle machine cycle varies with the type of Bus Idle machine cycle.** These three signals will conform to instruction fetch level during an instruction fetch Bus Idle machine cycle. During an instruction execute Bus Idle machine cycle, Memory Read signal levels are maintained, but the RD control signal is not pulse low.

During a Halt Bus Idle machine cycle, S0 and S1 are both low but IO/M, along with other tristate signals, is floated.



Figure 5-10. A Bus Idle Machine Cycle Following an Instruction Fetch During Execution of a DAD Instruction



Figure 5-11. Wait States Occurring in a Memory Read Machine Cycle

## THE WAIT STATE

The 8085A will insert Wait states between clock periods T<sub>2</sub> and T<sub>3</sub> in a manner that is closely analogous to the 8080A. Timing is illustrated in Figure 5-11, which shows Wait states being inserted in a memory read cycle; a Wait state inserted in any other memory reference or I/O machine cycle would differ only in the levels of control signals.

The 8085A samples the READY line during T<sub>2</sub>. If READY is low during T<sub>2</sub>, then a Wait clock period will follow T<sub>2</sub>. The READY line is sampled in the middle of each Wait clock period; Wait clock periods continue to be inserted until READY is sampled high. As soon as READY is sampled high, the next clock period will be a T<sub>3</sub> clock period — and normal program execution continues. This sampling may be illustrated as follows:



Wait states are used in an 8085A system exactly as described for the 8080A in Chapter 4 — to give slow memories and I/O devices more time in order to respond to an access. Thus the discussion of Wait states provided in Chapter 4 applies equally to the 8085A.

In Chapter 4 a pair of 7474 flip-flops are shown creating a low READY pulse that generates a single Wait state in a memory read machine cycle. For the 8085A the following variation applies:



The circuit will operate with the following timing:



If the cycle is a memory read ( $S = 1, S_0 = 0$ ) or an instruction fetch ( $S_1 = 1, S_0 = 1$ ), Q1 will go high at the falling edge of ALE. This will cause flip-flop 2 to go on at the next falling edge of the 8085A clock, thereby forcing READY low. The low on READY will clear flip-flop 1, so that READY will return high on the next falling edge of the 8085A clock.

## THE SID AND SOD SIGNALS

The 8085A has two instructions which handle single-bit data.

**The RIM instruction inputs data from the SID pin to the high-order bit of the Accumulator. The SIM instruction outputs the high-order bit of the Accumulator to the SOD pin.**

You may use the RIM and SIM instructions in order to implement a primitive serial I/O capability. A more useful application of these instructions is to read single signal status and to output single-signal controls.

When the RIM instruction is executed, the SID signal level is sampled on the rising edge of the clock signal during clock period T3 of the instruction fetch machine cycle. The high-order bit of the Accumulator is modified while the clock signal is high during T1 of the next instruction fetch machine cycle. Timing may be illustrated as follows:



When an SIM instruction is executed, the actual change in SOD signal level does not occur until T2 of the next instruction fetch machine cycle; that is to say execution of the SIM instruction overlaps with the next instruction fetch.

This may be illustrated as follows:



Following an SIM instruction fetch, the high-order bit of the Accumulator is sampled while the clock is low during T2 of the next instruction fetch machine cycle. During the same clock period, the SOD signal level is modified to reflect the contents of the high-order Accumulator bit. This overlap is feasible since neither the SOD signal nor the Accumulator contents are modified while an instruction is being fetched. Note that SOD must be enabled before it can be accessed or changed; you use bit 6 of the Accumulator to enable SOD, as detailed later in this chapter when we describe the 8085A instruction set.

Figure 5-12 illustrates SID and SOD signal timing during execution of a RIM instruction followed by a SIM instruction.



Figure 5-12. A RIM Instruction Followed by a SIM Instruction



Figure 5-13. A Hold State Following a Single Machine Cycle Instruction Execution

## THE HOLD STATE

The 8080A and the 8085A both use the Hold state as a means of transiently floating the System Bus. During a Hold, external logic gains bus control, usually to perform direct memory access operations.

External logic requests a Hold state by inputting HOLD high. The microprocessor responds by entering the Hold state and outputting HLDA high. During a Hold state the microprocessor floats all tristate signals.

In the 8085, an earlier version of the 8085A, ALE is a tristate signal and is floated during the Hold state. In the 8085A, however, ALE is kept low during Hold.

Both the 8080A and the 8085A initiate the Hold state at the conclusion of an instruction's execution. But there are significant differences between Hold state initiation logic for the 8085A as against the 8080A.

The 8080A initiates a Hold state following T3 for a Read machine cycle, or following T4 for a Write machine cycle. Timing is illustrated in Figures 4-9 and 4-10.

**HOLD STATE  
IN 8085 AND  
8085A**

The 8085A in contrast, has a fixed, two machine cycle sequence for Hold state initiation; it may be illustrated as follows:



During every machine cycle, Hold is sampled during T<sub>2</sub>; if Hold is high at this time, Hold acknowledge is output high during T<sub>3</sub> and the Hold state begins during T<sub>4</sub>. Timing is illustrated in Figure 5-13.

During a six clock period machine cycle, if Hold is low when sampled during T<sub>2</sub>, then Hold will be sampled again during T<sub>4</sub>. If Hold is sampled high during T<sub>4</sub>, then a Hold state will be initiated during T<sub>6H</sub>. This may be illustrated as follows:



**Hold is sampled during every clock period of a Halt state.** As soon as Hold is detected high, a two clock period Hold state initiation sequence begins. Figures 5-14 and 5-15 illustrate the onset of Hold states within and before Halt states.

A Hold state terminates two clock periods after the Hold signal goes low.

There are no restrictions placed by 8085A logic on the duration of a Hold state. The Hold state lasts for as long as the HOLD input is high. Here is an example of a one clock period Hold state occurring during T<sub>4</sub> and a three clock period Hold state beginning during T<sub>6</sub> of a six clock period machine cycle:



Figure 5-13 illustrates a Hold state lasting three clock periods, beginning during T4 of a four clock period machine cycle.

## THE HALT STATE AND INSTRUCTION

When a Halt instruction is executed, the 8085A enters a Halt state. The Halt state consists of an indeterminate number of Halt Bus Idle clock periods, during which the S1 and S0 status signals are both output low while the tristate signals are floated.

In the 8085, an earlier version of the 8085A, ALE is a tristate signal and is floated during the Halt state. In the 8085A, however, ALE is kept low during Halt.

Halt state timing is illustrated in Figure 5-14.

HALT STATE  
IN 8085 AND  
8085A



Figure 5-14. A Halt Instruction and a Halt State Terminated by an Interrupt Request

A Halt state may be terminated by a system reset or by an interrupt request. Figure 5-14 shows an interrupt request terminating the Halt state.

Note that the INTR signal, like the HOLD signal, is sampled two clock periods before anything can happen. Thus, as illustrated in Figure 5-14, an additional Halt clock period will occur after the clock period within which INTR goes high.



Figure 5-15. Hold States Occurring Within a Halt State

An interrupt request will only be executed if interrupts are enabled; however, the 8085A has a TRAP non-maskable interrupt. Thus you can always exit an 8085A Halt state via a TRAP interrupt request or by resetting the system.

**While in a Halt state you can enter and exit the Hold state. Figure 5-15 illustrates timing for the Hold state existing within the Halt state.** Notice that the Hold state only lasts for as long as the HOLD input is kept high.

**8085A HOLD  
WITHIN A  
HALT STATE**

Entering a Hold state within a Halt state also prevents you from terminating the 8085A Halt state with an interrupt request; this is because a HOLD request has priority over any interrupt request. Thus, if an interrupt request occurs while the 8085A is entering a Hold state, or is in a Hold state, the interrupt request will be ignored until the end of the Hold state. At that time, the interrupt request will be acknowledged — providing interrupts are enabled.

**Resetting the 8085A will terminate a Halt state at any time, whether or not you are in a Hold state.**



Figure 5-16. An Interrupt Being Acknowledged Using a Single Byte Instruction

## EXTERNAL INTERRUPTS

There are some differences between the interrupt acknowledge logic of the 8085A as compared with the 8080A; however, the 8080A interrupt acknowledge logic is a subset of 8085A capabilities.

Providing a valid interrupt request has been applied and interrupts are enabled, the 8085A acknowledges the interrupt request on terminating execution of the current instruction. The 8085A then executes an interrupt acknowledge machine cycle.

An interrupt acknowledge machine cycle is very similar to a six clock period instruction fetch machine cycle; however, during the interrupt acknowledge machine cycle the 8085A, like the 8080A, anticipates receiving an instruction object code from an I/O device — presumably the device whose interrupt request is being acknowledged. Since an I/O device is supposed to provide the object code during an interrupt acknowledge instruction fetch, INTA is pulsed low instead of RD. Timing is illustrated in Figure 5-16.

Figure 5-16 shows two differences between the 8085A and the earlier 8080. the 8085A samples INTR during the next-to-last clock period of each instruction's execution, but the 8085 samples INTR one clock period later. The level of IO/M during Interrupt Acknowledge is also different: the 8085A holds IO/M low at this time.

**INTERRUPT DIFFERENCES IN 8085 AND 8085A**

Note that even though memory is not being accessed, Program Counter contents are output on the Address Bus during an interrupt acknowledge instruction fetch; providing memory select logic uses  $\overline{IO/M}$  and  $\overline{RD}$ , no harm will be done by having a valid address on the Address Bus during an interrupt acknowledge instruction fetch.

The Program Counter contents are not incremented during the interrupt acknowledge process.

**The 8085A signal INTA serves as a read strobe during interrupt acknowledge. The 8085A first acknowledges an interrupt with the state of S1, S0, and  $\overline{IO/M}$ : in the 8085A these three status signals are all high during an interrupt acknowledge machine cycle.** Recall that S1 and S0 both high signifies an instruction fetch, which is always a memory operation. Therefore, an "instruction fetch" which access I/O instead of memory is an interrupt acknowledge.

**8085A  
INTERRUPT  
ACKNOWLEDGE**

**In the 8085, an earlier version of the 8085A, interrupt acknowledge has the same S1, S0, and  $\overline{IO/M}$  levels as an instruction fetch. This means the interrupt acknowledge signal INTA serves both as an interrupt acknowledge and a read strobe.** External logic must use INTA both as a device select signal and a strobe signal identifying the time interval during which the interrupt acknowledge instruction code must be placed on the Data Bus. This can cause a timing problem. For any other instruction fetch, the trailing edge of ALE can be used to initiate device select timing: thus during any other instruction fetch you have from the middle of T1 until the middle of T2 to resolve the device select and wait for the read strobe. But you cannot use ALE in this fashion following an interrupt acknowledge, since external logic does not know that the interrupt has been acknowledged until INTA goes low. On the trailing edge of ALE during an interrupt acknowledge instruction fetch machine cycle, the Program Counter contents are being output on the Address Bus even though this address is irrelevant. You must therefore use INTA as a signal which disables all I/O device select logic with the exception of the device whose interrupt request is being acknowledged.

**8085  
INTERRUPT  
ACKNOWLEDGE**

**If your system contains an 8085, rather than an 8085A, you may well have to insert Wait states during an interrupt acknowledge instruction fetch machine cycle;** the acknowledged external logic has the duration of the low INTA pulse within which it must resolve its select logic and place an instruction object code on the Data Bus.

**WAIT STATES  
DURING 8085  
INTERRUPT  
ACKNOWLEDGE**

Earlier in this chapter we showed you how you can create a one clock period low READY pulse using two 7474 D-type flip-flops. The circuit shown would generate the low READY pulse during a memory read or instruction fetch. The same circuit will also cause a Wait state during an 8085 interrupt acknowledge, which is identical to an instruction fetch as far as our small circuit is concerned.

**You can respond to an interrupt acknowledge by transmitting any instruction object code to the 8085A. Usually a Restart (RST) or a Call instruction object code will be transmitted.**

Figure 5-16 illustrates timing for a Restart instruction being transmitted following an interrupt acknowledge. The Restart instruction has been described in detail in Chapter 4 together with circuits which allow a Restart instruction to be created.

**The 8085A contains internal logic to cope with multibyte instruction object codes transmitted during the interrupt acknowledge process.** During the second and third instruction fetch machine cycles, INTA is pulsed low while  $\overline{IO/M}$  is output high. Thus responding to an interrupt acknowledge with a Call instruction simply involves creating a Call instruction's object code.

**8085A  
MULTIBYTE  
ACKNOWLEDGE**

**The earlier 8085 also handles multibyte instruction object codes during interrupt acknowledge.** The second and third acknowledge machine cycles are similar to memory read cycles, the only difference being that INTA pulses instead of RD.

**8085  
MULTIBYTE  
ACKNOWLEDGE**

**The 8085A has four interrupt request pins which the 8080A does not have. These are TRAP, RST 5.5, RST 6.5 and RST 7.5. Interrupts requested via these pins cause the 8085A to generate its own internal interrupt acknowledge instruction.**

The internal interrupt acknowledge instruction results in subroutine calls to the following addresses:

| Interrupt | CALL Address |
|-----------|--------------|
| TRAP      | 2416         |
| RST 5.5   | 2C16         |
| RST 6.5   | 3416         |
| RST7.5    | 3C16         |

**TRAP is a non-maskable interrupt.**

**RST 5.5 and RST6.5 are level sensitive;** that means a high level input at these pins generates an interrupt request.

**RST 7.5 is edge sensitive:** an interrupt request occurs when the input to RST 7.5 makes a low-to-high transition.

**TRAP is both level and edge sensitive:** the low-to-high transition and the subsequent high level generate an interrupt request.

If an interrupt request is generated at RST 7.5 by a low-to-high transition, the 8085A will remember the interrupt request, whether or not the RST 7.5 input remains high. **You can thus generate an interrupt request via RST 7.5 using a high pulse.**

Since you can request an interrupt via an RST 7.5 low-to-high transition, the RST 7.5 interrupt request signal itself cannot reset the interrupt request. This may be illustrated as follows:



You need not terminate service of an RST 7.5 interrupt request by executing an SIM instruction with bit 4 of the Accumulator set to 1; the CPU does this automatically when it recognizes the interrupt.

A low-to-high transition of the TRAP input creates an interrupt request. The interrupt request will only be acknowledged while the TRAP input remains high; however, once a TRAP interrupt request has been acknowledged, TRAP must go low and then high again before another interrupt request will be acknowledged.



Figure 5-17. A Bus Idle Instruction Fetch Machine Cycle

8085A interrupt priorities are as follows:

|         |         |
|---------|---------|
| Highest | HOLD    |
|         | TRAP    |
|         | RST 7.5 |
|         | RST6.5  |
|         | RST 5.5 |
| Lowest  | INTR    |

The 8085A executes an instruction fetch Bus Idle machine cycle after acknowledging a TRAP, RST 5.5, RST 6.5 or RST 7.5 interrupt request. Timing is given in Figure 5-17.

The TRAP interrupt request cannot be disabled. In the 8085A, but not in the 8085, the TRAP interrupt preserves the state of the interrupt enable flag. This allows the user to restore the interrupt enable status after a TRAP interrupt.

**8085A TRAP INTERRUPT**

The RST 5.5, RST6.5, and RST 7.5 interrupt requests can be individually enabled and disabled using the SIM instruction. All interrupts except the TRAP can be enabled and disabled via the EL and DI instructions.

You may at any time examine interrupt enable/disable status by executing the RIM instruction.

In the 8085A, but not the earlier 8085, the first RIM instruction executed after a TRAP interrupt will show what the interrupt status was just before the TRAP, no matter how many IEs and DIs have been executed since the TRAP acknowledge. You must perform RIM after every TRAP to ensure that subsequent RIMs will provide accurate interrupt enable status.

**8085A RIM AFTER TRAP**

The RIM and SIM instructions are described in detail later in this chapter.

You will service interrupts in an 8085A system exactly as described for the 8080A system. For a discussion of an interrupt acknowledge see Chapter 4.

Remember that a Hold request has priority over an interrupt request. Thus, an interrupt will not be acknowledged while a Hold state exists and the 8085A will respond to a Hold request following an interrupt acknowledge.



\*8085 floats ALE during Reset; 8085A does not do this.

Figure 5-18. Power On and RESET IN Timing for the 8085A

## THE RESET OPERATION

You reset an 8085A by inputting a low signal via **RESET IN**.

When power is first turned on, the **RESET IN** pulse must last at least 500 nanoseconds (3 full clock cycles); no further requirements are imposed on the **RESET IN** signal. Logic internal to the 8085A will synchronize the **RESET IN** pulse with the internal clock. Timing for a Reset following a powerup is given in Figure 5-18.

Notice that a **RESET OUT** signal is provided. You can use this signal to reset other devices in the 8085A microcomputer system.

**When the 8085A is reset the following events occur:**

- 1) The Program Counter is cleared; thus the first instruction executed following a reset must have its object code stored in memory location 0.
- 2) The Instruction register is cleared.
- 3) Interrupts are disabled.
- 4) The RST 7.5, RST 6.5 and RST 5.5 interrupts are masked out and thus disabled.
- 5) All tristate bus lines are floated. In the earlier 8085, ALE is tristate and thus floats during Reset. In the 8085A, ALE is not tristate.

Table 5-1. A Summary of 8085A Instruction Object Codes and Execution Cycles

| INSTRUCTION | OBJECT CODE | BYTES | CLOCK PERIODS |       | 8085A<br>MACHINE CYCLES |
|-------------|-------------|-------|---------------|-------|-------------------------|
|             |             |       | 8080A         | 8085A |                         |
| ACI DATA    | CE YY       | 2     | 7             | 7     | 1 3                     |
| ADC REG     | 10001XXX    | 1     | 4             | 4     | 1                       |
| ADC M       | 8E          | 1     | 7             | 7     | 1 3                     |
| ADD REG     | 10000XXX    | 1     | 4             | 4     | 1                       |
| ADD M       | 86          | 1     | 7             | 7     | 1 3                     |
| ADI DATA    | C6 YY       | 2     | 7             | 7     | 1 3                     |
| ANA REG     | 10100XXX    | 1     | 4             | 4     | 1                       |
| ANA M       | A6          | 1     | 7             | 7     | 1 3                     |
| ANI DATA    | E6 YY       | 2     | 7             | 7     | 1 3                     |
| CALL LABEL  | CD ppqq     | 3     | 17            | 18    | 2,3,3,5,5               |
| CC LABEL    | DC ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CM LABEL    | FC ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CMA         | 2F          | 1     | 4             | 4     | 1                       |
| CMC         | 3F          | 1     | 4             | 4     | 1                       |
| CMP REG     | 10111XXX    | 1     | 4             | 4     | 1                       |
| CMP M       | BE          | 1     | 7             | 7     | 1 3                     |
| CNC LABEL   | D4 ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CNZ LABEL   | C4 ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CP LABEL    | F4 ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CPE LABEL   | EC ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CPI DATA    | FE YY       | 2     | 7             | 7     | 1 3                     |
| CPO LABEL   | E4 ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| CZ LABEL    | CC ppqq     | 3     | 11/17         | 9/18  | 2,3,2,3,3,5,5           |
| DAA         | 27          | 1     | 4             | 4     | 1                       |
| DAD RP      | 00XX1001    | 1     | 10            | 10    | 1,7,7                   |
| DCR REG     | 00XX101     | 1     | 5             | 4     | 1                       |
| DCR M       | 35          | 1     | 10            | 10    | 1,3,5                   |
| DCX RP      | 00XX1011    | 1     | 5             | 6     | 2                       |
| DI          | F3          | 1     | 4             | 4     | 1                       |
| EI          | FB          | 1     | 4             | 4     | 1                       |
| HLT         | 76          | 1     | 4             | 4     | 1                       |
| IN PORT     | DB YY       | 2     | 10            | 10    | 1,3,4                   |
| INR REG     | 00XXX100    | 1     | 5             | 4     | 1                       |
| INR M       | 34          | 1     | 10            | 10    | 1,3,5                   |
| INX RP      | 00XX0011    | 1     | 5             | 6     | 2                       |
| JC LABEL    | DA ppqq     | 3     | 10            | 7/10  | 1,3,1,3,3               |
| JM LABEL    | FA ppqq     | 3     | 10            | 7/10  | 1,3,1,3,3               |
| JMP LABEL   | C3 ppqq     | 3     | 10            | 10    | 1,3,3                   |
| JNC LABEL   | D2 ppqq     | 3     | 10            | 7/10  | 1,3,1,3,3               |
| JNZ LABEL   | C2 ppqq     | 3     | 10            | 7/10  | 1,3,1,3,3               |
| JP LABEL    | F2 ppqq     | 3     | 10            | 7/10  | 1,3,1,3,3               |

Table 5-1. A Summary of 8085A Instruction Object Codes and Execution Cycles  
(Continued)

| INSTRUCTION   | OBJECT CODE | BYTES | CLOCK PERIODS |       | 8085A<br>MACHINE CYCLES |
|---------------|-------------|-------|---------------|-------|-------------------------|
|               |             |       | 8080A         | 8085A |                         |
| JPE LABEL     | EA ppqq     | 3     | 10            | 7/10  | 13,133                  |
| JPO LABEL     | E2 ppqq     | 3     | 10            | 7/10  | 13,133                  |
| JZ LABEL      | CA ppqq     | 3     | 10            | 7/10  | 13,133                  |
| LDA ADDR      | 3A ppqq     | 3     | 13            | 13    | 1333                    |
| LDAX RP       | 000X1010    | 1     | 7             | 7     | 13                      |
| LHLD ADDR     | 2A ppqq     | 3     | 16            | 16    | 13333                   |
| LXI RP,DATA16 | 00XX0001    | 3     | 10            | 10    | 133                     |
|               | YYYY        |       |               |       |                         |
| MOV REG,REG   | 01dddsss    | 1     | 5             | 4     | 1                       |
| MOV M,REG     | 01110ss     | 1     | 7             | 7     | 15                      |
| MOV REG,M     | 01ddd110    | 1     | 7             | 7     | 13                      |
| MVI REG,DATA  | 00ddd110    | 2     | 7             | 7     | 13                      |
|               | YY          |       |               |       |                         |
| MVI M,DATA    | 36 YY       | 2     | 10            | 10    | 135                     |
| NOP           | 00          | 1     | 4             | 4     | 1                       |
| ORA REG       | 10110XXX    | 1     | 5             | 4     | 1                       |
| ORA M         | B6          | 1     | 7             | 7     | 13                      |
| ORI DATA      | F6 YY       | 2     | 7             | 7     | 13                      |
| OUT PORT      | D3 YY       | 2     | 10            | 10    | 136                     |
| PCHL          | E9          | 1     | 5             | 6     | 2                       |
| POP RP        | 11XX0001    | 1     | 10            | 10    | 133                     |
| PUSH RP       | 11XX0101    | 1     | 11            | 12    | 255                     |
| RAL           | 17          | 1     | 4             | 4     | 1                       |
| RAR           | 1F          | 1     | 4             | 4     | 1                       |
| RC            | D8          | 1     | 5/11          | 6/12  | 2,233                   |
| RET           | C9          | 1     | 10            | 10    | 133                     |
| RIM           | 20          | 1     |               | 4     | 1                       |
| RLC           | 07          | 1     | 4             | 4     | 1                       |
| RM            | F8          | 1     | 5/11          | 6/12  | 2,233                   |
| RNC           | D0          | 1     | 5/11          | 6/12  | 2,233                   |
| RNZ           | C0          | 1     | 5/11          | 6/12  | 2,233                   |
| RP            | F0          | 1     | 5/11          | 6/12  | 2,233                   |
| RPE           | E8          | 1     | 5/11          | 6/12  | 2,233                   |
| RPO           | E0          | 1     | 5/11          | 6/12  | 2,233                   |
| RCC           | 0F          | 1     | 4             | 4     | 1                       |
| RST N         | 11XXX111    | 1     | 11            | 12    | 233                     |
| RZ            | C8          | 1     | 5/11          | 6/12  | 2,233                   |
| SBB REG       | 10011XXX    | 1     | 4             | 4     | 1                       |
| SBB M         | 9E          | 1     | 7             | 7     | 13                      |
| SBI DATA      | DE YY       | 2     | 7             | 7     | 13                      |
| SHLD ADDR     | 22 ppqq     | 3     | 16            | 16    | 13355                   |
| SIM           | 30          | 1     |               | 4     | 1                       |
| SPHL          | F9          | 1     | 5             | 6     | 2                       |
| STA ADDR      | 32 ppqq     | 3     | 13            | 13    | 1335                    |
| STAX RP       | 000X0010    | 1     | 7             | 7     | 15                      |
| STC           | 37          | 1     | 4             | 4     | 1                       |
| SUB REG       | 10010XXX    | 1     | 4             | 4     | 1                       |
| SUB M         | 96          | 1     | 7             | 7     | 13                      |
| SUI DATA      | D6 YY       | 2     | 7             | 7     | 13                      |
| XCHG          | EB          | 1     | 4             | 4     | 1                       |
| XRA REG       | 10101XXX    | 1     | 4             | 4     | 1                       |
| XRA M         | AE          | 1     | 7             | 7     | 13                      |
| XRI DATA      | EE YY       | 2     | 7             | 7     | 13                      |
| XTHL          | E3          | 1     | 18            | 16    | 13355                   |

ppqq represents four hexadecimal digit memory address

YY represents two hexadecimal data digits

YYYY represents four hexadecimal data digits

X represents an optional binary digit

ddd represents optional binary digits identifying a destination register

sss represents optional binary digits identifying a source register

## Machine cycle types:

1 - Four clock period instruction fetch (Figure 5-4)

2 - Six clock period instruction fetch (Figure 5-5)

3 - Memory read (Figure 5-6)

4 - I/O read (Figure 5-7)

5 - Memory write (Figure 5-8)

6 - I/O write (Figure 5-9)

7 - Bus idle (Figure 5-10)

## THE 8085A INSTRUCTION SET

**There are just three differences between the 8085A and the 8080A instruction sets:**

- 1) The 8085A has two additional instructions — RIM and SIM.
- 2) The number of clock periods required to execute instructions differs in some cases; Table 5-1 summarizes these differences.
- 3) Following a Halt instruction's execution, the 8085A floats tristate bus lines in the ensuing Halt state; the 8080A does not.

**Because the 8085A and 8080A instruction sets are so similar, the same benchmark program applies to both microprocessors.** Refer to Chapter 4 for a discussion of this benchmark program.

**Refer to Table 4-4 for a summary of the 8085A instruction set. The only two 8085A instructions not present in Table 4-4 are the RIM and SIM instructions.**

When the RIM instruction is executed, the following data is loaded into the Accumulator:



Thus, the RIM instruction allows you to examine interrupt and external status.

When the SIM instruction is executed the contents of the Accumulator are interpreted as follows:



Thus the SIM instruction is used to selectively mask interrupts and to output a control signal via the SOD pin.

Note that if bit 6 of the Accumulator is 0 when the SIM instruction is executed, then the contents of bit 7 will not be transferred to the SOD pin.

From our discussion of the 8085A reset, recall that following a reset RST 5.5, RST 6.5 and RST 7.5 are all disabled; also, reset sets the SOD output to 0. Thus, following a reset an RIM instruction would input the following data to the Accumulator:



## 8085A MICROPROCESSOR SUPPORT DEVICES

The 8085 has four special purpose multifunction support devices; they are described in this chapter.

The 8085A can use any -5 version of the 8080A support devices described in Chapter 4 and Volume III. If you use the low-order eight 8085A address lines, you must demultiplex the 8085A Address and Data Busses to use 8080A support devices.

### THE 8155/8156 STATIC READ/WRITE MEMORY WITH I/O PORTS AND TIMER

The 8155 and 8156 are custom circuits designed specifically for the 8085A microprocessor. Each device provides 256 bytes of static read/write memory, two or three parallel I/O ports, and a programmable timer. The 8155 and 8156 devices differ only in the active level of the chip enable signal.

Figure 5-19 illustrates that part of general microcomputer system logic which has been implemented on the 8155 /8156 devices.

Figure 5-20 provides a functional diagram of 8155/8156 logic.

The 8155 or 8156 device is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL compatible.

#### 8155/8156 DEVICE PINS AND SIGNALS

8155/8156 pins and signals are illustrated in Figure 5-21. Signals may be divided into the following categories:

- 1) CPU interface and control
- 2) Parallel I/O
- 3) Programmable Timer

We will first consider CPU interface and control signals.

**AD0 - AD7** connect to a bidirectional, multiplexed Data and Address Bus. As illustrated in Figure 5-22, these pins connect to the AD0 - AD7 bus lines output by the 8085A microprocessor.

**ALE** is the Address Latch Enable control signal output by the 8085A microprocessor to identify addresses on the multiplexed Data and Address Bus.

The 8155 or 8156 has both a memory space and an I/O address space. When **IO/M** is high, I/O port addresses are decoded off AD0 - AD7 on the high-to-low transition of ALE; this may be illustrated as follows:





Figure 5-19. Logic of the 8155 and 8156 Multifunction Devices

**When IO/M is low, the address strobed off AD0 - AD7 is interpreted as a memory address.**

**CE is active high in the 8156 device; it is active low in the 8155. There is no other difference between the 8155 and 8156 devices.**

**The 8155 or 8156 device uses standard 8085A control signals on its CPU interface. These signals are RD, WR, ALE and IO/M. Refer to the description of these control signals given in the 8085A section of this chapter.**



Figure 5-20. Logic Functions of the 8155/8156 Device



| PIN NAME                        | DESCRIPTION                          | TYPE          |
|---------------------------------|--------------------------------------|---------------|
| AD0 - AD7                       | Multiplexed Address and Data Bus     | Bidirectional |
| PA0 - PA7                       | Eight I/O pins, designated as Port A | Bidirectional |
| PB0 - PB7                       | Eight I/O pins, designated as Port B | Bidirectional |
| PC0 - PC5                       | Six I/O pins, designated as Port C   | Bidirectional |
| <u>RD</u>                       | Read from device control             | Input         |
| <u>WR</u>                       | Write to device control              | Input         |
| IO/M                            | I/O ports or memory select           | Input         |
| ALE                             | Address latch enable                 | Input         |
| RESET                           | System reset                         | Input         |
| CE/CE'                          | Chip enable                          | Input         |
| TIMER IN                        | Timer clock                          | Input         |
| TIMER OUT                       | Timer output signal                  | Output        |
| V <sub>SS</sub> V <sub>CC</sub> | Ground, Power                        |               |

Figure 5-21. 8155/8156 Multifunction Device Signals and Pin Assignments



Figure 5-22. An 8155 Device Connected to an 8085A CPU Bus

Table 5-2. 8155/8156 Device Port C Pin Options

| Pin | ALT 1      | ALT 2       | ALT 3                     | ALT 4                     |
|-----|------------|-------------|---------------------------|---------------------------|
| PC0 | Input Port | Output Port | A INTR (Port A Interrupt) | A INTR (Port A Interrupt) |
| PC1 | Input Port | Output Port | A BF (Port A Buffer Full) | A BF (Port A Buffer Full) |
| PC2 | Input Port | Output Port | A STB (Port A Strobe)     | A STB (Port A Strobe)     |
| PC3 | Input Port | Output Port | Output Port               | B INTR (Port B Interrupt) |
| PC4 | Input Port | Output Port | Output Port               | B BF (Port B Buffer Full) |
| PC5 | Input Port | Output Port | Output Port               | B STB (Port B Strobe)     |

The 8155/8156 device is reset by a high input at the RESET pin. **The Reset operation does not clear memory or I/O locations within the 8155/8156 device.** Thus all memory locations contain zero, I/O ports are assigned to input mode and the Counter/Timer is stopped with an initial zero value.

**8155  
DEVICE  
RESET**

## 8155/8156 PARALLEL INPUT/OUTPUT

The interface presented by the 8155/8156 device to external logic consists of three I/O ports and two signals associated with Counter/Timer logic.

We will examine the I/O port logic and then the Counter/Timer logic.

I/O Ports A and B are 8-bit parallel ports; each may be defined as an input port or an output port.

I/O Port C is a 6-bit parallel I/O port; it may be used to input or output parallel data, or Port C pins may support handshaking control signals for Ports A and B. Table 5-2 defines the four ways in which I/O Port C may be used.

When I/O Ports A and B are used for simple parallel input or output, then their operation is identical to Mode 0 as described in Chapter 4 for the 8255 PPI. Handshaking mode is identical to 8255 Mode 1. We will therefore discuss 8155 input and output with handshaking briefly. For a more detailed discussion refer to the 8255 PPI description given in Volume III.

|                                 |
|---------------------------------|
| <b>8155/8156 I/O<br/>MODE 0</b> |
| <b>8155/8156 I/O<br/>MODE 1</b> |

**Input with handshaking may be illustrated as follows:**



An event sequence begins with external logic inputting parallel data to I/O Port A or B: **external logic must pulse STROBE low**, at which time the parallel data is loaded into the I/O port buffer. This causes BF, the Buffer Full signal, to go high.

**External logic uses the BF signal as an indicator that no more data can be written.**

As soon as the externally provided low **STROBE** pulse is over, the interrupt request signal **INTR** goes high. This allows the 8085A to be interrupted once data has been loaded into the input buffer of the I/O port.

**BF** and **INTR** remain high until the CPU reads the contents of the I/O port. The read operation will be identified by a low **RD** pulse input to the 8155/8156 device. **INTR** is reset at the beginning of the **RD** pulse, while **BF** is reset at the end of the **RD** pulse. **BF** therefore is high while data is waiting to be read and while data is being loaded into the I/O port buffer or read out of the I/O port buffer. **INTR** is high only while data is waiting to be read.

**BF** and **INTR** have associated bits in the Status register of the 8155/8156 device.

**You connect INTR to an 8085A interrupt request if you want an interrupt-driven system. You write a program which polls the Status register of the 8155/8156 if you want to operate the system under program control.**

**Strobed output timing may be illustrated as follows:**



In output mode the I/O port buffer is initially empty, which means that the CPU must transmit data to the I/O port. Therefore **INTR** is initially high.

As soon as the CPU writes data to the I/O port, the interrupt request signal **INTR** is reset low; this occurs on the leading edge of the **WR** pulse. On the trailing edge of the **WR** pulse **BF** is output high, telling external logic that data is in the I/O port buffer and may be read.

**External logic strobes the data out by providing a low pulse at STROBE.** The leading edge of **STROBE** resets **BF** low, while the trailing edge of **STROBE** sets **INTR** high, causing the CPU to again output parallel data.

**You connect INTR to an appropriate 8085A interrupt request pin if you want an interrupt-driven system. You write a program to poll the Status register if you want to operate the 8155/8156 under program control.**

A simple method of using the 8155/8156 device parallel input/output with handshaking in interrupt mode would be to connect **INTRA** and **INTRB** to **RST 5.5** and **RST 6.5**.

## 8155/8156 DEVICE ADDRESSING

Having discussed 8155/8156 device memory and I/O ports, we must now look at device addressing.

The 8155/8156 has 256 bytes of static read/write memory which are addressed by **AD0 - AD7** while Chip Enable is true, and **IO/M = 0**.

**8155/8156  
I/O PORT  
ADDRESSES**

The 8155/8156 has eight addressable I/O ports. AD0, AD1 and AD2 select I/O ports while Chip Enable is true and IO/M = 1. **These are the eight addressable I/O ports:**

AD2 AD1 AD0 PORT

|   |   |   |                                         |
|---|---|---|-----------------------------------------|
| 0 | 0 | 0 | Status/Command registers                |
| 0 | 0 | 1 | Port A                                  |
| 0 | 1 | 0 | Port B                                  |
| 0 | 1 | 1 | Port C                                  |
| 1 | 0 | 0 | Counter/Timer register, low-order byte  |
| 1 | 0 | 1 | Counter/Timer register, high-order byte |
| 1 | 1 | 0 | Unused                                  |
| 1 | 1 | 1 | Unused                                  |

Chip Enable is derived from A8 - A15, which holds the high-order byte of a memory address, or the I/O device number. **Chip Enable thus defines the exact address and I/O space for the 8155/8156 device.** Here is one possible configuration:



8155/8156 memory bytes will be selected by any memory addresses in the range  $6n00_{16}$  through  $6nFF_{16}$ . "n" represents any digit in the range 0 through 7. Let us assume that programs access 8155/8156 memory bytes via addresses in the range  $6000_{16}$  through  $60FF_{16}$ ; we must further assume that addresses created by values of n in the range 1 through 7 never occur.

Now **the same chip select that you use to define your memory address space is also going to define your I/O address space.** Recall that the 8-bit I/O device number is output twice following execution of an I/O instruction — once on the high-order eight address lines A8 - A15 and again on the low-order Address/Data Bus lines AD0 - AD7. Thus the device select code which you generate from the eight high-order address lines for a memory address is the same device select code which you generate for the 8155/8156 I/O space.

But whereas the 8155/8156 has 256 addressable memory locations, it has eight addressable I/O ports; I/O ports are selected as follows:



If Chip Enable is true when A15 - A11 is 01100<sub>2</sub>, then I/O port addresses will be 60<sub>16</sub> through 67<sub>16</sub>.

Address lines A15 - A11 represent I/O device number bits 7 through 3. This is because the I/O device number is output on A15 - A8 following execution of an I/O instruction. It is therefore fortunate that we only used address lines A15 - A11 to create Chip Enable. Had we used A8, A9 or A10, the low-order three I/O device code bits would have served a double purpose — with strange results.

Suppose A10 = 0 is a prerequisite for device select logic to be true; these are the memory and I/O port selects which will result:



You can now address only four of the eight 8155/8156 I/O Ports. You cannot include address lines A8, A9 or A10 in the device select logic that you use for any 8155/8156 device; if you do, you will limit the I/O capabilities of the device.

$\text{IO/M}$  discriminates between execution of I/O instructions and memory reference instructions.

## THE 8155/8156 COUNTER/TIMER

Counter/Timer logic consists of a 16-bit register, addressed as two 8-bit I/O ports, an input clock signal and an output timer signal. This may be illustrated as follows:



**The low-order 14 bits of the Counter/Timer register must be initialized with a 14-bit binary value that will decrement on low-to-high transitions of TIMER IN.** If TIMER IN is connected to the 8085A clock output signal CLK, then the timer is computing real time. TIMER IN can alternatively be connected to any external logic in which case the timer is counting external events.

**The timer times out when it decrements to zero.**

**The two high-order bits of the Counter/Timer register define one of four ways in which the TIMER OUT signal may be created.**

In **Mode 0**, TIMER OUT is high for the first half of the time interval and low for the second half of the time interval. This may be illustrated as follows:

8155/8156  
TIMER  
MODE 0



If N is odd, the extra pulse will occur while TIMER OUT is high.

In **Mode 1**, as in Mode 0, TIMER OUT is high for the first half of the count and low for the second half. However, the timer is automatically reloaded with the initial value following each time out, creating a square wave which may be illustrated as follows:



**Mode 2** outputs a single low clock pulse on the terminal count, then stops the timer. Timing may be illustrated as follows:



**Mode 3** is identical to Mode 2, except that when the timer times out the initial counter value is automatically reloaded.

## 8155/8156 CONTROL AND STATUS REGISTERS

The Control and Status registers of the 8155/8156 are used to control both timer and parallel I/O logic. Let us now examine these registers.

The Control and Status registers of the 8155/8156 device are accessed via a single I/O port address. This is the lowest of the 8155/8156 I/O port addresses. When you write to this address you access the Control register; when you read from this address you access the Status register.

8155/8156 internal logic will interpret Control register bits as follows:



Status register bits are set and reset as follows:



## 8155/8156 DEVICE PROGRAMMING

**Accessing 8155/8156 read/write memory is self-evident.** If you execute a memory reference instruction that specifies an address within the 8155/8156 address space, you will access an 8155/8156 memory byte.

**Parallel I/O programming is also self-evident;** you begin by outputting an appropriate code to the Control register in order to define the modes in which various ports will operate, and to enable or disable Mode 1 interrupts. Your only caution at this time must be to ensure that the two high-order bits of the Control code are 0; this prevents initiation of any timer operations.

**If you are using I/O ports without handshaking, the Status register is not affected by I/O operations.** No control signals or status indicate that new data has been input to, or has been read from I/O ports.

If you are operating the 8155/8156 in handshaking mode under program control, then you must poll the Status register in order to determine whether data is waiting to be read or must be written. Your program will consist of a series of input instructions which read status, followed by conditional branches that read or write data.

If you are operating the 8155/8156 parallel I/O in handshaking mode under interrupt control, then whenever data is waiting to be read or must be written, the high INTR control signal will vector program execution to an appropriate interrupt service routine.

**You can at any time read the contents of an I/O port that has been declared an output port.** You will simply read back whatever data was most recently written out to that I/O port. Reading the contents of an output port will have no effect on handshaking control signals associated with that port.

#### Let us now examine programming associated with 8155/8156 Counter/Timer logic.

You must first initialize the 16-bit Counter/Timer register by outputting two bytes that specify timer mode and initial count. The order in which you output these two bytes is unimportant.

Next you output an appropriate Control code in order to start the timer. When you output a Control code, remember not to modify any control bits that define parallel I/O operations.

Here is an appropriate initialization instruction sequence:

```
MVI    A.80H    LOAD 6080H AS AN INITIAL COUNTER  
OUT    0C4H    VALUE. SELECT COUNTER MODE 1  
MVI    A.60H  
OUT    0C5H  
MVI    A.0FAH    START TIMER  
OUT    0COH
```

This instruction sequence assumes that the 8155/8156 I/O port addresses are C016 through C516. The code FA<sub>16</sub> output to the Control register starts the timer, and defines Port A as an input port, Port B as an output port, both in handshaking mode with interrupts enabled.

You can at any time stop the counter, either immediately or following the next time-out. The following instructions will stop the counter immediately:

```
MVI    A.7AH    STOP THE TIMER IMMEDIATELY  
OUT    COH
```

The following instructions will stop the counter after the next time-out:

```
MVI    A.BAH    STOP THE TIMER AFTER THE  
OUT    COH    NEXT TIME OUT
```

**The Counter/Timer instruction sequences illustrated above contain a nonobvious propensity for programming errors.** We start the timer by outputting the code FA<sub>16</sub> to the Control register; we stop immediately by outputting the code 7A<sub>16</sub> and we stop the timer after the next time-out by outputting the code BA<sub>16</sub>. In reality, this is the code we are outputting:



Whenever you output Control codes to modify 8155/8156 timer operation, you must always remember to output bits 0 through 5 correctly, in order to maintain previously defined parallel I/O options. **A commonly used programming technique that frees you from having to remember the condition of irrelevant bits in a control word is to use AND and OR masks.** Consider this general purpose instruction sequence:

```
IN     COH    INPUT PRESENT CONTROL CODE  
ANI    3FH    CLEAR TIMER BITS  
(ORI   COH    SET TIMER BITS)  
OUT    COH    RESTORE CONTROL CODE
```

This technique will not work with the 8155/8156 device, since you cannot read the contents of the Control register. If you read from the address of the Control register, you will access the Status register. If you want to use a masking technique, you must maintain the Control code in memory. Here is an instruction sequence that will work:

|      |        |                                  |
|------|--------|----------------------------------|
| LDA  | CONTRL | LOAD CONTROL CODE FROM MEMORY    |
| ANI  | 3FH    | CLEAR TIMER BITS                 |
| (ORI | C0H    | SET TIMER BITS)                  |
| OUT  | C0H    | OUTPUT CONTROL CODE TO 8155/8156 |
| STA  | CONTRL | SAVE CONTROL CODE IN MEMORY.     |

Your instruction sequence will include the ANI mask to clear timer bits, or the ORI mask to set timer bits, but obviously not both.

CONTRL is the label for some read/write memory byte which always holds the current 8155/8156 Control code.

## THE 8355 READ ONLY MEMORY WITH I/O

The 8355 provides 2048 bytes of read-only memory and two 8-bit I/O ports. The device has been designed to interface with the 8085A CPU.

Figure 5-23 illustrates that part of our general microcomputer system logic which has been implemented on the 8355 device.

The 8355 is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL-compatible. The device is implemented using N-channel MOS technology.

Figure 5-24 functionally illustrates logic of the 8355 device. A simple 8085A-8155/8156-8355 configuration is illustrated in Figure 5-26.

There are many similarities between the 8155/8156, which we have already described, and the 8355. Where appropriate we will refer back to the 8155/8156 discussion for clarification of concepts.

## 8355 DEVICE PINS AND SIGNALS

8355 pins and signals are illustrated in Figure 5-25.

The 8355-8085A interface differs somewhat from the 8155/8156-8085A interface in that the 8355 has more memory, fewer addressable I/O ports, plus the ability to address I/O ports within the memory space of the device.

Having 2048 bytes of addressable read-only memory, the 8355 requires eleven address pins. These are derived from AD0-AD7 and A8-A10.

Having only four addressable I/O ports, the 8355 I/O address logic decodes AD0 and AD1 only. I/O ports are selected as follows:

| AD1 | AD0 |                           |
|-----|-----|---------------------------|
| 0   | 0   | I/O PORT A                |
| 0   | 1   | I/O PORT B                |
| 1   | 0   | DATA DIRECTION REGISTER A |
| 1   | 1   | DATA DIRECTION REGISTER B |



Figure 5-23. Logic of the 8355 and 8755 Multifunction Devices



Figure 5-24. Logic Functions of the 8355 Device

**8355 device select logic must generate the chip enable signals  $\overline{CE}$  and  $CE$  from the five address lines A11-A15.** The discussion of select logic given for the 8155/8156 device applies also to the 8355.

**If you select 8355 memory and I/O ports in their respective address spaces, the control signals ALE,  $\overline{RD}$ , and  $\overline{IO/M}$  are used exactly as described for the 8155/8156 device.**

**But you can also access 8355 I/O ports within the 8355 memory space using control signals  $\overline{IOW}$  and  $\overline{IOR}$ .**

$\overline{IOW}$  and  $\overline{IOR}$  are control signals which override  $\overline{IO/M}$  and  $\overline{RD}$  when accessing I/O ports.

Providing  $CE$  and  $\overline{CE}$  are true, a low input on  $\overline{IOW}$  will cause data on the Data Bus to be written into the I/O port selected by AD0 and AD1, irrespective of the  $\overline{IO/M}$  level. Similarly,  $\overline{IOR}$  low will cause the contents of the I/O port selected by AD0 and AD1 to be output on the Data Bus.

You can connect  $\overline{IOW}$  directly to the  $\overline{WR}$  control signal, and thus write into the four I/O ports of the 8355 device as though they were the four low-order memory bytes. But connecting  $\overline{IOR}$  to  $\overline{RD}$  is not so straightforward. The 8355 device may receive a low input on  $\overline{IOR}$ , together with low inputs on  $\overline{RD}$  and  $\overline{IO/M}$ ; it will then attempt to read the contents of a read only memory byte and an I/O port at the same time. While elaborate schemes could be devised for generating separate selects that map the four I/O ports into a memory space of its own, **it is wisest to ignore the  $\overline{IOR}$  signal if you are using 8355 memory and I/O logic. Use  $\overline{IOR}$  only when the 8355 is configured as two I/O ports — and the 8355 memory is unused.  $\overline{IOR}$  and  $\overline{IOW}$  are used in 8048 microcomputer systems; that is the principal reason they were designed into the 8355 device.**



Figure 5-25. 8355 Multifunction Device Signals and Pin Assignments



Figure 5-26. An 8085A-8155/8156-8355 Microcomputer System

## 8355 READY LOGIC

The 8355 device has on-chip logic to create a READY signal that will insert one Wait state into the 8085A machine cycle that references the 8355 device. 8355 READY signal timing may be illustrated as follows:



The READY output is floated by the 8355 device while CE-CE is false.

READY is forced low by the combination of Chip Enable true while ALE is high; READY stays low until the first low-to-high transition of CLK following the end of the ALE pulse. If you refer back to Figure 5-11, you will see that this READY logic creates a single Wait state.

The problem with the READY logic illustrated above is that in order to have Chip Enable true while ALE is high, chip enable logic must be tied directly to Address Bus lines. Refer to the timing diagram below and you will see that A0-A15 is stable while ALE is high.

But as we discussed earlier in this chapter, you can derive chip enable logic directly from A8-A15 only in small 8085 microcomputer systems. When a large number of support devices are connected to the System Bus, you must guarantee against spurious device selects by including control signals in the chip enable logic. Logic illustrated earlier in this chapter shows how to create a chip select signal that is true between the trailing edge of ALE and the low-to-high transition of RD or WR. The following chip enable timing results:



Timing illustrated above is theoretically the best guarantee against spurious selects; but it will not work if you want to create a single Wait state when using an 8355 device. If Chip Enable (CE) goes true on the trailing edge of ALE, READY will never be reset low:



You can resolve this problem by simply inverting ALE as a clock input to the select logic flip-flop.

#### But when do you need to induce a Wait state?

8355 device timing is fast enough to respond to memory and I/O accesses without the inclusion of a Wait state, unless you have buffers on the System Bus and the buffers introduce unacceptably long response delays. Therefore, ignore the READY signal logic of the 8355 in small 8085A systems and derive chip enable logic directly from the high-order address lines A11-A15. In larger systems where buffers on the System Bus force the 8355 device to require a Wait state, use READY logic of the 8355 device.

#### 8355 I/O LOGIC

Let us now look at the I/O logic of the 8355 device. This device has two I/O ports whose pins can be individually assigned to input or output. This assignment is made by loading appropriate Control codes into a Data Direction register associated with each I/O port. A 1 in any bit position of the Data Direction register defines the associated I/O port pin as an output pin. A 0 in any bit position defines the associated I/O port pin as an input pin. This may be illustrated as follows:



Observe that the 8355 has no I/O with handshaking. For I/O with handshaking you should use the 8155/8156 or the 8255 devices.

## THE 8755A ERASABLE PROGRAMMABLE READ ONLY MEMORY WITH I/O

The 8755A device provides 2048 bytes of erasable programmable read-only memory and two 8-bit I/O ports. The only difference between this device and the 8355, which we have just described, is the fact that the 8755A read-only memory is programmable and erasable. There are minor pin and signal variations supporting the EPROM. These differences are identified in Figure 5-27.

The 8755A is a new version of an earlier device, the 8755. The only difference between the two is the level of  $V_{DD}$  during normal read operations: +5V on the current 8755A, but 0V on the earlier 8755.

 8755 AND  
8755A

This discussion of the 8755A device is limited to describing how you program the read-only memory. In all other ways, the 8755A device is identical to the 8355.

There are two Chip Enable signals on the 8755A device: CE is the standard chip enable, which must be true when the 8755 device is being accessed for any purpose, either in normal operation or when programming the read-only memory. CE is a high true signal.

The second Chip Enable signal,  $\overline{CE/PROG}$ , is first held low, then is pulsed true only when you are programming the read-only memory. You must apply a +25V pulse lasting between 50 and 100 milliseconds, beginning with the leading edge of ALE. At this time, data will be written into the addressed read-only memory location. Timing may be illustrated as follows:



You erase the programmable read-only memory by exposing it to ultraviolet light for a minimum of twenty minutes.



| PIN NAME                          | DESCRIPTION                                                                | TYPE             |
|-----------------------------------|----------------------------------------------------------------------------|------------------|
| AD0 - AD8                         | Multiplexed Address and Data Bus                                           | Bidirectional    |
| A8 - A10                          | Memory address lines                                                       | Input            |
| PA0 - PA7                         | Eight I/O pins, designated as Port A                                       | Bidirectional    |
| PB0 - PB7                         | Eight I/O pins, designated as Port B                                       | Bidirectional    |
| <u>RD</u>                         | Read from device control                                                   | Input            |
| <u>IOR</u>                        | Read from I/O port control                                                 | Input            |
| <u>IOW</u>                        | Write to I/O port control                                                  | Input            |
| <u>IO/M</u>                       | I/O ports or memory select                                                 | Input            |
| ALE                               | Address latch enable                                                       | Input            |
| RESET                             | System reset                                                               | Input            |
| CE                                | Chip enable                                                                | Input            |
| PROG AND <u>CE</u>                | PROM programming chip enable                                               | Input            |
| READY                             | Wait state request                                                         | Output, tristate |
| CLK                               | Timing for Wait state request                                              | Input            |
| V <sub>DD</sub>                   | Programming voltage:<br>+ 25V to program<br>+ 5V in normal read operation* | Input            |
| V <sub>SS</sub> , V <sub>CC</sub> | Ground, Power                                                              |                  |

\*V<sub>DD</sub> is 0V in earlier 8755 read mode

Figure 5-27. 8755A Multifunction Device Signals and Pin Assignments

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- 8085A CPU
- 8155/8156 RAM/IO
- 8355 ROM/IO
- 8755A EPROM/IO

## 8085A ABSOLUTE MAXIMUM RATINGS\*

|                                                        |                                                 |
|--------------------------------------------------------|-------------------------------------------------|
| Ambient Temperature Under Bias . . . . .               | $0^{\circ}\text{C}$ to $70^{\circ}\text{C}$     |
| Storage Temperature . . . . .                          | $-65^{\circ}\text{C}$ to $+150^{\circ}\text{C}$ |
| Voltage on Any Pin<br>With Respect to Ground . . . . . | -0.5 to +7V                                     |
| Power Dissipation . . . . .                            | 1.5 Watt                                        |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

( $T_A = 0^{\circ}\text{C}$  to  $70^{\circ}\text{C}$ ;  $V_{CC} = 5\text{V} \pm 5\%$ ;  $V_{SS} = 0\text{V}$ ; unless otherwise specified)

| Symbol    | Parameter               | Min. | Max.           | Units         | Test Conditions                         |
|-----------|-------------------------|------|----------------|---------------|-----------------------------------------|
| $V_{IL}$  | Input Low Voltage       | -0.5 | +0.8           | V             |                                         |
| $V_{IH}$  | Input High Voltage      | 2.0  | $V_{CC} + 0.5$ | V             |                                         |
| $V_{OL}$  | Output Low Voltage      |      | 0.45           | V             | $I_{OL} = 2\text{mA}$                   |
| $V_{OH}$  | Output High Voltage     | 2.4  |                | V             | $I_{OH} = -400\mu\text{A}$              |
| $I_{CC}$  | Power Supply Current    |      | 170            | mA            |                                         |
| $I_{IL}$  | Input Leakage           |      | $\pm 10$       | $\mu\text{A}$ | $V_{in} = V_{CC}$                       |
| $I_{LO}$  | Output Leakage          |      | $\pm 10$       | $\mu\text{A}$ | $0.45\text{V} \leq V_{out} \leq V_{CC}$ |
| $V_{ILR}$ | Input Low Level, RESET  | -0.5 | +0.8           | V             |                                         |
| $V_{IHR}$ | Input High Level, RESET | 2.4  | $V_{CC} + 0.5$ | V             |                                         |
| $V_{HY}$  | Hysteresis, RESET       | 0.25 |                | V             |                                         |

## TIMING CHARACTERISTICS

Bus Timing Specification as a  $t_{CYC}$  Dependent

|            |   |                     |     |
|------------|---|---------------------|-----|
| $t_{AL}$   | - | $(1/2) T - 50$      | MIN |
| $t_{LA}$   | - | $(1/2) T - 60$      | MIN |
| $t_{LL}$   | - | $(1/2) T - 20$      | MIN |
| $t_{LCK}$  | - | $(1/2) T - 60$      | MIN |
| $t_{LC}$   | - | $(1/2) T - 30$      | MIN |
| $t_{AD}$   | - | $(5/2 + N) T - 225$ | MAX |
| $t_{RD}$   | - | $(3/2 + N) T - 180$ | MAX |
| $t_{RAE}$  | - | $(1/2) T - 10$      | MIN |
| $t_{CA}$   | - | $(1/2) T - 40$      | MIN |
| $t_{DW}$   | - | $(3/2 + N) T - 60$  | MIN |
| $t_{WD}$   | - | $(1/2) T - 60$      | MIN |
| $t_{CC}$   | - | $(3/2 + N) T - 80$  | MIN |
| $t_{CL}$   | - | $(1/2) T - 110$     | MIN |
| $t_{ARY}$  | - | $(3/2) T - 260$     | MAX |
| $t_{HACK}$ | - | $(1/2) T - 50$      | MIN |
| $t_{HABF}$ | - | $(1/2) T + 50$      | MAX |
| $t_{HABE}$ | - | $(1/2) T + 50$      | MAX |
| $t_{AC}$   | - | $(2/2) T - 50$      | MIN |
| $t_1$      | - | $(1/2) T - 80$      | MIN |
| $t_2$      | - | $(1/2) T - 40$      | MIN |
| $t_{RV}$   | - | $(3/2) T - 80$      | MIN |

NOTE: N is equal to the total WAIT states.

$$T = t_{CYC}$$

## 8085A

A.C. CHARACTERISTICS ( $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ;  $V_{CC} = 5V \pm 5\%$ ;  $V_{SS} = 0V$ )

| Symbol     | Parameter                                                                | Min. | Max. | Units | Test Conditions                                      |
|------------|--------------------------------------------------------------------------|------|------|-------|------------------------------------------------------|
| $t_{CYC}$  | CLK Cycle Period                                                         | 320  | 2000 | ns    | $T_{CYC} = 320\text{ns};$<br>$C_L = 150 \mu\text{F}$ |
| $t_1$      | CLK Low Time                                                             | 80   |      | ns    |                                                      |
| $t_2$      | CLK High Time                                                            | 120  |      | ns    |                                                      |
| $t_r, t_f$ | CLK Rise and Fall Time                                                   |      | 30   | ns    |                                                      |
| $t_{AL}$   | Address Valid Before Trailing Edge of ALE                                | 110  |      | ns    |                                                      |
| $t_{LA}$   | Address Hold Time After ALE                                              | 100  |      | ns    |                                                      |
| $t_{LL}$   | ALE Width                                                                | 140  |      | ns    |                                                      |
| $t_{LCK}$  | ALE Low During CLK High                                                  | 100  |      | ns    |                                                      |
| $t_{LC}$   | Trailing Edge of ALE to Leading Edge of Control                          | 130  |      | ns    |                                                      |
| $t_{AFR}$  | Address Float After Leading Edge of READ (INTA)                          |      | 0    | ns    |                                                      |
| $t_{AD}$   | Valid Address to Valid Data In                                           |      | 575  | ns    |                                                      |
| $t_{RD}$   | READ (or INTA) to Valid Data                                             |      | 300  | ns    |                                                      |
| $t_{RDH}$  | Data Hold Time After READ (INTA)                                         | 0    |      | ns    |                                                      |
| $t_{RAE}$  | Trailing Edge of READ to Re-Enabling of Address                          | 150  |      | ns    |                                                      |
| $t_{CA}$   | Address (A8-A15) Valid After Control                                     | 120  |      | ns    |                                                      |
| $t_{DW}$   | Data Valid to Trailing Edge of WRITE                                     | 420  |      | ns    |                                                      |
| $t_{WD}$   | Data Valid After Trailing Edge of WRITE                                  | 100  |      | ns    |                                                      |
| $t_{CC}$   | Width of Control Low (RD, WR, INTA)                                      | 400  |      | ns    |                                                      |
| $t_{CL}$   | Trailing Edge of Control to Leading Edge of ALE                          | 50   |      | ns    |                                                      |
| $t_{ARY}$  | READY Valid From Address Valid                                           |      | 220  | ns    |                                                      |
| $t_{RYS}$  | READY Setup Time to Leading Edge of CLK                                  | 110  |      | ns    |                                                      |
| $t_{RYH}$  | READY Hold Time                                                          | 0    |      | ns    |                                                      |
| $t_{HACK}$ | HLDA Valid to Trailing Edge of CLK                                       | 110  |      | ns    |                                                      |
| $t_{HABF}$ | Bus Float After HLDA                                                     |      | 210  | ns    |                                                      |
| $t_{HABE}$ | HLDA to Bus Enable                                                       |      | 210  | ns    |                                                      |
| $t_{LDR}$  | ALE to Valid Data In                                                     |      | 460  | ns    |                                                      |
| $t_{RV}$   | Control Trailing Edge to Leading Edge of Next Control                    | 400  |      | ns    |                                                      |
| $t_{AC}$   | Address Valid to Leading Edge of Control                                 | 270  |      | ns    |                                                      |
| $t_{HDS}$  | HOLD Setup Time to Trailing Edge of CLK                                  | 170  |      | ns    |                                                      |
| $t_{HDH}$  | HOLD Hold Time                                                           | 0    |      | ns    |                                                      |
| $t_{INS}$  | INTR Setup Time to Falling Edge of CLK (M1, T1 only). Also RST and TRAP. | 160  |      | ns    |                                                      |
| $t_{INH}$  | INTR Hold Time                                                           | 0    |      | ns    |                                                      |

NOTES: 1. A8-15 Address Specs apply to IO/ $\bar{M}_0$ , S0 and S1.2. For all output timing where  $C_L \neq 150\text{pf}$  use the following correction factors:     $25\text{pf} < C_L < 150\text{pf} : -10 \text{ ns/pf}$      $150\text{pf} < C_L < 300\text{pf} : +30 \text{ ns/pf}$ 

3. Output timings are measured with purely capacitive load.

4. All timings are measured at output voltage  $V_L = .8V$ ,  $V_H = 2.0V$ , and  $1.5V$  with  $20\text{ns}$  rise and fall time on inputs.5. To calculate timing specifications at other values of  $T_{CYC}$  use the table in Table 2.

6. L.E. = Leading Edge    T.E. = Trailing Edge

**WAVEFORMS****Figure 10. Clock Timing Waveform****Read Operation****Write Operation****Figure 11. 8085A Bus Timing**

## 8085A

---



Figure 13. 8085A Hold Timing<sup>1</sup>

---



Figure 14. 8085A Interrupt and Hold Timing

---

**ABSOLUTE MAXIMUM RATINGS\***

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Temperature Under Bias .....                       | 0°C to +70°C    |
| Storage Temperature .....                          | -65°C to +150°C |
| Voltage on Any Pin<br>With Respect to Ground ..... | -0.3V to +7V    |
| Power Dissipation .....                            | 1.5W            |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. CHARACTERISTICS** (TA = 0°C to 70°C; VCC = 5V ± 5%)

| SYMBOL  | PARAMETER                           | MIN. | MAX.         | UNITS | TEST CONDITIONS    |
|---------|-------------------------------------|------|--------------|-------|--------------------|
| VIL     | Input Low Voltage                   | -0.5 | 0.8          | V     |                    |
| VIH     | Input High Voltage                  | 2.0  | VCC+0.5      | V     |                    |
| VOL     | Output Low Voltage                  |      | 0.45         | V     | IOL = 2mA          |
| VOH     | Output High Voltage                 | 2.4  |              | V     | IOH = -400µA       |
| IIL     | Input Leakage                       |      | ±10          | µA    | VIN = VCC to 0V    |
| ILO     | Output Leakage Current              |      | ±10          | µA    | 0.45V ≤ VOUT ≤ VCC |
| ICC     | VCC Supply Current                  |      | 180          | mA    |                    |
| IIL(CE) | Chip Enable Leakage<br>8155<br>8156 |      | +100<br>-100 | µA    | VIN = VCC to 0V    |

**A.C. CHARACTERISTICS** ( $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ;  $V_{CC} = 5\text{V} \pm 5\%$ )

| SYMBOL    | PARAMETER                              | MIN. | MAX. | UNITS | TEST CONDITIONS |
|-----------|----------------------------------------|------|------|-------|-----------------|
| $t_{AL}$  | Address to Latch Set Up Time           | 50   |      | ns    |                 |
| $t_{LA}$  | Address Hold Time after Latch          | 80   |      | ns    |                 |
| $t_{LC}$  | Latch to READ/WRITE Control            | 100  |      | ns    |                 |
| $t_{RD}$  | Valid Data Out Delay from READ Control |      | 170  | ns    |                 |
| $t_{AD}$  | Address Stable to Data Out Valid       |      | 400  | ns    |                 |
| $t_{LL}$  | Latch Enable Width                     | 100  |      | ns    |                 |
| $t_{RDF}$ | Data Bus Float After READ              | 0    | 100  | ns    |                 |
| $t_{CL}$  | READ/WRITE Control to Latch Enable     | 20   |      | ns    |                 |
| $t_{CC}$  | READ/WRITE Control Width               | 250  |      | ns    |                 |
| $t_{DW}$  | Data In to WRITE Set Up Time           | 150  |      | ns    |                 |
| $t_{WD}$  | Data In Hold Time After WRITE          | 0    |      | ns    |                 |
| $t_{RV}$  | Recovery Time Between Controls         | 300  |      | ns    |                 |
| $t_{WP}$  | WRITE to Port Output                   |      | 400  | ns    |                 |
| $t_{PR}$  | Port Input Setup Time                  | 70   |      | ns    |                 |
| $t_{RP}$  | Port Input Hold Time                   | 50   |      | ns    |                 |
| $t_{SBF}$ | Strobe to Buffer Full                  |      | 400  | ns    |                 |
| $t_{SS}$  | Strobe Width                           | 200  |      | ns    |                 |
| $t_{RBE}$ | READ to Buffer Empty                   |      | 400  | ns    |                 |
| $t_{SI}$  | Strobe to INTR On                      |      | 400  | ns    |                 |
| $t_{RDI}$ | READ to INTR Off                       |      | 400  | ns    |                 |
| $t_{PSS}$ | Port Setup Time to Strobe Strobe       | 50   |      | ns    |                 |
| $t_{PHS}$ | Port Hold Time After Strobe            | 120  |      | ns    |                 |
| $t_{SBE}$ | Strobe to Buffer Empty                 |      | 400  | ns    |                 |
| $t_{WBF}$ | WRITE to Buffer Full                   |      | 400  | ns    |                 |
| $t_{WI}$  | WRITE to INTR Off                      |      | 400  | ns    |                 |
| $t_{TL}$  | TIMER-IN to TIMER-OUT Low              |      | 400  | ns    |                 |
| $t_{TH}$  | TIMER-IN to TIMER-OUT High             |      | 400  | ns    |                 |
| $t_{RDE}$ | Data Bus Enable from READ Control      | 10   |      | ns    |                 |

150 pF Load

Note: For Timer Input Specification, see Figure 10.

**WAVEFORMS****Read Cycle****Write Cycle****Figure 7. 8155/8156 Read/Write Timing Diagrams**

**Strobed Input Mode****Strobed Output Mode****Figure 8. Strobed I/O Timing**

**Basic Input Mode****Basic Output Mode**

\*DATA BUS TIMING IS SHOWN IN FIGURE 7.

**Figure 9. Basic I/O Timing Diagram****Figure 10. Timer Output Waveform**

**ABSOLUTE MAXIMUM RATINGS\***

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Temperature Under Bias .....                       | 0°C to +70°C    |
| Storage Temperature .....                          | -65°C to +150°C |
| Voltage on Any Pin<br>With Respect to Ground ..... | -0.3V to +7V    |
| Power Dissipation .....                            | 1.5W            |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. CHARACTERISTICS (TA = 0°C to 70°C; VCC = 5V ± 5%)**

| SYMBOL | PARAMETER              | MIN. | MAX.    | UNITS | TEST CONDITIONS    |
|--------|------------------------|------|---------|-------|--------------------|
| VIL    | Input Low Voltage      | -0.5 | 0.8     | V     | VCC = 5.0V         |
| VIH    | Input High Voltage     | 2.0  | VCC+0.5 | V     | VCC = 5.0V         |
| VOL    | Output Low Voltage     |      | 0.45    | V     | IOL = 2mA          |
| VOH    | Output High Voltage    | 2.4  |         | V     | IOH = -400μA       |
| IIL    | Input Leakage          |      | 10      | μA    | VIN = VCC to 0V    |
| ILO    | Output Leakage Current |      | ±10     | μA    | 0.45V ≤ VOUT ≤ VCC |
| Icc    | VCC Supply Current     |      | 180     | mA    |                    |

**A.C. CHARACTERISTICS (TA = 0°C to 70°C; VCC = 5V ± 5%)**

| SYMBOL | PARAMETER                              | MIN. | MAX. | UNITS | TEST CONDITIONS |
|--------|----------------------------------------|------|------|-------|-----------------|
| tCyc   | Clock Cycle Time                       | 320  |      | ns    | CLOAD = 150 pF  |
| T1     | CLK Pulse Width                        | .80  |      | ns    |                 |
| T2     | CLK Pulse Width                        | 120  |      | ns    |                 |
| tf, tr | CLK Rise and Fall Time                 |      | 30   | ns    |                 |
| tAL    | Address to Latch Set Up Time           | 50   |      | ns    |                 |
| tLA    | Address Hold Time after Latch          | 80   |      | ns    |                 |
| tLC    | Latch to READ/WRITE Control            | 100  |      | ns    | 150 pF Load     |
| tRD    | Valid Data Out Delay from READ Control |      | 170  | ns    |                 |
| tAD    | Address Stable to Data Out Valid       |      | 400  | ns    |                 |
| tLL    | Latch Enable Width                     | 100  |      | ns    |                 |
| tRDF   | Data Bus Float after READ              | 0    | 100  | ns    |                 |
| tCL    | READ/WRITE Control to Latch Enable     | 20   |      | ns    |                 |
| tCC    | READ/WRITE Control Width               | 250  |      | ns    |                 |
| tDW    | Data In to WRITE Set Up Time           | 150  |      | ns    |                 |
| tWD    | Data In Hold Time After WRITE          | 10   |      | ns    |                 |
| tWP    | WRITE to Port Output                   |      | 400  | ns    |                 |
| tPR    | Port Input Set Up Time                 | 50   |      | ns    |                 |
| tRP    | Port Input Hold Time                   | 50   |      | ns    |                 |
| tRYH   | READY HOLD TIME                        | 0    | 160  | ns    |                 |
| tARY   | ADDRESS (CE) to READY                  |      | 160  | ns    |                 |
| tRV    | Recovery Time between Controls         | 300  |      | ns    |                 |
| tRDE   | Data Out Delay from READ Control       | 10   |      | ns    |                 |

## **WAVEFORMS**



**Figure 4. Clock Specification for 8355**



**Figure 5. ROM Read and I/O Read and Write**



Figure 6. Wait State Timing (READY 5 0)

**A. INPUT MODE****B. OUTPUT MODE**

\*DATA BUS TIMING IS SHOWN IN FIGURE 3.

Figure 7. I/O Port Timing

~~Preliminary~~

*\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.*

## ABSOLUTE MAXIMUM RATINGS\*

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Temperature Under Bias .....                       | -10°C to +70°C  |
| Storage Temperature .....                          | -65°C to +150°C |
| Voltage on Any Pin<br>With Respect to Ground ..... | -0.5V to +7V    |
| Power Dissipation .....                            | 1.5W            |

## D.C. CHARACTERISTICS (TA = 0°C to 70°C; VCC = 5V ± 5%)

| SYMBOL | PARAMETER              | MIN. | MAX.    | UNITS | TEST CONDITIONS    |
|--------|------------------------|------|---------|-------|--------------------|
| VIL    | Input Low Voltage      | -0.5 | 0.8     | V     |                    |
| VIH    | Input High Voltage     | 2.0  | VCC+0.5 | V     |                    |
| VOL    | Output Low Voltage     |      | 0.45    | V     | IOL = 2mA          |
| VOH    | Output High Voltage    | 2.4  |         | V     | IOH = -400μA       |
| IIL    | Input Leakage          |      | 10      | μA    | VIN = VCC to 0V    |
| ILO    | Output Leakage Current |      | ±10     | μA    | 0.45V ≤ VOUT ≤ VCC |
| Icc    | VCC Supply Current     |      | 180     | mA    |                    |

## A.C. CHARACTERISTICS (TA = 0°C to 70°C; VCC = 5V ± 5%)

| SYMBOL | PARAMETER                              | MIN. | MAX. | UNITS | TEST CONDITIONS |
|--------|----------------------------------------|------|------|-------|-----------------|
| tCYC   | Clock Cycle Time                       | 320  |      | ns    |                 |
| T1     | CLK Pulse Width                        | 80   |      | ns    |                 |
| T2     | CLK Pulse Width                        | 120  |      | ns    |                 |
| tf, tr | CLK Rise and Fall Time                 |      | 30   | ns    |                 |
| tAL    | Address to Latch Set Up Time           | 50   |      | ns    |                 |
| tLA    | Address Hold Time after Latch          | 80   |      | ns    |                 |
| tLC    | Latch to READ/WRITE Control            | 100  |      | ns    |                 |
| tRD    | Valid Data Out Delay from READ Control |      | 170  | ns    |                 |
| tAD    | Address Stable to Data Out Valid       |      | 450  | ns    |                 |
| tLL    | Latch Enable Width                     | 100  |      | ns    |                 |
| tRDF   | Data Bus Float after READ              | 0    | 100  | ns    |                 |
| tCL    | READ/WRITE Control to Latch Enable     | 20   |      | ns    |                 |
| tCC    | READ/WRITE Control Width               | 250  |      | ns    |                 |
| tDW    | Data In to WRITE Set Up Time           | 150  |      | ns    |                 |
| tWD    | Data In Hold Time After WRITE          | 30   |      | ns    |                 |
| tWP    | WRITE to Port Output                   |      | 400  | ns    |                 |
| tPR    | Port Input Set Up Time                 | 50   |      | ns    |                 |
| tRP    | Port Input Hold Time                   | 50   |      | ns    |                 |
| tRYH   | READY HOLD TIME                        | 0    | 160  | ns    |                 |
| tARY   | ADDRESS (CE) to READY                  |      | 160  | ns    |                 |
| tRV    | Recovery Time between Controls         | 300  |      | ns    |                 |
| tRDE   | Data Out Delay from READ Control       | 10   |      | ns    |                 |

## 8755A

## WAVEFORMS



Figure 5. Clock Specification for 8755A



Figure 6. PROM Read, I/O Read and Write Timing

Please note that CE1 must remain low for the entire cycle. This is due to the fact that the programming enable function common to this pin will disrupt internal data bus levels if CE1 is taken high during the read.

**Input Mode****A. INPUT MODE****Output Mode****B. OUTPUT MODE**

\*DATA BUS TIMING IS SHOWN IN FIGURE 6.

**Figure 7. I/O Port Timing**



**Figure 8. Wait State Timing (READY = 0)**

**PRELIMINARY**  
Notes: This is not a final specification. Some  
 parametric limits are subject to change.

**D.C. SPECIFICATION FOR PROGRAMMING**

(TA = 0°C to 70°C; VCC = 5V ±5%; VSS = 0V)

| SYMBOL          | PARAMETER                                      | MIN. | TYP. | MAX. | UNIT |
|-----------------|------------------------------------------------|------|------|------|------|
| VDD             | Programming Voltage<br>(during write to EPROM) | 24   | 25   | 26   | V    |
| I <sub>DD</sub> | Prog Supply Current                            |      | 15   | 30   | mA   |

**A.C.-SPECIFICATION FOR PROGRAMMING**

(TA = 0°C to 70°C; VCC = 5V ±5%; VSS = 0V)

| SYMBOL           | PARAMETER             | MIN. | TYP. | MAX. | UNIT |
|------------------|-----------------------|------|------|------|------|
| t <sub>PS</sub>  | Data Setup Time       | 10   |      |      | ns   |
| t <sub>PD</sub>  | Data Hold Time        | 0    |      |      | ns   |
| t <sub>S</sub>   | Prog Pulse Setup Time | 2    |      |      | μs   |
| t <sub>H</sub>   | Prog Pulse Hold Time  | 2    |      |      | μs   |
| t <sub>PR</sub>  | Prog Pulse Rise Time  | 0.01 | 2    |      | μs   |
| t <sub>PF</sub>  | Prog Pulse Fall Time  | 0.01 | 2    |      | μs   |
| t <sub>PRG</sub> | Prog Pulse Width      | 45   | 50   |      | msec |

# 8755A

## WAVEFORMS



\* VERIFY CYCLE IS A REGULAR MEMORY READ CYCLE (WITH V<sub>DD</sub> = +5V FOR 8755A, V<sub>DD</sub> = 0V FOR 8755.)

Figure 10. 8755/8755A Program Mode Timing Diagram

## Chapter 6

# THE 8048 MICROCOMPUTER DEVICES

The 8048 series microcomputers are single-chip 8-bit devices which have been developed by Intel to compete in the market for low-cost, high-volume applications. This is a market where the 8080A, with its high chip counts, does not do well. One version of the 8048, the 8748, is also likely to do exceptionally well in low-volume, custom applications because it is very easy to use.

The 8048 looks like a one-chip 8080A with heavy F8 influence. The F8 was the first 8-bit microprocessor to bring the economics of low chip counts to the attention of the semiconductor industry. It is therefore not surprising to find an F8 influence in the 8048. (The F8 has now been superceded by the 3870; both parts are described in Chapter 2.)

It is intriguing to note that, in terms of general architectural organization, there are striking similarities between the 8048 and the MCS6530 (which is described in Chapter 10).

The 8041 and 8021 are slave microcomputers of the 8048 family. On simple inspection the principal difference between the 8048 and the 8041/8021 would appear to be that the 8041/8021 cannot generate external System Busses. In fact, there are non-obvious differences between the 8048 and the 8041/8021; there are further significant differences between the 8041 and the 8021.

The 8048 is a simple, single-chip microcomputer that may be a stand-alone device, or part of a multi-microprocessor configuration. As a stand-alone device, the 8048 may or may not have external additional logic. Thus, **the 8048 is a straightforward, low-end, low-cost microprocessor** with less versatility than a device such as the 8085.

If you continue the philosophical progression from the 8085 to the 8048, you reach **the 8021. This is a single-chip microcomputer with no expansion capabilities**, and very low-cost. If the 8021 exists in a multi-microprocessor configuration, then so far as the 8021 is concerned there is logic beyond its perimeters. The fact that this logic contains one or more microprocessors is quite immaterial to the manner in which the 8021 will be programmed.

The 8041, in sharp contrast, is a slave microprocessor that assumes the presence of a master microprocessor on one side and external logic on the other side. The 8041 thus becomes an interface and control part — which is how the 8041 should be considered. But you will observe that a large number of microprocessor support parts also act as interfaces between a microprocessor, assumed to exist on one side, and some other logic, assumed to exist on the other side. This is a very accurate parallel to draw. The 8041 is, in fact, a universal interface device, limited only by the speed of the part and the amount of programmed logic that can be included in it. The 8041 can serve a wide variety of interface logic functions. Thus, **whenever you consider using a complex interface controller part, you should also consider using the 8041 as an alternative**. Because the 8041 is programmable, you can tailor it to meet, exactly, the requirements of the specific microprocessor on one side and specific logic on the other side. This is something you cannot do with dedicated controller parts such as floppy disk and CRT controllers, which must look generically, rather than specifically, upon the CPU on one side and the device being controlled on the other side.

**There is also an erasable programmable read-only memory version of the 8041; it is the 8741.**

**8048 series microcomputers are summarized in Table 6-1.**

**The only support device described in this chapter is the 8243 I/O Expander. In addition, the 8155, the 8355, and the 8755 multifunction devices (which have been described in Chapter 5) can be used with 8048 family microcomputers.**

The prime source for the 8048 series microcomputers is:

INTEL CORPORATION  
3065 Bowers Avenue  
Santa Clara, California 95051

Second sources for the 8048 include:

ADVANCED MICRO DEVICES  
901 Thompson Place  
Sunnyvale, California 94086

SINETICS  
811 East Arques Avenue  
Sunnyvale, California 94043

Neither of the 8048 second sources are likely to have significant product volumes until mid-1978.

Intersil plans to introduce a CMOS version of the 8048 in early 1979.

The 8048 series microcomputers use a single +5V power supply. There are two versions of each microcomputer; one uses a 2.5 microsecond clock while the other uses a 5 microsecond clock. 8048 instructions execute in either one or two clock periods. The 8021 uses a 10 microsecond clock. A new version of the 8049 uses a 1.4  $\mu$ sec clock.

All 8048, 8049 and 8041 devices are packaged as 40-pin DIPs and have TTL-compatible signals. 8021 devices are packaged as 28-pin DIPs and have TTL-compatible signals.

Table 6-1. A Summary of 8048 Series Microcomputers

|        | ON CHIP MEMORY |     | CYCLE TIME    | I/O PORTS            | EXTERNAL INTERRUPTS | TIMER | PACKAGE PINS | EXPANDABLE | ANALOG TO DIGITAL CONVERTER |
|--------|----------------|-----|---------------|----------------------|---------------------|-------|--------------|------------|-----------------------------|
|        | ROM/EPROM      | RAM |               |                      |                     |       |              |            |                             |
| 8048   | 1024 ROM       | 64  | 2.5 $\mu$ sec | 3x8 bits             | 1                   | Yes   | 40           | Yes        | No                          |
| 8035   | 0              | 64  | 2.5 $\mu$ sec | 3x8 bits             | 1                   | Yes   | 40           | Yes        | No                          |
| 8035-8 | 0              | 64  | 5.0 $\mu$ sec | 3x8 bits             | 1                   | Yes   | 40           | Yes        | No                          |
| 8748   | 1024 EPROM     | 64  | 2.5 $\mu$ sec | 3x8 bits             | 1                   | Yes   | 40           | Yes        | No                          |
| 8748-8 | 1024 EPROM     | 64  | 5.0 $\mu$ sec | 3x8 bits             | 1                   | Yes   | 40           | Yes        | No                          |
| 8049   | 2048 ROM       | 64  | 1.4 $\mu$ sec | 3x8 bits             | 1                   | Yes   | 40           | Yes        | No                          |
| 8041   | 1024 ROM       | 64  | 2.5 $\mu$ sec | 3x8 bits             | 0                   | Yes   | 40           | No         | No                          |
| 8741   | 1024 EPROM     | 64  | 2.5 $\mu$ sec | 3x8 bits             | 0                   | Yes   | 40           | No         | No                          |
| 8021   | 1024 ROM       | 64  | 10 $\mu$ sec  | 2x8 bits<br>1x4 bits | 0                   | Yes   | 28           | No         | No                          |
| 8022   | 2048 ROM       | 64  | 10 $\mu$ sec  | 3x8 bits             | 1                   | Yes   | 40           | No         | Yes                         |

## THE 8048, 8748, 8049, 8749 AND 8035 MICROCOMPUTERS

For a description of an 8048, 8748, 8049, 8749, or 8035 device, read the following text; where ambiguities may arise in your mind, remember these overriding rules:

- 1) The 8049 is an 8048 with twice as much on-chip program memory, and, in newer models, higher execution speed. There are no other differences between these two parts.
- 2) An 8035 is an 8048 with no on-chip program memory. There are no other differences between these two parts.

For a description of an 8041, 8741 or 8021 device, read the following text, then read the specific device discussion that appears later in this chapter.

Functions implemented on the three versions of the 8048 microcomputer are illustrated in Figure 6-1. With the exception of the 8035, you will see that complete microcomputer logic is provided within a single package. But remember, just because a function is present in Figure 6-1, that does not mean to say it will be sufficient for your application. For example, read/write memory is shown as present, yet there are only 64 bytes of read/write memory on any 8048 series microcomputer chip.



Figure 6-1. Logic of the 8048 Series Microcomputers

The only differences between 8048 series and 8049 series microcomputers are in the on-chip read-only memory and execution speed; 8049 series microcomputers have twice as much on-chip read-only memory as 8048 series microcomputers, and execute instructions 80% faster.

### 8049 SERIES MICROCOMPUTERS

## AN 8048 AND 8049 FUNCTIONAL OVERVIEW

**Logic of the 8048 and 8049 series microcomputers is illustrated functionally in Figure 6-2.**

The Arithmetic and Logic Unit, the Control Unit and the Instruction register are all inaccessible to you as a user; therefore we will ignore this portion of the microcomputer.

1024 bytes of program memory are provided by the 8048 and 8748 microcomputers; the 8035 has no program memory. The 8049 has 2048 bytes of program memory. The 8048 and 8049 have Read Only Memory (ROM), while the 8748 has Erasable Programmable Read Only Memory (EPROM); this is the only difference between the 8048/8049 and the 8748.

There is a 12-bit Program Counter which allows the 8048 series microcomputers to access 4096 bytes of program memory. Since the 8048 and 8748 microcomputers have only 1024 bytes of program memory on the computer chip, the additional 3072 bytes must be external if you are going to expand program memory to the maximum addressable space. All 8035 microcomputer program memory is external. Only 2048 bytes of external program memory can be added to an 8049.



Figure 6-2. Functional Logic of the 8048, 8049, 8748,  
8749 and 8035 Microcomputers

All 8048 series microcomputers (with the exception of the 8021) have three 8-bit I/O ports. For the 8048 series and 8049 series microcomputers, one of these ports, the Bus Port, is a truly bidirectional I/O port with input and output strobes. Outputs can be statically latched, while inputs are nonlatching. This means that external logic must hold input data true at Bus Port pins until the data has been read. All eight pins of the Bus Port must be assigned either to input or output; you cannot mix input and output on the Bus Port.

**8048 SERIES  
I/O PORTS**

Bus Port is used as the primary I/O port in a single-chip microcomputer system. In multiple-chip microcomputer systems Bus Port serves as a multiplexed Address and Data Bus.

**I/O Ports 1 and 2 are secondary I/O ports with characteristics that differ significantly from Bus Port.** If you output parallel data to I/O Port 1 or 2, it is latched and maintained at the I/O port until you next write data. But the only way external logic can input data to I/O Port 1 or 2 is by pulling individual pins from a high to a low level. Thus when a high level is being output at any pin of I/O Port 1 or 2, external logic can pull this level low — and subsequently if the CPU reads back data from the I/O port it will read a 0 bit value. This may be illustrated as follows:



External logic cannot create a high level at any pin of I/O Port 1 or 2 which is outputting a low level.

**Here is a summary of I/O Port 1 and 2 capabilities:**

- 1) You can at any time output parallel data to I/O Port 1 or 2. The data will be latched and held until the next output.
- 2) Individual pins of I/O Ports 1 and 2 can serve as input or output pins. When you output data to I/O Port 1 or 2, you must output a 1 bit to any input pin. This may be illustrated as follows:

Data Output → X 1 1 X X 1 X 1 (X = 0 or 1)



- 3) External logic writes to input pins of I/O Ports 1 and 2 by leaving low levels alone, and by pulling high levels low.

**Figure 6-3 illustrates logic associated with each pin of I/O Ports 1 and 2 in all 8048 series microcomputers.**

**8048 SERIES  
I/O PORT  
PIN LOGIC**

Output data is latched by a D-type flip-flop.

The Q and  $\bar{Q}$  outputs of the D-type flip-flop control a pair of gates on either side of the pin connection. To provide fast switching times in 0-to-1 transitions, a relatively low impedance ( $\sim 5K$  ohms) is switched in for approximately 500 nanoseconds whenever a 1 is output.



Figure 6-3. 8048 I/O Ports 1 and 2 Pin Logic

Pins are continuously pulled up to +5V through a relatively high impedance ( $\sim 50K$  ohms). When a 0 is output to the D-type flip-flop, a low impedance ( $\sim 3K$  ohms) overcomes the pull-up and provides TTL current sinking capability.

When a pin of I/O Port 1 or 2 is at a high level, external logic can sink the  $50K\Omega$  pull-up. But when the pin is at a low level, external logic cannot overcome the low impedance to ground; thus it cannot pull the pin up to a high level.

By placing an input buffer between the pin and the switching gates, pin logic allows the CPU to read current levels induced by external logic — but only while external logic is connected to the pin.

The buffer connecting the Q output of the D-type flip-flop to the D input is present to enable 8048 instructions that mask I/O port data.

Later in this chapter we will look at I/O ports in more detail, showing programming and design examples.

## 8048, 8748 AND 8035 MICROCOMPUTER PROGRAMMABLE REGISTERS

The 8048 series microcomputers have an 8-bit Accumulator, a 12-bit Program Counter and 64 bytes of scratchpad memory. Scratchpad memory may be visualized either as read/write memory or as general purpose registers.

The Accumulator, Program Counter and scratchpad memory may be illustrated as follows:



**The Accumulator is the principal conduit for all data transfers. The Accumulator is always one source and the destination for Arithmetic or Boolean operations involving memory or registers.**

**Two sets of eight scratchpad bytes serve as secondary registers.** At any time one set of general purpose registers is selected while the other set of general purpose registers is not selected.

**The first two general purpose registers of each set, R0 and R1, act as Data Counters** to address scratchpad memory and external data memory. Thus you address scratchpad memory using implied memory addressing via general purpose Register R0 or R1; you can address any one of the 64 scratchpad bytes, including the general purpose registers, or even the Data Counter register itself.

**In between the two sets of eight general purpose registers there is a 16-byte stack.** The Stack Pointer is maintained in the Program Status Word; therefore we will defer our discussion of stack operations until we look at status.

## 8048 SERIES ADDRESSING MODES

**The 8048 series microcomputers separate memory into program memory and data memory. Without resorting to complex expansion schemes, you are limited to a maximum of 4096 program memory bytes and 320 data memory bytes.**

**8048 SERIES  
MEMORY  
SPACES**

The 8048 and 8748 microcomputers have 1024 bytes of program memory on the CPU chip. The 8049 microcomputer has 2048 bytes of program memory on the CPU chip. More program memory, if present, must be external to the CPU chip. The 8035 microcomputer has no on-chip program memory; it requires all program memory to be external.

All 8048 series microcomputers provide 64 bytes of read/write data memory on the CPU chip. In addition, 256 bytes of external data memory may be addressed. **The external data memory space must be shared by external data memory and any external I/O ports** — that is to say, I/O ports other than the microcomputer's own three I/O ports or 8243 Expander ports.

**8048 series microcomputer address spaces and addressing modes are illustrated in Figure 6-4.**

**Let us first examine program memory addressing.**

A single address space is used to access all of program memory. In the normal course of events program memory is addressed via the 12-bit Program Counter. The high order Program Counter bit is isolated in Figure 6-4 because when the Program Counter is incremented only bits 0 through 10 are affected. You must execute special instructions to modify the contents of the high order Program Counter bit. Program memory is therefore effectively divided into two memory banks, each containing up to 2048 bytes of program memory. You cannot branch, via Jump-on-Condition instructions, from one program memory bank to the other, nor can instructions stored in one program memory bank directly access the other. You can switch completely from one program memory bank to the other by preceding a JMP, CALL or RET instruction with a SEL MB instruction.

**8048 SERIES  
PROGRAM  
MEMORY  
ADDRESSING**

**Two types of program memory addressing are available: you can read data from program memory and you can execute Jump instructions.**

You can unconditionally jump anywhere within the currently selected program memory bank; this may be illustrated as follows:





Figure 6-4. 8048 Series Microcomputers' Memory Addressing

Thus the JMP instruction stored in program memory bytes 010B<sub>16</sub> and 010C<sub>16</sub> causes program execution to jump to location 06BA<sub>16</sub>.

You can also jump using a form of paged, indirect addressing, where the Accumulator points to an indirect address stored in the current page of program memory. This may be illustrated as follows:



All conditional Jump instructions allow you to branch within the current page of program memory only. This may be illustrated as follows:



You can read data from program memory, but there are no instructions which allow you to write data to program memory. Instructions (other than immediate instructions) that read data from program memory use paged, implied addressing. There are two forms of paged, implied programming memory addressing; they may be illustrated as follows:



The illustration above compares execution of the MOVP and MOVP3 instructions. These are the two instructions which allow you to read a byte of data from program memory into the Accumulator. Both instructions load 4A into the Accumulator, as illustrated above.

When the MOVP instruction is executed, the program memory address is formed by concatenating the high-order four bits of the Program Counter with the contents of the Accumulator:



When the MOVP3 instruction is executed, the program memory address is computed by appending the Accumulator contents to 0011:



Thus the MOVP instruction loads into the Accumulator the contents of a program memory byte within the current program page. The MOVP3 instruction loads into the Accumulator the contents of a byte from program memory page 3.

**Note carefully that paged addressing of program memory carries with it the usual page boundary problems.** The program memory addressing modes which replace the low-order eight Program Counter bits keep the four high-order Program Counter bits — after the Program Counter has been incremented.

Refer back to the JMPP @A instruction. This instruction is illustrated as being stored in program memory location 015B<sub>16</sub>. But suppose this instruction were stored in memory location 01FF<sub>16</sub>; then after the JMPP instruction is fetched, the Program Counter will no longer contain 01FF<sub>16</sub>, it will contain 0200<sub>16</sub>. Now instead of jumping to program memory location 01CB<sub>16</sub>, you would jump to program memory location 02CB<sub>16</sub>.

This page boundary problem is common to all microcomputers that use absolute paged addressing. For a complete discussion of this problem refer to Volume I — Basic Concepts, Chapter 6.

**Note that the 8048 has no instructions which write into program memory. If you want to write into program memory you must have external logic which overlaps external program and data memory.**

**Let us now look at data memory addressing.** First of all, notice that scratchpad memory and external data memory have overlapping address spaces. Separate and distinct instructions access scratchpad memory as against external data memory. External data memory does not represent a continuation of scratchpad memory. For example, there will be memory bytes with addresses in the range 0016 through 3F16 in the scratchpad and in external data memory.

**Implied memory addressing is the only addressing mode available to you when accessing data memory.**

Instructions that access scratchpad memory take the scratchpad memory byte address from the low-order six bits of General Purpose Register R0 or R1.

Instructions that access external data memory take the external data memory address from all eight bits of General Purpose Register R0 or R1.

The eight general purpose registers within scratchpad memory can be addressed directly. We could argue that this constitutes a limited scratchpad memory direct addressing capability; but in order to remain consistent with other microcomputers described in this book, we will classify these direct accesses of general purpose registers as register-to-register operations rather than direct addressing of data memory.

## A PROGRAM MEMORY MAP

**The instruction set of the 8048 microcomputer is designed to allocate the on-chip program memory as follows:**



The MOVP3 instructions assume that the 256 bytes of program memory with addresses 300<sub>16</sub> - 3FF<sub>16</sub> have been set aside to hold tables of constant data.

Interrupt logic (which is described later) uses low memory locations 0, 3 and 7 to origin interrupt service routines that will be executed in response to a restart, an external interrupt or a timer interrupt. Jump instructions will normally be located in these low program memory locations.

## 8048 SERIES STATUS

8048 series microcomputers have an 8-bit Program Status Word which may be illustrated as follows:



C and AC are the standard Carry and Auxiliary Carry statuses as defined in Volume I and used throughout this book.

F0 is a flag which you set or reset using appropriate Status instructions. A conditional Jump instruction tests the level of F0. F0 is not connected to external logic and cannot be modified or tested by external logic.

BS identifies which set of general purpose registers is currently selected. If BS is 0, then scratchpad bytes 0 through 7 are serving as general purpose registers. If BS is 1, then scratchpad bytes 18<sub>16</sub> through 1F<sub>16</sub> are serving as general purpose registers.

The low-order three Program Status Word bits serve as a Stack Pointer. The 16 Stack bytes are treated as eight 16-bit registers, with the current top of Stack identified by the three low-order Program Status Word bits.

A subroutine Call instruction pushes the Program Counter contents and the four high-order Program Status Word bits onto the Stack as follows:



In the illustration above, P, Q, R, S and X represent any binary digits.

Observe that the beginning of the Stack has the lowest scratchpad address. The order in which Program Status Word and Program Counter contents are pushed onto the Stack is illustrated above. Here is a specific case:



You need to know the exact order in which data is stored on the Stack since the Stack is also accessible as general scratchpad memory.

There are two Return-from-Subroutine instructions; one restores Program Counter contents only, the other restores Program Counter and Program Status Word contents.

Since the Stack has eight 16-bit registers, subroutines may be nested eight deep. If you are using interrupts, then the combined total of subroutine nesting levels on either side of the interrupt must sum to 7 or less. For example, if the interrupt service routine nests subroutines to a maximum level of 3, then non-interrupt programs cannot nest subroutines to a level greater than 4. The interrupt itself requires one Stack location.

## 8048 SERIES MICROCOMPUTER OPERATING MODES

**8048 series microcomputers can operate in a variety of modes. Many signals serve more than one function, depending on the operating mode.**

In order to clarify this potentially confusing subject, we will summarize 8048 series operating modes in the paragraphs below, then we will summarize device signals; these two summaries are followed by an in-depth analysis of operating modes, illustrating timing and signal functions.

**Internal execution mode is the simplest case; the 8048 series microcomputers normally operate in Internal Execution mode, at which time they execute programs without accessing external program memory or data memory.** All information transfer with external logic occurs via I/O ports or control signals. The 8035, having no internal program memory, cannot operate in Internal Execution mode.

Expandable 8048 series microcomputers can access external program and data memory. Having external program memory and/or data memory causes the microcomputer to output additional control signals which identify external program and data memory accesses. This is External Memory Access mode. Memory addresses are output via the Bus Port and four pins of I/O Port 2; bidirectional data transfers occur via the Bus Port. This may be illustrated as follows:

|                                                            |
|------------------------------------------------------------|
| <b>8048 SERIES<br/>INTERNAL<br/>EXECUTION<br/>MODE</b>     |
| <b>8048 SERIES<br/>EXTERNAL<br/>MEMORY<br/>ACCESS MODE</b> |



External Memory Access mode represents the simplest case for the 8035 microcomputer, which has no on-chip program memory.

The 8048 series microcomputers can be operated in Debug mode. **In Debug mode the CPU is disconnected from its internal program memory.** All program memory accesses are deflected to external program memory. This may be illustrated as follows:

**8048 AND  
8748 DEBUG  
MODE**



Since the 8035 has no internal program memory, it is always in "Debug mode."

You will use Debug mode to test microcomputer systems built around an 8048 series microcomputer. Typically, special purpose test and verify programs will be maintained in external debug memory.

**Single stepping is not really a mode, but is worth mentioning in connection with Debug mode since it is a powerful debugging tool.** In any of the operating modes you can apply a Single Step signal (SS) which halts instruction execution following the next instruction fetch. This allows you to execute programs one instruction at a time in order to locate errors or gain a better understanding of event sequences.

**8048 SERIES  
SINGLE  
STEPPING**

The 8748 microcomputer contains Erasable Programmable Read Only Memory (EPROM). **In Programming mode you can program the EPROM.**

**8748  
PROGRAMMING  
MODE**  
**8048 SERIES  
VERIFY MODE**

Finally, there is a Verify mode. **In Verify mode you can read the contents of internal or external program memory as data.** Verify mode is used in conjunction with Programming mode to test data written into EPROMs. Verify mode can also be used on its own to examine the contents of program memory for any 8048 series microcomputer.

## 8048 SERIES MICROCOMPUTER PINS AND SIGNALS

Figure 6-5 illustrates pins and signals for the 8048 series microcomputers. We will briefly summarize functions performed by signals before discussing how signals are used in different modes.

**DB0 - DB7 serves both as a bidirectional I/O port and as a multiplexed Address and Data Bus.** When no external data or program memory accesses are occurring, DB0 - DB7 serves as a simple bidirectional I/O port or latch. During external program or data memory accesses, DB0 - DB7 serves as a bidirectional Data Bus as well as outputting the low-order eight bits of all memory addresses. Data inputs are not latched in bidirectional mode. External logic must hold input signal levels until the CPU has read input data.



| PIN NAME        | DESCRIPTION                                                            | TYPE                    |
|-----------------|------------------------------------------------------------------------|-------------------------|
| DB0 - DB7       | Bidirectional I/O port, Data Bus and low-order eight Address Bus lines | Bidirectional, tristate |
| P10 - P17       | I/O Port 1                                                             | Quasibidirectional      |
| P20 - P27       | I/O Port 2. P20 - P23 also serves as four high-order Address Bus lines | Quasibidirectional      |
| ALE             | External clock signal and address latch enable                         | Output                  |
| RD              | Data memory read control                                               | Output                  |
| WR              | Data memory write control                                              | Output                  |
| PSEN            | External program memory read control                                   | Output                  |
| EA              | External program memory access                                         | Input                   |
| SS              | Single step control                                                    | Input                   |
| INT             | Interrupt request                                                      | Input                   |
| T0              | Test input, optional clock output and Program/Verify mode select       | Bidirectional           |
| T1              | Test input, optional event counter input                               | Input                   |
| RESET           | System reset and EPROM address latch                                   | Input                   |
| V <sub>SS</sub> | Ground                                                                 |                         |
| V <sub>CC</sub> | + 5V                                                                   |                         |
| V <sub>DD</sub> | + 25V to program 8748. + 5V standby for 8048 RAM                       |                         |
| PROG            | + 25V input to program 8748. Control output for 4-bit I/O              | Bidirectional           |
| XTAL1, XTAL2    | External crystal connections                                           |                         |

Figure 6-5. 8048, 8748 and 8035 Microcomputer Pins and Signals

**P10 - P17 and P20 - P27 support I/O Ports 1 and 2, respectively.** We described the characteristics of these two I/O ports earlier in this chapter. During external accesses of program memory the four high-order address lines are output via P20 - P23.

**ALE** is a control signal which is pulsed high at the beginning of every instruction execution machine cycle. This signal may be used as a clock by external logic. During external memory accesses, the trailing edge of ALE strobes memory addresses being output.

**RD** is a control signal which is pulsed low to strobe data from external data memory onto the Data Bus.

**WR** is a control signal which is strobed low when external data memory is to read data off the Data Bus.

**PSEN** is a control signal which is strobed low when external program memory is to place data on the Data Bus.

**External logic inputs EA high** in order to separate the CPU from internal program memory and force the microcomputer into **Debug mode**.

**SS** is input low in order to stop instruction execution following an instruction fetch; this allows you to single step through a program.

**INT** is the input for external interrupt requests. If the interrupt is enabled, a low input at INT causes a subroutine call to program memory location 3 when the current instruction finishes execution.

**T0** is a test input which may be sampled by a conditional Jump instruction. **T0 is also used while selecting External Program mode and Verify mode. The internal CPU clock signal can be output via T0.**

**T1** is a test input which can be sampled by a Jump-on-Condition instruction. **T1 can also be used to input a signal to Counter/Timer logic** when it is serving as an event counter.

**RESET** is a standard system reset input signal. The normal RESET signal should be output from an open collector or active pull-up:

8048, 8748  
AND 8035  
RESET



The power-on RESET should be generated as follows:



There is an internal pull-up resistor which, in combination with an external  $1\mu F$  capacitor, generates an adequate internal RESET pulse. If the RESET pulse is generated externally, then it must be held below 0.5V for at least 50 milliseconds.

**This is what happens when you reset an 8048 series microcomputer:**

- 1) The Program Counter and the Program Status Word are cleared. This selects register bank 0 and program memory bank 0. Also, the first instruction executed following a Reset will be fetched from program memory location 0.
- 2) The Bus Port is floated.
- 3) I/O Ports 1 and 2 are set to Input mode.
- 4) External interrupts are disabled.
- 5) The counter/timer is stopped and T0 is disconnected from the timer.
- 6) The timer flag and internal flags F1 and F0 are cleared.

An external crystal, if present, is connected across XTAL1 and XTAL2. Typically a 6 MHz crystal will be used. You can input a clock signal directly to XTAL1. If you do, the input clock signal should have a frequency in the range of 1 MHz to 6 MHz, or 11 MHz for the 8049.

The 8048 series microcomputers use power supplies in a number of interesting ways.

V<sub>CC</sub> is the standard +5V power supply. V<sub>SS</sub> is the standard ground connection.

V<sub>DD</sub> is an additional +5V standby power supply. This standby power supply will maintain the contents of scratchpad memory when all other power has been removed. Typically V<sub>DD</sub> will be connected to a battery so that when the system is powered down data can be preserved in scratchpad memory (8048, 8035L and 8049 only).

The 8748 and 8749 microcomputers use V<sub>DDP</sub> and PROG in order to program the EPROM. While programming the EPROM, a voltage of +25V is input at V<sub>DD</sub>. +25V pulses lasting 50 milliseconds are input at PROG. A single byte of program memory will be written during a single PROG +25V pulse.

PROG serves as a control strobe output to the 8243 Input/Output Expander during the execution of instructions that reference the Expander ports. This function of PROG is described in more detail later in this chapter, when we describe the 8243 I/O Expander.

## 8048 SERIES TIMING AND INSTRUCTION EXECUTION

Let us begin our detailed analysis of 8048 series microcomputer operations by looking at basic instruction timing.

A master clock signal must be input via XTAL1, or the clock signal may be generated internally by connecting a crystal across XTAL1 or XTAL2. A 6 MHz crystal is recommended. This clock signal is divided by 3 to generate a master synchronizing 2 MHz signal which is used throughout the microcomputer system. You can output this 2 MHz clock signal via the T0 pin.

All -8 versions of 8048 series microcomputers operate at half speed; they use 3 MHz crystals and generate a 1 MHz master synchronizing signal.

Instructions execute in machine cycles. Every machine cycle has five clock periods. Using a 2 MHz clock signal, therefore, each machine cycle will last 2.5 microseconds. Instructions execute in either one or two machine cycles.

8048 SERIES  
MACHINE  
CYCLES AND  
CLOCK PERIODS

### INTERNAL EXECUTION MODE

Figure 6-6 illustrates timing for the simplest case — execution of a single machine cycle instruction accessing internal program or data memory only. The only signal change seen beyond the microcomputer chip itself is the ALE pulse — and the CLK signal, if you elect to output it via T0. The events which occur during each clock period are illustrated in Figure 6-6; but remember, these operations are internal to the microcomputer. They are beyond your access or control.

Figure 6-6 also illustrates timing for instructions that execute in two machine cycles, but access only program and/or data memory internal to the microcomputer chip. Once again external logic sees ALE, and optionally CLK.



Figure 6-6. Execution of 8048 Single Machine Cycle Instructions without any External Access



Figure 6-7. An 8048 Series External Instruction Fetch



Figure 6-8. An 8048 Series External Data Read or Write

## EXTERNAL MEMORY ACCESS MODE

Now consider external program and data memory accesses.

**Figure 6-7 illustrates timing for an external program memory read.** The external program memory address is output via DB0 - DB7 (low-order eight address lines) and P20 - P23 (high-order four address lines). The address is maintained stable just long enough for external logic to latch it on the high-to-low transition of ALE.

The low PSEN pulse serves as an external program memory read strobe. While PSEN is low, external program memory must decode the latched address and place the contents of the addressed memory byte on the DB0 - DB7 lines. The microcomputer will read DB0 - DB7 on the trailing (low-to-high) transition of PSEN.

**Timing associated with reading data from external data memory and writing to external data memory is illustrated in Figure 6-8.** Timing is very similar to the external instruction fetch illustrated in Figure 6-7. Instead of PSEN being pulsed low, RD is pulsed low to strobe data input; WR is pulsed low to strobe data output. Since the total external data memory address space is 256 bytes, the complete address is transmitted via DB0 - DB7; thus P20 - P23 is inactive during an access of external data memory.

**Note that the 8048 series microcomputers have no Wait state.** External memory must therefore respond to read or write operations within the allowed time. This is not much of a problem since 8048 series microcomputers operate relatively slowly; most standard memory devices will have no trouble meeting timing requirements. If you want to use slower memories, use the slower 5 microsecond machine cycle versions of the 8048 microcomputers.

**8048  
WAIT  
STATE**



Figure 6-9. An 8048-8355 Configuration



Figure 6-10. Demultiplexing DB0 - DB7 to Create Separate Address and Data Busses

**Let us examine microcomputer configurations that include external memory.**

Vendor literature illustrates complex microcomputer systems built around 8048 series microcomputers; while such large microcomputer systems are certainly feasible, they are not advisable. If you are going to expand an 8048 series microcomputer system to more than two or three devices, in all probability an 8085 system would be more economical and powerful — not to mention a number of other microcomputers described in this book. We will therefore confine ourselves to illustrating 2- and 3-chip configurations.

**Figure 6-9 illustrates an 8048-8355 (or 8755) configuration. The 8355 (or 8755) is a multifunction support device described in Chapter 5.**

**Figure 6-10 shows how you can connect standard memory devices to an 8048 series microcomputer.**

**Let us examine Figure 6-9.** The 8048 Bus Port is directly compatible with AD0 - AD7, the multiplexed Data and Address Bus of the 8355 device.

The three high-order address lines required by the 8355, A8, A9 and A10, are taken directly from P20, P21 and P22. P23, the high-order address line output by the 8048, is used to enable the 8355. As shown in Figure 6-9, this means the 8355 will respond to addresses in program memory bank 1. If you are using an 8035 microcomputer, then P23 could be connected to the  $\overline{CE}$  enable pin of the 8355; now the 8355 will respond to addresses in program memory bank 0. It would make little sense having the 8355 respond to addresses in program memory bank 0 when using an 8048 or 8748, because the first 1024 bytes of program memory are internal to these microcomputers; that means the first 1024 bytes of 8355 memory would never be accessed. The 8049 microcomputer has 2048 bytes of on-chip program memory, so you would access no 8355 memory.

**8355 OR 8755  
CONNECTED  
TO AN 8048  
SERIES  
MICROCOMPUTER**

Control signals needed to read data out of 8355 program memory are easily derived. The 8048 ALE output is exactly what is needed for the 8355 ALE input. The memory strobe  $\overline{RD}$  required by the 8355 is adequately generated by the  $\overline{PSEN}$  output of the 8048.

**You can also access the 8355 I/O ports by connecting the  $\overline{RD}$  and  $\overline{WR}$  outputs of the 8048 to the  $\overline{IOR}$  and  $\overline{IOW}$  inputs of the 8355; the  $\overline{IOR}$  and  $\overline{IOW}$  control inputs of the 8355 were specifically designed for this purpose.**  $\overline{RD}$  and  $\overline{WR}$  control signals are generated by the 8048 series microcomputers in order to access data memory external to the microcomputer device itself. Thus the I/O ports of the 8355 device must be accessed within the address space of external data memory. In Figure 6-9 external data memory addresses 0, 1, 2 and 3 will access the 8355 I/O ports — and their respective Data Direction registers. Of course, the 8355 I/O ports can be accessed only while the 8355 is selected — via a high CE input.

**In order to attach standard memory devices to an 8048 series microcomputer, you must demultiplex the DB0 - DB7 lines to create separate Data and Address Busses. Figure 6-10 shows how to do this using two 8212 I/O ports.** 8212 I/O port operations are described in Chapter 4. In Figure 6-10 the 8212 I/O ports are being used as simple output ports without handshaking. By tying STB and MD high, the 8212 I/O ports will output whatever is being input while the device is selected. We use the ALE signal to complete selection of the 8212 I/O ports; thus while ALE is high the two ports are selected.

**STANDARD  
MEMORY  
DEVICES  
CONNECTED  
TO AN 8048  
SERIES  
MICROCOMPUTER**

Timing may be illustrated as follows:



Thus the 8212 ports output DB0 - DB7 or P20 - P23 levels latched while ALE is high. Once ALE goes low, 8212 port outputs remain constant.

#### **But there are a few subtleties associated with Figure 6-10.**

When an 8048 series microcomputer is accessing external program memory, a 12-bit address is output via DB0 - DB7 and P20 - P23; therefore the entire Address Bus is needed as illustrated. A low PSEN pulse serves as the external memory read strobe.

When 8048 series microcomputers access external data memory, however, only DB0 - DB7 is affected. Thus the second 8212 I/O port creates address lines A8 - A15, which will carry the most recent data output to I/O Port 2 — for example, you may set all I/O Port 2 pins to 0 during initialization. If I/O Port 2 is undefined, spurious selection of program memory will occur in configurations that include external program and data memory. At the time ALE is output as a high pulse no other signals indicate whether the subsequent memory access will involve program memory or data memory. It is only the separate control strobes — PSEN for program memory, WR and RD for data memory — that insure the correct memory module will be accessed. If your 8048 program uses I/O Port 2 for data output as well as for external memory addressing, you should buffer the System Bus; make sure, in this case, that the System Bus has sufficient capacity to handle two selected memory devices simultaneously.

Even though two memory devices may be selected simultaneously, you will not run into memory access contentions since program memory is strobed by PSEN while data memory is strobed by RD and WR. Only one of these signals will be active at any time.

#### **DEBUG MODE**

**You can bypass program memory internal to the 8048 series microcomputer by inputting a high signal at EA. While EA is high, timing for all program memory accesses will conform to external program memory accesses as illustrated in Figure 6-7. You may change the level of EA only when RESET is low; that is, you cannot switch between internal and external memory during program execution.**

Here is one of the ways in which you may use Debug mode:

In user end products an external memory device may contain test and verify programs. A service representative will execute these test and verify programs by applying a high input at EA. For example, you could connect an 8355 multi-function device to the 8048, selecting it via program memory bank 0. If EA is taken out to a switch, a serviceman will be able to execute programs out of the first 1024 bytes of 8355 program memory, instead of internal microcomputer memory.

**EA is also used by programming and verification modes. This use of EA, however, has nothing to do with Debug mode.**

#### **SINGLE STEPPING**

If you input a low signal at SS, then when ALE next pulses high, it will stay high until SS returns high. While ALE is high, instruction execution ceases and the current Program Counter contents are output via DB0 - DB7 and P20 - P23. Timing may be illustrated as follows:



The CPU only tests SS level while ALE is high. At other times SS level is irrelevant.

**Single stepping is an 8048 series microcomputer program debugging aid. Intel literature suggests the circuit illustrated in Figure 6-11 to create an SS signal that is initiated by an ALE pulse and terminated by a pushbutton.**



Figure 6-11. An 8048 Single Step Circuit

If you do not wish to single step, then connecting the Single Step switch in the Run position will hold PRESET at ground, which forces the Q output high; instructions will execute normally. With the Single Step switch in the Single Step position, PRESET is held high; now the ALE input to CLEAR becomes active. As soon as ALE goes low the Q output is also driven low; thus  $\bar{SS}$  is low. The low  $\bar{SS}$  is detected on the next high ALE pulse, at which time ALE remains high and the cycle is stopped. This condition persists until the pushbutton is depressed. Depressing the pushbutton creates a low-to-high clock transition which forces  $\bar{SS}$  high — thus terminating the stopped condition. **You, as a user, will see a program advance one instruction every time you press the pushbutton.**

**While an 8048 series microcomputer is stopped in a single step, the current Program Counter contents are output via the Bus Port (DB0 - DB7) and P20 - P23.** The Bus Port output presents no problem since you would expect to see address information output at this time. But if I/O Port 2 is being used as a regular I/O port, then prior data present on lines P20 - P23 will not be available during the address output. **Thus if you wish to view I/O data output while single stepping, you must latch I/O Port 2 data externally.**

## PROGRAMMING MODE

Of the 8048 microcomputer series, only the 87XX numbered microcomputer program memory can be written into. We will now examine the way in which the 8748 EPROM is programmed and verified.

In all probability, you will program an 87XX memory using a development tool which automates the entire process. That being the case, the event sequence which we are about to describe is not particularly interesting to you, since it is taken care of by the PROM programmer. But if you build your own PROM programmer, or if for any reason you need to understand the PROM programming sequence, then read on.

While programming and verifying the EPROM, you should input a clock signal at XTAL1 with a frequency between 1 and 6 MHz; you can also use the on-chip oscillator at this time.

Operations now proceed one byte at a time; you write a byte into program memory, then you verify that the data has been written correctly.



Figure 6-12. 8748 EPROM Programming and Verification Timing

In the discussion which follows, refer to Figure 6-12, which illustrates timing for the program/verify sequence.

- Step 1) Initially +5V is input at V<sub>DD</sub>, T0 and EA. RESET is held at ground. Under these conditions you insert the 8748 into the programming socket. **You must make certain to insert the 8748 correctly. If you insert the 8748 incorrectly you will destroy it.**
- Step 2) T0 is pulled to ground; this selects Programming mode.
- Step 3) +25V is applied to EA. This activates Programming mode.
- Step 4) A 10-bit memory address is applied via DB0 - DB7 and P20 - P23. Remember, there are 1024 bytes of program memory on the 8748 device. The low-order eight address bits are input via DB0 - DB7 while the two high-order address bits are input via P20 and P21.
- Step 5) +5V is applied at RESET. This latches the address.
- Step 6) The data to be written into the addressed programmed memory byte is input at DB0 - DB7.
- Step 7) In order to write the data into the addressed program memory byte apply +25V to V<sub>DD</sub>, then ground PROG, then apply a +25V pulse at PROG; the +25V pulse at PROG must last at least 50 milliseconds.
- Step 8) Now reduce V<sub>DD</sub> to +5V. Programming is complete and verification is about to begin.
- Step 9) In order to verify the data just written, apply +5V to the T0 input. This selects Verify mode.
- Step 10) As soon as Verify mode has been selected, the data just written is output on DB0 - DB7. You must read and verify this data using appropriate external circuitry. Verification is now complete.

In order to write into the next memory byte, select Programming mode again by connecting T0 and RESET to ground; then return to Step 3.

Repeat the program/verify sequence, byte-by-byte, until the entire program memory has been written into.

**In order to erase the EPROM expose it to ultraviolet light for a minimum of 20 minutes.**

## VERIFICATION MODE

You can verify the contents of an 8048 series microcomputer program memory at any time.

When verifying program memory contents for an 8048 series microcomputer with EPROM, you enter the Verify mode by applying +25V to the EA pin and +5V to the T0 pin. RESET must be held at ground while you apply +5V to the T0 pin.

Using an 8048 series microcomputer with ROM, you enter the Verify mode by applying +12V to the EA pin.

Once in the Verify mode, place the address of the program memory location which is to be read at DB0 - DB7 (low-order byte) and P20 - P21 (high-order four bits).

Latch this address by applying +5V to RESET.

While RESET is high, the contents of the addressed program memory location are output via DB0 - DB7.

You may repeat the verification process, byte-by-byte.

Verification timing is illustrated as follows:



## INPUT/OUTPUT PROGRAMMING

**8048 series microcomputers (with the exception of the 8021) have three I/O ports**, the physical characteristics of which we have already described. Instructions allow you to input or output Accumulator data via any one of the three I/O ports. You can also directly mask data resident at an I/O port using an AND mask or an OR mask.

There are two types of input/output beyond the 8048 series microcomputer chip itself.

The low-order four bits of I/O Port 2 may be connected to the 8243 Input/Output Expander which has four individually addressable 4-bit I/O ports. The 8243 Input/Output Expander is described later in this chapter.

You can also implement I/O ports within the external data memory address space for the expandable microcomputers of the 8048 series. We have already seen how you do this using an 8355 multifunction device connected to an 8048 series microcomputer. In this particular case the two I/O ports of the 8355 device are addressed as external data memory locations 0 and 1. Any other implementation of external I/O ports is allowed; however, in every case the I/O ports must be addressed as external data memory bytes using external data memory access instructions.

## HOLD STATE

There is no Hold state that external logic can induce in an 8048 series microcomputer. This is not unreasonable, since the purpose of the Hold state is to enable direct memory access operations — which would make little sense in a microcomputer system as small as an 8048, which has a maximum of 256 external data memory bytes.

## COUNTER/TIMER OPERATIONS

All 8048 series microcomputers have an internal counter/timer. Counter/timer logic may be illustrated as follows:



The Counter/Timer register is eight bits wide; it is accessed via Accumulator instructions, which move Accumulator contents to the Counter/Timer register or move Counter/Timer register contents to the Accumulator.

**Generally stated, this is how the counter/timer works:**

You begin by loading an initial value into the Counter/Timer register. Next, you start the counter/timer by executing the STRT T or STRT CNT instruction. The counter/timer will increment continuously until stopped by a Stop Counter/Timer instruction.

Whenever the counter/timer increments from FF16 to 0016, it activates a counter/timer interrupt request and sets a time-out flag. If the counter/timer interrupt has been enabled, then program execution will branch to the appropriate interrupt service routine. If the counter/timer interrupt has been enabled, then you must test for a time-out by executing the JTO Branch-on-Condition instruction.

**You can operate the counter/timer as a counter or as a timer.** The STRT T instruction operates the counter/timer as a timer, in which case the internal system clock increments the Timer register once every 480 crystal oscillations (80 microseconds, assuming a 6 MHz crystal).

You operate the counter/timer as a counter by executing the STRT CNT instruction. **Now high-to-low transitions of a signal input at T1 increment the counter.** The minimum time interval between high-to-low T1 transitions is 45 crystal oscillations (7.5 microseconds, assuming a 6 MHz crystal). There is no maximum delay between T1 high-to-low transitions. Once T1 goes high it must remain high for at least 3 crystal oscillations (500 nanoseconds, assuming a 6 MHz crystal).

You execute the STOP TCNT instruction to stop the counter/timer, whether it is operating as a counter or as a timer.

**Here is an instruction sequence which initiates the counter/timer operating as a timer with interrupts enabled:**

```
MOV    A,#TSTART ;LOAD INITIAL COUNTER/TIMER CONSTANT
MOV    T,A
EN    TCNTI      ;ENABLE TIMER INTERRUPT
STRT   T          ;START THE TIMER
```

The following instruction sequence operates the counter/timer as a counter with interrupts disabled:

```
DIS    TCNTI      ;DISABLE COUNTER INTERRUPT EARLY IN PROGRAM
```

```
-
-
-
MOV    A,#TSTART ;LOAD INITIAL COUNTER/TIMER CONSTANT
MOV    T,A
STRT   CNT       ;START COUNTER
```

## INTERNAL AND EXTERNAL INTERRUPTS

The 8048 series microcomputers have a simple interrupt scheme that is effective and adequate for small microcomputers. Interrupts can originate from one of three sources:

- 1) A Reset. This is a non-maskable interrupt.
- 2) An external interrupt induced by setting INT low. (This is not available on the 8041 and 8021 series microcomputers.)
- 3) A counter/timer interrupt which is automatically requested every time the Counter/Timer register increments from FF16 to 0016.

External interrupts and counter/timer interrupts can be enabled and disabled individually.

**When any one of the three interrupt requests is acknowledged, the microcomputer executes a Call instruction to one of these three locations:**

Reset: CALL 0  
External interrupt: CALL 3  
Counter/Timer interrupt: CALL 7

The Reset interrupt always has highest priority and cannot be disabled.

If an external interrupt request and a counter/timer interrupt request occur simultaneously, the external interrupt will be acknowledged first. **When either an external interrupt or a counter/timer interrupt is acknowledged, all interrupts (except Reset) are disabled until an RETR instruction is executed. Within an External or Timer interrupt service routine you cannot enable interrupts under program control.** This may be a problem if you are using the timer and external interrupts in timer sensitive applications. If execution time for an external interrupt's service routine extends over more than one counter/timer time out, then you will fail to detect one or more time outs. The simplest way of resolving this problem is to make sure that your External interrupt service routines are very short — executing in 75% of the counter/timer interval, or less. If this is not feasible, then you must monitor the counter/timer by testing its time out flag rather than by using counter/timer interrupt logic. You can execute the JTF conditional Jump instruction at frequent intervals within the main program and interrupt service routines, thus catching time outs irrespective of when they occur.

**You can re-enable interrupts within an interrupt service routine by executing a dummy RETR instruction.** Here is an appropriate instruction sequence:

START OF INTERRUPT SERVICE ROUTINE

```
CALL    ENAB      ;RE-ENABLE INTERRUPTS
EN     I
EN     TCNTI
```

END OF INTERRUPT SERVICE ROUTINE

```
ENAB   RETR
```

**Enabling interrupts within a service routine, as illustrated above, is not recommended** in an 8048 microcomputer system.

**Two problems need to be resolved when using external interrupts in an 8048 series microcomputer system: an interrupt acknowledge must be created, and in multiple interrupt configurations we must be able to identify the interrupting source.**

8048 series microcomputers have no interrupt acknowledge signal. An interrupt acknowledge signal must be created; otherwise external logic does not know when to remove its interrupt request. And if the interrupt request remains after an RETR instruction executes, the interrupt will be reacknowledged. **The only straightforward way of acknowledging an interrupt is to assign one of the I/O port pins to serve as an interrupt acknowledge signal.** The external interrupt service routine will begin by outputting an appropriate low pin signal. **Here is one possibility:**

```
ANL    P1,#7FH      ;RESET PIN 7 OF I/O PORT 1 LOW
ORL    P1,#80H      ;SET PIN 7 OF I/O PORT 1 HIGH
```

Here, the output at pin 7 of I/O Port 1 is a low pulse with a duration of two machine cycles (5.0 microseconds).

But remember, if you use an I/O port pin as an interrupt acknowledge, you cannot use the same pin to perform standard I/O operations.



Figure 6-13. An Eight-Device Daisy Chained Interrupt Request/Acknowledge Scheme

If there are many external devices which can request interrupt service, then the most effective way of handling multiple interrupts is via a daisy chain. Daisy chain logic has been discussed in Volume I — Basic Concepts. The acknowledged device in the daisy chain must create a device code that is input to an I/O port. **Figure 6-13 illustrates a scheme whereby eight devices in a daisy chain may request interrupt service, and upon being acknowledged, the selected device will input a unique code to I/O Port 1.** The high-order bit of I/O Port 1 serves as an interrupt acknowledge. I/O Port 1 bits 0, 1 and 2 receive as inputs a 3-bit code identifying the acknowledged device.

The daisy chain logic in Figure 6-13 is created using a chain of eight AND gates and eight NAND gates. The AND gates are chained in order of priority, with INT0 having the highest priority and INT7 having the lowest priority. The first NAND gate receives as its inputs INT0 and the acknowledge signal output via pin 7 of I/O Port 1. Subsequent NAND gates receive as their inputs an interrupt request signal, the acknowledge signal and the output of the previous AND gate. The output of each NAND gate becomes an interrupt acknowledge signal which is low-true. Thus in Figure 6-13 there are eight low-true interrupt requests, represented by signals INT0 through INT7, and there are eight low-true interrupt acknowledges, represented by IACK0 through IACK7. Each external device capable of requesting an interrupt must output a low-true INTn which it removes upon receiving a low-true IACKn. For device 3 this may be illustrated as follows:



The eight interrupt request signals INT0 through INT7 are input to an AND gate. The AND gate generates a master low-true interrupt request, INT. If any one or more of the INTn signals are low, then the AND gate will output a low INT.

The eight interrupt acknowledge signals IACK0 - IACK7 are input to an 8-to-3 Decoder. The 8-to-3 Decoder will receive seven high signals and one low signal. The one low signal will be identified by the decoder 3-bit output which is transmitted to pins 0, 1 and 2 of I/O Port 1.

This then is the event sequence associated with an interrupt request:

- 1) INT is input low to the 8048.
- 2) The interrupt is acknowledged by the CPU, which branches to an interrupt service routine.
- 3) The first instruction of the interrupt service routine outputs a low level via pin 7 of I/O Port 1.
- 4) The interrupt service routine receives back, via pins 0, 1 and 2 of I/O Port 1, the device code for the acknowledged device. You must make sure that the program being executed gives external logic time to return this code. You may have to insert No Operation instructions to create the necessary time delay.
- 5) A high level is output via pin 7 of I/O Port 1.
- 6) Using the code input via pins 0, 1 and 2 of I/O Port 1, branch to the appropriate interrupt service routine.

**Here is the initial instruction sequence required by the logic of Figure 6-13:**

```
ORG      3
;START OF INTERRUPT SERVICE ROUTINE
JMP      EXTINT
-
-
ORG      EXTINT
ANL      P1,#7FH      ;SET I/O PORT 1 PIN 7 LOW
NOP      -            ;ALLOW SETTLING TIME
IN       A,P1         ;INPUT PORT 1 CONTENTS
ORL      P1,#80H      ;SET I/O PORT 1 PIN 7 HIGH
ANL      A,#7         ;CLEAR ALL ACCUMULATOR BITS BAR 0, 1 AND 2
JMPP    @A           ;JUMP TO IDENTIFIED INTERRUPT SERVICE ROUTINE
```

**Let us examine the interrupt service routine beginning instruction sequence illustrated above.**

When an 8048 series microcomputer is initially reset, all I/O port pins output high levels. Thus you do not have to initialize pin 7 of I/O Port 1 to a high level.

We actually identify one of eight device interrupt service routines by creating a 3-bit code in bits 1, 2 and 3 of the Accumulator. We then perform an indirect Jump. This Jump instruction will branch to a location on the current page of program memory: the address is fetched from the location in the current page addressed by the Accumulator contents. We illustrated this addressing technique earlier in the chapter.

Given the instruction sequence illustrated above, the first eight program memory locations on the same page as the JMPP instruction must be set aside for eight addresses: these are the starting addresses for the interrupt service routines. This may be illustrated as follows:

```
ORG      #0300H
DB       IS0          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 0
DB       IS1          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 1
DB       IS2          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 2
DB       IS3          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 3
DB       IS4          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 4
DB       IS5          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 5
DB       IS6          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 6
DB       IS7          ;ADDRESS OF INTERRUPT SERVICE ROUTINE 7
EXTINT  ANL      #7FH      ;SET I/O PORT 1 PIN 7 LOW
-
-
```

**The daisy chained interrupt scheme discussed above can also be implemented using the circuit in Figure 6-14. The advantage of this circuit is that it requires fewer chips than the circuit of Figure 6-13. As far as the 8048 program is concerned, however, the two circuits are identical.**

The INT and device code inputs are generated in exactly the same way. However, an eight-line-to-three-line priority encoder (9318 or 74148) replaces the network of AND gates. As the function table for the encoder shows, the device code output on lines A2, A1 and A0 is that of the highest priority request. The CPU enables the code outputs by sending the acknowledge signal.



| 74LS138, 74S138 FUNCTION TABLE |        |         |   |   |                |                |                | 9318, 74148 FUNCTION TABLE |                |                |                |                |    |                |                | INPUTS         |                |                |                |                |                |                |                | OUTPUTS        |    |    |  |
|--------------------------------|--------|---------|---|---|----------------|----------------|----------------|----------------------------|----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----|--|
| INPUTS                         |        | OUTPUTS |   |   |                |                |                | INPUTS                     |                |                |                |                |    |                |                | OUTPUTS        |                |                |                |                |                |                |                |                |    |    |  |
| ENABLE                         | SELECT | C       | B | A | Y <sub>0</sub> | Y <sub>1</sub> | Y <sub>2</sub> | Y <sub>3</sub>             | Y <sub>4</sub> | Y <sub>5</sub> | Y <sub>6</sub> | Y <sub>7</sub> | EI | I <sub>0</sub> | I <sub>1</sub> | I <sub>2</sub> | I <sub>3</sub> | I <sub>4</sub> | I <sub>5</sub> | I <sub>6</sub> | I <sub>7</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | GS | EO |  |
| X                              | H      | X       | X | X | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | X              | X              | X              | X              | X              | X              | X              | X              | H              | H              | H  |    |  |
| L                              | X      | X       | X | X | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | H              | H              | H              | H              | H              | H              | H              | H              | H              | L  |    |  |
| H                              | L      | L       | L | L | L              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | X              | X              | X              | X              | L              | L              | L              | H  |    |  |
| H                              | L      | L       | L | H | H              | L              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | X              | X              | X              | X              | L              | H              | L              | H  |    |  |
| H                              | L      | L       | H | L | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | X              | X              | X              | X              | L              | H              | L              | H  |    |  |
| H                              | L      | L       | H | H | H              | H              | H              | L                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | X              | X              | X              | X              | L              | H              | L              | H  |    |  |
| H                              | L      | H       | L | L | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | X              | X              | X              | X              | L              | H              | L              | H  |    |  |
| H                              | L      | H       | L | H | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | X              | X              | X              | X              | L              | H              | L              | H  |    |  |
| H                              | L      | H       | H | L | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | L              | H              | H              | H              | H              | H              | L              | H  |    |  |
| H                              | L      | H       | H | H | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | X              | L              | H              | H              | H              | H              | H              | L              | H  |    |  |
| H                              | L      | H       | H | H | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | L              | H              | H              | H              | H              | H              | H              | L              | H  |    |  |
| H                              | L      | H       | H | H | H              | H              | H              | H                          | H              | H              | H              | H              | H  | H              | L              | X              | L              | H              | H              | H              | H              | H              | H              | H              | L  |    |  |

\*G<sub>2</sub> = G<sub>2A</sub> V G<sub>2B</sub>      H = high level,      L = low level,      X = irrelevant

Figure 6-14. A Low Chip Count Implementation of an Eight-Device Daisy Chained Interrupt Request/Acknowledge Scheme

In Figure 6-13, a network of NAND gates generated the low-true interrupt acknowledge signal to inform the appropriate device that its interrupt was being serviced. In Figure 6-14, a three-line-to-eight-line decoder (74S138 or 74LS138) translates the device code output by the encoder and sets the corresponding acknowledge line low, as is shown in the function table for the decoder.

Connecting the enable inputs as shown prevents spurious acknowledgements or phantom device codes, provided that the CPU gives the external devices time for response and propagation delay.

# THE 8048 MICROCOMPUTER SERIES INSTRUCTION SET

**Table 6-2 summarizes the instruction set for the 8048 series microcomputers. Instruction object codes and timing are given in Table 6-3.** This instruction set reflects the specific architecture of 8048 series microcomputers. For example, there are separate I/O instructions to access the three on-chip I/O ports, as against 8243 Input/Output Expander I/O ports. Also, there are separate instructions to access on-chip scratchpad read/write memory, as against external data memory.

**The 8048 instruction set is probably more versatile than any other one-chip microcomputer instruction set described in this book.** The only omission that may cause problems is the lack of an Overflow status; this will make multibyte signed binary arithmetic harder to program.

## THE BENCHMARK PROGRAM

The benchmark program we have been using in this book is not realistic for the 8048 with its limited data memory. Using the 8048 you would not load data into some general depository, then transfer it to a specific data table.

In order to provide some illustration of 8048 instructions, however, we will slightly modify the benchmark program and move a number of data bytes from the top of scratchpad memory to a table in external data memory. Since the data in scratchpad memory must have been input from an I/O port, we will assume that the number of scratchpad memory bytes is stored in General Purpose Register R7. The table in external memory begins at a known location and the first table byte addresses the first free table location. Operations performed may be illustrated as follows:



```

MOV    R0,#TBASE      ;LOAD EXTERNAL TABLE BASE ADDRESS INTO R0
MOVX   A,@R0          ;LOAD ADDRESS OF FIRST FREE BYTE INTO A
MOV    R1,A           ;SAVE IN R1
ADD    A,R7           ;ADD NEW BYTE COUNT TO A
MOVX   @R0,A          ;RESTORE IN FIRST FREE BYTE OF EXTERNAL TABLE
MOV    R0,#3FH         ;LOAD SCRATCHPAD ADDRESS INTO R0
MOV    A,@R0          ;MOVE DATA FROM SCRATCHPAD TO A
MOVX   @R1,A          ;STORE IN EXTERNAL DATA TABLE
DEC    R0             ;DECREMENT R0
INC    R1             ;INCREMENT R1
DJNZ   R7,LOOP        ;DECREMENT R7, SKIP IF NOT ZERO

```

**These are the abbreviations used in Table 6-2:**

|      |                                                                             |
|------|-----------------------------------------------------------------------------|
| A    | The Accumulator                                                             |
| A03  | Accumulator bits 0-3                                                        |
| R    | Register R0 or R1                                                           |
| REG  | Accumulator, R0, R1, R2, R3, R4, R5, R6 or R7                               |
| RN   | Register R0, R1, R2, R3, R4, R5, R6 or R7                                   |
| T    | Timer/Counter                                                               |
| C    | Carry status                                                                |
| AC   | Auxiliary Carry status                                                      |
| MB0  | Program memory bank 0                                                       |
| MB1  | Program memory bank 1                                                       |
| MBN  | MB0 or MB1                                                                  |
| I    | The Instruction register                                                    |
| I2   | Second object code byte                                                     |
| PC   | The Program Counter                                                         |
| PC10 | The Program Counter, bits 0-10                                              |
| PCL  | The Program Counter, bits 0-7                                               |
| PCH  | The Program Counter, bits 8-11                                              |
| SP   | Stack Pointer: PSW bits 0, 1 and 2                                          |
| PSW  | The Program Status Word which has bits assigned to status flags as follows: |



|        |                                                                         |
|--------|-------------------------------------------------------------------------|
| S      | PSW bit C, F0 or F1                                                     |
| DATA   | 8-bit immediate data                                                    |
| DEV    | An I/O device                                                           |
| PORT   | I/O Port P1, P2 or BUS                                                  |
| ADDR   | An 11-bit address, specifying a data memory byte                        |
| ADDR8  | The low-order eight bits of a memory address                            |
| [ ]    | Contents of location identified within brackets                         |
| [[ ]]  | Scratchpad memory byte addressed by location identified within brackets |
| { [ ]} | External memory byte addressed by location identified within brackets   |
| ( [ ]) | Program memory byte addressed by location identified within brackets    |

|     |                                                        |
|-----|--------------------------------------------------------|
| ←   | Move data in direction of arrow                        |
| ↔   | Exchange contents of locations on either side of arrow |
| +   | Add                                                    |
| -   | Subtract                                               |
| Λ   | AND                                                    |
| ∨   | OR                                                     |
| ✗   | Exclusive-OR                                           |
| BUS | Bus I/O port                                           |
| P1  | I/O Port 1                                             |
| P2  | I/O Port 2                                             |
| EP  | 8243 Expander Port P4, P5, P6 or P7                    |
| PN  | P1 or P2                                               |

Table 6-2. A Summary of 8048 Microcomputer Instruction Set

| TYPE                     | MNEMONIC | OPERAND(S) | 8021 | 8041 | 8048<br>8049 | BYTES | STATUS |    | OPERATION PERFORMED                                                                                                                                                      |
|--------------------------|----------|------------|------|------|--------------|-------|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          |          |            |      |      |              |       | C      | AC |                                                                                                                                                                          |
| I/O                      | ANL      | PORT,#DATA |      |      |              | 2     |        |    | [PORT]—[PORT] A DATA<br>AND immediate data with I/O Port P1, P2 or BUS                                                                                                   |
|                          | ANLD     | EP,A       |      |      |              | 1     |        |    | [EP]—[A03] A [EP]<br>AND expander port P4, P5, P6 or P7 with Accumulator bits 0 - 3                                                                                      |
|                          | IN       | A,PN       |      |      |              | 1     |        |    | [A]—[PN]<br>Input I/O Port P1 or P2 to Accumulator                                                                                                                       |
|                          | IN       | A,DBB      |      |      |              | 1     |        |    | [A]—[BUS]<br>Input to Accumulator from Data Bus buffer                                                                                                                   |
|                          | INS      | A,BUS      |      |      |              | 1     |        |    | [A]—[BUS]<br>Input BUS to Accumulator with strobe                                                                                                                        |
|                          | MOVD     | A,EP       |      |      |              | 1     |        |    | [A03]—[EP]<br>Input expander port P4, P5, P6 or P7 to Accumulator bits 0 - 3                                                                                             |
|                          | MOVD     | EP,A       |      |      |              | 1     |        |    | [EP]—[A03]<br>Output Accumulator bits 0 - 3 to expander port P4, P5, P6 or P7                                                                                            |
|                          | ORL      | PORT,#DATA |      |      |              | 2     |        |    | [PORT]—[PORT] V DATA<br>OR immediate data with I/O Port P1, P2 or BUS                                                                                                    |
|                          | ORLD     | EP,A       |      |      |              | 1     |        |    | [EP]—[A03] V [EP]<br>OR Accumulator bits 0 - 3 with expander port P4, P5, P6 or P7                                                                                       |
|                          | OUT      | DBB,A      |      |      |              | 1     |        |    | [BUS]—[A]<br>Output from Accumulator to Data Bus buffer                                                                                                                  |
|                          | OUTL     | PORT,A     |      |      |              | 1     |        |    | [PORT]—[A]<br>Output Accumulator contents to I/O Port P1, P2 (or BUS 8048, 8049 only)                                                                                    |
| PRIMARY MEMORY REFERENCE | MOV      | A,@R       |      |      |              | 1     |        |    | [A]—[[R]]<br>Load contents of scratchpad byte addressed by R0 or R1 into Accumulator                                                                                     |
|                          | MOV      | @R,A       |      |      |              | 1     |        |    | [[R]]—[A]<br>Store Accumulator contents in scratchpad byte addressed by R0 or R1                                                                                         |
|                          | MOV#P    | A,@A       |      |      |              | 1     |        |    | [A]—[[PCH][A]]<br>Load into the Accumulator the contents of the program memory byte addressed by the Accumulator and Program Counter bits 8 - 11.                        |
|                          | MOV#P3   | A,@A       |      |      |              | 1     |        |    | [A]—{3[A]}<br>Load into the Accumulator the contents of the program memory byte with binary address 0011XXXXXXXX where XXXXXXXX represents initial Accumulator contents. |
|                          | MOVX     | A,@R       |      |      |              | 1     |        |    | [A]—{[R]}<br>Load contents of external data memory byte addressed by R0 or R1 into Accumulator                                                                           |
|                          | MOVX     | @R,A       |      |      |              | 1     |        |    | {[R]}—[A]<br>Store Accumulator contents in external data memory byte addressed by R0 or R1                                                                               |
|                          | XCH      | A,@R       |      |      |              | 1     |        |    | [A]—[[R]]<br>Exchange contents of Accumulator and scratchpad memory byte addressed by R0 or R1                                                                           |
|                          | XCHD     | A,@R       |      |      |              | 1     |        |    | [A03]—[[R]03]<br>Exchange contents of Accumulator bits 0 - 3 with bits 0 - 3 of scratchpad memory byte addressed by R0 or R1                                             |

Table 6-2. A Summary of 8048 Microcomputer Instruction Set (Continued)

| TYPE                                           | MNEMONIC | OPERAND(S) | 8021 | 8041 | 8048<br>8049 | BYTES | STATUS |    | OPERATION PERFORMED                                                                                                                                                                                                              |
|------------------------------------------------|----------|------------|------|------|--------------|-------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                |          |            |      |      |              |       | C      | AC |                                                                                                                                                                                                                                  |
| SECONDARY MEMORY REFERENCE<br>(MEMORY OPERATE) | ADD      |            |      |      |              | 1     | X      | X  | $[A] \leftarrow [A] + [[R]]$<br>Add contents of scratchpad byte addressed by R0 or R1 to Accumulator                                                                                                                             |
|                                                | ADDC     |            |      |      |              | 1     | X      | X  | $[A] \leftarrow [A] + [[R]] + [C]$<br>Add contents of scratchpad byte addressed by R0 or R1, plus Carry, to Accumulator                                                                                                          |
|                                                | ANL      |            |      |      |              | 1     |        |    | $[A] \leftarrow [A] \wedge [[R]]$<br>AND contents of scratchpad byte addressed by R0 or R1 with Accumulator                                                                                                                      |
|                                                | ORL      |            |      |      |              | 1     |        |    | $[A] \leftarrow [A] \vee [[R]]$<br>OR contents of scratchpad byte addressed by R0 or R1 with Accumulator                                                                                                                         |
|                                                | XRL      |            |      |      |              | 1     |        |    | $[A] \leftarrow [A] \vee\vee [[R]]$<br>Exclusive OR contents of scratchpad byte addressed by R0 or R1 with Accumulator                                                                                                           |
|                                                | INC      |            |      |      |              | 1     |        |    | $[[R]] \leftarrow [[R]] + 1$<br>Increment the contents of the scratchpad byte addressed by R0 or R1                                                                                                                              |
| IMMEDIATE                                      | MOV      |            |      |      |              | 2     |        |    | $[REG] \leftarrow DATA$<br>Load immediate data into Accumulator, or Register R0, R1, R2, R3, R4, R5, R6 or R7                                                                                                                    |
|                                                | MOV      |            |      |      |              | 2     |        |    | $[[R]] \leftarrow DATA$<br>Load immediate data into scratchpad byte addressed by R0 or R1                                                                                                                                        |
| JUMP                                           | JMP      | ADDR       |      |      |              | 2     |        |    | $[PC10] \leftarrow ADDR$<br>Jump to instruction in current 2K block having label ADDR                                                                                                                                            |
|                                                | JMPP     | @A         |      |      |              | 1     |        |    | $[PC] \leftarrow [PCH][A], [PCL] \leftarrow ([PCH][A])$<br>Load into the eight low order Program Counter bits the contents of the program memory byte addressed by the Accumulator and the four high order Program Counter bits. |
|                                                | SEL      | MB0        |      |      |              | 1     |        |    | With the next JMP or CALL instruction, reset the high order bit of PC to 0, thus selecting first 2K program memory bytes.                                                                                                        |
|                                                | SEL      | MB1        |      |      |              | 1     |        |    | With the next JMP or CALL instruction, set high order bit of PC to 1, thus selecting second 2K program memory bytes.                                                                                                             |
| SUBROUTINE CALL AND RETURN                     | CALL     | ADDR       |      |      |              | 2     |        |    | $STACK \leftarrow STATUS + [PC], [SP] \leftarrow [SP] + 1, [PC] \leftarrow ADDR$<br>Call subroutine at specified address.                                                                                                        |
|                                                | RET      |            |      |      |              | 1     |        |    | $[PC] \leftarrow STACK, [SP] \leftarrow [SP]-1$<br>Return from subroutine without restoring status                                                                                                                               |
|                                                | RETR     |            |      |      |              | 1     | X      | X  | $[PC] + STATUS \leftarrow STACK, [SP] \leftarrow [SP]-1$<br>Return from subroutine and restore status                                                                                                                            |

Table 6-2. A Summary of 8048 Microcomputer Instruction Set (Continued)

| TYPE              | MNEMONIC | OPERAND(S) | 8021 | 8041 | 8048<br>8049 | BYTES | STATUS |    | OPERATION PERFORMED                                                                                                                                                       |
|-------------------|----------|------------|------|------|--------------|-------|--------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |          |            |      |      |              |       | C      | AC |                                                                                                                                                                           |
| IMMEDIATE OPERATE | ADD      | A,#DATA    | X    | X    | X            | 2     | X      | X  | [A]-[A]+DATA<br>Add immediate data to Accumulator                                                                                                                         |
|                   | ADDC     | A,#DATA    | X    | X    | X            | 2     | X      | X  | [A]-[A]+DATA+[C]<br>Add immediate data plus Carry to Accumulator                                                                                                          |
|                   | ANL      | A,#DATA    | X    | X    | X            | 2     |        |    | [A]-[A] AND immediate data with Accumulator contents                                                                                                                      |
|                   | ORL      | A,#DATA    | X    | X    | X            | 2     |        |    | [A]-[A] OR immediate data with Accumulator contents                                                                                                                       |
|                   | XRL      | A,#DATA    | X    | X    | X            | 2     |        |    | [A]-[A] XOR immediate data with Accumulator contents                                                                                                                      |
| JUMP ON CONDITION | DJNZ     | RN,ADDR8   |      |      |              | 2     |        |    | [RN]-[RN]-1. If [RN] ≠ 0, [PCL]—ADDR8<br>Decrement Register R0, R1, R2, R3, R4, R5, R6 or R7. If the result is not 0, branch to ADDR8 on the current program memory page. |
|                   | JBb      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if Accumulator bit b is 1. b must be 0, 1, 2, 3, 4, 5, 6 or 7                                                                         |
|                   | JC       | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if Carry is 1                                                                                                                         |
|                   | JF0      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if flag F0 is 1                                                                                                                       |
|                   | JF1      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if flag F1 is 1                                                                                                                       |
|                   | JNC      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if Carry is 0                                                                                                                         |
|                   | JNI      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if interrupt request input is 0                                                                                                       |
|                   | JNIBF    | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump if IBF flag is 0                                                                                                                                      |
|                   | JNT0     | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if T0 input is 0                                                                                                                      |
|                   | JNT1     | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if T1 input is 0                                                                                                                      |
|                   | JNZ      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if Accumulator contents is nonzero                                                                                                    |
|                   | JOBF     | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump if OBF flag is 1                                                                                                                                      |
|                   | JTF      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if timer has timed out, that is, if timer flag is 1. The timer flag is reset to 0 by this instruction.                                |
|                   | JTO      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if T0 input is 1                                                                                                                      |
|                   | JT1      | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if T1 input is 1                                                                                                                      |
|                   | JZ       | ADDR8      |      |      |              | 2     |        |    | [PCL]—ADDR8<br>Jump on current page if Accumulator contents are zero                                                                                                      |

Table 6-2. A Summary of 8048 Microcomputer Instruction Set (Continued)

| TYPE                         | MNEMONIC | OPERAND(S) | 8021 | 8041 | 8048<br>8049 | BYTES | STATUS |    | OPERATION PERFORMED                                                                                                                          |
|------------------------------|----------|------------|------|------|--------------|-------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------|
|                              |          |            |      |      |              |       | C      | AC |                                                                                                                                              |
| REGISTER-<br>REGISTER MOVE   | MOV      | A,RN       |      |      |              | 1     |        |    | [A]—[RN]<br>Move the contents of a general purpose register to the Accumulator                                                               |
|                              | MOV      | RN,A       |      |      |              | 1     |        |    | [RN]—[A]<br>Move the Accumulator contents to a general purpose register                                                                      |
|                              | XCH      | A,RN       |      |      |              | 1     |        |    | [A]—→[RN]<br>Exchange the Accumulator contents with the contents of a general purpose register                                               |
| REGISTER-REGISTER<br>OPERATE | ADD      | A,RN       |      |      |              | 1     | X      | X  | [A]—[A]+[RN]<br>Add the contents of a general purpose register to the Accumulator                                                            |
|                              | ADDC     | A,RN       |      |      |              | 1     | X      | X  | [A]—[A]+[RN]+[C]<br>Add the contents of a general purpose register, plus Carry, to the Accumulator                                           |
|                              | ANL      | A,RN       |      |      |              | 1     |        |    | [A]—[A] ∧ [RN]<br>AND the contents of a general purpose register with the Accumulator                                                        |
|                              | ORL      | A,RN       |      |      |              | 1     |        |    | [A]—[A] ∨ [RN]<br>OR the contents of a general purpose register with the Accumulator                                                         |
|                              | XRL      | A,RN       |      |      |              | 1     |        |    | [A]—[A]⊕[RN]<br>Exclusive-OR the contents of a general purpose register with the Accumulator                                                 |
| REGISTER OPERATE             | CLR      | A          |      |      |              | 1     |        |    | [A]—0<br>Zero the Accumulator                                                                                                                |
|                              | CPL      | A          |      |      |              | 1     |        |    | [A]—[A]<br>Complement the Accumulator                                                                                                        |
|                              | DAA      |            |      |      |              | 1     |        |    | Decimal adjust Accumulator contents                                                                                                          |
|                              | DEC      | REG        |      |      |              | 1     |        |    | [REG]—[REG]-1<br>Decrement the contents of the Accumulator or general purpose register.<br>The 8021 can only decrement Accumulator contents. |
|                              | INC      | REG        |      |      |              | 1     |        |    | [REG]—[REG]+1<br>Increment the contents of the Accumulator or general purpose register                                                       |
|                              | RL       | A          |      |      |              | 1     |        |    | Rotate Accumulator left                                                                                                                      |
|                              | RLC      | A          |      |      |              | 1     | X      |    | Rotate Accumulator left through Carry                                                                                                        |
|                              | RR       | A          |      |      |              | 1     |        |    | Rotate Accumulator right                                                                                                                     |

Table 6-2. A Summary of 8048 Microcomputer Instruction Set (Continued)

| TYPE                         | MNEMONIC | OPERAND(S) | 8021 | 8041 | 8048<br>8049 | BYTES | STATUS |    | OPERATION PERFORMED                                                                                                                    |
|------------------------------|----------|------------|------|------|--------------|-------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------|
|                              |          |            |      |      |              |       | C      | AC |                                                                                                                                        |
| REGISTER OPERATE (CONTINUED) | RRC      | A          |      |      |              | 1     | X      |    | Rotate Accumulator right through Carry<br>                                                                                             |
|                              | SEL      | RBO        |      |      |              | 1     |        |    | Select register bank 0                                                                                                                 |
|                              | SEL      | RB1        |      |      |              | 1     |        |    | Select register bank 1                                                                                                                 |
|                              | SWAP     | A          |      |      |              | 1     |        |    | Swap Accumulator nibbles<br>                                                                                                           |
| INTERRUPT                    | .DIS     | TCNTI      |      |      |              | 1     |        |    | Disable timer interrupt                                                                                                                |
|                              | EN       | TCNTI      |      |      |              | 1     |        |    | Enable timer interrupt                                                                                                                 |
|                              | .DIS     | I          |      |      |              | 1     |        |    | Disable external interrupt                                                                                                             |
|                              | EN       | I          |      |      |              | 1     |        |    | Enable external interrupts                                                                                                             |
| TIMERS                       | ENT0     | CLK        |      |      |              | 1     |        |    | Enable timer output on T0 until next system reset                                                                                      |
|                              | MOV      | A,T        |      |      |              | 1     |        |    | [A]—[T]<br>Read timer/counter                                                                                                          |
|                              | MOV      | T,A        |      |      |              | 1     |        |    | [T]—[A]<br>Load timer/counter                                                                                                          |
|                              | STOP     | TCNT       |      |      |              | 1     |        |    | Stop timer/counter                                                                                                                     |
| COUNTERS                     | STRT     | CNT        |      |      |              | 1     |        |    | Start counter                                                                                                                          |
|                              | STRT     | T          |      |      |              | 1     |        |    | Start timer                                                                                                                            |
|                              | CLR      | S          |      |      |              | 1     | 0      |    | Clear PSW bit C, F0 or F1. 8021 can only clear Carry.                                                                                  |
|                              | CPL      | S          |      |      |              | 1     | X      |    | Complement PSW bit C, F0 or F1. 8021 can only complement Carry.                                                                        |
| PSW                          | MOV      | A,PSW      |      |      |              | 1     | X      | X  | [A]—[PSW]<br>Move Program Status Word contents to the Accumulator<br>[PSW]—[A]<br>Move Accumulator contents to the Program Status Word |
|                              | MOV      | PSW,A      |      |      |              | 1     |        |    | No Operation                                                                                                                           |

The following symbols are used in Table 6-3:

- bbb Three bits designating which bit of the Accumulator is to be tested.
- ee Two bits designating an 8243 Expander port:
  - 00 - P4
  - 01 - P5
  - 10 - P6
  - 11 - P7
- k One bit selecting a memory or register bank:
  - 0 MBO or RBO
  - 1 MB1 or RB1
- MM Eight bits of immediate data
- nnn Three bits designating one of the eight general purpose registers
- pp Two bits designating one of the on-chip I/O ports:
  - 00 - BUS
  - 01 - P1
  - 10 - P2
- qq Two bits designating either I/O Port 1 or I/O Port 2:
  - 01 - P1
  - 10 - P2
- r One bit selecting a pointer register:
  - 0 - R0
  - 1 - R1
- xxx The high-order three bits of a program memory address
- XX The low-order eight bits of a program memory address

Table 6-3. 8048 Series Instruction Set Object Codes

| INSTRUCTION    | OBJECT CODE | BYTES | MACHINE CYCLES | INSTRUCTION    | OBJECT CODE | BYTES | MACHINE CYCLES |
|----------------|-------------|-------|----------------|----------------|-------------|-------|----------------|
| ADD A,RN       | 01101nnn    | 1     | 1              | JOBF ADDR8     | 86 XX       | 2     | 2              |
| ADD A,@R       | 0110000r    | 1     | 1              | JTF ADDR8      | 16 XX       | 2     | 2              |
| ADD A,#DATA    | 03 MM       | 2     | 2              | JTO ADDR8      | 36 XX       | 2     | 2              |
| ADDC A,RN      | 01111nnn    | 1     | 1              | JT1 ADDR8      | 56 XX       | 2     | 2              |
| ADDC A,@R      | 0111000r    | 1     | 1              | JZ ADDR8       | C6 XX       | 2     | 2              |
| ADDC A,#DATA   | 13 MM       | 2     | 2              | MOV A,#DATA    | 23 MM       | 2     | 2              |
| ANL A,RN       | 01011nnn    | 1     | 1              | MOV A,PSW      | C7          | 1     | 1              |
| ANL A,@R       | 0101000r    | 1     | 1              | MOV A,RN       | 11111nnn    | 1     | 1              |
| ANL A,#DATA    | 53 MM       | 2     | 2              | MOV A,@R       | 1111000r    | 1     | 1              |
| ANL PORT,#DATA | 100110pp    | 2     | 2              | MOV A,T        | 42          | 1     | 1              |
|                | MM          |       |                | MOV PSW,A      | D7          | 1     | 1              |
| ANLD EP,A      | 100111ee    | 1     | 2              | MOV RN,A       | 10101nnn    | 1     | 1              |
| CALL ADDR      | xxx10100    | 2     | 2              | MOV RN,#DATA   | 10111nn     | 2     | 2              |
|                | XX          |       |                | MM             |             |       |                |
| CLR A          | 27          | 1     | 1              | MOV @R,A       | 1010000r    | 1     | 1              |
| CLR C          | 97          | 1     | 1              | MOV @R,#DATA   | 1011000r    | 2     | 2              |
| CLR F1         | A5          | 1     | 1              | MOV T,A        | 62          | 1     | 1              |
| CLR F0         | 85          | 1     | 1              | MOVD A,EP      | 000011ee    | 1     | 2              |
| CPL A          | 37          | 1     | 1              | MOVD EP,A      | 001111ee    | 1     | 2              |
| CPL C          | A7          | 1     | 1              | MOV P A,@A     | A3          | 1     | 2              |
| CPL F0         | 95          | 1     | 1              | MOV P3 A,@A    | E3          | 1     | 2              |
| CPL F1         | 85          | 1     | 1              | MOVX A,@R      | 1000000r    | 1     | 2              |
| DA A           | 57          | 1     | 1              | MOVX @R,A      | 1001000r    | 1     | 2              |
| DEC A          | 07          | 1     | 1              | NOP            | 00          | 1     | 1              |
| DEC RN         | 11001nnn    | 1     | 1              | ORL A,RN       | 01001nnn    | 1     | 1              |
| DIS I          | 15          | 1     | 1              | ORL A,@R       | 0100000r    | 1     | 1              |
| DIS TCNTI      | 35          | 1     | 1              | ORL A,#DATA    | 43 MM       | 2     | 2              |
| DJNZ RN,ADDR8  | 11101rrr    | 2     | 2              | ORL PORT,#DATA | 100010pp    | 2     | 2              |
|                | XX          |       |                | MM             |             |       |                |
| EN I           | 05          | 1     | 1              | ORLD EP,A      | 100011ee    | 1     | 2              |
| EN TCNTI       | 25          | 1     | 1              | OUT DBB,A      | 02          | 1     | 1              |
| ENT0 CLK       | 75          | 1     | 1              | OUTL BUS,A     | 02          | 1     | 2              |
| IN A,PN        | 000010qq    | 1     | 2              | OUTL PN,A      | 001110qq    | 1     | 2              |
| IN A,DBB       | 22          | 1     | 1              | RET            | 83          | 1     | 2              |
| INC A          | 17          | 1     | 1              | RETR           | 93          | 1     | 2              |
| INC RN         | 00011nnn    | 1     | 1              | RL A           | E7          | 1     | 1              |
| INC @R         | 0001000r    | 1     | 1              | RLC A          | F7          | 1     | 1              |
| INS A,BUS      | 08          | 1     | 2              | RR A           | 77          | 1     | 1              |
| JBb ADDR8      | bbb10010    | 2     | 2              | RRC A          | 67          | 1     | 1              |
|                | XX          |       |                | SEL MBK        | 111k0101    | 1     | 1              |
| JC ADDR8       | F6 XX       | 2     | 2              | SEL RBK        | 110k0101    | 1     | 1              |
| JFO ADDR8      | B6 XX       | 2     | 2              | STOP TCNT      | 65          | 1     | 1              |
| JF1 ADDR8      | 76 XX       | 2     | 2              | STRT CNT       | 45          | 1     | 1              |
| JMP ADDR       | xxx00100    | 2     | 2              | STRT T         | 55          | 1     | 1              |
|                | XX          |       |                | SWAP A         | 47          | 1     | 1              |
| JMPP @A        | B3          | 1     | 2              | XCH A,RN       | 00101nnn    | 1     | 1              |
| JNC ADDR8      | E6 XX       | 2     | 2              | XCH A,@R       | 0010000r    | 1     | 1              |
| JNI ADDR8      | 86 XX       | 2     | 2              | XCHD A,@R      | 0011000r    | 1     | 1              |
| JNIBF ADDR8    | D6 XX       | 2     | 2              | XRL A,RN       | 11011nnn    | 1     | 1              |
| JNT0 ADDR8     | 26 XX       | 2     | 2              | XRL A,@R       | 1101000r    | 1     | 1              |
| JNT1 ADDR8     | 46 XX       | 2     | 2              | XRL A,#DATA    | D3 MM       | 2     | 2              |
| JNZ ADDR8      | 96 XX       | 2     | 2              |                |             |       |                |

## THE 8041 SLAVE MICROCOMPUTER

This device is also referred to in Intel literature as a Universal Programmable Interface (UPI); it represents a simple variation of the 8048 microcomputer.

The 8741 is a slave variation of the 8748 microcomputer.

This discussion of the 8041 and 8741 slave microcomputers explains differences as compared to the 8048 and 8748; you should therefore read the following pages after reading the 8048 and 8748 descriptions.

## AN 8041 FUNCTIONAL OVERVIEW

The principal difference between the 8048 and the 8041 is the fact that the 8041 Data Bus and I/O Port 0 are used exclusively to communicate with a master microprocessor. The 8041 generates no external Address or Data Bus, so on-chip 8041 program memory and scratchpad data memory cannot be expanded.

External interrupt logic, which is available on the 8048, is not available on an 8041; the 8041 uses this logic as a handshaking interrupt for data input from the master microprocessor.

8048 and 8041 logic are compared functionally in Figure 6-15.



Figure 6-15. A Comparison of 8048 and 8041 Functional Logic

**Communications between an 8041 and a master microprocessor are very limited.** Data must be transferred byte-by-byte under program control, with nearly all handshaking protocol being implemented via program logic. You must therefore define the protocol within the logic of your 8041 and master microprocessor programs. **A rigid protocol is absolutely necessary, since the 8041 offers no protection against data transfer contentions.**

## 8041 DATA BUS LOGIC

8041 Data Bus logic may be illustrated conceptually as follows:



In reality, the Data Out buffer and the Data In buffer are a single piece of logic; however, operations occur (to some extent) as though there were two separate buffers.

A master microprocessor will access an 8041 as two I/O ports or two memory locations. These locations are identified via chip select ( $\overline{CS}$ ) and address (A0) input signals as follows:

| $\overline{CS}$ | A0 |                                                                                              |
|-----------------|----|----------------------------------------------------------------------------------------------|
| 0               | 0  | Read from Data Out buffer<br>Write to Data In buffer and reset<br>F1 Buffer status to 0      |
| 0               | 1  | Read from Buffer Status register<br>Write to Data In buffer and set<br>F1 Buffer status to 1 |

"Read" and "Write" above refer to master microprocessor operations.

**The 8041 accesses the Data Bus buffer register as I/O Port 0.** The Status register is inaccessible to the 8041 as an addressable I/O port; however, there are specific 8041 instructions that access the F0 and F1 Buffer Status bits.

**The four Buffer Status register bits may be defined as follows:**

**OBF** is the output buffer full flag. This flag is automatically set to 1 when the 8041 outputs data to the Data Out buffer. When the master microprocessor reads the contents of the Data Out buffer, the OBF flag is reset to 0.

8041  
BUFFER  
STATUS  
REGISTER

**IBF** is the input buffer full flag. This flag is set to 1 when the master microprocessor writes data into the Data In buffer. This flag is reset to 0 when the 8041 subsequently reads data from the Data In buffer.

**F0** is a general-purpose flag which can be set or reset by the 8041. The master microprocessor can sample F0 by reading Buffer Status register contents.

**F1** is another general-purpose flag which can be modified by the 8041. F1 is also set or reset to the level of A0 whenever the master microprocessor writes data into the Data In buffer. The master microprocessor can sample F1 by reading Buffer Status register contents.

When the master microprocessor reads buffer status, flags appear on the Data Bus lines as follows:



Whenever the 8041 outputs data to I/O Port 0, the data is stored in the Data Out buffer and the OBF status flag is set to 1; when the master microprocessor subsequently reads the contents of the Data Out buffer, the OBF flag is reset to 0.

When the master microprocessor writes to the 8041, the data is loaded into the Data In buffer, the IBF status is set to 1 and an interrupt request is generated within the 8041; this interrupt request replaces the external interrupt logic of the 8048. The IBF status is cleared when the 8041 subsequently reads the contents of the Data In buffer.

The F0 flag is set or reset by the 8041 using appropriate instructions. There is no predefined manner in which this flag is interpreted; your program logic can use this flag in any way.

The F1 flag is set to the level of the A0 signal input whenever the master microprocessor writes a control byte into the Data In buffer. In reality, there is no difference between a control byte and a data byte; that is to say, there is no predefined way in which the 8041 will interpret the contents of the Data In buffer based on the F1 flag level.

The master microprocessor reads data which has been output by the 8041; the master microprocessor cannot read back data which it wrote to the 8041.

The 8041 inputs from I/O Port 0 data that was written by the master microprocessor; the 8041 cannot read back data which it previously output to I/O Port 0.

## 8041 I/O PORTS ONE AND TWO

**Physically, 8041 I/O Ports 1 and 2 have logic which is identical to the 8048.** Thus the pseudo-bidirectional I/O port characteristics described for the 8048 I/O Ports 1 and 2 apply also to the 8041 I/O Ports 1 and 2.

Note that the 8041 does not generate an external Address Bus, therefore I/O Port 2 pins P20 - P23 never output address information.

## 8041 AND 8741 PROGRAMMABLE REGISTERS

The 8041 and 8741 have a 10-bit Program Counter. The 8048 and 8748 have a 12-bit Program Counter. These are the only differences between the 8041 series and 8048 series programmable registers.

## 8041 AND 8741 ADDRESSING MODES

The 8041 and 8741 can address only on-chip memory. This includes the 1024 bytes of on-chip program memory and 64 bytes of on-chip scratchpad data memory. **8041 and 8741 addressing modes are identical to the 8048 and 8748 on-chip memory addressing modes.** Of course, the 8048 and 8748 external memory addressing modes will not apply to the 8041 or the 8741.

## 8041 AND 8741 STATUS

The 8041 and 8741 slave microcomputers have two Status registers. First, there is the Buffer Status register, which is part of the Data Bus logic. We have already described this 4-bit Status register. The 8041 and 8741 also have the 8-bit Program Status Word described for the 8048 series microcomputers. 8041 and 8048 Program Status Words are identical.

## 8041 AND 8741 SLAVE MICROCOMPUTER OPERATING MODES

The 8041 and 8741 can be operated in Internal Execution mode and Debug mode; in addition, the 8741 can be operated in Single Stepping mode, Programming mode and Verification mode. Neither the 8041 nor the 8741 can be operated in External Memory Access mode.

## 8041 AND 8741 PINS AND SIGNALS

There are a few differences between 8041 and 8741 pins and signals, as compared to the 8048 and 8748. Figure 6-16 defines 8041 and 8741 pins and signals; the four changed signals are shaded.



Figure 6-16. 8041 and 8741 Microcomputer Pins and Signals

**CS** and **A0** are the device select inputs which we have already described.

**SYNC** is an external synchronizing signal which is output once per machine cycle.

**T0** cannot be connected to the internal system clock; other uses of **T0** are the same for the 8041/8741 and the 8048/8748.

All other signals are identical to the 8048 and 8748 as previously described. Note, however, that no addresses are output on the DB0 - DB7 pins or the P20 - P23 pins.

## 8041 SERIES TIMING AND INSTRUCTION EXECUTION

The 8041/8741 clock signals and instruction execution timing logic is identical to the 8048/8748. Of course, the 8041 and 8741 have no external memory reference instructions, therefore timing associated with these instructions will not apply.

## 8741 SINGLE STEPPING AND PROGRAMMING MODE

Single Stepping and Programming modes of operation are available only with the 8741; the 8041 cannot be operated in these modes.

There are, of necessity, some differences between 8741 and 8748 Single Stepping and Programming modes; this is because the 8741 has no ALE signal and no output Address Bus.

In Single Stepping mode, the 8741 is stopped by applying a low **SS** input when SYNC is low.

The 8741 responds by stopping during the next instruction fetch. At this time, SYNC is maintained high. The address of the next instruction to be accessed appears at I/O Port 1 and the low-order two bits of I/O Port 2. This condition is maintained until **SS** is input high again. Timing may be illustrated as follows:



There are also some minor differences between 8741 and 8748 Programming modes. The ten-step 8741 programming sequence is therefore given below. Differences as compared to the 8748 are shaded.

- Step 1) Initially +5V is input at **V<sub>DD</sub>**, **CS**, **T0** and **EA**. **RESET** and **A0** are held at ground. Under these conditions you insert the 8741 into the programming socket. You must make certain to insert the 8741 correctly. If you insert the 8741 incorrectly you will destroy it.
- Step 2) **T0** is pulled to ground; this selects Programming mode.
- Step 3) +25V is applied to **EA**. This activates Programming mode.
- Step 4) A 10-bit memory address is applied via **DB0 - DB7** and **P20 - P21**. Remember, there are 1024 bytes of program memory on the 8741 device. The low-order eight address bits are input via **DB0 - DB7** while the two high-order address bits are input via **P20** and **P21**.
- Step 5) +5V is applied at **RESET**. This latches the address.
- Step 6) The data to be written into the addressed programmed memory byte is input at **DB0 - DB7**.
- Step 7) In order to write the data into the addressed program memory byte apply +25V to **V<sub>DD</sub>**, then ground **PROG**, then apply a +25V pulse at **PROG**; the +25V pulse at **PROG** must last at least 50 milliseconds.
- Step 8) Now reduce **V<sub>DD</sub>** to +5V. Programming is complete and verification is about to begin.
- Step 9) In order to verify the data just written, apply +5V to the **T0** input. This selects Verify mode.
- Step 10) As soon as Verify mode has been selected, the data just written is output on **DB0 - DB7**. You must read and verify this data using appropriate external circuitry. Verification is now complete.

## 8041 INPUT/OUTPUT PROGRAMMING

The only differences between 8041/8741 and 8048/8748 input/output programming are those which result from the unique 8041 I/O Port 0 logic — which we have described.

### 8041 COUNTER/TIMER OPERATIONS

8041 series and 8048 series counter/timer operations are identical.

### 8041 INTERRUPT LOGIC

The entire external interrupt logic of the 8048 has been converted in the 8041/8741 Data Bus handshaking interrupt logic. This interrupt request occurs every time a master microprocessor writes to either of the 8041/8741 addressable locations.

In order to generate external interrupt logic at an 8041 or 8741 you must use the counter/timer. By loading the counter/timer with an initial value of FF<sub>16</sub> and operating the counter/timer in Counter mode, the first high-to-low input transition on T1 will generate a Timer interrupt request. Of course, if you are using the counter/timer in this way, you cannot use it for any of its normal functions.

### PROGRAMMING 8048-8041 DATA TRANSFERS

The only complexity associated with programming an 8041 involves data transfers between the 8041 and a master microcomputer. Programming these data transfers is not straightforward.

We described earlier how there are separate data paths for data entering or leaving the 8041 via the Data Bus buffer. Nevertheless, if a master microcomputer attempts to write to the 8041/8741 while the 8041/8741 is simultaneously outputting to I/O Port 0, then there will be an undefined result. This is unfortunate, since there are no signals or indicators of any kind allowing the master microcomputer to lock out the 8041/8741; nor can the 8041/8741 lock out the master microcomputer. Lock out logic must be implemented by you, via your program logic. Program logic must also make sure that data written by a master microcomputer has been read by the 8041/8741 before the master microcomputer writes any new data; similarly, the 8041/8741 must make sure that any data it has output to I/O Port 0 has been read by the master microcomputer before the 8041/8741 attempts to output new data to I/O Port 0.

Let us look at the programming steps required for error free data transfers between the 8041/8741 and a master microcomputer. Programming examples assume an 8048 is the master microprocessor because the 8048 is described in this chapter and has an instruction set that is similar to the 8041. In reality, the master microprocessor is likely to be an 8085-type device.

The master microcomputer can make sure that it does not overwrite data by testing both the IBF and the OBF flags; that is to say, the master microcomputer will not attempt to write data to the 8041/8741 if prior data it wrote is waiting to be read by the 8041/8741, or if data output by the 8041/8741 is waiting to be read by the master microcomputer. The following master microcomputer output instruction sequence will suffice:

```

MOV    0,ADDR+1 ;LOAD 8041 ADDRESS INTO 8048 REGISTER R0
-
-
MOVX  A,@0      ;LOAD STATUS
RRC   A          ;TEST LOW ORDER (OBF) FLAG
JC    NEXT       ;IF IT IS 1, DO NOT WRITE NEW DATA
RRC   A          ;TEST NEXT BIT (IBF) FLAG
JC    READ       ;IF IT IS 1, DATA IS WAITING TO BE READ
DEC   0          ;OK TO OUTPUT
-
-
```

But this scheme does not prevent the master microcomputer and the 8041/8741 from simultaneously accessing the Data Bus buffer. This must be guaranteed by 8041/8741 lock out logic. The 8041/8741 can use programming logic or interrupt logic to lock out the master microcomputer. Using programming logic, the 8041/8741 will use the F0 flag to identify those time intervals when the master microcomputer is free to access the Data Bus buffer. Now any 8048 master microcomputer instruction sequence that accesses the 8041/8741 will first read 8041/8741 status and test the F0 flag. If this flag is "false", no data transfer must occur. Continuing our master microprocessor instruction sequence, this may be illustrated as follows:

```

MOV    0,ADDR+1 ;LOAD 8041 ADDRESS INTO 8048 REGISTER R0
-
-
TEST   MOVX  A,@0      ;LOAD STATUS
       RRC   A      ;TEST LOW ORDER (OBF) FLAG
       JC    NEXT    ;IF IT IS 1, DO NOT WRITE NEW DATA
       RRC   A      ;TEST NEXT BIT (IBF) FLAG
       JC    READ    ;IF IT IS 1, DATA IS WAITING TO BE READ
       RRC   A      ;TEST F0 FLAG
       JNC   TEST    ;IF F0 IS 0, MASTER IS LOCKED OUT
       DEC   0      ;F0 IS 1 SO IT IS OK TO OUTPUT DATA
       MOV   A,@1      ;LOAD DATA TO BE OUTPUT INTO ACCUMULATOR
       MOVX @0,A      ;OUTPUT DATA TO 8041
       JMP   OUT      ;OUTPUT DATA TO 8041
READ   RRC   A      ;TEST F0 FLAG
       JNC   TEST    ;IF F0 IS 0, MASTER IS LOCKED OUT
       DEC   0      ;F0 IS 1 SO IT IS OK TO READ DATA
       MOVX A,@0      ;INPUT DATA
       MOV   @1,A      ;STORE IN SCRATCHPAD
       JMP   OUT      ;OUTPUT DATA TO 8041

```

The instructions above assume that scratchpad register R1 addresses the scratchpad byte out of which written data is fetched, or into which read data is stored.

If there is heavy traffic between an 8041/8741 and a master microcomputer, then the 8041/8741 should use interrupt logic to identify times when a master microcomputer can either output data to the 8041/8741 or input data from the 8041/8741. To do this, one or two 8041/8741 I/O port pins must be set aside as interrupt request generation lines. Now the master microcomputer will not access the 8041/8741 except within an interrupt service routine which is initiated by an interrupt request arising from one of the two dedicated 8041/8741 I/O port pins.

Data transfers from the 8041/8741 to the master microcomputer are easy to program. When the 8041/8741 writes to I/O Port 0, the OBF flag is set to 1; this flag is reset to 0 when a master microcomputer reads data. Thus, the 8041/8741 simply tests the OBF status before outputting data; here are appropriate instructions:

```

CLR   F0      ;ZERO F0 TO LOCK OUT THE MASTER MICROPROCESSOR
JOBF  NEXT    ;TEST OBF FLAG
OUT   DBB,A    ;IF IT IS ZERO, OUTPUT NEXT DATA BYTE
CPL   F0      ;SET F0 TO ALLOW MASTER MICROPROCESSOR ACCESS
-
-
```

NEXT

The 8041/8741 can respond to data arriving from the master microcomputer by using polling logic or interrupt logic. If polling logic is used, then the 8041/8741 must test the IBF flag before reading any data that the master microcomputer has output. In order to determine whether the master microprocessor has output data or a control code, the 8041/8741 must also check the F1 flag. Here is an appropriate instruction sequence:

|       |       |                                                                  |
|-------|-------|------------------------------------------------------------------|
| CLR   | F0    | :ZERO F0 TO LOCK OUT THE MASTER MICROPROCESSOR                   |
| JNIBF | NEXT  | :TEST FOR DATA WAITING TO BE READ                                |
| JF1   | CONT  | :DATA IS READY TO BE READ. TEST<br>FOR DATA BYTE OR CONTROL BYTE |
| IN    | A,DBB | :READ DATA                                                       |
| CPL   | F0    | :SET F0 TO ALLOW MASTER MICROPROCESSOR ACCESS                    |
| -     |       |                                                                  |
| -     |       |                                                                  |
| -     |       |                                                                  |
| CONT  | IN    | A,DBB :READ CONTROL CODE                                         |
|       | CPL   | F0 :SET F0 TO ALLOW MASTER MICROPROCESSOR ACCESS                 |
| -     |       |                                                                  |
| -     |       |                                                                  |
| -     |       |                                                                  |
| NEXT  |       |                                                                  |

If 8041/8741 data input logic is interrupt driven, then external interrupts must be left enabled. Now as soon as the master microcomputer outputs data to the 8041/8741, an interrupt request will occur, followed by a Call 3 instruction being executed. Beginning at memory location 3, the following instruction sequence will initiate the data input interrupt service routine within the 8041/8741:

|      |      |                                               |
|------|------|-----------------------------------------------|
| ORG  | 3    |                                               |
| JMP  | DTIN | ;JUMP TO DATA INPUT ROUTINE                   |
| -    |      |                                               |
| -    |      |                                               |
| -    |      |                                               |
| DTIN | CLR  | F0 ;ZERO F0 TO LOCK OUT MASTER MICROPROCESSOR |
|      | JF1  | CONT ;TEST FOR DATA TYPE                      |
|      | IN   | A,DBB ;READ DATA                              |
| -    |      |                                               |
| -    |      |                                               |
| -    |      |                                               |
| CONT | IN   | A,DBB ;READ CONTROL CODE                      |
| -    |      |                                               |
| -    |      |                                               |
| -    |      |                                               |
| CPL  | F0   | ;SET F0 TO ALLOW MASTER MICROPROCESSOR ACCESS |
| RET  |      | ;RETURN FROM INTERRUPT SERVICE ROUTINE        |

The master microprocessor must not write to the 8041/8741 while data that the 8041/8741 has output is waiting to be read; similarly, the 8041/8741 cannot output data to the master microprocessor while data from the master microprocessor is waiting to be read by the 8041/8741. In each case, prior data will be overwritten and lost. In order to prevent this from happening, you must have appropriate lock out logic. F0 is used for this purpose above.

## **THE 8041/8741 INSTRUCTION SET**

The 8041/8741 instruction set differs from the 8048/8748 in minor ways only. Tables 6-2 and 6-3 therefore summarize the instruction set for both the 8048 series and 8041 series microcomputers.



Figure 6-17. A Comparison of 8048 and 8021 Functional Logic

## THE 8021 SINGLE-CHIP MICROCOMPUTER

The 8021 is a low-cost subset of the 8048 single-chip microcomputer. Unlike the 8041, the 8021 is not designed to operate as a slave microcomputer. The 8021 is intended for high-volume, low-cost applications with limited microcomputer logic requirements. The only easy way in which an 8021 can be expanded is by adding an 8243 Input/Output Expander. There is no simple way to increase either 8021 program memory or data memory, over and above that which is internal to the 8021.

This discussion of the 8021 single-chip microcomputer explains differences as compared to the 8048 and 8748; you should therefore read the following pages after reading the 8048 and 8748 descriptions.

### AN 8021 FUNCTIONAL OVERVIEW

The principal difference between the 8048 and the 8021 is the fact that the 8021 has no Data Bus, and I/O Port 0 is simply another I/O port. Thus, the only way in which an 8021 can communicate with logic beyond the chip itself is via its I/O ports, which have no accompanying handshaking control signals. In contrast, the 8041 has I/O Port 0 logic designed for two-way communication between the 8041 and a master microprocessor. The 8021 cannot distinguish between a master microprocessor or any other external logic.

The 8021 has no external interrupt logic and only one Test input.

Only two control signals are output by the 8021: a synchronizing clock signal and an 8243 Input/Output Expander control strobe.

With these reduced capabilities, the 8021 is packaged as a 28-pin DIP, in contrast to other members of the 8048 series, which are packaged as 40-pin DIPs.

**The 8021 can be driven by a crystal oscillator with a maximum 3 MHz frequency.** This is half the maximum frequency of the 8048 and 8041, but equivalent to the maximum frequency of the -8 parts. This 3 MHz crystal generates 10-microsecond machine cycles. Thus, all 8021 instructions execute in either 10 or 20 microseconds.

Functionally, 8048 and 8021 logic are compared in Figure 6-17. 8021 pins and signals are illustrated in Figure 6-18.

### 8021 I/O PORT PINS

8021 I/O port pins are referred to as quasi-bidirectional, a term we also use to describe 8048 I/O port pins. 8048 and 8021 I/O port pin logic is identical.

### THE T1 PIN

When you order an 8021 microcomputer, you can specify one of two configurations for the T1 pin. Electrically, these may be illustrated as follows:



Option A allows you to detect the zero cross-over point on slow-moving input signals. Option B, with the pull-up, is designed to sense fast changes such as contact switches.



Figure 6-18. 8021 Microcomputer Pins and Signals

## THE 8021 RESET INPUT

When the 8021 is reset, the same internal operations occur as described for the 8048; the Program Counter and Program Status Word are cleared and 1 is output to I/O port pins. However, 8021 reset logic has been modified so that the 8021 can operate with noisy power supplies. You have one of two options, which may be illustrated as follows:

Option A (Reset when power falls below 1.5V)



Option B (Operate as long as power will drive chip)



In the case of Option A, you connect the diode between reset and ground to force a reset whenever power drops below 1.5V. Thus, operations will stop while power falls below 1.5V, but when normal power returns operations will restart. Since chip operations continue only as long as power remains high enough to maintain the contents of chip read/write locations, this circuit guards against execution with faulty data. By removing the diode, as illustrated in Option B, this reset feature is eliminated and the 8021 will operate as long as power is sufficient to drive logic internal to the chip.

## THE 8021 CLOCK INPUTS

A crystal Resistor/Capacitor or inductor circuit can be connected to the XTL1 and XTL2 pins to provide the needed internal clock signal. The maximum external crystal frequency allowed is 3 MHz. This generates 10-microsecond machine cycles. All instructions execute in 1 or 2 machine cycles.

## THE 8021 TIMER/COUNTER

Logic associated with the 8021 timer/counter is identical to that which we have described for the 8048. The contents of the Accumulator can be moved to the Counter/Timer register, which is subsequently incremented once every 32 crystal oscillations in Timer mode, or once every high-to-low transition of a T1 input in Counter mode. However, there is no interrupt logic on the 8021, which means that a time-out will not cause an interrupt request to occur. You must therefore test for a time-out under program control using the JTF (Branch-on-Timer Flag) instruction.

## 8021 SCRATCHPAD MEMORY AND PROGRAMMING

In addition to the lack of interrupt logic, the 8021 has no Status register and data memory is simplified.

Instead of having a Status register, the 8021 has a 3-bit Stack Pointer and a single Carry status flag.

Data memory consists of eight general purpose registers in scratchpad bytes 0-7, plus a 16-byte Stack which uses scratchpad bytes 8-17<sub>16</sub>. This stack allows subroutines to be nested to a level of 8. The 8021 does not have the second set of eight registers located in scratchpad bytes 18<sub>16</sub> - 1F<sub>16</sub>, as is available on the 8048 and the 8041.

The 8021 instruction set is a subset of the 8048 instruction set. In Table 6-1, 8021 instructions are identified.

## THE 8243 INPUT/OUTPUT EXPANDER

This support device expands I/O Port 2 of an 8041 or 8048 series microcomputer to four individually addressable 4-bit I/O ports. The 8243 Input/Output Expander is particularly useful in numerical applications where data is transferred in 4-bit nibbles.

Figure 6-19 illustrates that part of our general microcomputer system logic which has been implemented on the 8243 Input/Output Expander.

The 8243 Input/Output Expander is packaged as a 24-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL-compatible. The device is implemented using N-channel MOS technology.

## 8243 INPUT/OUTPUT EXPANDER PINS AND SIGNALS

The 8243 Input/Output Expander pins and signals are illustrated in Figure 6-20. Functional internal architecture is illustrated in Figure 6-21.

P20 - P23 represent the 4-bit bidirectional I/O port or bus connection between the 8243 Input/Output Expander and the 8048 series microcomputer. P20 - P23 must be connected to the low-order four pins of the microcomputer I/O Port 2. Figure 6-22 illustrates the 8243-8048 interface.

**P40 - P43, P50 - P53, P60 - P63 and P70 - P73 provide four bidirectional I/O ports**, referred to as Ports 4, 5, 6 and 7, respectively. These are 4-bit ports via which data is transferred to or from external logic.

Data being output via one of these four ports is latched and held in a low impedance state.

Data input is buffered. During a read operation 8243 I/O port pins are sampled — while the read is being executed; then I/O port pins are floated.

**CS** is the single chip select signal for the 8243 device. CS must be low for the device to be selected. There is no specifically defined manner in which CS has to be created; in Figure 6-22 it is shown being decoded off the four high-order pins of I/O Port 2.

**PROG** is the single control strobe output by the 8048 series microcomputer to time 8243 events. On the falling edge of PROG, data input via P20 - P23 is decoded as an I/O port select and operation specification. Resulting 8243 operations are strobed by the rising edge of PROG.

There is no Reset input to the 8243. The device is reset when power is first applied, or when power input at the V<sub>CC</sub> pin drops below +1 volt. Following Reset, Port 2 is in Input mode while Ports 4, 5, 6 and 7 are floated. The 8243 device will exit the Reset mode on the first high-to-low transition of PROG.

**8243 RESET**



Figure 6-19. Logic of the 8243 Input/Output Expander



| PIN NAME              | DESCRIPTION                   | TYPE                    |
|-----------------------|-------------------------------|-------------------------|
| P20 - P23             | Bidirectional I/O Port to CPU | Bidirectional, tristate |
| P40 - P43             | I/O Port 4                    | Bidirectional, tristate |
| P50 - P54             | I/O Port 5                    | Bidirectional, tristate |
| P60 - P64             | I/O Port 6                    | Bidirectional, tristate |
| P70 - P74             | I/O Port 7                    | Bidirectional, tristate |
| PROG                  | Address/Data Strobe           | Input                   |
| CS                    | Chip Select                   | Input                   |
| V <sub>CC</sub> , GND | Power, Ground                 |                         |

Figure 6-20. 8243 Input/Output Expander Pins and Signals

## 8243 INPUT/OUTPUT EXPANDER OPERATIONS

8048 and 8041 series microcomputers have four instructions designed specifically to access an 8243 Input/Output Expander. These instructions are:

```
MOVD PN,A  
MOVD A,PN  
ORLD PN,A  
ANLD PN,A
```

These are the operations performed:

- 1) You can output the low-order four Accumulator bits to I/O Expander Port 4, 5, 6 or 7. Following a write operation the four port lines are held in a low impedance state. External logic does not receive any type of "data ready" signal after data has been output; however, as illustrated in Figure 6-22, you can easily create such a signal by combining PROG and device select logic.
- 2) You can input data from Port 4, 5, 6 or 7 of the 8243 device to the four low-order Accumulator bits. Again Figure 6-22 shows how you can create a strobe signal which tells external logic when to apply data to an I/O port of the 8243 device.
- 3) You can output data from the low-order four Accumulator bits to one of the four 8243 device ports, but instead of simply writing to the port, you can AND or OR with data already in the port output latch. That is to say, you perform a Boolean operation between the four low-order Accumulator bits and the data most recently output to the 8243 port.

You cannot perform a Boolean operation between the low-order four Accumulator bits and data input to an 8243 port; the input data is buffered, not latched. You must read the input data to the Accumulator and mask it there.

8243 device Ports 4, 5, 6 and 7 have been designed to operate continuously as input ports or output ports. If you switch a port from input to output, or from output to input, then the first 4-bit data unit written or read will be erroneous and should be discarded.



Figure 6-21. Functional Diagram of the 8243 Input/Output Expander



Figure 6-22. An 8243/8048 Configuration with External Logic Read and Write Strobes



Figure 6-23. Timing for Data Output to an 8243 Port Via an MOVD, ORLD or ANLD Instruction



Figure 6-24. Timing for Data Input from an 8243 Port

**Timing for 8243 port accesses is illustrated in Figures 6-23 and 6-24.**

**In each case an instruction is output via P20 - P23 of the 8048 microcomputer on the high-to-low transition of PROG. The instruction is decoded as follows:**

| P20 | P21 | 8243 Port Selected | P22 | P23 | Function Defined |
|-----|-----|--------------------|-----|-----|------------------|
| 0   | 0   | Port 4             | 0   | 0   | Read from Port   |
| 0   | 1   | Port 5             | 0   | 1   | Write to Port    |
| 1   | 0   | Port 6             | 1   | 0   | OR with Port     |
| 1   | 1   | Port 7             | 1   | 1   | AND with Port    |

**The actual I/O operation within the 8243 device is strobed by the subsequent low-to-high transition of PROG.**

Observe that external logic must transmit data to an 8243 I/O port on the high-to-low transition of PROG. External logic must read data output after the low-to-high transition of PROG. These **signals to external logic are shown in Figure 6-22. Let us take a more careful look at this figure.**

The 8243 device select  $\overline{CS}$  is derived in some fashion from the four high-order lines of the 8048 I/O Port 2. The manner in which we decode  $\overline{CS}$  from these four lines is not relevant; however, the fact that we are generating  $\overline{CS}$  in this fashion means that any 8243 access instruction must be bracketed by instructions that select and then deselect the 8243 device.

It is not a good idea to leave the 8243 device selected when you are not accessing it; therefore do not leave high-order bits of I/O Port 2 in a condition that would select the 8243 device while the device is supposed to be idle.

The PROG signal connecting the 8048 to the 8243 requires no explanation. The signal is output by the 8048 with timing required by the 8243.

The READ and WRITE strobes created in Figure 6-22 identify the time at which external logic must either read data from an I/O port, or write data to an I/O port; however, the I/O port is not itself identified. The READ and WRITE strobes would have to be qualified by P20 and P21 on the high-to-low transition of PROG in order to create READ and WRITE strobes specific to any given I/O port. Here, for example, is the logic which would make READ and WRITE specific to I/O Port 5:



Referring to the timing in Figure 6-22, let us first look at the READ strobe. This signal must go true on the high-to-low transition of PROG — but only if P22 and P23 are both low. READ can stay high until the device is deselected, providing external logic uses the low-to-high transition of READ or timing immediately thereafter, in order to place data at the required I/O port — whence it can be read by the 8048. We obtained the required waveform by using the complement of  $\bar{CS}$  as a CLEAR input to the READ 7474 flip-flop. Thus while the 8243 device is not selected READ will be low. The NOR of P22 and P23 becomes the D input to the READ flip-flop; this input will be high only when P22 and P23 are both low — and that specifies a Read operation. On the high-to-low transition of PROG, PROG goes low-to-high, and that clocks the READ flip-flop Q output high. READ subsequently stays high until  $\bar{CS}$  goes high again, at which point the READ flip-flop is cleared and READ goes low.

A 74107 master-slave flip-flop creates the WRITE pulse. The high-to-low transition of PROG marks the instant at which P22 and P23 must be decoded to determine that a non-read operation is in progress, but the actual low-to-high transition WRITE must not occur until the subsequent low-to-high transition of PROG.

The 74107 modifies the Q1 output on the trailing edge of CLK, based on the JK inputs at the leading edge of CLK; thus WRITE logic requirements are met.

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

8048/8748/8035 }  
8049/8039      } One-Chip Microcomputers  
8041/8021      }  
8243 I/O Expander

**ABSOLUTE MAXIMUM RATINGS\***

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Ambient Temperature Under Bias .....               | 0°C to 70°C     |
| Storage Temperature .....                          | -65°C to +150°C |
| Voltage On Any Pin With Respect<br>to Ground ..... | -0.5V to +7V    |
| Power Dissipation .....                            | 1.5 Watt        |

**\*COMMENT:**

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

**D.C. AND OPERATING CHARACTERISTICS  $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = V_{DD} = +5V \pm 10\%$ ,  $V_{SS} = 0V$** 

| Symbol            | Parameter                                                  | Limits |      |          | Unit          | Test Conditions                        |
|-------------------|------------------------------------------------------------|--------|------|----------|---------------|----------------------------------------|
|                   |                                                            | Min.   | Typ. | Max.     |               |                                        |
| $V_{IL}$          | Input Low Voltage<br>(All Except XTAL1, XTAL2)             | -.5    |      | .8       | V             |                                        |
| $V_{IH}$          | Input High Voltage<br>(All Except XTAL1, XTAL2, RESET)     | 2.0    |      | $V_{CC}$ | V             |                                        |
| $V_{IH1}$         | Input High Voltage ( $\overline{\text{RESET}}$ , XTAL1)    | 3.0    |      | $V_{CC}$ | V             |                                        |
| $V_{OL}$          | Output Low Voltage<br>(BUS, RD, WR, PSEN, ALE)             |        |      | .45      | V             | $I_{OL} = 2.0\text{mA}$                |
| $V_{OL1}$         | Output Low Voltage<br>(All Other Outputs Except PROG)      |        |      | .45      | V             | $I_{OL} = 1.6\text{mA}$                |
| $V_{OL2}$         | Output Low Voltage (PROG)                                  |        |      | .45      | V             | $I_{OL} = 1.0\text{mA}$                |
| $V_{OH}$          | Output High Voltage<br>(BUS, RD, WR, PSEN, ALE)            | 2.4    |      |          | V             | $I_{OH} = 100\mu\text{A}$              |
| $V_{OH1}$         | Output High Voltage<br>(All Other Outputs)                 | 2.4    |      |          | V             | $I_{OH} = 50\mu\text{A}$               |
| $I_{IL}$          | Input Leakage Current<br>(T1, EA, INT)                     |        |      | $\pm 10$ | $\mu\text{A}$ | $V_{SS} \leq V_{IN} \leq V_{CC}$       |
| $I_{OL}$          | Output Leakage Current (BUS, T0)<br>(High Impedance State) |        |      | -10      | $\mu\text{A}$ | $V_{CC} \geq V_{IN} \geq V_{SS} + .45$ |
| $I_{DD}$          | $V_{DD}$ Supply Current                                    |        | 10   | 20       | mA            |                                        |
| $I_{DD} + I_{CC}$ | Total Supply Current                                       |        | 65   | 135      | mA            |                                        |

**A.C. CHARACTERISTICS  $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = V_{DD} = +5V \pm 10\%$ ,  $V_{SS} = 0V$** 

| Symbol    | Parameter                          | 8048/8748 |      | 8748-8 |      | Unit          | Conditions (Note 1)                |
|-----------|------------------------------------|-----------|------|--------|------|---------------|------------------------------------|
|           |                                    | Min.      | Max. | Min.   | Max. |               |                                    |
| $t_{LL}$  | ALE Pulse Width                    | 400       |      | 600    |      | ns            |                                    |
| $t_{AL}$  | Address Setup to ALE               | 150       |      | 150    |      | ns            |                                    |
| $t_{LA}$  | Address Hold from ALE              | 80        |      | 80     |      | ns            |                                    |
| $t_{CC}$  | Control Pulse Width (PSEN, RD, WR) | 900       |      | 1500   |      | ns            |                                    |
| $t_{DW}$  | Data Setup before WR               | 500       |      | 640    |      | ns            |                                    |
| $t_{WD}$  | Data Hold After WR                 | 120       |      | 120    |      | ns            | $C_L = 20\text{pF}$                |
| $t_{CY}$  | Cycle Time                         | 2.5       | 15.0 | 4.17   | 15.0 | $\mu\text{s}$ | 6 MHz XTAL<br>(3.6MHz XTAL for -8) |
| $t_{DR}$  | Data Hold                          | 0         | 200  | 0      | 200  | ns            |                                    |
| $t_{RD}$  | PSEN, RD to Data In                |           | 500  |        | 750  | ns            |                                    |
| $t_{AW}$  | Address Setup to WR                | 230       |      | 260    |      | ns            |                                    |
| $t_{AD}$  | Address Setup to Data In           |           | 950  |        | 1450 | ns            |                                    |
| $t_{AFC}$ | Address Float to RD, PSEN          | 0         |      | 0      |      | ns            |                                    |

\*Standard 8748 and 8035  $\pm 5\%$ ,  $\pm 10\%$  available.Note 1: Control Outputs:  $C_L = 80\text{ pF}$   
BUS Outputs:  $C_L = 150\text{ pF}$ ,  $t_{CY} = 25\mu\text{s}$

**8048/8748/8035****A.C. CHARACTERISTICS**

TA = 0°C to 70°C, VCC = 5V±10%

| Symbol          | Parameter                                      | Min. | Max. | Unit | Test Conditions |
|-----------------|------------------------------------------------|------|------|------|-----------------|
| t <sub>CP</sub> | Port Control Setup Before Falling Edge of PROG | 110  |      | ns   |                 |
| t <sub>PC</sub> | Port Control Hold After Falling Edge of PROG   | 140  |      | ns   |                 |
| t <sub>PR</sub> | PROG to Time P2 Input Must Be Valid            | 810  |      | ns   |                 |
| t <sub>DP</sub> | Output Data Setup Time                         | 220  |      | ns   |                 |
| t <sub>PD</sub> | Output Data Hold Time                          | 65   |      | ns   |                 |
| t <sub>PF</sub> | Input Data Hold Time                           | 110  |      | ns   |                 |
| t <sub>PP</sub> | PROG Pulse Width                               | 1510 |      | ns   |                 |
| t <sub>PL</sub> | Port 2 I/O Data Setup                          | 400  |      | ns   |                 |
| t <sub>LP</sub> | Port 2 I/O Data Hold                           | 150  |      | ns   |                 |

**WAVEFORMS****PORT 2 TIMING**

## WAVEFORMS

## Instruction Fetch From External Program Memory



## Read From External Data Memory



## Write to External Data Memory



## WARNING:

An attempt to program a missocketed 8748 will result in severe damage to the part. An indication of a properly socketed part is the appearance of the ALE clock output. The lack of this clock may be used to disable the programmer.

## 8048/8748/8035

### Programming Options

The 8748 EPROM can be programmed by either of two Intel products:

1. PROMPT-48 Microcomputer Design Aid, or
2. Universal PROM Programmer (UPP-101 or UPP-102) peripheral of the Intellec® Development System with a UPP-848 Personality Card.

### 8748 Erasure Characteristics

The erasure characteristics of the 8748 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\text{\AA}$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the 3000-4000 $\text{\AA}$  range.

Data show that constant exposure to room level fluorescent lighting could erase the typical 8748 in approximately 3 years while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 8748 is to be exposed to these types of lighting conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 8748 window to prevent unintentional erasure.

The recommended erasure procedure for the 8748 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ( $\text{\AA}$ ). The integrated dose (i.e., UV intensity X exposure time) for erasure should be a minimum of 15W-sec/cm<sup>2</sup>. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a 12000 $\mu\text{W}/\text{cm}^2$  power rating. The 8748 should be placed within one inch from the lamp tubes during erasure. Some lamps have a filter on their tubes and this filter should be removed before erasure.

### WAVEFORMS

#### Combination Program/Verify Mode (EPROM's Only)



#### Verify Mode (ROM/EPROM)



#### NOTES:

1. PROG MUST FLOAT IF EA IS LOW (i.e., #25V), OR IF TO = 5V FOR THE 8741. FOR THE 8041 PROG MUST ALWAYS FLOAT.
2. V<sub>EE</sub> FOR 8041 = 11.4V MIN., 12.6V MAX.

#### 3. THE FOLLOWING CONDITIONS MUST BE MET:

$$\text{CS} = \text{TTL '1'}$$

$$\text{AO} = \text{TTL '0'}$$

THIS CAN BE DONE USING 10K RESISTORS TO V<sub>CC</sub>, V<sub>SS</sub> RESPECTIVELY.

4. X<sub>1</sub> AND X<sub>2</sub> DRIVEN BY 3 MHZ CLOCK WILL GIVE 5  $\mu\text{sec}$  t<sub>cy</sub>. THIS IS GOOD FOR -8 PARTS AS WELL AS NON -8 PARTS.

## 8048/8748/8035

### AC TIMING SPECIFICATION FOR PROGRAMMING

T<sub>A</sub> = 25°C ± 5°C, V<sub>CC</sub> = 5V ± 5%, V<sub>DD</sub> = 25V ± 1V

| Symbol                          | Parameter                                    | Min. | Max. | Unit | Test Conditions |
|---------------------------------|----------------------------------------------|------|------|------|-----------------|
| t <sub>AW</sub>                 | Address Setup Time to RESET I                | 4tcy |      |      |                 |
| t <sub>WA</sub>                 | Address Hold Time After RESET I              | 4tcy |      |      |                 |
| t <sub>DW</sub>                 | Data in Setup Time to PROG I                 | 4tcy |      |      |                 |
| t <sub>WD</sub>                 | Data in Hold Time After PROG I               | 4tcy |      |      |                 |
| t <sub>PH</sub>                 | RESET Hold Time to Verify                    | 4tcy |      |      |                 |
| t <sub>VDDW</sub>               | V <sub>DD</sub>                              | 4tcy |      |      |                 |
| t <sub>VDDH</sub>               | V <sub>DD</sub> Hold Time After PROG I       | 0    |      |      |                 |
| t <sub>PW</sub>                 | Program Pulse Width                          | 50   | 60   | MS   |                 |
| t <sub>Tw</sub>                 | Test 0 Setup Time for Program Mode           | 4tcy |      |      |                 |
| t <sub>WT</sub>                 | Test 0 Hold Time After Program Mode          | 4tcy |      |      |                 |
| t <sub>DO</sub>                 | Test 0-to-Data Out Delay                     |      | 4tcy |      |                 |
| t <sub>WW</sub>                 | RESET Pulse Width to Latch Address           | 4tcy |      |      |                 |
| t <sub>r</sub> , t <sub>f</sub> | V <sub>DD</sub> and PROG Rise and Fall Times | 0.5  | 2.0  | μs   |                 |
| t <sub>CY</sub>                 | CPU Operation Cycle Time                     | 5.0  |      | μs   |                 |
| t <sub>RE</sub>                 | RESET Setup Time Before EA I                 | 4tcy |      |      |                 |

Note: If Test 0 is high too can be triggered by RESET I.

### DC SPECIFICATION FOR PROGRAMMING

T<sub>A</sub> = 25°C ± 5°C, V<sub>CC</sub> = 5V ± 5%, V<sub>DD</sub> = 25V ± .1V

| Symbol            | Parameter                                   | Min. | Max. | Unit | Test Conditions |
|-------------------|---------------------------------------------|------|------|------|-----------------|
| V <sub>DOH</sub>  | V <sub>DD</sub> Program Voltage High Level  | 24.0 | 26.0 | V    |                 |
| V <sub>DDL</sub>  | V <sub>DD</sub> Voltage Low Level           | 4.75 | 5.25 | V    |                 |
| V <sub>PH</sub>   | PROG Program Voltage High Level             | 21.5 | 24.5 | V    |                 |
| V <sub>PL</sub>   | PROG Voltage Low Level                      |      | 0.2  | V    |                 |
| V <sub>EAH</sub>  | EA Program or Verify Voltage High Level     | 21.5 | 24.5 | V    |                 |
| V <sub>EAL</sub>  | EA Voltage Low Level                        |      | 5.25 | V    |                 |
| I <sub>DD</sub>   | V <sub>DD</sub> High Voltage Supply Current |      | 30.0 | mA   |                 |
| I <sub>PROG</sub> | PROG High Voltage Supply Current            |      | 16.0 | mA   |                 |
| I <sub>EA</sub>   | EA High Voltage Supply Current              |      | 1.0  | mA   |                 |

**8049/8039****ABSOLUTE MAXIMUM RATINGS\***

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Ambient Temperature Under Bias .....               | 0°C to 70°C     |
| Storage Temperature .....                          | -65°C to +150°C |
| Voltage on Any Pin With<br>Respect to Ground ..... | -0.5V to +7V    |
| Power Dissipation .....                            | 1.5 Watt        |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. AND OPERATING CHARACTERISTICS**

T<sub>A</sub> = 0°C to 70°C, V<sub>CC</sub> = V<sub>DD</sub> = +5V ±10%, V<sub>SS</sub> = 0V

| Symbol                           | Parameter                                                      | Limits |      |                 | Unit | Test Conditions                                            |
|----------------------------------|----------------------------------------------------------------|--------|------|-----------------|------|------------------------------------------------------------|
|                                  |                                                                | Min.   | Typ. | Max.            |      |                                                            |
| V <sub>IL</sub>                  | Input Low Voltage<br>(All Except XTAL1, XTAL2)                 | -0.5   |      | 0.8             | V    |                                                            |
| V <sub>IH</sub>                  | Input High Voltage<br>(All Except XTAL1, XTAL2, <u>RESET</u> ) | 2.0    |      | V <sub>CC</sub> | V    |                                                            |
| V <sub>IH1</sub>                 | Input High Voltage ( <u>RESET</u> , XTAL1)                     | 3.0    |      | V <sub>CC</sub> | V    |                                                            |
| V <sub>OL</sub>                  | Output Low Voltage<br>(BUS, RD, WR, PSEN, ALE)                 |        |      | 0.45            | V    | I <sub>OL</sub> = 2.0mA                                    |
| V <sub>OL1</sub>                 | Output Low Voltage<br>(All Other Outputs Except PROG)          |        |      | 0.45            | V    | I <sub>OL</sub> = 1.6mA                                    |
| V <sub>OH</sub>                  | Output High Voltage<br>(BUS, RD, WR, PSEN, ALE)                | 2.4    |      |                 | V    | I <sub>OH</sub> = 100µA                                    |
| V <sub>OH1</sub>                 | Output High Voltage<br>(All Other Outputs)                     | 2.4    |      |                 | V    | I <sub>OH</sub> = 50µA                                     |
| I <sub>IL</sub>                  | Input Leakage Current<br>(T1, EA, INT)                         |        |      | ±10             | µA   | V <sub>SS</sub> ≤ V <sub>IN</sub> ≤ V <sub>CC</sub>        |
| I <sub>OL</sub>                  | Output Leakage Current (Bus, T0)<br>(High Impedance State)     |        |      | -10             | µA   | V <sub>CC</sub> ≥ V <sub>IN</sub> ≥ V <sub>SS</sub> + 0.45 |
| I <sub>DD</sub>                  | Power Down Supply Current                                      |        | 20   | 50              | mA   | T <sub>A</sub> = 25°C                                      |
| I <sub>DD</sub> +I <sub>CC</sub> | Total Supply Current                                           |        | 75   | 140             | mA   | T <sub>A</sub> = 25°C                                      |

**A.C. CHARACTERISTICS** T<sub>A</sub> = 0°C to 70°C, V<sub>CC</sub> = V<sub>DD</sub> = +5V ±10%, V<sub>SS</sub> = 0V

| Symbol           | Parameter                          | 8049/8039 |      | Unit | Conditions             |
|------------------|------------------------------------|-----------|------|------|------------------------|
|                  |                                    | Min.      | Max. |      |                        |
| t <sub>LL</sub>  | ALE Pulse Width                    | 400       |      | ns   |                        |
| t <sub>AL</sub>  | Address Setup to ALE               | 150       |      | ns   |                        |
| t <sub>LA</sub>  | Address Hold from ALE              | 80        |      | ns   |                        |
| t <sub>CC</sub>  | Control Pulse Width (PSEN, RD, WR) | 900       |      | ns   |                        |
| t <sub>DW</sub>  | Data Set-Up Before WR              | 500       |      | ns   |                        |
| t <sub>WD</sub>  | Data Hold After WR                 | 120       |      | ns   | C <sub>L</sub> = 20 pF |
| t <sub>CY</sub>  | Cycle Time                         | 2.5       | 15.0 | µs   | 6 MHz XTAL             |
| t <sub>DR</sub>  | Data Hold                          | 0         | 200  | ns   |                        |
| t <sub>RD</sub>  | PSEN, RD to Data In                |           | 500  | ns   |                        |
| t <sub>AW</sub>  | Address Setup to WR                | 230       |      | ns   |                        |
| t <sub>AD</sub>  | Address Setup to Data In           |           | 950  | ns   |                        |
| t <sub>AFC</sub> | Address Float to RD, PSEN          | 0         |      | ns   |                        |

**A.C. TEST CONDITIONS** Control Outputs: C<sub>L</sub> = 80 pF

BUS Outputs: C<sub>L</sub> = 150 pF

t<sub>CY</sub> = 2.5µs

**WAVEFORMS****Instruction Fetch From External Program Memory****Read From External Data Memory****Write To External Data Memory**

8041/8741

**ABSOLUTE MAXIMUM RATINGS\***

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Ambient Temperature Under Bias .....               | 0°C to 70°C     |
| Storage Temperature .....                          | -65°C to +150°C |
| Voltage on Any Pin With<br>Respect to Ground ..... | 0.5V to +7V     |
| Power Dissipation .....                            | 1.5 Watt        |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. AND OPERATING CHARACTERISTICS** $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = V_{DD} = +5V \pm 5\%$ ,  $V_{SS} = 0V$ 

| Symbol            | Parameter                                                             | Limits |      |          | Unit          | Test Conditions                         |
|-------------------|-----------------------------------------------------------------------|--------|------|----------|---------------|-----------------------------------------|
|                   |                                                                       | Min.   | Typ. | Max.     |               |                                         |
| $V_{IL}$          | Input Low Voltage (All Except $X_1, X_2$ )                            | -0.5   |      | 0.8      | V             |                                         |
| $V_{IH}$          | Input High Voltage (All Except $X_1, X_2$ RESET)                      | 2.0    |      | $V_{CC}$ | V             |                                         |
| $V_{IH2}$         | Input High Voltage ( $X_1$ , RESET)                                   | 3.0    |      | $V_{CC}$ | V             |                                         |
| $V_{OL}$          | Output Low Voltage ( $D_0-D_7$ , Sync)                                |        |      | 0.45     | V             | $I_{OL} = 2.0 \text{ mA}$               |
| $V_{OL2}$         | Output Low Voltage (All Other Outputs Except Prog)                    |        |      | 0.45     | V             | $I_{OL} = 1.6 \text{ mA}$               |
| $V_{OH}$          | Output High Voltage ( $D_0-D_7$ )                                     | 2.4    |      |          | V             | $I_{OH} = -400 \mu\text{A}$             |
| $V_{OH1}$         | Output High Voltage (All Other Outputs)                               | 2.4    |      |          | V             | $I_{OH} = -50 \mu\text{A}$              |
| $I_{IL}$          | Input Leakage Current ( $T_0, T_1, \bar{RD}, WR, \bar{CS}, A_0, EA$ ) |        |      | $\pm 10$ | $\mu\text{A}$ | $V_{SS} \leq V_{IN} \leq V_{CC}$        |
| $I_{OL}$          | Output Leakage Current ( $D_0-D_7$ , High Z State)                    |        |      | $\pm 10$ | $\mu\text{A}$ | $V_{SS} + 0.45 \leq V_{IN} \leq V_{CC}$ |
| $I_{DD}$          | $V_{DD}$ Supply Current                                               |        | 10   | 25       | mA            |                                         |
| $I_{CC} + I_{DD}$ | Total Supply Current                                                  |        | 65   | 135      | mA            |                                         |
| $V_{OL3}$         | Output Low Voltage (Prog)                                             |        |      | 0.45     | V             | $I_{OL} = 1.0 \text{ mA}$               |
| $I_{LI1}$         | Low Input Source Current $P_{10}-P_{17} P_{20}-P_{27}$                |        |      | 0.4      | mA            | $V_{IL} = 0.8V$                         |
| $I_{LI2}$         | Low Input Source Current RESET, SS                                    |        |      | 0.2      | mA            | $V_{IL} = 0.8V$                         |

**A.C. CHARACTERISTICS** $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = V_{DD} = +5V \pm 5\%$ ,  $V_{SS} = 0V$ 

DBB Read:

| Symbol   | Parameter                                      | 8741 |                   | 8041 |      | Units         | Test Conditions            |
|----------|------------------------------------------------|------|-------------------|------|------|---------------|----------------------------|
|          |                                                | Min. | Max.              | Min. | Max. |               |                            |
| $t_{AR}$ | $\bar{CS}, A_0$ Setup to $\bar{RD} \downarrow$ | 60   |                   | 0    |      | ns            |                            |
| $t_{RA}$ | $\bar{CS}, A_0$ Hold After $\bar{RD} \uparrow$ | 30   |                   | 0    |      | ns            |                            |
| $t_{RR}$ | $\bar{RD}$ Pulse Width                         | 300  | $2 \times t_{CY}$ | 250  |      | ns            | $t_{CY} = 2.5 \mu\text{s}$ |
| $t_{AD}$ | $\bar{CS}, A_0$ to Data Out Delay              |      | 370               |      | 150  | ns            |                            |
| $t_{RD}$ | $\bar{RD} \downarrow$ to Data Out Delay        |      | 200               |      | 150  | ns            |                            |
| $t_{DF}$ | $\bar{RD} \uparrow$ to Data Float Delay        | 10   |                   | 10   |      | ns            |                            |
|          |                                                |      | 140               |      | 100  | ns            |                            |
| $t_{RV}$ | Recovery Time Between Reads And/Or Write       | 1    |                   | 1    |      | $\mu\text{s}$ |                            |
| $t_{CY}$ | Cycle Time                                     | 2.5  |                   | 2.5  |      | $\mu\text{s}$ | 6 MHz Crystal              |

**DBB Write:**

| Symbol   | Parameter                                                | 8741 |                   | 8041 |      | Units | Test Conditions      |
|----------|----------------------------------------------------------|------|-------------------|------|------|-------|----------------------|
|          |                                                          | Min. | Max.              | Min. | Max. |       |                      |
| $t_{AW}$ | $\overline{CS}, A_0$ Setup to $\overline{WR} \downarrow$ | 60   |                   | 0    |      | ns    |                      |
| $t_{WA}$ | $CS, A_0$ Hold After WR $\uparrow$                       | 30   |                   | 0    |      | ns    |                      |
| $t_{WW}$ | WR Pulse Width                                           | 300  | $2 \times t_{CY}$ | 250  |      | ns    | $t_{CY} = 2.5 \mu s$ |
| $t_{DW}$ | Data Setup to WR $\uparrow$                              | 250  |                   | 150  |      | ns    |                      |
| $t_{WD}$ | Data Hold After WR $\uparrow$                            | 30   |                   | 0    |      | ns    |                      |

**A.C. TEST CONDITIONS**

$D_7-D_0$  Outputs       $R_L = 2.2k$  to  $V_{SS}$   
                                  $4.3k$  to  $V_{CC}$   
                                  $C_L = 100 \text{ pF}$

**WAVEFORMS****Read Operation — Data Bus Buffer Register****Write Operation — Data Bus Buffer Register**

**8041/8741****8748 Erasure Characteristics**

The erasure characteristics of the 8748 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms (A). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the 3000-4000Å range. Data show that constant exposure to room level fluorescent lighting could erase the typical 8748 in approximately 3 years while it would take approximately one week to cause erasure when exposed to direct sunlight. If the 8748 is to be exposed to these types of lighting conditions for extended periods of

time, opaque labels are available from Intel which should be placed over the 8748 window to prevent unintentional erasure.

The recommended erasure procedure for the 8748 is exposure to shortwave ultraviolet light which has a wavelength of 2537Å. The integrated dose (i.e., UV intensity  $\times$  exposure time) for erasure should be a minimum of 15 W-sec/cm<sup>2</sup>. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a 12,000  $\mu$ W/cm<sup>2</sup> power rating. The 8748 should be placed within one inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

**A.C. TIMING SPECIFICATION FOR PROGRAMMING**

$T_A = 25^\circ\text{C} \pm 5^\circ\text{C}$ ,  $V_{CC} = 5V \pm 5\%$ ,  $V_{DD} = 25V \pm 1V$

| Symbol             | Parameter                                    | Min. | Max. | Unit    | Test Conditions |
|--------------------|----------------------------------------------|------|------|---------|-----------------|
| t <sub>AW</sub>    | Address Setup Time to RESET 1                | 4tcy |      |         |                 |
| t <sub>WA</sub>    | Address Hold Time After RESET 1              | 4tcy |      |         |                 |
| t <sub>DW</sub>    | Data in Setup Time to PROG 1                 | 4tcy |      |         |                 |
| t <sub>WD</sub>    | Data in Hold Time After PROG 1               | 4tcy |      |         |                 |
| t <sub>PH</sub>    | RESET Hold Time to Verify                    | 4tcy |      |         |                 |
| t <sub>VDDW</sub>  | V <sub>DD</sub>                              | 4tcy |      |         |                 |
| t <sub>VDDH</sub>  | V <sub>DD</sub> Hold Time After PROG 1       | 0    |      |         |                 |
| t <sub>PW</sub>    | Program Pulse Width                          | 50   | 60   | MS      |                 |
| t <sub>TW</sub>    | Test 0 Setup Time for Program Mode           | 4tcy |      |         |                 |
| t <sub>WT</sub>    | Test 0 Hold Time After Program Mode          | 4tcy |      |         |                 |
| t <sub>DO</sub>    | Test 0 to Data Out Delay                     |      | 4tcy |         |                 |
| t <sub>WW</sub>    | RESET Pulse Width to Latch Address           | 4tcy |      |         |                 |
| t <sub>r, tr</sub> | V <sub>DD</sub> and PROG Rise and Fall Times | 0.5  | 2.0  | $\mu$ s |                 |
| t <sub>CY</sub>    | CPU Operation Cycle Time                     | 5.0  |      | $\mu$ s |                 |
| t <sub>RE</sub>    | RESET Setup Time Before EA 1                 | 4tcy |      |         |                 |

Note: If TEST 0 is high, t<sub>DO</sub> can be triggered by RESET 1.

**D.C. SPECIFICATION FOR PROGRAMMING**

$T_A = 25^\circ\text{C} \pm 5^\circ\text{C}$ ,  $V_{CC} = 5V \pm 5\%$ ,  $V_{DD} = 25V \pm 1V$

| Symbol            | Parameter                                   | Min. | Max. | Unit | Test Conditions |
|-------------------|---------------------------------------------|------|------|------|-----------------|
| V <sub>D0H</sub>  | V <sub>DD</sub> Program Voltage High Level  | 24.0 | 26.0 | V    |                 |
| V <sub>D0L</sub>  | V <sub>DD</sub> Voltage Low Level           | 4.75 | 5.25 | V    |                 |
| V <sub>P0H</sub>  | PROG Program Voltage High Level             | 21.5 | 24.5 | V    |                 |
| V <sub>P0L</sub>  | PROG Voltage Low Level                      |      | 0.2  | V    |                 |
| V <sub>EAH</sub>  | EA Program or Verify Voltage High Level     | 21.5 | 24.5 | V    |                 |
| V <sub>EAL</sub>  | EA Voltage Low Level                        |      | 5.25 | V    |                 |
| I <sub>DD</sub>   | V <sub>DD</sub> High Voltage Supply Current |      | 30.0 | mA   |                 |
| I <sub>PROG</sub> | PROG High Voltage Supply Current            |      | 16.0 | mA   |                 |
| I <sub>EA</sub>   | EA High Voltage Supply Current              |      | 1.0  | mA   |                 |

## WAVEFORMS

## Combination Program/Verify Mode (EPROMs Only)



## Verify Mode (ROM/EPROM)

## VERIFY MODE (ROM/EPROM)



**ABSOLUTE MAXIMUM RATINGS\***

Ambient Temperature Under Bias . . . . . 0°C to 70°C  
 Storage Temperature . . . . . -65°C to +150°C  
 Voltage on Any Pin  
     With Respect to Ground . . . . . -0.5V to +7V  
 Power Dissipation . . . . . 1 Watt

*\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.*

**D.C. AND OPERATING CHARACTERISTICS**

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = 5\text{V} \pm 10\%$

| Symbol    | Parameter                           | Min. | Typ. | Max.         | Units         | Test Conditions           |
|-----------|-------------------------------------|------|------|--------------|---------------|---------------------------|
| $V_{IL}$  | Input Low Voltage                   | -0.5 |      | 0.8          | V             |                           |
| $V_{IH}$  | Input High Voltage                  | 2.0  |      | $V_{CC}+0.5$ | V             |                           |
| $V_{OL1}$ | Output Low Voltage Ports 4-7        |      |      | 0.45         | V             | $I_{OL} = 5\text{ mA}^*$  |
| $V_{OL2}$ | Output Low Voltage Port 7           |      |      | 1            | V             | $I_{OL} = 20\text{ mA}$   |
| $V_{OH1}$ | Output High Voltage Ports 4-7       | 2.4  |      |              | V             | $I_{OH} = 240\mu\text{A}$ |
| $I_{IL1}$ | Input Leakage Ports 4-7             | -10  |      | 20           | $\mu\text{A}$ | $V_{in} = V_{CC}$ to 0V   |
| $I_{IL2}$ | Input Leakage Port 2, CS, PROG      | -10  |      | 10           | $\mu\text{A}$ | $V_{in} = V_{CC}$ to 0V   |
| $V_{OL3}$ | Output Low Voltage Port 2           |      |      | .45          | V             | $I_{OL} = 0.6\text{ mA}$  |
| $I_{CC}$  | $V_{CC}$ Supply Current             |      | 10   | 20           | mA            |                           |
| $V_{OH2}$ | Output Voltage Port 2               | 2.4  |      |              |               | $I_{OH} = 100\mu\text{A}$ |
| $I_{OL}$  | Sum of all $I_{OL}$ from 16 Outputs |      |      | 100          | mA            | 5 mA Each Pin             |

\*See following graph for additional sink current capability.

**A.C. CHARACTERISTICS**

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = 5\text{V} \pm 10\%$

| Symbol    | Parameter                         | Min. | Max. | Units | Test Conditions |
|-----------|-----------------------------------|------|------|-------|-----------------|
| $t_A$     | Code Valid Before PROG            | 100  |      | ns    | 80 pF Load      |
| $t_B$     | Code Valid After PROG             | 60   |      | ns    | 20 pF Load      |
| $t_C$     | Data Valid Before PROG            | 200  |      | ns    | 80 pF Load      |
| $t_D$     | Data Valid After PROG             | 20   |      | ns    | 20 pF Load      |
| $t_H$     | Floating After PROG               | 0    | 150  | ns    | 20 pF Load      |
| $t_K$     | PROG Negative Pulse Width         | 900  |      | ns    |                 |
| $t_{CS}$  | CS Valid Before/After PROG        | 50   |      | ns    |                 |
| $t_{PO}$  | Ports 4-7 Valid After PROG        |      | 700  | ns    | 100 pF Load     |
| $t_{LP1}$ | Ports 4-7 Valid Before/After PROG | 100  |      | ns    |                 |
| $t_{ACC}$ | Port 2 Valid After PROG           |      | 750  | ns    | 80 pF Load      |

## WAVEFORMS



# Chapter 7

## ZILOG Z80

Zilog Z80 microcomputer devices have been designed as 8080A enhancements. In fact, the same individuals responsible for designing the 8080A CPU at Intel designed the Z80 devices at Zilog. The 8085, described in Chapter 5, is Intel's 8080A enhancement.

The Z80 instruction set includes all 8080A instructions as a subset. In deference to rational necessity, however, neither the Z80 CPU, nor any of its support devices attempt to maintain pin-for-pin compatibility with 8080A counterparts. Compatibility is limited to instruction sets and general functional capabilities. A program that has been written to drive an 8080A microcomputer system will also drive the Z80 system — within certain limits; for example, a ROM device that has been created to implement object programs for an 8080A microcomputer system can be physically removed and used in a Z80 system.

But Z80-8080A compatibility does extend somewhat further, since most support devices that have been designed for the 8080A CPU will also work with a Z80 CPU; therefore in many cases you will be able to upgrade an 8080A microcomputer system to a Z80, confining hardware modifications to the CPU and its immediate interface only.

It is interesting to note that the Z80 pins and signal interface is far closer than the 8085 to the three-chip 8080A configuration illustrated in 8080A chapter. Also, whereas the Z80 instruction set is greatly expanded as compared to the 8080A, the 8085 instruction set contains just two new instructions. However, both the Z80 and the 8085 have resolved the two most distressing problems associated with the 8080A — the three-chip 8080A CPU has in both cases been reduced to one chip, and the three 8080A power supplies have in both cases been reduced to a single +5V power supply.

ZILOG, INC., manufacturers of the Z80, are located at:

10460 Bubb Road  
Cupertino, California 95014

The official second source for Zilog products is:

MOSTEK, INC.  
1215 West Crosby Road  
Carrollton, Texas 75006

N-Channel MOS technology is used for all Z80 devices.

Z80 LSI  
TECHNOLOGY

### THE Z80 CPU

Functions implemented on the Z80 CPU are illustrated in Figure 7-1. They represent "typical" CPU logic, equivalent to the three devices: 8080A CPU, 8224 Clock and 8228 System Controller.

#### A SUMMARY OF Z80/8080A DIFFERENCES

We are going to summarize Z80/8080A differences before describing differences in detail. If you know the 8080A well, read on; if you do not, come back to this summary after reading the rest of the Z80 CPU description. We will also contrast the Z80 and the 8085, where relevant.

For the programmer, the Z80 provides more registers and addressing modes than the 8080A, plus a much larger instruction set.

Significant hardware features are a single power supply (+5V), a single system clock signal, an additional interrupt, and logic to refresh dynamic memories.



Figure 7-1. Logic Functions of the Z80 CPU

The 8085 also has a single power supply and a single system clock signal. The 8085 has three additional interrupts, but lacks logic to refresh dynamic memories.

#### **Is the Z80 CPU indeed the logical next 8080A evolution?**

**Hardware aspects of the 8080A represent its weakest features, as compared to principal current competitors.** Specifically, the fact that the 8080A is really a three-chip CPU is its biggest single problem; three chips are always going to cost more than one. Next, the fact that the 8080A requires three power supplies (+5V, -5V and +12V) is a very negative feature for many users and the desirability of going to a single power supply is self-evident; the Z80 requires a single +5V power supply. This is also true of the 8085.

The problems associated with condensing logic from three chips onto one chip are not so straightforward. Figure 7-2 illustrates the standard three-chip 8080A CPU. Let us assume that the three devices are to be condensed into a single chip. Asterisks (\*) have been placed by the signals which must be maintained if the single chip is to be hardware compatible with the three chips it replaces. Forty-three signals are asterisked, therefore the standard 40-pin DIP cannot be used. The problem is compounded by the fact that not all 8080A systems use an 8228 System Controller. Some 8080A systems use an 8212 bidirectional I/O port to create control signals. A few of the earliest 8080 systems use neither the 8228 System Controller, nor an 8212 I/O port; rather external logic decodes the Data Bus when SYNC is true in order to generate control signals; for example, that is how the TMS5501 works. We must therefore conclude that any attempt

to reduce three chips to one will create a product that is not pin compatible with the 8080A; and, indeed, the Z80 is not pin compatible. What Zilog has done is include as many hardware enhancements as possible within the confines of a 40-pin DIP that must be philosophically similar to the 8080A, without attempting any form of pin compatibility. Figure 7-2 identifies the correlation between Z80 signals and 8080A signals. Notice that there is a significant similarity.

Figure 5-3 is equivalent to Figure 7-2, comparing 8085 and 8080A signals. Z80 signals are far closer to the 8080A three-chip set than the 8085.

#### Here is a summary of the hardware differences:

- 1) The Z80 has reduced three power supplies to a single +5V power supply.
- 2) Clock logic is entirely within the Z80.
- 3) The complex, two clock signals of the 8080A have been replaced by a single clock signal.
- 4) Automatic dynamic memory refresh logic has been included within the CPU.
- 5) Read and write control signal philosophy has changed. The 8080A uses separate memory read, memory write, I/O read and I/O write signals. The Z80 uses a general read and a general write, coupled with a memory select and an I/O select. This means that if a Z80 CPU is to replace an 8080A CPU then additional logic will be required beyond the Z80 CPU. You will either have to combine the four Z80 control signals to generate 8080A equivalents, or you will have to change the select and strobe logic for every I/O device. We will discuss this in more detail later.
- 6) Address and Data Bus float timing associated with DMA operations have changed. The 8080A floats these busses at the beginning of the third or fourth time period within the machine cycle during which a bus request occurs; this initiates a Hold state. The Z80 has a more straightforward scheme: a Bus Request input signal causes the Data and Address Busses to float at the beginning of the machine cycle; floating busses are acknowledged with a Bus Acknowledge output signal.
- 7) The Z80 has an additional interrupt request. In addition to the RESET and normal 8080A interrupt request, the Z80 has a nonmaskable interrupt which is typically used to execute a short program that prepares for power failure, once a power failure has been detected.

#### Now consider internal organization of the Z80 in terms of instruction set compatibility and enhancement.

As illustrated by Table 7-3 the 8080A instruction set is, indeed, a subset of the Z80 instruction set. Unfortunately, the Z80 uses completely new source program instruction mnemonics, therefore 8080A instructions cannot immediately be identified. Technical Design Labs, Inc., has an 8080-like Z80 assembly language.



Figure 7-2. The Standard 8080A Three-Chip System and Z80 Signal Equivalents

There are very few unused object codes in the 8080A instruction set. The Z80 has therefore taken what few unused object codes there are, and used them to specify that an additional byte of object code follows:

11011101 ← Spare 8080A object code  
← Specifies new Z80 object code follows

This results in most new Z80 instructions having 16-bit object codes; but simultaneously it means that a very large number of new instructions can be added.

Any enhancement of the 8080A can include major changes within the CPU; providing the 8080A registers and status flags remain as a subset of the new design, instruction compatibility remains. These are the principal enhancements made by the Z80:

- 1) The standard general purpose registers and status flags have been duplicated. This makes it very easy to handle single-level interrupts, since general purpose register and Accumulator contents no longer need to be saved on the Stack; instead, the program may simply switch to the alternate register set.
- 2) Two Index registers have been added. This means that additional Z80 instructions can use indexed memory addressing.
- 2) An Interrupt Vector register allows external logic the option of responding to an interrupt acknowledge by issuing the equivalent of a Call instruction — which vectors program execution to a memory address which is dedicated to the acknowledged external logic.
- 4) A single Block Move instruction allows the contents of any number of contiguous memory bytes to be moved from one area of memory to another, or between an area of memory and a single I/O port. You can also scan a block of memory for a defined value by executing a Block Compare instruction.
- 5) Instructions have been added to test or alter the condition of individual register and memory bits.

In contrast to the extensive enhancements of the Z80, the 8085 registers and status architecture are identical to the 8080A. There are only two additional instructions in the 8085 instruction set; however, the 8085, like the Z80, allows Call instructions to be used when acknowledging an interrupt — a particularly useful enhancement.

**While on the surface the Z80 instruction set appears to be very powerful, note that instruction sets are very subjective; right and wrong, good and bad are not easily defined. Let us look at some nonobvious features of the Z80 instruction set.**

First of all, the execution speed advantage that results from the new Z80 instructions is reduced by the fact that many of these instructions require two bytes of object code. Some examples of Z80 instructions and equivalent 8080A instruction sequences with equivalent cycle times are given in Table 7-1.

Table 7-1. Comparisons of Z80 and 8080A  
Instruction Execution Cycles

| Z80           |        | 8080A        |                |
|---------------|--------|--------------|----------------|
| Instructions  | Cycles | Instructions | Cycles         |
| LD R,(IX + d) | 19     | LXI H,d      | 10             |
|               |        | DAD IX       | 10             |
|               |        | MOV R,M      | <u>7</u><br>27 |
| LD RP,ADDR    | 20     | LHLD ADDR    | 16             |
|               |        | MOV C,L      | 5              |
|               |        | MOV B,H      | <u>5</u><br>26 |
| SET B,(HL)    | 15     | MOV A,M      | 7              |
|               |        | ORI MASK     | 7              |
|               |        | MOV M,A      | <u>7</u><br>21 |

Also, a novice programmer may find the Z80 instruction set bewilderingly complex. At a time when the majority of potential microcomputer users are terrified by simple assembly language instruction sets, it is possible that users will react negatively to an instruction set whose complexity (if not power) rivals that of many large minicomputers.

Many of the new Z80 instructions use direct, indexed memory addressing to perform operations which are otherwise identical to existing 8080A instructions. Now the Z80 has two new 16-bit Index registers whose contents are added to

an 8-bit displacement provided by the instruction code: this is the scheme adopted by the Motorola MC6800. This scheme is inherently weaker than having a 16-bit, instruction-provided displacement, as implemented by the Signetics 2650. When the Index register is larger than the displacement, the Index register, in effect, becomes a base register. When the Index register has the same size, or is smaller than the displacement, it is truly an Index register as described in "Volume 1 — Basic Concepts". The Signetics 2650 implementation is more powerful.

## Z80 PROGRAMMABLE REGISTERS

We will now start looking at the Z80 CPU in detail, beginning with its programmable registers.

The Z80 has two sets of 8-bit programmable registers, and two Program Status Words. At any time one set of programmable registers and one Program Status Word will be active and accessible.

In addition, the Z80 has a 16-bit Program Counter, a 16-bit Stack Pointer, two 16-bit Index registers, an 8-bit Interrupt Vector and an 8-bit Memory Refresh register.

Figure 7-3 illustrates the Z80 registers. Within this figure, the 8080A registers' subset is shaded.



Figure 7-3. Z80 Programmable Registers

The Z80 uses its Program Status Word, its A, B, C, D, E, H, and L registers, plus the Stack Pointer and the Program Counter exactly as the 8080A uses these locations; therefore no additional discussion of these registers is needed.

The Program Status Word, plus registers A, B, C, D, E, H and L are duplicated. Single Z80 instructions allow you to switch access from one register set to another, or to exchange the contents of selected registers. At any time, one or the other set of registers, but not both, is accessible.

There are two 16-bit Index registers, marked IX and IY. These are more accurately looked upon as base registers, as will become apparent when we examine Z80 addressing modes.

The Interrupt Vector register performs a function similar to the ICW2 byte of the 8259 PICU device (described in the 8080A chapter). Z80 interrupt acknowledge logic gives you the option of initiating an interrupt service routine with a Call instruction, where the high order address byte for the call is provided by the Interrupt Vector register. The 8085 also provides this capability.

The Memory Refresh Counter register represents a feature of microcomputer systems which has been overlooked by everyone except Fairchild and Zilog. Dynamic memory devices will not hold their contents for very long, irrespective of whether power is off or on. A dynamic memory must therefore be accessed at millisecond intervals. Dynamic memory devices compensate for this short-coming by being very cheap — and dynamic refresh circuitry is very simple. Using a technique akin to direct memory access, dynamic refresh circuitry will periodically access dynamic memories, rewriting the contents of individual memory words on each access. About the only logic needed by dynamic refresh is a counter via which it keeps track of its progress through the dynamic memory; that is the purpose of the Z80 Memory Refresh Counter register. The Z80 also has a special DMA refresh control signal; therefore the Z80 provides much of the dynamic refresh logic needed by dynamic memory devices.

## Z80 ADDRESSING MODES

Z80 instructions use all of the 8080A addressing modes; the Z80 also has these two enhancements:

- 1) A number of memory reference instructions use the IX and IY registers for indexed, or base relative addressing.
- 2) There are some two-byte program relative Jump instructions.

A memory reference instruction that uses the IX or IY register will include a single data displacement byte. The 8-bit value provided by the instruction object code is added to the 16-bit value provided by the identified Index register in order to compute the effective memory address:

**Z80  
INDEXED  
ADDRESSING**



This is standard microcomputer indexed addressing and is less powerful than having the memory reference instruction provide a 16-bit base address or displacement; for a discussion of these addressing modes see "Volume 1 — Basic Concepts". Chapter 6.

The program relative, two-byte Jump instructions provided by the Z80 provide standard two-byte, program relative addressing. A single, 8-bit displacement is provided by the Jump instruction's object code; this 8-bit displacement is added, as a signed binary value, to the contents of the Program Counter — after the Program Counter has been incremented to point to the sequential instruction:



The next instruction object code will be fetched from memory location  $ppqq+2+dd$ . p, q, and d represent any hexadecimal digits. dd represents a signed binary, 8-bit value.

For a discussion of program relative addressing, see "Volume 1 - Basic Concepts"

**The Z80 addressing enhancements are of significant value when comparing the Z80 to the 8080A.**

The value of the Index register comes not so much from having an additional addressing option, but rather IX and IY allow an efficient programmer to husband his CPU register space more effectively. Look upon IX and IY as performing memory addressing tasks which the 8080A would have to perform using the BC and DE registers. By freeing up the BC and DE registers for data manipulation, you can significantly reduce the number of memory reference instructions executed by the Z80.

The two-byte program relative Jump instruction is useful because in most programs 80% of the Jump instructions branch to a memory location that is within 128 bytes of the Jump. That is the rationale for most microcomputers offering two-byte as well as three-byte Jump instructions.

## Z80 STATUS

**The Z80 and 8080A both use the Program Status Word in order to store status flags. These are the Z80 status flags:**

- Carry (C)
- Zero (Z)
- Sign (S)
- Parity/Overflow (P/O)
- Auxiliary Carry (AC)
- Subtract (N)

Statuses are recorded in the Program Status Word by the Z80, as compared to the 8080A, as follows:



**The Parity/Overflow and Subtract statuses differ from the 8080A. All other statuses are the same. Note that the Z80, like the 8080A, uses borrow philosophy for the Carry status when performing subtract operations.** That is to say, during a subtract operation, the Carry status takes the reciprocal value of any Carry out of the high-order bit. For details see the 8080A Carry status descriptions given in the 8080A chapter.

The 8080A has a Parity status but no Overflow status. The Z80 uses a single status flag for both operations, which makes a lot of sense. The Z80 Overflow status is absolutely standard, therefore only has meaning when signed binary arithmetic is being performed — at which time the Parity status has no meaning. Within the Z80, therefore, this single status is used by arithmetic operations to record overflow and by other operations to record parity. For a complete discussion of the Overflow status see "Volume 1 — Basic Concepts".

The Subtract status is used by the DAA instruction for BCD operations, to differentiate between decimal addition or subtraction. The Subtract and Auxiliary Carry statuses cannot be used as conditions for program branching (conditional Jump, Call or Return instructions).

## Z80 CPU PINS AND SIGNALS

**The Z80 CPU pins and signals are illustrated in Figure 7-4. Figure 7-2 provides the direct comparison between Z80 CPU signals and the standard 8080A, 8228, 8224 three-chip systems.**

Let us first look at the Data and Address Busses.

**The 16 address lines A0 - A15 output memory and I/O device addresses.** The address lines are tristate; they may be floated by the Z80 CPU, giving external logic control of the Address Bus. **There is no difference between Z80 and 8080A Address Bus lines.**

**The Data Bus lines D0 - D7 transmit bidirectional data into or out of the Z80 CPU.** Like the Address Bus lines, the Data Bus lines are tristate. **The Z80 Data Bus lines do differ from the 8080A equivalent.** The 8080A Data Bus is multiplexed; status output on the Data Bus by the 8080A during the T2 clock period of very machine cycle is strobed by the SYNC pulse. The Z80 does not multiplex the Data Bus in this way. The Z80 Data Bus lines operate at normal TTL levels, whereas the 8080A Data Bus lines do not.

**Control signals are described next; these may be divided into system control, CPU control and Bus control. First we will describe the System control signals.**

**Z80 SYSTEM  
CONTROL  
SIGNALS**

**M1 identifies the instruction fetch machine cycle of an instruction's execution. Its function is similar, but not identical to the 8080A SYNC pulse.** The Z80 PIO device uses the low M1 pulse as a reset signal if it occurs without IORQ or RD simultaneously low.

**MREQ identifies any memory access operation in progress; it is a tristate control signal.**

**IORQ identifies any I/O operation in progress.** When **IORQ** is low, A0 - A7 contain a valid I/O port address. **IORQ is also used as an interrupt acknowledge; an interrupt is acknowledged by M1 and IORQ being output low** — a unique combination, since M1 is otherwise low only during an instruction fetch, which cannot address an I/O device.

RD is a tristate signal which indicates that the CPU wishes to read data from either memory or an I/O device, as identified MREQ or IORQ.

WR is a tristate control signal which indicates that the CPU wishes to write data to memory or an I/O device as indicated by MREQ and IORQ. Some Z80 I/O devices have no WR input. These devices assume a Write operation when IORQ is low and RD is high. RD low specifies a Read operation.

The various ways in which the three control signals, M1, IORQ, and RD, may be interpreted are summarized in Table 7-5, which occurs in the description of the Z80 PIO device.

RFSH is a control signal used to refresh dynamic memories. When RFSH is output low, the current MREQ signal should be used to refresh dynamic memory, as addressed by the lower seven bits of the Address Bus, A0 - A6.

Next we will describe CPU control signals.



Figure 7-4. Z80 CPU Signals and Pin Assignments

**HALT** is output low following execution of a Halt instruction. The CPU now enters a Halt state during which it continuously re-executes a NOP instruction in order to maintain memory refresh activity. A Halt can only be terminated with an interrupt.

### Z80 CPU CONTROL SIGNALS

**WAIT** is equivalent to the 8080A READY input. External logic which cannot respond to a CPU access request within the allowed time interval extends the time interval by pulling the WAIT input low. In response to WAIT low, the Z80 enters a Wait state during which the CPU inserts an integral number of clock periods; taken together, these clock periods constitute a Wait state.

**INT** and **NMI** are two interrupt request inputs. The difference between these two signals is that NMI has higher priority and cannot be disabled.

There are two Bus control signals.

### Z80 BUS CONTROL SIGNALS

**RESET** is a standard reset control input. When the Z80 is reset, this is what happens:

The Program Counter, IV and R registers' contents are all set to zero.

Interrupt requests via INT are disabled.

All tristate bus signals are floated.

**BUSRQ** and **BUSAK** are bus request and acknowledge signals. In order to perform any kind of DMA operation, external logic must acquire control of the microcomputer System Bus. This is done by inputting **BUSRQ** low; at the conclusion of the current machine cycle, the Z80 CPU will float all tristate bus lines and will acknowledge the bus request by outputting **BUSAK** low.

## Z80 - 8080A SIGNAL COMPATIBILITY

If you are designing a new product around the Z80 CPU, then questions of Z80 - 8080A signal compatibility are irrelevant; you will design for the CPU on hand.

If you are replacing an 8080A with a Z80, then it would be helpful to have some type of lookup table which directly relates 8080A signals to Z80 signals. Unfortunately, such a lookup table cannot easily be created. The problem is that the Z80 is an implementation of three devices: the 8080A CPU, the 8224 Clock, and 8228 System Controller; but there are very many 8080A configurations that do not include an 8228 System Controller.

Possibly the most important conceptual difference between the Z80 and 8080A involves read and write control signals. The 8228 System Controller develops four discrete control signals for memory read, memory write, I/O read and I/O write. The Z80 has a general read and a general write, coupled with an I/O select and a memory select. By adding logic, it would be easy enough to generate the four discrete 8080A signals from the two Z80 signal pairs; here is one elementary possibility:



If your design allows it, however, it would be wiser to extend the Z80 philosophy to the various support devices surrounding the CPU. Recall from our discussion of 8080A support devices in Chapter 4 that every device requires separate device select and device access logic. For some arbitrary read operation, timing might be illustrated as follows:



With an 8080A scheme, select logic is decoded from Address Bus lines, while strobe logic depends on one of the four control lines I/OR, I/OW, MEMR or MEMW. Using the Z80 philosophy, the memory select (MREQ) or I/O select (IORQ) control lines become part of the device select logic, while the read (RD) or write (WR) controls generate the strobe.

**The Z80 has no interrupt acknowledge signal; rather it combines IORQ with M1 as follows:**



Some Z80 support devices also check for a "Return-from-Interrupt" instruction object code appearing on the Data Bus during an instruction fetch (when M1 and RD will both be low). This condition is used to reset interrupt priorities among Z80 support devices.

**The 8080A HOLD and HLDA signals are functionally reproduced by the Z80 BUSRQ and BUSAK signals.**

The 8080A SYNC pulse has no direct Z80 equivalent. M1 is pulsed low during an instruction fetch, or an interrupt acknowledge, but it is not pulsed low during the initial time periods of an instruction's second or subsequent machine cycles. **Frequently the complement of M1 can be used instead of SYNC to drive those 8080A peripheral devices that require the SYNC pulse.**

**The Z80 has no signals equivalent to 8080A INTE, WAIT or  $\Phi_2$ . There is also no signal equivalent to the 8228 BUSEN.**

If for any reason external logic must know when interrupts have been disabled internally by the CPU, then the Z80 will be at a loss to provide any signal equivalent to the 8080A control signals. Remember INTE in an 8080A system tells external logic when the CPU has enabled or disabled all interrupts; since external logic can do nothing about interrupts being disabled, and requesting an interrupt at this time does neither good nor harm, knowing that the condition exists is generally irrelevant.

The single Z80 WAIT input serves the function of the 8080A READY input. Irrespective of when the WAIT is requested, a Wait clock period will only be inserted between  $T_2$  and  $T_3$ ; moreover, as we will see shortly, there are certain Z80 instructions which automatically insert a Wait state, without waiting for external demand. You would need relatively complex logic to decode instruction object codes, clock signal and the WAIT input if your Z80 system is to generate the equivalent of an 8080A WAIT output. In all probability, it would be simpler to find an alternative scheme that did not require a signal equivalent to the 8080A WAIT output.

The Z80 simply has no second clock equivalent to 8080A  $\Phi_2$ . Any device that needs clock signal  $\Phi_2$  cannot easily be used in Z80 configurations.

The 8228 BUSEN input is used by external logic to float the System Bus. In a Z80 system, CPU logic floats the System Bus; therefore BUSEN becomes irrelevant.

**The 8080A CPU has no signals equivalent to Z80 RFSH, HALT and NMI.**

RFSH applies to dynamic memory refresh only; it is irrelevant within the context of a Z80 - 8080A signal comparison. NMI, being a nonmaskable interrupt request, also has no 8080A equivalent logic.

**The Z80 HALT output needs some discussion. One of the more confusing aspects of the 8080A is the interaction of Wait, Halt and Hold states. Let us look at these three states, comparing the Z80 and 8080A configurations and in the process we will see the purpose of the Z80 HALT output.**

The purpose of the Wait state is to elongate a memory reference machine cycle in deference to slow external memory or I/O devices. The Wait state consists of one or more Wait clock periods inserted between  $T_2$  and  $T_3$  of a machine cycle. The 8080A and the Z80 handle Wait states in exactly the same way, except for the fact that the Z80 has no Wait acknowledge output and under certain circumstances will automatically insert Wait clock periods.

The purpose of the Hold condition is to allow external logic to acquire control of the System Bus and perform Direct Memory Access operations. Again both the Z80 and the 8080A have very similar Hold states. The only significant difference is that the Z80 initiates a Hold state at the conclusion of a machine cycle, whereas the 8080A initiates the Hold state during time period T<sub>3</sub> or T<sub>4</sub>. The 8228 System Controller also needs a high BUSEN input in order to float its Data and Control Busses while the Z80 has no equivalent need.

The big difference between the Z80 and the 8080A comes within the Halt state. When the 8080A executes a Halt instruction, it goes into a Halt state, which differs from a Hold state. There are some complex interactions between Hold, Halt, Wait and interrupts within 8080A systems. None of these complications exists in the Z80 system, since the Z80 has no Halt state. After executing a Halt instruction, the Z80 outputs HALT low, then proceeds to continuously execute a NOP instruction. This allows dynamic memory refresh logic to continue operating. **If you are replacing an 8080A with a Z80, you must give careful attention to the Halt state. This is one condition where unexpected incompatibilities can arise.**

## Z80 TIMING AND INSTRUCTION EXECUTION

**Z80 timing is conceptually similar to, but far simpler than 8080A timing. Like the 8080A, the Z80 divides its instructions into machine cycles and clock periods. However, all Z80 machine cycles consist of either three or four clock periods. Some instructions always insert Wait clock periods, in which case five or six clock periods may be present in a machine cycle. Recall that 8080A machine cycles may have three, four or five clock periods.**

The 8080A may require from one to five machine cycles in order to execute an instruction: Z80 instructions execute in one to six machine cycles. If we shade optional machine cycles and clock periods, Z80 and 8080A instruction time subdivisions may be compared and illustrated as follows:



**Z80 clock signals are also far simpler than the 8080A equivalent.** Where the 8080A uses two clock signals the Z80 uses one. Clock logic may be compared as follows:



## INSTRUCTION FETCH EXECUTION SEQUENCES

As compared to the 8080A, Z80 instruction timing is marvelously simple. Gone is the SYNC pulse and the decoding of Data Bus for status. Every instruction's timing degenerates into an instruction fetch, optionally followed by memory or I/O read or write. Add to this a few variations for Wait state, interrupt acknowledge and bus floating and you are done.

Let us begin by looking at an instruction fetch. Timing is illustrated in Figure 7-5. Look at the instruction fetch timing in the 8080A chapter to obtain an immediate comparison of the Z80 and the 8080A.



Figure 7-5. Z80 Instruction Fetch Sequence

Referring to Figure 7-5, note that the instruction fetch cycle is identified by  $\overline{M1}$  output low during T1 and T2 (①). Since there is no status on the Data Bus to worry about, the Program Counter contents are output immediately on the Address Bus and stay stable for the duration of T1 and T2.

Since an instruction fetch is also a memory operation,  $\overline{MREQ}$  and  $\overline{RD}$  controls are both output low. This occurs half-way through T1, at which time the Address Bus will stabilize. The falling edges of  $\overline{MREQ}$  and  $\overline{RD}$  can therefore be used to select a memory device and strobe data out. The CPU polls data on the Data Bus at the rising edge of the T3 clock (②).

**Clock periods T<sub>3</sub> and T<sub>4</sub> of the instruction fetch machine cycle are used by the Z80 CPU for internal operations.** These clock periods are also used to refresh dynamic memory. As soon as the Program Counter contents are taken off the Address Bus (②), the refresh address from the Refresh register is output on lines A0 - A6 of the Address Bus. This address stays on the Address Bus until the conclusion of T<sub>4</sub> (③).

Since a memory refresh is a memory access operation, MREQ is again output low; however, it is accompanied by RFSH rather than RD low. Thus memory reference logic does not attempt to read data during a refresh cycle.

## A MEMORY READ OPERATION

**Memory interface logic responds to an instruction fetch and a memory read in exactly the same way. There are, however, a few differences between memory read and instruction fetch timing.** Memory read timing is illustrated in Figure 7-6. The principal difference to note is that during a memory read operation, the data is sampled on the falling edge of the T<sub>3</sub> clock pulse, whereas during an instruction fetch it is sampled on the rising edge of this clock pulse. Also a normal memory read machine cycle will consist of three clock periods, while the normal instruction fetch consists of four clock periods. Remember also that the Z80 identifies an instruction fetch machine cycle by outputting M1 low during the first two clock periods of the instruction fetch machine cycle.



Figure 7-6. Z80 Memory Read Timing



Figure 7-7. Z80 Memory Write Timing

## MEMORY WRITE OPERATION

**Figure 7-7 illustrates memory write timing for the Z80. The only differences between memory read and memory write timing are the obvious ones:** WR is pulsed low for a write, and can be used as a strobe by memory interface logic to read data off the Data Bus.

## THE WAIT STATE

Like the 8080A, the Z80 allows a Wait state to occur between clock periods  $T_2$  and  $T_3$  of a machine cycle. The Wait state frees external logic or memory from having to operate at CPU speed.

The Z80 CPU samples the WAIT input on the falling edge of  $\Phi$  during  $T_2$ . Providing WAIT is low on the falling edge of  $\Phi$  during  $T_2$ , Wait clock periods will be inserted. The number of Wait clock periods inserted depends strictly on how long the WAIT input is held low. As soon as the Z80 detects WAIT high on the falling edge of  $\Phi$ , it will initiate  $T_3$  on the next rising edge of  $\Phi$ .

Note that the single Z80 WAIT signal replaces the READY and WAIT 8080A signals. As this would imply, no signal is output telling external logic the Z80 has entered the Wait state. In the event that external logic needs to know whether or not a Wait state has been entered, these are the rules:

- 1) The Z80 will sample WAIT on the falling edge of  $\Phi$  in  $T_2$ .
- 2) If WAIT is low, then the Z80 will continue to sample the WAIT input for all subsequent Wait state clock periods.
- 3) The Z80 will not sample the WAIT input during any clock period other than  $T_2$  or a Wait state.

Figure 7-8 illustrates Z80 Wait state timing.



Figure 7-8. Z80 Wait State Timing

## INPUT OR OUTPUT GENERATION

Timing for Z80 input and output generation is given in Figures 7-9 and 7-10.

The important point to note is that Zilog has acknowledged the infrequency with which typical I/O logic can operate at CPU speed. One Wait clock period is therefore automatically inserted between  $T_2$  and  $T_3$  for all input or output machine cycles. Otherwise timing differs from memory read and write operations only in that IORQ is output low rather than MREQ.

Note that there is absolutely nothing to prevent you from selecting I/O devices within the memory space. This is something we did consistently in the 8080A chapter when describing 8080A support devices. But if you adopt this design policy, remember that your I/O logic must execute at CPU speed, unless you insert Wait states.



Figure 7-9. Z80 Input or Output Cycles



Figure 7-10. Z80 Input or Output Cycles with Wait States

## BUS REQUESTS

The Z80 does not have a Hold state as described for the 8080A, but Z80 bus request logic is equivalent. **The Z80 will float Address, Data and tristate Control Bus lines upon sensing a low BUSRQ signal.** BUSRQ is sampled by the Z80 CPU on the rising edge of the last clock pulse of any machine cycle. If BUSRQ is sampled low, then tristate lines are floated by the CPU, which also outputs BUSAK low. The Z80 CPU continues to sample BUSRQ on the rising edge of every clock pulse. As soon as BUSRQ is sensed high, floating will cease on the next clock pulse. This timing is illustrated in Figure 7-11.

**One significant difference between the Z80 and 8080A results from differences between the Hold and bus floating states.** As the logic we have described for the Z80 would imply, it will only float the System Bus in between machine cycles. The 8080A, on the other hand, will enter a Hold state variably during T<sub>3</sub> or T<sub>4</sub> of the machine cycle. It is therefore possible for the Z80 to float its bus three clock periods later than an 8080A in a similar configuration.



Figure 7-11. Z80 Bus Timing



Figure 7-12. Z80 Response to a Maskable Interrupt Request

Note also that if you are using the dynamic memory refresh logic of the Z80, then during long bus floats, external logic must refresh dynamic memory. The simplest way around this problem in a Z80 system is to ensure that DMA operations acquire the System Bus for many short periods of time, rather than for a single long access.

## EXTERNAL INTERRUPTS

The Z80 has two interrupt request input signals, one of which cannot be disabled.

Timing for the lower priority interrupt request acknowledge sequence differs significantly from the single 8080A interrupt request, and is illustrated in Figure 7-12.

The interrupt request signal INT is sampled by the Z80 CPU on the rising edge of the last clock pulse of any instruction's execution.

An interrupt request will be denied if interrupts have been disabled under program control, or if the BUSRQ signal is also low. Thus a DMA access will have priority over maskable interrupts.

The Z80 CPU acknowledges an interrupt request by outputting M1 and TORQ low. This occurs in a special interrupt acknowledge machine cycle, as illustrated in Figure 7-12. Note that this machine cycle has two Wait states inserted so that external logic will have time for any type of daisy chained priority interrupt scheme to be implemented.

**When TORQ is output low while M1 is low, external logic must interpret this signal combination as requiring an interrupt vector to be placed on the Data Bus by the acknowledged external interrupt requesting source. This interrupt vector can take one of three forms:** the form depends on which of the three modes you have selected for the Z80 under program control.

In **Mode 0**, the interrupt vector will be interpreted as a single-byte object code, representing the first instruction to be executed following the interrupt acknowledge. This is equivalent to the standard **RST instruction response used by the 8080A**. Whenever you are replacing an 8080A with a Z80, therefore, the Z80 must operate in interrupt response Mode 0.

Z80 interrupt response logic in **Mode 1** automatically assumes that the first instruction executed following the interrupt response will be a **Restart**, branching to memory location **0038<sub>16</sub>**. If the Z80 is in Mode 1, no interrupt vector is needed.

Z80 Mode 2 interrupt response has no 8080A equivalent. When you operate the Z80 in **Mode 2**, you must create a table of 16-bit interrupt address vectors, which can reside anywhere in addressable memory. These 16-bit addresses identify the first executable instruction of interrupt service routines. When an interrupt is acknowledged by the CPU in Mode 2, the acknowledged external logic must place an interrupt response vector on the Data Bus. The Z80 CPU will combine the IV register contents with the interrupt acknowledge vector to form a 16-bit address, which accesses the interrupt address vector table. Since 16-bit addresses must lie at even memory address boundaries, only seven of the eight bits provided by the acknowledged external logic will be used to create the table address; the low order bit will be set to 0. Thus the table of 16-bit interrupt address vectors will be accessed as follows:



**The Z80 CPU will execute a Call to the memory location obtained from the interrupt address vector table.**

**Let us clarify this logic with a simple example.** Suppose that you have 64 possible external interrupts; each interrupt has its own interrupt service routine, therefore 64 starting addresses will be stored in 128 bytes of memory. Let us arbitrarily assume that these 128 bytes are stored in a table with memory addresses **0F00<sub>16</sub>** through **0F7F<sub>16</sub>**. Now in

order to use Mode 2, you must initially load the value  $0F_{16}$  into the Z80 IV register. Subsequently an external interrupt request is acknowledged and the acknowledged external logic returns on the Data Bus the vector  $2E_{16}$ ; this is what will happen:



If two Wait states are insufficient for external logic to arbitrate interrupt priorities and place the required vector on the Data Bus, then additional Wait states can be inserted in the usual way by inputting WAIT low. Timing is illustrated in Figure 7-13.

#### Z80 WAIT STATES DURING INTERRUPT ACKNOWLEDGE



Figure 7-13. Wait States During Z80 Response to a Maskable Interrupt Request

**The nonmaskable interrupt differs from the maskable interrupt in two significant ways.**

First of all the nonmaskable interrupt has priority over both the maskable interrupt and bus requests.

Next, the nonmaskable interrupt operates in Mode 1 only. Following the interrupt acknowledge, an RST instruction will always be executed, with a Call to memory location 0066<sub>16</sub>. No other RST instruction can be executed and no interrupt vector should be placed on the Data Bus; if a vector is placed on the Data Bus, it will be ignored.

Nonmaskable interrupt timing is illustrated in Figure 7-14.



Figure 7-14. Z80 Response to a Nonmaskable Interrupt Request

## THE HALT INSTRUCTION

When a Halt instruction is executed by the Z80 CPU, a sequence of NOP instructions is executed until an interrupt request is received. Both maskable and nonmaskable interrupt request lines are sampled on the rising edge of Φ during T4 of every NOP instruction's machine cycle.

The Halt state will terminate when any interrupt request is detected, at which time the appropriate interrupt acknowledge sequence will be initiated, as illustrated in Figures 7-13 and 7-14.

Note that the Z80 executes the sequence of NOP instructions during a Halt so that it can continue to generate dynamic memory refresh signals.

Halt instruction timing is illustrated in Figure 7-15.



Figure 7-15. Z80 Halt Instruction Timing

The following abbreviations are used in this chapter:

|                 |                                                                                                                                                                                                                                               |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A,F,B,C,D,E,H,L | The 8-bit registers. A is the Accumulator and F is the Program Status Word.                                                                                                                                                                   |
| AF',BC',DE',HL' | The alternative register pairs                                                                                                                                                                                                                |
| addr            | A 16-bit memory address                                                                                                                                                                                                                       |
| x(b)            | Bit b of 8-bit register or memory location x                                                                                                                                                                                                  |
| cond            | Condition for program branching. Conditions are:<br>NZ - Non-Zero (Z=0)<br>Z - Zero (Z=1)<br>NC - Non-carry (C=0)<br>C - Carry (C=1)<br>PO - Parity Odd (P=0)<br>PE - Parity Even (P=1)<br>P - Sign Positive (S=0)<br>M - Sign Negative (S=1) |
| data            | An 8-bit binary data unit                                                                                                                                                                                                                     |
| data16          | A 16-bit binary data unit                                                                                                                                                                                                                     |
| disp            | An 8-bit signed binary address displacement                                                                                                                                                                                                   |
| xx(HI)          | The high-order 8 bits of a 16-bit quantity xx                                                                                                                                                                                                 |
| IV              | Interrupt vector register (8 bits)                                                                                                                                                                                                            |
| IX,IY           | The Index registers (16 bits each)                                                                                                                                                                                                            |
| xy              | Either one of the Index registers (IX or IY)                                                                                                                                                                                                  |
| LSB             | Least Significant Bit (Bit 0)                                                                                                                                                                                                                 |
| label           | A 16-bit instruction memory address                                                                                                                                                                                                           |
| xx(LO)          | The low-order 8 bits of a 16-bit quantity xx                                                                                                                                                                                                  |
| MSB             | Most Significant Bit (Bit 7)                                                                                                                                                                                                                  |
| PC              | Program Counter                                                                                                                                                                                                                               |
| port            | An 8-bit I/O port address                                                                                                                                                                                                                     |
| pr              | Any of the following register pairs:<br>BC<br>DE<br>HL<br>AF                                                                                                                                                                                  |
| R               | The Refresh register (8 bits)                                                                                                                                                                                                                 |
| reg             | Any of the following registers:<br>A<br>B<br>C<br>D<br>E<br>H<br>L                                                                                                                                                                            |
| rp              | Any of the following register pairs:<br>BC<br>DE<br>HL<br>SP                                                                                                                                                                                  |
| SP              | Stack Pointer (16 bits)                                                                                                                                                                                                                       |

|          |                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Statuses | The Z80 has the following status flags:<br>C - Carry status<br>Z - Zero status<br>S - Sign status<br>P/O - Parity/Overflow status<br>AC - Auxiliary Carry status<br>N - Subtract status                                                                                                                                                                                                  |
|          | The following symbols are used in the status columns:<br>X - flag is affected by operation<br>(blank) - flag is not affected by operation<br>1 - flag is set by operation<br>0 - flag is reset by operation<br>? - flag is unknown after operation<br>P - flag shows parity status<br>O - flag shows overflow status<br>I - flag shows interrupt enabled/disabled status                 |
| [ ]      | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If an I/O port number is enclosed within the brackets, then the I/O port contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified. |
| [[ ]]    | Implied memory addressing; the contents of the memory location designated by the contents of a register.                                                                                                                                                                                                                                                                                 |
| A        | Logical AND                                                                                                                                                                                                                                                                                                                                                                              |
| V        | Logical OR                                                                                                                                                                                                                                                                                                                                                                               |
| ¬        | Logical Exclusive-OR                                                                                                                                                                                                                                                                                                                                                                     |
| →        | Data is transferred in the direction of the arrow                                                                                                                                                                                                                                                                                                                                        |
| ↔        | Data is exchanged between the two locations designated on either side of the arrow.                                                                                                                                                                                                                                                                                                      |

**The fixed part of an assembly language instruction is shown in UPPER CASE.**

**The variable part (immediate data, I/O device number, register name, label or address) is shown in lower case.**

\*Address Bus: A0-A7: [C]  
A8-A15: [B]

Table 7-2. A Summary of the Z80 Instruction Set

| TYPE | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                              |
|------|----------|------------|-------|--------|---|---|-----|----------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          |            |       | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                                                                                                                                  |
| I/O  | IN       | A,port     | 2     |        |   |   |     |                |   | [A]—[port]<br>Input to Accumulator from directly addressed I/O port.<br>Address Bus: A0-A7: port<br>A8-A15: [A]                                                                                                                                                                                  |
|      | IN       | reg,(C)    | 2     | X      | X |   | P   | X              | 0 | [reg]—[[C]]<br>Input to register from I/O port addressed by the contents of C.*<br>If second byte is 70 <sub>16</sub> only the flags will be affected.                                                                                                                                           |
|      | INIR     |            | 2     | 1      | ? | ? | ?   | ?              | 1 | Repeat until [B]=0:<br>[[HL]]—[[C]]<br>[B]—[B] - 1<br>[HL]—[HL] + 1                                                                                                                                                                                                                              |
|      | INDR     |            | 2     | 1      | ? | ? | ?   | ?              | 1 | Transfer a block of data from I/O port addressed by contents of C to memory location addressed by contents of HL, going from low addresses to high. Contents of B serve as a count of bytes remaining to be transferred.*<br>Repeat until [B]=0:<br>[[HL]]—[[C]]<br>[B]—[B] - 1<br>[HL]—[HL] - 1 |
|      | INI      |            | 2     | X      | ? | ? | ?   | ?              | 1 | Transfer a block of data from I/O port addressed by contents of C to memory location addressed by contents of HL, going from high addresses to low. Contents of B serve as a count of bytes remaining to be transferred.*<br>[[HL]]—[[C]]<br>[B]—[B] - 1<br>[HL]—[HL] + 1                        |
|      | IND      |            | 2     | X      | ? | ? | ?   | ?              | 1 | Transfer a byte of data from I/O port addressed by contents of C to memory location addressed by contents of HL. Decrement byte count and increment destination address.*<br>[[HL]]—[[C]]<br>[B]—[B] - 1<br>[HL]—[HL] - 1                                                                        |
|      | OUT      | port,A     | 2     |        |   |   |     |                |   | Transfer a byte of data from I/O port addressed by contents of C to memory location addressed by contents of HL. Decrement both byte count and destination address.*<br>[port]—[A]<br>Output from Accumulator to directly addressed I/O port.<br>Address Bus: A0-A7: port<br>A8-A15: [A]         |
|      | OUT      | (C),reg    | 2     |        |   |   |     |                |   | [[C]]—[reg]<br>Output from register to I/O port addressed by the contents of C.*                                                                                                                                                                                                                 |
|      | OTIR     |            | 2     | 1      | ? | ? | ?   | ?              | 1 | Repeat until [B]=0:<br>[[C]]—[[HL]]<br>[B]—[B] - 1<br>[HL]—[HL] + 1<br>Transfer a block of data from memory location addressed by contents of HL to I/O port addressed by contents of C, going from low memory to high. Contents of B serve as a count of bytes remaining to be transferred.*    |

\*Address Bus: A0-A7: [C]  
A8-A15: [B]

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                     | MNEMONIC | OPERAND(S)             | BYTES | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                       |
|--------------------------|----------|------------------------|-------|--------|---|---|-----|----------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          |          |                        |       | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                                                                                                                           |
| I/O (Continued)          | OTDR     |                        | 2     |        | 1 | ? | ?   | ?              | 1 | Repeat until [B]=0:<br>[[C]]←[[HL]]<br>[B]←[B]-1<br>[HL]←[HL]-1<br>Transfer a block of data from memory location addressed by contents of HL to I/O port addressed by contents of C, going from high memory to low. Contents of B serve as a count of bytes remaining to be transferred.* |
|                          | OUTI     |                        | 2     |        | X | ? | ?   | ?              | 1 | [[C]]←[[HL]]<br>[B]←[B]-1<br>[HL]←[HL]+1<br>Transfer a byte of data from memory location addressed by contents of HL to I/O port addressed by contents of C. Decrement byte count and increment source address.*                                                                          |
|                          | OUTD     |                        | 2     |        | X | ? | ?   | ?              | 1 | [[C]]←[[HL]]<br>[B]←[B]-1<br>[HL]←[HL]-1<br>Transfer a byte of data from memory location addressed by contents of HL to I/O port addressed by contents of C. Decrement both byte count and source address.*                                                                               |
| PRIMARY MEMORY REFERENCE | LD       | A,(addr)               | 3     |        |   |   |     |                |   | [A]←[addr]<br>Load Accumulator from directly addressed memory location.                                                                                                                                                                                                                   |
|                          | LD       | HL,(addr)              | 3     |        |   |   |     |                |   | [H]←[addr+1], [L]←[addr]<br>Load HL from directly addressed memory.                                                                                                                                                                                                                       |
|                          | LD       | rp,(addr)<br>xy,(addr) | 4     |        |   |   |     |                |   | [rp(HI)]←[addr+1], [rp(LO)]←[addr] or<br>[xy(HI)]←[addr+1], [xy(LO)]←[addr]<br>Load register pair or Index register from directly addressed memory.                                                                                                                                       |
|                          | LD       | (addr),A               | 3     |        |   |   |     |                |   | [addr]←[A]<br>Store Accumulator contents in directly addressed memory location.                                                                                                                                                                                                           |
|                          | LD       | (addr),HL              | 3     |        |   |   |     |                |   | [addr+1]←[H], [addr]←[L]<br>Store contents of HL to directly addressed memory location.                                                                                                                                                                                                   |
|                          | LD       | (addr),rp<br>(addr),xy | 4     |        |   |   |     |                |   | [addr+1]←[rp(HI)], [addr]←[rp(LO)] or<br>[addr+1]←[xy(HI)], [addr]←[xy(LO)]<br>Store contents of register pair or Index register to directly addressed memory.                                                                                                                            |
|                          | LD       | A,(BC)<br>A,(DE)       | 1     |        |   |   |     |                |   | [A]←[[BC]] or [A]←[[DE]]<br>Load Accumulator from memory location addressed by the contents of the specified register pair.                                                                                                                                                               |
|                          | LD       | reg,(HL)               | 1     |        |   |   |     |                |   | [reg]←[[HL]]<br>Load register from memory location addressed by contents of HL.                                                                                                                                                                                                           |
|                          | LD       | (BC),A<br>(DE),A       | 1     |        |   |   |     |                |   | [[BC]]←[A] or [[DE]]←[A]<br>Store Accumulator to memory location addressed by the contents of the specified register pair.                                                                                                                                                                |
|                          | LD       | (HL),reg               | 1     |        |   |   |     |                |   | [[HL]]←[reg]<br>Store register contents to memory location addressed by the contents of HL.                                                                                                                                                                                               |
|                          | LD       | reg,(xy + disp)        | 3     |        |   |   |     |                |   | [reg]←[[xy + disp]]<br>Load register from memory location using base relative addressing.                                                                                                                                                                                                 |
|                          | LD       | (xy + disp),reg        | 3     |        |   |   |     |                |   | [[xy + disp]]←[reg]<br>Store register to memory location addressed relative to contents of index register.                                                                                                                                                                                |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                      | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------|----------|------------|-------|--------|---|---|-----|----------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           |          |            |       | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                                                                                                                                                                                                                            |
| BLOCK TRANSFER AND SEARCH | LDIR     |            | 2     |        |   |   | 0   | 0              | 0 | Repeat until $[BC]=0$ :<br>$[[DE]] \leftarrow [[HL]]$<br>$[DE] \leftarrow [DE] + 1$<br>$[HL] \leftarrow [HL] + 1$<br>$[BC] \leftarrow [BC] - 1$<br>Transfer a block of data from the memory location addressed by the contents of HL to the memory location addressed by the contents of DE, going from low addresses to high. Contents of BC serve as a count of bytes to be transferred. |
|                           | LDDR     |            | 2     |        |   |   | 0   | 0              | 0 | Repeat until $[BC]=0$ :<br>$[[DE]] \leftarrow [[HL]]$<br>$[DE] \leftarrow [DE] - 1$<br>$[HL] \leftarrow [HL] - 1$<br>$[BC] \leftarrow [BC] - 1$<br>Transfer a block of data from the memory location addressed by the contents of HL to the memory location addressed by the contents of DE, going from high addresses to low. Contents of BC serve as a count of bytes to be transferred. |
|                           | LDI      |            | 2     |        |   |   | X   | 0              | 0 | $[[DE]] \leftarrow [[HL]]$<br>$[DE] \leftarrow [DE] + 1$<br>$[HL] \leftarrow [HL] + 1$<br>$[BC] \leftarrow [BC] - 1$<br>Transfer one byte of data from the memory location addressed by the contents of HL to the memory location addressed by the contents of DE. Increment source and destination addresses and decrement byte count.                                                    |
|                           | LDD      |            | 2     |        |   |   | X   | 0              | 0 | $[[DE]] \leftarrow [[HL]]$<br>$[DE] \leftarrow [DE] - 1$<br>$[HL] \leftarrow [HL] - 1$<br>$[BC] \leftarrow [BC] - 1$<br>Transfer one byte of data from the memory location addressed by the contents of HL to the memory location addressed by the contents of DE. Decrement source and destination addresses and byte count.                                                              |
|                           | CPIR     |            | 2     | X      | X | X | X   | X              | 1 | Repeat until $[A]=[HL]$ or $[BC]=0$ :<br>$[A] - [[HL]]$ (only flags are affected)<br>$[HL] \leftarrow [HL] + 1$<br>$[BC] \leftarrow [BC] - 1$<br>Compare contents of Accumulator with those of memory block addressed by contents of HL, going from low addresses to high. Stop when a match is found or when the byte count becomes zero.                                                 |
|                           | CPDR     |            | 2     | X      | X | X | X   | X              | 1 | Repeat until $[A]=[HL]$ or $[BC]=0$ :<br>$[A] - [[HL]]$ (only flags are affected)<br>$[HL] \leftarrow [HL] - 1$<br>$[BC] \leftarrow [BC] - 1$<br>Compare contents of Accumulator with those of memory block addressed by contents of HL, going from high addresses to low. Stop when a match is found or when the byte count becomes zero.                                                 |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                                  | MNEMONIC | OPERAND(S)          | BYTES  | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                                                       |
|---------------------------------------|----------|---------------------|--------|--------|---|---|-----|----------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       |          |                     |        | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                                                           |
| BLOCK TRANSFER AND SEARCH (Continued) | CPI      |                     | 2      | X      | X | X | X   | X              | 1 | [A] - [[HL]].(only flags are affected)<br>[HL] - [HL] + 1<br>[BC] - [BC] - 1<br>Compare contents of Accumulator with those of memory location addressed by contents of HL.<br>Increment address and decrement byte count. |
|                                       | CPD      |                     | 2      | X      | X | X | X   | X              | 1 | [A] - [[HL]].(only flags are affected)<br>[HL] - [HL] - 1<br>[BC] - [BC] - 1<br>Compare contents of Accumulator with those of memory location addressed by contents of HL.<br>Decrement address and byte count.           |
| SECONDARY MEMORY REFERENCE            | ADD      | (HL)<br>(xy + disp) | 1<br>3 | X      | X | X | O   | X              | 0 | [A] - [A] + [[HL]] or [A] - [A] - [[xy] + disp]<br>Add to Accumulator using implied addressing or base relative addressing.                                                                                               |
|                                       | ADC      | (HL)<br>(xy + disp) | 1<br>3 | X      | X | X | O   | X              | 0 | [A] - [A] + [[HL]] + C or [A] - [A] + [[xy] + disp] + C<br>Add with Carry using implied addressing or base relative addressing.                                                                                           |
|                                       | SUB      | (HL)<br>(xy + disp) | 1<br>3 | X      | X | X | O   | X              | 1 | [A] - [A] - [[HL]] or [A] - [A] - [[xy] + disp]<br>Subtract from Accumulator using implied addressing or base relative addressing.                                                                                        |
|                                       | SBC      | (HL)<br>(xy + disp) | 1<br>3 | X      | X | X | O   | X              | 1 | [A] - [A] - [[HL]] - C or [A] - [A] - [[xy] + disp] - C<br>Subtract with Carry using implied addressing or base relative addressing.                                                                                      |
|                                       | AND      | (HL)<br>(xy + disp) | 1<br>3 | 0      | X | X | P   | 1              | 0 | [A] - [A] $\wedge$ [[HL]] or [A] - [A] $\wedge$ [[xy] + disp]<br>AND with Accumulator using implied addressing or base relative addressing.                                                                               |
|                                       | OR       | (HL)<br>(xy + disp) | 1<br>3 | 0      | X | X | P   | 1              | 0 | [A] - [A] $\vee$ [[HL]] or [A] - [A] $\vee$ [[xy] + disp]<br>OR with Accumulator using implied addressing or base relative addressing.                                                                                    |
|                                       | XOR      | (HL)<br>(xy + disp) | 1<br>3 | 0      | X | X | P   | 1              | 0 | [A] - [A] $\oplus$ [[HL]] or [A] - [A] $\oplus$ [[xy] + disp]<br>Exclusive-OR with Accumulator using implied addressing or base relative addressing.                                                                      |
|                                       | CP       | (HL)<br>(xy + disp) | 1<br>3 | X      | X | X | O   | X              | 1 | [A] - [[HL]] or [A] - [[xy] + disp]<br>Compare with Accumulator using implied addressing or base relative addressing. Only the flags are affected.                                                                        |
|                                       | INC      | (HL)<br>(xy + disp) | 1<br>3 |        | X | X | O   | X              | 0 | [[HL]] - [[HL]] + 1 or [[xy] + disp] - [[xy] + disp] + 1<br>Increment using implied addressing or base relative addressing.                                                                                               |
|                                       | DEC      | (HL)<br>(xy + disp) | 1<br>3 |        | X | X | O   | X              | 1 | [[HL]] - [[HL]] - 1 or [[xy] + disp] - [[xy] + disp] - 1<br>Decrement using implied addressing or base relative addressing.                                                                                               |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                    | MNEMONIC | OPERAND(S)          | BYTES  | STATUS |   |   |     |                |   | OPERATION PERFORMED:                                                           |
|-------------------------|----------|---------------------|--------|--------|---|---|-----|----------------|---|--------------------------------------------------------------------------------|
|                         |          |                     |        | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                |
| MEMORY SHIFT AND ROTATE | RLC      | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
|                         | RL       | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
|                         | RRC      | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
|                         | RR       | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
|                         | SLA      | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
|                         | SRA      | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
|                         | SRL      | (HL)<br>(xy + disp) | 2<br>4 | X      | X | X | P   | 0              | 0 | <br>[[HL]] or [[xy] + disp]                                                    |
| IMMEDIATE               | LD       | reg,data            | 2      |        |   |   |     |                |   | [reg]—data<br>Load immediate into register.                                    |
|                         | LD       | rp,data16           | 3      |        |   |   |     |                |   | [rp]—data16 or [[xy]]—data16                                                   |
|                         | LB       | xy,data16           | 4      |        |   |   |     |                |   | Load 16 bits of immediate data into register pair or index register.           |
|                         |          | (HL),data           | 2      |        |   |   |     |                |   | [[HL]]—data or [[xy]]+disp—data                                                |
|                         |          | (xy + disp),data    | 4      |        |   |   |     |                |   | Load immediate into memory location using implied or base relative addressing. |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                       | MNEMONIC    | OPERAND(S)   | BYTES  | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                                   |
|----------------------------|-------------|--------------|--------|--------|---|---|-----|----------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |             |              |        | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                                       |
| JUMP                       | JP          | label        | 3      |        |   |   |     |                |   | [PC]— label<br>Jump to instruction at address represented by label.                                                                                                                                   |
|                            | JR          | disp         | 2      |        |   |   |     |                |   | [PC]—[PC] + 2 + disp<br>Jump relative to present contents of Program Counter.                                                                                                                         |
|                            | JP          | (HL)<br>(xy) | 1<br>2 |        |   |   |     |                |   | [PC]—[HL] or [PC]—[xy]<br>Jump to address contained in HL or Index register.                                                                                                                          |
| SUBROUTINE CALL AND RETURN | CALL        | label        | 3      |        |   |   |     |                |   | [[SP]-1]—[PC(HI)]<br>[[SP]-2]—[PC(LO)]<br>[SP]—[SP]-2<br>[PC]— label                                                                                                                                  |
|                            | CALL<br>RET | cond,label   | 3<br>1 |        |   |   |     |                |   | Jump to subroutine starting at address represented by label.<br>Jump to subroutine if condition is satisfied; otherwise, continue in sequence.<br>[PC(LO)]—[[SP]]<br>[PC(HI)]—[[SP]+1]<br>[SP]—[SP]+2 |
|                            | RET         | cond         | 1      |        |   |   |     |                |   | Return from subroutine.<br>Return from subroutine if condition is satisfied; otherwise, continue in sequence.                                                                                         |
| IMMEDIATE OPERATE          | ADD         | data         | 2      | X      | X | X | O   | X              | 0 | [A]—[A] + data<br>Add immediate to Accumulator.                                                                                                                                                       |
|                            | ADC         | data         | 2      | X      | X | X | O   | X              | 0 | [A]—[A] + data + C<br>Add immediate with Carry.                                                                                                                                                       |
|                            | SUB         | data         | 2      | X      | X | X | O   | X              | 1 | [A]—[A] - data<br>Subtract immediate from Accumulator.                                                                                                                                                |
|                            | SBC         | data         | 2      | X      | X | X | O   | X              | 1 | [A]—[A] - data - C<br>Subtract immediate with Carry.                                                                                                                                                  |
|                            | AND         | data         | 2      | 0      | X | X | P   | 1              | 0 | [A]—[A] $\wedge$ data<br>AND immediate with Accumulator.                                                                                                                                              |
|                            | OR          | data         | 2      | 0      | X | X | P   | 1              | 0 | [A]—[A] V data<br>OR immediate with Accumulator.                                                                                                                                                      |
|                            | XOR         | data         | 2      | 0      | X | X | P   | 1              | 0 | [A]—[A] $\vee$ data<br>Exclusive-OR immediate with Accumulator.                                                                                                                                       |
|                            | CP          | data         | 2      | X      | X | X | O   | X              | 1 | [A] - data<br>Compare immediate data with Accumulator contents; only the flags are affected.                                                                                                          |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                   | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                 |
|------------------------|----------|------------|-------|--------|---|---|-----|----------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |          |            |       | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                     |
| JUMP ON CONDITION      | JP       | cond,label | 3     |        |   |   |     |                |   | If cond, then [PC]—label<br>Jump to instruction at address represented by label if the condition is true.                                                                           |
|                        | JR       | C,disp     | 2     |        |   |   |     |                |   | If C=1, then [PC]—[PC] + 2 + disp<br>Jump relative to contents of Program Counter if Carry flag is set.                                                                             |
|                        | JR       | NC,disp    | 2     |        |   |   |     |                |   | If C=0, then [PC]—[PC] + 2 + disp<br>Jump relative to contents of Program Counter if Carry flag is reset.                                                                           |
|                        | JR       | Z,disp     | 2     |        |   |   |     |                |   | If Z=1, then [PC]—[PC] + 2 + disp<br>Jump relative to contents of Program Counter if Zero flag is set.                                                                              |
|                        | JR       | NZ,disp    | 2     |        |   |   |     |                |   | If Z=0, then [PC]—[PC] + 2 + disp<br>Jump relative to contents of Program Counter if Zero flag is reset.                                                                            |
|                        | DJNZ     | disp       | 2     |        |   |   |     |                |   | [B]—[B] - 1<br>If [B] ≠ 0, then [PC]—[PC] + 2 + disp<br>Decrement contents of B and Jump relative to contents of Program Counter if result is not 0.                                |
| REGISTER-REGISTER MOVE | LD       | dst,src    | 1     |        |   |   |     |                |   | [dst]—[src]<br>Move contents of source register to destination register. Register designations src and dst may each be A, B, C, D, E, H or L.                                       |
|                        | LD       | A,IV       | 2     | X      | X | I | 0   | 0              |   | [A]—[IV]<br>Move contents of Interrupt Vector register to Accumulator.                                                                                                              |
|                        | LD       | A,R        | 2     | X      | X | I | 0   | 0              |   | [A]—[R]<br>Move contents of Refresh register to Accumulator.                                                                                                                        |
|                        | LD       | IV,A       | 2     |        |   |   |     |                |   | [IV]—[A]<br>Load Interrupt Vector register from Accumulator.                                                                                                                        |
|                        | LD       | R,A        | 2     |        |   |   |     |                |   | [R]—[A]<br>Load Refresh register from Accumulator.                                                                                                                                  |
|                        | LD       | SP,HL      | 1     |        |   |   |     |                |   | [SP]—[HL]<br>Move contents of HL to Stack Pointer.                                                                                                                                  |
|                        | LD       | SP,xy      | 2     |        |   |   |     |                |   | [SP]—[xy]<br>Move contents of Index register to Stack Pointer.                                                                                                                      |
|                        | EX       | DE,HL      | 1     |        |   |   |     |                |   | [DE]—[HL]<br>Exchange contents of DE and HL.                                                                                                                                        |
|                        | EX       | AF,AF'     | 1     |        |   |   |     |                |   | [AF]—[AF']<br>Exchange program status and alternate program status.                                                                                                                 |
|                        | EXX      |            | 1     |        |   |   |     |                |   | $\begin{pmatrix} [BC] \\ [DE] \\ [HL] \end{pmatrix} \longrightarrow \begin{pmatrix} [BC'] \\ [DE'] \\ [HL'] \end{pmatrix}$<br>Exchange register pairs and alternate register pairs. |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                      | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |     |                | OPERATION PERFORMED |                                                                                                                      |
|---------------------------|----------|------------|-------|--------|---|---|-----|----------------|---------------------|----------------------------------------------------------------------------------------------------------------------|
|                           |          |            |       | C      | Z | S | P/O | A <sub>C</sub> | N                   |                                                                                                                      |
| REGISTER-REGISTER OPERATE | ADD      | reg        | 1     | X      | X | X | O   | X              | 0                   | [A]—[A]+[reg]<br>Add contents of register to Accumulator.                                                            |
|                           | ADC      | reg        | 1     | X      | X | X | O   | X              | 0                   | [A]—[A]+[reg]+C<br>Add contents of register and Carry to Accumulator.                                                |
|                           | SUB      | reg        | 1     | X      | X | X | O   | X              | 1                   | [A]—[A]-[reg]<br>Subtract contents of register from Accumulator.                                                     |
|                           | SBC      | reg        | 1     | X      | X | X | O   | X              | 1                   | [A]—[A]-[reg]-C<br>Subtract contents of register and Carry from Accumulator.                                         |
|                           | AND      | reg        | 1     | 0      | X | X | P   | 1              | 0                   | [A]—[A]Λ[reg]<br>AND contents of register with contents of Accumulator.                                              |
|                           | OR       | reg        | 1     | 0      | X | X | P   | 1              | 0                   | [A]—[A]V[reg]<br>OR contents of register with contents of Accumulator.                                               |
|                           | XOR      | reg        | 1     | 0      | X | X | P   | 1              | 0                   | [A]—[A]⊕[reg]<br>Exclusive-OR contents of register with contents of Accumulator.                                     |
|                           | CP       | reg        | 1     | X      | X | X | O   | X              | 1                   | [A]-[reg]<br>Compare contents of register with contents of Accumulator. Only the flags are affected.                 |
|                           | ADD      | HL, rp     | 1     | X      |   |   |     | ?              | 0                   | [HL]—[HL]+[rp]<br>16-bit add register pair contents to contents of HL.                                               |
|                           | ADC      | HL, rp     | 2     | X      | X | X | O   | ?              | 0                   | [HL]—[HL]+[rp]+C<br>16-bit add with Carry register pair contents to contents of HL.                                  |
|                           | SBC      | HL, rp     | 2     | X      | X | X | O   | ?              | 1                   | [HL]—[HL]-[rp]-C<br>16-bit subtract with Carry register pair contents from contents of HL.                           |
| REGISTER OPERATE          | ADD      | IX, pp     | 2     | X      |   |   |     | ?              | 0                   | [IX]—[IX]+[pp]<br>16-bit add register pair contents to contents of Index register IX (pp=BC, DE, IX, SP)             |
|                           | ADD      | IY, rr     | 2     | X      |   |   |     | ?              | 0                   | [IY]—[IY]+[rr]<br>16-bit add register pair contents to contents of Index register IY (rr=BC, DE, IY, SP).            |
|                           | DAA      |            | 1     | X      | X | X | P   | X              |                     | Decimal adjust Accumulator, assuming that Accumulator contents are the sum or difference of BCD operands.<br>[A]—[A] |
|                           | CPL      |            | 1     |        |   |   |     | 1              | 1                   | Complement Accumulator (ones complement).<br>[A]—[A]+1                                                               |
|                           | NEG      |            | 2     | X      | X | X | O   | X              | 1                   | Negate Accumulator (twos complement).<br>[reg]—[reg]+1                                                               |
|                           | INC      | reg        | 1     |        | X | X | O   | X              | 0                   | Increment register contents.<br>[reg]—[reg]+1                                                                        |
|                           | INC      | rp<br>xy   | 1     |        |   | X |     |                |                     | [rp]—[rp]+1 or [xy]—[xy]+1<br>Increment contents of register pair or Index register.                                 |
| REGISTER OPERATE          | DEC      | reg        | 2     |        | X | X | O   | X              | 1                   | [reg]—[reg]-1<br>Decrement register contents.<br>[rp]—[rp]-1 or [xy]—[xy]-1                                          |
|                           | DEC      | rp<br>xy   | 1     |        |   | X |     |                |                     | Decrement contents of register pair or Index register.                                                               |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                      | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                    |
|---------------------------|----------|------------|-------|--------|---|---|-----|----------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           |          |            |       | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                        |
| REGISTER SHIFT AND ROTATE | RLCA     |            | 1     | X      |   |   |     | 0              | 0 | <br>[A]<br>Rotate Accumulator left with branch Carry.                                |
|                           | RLA      |            | 1     | X      |   |   |     | 0              | 0 | <br>[A]<br>Rotate Accumulator left through Carry.                                    |
|                           | RRCA     |            | 1     | X      |   |   |     | 0              | 0 | <br>[A]<br>Rotate Accumulator right with branch Carry.                               |
|                           | RRA      |            | 1     | X      |   |   |     | 0              | 0 | <br>[A]<br>Rotate Accumulator right through Carry.                                   |
|                           | RLC      | reg        | 2     | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Rotate contents of register left with branch Carry.                     |
|                           | RL       | reg        | 2     | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Rotate contents of register left through Carry.                         |
|                           | RRC      | reg        | 2     | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Rotate contents of register right with branch Carry.                    |
|                           | RR       | reg        | 2     | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Rotate contents of register right through Carry.                        |
|                           | SLA      | reg        | 2     | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Shift contents of register left and clear LSB (Arithmetic Shift).     |
|                           | SRA      | reg        | 2     | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Shift contents of register right and preserve MSB (Arithmetic Shift). |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE                                     | MNEMONIC | OPERAND(S)              | BYTES  | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                    |
|------------------------------------------|----------|-------------------------|--------|--------|---|---|-----|----------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          |          |                         |        | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                                                                                                                                                                                                        |
| REGISTER SHIFT AND ROTATE<br>(Continued) | SRL      |                         | 2      | X      | X | X | P   | 0              | 0 | <br>[reg]<br>Shift contents of register right and clear MSB (Logical Shift).                                                                                                                         |
|                                          | RLD      |                         | 2      |        | X | X | P   | 0              | 0 | <br>[A]                    [[HL]]<br>Rotate one BCD digit left between the Accumulator and memory location (implied addressing).<br>Contents of the upper half of the Accumulator are not affected.  |
|                                          | RRD      | reg                     | 2      |        | X | X | P   | 0              | 0 | <br>[A]                    [[HL]]<br>Rotate one BCD digit right between the Accumulator and memory location (implied addressing).<br>Contents of the upper half of the Accumulator are not affected. |
| BIT MANIPULATION                         | BIT      | b,reg                   | 2      |        | X | ? | ?   | 1              | 0 | Z— <u>reg(b)</u><br>Zero flag contains complement of the selected register bit.                                                                                                                                                                                                        |
|                                          | BIT      | b,(HL)<br>b,(xy + disp) | 2<br>4 |        | X | ? | ?   | 1              | 0 | Z— <u>[[HL]](b)</u> or Z— <u>[[xy] + disp](b)</u><br>Zero flag contains complement of selected bit of the memory location (implied addressing or base relative addressing).                                                                                                            |
|                                          | SET      | b,reg                   | 2      |        |   |   |     |                |   | reg(b)—1<br>Set indicated register bit.                                                                                                                                                                                                                                                |
|                                          | SET      | b,(HL)<br>b,(xy + disp) | 2<br>4 |        |   |   |     |                |   | [[HL]](b)—1 or [[xy] + disp](b)—1<br>Set indicated bit of memory location (implied addressing or base relative addressing).                                                                                                                                                            |
|                                          | RES      | b,reg                   | 2      |        |   |   |     |                |   | reg(b)—0<br>Reset indicated register bit.                                                                                                                                                                                                                                              |
|                                          | RES      | b,(HL)<br>b,(xy + disp) | 2<br>4 |        |   |   |     |                |   | [[HL]](b)—0 or [[xy] + disp](b)—0<br>Reset indicated bit in memory location (implied addressing or base relative addressing).                                                                                                                                                          |
| STACK                                    | PUSH     | pr<br>xy                | 1<br>2 |        |   |   |     |                |   | [[SP]-1]—[pr(HI)]<br>[[SP]-2]—[pr(LO)]<br>[SP]—[SP]-2<br>Put contents of register pair or Index register on top of Stack and decrement Stack Pointer.                                                                                                                                  |
|                                          | POP      | pr<br>xy                | 1<br>2 |        |   |   |     |                |   | [pr(LO)]—[[SP]]<br>[pr(HI)]—[[SP]+1]<br>[SP]—[SP]+2<br>Put contents of top of Stack in register pair or Index register and increment Stack Pointer.                                                                                                                                    |
|                                          | EX       | (SP),HL<br>(SP),xy      | 1<br>2 |        |   |   |     |                |   | [H]—[[SP]+1]<br>[L]—[[SP]]<br>Exchange contents of HL or Index register and top of Stack.                                                                                                                                                                                              |

Table 7-2. A Summary of the Z80 Instruction Set (Continued)

| TYPE      | MNEMONIC    | OPERAND(S)  | BYTES  | STATUS |   |   |     |                |   | OPERATION PERFORMED                                                                                       |
|-----------|-------------|-------------|--------|--------|---|---|-----|----------------|---|-----------------------------------------------------------------------------------------------------------|
|           |             |             |        | C      | Z | S | P/O | A <sub>C</sub> | N |                                                                                                           |
| INTERRUPT | DI          | n           | 1      |        |   |   |     |                |   | Disable interrupts.                                                                                       |
|           | EI          |             | 1      |        |   |   |     |                |   | Enable interrupts.                                                                                        |
|           | RST         |             | 1      |        |   |   |     |                |   | [[SP]-1]—[PCH]]<br>[[SP]-2]—[PLO]]<br>[SP]—[SP]-2<br>[PC]—(8-n) <sub>16</sub>                             |
|           | RETI        | 0<br>1<br>2 | 2      |        |   |   |     |                |   | Restart at designated location.                                                                           |
|           | RETN        |             | 2      |        |   |   |     |                |   | Return from interrupt.                                                                                    |
|           | IM          |             | 2      |        |   |   |     |                |   | Return from nonmaskable interrupt.<br>Set interrupt mode 0, 1, or 2.                                      |
| STATUS    | SCF         |             | 1      | 1      |   |   |     | 0              | 0 | C ← 1<br>Set Carry flag.                                                                                  |
|           | CCF         |             | 1      | X      |   |   |     | ?              | 0 | C ← C̄<br>Complement Carry flag.                                                                          |
|           | NOP<br>HALT |             | 1<br>1 |        |   |   |     |                |   | No operation — volatile memories are refreshed.<br>CPU halts, executes NOPs to refresh volatile memories. |

Table 7-3. A Summary of Instruction Object Codes and Execution Cycles with 8080A Mnemonics  
for Identical Instructions

| INSTRUCTION       | OBJECT CODE | BYTES | CLOCK PERIODS | 8080A MNEMONIC | 8080A CLOCK PERIODS |
|-------------------|-------------|-------|---------------|----------------|---------------------|
| ADC data          | CE yy       | 2     | 7             | ACI data       | 7                   |
| ADC (HL)          | 8E          | 1     | 7             | ADC M          | 7                   |
| ADC HL, rp        | ED 01xx1010 | 2     | 15            |                |                     |
| ADC (IX + disp)   | DD 8E yy    | 3     | 19            |                |                     |
| ADC (IY + disp)   | FD 8E yy    | 3     | 19            |                |                     |
| ADC reg           | 10001xxx    | 1     | 4             | ADC reg        | 4                   |
| ADD data          | C6 yy       | 2     | 7             | ADI data       | 7                   |
| ADD (HL)          | 86          | 1     | 7             | ADD M          | 7                   |
| ADD HL, rp        | 00xx1001    | 1     | 11            | DAD rp         | 10                  |
| ADD (IX + disp)   | DD 86 yy    | 3     | 19            |                |                     |
| ADD IX, pp        | DD 00xx1001 | 2     | 15            |                |                     |
| ADD (IY + disp)   | FD 86 yy    | 3     | 19            |                |                     |
| ADD IY, rr        | FD 00xx1001 | 2     | 15            |                |                     |
| ADD reg           | 10000xxx    | 1     | 4             | ADD reg        | 4                   |
| AND data          | E6 yy       | 2     | 7             | ANI data       | 7                   |
| AND (HL)          | A6          | 1     | 7             | ANA M          | 7                   |
| AND (IX + disp)   | DD A6 yy    | 3     | 19            |                |                     |
| AND (IY + disp)   | FD A6 yy    | 3     | 19            |                |                     |
| AND reg           | 10100xxx    | 1     | 4             | ANA reg        | 4                   |
| BIT b,(HL)        | CB          | 2     | 12            |                |                     |
|                   | 01bbb110    |       |               |                |                     |
| BIT b,(IX + disp) | DD CB yy    | 4     | 20            |                |                     |
|                   | 01bbb110    |       |               |                |                     |
| BIT b,(IY + disp) | FD CB yy    | 4     | 20            |                |                     |
|                   | 01bbb110    |       |               |                |                     |
| BIT b,reg         | CB          | 2     | 8             |                |                     |
|                   | 01bbbxxx    |       |               |                |                     |
| CALL label        | CD ppqq     | 3     | 17            | CALL label     | 17                  |
| CALL C,label      | DC ppqq     | 3     | 10/17         | CC label       | 11/17               |
| CALL M,label      | FC ppqq     | 3     | 10/17         | CM label       | 11/17               |
| CALL NC,label     | D4 ppqq     | 3     | 10/17         | CNC label      | 11/17               |
| CALL NZ,label     | C4 ppqq     | 3     | 10/17         | CNZ label      | 11/17               |
| CALL P,label      | F4 ppqq     | 3     | 10/17         | CP label       | 11/17               |
| CALL PE,label     | EC ppqq     | 3     | 10/17         | CPE label      | 11/17               |
| CALL PO,label     | E4 ppqq     | 3     | 10/17         | CPO label      | 11/17               |
| CALL Z,label      | CC ppqq     | 3     | 10/17         | CZ label       | 11/17               |
| CCF               | 3F          | 1     | 4             | CMC            | 4                   |
| CP data           | FE yy       | 2     | 7             | CPI data       | 7                   |
| CP (HL)           | BE          | 1     | 7             | CMP M          | 7                   |
| CP (IX + disp)    | DD BE yy    | 3     | 19            |                |                     |
| CP (IY + disp)    | FD BE yy    | 3     | 19            |                |                     |
| CP reg            | 10111xxx    | 1     | 4             | CMP reg        | 19                  |
| CPD               | ED A9       | 2     | 16            |                |                     |
| CPDR              | ED B9       | 2     | 21/16*        |                | *                   |
| CPI               | ED A1       | 2     | 16            |                |                     |
| CPIR              | ED B1       | 2     | 21/16*        |                | *                   |
| CPL               | 2F          | 1     | 4             | CMA            | 4                   |
| DAA               | 27          | 1     | 4             | DAA            | 4                   |
| DEC (HL)          | 35          | 1     | 11            | DCR M          | 10                  |
| DEC IX            | DD 2B       | 2     | 10            |                |                     |
| DEC (IX + disp)   | DD 35 yy    | 3     | 23            |                |                     |
| DEC IY            | FD 2B       | 2     | 10            |                |                     |
| DEC (IY + disp)   | FD 35 yy    | 3     | 23            |                |                     |
| DEC rp            | 00xx1011    | 1     | 6             | DCX rp         | 5                   |
| DEC reg           | 00xxx101    | 1     | 4             | DCR reg        | 5                   |
| DI                | F3          | 1     | 4             | DI             | 4                   |
| DJNZ disp         | 10 yy       | 2     | 8/13          |                |                     |
| EI                | FB          | 1     | 4             | EI             | 4                   |
| EX AF,AF          | 08          | 1     | 4             |                |                     |
| EX DE,HL          | EB          | 1     | 4             | XCHG           | 4                   |
| EX (SP),HL        | E3          | 1     | 19            | XTHL           | 18                  |
| EX (SP),IX        | DD E3       | 2     | 23            |                |                     |

Table 7-3. A Summary of Instruction Object Codes and Execution Cycles with 8080A Mnemonics  
for Identical Instructions (Continued)

| INSTRUCTION         | OBJECT CODE | BYTES | CLOCK PERIODS | 8080A MNEMONIC | 8080A CLOCK PERIODS |
|---------------------|-------------|-------|---------------|----------------|---------------------|
| EX (SP),IY          | FD E3       | 2     | 23            |                |                     |
| EXX                 | D9          | 1     | 4             |                |                     |
| HALT                | 76          | 1     | 4             |                |                     |
| IM 0                | ED 46       | 2     | 8             |                |                     |
| IM 1                | ED 56       | 2     | 8             |                |                     |
| IM 2                | ED 5E       | 2     | 8             |                |                     |
| IN A,port           | DB yy       | 2     | 10            |                |                     |
| IN reg,(C)          | ED          | 2     | 11            |                |                     |
|                     | 01ddd000    |       |               |                |                     |
| INC (HL)            | 34          | 1     | 11            |                |                     |
| INC IX              | DD 23       | 2     | 10            |                |                     |
| INC (IX + disp)     | DD 34 yy    | 3     | 23            |                |                     |
| INC IY              | FD 23       | 2     | 10            |                |                     |
| INC (IY + disp)     | FD 34 yy    | 3     | 23            |                |                     |
| INC rp              | 00xx0011    | 1     | 6             |                |                     |
| INC reg             | 00xxx100    | 1     | 4             |                |                     |
| IND                 | ED AA       | 2     | 15            |                |                     |
| INDR                | ED BA       | 2     | 20/15         |                |                     |
| INI                 | ED A2       | 2     | 15            |                |                     |
| INIR                | ED B2       | 2     | 20/15         |                |                     |
| JP label            | C3 ppqq     | 3     | 10            |                |                     |
| JP C,label          | DA ppqq     | 3     | 10            |                |                     |
| JP (HL)             | E9          | 1     | 4             |                |                     |
| JP (IX)             | DD E9       | 2     | 8             |                |                     |
| JP (IY)             | FD E9       | 2     | 8             |                |                     |
| JP M,label          | FA ppqq     | 3     | 10            |                |                     |
| JP NC,label         | D2 ppqq     | 3     | 10            |                |                     |
| JP NZ,label         | C2 ppqq     | 3     | 10            |                |                     |
| JP P,label          | F2 ppqq     | 3     | 10            |                |                     |
| JP PE,label         | EA ppqq     | 3     | 10            |                |                     |
| JP PO,label         | E2 ppqq     | 3     | 10            |                |                     |
| JP Z,label          | CA ppqq     | 3     | 10            |                |                     |
| JR C,disp           | 38 yy       | 2     | 7/12          |                |                     |
| JR disp             | 18 yy       | 2     | 12            |                |                     |
| JR NC,disp          | 30 yy       | 2     | 7/12          |                |                     |
| JR NZ,disp          | 20 yy       | 2     | 7/12          |                |                     |
| JR Z,disp           | 28 yy       | 2     | 7/12          |                |                     |
| LD A,(addr)         | 3A ppqq     | 3     | 13            |                |                     |
| LD A,(BC)           | 0A          | 1     | 7             |                |                     |
| LD A,(DE)           | 1A          | 1     | 7             |                |                     |
| LD AJ               | ED 57       | 2     | 9             |                |                     |
| LD A,R              | ED 5F       | 2     | 9             |                |                     |
| LD (addr),A         | 32 ppqq     | 3     | 13            |                |                     |
| LD (addr),BC        | ED 43 ppqq  | 4     | 20            |                |                     |
| LD (addr),DE        | ED 53 ppqq  | 4     | 20            |                |                     |
| LD (addr),HL        | 22 ppqq     | 3     | 16            |                |                     |
| LD (addr),IX        | DD 22 ppqq  | 4     | 20            |                |                     |
| LD (addr),IY        | FD 22 ppqq  | 4     | 20            |                |                     |
| LD (addr),SP        | ED 73 ppqq  | 4     | 20            |                |                     |
| LD (BC),A           | 02          | 1     | 7             |                |                     |
| LD (DE),A           | 12          | 1     | 7             |                |                     |
| LD HL,(addr)        | 2A ppqq     | 3     | 16            |                |                     |
| LD (HL),data        | 36 yy       | 2     | 10            |                |                     |
| LD (HL),reg         | 01110sss    | 1     | 7             |                |                     |
| LD I,A              | ED 47       | 2     | 9             |                |                     |
| LD IX,(addr)        | DD 2A ppqq  | 4     | 20            |                |                     |
| LD IX,data16        | DD 21 yyyy  | 4     | 14            |                |                     |
| LD (IX + disp),data | DD 36 yy yy | 4     | 19            |                |                     |
| LD (IX + disp),reg  | DD 01110sss | 3     | 19            |                |                     |
|                     | yy          |       |               |                |                     |
| LD IY,(addr)        | FD 2A ppqq  | 4     | 20            |                |                     |
| LD IY,data16        | FD 21 yyyy  | 4     | 14            |                |                     |

Table 7-3. A Summary of Instruction Object Codes and Execution Cycles with 8080A Mnemonics  
for Identical Instructions (Continued)

| INSTRUCTION         | OBJECT CODE | BYTES | CLOCK PERIODS | 8080A MNEMONIC | 8080A CLOCK PERIODS |
|---------------------|-------------|-------|---------------|----------------|---------------------|
| LD (IY + disp),data | FD 38 yyyy  | 4     | 19            |                |                     |
| LD (IY + disp),reg  | FD 01110sss | 3     | 19            |                |                     |
|                     | YY          |       |               |                |                     |
| LD R,A              | ED 4F       | 2     | 9             |                |                     |
| LD reg,data         | 00ddd110    | 2     | 7             | MVI            | reg,data            |
|                     | YY          |       |               |                |                     |
| LD reg,(HL)         | 01ddd110    | 1     | 7             | MOV            | reg,M               |
| LD reg,(IX + disp)  | DD          | 3     | 19            |                |                     |
|                     | 01ddd110    |       |               |                |                     |
|                     | YY          |       |               |                |                     |
| LD reg,(IY + disp)  | FD          | 3     | 19            |                |                     |
|                     | 01dddd110   |       |               |                |                     |
|                     | YY          |       |               |                |                     |
| LD reg,reg          | 01ddssss    | 1     | 4             | MOV            | reg,reg             |
| LD rp,(addr)        | ED 01xx1011 | 4     | 20            |                |                     |
|                     | ppqq        |       |               |                |                     |
| LD rp,data16        | 00xx0001    | 3     | 10            | LXI            | rp,data16           |
|                     | YYYY        |       |               |                |                     |
| LD SP,HL            | F9          | 1     | 6             | SPHL           |                     |
| LD SP,IX            | DD F9       | 2     | 10            |                |                     |
| LD SP,IY            | FD F9       | 2     | 10            |                |                     |
| LDD                 | ED A8       | 2     | 16            |                |                     |
| LDDR                | ED B8       | 2     | 21/16*        |                |                     |
| LDI                 | ED A0       | 2     | 16            |                |                     |
| LDIR                | ED B0       | 2     | 21/16*        |                |                     |
| NEG                 | ED 44       | 2     | 8             |                |                     |
| NOP                 | 00          | 1     | 4             | NOP            |                     |
| OR data             | F8 yy       | 2     | 7             | ORI            | data                |
| OR (HL)             | B8          | 1     | 7             | ORA            | M                   |
| OR (IX + disp)      | DD B6 yy    | 3     | 19            |                |                     |
| OR (IY + disp)      | FD B6 yy    | 3     | 19            |                |                     |
| OR reg              | 10110xxx    | 1     | 4             | ORA            | reg                 |
| OTDR                | ED BB       | 2     | 20/15*        |                |                     |
| OTIR                | ED B3       | 2     | 20/15*        |                |                     |
| OUT (C),reg         | ED 01sss001 | 2     | 12            |                |                     |
| OUT port,A          | D3 yy       | 2     | 11            | OUT            | port                |
| OUTD                | ED AB       | 2     | 15            |                |                     |
| OUTI                | ED A3       | 2     | 15            |                |                     |
| POP IX              | DD E1       | 2     | 14            |                |                     |
| POP IY              | FD E1       | 2     | 14            |                |                     |
| POP pr              | 11xx0001    | 1     | 10            | POP            | rp                  |
| PUSH IX             | DD E5       | 2     | 15            |                |                     |
| PUSH IY             | FD E5       | 2     | 15            |                |                     |
| PUSH pr             | 11xx0101    | 1     | 11            | PUSH           | rp                  |
| RES b,(HL)          | CB          | 2     | 15            |                |                     |
|                     | 10bbb110    |       |               |                |                     |
| RES b,(IX + disp)   | DD CB yy    | 4     | 23            |                |                     |
|                     | 10bbb110    |       |               |                |                     |
| RES b,(IY + disp)   | FD CB yy    | 4     | 23            |                |                     |
|                     | 10bbb110    |       |               |                |                     |
| RES b,reg           | CB          | 2     | 8             |                |                     |
|                     | 10bbbxss    |       |               |                |                     |
| RET                 | C9          | 1     | 10            | RET            |                     |
| RET C               | D8          | 1     | 5/11          | RC             | 5/11                |
| RET M               | F8          | 1     | 5/11          | RIM            | 5/11                |
| RET NC              | D0          | 1     | 5/11          | RNC            | 5/11                |
| RET NZ              | C0          | 1     | 5/11          | RNZ            | 5/11                |
| RET P               | F0          | 1     | 5/11          | RP             | 5/11                |
| RET PE              | E8          | 1     | 5/11          | RPE            | 5/11                |
| RET PO              | E0          | 1     | 5/11          | RPO            | 5/11                |
| RET Z               | C8          | 1     | 5/11          | RZ             | 5/11                |
| RETI                | ED 4D       | 2     | 14            |                |                     |

Table 7-3. A Summary of Instruction Object Codes and Execution Cycles with 8080A Mnemonics  
for Identical Instructions (Continued)

| INSTRUCTION       | OBJECT CODE | BYTES | CLOCK PERIODS | 8080A MNEMONIC | 8080A CLOCK PERIODS |
|-------------------|-------------|-------|---------------|----------------|---------------------|
| RETN              | ED 45       | 2     | 14            |                |                     |
| RL (HL)           | CB 16       | 2     | 15            |                |                     |
| RL (IX + disp)    | DD CB yy 16 | 4     | 23            |                |                     |
| RL (IY + disp)    | FD CB yy 16 | 4     | 23            |                |                     |
| RL reg            | CB          | 2     | 8             |                |                     |
|                   | 00010xxx    |       |               |                |                     |
| RLA               | 17          | 1     | 4             | RAL            | 4                   |
| RLC (HL)          | CB 06       | 2     | 15            |                |                     |
| RLC (IX + disp)   | DD CB yy 06 | 4     | 23            |                |                     |
| RLC (IY + disp)   | FD CB yy 06 | 4     | 23            |                |                     |
| RLC reg           | CB          | 2     | 8             |                |                     |
|                   | 00000xxx    |       |               |                |                     |
| RLCA              | 07          | 1     | 4             | RLC            | 4                   |
| RLD               | ED 6F       | 2     | 18            |                |                     |
| RR (HL)           | CB 1E       | 2     | 15            |                |                     |
| RR (IX + disp)    | DD CB yy 1E | 4     | 23            |                |                     |
| RR (IY + disp)    | FD CB yy 1E | 4     | 23            |                |                     |
| RR reg            | CB          | 2     | 8             |                |                     |
|                   | 00011xxx    |       |               |                |                     |
| RRA               | 1F          | 1     | 4             | RAR            | 4                   |
| RRC (HL)          | CB 0E       | 2     | 15            |                |                     |
| RRC (IX + disp)   | DD CB yy 0E | 4     | 23            |                |                     |
| RRC (IY + disp)   | FD CB yy 0E | 4     | 23            |                |                     |
| RRC reg           | CB          | 2     | 8             |                |                     |
|                   | 00001xxx    |       |               |                |                     |
| RRCA              | 0F          | 1     | 4             | RRC            | 4                   |
| RRD               | ED 67       | 2     | 18            |                |                     |
| RST n             | 11xxx111    | 1     | 11            | RST n          | 11                  |
| SBC data          | DE yy       | 2     | 7             | SBI data       | 7                   |
| SBC (HL)          | 9E          | 1     | 7             | SBB m          | 7                   |
| SBC HL, rp        | ED 01xx0010 | 2     | 15            |                |                     |
| SBC (IX + disp)   | DD 9E yy    | 3     | 19            |                |                     |
| SBC (IY + disp)   | FD 9E yy    | 3     | 19            |                |                     |
| SBC reg           | 10011xxx    | 1     | 4             | SBB reg        | 4                   |
| SCF               | 37          | 1     | 4             | STC            | 4                   |
| SET b,(HL)        | CB          | 2     | 15            |                |                     |
|                   | 11bbb110    |       |               |                |                     |
| SET b,(IX + disp) | DD CB yy    | 4     | 23            |                |                     |
|                   | 11bbb110    |       |               |                |                     |
| SET b,(IY + disp) | FD CB yy    | 4     | 23            |                |                     |
|                   | 11bbb110    |       |               |                |                     |
| SET b,reg         | CB          | 2     | 8             |                |                     |
|                   | 11bbbxxx    |       |               |                |                     |
| SLA (HL)          | CB 26       | 2     | 15            |                |                     |
| SLA (IX + disp)   | DD CB yy 26 | 4     | 23            |                |                     |
| SLA (IY + disp)   | FD CB yy 26 | 4     | 23            |                |                     |
| SLA reg           | CB 00100xxx | 2     | 8             |                |                     |
| SRA (HL)          | CB 2E       | 2     | 15            |                |                     |
| SRA (IX + disp)   | DD CB yy 2E | 4     | 23            |                |                     |
| SRA (IY + disp)   | FD CB yy 2E | 4     | 23            |                |                     |
| SRA reg           | CB 00101xxx | 2     | 8             |                |                     |
| SRL (HL)          | CB 3E       | 2     | 15            |                |                     |
| SRL (IX + disp)   | DD CB yy 3E | 4     | 23            |                |                     |
| SRL (IY + disp)   | FD CB yy 3E | 4     | 23            |                |                     |
| SRL reg           | CB 00111xxx | 2     | 8             |                |                     |
| SUB data          | D6 yy       | 2     | 7             | SUI data       | 7                   |
| SUB (HL)          | 96          | 1     | 7             | SUB M          | 7                   |
| SUB (IX + disp)   | DD 96 yy    | 3     | 19            |                |                     |
| SUB (IY + disp)   | FD 96 yy    | 3     | 19            |                |                     |
| SUB reg           | 10010xxx    | 1     | 4             | SUB reg        | 4                   |
| XOR data          | EE yy       | 2     | 7             | XRI data       | 7                   |
| XOR (HL)          | AE          | 1     | 7             | XRA M          | 7                   |

Table 7-3. A Summary of Instruction Object Codes and Execution Cycles with 8080A Mnemonics for Identical Instructions (Continued)

| INSTRUCTION     | OBJECT CODE | BYTES | CLOCK PERIODS | 8080A MNEMONIC | 8080A CLOCK PERIODS |
|-----------------|-------------|-------|---------------|----------------|---------------------|
| XOR (IX + disp) | DD AE yy    | 3     | 19            |                |                     |
| XOR (IY + disp) | FD AE yy    | 3     | 19            |                |                     |
| XOR reg         | 10101xxx    | 1     | 4             | XRA reg        | 4                   |

x represents an optional binary digit.  
 bbb represents optional binary digits identifying a bit location in a register or memory byte.  
 ddd represents optional binary digits identifying a destination register.  
 sss represents optional binary digits identifying a source register.  
 ppqq represents a four hexadecimal digit memory address.  
 yy represents two hexadecimal data digits.  
 yyyy represents four hexadecimal data digits.

When two possible execution times are shown (i.e., 5/11), it indicates that the number of clock periods depends on condition flags.

\*Execution time shown is for one iteration.

## THE Z80 INSTRUCTION SET

We are going to describe the Z80 instruction set as an 8080A enhancement. Table 7-2 summarizes the Z80 instruction set in the standard format used for all microcomputers in this book; unfortunately, the fact that the 8080A instruction set is a subset of Table 7-2 is not immediately obvious, since a number of significant conceptual differences exist between the Zilog and 8080A assembly language mnemonics. Table 7-3 therefore shows Z80 equivalents for every 8080A instruction. The few incompatibilities which exist are identified.

Also because of Z80 mnemonics, the Zilog instruction set is not easily forced into the standard instruction categories that we have selected for consistency. In particular, Z80 mnemonics group Memory Reference, Register-Register Move and Immediate instruction into a single "Load and Exchange" category. The same holds true for Z80 Arithmetic and Logical instructions; in Table 7-2 these become Secondary Memory Reference, Register-Register Operate and Immediate Operate instructions.

### INPUT/OUTPUT INSTRUCTIONS

These are the types of input/output instructions provided by the Z80:

- 1) **The standard 8080A IN and OUT instructions.** whereby the second byte of instruction object code provides an I/O port address, which appears on Address Bus lines A0 - A7.
- 2) **Register indirect Input and Output instructions.** These instructions transfer data between Register A, B, C, D, E, H or L, and the I/O port identified by the contents of Register C. Thus the instruction:

LD C,PORTN ;LOAD PORT NUMBER INTO REGISTER C

-

-

-

IN D,(C) ;INPUT DATA FROM PORTN TO REGISTER D

is equivalent to:

IN A,(PORTN)

LD D,A

The I/O port address, now the contents of Register C, is output on A0 - A7 in the usual way.

- 3) **Block Transfer I/O instructions.** These instructions move a block of data between the I/O port identified by Register C and a memory location addressed by the H and L register pair. Register B is used as a block byte counter. After each byte of data within the block is transferred, the contents of Register B are decremented; you can specify block transfer I/O instructions that will either increment or decrement the memory address in Registers H and L. Here is a programming example with the 8080A equivalent:

|      | Z80      | 8080A          |
|------|----------|----------------|
| LD   | B,COUNT  | MVI B,COUNT    |
| LD   | C,PORTN  | LXI H,START    |
| LD   | HL,START | LOOP: IN PORTN |
| INIR |          | MOV M,A        |
|      |          | INX H          |
|      |          | DCR B          |
|      |          | JNZ LOOP       |

These instruction sequences input COUNT bytes from I/O port PORTN, and store the data in a memory buffer whose beginning address is START. COUNT and PORTN are symbols representing 8-bit numbers. START is an address label. The block transfer I/O instruction will continue executing until the B register has decremented to 0.

- 4) **Single Step Block Transfer I/O instructions.** These are identical to the block transfer I/O instructions described in category 3 above, except that instruction execution ceases after one iterative step. Referring to the INIR instruction example, if the INIR instruction were replaced by an INI instruction, a single byte of data would be transferred from PORTN to the memory location addressed by START. The address START would be incremented, Register B contents would be decremented, then instruction execution would cease.

When a block transfer or single step, block transfer I/O instruction is executed, C register contents, which identify the I/O port, are output on the lower eight Address Bus lines in the usual way; however, B register contents are output on the higher eight address lines A15 - A8. Therefore external logic can, if it wishes, determine the extent of the transfer.

**Let us now look at the advantages gained by having the new Z80 I/O instructions.**

**The value of the Register Indirect I/O instructions is that programs stored in ROM can access any I/O port.** If I/O port assignments change, then all you need to do is modify that small portion of program which loads the I/O port address into the C register.

**The Block Transfer I/O instructions must be approached with an element of caution.** In response to the execution of a single instruction's object code, up to 256 bytes of data may be transferred between memory and an I/O port. This data transfer occurs at CPU speed — which means external logic must input or output data at the same speed. If external logic cannot operate fast enough, it can insert Wait states in order to slow the CPU, but that takes additional logic; and one might argue that the traditional methods of polling on status to effect block I/O transfers is cheaper than adding extra Wait state logic.

Note that all Z80 enhanced I/O instructions require two bytes of object code.

## PRIMARY MEMORY REFERENCE INSTRUCTIONS

Instructions that we classify as Primary Memory Reference constitute a subset of the Load instructions, as classified by Zilog. **Within the Primary Memory Reference instructions category, as we define it, Zilog offers a single enhancement: base relative addressing.** Instructions that move data between a register and memory may specify the memory address as the contents of an Index register; plus an 8-bit displacement provided by the instruction object code. Here is a programming example of Zilog base relative addressing and the 8080A equivalent:

|    | Z80           | 8080A       |
|----|---------------|-------------|
| LD | IX, BASE      | LXI H, BASE |
| LD | C,(IX + DISP) | LXI D, DISP |
|    | DAD           | D           |
|    | MOV           | C,M         |

Observe that the two Z80 instructions do not use any CPU registers — other than the IX Index register. The 8080A uses the DE and HL registers. Here is an example of the true value that results from having Index registers. The Z80 can use the DE and HL registers to store temporary data, which the 8080A cannot do; the 8080A would have to store such temporary data in external read/write memory.

The biggest single advantage that accrues to the Z80 from having indexed addressing is the fact that well written Z80 programs will contain far fewer memory reference instructions than equivalent 8080A programs; therefore Z80 programs will execute faster.

Other primary memory reference instructions provided by the Z80, and not present in the 8080A, include instructions which load data into the Index registers and store Index registers' contents in memory. Since the 8080A does not have Index registers, it cannot have memory reference instructions for them. The Z80 also has instructions which transfer 16-bit data between directly addressed memory and any register pair, except AF. Recall that in the 8080A, HL is the only register pair which stores to memory and loads from memory using direct addressing.

## BLOCK TRANSFER AND SEARCH INSTRUCTIONS

We classify the Zilog Block Transfer and Search instructions in a separate category, since our hypothetical computer, as described in Volume I, had no equivalent instructions.

A Block Transfer instruction allows you to move up to 65,536 bytes of data between two memory buffers which may be anywhere in memory. The H and L registers address the source buffer, the D and E registers address the destination buffer, and the B and C registers hold the byte count.

After every byte of data is transferred, the B and C registers' contents are decremented; instruction execution ceases after the B and C registers decrement to zero. You have the option of incrementing or decrementing the source and destination addresses following the transfer of each data byte. Thus you can transfer data from low to high memory, or from high to low memory. Here is a programming example of the Z80 Block Move instruction, along with the 8080A equivalent:

|      | Z80      | 8080A       |
|------|----------|-------------|
| LD   | BC,COUNT | LXI B,COUNT |
| LD   | DE,DEST  | LXI D,DEST  |
| LD   | HL,SRCE  | LXI H,SRCE  |
| LDIR | LOOP:    | MOV A,M     |
|      |          | STAX D      |
|      |          | INX H       |
|      |          | INX D       |
|      |          | DCX B       |
|      |          | MOV A,B     |
|      |          | ORA C       |
|      |          | JNZ LOOP    |

The two instruction sequences illustrated above move a block of data, COUNT bytes long, from a buffer whose starting address is SRCE to another buffer whose starting address is DEST. SRCE and DEST are 16-bit address labels. COUNT is a symbol representing a 16-bit data value.

The Z80 - 8080A comparison above is one that makes the 8080A look particularly bad. This is because it emphasizes 8080A weaknesses; the 8080A requires memory addresses to be incremented as separate steps. Also, after decrementing the counter in Registers B and C, status is not set, therefore BC contents are tested by loading B into A and ORing with C.

**You can use Block Move instructions in Z80 configurations that include dynamic memory.** While the Block Move is being executed, dynamic memory is refreshed.

**The Block Search instruction will search a block of data in memory, looking for a match with the Accumulator contents.** The H and L registers address memory, while the B and C registers again act as a byte counter. When a match between Accumulator contents and a memory location is found, the Search instruction ceases executing. After every Compare, the B and C registers' contents are decremented: once again you have the option of either incrementing or decrementing H and L registers' contents. Thus you can search a block of memory from high address down, or from low address up.

The results of every step in a Block Search are reported in the Z and P/O statuses. If a match is found between Accumulator and memory contents, then Z is set to 1; otherwise Z will equal 0. When the B and C registers count out to zero, the P/O status will be reset to 0; otherwise the P/O status will equal 1.

Here is an example of a program using the Z80 Block Search instruction, along with 8080A program equivalent:

| Z80             | 8080A            |
|-----------------|------------------|
| LD A,REFC       | LXI BC,COUNT     |
| LD BC,COUNT     | LXI HL,SRCE      |
| LD HL,SRCE      | LOOP: MVI A,REFC |
| CPDR            | CMP M            |
| JR Z,FOUND      | JZ FOUND         |
| ;NO MATCH FOUND |                  |
| -               | DCX H            |
| -               | DCX B            |
| -               | MOV A,B          |
| ;MATCH FOUND    |                  |
| FOUND:          | ORA C            |
| -               | JNZ LOOP         |
| ;NO MATCH FOUND |                  |
| - - - - -       |                  |
| ;MATCH FOUND    |                  |
| FOUND:          | -                |

Each of the above instruction sequences tries to match a character represented by the symbol REFC with the contents of bytes in a memory buffer. The memory buffer is originated at SRCE and is COUNT bytes long.

In the example illustrated above, SRCE is the highest memory address for the buffer, which is searched towards the low memory address. FOUND is the label for the first instruction in the sequence which is executed if a match is found. If no match is found, that is, the BC registers count out to 0, program execution continues with the next sequential instruction.

**The Z80 Block Search instruction is particularly useful when searching a large memory buffer for a byte that may frequently occur.** Suppose you have an ASCII text in which Control codes have been imbedded. For the sake of argument, let us assume that all Control codes are two bytes long, where the first byte has the hexadecimal value 02 and the second byte identifies the Control code. You can use one set of registers in order to search the text buffer for Control codes, while using the second set of registers to process the text buffer after each Control code has been located.

All you need to do in the Block Search instruction sequence illustrated above is follow the CPDR instruction with an EXX instruction; after executing the instruction sequence following MATCH FOUND, again execute an EXX instruction before returning to search for the next Control code.

**Each of the Block Move and Block Search instructions has a single step equivalent.** The single step instruction moves one byte of data, or compares the Accumulator contents with the next byte in a data buffer; addresses and counters are incremented and decremented as for the Block Move and Search instructions, however execution ceases after a single step has been completed.

## SECONDARY MEMORY REFERENCE (MEMORY OPERATE) INSTRUCTIONS

Instructions that we classify as Secondary Memory Reference, or Memory Operate, constitute a portion of the arithmetic and logical instructions, as defined by the Z80. **Within the Memory Operate group of instructions, the single enhancement offered by the Z80 is a duplicate set of instructions that uses base relative addressing.** We have already discussed this enhancement in connection with Primary Memory Reference instructions. Here is a programming example with the 8080A equivalent:

|     | Z80         | 8080A      |
|-----|-------------|------------|
| LD  | IX, BASE    | LXI HBASE  |
| ADD | (IX + DISP) | LXI D,DISP |
|     | DAD         | D          |
|     | ADD         | M          |

The same comments we made regarding the use of indexed addressing in the Primary Memory Reference example apply to the instruction sequences above.

## IMMEDIATE INSTRUCTIONS

Within the group of instructions that we classify as Immediate, the Z80 offers two enhancements:

- 1) Instructions are provided to load immediate data into the additional Z80 registers.
- 2) You can use base relative addressing to load a byte of data immediately into read/write memory.

## JUMP INSTRUCTIONS

In addition to the standard Jump instruction offered by the 8080A, the Z80 has a two-byte, unconditional Branch instruction, and two instructions which allow you to jump to the memory location specified by an Index register.

The two indexed Jump instructions transfer the contents of the identified Index register to the Program Counter.

The two-byte Jump instruction interprets the second object code byte as an 8-bit signed binary number, which is added to the Program Counter, after the Program Counter has been incremented to point to the next instruction. This is a standard program relative branch, as described in Volume I.

Note that the Z80 uses many of the spare 8080A object codes to implement the two-byte Branch and Branch-on-Condition instructions. This makes sense; it would certainly not make much sense to have two bytes of object code followed by a single branch byte, since that would create a three-byte Branch instruction — offering no advantage over the three-byte Jump instructions which already exist.

## SUBROUTINE CALL AND RETURN INSTRUCTIONS

The Z80 instructions in this group are identical to 8080A equivalents.

## IMMEDIATE OPERATE INSTRUCTIONS

Z80 Immediate Operate instructions, as we define them, are identical to those in the 8080A instruction set.

## JUMP-ON-CONDITION INSTRUCTION

The Z80 offers two significant Jump-on-Condition instruction enhancements over the 8080A:

- 1) There are two-byte equivalents for four of the more commonly used Jump-on-Condition instructions. The two-byte Jump-on-Condition instructions execute exactly as described for the two-byte Jump instruction.
- 2) There is a decrement and Jump-on-Nonzero instruction which is particularly useful in any kind of iterative loop. When this instruction is executed, the B register contents are decremented; if the B register contents, after being decremented, equal zero, the next sequential instruction is executed. If after being decremented the B register contents are not zero, then a Jump occurs. This is a two-byte instruction, where the Jump is specified by a single 8-bit signed binary value.

Here is an example of how the DJNZ instruction may be used along with the 8080A equivalent:

|       | Z80        | 8080A        |
|-------|------------|--------------|
|       | AND A      | ANA A        |
|       | LD IX,VALA | LXI D,VALA   |
|       | LD IY,VALB | LXI H,VALB   |
|       | LD B,CNT   | MVI B,CNT    |
| LOOP: | LD A,(IX)  | LOOP: LDAX D |
|       | ADC A,(IY) | ADC M        |
|       | LD (IX),A  | STAX D       |
|       | INC IX     | INX D        |
|       | INC IY     | INX H        |
|       | DJNZ LOOP  | DCR B        |
|       |            | JNZ LOOP     |

The two instruction sequences illustrated above perform simple multibyte binary addition. The contents of two buffers, originated at VALA and VALB, are summed; the results are stored in buffer VALA.

The first instruction in each sequence is executed in order to clear the Carry status. Like the 8080A, the Z80 does not have an instruction which sets the Carry status to 0, while performing no other operation.

## REGISTER-REGISTER MOVE INSTRUCTIONS

Register-Register Move instructions, as we defined them in this book, constitute a subset of the Z80 Load instructions. All Z80 Exchange instructions, except those that exchange with the top of the Stack, are also classified as Register-Register Move instructions.

**The Z80 enhancements within this instruction group apply strictly to the additional registers implemented within the Z80.** That is to say, because the Z80 has registers which the 8080A does not have, the Z80 must also have instructions to move data in and out of these additional registers.

The instructions which exchange data between registers and their alternates need comment. Note that you can swap the entire set of duplicated registers, or you can swap selected register pairs. If you use these instructions following an interrupt acknowledge, you do not have to save the contents of the registers on the Stack. Of course, this will only work for a single interrupt level. There are also occasions when the alternate set of registers can be used effectively in normal programming logic, as we illustrated when describing the Block Search instruction.

## REGISTER-REGISTER OPERATE INSTRUCTIONS

**There are a few new Z80 Register-Register Operate instructions which do the following:**

- 1) Add without Carry the contents of a register pair to an Index register.
- 2) Add with Carry to HL the contents of a register pair.
- 3) Subtract with Carry from HL the contents of a register pair.

## REGISTER OPERATE INSTRUCTIONS

**Within this category, the Z80 has two enhancements:**

- 1) You can increment or decrement the contents of an Index register.
- 2) A rich variety of Shift and Rotate instructions have been added. These instructions are illustrated in Table 7-2. In particular, note the RLD and RRD instructions, which are very useful when performing multidigit BCD left and right shifts.

## BIT MANIPULATION INSTRUCTIONS

**The 8080A has no equivalent for this set of Z80 instructions.** We give these instructions a separate category in Table 7-2 because of their extreme importance in microprocessor applications.

Bit manipulation instructions are particularly important for signal processing. A single signal is a binary entity; it is not part of an 8-bit unit. One of the great oversights among microprocessor designers has been to ignore bit manipulation instructions. **The Z80 has instructions that set to 1 (SET), reset to 0 (RES) or test (BIT) individual bits in memory or any general purpose register.** The result of a bit test is reported in the Zero status.

Here are some Z80 instructions with 8080A equivalents:

|     | Z80 | 8080A   |
|-----|-----|---------|
| BIT | 4,A | MOV B,A |
|     |     | ANI 10H |
|     |     | MOV A,B |

The 8080A tests Accumulator bits destructively — all untested bits are cleared; Accumulator contents must therefore be saved before testing. We can also contrive an example to emphasize the strengths of the Z80 bit instructions:

|     | Z80           | 8080A       |
|-----|---------------|-------------|
| LD  | IY.BASE       | LXI H, BASE |
| SET | 2,(IY + DISP) | LXI D, DISP |
|     |               | DAD D       |
|     |               | MVI A,4     |
|     |               | ORA M       |

Once again, note that the 8080A needs to use the D, E, H and L registers.

Note that all Z80 Bit instructions operate on memory or CPU registers. But in most microcomputer applications individual pins at I/O ports will most frequently be set, reset or tested. The Z80 has no I/O Bit instructions. If you wish, you can interface I/O devices so that they are addressed as memory locations; however, in that case, you cannot use Block I/O instructions.

The 8080A can do anything that a Z80 Bit Manipulation instruction can do but an additional Mask instruction is needed and the Accumulator is involved. On the surface these seem to be small penalties; but it is the frequency with which Bit Manipulation instructions are needed that escalates small penalties into major aggravations.

## STACK INSTRUCTIONS

**Additional Stack instructions provided by the Z80 allow the Z80 Index registers to be pushed onto the Stack, popped from the Stack, or exchanged with the top of the Stack.**

## INTERRUPT INSTRUCTIONS

In addition to the 8080A Interrupt instructions, the Z80 has two Return-from-Interrupt instructions. **RETI and RETN are used to return from maskable and nonmaskable interrupt service routines, respectively.**

RETI and RETN are two-byte instructions. **Within the CPU these instructions enable interrupts, but otherwise execute exactly as a Return-from-Subroutine (RET) instruction. However, devices designed by Zilog to support the Z80 CPU use the RETI and RETN instructions in a unique way.** Any support device that has logic to request an interrupt also includes logic which tests the Data Bus contents during the low M1 pulse. Upon detecting the second byte of an RETI or RETN instruction's object code, a device which has had an interrupt request acknowledged determines that the interrupt has been serviced.

Why does a support device need to know that an interrupt service routine has completed execution? The reason is that Zilog extends interrupt priority arbitration logic beyond the interrupt acknowledge process to the entire interrupt service routine.

This is the scheme adopted by the 8259 PICU. After reading the next paragraph, if you are still unclear on concepts, refer to the 8259 PICU discussion in the 8080A chapter.

Consider the typical daisy chain scheme used to set interrupt priorities in a multiple interrupt microcomputer system. Daisy chaining has been described in good detail in Volume 1. When more than one device is requesting an interrupt, an acknowledge ripples down the daisy chain until trapped by the interrupt requesting device electrically closest to the CPU. As soon as the interrupt acknowledge process has ceased, an interrupt service routine is executed for the acknowledged interrupt; acknowledged external logic will now remove its interrupt request. Unless the CPU disables further interrupts, a lower priority device can immediately interrupt the service routine of a higher priority device. With the Zilog system, that is not the case. A device which has its interrupt request acknowledged continues to suppress interrupt requests from all lower priority devices in a daisy chain, until the second object code byte for an RETI or RETN instruction is detected on the Data Bus. The acknowledged device responds to an RETI or RETN instruction's object code by re-enabling interrupts for devices with lower priority in the daisy chain.

Providing a Zilog microcomputer system has been designed to make correct use of the RETI and RETN instructions, interrupt priority arbitration logic will allow an interrupt service routine to be interrupted only by a high priority interrupt request.

Here is an illustration of the Zilog interrupt priority arbitration scheme:



**The three IM instructions allow you to specify that the CPU will respond to maskable interrupts in Mode 0, 1 or 2.** These three interrupt response modes have already been described.

## STATUS AND MISCELLANEOUS INSTRUCTIONS

Z80 and 8080A instructions in these categories are identical.

## THE BENCHMARK PROGRAM

Our benchmark program is coded for the Z80 as follows:

```

LD      BC,LENGTH      ;LOAD IO BUFFER LENGTH INTO BC
LD      DE,(TABLE)     ;LOAD ADDRESS OF FIRST FREE TABLE BYTE OUT OF FIRST TWO TABLE
                      ;BYTES
LD      HL,IOBUF        ;LOAD SOURCE ADDRESS INTO HL
LDIR

```

The program above makes absolutely no assumptions. Both source and destination tables may have any length and may be located anywhere in memory.

Notice that there is no instruction execution loop, since the LDIR block move will not stop executing until the entire block of data has been moved.

## SUPPORT DEVICES THAT MAY BE USED WITH THE Z80

The Z80 signal interface is very close to that of the 8080A. When looking at Z80 signals we saw how they may be combined to generate 8080A equivalents. Thus **8080A support devices may be used with the Z80 CPU. Exceptions are the 8259 Priority Interrupt Control Unit and the TMS5501 multifunction device.**

The 8259 Priority Interrupt Control Unit should not be used with the Z80 CPU because the Z80 CPU provides essentially the same capabilities within the CPU chip itself. So far as signal interface is concerned, you could use an 8259 with a Z80, but it would make no sense.

The TMS5501 cannot be used with a Z80 because it assumes status on the Data Bus — as output by the 8080A without an 8228 System Controller.

**The 8085 support devices** — the 8155, the 8355 and the 8755 — are difficult to use with the Z80; you have to multiplex the low order eight Z80 address lines and the Z80 8-bit Data Bus to simulate the 8085 multiplexed bus lines. Logic needed to perform this bus multiplexing would likely be more expensive than discrete packages that implement individual functions provided by the 8155 and 8355 multifunction devices.

**Using MC6800 support devices with the Z80 is not practical.** MC6800 support devices all require a synchronizing clock signal whose characteristics cannot be generated simply from the Z80 clock signal.

**With the exception of the Z80 DMA device, Z80 support devices (which we are about to describe) are not general-purpose devices.** The Z80 PIO, SIO, and CTC devices decode the M1, IORQ, and RD control signals to identify a number of functions. Table 7-4 defines the manner in which these signals are decoded. Were you to use the Z80 PIO, SIO, or CTC with any other microprocessor, you would have to multiplex the other microprocessor's control signals in order to create equivalents of M1, IORQ, and RD; this may not be straightforward.

Table 7-4. Z80 PIO Interpretation of Control Signals

| SIGNALS |      |    | FUNCTIONAL INTERPRETATION *                |
|---------|------|----|--------------------------------------------|
| M1      | IORQ | RD |                                            |
| 0       | 0    | 0  | No function                                |
| 0       | 0    | 1  | Interrupt acknowledge                      |
| 0       | 1    | 0  | Check for end of interrupt service routine |
| 0       | 1    | 1  | Reset                                      |
| 1       | 0    | 0  | Read from PIO to CPU                       |
| 1       | 0    | 1  | Write from CPU to PIO                      |
| 1       | 1    | 0  | No function                                |
| 1       | 1    | 1  | No function                                |

\* These interpretations only apply if the device has been selected

Z80 support devices also rely on exact Z80 CPU characteristics for interrupt processing. Specifically, Z80 support devices detect every instruction fetch, as identified by  $\overline{M1}$  and  $\overline{RD}$  simultaneously low; if a return from interrupt object code is fetched, then Z80 support devices respond to this object code by resetting internal interrupt priority logic. Accounting for this end of interrupt logic in a non-Z80 system could be difficult.

**Because of the unique characteristics of the Z80 support devices, the Z80 PIO and CTC devices are described in this chapter. The Z80 DMA device is described in Volume 3,** however, because this device is easily used in non-Z80 configurations; moreover, its unique capabilities make it a highly desirable part to include in any microcomputer system that has to move text or data strings. **The Z80 SIO device is also described in Volume 3** because it is an exceptionally powerful device; in many cases the power of the Z80 SIO device will compensate for the additional logic it will demand in a non-Z80 microcomputer system.

## THE Z80 PARALLEL I/O INTERFACE (PIO)

The Z80 PIO is Zilog's parallel interface device; it may be looked upon as a replacement for the 8255 PPI, but it is equivalent to the PPI at a functional level only. No attempt has been made to make the Z80 PIO an upward compatible replacement for the 8255 PPI.

The Z80 PIO has 16 I/O pins, divided into two 8-bit I/O ports. Each I/O port has two associated control lines. This makes the Z80 PIO more like the Motorola MC6820 than the 8255 PPI.

The two Z80 PIO I/O ports may be separately specified as input, output or control ports. When specified as a control port, pins may be individually assigned to input or output. Port A may be used as a bidirectional I/O port.

The Z80 PIO also provides a significant interrupt handling capability. This includes:

- The ability to define conditions which will initiate an interrupt.
- Interrupt priority arbitration
- Vectored response to an interrupt acknowledge

Figure 7-16 illustrates that part of our general microcomputer system logic which has been implemented on the Z80 PIO.

The Z80 PIO is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL-level compatible. The device is fabricated using N-channel silicon gate depletion load technology.



Figure 7-16. Logic Functions of the Z80 PIO

## Z80 PIO PINS AND SIGNALS

Z80 PIO pins and signals are illustrated in Figure 7-17. Signals are very straightforward; therefore their functions will be summarized before we discuss device characteristics and operation.

Let us first consider the PIO CPU interface.

All data transfers between the PIO and the CPU occur via the Data Bus, which connects to pins D0 - D7.

For the PIO to be selected, a low input must be present at  $\overline{CE}$ . There are two additional address lines.  $B/A\ SEL$  selects Port A if low and Port B if high. For the selected I/O port,  $C/D\ SEL$  selects a data buffer when low and a control buffer when high. Device select logic is summarized in Table 7-5.

Table 7-5. Z80 PIO Select Logic

| SIGNAL |         |         | SELECTED LOCATION     |
|--------|---------|---------|-----------------------|
| CE     | B/A SEL | C/D SEL |                       |
| 0      | 0       | 0       | Port A data buffer    |
| 0      | 0       | 1       | Port A control buffer |
| 0      | 1       | 0       | Port B data buffer    |
| 0      | 1       | 1       | Port B control buffer |
| 1      | X       | X       | Device not selected   |

Z80 PIO device control logic is not straightforward. Of the control signals output by the Z80 CPU, three are input to the PIO:  $\overline{M1}$ ,  $\overline{IORQ}$ , and  $\overline{RD}$ .  $\overline{WR}$  is not input to the PIO. **Table 7-5 illustrates the way in which Z80 PIO interprets  $\overline{M1}$ ,  $\overline{IORQ}$  and  $\overline{RD}$** . Observe that  $\overline{RD}$  is being treated as a signal with two active states: low  $\overline{RD}$  specifies a read operation, whereas high  $\overline{RD}$  specifies a write operation. This does not conform to the CPU, which treats  $\overline{RD}$  and  $\overline{WR}$  as signals with a low active state only.

Let us now look at the PIO external logic interface.

**A0 - A7 represent the eight bidirectional I/O Port A lines; I/O Port A is supported by two control signals, A RDY and A STB.**

**Similarly, I/O Port B is implemented via the eight bidirectional lines B0 - B7 and the two associated control lines B RDY and B STB.**

The I/O Port A and B control lines provide handshaking logic which we will describe shortly.

Now consider interrupt control signals.

**IEI and IEO are standard daisy chain interrupt priority signals.** When more than one PIO is present in a system, the highest priority PIO will have IEI tied to +5V and will connect its IEO to the IEI for the next highest priority PIO in the daisy chain:



If you are unsure of daisy chain priority networks, refer to Volume 1 for clarification.

**INT is a standard interrupt request signal** which is output by the Z80 PIO and must be connected as an input to the Z80 CPU interrupt request. Observe that there is no interrupt acknowledge line, since  $\overline{M1}$  and  $\overline{IORQ}$  simultaneously low constitute an interrupt acknowledge and will thus be decoded by the Z80 PIO.

**Clock, power, and ground signals are absolutely standard.** The same clock signal is used by the PIO and the Z80 CPU.

**Observe that there is no Reset signal to the PIO.**  $M1$  low with both  $\overline{RD}$  and  $\overline{IORQ}$  high constitutes a reset. We will describe the effect of a Z80 PIO reset after discussing operating modes.



| PIN NAME    | DESCRIPTION                                     | TYPE                    |
|-------------|-------------------------------------------------|-------------------------|
| D0 - D7     | Data Bus                                        | Tristate, Bidirectional |
| CE          | Device Enable                                   | Input                   |
| B/A SEL     | Select Port A or Port B                         | Input                   |
| C/D SEL     | Select Control or Data                          | Input                   |
| M1          | Instruction fetch machine cycle signal from CPU | Input                   |
| IORQ        | Input/Output request from CPU                   | Input                   |
| RD          | Read cycle status from CPU                      | Input                   |
| A0 - A7     | Port A Bus                                      | Tristate, Bidirectional |
| A RDY       | Register A Ready                                | Output                  |
| A STB       | Port A strobe pulse                             | Input                   |
| B0 - B7     | Port B Bus                                      | Tristate, Bidirectional |
| B RDY       | Register B Ready                                | Output                  |
| B STB       | Port B strobe pulse                             | Input                   |
| IEI         | Interrupt enable in                             | Input                   |
| IEO         | Interrupt enable out                            | Output                  |
| INT         | Interrupt request                               | Output, Open-drain      |
| Φ, +5V, GND | Clock, Power and Ground                         |                         |

Figure 7-17. Z80 PIO Signals and Pin Assignments

## Z80 PIO OPERATING MODES

To the programmer, a Z80 PIO will be accessed as four addressable locations:



By loading appropriate information into the Control register you determine the mode in which the I/O port is to operate.

The Z80 PIO has operating modes which are equivalent to those of the 8255 PPI, plus an additional mode which the 8255 PPI does not have. However, 8255 PPI Mode 0 provides 24 I/O lines, as against a maximum of 16 I/O lines available with the Z80 PIO.

Zilog literature uses Mode 0, Mode 1, Mode 2, and Mode 3 to describe the ways in which the Z80 PIO can operate; in order to avoid confusion between mode designations as used by the Z80 PIO and the 8255 PPI, mode equivalences are given in Table 7-6.

Table 7-6. Z80 PIO And 8255 Mode Equivalences

| Z80 PIO | 8255 PPI | INTERPRETATION                              |
|---------|----------|---------------------------------------------|
| Mode 3* | Mode 0   | Simple input or output                      |
| Mode 0  | Mode 1   | Output with handshaking                     |
| Mode 1  | Mode 1   | Input with handshaking                      |
| Mode 2  | Mode 2   | Bidirectional I/O with handshaking          |
| Mode 3  | None     | Port pins individually assigned as controls |

\*Special case of Mode 3

Let us now look at the Z80 PIO modes in more detail.

**Output mode (Mode 0) allows Port A and/or Port B to be used as a conduit for transferring data to external logic.** Figure 7-18 illustrates timing for Mode 0. An output cycle is initiated when the CPU executes any Output instruction accessing the I/O port. The Z80 PIO does not receive the WR pulse from the CPU, therefore it derives an equivalent signal by ANDing RD • CE • C/D • T0Q.

This pseudo write pulse (WR\* in Figure 7-18) is used to strobe data off the Data Bus and into the addressed I/O port's Output register. After the pseudo write pulse goes high, on the next high-to-low transition of the clock pulse  $\Phi$ , the RDY control signal is output high to external logic. RDY remains high until external logic returns a low pulse on the STB acknowledge. On the following high-to-low clock pulse  $\Phi$  transition, RDY returns low. The low-to-high STB transition also generates an interrupt request.



Figure 7-18. Mode 0 (Output) Timing

The RDY and  $\overline{STB}$  signal transition logic has been designed to let RDY create  $\overline{STB}$ . If you connect these two signals, the RDY low-to-high transition becomes the  $\overline{STB}$  low-to-high transition and RDY is strobed high for one clock pulse only. This may be illustrated as follows:



**Timing for input mode (Mode 1) is illustrated in Figure 7-19.** External logic initiates an input cycle by pulsing  $\overline{STB}$  low. This low pulse causes the Z80 PIO to load data from the I/O port pins into the port Input register. On the rising edge of the  $\overline{STB}$  pulse an interrupt request will be triggered.

On the falling edge of the  $\Phi$  clock pulse which follows  $\overline{STB}$  input high, RDY will be output low informing external logic that its data has been received but has not yet been read. RDY will remain low until the CPU has read the data, at which time RDY will be returned high.

**It is up to external logic to ensure that data is not input to the Z80 PIO while RDY is low.** If external logic does input data to the Z80 PIO while RDY is low, then the previous data will be overwritten and lost — and no error status will be reported.

**In bidirectional mode (Mode 2), the control lines supporting I/O Ports A and B are both applied to bidirectional data being transferred via Port A; Port B must be set to bit control (Mode 3).**

Figure 7-20 illustrates timing for bidirectional data transfers. This figure is simply a combination of Figures 7-18 and 7-19 where the A control lines apply to data output while the B control lines apply to data input. The only unique feature of Figure 7-20 is that bidirectional data being output via Port A is stable only for the duration of the A  $\overline{STB}$  low pulse. This is necessary in bidirectional mode since the Port A pins must be ready to receive input data as soon as the output operation has been completed.

Once again, it is up to external logic to make sure that it conforms with the timing requirements of bidirectional mode operation. External logic must read output data while A  $\overline{STB}$  is low. If external logic does not read data at this time, the data will not be read and the Z80 PIO will not report an error status to the CPU; there is no signal that external logic sends back to the Z80 PIO following a successful read.

Also, it is up to external logic to make sure that it transmits data to Port A only while B RDY is high and A RDY is low. If external logic tries to input data while the Z80 PIO is outputting data, input data will not be accepted. If external logic tries to input data before previously input data has been read, the previously input data will be lost and no error status will be reported.



Figure 7-19. Mode 1 (Input) Timing



Figure 7-20. Port A, Mode 2 (Bidirectional) Timing

**Control mode (Mode 3) does not use control signals. You must define every pin of an I/O port in Mode 3 as an input or an output pin.** The section on programming the Z80 PIO explains how to do this. Timing associated with the actual transfer of data at a single pin is as illustrated in Figures 7-18 and 7-19, ignoring the RDY and STB signals. If all the pins of a single port are defined in the same direction, then that port can be used for simple parallel input or output (without handshaking).

## Z80 PIO INTERRUPT SERVICING

The Z80 PIO has a single interrupt request line via which it transmits interrupt requests to the CPU.

**An interrupt request can originate from I/O Port A logic, or from I/O Port B logic. In the case of simultaneous interrupt requests, I/O Port A logic has higher priority.**

An interrupt request may be created in one of two ways. We have already seen in our discussion of Modes 0, 1 and 2 that appropriate control signal transitions will activate the interrupt request line; that is the first way in which an interrupt request may occur. In Mode 3 you can program either I/O port to generate an interrupt request based on the status of signals at individual I/O port pins; you can specify which I/O port pins will contribute to interrupt request logic and what the pin states must be for the interrupt request to occur. In a microcomputer system that has more than one Z80 PIO, interrupt priorities are arbitrated using daisy chain logic as we have already described. But there is a significant difference between priority arbitration within a Z80 system as compared to typical priority arbitration. Figure 7-21 illustrates interrupt acknowledge timing.



Figure 7-21. Interrupt Acknowledge Timing

**The Z80 PIO requires the CPU to execute an RETI instruction upon concluding an interrupt service routine.** Following an interrupt, an acknowledged Z80 PIO continuously scans the Data Bus whenever  $\overline{M1}$  is pulsed low. Until an RETI instruction's object code is detected, the acknowledged Z80 PIO will continuously output IEO low, thus disabling all lower priority Z80 PIOs. As soon as an RETI instruction's object code is detected on the Data Bus, the Z80 PIO will output IEO high, thus enabling lower priority Z80 PIOs. What this means is that interrupt priorities extend to the interrupt service routine as well as the interrupt request arbitration logic. Once an interrupt has been acknowledged, all lower priority interrupt requests will be denied until the acknowledged interrupt service routine has completed execution and has executed an RETI instruction. However, higher priority interrupts can be acknowledged and in turn interrupt an executing service routine. This is identical to the priority arbitration logic which we described for the 8259 PICU.

You can, if you wish, enable lower priority interrupts by executing an RETI instruction before an interrupt service routine has completed execution. But this requires that you execute an RETI instruction in order to return from a subroutine within the interrupted service routine. This instruction sequence may be illustrated as follows:

:START OF INTERRUPT SERVICE ROUTINE

```

CALL    ENABLE      ;ENABLE ALL INTERRUPTS AT PIO DEVICES
;
;
RET          ;END OF INTERRUPT SERVICE ROUTINE
ENABLE RETI

```

If you simply executed an RETI instruction shortly after entering an interrupt service routine, you would make a hasty exit from the routine — before completing the tasks that have to be performed in response to the acknowledged interrupt.

## PROGRAMMING THE Z80 PIO

You program the Z80 PIO by outputting a series of commands.

Let us start by identifying command format.

If the 0 bit of a command is low, then the receiving I/O port logic will interpret the command as an interrupt vector, with which it must respond to an interrupt acknowledge, assuming that the CPU is operating in interrupt Mode 2:



Do not confuse CPU interrupt modes with I/O port modes; they have nothing in common.

**In order to define an I/O port's mode you must output a Control code to the I/O port's Control buffer. This is the Control code format:**



Observe that the same address, the I/O Port A or B Control buffer address, is used when outputting a Control code, an interrupt vector, or a mode select. The low-order four bits of the Control code determine the way in which the Control code will be interpreted. **The following Control code will enable or disable interrupts:**



If a Mode Select Control code is output specifying that an I/O port will operate in Mode 3, then the next byte output is assumed to be a pin direction mask. 1 identifies an input pin, whereas 0 identifies an output pin. Here is a sample instruction sequence:

```

LD      C,(PORTAC)    :LOAD PORT A CONTROL ADDRESS INTO REGISTER C
LD      A,0CFH        :LOAD MODE 3 SELECT INTO ACCUMULATOR
OUT     (C),A         :OUTPUT TO PORT A CONTROL REGISTER
LD      A,3AH         :DEFINE PINS 5, 4, 3 AND 1 AS INPUTS,
OUT     (C),A         :PINS 7, 6, 2 AND 0 AS OUTPUTS

```

If you set an I/O port to Mode 3, then you can define the conditions which will cause an interrupt request; you do this by outputting the following interrupt Control code:



When you output an interrupt Control code, as illustrated above, if bit 4 is 1, Z80 PIO logic will assume that the next Control code output is an interrupt mask. An interrupt mask selects the pins that will contribute to interrupt request logic. A 0 bit selects a pin, while a 1 bit deselects the pin.

Combining the various Control codes that have been described we can now illustrate a typical sequence of instructions for accessing a Z80 PIO. Assume that PIO I/O port addresses are:

|                |   |
|----------------|---|
| Port A data    | 4 |
| Port A command | 5 |
| Port B data    | 6 |
| Port B command | 7 |

We are going to set I/O Port B to Mode 3, with an interrupt request triggered by either pin 6, 3 or 2 high. Pins 6, 3, 2 and 1 will be input pins, while pins 7, 5, 4 and 0 are outputs. The Port B interrupt vector will be 04. Port A will be a bidirectional I/O port with an interrupt vector of 02. Here is the initialization instruction sequence:

```
LD    A,8FH      ;SET PORT A TO MODE 2
OUT   (5),A
LD    A,2      ;OUTPUT INTERRUPT VECTOR
OUT   (5),A
LD    C,7      ;SET PORT B ADDRESS IN C
LD    A,0CFH     ;SET PORT B TO MODE 3
OUT   (C),A
LD    A,4EH      ;OUTPUT PIN DIRECTION MASK
OUT   (C),A
LD    A,4      ;OUTPUT INTERRUPT VECTOR
OUT   (C),A
LD    A,0B7H     ;OUTPUT INTERRUPT CONTROL WORD
OUT   (C),A
LD    A,0B3H     ;OUTPUT INTERRUPT MASK
OUT   (C),A
```

## THE Z80 CLOCK TIMER CIRCUIT (CTC)

**The Z80 Clock Timer Circuit is a programmable device which contains four sets of timing logic. Each set of timing logic can be programmed independently as an interval timer or an external event counter.**

The master Z80 system clock is used by interval timer logic. A time out may be identified by an interrupt request.

An external signal is used to trigger decrement logic when the timer is functioning as an event counter. An interrupt may be requested when the predetermined number of events count out.

**If you compare the Z80 CTC with the 8253 Counter/Timer** described in Chapter 4, **you will see that the Z80 CTC has four sets of counter/timer logic as compared to the three sets of the 8253;** however the 8253 has more programmable options. In addition to functioning as an event counter or an interval timer, the 8253 can be programmed to generate a variety of square waves and pulse output signals.

**The Z80 CTC is fabricated using N-channel depletion load technology. It is packaged as a 28-pin DIP. All pins are TTL-level compatible.**

### Z80 CTC FUNCTIONAL ORGANIZATION

Before we examine pins, signals, and operating characteristics of the Z80 CTC in detail, let us take an overall look at device logic.

There are four counter/timer logic elements in a Z80 CTC; each is referred to as a "channel".

Each of the four counter/timer channels may be visualized as consisting of three 8-bit registers and two control signals. This may be illustrated as follows:



An initial counter or timer constant is loaded into the Time Constant register. The value in the Time Constant register is maintained unaltered until you write a new value into this register.

The initial Timer Constant is loaded into the Down Counter register at the beginning of a counter or timer operation; the contents of the Down Counter register are decremented. You can at any time read the contents of the Down Counter register in order to determine how far a time interval or event counting sequence has progressed.

The Channel Control register contains a Control code which defines the channel's programmable options. There are four Control registers, one for each of the four channels. Thus one channel's operations in no way influence operations for any other channel.

There is an Interrupt Vector register which is addressed as though it were part of channel 0 logic. This register contains the address which is transmitted by the Z80 CTC upon receiving an interrupt acknowledge. The Z80 CTC assumes that the Z80 CPU is operating in Interrupt mode 2 — in which mode the device requesting an interrupt responds to an acknowledge by providing the second byte of a subroutine address which the CPU will Call. For details refer to our earlier discussion of the Z80 CPU.

## Z80 CTC PINS AND SIGNALS

Z80 CTC pins and signals are illustrated in Figure 7-22.

D0 - D7 is the bidirectional Data Bus via which parallel data is transferred between the CPU and any register of the Z80 CTC.

**CE** is the master chip select signal for the Z80 CTC. This signal must be low for the device to be selected.

While  $\overline{CE}$  is low, **CS0** and **CS1** are used to select one of the four counter/timer logic channels as follows:

| CS1 | CS0 | Channel |
|-----|-----|---------|
| 0   | 0   | 0       |
| 0   | 1   | 1       |
| 1   | 0   | 2       |
| 1   | 1   | 3       |



Figure 7-22. Z80-CTC Signals and Pin Assignments

CS0 and CS1 select registers associated with counter/timer logic, to be accessed by read and write operations. The actual register which will be accessed is determined as follows:



As the illustration above would imply, the Down Counter register is the only location of any channel whose contents can be read. All other registers are write only locations.

When you write to a channel, bits 0 and 2 of the data byte being written determine the data destination as follows:

- 1) If bit 0 is 0 and you are selecting channel 0, then the data is written to the Interrupt Vector register.
- 2) If bit 0 is 0 and you select channel 1, 2 or 3, the data destination is undefined.
- 3) If bit 0 is 1, then on the first access of any channel the data will be written to the Channel Control register.
- 4) If within the data byte written to a Channel Control register bit 0 is 1 and bit 2 is 0, then the next data byte written to this channel will be loaded into the Time Constant register, irrespective of whether bit 0 is 0 or 1. The data written will be interpreted as a time constant; select logic will immediately revert to selecting the Channel Control register or the Interrupt Vector register on the next write, depending on the condition of bit 0 of the next data byte.

**M1, IORQ and RD** are three control signals input to the Z80 CTC. Combinations of these three control signals **control logic within the Z80 CTC, as described for the Z80 PIO**. An exception is the device Reset. The Z80 CTC has its own **RESET** input. The PIO decodes a Reset when **M1** is low while **IORQ** and **RD** are high. With the exception of the RESET function, Table 7-4 defines the manner in which the Z80 CTC interprets **M1, IORQ, and RD** signals.

**Interrupt logic has three associated signals: IEI, IEO and INT.** These signals operate exactly as described for the Z80 PIO.

The Z80 CTC requests an interrupt with a low **INT** output.

**IEI** and **IEO** are used to implement daisy chain priority interrupt logic as described for the PIO.

**Each of the four counter/timer channels has a CLK/TRG input control.** This signal can be used to trigger timer logic; it is also used as a decrement control by counter logic.

Counter/timer logic channels 0, 1 and 2 have a ZC/TO output. This signal is pulsed high on a time out or a count out.

**When a low input is applied to the RESET pin, the Z80 CTC is reset.** At this time all counter/timer logic is stopped. **INT** is output high, **IEO** is output at the **IEI** level and the Data Bus is floated. Register contents are not cleared during a reset.

## Z80 CTC OPERATING MODES

The Z80 CTC is accessed by the CPU as four I/O ports or four memory locations. Timing for any CTC access conforms to descriptions given earlier in this chapter for the CPU.

Let us begin by looking at a counter/timer operating as a timer.

Using an appropriate Control code (described later) you select Timer mode for the channel and specify that an initial time constant is to follow.

You load an initial constant into the Time Constant register, after which timer operations begin.

You have the option of using the CLK/TRG input to start the timer, in which case timer logic is initiated by external logic. The alternative is to initiate the timer under program control, in which case the timer starts on the clock pulse following the Time Constant register being loaded.

When timer operations begin, the Time Constant register contents are transmitted to the Down Counter register. The Down Counter register contents are decremented on every 16th system clock pulse, or on every 256th system clock pulse. You make the selection via the Control code. Assuming a 500 nanosecond clock, therefore, the timer will decrement the Down Counter register contents every 8 microseconds, or every 128 microseconds.

When timer logic decrements the Down Counter register contents from 1 to 0 a time out occurs. At this time ZC/TO is pulsed high, the Time Constant register contents are reloaded into the Down Counter register and timer logic starts again. Thus timer logic is free running; once started, the timer will run continuously until stopped by an appropriate Control code.

Here is a timing example for a timer started under program control and decrementing the Down Counter register on every 16th clock pulse:



Here is a timing example for a timer whose operations are initiated by CLK/TRG, where the Down Counter register contents are decremented on every 256th clock pulse:



Observe that every time out is marked by a ZC/TO high pulse. INT is also output low providing interrupt logic is enabled at the channel.

In the illustration above CLK/TRG is shown as a high true signal. You can specify CLK/TRG as a low true signal via the Channel Control code; the timer will be initiated as follows:



For exact timing requirements see the data sheets at the end of this chapter.

You can at any time write new data into the Time Constant register. If you do this while the timer is running, nothing happens until the next time out; at that time the new Time Constant register contents will be transferred to the Down Counter register and subsequent time intervals will be computed based on the new Time Constant register contents.

If you are unfortunate enough to output data to the Time Constant register while a time out is in progress and the Time Constant register contents are being transferred to the Down Counter register, then an undefined value will be loaded into the Down Counter register; however, following the next time out the new value in the Time Constant register will apply; that is to say, there will only be one undefined time interval.

#### **Let us now look at a counter/timer operating as a counter.**

Using an appropriate Control code (described later) you select Counter mode for the channel and specify that an initial time constant is to follow.

You load an initial constant into the Time Constant register, after which counter operations begin.

When counter operations begin, the Time Constant register contents are transmitted to the Down Counter register. The Down Counter register contents are decremented every time the CLK/TRG input makes an active transition. Counter logic begins on the first active transition of CLK/TRG following data being loaded into the Time Constant register. The active transition of CLK/TRG may be selected under program control as low-to-high or high-to-low.

When counter logic decrements the Down Counter register contents from 1 to 0, a count out occurs. At this time the ZC/TO signal is pulsed high; an interrupt request occurs, providing the channel's interrupt logic has been enabled. The Time Constant register contents are reloaded into the Down Counter register and counter operations begin again. That is to say, counter logic is free running and will continue to re-execute until specifically stopped by an appropriate Control code. Counter logic timing may be illustrated as follows:



## Z80 CTC INTERRUPT LOGIC

Every Z80 CTC channel has its own interrupt logic. A channel's interrupt logic generates an interrupt request when the channel counts out or times out. All interrupt requests are transmitted to the CPU via the  $\overline{INT}$  output. This is true if one, or more than one channel is requesting an interrupt. If more than one channel is requesting an interrupt, then priorities are arbitrated as follows:

|                  |           |
|------------------|-----------|
| Highest Priority | Channel 0 |
|                  | Channel 1 |
|                  | Channel 2 |
| Lowest Priority  | Channel 3 |

Every channel's interrupt logic can be individually enabled or disabled under program control.

**The Z80 CTC device's overall interrupt logic is identical to that which we have already described for the Z80 PIO.**

The interrupt request is transmitted to the CPU via a low  $\overline{INT}$  signal.

The CPU acknowledges the interrupt by outputting  $\overline{M1}$  and  $\overline{IORQ}$  low as illustrated in the data sheets at the end of this chapter.

The device requesting an interrupt which is highest in the daisy chain acknowledges the interrupt. Presuming this is a Z80 CTC, the CTC places its interrupt vector on the Data Bus; it is assumed that the CPU is operating in Interrupt mode 2. The Z80 CTC immediately outputs IEO low, disabling all devices below it in the daisy chain.

When an RETI instruction is executed, Z80 CTC logic sets IEO high again.

For more information on Z80 interrupt logic refer to discussions of this subject given earlier in the chapter for the Z80 CPU and the PIO.

## PROGRAMMING THE Z80 CTC

These are the steps required to program a Z80 CTC:

- 1) Output an interrupt vector once, when initializing the Z80 CTC.
- 2) For each active counter/timer channel, output one or more Control codes. Control codes are used initially to set counter/timer operating conditions and to load the Time Constant register. Subsequently Control codes are used to start and stop the counter/timer, or to change the initial time constant.

The interrupt vector is written to a counter/timer by outputting a byte of data to counter/timer channel 0 with a 0 in the low order bit. The interrupt vector may be illustrated as follows:



The Control code which must be output to each active channel will be interpreted as illustrated in Figure 7-23.



Figure 7-23. Z80 CTC Control Code Interpretation

Bit 0 must be 1 to identify the data as a Control code. If bit 0 is 0, then the data is interpreted as an interrupt vector — providing Channel 0 is addressed; the data is undefined otherwise.

Bit 1 is used to stop the channel when it is running. If bit 1 is 0, then every time the channel times out the Down Counter register is immediately reloaded from the Time Constant register contents and channel operations restart according to current options. If bit 1 is 1, the channel stops immediately; the ZC/TO output is inactive and channel interrupt logic is disabled. The channel must be restarted by outputting a new Control code.

Bit 2 is used to output time constants. If bit 2 is 1, then the next data output to the channel will be interpreted as a time constant. If bit 2 is 0, then the next data output to the channel will be interpreted as another Control code, or an interrupt vector, depending on the bit 0 value.

Bit 3 applies to Timer mode only; assuming that the timer is not running, it determines whether timer operations will be initiated by the system clock signal  $\Phi$ , or by CLK/TRG.

If bit 3 is 0 then timer operations are initiated by system clock signal  $\Phi$ ; the timer will start on the next leading edge of  $\Phi$ , unless the current Control code specifies (via bit 2) that a new time constant is to be output, in which case the timer will start on the rising edge of  $\Phi$  which immediately follows output of the time constant. Timing for these two cases has been illustrated earlier.

If bit 3 is 1, then the active transition of the CLK/TRG signal initiates the timer. Once again, if bit 2 of the current Control code specifies that a new time constant is to be output then timer logic cannot be started until this new time constant has been output. Timing has been illustrated earlier.

Bit 4 determines whether the low-to-high or the high-to-low transition of CLK/TRG is active. Assuming that bit 6 has specified Timer mode and bit 3 has specified the timer will be triggered externally by CLK/TRG, the active transition of CLK/TRG starts the timer. If bit 6 is not 0 or bit 3 is not 1, then the active transition of CLK/TRG decrements the counter.

If bit 4 specifies that a low-to-high transition of CLK/TRG will be active then CLK/TRG may be illustrated as follows:



If bit 4 specifies that the high-to-low transition of CLK/TRG will be active then CLK/TRG may be illustrated as follows:



Bit 5 applies to Timer mode only. If bit 5 is 0, Down Counter register contents will be decremented every 16th system clock pulse ( $\Phi$ ). If bit 5 is 1, the Down Counter register contents will be decremented every 256th system clock pulse ( $\Phi$ ).

Bit 6 determines whether the channel will be operated as a counter or a timer. If bit 6 is 0, Timer mode is selected; Counter mode is selected if bit 6 is 1.

Bit 7 is an interrupt enable/disable flag. If 0, the channel's interrupt logic is disabled; if 1, the channel's interrupt logic is enabled.

**Let us now look at the programming example. Here are the assumed operating conditions for the Z80 CTC:**

- 1) Channel 0 is operating as a counter with an initial time constant of  $80_{16}$  and interrupt logic enabled.
- 2) Channel 1 is operating as a timer. It decrements on every 16th system clock pulse and has an initial time constant of  $40_{16}$ ; its interrupts are disabled and CLK/TRG starts the timer on its low-to-high transition.
- 3) Channel 2 is operating as a timer. It decrements every 256th system clock pulse and has an initial time constant of  $C8_{16}$ ; its interrupts are enabled and the system clock starts the timer.
- 4) Channel 3 is inactive.

The CPU is operating with interrupt logic in Mode 2. CTC interrupt service routine starting addresses are stored at memory locations  $2C40_{16}$ ,  $2C42_{16}$  and  $2C44_{16}$ . The CTC is accessed as I/O ports  $B8_{16}$ ,  $B9_{16}$ ,  $BA_{16}$ , and  $BB_{16}$ .

**Here is the appropriate CTC initiation instruction sequence:**

```
LD    A,2CH      ;LOAD INTERRUPT VECTOR REGISTER OF CPU
LD    I,A
IM    2          ;SELECT CPU INTERRUPT MODE 2
LD    A,40H      ;OUTPUT INTERRUPT VECTOR TO
OUT   (0B8H),A   ;CHANNEL 0

:START CHANNEL 0
LD    A,0C5H     ;OUTPUT THE CONTROL CODE TO CHANNEL 0
OUT  (0B8H),A
LD    A,80H      ;OUTPUT THE INITIAL COUNT TO CHANNEL 0
OUT  (0B8H),A   ;CHANNEL 0 BEGINS OPERATING.

:START CHANNEL 1
LD    A,1DH      ;OUTPUT THE CONTROL CODE TO CHANNEL 1
OUT  (0B9H),A
LD    A,40H      ;OUTPUT THE INITIAL TIMER CONSTANT TO CHANNEL1
OUT  (0B9H),A   ;CHANNEL 1 BEGINS OPERATING. (IF TRANSITION OCCURS)

:START CHANNEL 2
LD    A,0A5H     ;OUTPUT THE CONTROL CODE TO CHANNEL 2
OUT  (0BAH),A
LD    A,0C8H     ;OUTPUT THE INITIAL TIMER CONSTANT TO CHANNEL 2
OUT  (0BAH),A   ;CHANNEL 2 BEGINS OPERATING
```

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

Z80 and Z80A CPU

Z80 and Z80A PIO

Z80 and Z80A CTC

## Z80-CPU Absolute Maximum Ratings

|                                              |                            |
|----------------------------------------------|----------------------------|
| Temperature Under Bias                       | Specified operating range. |
| Storage Temperature                          | -65°C to +150°C            |
| Voltage On Any Pin<br>with Respect to Ground | -0.3V to +7V               |
| Power Dissipation                            | 1.5W                       |

\*Comment  
Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Note: For Z80-CPU all AC and DC characteristics remain the same for the military grade parts except  $I_{CC}$ .

$$I_{CC} = 200 \text{ mA}$$

## Z80-CPU D.C. Characteristics

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = 5V \pm 5\%$  unless otherwise specified

| Symbol    | Parameter                                 | Min.          | Typ. | Max.          | Unit          | Test Condition              |
|-----------|-------------------------------------------|---------------|------|---------------|---------------|-----------------------------|
| $V_{ILC}$ | Clock Input Low Voltage                   | -0.3          |      | 0.45          | V             |                             |
| $V_{IHC}$ | Clock Input High Voltage                  | $V_{CC} - .6$ |      | $V_{CC} + .3$ | V             |                             |
| $V_{IL}$  | Input Low Voltage                         | -0.3          |      | 0.8           | V             |                             |
| $V_{IH}$  | Input High Voltage                        | 2.0           |      | $V_{CC}$      | V             |                             |
| $V_{OL}$  | Output Low Voltage                        |               |      | 0.4           | V             | $I_{OL} = 1.8 \text{ mA}$   |
| $V_{OH}$  | Output High Voltage                       | 2.4           |      |               | V             | $I_{OH} = -250 \mu\text{A}$ |
| $I_{CC}$  | Power Supply Current                      |               |      | 150           | mA            |                             |
| $I_{LI}$  | Input Leakage Current                     |               |      | 10            | $\mu\text{A}$ | $V_{IN} = 0$ to $V_{CC}$    |
| $I_{LOH}$ | Tri-State Output Leakage Current in Float |               |      | 10            | $\mu\text{A}$ | $V_{OUT} = 2.4$ to $V_{CC}$ |
| $I_{LOL}$ | Tri-State Output Leakage Current in Float |               |      | -10           | $\mu\text{A}$ | $V_{OUT} = 0.4V$            |
| $I_{LD}$  | Data Bus Leakage Current in Input Mode    |               |      | $\pm 10$      | $\mu\text{A}$ | $0 \leq V_{IN} \leq V_{CC}$ |

## Capacitance

$T_A = 25^\circ\text{C}$ ,  $f = 1 \text{ MHz}$ ,  
unmeasured pins returned to ground

| Symbol    | Parameter          | Max. | Unit |
|-----------|--------------------|------|------|
| $C_\Phi$  | Clock Capacitance  | 35   | pF   |
| $C_{IN}$  | Input Capacitance  | 5    | pF   |
| $C_{OUT}$ | Output Capacitance | 10   | pF   |

## Z80A-CPU D.C. Characteristics

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = 5V \pm 5\%$  unless otherwise specified

| Symbol    | Parameter                                 | Min.          | Typ. | Max.          | Unit          | Test Condition              |
|-----------|-------------------------------------------|---------------|------|---------------|---------------|-----------------------------|
| $V_{ILC}$ | Clock Input Low Voltage                   | -0.3          |      | 0.45          | V             |                             |
| $V_{IHC}$ | Clock Input High Voltage                  | $V_{CC} - .6$ |      | $V_{CC} + .3$ | V             |                             |
| $V_{IL}$  | Input Low Voltage                         | -0.3          |      | 0.8           | V             |                             |
| $V_{IH}$  | Input High Voltage                        | 2.0           |      | $V_{CC}$      | V             |                             |
| $V_{OL}$  | Output Low Voltage                        |               |      | 0.4           | V             | $I_{OL} = 1.8 \text{ mA}$   |
| $V_{OH}$  | Output High Voltage                       | 2.4           |      |               | V             | $I_{OH} = -250 \mu\text{A}$ |
| $I_{CC}$  | Power Supply Current                      |               | 90   | 200           | mA            |                             |
| $I_{LI}$  | Input Leakage Current                     |               |      | 10            | $\mu\text{A}$ | $V_{IN} = 0$ to $V_{CC}$    |
| $I_{LOH}$ | Tri-State Output Leakage Current in Float |               |      | 10            | $\mu\text{A}$ | $V_{OUT} = 2.4$ to $V_{CC}$ |
| $I_{LOL}$ | Tri-State Output Leakage Current in Float |               |      | -10           | $\mu\text{A}$ | $V_{OUT} = 0.4V$            |
| $I_{LD}$  | Data Bus Leakage Current in Input Mode    |               |      | $\pm 10$      | $\mu\text{A}$ | $0 \leq V_{IN} \leq V_{CC}$ |

## Capacitance

$T_A = 25^\circ\text{C}$ ,  $f = 1 \text{ MHz}$ ,  
unmeasured pins returned to ground

| Symbol    | Parameter          | Max. | Unit |
|-----------|--------------------|------|------|
| $C_\Phi$  | Clock Capacitance  | 35   | pF   |
| $C_{IN}$  | Input Capacitance  | 5    | pF   |
| $C_{OUT}$ | Output Capacitance | 10   | pF   |

## Z80A-CPU Ordering Information

C – Ceramic  
P – Plastic  
S – Standard  $5V \pm 5\% 0^\circ$  to  $70^\circ\text{C}$   
E – Extended  $5V \pm 5\% -40^\circ$  to  $85^\circ\text{C}$   
M – Military  $5V \pm 10\% -55^\circ$  to  $125^\circ\text{C}$

## Z80-CPU

## A.C. Characteristics

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = +5V \pm 5\%$ , Unless Otherwise Noted.

| Signal   | Symbol                                   | Parameter                                                | Min   | Max  | Unit            | Test Condition      |
|----------|------------------------------------------|----------------------------------------------------------|-------|------|-----------------|---------------------|
| $\Phi$   | $t_C$                                    | Clock Period                                             | -4    | {12} | $\mu\text{sec}$ |                     |
|          | $t_W(\Phi H)$                            | Clock Pulse Width, Clock High                            | 180   | {1E} | nsec            |                     |
|          | $t_W(\Phi L)$                            | Clock Pulse Width, Clock Low                             | 180   | 2000 | nsec            |                     |
|          | $t_{R,F}$                                | Clock Rise and Fall Time                                 |       | 30   | nsec            |                     |
| $A_0-15$ | $t_D(D)$                                 | Address Output Delay                                     |       | 145  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_F(D)$                                 | Delay to Float                                           |       | 110  | nsec            |                     |
|          | $t_{ACM}$                                | Address Stable Prior to MREQ (Memory Cycle)              | {111} |      | nsec            |                     |
|          | $t_{DCM}$                                | Address Stable Prior to IORQ, RD or WR (I/O Cycle)       | {121} |      | nsec            |                     |
|          | $t_{ACI}$                                | Address Stable From RD, WR, IORQ or MREQ                 | {131} |      | nsec            |                     |
|          | $t_{CAF}$                                | Address Stable From RD or WR During Float                | {141} |      | nsec            |                     |
| $D_0-7$  | $t_D(D)$                                 | Data Output Delay                                        |       | 230  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_F(D)$                                 | Delay to Float During Write Cycle                        |       | 90   | nsec            |                     |
|          | $t_{S\Phi}(D)$                           | Data Setup Time to Rising Edge of Clock During M1 Cycle  | 50    |      | nsec            |                     |
|          | $t_{S\Phi}(D)$                           | Data Setup Time to Falling Edge of Clock During M2 to M3 | 60    |      | nsec            |                     |
|          | $t_{DCM}$                                | Data Stable Prior to WR (Memory Cycle)                   | {151} |      | nsec            |                     |
|          | $t_{DCI}$                                | Data Stable Prior to WR (I/O Cycle)                      | {161} |      | nsec            |                     |
|          | $t_{CDF}$                                | Data Stable From WR                                      | {171} |      | nsec            |                     |
|          | $t_H$                                    | Any Hold Time for Setup Time                             | 0     |      | nsec            |                     |
| $MREQ$   | $t_{DL\Phi}(MREQ)$                       | MREQ Delay From Falling Edge of Clock, MREQ Low          |       | 100  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DH\Phi}(MREQ)$                       | MREQ Delay From Rising Edge of Clock, MREQ High          |       | 100  | nsec            |                     |
|          | $t_{DH\Phi}(MREQ)$                       | MREQ Delay From Falling Edge of Clock, MREQ' High        |       | 100  | nsec            |                     |
|          | $t_W(MRL)$                               | Pulse Width, MREQ Low                                    | {181} |      | nsec            |                     |
|          | $t_W(MRH)$                               | Pulse Width, MREQ High                                   | {191} |      | nsec            |                     |
| $IORQ$   | $t_{DL\Phi}(IR)$                         | IORQ Delay From Rising Edge of Clock, IORQ Low           |       | 90   | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DL\Phi}(IR)$                         | IORQ Delay From Falling Edge of Clock, IORQ Low          |       | 110  | nsec            |                     |
|          | $t_{DH\Phi}(IR)$                         | IORQ Delay From Rising Edge of Clock, IORQ High          |       | 100  | nsec            |                     |
|          | $t_{DH\Phi}(IR)$                         | IORQ Delay From Falling Edge of Clock, IORQ High         |       | 110  | nsec            |                     |
| $RD$     | $t_{DL\Phi}(RD)$                         | RD Delay From Rising Edge of Clock, RD Low               |       | 100  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DL\Phi}(RD)$                         | RD Delay From Falling Edge of Clock, RD Low              |       | 130  | nsec            |                     |
|          | $t_{DH\Phi}(RD)$                         | RD Delay From Rising Edge of Clock, RD High              |       | 100  | nsec            |                     |
|          | $t_{DH\Phi}(RD)$                         | RD Delay From Falling Edge of Clock, RD High             |       | 110  | nsec            |                     |
| $WR$     | $t_{DL\Phi}(WR)$                         | WR Delay From Rising Edge of Clock, WR Low               |       | 80   | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DL\Phi}(WR)$                         | WR Delay From Falling Edge of Clock, WR Low              |       | 90   | nsec            |                     |
|          | $t_{DH\Phi}(WR)$                         | WR Delay From Falling Edge of Clock, WR High             |       | 100  | nsec            |                     |
|          | $t_W(WRL)$                               | Pulse Width, WR Low                                      | {101} |      | nsec            |                     |
| $M1$     | $t_{DL}(M1)$                             | M1 Delay From Rising Edge of Clock, M1 Low               |       | 130  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DH}(M1)$                             | M1 Delay From Rising Edge of Clock, M1 High              |       | 130  | nsec            |                     |
| $RFSH$   | $t_{DL}(RF)$                             | RFSH Delay From Rising Edge of Clock, RFSH Low           |       | 180  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DH}(RF)$                             | RFSH Delay From Rising Edge of Clock, RFSH High          |       | 150  | nsec            |                     |
| $WAIT$   | $t_s(WT)$                                | WAIT Setup Time to Falling Edge of Clock                 | 70    |      | nsec            |                     |
| $HALT$   | $t_D(HALT)$                              | HALT Delay Time From Falling Edge of Clock               |       | 300  | nsec            | $C_L = 50\text{pF}$ |
| $INT$    | $t_s(IT)$                                | INT Setup Time to Rising Edge of Clock                   | 80    |      | nsec            |                     |
| $NMI$    | $t_W(NML)$                               | Pulse Width, NMI Low                                     | 80    |      | nsec            |                     |
| $BUSRQ$  | $t_s(BQ)$                                | BUSRQ Setup Time to Rising Edge of Clock                 | 80    |      | nsec            |                     |
| $BUSAK$  | $t_{DL}(BA)$                             | BUSAK Delay From Rising Edge of Clock, BUSAK Low         |       | 120  | nsec            | $C_L = 50\text{pF}$ |
|          | $t_{DH}(BA)$                             | BUSAK Delay From Falling Edge of Clock, BUSAK High       |       | 110  | nsec            |                     |
| $RESET$  | $t_s(RS)$                                | RESET Setup Time to Rising Edge of Clock                 | 90    |      | nsec            |                     |
| $t_F(C)$ | Delay to Float (MREQ, IORQ, RD and WR)   |                                                          |       | 100  | nsec            |                     |
| $t_{MR}$ | M1 Stable Prior to IORQ (Interrupt Ack.) |                                                          | {111} |      | nsec            |                     |

## NOTES:

- A. Data should be enabled onto the CPU data bus when  $\overline{RD}$  is active. During interrupt acknowledge data should be enabled when  $M1$  and  $IORQ$  are both active.
- B. All control signals are internally synchronized, so they may be totally asynchronous with respect to the clock.
- C. The RESET signal must be active for a minimum of 3 clock cycles.
- D. Output Delay vs. Loaded Capacitance  
 $T_A = 70^\circ\text{C}$     $V_{CC} = +5V \pm 5\%$   
 Add 10nsec delay for each 50pf increase in load up to a maximum of 200pf for the data bus & 100pf for address & control lines
- E. Although static by design, testing guarantees  $t_{W(\Phi H)}$  of 200  $\mu\text{sec}$  maximum



# Z80A-CPU

## A.C. Characteristics

$T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = +5V \pm 5\%$ , Unless Otherwise Noted.

| Signal     | Symbol                                                                                                                                    | Parameter                                                                                                                                                                                                                                                                             | Min                              | Max                                        | Unit                                                 | Test Condition      |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------|------------------------------------------------------|---------------------|
| $\Phi$     | $t_c$<br>$t_w(\Phi H)$<br>$t_w(\Phi L)$<br>$t_r, t_f$                                                                                     | Clock Period<br>Clock Pulse Width, Clock High<br>Clock Pulse Width, Clock Low<br>Clock Rise and Fall Time                                                                                                                                                                             | .25<br>110 [E]<br>110 2000<br>30 | [12]<br>nsec<br>nsec<br>nsec               | nsec                                                 |                     |
| $A_{0-15}$ | $t_D(\text{AD})$<br>$t_F(\text{AD})$<br>$t_{acm}$<br>$t_{aci}$<br>$t_{ca}$<br>$t_{caf}$                                                   | Address Output Delay<br>Delay to Float<br>Address Stable Prior to MREQ (Memory Cycle)<br>Address Stable Prior to IORQ, RD or WR (I/O Cycle)<br>Address Stable From RD, WR, IORQ or MREQ<br>Address Stable From RD or WR During Float                                                  |                                  | 110<br>90<br>[11]<br>[2]<br>[3]<br>[4]     | nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec         | $C_L = 50\text{pF}$ |
| $D_{0-7}$  | $t_D(D)$<br>$t_F(D)$<br>$t_{s0}(D)$<br>$t_{s0}(D)$<br>$t_{dcm}$<br>$t_{dci}$<br>$t_{cdf}$                                                 | Data Output Delay<br>Delay to Float During Write Cycle<br>Data Setup Time to Rising Edge of Clock During M1 Cycle<br>Data Setup Time to Falling Edge of Clock During M2 to M5<br>Data Stable Prior to WR (Memory Cycle)<br>Data Stable Prior to WR (I/O Cycle)<br>Data Stable From WR |                                  | 150<br>90<br>35<br>50<br>[5]<br>[6]<br>[7] | nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | $C_L = 50\text{pF}$ |
|            | $t_H$                                                                                                                                     | Any Hold Time for Setup Time                                                                                                                                                                                                                                                          |                                  | 0                                          | nsec                                                 |                     |
| MREQ       | $t_{DL\bar{\Phi}}(\text{MR})$<br>$t_{DH\bar{\Phi}}(\text{MR})$<br>$t_{DH\bar{\Phi}}(\text{MR})$<br>$t_w(\text{MRL})$<br>$t_w(\text{MRH})$ | MREQ Delay From Falling Edge of Clock, MREQ Low<br>MREQ Delay From Rising Edge of Clock, MREQ High<br>MREQ Delay From Falling Edge of Clock, MREQ High<br>Pulse Width, MREQ Low<br>Pulse Width, MREQ High                                                                             |                                  | 85<br>85<br>85<br>[8]<br>[9]               | nsec<br>nsec<br>nsec<br>nsec<br>nsec                 | $C_L = 50\text{pF}$ |
| IORQ       | $t_{DL\bar{\Phi}}(\text{IR})$<br>$t_{DL\bar{\Phi}}(\text{IR})$<br>$t_{DH\bar{\Phi}}(\text{IR})$<br>$t_{DH\bar{\Phi}}(\text{IR})$          | IORQ Delay From Rising Edge of Clock, IORQ Low<br>IORQ Delay From Falling Edge of Clock, IORQ Low<br>IORQ Delay From Rising Edge of Clock, IORQ High<br>IORQ Delay From Falling Edge of Clock, IORQ High                                                                              |                                  | 75<br>85<br>85<br>85                       | nsec<br>nsec<br>nsec<br>nsec                         | $C_L = 50\text{pF}$ |
| RD         | $t_{DL\bar{\Phi}}(\text{RD})$<br>$t_{DL\bar{\Phi}}(\text{RD})$<br>$t_{DH\bar{\Phi}}(\text{RD})$<br>$t_{DH\bar{\Phi}}(\text{RD})$          | RD Delay From Rising Edge of Clock, RD Low<br>RD Delay From Falling Edge of Clock, RD Low<br>RD Delay From Rising Edge of Clock, RD High<br>RD Delay From Falling Edge of Clock, RD High                                                                                              |                                  | 85<br>95<br>85<br>85                       | nsec<br>nsec<br>nsec<br>nsec                         | $C_L = 50\text{pF}$ |
| WR         | $t_{DL\bar{\Phi}}(\text{WR})$<br>$t_{DL\bar{\Phi}}(\text{WR})$<br>$t_{DH\bar{\Phi}}(\text{WR})$<br>$t_w(\text{WRL})$                      | WR Delay From Rising Edge of Clock, WR Low<br>WR Delay From Falling Edge of Clock, WR Low<br>WR Delay From Falling Edge of Clock, WR High<br>Pulse Width, WR Low                                                                                                                      |                                  | 65<br>80<br>80<br>[10]                     | nsec<br>nsec<br>nsec<br>nsec                         | $C_L = 50\text{pF}$ |
| M1         | $t_{DL(\text{M1})}$<br>$t_{DH(\text{M1})}$                                                                                                | M1 Delay From Rising Edge of Clock, M1 Low<br>M1 Delay From Rising Edge of Clock, M1 High                                                                                                                                                                                             |                                  | 100<br>100                                 | nsec<br>nsec                                         | $C_L = 50\text{pF}$ |
| RFSH       | $t_{DL(\text{RF})}$<br>$t_{DH(\text{RF})}$                                                                                                | RFSH Delay From Rising Edge of Clock, RFSH Low<br>RFSH Delay From Rising Edge of Clock, RFSH High                                                                                                                                                                                     |                                  | 130<br>120                                 | nsec<br>nsec                                         | $C_L = 50\text{pF}$ |
| WAIT       | $t_s(\text{WT})$                                                                                                                          | WAIT Setup Time to Falling Edge of Clock                                                                                                                                                                                                                                              | 70                               |                                            | nsec                                                 |                     |
| HALT       | $t_D(\text{HT})$                                                                                                                          | HALT Delay Time From Falling Edge of Clock                                                                                                                                                                                                                                            | 300                              |                                            | nsec                                                 | $C_L = 50\text{pF}$ |
| INT        | $t_s(\text{IT})$                                                                                                                          | INT Setup Time to Rising Edge of Clock                                                                                                                                                                                                                                                | 80                               |                                            | nsec                                                 |                     |
| NMI        | $t_w(\text{NML})$                                                                                                                         | Pulse Width, NMI Low                                                                                                                                                                                                                                                                  | 80                               |                                            | nsec                                                 |                     |
| BUSRQ      | $t_s(\text{BQ})$                                                                                                                          | BUSRQ Setup Time to Rising Edge of Clock                                                                                                                                                                                                                                              | 50                               |                                            | nsec                                                 |                     |
| BUSAK      | $t_{DL(\text{BA})}$<br>$t_{DH(\text{BA})}$                                                                                                | BUSAK Delay From Rising Edge of Clock, BUSAK Low<br>BUSAK Delay From Falling Edge of Clock, BUSAK High                                                                                                                                                                                |                                  | 100<br>100                                 | nsec<br>nsec                                         | $C_L = 50\text{pF}$ |
| RESET      | $t_s(\text{RS})$                                                                                                                          | RESET Setup Time to Rising Edge of Clock                                                                                                                                                                                                                                              | 60                               |                                            | nsec                                                 |                     |
|            | $t_F(C)$                                                                                                                                  | Delay to Float (MREQ, IORQ, RD and WR)                                                                                                                                                                                                                                                |                                  | 80                                         | nsec                                                 |                     |
|            | $t_{mr}$                                                                                                                                  | M1 Stable Prior to IORQ (Interrupt Ack.)                                                                                                                                                                                                                                              | 1111                             |                                            | nsec                                                 |                     |

$$[12] t_c = t_w(\Phi H) + t_w(\Phi L) + t_r + t_f$$

$$[1] t_{acm} = t_w(\Phi H) + t_r - 65$$

$$[2] t_{aci} = t_c - 70$$

$$[3] t_{ca} = t_w(\Phi L) + t_r - 45$$

$$[4] t_{caf} = t_w(\Phi L) + t_r - 45$$

$$[5] t_{dcm} = t_c - 170$$

$$[6] t_{dci} = t_w(\Phi L) + t_r - 170$$

$$[7] t_{cdf} = t_w(\Phi L) + t_r - 70$$

$$[8] t_w(\text{MRL}) = t_c - 30$$

$$[9] t_w(\text{MRH}) = t_w(\Phi H) + t_r - 20$$

$$[10] t_w(\text{WRL}) = t_c - 30$$

$$[11] t_{mr} = 2t_c + t_w(\Phi H) + t_r - 65$$

### NOTES:

- A. Data should be enabled onto the CPU data bus when RD is active. During interrupt acknowledge data should be enabled when M1 and IORQ are both active.
- B. All control signals are internally synchronized, so they may be totally asynchronous with respect to the clock.
- C. The RESET signal must be active for a minimum of 3 clock cycles.
- D. Output Delay vs. Loaded Capacitance  
 $TA = 70^\circ\text{C}$     $Vcc = +5V \pm 5\%$   
 Add 10nsec delay for each 50pf increase in load up to maximum of 200pf for data bus and 100pf for address & control lines.
- E. Although static by design, testing guarantees  $t_w(\Phi H)$  of 200  $\mu\text{sec}$  maximum



Load circuit for Output

Z80-CPU

## A.C. Timing Diagram

Timing measurements are made at the following voltages, unless otherwise specified:



## Z80-PIO

### Absolute Maximum Ratings

|                                           |                            |
|-------------------------------------------|----------------------------|
| Temperature Under Bias                    | Specified operating range. |
| Storage Temperature                       | -65° C to +150° C          |
| Voltage On Any Pin With Respect To Ground | -0.3 V to +7 V             |
| Power Dissipation                         | .6 W                       |

#### \*Comment

Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### Z80-PIO and Z80A-PIO

### D.C. Characteristics

TA = 0° C to 70° C, Vcc = 5 V ± 5% unless otherwise specified

Note: All AC and DC characteristics remain the same for the military grade parts except I<sub>CC</sub>.

I<sub>CC</sub> = 130 mA.

| Symbol           | Parameter                                 | Min.                | Max.                | Unit | Test Condition                                                     |
|------------------|-------------------------------------------|---------------------|---------------------|------|--------------------------------------------------------------------|
| V <sub>ILC</sub> | Clock Input Low Voltage                   | -0.3                | .45                 | V    |                                                                    |
| V <sub>IHC</sub> | Clock Input High Voltage                  | V <sub>cc</sub> -.6 | V <sub>cc</sub> +.3 | V    |                                                                    |
| V <sub>IL</sub>  | Input Low Voltage                         | -0.3                | 0.8                 | V    |                                                                    |
| V <sub>IH</sub>  | Input High Voltage                        | 2.0                 | V <sub>cc</sub>     | V    |                                                                    |
| V <sub>OL</sub>  | Output Low Voltage                        |                     | 0.4                 | V    | I <sub>OL</sub> = 2.0 mA                                           |
| V <sub>OH</sub>  | Output High Voltage                       | 2.4                 |                     | V    | I <sub>OHI</sub> = -250 μA                                         |
| I <sub>CC</sub>  | Power Supply Current                      |                     | 70                  | mA   |                                                                    |
| I <sub>LI</sub>  | Input Leakage Current                     |                     | 10                  | μA   | V <sub>IN</sub> = 0 to V <sub>cc</sub>                             |
| I <sub>LOH</sub> | Tri-State Output Leakage Current in Float |                     | 10                  | μA   | V <sub>OUT</sub> = 2.4 to V <sub>cc</sub>                          |
| I <sub>LOL</sub> | Tri-State Output Leakage Current in Float | -10                 | μA                  |      | V <sub>OUT</sub> = 0.4 V                                           |
| I <sub>LD</sub>  | Data Bus Leakage Current in Input Mode    | ±10                 | μA                  |      | 0 ≤ V <sub>IN</sub> ≤ V <sub>cc</sub>                              |
| I <sub>OHD</sub> | Darlington Drive Current                  | -1.5                | 3.8                 | mA   | V <sub>OH</sub> = 1.5 V<br>R <sub>EXT</sub> = 390 Ω<br>Port B Only |

# Z80-PIO

## A.C. Characteristics

TA = 0° C to 70° C, V<sub>CC</sub> = +5 V ± 5%, unless otherwise noted

| SIGNAL                                                         | SYMBOL                                                                                          | PARAMETER                                                                                                                                                                                                                                                                       | MIN               | MAX                          | UNIT                         | COMMENTS                                 |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------------|------------------------------|------------------------------------------|
| Φ                                                              | t <sub>C</sub><br>t <sub>W (ΦH)</sub><br>t <sub>W (ΦL)</sub><br>t <sub>r</sub> , t <sub>f</sub> | Clock Period<br>Clock Pulse Width, Clock High<br>Clock Pulse Width, Clock Low<br>Clock Rise and Fall Times                                                                                                                                                                      | 400<br>170<br>170 | [1]<br>2000<br>2000<br>30    | nsec<br>nsec<br>nsec<br>nsec |                                          |
|                                                                | t <sub>H</sub>                                                                                  | Any Hold Time for Specified Set-Up Time                                                                                                                                                                                                                                         | 0                 |                              | nsec                         |                                          |
| CS, CE<br>ETC.                                                 | t <sub>SΦ (CS)</sub>                                                                            | Control Signal Set-Up Time to Rising Edge of Φ During Read or Write Cycle                                                                                                                                                                                                       | 280               |                              | nsec                         |                                          |
| D <sub>0-D<sub>7</sub></sub>                                   | t <sub>DR (D)</sub><br>t <sub>SΦ (D)</sub><br>t <sub>DI (D)</sub><br>t <sub>F (D)</sub>         | Data Output Delay from Falling Edge of RD<br>Data Set Up Time to Rising Edge of Φ During Write or M <sub>1</sub> Cycle<br>Data Output Delay from Falling Edge of I <sub>ORQ</sub> During INTA Cycle.<br>Delay to Floating Bus (Output Buffer Disable Time)                      | 50                | 430<br>340<br>160            | nsec<br>nsec<br>nsec         | [2]<br>C <sub>L</sub> = 50 pF<br>[3]     |
| IEI                                                            | t <sub>S (IEI)</sub>                                                                            | IEI Set-Up Time to Falling Edge of I <sub>ORQ</sub> During INTA Cycle                                                                                                                                                                                                           | 140               |                              | nsec                         |                                          |
| IEO                                                            | t <sub>DH (IO)</sub><br>t <sub>DL (IO)</sub><br>t <sub>DM (IO)</sub>                            | IEO Delay Time from Rising Edge of IEI<br>IEO Delay Time from Falling Edge of IEI<br>IEO Delay from Falling Edge of M <sub>1</sub> (Interrupt Occurring Just Prior to M <sub>1</sub> ) See Note A.                                                                              |                   | 210<br>190<br>300            | nsec<br>nsec<br>nsec         | [5]<br>[5] C <sub>L</sub> = 50 pF<br>[5] |
| I <sub>ORQ</sub>                                               | t <sub>SΦ (IR)</sub>                                                                            | I <sub>ORQ</sub> Set-Up Time to Rising Edge of Φ During Read or Write Cycle                                                                                                                                                                                                     | 250               |                              | nsec                         |                                          |
| M <sub>1</sub>                                                 | t <sub>SΦ (M<sub>1</sub>)</sub>                                                                 | M <sub>1</sub> Set-Up Time to Rising Edge of Φ During INTA or M <sub>1</sub> Cycle. See Note B.                                                                                                                                                                                 | 210               |                              | nsec                         |                                          |
| RD                                                             | t <sub>SΦ (RD)</sub>                                                                            | RD Set-Up Time to Rising Edge of Φ During Read or M <sub>1</sub> Cycle                                                                                                                                                                                                          | 240               |                              | nsec                         |                                          |
| A <sub>0-A<sub>7</sub></sub> ,<br>B <sub>0-B<sub>7</sub></sub> | t <sub>S (PD)</sub><br>t <sub>DS (PD)</sub><br>t <sub>F (PD)</sub><br>t <sub>DI (PD)</sub>      | Port Data Set-Up Time to Rising Edge of STROBE (Mode 1)<br>Port Data Output Delay from Falling Edge of STROBE (Mode 2)<br>Delay to Floating Port Data Bus from Rising Edge of STROBE (Mode 2)<br>Port Data Stable from Rising Edge of I <sub>ORQ</sub> During WR Cycle (Mode 0) | 260               | 230<br>200<br>200            | nsec<br>nsec<br>nsec         | [5]<br>C <sub>L</sub> = 50 pF<br>[5]     |
| ASTB,<br>BSTB                                                  | t <sub>W (ST)</sub>                                                                             | Pulse Width, STROBE                                                                                                                                                                                                                                                             | 150<br>[4]        |                              | nsec<br>nsec                 |                                          |
| INT                                                            | t <sub>D (IT)</sub><br>t <sub>D (IT3)</sub>                                                     | INT Delay Time from Rising Edge of STROBE<br>INT Delay Time from Data Match During Mode 3 Operation                                                                                                                                                                             |                   | 490<br>420                   | nsec<br>nsec                 |                                          |
| ARDY,<br>BRDY                                                  | t <sub>DH (RY)</sub><br>t <sub>DL (RY)</sub>                                                    | Ready Response Time from Rising Edge of I <sub>ORQ</sub><br>Ready Response Time from Rising Edge of STROBE                                                                                                                                                                      |                   | t <sub>C</sub><br>460<br>400 | nsec<br>nsec                 | [5]<br>C <sub>L</sub> = 50 pF<br>[5]     |

### NOTES:

- A.  $2.5 t_c > (N-2) t_{DL (IO)} + t_{DM (IO)} + t_{S (IEI)} + \text{TTL Buffer Delay}$ , if any  
 B. M<sub>1</sub> must be active for a minimum of 2 clock periods to reset the PIO.

### Output load circuit.



[1] t<sub>C</sub> + t<sub>W (ΦH)</sub> + t<sub>W (ΦL)</sub> + t<sub>r</sub> + t<sub>f</sub>

[2] Increase t<sub>DR (D)</sub> by 10 nsec for each 50 pF increase in loading up to 200 pF max.

[3] Increase t<sub>DI (D)</sub> by 10 nsec for each 50 pF increase in loading up to 200 pF max.

[4] For Mode 2: t<sub>W (ST)</sub> > t<sub>S (PD)</sub>

[5] Increase these values by 2 nsec for each 10 pF increase in loading up to 100 pF max.

## Capacitance

TA = 25° C, f = 1 MHz

| Symbol           | Parameter          | Max. | Unit | Test Condition                        |
|------------------|--------------------|------|------|---------------------------------------|
| C <sub>Φ</sub>   | Clock Capacitance  | 10   | pF   | Unmeasured Pins<br>Returned to Ground |
| C <sub>IN</sub>  | Input Capacitance  | 5    | pF   |                                       |
| C <sub>OUT</sub> | Output Capacitance | 10   | pF   |                                       |

# Z80A-PIO

## A.C. Characteristics

TA = 0° C to 70° C; Vcc = +5 V ± 5%, unless otherwise noted

| SIGNAL                                                             | SYMBOL                                                                                          | PARAMETER                                                                                                                                                                                                                                                           | MIN                     | MAX                                                | UNIT                 | COMMENTS                                    |
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------------------------------|----------------------|---------------------------------------------|
| Φ                                                                  | t <sub>c</sub><br>t <sub>W</sub> (PH)<br>t <sub>W</sub> (PL)<br>t <sub>r</sub> , t <sub>f</sub> | Clock Period<br>Clock Pulse Width, Clock High<br>Clock Pulse Width, Clock Low<br>Clock Rise and Fall Times                                                                                                                                                          | 250<br>105<br>105<br>30 | [1]<br>2000<br>2000<br>nsec                        | nsec                 |                                             |
|                                                                    | t <sub>h</sub>                                                                                  | Any Hold Time for Specified Set-Up Time                                                                                                                                                                                                                             | 0                       |                                                    | nsec                 |                                             |
| CS, CE<br>ETC.                                                     | t <sub>SΦ</sub> (CS)                                                                            | Control Signal Set-Up Time to Rising Edge of Φ During Read or Write Cycle                                                                                                                                                                                           | 145                     |                                                    | nsec                 |                                             |
| D <sub>0</sub> -D <sub>7</sub>                                     | t <sub>DR</sub> (D)<br>t <sub>SΦ</sub> (D)<br>t <sub>DI</sub> (D)<br>t <sub>F</sub> (D)         | Data Output Delay From Falling Edge of RD<br>Data Set-Up Time to Rising Edge of Φ During Write or M1 Cycle<br>Data Output Delay from Falling Edge of IORQ During INTA Cycle<br>Delay to Floating Bus (Output Buffer Disable Time)                                   | 50                      | 380<br>250<br>110                                  | nsec<br>nsec<br>nsec | [2]<br>C <sub>L</sub> = 50 pF<br>[3]        |
| IEI                                                                | t <sub>S</sub> (IEI)                                                                            | IEI Set-Up Time to Falling edge of IORQ During INTA Cycle                                                                                                                                                                                                           | 140                     |                                                    | nsec                 |                                             |
| IEO                                                                | t <sub>DH</sub> (IO)<br>t <sub>DL</sub> (IO)<br>t <sub>DM</sub> (IO)                            | IEO Delay Time from Rising Edge of IEI<br>IEO Delay Time from Falling Edge of IEI<br>IEO Delay from Falling Edge of M1 (Interrupt Occurring Just Prior to M1). See Note A.                                                                                          |                         | 160<br>130<br>190                                  | nsec<br>nsec<br>nsec | [5]<br>[5]<br>C <sub>L</sub> = 50 pF<br>[5] |
| IORQ                                                               | t <sub>SΦ</sub> (IR)                                                                            | IORQ Set Up Time to Rising Edge of Φ During Read or Write Cycle                                                                                                                                                                                                     | 115                     |                                                    | nsec                 |                                             |
| M1                                                                 | t <sub>SΦ</sub> (M1)                                                                            | M1 Set-Up Time to Rising Edge of Φ During INTA or M1 Cycle. See Note B                                                                                                                                                                                              | 90                      |                                                    | nsec                 |                                             |
| RD                                                                 | t <sub>SΦ</sub> (RD)                                                                            | RD Set-Up Time to Rising Edge of Φ During Read or M1 Cycle                                                                                                                                                                                                          | 115                     |                                                    | nsec                 |                                             |
| A <sub>0</sub> -A <sub>7</sub> ,<br>B <sub>0</sub> -B <sub>7</sub> | t <sub>S</sub> (PD)<br>t <sub>DS</sub> (PD)<br>t <sub>F</sub> (PD)<br>t <sub>DI</sub> (PD)      | Port Data Set-Up Time to Rising Edge of STROBE (Mode 1)<br>Port Data Output Delay from Falling Edge of STROBE (Mode 2)<br>Delay to Floating Port Data Bus from Rising Edge of STROBE (Mode 2)<br>Port Data Stable from Rising Edge of IORQ During WR Cycle (Mode 0) | 230                     | 210<br>180<br>180                                  | nsec<br>nsec<br>nsec | [5]<br>C <sub>L</sub> = 50 pF<br>[5]        |
| ASTB,<br>BSTB                                                      | t <sub>W</sub> (ST)                                                                             | Pulse Width, STROBE                                                                                                                                                                                                                                                 | 150<br>[4]              |                                                    | nsec<br>nsec         |                                             |
| INT                                                                | t <sub>D</sub> (IT)<br>t <sub>D</sub> (IT3)                                                     | INT Delay time from Rising Edge of STROBE<br>INT Delay Time from Data Match During Mode 3 Operation                                                                                                                                                                 |                         | 440<br>380                                         | nsec<br>nsec         |                                             |
| ARDY,<br>BRDY                                                      | t <sub>DH</sub> (RY)<br>t <sub>DL</sub> (RY)                                                    | Ready Response Time from Rising Edge of IORQ<br>Ready Response Time from Rising Edge of STROBE                                                                                                                                                                      |                         | t <sub>c</sub> +<br>410<br>t <sub>c</sub> +<br>360 | nsec<br>nsec         | [5]<br>C <sub>L</sub> = 50 pF<br>[5]        |

### NOTES:

- A. 2.5 t<sub>c</sub> > (N-2) t<sub>DL</sub> (IO) + t<sub>DM</sub> (IO) + t<sub>S</sub> (IEI) + TTL Buffer Delay, if any.  
 B. M1 must be active for a minimum of 2 clock periods to reset the PIO.

- [1] t<sub>c</sub> = t<sub>W</sub> (PH) + t<sub>W</sub> (PL) + t<sub>r</sub> + t<sub>f</sub>  
 [2] Increase t<sub>DR</sub> (D) by 10 nsec for each 50 pF increase in loading up to 200 pF max.  
 [3] Increase t<sub>DI</sub> (D) by 10 nsec for each 50 pF increase in loading up to 200 pF max.  
 [4] For Mode 2: t<sub>W</sub> (ST) > t<sub>S</sub> (PD)  
 [5] Increase these values by 2 nsec for each 10 pF increase in loading up to 100 pF max.

## Z80-PIO

### A.C. Timing Diagram



## Z80-CTC

### Absolute Maximum Ratings

|                                           |                   |
|-------------------------------------------|-------------------|
| Temperature Under Bias                    | 0° C to 70° C     |
| Storage Temperature                       | -65° C to +150° C |
| Voltage On Any Pin With Respect To Ground | -0.3 V to +7 V    |
| Power Dissipation                         | 0.8W              |

**Comment**  
 Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### D.C. Characteristics

TA = 0° C to 70° C, Vcc = 5 V ± 5% unless otherwise specified

#### Z80-CTC

| Symbol           | Parameter                                 | Min      | Max      | Unit | Test Condition                                    |
|------------------|-------------------------------------------|----------|----------|------|---------------------------------------------------|
| VILC             | Clock Input Low Voltage                   | -0.3     | .45      | V    |                                                   |
| VIHC             | Clock Input High Voltage [1]              | VCC - .6 | VCC + .3 | V    |                                                   |
| VIL              | Input Low Voltage                         | -0.3     | 0.8      | V    |                                                   |
| VIH              | Input High Voltage                        | 2.0      | VCC      | V    |                                                   |
| VOL              | Output Low Voltage                        |          | 0.4      | V    | I <sub>OL</sub> = 2 mA                            |
| VOH              | Output High Voltage                       | 2.4      |          | V    | I <sub>OH</sub> = -250 μA                         |
| I <sub>CC</sub>  | Power Supply Current                      |          | 120      | mA   | T <sub>C</sub> = 400 nsec                         |
| I <sub>LI</sub>  | Input Leakage Current                     |          | 10       | μA   | V <sub>IN</sub> = 0 to V <sub>CC</sub>            |
| I <sub>LOH</sub> | Tri-State Output Leakage Current in Float |          | 10       | μA   | V <sub>OUT</sub> = 2.4 to V <sub>CC</sub>         |
| I <sub>LOL</sub> | Tri-State Output Leakage Current in Float |          | -10      | μA   | V <sub>OUT</sub> = 0.4V                           |
| I <sub>OHD</sub> | Darlington Drive Current                  | -1.5     |          | mA   | V <sub>OH</sub> = 1.5V<br>R <sub>EXT</sub> = 390Ω |

#### Z80A-CTC

| Symbol           | Parameter                                 | Min      | Max      | Unit | Test Condition                                    |
|------------------|-------------------------------------------|----------|----------|------|---------------------------------------------------|
| VILC             | Clock Input Low Voltage                   | -0.3     | .45      | V    |                                                   |
| VIHC             | Clock Input High Voltage [1]              | VCC - .6 | VCC + .3 | V    |                                                   |
| VIL              | Input Low Voltage                         | -0.3     | 0.8      | V    |                                                   |
| VIH              | Input High Voltage                        | 2.0      | VCC      | V    |                                                   |
| VOL              | Output Low Voltage                        |          | 0.4      | V    | I <sub>OL</sub> = 2 mA                            |
| VOH              | Output High Voltage                       | 2.4      |          | V    | I <sub>OH</sub> = -250 μA                         |
| I <sub>CC</sub>  | Power Supply Current                      |          | 120      | mA   | T <sub>C</sub> = 250 nsec                         |
| I <sub>LI</sub>  | Input Leakage Current                     |          | 10       | μA   | V <sub>IN</sub> = 0 to V <sub>CC</sub>            |
| I <sub>LOH</sub> | Tri-State Output Leakage Current in Float |          | 10       | μA   | V <sub>OUT</sub> = 2.4 to V <sub>CC</sub>         |
| I <sub>LOL</sub> | Tri-State Output Leakage Current in Float |          | -10      | μA   | V <sub>OUT</sub> = 0.4V                           |
| I <sub>OHD</sub> | Darlington Drive Current                  | -1.5     |          | mA   | V <sub>OH</sub> = 1.5V<br>R <sub>EXT</sub> = 390Ω |

### Capacitance

TA = 25° C, f = 1 MHz

| Symbol           | Parameter          | Max. | Unit | Test Condition                        |
|------------------|--------------------|------|------|---------------------------------------|
| C <sub>Φ</sub>   | Clock Capacitance  | 20   | pF   |                                       |
| C <sub>IN</sub>  | Input Capacitance  | 5    | pF   | Unmeasured Pins<br>Returned to Ground |
| C <sub>OUT</sub> | Output Capacitance | 10   | pF   |                                       |

**Z80-CTC****A.C. Characteristics**TA = 0° C to 70° C, V<sub>CC</sub> = +5 V ± 5%, unless otherwise noted

| Signal                              | Symbol                                                                                                                                          | Parameter                                                                                                                                                                                                                                                                                      | Min                                | Max                                                 | Unit                                                                                                       | Comments                                                                                         |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| Φ                                   | t <sub>C</sub><br>t <sub>W(ΦH)</sub><br>t <sub>W(ΦL)</sub><br>t <sub>r</sub> , t <sub>f</sub>                                                   | Clock Period<br>Clock Pulse Width, Clock High<br>Clock Pulse Width, Clock Low<br>Clock Rise and Fall Times                                                                                                                                                                                     | 400<br>170<br>170<br>—             | [1]<br>2000<br>2000<br>30                           | ns<br>ns<br>ns<br>ns                                                                                       |                                                                                                  |
|                                     | t <sub>H</sub>                                                                                                                                  | Any Hold Time for Specified Setup Time                                                                                                                                                                                                                                                         | 0                                  | —                                                   | ns                                                                                                         |                                                                                                  |
| CS, $\overline{CE}$ , etc.          | t <sub>SΦ(CS)</sub>                                                                                                                             | Control Signal Setup Time to Rising Edge of Φ During Read or Write Cycle                                                                                                                                                                                                                       | 160                                | —                                                   | ns                                                                                                         |                                                                                                  |
| D <sub>0</sub> –D <sub>7</sub>      | t <sub>DR(D)</sub><br>t <sub>SΦ(D)</sub><br>t <sub>DI(D)</sub><br>t <sub>F(D)</sub>                                                             | Data Output Delay from Rising Edge of RD During Read Cycle<br>Data Setup Time to Rising Edge of Φ During Write or M1 Cycle<br>Data Output Delay from Falling Edge of IORQ During INTA Cycle<br>Delay to Floating Bus (Output Buffer Disable Time)                                              | —<br>60<br>—<br>—                  | 480<br>ns<br>340<br>230                             | ns<br>ns<br>ns<br>ns                                                                                       | [2]<br>[2]                                                                                       |
| IEI                                 | t <sub>S(IEI)</sub>                                                                                                                             | IEI Setup Time to Falling Edge of IORQ During INTA Cycle                                                                                                                                                                                                                                       | 200                                | —                                                   | ns                                                                                                         |                                                                                                  |
| IEO                                 | t <sub>DH(I0)</sub><br>t <sub>DL(I0)</sub><br>t <sub>DM(I0)</sub>                                                                               | IEO Delay Time from Rising Edge of IEI<br>IEO Delay Time from Falling Edge of IEI<br>IEO Delay from Falling Edge of M1 (Interrupt Occurring just Prior to M1)                                                                                                                                  | —<br>—<br>—                        | 220<br>190<br>300                                   | ns<br>ns<br>ns                                                                                             | [3]<br>[3]<br>[3]                                                                                |
| IORQ                                | t <sub>SΦ(IIR)</sub>                                                                                                                            | IORQ Setup Time to Rising Edge of Φ During Read or Write Cycle                                                                                                                                                                                                                                 | 250                                | —                                                   | ns                                                                                                         |                                                                                                  |
| M1                                  | t <sub>SΦ(M1)</sub>                                                                                                                             | M1 Setup Time to Rising Edge of Φ During INTA or M1 Cycle                                                                                                                                                                                                                                      | 210                                | —                                                   | ns                                                                                                         |                                                                                                  |
| RD                                  | t <sub>SΦ(RD)</sub>                                                                                                                             | RD Setup Time to Rising Edge of Φ During Read or M1 Cycle                                                                                                                                                                                                                                      | 240                                | —                                                   | ns                                                                                                         |                                                                                                  |
| INT                                 | t <sub>DCK(IT)</sub><br>t <sub>DΦ(IT)</sub>                                                                                                     | INT Delay Time from Rising Edge of CLK/TRG<br>INT Delay Time from Rising Edge of Φ                                                                                                                                                                                                             | —<br>—                             | 2t <sub>C(Φ)</sub> + 200<br>t <sub>C(Φ)</sub> + 200 | —<br>—                                                                                                     | Counter Mode<br>Timer Mode                                                                       |
| CLK/TRG <sub>0</sub> – <sub>3</sub> | t <sub>C(CK)</sub><br>t <sub>r</sub> , t <sub>f</sub><br>t <sub>S(CK)</sub><br>t <sub>S(TR)</sub><br>t <sub>W(CTH)</sub><br>t <sub>W(CTL)</sub> | Clock Period<br>Clock and Trigger Rise and Fall Times<br>Clock Setup Time to Rising Edge of Φ for Immediate Count<br>Trigger Setup Time to Rising Edge of Φ for Enabling of Prescaler on Following Rising Edge of Φ<br>Clock and Trigger High Pulse Width<br>Clock and Trigger Low Pulse Width | —<br>—<br>210<br>210<br>200<br>200 | 2t <sub>C(Φ)</sub><br>50<br>—<br>—<br>—<br>—        | —<br>—<br>Counter Mode<br>Counter Mode<br>Timer Mode<br>Counter and Timer Modes<br>Counter and Timer Modes | Counter Mode<br>Counter Mode<br>Timer Mode<br>Counter and Timer Modes<br>Counter and Timer Modes |
| ZC/TO <sub>0</sub> – <sub>2</sub>   | t <sub>DH(ZC)</sub><br>t <sub>DL(ZC)</sub>                                                                                                      | ZC/TO Delay Time from Rising Edge of Φ, ZC/TO High<br>ZC/TO Delay Time from Falling Edge of Φ, ZC/TO Low                                                                                                                                                                                       | —<br>—                             | 190<br>190                                          | —<br>—                                                                                                     | Counter and Timer Modes<br>Counter and Timer Modes                                               |

Notes: [1] t<sub>C</sub> = t<sub>W(ΦH)</sub> + t<sub>W(ΦL)</sub> + t<sub>r</sub> + t<sub>f</sub>.

[2] Increase delay by 10 nsec for each 50 pF increase in loading, 200 pF maximum for data lines and 100 pF for control lines.

[3] Increase delay by 2 nsec for each 10 pF increase in loading, 100 pF maximum

[4] RESET must be active for a minimum of 3 clock cycles.

**OUTPUT LOAD CIRCUIT**

# Z80A-CTC

## A.C. Characteristics

TA = 0° C to 70° C, V<sub>CC</sub> = +5 V ± 5%, unless otherwise noted

| Signal                         | Symbol          | Parameter                                                                                                | Min | Max                | Unit | Comments                |
|--------------------------------|-----------------|----------------------------------------------------------------------------------------------------------|-----|--------------------|------|-------------------------|
| $\Phi$                         | $t_C$           | Clock Period                                                                                             | 250 | [1]                | ns   |                         |
|                                | $t_W(\Phi H)$   | Clock Pulse Width, Clock High                                                                            | 105 | 2000               | ns   |                         |
|                                | $t_W(\Phi L)$   | Clock Pulse Width, Clock Low                                                                             | 105 | 2000               | ns   |                         |
|                                | $t_r, t_f$      | Clock Rise and Fall Times                                                                                |     | 30                 | ns   |                         |
|                                | $t_H$           | Any Hold Time for Specified Setup Time                                                                   | 0   |                    | ns   |                         |
| CS, $\overline{CE}$ , etc      | $t_{S\Phi}(CS)$ | Control Signal Setup Time to Rising Edge of $\Phi$ During Read or Write Cycle                            | 60  |                    | ns   |                         |
| D <sub>0</sub> -D <sub>7</sub> | $t_{DR}(D)$     | Data Output Delay from Falling Edge of $\overline{RD}$ During Read Cycle                                 |     | 380                | ns   | [2]                     |
|                                | $t_{S\Phi}(D)$  | Data Setup Time to Rising Edge of $\Phi$ During Write or M1 Cycle                                        | 50  |                    | ns   |                         |
|                                | $t_{DI}(D)$     | Data Output Delay from Falling Edge of IORG During INTA Cycle                                            |     | 160                | ns   | [2]                     |
|                                | $t_F(D)$        | Delay to Floating Bus (Output Buffer Disable Time)                                                       |     | 110                | ns   |                         |
| IEI                            | $t_S(IEI)$      | IEI Setup Time to Falling Edge of $\overline{IORQ}$ During INTA Cycle                                    | 140 |                    | ns   |                         |
| IEO                            | $t_{DH}(IO)$    | IEO Delay Time from Rising Edge of IEI                                                                   |     | 160                | ns   | [3]                     |
|                                | $t_{DL}(IO)$    | IEO Delay Time from Falling Edge of IEI                                                                  |     | 130                | ns   | [3]                     |
|                                | $t_{DM}(IO)$    | IEO Delay from Falling Edge of M1 (Interrupt Occurring just Prior to M1)                                 |     | 190                | ns   | [3]                     |
| IORQ                           | $t_{S\Phi}(IR)$ | IORQ Setup Time to Rising Edge of $\Phi$ During Read or Write Cycle                                      | 115 |                    | ns   |                         |
| M1                             | $t_{S\Phi}(M1)$ | M1 Setup Time to Rising Edge of $\Phi$ During INTA or M1 Cycle                                           | 90  |                    | ns   |                         |
| RD                             | $t_{S\Phi}(RD)$ | $\overline{RD}$ Setup Time to Rising Edge of $\Phi$ During Read or M1 Cycle                              | 115 |                    | ns   |                         |
| INT                            | $t_{DCK}(IT)$   | INT Delay Time from Rising Edge of CLK/TRG                                                               |     | $2t_C(\Phi) + 140$ |      | Counter Mode            |
|                                | $t_{D\Phi}(IT)$ | INT Delay Time from Rising Edge of $\Phi$                                                                |     | $t_C(\Phi) + 140$  |      | Timer Mode              |
| CLK/TRG <sub>0</sub> -3        | $t_C(CK)$       | Clock Period                                                                                             |     | $2t_C(\Phi)$       |      | Counter Mode            |
|                                | $t_r, t_f$      | Clock and Trigger Rise and Fall Times                                                                    |     | 30                 |      |                         |
|                                | $t_S(CK)$       | Clock Setup Time to Rising Edge of $\Phi$ for Immediate Count                                            | 130 |                    |      | Counter Mode            |
|                                | $t_S(TR)$       | Trigger Setup Time to Rising Edge of $\Phi$ for enabling of Prescaler on Following Rising Edge of $\Phi$ | 130 |                    |      | Timer Mode              |
|                                | $t_W(CTH)$      | Clock and Trigger High Pulse Width                                                                       | 120 |                    |      | Counter and Timer Modes |
|                                | $t_W(CTL)$      | Clock and Trigger Low Pulse Width                                                                        | 120 |                    |      | Counter and Timer Modes |
|                                |                 |                                                                                                          |     |                    |      |                         |
| ZC/TO <sub>0</sub> -2          | $t_{DH}(ZC)$    | ZC/TO Delay Time from Rising Edge of $\Phi$ , ZC/TO High                                                 |     | 120                |      | Counter and Timer Modes |
|                                | $t_{DL}(ZC)$    | ZC/TO Delay Time from Rising Edge of $\Phi$ , ZC/TO Low                                                  |     | 120                |      | Counter and Timer Modes |

Notes: [1]  $t_C = t_W(\Phi H) + t_W(\Phi L) + t_r + t_f$ .

[2] Increase delay by 10 nsec for each 50 pF increase in loading, 200 pF maximum for data lines and 100 pF for control lines.

[3] Increase delay by 2 nsec for each 10 pF increase in loading, 100 pF maximum.

[4] RESET must be active for a minimum of 3 clock cycles.

## OUTPUT LOAD CIRCUIT



# Z80-CTC

## A.C. Timing Diagram

Timing measurements are made at the following voltages, unless otherwise specified:

|        | "1"                   | "0"  |
|--------|-----------------------|------|
| CLOCK  | V <sub>CC</sub> - .6V | .45V |
| OUTPUT | 2.0V                  | .8V  |
| INPUT  | 2.0V                  | .8V  |
| FLOAT  | ΔV                    | ±.5V |



# **Chapter 8**

## **THE ZILOG Z8**

**This chapter will be provided at a later date as an update.**

## Chapter 9

# THE MOTOROLA MC6800

**The MC6800 was developed by Motorola as an enhancement of the Intel 8008, at the same time that Intel was developing the 8080A, also as an enhancement of the 8008.**

**When comparing the MC6800 to the 8080A, the most important feature of the MC6800 is its relative simplicity. Here are a few superficial, but illustrative comparisons between the two products:**

- 1) As compared to the 8080A, MC6800 timing is very simple. MC6800 instructions execute in two or more machine cycles, all of which are identical in length. In contrast to the 8080A, which we described in Chapter 4, note that an MC6800 machine cycle and clock period are one and the same thing — each MC6800 machine cycle has a single clock period.
- 2) Whereas the 8080A has separate I/O instructions, the MC6800 includes memory and I/O within a single address space. Thus all I/O devices are accessed as memory locations.
- 3) The MC6800 has a simpler set of control signals, therefore it does not multiplex the Data Bus — and does not need any device equivalent to the 8228 System Controller.
- 4) Whereas the 8080A requires three levels of power supply, the MC6800 uses just one — +5V.
- 5) The instruction set of the MC6800 is much easier to comprehend than that of the 8080A. The MC6800 has fewer basic instruction types, with more memory addressing options; the 8080A, by way of contrast, has a large number of special, one-of-a-kind instructions.

**It is very informative to extend the five comparisons above with the enhancements that Intel has made to the 8080A in order to come up with the 8085. Let us take the five points one at a time.**

- 1) 8085 instruction execution timing is far simpler than the 8080A. But MC6800 timing is still far simpler than the 8085.
- 2) The 8085 retains the separate memory and I/O spaces of the 8080A.
- 3) The 8085 has separate control signals which do not need to be demultiplexed off the Data Bus, as required by the 8080A. The price paid by the 8085 is a multiplexed Data and Address Bus. Neither the MC6800 nor the 8085 need any device equivalent to the 8228 System Controller; however, the 8085 will need a bus demultiplexer in configurations that do not use the standard 8085 support devices.
- 4) The 8085, like the MC6800, has gone to a single +5V power supply.
- 5) The 8085 instruction set is almost identical to that of the 8080A.

An additional point worth noting is that the 8085 includes clock logic on the CPU chip. The MC6800 requires a separate clock logic chip.

**Looking at the 8085, there are grounds for arguing that Intel has acknowledged that the MC6800 has some desirable characteristics not present in the 8080A. In order to compete with the 8085, therefore, Motorola will not be required to make MC6800 enhancements of the same magnitude as Intel made going from the 8080A to the 8085. Specifically, these are the MC6800 characteristics which remain to be addressed by any MC6800 enhancement:**

- 1) Clock logic must be moved on to the CPU chip.
- 2) Multifunction CPU and support devices must be developed so that Motorola can offer low chip count microcomputers.

**Additional weaknesses of the MC6800 that have manifested themselves include:**

- 1) An instruction set that makes excessive use of memory as a result of too few Index registers and a lack of data mobility between registers of the CPU. This is a weakness that was identified in the first version of this book.
- 2) The synchronizing E signal, required by support devices of the MC6800, render these support devices useless in any microcomputer system other than the MC6800. In contrast, 8080A support devices can be used widely in microcomputer systems not based on the 8080A CPU.

Future Motorola plans address many of the points raised above. The MC6802, described in this chapter, is the first step towards reducing chip counts in MC6800-based microcomputer systems. The MC6809 will be the new enhanced MC6800, to compete with the 8085. The MC6809 will provide additional Index registers, plus instructions that move data between Accumulators and Index registers. The MC6809 will have clock logic on the CPU chip.

MC6800 and MCS6500 support devices are interchangeable; that is to say, you can use MC6800 support devices (described in this chapter) with the MCS6500 microprocessor (described in Chapter 10) and you can use MCS6500 support devices (described in Chapter 10) with the MC6800 CPU.

Although MC6800 and MCS6500 support devices are interchangeable, they should not be used with other microprocessors, with the exception of parts described in Volume 3.

**These are the devices described in this chapter:**

- The MC6800 CPU
- The MC6802 CPU with RAM
- The MC6870 series Clocks
- The MC6820 Peripheral Interface Adapter (PIA)
- The MC6850 Asynchronous Communications Interface Adapter (ACIA)
- The XC6852 Synchronous Serial Data Adapter (SSDA)
- The MC6828 Priority Interrupt Controller (PIC)
- The MC6840 Programmable Counter/Timer
- The MC6844 Direct Memory Access Controller
- The MC6846 Multifunction device - the second part in an MC6802-based two-chip microcomputer.

**Devices described in Volume 3 include the MC6845 CRT controller, the MC6843 Floppy Disk controller and the MC68488 General Purpose Interface Adapter.**

**Two new series of MC6800 parts offer higher speeds.** Standard MC6800 parts use a 1 MHz clock signal. "A" parts use a 1.5 MHz clock signal, while "B" parts use a 2 MHz clock signal. There is, in addition, an MC6821 PIA which is identical to the MC6820 in operating characteristics, but has different physical characteristics.

**MOTOROLA  
A AND B  
SERIES PARTS**

The principal MC6800 manufacturer is:

MOTOROLA INCORPORATED  
Semiconductor Products Division  
3501 Ed Bluestein Boulevard  
Austin, TX 78721

The second sources are:

AMERICAN MICROSYSTEMS  
3800 Homestead Road  
Santa Clara, California 95051

FAIRCHILD SEMICONDUCTOR  
464 Ellis Street  
Mountain View, California 94040

HITACHI  
Semiconductors And Integrated  
Circuits Division of Hitachi LTD  
1450 Josuihan-Cho-Kodaira-Shi  
Tokyo, Japan

SESCOSEM  
Thompson CSF  
173 Haussmann Blvd.  
Paris, France 75008

**The MC6800 devices use a single +5V power supply. Using a one microsecond clock, instruction execution times range from 2 to 12 microseconds. A one microsecond clock is the standard for MC6800 microcomputer systems. 667 nanosecond clocks are standard for the 68A00 series while 500 nanosecond clocks are standard for the 68B00 series.**

**All MC6800 devices have TTL compatible signals.**

**N-channel silicon gate, depletion load MOS technology is used for the MC6800.**

## THE MC6800 CPU

**Functions implemented on the MC6800 CPU are illustrated in Figure 9-1;** they represent typical CPU logic. As compared to other microprocessors described in this book, the MC6800 might be considered deficient in requiring external clock logic; however, its principal competitor, the 8080A, requires external clock logic and Data Bus demultiplexing logic.

The need for external clock logic simply reflects the fact that the MC6800 is one of the earlier microprocessors.

### THE MC6800 PROGRAMMABLE REGISTERS

**The MC6800 has two Accumulators, a Status register, an Index register, a Stack Pointer and a Program Counter. These may be illustrated as follows:**



**The two Accumulators, A and B, are both primary Accumulators.** The only instructions which apply to one Accumulator, but not the other, are the instructions which move statuses between Accumulator A and the Status register and the DAA (Decimal Adjust) instruction.

**The Index register is a typical microcomputer Index register, as described in Volume 1.**

**The MC6800 has a Stack implemented in memory and indexed by the Stack Pointer, as described in Volume 1.** Because of the nature of the MC6800 instruction set, it is more realistic to look upon the MC6800 Stack Pointer as a cross between a Stack Pointer and a Data Counter. Memory reference instructions make it very easy to store the contents of either the Stack Pointer or the Index register in read/write memory; by maintaining a number of base page memory locations as storage for these two Address registers, each can be put to multiple use.

**The Program Counter is a typical Program Counter, as described in Volume 1.**

### MC6800 MEMORY ADDRESSING MODES

**MC6800 memory reference instructions use direct addressing and indexed addressing.**

**The MC6800 has an unusually large variety of three-byte memory referencing instructions; a 16-bit direct address is provided by the second and third bytes of the instruction. Therefore, 65,536 bytes of memory can be directly addressed. The commonly used memory reference instructions also have a base page, direct addressing option; this is a two-byte instruction, with a one-byte address which can directly address any one of the first 256 bytes of memory.**

**All memory reference instructions are available with indexed addressing.** Indexed addressing on the MC6800 differs from indexed addressing as described in Volume 1, in that the one-byte displacement provided by the memory reference instruction is added to the Index register as an unsigned 8-bit value:



MC6800 programs can use the Stack Pointer as an Address register, but two bytes of read/write memory must be reserved for the current top of Stack address and interrupts must be disabled while the Stack Pointer is being used to address data memory. A single instruction allows an address to be loaded into the Stack Pointer; another single instruction allows the Stack Pointer contents to be stored in read/write memory. In most programs, the Stack is unused for much of the time; therefore, given the low MC6800 overhead involved with swapping addresses between the Stack Pointer and read/write memory, making dual use of the Stack Pointer is advisable.



Figure 9-1. Logic of the MC6800 CPU Device

**Branch and Branch-on-Condition instructions use program relative, direct addressing;** a single byte displacement is treated as a signed binary number which is added to the Program Counter, after Program Counter contents have been incremented to address the next sequential instruction. This allows displacements in the range +129 to -126 bytes.

One note of caution: Motorola's MC6800 literature uses the term "implied addressing" to describe instructions that identify one of the programmable registers. **The closest thing the MC6800 has to implied addressing, as the term is used in this book, is indexed addressing with a zero displacement.**



| PIN NAME                          | DESCRIPTION            | TYPE                    |
|-----------------------------------|------------------------|-------------------------|
| *A <sub>0</sub> - A <sub>15</sub> | Address Lines          | Tristate, Output        |
| *D <sub>0</sub> - D <sub>7</sub>  | Data Bus Lines         | Tristate, Bidirectional |
| *HALT                             | Halt                   | Input                   |
| *TSC                              | Three State Control    | Input                   |
| *R/W                              | Read/Write             | Tristate, Output        |
| *VMA                              | Valid Memory Address   | Output                  |
| *DBE                              | Data Bus Enable        | Input                   |
| *BA                               | Bus Available          | Output                  |
| *IRQ                              | Interrupt Request      | Input                   |
| RESET                             | Reset                  | Input                   |
| NMI                               | Non-Maskable Interrupt | Input                   |
| $\Phi_1$ , $\Phi_2$               | Clock Signals          | Input                   |
| V <sub>SS</sub> , V <sub>CC</sub> | Power                  |                         |

\*These signals connect to the System Bus.

Figure 9-2. MC6800 CPU Signals and Pin Assignments

## MC6800 STATUS FLAGS

The MC6800 has a Status register which maintains five status flags and an interrupt control bit. These are the five status flags:

- Carry (C)
- Overflow (O)
- Sign (S)
- Zero (Z)
- Auxiliary Carry (AC)

Statuses are assigned bit positions within the Status register as follows:



The Carry status is standard for all additions and shift operations; however, Borrow logic sets the Carry status to 1 when there is no carry out of the high-order bit during a subtract operation, while the carry status is reset to 0 if there is a carry out of the high-order bit during a subtract operation. For a discussion of Carry status logic during subtract operations, see the Status flag section of Chapter 4.

I is the external interrupt enable/disable flag. When it is 1, interrupts via IRQ are disabled; when it is 0, interrupts via IRQ are enabled.

MC6800 literature refers to the Sign bit as a negative bit, given the symbol N; the Overflow bit is given the symbol V. The Intermediate Carry bit represents the standard Carry out of bit 3 and is referred to as the Half Carry bit, given the symbol H. Statuses are nevertheless set and reset as described for our hypothetical microcomputer in Volume 1.

## MC6800 CPU PINS AND SIGNALS

**The MC6800 CPU pins and signals are illustrated in Figure 9-2. A description of these signals is useful as a guide to the way in which the MC6800 microcomputer system works.**

**The Address Bus is a tristate bus; it is 16 bits wide and is used to address all types of memory and external devices.**

**The Data Bus is also a tristate bus; it is an 8-bit bidirectional bus via which data is transmitted between memory and all MC6800 microcomputer system devices.**

**Control signals on the MC6800 Control Bus may be divided into bus state controls, bus data identification, and interrupt processing.**

**These are the bus state control signals:**

**Three State Control (TSC).** This input is used to float the Address Bus and the read/write control output.

**MC6800  
BUS STATE  
CONTROLS**

**Data Bus Enable (DBE).** This signal is input low in order to float the Data Bus. When the Data Bus, the Address Bus and the read/write control output have all been floated, Direct Memory Access operations may be performed by external logic. DBE is frequently tied to the  $\Phi_2$  clock input, in which case  $\Phi_2$  and DBE are identical signals.

**HALT.** When this signal is input low, the CPU ceases execution at the end of the present instruction execution and floats the entire System Bus.

**Bus Available (BA).** This line is output high when the Data and Address Busses have been floated following a HALT input only. **When BA is low, the CPU is controlling the Data and Address Busses; information on these busses is identified by the following two control signals:**

**Read/Write (R/W).** When high, this signal indicates that the CPU wishes to read data off the Data Bus; when low, this signal indicates that the CPU is outputting data on the Data Bus. The normal standby state for this signal is "read" (high).

**Valid Memory Address (VMA).** This signal is output high whenever a valid address has been output on the Address Bus.

**There are three interrupt processing signals as follows:**

**IRQ.** **This signal is used to request an interrupt.** If interrupts have been enabled and the CPU is not in the Halt state, then it will acknowledge the interrupt at the end of the currently executing instruction.

**Non-Maskable Interrupt (NMI).** This signal differs from IRQ in that it cannot be inhibited. Typically, this input is used for catastrophic interrupts such as power fail.

**RESET.** This is a typical reset signal.

Note that a number of control signals output by the MC6800 are only capable of driving one standard TTL load. Some form of signal buffering and amplification will therefore be required in most systems.

## MC6800 TIMING AND INSTRUCTION EXECUTION

The MC6800 uses a relatively simple combination of two clock signals to time events within the microprocessor CPU and the microcomputer system in general. These two clock signals may be illustrated as follows:

**MC6800  
CLOCK  
SIGNALS**



Observe that clock signals  $\Phi_1$  and  $\Phi_2$  both have high pulses which occur within the width of the other clock signal's low pulse.

A further timing signal, given the symbol E, is used by support devices within an MC6800 microcomputer system.  $\Phi_1$ ,  $\Phi_2$  and E timing signals are generated by the clock logic devices described later in this chapter.

Each repeating pattern of  $\Phi_1$  and  $\Phi_2$  signals constitutes a single machine cycle:

**MC6800  
MACHINE  
CYCLE**



MC6800 instructions require between two and eight machine cycles to execute. Interrupt instructions are an exception, requiring longer instruction execution times.

So far as external logic is concerned, there are only three types of machine cycles which can occur during an instruction's execution:

- 1) A **read operation** during which a byte of data must be input to the CPU.
- 2) A **write operation** during which a byte of data is output by the CPU.
- 3) An **internal operation** during which no activity occurs on the System Bus.

**MC6800  
MACHINE  
CYCLE  
TYPES**

All MC6800 instructions have timing which is a simple concatenation of the three basic machine cycle types.

Let us therefore begin by looking at these three basic machine cycles.

Figure 9-3 illustrates timing for a standard read machine cycle. Observe that in the normal course of events, neither the Address nor the Data Busses are available for DMA operations. The address output is stable for most of the machine cycle. Data needs to be stable for a short interval of time late in the machine cycle. Exact timing is given in MC6800 data sheets at the end of this chapter.

**MC6800  
READ  
MACHINE  
CYCLE**



Figure 9-3. A Standard MC6800 Read Machine Cycle

Figure 9-4 illustrates a standard MC6800 write machine cycle. This machine cycle is not as straightforward as the read. The address to which data is being written is stable on the Address Bus for the duration of the machine cycles; however, the data being written is stable for a period within the high DBE pulse. While DBE is low, the Data Bus is floated.

**MC6800  
WRITE  
MACHINE  
CYCLE**



Figure 9-4. A Standard MC6800 Write Machine Cycle

Under normal circumstances, DBE is identical to  $\Phi_2$ :



If the high  $\Phi_2$  pulse is too short for external logic to respond to the write, the slow external logic can be accommodated in two ways. You can input a DBE signal to the CPU that has a shorter low pulse and a longer high pulse. DBE and  $\Phi_2$  are no longer identical signals:

**MC6800 WAIT STATE WITH SLOW MEMORY**



There is some minimum time during which DBE must be low, since the CPU itself requires time to perform internal operations. This minimum time is given in the MC6800 data sheets at the end of this chapter.

You can also accommodate slow memories by stretching the system clocks; this may be illustrated as follows:



The standard clock devices, described later in this chapter, provide clock stretching logic. During a clock stretch,  $\Phi_1$  and  $\Phi_2$  cannot be held constant for more than 9.5  $\mu$ sec; the MC6800 is a dynamic device, and longer static clock periods can result in loss of internal data.

During an internal operation's machine cycle, there is no activity on the System Bus. R/W is in its normal high state and VMA is low.

**Table 9-2 defines the way in which individual MC6800 instructions concatenate machine cycles and use the System Bus during the course of instruction execution.**

**MC6800 INTERNAL OPERATIONS MACHINE CYCLE**

The VMA and DBE signals require special mention, because their significance can easily be missed. External logic uses VMA as a signal identifying the address on the Address Bus as having been placed there by the CPU. DBE similarly identifies that portion of a machine cycle when the CPU is active at one end of the Data Bus, either transmitting or receiving data. And this is why these signals are so important: MC6800 microcomputer systems rely heavily on clock signal manipulation as a means of accommodating slow memories, implementing Direct Memory Access, or refreshing dynamic memory. On the next few pages we are going to see examples of how this is done. So long as you understand that the VMA and DBE signals identify the unmanipulated portions of a standard machine cycle, you will have no trouble locating the time slices within which special operations such as Direct Memory Access or dynamic memory refresh are occurring.

## THE HOLD STATE, THE HALT STATE AND DIRECT MEMORY ACCESS

The Hold state typically describes a CPU condition during which System Busses are floated, so that external logic can perform Direct Memory Access operations.

Though the MC6800 literature does not talk about a Hold state, this microprocessor does indeed have two equivalent conditions.

You can float the Address and Data Busses separately, using the TSC and DBE signals.

You can enter an MC6800 Halt state, which is equivalent to our definition of a Hold state.

Let us begin by looking at the use of TSC and DBE signals.

The Three State Control signal (TSC), if input high, will float the Address Bus and R/W line. VMA and BA are forced low. The unusual feature of the Three State Control input is that when this signal is input high, you must simultaneously stop the clock by holding  $\Phi_1$  high and  $\Phi_2$  low. Timing is illustrated in Figure 9-5. Now the MC6800, being a dynamic device, will lose its data contents if the clock is stopped for more than 9.5  $\mu$ sec. You must therefore float the Address Bus just long enough to perform a single Direct Memory Access.



Figure 9-5. TSC Floating the Address Bus

Just as the Three State Control input floats the Address Bus, so the Data Bus Enable input (DBE) floats the Data Bus. When DBE is input low, the Data Bus is floated.

The clock devices, which are described later in this chapter, provide all necessary clock stretching logic.

There are two very important points to note regarding the use of Three State Control (TSC) and Data Bus Enable (DBE) signals.

First of all, note carefully that the Bus Available (BA) signal is held low when the busses are floated by the Three State Control (TSC) and Data Bus Enable (DBE) signals. The purpose of the Bus Available signal is to indicate that the System Bus is available during a Halt or Wait state, both of which we have yet to describe.

The second important feature of the Three State Control (TSC) and Data Bus Enable (DBE) signals is that they do indeed float the System Bus in two halves. Now in many MC6800 systems  $\Phi_2$  and DBE are the same signal; in such a configuration you will automatically float the Data Bus whenever you float the Address Bus, as illustrated in Figure 9-6.

Now consider the MC6800 Halt state.

The Halt state of the MC6800 is equivalent to the Hold state of the 8080A. If a low  $\overline{\text{HALT}}$  is input to the MC6800, then upon conclusion of the current instruction's execution, the System Bus is floated. Timing is illustrated in Figure 9-7. Observe that the Bus Available signal, BA, is output high; VMA is output low. The Address and Data Busses, and the R/W control are floated.

In summary, the MC6800 provides two means of performing Direct Memory Access operations. You can use the TSC and DBE inputs to gain control of the System Bus for as long as it takes to perform a single DMA access, or you can use the  $\overline{\text{HALT}}$  input, following which external logic can gain control of the System Bus for as long as you wish.



Figure 9-6. TSC Floating the Address and Data Busses When DBE Is Tied to  $\Phi 2$

Conceptually, the MC6800 scheme for implementing Direct Memory Access or dynamic memory refresh, is very elegant. If you stretch the  $\Phi 1$  and  $\Phi 2$  clock signals, then you can transfer the normal CPU generated address, and an extraneous address within one machine cycle. VMA identifies the CPU generated address. Within the one machine cycle can perform two Data Bus transfers; the first is in response to the external address, while the second is in response to the CPU address. Now DBE identifies the CPU response. This scheme may be illustrated as follows:



From this conceptually elegant beginning, some very complex design considerations can arise. Complexities disappear, however, when standard 6800 support devices are used to implement direct memory access logic. Specifically, you should use the MC6875 clock device in conjunction with the 6844 Direct Memory Access controller.



Figure 9-7. System Bus Floating During the Halt State

## INTERRUPT PROCESSING, RESET AND THE WAIT STATE

MC6800 microcomputer system interrupt logic, as implemented within the 6800 CPU, is based on polling rather than vectoring. The MC6828 Priority Interrupt Control device, described later in this chapter, extends CPU interrupt logic to provide vectored interrupt response. All normal interrupt requests, when acknowledged, result in an indirect addressing Call to a single high memory address. If more than one device can request an interrupt, then the basic assumption made is that the interrupt service routine will initially read the Status register contents of every device that might be requesting an interrupt; and by testing appropriate status bits, the interrupt service routine will determine which interrupt requests are active. If more than one interrupt request is active, interrupt service routine logic must decide the order in which interrupt requests will be acknowledged.

**But be warned:** this type of polling quickly becomes untenable as a means of controlling microcomputer systems with multiple random interrupts. If you have more than two or three competing external interrupts, the time taken to read Status register contents and arbitrate priority will become excessive. If your application demands numerous external interrupts, then you must resort to external hardware which implements interrupt vectoring. We will describe ways in which this can be done.

If you casually look at a description of MC6800 interrupt logic, you may at first believe that some level of interrupt vectoring is provided. In reality, that is not the case.

The MC6800 sets aside the eight highest addressable memory locations for interrupt processing purposes. Four 16-bit addresses are stored in these eight memory locations, identifying the interrupt service routine's starting address for the four possible sources of interrupt. This is how the eight memory locations are used:

|               |                           |
|---------------|---------------------------|
| FFF8 and FFF9 | Normal external interrupt |
| FFFA and FFFB | Software interrupt        |
| FFFC and FFFD | Non-maskable interrupt    |
| FFFE and FFFF | Reset (or restart)        |

The lower address (FFF8, FFFA, FFFC, FFFE) holds the high order byte of the starting address.

In the event of simultaneous interrupt requests, this is the priority sequence during the acknowledge process:

- |         |                               |
|---------|-------------------------------|
| Highest | (1) Restart                   |
|         | (2) Non-maskable interrupt    |
|         | (3) Software interrupt        |
| Lowest  | (4) Normal external interrupt |

Only the lowest priority interrupt is normally used by the typical support device that is capable of requesting interrupt service. The three higher priority interrupt levels represent special conditions and cannot be accessed by the standard external interrupt request.

We will begin our discussion of MC6800 interrupt processing by describing the four interrupts.

The normal external interrupt request is the standard interrupt present on all microprocessors that support interrupts; it is equivalent to the 8080A INT input. In very simple systems, the addresses FFF8<sub>16</sub> and FFF9<sub>16</sub> may indeed access real memory locations; in the multiple interrupt MC6800 microcomputer systems, FFF9<sub>16</sub> is more likely to select an 8-bit buffer within which an address vector is stored identifying the interrupting source. This is essentially how the MC6828 Priority Interrupt Controller (PIC) works.

A software interrupt is initiated by the execution of the SWI instruction. What the SWI instruction does is cause the MC6800 to go through the complete logic of an interrupt request and acknowledge, even though the interrupting source is within the CPU. Software interrupts are typically used as a response to fatal errors occurring within program logic. Whenever your program logic encounters a situation that must not, or should not exist, the error condition is trapped by executing an SWI instruction; this causes a call to some general purpose, error recovery program.

The non-maskable interrupt cannot be disabled. Otherwise it is identical to the normal external interrupt request. Note that the 8080A has no non-maskable interrupt; however, the Zilog Z80 and the 8085 have incorporated this feature.

A Reset is treated as the highest priority interrupt in an MC6800. How does the Reset differ from the non-maskable interrupt? Conceptually, the non-maskable interrupt is going to be triggered by a termination condition such as power failure, while the Reset is going to be triggered by an initiating condition such as power being turned on.

There are some differences between the MC6800's response to a Reset as compared to any other interrupt request.

To contrast the two, we will look at the normal interrupt acknowledge sequence, and then we will look at a reset. Figure 9-8 illustrates MC6800 response to a normal external interrupt, a software interrupt, or a non-maskable interrupt. In each case, the interrupt request will be acknowledged upon completion of an instruction's execution. A normal external interrupt will only be acknowledged providing interrupts have been enabled.

If more than one interrupt request exists, then the highest priority interrupt will be acknowledged.

Following the interrupt acknowledge, normal interrupts are disabled by the CPU, which then pushes onto the Stack the contents of all internal registers. This process is illustrated in Figure 9-8. The Program Counter is then loaded with the appropriate interrupt service routine starting address, which will be fetched from memory locations FFF8<sub>16</sub> and FFF9<sub>16</sub>, FFFA<sub>16</sub> and FFFB<sub>16</sub> or FFFC<sub>16</sub> and FFFD<sub>16</sub>.

MC6800  
INTERRUPT  
PRIORITIES

MC6800  
NORMAL  
EXTERNAL  
INTERRUPTS

MC6800  
SWI  
INSTRUCTION

MC6800  
NON-MASKABLE  
INTERRUPT

MC6800  
RESET



Figure 9-8. MC6800 Interrupt Acknowledge Sequence

Referring to Figure 9-8, note that an interrupt is acknowledged following the last machine cycle for the instruction during which the interrupt request occurred. During the first two machine cycles following the interrupt acknowledgement, an instruction fetch is executed; as it would have been had the interrupt not occurred. This instruction fetch is aborted and will reoccur after the interrupt service routine has completed execution. Two machine cycles are expended performing this aborted instruction fetch.

Following the aborted instruction fetch, CPU registers' contents are pushed onto the Stack in the following order:

- Lower half of Program Counter
- Upper half of Program Counter
- Lower half of Index register
- Upper half of Index register
- Accumulator A
- Accumulator B
- Status register

When the 8080A acknowledges an interrupt, if CPU registers' contents are going to be saved on the Stack, you must execute individual instructions to perform the operations which the MC6800 performs automatically. The advantage of the MC6800's scheme is that it saves instruction execution time. The disadvantage of this scheme is that there are occasions when you do not need to bother saving registers' contents.

After all CPU registers' contents have been saved on the Stack, the next two machine cycles are used to fetch an address from the appropriate two high memory bytes. This address is loaded into the Program Counter, causing a branch to the appropriate interrupt service routine.



Figure 9-9. The Reset Sequence

### We will now examine the MC6800 Reset operation.

**Figure 9-9 illustrates Reset timing.** First of all, note that RESET must be held low for at least eight machine cycles to give the CPU sufficient response time. On the high-to-low transition of RESET the CPU outputs VMA and BA low and R/W is high. On the subsequent low-to-high transition of RESET, maskable interrupts are disabled, then the contents of memory locations FFFE<sub>16</sub> and FFFF<sub>16</sub> are fetched and loaded into the Program Counter. If RESET is not held low for a minimum of eight machine cycles, then when RESET is input high again, indeterminate program execution may follow.

**It is absolutely vital that the RESET rise time is less than 100 nanoseconds on the low-to-high transition of RESET.**

We stated that the difference between a Reset and a non-maskable interrupt is that the Reset represents initiation conditions. This is illustrated in Figure 9-9, which includes the power supply level. When power is first turned on, the MC6800 will automatically trigger a Reset when power increases above +4.75 volts; this is in response to the normal powering up sequence. The fact that Reset represents initiation conditions also explains why no CPU registers' contents are saved, as occurs with any other interrupt. Clearly, if we are initiating operations, there can be no prior registers' contents to be saved. Therefore pushing registers' contents on the Stack would be pointless and impossible: it would be pointless because there is nothing to save; it would be impossible because when powering up, we have no idea what the Stack Pointer contains.

**Powering up an MC6800 microcomputer system represents a special Reset case.** Those MC6800 microcomputer system devices that have an external Reset input control, expect this control to be held low while power is being turned on for the first eight clock cycles following power-up. When designing Reset logic be sure to keep this in mind.

MC6800 configurations using 8080A support devices are easy to design and commonly seen. Necessary system bus logic is described later in this chapter. But if you have such a mixed configuration, be sure to satisfy the separate and distinct Reset requirements of the MC6800 CPU as against the 8080A support devices.

### The MC6800 RESET OPERATION

### MC6800 RESET DURING POWER UP



Figure 9-10. MC6800 Wait Instruction Execution Sequence

We complete our discussion of the MC6800 interrupt logic with a discussion of the WAI instruction, which puts the MC6800 into a "Wait-for-interrupt" state.

A WAI instruction is executed when the CPU has nothing to do except wait for an interrupt. Rather than pushing registers' contents onto the Stack following the interrupt acknowledge, as illustrated in Figure 9-8, the WAI instruction pushes registers' contents onto the Stack while waiting for the interrupt, as illustrated in Figure 9-10. Thus some execution time is saved.

Once all registers' contents have been pushed onto the Stack, the MC6800 floats the System Bus in the Wait state.

This gives rise to another frequent use of the WAI instruction: block data transfers under DMA control.

Consider again the sequence of events which follows the WAI instruction execution:

- 1) All registers' contents are pushed onto the Stack.
- 2) The System Bus is floated.

**MC6800  
WAIT STATE**  
**MC6800  
WAI  
INSTRUCTION**

**MC6800  
USE OF  
WAIT FOR  
DMA**

This is very convenient if you are going to transfer a large block of data via DMA, because you will announce the end of the DMA transfer with an interrupt request. This method of handling block DMA transfers has been discussed in Volume I. Now when using an MC6800 microcomputer system, all you need to do is initiate the actual DMA transfer by executing a WAI instruction; knowing that once the DMA transfer has been completed, an interrupt will be requested and program execution can continue.

## THE MC6800 INSTRUCTION SET

Table 9-1 summarizes the MC6800 instruction set; this instruction set is characterized by a heavy use of read/write memory and a rich variety of instructions that are able to manipulate the contents of memory locations as though they were programmable registers. Whereas the primary memory reference instructions offer base page direct addressing, extended direct addressing or indexed addressing, secondary memory reference instructions offer extended direct addressing and indexed addressing only. This simply means that secondary memory reference instructions use three-byte direct addressing even when a base page byte must be accessed.

**Of the microcomputers described in this chapter, the MC6800 has one of the largest varieties of Branch-on-Condition instructions.** Note that these and the unconditional Branch instructions are the only MC6800 instructions which use program relative direct addressing.

**When comparing the MC6800 and 8080A instruction sets,** the conclusion we must draw is that the MC6800 is going to have to rely on a large number of memory reference instructions. You are going to have to set up programs with this in mind. As a result, relatively simple programs will make the MC6800 look better than the 8080A, because the MC6800 has such a diverse variety of memory reference instructions. The moment a program starts to become complicated, the large number of 8080A registers is quickly going to become an advantage, since the MC6800 will be forced to execute memory reference instructions where the 8080A can use register-register instructions.

**The SWI and WAI instructions within the interrupt instruction group are relatively unusual within microcomputer systems.**

The SWI instruction initiates a normal interrupt sequence, taking the interrupt service routine's starting address from memory locations FFFA16 and FFFF16.

The WAI instruction prepares for an interrupt by saving the contents of all registers and status on the Stack; the System Bus is then floated while the CPU waits for an interrupt request to occur.

**We have described both the SWI and WAI instructions in some detail earlier in this chapter.**

The one set of instructions which are missing, and which would greatly enhance the MC6800 instruction set, are instructions that move data between the Accumulator and the Index register, or allow Accumulator contents to be added to the Index register.

## THE BENCHMARK PROGRAM

The benchmark program is coded for the MC6800 as follows:

|      |        |                                                   |
|------|--------|---------------------------------------------------|
| STS  | SSP    | SAVE STACK POINTER CONTENTS IN MEMORY             |
| LDX  | #TABLE | LOAD TABLE BASE ADDRESS INTO INDEX REGISTER       |
| LDX  | 0,X    | LOAD ADDRESS OF FIRST FREE TABLE BYTE             |
| LDS  | #IOBUF | LOAD I/O BUFFER STARTING ADDRESS                  |
| LOOP | PULL   | A LOAD NEXT BYTE INTO A                           |
|      | STA    | 0,X STORE IN NEXT FREE TABLE BYTE                 |
|      | INX    | INCREMENT INDEX REGISTER                          |
|      | DEC    | IOCNT DECREMENT I/O BYTE COUNT IN MEMORY          |
|      | BNE    | LOOP RETURN FOR MORE BYTES                        |
|      | STX    | TABLE STORE NEW ADDRESS FOR FIRST FREE TABLE BYTE |
|      | LDS    | SSP RELOAD STACK POINTER                          |

The memory initialization for the MC6800 interpretation of the benchmark program is identical to the memory initialization for the 8080A benchmark program. The MC6800 assumes that there is some memory location in which the current real Stack address can be stored, so that the Stack Pointer may be used as a Data Counter.

In Table 9-1, symbols are used as follows:

ACX Either Accumulator A or Accumulator B

The registers:

|     |                 |
|-----|-----------------|
| A,B | Accumulator     |
| X   | Index register  |
| PC  | Program Counter |
| SP  | Stack Pointer   |
| SR  | Status register |

Statuses shown:

|    |                        |
|----|------------------------|
| C  | Carry status           |
| Z  | Zero status            |
| S  | Sign status            |
| O  | Overflow status        |
| I  | Interrupt status       |
| AC | Auxiliary Carry status |

Symbols in the STATUSES column:

|         |                                  |
|---------|----------------------------------|
| (blank) | operation does not affect status |
| X       | operation affects status         |
| 0       | flag is cleared by the operation |
| 1       | flag is set by the operation     |

|        |                                                                                                                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADR8   | An 8-bit (1-byte) quantity which may be used to directly address the first 256 locations in memory, or may be an 8-bit unsigned displacement to be added to the Index register. |
| ADR16  | A 16-bit memory address                                                                                                                                                         |
| B2     | Instruction Byte 2                                                                                                                                                              |
| B3     | Instruction Byte 3                                                                                                                                                              |
| DATA   | An 8-bit binary data unit                                                                                                                                                       |
| DATA16 | A 16-bit binary data unit                                                                                                                                                       |
| DISP   | An 8-bit signed binary address displacement                                                                                                                                     |
| xx(HI) | The high order 8 bits of the 16-bit quantity xx; for example, SP(HI) means bits 15 - 8 of the Stack Pointer.                                                                    |
| xx(LO) | The low order 8 bits of the 16-bit quantity xx; for example, PC(LO) means bits 7 - 0 of the Program Counter.                                                                    |
| [ ]    | Contents of location enclosed within brackets.                                                                                                                                  |
| [[ ]]  | Implied memory addressing: the contents of the memory location designated by the contents of a register.                                                                        |
| [MEM]  | Symbol for memory location indicated by base page direct, extended direct, or indexed addressing.<br>That is:                                                                   |
|        | [MEM] = [[ADR8]]                                                                                                                                                                |
|        | or                                                                                                                                                                              |
|        | [ADR16]                                                                                                                                                                         |
|        | or                                                                                                                                                                              |
|        | [[X]+ADR8]                                                                                                                                                                      |
| [M]    | Symbol for memory location indicated by extended direct or indexed addressing. That is:<br>[M]=[ADR16]                                                                          |
|        | or                                                                                                                                                                              |
|        | [[X]+ADR8]                                                                                                                                                                      |
| Λ      | Logical AND                                                                                                                                                                     |
| ∨      | Logical OR                                                                                                                                                                      |
| ⊖      | Logical Exclusive-OR                                                                                                                                                            |
| ←      | Data is transferred in the direction of the arrow.                                                                                                                              |

Table 9-1. A Summary of the MC6800 Instruction Set

| TYPE                                        | MNEMONIC | OPERAND(S)            | BYTES  | STATUS |   |   |   |                |   | OPERATION PERFORMED                                                                                                                                                                                                                  |
|---------------------------------------------|----------|-----------------------|--------|--------|---|---|---|----------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |                       |        | C      | Z | S | O | A <sub>C</sub> | I |                                                                                                                                                                                                                                      |
| PRIMARY MEMORY REFERENCE AND I/O            | LDA      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 |        | X | X | 0 |                |   | [ACX]—[MEM]<br>Load A or B using base page direct, extended direct, or indexed addressing.<br>[MEM]—[ACX]                                                                                                                            |
|                                             | STA      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 |        | X | X | 0 |                |   | Store A or B using direct, extended, or indexed addressing.                                                                                                                                                                          |
|                                             | LDX      | ADR8<br>ADR16         | 2<br>3 |        | X | X | 0 |                |   | [X(HI)]—[MEM], [X(LO)]—[MEM + 1]<br>Load Index register using direct, extended, or indexed addressing. Sign status reflects Index register bit 15.                                                                                   |
|                                             | STX      | ADR8<br>ADR16         | 2<br>3 |        | X | X | 0 |                |   | [MEM]—[X(HI)], [MEM + 1]—[X(LO)]<br>Store contents of Index register using direct, extended, or indexed addressing. Sign status reflects Index register bit 15.                                                                      |
|                                             | LDS      | ADR8<br>ADR16         | 2<br>3 |        | X | X | 0 |                |   | [SP(HI)]—[MEM], [SP(LO)]—[MEM + 1]<br>Load Stack Pointer using direct, extended, or indexed addressing. Sign status reflects Stack Pointer bit 15.                                                                                   |
|                                             | STS      | ADR8<br>ADR16         | 2<br>3 |        | X | X | 0 |                |   | [MEM]—[SP(HI)], [MEM + 1]—[SP(LO)]<br>Store contents of Stack Pointer using direct, extended, or indexed addressing. Sign status reflects Stack Pointer bit 15.                                                                      |
|                                             |          |                       |        |        |   |   |   |                |   |                                                                                                                                                                                                                                      |
| SECONDARY MEMORY REFERENCE (MEMORY OPERATE) | ADD      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 | X      | X | X | X | X              |   | [ACX]—[ACX] + [MEM]<br>Add to Accumulator A or B using base page direct, extended direct, or indexed addressing.                                                                                                                     |
|                                             | ADC      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 | X      | X | X | X | X              |   | [ACX]—[ACX] + [MEM] + C<br>Add with carry to Accumulator A or B using direct, extended, or indexed addressing.                                                                                                                       |
|                                             | AND      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 |        | X | X | 0 |                |   | [ACX]—[ACX] $\wedge$ [MEM]<br>AND with Accumulator A or B using direct, extended, or indexed addressing.                                                                                                                             |
|                                             | BIT      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 |        | X | X | 0 |                |   | [ACX] $\wedge$ [MEM]<br>AND with Accumulator A or B, but only Status register is affected.                                                                                                                                           |
|                                             | CMP      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 | X      | X | X | X |                |   | [ACX] - [MEM]<br>Compare with Accumulator A or B (only Status register is affected).                                                                                                                                                 |
|                                             | EOR      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 |        | X | X | 0 |                |   | [ACX]—[ACX] $\vee$ [MEM]<br>Exclusive-OR with Accumulator A or B using direct, extended, or indexed addressing.                                                                                                                      |
|                                             | ORA      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 |        | X | X | 0 |                |   | [ACX]—[ACX] V [MEM]<br>OR with Accumulator A or B using direct, extended, or indexed addressing.                                                                                                                                     |
|                                             | SUB      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 | X      | X | X | X |                |   | [ACX]—[ACX] - [MEM]<br>Subtract from Accumulator A or B using direct, extended, or indexed addressing.                                                                                                                               |
|                                             | SBC      | ACX,ADR8<br>ACX,ADR16 | 2<br>3 | X      | X | X | X |                |   | [ACX]—[ACX] - [MEM] - C<br>Subtract with carry from Accumulator A or B using direct, extended, or indexed addressing.                                                                                                                |
|                                             | CPX      | ADR8<br>ADR16         | 2<br>3 |        | X | X | X |                |   | [X(HI)] - [MEM], [X(LO)] - [MEM + 1]<br>Compare with contents of Index register (only Status register is affected). Sign and Overflow statuses reflect result on most significant byte.                                              |
|                                             | CLR      | ADR8<br>ADR16         | 2<br>3 | 0      | 1 | 0 | 0 |                |   | [M]—00 <sub>16</sub><br>Clear memory location using extended or indexed addressing.                                                                                                                                                  |
|                                             | COM      | ADR8<br>ADR16         | 2<br>3 | 1      | X | X | 0 |                |   | [M]—[M]<br>Complement contents of memory location (ones complement).                                                                                                                                                                 |
|                                             | NEG      | ADR8<br>ADR16         | 2<br>3 | X      | X | X | X |                |   | [M]—00 <sub>16</sub> - [M]<br>Negate contents of memory location (twos complement). Carry status is set if result is 00 <sub>16</sub> and reset otherwise. Overflow status is set if result is 80 <sub>16</sub> and reset otherwise. |

| TYPE                                                     | MNEMONIC | OPERAND(S)    | BYTES  | STATUS |   |   |   |                |   | OPERATION PERFORMED                                                                                                                                                                       |
|----------------------------------------------------------|----------|---------------|--------|--------|---|---|---|----------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                          |          |               |        | C      | Z | S | O | A <sub>C</sub> | I |                                                                                                                                                                                           |
| SECONDARY MEMORY REFERENCE (MEMORY OPERATE)<br>CONTINUED | DEC      | ADR8<br>ADR16 | 2<br>3 |        | X | X | X |                |   | [M]—[M]-1<br>Decrement contents of memory location, using extended or indexed addressing. Overflow status is set if operand was 80 <sub>16</sub> before execution, and cleared otherwise. |
|                                                          | INC      | ADR8<br>ADR16 | 2<br>3 |        | X | X | X |                |   | [M]—[M]+1<br>Increment contents of memory location, using extended or indexed addressing. Overflow status is set if operand was 7F <sub>16</sub> before execution, and cleared otherwise. |
|                                                          | ROL      | ADR8<br>ADR16 | 2<br>3 | X      | X | X | X |                |   | <br>Rotate contents of memory location left through carry.                                              |
|                                                          | ROR      | ADR8<br>ADR16 | 2<br>3 | X      | X | X | X |                |   | <br>Rotate contents of memory location right through carry.                                             |
|                                                          | ASL      | ADR8<br>ADR16 | 2<br>3 | X      | X | X | X |                |   | <br>Arithmetic shift left. Bit 0 is set to 0.                                                           |
|                                                          | ASR      | ADR8<br>ADR16 | 2<br>3 | X      | X | X | X |                |   | <br>Arithmetic shift right. Bit 7 stays the same.                                                       |
|                                                          | LSR      | ADR8<br>ADR16 | 2<br>3 | X      | X | 0 | X |                |   | <br>Logical shift right. Bit 7 is set to 0.                                                             |
|                                                          | TST      | ADR8<br>ADR16 | 2<br>3 | 0      | X | X | 0 |                |   | [M] - 00 <sub>16</sub><br>Test contents of memory location for zero or negative value.                                                                                                    |
|                                                          | LDA      | ACX,DATA      | 2      |        | X | X | 0 |                |   | [ACX]—DATA<br>Load A or B immediate.                                                                                                                                                      |
| IMMEDIATE OPERATE                                        | LDX      | DATA16        | 3      |        | X | X | 0 |                |   | [X(H)]—[B2], [X(L)]—[B3]<br>Load Index register immediate. Sign status reflects Index register bit 15.                                                                                    |
|                                                          | LDS      | DATA16        | 3      |        | X | X | 0 |                |   | [SP(H)]—[B2], [X(L)]—[B3]<br>Load Stack Pointer immediate. Sign status reflects Stack Pointer bit 15.                                                                                     |
|                                                          | ADD      | ACX,DATA      | 2      | X      | X | X | X | X              |   | [ACX]—[ACX]+DATA<br>Add immediate to Accumulator A or B.                                                                                                                                  |
|                                                          | ADC      | ACX,DATA      | 2      | X      | X | X | X | X              |   | [ACX]—[ACX]+DATA+C<br>Add immediate with carry to Accumulator A or B.                                                                                                                     |
|                                                          | AND      | ACX,DATA      | 2      |        | X | X | 0 |                |   | [ACX]—[ACX] $\wedge$ DATA<br>AND immediate with Accumulator A or B.                                                                                                                       |

Table 9-1. A Summary of the MC6800 Instruction Set (Continued)

| TYPE                             | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |    |   | OPERATION PERFORMED                                                                                                                                                                           |
|----------------------------------|----------|------------|-------|--------|---|---|---|----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  |          |            |       | C      | Z | S | O | AC | I |                                                                                                                                                                                               |
| IMMEDIATE OPERATE<br>(CONTINUED) | BIT      | ACX,DATA   | 2     |        | X | X | 0 |    |   | [ACX] A DATA<br>AND immediate with Accumulator A or B, but only the Status register is affected.                                                                                              |
|                                  | CMP      | ACX,DATA   | 2     | X      | X | X | X |    |   | [ACX] - DATA<br>Compare immediate with Accumulator A or B (only the Status register is affected).                                                                                             |
|                                  | EOR      | ACX,DATA   | 2     |        | X | X | 0 |    |   | [ACX] - [ACX] V DATA<br>Exclusive-OR immediate with Accumulator A or B.                                                                                                                       |
|                                  | ORA      | ACX,DATA   | 2     |        | X | X | 0 |    |   | [ACX] - [ACX] V DATA<br>OR immediate with Accumulator A or B.                                                                                                                                 |
|                                  | SUB      | ACX,DATA   | 2     | X      | X | X | X |    |   | [ACX] - [ACX] - DATA<br>Subtract immediate from Accumulator A or B.                                                                                                                           |
|                                  | SBC      | ACX,DATA   | 2     | X      | X | X | X |    |   | [ACX] - [ACX] - DATA<br>Subtract immediate with carry from Accumulator A or B.                                                                                                                |
|                                  | CPX      | DATA16     | 3     |        | X | X | X |    |   | [X(HI)] - [B2], [X(LO)] - [B3]<br>Compare immediate with contents of Index register (only the Status register is affected). Sign and Overflow status reflect result on most significant byte. |
| JUMP                             | JMP      | ADR8       | 2     |        |   |   |   |    |   | [PC] - [X] + ADR8 or<br>[PC(HI)] - [B2], [PC(LO)] - [B3]                                                                                                                                      |
|                                  |          | ADR16      | 3     |        |   |   |   |    |   | Jump to indexed or extended address.<br>[[SP]] - [PC(LO)], [[SP]-1] - [PC(HI)], [SP] - [SP]-2                                                                                                 |
|                                  | JSR      | ADR8       | 2     |        |   |   |   |    |   | [PC] - [X] + ADR8 or<br>[PC(HI)] - [B2], [PC(LO)] - [B3]                                                                                                                                      |
|                                  |          | ADR16      | 3     |        |   |   |   |    |   | Jump to subroutine (indexed or extended addressing).<br>[PC] - [PC] + DISP + 2                                                                                                                |
| BRA                              |          | DISP       | 2     |        |   |   |   |    |   | Unconditional branch relative to present Program Counter contents.                                                                                                                            |
|                                  | BRA      | DISP       | 2     |        |   |   |   |    |   | [[SP]] - [PC(LO)], [[SP]-1] - [PC(HI)], [SP] - [SP]-2,<br>[PC] - [PC] + DISP + 2                                                                                                              |
| BRANCH ON CONDITION              | BSR      | DISP       | 2     |        |   |   |   |    |   | Unconditional branch to subroutine located relative to present Program Counter contents.                                                                                                      |
|                                  | BCC      | DISP       | 2     |        |   |   |   |    |   | [PC] - [PC] + DISP + 2 if the given condition is true:                                                                                                                                        |
|                                  | BCS      | DISP       | 2     |        |   |   |   |    |   | C = 0 (Branch if carry clear)                                                                                                                                                                 |
|                                  | BEQ      | DISP       | 2     |        |   |   |   |    |   | C = 1 (Branch if carry set)                                                                                                                                                                   |
|                                  | BGE      | DISP       | 2     |        |   |   |   |    |   | Z = 1 (Branch if equal to zero)                                                                                                                                                               |
|                                  | BGT      | DISP       | 2     |        |   |   |   |    |   | S V O = 0 (Branch if greater than or equal to zero)                                                                                                                                           |
|                                  | BHI      | DISP       | 2     |        |   |   |   |    |   | Z V (S V O) = 0 (Branch if greater than zero)                                                                                                                                                 |
|                                  | BLE      | DISP       | 2     |        |   |   |   |    |   | C V Z = 0 (Branch if Accumulator contents higher than comparand)                                                                                                                              |
|                                  | BLS      | DISP       | 2     |        |   |   |   |    |   | Z V (S V O) = 1 (Branch if less than or equal to zero)                                                                                                                                        |
|                                  | BLT      | DISP       | 2     |        |   |   |   |    |   | C V Z = 1 (Branch if Accumulator contents less than or same as comparand)                                                                                                                     |
|                                  | BMI      | DISP       | 2     |        |   |   |   |    |   | S V O = 1 (Branch if less than zero)                                                                                                                                                          |
|                                  | BNE      | DISP       | 2     |        |   |   |   |    |   | S = 1 (Branch if minus)                                                                                                                                                                       |
|                                  | BVC      | DISP       | 2     |        |   |   |   |    |   | Z = 0 (Branch if not equal to zero)                                                                                                                                                           |
|                                  | BVS      | DISP       | 2     |        |   |   |   |    |   | O = 0 (Branch if overflow clear)                                                                                                                                                              |
|                                  | BPL      | DISP       | 2     |        |   |   |   |    |   | O = 1 (Branch if overflow set)                                                                                                                                                                |
|                                  |          |            |       |        |   |   |   |    |   | S = 0 (Branch if plus)                                                                                                                                                                        |

Table 9-1. A Summary of the MC6800 Instruction Set (Continued)

| TYPE                      | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |    |   | OPERATION PERFORMED                                                                                                                                                                                                                        |
|---------------------------|----------|------------|-------|--------|---|---|---|----|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           |          |            |       | C      | Z | S | O | Ac | I |                                                                                                                                                                                                                                            |
| REGISTER-REGISTER MOVE    | TAB      |            | 1     |        | X | X | 0 |    |   | [B]—[A]<br>Move Accumulator A contents to Accumulator B.                                                                                                                                                                                   |
|                           | TBA      |            | 1     |        | X | X | 0 |    |   | [A]—[B]<br>Move Accumulator B contents to Accumulator A.                                                                                                                                                                                   |
|                           | TXS      |            | 1     |        |   |   |   |    |   | [SP]—[X]-1<br>Move Index register contents to Stack Pointer and decrement.                                                                                                                                                                 |
|                           | TSX      |            | 1     |        |   |   |   |    |   | [X]—[SP]+1<br>Move Stack Pointer contents to Index register and increment.                                                                                                                                                                 |
| REGISTER REGISTER OPERATE | ABA      |            | 1     | X      | X | X | X | X  |   | [A]—[A]+[B]<br>Add contents of Accumulators A and B.                                                                                                                                                                                       |
|                           | CBA      |            | 1     | X      | X | X | X | X  |   | [A]—[B]<br>Compare contents of Accumulators A and B. Only the Status register is affected.                                                                                                                                                 |
|                           | SBA      |            | 1     | X      | X | X | X | X  |   | [A]—[A]-[B]<br>Subtract contents of Accumulator B from those of Accumulator A.                                                                                                                                                             |
| REGISTER OPERATE          | CLR      | ACX        | 1     | 0      | 1 | 0 | 0 |    |   | [ACX]—00 <sub>16</sub><br>Clear Accumulator A or B.                                                                                                                                                                                        |
|                           | COM      | ACX        | 1     | 1      | X | X | 0 |    |   | [ACX]—[ACX]<br>Complement contents of Accumulator A or B (ones complement).                                                                                                                                                                |
|                           | NEG      | ACX        | 1     | X      | X | X | X |    |   | [ACX]—00 <sub>16</sub> -[ACX]<br>Negate contents of Accumulator A or B (twos complement). Carry status is set if result is 00 <sub>16</sub> and reset otherwise. Overflow status is set if result is 80 <sub>16</sub> and reset otherwise. |
|                           | DAA      |            | 1     | X      | X | X | X | X  |   | Decimal adjust A. Convert contents of A (the binary sum of BCD operands) to BCD format. Carry status is set if value of upper four bits is greater than 9, but not cleared if previously set.                                              |
|                           | DEC      | ACX        | 1     |        | X | X | X | X  |   | [ACX]—[ACX]-1<br>Decrement contents of Accumulator A or B. Overflow status is set if operand was 80 <sub>16</sub> before execution, and cleared otherwise.                                                                                 |
|                           | DEX      |            | 1     |        | X |   |   |    |   | [X]—[X]-1<br>Decrement contents of Index register.                                                                                                                                                                                         |
|                           | DES      |            | 1     |        |   |   |   |    |   | [SP]—[SP]-1<br>Decrement contents of Stack Pointer.                                                                                                                                                                                        |
|                           | INC      | ACX        | 1     |        | X | X | X |    |   | [ACX]—[ACX]+1<br>Increment contents of Accumulator A or B. Overflow status is set if operand was 7F <sub>16</sub> before execution, and cleared otherwise.                                                                                 |
|                           | INX      |            | 1     |        | X |   |   |    |   | [X]—[X]+1<br>Increment contents of Index register.                                                                                                                                                                                         |
|                           | INS      |            | 1     |        |   |   |   |    |   | [SP]—[SP]+1<br>Increment contents of Stack Pointer.                                                                                                                                                                                        |
|                           | ROL      | ACX        | 1     | X      | X | X | X | X  |   | <br>Rotate Accumulator A or B left through carry.                                                                                                      |

Table 9-1. A Summary of the MC6800 Instruction Set (Continued)

| TYPE                         | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |                |   |                                                                                                                                                                         | OPERATION PERFORMED                                                                |
|------------------------------|----------|------------|-------|--------|---|---|---|----------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
|                              |          |            |       | C      | Z | S | O | A <sub>C</sub> | I |                                                                                                                                                                         |                                                                                    |
| REGISTER OPERATE (CONTINUED) | ROR      | ACX        | 1     | X      | X | X | X |                |   | <br>[ACX]                                                                             | O ← S + C                                                                          |
|                              | ASL      | ACX        | 1     | X      | X | X | X |                |   | <br>[ACX]                                                                             | O ← S + C                                                                          |
|                              | ASR      | ACX        | 1     | X      | X | X | X |                |   | <br>[ACX]                                                                             | O ← S + C                                                                          |
|                              | LSR      | ACX        | 1     | X      | X | 0 | X |                |   | <br>[ACX]                                                                             | O ← S + C                                                                          |
|                              | TST      | ACX        | 1     | 0      | X | X | 0 |                |   | [ACX] - 00 <sub>16</sub>                                                                                                                                                | Logical shift right. Bit 7 is set to 0.                                            |
| STACK                        | PSH      | ACX        | 1     |        |   |   |   |                |   | [SP] → [ACX]<br>[SP] → [SP] - 1                                                                                                                                         | Push contents of Accumulator A or B onto top of Stack and decrement Stack Pointer. |
|                              | PUL      | ACX        | 1     |        |   |   |   |                |   | [SP] → [SP] + 1<br>[ACX] → [SP]                                                                                                                                         | Increment Stack Pointer and pull Accumulator A or B from top of Stack.             |
|                              | RTS      |            | 1     |        |   |   |   |                |   | [PC(HI)] → [SP] + 1, [PC(LO)] → [SP] + 2, [SP] → [SP] + 2                                                                                                               | Return from subroutine. Pull PC from top of Stack and increment Stack Pointer.     |
| INTERRUPT                    | CLI      |            | 1     |        |   |   |   | 0              |   | I → 0                                                                                                                                                                   | Clear interrupt mask to enable interrupts.                                         |
|                              | SEI      |            | 1     |        |   |   |   | 1              |   | I → 1                                                                                                                                                                   | Set interrupt mask to disable interrupts.                                          |
|                              | RTI      |            | 1     | X      | X | X | X | X              |   | [SR] → [SP] + 1,<br>[B] → [SP] + 2,<br>[A] → [SP] + 3,<br>[X(HI)] → [SP] + 4,<br>[X(LO)] → [SP] + 5,<br>[PC(HI)] → [SP] + 6,<br>[PC(LO)] → [SP] + 7,<br>[SP] → [SP] + 7 | Return from interrupt. Pull registers from Stack and increment Stack Pointer.      |

Table 9-1. A Summary of the MC6800 Instruction Set (Continued)

## MC6800 SUMMARY OF CYCLE BY CYCLE OPERATION

This table provides a detailed description of the information present on the Address Bus, Data Bus, Valid Memory Address line (VMA), and the Read/Write line (R/W) during each cycle for each instruction.

This information is useful in comparing actual with expected results during debug of both software and hardware as the control program is executed. The information is categorized in groups according to Addressing Mode and Number of Cycles per instruction. (In general, instructions with the same Addressing Mode and Number of Cycles execute in the same manner; exceptions are indicated in the table.)

Table 9-2. Operation Summary

|           | ADDRESS MODE<br>AND<br>INSTRUCTIONS                        | CYCLES | CYCLE<br>NO.                         | VMA<br>LINE                                   | ADDRESS BUS                                                                                                                                                                                      | R/W<br>LINE                          | DATA BUS                                                                                                                                                                                                 |
|-----------|------------------------------------------------------------|--------|--------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IMMEDIATE | ADC EOR<br>ADD LDA<br>AND ORA<br>BIT SBC<br>CMP SUB        | 2      | 1                                    | 1                                             | Op Code Address<br>Op Code Address + 1                                                                                                                                                           | 1<br>1                               | Op Code<br>Operand Data                                                                                                                                                                                  |
|           | CPX<br>LDS<br>LDX                                          |        | 1<br>2<br>3                          | 1<br>1<br>1                                   | Op Code Address<br>Op Code Address + 1<br>Op Code Address + 2                                                                                                                                    | 1<br>1<br>1                          | Op Code<br>Operand Data (High Order Byte)<br>Operand Data (Low Order Byte)                                                                                                                               |
| DIRECT    | ADC EOR<br>ADD LDA<br>AND ORA<br>BIT SBC<br>CMP SUB        | 3      | 1<br>2<br>3                          | 1<br>1<br>1                                   | Op Code Address<br>Op Code Address + 1<br>Address of Operand                                                                                                                                     | 1<br>1<br>1                          | Op Code<br>Address of Operand<br>Operand Data                                                                                                                                                            |
|           | CPX<br>LDS<br>LDX                                          |        | 1<br>2<br>3<br>4                     | 1<br>1<br>1<br>1                              | Op Code Address<br>Op Code Address + 1<br>Address of Operand<br>Operand Address + 1                                                                                                              | 1<br>1<br>1<br>1                     | Op Code<br>Address of Operand<br>Operand Data (High Order Byte)<br>Operand Data (Low Order Byte)                                                                                                         |
| INDEXED   | STA                                                        | 4      | 1<br>2<br>3<br>4                     | 1<br>1<br>0<br>1                              | Op Code Address<br>Op Code Address + 1<br>Destination Address<br>Destination Address                                                                                                             | 1<br>1<br>1<br>0                     | Op Code<br>Destination Address<br>Irrelevant Data (Note 1)<br>Data from Accumulator                                                                                                                      |
|           | STS<br>STX                                                 |        | 1<br>2<br>3<br>4<br>5                | 1<br>1<br>0<br>1<br>1                         | Op Code Address<br>Op Code Address + 1<br>Address of Operand<br>Address of Operand<br>Address of Operand + 1                                                                                     | 1<br>1<br>1<br>0<br>0                | Op Code<br>Address of Operand<br>Irrelevant Data (Note 1)<br>Register Data (High Order Byte)<br>Register Data (Low Order Byte)                                                                           |
| INDEXED   | JMP                                                        | 4      | 1<br>2<br>3<br>4                     | 1<br>1<br>0<br>0                              | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Index Register Plus Offset (w/o Carry)                                                                                               | 1<br>1<br>1<br>1                     | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)                                                                                                                                |
|           | ADC EOR<br>ADD LDA<br>AND ORA<br>BIT SBC<br>CMP SUB        |        | 1<br>2<br>3<br>4<br>5                | 1<br>1<br>0<br>0<br>1                         | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Index Register Plus Offset (w/o Carry)<br>Index Register Plus Offset                                                                 | 1<br>1<br>1<br>1<br>1                | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Operand Data                                                                                                                |
| INDEXED   | CPX<br>LDS<br>LDX                                          | 6      | 1<br>2<br>3<br>4<br>5<br>6           | 1<br>1<br>0<br>0<br>1<br>1                    | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Index Register Plus Offset (w/o Carry)<br>Index Register Plus Offset<br>Index Register Plus Offset + 1                               | 1<br>1<br>1<br>1<br>1<br>1           | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Operand Data (High Order Byte)<br>Operand Data (Low Order Byte)                                                             |
|           | STA                                                        |        | 1<br>2<br>3<br>4<br>5<br>6           | 1<br>1<br>0<br>0<br>0<br>1                    | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Index Register Plus Offset (w/o Carry)<br>Index Register Plus Offset<br>Index Register Plus Offset                                   | 1<br>1<br>1<br>1<br>1<br>0           | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Operand Data                                                                                    |
| INDEXED   | ASL LSR<br>ASR NEG<br>CLR ROL<br>COM ROR<br>DEC TST<br>INC | 7      | 1<br>2<br>3<br>4<br>5<br>6<br>7      | 1<br>1<br>0<br>0<br>1<br>0<br>1/0<br>(Note 3) | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Index Register Plus Offset (w/o Carry)<br>Index Register Plus Offset<br>Index Register Plus Offset<br>Index Register Plus Offset     | 1<br>1<br>1<br>1<br>1<br>1<br>0      | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Current Operand Data<br>Irrelevant Data (Note 1)<br>New Operand Data (Note 3)                                               |
|           | STS<br>STX                                                 |        | 1<br>2<br>3<br>4<br>5<br>6<br>7      | 1<br>1<br>0<br>0<br>0<br>1<br>1               | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Index Register Plus Offset (w/o Carry)<br>Index Register Plus Offset<br>Index Register Plus Offset<br>Index Register Plus Offset + 1 | 1<br>1<br>1<br>1<br>1<br>1<br>0      | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Operand Data (High Order Byte)<br>Operand Data (Low Order Byte)                                 |
| INDEXED   | JSR                                                        | 8      | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8 | 1<br>1<br>0<br>1<br>1<br>0<br>0<br>0          | Op Code Address<br>Op Code Address + 1<br>Index Register<br>Stack Pointer<br>Stack Pointer - 1<br>Stack Pointer - 2<br>Index Register<br>Index Register Plus Offset (w/o Carry)                  | 1<br>1<br>1<br>0<br>0<br>1<br>1<br>1 | Op Code<br>Offset<br>Irrelevant Data (Note 1)<br>Return Address (Low Order Byte)<br>Return Address (High Order Byte)<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1)<br>Irrelevant Data (Note 1) |

Table 9-2. Operation Summary (Continued)

|                   | ADDRESS MODE<br>AND<br>INSTRUCTIONS                                                                                             | CYCLES | CYCLE<br>NO. | VMA<br>LINE     | ADDRESS BUS                 | R/W<br>LINE | DATA BUS                                |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|--------|--------------|-----------------|-----------------------------|-------------|-----------------------------------------|
| EXTENDED          | JMP                                                                                                                             | 3      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Jump Address (High Order Byte)          |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Jump Address (Low Order Byte)           |
|                   | ADC EOR<br>ADD LDA<br>AND ORA<br>BIT SBC<br>CMP SUB                                                                             | 4      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Address of Operand (High Order Byte)    |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Address of Operand (Low Order Byte)     |
|                   |                                                                                                                                 |        | 4            | 1               | Address of Operand          | 1           | Operand Data                            |
|                   | CPX<br>LDS<br>LDX                                                                                                               | 5      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Address of Operand (High Order Byte)    |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Address of Operand (Low Order Byte)     |
|                   |                                                                                                                                 |        | 4            | 1               | Address of Operand          | 1           | Operand Data (High Order Byte)          |
|                   |                                                                                                                                 |        | 5            | 1               | Address of Operand + 1      | 1           | Operand Data (Low Order Byte)           |
|                   | STA A<br>STA B                                                                                                                  | 5      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Destination Address (High Order Byte)   |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Destination Address (Low Order Byte)    |
|                   |                                                                                                                                 |        | 4            | 0               | Operand Destination Address | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 5            | 1               | Operand Destination Address | 0           | Data from Accumulator                   |
|                   | ASL LSR<br>ASR NEG<br>CLR ROL<br>COM ROR<br>DEC TST<br>INC                                                                      | 6      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Address of Operand (High Order Byte)    |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Address of Operand (Low Order Byte)     |
|                   |                                                                                                                                 |        | 4            | 1               | Address of Operand          | 1           | Current Operand Data                    |
|                   |                                                                                                                                 |        | 5            | 0               | Address of Operand          | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 6            | 1/0<br>(Note 3) | Address of Operand          | 0           | New Operand Data (Note 3)               |
|                   | STS<br>STX                                                                                                                      | 6      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Address of Operand (High Order Byte)    |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Address of Operand (Low Order Byte)     |
|                   |                                                                                                                                 |        | 4            | 0               | Address of Operand          | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 5            | 1               | Address of Operand          | 0           | Operand Data (High Order Byte)          |
|                   |                                                                                                                                 |        | 6            | 1               | Address of Operand + 1      | 0           | Operand Data (Low Order Byte)           |
|                   | JSR                                                                                                                             | 9      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Address of Subroutine (High Order Byte) |
|                   |                                                                                                                                 |        | 3            | 1               | Op Code Address + 2         | 1           | Address of Subroutine (Low Order Byte)  |
|                   |                                                                                                                                 |        | 4            | 1               | Subroutine Starting Address | 1           | Op Code of Next Instruction             |
|                   |                                                                                                                                 |        | 5            | 1               | Stack Pointer               | 0           | Return Address (Low Order Byte)         |
|                   |                                                                                                                                 |        | 6            | 1               | Stack Pointer - 1           | 0           | Return Address (High Order Byte)        |
|                   |                                                                                                                                 |        | 7            | 0               | Stack Pointer - 2           | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 8            | 0               | Op Code Address + 2         | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 9            | 1               | Op Code Address + 2         | 1           | Address of Subroutine (Low Order Byte)  |
| REGISTER-REGISTER | ABA DAA SEC<br>ASL DEC SEI<br>ASR INC SEV<br>CBA LSR TAB<br>CLC NEG TAP<br>CLI NOP TBA<br>CLR ROL TPA<br>CLV ROR TST<br>COM SBA | 2      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Op Code of Next Instruction             |
|                   | DES DEX<br>INS INX                                                                                                              | 4      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Op Code of Next Instruction             |
|                   |                                                                                                                                 |        | 3            | 0               | Previous Register Contents  | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 4            | 0               | New Register Contents       | 1           | Irrelevant Data (Note 1)                |
|                   | PSH                                                                                                                             | 4      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Op Code of Next Instruction             |
|                   |                                                                                                                                 |        | 3            | 1               | Stack Pointer               | 0           | Accumulator Data                        |
|                   |                                                                                                                                 |        | 4            | 0               | Stack Pointer - 1           | 1           | Accumulator Data                        |
|                   | PUL                                                                                                                             | 4      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Op Code of Next Instruction             |
|                   |                                                                                                                                 |        | 3            | 0               | Stack Pointer               | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 4            | 1               | Stack Pointer + 1           | 1           | Operand Data from Stack                 |
|                   | TSX                                                                                                                             | 4      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Op Code of Next Instruction             |
|                   |                                                                                                                                 |        | 3            | 0               | Stack Pointer               | 1           | Irrelevant Data (Note 1)                |
|                   |                                                                                                                                 |        | 4            | 0               | New Index Register          | 1           | Irrelevant Data (Note 1)                |
|                   | TXS                                                                                                                             | 4      | 1            | 1               | Op Code Address             | 1           | Op Code                                 |
|                   |                                                                                                                                 |        | 2            | 1               | Op Code Address + 1         | 1           | Op Code of Next Instruction             |
|                   |                                                                                                                                 |        | 3            | 0               | Index Register              | 1           | Irrelevant Data                         |
|                   |                                                                                                                                 |        | 4            | 0               | New Stack Pointer           | 1           | Irrelevant Data                         |

Table 9-2. Operation Summary (Continued)

|                               | ADDRESS MODE<br>AND<br>INSTRUCTIONS                                     | CYCLES | CYCLE<br>NO. | VMA<br>LINE | ADDRESS BUS                    | R/W<br>LINE | DATA BUS                                              |
|-------------------------------|-------------------------------------------------------------------------|--------|--------------|-------------|--------------------------------|-------------|-------------------------------------------------------|
| REGISTER REGISTER (CONTINUED) | RTS                                                                     | 5      | 1            | 1           | Op Code Address                | 1           | Op Code                                               |
|                               |                                                                         |        | 2            | 1           | Op Code Address + 1            | 1           | Irrelevant Data (Note 2)                              |
|                               |                                                                         |        | 3            | 0           | Stack Pointer                  | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 4            | 1           | Stack Pointer + 1              | 1           | Address of Next Instruction (High Order Byte)         |
|                               |                                                                         |        | 5            | 1           | Stack Pointer + 2              | 1           | Address of Next Instruction (Low Order Byte)          |
|                               | WAI                                                                     | 9      | 1            | 1           | Op Code Address                | 1           | Op Code                                               |
|                               |                                                                         |        | 2            | 1           | Op Code Address + 1            | 1           | Op Code of Next Instruction                           |
|                               |                                                                         |        | 3            | 1           | Stack Pointer                  | 0           | Return Address (Low Order Byte)                       |
|                               |                                                                         |        | 4            | 1           | Stack Pointer - 1              | 0           | Return Address (High Order Byte)                      |
|                               |                                                                         |        | 5            | 1           | Stack Pointer - 2              | 0           | Index Register (Low Order Byte)                       |
|                               |                                                                         |        | 6            | 1           | Stack Pointer - 3              | 0           | Index Register (High Order Byte)                      |
|                               |                                                                         |        | 7            | 1           | Stack Pointer - 4              | 0           | Contents of Accumulator A                             |
|                               |                                                                         |        | 8            | 1           | Stack Pointer - 5              | 0           | Contents of Accumulator B                             |
|                               |                                                                         |        | 9            | 1           | Stack Pointer - 6 (Note 4)     | 1           | Contents of Cond. Code Register                       |
|                               | RTI                                                                     | 10     | 1            | 1           | Op Code Address                | 1           | Op Code                                               |
|                               |                                                                         |        | 2            | 1           | Op Code Address + 1            | 1           | Irrelevant Data (Note 2)                              |
|                               |                                                                         |        | 3            | 0           | Stack Pointer                  | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 4            | 1           | Stack Pointer + 1              | 1           | Contents of Cond. Code Register from Stack            |
|                               |                                                                         |        | 5            | 1           | Stack Pointer + 2              | 1           | Contents of Accumulator B from Stack                  |
|                               |                                                                         |        | 6            | 1           | Stack Pointer + 3              | 1           | Contents of Accumulator A from Stack                  |
|                               |                                                                         |        | 7            | 1           | Stack Pointer + 4              | 1           | Index Register from Stack (High Order Byte)           |
|                               |                                                                         |        | 8            | 1           | Stack Pointer + 5              | 1           | Index Register from Stack (Low Order Byte)            |
|                               |                                                                         |        | 9            | 1           | Stack Pointer + 6              | 1           | Next Instruction Address from Stack (High Order Byte) |
|                               |                                                                         |        | 10           | 1           | Stack Pointer + 7              | 1           | Next Instruction Address from Stack (Low Order Byte)  |
|                               | SWI                                                                     | 12     | 1            | 1           | Op Code Address                | 1           | Op Code                                               |
|                               |                                                                         |        | 2            | 1           | Op Code Address + 1            | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 3            | 1           | Stack Pointer                  | 0           | Return Address (Low Order Byte)                       |
|                               |                                                                         |        | 4            | 1           | Stack Pointer - 1              | 0           | Return Address (High Order Byte)                      |
|                               |                                                                         |        | 5            | 1           | Stack Pointer - 2              | 0           | Index Register (Low Order Byte)                       |
|                               |                                                                         |        | 6            | 1           | Stack Pointer - 3              | 0           | Index Register (High Order Byte)                      |
|                               |                                                                         |        | 7            | 1           | Stack Pointer - 4              | 0           | Contents of Accumulator A                             |
|                               |                                                                         |        | 8            | 1           | Stack Pointer - 5              | 0           | Contents of Accumulator B                             |
|                               |                                                                         |        | 9            | 1           | Stack Pointer - 6              | 0           | Contents of Cond. Code Register                       |
|                               |                                                                         |        | 10           | 0           | Stack Pointer - 7              | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 11           | 1           | Vector Address FFFA (Hex)      | 1           | Address of Subroutine (High Order Byte)               |
|                               |                                                                         |        | 12           | 1           | Vector Address FFFB (Hex)      | 1           | Address of Subroutine (Low Order Byte)                |
| RELATIVE                      | BCC BHI BNE<br>BCS BLE BPL<br>BEQ BLS BRA<br>BGE BLT BVC<br>BGT BMI BVS | 4      | 1            | 1           | Op Code Address                | 1           | Op Code                                               |
|                               |                                                                         |        | 2            | 1           | Op Code Address + 1            | 1           | Branch Offset                                         |
|                               |                                                                         |        | 3            | 0           | Op Code Address + 2            | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 4            | 0           | Branch Address                 | 1           | Irrelevant Data (Note 1)                              |
|                               | BSR                                                                     | 8      | 1            | 1           | Op Code Address                | 1           | Op Code                                               |
|                               |                                                                         |        | 2            | 1           | Op Code Address + 1            | 1           | Branch Offset                                         |
|                               |                                                                         |        | 3            | 0           | Return Address of Main Program | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 4            | 1           | Stack Pointer                  | 0           | Return Address (Low Order Byte)                       |
|                               |                                                                         |        | 5            | 1           | Stack Pointer - 1              | 0           | Return Address (High Order Byte)                      |
|                               |                                                                         |        | 6            | 0           | Stack Pointer - 2              | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 7            | 0           | Return Address of Main Program | 1           | Irrelevant Data (Note 1)                              |
|                               |                                                                         |        | 8            | 0           | Subroutine Address             | 1           | Irrelevant Data (Note 1)                              |

Note 1. If device which is addressed during this cycle uses VMA, then the Data Bus will go to the high impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.

Note 2. Data is ignored by the MPU.

Note 3. For TST, VMA = 0 and Operand data does not change.

Note 4. While the MPU is waiting for the interrupt, Bus Available will go high indicating the following states of the control lines: VMA is low; Address Bus, R/W, and Data Bus are all in the high impedance state.

The following codes are used in Table 9-3:

- aa two bits choosing the address mode:
  - 00 immediate data
  - 01 base page direct addressing
  - 10 indexed addressing
  - 11 extended direct addressing
- pp the second byte of a two- or three-byte instruction.
- qq the third byte of a three-byte instruction.
- x one bit choosing the Accumulator:
  - 0 Accumulator A
  - 1 Accumulator B
- yy two bits choosing the address mode:
  - 00 (inherent addressing) Accumulator A
  - 01 (inherent addressing) Accumulator B
  - 10 indexed addressing
  - 11 extended direct addressing
- y one bit choosing the address mode:
  - 0 indexed addressing
  - 1 extended direct addressing

Two numbers in the "Machine Cycles" column (for example, 2 - 5) indicate that execution time depends on the addressing mode.

Table 9-3. MC6800 Instruction Set Object Codes

| MNEMONIC | OPERAND(S)                    | OBJECT CODE          | BYTE        | MACHINE CYCLES | MNEMONIC | OPERAND(S)                        | OBJECT CODE          | BYTE             | MACHINE CYCLES |
|----------|-------------------------------|----------------------|-------------|----------------|----------|-----------------------------------|----------------------|------------------|----------------|
| ABA      |                               | 1B                   | 1           | 2              | JMP      |                                   | 011y1110             |                  |                |
| ADC      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xa001<br>pp<br>qq   | 1<br>2<br>3 | 2-5<br>4       | JSR      | ADR8<br>ADR16                     | pp<br>qq             | 2<br>3           | 4<br>3         |
| ADD      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xaa1011<br>pp<br>qq | 1<br>2<br>3 | 2-5<br>4       | LDA      | ADR8<br>ADR16<br>ACX,<br>1xa00110 | pp<br>qq<br>pp<br>qq | 2<br>3<br>2<br>3 | 8<br>9         |
| AND      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xa0100<br>pp<br>qq  | 1<br>2<br>3 | 2-5<br>4       | LDS      | ADR8<br>ADR16                     | pp<br>qq             | 2<br>3           | 2-5<br>4       |
| ASL      | ACX<br>ADR8<br>ADR16          | 01yy1000<br>pp<br>qq | 1<br>2<br>3 | 2<br>7<br>6    | LDX      | ADR8<br>ADR16 or DATA16           | pp<br>qq             | 2<br>3           | 3-5<br>4-6     |
| ASR      | ACX<br>ADR8<br>ADR16          | 01yy0111<br>pp<br>qq | 1<br>2<br>3 | 2<br>7<br>6    | LSR      | ADR8<br>ADR16 or DATA16<br>ACX    | pp<br>qq<br>pp       | 2<br>3<br>2      | 3-5<br>4-6     |
| BCC      | DISP                          | 24 pp                | 2           | 4              |          | ADR8                              | pp                   | 2                | 7              |
| BCS      | DISP                          | 25 pp                | 2           | 4              |          | ADR16                             | pp                   | 2                | 6              |
| BEQ      | DISP                          | 27 pp                | 2           | 4              | NEG      | ACX                               | 01yy0000             | 1                | 2              |
| BGE      | DISP                          | 2C pp                | 2           | 4              |          | ADR8                              | pp                   | 2                | 7              |
| BGT      | DISP                          | 2E pp                | 2           | 4              |          | ADR16                             | qq                   | 3                | 6              |
| BHI      | DISP                          | 22 pp                | 2           | 4              | NOP      |                                   | 01                   | 1                | 2              |
| BIT      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xa0101<br>pp<br>qq  | 1<br>2<br>3 | 2              | ORA      | ACX,<br>ADR8 or DATA<br>ADR16     | 1xa0101<br>pp<br>qq  | 2<br>3           | 2-5<br>4       |
| BLE      | DISP                          | 2F pp                | 2           | 4              | PSH      | ACX                               | 0011011x             | 1                | 4              |
| BLS      | DISP                          | 23 pp                | 2           | 4              | PUL      | ACX                               | 0011001x             | 1                | 4              |
| BLT      | DISP                          | 2D pp                | 2           | 4              | ROL      | ACX                               | 01yy1001             | 1                | 2              |
| BMI      | DISP                          | 2B pp                | 2           | 4              |          | ADR8                              | pp                   | 2                | 7              |
| BNE      | DISP                          | 26 pp                | 2           | 4              |          | ADR16                             | qq                   | 3                | 6              |
| BPL      | DISP                          | 2A pp                | 2           | 4              | ROR      | ACX                               | 01yy0110             | 1                | 2              |
| BRA      | DISP                          | 20 pp                | 2           | 4              |          | ADR8                              | pp                   | 2                | 7              |
| BSR      | DISP                          | 8D pp                | 2           | 8              |          | ADR16                             | qq                   | 3                | 6              |
| BVC      | DISP                          | 28 pp                | 2           | 4              | RTI      |                                   | 3B                   | 1                | 10             |
| BVS      | DISP                          | 29 pp                | 2           | 4              | RTS      |                                   | 39                   | 1                | 5              |
| CBA      |                               | 11                   | 1           | 2              | SBA      |                                   | 10                   | 1                | 2              |
| CLC      |                               | 0C                   | 1           | 2              | SBC      | ACX,<br>ADR8 or DATA<br>ADR16     | 1xa00010<br>pp<br>qq | 2<br>3           | 2-5<br>4       |
| CLI      | ACX                           | 01yy1111             | 1           | 2              | SEC      |                                   | OD                   | 1                | 2              |
| CLR      | ADR8<br>ADR16                 | pp<br>qq             | 2<br>3      | 7<br>6         | SEI      |                                   | OF                   | 1                | 2              |
| CLV      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xa0001<br>pp<br>qq  | 1<br>2<br>3 | 2              | SEV      |                                   | OB                   | 1                | 2              |
| CMP      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xa0001<br>pp<br>qq  | 2<br>3      | 2-5<br>4       | STA      | ACX,<br>ADR8<br>ADR16             | 1xa01111<br>pp<br>qq | 2<br>3           | 4-6<br>5       |
| COM      | ACX<br>ADR8<br>ADR16          | 01yy0011<br>pp<br>qq | 1<br>2<br>3 | 2<br>7<br>6    | STS      |                                   | 10aa1111             | *                |                |
| CPX      |                               | 10aa1100             |             |                | STX      |                                   | ADR8<br>ADR16        | pp<br>qq         | 2<br>3         |
| DAA      | ADR8<br>ADR16 or DATA16       | pp<br>qq             | 2<br>3      | 4-6<br>3-5     |          |                                   | pp<br>qq             | 2<br>3           | 5-7<br>6       |
| DEC      | ACX<br>ADR8<br>ADR16          | 01yy1010<br>pp<br>qq | 1<br>2<br>3 | 2<br>6         | SUB      | ACX,<br>ADR8 or DATA<br>ADR16     | 1xa00000<br>pp<br>qq | 2<br>3           | 2-5<br>4       |
| DES      |                               | 34                   | 1           | 4              | SWI      |                                   | 3F                   | 1                | 12             |
| DEX      |                               | 09                   | 1           | 4              | TAB      |                                   | 16                   | 1                | 2              |
| EOR      | ACX,<br>ADR8 or DATA<br>ADR16 | 1xa01000<br>pp<br>qq | 1<br>2<br>3 | 2-5<br>4       | TAP      |                                   | 06                   | 1                | 2              |
| INC      | ACX<br>ADR8<br>ADR16          | 01yy1100<br>pp<br>qq | 1<br>2<br>3 | 2<br>7<br>6    | TBA      |                                   | 17<br>07             | 1                | 2              |
| INS      |                               | 31                   | 1           | 4              | TPA      |                                   | 07                   | 1                | 2              |
| INX      |                               | 08                   | 1           | 4              | TST      | ACX<br>ADR8<br>ADR16              | 01yy1101<br>pp<br>qq | 1<br>2<br>3      | 2<br>7<br>6    |
|          |                               |                      |             |                | TSX      |                                   | 30                   | 1                | 4              |
|          |                               |                      |             |                | TXS      |                                   | 35                   | 1                | 4              |
|          |                               |                      |             |                | WAI      |                                   | 3E                   | 1                | 9              |

\*aa = 00 is not permitted.

## **SUPPORT DEVICES THAT MAY BE USED WITH THE MC6800**

Using 8080A support devices with the MC6800 is very straightforward in terms of control signals generated. You must break out the single MC6800 R/W control signal into separate RD and WR control signals. Other signal interconnections are self-evident. Here is appropriate logic:



Signals illustrated above apply to communications between the MC6800 CPU and 8080A support devices. External memory will communicate with the MC6800 CPU using standard MC6800 timing.

There are some limitations imposed on communications between the MC6800 CPU and 8080A support devices.

As illustrated above, you must create an interrupt acknowledge control signal by decoding the second interrupt acknowledgement address, FFF916, appearing on the Address Bus. Similarly, if you wish to create specific I/O read and write control signals, then you must decode off the Address Bus those memory addresses which you have assigned to I/O devices.

If you wish to extend instruction execution cycles for slow 8080A support devices, then you must use the MC6800 clock stretching logic for this purpose. Clearly the 8080A support devices cannot use Wait state logic since the MC6800 has no such logic.

You can generate an 8080A compatible system clock from the  $\Phi_2$  (TTL) 6870 series clock as follows:





Figure 9-11. Use of 8080A Support Devices With MC6800 CPU

**Figure 9-11 illustrates the interface for an 8251, an 8253 or an 8255 device connected to an MC6800 CPU. Figure 9-12 provides the timing for 8080A support devices used with an MC6800 CPU.**

The 8257 DMA device and the 8259 PICU should not be used in an MC6800 since MC6800 DMA and interrupt logic are not compatible with these devices.

**8085 support devices could be used with an MC6800 but would require that you multiplex the Data Bus and low order eight Address Bus lines,** as required by the 8155, 8355, and 8755. Extra logic needed to perform this bus multiplexing would probably destroy the cost effectiveness of the 8085 support devices in an MC6800 system.

**The only Z80 support device that is practical in an MC6800 system is the Z80 DMA device.** This is because the other Z80 support devices decode a Write state from a combination of the M1, INT, and RD control signals. The Z80 DMA device uses separate read and write control inputs; therefore it may be used with an MC6800 CPU. The logic needed to create Z80 DMA control inputs from MC6800 control signals is identical to the 8080A control signal logic illustrated above. The Z80 SIO device will probabl, not be effective in an MC6800 system; in preference, use specific MC6800 serial I/O devices.



Figure 9-12. Timing for 8080A Support Devices Used With an MC6800 CPU

**When using non-MC6800 support devices with the MC6800 CPU, remember that there is a particularly pernicious problem associated with MC6800 Reset logic on power-up.** As discussed earlier in this chapter, the MC6800 does not internally disable interrupt requests until the trailing low-to-high transition of the RESET signal. Thus external devices capable of requesting an interrupt may randomly do so during the power on Reset sequence; and this may result in an interrupt being acknowledged following the initial system Reset, rather than the expected system initialization program getting executed. You must make certain that all support devices capable of requesting an interrupt are disabled by the leading high-to-low transition of RESET during the power-up sequence.

## THE MC6802 CPU WITH READ/WRITE MEMORY

The MC6802 is a combination of the MC6800 CPU, clock logic, and 128 bytes of read/write memory. Figure 9-13 illustrates logic of the MC6802 CPU device.

The actual CPU architecture and the instruction set of the MC6802 are identical to the MC6800 which we have already described.

The 128 bytes of read/write memory which are present on the MC6802 chip are accessed by memory addresses  $0000_{16}$  through  $007F_{16}$ . The first 32 bytes of this read/write memory may be protected during power down by a special low power standby input.

**MC6802 CPU pins and signals are illustrated in Figure 9-14. Pins and signals which differ from the MC6800 illustrated in Figure 9-2 are shaded. We will examine these new signals only.**

Since clock logic is on the MC6802 chip, three pins are needed for this specific purpose. Normally a **crystal will be connected across XTAL1 and XTAL2**. A 4 MHz crystal should be used since the MC6802 has internal divide-by-four logic to create a 1 MHz system clock signal. (An inexpensive 3.58 MHz color burst crystal may also be used.) **A TTL level system clock signal is output via Φ2 (TTL)**.

You can, if you wish, drive the MC6802 using **an external clock signal**; this signal is input via XTAL2; it must not be faster than 4 MHz. XTAL1 should be left unconnected in this mode.



Figure 9-13. Logic of the MC6802 CPU Device

In order to provide the **clock stretching logic** that is a standard part of MC6800 microcomputer system, a **Memory Ready (MR)** signal is present. MR is normally high. In order to stretch  $\Phi_2$ , MR must make a high-to-low transition while  $\Phi_2$  is high;  $\Phi_2$  then remains high until MR makes a low-to-high transition. Timing may be illustrated as follows:





| PIN NAME                          | DESCRIPTION               | TYPE                    |
|-----------------------------------|---------------------------|-------------------------|
| *A <sub>0</sub> - A <sub>15</sub> | Address Lines             | Output                  |
| *D <sub>0</sub> - D <sub>7</sub>  | Data Bus Lines            | Tristate, Bidirectional |
| *HALT                             | Halt                      | Input                   |
| *MR                               | Memory Ready              | Input                   |
| *RE                               | RAM Enable                | Input                   |
| *R/W                              | Read/Write                | Output                  |
| *VMA                              | Valid Memory Address      | Output                  |
| *BA                               | Bus Available             | Output                  |
| *IRQ                              | Interrupt Request         | Input                   |
| RESET                             | Reset                     | Input                   |
| NMI                               | Non-Maskable Interrupt    | Input                   |
| XTAL1,XTAL2                       | Crystal/Clock Connections | Input                   |
| E                                 | Enable                    | Output                  |
| V <sub>SS</sub> ,V <sub>CC</sub>  | Power                     |                         |
| V <sub>CC</sub> (ST)              | Standby Power             |                         |

\*These signals connect to the System Bus.

Figure 9-14. MC6802 CPU Signals and Pin Assignments

Two signals have been added to support the on-chip read/write memory. **RE is an enable signal for the on-chip memory.** RE must be input high for the on-chip memory to be accessed. If RE is low, on-chip memory cannot be written into or read. While on-chip memory is disabled its address space is also disabled, and addresses in the range 0000<sub>16</sub> through 007F<sub>16</sub> are deflected to external memory. Thus **the address space 0000<sub>16</sub> through 007F<sub>16</sub> is duplicated;** it accesses on-chip RAM when RE is high, but it accesses external RAM when RE is low.

The first 32 on-chip read/write memory bytes (with addresses 0000 through 001F) can have the contents preserved by applying +5V at the V<sub>CC</sub> standby pin when power is down on the MC6802. But to be of any value, we must guarantee that the contents of these 32 read/write memory locations are not destroyed during any power down sequence; in other words, we must anticipate any power down. In order to preserve the contents of the 32 low-order read/write memory bytes, RE must be input low at least three clock periods before power drops below +4.75V. This is easy enough to do for a scheduled power down; however, it is impossible during a non-scheduled power down — such as might occur as the result of a power failure — unless power-down-interrupt circuitry is provided.

**MC6800 signals which have been removed**, going to the MC6802, **include the clock inputs  $\Phi_1$  and  $\Phi_2$ , plus the bus control signals TSC and DBE.**

Obviously, the clock inputs must be removed since clock logic is now on the CPU chip.

Removal of the System Bus control signals TSC and DBE reflects the fact that if you are going to need direct memory access, you are not going to use the MC6802. Only larger microcomputer systems need direct memory access; for such systems the MC6800 is available. The MC6802 is intended as half of a two-chip 6800 configuration, within which direct memory access would be meaningless.

If DMA is necessary with a 6802-based system, then the use of external tristate bus drivers will be necessary. Bus Available (BA) and HALT are available on the 6802 for this purpose.

**The MC6846 multi-function device is the other half of the two-chip microcomputer system. However, the MC6846 can be used with the MC6800 CPU or the MC6802 CPU; therefore it is described later in this chapter along with other 6800 support devices.**

**When HALT is input low, the MC6802 enters the Halt state** at the end of the current instruction's execution. In the Halt state the Data Bus is floated, Bus Available (BA) is output high, and valid memory address (VMA) is output low. The Address Bus outputs the address of the instruction which will be executed when the halt condition ends. Timing may be illustrated as follows:



The HALT input signal is level sensitive. The level of HALT is sensed 250 nanoseconds before the end of a machine cycle. If HALT is low at this time, then the low level is detected. If HALT makes a high-to-low transition within the last 250 nanoseconds of a machine cycle, then it may not be detected. This may be illustrated as follows:



Once a Halt has been detected, the current instruction completes execution before the Halt condition starts. In the simplest case this may be illustrated as follows:



If a Halt transition occurs within the last 250 nanoseconds of a machine cycle, then the HALT will probably not be detected until the next machine cycle. Assuming that the next machine cycle terminates an instruction's execution, the Halt condition will begin as follows:



The next machine cycle could be the first of a multi-machine cycle instruction. Now the Halt condition will begin as follows:



Note that if the HALT transition had occurred a little earlier, the HALT condition would have begun a whole instruction execution time sooner — three machine cycles sooner in the illustration above.

The HALT condition terminates on the machine cycle that follows HALT going high again. Once again the HALT signal is sampled 250 nanoseconds before the end of the machine cycle. Thus the HALT may terminate within the machine cycle where the HALT signal makes a low-to-high transition:



But the HALT condition may terminate one machine cycle later if the HALT signal makes its low-to-high transition within the last 250 nanoseconds of a machine cycle. This may be illustrated as follows:



Observe that **it is possible for a low HALT pulse to be completely missed if it is less than one machine cycle long and transitions are not properly synchronized**. If, for example, the high-to-low transition occurs within the last 250 nanoseconds of a machine cycle and the subsequent low-to-high transition occurs correctly in the next machine cycle, the HALT pulse will be completely missed. This may be illustrated as follows:



**During the HALT condition no interrupts will be acknowledged. If any interrupt requests occur during a HALT condition, they simply stack up waiting for the end of the HALT condition.**

**There are also some differences in MC6802 interrupt and reset logic as compared to the MC6800.**

#### INTERRUPTS DURING AN MC6802 HALT

Motorola literature recommends that interrupt request inputs  $\overline{IRQ}$  and  $\overline{NMI}$  have a 3K ohm external resistor to  $V_{CC}$ . This may be illustrated as follows:



The MC6802 RESET input may be a stand-alone input or it may be tied to the RAM enable input (RE). Timing for the RESET signal rise and fall differs in the two cases, as defined in the data sheets at the end of this chapter. Note that by tying RESET to RE you cause the on-chip RAM to be enabled whenever the MC6802 is receiving power.

**The MC6802, like the MC6800, does not disable interrupts until close to the end of the reset sequence.** Thus, if you have non-6800 support devices connected to an MC6802, you must make certain that you have included logic that prevents these support devices from requesting an interrupt until after the reset operation has gone to completion. If you do not take this precaution, then following RESET you may vector to a support device's interrupt service routine rather than executing the intended system initialization program.

## THE MC6870 TWO PHASE CLOCKS

Four clock logic devices supporting the MC6800 CPU are described. The MC6802 does not need any external clock logic device.

The MC6870A is a very elementary device providing minimum clock signals needed with an MC6800 microcomputer system. Its pin assignments are illustrated in Figure 9-15.



Figure 9-15. MC6870A Clock Device Pins and Signals

The first enhancement is provided by the MC6871A, illustrated in Figure 9-16, which adds clock signal stretching capabilities and a twice frequency clock output.



Figure 9-16. MC6871A Clock Device Pins and Signals

The MC6871B, illustrated in Figure 9-17, is a variation of the MC6871A.



Figure 9-17. MC6871B Clock Device Pins and Signals



Figure 9-18. MC6875 Clock Device Pins and Signals

The MC6875 is the most versatile of the clock devices provided for the MC6800. It is illustrated in Figure 9-18.

Since these various clock logic devices represent essentially the same capabilities, but with increasing enhancements, we will describe logic and capabilities in the order of the device illustrations.

Much of the clock device logic we are going to describe stretches the Φ1 (NMOS) and Φ2 (NMOS) clock signals. But recall that stretching Φ1 (NMOS) and Φ2 (NMOS), in itself, is only half of the logic needed to stretch the entire System Bus. Additionally, the MC6800 needs a high TSC input to float the Address and R/W Bus lines while Φ1 (NMOS) is high. DBE must be input low in order to float the Data Bus lines while the clock is being stretched with Φ1 (NMOS) low.

### THE MC6870A CLOCK DEVICE

This is a minimum clock device; it outputs Φ1 (NMOS) and Φ2 (NMOS), the two clock signals required by an MC6800 CPU.

Φ2 (TTL) is also generated. Φ2 (TTL) is used to synchronize support devices; it has sufficient load capacity to drive five devices without signal buffering.

The MC6870A contains an internal crystal and oscillator; in its standard form clock signals with a 1 MHz frequency are generated. A variety of other clock frequencies can also be ordered.

### THE MC6871A CLOCK DEVICE

In addition to the standard signals output by the MC6870A, the MC6871A provides two additional TTL output clock signals and externally controlled pulse stretching capabilities.

**HOLD1** is used to stretch the standard clock signals:  $\Phi_1$  (NMOS),  $\Phi_2$  (NMOS) and  $\Phi_2$  (TTL), which we described for the MC6870A. Timing may be illustrated as follows:



It is very important that **HOLD1** makes its active high-to-low transition during a  $\Phi_1$  (NMOS) high state. Subsequently,  $\Phi_1$  (NMOS),  $\Phi_2$  TTL clocks will be stretched until **HOLD1** makes a low-to-high transition within the constraints described below.

As illustrated above, **HOLD1** stretches clocks with  $\Phi_1$  (NMOS) high. If you refer back to our discussion of the MC6800, you will see that these clock levels identify the portion of a machine cycle when an address is being output. Typically, the clock will be stretched so that two addresses can be output: the first for a Direct Memory Access or dynamic memory refresh operation; the second for the normal address output which is required when any instruction is executed. Device select logic must discriminate between the two addresses being output; DMA or dynamic memory refresh logic must receive the first address only, while memory or I/O devices receive the second address only.

### MC6800 STRETCHING ADDRESS TIMING

**Two additional clock signals are output by the MC6871A:**  $2xfc$  and **MEMORY CLOCK**; they are not part of normal memory addressing logic, therefore these two clock signals are not stretched by **HOLD1**.

**$2xfc$  is a twice frequency clock signal** which can be used for various synchronization logic around an MC6800 microcomputer system.

**MEMORY CLOCK is identical in waveform to  $\Phi_2$  TTL except MEMORY CLOCK is not stretched by HOLD1.**

**HOLD1** must make its high-to-low transition while  $\Phi_1$  (NMOS) is high. **HOLD1** must subsequently make its low-to-high transition while  $\Phi_1$  (NMOS) would have been high, had it not been stretched. **An asynchronous HOLD1 request must therefore be synchronized** with  $\Phi_1$  (NMOS) in order to generate a valid **HOLD1** clock input. This is a simple logic operation; here is one possibility:



This circuit synchronizes the high-to-low and the low-to-high transition of HOLD1. The low-to-high clock transition occurs only during  $\Phi 1$  (NMOS) high time:



Observe that synchronization logic can create a time delay of up to one half clock cycle between the unsynchronized and the synchronized HOLD signals changing state.

**MEMORY READY** also stretches clock signals. Timing may be illustrated as follows:



Clock signal stretching begins with  $\Phi 2$  (NMOS) high following the MEMORY READY high-to-low transition. Clock stretching ends with the falling edge of  $2xfc$  following the MEMORY READY low-to-high transition. Observe that MEMORY READY stretches MEMORY CLOCK, which HOLD1 does not do.  $2xfc$ , however, is not stretched, either by HOLD1 or by MEMORY READY. Also note that MEMORY READY does not require input synchronization, as does HOLD1.

If you refer back to the timing diagrams which illustrate MC6800 instructions' execution, you will see that MEMORY READY stretches clock signals during the data access portion of a machine cycle. This is the part of the machine cycle during which external memory has to respond to a CPU access; therefore, this is the portion of the machine cycle which must be stretched for slow memories — which is why MEMORY READY can be visualized as the signal which slow memories must input low in order to gain the access time they require.

**The MC6871A contains an internal crystal oscillator. In its standard form, clock signals with a 1 MHz frequency are generated. A variety of other clock frequencies can also be ordered.**

### THE MC6871B CLOCK DEVICE

**This device differs from the MC6871A in two ways. MEMORY READY is replaced by HOLD2 and MEMORY CLOCK is replaced by  $\Phi 2$  (TTL) UNGATED.** HOLD2 stretches clock signals with  $\Phi 1$  (NMOS) low, just as MEMORY READY did; however, like HOLD1, HOLD2 must have its active transitions synchronized with the clock output — in this case with  $\Phi 2$  high.  $\Phi 2$  (TTL) UNGATED, however, is not stretched. Timing may be illustrated as follows:



## THE MC6875 CLOCK DEVICE

This is the most sophisticated of the clock devices offered with the MC6800 microcomputer system. Its principal features are that it performs control input synchronization which must be handled externally by other clock devices; also, the MC6875 allows external timing.

As we have already stated, clock signals are stretched with  $\Phi_1$  and  $\Phi_2$  low in order to allow a Direct Memory Access or dynamic memory refresh address to be output. The MC6875 DMA/REF REQ input performs this clock stretching operation, just as HOLD1 does, except that DMA/REF REQ can be an asynchronous input. MC6875 internal logic performs the synchronization operations which have to be handled externally for the MC6871A and MC6871B clocks. In addition, the MC6875 outputs REF GRANT high while the clocks are being stretched with  $\Phi_1$  (NMOS) high. External DMA or dynamic memory refresh logic can use REF GRANT as an enable strobe.

**MEMORY READY** and **MEMORY CLOCK** are as described for the MC6871A. MEMORY READY stretches clocks with  $\Phi_1$  (NMOS) low. MEMORY CLOCK follows  $\Phi_2$  (NMOS) and is stretched by MEMORY READY but not by DMA/REF REQ.

The MC6875 clock signal outputs  $\Phi_1$  (NMOS) and  $\Phi_2$  (NMOS) have sufficient capacity to drive two MC6800 CPUs. 4xfc is an additional oscillator running at four times the  $\Phi_1$  and  $\Phi_2$  clock rates.

**X1, X2 and EXT IN** are three signals which allow MC6875 clock rates to be controlled externally.

You can optionally attach a crystal oscillator or an RC network to X1, X2 as follows:



You can also input an external clock signal to EXT IN, in which case the MC6875 will adopt the frequency of the external signal. The external clock frequency must be four times the  $\Phi_1$  and  $\Phi_2$  clock frequency.

The MC6875 is able to take an asynchronous SYSTEM RESET input and convert it into a synchronous RESET, which may be used throughout an MC6800 microcomputer system. SYSTEM RESET can be any input signal which is processed through a Schmitt trigger to create a RESET output, as described for the 8224 clock device in Chapter 4.

## SOME STANDARD CLOCK SIGNAL INTERFACE LOGIC

There are a number of very common ways in which MC6870 series clock signals are used within MC6800 microcomputer systems.

You will find that all of the support devices described in the rest of this chapter require an enable synchronizing signal, given the symbol "E". This signal is usually generated as the AND of the MC6800 VMA output and the  $\Phi_2$  TTL clock output:



**MC6800  
ENABLE  
SIGNAL  
GENERATION**

The purpose of ANDing  $\Phi_2$  with VMA is to make sure that devices receiving signal E are inhibited while VMA is low — at which time the CPU cannot be accessing the support device...

The HALT signal, which is used in MC6800 microcomputer systems to float the System Bus for extended periods, must be a synchronous input. You can create a synchronous HALT from an asynchronous HALT using  $\Phi_2$  TTL as follows:

**MC6800  
SYNCHRONOUS  
HALT  
GENERATION**



## THE MC6820 AND MCS6520 PERIPHERAL INTERFACE ADAPTER (PIA)

This part is manufactured as the MC6820 by the companies listed at the beginning of this chapter. MOS Technology and its second source companies (whose products are described in Chapter 10) manufacture the same part, but call it the MCS6520.

The MC6820 PIA is a general purpose I/O device, designed for use within MC6800 microcomputer systems.

The MC6820 PIA provides 16 I/O pins, configured as two 8-bit I/O ports. We will refer to these as Port A and Port B. Individual pins of each I/O port may be used separately as inputs or outputs. Each I/O port has two associated control signals, one of which is input only, while the other is bidirectional. The only differences between I/O Ports A and B are in their electrical characteristics, and in their handshaking control capabilities. But these are very significant differences, as we will explain shortly.

Figure 9-19 illustrates that part of our general microcomputer system logic which has been implemented on the MC6820 PIA.

The MC6820 PIA is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL compatible.

The device is implemented using N-channel silicon gate MOS technology.

### THE MC6820 PIA PINS AND SIGNALS

The MC6820 pins and signals are illustrated in Figure 9-20. We will summarize signal functions before describing PIA operations.

Consider first the various Data Busses.

D0 - D7 represents the bidirectional Data Bus via which all communications between the CPU and the MC6820 occur.

PA0 - PA7 and PB0 - PB7 represent Data Busses connecting the two 8-bit I/O Ports A and B with external logic. The 16 I/O port pins may be looked upon as 16 individual signal lines, or two 8-bit I/O busses. Each I/O port pin can be individually assigned to input or output, but an individual pin cannot support bidirectional data transfers.

These are the differences between I/O Port A and B pins:

- 1). Bits of I/O Port A may be set or reset at any time by voltage levels applied to associated pins. Irrespective of data that may be in a bit position following a Read or Write operation, an I/O Port A bit will be reset to zero any time a voltage of +0.8V or less is applied to a Port A pin. A 1 will be written into a Port A bit any time a voltage of +2V or more is applied to the Port A pin. I/O Port B bit contents are not affected by voltage levels at I/O Port B pins. For example, suppose that a 1 has been output to bit 2 of I/O Ports A and B. Subsequently suppose that pin 2 of I/O Ports A and B are drained excessively, so that voltage levels transiently drop to +0.5V. I/O Port A bit 2 will become 0, but I/O Port B bit 2 will retain a level of 1.
- 2). As outputs, I/O Port B pins may be used as a source of up to 1 mA at +1.5V, to directly drive the base of a transistor switch. This is not feasible using I/O Port A pins.



Figure 9-19. Logic of the MC6820 PIA

**There are five device select pins.**

**CS0, CS1 and CS2 are three typical chip select signals.** For an MC6820 device to be selected, CS0 and CS1 must receive high inputs while CS2 simultaneously receives a low input.

Providing CS0, CS1 and CS2 have selected an MC6820 device, **RS0 and RS1 address one of four memory locations.** Thus an MC6820 device will appear to a programmer as four memory locations.

Any of the standard schemes described in Volume I can be used to address an MC6820 PIA. There is nothing unusual about the select logic with which you will assign four unique memory addresses to an MC6820.

**There are four timing and control signals which interface an MC6820 with external logic.**

**CA1 and CA2 are control signals associated with I/O Port A.** CA1 is an input only signal and is usually used by external logic to request an interrupt. CA2 is a bidirectional control signal which is used to implement various types of handshaking logic.

**CB1 and CB2 are the control signals which support I/O Port B.** These two signals are analogous to CA1 and CA2, although there are some differences in the handshaking logic associated with CB2 as compared to CA2.



| Pin Name                          | Description                | Type                      |
|-----------------------------------|----------------------------|---------------------------|
| D0 - D7                           | Data Bus to CPU            | Tristate, bidirectional   |
| PA0 - PA7                         | Port A peripheral Data Bus | Input or Output           |
| PB0 - PB7                         | Port B peripheral Data Bus | Tristate, Input or Output |
| CS0, CS1, CS2                     | Chip Select                | Input                     |
| RS0, RS1                          | Register Select            | Input                     |
| CA1                               | Interrupt input to Port A  | Input                     |
| CA2                               | Port A peripheral control  | Input or Output           |
| CB1                               | Interrupt input to Port B  | Input                     |
| CB2                               | Port B peripheral control  | Input or Output           |
| E                                 | Device synchronization     | Input                     |
| R/W                               | Read/Write control         | Input                     |
| IRQA, IRQB                        | Interrupt request          | Output                    |
| RESET                             | Reset                      | Input                     |
| V <sub>cc</sub> , V <sub>ss</sub> | Power and Ground           |                           |

Figure 9-20. MC6820 PIA Signals and Pin Assignments

**There are two control signals associated with the MC6820 CPU interface.**

**E** is the standard synchronization signal generated by the various MC6870 series clock devices. The trailing edge of E pulses synchronizes all logic and timing within the MC6820. Manufacturer literature refers to E as a device enable signal, but it is more accurately viewed as a device synchronization signal.

**R/W** is the standard Read/Write control signal output by the MC6800 CPU. When R/W is high, a Read operation is specified; that is, data transfer from the MC6820 PIA to the MC6800 CPU occurs. When R/W is low, a Write operation is specified; that is, data transfer from the CPU to the PIA occurs.

**There are two interrupt request signals, IRQA and IRQB.** Under program control you can specify the conditions under which an interrupt request can originate at logic associated with I/O Port A or I/O Port B. The actual interrupt request is transmitted to the MC6800 CPU via signal IRQA for I/O Port A logic, and via IRQB for I/O Port B logic. Interrupt requests originating at either signal will connect to the MC6800 IRQ input.

**RESET** is a standard Reset input. When it is input low, the contents of all MC6820 registers will be set to zero.



Figure 9-21. Functional Block Diagram for the MC6820 PIA

## MC6820 OPERATIONS

As compared to the 8255 PPI, the MC6820 PIA has less formalized operating modes. The MC6820-to-external logic interface consists of two I/O ports, each of which has two dedicated control lines. You have the option of assigning individual I/O port lines to input or output; as a completely separate operation you can use the two control lines to perform a limited amount of handshaking and interrupt processing — or you can ignore the control lines, in which case the I/O port is supporting simple input and/or output. Bidirectional I/O, equivalent to 8255 Mode 2, is not available. Figure 9-21 generally represents MC6820 functional organization and Table 9-4 summarizes the available operating modes.

Table 9-4. MC6820 Operating Modes

| OPERATING MODE                           | MC6800 AVAILABILITY                                                                                       |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Simple input<br>without handshaking      | I/O Port A or B                                                                                           |
| Simple output<br>without handshaking     | I/O Port A or B                                                                                           |
| Bidirectional I/O<br>without handshaking | Not available, but individual pins of<br>either I/O port may be separately<br>assigned to input or output |
| Input with<br>handshaking                | I/O Port A only                                                                                           |
| Output with<br>handshaking               | I/O Port B only                                                                                           |
| Bidirectional I/O<br>with handshaking    | Not Available                                                                                             |

Table 9-5. Addressing MC6820 Internal Registers

| SELECT LINES |     |   | ADDRESSED LOCATION                 |  |  |  |  |  |  |  |
|--------------|-----|---|------------------------------------|--|--|--|--|--|--|--|
| RS1          | RS0 | X |                                    |  |  |  |  |  |  |  |
| 0            | 1   |   | <br>Bit No.                        |  |  |  |  |  |  |  |
| 0            | 0   | 0 | I/O Port A Data Direction register |  |  |  |  |  |  |  |
| 0            | 0   | 1 | I/O Port A Data buffer             |  |  |  |  |  |  |  |
| 1            | 1   |   | <br>Bit No.                        |  |  |  |  |  |  |  |
| 1            | 0   | 0 | I/O Port B Data Direction register |  |  |  |  |  |  |  |
| 1            | 0   | 1 | I/O Port B Data buffer             |  |  |  |  |  |  |  |

**There are six addressable locations within an MC6820 PIA; they are shaded in Figure 9-21.**

Since there are only two register select lines, RSO and RS1, four unique addressable locations can be identified within the MC6820. Table 9-5 summarizes the manner in which the MC6820 uses four addresses to access six locations. Logic defined in Table 9-5 requires that you first output a Control code to each I/O port Control register; next you access either the I/O port Data Direction register or Data Buffer. You use the same memory address to access an I/O port Data Direction register and its Data Buffer. Which location you access is determined by bit 2 of the I/O port's Control register.

## **MC6820 REGISTERS ADDRESSING**

You must precede any I/O port Data Direction register, or Data Buffer access with a Control code, written to the I/O port's Control register. Once you have written a Control code to an I/O port Control register, you do not have to write another Control code for addressing purposes until you wish to switch from accessing the I/O port Data Direction register to the Data Buffer, or from accessing the Data Buffer to the Data Direction register.

To illustrate MC6820 addressing, suppose the four addresses C00016, C00116, C00216 and C00316 select an MC6820. This is how addressable locations within the MC6820 would actually be selected if address line A0 were connected to RS0 and A1 to RS1:

| Address | Selected                                                    |
|---------|-------------------------------------------------------------|
| C00016  | I/O Port A Data Direction register, if C00116CF1, bit 2 = 0 |
|         | I/O Port A Data buffer, if C00116, bit 2 = 1                |
| C00116  | I/O Port A Control register                                 |
| C00216  | I/O Port B Data Direction register, if C00316, bit 2 = 0    |
|         | I/O Port B Data buffer, if C00316, bit 2 = 1                |
| C00316  | I/O Port B Control register                                 |

If you read from an I/O port data buffer, you input from the I/O port to the CPU; if you write to an I/O port data buffer, you output from the CPU to the I/O port.

The Data Direction registers identify each pin of an I/O port as being dedicated to either input or output. These are write only registers. You must write a control word into each Data Direction register; a 0 in a bit position configures the corresponding I/O port pin as an input, while a 1 results in an output:



Observe that I/O Ports A and B will both be configured as 8-bit input ports when the MC6820 is reset, since RESET clears all internal registers.

### Control register interpretation is quite complex.

The two high-order bits of each Control register are read only locations, which record the status of interrupt requests which may originate from either of two control lines associated with an I/O port:

**MC6820  
CONTROL  
CODES**



The remaining six control bits may be written into or read; they define the way in which the I/O port will operate.

Figures 9-22 and 9-23 describe the Control register interpretation for I/O Ports A and B respectively; since the two Control register interpretations are very similar, the points of difference are shaded so that they are easy to spot.

#### Let us clarify the functions enabled by the two Control registers.

Each I/O port has its own interrupt request signal: IRQA for I/O Port A and IRQB for I/O Port B. Each interrupt request signal has two separate sets of request logic, based on an interrupt request originating with a CA1/CB1 signal transition, or a CA2/CB2 signal transition.

**MC6820  
INTERRUPT  
LOGIC**

Control register bit 0 enables or disables IRQA/IRQB, based on signal CA1/CB1 transitions only. Quite independently, Control register bit 3 enables or disables IRQA/IRQB based on transitions of signal CA2/CB2. However, Control register bit 3 has an alternative interpretation; the one we have just described only applies if Control register bit 5 is 0.

Interrupt requests are triggered by the "active transitions" of a control signal. The active transitions of control signals may be a high-to-low, or a low-to-high transition. For CA1/CB1, the active transition is selected by Control register bit 1. For CA2/CB2, the active transition is selected by Control register bit 4, but only if Control register bit 5 is 0.

Irrespective of whether interrupt request signals IRQA and IRQB have been enabled or disabled, Control register bits 6 and 7 will report the interrupt request as a status, that is to say, if a condition exists where CA1/CB1 makes an interrupt requesting active transition, then Control register bit 7 will be set to 1. Similarly, if control signal CA2/CB2 makes an interrupt requesting transition, then Control register bit 6 will be set to 1. Once set, Control register bits 6 and 7 will remain set until a Read operation addresses the Control register; at that time Control register bits 6 and 7 will both be reset to 0, while other bits of the Control register are left unaltered.

If Control register bit 5 is 1, then Control register bits 4 and 3 take on a second interpretation. If Control register bits 5 and 4 are both 1, then control signal CA2/CB2 will be output at all times with the level of control bit 3.



Figure 9-22. I/O Port A Control Register Interpretation



Figure 9-23. I/O Port B Control Register Interpretation

If Control register bits 5 and 4 are 1 and 0 respectively, then Control register bit 3 specifies an automatic handshaking signal sequence. Let us describe these signal sequences.

**MC6820  
AUTOMATIC  
HANDSHAKING**

Input interrupt handshaking applies to I/O Port A only, and may be illustrated as follows:



CA2 is output on the trailing edge of E, after the CPU has read the contents of the I/O Port A data buffer; this tells external logic that previously input data has been read and new data may now be input. External logic receives CA2 low, and upon transmitting new data to I/O Port A, must cause an active interrupt requesting transition of input control signal CA1. What constitutes an active transition will be determined by I/O Port A Control register bit 1. When external logic requests an interrupt via signal CA1, CA2 will be set high again.

Input programmed handshaking applies only to I/O Port A, and may be illustrated as follows:



Once again control signal CA2 is output low when I/O Port A data buffer contents are read by the CPU. This tells external logic that previously input data has been read and new data may be input. External logic does not have to identify newly transmitted data with an interrupt request; rather, CA2 will be reset as soon as the MC6820 is deselected. Using programmed handshaking, external logic may use the CA2 low pulse as a Write strobe, causing new data to be input to I/O Port A.

**Output interrupt handshaking applies only to I/O Port B, and may be illustrated as follows:**



In this instance, control signal CB2 is output low on the high-to-low transition of E following a Write to I/O Port A Data buffer. In other words, CB2 tells external logic that new data has been output to I/O Port B and is ready to be read. External logic tells the MC6820 that I/O Port B contents have been read by making an interrupt requesting active transition of the CB1 signal. Once again, I/O Port B Control register bit 1 will determine what constitutes an active transition of the CB1 signal. Program logic can use an interrupt to branch to a program which outputs the next byte of data to I/O Port B.

**Output programmed handshaking applies only to I/O Port B, and may be illustrated as follows:**



CB2 makes a high-to-low transition when data is written into the I/O Port B data buffer, just as occurred with output interrupt handshaking. However, CB2 will automatically be set to 1 as soon as the MC6820 is deselected. External logic can use the CB2 low pulse as a strobe, causing it to read the contents of I/O Port B.

**Many other handshaking protocols may be created under program control.** The four automatic protocols described above are simply four situations which can be specified, and which will subsequently occur without further program intervention. But remember, you can modify the level of control signal CA2/CB2 any time by outputting a Control code with bits 5 and 4 both set to 1; CA2/CB2 will then take the level of Control code bit 3. You can also determine the conditions which will cause an interrupt request as a result of any control signal transition.

## THE MC6850 ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (ACIA)

The MC6800 microcomputer system provides separate devices supporting synchronous and asynchronous serial I/O. The MC6850, which we are about to describe, provides asynchronous serial I/O. The MC6852, which we will describe next, supports synchronous serial I/O.

Taken together, the MC6850 and MC6852 devices are approximately equivalent to the 8251 USART. The 8251 is a general purpose 8080 device that can be used with a variety of microcomputers. Refer to Volume 3 for a description of 8251's.

**Figure 9-24 illustrates that part of our general microcomputer system logic which is provided by the MC6850 and MC6852 devices.**

Having separate synchronous and asynchronous serial I/O devices has advantages and disadvantages, when compared to the 8251 USART which provides both sets of logic on a single device. In a microcomputer system that uses either asynchronous or synchronous serial I/O, but not both, separate devices are better, because they come in smaller packages and require less space on a PC card. If your microcomputer system uses both synchronous and asynchronous serial I/O, then a single device will be more economical.

When comparing the MC6850 with the 8251, you will find that the 8251 offers more asynchronous serial I/O options, but it is harder to program. In fact, you must program the 8251 defensively; 8251 statuses and control signals simply prompt your program logic, but actually do nothing within the 8251 USART itself. When using the MC6850 and MC6852, that is not the case; these two devices are much easier to program.

**The MC6850 ACIA is packaged as a 24-pin DIP. It is fabricated using N-channel silicon gate technology.**

A single +5V power supply is required.

In the discussion of the MC6850 that follows we will frequently refer to the 8251 USART description in Volume 3. If you are unfamiliar with asynchronous serial I/O devices in general, see Chapter 5 of Volume 1, then read the description of the 8251 USART which is given in Volume 3.

### THE MC6850 ACIA PINS AND SIGNALS

MC6850 ACIA pins and signals are illustrated in Figure 9-25. Signals may be divided into the following four categories:

- 1) CPU interface and control signals
- 2) Serial input
- 3) Serial output
- 4) Modem control

We will first consider CPU interface and control signals.

D0 - D7 constitutes an 8-bit bidirectional Data Bus connecting the MC6850 with the CPU.

When data is output to the MC6850 by the CPU, either a byte of parallel data or a Control code will be transmitted.

A byte of parallel data will be serialized and transmitted according to the protocol which has been selected under program control.

Either data or status may be input from the MC6850 ACIA to the CPU via the Data Bus. Data consists of an 8-bit parallel data unit extracted from the serial input data stream. Status consists of the contents of the ACIA Status register.

The Status register of the MC6850 ACIA is very important, because the MC6850 uses status flags where the 8251 uses control signals to monitor serial data transfer logic.

The MC6850 ACIA is accessed by the CPU as two memory locations. MC6850 select logic consists of the three chip select signals CS0, CS1 and CS2; manufacturers' literature also refers to the enable signal E as being part of the chip select logic; however, E is more accurately visualized as an internal synchronization signal.

For the MC6850 ACIA to be selected, CS0 and CS1 must be input high while CS2 is simultaneously input low. Once selected, the register select signal RS determines which of the two addressable locations within the MC6850 ACIA will be accessed. When RS is low, a Read will access the ACIA Status register, while a Write will access the ACIA Control register. When RS is high, ACIA data buffers will be addressed.

While the MC6850 ACIA is selected, internal logic is synchronized on the trailing edge of the E signal. E is a standard output of the various MC6870 clock devices used to synchronize support logic throughout an MC6800 microcomputer system.



Figure 9-24. Logic of the MC6850 ACIA or MC6852 SSDA Devices.

**R/W** is the control input which determines whether a Read or Write operation is in progress. When R/W is high, the CPU is reading data out of the MC6850. When R/W is low, the CPU is writing data to the MC6850.

The MC6850 has no RESET input; a Control code is used as a master Reset. When power is first detected within the MC6850, internal logic automatically initiates a Reset sequence. Subsequently, before initializing the MC6850 for serial data transfer you should again reset the device by inputting a Reset Control code.



| Pin Name      | Description              | Type                    |
|---------------|--------------------------|-------------------------|
| D0 - D7       | Data Bus to CPU          | Tristate, bidirectional |
| CS0, CS1, CS2 | Chip Select              | Input                   |
| E             | Internal synchronization | Input                   |
| RS            | Register Select          | Input                   |
| R/W           | Read/Write control       | Input                   |
| TxCLK         | Transmit Clock           | Input                   |
| TxD           | Transmit Data            | Output                  |
| RxCLK         | Receive Clock            | Input                   |
| RxD           | Receive Data             | Input                   |
| CTS           | Clear To Send            | Input                   |
| RTS           | Request To Send          | Output                  |
| DCD           | Data Carrier Detect      | Input                   |
| IRQ           | Interrupt request        | Output                  |
| VDD, VSS      | Power and Ground         |                         |

Figure 9-25. MC6850 ACIA Signals and Pin Assignments

## MC6850 DATA TRANSFER AND CONTROL OPERATIONS

There are a number of buffers through which data flows in and out of the MC6850 ACIA. These data flows may be illustrated as follows:



**Buffer names in the illustration above conform with terminology used for the 8251 in Volume 3; this will make it easier for you to compare the two devices.**

Like the 8251, the MC6850 has double buffered serial input and output logic. As described for the 8251, **while a data byte is being serialized and output from Buffer TB, you must simultaneously write the next data byte to Buffer TA. Also, while a serial data byte is being assembled in Buffer RB, you must read the previously assembled data byte out of Buffer RA.**

Unlike the 8251, the **MC6850 has a separate Control register**. You can therefore write Control codes and read status at any time without fear of scrambling data waiting to be transmitted.

As compared to the 8251, the MC6850 has very elementary serial I/O logic.

**TxCLK is an externally provided clock signal which times the serial, asynchronous data stream which is output via TxD.**

**Similarly, RxCLK is an externally provided clock signal which times the serial, asynchronous data stream which is input via RxD.**

**MC6850  
SERIAL I/O  
DATA AND  
CONTROL  
SIGNALS**

**There are no control signals accompanying serial I/O data;** rather, a single interrupt request signal is shared by all transmit and receive conditions. You have to write an interrupt service routine which reads the contents of the MC6850 Status register, and thus determine which one of the many serial data transfer interrupt request conditions has occurred.

The fact that you must execute instructions to duplicate the logic which the 8251 provides with its TxRDY, RxRDY and TxE signals will certainly make an MC6800 microcomputer system less attractive in an application that makes heavy use of serial I/O. Conversely, the MC6800 system will appear more attractive in simple applications, since you have less interface circuitry to be concerned with.

**Three modem control signals are provided: Clear To Send (CTS), Request To Send (RTS), and Data Carrier Detect (DCD).** CTS and RTS are identical to the signals with the same names described in Volume 1, Chapter 5 for the general case, and in Volume 3 for the 8251.

**MC6850  
MODEM  
CONTROL  
SIGNALS**

RTS is output by the MC6850 under program control when the MC6850 is ready to transmit data. A full duplex line turns RTS around and sends it back as CTS; a half duplex line returns CTS after line turnaround has occurred.

The MC6850 has no Data Set Ready (DSR) signal; this is the signal which many serial I/O devices transmit to modems or any external receiving logic when ready to commence with serial data communications. When using an MC6850, RTS must serve double duty, additionally substituting for DSR.

**Even though the MC6850 has only three of the normal four control signals, these signals work hard within the MC6850.**

The DCD input must be low for serial transmit logic within the MC6850 to be enabled. This is true also of the equivalent 8251 DSR signal; however, if the DCD signal makes a low-to-high transition, the MC6850 will generate an interrupt request, thus effectively halting serial data output. A low-to-high DCD transition implies that the modem has, for some reason, disconnected itself; any further data transfer will be lost. In the case of the 8251, if a modem disconnects itself and DSR goes high, this condition will be reflected in a Status register flag, but unless the CPU executes instructions to read the Status register and test for this condition, the 8251 will continue transmitting data — even though the receiving end is dead.

The MC6850 uses CTS high to prevent the Status register from reporting a "Transmit Register Empty" condition. The MC6800 CPU determines when to send another byte of data to the MC6850 by testing the Status register, and looking for a "Transmit Register Empty" condition. If this condition never gets reported, no data will ever be uselessly transmitted. Contrast this with 8251 logic, where a misprogrammed 8251 can and will continue to transmit data after CTS has gone high.

## MC6850 ACIA CONTROL CODES AND STATUS FLAGS

Let us now examine the way in which the MC6850 Control and Status registers are interpreted.

Here is the Control register interpretation:



MC6850  
CONTROL  
REGISTER

The CPU neither sends nor receives the parity bit. The MC6850 adds the parity bit to transmitted data and strips or resets the parity bit in received data before it goes to the CPU.

Control register bits 0 and 1 determine the data transfer clock rate. Recall that serial data is usually transmitted or received at 1/16th or 1/64th of the clock rate, TxCLK or RxCLK. Transferring serial data at the exact clock rate is referred to as isosynchronous data transfer.

**The master reset Control code substitutes for the normal reset input signal, which the MC6850 lacks.** A master reset clears all MC6850 registers, with the exception of Status register bit 3, which is unaltered.

MC6850  
SYSTEM  
RESET

Control register bits 2, 3 and 4 identify data bit, stop bit and parity options. Compared to the 8251, MC6850 options are somewhat limited; five and six data bits are not provided and you cannot select 1.5 stop bits.

**Control register bits 5 and 6 are transmit logic control bits. Control register bit 7 is a receive logic control bit.**

MC6850  
SERIAL I/O  
CONTROL  
LOGIC

Transmit logic consists of the RTS modem control and various transmit conditions that can cause an interrupt request.

Receive control logic consists of various receive conditions that can cause an interrupt request.

**Interrupt logic of the MC6850 is an integral part of status logic. Conditions that can result in an interrupt request are therefore summarized below along with a definition of Status register bits.** A "T" is placed in those bit positions that can result in an interrupt request from transmit logic. An "R" is placed in those bit positions that can result in an interrupt request from receive logic. Status register bit positions that have neither a "T" nor an "R" identify conditions that do not result in interrupt requests.

MC6850  
INTERRUPT  
LOGIC

In those bit positions containing a "T" or an "R", a 1 causes an interrupt request to occur. DCD (bit 3) is an exception; here it is the transition from 0 to 1 that causes an interrupt request. In each case, the interrupt request will only occur if interrupt logic has been enabled. If you look back at the Control register, you will see that transmit and receive interrupt logic can be enabled and disabled separately. Control register bits 5 and 6 determine whether transmit interrupt logic is enabled, while Control register bit 7 determines whether receive interrupt logic is enabled. Note that the condition of Status register bit 3 can also disable a TDRE interrupt request.

When an interrupt request occurs, the requesting condition is cleared in various ways depending upon where the request originated.

An RDRF interrupt request will be cleared if the CPU reads data from the MC6850, or if a reset Control code is output. A TDRE interrupt request will be cleared by writing data to the MC6850 or by issuing a reset Control code.

Interrupts requested by DCD or OVRN are cleared by reading the Status register after the error condition has occurred, and then reading the Data register. A Master Reset will also clear these interrupt requests.

Let us now take a closer look at the Status register itself. **This is how register bits are interpreted:**



(1 in a bit position represents "true" condition for bits 7, 6, 5, 4, 1 and 0.)

**Status register bit 0, Receive Data Register Full**, goes to 1 when a byte of assembled data is transferred from Receive register RB to Receive register RA. Bit 0 is cleared as soon as the CPU reads the contents of Register RA. The DCD modem control signal, when high, forces Status register bit 0 to stay low so that the CPU will not attempt to read nonexistent data.

**Status register bit 1, Transmit Data Register Empty**, goes from 0 to 1 as soon as data is transferred from Register TA to Register TB. This bit is reset to 0 as soon as the CPU writes another bit of data into Register TA.

**Status register bit 2, Data Carrier Detect**, is used by the MC6800 to determine the status of external logic communicating with the MC6850. When DCD makes a low-to-high transition, an interrupt request is generated and Status register bit 2 goes high. Bit 2 remains high until the Status register contents are read by the CPU after DCD has gone low again. A Reset will also set Status register bit 2 to 0. If the CPU reads the Status register while DCD is high, then subsequently Status register bit 2 will track the DCD level; however, another interrupt will not be requested. It is the actual low-to-high transition of the DCD signal which causes an interrupt request, not a high level of Status register bit 2.

**Status register bit 3, Clear To Send**, tracks the CTS modem control input. MC6850 logic uses Status register bit 3 to inhibit serial data transfer when external receiving logic is not ready to receive the serial data. When CTS is high, Status register bit 1 will be held low. A TDRE interrupt request cannot occur, and program logic which tests Status register bit 1 will not transmit another data byte to Register TA until it detects a 1 in Status register bit 1. Thus, for as long as CTS is high, serial transmit logic will be inhibited.

**Status register bits 4, 5 and 6 report framing, overrun and parity errors, respectively.** Recall that a framing error is reported when start and stop bits do not correctly frame a data character; a framing error refers to the data byte currently waiting to be read out of RA. An overrun error is reported if the CPU does not read Register RA contents before a byte of data is transferred from Register RB to Register RA. A parity error is reported if parity has been enabled by Control register bits 2, 3 and 4, but the wrong parity is detected.

A framing or parity error is automatically reset as soon as the erroneous data is read out of Register RA, or is overwritten.

An overrun error is cleared by reading data from the MC6850.

**Status register bit 7, Interrupt Request,** is 1 whenever there is an unacknowledged interrupt request pending at the MC6850 device. One method that an MC6800 will use to determine the source of an interrupt request is to read device Status registers. If the MC6850 has no other method of identifying itself to the CPU when requesting an interrupt, then the CPU determines whether the MC6850 was the requesting device by reading the contents of the MC6850 Status register and testing the condition of bit 7.

## THE MC6852 SYNCHRONOUS SERIAL DATA ADAPTER (SSDA)

The MC6852 SSDA provides MC6800 microcomputer systems with synchronous serial I/O logic.

The MC6852 SSDA may be looked upon as a companion device to the MC6850 ACIA which we have just described. Taken together, these two devices provide MC6800 microcomputer systems with total serial I/O capability.

Figure 9-24 illustrates that part of our general microcomputer system logic which is provided by the MC6850 and MC6852 devices.

The most striking difference between the MC6850 and the MC6852 is their respective capabilities. Whereas the MC6850 offers fewer asynchronous serial I/O options than the 8251 USART (described in Volume 3), the MC6852 offers significantly more synchronous serial I/O options. Moreover, the MC6852 provides additional serial I/O options without the penalty of defensive programming which is demanded by the 8251 USART.

The MC6852 SSDA is packaged as a 24-pin DIP. It is fabricated using N-channel silicon gate technology.

A single +5V power supply is required.

In the discussion of the MC6852 that follows, we will frequently refer to the 8251 USART description given in Volume 3. If you are unfamiliar with synchronous serial I/O devices in general, see Chapter 5 of Volume 1, then read the description of the 8251 USART which is given in Volume 3.

### MC6852 SSDA PINS AND SIGNALS

MC6852 SSDA pins and signals are illustrated in Figure 9-26. Most of these signals are identical to those illustrated in Figure 9-25 for the MC6850, therefore we will only describe four signals which differ.

The MC6852 has a master Reset input, which, when input low, logically resets the MC6852. We will define how a Reset occurs after describing the MC6852 controls and status flags affected by a Reset.

The Data Carrier Detect (DCD) modem control input performs two functions. The normal function of DCD is to serve as a control signal transmitted by an external data carrier which is ready to transmit serial data to the MC6852 SSDA. Both the high-to-low and the low-to-high transitions of DCD have additional significance. The high-to-low signal transition can optionally be used as an external synchronization indicator, while a subsequent low-to-high transition is an error indicator, signaling an unexpected disconnect:



Using the high-to-low DCD pulse for external synchronization is a programmable option. The error condition reported if DCD makes an unexpected low-to-high transition is not a programmable option; it is a permanent part of the MC6852 error detection logic.



| Pin Name | Description                    | Type                    |
|----------|--------------------------------|-------------------------|
| D0 - D7  | Data Bus to CPU                | Tristate, bidirectional |
| CS       | Chip Select                    | Input                   |
| E        | Internal synchronization       | Input                   |
| RS       | Register Select                | Input                   |
| R/W      | Read/Write control             | Input                   |
| TxCLK    | Transmit Clock                 | Input                   |
| TxD      | Transmit Data                  | Output                  |
| RxCLK    | Receive Clock                  | Input                   |
| RxD      | Receive Data                   | Input                   |
| RESET    | Master Reset                   | Input                   |
| DCD      | Data Carrier Detect            | Input                   |
| CTS      | Clear To Send                  | Input                   |
| SM/DTR   | Sync Match/Data Terminal Ready | Output                  |
| TUF      | Transmitter Underflow          | Output                  |
| IRQ      | Interrupt request              | Output                  |
| VDD, VSS | Power and Ground               |                         |

Figure 9-26. MC6852 SSDA Signals and Pin Assignments

**Clear To Send (CTS)** is the modem control signal which is normally input by external receiving logic, indicating that the MC6852 may begin transmitting serial data. Like DCD, the CTS high-to-low transition can be used to synchronize the beginning of data transmission; the low-to-high transition of CTS is an error indicator. Once again, using the high-to-low CTS pulse to provide external transmit synchronization is a programmable option. However, an untimely low-to-high transition of CTS is an error indicator only if internal synchronization is being used. Therefore, if the high-to-low CTS transition is active, then the low-to-high subsequent transition must be inactive; conversely, if the high-to-low CTS transition is inactive, then a subsequent low-to-high transition will be active. This is because the high-to-low transition, if active, means that external synchronization has been selected — in which case the disconnect error logic is inactive.

Note that whereas the CTS signal low-to-high transition is only active during internal synchronization operations, the DCD low-to-high transition is active at all times. This means that **external logic disconnecting itself during a serial transmit operation will only cause an error to be indicated if external synchronization has been selected. On the other hand, during a serial receive operation, if external logic disconnects itself, an error will be indicated whether internal or external synchronization has been selected.**

Since DCD and CTS can both be used for external synchronization, as we might expect, **DTR also serves a double function.** Under normal circumstances, DTR will be output low by the MC6852 when it is ready either to transmit, or to receive serial data. If the MC6852 has output DTR low before transmitting serial data, then the receiving data carrier will turn DTR around and send back a high-to-low DCD pulse as we illustrated. If you have selected external synchronization under program control, then you can additionally program DTR to output a single high pulse as soon as

synchronization has been detected. This may be illustrated as follows:



Because **DTR** also acts as a Sync Match acknowledge, it is referred to as **SM/DTR**.

**When the MC6852 transmits serial data, it transmits the least significant bit first. The MC6852 also expects to receive the least significant bit first when receiving serial data.**

#### MC6852 SERIALIZATION SEQUENCE

**Transmitter Underflow (TUF)** is the fourth unique MC6852 signal. This signal is output when an underflow condition occurs during serial synchronous data transmission. Recall that during serial synchronous data transmission, if serial transmit logic finds no data ready to be output, then in order to maintain synchronization, a break character or a Sync character will be output. A break character is a continuous high level, equivalent to FF<sub>16</sub>. A Sync character will have some predefined binary pattern. Providing you have programmed the MC6852 to output Sync characters when no valid data is ready for serial transmission, the MC6852 will precede each Sync character with a high TUF pulse. External receive logic can use a high TUF pulse as an indicator that the next received character is a Sync and can be discarded.

## MC6852 DATA TRANSFER AND CONTROL OPERATIONS

Like the MC6850, the MC6852 SSDA is accessed via two memory addresses; however, these two memory addresses are shared by seven locations within the MC6852, which results in a complex set of data flows, as illustrated in Figure 9-27.

These are the seven addressable locations of the MC6852:

- 1) Data input — a read only location.
- 2) Data output — a write only location.
- 3) Status register — a read only location.
- 4) Sync Code register — a write only location.
- 5, 6, and 7) Three Control registers — all are write only locations.

Data input and data output are self-evident: apart from being triple buffered — and we will discuss the implications of triple buffering shortly — there is nothing unusual about MC6852 data input or output.

The Status register is absolutely standard.

The three 8-bit Control registers provide the MC6852 with a substantial variety of control options, as compared to the MC6850, which was somewhat limited in this respect.

The Sync Code register stores the 8-bit synchronization character code; this is the character which must appear at the beginning of any synchronous serial data stream and may also be transmitted when data is unavailable during a normal transmit sequence.



Figure 9-27. Data Flows Within an MC6852 SSDA

Of the seven addressable locations, two are read only, while five are write only. **Each memory address can access two locations, providing one is exclusively read only, while the other is exclusively write only.** Since there are just two read only locations, one is assigned to each memory address. Since there are five write only locations, one (Control Code 1) is assigned to the lower address, which leaves four assigned to the higher address: the two high-order bits of Control Code 1 are used to select one of the four write only locations assigned to the higher address. While this may look like a complex scheme, in reality it is not: all it means is that you have to observe a rigid programming sequence when using an MC6852. In fact, understanding the MC6852 depends completely on understanding the Control and Status registers; therefore we will describe these registers first, then look at data transfer sequences.

## MC6852 STATUS REGISTER

The MC6852 Status register may be illustrated as follows:



(1 in a bit position represents "true" condition for bits 7, 6, 5, 4, 1 and 0.)

**Conditions that may generate interrupts are marked with letters in appropriate Status register bit positions.** An interrupt request initiated by an error condition is represented by the letter E. Interrupt requests originating at transmit or receive logic are represented by the letters T and R, respectively.

**Status register bit 0 (RDA) indicates when the MC6852 Status register has a byte of data ready to be read. Similarly Status register bit 1 (TDA) indicates when the MC6852 is ready to receive another byte of data which will be output as a serial data stream.**

As indicated in Figure 9-27, MC6852 transmit and receive logic is triple buffered. This differs from the MC6850 which uses double buffering.

**MC6852  
TRIPLE  
DATA  
BUFFERS**

**You can use the triple buffering of the MC6852 in one of two ways which you select using appropriate Control register codes.**

**You can select a single byte option,** in which case as soon as a single byte of data can be written to Buffer TA or read from Buffer RA, the appropriate status flag will be set—and if interrupts are enabled, an interrupt request will be made to the CPU. The program controlling MC6852 operation must respond by reading or writing a single byte of data. A byte of data written to Buffer TA will automatically be rippled through Buffer TT to Buffer TB, whence it will output as a serial data stream. Data arriving at Buffer RB will be rippled through Buffer RT to Buffer RA, whence it must be read by the CPU.

**If you select the two byte option under program control,** then no status flags will be set, nor will interrupt requests occur until two of the three 8-bit buffers are empty. Thus, status bit 0 will be set and a receive interrupt request will occur when Buffers RA and RT are both full. Under program control you must, at this time, read two bytes of data. So long as a single pulse of the timing E signal separates the two read commands, MC6852 logic will transfer Buffer RT contents to Buffer RA so that the second read accesses what had been in Buffer RT. In fact, you should read RA contents, then status, then RA contents again. If there are errors associated with the data byte in RT, they will not be reported until RT contents have been transferred to RA.

When using the two byte option with transmit logic, Status register bit 1 will not be set and the appropriate interrupt request will not occur until Buffers TA and TT are both empty. At this time the executing program must write two bytes of data to the higher MC6852 address, while Control code 1, bits 7 and 6 are both 1. The first byte of data written to the higher MC6852 address will store data in Buffer TA. The next pulse of the E clock will transfer the contents of Buffer TA to Buffer TT. The second write will again load Buffer TA whose previous contents are now in Buffer TT.

**Status register bits 2 and 3 are associated with signals DCD and CTS, respectively.** If DCD or CTS makes a low-to-high transition, then its corresponding Status register bit will latch high — that is, it will maintain a level of 1 until it is reset by the CPU. Once bit 2 (or 3) has been reset, it will track DCD (or CTS) until the next low-to-high transition.

**Note that in Sync mode, if Status register bit 3 is 1, then Status register bit 1 will be held at 0; this is how the MC6852 suppresses subsequent transmit logic.**

**Status register bits 4, 5 and 6 indicate Underflow, Overrun or Parity errors, respectively.**

**An Underflow error** occurs when transmit logic does not have a byte of data ready to transmit and has to insert a Sync character. The Underflow error is reported just before the Sync character is transmitted. When Status register bit 4 is set, the TUF signal is simultaneously pulsed high.

**An Overrun error** occurs when a byte of data is written into Buffer RA before prior buffer contents have been read. An Overrun error therefore indicates that a single byte of data has been lost.

**A Parity error** indicates that a Parity option has been selected, but the wrong Parity was detected for the data byte currently in Buffer RA.

**These three error conditions are completely standard; however, the way they are handled within the MC6852 is not standard.** When any one of these error conditions occurs, the appropriate Status register bit will be set and simultaneously an interrupt request will be generated, providing you have enabled these three error interrupts.

An error status is not cleared automatically. To clear Status register bits 4, 5 or 6, you have to read Status register contents, then issue an appropriate Control code to reset the selected bit.

We can summarize the functions performed by MC6852 Status register bits by looking at the manner in which each bit is set or reset; then we can separately examine the way in which interrupt logic is associated with each status bit position.

**Table 9-6 summarizes the conditions which cause each bit to be set and then reset. Table 9-7 summarizes interrupt requests associated with each status bit**, indicating the way the interrupt is enabled or disabled and the way in which an interrupt request occurs. You will find Table 9-7 following the three Control registers' description, because interrupt logic is equally dependent upon the Status register's contents and the three Control registers' contents.

## THE MC6852 CONTROL REGISTERS

Now consider the three MC6852 Control registers.

Control register 1 is normally the first to be accessed and has to be written into in order to select any other write only MC6852 location. **Control register 1 format may be illustrated as follows:**



(1 in a bit position represents "true" condition for bits 5, 4, 3, 2, 1 and 0.)

**Control register 1, bits 0 and 1 reset and inhibit receive and transmit logic, respectively.** You use these two Control register bits in order to disable transmit and receive logic while modifying the contents of any Control register or the Sync register.

**Control register 1, bits 0 and 1 are very important. It is easy to miss the significance of these two control bits.** If you always inhibit transmit and receive logic before modifying the contents of Control or Sync registers, you can make sure that spurious data is never transmitted or received. The 8251 USART described in Volume 3, does not have any inhibit logic of this type; and as a result, you have to adopt elaborate precautions to avoid data transmission errors.

While transmit and receive logic is inhibited, Status register bits 2 and 3 will still track the DCD and CTS signals; however, no data transfers will occur and interrupts associated with the inhibited logic will be disabled.

Using Control register 1, bits 0 and 1 to inhibit transmit and/or receive logic also affects Status register bits and interrupt requests, as summarized in Tables 9-6 and 9-7.

Table 9-6. MC6852 Status Register Bit Set/Reset Conditions

| STATUS       | SET                                                                                                                                   | RESET                                                                                                                                                                                                                      |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RDA - Bit 0  | 1) If Control register 2 bit 2 is 1, when Buffer RA is full.<br>2) If Control register 2 bit 2 is 0, when Buffers RA and RT are full. | 1) Write 1 in Control register 1 bit 0.<br>2) Read Buffer RA contents.                                                                                                                                                     |
| TDA - Bit 1  | 1) If Control register 2 bit 2 is 1 when Buffer TA is empty.<br>2) If Control register 2 bit 2 is 0 when Buffers TA and TT are empty. | 1) 1 occurs in Status register bit 5, together with 0 in Control register 3 bit 0.<br>2) Write 1 in Control register 1 bit 1.<br>3) Write into Buffer TA.                                                                  |
| DCD - Bit 2  | A low-to-high <u>DCD</u> input transition when Control register 1 bit 0 is 0.                                                         | 1) Read Status register, then read Buffer RA. Status will subsequently go low when <u>DCD</u> input goes low.<br>2) Write 1 into Control register 1 bit 0. Status will subsequently go low when <u>DCD</u> input goes low. |
| CTS - Bit 3  | A low-to-high <u>CTS</u> input transition when Control register 1 bit 1 is 0.                                                         | 1) Write 1 to Control register 3 bit 2. Status will subsequently go low when <u>CTS</u> input goes low.<br>2) Write 1 into Control register 1 bit 1. Status will subsequently go low when <u>CTS</u> input goes low.       |
| TUF - Bit 4  | Underflow when Control register 3 bit 0 is 0 and Control register 2 bit 6 is 1.                                                       | 1) Write 1 into Control register 3 bit 3.<br>2) Write 1 into Control register 1 bit 1.                                                                                                                                     |
| OVRN - Bit 5 | Buffer RT contents is transferred to Buffer RA before Buffer RA contents is read by CPU.                                              | 1) Read Status register, then read Buffer RA.<br>2) Write 1 into Control register 1 bit 0.                                                                                                                                 |
| PE - Bit 6   | Parity error for data in RA; providing Control register 2 bits 3, 4 and 5 identify a parity option.                                   | 1) Read data out of Buffer RA.<br>2) Write 1 into Control register 1 bit 0.                                                                                                                                                |
| IRQ - Bit 7  | Any interrupt request occurs.                                                                                                         | No active interrupt requests exist.                                                                                                                                                                                        |

Table 9-7. MC6852 Interrupt Summary

| INTERRUPT                                          | ENABLE                                                        | REQUEST                                                                         |
|----------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------|
| RDA — Read Buffer RA or Buffers RA and RT contents | Control register 1 bits 0 and 5 must be 0 and 1 respectively. | Status register bit 0 = 1                                                       |
| TDA — Write into Buffer TA or RA and TT            | Control register 1 bits 1 and 4 must be 0 and 1 respectively. | Status register bit 1 = 1.<br>This will not occur if Status register bit 3 = 1. |
| DCD — Transmitting data carrier disconnected       | Control register 2 bit 7 must be 1.                           | On low-to-high transition of DCD.                                               |
| CTS — Receiving external logic disconnected        | Control register 2 bit 7 must be 1.                           | On low-to-high transition of CTS.                                               |
| TUF — Transmit underflow has occurred              | Control register 2 bit 7 must be 1.                           | Status register bit 4 = 1.                                                      |
| OVRN — Receive overrun error has occurred          | Control register 2 bit 7 must be 1.                           | Status register bit 5 = 1.                                                      |
| PE — Parity Error                                  | Control register 2 bit 7 must be 1                            | Status register bit 6 = 1.                                                      |

**Control register 1, bit 5 allows you to enable or disable receive data interrupt logic. Control register 1, bit 4 allows you to enable or disable transmit data interrupt logic.**

There is no connection between Control register 1, bits 0 and 1, and Control register 1, bits 4 and 5. Obviously, if transmit or receive logic has been inhibited, then it makes no difference whether interrupt logic has been enabled or disabled; in either case an interrupt cannot occur. However, if transmit or receive logic is enabled, then interrupt logic may be separately enabled or disabled.

**Control register 1, bits 2 and 3 determine the way the Sync character will be handled.** If Control register 1 bit 2 is high, then all Sync characters in a serial receive data stream will be stripped, so that only non-Sync characters are read by the CPU. If Control register 1, bit 2 is low, then the entire data stream will be transmitted to the CPU, including data and Sync characters. Note that the initial Sync character is always stripped.

**Control register 1, bit 3 allows you to completely inhibit all Sync character logic.** Now the Sync character will be cleared, and the MC6852 must use external synchronization.

**Control register bits 6 and 7 determine which write only location will be accessed when the CPU writes to the higher memory location of the MC6852.**

Now consider Control registers 2 and 3, which are best looked upon as a single 12-bit control unit. These two Control registers may be illustrated as follows:



#### Control register 2, bits 0 and 1, and Control register 3, bits 0, 1, 2 and 3 are used to define synchronization logic.

Control register 3, bit 0 is used to determine whether internal or external synchronization will be employed. If internal synchronization is selected, then Control register 3, bit 1 determines whether one or two Sync characters must precede a serial data stream for initial synchronization to occur.

Control register 2, bits 0 and 1 must now be set so that SM/DTR logic conforms to the synchronization options selected by Control register 3, bits 0 and 1. You also use Control register 2, bits 0 and 1 to select the signal level that will be output for a standard DTR modem control.

#### Control register 2, bits 2, 3, 4, 5 and 6 define the data transfer options.

Recall that when the CPU reads received data, or writes data to be transmitted, data may be read and written one byte at a time, or two bytes at a time. We discussed this option when describing Status register bits 0 and 1. **You select the one byte or two byte mode via Control register 2, bit 2.**

**Control register 2, bits 3, 4 and 5 allow you to define the number of data bits per word, and parity options.** These are standard selections which have been described in detail in Volume 1, Chapter 5. Notice that the MC6852 provides a much wider variety of data and parity options than the MC6850.

Control register 2, bit 6 determines the response of MC6852 transmit logic when no data is ready to be transmitted. If Control register 2, bit 6 is 0, then a break code will be output on underflow; if this bit is 1, then a Sync character code will be output on underflow. Remember, an Underflow error will be reported in the Status register only if you transmit Sync character codes on Underflow. Therefore, Control register 2, bit 6 must be 1 if Underflow errors are to be reported in the Status register. Recall that an underflow error is reported before a Sync character is transmitted; also, the underflow error status is accompanied by a high TUF output signal pulse.

**Along with Control register 1, bits 4 and 5, which we have already described, Control register 2, bit 7 and Control register 3, bits 2 and 3 apply to MC6852 interrupt logic.**

MC6852 interrupt logic is quite complex. There are a number of interrupt sources and no standard procedure for enabling, disabling, acknowledging or processing different interrupt requests.

Rather than describing the Control register bits that pertain to interrupts, therefore, **various interrupt options provided by the MC6852 are summarized in Table 9-7.**

**MC6852  
INTERRUPT  
LOGIC**

## PROGRAMMING THE MC6852

Let us now look at the normal sequence of events when programming the MC6852.

**First the MC6852 must be initialized.** Initialization begins by resetting the MC6852 using the RESET control input. When the MC6852 is reset this is what happens:

- 1) Control Register 1, bits 0 and 1 are set to 1, inhibiting transmit and receive logic.
- 2) Control register 2, bits 0 and 1 are reset to 0, causing SM/DTR to be output high.
- 3) Control register 2, bit 7 is reset to 0, disabling DCD and CTS interrupt requests, and all error interrupt requests.
- 4) Control register 3, bit 0 is reset to 0, selecting internal synchronous mode.
- 5) Status register bit 1 is cleared and held low so that the CPU never reads a status that requests data be written to the MC6852.

**MC6852  
RESET  
OPERATION**

Control register bits affected by the RESET control input cannot be modified until RESET goes high again.

Following device Reset, you must load Control registers 1, 2 and 3 and the Sync Code register. The only caution concerns Control register 1; remember, Control register 1, bits 6 and 7 must be modified so that you can access Control registers 2 and 3 and the Sync Code register. When modifying Control register bits 6 and 7, be sure not to inadvertently modify the remaining six bits of Control register 1.

**Once the MC6852 has been initialized, you are ready to start transmitting or receiving data.**

The only complications associated with transmitting or receiving data involve the way in which you select the programmable options of this device. There is nothing intrinsically different or complicated about the MC6852, as compared to any other synchronous serial I/O device. **These are the only rules to observe:**

- 1) Always inhibit transmit and receive logic via Control register 1, bits 0 and 1 before modifying the contents of any Control register or the Sync register.
- 2) Unless you have enabled error interrupts, always precede any data read or write operation by reading the contents of the Status register and checking for errors.
- 3) **Remember, the MC6852 transmits serial data least significant bit first. This is the inverse of IBM format; and it is up to you to invert the data stream when using an MC6852 with external IBM protocol logic.**



Figure 9-28. Logic of the MC6828 Priority Interrupt Controller

## THE MC8507 (OR MC6828) PRIORITY INTERRUPT CONTROLLER (PIC)

This Priority Interrupt Controller has two part numbers, identifying the fact that it is a bipolar part, and also compatible with the NMOS family of the MC6800 microcomputer devices. We will use the part identification MC6828 in the discussion that follows.

The MC6828 Priority Interrupt Controller processes up to eight external interrupt requests, creating a vectored response to an interrupt acknowledge. Interrupt priorities are determined by pin connections, but under program control you can set a priority level below which all interrupts are inhibited.

Figure 9-28 illustrates that part of our general microcomputer system logic which is provided by the MC6828 PIC.

**The MC6828 PIC cannot be compared to the 8259 PICU which is available with 8080A microcomputer systems.** The briefest inspection of the two devices will indicate that the 8259 offers a significantly wider range of options — which can be a good thing or a bad thing. As we have often stated, an excessive dependence on interrupt processing in microcomputer applications is hard to justify; in all probability the more limited capabilities of the MC6828 will adequately serve the needs of any reasonable microcomputer application.

**The MC6828 is packaged as a 24-pin DIP. It is fabricated using bipolar LSI technology.**

**A single +5V power supply is required.**

## MC6828 PINS AND SIGNALS

MC6828 pins and signals are illustrated in Figure 9-29.

In order to understand this device, you must first look at the way in which it is used within an MC6800 microcomputer system.



Figure 9-29. MC6828 Signals and Pin Assignments

Recall that when any standard external interrupt is acknowledged by an MC6800 CPU, the CPU will fetch the starting address for the interrupt service routine from memory locations  $\text{FFF8}_{16}$  and  $\text{FFF9}_{16}$ . These two addresses may be illustrated as follows:



The MC6828 PIC is positioned serially, preceding the external memory device which is to be selected by the addresses FFF8<sub>16</sub> and FFF9<sub>16</sub>. Address lines A<sub>1</sub>, A<sub>2</sub>, A<sub>3</sub> and A<sub>4</sub> terminate at the MC6828. Logic within the MC6828 appropriately manipulates these four address lines and outputs some value which may differ from the input value. This may be illustrated as follows:



Thus, what the MC6828 does is extend the two addresses FFF8<sub>16</sub> and FFF9<sub>16</sub> into 16 addresses, FFE8<sub>16</sub> through FFF7<sub>16</sub>.

The CPU knows nothing about the address manipulation which is taking place within the MC6828. So far as the CPU is concerned, upon acknowledging an external interrupt, it reads two bytes of data from memory locations FFF8<sub>16</sub> and FFF9<sub>16</sub>; the fact that there are eight possible responses to these two addresses is of no concern to the CPU.

Conceptually, the MC6828 is acting as an 8-way switch. The CPU addresses the switch by its "stem", via a single address. The actual conduit for the transfer of two bytes of data depends on the switch position at the time the CPU accesses the switch stem; and the switch position is going to be determined by the highest priority active interrupt request. This may be illustrated as follows:



Let us now look at the device pins and signals.

A<sub>1</sub> - A<sub>4</sub> represents the termination of System Address Bus lines A<sub>1</sub> - A<sub>4</sub> at the MC6828.

The continuation of the four address lines is via pins Z<sub>1</sub> - Z<sub>4</sub>.

The eight external interrupt requests are connected to IN0 - IN7. Interrupt priorities are in ascending level, from IN0 which has lowest priority through IN7 which has highest priority.

Device select logic consists of CS<sub>0</sub> and CS<sub>1</sub>. For this device to be selected, CS<sub>0</sub> must be low while CS<sub>1</sub> is high. There are additional select requirements that depend on the operation being performed, as we will describe shortly.

**R/W** is the read/write control output by the MC6800 CPU.

**E** is the standard enable signal required by all support devices of an MC6800 microcomputer system. You can extend the response time available to the MC6828 by extending the E input.

A **STRETCH** output is created and can be connected directly to the clock device of the microcomputer system in order to provide as much response time as needed by the MC6828.

The actual interrupt request which generates the entire response process occurs via the **IRQ** output from the MC6828. This output will normally be connected to the MC6800 **IRQ** input.

## THE INTERRUPT ACKNOWLEDGE PROCESS

When any one of the eight interrupt request lines **IN0 - IN7** is low, an interrupt request is generated via **IRQ**. This interrupt request is passed on to the MC6800 CPU.

As is normal, the MC6800, upon acknowledging the interrupt request, will perform two read operations; during these read operations the contents of memory locations FFF8<sub>16</sub> and FFF9<sub>16</sub> are read. The MC6800 CPU interprets the contents of these two memory locations as a 16-bit address, identifying the beginning of the interrupt service routine which is to be executed following the acknowledge.

When the MC6800 CPU is reading the contents of memory locations FFF8<sub>16</sub> and FFF9<sub>16</sub>, these are the signal levels for the control and select inputs to the MC6828:

| R/W | CS0 | CS1 | A4 | A3 | A2 | A1 |
|-----|-----|-----|----|----|----|----|
| 1   | 0   | 1   | 1  | 1  | 0  | 0  |

The MC6828 interprets the signal combination R/W·CS0·CS1·A1·A2·A3·A4, as a special select, causing it to output binary data on the Z1, Z2, Z3 and Z4 pins representing the highest priority active interrupt request occurring on any of the interrupt request pins **IN0 - IN7**. Table 9-8 defines the binary data output corresponding to each interrupt level.

If R/W is high, CS0 is low and CS1 is high, but A1, A2, A3, A4 are not 0011, then the MC6828 will simply output, via Z1 - Z4, whatever is being input via A1 - A4. Also, when the MC6828 is not selected, A1 - A4 is simply output via Z1 - Z4, whatever values are input via A1 - A4; that is to say, 0011 input to A1 - A4 will be output via Z1 - Z4 if the MC6828 is not selected. Thus, the presence of the MC6828 on the A1 - A4 address lines of the Address Bus will be transparent until either the address FFF8<sub>16</sub> or the address FFF9<sub>16</sub> appears on the Address Bus.

In order to guarantee that the MC6828 remains synchronized with the rest of the MC6800 microcomputer system, logic internal to the MC6828 uses the E synchronization signal as part of internal enable logic. The way in which the E synchronization signal is used is of no particular concern to you, as an MC6828 user. Providing the E synchronization signal which drives the rest of the MC6800 microcomputer system also drives the MC6828, problems will not arise.

Table 9-8. MC6828 Address Vectors Created for Eight Priority Interrupt Requests

| PRIORITY  | PIN | Z4 | Z3 | Z2 | Z1 | EFFECTIVE ADDRESSES |
|-----------|-----|----|----|----|----|---------------------|
| Highest 7 | IN7 | 1  | 0  | 1  | 1  | FFF6 and FFF7       |
| 6         | IN6 | 1  | 0  | 1  | 0  | FFF4 and FFF5       |
| 5         | IN5 | 1  | 0  | 0  | 1  | FFF2 and FFF3       |
| 4         | IN4 | 1  | 0  | 0  | 0  | FFF0 and FFF1       |
| 3         | IN3 | 0  | 1  | 1  | 1  | FFEE and FFEEF      |
| 2         | IN2 | 0  | 1  | 1  | 0  | FFEC and FFED       |
| 1         | IN1 | 0  | 1  | 0  | 1  | FFEA and FFEB       |
| Lowest 0  | IN0 | 0  | 1  | 0  | 0  | FFE8 and FFE9       |

## **INTERRUPT PRIORITIES**

**Table 9-8 defines the priorities that will be applied to simultaneous interrupt requests occurring at pins IN0 - IN7.** This table also indicates the exact memory addresses which will be created by the MC6828 in response to each of the interrupt requests. In order to use the MC6828 PIC in an MC6800 microcomputer system, 16 bytes of PROM or ROM, selected by the addresses given in Table 9-8 must be connected to the MC6828. Within these 16 bytes of PROM or ROM, you must store the starting addresses for the eight interrupt service routines which are going to be executed following acknowledgement of each possible external interrupt request. For example, suppose that interrupt requests arriving at the IN5 pin of the MC6828 must be serviced by an interrupt service routine whose first executable instruction is stored in memory location 2E00<sub>16</sub>. The value 2E00<sub>16</sub> must then be stored in the two PROM or ROM bytes selected by memory addresses FFF2<sub>16</sub> and FFF3<sub>16</sub>. Remember, the high-order byte of an address is always stored at the lower address. Thus 2E<sub>16</sub> will be stored in memory location FFF2<sub>16</sub> while 00<sub>16</sub> is stored in memory location FFF3<sub>16</sub>.

**In simple configurations** the 16 bytes of PROM or ROM selected by **the MC6828** will be part of the MC6800 address space; the MC6828 simply **sits on the Address Bus**. Logic may be illustrated as follows:



Chip select logic generates  $\overline{CS_0}$  as the NAND of address lines A5 through A15; thus, the MC6828 will be selected only when these address lines are all high. VMA is used to generate select line CS1. Since VMA is high only while a valid memory address is being output, valid select logic is completed. Address lines A4 through A1 physically terminate at the MC6828, which re-generates them via the Z4 through Z1 outputs. Z4 through Z1 will exactly reflect A4 through A1, unless the MC6828 is selected and A4 through A1 is 1100. Thus, the presence of the MC6828 will add a slight propagation delay on the Address Bus, but otherwise it will have no effect on addresses being transmitted until FFF816 or FFF916 appear.

**It is also possible to move the MC6828 PIC out of the main Address Bus path**, in which case its 16 bytes of PROM or ROM are not within the main microcomputer address space. This scheme may be illustrated as follows:



In the above scheme it is only necessary that memory addresses  $FFF8_{16}$  and  $FFF_{16}$  be reserved for the MC6828 PIC. This is because A4, A3, A2 and A1 contribute to  $\bar{CS}_0$  logic; they must be 1100 for  $\bar{CS}_0$  to be low.  $CS_1$  is generated by the high VMA pulse. Address Bus lines A1, A2, A3 and A4 now branch to form a new five-line Address Bus — A0 with Z1 through Z4. This five-line Address Bus is input to a separate ROM or PROM which is enabled by the same logic that enables the MC6828.

If you move the MC6828 PIC out of the main Address Bus, then you can have more than one MC6828 device within a single MC6800 microcomputer system. Each MC6828 device must have its own 32 bytes of PROM or ROM, and device priority must be established by conditioning lower priority MC6828 select logic with higher priority interrupt request logic. This may be illustrated as follows:



Any one interrupt request being true at a higher priority MC6828 PIC will suppress the high VMA pulse and automatically prevent a lower priority MC6828 PIC from being selected.

### INTERRUPT INHIBIT LOGIC

**The MC6828 provides a very elementary level of interrupt inhibit logic. You can output a mask to the MC6828 identifying a priority level below which all interrupts will be inhibited.**

Now the mask is written out to the MC6828 in a very unusual way.

Recall that the MC6828 requires memory addresses FFE8<sub>16</sub> through FFF9<sub>16</sub> to access PROM or ROM. Any attempt to write into these memory addresses will be ignored. The MC6828 takes advantage of this fact by trapping attempts to write into memory locations FFE8<sub>16</sub> through FFF9<sub>16</sub>. That is to say, when R/W is low while CS0 is low and CS1 is high, the MC6828 considers itself selected, but it interprets the four address lines A1, A2, A3, A4 as data, defining the mask level below which interrupts will be inhibited. **Table 9-9 defines the way in which the mask specified by address lines A1, A2, A3 and A4 will be interpreted.**

Table 9-9. MC6828 Interrupt Masks — Their Creation and Interpretation

| Write anything to this address: | and Address Bus lines A1-A4 will have this value: | Which will inhibit all interrupts, including and below: |
|---------------------------------|---------------------------------------------------|---------------------------------------------------------|
| FFE0 or FFE1                    | 0000                                              | All interrupts enabled                                  |
| FFE2 or FFE3                    | 0001                                              | IN1                                                     |
| FFE4 or FFE5                    | 0010                                              | IN2                                                     |
| FFE6 or FFE7                    | 0011                                              | IN3                                                     |
| FFE8 or FFE9                    | 0100                                              | IN4                                                     |
| FFEA or FFEB                    | 0101                                              | IN5                                                     |
| FFEC or FFED                    | 0110                                              | IN6                                                     |
| FFEE or FFFF                    | 0111                                              | IN7                                                     |
| FFFO through FFFF               | 1000 through 1111                                 | All interrupts disabled                                 |

## THE MC6840 PROGRAMMABLE COUNTER/TIMER

This is a programmable device which contains three sets of counter/timer logic. Each set of counter/timer logic can be programmed independently to perform a variety of time interval, pulse width measurement and signal generation operations.

The MC6840 programmable counter/timer is described in this chapter rather than in Volume 3 because, like other 6800 support devices, it requires the enable clock signal as an input.

The MC6840 is somewhat more versatile than the 8253 programmable counter/timer, which was first developed as an Intel 8080 support device; the 8253 counter/timer is described in Volume 3. Within an MC6800 or MCS6500 microcomputer system, the 8253 is probably preferable to the MC6840; this is because capabilities of the MC6840 are not sufficiently superior to the 8253 to compensate for the enable clock signal and its attendant synchronization problems.

The MC6840 is fabricated using N-channel silicon gate depletion load technology; it is packaged as a 28-pin DIP.

### THE MC6840 COUNTER/TIMER PINS AND SIGNALS

MC6840 counter/timer pins and signals are illustrated in Figure 9-30. These pins and signals are described in conjunction with a general discussion of the MC6840 organization logic and capabilities.

Each of the three sets of timer logic has a 16-bit Counter, a 16-bit Latch and three control signals, illustrated as follows:





Figure 9-30. MC6840 Counter/Timer Signals and Pin Assignments

When any counter or timer operation is initialized, the 16-bit Latch contents are loaded into the associated 16-bit Counter. The Counter is then decremented either on high-to-low transitions of the external clock signal (C<sub>1</sub>) or on high-to-low transitions of the internal Φ<sub>2</sub> clock signal; selecting one or the other is a programmable option. This may be illustrated as follows:

**MC6840  
COUNTER/TIMER  
INITIALIZATION**



XXXX represents any initial 16-bit value.

If the external clock signal is used to decrement the counter/timer, then it is being used as an event counter; if the internal synchronization clock is used to decrement the counter/timer, then it is being used as a timer.

The external signals C̄ and Ḡ are sampled on the trailing edge of Φ<sub>2</sub>. This has important synchronization consequences.

Timing for external clock signal  $\bar{C}$  or  $G$  may be illustrated as follows:

MC6840  
EXTERNAL  
SIGNAL  
TIMING



Thus, external clock signal frequencies may vary from 0 (DC) to somewhere less than half of the internal  $\Phi_2$  clock frequency.

**It is very important that external signal timing conform to the illustration above.** If insufficient setup time is provided, MC6840 logic will possibly recognize the initial high-to-low signal transition twice: once assuming that the setup time just made it, and again assuming that it did not; this may be illustrated as follows:



A similar problem may occur on the trailing edge of the external signal. This may result in clock pulses being missed. This may be illustrated as follows:



**Any transition of the  $\bar{C}$  or G input signals is not recognized by internal MC6840 logic for four  $\Phi_2$  clock periods.** This may be illustrated as follows:



One point can cause confusion when you are using the external clock ( $\bar{C}$ ) to decrement the counter/timer: it will still take four internal clock pulses ( $\Phi_2$ ) to recognize each external clock pulse, as illustrated above. A common mistake, when using this part, is to assume that internal clock recognition is simply delayed four clock pulses: the delay is four internal clock pulses.

The only significance of this delay is that there is indeed a delay. This delay has no effect on external clock signal frequency or timing.

The gate input (G) is used variously to initiate or suspend timer operations.

Timer results can be output via the output signal O. A variety of continuous or one-shot wave forms may be generated via the O output signals.

The programmer accesses an MC6840 counter/timer as eight contiguous memory locations. A memory location is selected via two chip select inputs (CS0 and CS1) plus three register select inputs (RS0, RS1 and RS2).

As is standard for MC6800 support devices, chip select logic should be conditioned by the valid memory address (VMA) signal. Device select and addressing logic may be illustrated as follows:



Once the MC6840 has been selected, **the level of the R/W signal determines whether a read (R/W high) or a write (R/W low) operation is to occur.** If R/W is low, the CPU will write into the selected MC6840 location; if R/W is high, the contents of the selected MC6840 location will be read.

**Any data transferred to or from the MC6840 is transferred via the Data Bus.** The MC6840 Data Bus connection is three-state: when a read or a write operation is not in progress, the MC6840 disconnects itself from the Data Bus.

**The MC6840 is reset by applying a low input signal to the RESET pin. Necessary reset timing may be illustrated as follows:**



RESET signal timing requirements are the same as the C and G requirements which we just described. The RESET is recognized by internal logic two clock pulses after a low level is detected.

Following a valid reset, all Latches are loaded with the value FF<sub>16</sub>, and this value is transferred to the Counter registers. All Control registers are reset to 0, with the exception of Control Register 1 bit 0, which is set to 1. This is a system initialization bit which we will describe later. The Status register is also cleared. Thus, following a reset, those programmable options which are selected by 0 bits in the Control registers will be enabled.

## MC6840 ADDRESSING

Addressable locations within the MC6840 are all read-only or write-only locations. Table 9-10 identifies MC6840 addressable locations.

Table 9-10. MC6840 Addressable Locations

| Register Selected |     |     |               | Operations                                                                                                                           |                         |
|-------------------|-----|-----|---------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| RS2               | RS1 | RS0 | Label Address | R/W=0 (Write)                                                                                                                        | R/W=1 (Read)            |
| 0                 | 0   | 0   | DEV           | Write to Control Register 3<br>if Control Register 2, bit 0 is 0<br>Write to Control Register 1<br>if Control Register 2, bit 0 is 1 | No operation            |
| 0                 | 0   | 1   | DEV + 1       | Write to Control Register 2                                                                                                          | Read Status register    |
| 0                 | 1   | 0   | DEV + 2       | Write to MSB register                                                                                                                | Read Counter Register 1 |
| 0                 | 1   | 1   | DEV + 3       | Write to Latches 1                                                                                                                   | Read LSB register       |
| 1                 | 0   | 0   | DEV + 4       | Write to MSB register                                                                                                                | Read Counter Register 2 |
| 1                 | 0   | 1   | DEV + 5       | Write to Latches 2                                                                                                                   | Read LSB register       |
| 1                 | 1   | 0   | DEV + 6       | Write to MSB register                                                                                                                | Read Counter Register 3 |
| 1                 | 1   | 1   | DEV + 7       | Write to Latches 3                                                                                                                   | Read LSB register       |

There are some nonobvious aspects to MC6840 addressing. We will first look at write addresses.

If we number the three counter/timer logic elements 1, 2 and 3, counter/timer logic element 2 has a unique write-only address for its Control register. (It is address DEV+1). Counter/timer elements 1 and 3 share a single write-only address (DEV). The level of Control register 2 bit 0 determines whether Control Register 1 or 3 will be selected by address DEV. This may be illustrated as follows:



Following a device reset, Control Register 2, bit 0 will be 0. Therefore, initially Control Register 3 will be selected by address DEV. Thus, you will normally access Control registers in the sequence 3, 2, 1, as follows:

- 1) Select address DEV, access Control Register 3.
- 2) Select address DEV+1, access Control Register 2. Set Control Register 2, bit 0 to 1.
- 3) Select address DEV, access Control Register 1.

Three write addresses select an "MSB" register. All three write addresses select the same temporary "Most Significant Byte" buffer. This buffer allows 16 data bits to be written into any one of the three 16-bit latches when a single 8-bit write is executed. This may be illustrated as follows:



The Most Significant Byte (MSB) buffer allows the MC6840 to be accessed by MC6800 16-bit write instructions. You can, for example, use an STX or STS instruction to transfer the contents of the Index register or the Stack Pointer to the selected MC6840 location. There are three MC6840 locations which can receive a 16-bit data value; they are the three counter/timer latches illustrated above as Latches 1, Latches 2 and Latches 3. You address these counter/timer latches via their associated Most Significant Byte buffer address. Now when you output a 16-bit value (for example, from the Index register), first the high-order byte is transferred to the Most Significant Byte (MSB) buffer. For Latches 2 this may be illustrated as follows:



Then the low-order byte is transferred to the low-order byte of the addressed counter/timer latches, while simultaneously the Most Significant Byte (MSB) buffer contents are transferred to the high-order byte of the addressed counter/timer latches. This may be illustrated as follows:



You can, of course, access counter/timer latches using single byte instructions. You could, for example, transfer a 16-bit value one byte at a time from Accumulator A, via the following instruction sequence:

|     |         |                                                |
|-----|---------|------------------------------------------------|
| LDA | A,#HI   | LOAD ADDRESS HIGH-ORDER BYTE AS IMMEDIATE DATA |
| STA | A,DEV+4 | STORE IN MSB BUFFER                            |
| LDA | A,#LO   | LOAD ADDRESS LOW-ORDER BYTE AS IMMEDIATE DATA  |
| STA | A,DEV+5 | WRITE 11 DATA BITS TO LATCHES 2                |

This instruction sequence may be illustrated as follows:







As illustrated by the instruction sequence above, you must first transfer the high-order byte of data to the Most Significant Byte (MSB) buffer, then you must transfer the low-order byte of data to the timer/counter Latches address; when you write to the timer/counter Latches address, the data moves into the low-order byte of the timer/counter Latches, while simultaneously the Most Significant Byte buffer contents are transferred to the high-order byte of the timer/counter Latches.

#### **There are seven read-only locations within the MC6840.**

Address DEV does not select any read-only location.

Address DEV+1 reads the contents of a Status register; this register records time out and interrupt request status for the three sets of counter/timer logic. The Status register is described later.

The remaining six read-only addresses are used to read the contents of the counter/timer counters in a manner that is analogous to the way in which you write into the counter/timer latches. This may be illustrated as follows:



The three addresses which select the Least Significant Byte (LSB) buffer once again address the same location. Consider the LDX instruction which loads a 16-bit data value into the CPU Index register. When this instruction addresses an MC6840 counter/timer, you first read a Counter register high-order byte into the Index register high-order byte while simultaneously transferring the Counter register low-order byte into the Least Significant Byte (LSB) buffer. For Counter 2 this may be illustrated as follows:



The Least Significant Byte (LSB) buffer contents are then transferred to the low-order Index register byte:



You can, of course, read Counter register contents one byte at a time, but you must make sure that you read the high-order byte first by addressing the counter itself; then you must read the low-order byte by addressing the next addressable location. This may be illustrated for Counter 2 by the following instruction sequence:

```
LDA A,DEV+4    LOAD COUNTER HIGH-ORDER BYTE TO ACCUMULATOR A
LDA B,DEV+5    LOAD COUNTER LOW-ORDER BYTE TO ACCUMULATOR B
```

#### **There are some ways of getting into trouble when accessing the MC6840.**

As illustrated for Counter read and Latch write operations, when reading or writing to the MC6840 you must first select an even address location, and then address the next sequential location. If you write first to an odd address, you will transfer into the selected latches eight bits of data plus whatever happens to be in the Most Significant Byte buffer.

If you read first from an odd address, you will read whatever happens to be in the Least Significant Byte (LSB) buffer. You must never access the MC6840 with an instruction that modifies the contents of a memory location; these instructions read the contents of the addressed memory location to the CPU, modify its contents, and then write the contents back to the same addressed memory location. For an increment memory instruction:

```
INC DEV+4
```

this may be illustrated as follows:

Step 1



## Step 2



As illustrated above, the same address accesses different MC6840 locations on a read or write; you will read the contents of one location, modify them, and write them back to a totally different location. Therefore, when accessing the MC6840 under program control, you must be sure not to use instructions that modify memory; use only instructions that read from memory or write to memory.

## MC6840 COUNTER/TIMER PROGRAMMABLE OPTIONS

We will begin our discussion of the MC6840 counter/timer options by describing the Control code which must be written into each Control register. Subsequently, the various operating modes will be discussed along with appropriate examples.

This is the general format for the Control code:



Bits 0 of the three Control registers are unusual in that they have different interpretations for the three Control registers.

Control Register 1, bit 0 is a system initialization bit. System initialization is identical to a system reset, with the exception that latches are not effective. Thus, as soon as a 1 is written to Control Register 1, bit 0, all three counter/timers are stopped, the contents of all three Latches are transferred to their associated Counter registers, the Status register is cleared, and all Control register bits (with the exception of Control Register 1 bit 0) are reset to 0.

### MC6840 PROGRAMMED INITIALIZATION

Control Register 2, bit 0 is an addressing bit. When this bit is 0, a write to the lowest MC6840 address (DEV) will access Control Register 3; when this bit is 1, a write to address DEV will select Control Register 1. This was graphically illustrated in our earlier discussion of MC6840 addressing.

Control Register 3, bit 0 is unique to counter/timer 3. When this bit is 1, every eighth clock pulse will be active at counter/timer 3. This may be illustrated as follows:

**MC6840  
DIVIDE-BY-EIGHT CLOCK**



Control register bits 1 through 7 serve identical functions, but apply only to one set of counter/timer logic. Each of the three counter/timer logic elements operates quite independently, and is in no way influenced by conditions at either of the other counter/timer elements.

Control register bit 1 determines whether Counter register contents will be decremented by external clock signal (C) transitions, or by the internal  $\Phi_2$  clock. In either case the counter will be decremented on high-to-low clock transitions.

Control register bit 2 determines the way in which the Counter register will decrement. There are two options: 16-bit counting mode and 8-bit counting mode. In 16-bit counting mode, the 16-bit counter contents are treated as a single 16-bit entity. Once an initial value has been loaded into the counter, it decrements on each active clock transition. When the clock decrements to 0, a time out occurs. This may be illustrated as follows:

**MC6840  
16-BIT COUNTING MODE**



There are a variety of ways in which you initialize a counter/timer. These are programmable options which depend on the selected operating mode — which we will describe later.

A time out occurs after a Counter register decrements to 0. On the next clock pulse the Counter register is reloaded with the contents of the latches. Under program control you can determine whether a time out will be marked by an interrupt request, and whether the counter/timer will stop or run continuously.

**MC6840  
8-BIT  
COUNTING  
MODE**

In 8-bit counting mode the high-order and low-order bytes of the counter are treated as separate entities. On each active clock transition the low-order counter byte is decremented; when the low-order byte decrements from 1 to 0, nothing happens. On the next active transition of the clock, the low-order byte is reloaded from the low-order byte of the latch and the high-order byte is decremented. This may be illustrated as follows:



Initialization logic, time out logic and programmable options are identical in 16-bit and 8-bit modes. What differs are the events between initialization and time out.

We can contrast 8-bit and 16-bit modes decrement logic by looking at what happens after an initial value of 040A<sub>16</sub> has been loaded into a counter/timer latch. In 16-bit mode a time out will occur after 1011<sub>10</sub> clock pulses. Assuming a 1 microsecond clock, a time out will occur every 1.011 milliseconds:

$$040A_{16} = 101010 \\ \text{Time out occurs one clock pulse later, that is, after } 1011_{10} \text{ pulses} \\ 1011_{10} \text{ microseconds} = 1.011 \text{ milliseconds}$$

In 8-bit mode a time out will occur after 55 clock pulses. With reference to the 8-bit mode illustrated above, let us see how we derive this value.

The low-order Counter register byte contains 0A<sub>16</sub>, which is equal to 1010. It takes 1010 clock pulses to decrement the low-order byte to 0. On the 11th clock pulse the high-order byte is decremented, while the low-order byte is reloaded from the low-order byte of the latches. The high-order byte is therefore decremented once every N+1 clock pulses, where N is the initial value which is loaded into the Counter register low-order byte.

The Counter register high-order byte decrements to 0. On the next attempt to decrement the Counter register high-order byte, if it already contains 0, a time out occurs. Thus, the Counter register high-order byte is decremented M+1 times, where M is the initial Counter register high-order byte contents. Thus, you can compute the number of clock pulses until a time out occurs in 8-bit mode via the following equation:

$$(M+1) * (N+1)$$

where M is the initial Counter register high-order byte contents and N is the initial Counter register low-order byte contents.

**For each counter/timer you can select one of eight operating methods via Control registers bits 3, 4 and 5.**

**For any MC6840 operating mode, interrupts and/or the output signal (O) may or may not be enabled.**

If interrupts have been enabled (via Control register bit 6), then on every time out (and for certain other special conditions) an interrupt request will be made to the CPU by outputting a low IRQ signal. Simultaneously, appropriate Status flags are set in a Status register. If interrupts are disabled, the Status register bit settings occur, but no interrupt request is output via IRQ.

**MC6840  
INTERRUPT  
ENABLE**

If the output signal (O) is enabled, then during Continuous and Single Shot operating modes an output signal is generated. The output signal (O) is not used in frequency comparison and pulse width comparison operating modes.

**The Status register of the MC6840 reports time outs and interrupt request status. Status register bits are interpreted as follows:**

|          |
|----------|
| MC6840   |
| OUTPUT   |
| SIGNAL   |
| ENABLE   |
| STATUS   |
| REGISTER |



The MC6840 Status register is a read-only location accessed via the address DEV+1, as shown in Table 9-10.

**There are some nonobvious consequences of Status register organization. We will therefore describe the individual Status register bits and then the way in which they should be used.**

**Status register bits 0, 1 and 2 will be set to 1 if an interrupt condition exists at counter/timer 1, 2 or 3, respectively.** This will occur whether or not interrupts have been enabled. For example, if a time out occurs at counter/timer 2, then Status register bit 1 will be set, irrespective of whether counter/timer 2 interrupts have or have not been enabled via Control Register 2, bit 6. Thus, Status register bits 0, 1 and 2 do not report an interrupt pending from a counter/timer; rather, they report the existence of a condition capable of generating an interrupt request. **Status register bit 7 indicates the presence of a valid interrupt request.** Status register bit 7 will be set to 1 if a valid interrupt request has been generated by one or more of the counter/timers. That is to say, if Status register bit 0, 1 or 2 has been set to 1 while the associated Control register bit 6 is 1, then Status register bit 7 will be set to 1. This may be illustrated via the following logical equation:

$$S7 = (S0 \cdot C16) + (S1 \cdot C26) + (S2 \cdot C36)$$

In the equation above, S0, S1, S2 and S7 represent Status register bits 0, 1, 2 and 7, respectively. C16, C26 and C36 represent bit 6 of Control Registers 1, 2 and 3, respectively. • and + signs represent logical AND and OR operations, respectively.

Now, in an MC6800 microcomputer system that is using vectored interrupt acknowledge logic, Status register bit 7 is useless. This is because the vectoring logic associated with the interrupt acknowledge allows the executing program to branch directly to an interrupt service routine dedicated to this particular MC6840 device. For example, in an MC6800 microcomputer system that includes an MC6828 Priority Interrupt Controller (PIC), the interrupt request line from the MC6840 would terminate at one of the MC6828 interrupt request pins; the MC6840 interrupt service routine's start address would be fetched by the MC6828 PIC following an interrupt acknowledge.

Upon acknowledging the interrupt request, the MC6800 knows that this particular MC6840's interrupt has been acknowledged; therefore the high-order Status register bit contains no useful information. In MC6800 microcomputer systems that use polling logic following an interrupt acknowledge, the interrupt acknowledge process will begin with a general purpose interrupt service routine that reads the contents of every device Status register — checking for devices with an active interrupt request. Now Status register bit 7 of the MC6840 is useful. The initial general purpose interrupt service routine will read the contents of the MC6840 Status register and check bit 7. If this bit is 1, then an active interrupt request exists. Here is an appropriate instruction sequence:

```

LDA    A.DEV+1      READ STATUS REGISTER
BIT    A.#80H        TEST HIGH-ORDER BIT
BNE    MC6840        IF NOT 0, BRANCH TO SERVICE ROUTINE
LDA    A.NEXT        READ NEXT DEVICE'S STATUS REGISTER

```

**You cannot use the MC6800 Status register to create interrupt request priorities within the MC6840.** One or more counter/timer interrupts must be enabled via the Control register bit 6 for an interrupt request to be generated, but if more than one counter/timer can generate an interrupt request, you have no way of determining which counter/timer generated the interrupt request. Suppose, for example, that only counter/timer 1 has its interrupt request logic enabled via Control Register 1, bit 6. Now if a time out (or other condition capable of generating an interrupt

request) occurs at counter/timer 2, and then at counter/timer 3, and then at counter/timer 1, this is how Status register bits will be set:

| Event                     | Status Register                                                                                       | Comment                                                                                                  |
|---------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Counter/Timer 2 times out | A 8-bit register showing bits 0 through 7. Bits 0, 1, 2, 3, 4, and 5 are 0, while bits 6 and 7 are 1. | Counter/Timer 2 interrupts are disabled so there is no interrupt request and Status register bit 7 is 0. |
| Counter/Timer 3 times out | A 8-bit register showing bits 0 through 7. Bits 0, 1, 2, 3, 4, and 5 are 0, while bits 6 and 7 are 1. | Counter/Timer 3 interrupts are disabled so there is no interrupt request and Status register bit 7 is 0. |
| Counter/Timer 1 times out | A 8-bit register showing bits 0 through 7. Bits 0, 1, 2, 3, 4, and 5 are 0, while bits 6 and 7 are 1. | Counter/Timer 1 interrupts are enabled so there is an interrupt request and Status register bit 7 is 1.  |

An interrupt request is generated only after counter/timer 1 encounters an interrupt condition, but there is no way of reading the Status register in order to find out what happened. All the Status register says is that all three counter/timers have active interrupt conditions and at least one of them has its interrupt request logic enabled. Program logic within the interrupt service routine must therefore take care of arbitrating priorities between the three counter/timer elements of an MC6840 counter/timer. Therefore, **use the MC6840 interrupt enable/disable logic to select the counter/timers that can cause an interrupt request to occur, but make sure that your MC6840 interrupt service routine uses program logic to arbitrate interrupt priorities between the three counter/timer elements.**

Status register bits are reset to 0 by a reset operation (RESET is input low) or by a general initialization (Control Register 1 bit 0 is 1). Logic that resets individual Status register bits has been carefully designed to avoid missing interrupt requests. In order to reset Status register bit 0, 1 or 2 to 0, you must read the Status register and then read the particular counter/timer's Counter register. This may be illustrated for counter/timer 2 as follows:

```
LDA    A,DEV+1    READ STATUS REGISTER CONTENTS
LDX    DEV+4      READ COUNTER 2 CONTENTS AND RESET STATUS REGISTER BIT 1 TO 0
```

By reading the contents of one particular Counter register, you also identify the Status register bit to be reset. If all Status register bits were reset when you read Status register contents, you might miss pending interrupts that you are not currently processing.

You can also reset individual Status register bits by writing to a counter/timer's counter latches, providing the counter/timer's Control register bit 4 is 0 — which results in the counter/timer being initialized when data is written to the counter/timer's latches.

**Let us now look at each of the operating modes in turn. Options are defined by the Control register, whose bits we have already described. Table 9-11 provides an options summary.**

We will first examine Continuous mode.

Table 9-11. A Summary of MC6840 Options and Control Register Settings

| Mode                   | Options              |          |            |            |                           |                |            |          |          |          |                                                                                                              | Special Conditions |
|------------------------|----------------------|----------|------------|------------|---------------------------|----------------|------------|----------|----------|----------|--------------------------------------------------------------------------------------------------------------|--------------------|
|                        | Control Code Options |          |            |            |                           |                |            |          |          |          |                                                                                                              |                    |
|                        | Counter              |          | Initialize |            | Output                    |                | Interrupts |          | Clock    |          |                                                                                                              |                    |
|                        | 16-Bit               | 8-Bit    | G↓ + R     | G↓ + W + R | Enabled                   | Disabled       | Enabled    | Disabled | Internal | External |                                                                                                              |                    |
| Continuous             | XX0X00XX             | XX0X01XX | XX010XXX   | XX000XXX   | 1X0X0XXX                  | 0X0X0XXX       | 1X10X0XXX  | X00X0XXX | XX0X0X1X | XX0X0X0X | 8-bit counter with L=0 generates 16-bit waveform. N=0 generates square wave output with half clock frequency |                    |
| One Shot               | XX1X00XX             | XX1X01XX | XX110XXX   | XX100XXX   | 1X1X0XXX                  | 0X1X0XXX       | X11X0XXX   | X01X0XXX | XX1X0X1X | XX1X0X0X | L and M=0 in 8-bit mode or N=0 in 16-bit mode disables output                                                |                    |
| Frequency Comparison   | XXX010XX             | XXX011XX | NA         | NA         | $\bar{G}$ pulse versus TO |                | X1X01XXX   | X0X01XXX | XXX01X1X | XXX01X0X | Output signal is not significant in these modes. W is always part of initialization                          |                    |
|                        |                      |          |            |            | $\bar{G}$ less            | $\bar{G}$ more |            |          |          |          |                                                                                                              |                    |
| Pulse Width Comparison | XXX110XX             | XXX111XX | NA         | NA         | XX011XXX                  | XX111XXX       | X1X11XXX   | X0X11XXX | XXX11X1X | XXX11X0X |                                                                                                              |                    |

Table 9-12. MC6844 DMAC Register Addresses

| Address |    |    |    |    |          | Accessed Location                              |
|---------|----|----|----|----|----------|------------------------------------------------|
| A4      | A3 | A2 | A1 | A0 | Label    |                                                |
| 0       | 0  | 0  | 0  | 0  | DEV      | Channel 0 Address register, high-order byte    |
| 0       | 0  | 0  | 0  | 1  | DEV + 1  | Channel 0 Address register, low-order byte     |
| 0       | 0  | 0  | 1  | 0  | DEV + 2  | Channel 0 Byte Count register, high-order byte |
| 0       | 0  | 0  | 1  | 1  | DEV + 3  | Channel 0 Byte Count register, low-order byte  |
| 0       | 0  | 1  | 0  | 0  | DEV + 4  | Channel 1 Address register, high-order byte    |
| 0       | 0  | 1  | 0  | 1  | DEV + 5  | Channel 1 Address register, low-order byte     |
| 0       | 0  | 1  | 1  | 0  | DEV + 6  | Channel 1 Byte Count register, high-order byte |
| 0       | 0  | 1  | 1  | 1  | DEV + 7  | Channel 1 Byte Count register, low-order byte  |
| 0       | 1  | 0  | 0  | 0  | DEV + 8  | Channel 2 Address register, high-order byte    |
| 0       | 1  | 0  | 0  | 1  | DEV + 9  | Channel 2 Address register, low-order byte     |
| 0       | 1  | 0  | 1  | 0  | DEV + A  | Channel 2 Byte Count register, high-order byte |
| 0       | 1  | 0  | 1  | 1  | DEV + B  | Channel 2 Byte Count register, low-order byte  |
| 0       | 1  | 1  | 0  | 0  | DEV + C  | Channel 3 Address register, high-order byte    |
| 0       | 1  | 1  | 0  | 1  | DEV + D  | Channel 3 Address register, low-order byte     |
| 0       | 1  | 1  | 1  | 0  | DEV + E  | Channel 3 Byte Count register, high-order byte |
| 0       | 1  | 1  | 1  | 1  | DEV + F  | Channel 3 Byte Count register, low-order byte  |
| 1       | 0  | 0  | 0  | 0  | DEV + 10 | Channel 0 Control register                     |
| 1       | 0  | 0  | 0  | 1  | DEV + 11 | Channel 1 Control register                     |
| 1       | 0  | 0  | 1  | 0  | DEV + 12 | Channel 2 Control register                     |
| 1       | 0  | 0  | 1  | 1  | DEV + 13 | Channel 3 Control register                     |
| 1       | 0  | 1  | 0  | 0  | DEV + 14 | Priority Control register                      |
| 1       | 0  | 1  | 0  | 1  | DEV + 15 | Interrupt Control register                     |
| 1       | 0  | 1  | 1  | 0  | DEV + 16 | Data Chain Control register                    |

In **Continuous Operating mode with 16-bit counting**, a time out will occur after N+1 active clock transitions; recall that you may select the internal  $\Phi_2$  clock or the external clock (C). In each case the high-to-low transition of the selected clock is an active transition. If the output signal (O) is disabled, then Continuous Operating mode with 16-bit counting simply generates a time out every N+1 active clock transition. This may be illustrated as follows:

**MC6840  
CONTINUOUS  
MODE**



If interrupts are enabled for the counter/timer which times out, then the time out causes an interrupt request to be transmitted to the CPU and appropriate Status register bits are set. If interrupts are not enabled, then the appropriate Status register bit is set, but no interrupt request is transmitted to the CPU.

In Continuous Operating mode with 16-bit counting, if the output signal (O) is enabled, then this signal will change level on each time out, thus creating a square wave. Here is the exact waveform:



In Continuous mode, observe that following each time out the value held in the counter latches (N in the illustration above) is transferred to the Counter register. If the output signal O is enabled, therefore, the following square wave is generated:



$T_0$  identifies a time out.  $P$  represents the time interval between time outs; it is equal to  $(N+1) \cdot t$  where  $N$  is the initial 16-bit value loaded into the Counter register and  $t$  is the time interval between active transitions of the clock ( $\Phi_2$  or  $C$ ).

In **Continuous Operating mode with 8-bit counting**, the interval to time out is  $(N+1) \cdot (M+1)$  clock transitions, where  $M$  is the initial Counter register byte and  $N$  is the initial low-order Counter register byte. We have already described this time out logic. If the output signal (O) is disabled, then a time out will occur after the appropriate number of active clock transitions. When the time out occurs, an interrupt will be requested via IRQ if interrupts are enabled for this counter/timer by setting its Control register bit 6 to 1. Simultaneously, appropriate Status register bits will be set. If interrupts are disabled, then a Status register bit will be set but no interrupt request will occur. If the output signal (O) is enabled, then it generates pulses as follows:



Thus, in 8-bit counting mode you use the low-order Counter register byte to define the pulse width, and you use the high-order Counter register byte to define the interval between pulses. This may be illustrated as follows:



In the illustration above, TO identifies a time out. P represents the time interval between time outs. In 8-bit counting mode P is equal to  $(M+1) * (N+1) * t$ , where M is the initial value for the high-order byte of the Counter register, N is the initial value for the low-order byte of the Counter register, and t is the time interval between active transitions of the clock ( $\Phi_2$  or C). W represents the time interval of the high O pulse; it is equal to  $N * t$ . Suppose, for example,  $0A0C_{16}$  is the initial value loaded into the Counter register which is being operated in 8-bit counting mode. O will generate a pulse output where the high pulse is  $12_{10}$  clock periods long and the frequency is  $143_{10}$  clock periods:



**There are some further options available to you when operating the MC6840 in Continuous mode.**

Having loaded the counter latches by writing out data to the appropriate address, there are two ways in which you can initialize the counter. A high-to-low transition of the Gate (G) input will always start the counter:



**MC6840 HARDWARE INITIALIZATION**

You can always initialize any counter/timer via its Gate input ( $\bar{G}$ ) as illustrated above. Once a counter/timer has been initialized via its Gate input ( $G$ ),  $G$  must remain low. If  $\bar{G}$  goes high at any time this will stop the counter/timer immediately. When  $\bar{G}$  subsequently makes a high-to-low transition, the counter/timer will be re-initialized. This may be illustrated as follows:



Note carefully that the Gate signal ( $\bar{G}$ ) going high does not suspend counter/timer operations: it stops these operations, then restarts them with a re-initialization.

**You can also initialize a counter/timer under program control.** Programmed initialization is an option, whereas hardware initialization via the Gate input ( $\bar{G}$ ) is always available, whether or not programmed initialization has been selected. You select programmed initialization via bit 4 of the counter/timer element's Control register.

If Control register bit 4 is 0, then the process of writing a 16-bit value to the counter/timer's latches will start the associated counter/timer logic. That is to say, as soon as the 16-bit value has been written to the latches, this value is transferred to the 16-bit Counter register and the counter begins operation.

**When using counter/timer 3 only, you can select a "divide by 8" mode;** this is done by setting Control Register 3, bit 0 to 1. Now every eighth active clock transition (of either the internal  $\Phi_2$  clock or the external clock) will be considered active, as illustrated earlier. All other options remain available when operating counter/timer 3 in "divide-by-8" mode. The clock has effectively been slowed down by a factor of 8 — and that is all.

**When operating in Continuous mode with 8-bit counting, two special options that depend on the initial value loaded into the latches are available.** If the low-order byte of the initial counter value is 0, then, as we might expect, there is no high output signal ( $O$ ) pulse (assuming that the output signal is enabled); however, on each time out the output signal changes levels to create a square wave that is similar to a 16-bit counting. This may be illustrated as follows:



When operating in Continuous mode with either 8-bit or 16-bit counting, if the initial value loaded into the latches is 0, then Counter registers are not decremented and a square wave is output with half the clock frequency. This may be illustrated as follows:

**MC6840  
DIVIDE  
BY 8 MODE**

**MC6840  
CONTINUOUS  
8-BIT COUNTING  
SQUARE WAVE  
OPTION**

**MC6840  
CONTINUOUS  
MODE WITH  
0 INITIAL  
VALUE**



Time outs occur on every transition of O. Since interrupts could not possibly be serviced every other clock pulse, they should be disabled (by having 0 in Control Registers 1 to 6) for any counter/timer element operating in the form illustrated above.

**Note again that in any operating mode, continuous or otherwise, when the external clock (C) is selected, you are in fact counting events, not time.** Although all of our illustrations show a synchronous clock signal with all active transitions evenly spaced, in reality active transitions could be quite random. This may be illustrated as follows:

**MC6840  
EVENT  
COUNTING**



If random timing is present on the external clock (C), then wave forms, if output via the output signal (O), will not be uniform. This is something you may wish to use when counting external events. You could, for example, use continuous operating mode with 8-bit counting to count a fixed number of events, but to signal shortly before this fixed number of events has occurred.

Suppose you wish to count 100 events, with a signal identifying the 90th event. This could be done loading 0909<sub>16</sub> as the initial Counter register value:



The low-to-high O signal transition must now be used to generate an interrupt request. Time Out (TO) interrupt requests may or may not be disabled.

**Note again that the three sets of counter/timer logic are totally independent of each other. The manner in which you operate one set of counter/timer logic has no bearing whatsoever on the manner in which you operate either of the other two sets of counter/timer logic.**

**The primary difference between one shot mode and continuous mode is that following the first time out the output signal (O), if enabled, is disabled.** In single shot, 16-bit counting mode, the output signal (O) does not make its low-to-high transition until the end of the first clock pulse. This may be illustrated as follows:

**MC6840  
ONE SHOT  
MODE**



In single shot, 8-bit counting mode, the output signal is simply disabled after the first time out. The counter/timer continues to run and time outs continue to be generated, but the output signal (O) remains disabled until the counter/timer is re-initialized.

Another difference between one shot mode and continuous mode is that in one shot mode you do not stop the counter/timer by inputting the Gate signal ( $\bar{G}$ ) high. Recall that in continuous mode, if the counter/timer has been initialized by inputting a high-to-low Gate ( $\bar{G}$ ) pulse, you can stop the counter/timer at any time by inputting the Gate signal ( $\bar{G}$ ) high again. This property of the  $\bar{G}$  input applies only in continuous mode.

Notice that the two special continuous mode conditions that result when the low-order Counter register byte is initially 0 or the entire Counter register contents are initially 0 do not apply in one shot mode. This is because in continuous mode nothing happens to the output signal until the end of the first time out, at which time in one shot mode the output signal is disabled anyway.

MC6840 frequency comparison and pulse width measurement modes are almost identical; they differ only in the active levels of the  $\bar{G}$  input. The frequency comparison and pulse width measurement modes both compare the time interval of a pulse, input via the  $\bar{G}$  signal, with the time interval to a time out. In frequency comparison mode a high  $\bar{G}$  pulse is measured.

You can select frequency comparison mode with Gate pulse by having 001 in control register bits 5, 4, and 3 as described earlier; then an interrupt request will be generated if the G signal makes a high-to-low transition before a time out occurs. This may be illustrated as follows:

**MC6840  
FREQUENCY  
COMPARISON  
AND PULSE  
WIDTH  
MEASUREMENT  
MODE 5**



As illustrated above, if the G signal makes its high-to-low transition after the time out occurs, then no interrupt is requested.

The Counter register is reloaded from the latches and continues to decrement, but time outs do cause interrupt requests or Status register bit settings. Until the counter/timer is re-initialized by a high-to-low transition of the G input signal, it continues to run freely as though it were in continuous mode, but time outs lose their significance. Once the counter/timer is re-initialized by a high-to-low  $\bar{G}$  transition, then frequency comparison logic begins again.

If following an initialization or re-initialization the  $\bar{G}$  input does make a high-to-low transition before a time out occurs, then an interrupt will be requested and the counter/timer logic is stopped; it cannot be re-initialized until the interrupt has been cleared. Clearing interrupts is described in conjunction with our discussion of the Status register. Once an interrupt has been cleared, then on the next high-to-low transition of the gate input, counter/timer logic will be re-initialized.

In other words, between the time an interrupt request occurs and the interrupt is serviced, high-to-low transitions of the  $\bar{G}$  input are ignored.

Observe that you can select either 8-bit or 16-bit counting modes in order to generate time outs when operating the MC6840 in frequency comparison or pulse width measurement modes.

**You select frequency comparison mode with time out shorter by loading 101 into bits 5, 4, and 3 of the Control register.** Now an interrupt request will occur if the  $\bar{G}$  input makes its high-to-low transition after the time out has occurred. We can compare the previous illustration for frequency comparison mode with Gate pulse shorter, using the illustration below for frequency comparison mode with time out shorter:



Once again, if an interrupt occurs the counter/timer will stop. It cannot be restarted until the interrupt is cleared and the  $\bar{G}$  input makes a high-to-low transition.

**Pulse width comparison modes are identical to frequency comparison modes, with the exception that once a counter/timer is operating, low-to-high transitions of the gate input are active. The frequency comparison modes may therefore be reproduced for pulse width comparison equivalents, as follows.**

First, here is pulse width comparison mode with Gate pulse shorter:



Next, here is pulse width comparison mode with time out shorter:



Notice that in pulse width comparison mode, initialization and re-initialization require a high-to-low  $\bar{G}$  transition, although the end of the  $\bar{G}$  pulse is marked by a low-to-high G transition.

## THE MC6844 DIRECT MEMORY ACCESS CONTROLLER

The MC6844 Direct Memory Access controller provides MC6800-based microcomputer systems with logic to support four direct memory access channels. This device has been designed to work with the unique timing logic of MC6800 and MCS6500 microcomputer systems; it should therefore be used with MC6800 and MCS6500 microcomputer systems only. That is why the MC6844 is described in this chapter rather than in Volume 3.

From our discussion of the MC6800 CPU, recall that this microprocessor allows its system clock to be stretched so that direct memory access operations may be intermingled with normal instruction execution. Alternatively, the MC6800 may be put into a Halt state during which the CPU disconnects itself from the system busses; external logic then accesses memory by mimicking CPU signals on the Address, Data and Control Busses. Logic of the MC6844 DMA controller allows you to perform Direct Memory Access operations using either clock stretching or Halt state techniques.

Two noteworthy features of the 8256 DMA controller, described in Chapter 4, are also available with the MC6844 DMA controller. These noteworthy features are:

- 1) The ability to assign permanent priorities to the four DMA channels or to rotate priorities on a round-robin basis.
- 2) By reducing the number of DMA channels to three, one DMA channel can be used for the recursive DMA transfer of fixed length or chained records.

Figure 9-31 illustrates that part of our general microcomputer system logic which has been implemented on the MC6844 DMA controller device.



Figure 9-31. Logic of the MC6844 DMA Controller.

The MC6844 DMA controller chip is fabricated using N-channel silicon gate MOS technology. It is packaged as a 40-pin ceramic or plastic DIP. All signals are TTL-compatible.

### MC6844 DMA CONTROLLER PINS AND SIGNALS

Figure 9-32 summarizes MC6844 DMA pins and signals. Many of these signals have MC6800 counterparts; therefore we will describe them within the context of a general MC6844 device discussion.



| PIN NAME                          | DESCRIPTION                                                | TYPE                    |
|-----------------------------------|------------------------------------------------------------|-------------------------|
| D0 - D7                           | Bidirectional Data Bus                                     | Tristate, bidirectional |
| A0 - A4                           | Four low-order Address Bus lines and Register Select lines | Tristate, bidirectional |
| A5 - A15                          | Address Bus lines                                          | Output                  |
| <u>R/W</u>                        | Read/Write Control                                         | Bidirectional           |
| <u>IRQ/DEND</u>                   | Interrupt request and end of DMA indicator                 | Output                  |
| <u>DRQH</u>                       | DMA Hold Request                                           | Output                  |
| <u>DRQT</u>                       | DMA Clock Stretch Request                                  | Output                  |
| <u>DGRNT</u>                      | DMA Acknowledge                                            | Input                   |
| <u>CS/TxAKB</u>                   | Chip Select and Device Acknowledge                         | Bidirectional           |
| TxAKA                             | Device Acknowledge                                         | Output                  |
| TxSTB                             | DMA I/O Device Strobe                                      | Output                  |
| TxRQ0 - TxRQ3                     | DMA Service Request                                        | Input                   |
| <u>Φ2DMA</u>                      | Clock Input                                                | Input                   |
| RES                               | System Reset                                               | Input                   |
| V <sub>SS</sub> , V <sub>DD</sub> | Power and Ground                                           |                         |

Figure 9-32. MC6844 DMA Controller Signals and Pin Assignments

## MC6844 ADDRESSABLE REGISTERS

Logic associated with each DMA channel consists of a 16-bit Address register, a 16-bit Byte Count register and an 8-bit Control register. There are three additional registers which are shared by the four DMA channels. These are a Priority Control register, an Interrupt Control register and a Data Chain Definition register. These may be illustrated as follows:



The transfer of any block of data via DMA begins with an initial memory address, byte count and DMA mode being specified via the registers illustrated above. As each byte of data is transferred, the method of data transfer is controlled by options selected via the Control register. The Address register identifies the memory location which will be accessed during the DMA transfer. Address register contents may either be incremented or decremented following each DMA transfer. The Byte Count register contents are always decremented following each data transfer, and the DMA operation ends when the Byte Count register contents reach 0.

**The MC6844 DMA controller is accessed by the CPU under program control as 23 memory locations. Individual memory locations are selected via address lines A0 - A4, as defined in Table 9-12.** When writing into or reading out of 16-bit registers, you will usually use the LDX and STX instruction; that is to say, the most efficient method of transferring 16-bit data between the CPU and MC6844 DMA controller is via the CPU Index register.

**Note carefully that addresses given in Table 9-12 apply only when the CPU accesses the MC6844 DMAC under program control to initialize a DMA transfer or to monitor DMA operations.** These memory addresses have no significance to actual DMA logic. Furthermore, the Data Bus connection to the MC6844 DMA controller plays no part during a DMA operation. **Data is transferred between the CPU and the MC6844 DMAC via the Data Bus (D0 - D7) only while the CPU is accessing MC6844 addressable locations under program control.** Actual data transfers between an external device and memory occur via the microcomputer system Data Bus, completely bypassing the Data Bus connection to the MC6844 DMA device. However, during DMA data transfers, addresses and control signals are output from the MC6844 DMAC to the System Bus via the Address Bus lines A0 - A15 and appropriate control signal outputs. This is standard DMA logic. If you do not understand these DMA operations, see the discussion of direct memory access given in Volume 1 before proceeding further with this description of the MC6844 DMAC device.

The CPU may access the MC6844 DMAC under program control at any time by simply executing an instruction which references one of the 23 memory addresses set aside for the MC6844 DMAC device. The MC6844 DMAC is selected by a low CS pulse. This low pulse must be generated by appropriately decoding Address Bus lines A5 through A15, together with VMA. VMA must contribute to MC6844 device select logic to guarantee that spurious selections do not occur during a DMA transfer or while the Address Bus is floated. In this context it is important that only a VMA signal output by the

|                         |
|-------------------------|
| MC6844 DMAC DATA BUS    |
| MC6844 DMAC ADDRESS BUS |

|                                    |
|------------------------------------|
| MC6844<br>DMAC<br>DEVICE<br>SELECT |
|------------------------------------|

MC6800 CPU be used by MC6844 device select logic. During a DMA operation, the MC6844 DMAC generates its own VMA equivalent via TxSTB. TxSTB must be excluded from MC6844 device select logic. Here is one possibility:



Depending on the number of active MC6844 DMA channels,  $\overline{CS}$  may become a bidirectional signal; TxAKB is output via the same pin as the  $\overline{CS}$  input. In this case remember that  $\overline{CS}$  must be generated as an open collector gate output.

We will discuss the individual MC6844 addressable locations and the way in which you will program them after describing MC6844 operating modes.

## MC6844 DMA TRANSFER MODES

You can select, under program control, one of three modes via which DMA transfers will occur for each of the four MC6844 DMA channels. You can mix and match separate and distinct modes for each of the four channels in any way since each channel has its own Control register.

We will begin our discussion of modes by looking at all three modes superficially before examining each one in detail.

**First there is Three-State Control, Cycle Stealing mode.** In this mode the MC6800 CPU clock is stretched with  $\Phi_2$  low while the MC6844 device transfers a single byte of data via direct memory access. This may be illustrated as follows:



We have discussed clock stretching logic of the MC6800 microcomputer earlier in this chapter.

**The second and third MC6844 DMA transfer modes both force the MC6800 CPU into a Halt state** which floats the System Bus. The Halt state may last long enough for a single byte of data to be transferred via direct memory

access, in which case the mode is referred to as **Halt, Steal mode**. This may be illustrated as follows:



The Halt state may be maintained for as long as it takes to transfer an entire block of data; that is to say, until a channel's Byte Count register decrements to 0. This is referred to as **Halt Burst mode**.

### MC6844 DMAC THREE-STATE CONTROL, CYCLE STEALING MODE

Let us now look at the different DMA modes in detail beginning with the three-state control cycle stealing mode. Timing for this mode is given in Figure 9-33 and appropriate pin connections are given in Figure 9-34.



Figure 9-33. Timing for Three State Control, Cycle Stealing Direct Memory Access with the MC6844



Figure 9-34. An MC6844 DMAC Connected for Three State Control. Cycle Stealing Direct Memory Access

A DMA operation begins when an external device makes a DMA access request by inputting a high signal via one of the four inputs TxRQ0 through TxRQ3. This input to the MC6844 DMAC may be asynchronous. The MC6844 responds by outputting  $\overline{DRQT}$  low. This low output must be connected to the MC6875 clock CMA/REF REQ input. This connection causes the MC6875 clock device to stretch the  $\Phi_1$  and  $\Phi_2$  clocks at the end of the next machine cycle — with  $\Phi_1$  high and  $\Phi_2$  low. The onset of the stretched clocks is identified by the MC6875 device outputting REF GRANT high. This signal must be input to the MC6844 DGRNT pin. The DMA data transfer now occurs, taking three machine cycles to transfer one byte of data. Machine cycles are timed by  $\Phi_2$  DMA, which is the memory clock output of the MC6875 device. Recall that when the MC6875 clock device receives a low input via DMA/REF REQ it does not stretch the memory clock output. The MC6844 DMAC needs a  $\Phi_2$  DMA input only while a DMA data transfer is in progress.  $\Phi_2$  DMA is therefore frequently the AND of MEMORY CLOCK and REF GRANT:



**MC6844 DMAC  
TxRON, DQRT  
DGRNT SIGNALS**

**MC6844 DMAC  
 $\Phi_2$  DMA CLOCK**

As soon as clock stretching begins, the MC6800 CPU must float the System Bus. This may be done by inputting the REF GRANT signal to the MC6800 TSC pin as well as to the MC6844 DGRNT pin. Now REF GRANT input to TSC will cause the MC6800 CPU to float its Address Bus and three-state control signals. If DBE is connected to  $\Phi_2$ , as is usually the case, then the low  $\Phi_2$  signal will automatically cause the MC6800 CPU to float the Data Bus. Now as soon as REF GRANT goes high, the MC6800 CPU is disconnected from the System Bus and the MC6844 DMAC can become bus master.

The MC6844 DMAC takes control of the System Bus for three machine cycles, during which it transfers a single byte of data. The first and third machine cycles represent setup time. The actual DMA transfer occurs during the second machine cycle. For the memory end of the DMA transfer, the MC6844 DMAC outputs a memory address via the Address Bus. For the I/O device end of the DMA transfer, the DMAC identifies the direct memory access channel being acknowledged via the output signals TxAKA and TxAKB, as follows:

| TxAKB | TxAKA | Acknowledged |
|-------|-------|--------------|
| 0     | 0     | TxRQ0        |
| 0     | 1     | TxRQ1        |
| 1     | 0     | TxRQ2        |
| 1     | 1     | TxRQ3        |

Timing for signals output by the MC6844 DMAC conform to normal MC6800 System Bus timing for a memory read or memory write operation.

The low TxSTB pulse substitutes for VMA at the memory and I/O device ends of the DMA transfer. The direction of the DMA transfer is defined by the level of the R/W signal; the interpretation of this signal conforms to normal memory read and write operations:

R/W low causes data to flow from the I/O device to memory.

R/W high causes data to flow from memory to the I/O device.

Data may flow freely across the Data Bus during the direct memory access operation, since both the MC6800 CPU and the MC6844 DMAC are disconnected from the Data Bus at this time.

As each byte of data is transferred, the Byte Count register contents for the selected DMA channel are decremented; but the Address register contents may be either incremented or decremented, depending on the Control register option selected. When the Byte Count register contents decrement to 0, a low pulse is output via IRQ/DEND. This pulse can be used to generate an interrupt at the MC6800 CPU and/or it may be used to tell the external device that the current data transfer has gone to completion.

The interrupt request output IRQ/DEND will pulse low when the Byte Count register decrements to 0 only if interrupts have been enabled for this DMA channel via its Interrupt Control register. If interrupts have been enabled, it is a good idea to guard against spurious interrupt requests by conditioning IRQ/DEND with the DGRNT high pulse. The interrupt request input to the MC6800 CPU should be an open collector signal generated as follows:



The DEND signal output to I/O devices may be ANDed with REF GRANT or with TxSTB. An AND with TxSTB is illustrated in Figure 9-34.

Assuming that the acknowledged DMA channel is transferring data at less than maximum speed, it must use the low TxSTB strobe to remove its TxRQN high request. If the channel keeps its TxRQN DMA request active, then the next DMA transfer will occur during the next machine cycle. Using Three-State Control, cycle stealing direct memory access, therefore, it is possible to transfer a byte of data during every machine cycle; however, each machine cycle will have its length increased by three machine cycles. Thus, any executing program will be reduced to executing at one quarter of its normal execution speed.

## MC6844 DMAC HALT MODES

The next DMA operating mode we are going to look at is the Halt Cycle Stealing mode. In this mode the CPU is halted for three machine cycles, during which a single byte of data is transferred. Timing is illustrated in Figure 9-35 and appropriate pin connections are illustrated in Figure 9-36.

**MC6844  
DMAC  
TxAKA AND  
TxAKB  
SIGNALS**

**MC6844  
DMAC  
TxSTB  
SIGNAL**

**MC6844  
DMAC  
IRQ/DEND  
SIGNAL**



Figure 9-35. Timing for Halt, Cycle Stealing Direct Memory Access with the MC6844

A DMA transfer is initiated by one of the four DMA request signals TxR0 through TxR3 going high. These signals are sampled on the rising edge of  $\Phi_2$ . The MC6844 responds to a high DMA transfer request by outputting DRQH low. In the Halt, Cycle Stealing mode, DRQH must be input as the MC6800 CPU halt request. As explained earlier in this chapter, when a low input occurs at HALT, the MC6800 CPU completes executing its current instruction, then enters a Halt state. During the Halt state, VMA is output low while the Address and Data Busses, along with the R/W control signal, are floated. In Figure 9-35 the Halt state is shown beginning one full machine cycle after DRQH goes low.

The MC6800 CPU indicates the onset of the Halt state by outputting BA high. This output becomes the DGRNT input to the MC6844. Once DGRNT goes high, the MC6844 assumes control of the System Bus. TxSTB is pulsed low as a substitute for the VMA signal. The address of the memory location to be accessed during the DMA transfer is output on the Address Bus along with the R/W, which indicates the direction of the DMA data transfer (as described for three-state control cycle stealing mode). The DMA channel being acknowledged is identified via the TxAKA and TxAKB signals, which are decoded as described earlier.

**MC6844 DMAC TxR0 - TxR3 SIGNALS**

**MC6844 DMAC DRQH SIGNAL**

**MC6844 DMAC DGRNT, TxSTB, TxAKA AND TxAKB SIGNALS**



Figure 9-36. An MC6844 DMA Connected for Halt, Cycle Stealing or Halt Burst Direct Memory Access

The VMA signal used by the system must now be the OR of VMA and TxSTB. The external device whose DMA request has been acknowledged must detect the low TxSTB signal and use it to reset its DMA request. If the DMA request is still active after a single byte of data has been transferred via DMA, then a single instruction will be executed before the next byte of data is transferred via direct memory access. One instruction will be executed even if TxRQN remains high, because in Halt Cycle Stealing mode the MC6844 will return its DRQH signal high as soon as a single byte of data has been transferred via direct memory access. This will free the CPU to execute another instruction, and while this new instruction is being executed the whole timing process illustrated in Figure 9-35 will begin again.

#### MC6844 DMA TxSTB SIGNAL

When the Byte Count register contents decrement to 0, the IRQ/DEND signal will output low. As was the case for Three-State Control Cycle Stealing mode, this signal can be used to request an interrupt and/or to identify the end of a data transfer block to external logic. It is a good idea to condition interrupt requests and DEND outputs with TxSTB in order to avoid generating spurious signals.

**The third and last MC6844 DMA mode is the Halt Burst mode.** This differs from Halt Cycle Stealing mode in that once a Halt condition has been initiated, it is maintained while data is transferred via direct memory access until the Byte Count register has decremented to 0. Thus, Halt Burst mode timing will differ from Figure 9-35 only in that DRQH will remain low until the channel's Byte Count register decrements to 0. This will happen irrespective of the level on the DMA request line TxRQN. Note that, as illustrated in Figure 9-35, one byte of data will be transferred via direct memory access in three machine cycles, even when operating in Halt Burst mode. Pin connections for Halt Burst mode are as illustrated in Figure 9-36.

## COMPARING MC6844 DMAC MODES

You will use Three-State Control. Cycle Stealing mode when program execution time is critical but data transfer rates are not.

You will use Halt/Cycle Stealing mode when data transfer rates are not critical, program execution time is important and you do not have an MC6875 clock device.

You will use Halt Burst mode when data transfer rates are critical and program execution time is not.

Table 9-13 summarizes maximum data transfer rates for the three modes. A  $\mu$ sec machine cycle time is assumed.

Table 9-13. MC6844 DMAC Modes' Response Times and Transfer Rates

| Mode       | Response Time<br>( $\mu$ sec) | Maximum Transfer Rate<br>KHz |
|------------|-------------------------------|------------------------------|
| TSC Steal  | 2.5 to 3.5                    | 250                          |
| Halt Steal | 3.5 to 15.5                   | 200 - 67                     |
| Halt Burst | 2.5 to 3.5                    | 1000                         |

## USING AN MC6844 DMAC WITH MIXED MODES

If you are going to use Three-State Control and Halt modes with a single MC6844 DMAC device, the only special precaution needed is to generate DGRNT as the OR of BA and REF GRANT.

The Three-State Control and Halt modes have separate DMA request lines, DRQT and DRQH, respectively; therefore no special logic is needed to handle DMA requests using mixed modes.

## THE MC6844 CONTROL REGISTERS AND OPERATING OPTIONS

As summarized in Table 9-12, the MC6844 DMAC has a number of programmable Control registers, which are used to select the DMA transfer modes which we have already described, plus additional operating options.

The best place to begin a discussion of Control registers is with the **Enable/Priority Control register**. Bit settings for this register may be illustrated as follows:



MC6844  
ENABLE/  
PRIORITY  
CONTROL  
REGISTER

Each DMA channel that is to be active must have a 1 placed in its enable bit within the Enable/Priority Control register. A 0 in any channel's enable bit will disable the channel. It is important to understand that if a channel is disabled, this simply means that DMA requests arriving via the associated TxRQN input will be ignored. Disabling a DMA channel has no effect on your ability to write into the channel's registers or read from the channel's registers.

If more than one DMA channel is enabled, then two or more DMA requests can occur simultaneously. You arbitrate priority in one of two ways. If bit 7 of the Enable/Priority Control register is 0, the following fixed priorities will always be used:

Highest Priority: Channel 0

Channel 1

Channel 2

Lowest Priority: Channel 3.

MC6844  
FIXED DMA  
PRIORITY  
ARBITRATION

Rotating priority may be selected by writing a 1 into bit 7 of the Enable/Priority Control register. Rotating priority initializes the four channels with the fixed priority illustrated above. As soon as any DMA channel has been serviced, however, it becomes the lowest priority channel — and associated channels are rotated in a round-robin fashion. In order to illustrate rotating priority mode, let us assume that DMA Channel 2 is serviced and then DMA Channel 0 is serviced. This is how priorities would be assigned:

**MC6844  
ROTATING  
DATA  
PRIORITY  
ARBITRATION**

Initial Priority:

Highest Priority: Channel 0  
Channel 1  
Channel 2

Lowest Priority: Channel 3

Channel 2 is serviced. These are the new priorities:

Highest Priority: Channel 3  
Channel 0  
Channel 1

Lowest Priority: Channel 2

Channel 0 is serviced. These are the new priorities:

Highest Priority: Channel 1  
Channel 2  
Channel 3

Lowest Priority: Channel 0

The next Control register we will look at is the Data Chaining Control register, because this also contributes to channel enable logic. **Data Chaining Control register bit assignments may be illustrated as follows:**

**MC6844  
DATA  
CHAINING  
CONTROL  
REGISTER**



Bit 3 of the Data Chaining Control register is, in fact, an enable/disable bit for the TxAKB output function associated with the CS/TxAKB signal. TxAKB is disabled if the Data Chaining Control register bit 3 is 0. This is referred to as Two-Channel mode, because with only TxAKA enabled it is only possible to acknowledge DMA requests from channels 0 or 1. This may be illustrated as follows:

**MC6844 DMAC  
TWO-CHANNEL  
MODE**



If the Data Chaining Control register bit 3 is 1, then the TxAKB signal is active, allowing any one of the four DMA channels to be acknowledged. This is referred to as Four-Channel mode, and may be illustrated as follows:

**MC6844 DMAC  
FOUR-CHANNEL  
MODE**



The logic above uses the TxSTB pulse as a strobe for a 2-to-4 decoder. The four decoder outputs become individual select lines for the four devices capable of requesting DMA access.

In order to rotate CS/TxAKB requirements, chip select creation logic is shown. This logic has nothing to do with generation of the Select 0 through Select 3 lines; however, unless the chip select input portion of the CS/TxAKB signal is correctly generated, TxAKB will either be held at ground or pulled to a level of 1, in which case the four-channel select logic will not work.

It is very important to note that there is no direct connection between the logic of the Data Chaining Control register bit 3 and the Enable/Priority Control register bits 0 through 3. Whether you select Two-Channel mode or Four-Channel mode via bit 3 of the Data Chaining Control register, you can independently enable or disable each of the individual channels via Enable/Priority Control register bits 0 through 3. Clearly, there are certain combinations which are not reasonable. Options may be illustrated as follows:

| Data Chaining Control Register Bit 3 | Enable/Priority Control Register |       |       |       |                                                                                                                                                                                                         |
|--------------------------------------|----------------------------------|-------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      | Bit 3                            | Bit 2 | Bit 1 | Bit 0 |                                                                                                                                                                                                         |
| 0                                    | 0                                | 0     | 0     | 0     | Select Two-Channel mode, but channels 0 and 1 are disabled.                                                                                                                                             |
| 0                                    | 0                                | 0     | 0     | 1     | Select Two-Channel mode, but only channel 0 or channel 1 is enabled.                                                                                                                                    |
| 0                                    | 0                                | 0     | 1     | 1     | Normal Two-Channel mode with both channels active.                                                                                                                                                      |
| 0                                    | 0                                | 1     | X     | X     | In Two-Channel mode you can enable channels 2 and 3. Their DMA requests will be accepted via TxRQ2 and TxRQ3, but DMA requests will not be acknowledged via TxAKB. Channels 0 and/or 1 must be enabled. |
| 1                                    | 0                                | 0     | X     | X     | Four-Channel mode with channels 2 and 3 disabled makes no sense. Use Two-Channel mode instead.                                                                                                          |
| 1                                    | 0                                | 1     | X     | X     | Four-Channel mode with channel 2 and/or 3 enabled, and any enable/disable combination for channels 0 and 1 is alright.                                                                                  |
| 1                                    | 1                                | 1     | X     | X     |                                                                                                                                                                                                         |

**MC6844  
DATA  
CHAINING**

If you enable data chaining by writing a 1 into the Data Chaining Control register bit 0, then DMA operations at channel 0, 1 or 2 become continuous. Via bits 1 and 2 of the Data Chaining Control register, you select channel 0, 1 or 2 to operate in Chained mode.

Chained mode simply means that as soon as the selected channel's Byte Count register decrements to 0, the selected channel's Byte Count and Address registers will be reloaded with values stored in the Channel 3 Byte Count and Address registers. Suppose, for example, you want to continuously transfer, via direct memory access, 256 bytes of data. The data is to flow via Channel 0 to memory, with the data being loaded in memory locations 0A0016 through 0AFF16. To perform this task you would store 00FF16 in the Channel 3 Byte Count register, and 0A0016 in the Channel 3 Address register. (We assume that the Address register is going to be incremented.) Every DMA transfer will begin with 00FF16 being loaded into the Channel 0 Byte Count register from the Channel 3 Byte Count register, while 0A0016 is loaded into the Channel 0 Address register from the Channel 3 Address register. This is an automatic operation which requires no program intervention once data chaining has been enabled. Thus, DMA transfer via Channel 0 will continue endlessly with the DMA transfer rate determined by the DMA mode selected.

It is important to note that a data chaining specification is to MC6844 DMAC logic an isolated event. The fact that data chaining has been enabled does not automatically disable DMA Channel 3 logic. You must do this by writing 0 into the Enable/Priority Control register bit 3. Also, if you specify chaining, you in no way affect the manner in which registers can be accessed. You can write into Channel 3 registers, or you can read the contents of Channel 3 registers. This can be very useful. If 256 bytes of data are continuously being read into memory locations 0A0016 through 0AFF16, it would take complex program logic to access all data that gets written into this buffer before the data gets overwritten on the next DMA pass.

A better way would be to have two buffers: for example, the first from 0A0016 through 0AFF16 and the second from 0B0016 through 0BFF16. Now, following each end of block interrupt, you would write the new address into the Channel 3 Address register. This is illustrated in Figure 9-37.

**There are some nonobvious aspects of Figure 9-37.**

Observe that when you are initializing the MC6844 operating in Chained mode, you must load initial addresses and byte counts in Channel 3 Address and Byte Count registers as well as in the Address and Byte Count register for the chained channel. The actual chaining operating does not occur until the chained channel's Byte Count register decrements to 0. When you start the chained channel, the first DMA operation uses initial Byte Count and Address values loaded into the chained channel's Byte Count and Address registers. After the first end-of-block interrupt, the byte count and address values loaded into the Channel 3 registers will be transferred to the chained channel registers for the next operation.

**Let us now consider the Channel Control register which is associated with each DMA channel. Channel Control register bit assignments may be illustrated as follows:**

**MC6844  
CHANNEL  
CONTROL  
REGISTERS**



Channel Control register bit 0 simply reflects the level which will be output on the R/W pin during DMA operations—that is to say, while R/W is an output from the MC6844 DMAC. Channel Control register bit 0 has no effect on R/W while the MC6800 CPU is accessing the MC6844 DMAC under program control. The level of the R/W signal during a DMA operation determines whether data will be transferred from the I/O device to memory (R/W is low), or from memory to the I/O device (R/W is high). Since each DMA channel has its own Control register and therefore its own Control register bit 0, channels may be programmed independently to generate DMA transfers in either direction.



Figure 9-37. Logic for MC6844 DMA with Channel 3 Chained to Channel 0 and Data Flowing into Alternate Memory Buffers

Channel Control register bits 1 and 2 are used to select one of the three DMA transfer modes which we have just described.

Channel Control register bit 3 determines whether the channel's Address register contents will be incremented or decremented following each DMA transfer. Thus you can perform a DMA operation specifying the highest address or the lowest address of a memory buffer as the starting address..

Channel Control register bits 4 and 5 are unassigned.

Channel Control register bits 6 and 7 are read-only status bits which should be looked at in conjunction with the Interrupt Control register. **Interrupt Control register bits are assigned as follows:**

**MC6844  
INTERRUPT  
CONTROL  
REGISTER**



You can, at any time, examine a DMA channel to find out if it is "busy" or if it is "done". If "busy", the channel is in the middle of transferring a block of data. If "done", the channel is currently idle. You determine a channel's status by reading the contents of the Channel Control register and examining the level of bit 6.

When you reach the end of a data block, that is, a DMA channel's Byte Count register decrements to 0, the channel's Control register bit 7 will be set to 1. If the channel's interrupt logic has been enabled via bit 0, 1, 2 or 3 of the Interrupt Control register, then an interrupt request will occur via a low output at IRO/DEND. This interrupt request will not occur if the channel's interrupt logic has been disabled within the Interrupt Control register.

If an interrupt request does occur, then bit 7 of the Interrupt Control register will be set to 1.

Irrespective of whether a channel's interrupt logic has or has not been disabled, the channel's Control register bit 7 will be set to 1 when the channel's Byte Count register decrements to 0.

Bit 7 of the Channel Control register remains set to 1 until the CPU reads the contents of the Channel Control register. The process of reading the Channel Control register contents automatically resets bit 7 to 0.

The Interrupt Control register bit 7 is reset to 0 as soon as the Channel Control register for the DMA channel requesting the interrupt is read by the CPU.

Suppose, for example, Channels 0 and 1 are active, with Channel 0 interrupts enabled and Channel 1 interrupts disabled. Here are appropriate Interrupt Control register settings:

| 7                                | 6                                | 5 | 4 | 3 | 2   | 1   | 0   | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----------------------------------|----------------------------------|---|---|---|-----|-----|-----|---|---|---|---|-----|-----|-----|-----|---|---|---|---|---|---|---|---|--|
| 0                                | 0                                | 0 | 0 | 0 | 0/1 | 0/1 | 0/1 | 0 | 0 | 0 | 0 | 0/1 | 0/1 | 0/1 | 0/1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| Channel 0<br>Control<br>Register | Channel 1<br>Control<br>Register |   |   |   |     |     |     |   |   |   |   |     |     |     |     |   |   |   |   |   |   |   |   |  |

0/1 means the bit may be 0 or 1.

Now suppose Channel 1 becomes active. Its Control register Busy bit will be set:

| 7                                | 6                                | 5 | 4 | 3 | 2   | 1   | 0   | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----------------------------------|----------------------------------|---|---|---|-----|-----|-----|---|---|---|---|---|-----|-----|-----|---|---|---|---|---|---|---|---|--|
| 0                                | 0                                | 0 | 0 | 0 | 0/1 | 0/1 | 0/1 | 0 | 0 | 1 | 0 | 0 | 0/1 | 0/1 | 0/1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| Channel 0<br>Control<br>Register | Channel 1<br>Control<br>Register |   |   |   |     |     |     |   |   |   |   |   |     |     |     |   |   |   |   |   |   |   |   |  |

Next, suppose Channel 0 becomes active. The Channel 0 Busy bit will also be set:

| 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------|---|---|---|---|---|---|---|----------------------------|---|---|---|---|---|---|---|----------------------------|---|---|---|---|---|---|---|
| 0                          | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0                          | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| Channel 0 Control Register |   |   |   |   |   |   |   | Channel 1 Control Register |   |   |   |   |   |   |   | Interrupt Control Register |   |   |   |   |   |   |   |

When the Channel 1 DMA operation ends, no interrupt request will occur, since the Channel 1 interrupt logic has been disabled. Thus, the Channel 1 Control register Busy bit will be reset to 0, the DEND bit will be set to 1 and the Interrupt Control register will not change:

| 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------|---|---|---|---|---|---|---|----------------------------|---|---|---|---|---|---|---|----------------------------|---|---|---|---|---|---|---|
| 0                          | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0                          | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0                          | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| Channel 0 Control Register |   |   |   |   |   |   |   | Channel 1 Control Register |   |   |   |   |   |   |   | Interrupt Control Register |   |   |   |   |   |   |   |

As soon as the CPU reads the contents of the Channel 1 Control register, the Channel 1 DEND bit (bit 7) will be reset to 0.

Suppose Channel 0 now reaches the end of a data block; it will request an interrupt. The Channel 0 Control register's Busy bit will be reset to 0, the DEND bit will be set to 1 and the active interrupt request bit of the Interrupt Control register will also be set to 1:

| 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7                          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                            |  |  |  |  |  |  |  |
|----------------------------|---|---|---|---|---|---|---|----------------------------|---|---|---|---|---|---|---|----------------------------|--|--|--|--|--|--|--|
| 1                          | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0                          | 1 | 0 | 0 | 0 | 0 | 0 | 1 |                            |  |  |  |  |  |  |  |
| Channel 0 Control Register |   |   |   |   |   |   |   | Channel 1 Control Register |   |   |   |   |   |   |   | Interrupt Control Register |  |  |  |  |  |  |  |

Reading the contents of the Channel 0 Control register will reset the Channel 0 DEND bit (bit 7). Reading the Channel 0 Control register contents will also reset the Interrupt Control register bit 7, since the Channel 0 interrupt request caused this bit to be set. Reading the Channel 1 Control register will have no effect on the Interrupt Control register bit 7, since Channel 1 did not cause the interrupt request to be generated.

If more than one active interrupt is present, then your program must arbitrate priorities by examining the DEND status of each channel's Control register. Also, bit 7 of the Interrupt Control register will be reset when you read the contents of the Control register for the first channel to request an interrupt. For example, suppose all channel interrupts have been enabled, and Channel 0, then Channel 2, then Channel 1 request interrupts—before the CPU acknowledges an interrupt. The CPU can determine which channels have requested interrupts by reading Control register contents for Channels 0, 1 and 2. But it is the act of reading Channel 0 Control register contents that will reset bit 7 of the Interrupt Control register.

## RESETTING THE MC6844 DMAC

The MC6844 DMAC is reset when a low signal is input at the Reset pin. When the MC6844 DMAC is reset, all Control registers have their contents reset to 0. Address and Byte Count registers' contents, however, are not altered.

## PROGRAMMING THE MC6844 DMAC

Programming the MC6844 DMAC is quite straightforward.

**The first step is initialization.** If you have reset the MC6844, then all Control registers' contents will be 0—in which case all DMA requests and interrupt requests have been disabled. If you have not reset the MC6844 DMAC, then you should do so under program control by outputting 0 to the Enable/Priority Control register and the Interrupt Control register.

**Once the MC6844 DMAC has been disabled, then initialize channel Address and Byte Count registers by loading appropriate initial values into these registers.**

**Next, define the DMA operating modes** by loading appropriate codes into the channel Control registers for the enabled channels, and into the Data Chain Control register.

**Initialization is now complete.** You start DMA channels by outputting an appropriate code to the Interrupt Control register and then to the Enable/Priority Control register.

**Monitoring DMA operations while they are in progress is also quite straightforward.** Normally you will wait until the end of a DMA transfer is signaled by an interrupt request, at which time if more than one channel could have requested the interrupt, the interrupt service routine arbitrates priorities by reading all active channel Control registers' contents. The interrupt service routine must now respond to the active interrupt request according to the requirements of your program logic. This may or may not require restarting the same channel or another channel.

**You can monitor DMA operations while they are in progress by reading the contents of Address and Byte Count registers while a DMA operation is in progress. However, this is something you should only do while operating a DMA channel in one of the Halt modes. If you read register contents on the fly while operating in Three-State Control mode, you may read the wrong answer,** and determining what the right reading should be is not easy. This is because an instruction that reads 16 bits of data executes in two machine cycles. If this read operation occurs while a Three-State Control, Cycle Stealing DMA transfer is occurring, this is what happens:



In the illustration above, an LDX instruction loads the contents of a 16-bit register (we will assume it is the Channel Address register) into the Index register of the CPU. First the high-order byte of the Address register (03) is transferred to the high-order byte of the Index register. At the end of this machine cycle, however, the Address register is incremented. Now, you may say that this is no problem since you have read the valid Address register contents as they were at the end of the LDX instruction's execution. But unfortunately there is a special case. Suppose the Address register contained 0200<sub>16</sub> and was decrementing. Now you will read 02FF when 01FF was the correct value:



The error illustrated above cannot occur when operating DMA in a Halt mode, since the DMA transfer occurs in between instruction executions. Thus, the contents of any 16-bit registers within the MC6844 DMAC will not change while an LDX instruction is being executed, because no DMA transfer can occur until the LDX instruction has completed execution.

You can, if you wish, write into any MC6844 DMAC register at any time. For example, you can write into an Address or Byte Count register for a channel that is busy. Once again, you can get into trouble if you write into Address or Byte Count registers for a channel that is operating in Three-State Control, Cycle Stealing mode, since you will write the low-order byte, all 16 bits may be incremented or decremented, and then you will write the high-order byte; and who knows what the results will be. Writing into registers on the fly will not cause errors if you are operating in one of the Halt modes.

## THE MC6846 MULTIFUNCTION SUPPORT DEVICE

The MC6846 multifunction support device is designed to work with the MC6802 as a two-chip microcomputer. However, the MC6846 can be used just as easily in any other MC6800 microcomputer system.

Figure 9-38 illustrates part of our microcomputer system logic which is implemented on the MC6846 multifunction device. This device provides 2048 bytes of read-only memory, a single 8-bit parallel I/O port with handshaking control signals, and a counter/timer.

The MC6846 multifunction device is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL-compatible.

The device is implemented using N-channel silicon gate depletion load technology.

### MC6846 MULTIFUNCTION DEVICE PINS AND SIGNALS

MC6846 pins and signals are illustrated in Figure 9-39.

The device select lines CS0 and CS1 work in two ways: they activate the MC6846, and they select which function is in use — ROM or I/O and counter/timer. The user specifies as a mask option two active combinations of CS0 and CS1 levels: one to enable the ROM and one to enable the I/O and counter/timer. For example, you might wish to enable ROM when CS1 is high and CS0 is low, and enable the I/O and counter/timer when both select lines are high. This combination would then disable the MC6846 when CS1 is low.

When ROM is selected, the eleven lines A0 - A10 will address one of the 2048 bytes of read-only memory. These 2048 memory bytes may be located anywhere in the memory space.

In addition to CS0 and CS1, certain of the address lines are used to select the I/O and counter/timer functions. Lines A5, A4, and A3 must be low to select the I/O and counter/timer operations. You select as a mask option what level at line A6 enables I/O and the counter/timer, and whether or not one of the lines A10, A9, A8, and A7 must be high to enable these functions. Here is how address lines are used to select I/O and the counter/timer:



Once an MC6846 has been selected as an I/O device, address lines A0, A1, and A2 select one of seven registers in eight I/O addressable locations. Table 9-14 identifies the locations accessed with each address. Note that addresses 0 and 4 access the same location.

Table 9-14. MC6846 I/O Addressable Locations

| Address Line |    |    | Internal Register Selected       |
|--------------|----|----|----------------------------------|
| A2           | A1 | A0 |                                  |
| 0            | 0  | 0  | Composite Status register        |
| 0            | 0  | 1  | Peripheral Control register      |
| 0            | 1  | 0  | Data Direction register          |
| 0            | 1  | 1  | Peripheral Data register         |
| 1            | 0  | 0  | Composite Status register        |
| 1            | 0  | 1  | Timer Control register           |
| 1            | 1  | 0  | Timer register (high-order byte) |
| 1            | 1  | 1  | Timer register (low-order byte)  |



Figure 9-38. Logic of the MC6846 Multifunction Device



| PIN NAME  | DESCRIPTION                      | TYPE            |
|-----------|----------------------------------|-----------------|
| CS0, CS1  | Device select                    | Input           |
| A0 - A10  | Address lines                    | Input           |
| D0 - D7   | Data lines                       | Bidirectional   |
| R/W       | Read/Write                       | Input           |
| E         | Device synchronization           | Input           |
| PP0 - PP7 | I/O Port lines                   | Bidirectional   |
| CP1       | Interrupt/Strobe                 | Input           |
| CP2       | Peripheral Control               | Input or Output |
| CTO       | Counter/timer output             | Output          |
| CTC       | External clock for counter/timer | Input           |
| CTG       | Counter/timer gate               | Input           |
| IRQ       | Interrupt request                | Output          |
| RES       | Reset                            | Input           |
| VCC, VSS  | Power and Ground                 |                 |

Figure 9-39. MC6846 Multifunction Device Signals and Pin Assignments

All data transfers between the CPU and the MC6846 device occur via the bidirectional Data Bus (D0 - D7). This is a three-state State Bus; when the device is not selected the MC6846 holds these lines in the high-impedance state.

The R/W control determines whether data will flow into the MC6846 (a Write operation with R/W low) or from the MC6846 (a Read operation with R/W high).

E is the standard synchronizing clock signal used throughout an MC6800 microcomputer system.

The 8-bit parallel I/O port of the MC6846 is very similar to I/O Port B of an MC6820 Peripheral Interface Adapter (PIA). Differences are described later. Lines PPO - PP7 constitute an 8-bit bidirectional parallel I/O port. Control lines CP1 and CP2 are the two handshaking and interrupt control signals associated with the parallel I/O port.

The counter/timer of the MC6846 is very similar to counter/timer 3 of the MC6840 counter/timer, which has been described earlier in this chapter. CTO is the output signal, CTC is the external clock and CTG is the gate input.

Interrupt requests originating from the parallel I/O logic of the counter/timer logic are output via IRQ.

The device is reset by inputting a low level at RES. The actual operation of the reset logic is described after the registers which it affects have been discussed.

### MC6846 COUNTER/TIMER LOGIC

Before reading this section, you should be familiar with the MC6840 counter/timer device described earlier in this chapter. We are only going to examine the differences between counter/timer logic of the MC6846 and channel 3 of the MC6840. Note that channel 3 of the MC6840, like the counter/timer logic of the MC6846, can be operated in divide-by-eight mode.

The MC6846 counter/timer has its own Control register, Most Significant Byte register, and Least Significant Byte register. As illustrated in Table 9-13, these three registers are accessed via addresses DEV+5, DEV+6, and DEV+7 respectively. The counter/timer logic does not have its own Status register; this is shared with I/O port logic.

The counter/timer Control register address is not the same as any of the three addresses set aside for Control registers of the MC6840. The Most Significant Byte register and Least Significant Byte register addresses, however, are the same as two addresses allocated to these two registers by the MC6840.

Bits of the MC6846 counter/timer Control register are not assigned in the same way as they are for any MC6840 Control register. Here are the counter/timer Control register bit assignments for the MC6846:



Bit 0 is the internal reset bit. This is the same as bit 0 of the Control register of MC6840 counter/timer logic 1.

Bit 1 determines whether the external clock (CTC) or the system clock (P2, via E) will be the timing signal. This is the same as in MC6840 Control registers.

Bit 2 enables or disables the divide-by-eight prescaler; bit 0 of counter/timer 3's Control register performs the same task in the MC6840.

Bit 6 enables or disables interrupt logic, and bit 7 enables or disables the output signal for the counter/timer as described for the MC6840.

Control register bits 3, 4 and 5 determine the operating mode of the counter/timer. There is just one difference between the interpretation of these three bits in the MC6846 as compared to the interpretation of these three bits in the MC6840. The MC6846 has no program-initiated single-shot mode. Only a high-to-low transition of the gate input will initiate single-shot mode. This missing variation of single-shot mode is replaced by a cascade mode. In the cascade mode, Control register bit 7 is connected to the output signal CTO. When Control register bit 7 is 0, the output signal is set low on the next timeout; when Control register bit 7 is 1, the next timeout sets the output signal high. This is called a "cascade" mode because it allows you, under program control, to count timeouts which generate interrupt requests in the usual way and then, under program control, to change the level of the output based on the time interval computed via timeouts.

## MC6846 I/O PORT LOGIC

Before reading this section, you should be familiar with the MC6820 PIA described earlier in this chapter. **We are only going to examine the differences between I/O port logic of the MC6846 and I/O Port B of the MC6820.**

The MC6846 I/O Port can provide programmed handshaking on either input or output.

Any of the data lines PP0 - PP7 can directly drive the base of a Darlington NPN transistor. The control line CP2 also has this capability.

The MC6846 I/O Port has its own Control register, Data Direction register, and Peripheral Data register. As illustrated in Table 9-13, these three registers are accessed via addresses DEV+1, DEV+2, and DEV+3 respectively. **The I/O port logic does not have its own Status register; this is shared with the counter/timer logic.** We will describe the Composite Status register later on.

In the MC6846, the Data Direction register and the Peripheral Data register have separate addresses. Recall that in the MC6820 PIA these two registers share one address, and Bit 2 of the Control register determines which location is accessed by that address.

Bits of the MC6846 Peripheral Control register are not assigned in the same way as they are for either of the MC6820 Control registers. **Here are the Peripheral Control register bit assignments for the MC6846:**



If Bit 0 is set to 1, then an active transition (as defined in Bit 1) at CP1 will set IRQ low. Bits 0 and 1 are used in the same way in the Control registers of the MC6820.

Bit 2 selects the input latch function. When bit 2 is set, an active transition at CP1 will latch data input on lines PPO - PP7. The MC6820 does not provide an input latch function.

Bits 3, 4, and 5 control the CP2 line in the same way that MC6820 Control Register B bits 3, 4, and 5 control line CB2 of that device.

Bit 6 is not used in the MC6846.

Bit 7 serves as an internal reset for the I/O port. The CPU may set this bit by writing a 1 into it, but it will also be set automatically when the MC6846 receives a low level at the reset input, RES. You clear bit 7 by writing a 0 to it during a CPU write to the Peripheral Control register.

**The interrupt flags for both the timer/counter and the I/O port appear in the Composite Status register, which the CPU accesses via either of the addresses DEV or DEV+4. This register is a read-only location.**

**MC6846  
COMPOSITE STATUS REGISTER**

Here are the bit assignments for the Composite Status register:



Note that interrupt conditions will appear in bits 0, 1, and 2 of the Composite Status register, whether or not interrupts are enabled in the corresponding Control register.

A counter/timer interrupt will set bit 0 of the Composite Status register. Any of the following actions will reset the counter/timer interrupt flag to 0:

- Timer reset via either Timer Control register bit 7 or RES input
- Initializing the counter
- Writing to the timer latches in Frequency Comparison mode or Pulse Width Comparison mode
- Reading the Timer register after reading the Composite Status register while the timer interrupt bit was set. That is, the following sequence resets bit 0 of the Composite Status register: bit 0 is set by the counter/timer interrupt; the CPU reads the Composite Status register (location DEV or DEV+4); then the CPU reads the Timer register (locations DEV+6 and DEV+7).

Interrupt transitions at CP1 and CP2 will set bits 1 and 2, respectively, of the Composite Status register. Each of these bits will be reset to 0 by a Read or Write to the Peripheral Data register (location DEV+3), but only if the flag was already set when the CPU last read the Composite Status register. This is analogous to the fourth counter/timer flag reset condition described above.

Bit 7 will be set to 1 only when IRQ is set low; that is, any one of the three interrupt bits described above will set bit 7, but only if that interrupt has been enabled in the appropriate Control register bit. Bit 7 will be 0 only when all three of bits 0, 1, and 2 are reset to 0.

Bits 3, 4, and 5 of the Composite Status register are not used.

**The Data Direction register and the Peripheral Data register work in the same way as those in the MC6820 do.**

### MC6846 DEVICE RESET

**When the MC6846 receives a low level on RES, all the I/O and counter/timer logic enters the Reset state. In addition, the I/O port and the counter/timer can be reset individually via the internal reset bits of their respective Control registers — bit 0 of the Timer Control register and bit 7 of the Peripheral Control register.**

**These are the results of a counter/timer reset:**

- The counter latches take on the maximum count (65,536). This occurs only during external reset (RES low).
- The counter clock is disabled.
- Bits 1 through 6 of the Timer Control register are reset to 0, as are the output line CTO and the interrupt flag (bit 0 of the Composite Status register).

**The net effect is that the counter/timer becomes inactive until the CPU writes a 0 to bit 0 of the Timer Control register.**

**These are the results of an I/O port reset:**

- All bits of the Peripheral Data register and Data Direction register are reset to 0, as are the interrupt flags (bits 1 and 2 of the Composite Status register).
- Bits 6 through 0 of the Peripheral Control register are reset to 0.

**The net effect is that the port is in input mode, and its interrupts are disabled.**

## DATA SHEETS

This section contains specific electrical and timing data for the following devices:

- MC6800 CPU
- MC6802 CPU/RAM
- MC6870A Clock
- MC6871A Clock
- MC6871B Clock
- MC6820 PIA
- MC6850 ACIA
- MC6852 SSDA
- MC6840 PTM
- MC6844 DMAC
- MC6846 ROM-I/O-Timer

## MC6800

TABLE 1 – MAXIMUM RATINGS

| Rating                                                       | Symbol           | Value                                 | Unit |
|--------------------------------------------------------------|------------------|---------------------------------------|------|
| Supply Voltage                                               | V <sub>CC</sub>  | -0.3 to +7.0                          | Vdc  |
| Input Voltage                                                | V <sub>in</sub>  | -0.3 to +7.0                          | Vdc  |
| Operating Temperature Range—T <sub>L</sub> to T <sub>H</sub> | T <sub>A</sub>   | 0 to +70<br>-40 to +85<br>-55 to +125 | °C   |
| Storage Temperature Range                                    | T <sub>stg</sub> | -55 to +150                           | °C   |
| Thermal Resistance                                           | θ <sub>JA</sub>  | 70<br>50                              | °C/W |

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.

TABLE 2 – ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V, ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub> unless otherwise noted)

| Characteristic                                                                                                                                                                                       | Symbol                              | Min                                            | Typ                                                                     | Max                                            | Unit  |    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------|-------|----|
| Input High Voltage<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = max)<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = 0 V)                                                               | V <sub>IH</sub><br>V <sub>IHC</sub> | V <sub>SS</sub> + 2.0<br>V <sub>CC</sub> - 0.6 | —<br>—                                                                  | V <sub>CC</sub> + 0.3                          | Vdc   |    |
| Input Low Voltage<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = min)                                                                                                                          | V <sub>IL</sub><br>V <sub>ILC</sub> | V <sub>SS</sub> - 0.3<br>V <sub>SS</sub> - 0.3 | —<br>—                                                                  | V <sub>SS</sub> + 0.8<br>V <sub>SS</sub> + 0.4 | Vdc   |    |
| Input Leakage Current<br>(I <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = max)<br>(I <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = 0 V)                                                            | I <sub>in</sub>                     | —<br>—                                         | 1.0<br>—                                                                | 2.5<br>100                                     | μA/dc |    |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 V, V <sub>CC</sub> = max)                                                                                                     | D0-D7                               | I <sub>TSI</sub>                               | —                                                                       | 2.0                                            | μA/dc |    |
| Output High Voltage<br>(I <sub>Load</sub> = -205 μA/dc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -145 μA/dc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -100 μA/dc, V <sub>CC</sub> = min) | A0-A15,R/W                          | V <sub>OH</sub>                                | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | —<br>—<br>—                                    | Vdc   |    |
| Output Low Voltage (I <sub>Load</sub> = 1.6 mA/dc, V <sub>CC</sub> = min)                                                                                                                            | V <sub>OL</sub>                     | —                                              | —                                                                       | V <sub>SS</sub> + 0.4                          | Vdc   |    |
| Power Dissipation                                                                                                                                                                                    | P <sub>D</sub>                      | —                                              | 0.5                                                                     | 1.0                                            | W     |    |
| Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                                                                             | C <sub>in</sub>                     | —<br>—<br>—<br>—                               | 25<br>45<br>10<br>6.5                                                   | 35<br>70<br>12.5<br>10                         | pF    |    |
| Logic Inputs                                                                                                                                                                                         | D0-D7<br>A0-A15,R/W,VMA             | C <sub>out</sub>                               | —                                                                       | —                                              | 12    | pF |

TABLE 3 – CLOCK TIMING (V<sub>CC</sub> = 5.0 V, ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub> unless otherwise noted)

| Characteristics                                                                                                                                                                                                                                      | Symbol                            | Min                     | Typ         | Max                  | Unit |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------------|-------------|----------------------|------|
| Frequency of Operation<br>MC6800<br>MC68A00<br>MC68B00                                                                                                                                                                                               | f                                 | 0.1<br>0.1<br>0.1       | —<br>—<br>— | 1.0<br>1.5<br>2.0    | MHz  |
| Cycle Time (Figure 1)<br>MC6800<br>MC68A00<br>MC68B00                                                                                                                                                                                                | t <sub>cyc</sub>                  | 1.000<br>0.666<br>0.500 | —<br>—<br>— | 10<br>10<br>10       | μs   |
| Clock Pulse Width<br>(Measured at V <sub>CC</sub> - 0.6 V)<br>φ1,φ2 – MC6800<br>φ1,φ2 – MC68A00<br>φ1,φ2 – MC68B00                                                                                                                                   | PW <sub>φH</sub>                  | 400<br>230<br>180       | —<br>—<br>— | 9500<br>9500<br>9500 | ns   |
| Total φ1 and φ2 Up Time<br>MC6800<br>MC68A00<br>MC68B00                                                                                                                                                                                              | t <sub>ut</sub>                   | 900<br>600<br>440       | —<br>—<br>— | —                    | ns   |
| Rise and Fall Times<br>(Measured between V <sub>SS</sub> + 0.4 and V <sub>CC</sub> - 0.6)                                                                                                                                                            | t <sub>φr</sub> , t <sub>φf</sub> | —                       | —           | 100                  | ns   |
| Delay Time or Clock Separation (Figure 1)<br>(Measured at V <sub>OV</sub> = V <sub>SS</sub> + 0.6 V @ t <sub>r</sub> = t <sub>f</sub> ≤ 100 ns)<br>(Measured at V <sub>OV</sub> = V <sub>SS</sub> + 1.0 V @ t <sub>r</sub> = t <sub>f</sub> ≤ 35 ns) | t <sub>d</sub>                    | 0<br>0                  | —<br>—      | 9100<br>9100         | ns   |



**MOTOROLA Semiconductor Products Inc.**

Data sheets on pages 9-D2 through 9-D30 reprinted by permission of Motorola Semiconductor Products, Inc.

## MC6800

TABLE 4 – READ/WRITE TIMING (Reference Figures 2 through 6)

| Characteristic                                                        | Symbol                                | MC6800 |     |            | MC68A00 |     |            | MC68B00 |     |            | Unit <sup>1</sup> |
|-----------------------------------------------------------------------|---------------------------------------|--------|-----|------------|---------|-----|------------|---------|-----|------------|-------------------|
|                                                                       |                                       | Min    | Typ | Max        | Min     | Typ | Max        | Min     | Typ | Max        |                   |
| Address Delay<br>C = 90 pF<br>C = 30 pF                               | t <sub>AD</sub>                       | —      | —   | 270<br>250 | —       | —   | 180<br>165 | —       | —   | 150<br>135 | ns                |
| Peripheral Read Access Time<br>$t_{ac} = t_{ut} - (t_{AD} + t_{DSR})$ | t <sub>ac</sub>                       | —      | —   | 530        | —       | —   | 360        | —       | —   | 250        | ns                |
| Data Setup Time (Read)                                                | t <sub>DSR</sub>                      | 100    | —   | —          | 60      | —   | —          | 40      | —   | —          | ns                |
| Input Data Hold Time                                                  | t <sub>H</sub>                        | 10     | —   | —          | 10      | —   | —          | 10      | —   | —          | ns                |
| Output Data Hold Time                                                 | t <sub>H</sub>                        | 10     | 25  | —          | 10      | 25  | —          | 10      | 25  | —          | ns                |
| Address Hold Time<br>(Address, R/W, VMA)                              | t <sub>AH</sub>                       | 30     | 50  | —          | 30      | 50  | —          | 30      | 50  | —          | ns                |
| Enable High Time for DBE Input                                        | t <sub>EH</sub>                       | 450    | —   | —          | 280     | —   | —          | 220     | —   | —          | ns                |
| Data Delay Time (Write)                                               | t <sub>DDW</sub>                      | —      | —   | 225        | —       | —   | 200        | —       | —   | 160        | ns                |
| Processor Controls                                                    |                                       |        |     |            |         |     |            |         |     |            |                   |
| Processor Control Setup Time                                          | t <sub>PCS</sub>                      | 200    | —   | —          | 140     | —   | —          | 110     | —   | —          | ns                |
| Processor Control Rise and Fall Time                                  | t <sub>PCr</sub> , t <sub>PCf</sub>   | —      | —   | 100        | —       | —   | 100        | —       | —   | 100        | ns                |
| Bus Available Delay                                                   | t <sub>BA</sub>                       | —      | —   | 250        | —       | —   | 165        | —       | —   | 135        | ns                |
| Three-State Delay                                                     | t <sub>TSD</sub>                      | —      | —   | 270        | —       | —   | 270        | —       | —   | 220        | ns                |
| Data Bus Enable Down Time During φ1 Up Time                           | t <sub>DBE</sub>                      | 150    | —   | —          | 120     | —   | —          | 75      | —   | —          | ns                |
| Data Bus Enable Rise and Fall Times                                   | t <sub>DBEr</sub> , t <sub>DBEf</sub> | —      | —   | 25         | —       | —   | 25         | —       | —   | 25         | ns                |

FIGURE 1 – CLOCK TIMING WAVEFORM



FIGURE 2 – READ DATA FROM MEMORY OR PERIPHERALS



MOTOROLA Semiconductor Products Inc.

FIGURE 3 - WRITE IN MEMORY OR PERIPHERALS

FIGURE 4 - TYPICAL DATA BUS OUTPUT DELAY versus CAPACITIVE LOADING ( $T_{DDW}$ )FIGURE 5 - TYPICAL READ/WRITE, VMA, AND ADDRESS OUTPUT DELAY versus CAPACITIVE LOADING ( $T_{AD}$ )

MOTOROLA Semiconductor Products Inc.

FIGURE 6 – BUS TIMING TEST LOADS



C = 130 pF for D0-D7, E  
 = 90 pF for A0-A15, R/W, and VMA  
 (Except t<sub>AD2</sub>)  
 = 30 pF for A0-A15, R/W, and VMA ,  
 (t<sub>AD2</sub> only)  
 = 30 pF for BA

R = 11.7 kΩ for D0-D7  
 = 16.5 kΩ for A0-A15, R/W, and VMA  
 = 24 kΩ for BA

## TEST CONDITIONS

The dynamic test load for the Data Bus is 130 pF and one standard TTL load as shown. The Address, R/W, and VMA outputs are tested under two conditions to allow optimum operation in both buffered and unbuffered systems. The resistor (R) is chosen to insure specified load currents during  $V_{OH}$  measurement.

Notice that the Data Bus lines, the Address lines, the Interrupt Request line, and the DBE line are all specified and tested to guarantee 0.4 V of dynamic noise immunity at both "1" and "0" logic levels.

FIGURE 12 – THREE STATE CONTROL TIMING



FIGURE 13 – HALT AND SINGLE INSTRUCTION EXECUTION FOR SYSTEM DEBUG



MOTOROLA Semiconductor Products Inc.

## MAXIMUM RATINGS

| Rating                      | Symbol           | Value        | Unit |
|-----------------------------|------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C   |
| Thermal Resistance          | θ <sub>JA</sub>  | 70           | °C/W |

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.

ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to 70°C unless otherwise noted.)

| Characteristic                                                                                                                                                                                       | Symbol                                | Min                                                                     | Typ         | Max                                | Unit  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------------------------------------------------------------------|-------------|------------------------------------|-------|
| Input High Voltage<br>Logic, EXtal<br>Reset                                                                                                                                                          | V <sub>IH</sub>                       | V <sub>SS</sub> + 2.0<br>V <sub>SS</sub> + 4.0                          | —<br>—      | V <sub>CC</sub><br>V <sub>CC</sub> | Vdc   |
| Input Low Voltage<br>Logic, EXtal, Reset                                                                                                                                                             | V <sub>IL</sub>                       | V <sub>SS</sub> - 0.3                                                   | —           | V <sub>SS</sub> + 0.8              | Vdc   |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = max)                                                                                                                      | I <sub>in</sub>                       | —                                                                       | 1.0         | 2.5                                | μA/dc |
| Output High Voltage<br>(I <sub>Load</sub> = -205 μA/dc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -145 μA/dc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -100 μA/dc, V <sub>CC</sub> = min) | V <sub>OH</sub>                       | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | —<br>—<br>— | —<br>—<br>—                        | Vdc   |
| Output Low Voltage<br>(I <sub>Load</sub> = 1.6 mA/dc, V <sub>CC</sub> = min)                                                                                                                         | V <sub>OL</sub>                       | —                                                                       | —           | V <sub>SS</sub> + 0.4              | Vdc   |
| Power Dissipation                                                                                                                                                                                    | P <sub>D</sub> **                     | —                                                                       | 0.600       | 1.2                                | W     |
| Capacitance #<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                                                                           | C <sub>in</sub>                       | —<br>—                                                                  | 10<br>6.5   | 12.5<br>10                         | pF    |
| Logic Inputs, EXtal<br>A0-A15, R/W, VMA                                                                                                                                                              | C <sub>out</sub>                      | —                                                                       | —           | 12                                 | pF    |
| Frequency of Operation (Input Clock ÷ 4)<br>(Crystal Frequency)                                                                                                                                      | f<br>f <sub>Xtal</sub>                | 0.1<br>1.0                                                              | —<br>—      | 1.0<br>4.0                         | MHz   |
| Clock Timing<br>Cycle Time                                                                                                                                                                           | t <sub>cyc</sub>                      | 1.0                                                                     | —           | 10                                 | μs    |
| Clock Pulse Width<br>(Measured at 2.4 V)                                                                                                                                                             | PW <sub>QHs</sub><br>PW <sub>QL</sub> | 450                                                                     | —           | 4500                               | ns    |
| Fall Time<br>(Measured between V <sub>SS</sub> + 0.4 V and V <sub>SS</sub> - 2.4 V)                                                                                                                  | t <sub>φ</sub>                        | —                                                                       | —           | 25                                 | ns    |

\*Except IRQ and NMI, which require 3 kΩ pullup load resistors for wire-OR capability at optimum operation. Does not include EXtal and Xtal, which are crystal inputs.

\*\*In power-down mode, maximum power dissipation is less than 40 mW.

#Capacitances are periodically sampled rather than 100% tested.

## READ/WRITE TIMING (Figures 2 through 6; Load Circuit of Figure 4.)

| Characteristic                                                                                                                   | Symbol                                                 | Min      | Typ    | Max      | Unit     |
|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|----------|--------|----------|----------|
| Address Delay                                                                                                                    | t <sub>AD</sub>                                        | —        | —      | 270      | ns       |
| Peripheral Read Access Time<br>t <sub>acc</sub> = t <sub>ut</sub> - (t <sub>AD</sub> + t <sub>DSR</sub> )                        | t <sub>acc</sub>                                       | —        | —      | 530      | ns       |
| Data Setup Time (Read)                                                                                                           | t <sub>DSR</sub>                                       | 100      | —      | —        | ns       |
| Input Data Hold Time                                                                                                             | t <sub>H</sub>                                         | 10       | —      | —        | ns       |
| Output Data Hold Time                                                                                                            | t <sub>H</sub>                                         | 20       | —      | —        | ns       |
| Address Hold Time (Address, R/W, VMA)                                                                                            | t <sub>AH</sub>                                        | 20       | —      | —        | ns       |
| Data Delay Time (Write)                                                                                                          | t <sub>DDW</sub>                                       | —        | 165    | 225      | ns       |
| Processor Controls<br>Processor Control Setup Time<br>Processor Control Rise and Fall Time<br>(Measured between 0.8 V and 2.0 V) | t <sub>PCS</sub><br>t <sub>PCr</sub> , t <sub>Cf</sub> | 200<br>— | —<br>— | —<br>100 | ns<br>ns |



MOTOROLA Semiconductor Products Inc.

FIGURE 2 – READ DATA FROM MEMORY OR PERIPHERALS



FIGURE 3 – WRITE DATA IN MEMORY OR PERIPHERALS



FIGURE 4 – BUS TIMING TEST LOAD

C = 130 pF for D0-D7, E  
 = 90 pF for A0-A15, R/W, and VMA  
 = 30 pF for BA  
 R = 11.7 k $\Omega$  for D0-D7, E  
 = 16.5 k $\Omega$  for A0-A15, R/W, and VMA  
 = 24 k $\Omega$  for BA



MOTOROLA Semiconductor Products Inc.

**FIGURE 5 – TYPICAL DATA BUS OUTPUT DELAY versus CAPACITIVE LOADING****FIGURE 6 – TYPICAL READ/WRITE, VMA, AND ADDRESS OUTPUT DELAY versus CAPACITIVE LOADING****FIGURE 10 – POWER-UP AND RESET TIMING****MOTOROLA Semiconductor Products Inc.**

## MC6802

FIGURE 11 – POWER-DOWN SEQUENCE



FIGURE 13 – MEMORY READY CONTROL FUNCTION



MOTOROLA Semiconductor Products Inc.



# MC6871A

full function microprocessor clock  
850 kHz to 2.5 MHz



## specifications

| Rating                      | Symbol           | Value       | Unit |
|-----------------------------|------------------|-------------|------|
| Supply Voltage              | V <sub>cc</sub>  | 5.00 ± 5%   | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70    | °C   |
| Storage Temperature         | T <sub>stg</sub> | -55 to +125 | °C   |
| Power Supply Drain (max.)   | I <sub>pd</sub>  | 100         | mA   |

ELECTRICAL CHARACTERISTICS (V<sub>cc</sub> = 5.0 ± 5%, V<sub>H</sub> = 0, T<sub>A</sub> = 0 to 70°C, unless otherwise noted)

| Characteristic                                                                                                                                          | Symbol         | Min  | Typ  | Max | Unit |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------|------|-----|------|
| Frequency                                                                                                                                               |                |      |      |     |      |
| Operating Frequency                                                                                                                                     | T <sub>o</sub> | .850 |      | 2.5 | MHz  |
| Frequency stability (inclusive of calibration tolerance at +25°C, operating temperature, input voltage change, load change, aging, shock and vibration) |                |      | ±.01 |     | %    |

### NMOS Outputs at 1.0 MHz Operation\*\*\*

|                                                      |                  |                    |      |                    |     |
|------------------------------------------------------|------------------|--------------------|------|--------------------|-----|
| Pulse Width (meas. at V <sub>cc</sub> = 3V dc level) | T <sub>O,H</sub> | 430                |      |                    | ns  |
|                                                      | T <sub>O,H</sub> | 450                |      |                    | ns  |
| Logic Levels                                         | V <sub>OL</sub>  | V <sub>cc</sub> -1 | —    | V <sub>cc</sub> +3 | Vdc |
|                                                      | V <sub>OH</sub>  | V <sub>cc</sub> -3 | —    | V <sub>cc</sub> +1 | Vdc |
| Rise and Fall Times                                  | t <sub>r</sub>   | 5                  | 12   | 50                 | ns  |
|                                                      | t <sub>f</sub>   | 5                  | 12   | 50                 | ns  |
| *Overshoot/Uncertain Logic "1"                       | V <sub>os</sub>  | V <sub>cc</sub> -5 | —    | V <sub>cc</sub> +5 | Vdc |
| Logic "0"                                            | V <sub>os</sub>  | V <sub>cc</sub> -5 | —    | V <sub>cc</sub> +5 | Vdc |
| Pulse duration of any overshoot or undershoot        | T <sub>os</sub>  |                    | 40   |                    | ns  |
| Period @ 0.3V dc Level                               | T <sub>o,T</sub> |                    | 1.00 |                    | us  |
| Edge Timing @ V <sub>cc</sub> =0.3V dc               | T <sub>X</sub>   | 940                |      |                    | ns  |
| NMOS Relationship                                    | t <sub>d1</sub>  | 0                  |      |                    |     |
| (@ +0.5V dc Level)                                   | t <sub>d2</sub>  | 0                  |      | 8.0                | us  |

### TTL Outputs

|                                                                  |                 |     |     |      |     |
|------------------------------------------------------------------|-----------------|-----|-----|------|-----|
| In ref. to $\emptyset$ , NMOS @ 0.3V dc                          |                 |     |     |      |     |
| $\emptyset$ , TTL @ 1.4V dc                                      | T <sub>A</sub>  | 15  | 30  | 45   | ns  |
|                                                                  | T <sub>J</sub>  | 10  | 25  | 40   | ns  |
| Memory Clock @ 1.4V dc                                           | T <sub>C</sub>  | 30  | 50  | 70   | ns  |
|                                                                  | T <sub>J</sub>  | 20  | 40  | 60   | ns  |
| 2x10 @ 1.4V dc                                                   | T <sub>S</sub>  | 40  | 80  | 120  | ns  |
| Logic Levels                                                     | V <sub>OH</sub> | 2.4 | 3.2 | .3   | Vdc |
|                                                                  | V <sub>OL</sub> |     |     | .4   | Vdc |
| Rise and Fall Times 4V and 2.4V 2.4V and .4V                     | t <sub>r</sub>  |     |     | 15   | ns  |
|                                                                  | t <sub>f</sub>  |     |     | 15   | ns  |
| Logic "0" Sink (/Gate)                                           | I <sub>OL</sub> |     |     | -1.6 | mA  |
| Logic "1" Source (/Gate)                                         | I <sub>OH</sub> |     |     | +40  | uA  |
| Current Output Shorted                                           | I <sub>SC</sub> | -18 |     | -57  | mA  |
| Load                                                             |                 |     |     |      |     |
| NMOS—Load Capacity $\emptyset$ , $\emptyset$ , C <sub>NMOS</sub> | 80              | 120 | 160 |      | pf  |
| TTL—No. of Loads                                                 |                 |     |     | 5    | ttl |
| TTL—Load Capacity C <sub>ttl</sub>                               |                 |     |     | 50   | pf  |

### Logic Inputs\*\* ("0" Level Applies HOLD or MEMORY READY)

|                                                                                                       |              |     |     |     |
|-------------------------------------------------------------------------------------------------------|--------------|-----|-----|-----|
| Holds $\emptyset$ , NMOS "High", $\emptyset$ , NMOS "Low", $\emptyset$ , TTL "Low"                    | HOLD 1       | -2  | +.4 | Vdc |
| Holds $\emptyset$ , NMOS "Low", $\emptyset$ , NMOS "High", $\emptyset$ , TTL "High", and MEMORY READY | MEMORY READY | -.2 | +.4 | Vdc |

\*Indicates specified test load.

\*\*Must be externally held at "1" (24 min., 5.0V max.) if not used.

\*\*\*Apply the following parameters for frequencies other than 1 MHz:

T<sub>O,H</sub>=0.5 (P=100) ns

T<sub>X</sub>=P/60 ns

where P=desired period of operation in nanoseconds.

| PIN | CONNECTION              |
|-----|-------------------------|
| 1   | GND                     |
| 3   | MEMORY CLOCK            |
| 5   | $\emptyset$ , TTL       |
| 7   | V <sub>cc</sub> (+5VDC) |
| 12  | $\emptyset$ , NMOS      |
| 13  | $\emptyset$ , NMOS      |
| 18  | GND                     |
| 20  | HOLD 1                  |
| 22  | MEMORY READY            |
| 24  | 2x10                    |



Note: All dimensions are in inches

## WAVEFORM TIMING



## TEST CIRCUIT



C<sub>H1</sub> = MAX CAPACITY 50 pF

C<sub>H2</sub> = 100 pF (40% OF THE SPECIFIED MAX LOAD CAPACITANCE THAT SIMULATES THE MOTOROLA MC6800 MPU INPUT)

R<sub>S</sub>=(22Ω) SIMULATES REAL PART OF MPU

\*HOLD AND MEMORY READY MUST BE EXTERNALLY HELD AT "1" LEVEL (24VDC MIN. 5.0VDC MAX.) WHEN NOT USED.



MOTOROLA INC. COMPONENT PRODUCTS DEPT.



ELECTRICAL CHARACTERISTICS ( $V_{CC} = 5.0 \text{ V} \pm 5\%$ ,  $V_{SS} = 0$ ,  $T_A = 0 \text{ to } 70^\circ\text{C}$  unless otherwise noted.)

| Characteristic                                                                                                                                                                    | Symbol                                                                      | Min                                                                                            | Typ                              | Max                              | Unit                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------|-------------------------|
| Input High Voltage<br>Enable Other Inputs                                                                                                                                         | $V_{IH}$                                                                    | $V_{SS} + 2.4$<br>$V_{SS} + 2.0$                                                               | —                                | $V_{CC}$<br>$V_{CC}$             | Vdc                     |
| Input Low Voltage<br>Enable Other Inputs                                                                                                                                          | $V_{IL}$                                                                    | $V_{SS} - 0.3$<br>$V_{SS} - 0.3$                                                               | —                                | $V_{SS} + 0.4$<br>$V_{SS} + 0.8$ | Vdc                     |
| Input Leakage Current<br>( $V_{in} = 0 \text{ to } 5.5 \text{ Vdc}$ )<br>R/W, Reset, RS0, RS1, CS0, CS1, CS2, CA1, CB1, Enable                                                    | $I_{in}$                                                                    | —                                                                                              | 1.0                              | 2.5                              | $\mu\text{Adc}$         |
| Three-State (Off State) Input Current<br>( $V_{in} = 0.4 \text{ to } 2.4 \text{ Vdc}$ )                                                                                           | $I_{TSI}$                                                                   | —                                                                                              | 2.0                              | 10                               | $\mu\text{Adc}$         |
| Input High Current<br>( $V_{IH} = 2.4 \text{ Vdc}$ )                                                                                                                              | PA0-PA7, CA2                                                                | $I_{IH}$                                                                                       | -100                             | -250                             | —                       |
| Input Low Current<br>( $V_{IL} = 0.4 \text{ Vdc}$ )                                                                                                                               | PA0-PA7, CA2                                                                | $I_{IL}$                                                                                       | —                                | -1.0                             | -1.6                    |
| Output High Voltage<br>( $I_{Load} = -205 \mu\text{Adc}$ , Enable Pulse Width < 25 $\mu\text{s}$ )<br>( $I_{Load} = -100 \mu\text{Adc}$ , Enable Pulse Width < 25 $\mu\text{s}$ ) | D0-D7<br>Other Outputs                                                      | $V_{OH}$                                                                                       | $V_{SS} + 2.4$<br>$V_{SS} + 2.4$ | —                                | Vdc                     |
| Output Low Voltage<br>( $I_{Load} = 1.6 \text{ mAdc}$ , Enable Pulse Width < 25 $\mu\text{s}$ )                                                                                   |                                                                             | $V_{OL}$                                                                                       | —                                | —                                | $V_{SS} + 0.4$          |
| Output High Current (Sourcing)<br>( $V_{OH} = 2.4 \text{ Vdc}$ )                                                                                                                  | D0-D7<br>Other Outputs                                                      | $I_{OH}$                                                                                       | -205<br>-100                     | —                                | —                       |
| ( $V_O = 1.5 \text{ Vdc}$ , the current for driving other than TTL, e.g.,<br>Darlington Base)                                                                                     | PA0-PB7, CB2                                                                |                                                                                                | -1.0                             | -2.5                             | -10                     |
| Output Low Current (Sinking)<br>( $V_{OL} = 0.4 \text{ Vdc}$ )                                                                                                                    |                                                                             | $I_{OL}$                                                                                       | 1.6                              | —                                | —                       |
| Output Leakage Current (Off State)<br>( $V_{OH} = 2.4 \text{ Vdc}$ )                                                                                                              | IRQA, IRQB                                                                  | $I_{LOH}$                                                                                      | —                                | 1.0                              | 10                      |
| Power Dissipation                                                                                                                                                                 |                                                                             | $P_D$                                                                                          | —                                | —                                | 650                     |
| Input Capacitance<br>( $V_{in} = 0$ , $T_A = 25^\circ\text{C}$ , $f = 1.0 \text{ MHz}$ )                                                                                          | PA0-PA7, PB0-PB7, CA2, CB2<br>R/W, Reset, RS0, RS1, CS0, CS1, CS2, CA1, CB1 | Enable<br>D0-D7<br>PA0-PA7, PB0-PB7, CA2, CB2<br>R/W, Reset, RS0, RS1, CS0, CS1, CS2, CA1, CB1 | $C_{in}$                         | —<br>—<br>—<br>—                 | 20<br>12.5<br>10<br>7.5 |
| Output Capacitance<br>( $V_{in} = 0$ , $T_A = 25^\circ\text{C}$ , $f = 1.0 \text{ MHz}$ )                                                                                         | IRQA, IRQB<br>PB0-PB7                                                       |                                                                                                | $C_{out}$                        | —<br>—                           | 5.0<br>10               |
| Peripheral Data Setup Time (Figure 1)                                                                                                                                             |                                                                             | $t_{PDSU}$                                                                                     | 200                              | —                                | ns                      |
| Delay Time, Enable negative transition to CA2 negative transition<br>(Figure 2, 3)                                                                                                |                                                                             | $t_{CA2}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Delay Time, Enable negative transition to CA2 positive transition<br>(Figure 2)                                                                                                   |                                                                             | $t_{RS1}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Rise and Fall Times for CA1 and CA2 input signals (Figure 3)                                                                                                                      |                                                                             | $t_{rf}$                                                                                       | —                                | —                                | $\mu\text{s}$           |
| Delay Time from CA1 active transition to CA2 positive transition<br>(Figure 3)                                                                                                    |                                                                             | $t_{RS2}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Delay Time, Enable negative transition to Peripheral Data valid<br>(Figures 4, 5)                                                                                                 |                                                                             | $t_{PDW}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Delay Time, Enable negative transition to Peripheral CMOS Data Valid<br>( $V_{CC} = 30\% V_{CC}$ , Figure 4; Figure 12 Load C)                                                    | PA0-PA7, CA2                                                                | $t_{CMOS}$                                                                                     | —                                | —                                | 2.0                     |
| Delay Time, Enable positive transition to CB2 negative transition<br>(Figure 6, 7)                                                                                                |                                                                             | $t_{CB2}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Delay Time, Peripheral Data valid to CB2 negative transition<br>(Figure 5)                                                                                                        |                                                                             | $t_{DC}$                                                                                       | 20                               | —                                | ns                      |
| Delay Time, Enable positive transition to CB2 positive transition<br>(Figure 6)                                                                                                   |                                                                             | $t_{RS1}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Rise and Fall Time for CB1 and CB2 input signals (Figure 7)                                                                                                                       |                                                                             | $t_{rf}$                                                                                       | —                                | —                                | $\mu\text{s}$           |
| Delay Time, CB1 active transition to CB2 positive transition<br>(Figure 7)                                                                                                        |                                                                             | $t_{RS2}$                                                                                      | —                                | —                                | $\mu\text{s}$           |
| Interrupt Release Time, IRQA and IRQB (Figure 8)                                                                                                                                  |                                                                             | $t_{IR}$                                                                                       | —                                | —                                | 1.6                     |
| Reset Low Time* (Figure 9)                                                                                                                                                        |                                                                             | $t_{RL}$                                                                                       | 2.0                              | —                                | —                       |

\*The Reset line must be high a minimum of 1.0  $\mu\text{s}$  before addressing the PIA.



MOTOROLA Semiconductor Products Inc.

## MC6820

## MAXIMUM RATINGS

| Rating                      | Symbol           | Value        | Unit            |
|-----------------------------|------------------|--------------|-----------------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | V <sub>dc</sub> |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | V <sub>dc</sub> |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C              |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C              |
| Thermal Resistance          | θ <sub>JA</sub>  | 82.5         | °C/W            |

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.

## BUS TIMING CHARACTERISTICS

READ (Figures 10 and 12)

| Characteristic                                                  | Symbol                            | Min  | Typ | Max | Unit |
|-----------------------------------------------------------------|-----------------------------------|------|-----|-----|------|
| Enable Cycle Time                                               | t <sub>cycE</sub>                 | 1.0  | —   | —   | μs   |
| Enable Pulse Width, High                                        | PW <sub>EH</sub>                  | 0.45 | —   | 25  | μs   |
| Enable Pulse Width, Low                                         | PW <sub>EL</sub>                  | 0.43 | —   | —   | μs   |
| Setup Time, Address and R/W valid to Enable positive transition | t <sub>AS</sub>                   | 160  | —   | —   | ns   |
| Data Delay Time                                                 | t <sub>DDR</sub>                  | —    | —   | 320 | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                    | 10   | —   | —   | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                   | 10   | —   | —   | ns   |
| Rise and Fall Time for Enable input                             | t <sub>Er</sub> , t <sub>Ef</sub> | —    | —   | 25  | ns   |

WRITE (Figures 11 and 12)

| Characteristic                                                  | Symbol                            | Min  | Typ | Max | Unit |
|-----------------------------------------------------------------|-----------------------------------|------|-----|-----|------|
| Enable Cycle Time                                               | t <sub>cycE</sub>                 | 1.0  | —   | —   | μs   |
| Enable Pulse Width, High                                        | PW <sub>EH</sub>                  | 0.45 | —   | 25  | μs   |
| Enable Pulse Width, Low                                         | PW <sub>EL</sub>                  | 0.43 | —   | —   | μs   |
| Setup Time, Address and R/W valid to Enable positive transition | t <sub>AS</sub>                   | 160  | —   | —   | ns   |
| Data Setup Time                                                 | t <sub>DSW</sub>                  | 195  | —   | —   | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                    | 10   | —   | —   | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                   | 10   | —   | —   | ns   |
| Rise and Fall Time for Enable input                             | t <sub>Er</sub> , t <sub>Ef</sub> | —    | —   | 25  | ns   |

FIGURE 1 – PERIPHERAL DATA SETUP TIME  
(Read Mode)FIGURE 2 – CA2 DELAY TIME  
(Read Mode; CRA-5 = CRA-3 = 1, CRA-4 = 0)FIGURE 3 – CA2 DELAY TIME  
(Read Mode; CRA-5 = 1, CRA-3 = CRA-4 = 0)

MOTOROLA Semiconductor Products Inc.

**FIGURE 4 – PERIPHERAL CMOS DATA DELAY TIMES**  
(Write Mode; CRA-5 = CRA-3 = 1, CRA-4 = 0)



**FIGURE 5 – PERIPHERAL DATA AND CB2 DELAY TIMES**  
(Write Mode; CRB-5 = CRB-3 = 1, CRB-4 = 0)



**FIGURE 6 – CB2 DELAY TIME**  
(Write Mode; CRB-5 = CRB-3 = 1, CRB-4 = 0)



**FIGURE 7 – CB2 DELAY TIME**  
(Write Mode; CRB-5 = 1, CRB-3 = CRB-4 = 0)



**FIGURE 8 – TRQ RELEASE TIME**



**FIGURE 9 – RESET LOW TIME**



**FIGURE 10 – BUS READ TIMING CHARACTERISTICS**  
(Read Information from PIA)



**FIGURE 11 – BUS WRITE TIMING CHARACTERISTICS**  
(Write Information into PIA)



MOTOROLA Semiconductor Products Inc.

## MC6850

## MAXIMUM RATINGS

| Rating                      | Symbol           | Value        | Unit |
|-----------------------------|------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C   |
| Thermal Resistance          | θ <sub>JA</sub>  | 82.5         | °C/W |

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.

ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V ±5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to 70°C unless otherwise noted.)

| Characteristic                                                                                                                                    | Symbol                        | Min                                            | Typ       | Max                   | Unit  |
|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------------------------------------------|-----------|-----------------------|-------|
| Input High Voltage                                                                                                                                | V <sub>IH</sub>               | V <sub>SS</sub> + 2.0                          | —         | V <sub>CC</sub>       | Vdc   |
| Input Low Voltage                                                                                                                                 | V <sub>IL</sub>               | V <sub>SS</sub> - 0.3                          | —         | V <sub>SS</sub> + 0.8 | Vdc   |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 Vdc)                                                                                        | I <sub>in</sub>               | —                                              | 1.0       | 2.5                   | μA/dc |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 Vdc)                                                                       | I <sub>TSI</sub>              | —                                              | 2.0       | 10                    | μA/dc |
| Output High Voltage<br>(I <sub>Load</sub> = ~205 μA/dc, Enable Pulse Width <25 μs)<br>(I <sub>Load</sub> = ~100 μA/dc, Enable Pulse Width <25 μs) | V <sub>OH</sub>               | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | —<br>—    | —<br>—                | Vdc   |
| Output Low Voltage<br>(I <sub>Load</sub> = 1.6 mA/dc, Enable Pulse Width <25 μs)                                                                  | V <sub>OL</sub>               | —                                              | —         | V <sub>SS</sub> + 0.4 | Vdc   |
| Output Leakage Current (Off State)<br>(V <sub>OH</sub> = 2.4 Vdc)                                                                                 | I <sub>LOH</sub>              | —                                              | 1.0       | 10                    | μA/dc |
| Power Dissipation                                                                                                                                 | P <sub>D</sub>                | —                                              | 300       | 525                   | mW    |
| Input Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)<br>E, Tx Clk, Rx Clk, R/W, RS, Rx Data, CS0, CS1, CS2, CTS, DCD    | C <sub>in</sub>               | —<br>—                                         | 10<br>7.0 | 12.5<br>7.5           | PF    |
| Output Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                   | C <sub>out</sub>              | —<br>—                                         | —<br>—    | 10<br>5.0             | PF    |
| Minimum Clock Pulse Width, Low (Figure 1)                                                                                                         | ±16, ±64 Modes                | PW <sub>CL</sub>                               | 600       | —                     | ns    |
| Minimum Clock Pulse Width, High (Figure 2)                                                                                                        | ±16, ±64 Modes                | PW <sub>CH</sub>                               | 600       | —                     | ns    |
| Clock Frequency                                                                                                                                   | ÷1 Mode<br>÷16, ±64 Modes     | f <sub>C</sub>                                 | —<br>—    | 500<br>800            | kHz   |
| Clock-to-Data Delay for Transmitter (Figure 3)                                                                                                    | t <sub>TDD</sub>              | —                                              | —         | 1.0                   | μs    |
| Receive Data Setup Time (Figure 4)                                                                                                                | ÷1 Mode                       | t <sub>RDSU</sub>                              | 500       | —                     | ns    |
| Receive Data Hold Time (Figure 5)                                                                                                                 | ÷1 Mode                       | t <sub>RDH</sub>                               | 500       | —                     | ns    |
| Interrupt Request Release Time (Figure 6)                                                                                                         | t <sub>IR</sub>               | —                                              | —         | 1.2                   | μs    |
| Request-to-Send Delay Time (Figure 6)                                                                                                             | t <sub>RTS</sub>              | —                                              | —         | 1.0                   | μs    |
| Input Transition Times (Except Enable)                                                                                                            | t <sub>r, t<sub>f</sub></sub> | —                                              | —         | 1.0*                  | μs    |

\*1.0 μs or 10% of the pulse width, whichever is smaller.

## BUS TIMING CHARACTERISTICS

## READ (Figures 7 and 9)

| Characteristic                                                  | Symbol                                     | Min  | Typ | Max | Unit |
|-----------------------------------------------------------------|--------------------------------------------|------|-----|-----|------|
| Enable Cycle Time                                               | t <sub>cycE</sub>                          | 1.0  | —   | —   | μs   |
| Enable Pulse Width, High                                        | PWEH                                       | 0.45 | —   | 25  | μs   |
| Enable Pulse Width, Low                                         | PWEL                                       | 0.43 | —   | —   | μs   |
| Setup Time, Address and R/W valid to Enable positive transition | t <sub>AS</sub>                            | 160  | —   | —   | ns   |
| Data Delay Time                                                 | t <sub>DDR</sub>                           | —    | —   | 320 | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                             | 10   | —   | —   | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                            | 10   | —   | —   | ns   |
| Rise and Fall Time for Enable input                             | t <sub>Er, t<subef< sub=""></subef<></sub> | —    | —   | 25  | ns   |

## WRITE (Figure 8 and 9)

| Characteristic                                                  | Symbol                                     | Min  | Typ | Max | Unit |
|-----------------------------------------------------------------|--------------------------------------------|------|-----|-----|------|
| Enable Cycle Time                                               | t <sub>cycE</sub>                          | 1.0  | —   | —   | μs   |
| Enable Pulse Width, High                                        | PWEH                                       | 0.45 | —   | 25  | μs   |
| Enable Pulse Width, Low                                         | PWEL                                       | 0.43 | —   | —   | μs   |
| Setup Time, Address and R/W valid to Enable positive transition | t <sub>AS</sub>                            | 160  | —   | —   | ns   |
| Data Setup Time                                                 | t <sub>DSW</sub>                           | 195  | —   | —   | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                             | 10   | —   | —   | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                            | 10   | —   | —   | ns   |
| Rise and Fall Time for Enable input                             | t <sub>Er, t<subef< sub=""></subef<></sub> | —    | —   | 25  | ns   |



MOTOROLA Semiconductor Products Inc.

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  
( $\pm 1$  Mode)FIGURE 5 – RECEIVE DATA HOLD TIME  
( $\pm 1$  Mode)FIGURE 6 – REQUEST-TO-SEND DELAY AND  
INTERRUPT-REQUEST RELEASE TIMESFIGURE 7 – BUS READ TIMING CHARACTERISTICS  
(Read information from ACIA)FIGURE 8 – BUS WRITE TIMING CHARACTERISTICS  
(Write information into ACIA)

MOTOROLA Semiconductor Products Inc.

## MAXIMUM RATINGS

| Rating                      | Symbol           | Value        | Unit |
|-----------------------------|------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C   |
| Thermal Resistance          | θ <sub>JA</sub>  | 70           | °C/W |

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.

ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V ±5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to 70°C unless otherwise noted.)

| Characteristic                                                                                                                                      | Symbol                          | Min                   | Typ | Max                   | Unit  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-----------------------|-----|-----------------------|-------|
| Input High Voltage                                                                                                                                  | V <sub>IH</sub>                 | V <sub>SS</sub> + 2.0 | —   | —                     | Vdc   |
| Input Low Voltage                                                                                                                                   | V <sub>IL</sub>                 | —                     | —   | V <sub>SS</sub> + 0.8 | Vdc   |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 Vdc)<br>Tx Clk, Rx Clk, Rx Data, Enable,<br>Reset, RS, R/W, CS, DCD, CTS                      | I <sub>in</sub>                 | —                     | 1.0 | 2.5                   | μA/dc |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 Vdc, V <sub>CC</sub> = 5.25 Vdc)                                             | I <sub>TSI</sub>                | —                     | 2.0 | 10                    | μA/dc |
| Output High Voltage<br>(I <sub>Load</sub> = -205 μA/dc, Enable Pulse Width < 25 μs)<br>(I <sub>Load</sub> = -100 μA/dc, Enable Pulse Width < 25 μs) | V <sub>OH</sub>                 | V <sub>SS</sub> + 2.4 | —   | —                     | Vdc   |
| Output Low Voltage<br>(I <sub>Load</sub> = 1.6 mA/dc, Enable Pulse Width < 25 μs)                                                                   | V <sub>OL</sub>                 | —                     | —   | V <sub>SS</sub> + 0.4 | Vdc   |
| Output Leakage Current (Off State)<br>(V <sub>OH</sub> = 2.4 Vdc)                                                                                   | I <sub>LOH</sub>                | —                     | 1.0 | 10                    | μA/dc |
| Power Dissipation                                                                                                                                   | P <sub>D</sub>                  | —                     | 300 | 525                   | mW    |
| Input Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                      | C <sub>in</sub>                 | —                     | —   | 12.5                  | pF    |
| All Other Inputs                                                                                                                                    |                                 | —                     | —   | 7.5                   |       |
| Output Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                     | C <sub>out</sub>                | —                     | —   | 10                    | pF    |
| Minimum Clock Pulse Width, Low (Figure 1)                                                                                                           | PW <sub>CL</sub>                | 700                   | —   | —                     | ns    |
| Minimum Clock Pulse Width, High (Figure 2)                                                                                                          | PW <sub>CH</sub>                | 700                   | —   | —                     | ns    |
| Clock Frequency                                                                                                                                     | f <sub>C</sub>                  | —                     | —   | 600                   | kHz   |
| Receive Data Setup Time (Figure 3, 7)                                                                                                               | t <sub>RDSU</sub>               | 350                   | —   | —                     | ns    |
| Receive Data Hold Time (Figure 3)                                                                                                                   | t <sub>RDH</sub>                | 350                   | —   | —                     | ns    |
| Sync Match Delay Time (Figure 3)                                                                                                                    | t <sub>SM</sub>                 | —                     | —   | 1.0                   | μs    |
| Clock-to-Data Delay for Transmitter (Figure 4)                                                                                                      | t <sub>TDD</sub>                | —                     | —   | 1.0                   | μs    |
| Transmitter Underflow (Figure 4,6)                                                                                                                  | t <sub>TUF</sub>                | —                     | —   | 1.0                   | μs    |
| DTT Delay Time (Figure 5)                                                                                                                           | t <sub>DTR</sub>                | —                     | —   | 1.0                   | μs    |
| Interrupt Request Release Time (Figure 5)                                                                                                           | t <sub>IR</sub>                 | —                     | —   | 1.2                   | μs    |
| Reset Minimum Pulse Width                                                                                                                           | t <sub>Res</sub>                | 1.0                   | —   | —                     | μs    |
| CTS Setup Time (Figure 6)                                                                                                                           | t <sub>CTS</sub>                | —                     | —   | 200                   | ns    |
| DCD Setup Time (Figure 7)                                                                                                                           | t <sub>DCD</sub>                | —                     | —   | 500                   | ns    |
| Input Rise and Fall Times (except Enable)<br>(0.8 V to 2.0 V)                                                                                       | t <sub>r</sub> , t <sub>f</sub> | —                     | —   | 1.0*                  | μs    |

\*1.0 μs or 10% of the pulse width, whichever is smaller.

FIGURE 1 – CLOCK PULSE WIDTH, LOW-STATE



FIGURE 2 – CLOCK PULSE WIDTH, HIGH-STATE



MOTOROLA Semiconductor Products Inc.

**BUS TIMING CHARACTERISTICS**

READ (Figures 8 and 10)

| Characteristic                                                  | Symbol           | Min  | Typ | Max | Unit    |
|-----------------------------------------------------------------|------------------|------|-----|-----|---------|
| Enable Cycle Time                                               | $t_{cycE}$       | 1.0  | —   | —   | $\mu s$ |
| Enable Pulse Width, High                                        | $PW_{EH}$        | 0.45 | —   | 25  | $\mu s$ |
| Enable Pulse Width, Low                                         | $PW_{EL}$        | 0.43 | —   | —   | $\mu s$ |
| Setup Time, Address and R/W valid to Enable positive transition | $t_{AS}$         | 160  | —   | —   | ns      |
| Data Delay Time                                                 | $t_{DDR}$        | —    | —   | 320 | ns      |
| Data Hold Time                                                  | $t_H$            | 10   | —   | —   | ns      |
| Address Hold Time                                               | $t_{AH}$         | 10   | —   | —   | ns      |
| Rise and Fall Time for Enable input                             | $t_{Er}, t_{Ef}$ | —    | —   | 25  | ns      |

WRITE (Figures 9 and 10)

|                                                                 |                  |      |   |    |         |
|-----------------------------------------------------------------|------------------|------|---|----|---------|
| Enable Cycle Time                                               | $t_{cycE}$       | 1.0  | — | —  | $\mu s$ |
| Enable Pulse Width, High                                        | $PW_{EH}$        | 0.45 | — | 25 | $\mu s$ |
| Enable Pulse Width, Low                                         | $PW_{EL}$        | 0.43 | — | —  | $\mu s$ |
| Setup Time, Address and R/W valid to Enable positive transition | $t_{AS}$         | 160  | — | —  | ns      |
| Data Setup Time                                                 | $t_{DSW}$        | 195  | — | —  | ns      |
| Data Hold Time                                                  | $t_H$            | 10   | — | —  | ns      |
| Address Hold Time                                               | $t_{AH}$         | 10   | — | —  | ns      |
| Rise and Fall Time for Enable input                             | $t_{Er}, t_{Ef}$ | —    | — | 25 | ns      |

FIGURE 3 – RECEIVE DATA SETUP AND HOLD TIMES AND SYNC MATCH DELAY TIME



FIGURE 4 – TRANSMIT DATA OUTPUT DELAY AND TRANSMITTER UNDERFLOW DELAY TIME



FIGURE 5 – DATA TERMINAL READY AND INTERRUPT REQUEST RELEASE TIMES



MOTOROLA Semiconductor Products Inc.

FIGURE 6 - CLEAR-TO-SEND SETUP TIME

FIGURE 8 - BUS READ TIMING CHARACTERISTICS  
(Read information from SSDA)

FIGURE 7 - DATA CARRIER DETECT SETUP TIME

FIGURE 9 - BUS WRITE TIMING CHARACTERISTICS  
(Write information into SSDA)

FIGURE 10 - BUS TIMING TEST LOADS



MOTOROLA Semiconductor Products Inc.

## MAXIMUM RATINGS

| Rating                      | Symbol           | Value        | Unit |
|-----------------------------|------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C   |
| Thermal Resistance          | θ <sub>JA</sub>  | 82.5         | °C/W |

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.

ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to 70°C unless otherwise noted)

| Characteristic                                                                        | Symbol           | Min                                          | Typ    | Max                                          | Unit |      |
|---------------------------------------------------------------------------------------|------------------|----------------------------------------------|--------|----------------------------------------------|------|------|
| Input High Voltage                                                                    | V <sub>IH</sub>  | V <sub>SS</sub> +2.0                         | —      | V <sub>CC</sub>                              | Vdc  |      |
| Input Low Voltage                                                                     | V <sub>IL</sub>  | V <sub>SS</sub> -0.3                         | —      | V <sub>SS</sub> +0.8                         |      |      |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 V)                              | I <sub>in</sub>  | —                                            | 1.0    | 2.5                                          | μAdc |      |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 V)             | I <sub>TSI</sub> | —                                            | 2.0    | 10                                           | μAdc |      |
| Output High Voltage<br>(I <sub>load</sub> = -205 μA)<br>(I <sub>load</sub> = -200 μA) | V <sub>OH</sub>  | V <sub>SS</sub> +2.4<br>V <sub>SS</sub> +2.4 | —<br>— | —<br>—                                       | Vdc  |      |
| Output Low Voltage<br>(I <sub>load</sub> = 1.6 mA)<br>(I <sub>load</sub> = 3.2 mA)    | V <sub>OL</sub>  | —<br>—                                       | —<br>— | V <sub>SS</sub> +0.4<br>V <sub>SS</sub> +0.4 | Vdc  |      |
| Output Leakage Current (Off State)<br>(V <sub>OH</sub> = 2.4 Vdc)                     | IRQ              | I <sub>LOH</sub>                             | —      | 1.0                                          | 10   | μAdc |
| Power Dissipation                                                                     | P <sub>D</sub>   | —                                            | —      | 550                                          | mW   |      |
| Input Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)        | C <sub>in</sub>  | —<br>—                                       | —<br>— | 12.5<br>7.5                                  | pF   |      |
| Output Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)       | C <sub>out</sub> | —<br>—                                       | —<br>— | 5.0<br>10                                    | pF   |      |

## BUS TIMING CHARACTERISTICS

| Characteristic                                                  | Symbol                            | Min  | Max | Unit |
|-----------------------------------------------------------------|-----------------------------------|------|-----|------|
| <b>READ (See Figures 2 and 8)</b>                               |                                   |      |     |      |
| Enable Cycle Time                                               | t <sub>cycE</sub>                 | 1.0  | 10  | μs   |
| Enable Pulse Width, High                                        | PWEH                              | 0.45 | 4.5 | μs   |
| Enable Pulse Width, Low                                         | PWEL                              | 0.43 | —   | μs   |
| Setup Time, Address and R/W valid to enable positive transition | t <sub>AS</sub>                   | 160  | —   | ns   |
| Data Delay Time                                                 | t <sub>DDR</sub>                  | —    | 320 | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                    | 10   | —   | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                   | 10   | —   | ns   |
| Rise and Fall Time for Enable input                             | t <sub>Er</sub> , t <sub>Ef</sub> | —    | 25  | ns   |
| <b>WRITE (See Figures 3 and 8)</b>                              |                                   |      |     |      |
| Enable Cycle Time                                               | t <sub>cycE</sub>                 | 1.0  | 10  | μs   |
| Enable Pulse Width, High                                        | PWEH                              | 0.45 | 4.5 | μs   |
| Enable Pulse Width, Low                                         | PWEL                              | 0.43 | —   | μs   |
| Setup Time, Address and R/W valid to enable positive transition | t <sub>AS</sub>                   | 160  | —   | ns   |
| Data Setup Time                                                 | t <sub>DSW</sub>                  | 195  | —   | ns   |
| Data Hold Time                                                  | t <sub>H</sub>                    | 10   | —   | ns   |
| Address Hold Time                                               | t <sub>AH</sub>                   | 10   | —   | ns   |
| Rise and Fall Time for Enable input                             | t <sub>Er</sub> , t <sub>Ef</sub> | —    | 25  | ns   |



MOTOROLA Semiconductor Products Inc.

## AC OPERATING CHARACTERISTICS

| Characteristic                                                                                                                             | Symbol             | Min                                | Max         | Unit                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------|-------------|------------------------------------------|
| Input Rise and Fall Times<br>$\overline{C_1 - C_3}$ and Reset                                                                              | $t_{rf}$           | —                                  | 1.0*        | $\mu s$                                  |
| Input Pulse Width Low (Figure 4)<br>$\overline{C_1 - C_3}$ and Reset                                                                       | $PW_L$             | $t_{cycE} + t_{su} + t_{hd}$       | —           | ns                                       |
| Input Pulse Width High (Figure 5)<br>$C_1, G_1$                                                                                            | $PW_H$             | $t_{cycE} + t_{su} + t_{hd}$       | —           | ns                                       |
| Input Setup Time (Figure 6)<br>(Synchronous Mode)<br>$\overline{C_3}$ ( $\div 8$ Prescaler Mode only)                                      | $t_{su}$           | 200                                | —           | ns                                       |
| Input Hold Time (Figure 6)<br>(Synchronous Mode)<br>$\overline{C_3}$ ( $\div 8$ Prescaler Mode only)                                       | $t_{hd}$           | 50                                 | —           | ns                                       |
| Output Delay, O1—O3 (Figure 7)<br>( $V_{OH} = 2.4$ V, Load A)<br>( $V_{OH} = 2.4$ V, Load C)<br>( $V_{OH} = 0.7$ V <sub>DD</sub> , Load C) | TTL<br>MOS<br>CMOS | $t_{co}$<br>$t_{cm}$<br>$t_{cmos}$ | —<br>—<br>— | 700<br>450<br>2.0<br>ns<br>ns<br>$\mu s$ |
| Interrupt Release Time                                                                                                                     | $t_{IR}$           | —                                  | 1.6         | $\mu s$                                  |

\* $t_r$  and  $t_f \leq 1 \times$  Pulse Width or 1.0  $\mu s$ , whichever is smaller.

FIGURE 2 — BUS READ TIMING CHARACTERISTICS  
(Read Information from PTM)



FIGURE 3 — BUS WRITE TIMING CHARACTERISTICS  
(Write Information into PTM)



FIGURE 4 — INPUT PULSE WIDTH LOW



FIGURE 5 — INPUT PULSE WIDTH HIGH



MOTOROLA Semiconductor Products Inc.

**FIGURE 6 – INPUT SETUP AND HOLD TIMES**



**FIGURE 7 – OUTPUT DELAY**



**FIGURE 8 –  $\overline{IRQ}$  RELEASE TIME**



**FIGURE 9 – BUS TIMING TEST LOADS**



**MOTOROLA Semiconductor Products Inc.**

**MAXIMUM RATINGS**

| Rating                      | Symbol            | Value        | Unit |
|-----------------------------|-------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub> * | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub> * | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>    | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub>  | -55 to +150  | °C   |
| Thermal Resistance          | R <sub>θJA</sub>  | 82.5         | °C/W |

\* In respect to V<sub>SS</sub>.

Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to RECOMMENDED OPERATING CONDITIONS. Exposure to higher than recommended voltages for extended periods of time could affect device reliability.

**RECOMMENDED OPERATING CONDITIONS**

| Rating                              | Symbol                             | Value                                  | Unit |
|-------------------------------------|------------------------------------|----------------------------------------|------|
| Power Supply Voltage                | V <sub>CC</sub>                    | +4.75 to +5.25                         | Vdc  |
| Input Voltage                       | V <sub>IL</sub><br>V <sub>IH</sub> | -0.3 to +0.8<br>2.0 to V <sub>CC</sub> | Vdc  |
| Operating Ambient Temperature Range | T <sub>A</sub>                     | 0 to +70                               | °C   |

**ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = -20 to +75°C unless otherwise noted)**

| Characteristic                                                        | Symbol           | Min                  | Typ | Max                  | Unit |
|-----------------------------------------------------------------------|------------------|----------------------|-----|----------------------|------|
| Input High Voltage                                                    | V <sub>IH</sub>  | V <sub>SS</sub> +2.0 | —   | V <sub>CC</sub>      | Vdc  |
| Input Low Voltage                                                     | V <sub>IL</sub>  | V <sub>SS</sub> -0.3 | —   | V <sub>SS</sub> +0.8 | Vdc  |
| Input Leakage Current (V <sub>in</sub> = 0 to 5.25 V)                 | I <sub>in</sub>  | —                    | —   | 2.5                  | μAdc |
| Three-State Leakage Current (V <sub>in</sub> = 0.4 to 2.4 V)          | I <sub>TSI</sub> | -10                  | —   | 10                   | μAdc |
| Output High Voltage (I <sub>Load</sub> = -205 μAdc)                   | V <sub>OH</sub>  | V <sub>SS</sub> +2.4 | —   | —                    | Vdc  |
| (I <sub>Load</sub> = -145 μAdc)                                       | D0-D7            | V <sub>SS</sub> +2.4 | —   | —                    |      |
| (I <sub>Load</sub> = -100 μAdc)                                       | A0-15, R/W       | V <sub>SS</sub> +2.4 | —   | —                    |      |
| All Others                                                            | —                | —                    | —   | —                    |      |
| Output Low Voltage (I <sub>Load</sub> = 1.6 mA)                       | V <sub>OL</sub>  | —                    | —   | V <sub>SS</sub> +0.4 | Vdc  |
| Source Current (V <sub>in</sub> = 0 Vdc, Figure 10)                   | I <sub>CSS</sub> | —                    | 10  | —                    | —    |
| Power Dissipation                                                     | P <sub>D</sub>   | —                    | 500 | —                    | mW   |
| Capacitance (V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz) | C <sub>in</sub>  | —                    | —   | 20                   | pF   |
| D0-D7, φ2 DMA, A0-A4, R/W                                             | —                | —                    | —   | 12.5                 |      |
| All Others                                                            | —                | —                    | —   | 10                   |      |
| C <sub>out</sub>                                                      | —                | —                    | —   | 12                   | pF   |

**MOTOROLA Semiconductor Products Inc.**

**BUS TIMING CHARACTERISTICS** (Load Condition Figure 11)

| Characteristic                |                | Symbol           | Min | Max | Unit |
|-------------------------------|----------------|------------------|-----|-----|------|
| <b>READ TIMING (Figure 4)</b> |                |                  |     |     |      |
| Address Setup Time            | A0-A4, R/W, CS | t <sub>AS</sub>  | 160 | —   | ns   |
| Address Input Hold Time       | A0-A4, R/W, CS | t <sub>AHI</sub> | 10  | —   | ns   |
| Data Delay Time               | D0-D7          | t <sub>DDR</sub> | —   | 320 | ns   |
| Data Access Time              | D0-D7          | t <sub>ACC</sub> | —   | 480 | ns   |
| Data Output Hold Time         | D0-D7          | t <sub>DHR</sub> | 10  | —   | ns   |

**WRITE TIMING (Figure 4)**

|                         |                |                  |     |   |    |
|-------------------------|----------------|------------------|-----|---|----|
| Address Setup Time      | A0-A4, R/W, CS | t <sub>AS</sub>  | 160 | — | ns |
| Address Input Hold Time | A0-A4, R/W, CS | t <sub>AHI</sub> | 10  | — | ns |
| Data Setup Time         | D0-D7          | t <sub>DSW</sub> | 195 | — | ns |
| Data Input Hold Time    | D0-D7          | t <sub>DHW</sub> | 10  | — | ns |

**CLOCK TIMING**

| Characteristic               |  | Symbol                          | Min  | Max | Unit |
|------------------------------|--|---------------------------------|------|-----|------|
| <b>φ2 DMA (See Figure 4)</b> |  |                                 |      |     |      |
| Cycle Time                   |  | t <sub>cyc</sub>                | 1000 | —   | ns   |
| Pulse Width—High             |  | PW <sub>H</sub>                 | 450  | —   | ns   |
| Low                          |  | PW <sub>L</sub>                 | 430  | —   | ns   |
| Rise and Fall Time           |  | t <sub>φr, t<sub>φf</sub></sub> | —    | 25  | ns   |

**DMA TIMING (Load Condition Figure 11)**

|                                                                                        |  |                                        |            |            |    |
|----------------------------------------------------------------------------------------|--|----------------------------------------|------------|------------|----|
| Tx RQ Setup Time (Figure 5)<br>φ2 DMA Rising Edge<br>φ2 DMA Falling Edge               |  | t <sub>TQS1</sub><br>t <sub>TQS2</sub> | 120<br>210 | —          | ns |
| Tx RQ Hold Time (Figure 5)<br>φ2 DMA Rising Edge<br>φ2 DMA Falling Edge                |  | t <sub>TQH1</sub><br>t <sub>TQH2</sub> | 20<br>20   | —          | ns |
| DGRNT Setup Time (Figure 6)                                                            |  | t <sub>DGS</sub>                       | 155        | —          | ns |
| DGRNT Hold Time (Figure 6)                                                             |  | t <sub>DGH</sub>                       | 10         | —          | ns |
| Address Output Delay Time (Figure 15) A0-A15, R/W, Tx STB                              |  | t <sub>AD</sub>                        | —          | 270        | ns |
| Address Output Hold Time (Figure 15) A0-15, R/W<br>Tx STB                              |  | t <sub>AHO</sub>                       | 30<br>35   | —          | ns |
| Address Three-State Delay Time (Figure 8) A0-A15, R/W                                  |  | t <sub>ATSD</sub>                      | —          | 700        | ns |
| Address Three-State Recovery Time (Figure 8)                                           |  | t <sub>ATSR</sub>                      | —          | 400        | ns |
| Delay Time (Figure 7) DRQH, DRQT                                                       |  | t <sub>DQD</sub>                       | —          | 375        | ns |
| Tx AK Delay Time<br>φ2 DMA Rising Edge (Figure 7)<br>DGRNT Rising Edge (Figure 10)     |  | t <sub>TKD1</sub><br>t <sub>TKD2</sub> | —<br>—     | 400<br>190 | ns |
| IRQ/DEND Delay Time<br>φ2 DMA Falling Edge (Figure 8)<br>DGRNT Rising Edge (Figure 10) |  | t <sub>DED1</sub><br>t <sub>DED2</sub> | —<br>—     | 300<br>190 | ns |



MOTOROLA Semiconductor Products Inc.

**FIGURE 4 – READ/WRITE OPERATION SEQUENCE****FIGURE 5 – Tx RQ INPUT TIMING****FIGURE 6 – DGRNT INPUT TIMING****FIGURE 7 – DRQH, DRQT, Tx AK OUTPUT TIMING****FIGURE 8 – ADDRESS, IRQ/DEND OUTPUT TIMING****FIGURE 9 – ADDRESS THREE-STATE TIMING****FIGURE 10 – Tx AKB, IRQ/DEND OUTPUT TIMING FROM DGRNT INPUT****MOTOROLA Semiconductor Products Inc.**

FIGURE 11 - TEST LOADS



| Test Pin    | C = pF | R = kΩ |
|-------------|--------|--------|
| D0-D7       | 130    | 11.7   |
| A0-A15, R/W | 90     | 16.5   |
| CS/Tx AKB   | 50     | 24     |
| Others      | 30     | 24     |

FIGURE 12 - CS/Tx AKB  
SOURCE CURRENT TEST CIRCUIT

**MAXIMUM RATINGS**

| Rating                      | Symbol           | Value        | Unit |
|-----------------------------|------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C   |
| Thermal Resistance          | θ <sub>JA</sub>  | 70           | °C/W |

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.

**ELECTRICAL CHARACTERISTICS** (V<sub>CC</sub> = 5.0 V ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to 70°C unless otherwise noted.)

| Characteristic                                                                              | Symbol            | Min                                            | Typ              | Max                                            | Unit  |
|---------------------------------------------------------------------------------------------|-------------------|------------------------------------------------|------------------|------------------------------------------------|-------|
| Input High Voltage<br>All Inputs                                                            | V <sub>IH</sub>   | V <sub>SS</sub> + 2.0                          | —                | V <sub>CC</sub>                                | Vdc   |
| Input Low Voltage<br>All Inputs                                                             | V <sub>IL</sub>   | V <sub>SS</sub> - 0.3                          | —                | V <sub>SS</sub> + 0.8                          | Vdc   |
| Clock Overshoot/Ubershoot — Input High Level<br>— Input Low Level                           | V <sub>OS</sub>   | V <sub>CC</sub> - 0.5<br>V <sub>SS</sub> - 0.5 | —                | V <sub>CC</sub> + 0.5<br>V <sub>SS</sub> + 0.5 | Vdc   |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 Vdc)                                  | I <sub>in</sub>   | —                                              | 1.0              | 2.5                                            | μA/dc |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> 0.4 to 2.4 Vdc)                   | I <sub>TSI</sub>  | —                                              | 2.0              | 10                                             | μA/dc |
| Output High Voltage<br>(I <sub>Load</sub> = -205 μA/dc)<br>(I <sub>Load</sub> = -200 μA/dc) | V <sub>OH</sub>   | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | —                | —                                              | Vdc   |
| Output Low Voltage<br>(I <sub>Load</sub> = 1.6 mA/dc)<br>(I <sub>Load</sub> = 3.2 mA/dc)    | V <sub>OL</sub>   | —                                              | —                | V <sub>SS</sub> + 0.4<br>V <sub>SS</sub> + 0.4 | Vdc   |
| Output High Current (Sourcing)<br>(V <sub>OH</sub> = 2.4 Vdc)                               | I <sub>OH</sub>   | -205<br>-200                                   | —                | —                                              | μA/dc |
| Output Low Current (Sinking)<br>(V <sub>OL</sub> = 0.4 Vdc)                                 | I <sub>OL</sub>   | 1.6<br>3.2                                     | —                | —                                              | mA/dc |
| Output Leakage Current (Off State)<br>(V <sub>OH</sub> = 2.4 Vdc)                           | I <sub>LOH</sub>  | —                                              | —                | 10                                             | μA/dc |
| Power Dissipation                                                                           | P <sub>D</sub>    | —                                              | —                | 1000                                           | mW    |
| Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                    | C <sub>in</sub>   | —<br>—<br>—<br>—                               | —<br>—<br>—<br>— | 20<br>12.5<br>10<br>7.5                        | pF    |
|                                                                                             |                   |                                                |                  |                                                |       |
|                                                                                             | C <sub>out</sub>  |                                                | —<br>—           | 5.0<br>10                                      | pF    |
| Frequency of Operation                                                                      | f                 | 0.1                                            | —                | 1.0                                            | MHz   |
| Clock Timing                                                                                | t <sub>cycE</sub> | 1.0                                            | —                | —                                              | μs    |
| Cycle Time                                                                                  | t <sub>RL</sub>   | 2                                              | —                | —                                              | μs    |
| Reset Low Time                                                                              | t <sub>IR</sub>   | —                                              | —                | 1.6                                            | μs    |
| Interrupt Release                                                                           |                   |                                                |                  |                                                |       |



MOTOROLA Semiconductor Products Inc.

# MC6846

## READ/WRITE TIMING (Figures 3 and 4).

| Characteristic                      | Symbol   | Min | Typ | Max | Unit |
|-------------------------------------|----------|-----|-----|-----|------|
| Enable Pulse Width, Low             | PWEL     | 430 | —   | —   | ns   |
| Enable Pulse Width, High            | PWEH     | 430 | —   | —   | ns   |
| Set Up Time (Address CS0, CS1, R/W) | tAS      | 160 | —   | —   | ns   |
| Data Delay Time                     | tDDR     | —   | —   | 320 | ns   |
| Data Hold Time                      | tH       | 10  | —   | —   | ns   |
| Address Hold Time                   | tAH      | 10  | —   | —   | ns   |
| Rise and Fall Time                  | tEf, tEr | —   | —   | 25  | ns   |
| Data Set Up Time                    | tDSW     | 195 | —   | —   | ns   |

## BUS TIMING

### Peripheral I/O Lines

| Characteristic                       | Symbol   | Min | Typ | Max | Unit |
|--------------------------------------|----------|-----|-----|-----|------|
| Peripheral Data Setup                | tPDSU    | 200 | —   | —   | ns   |
| Rise and Fall Times CP1, CP2         | tPr, tPc | —   | —   | 1.0 | μs   |
| Delay Time E to CP2 Fall             | tCP2     | —   | —   | 1.0 | μs   |
| Delay Time I/O Data CP2 Fall         | tDC      | 20  | —   | —   | ns   |
| Delay Time E to CP2 Rise             | tRS1     | —   | —   | 1.0 | μs   |
| Delay Time CP1 to CP2 Rise           | tRS2     | —   | —   | 2.0 | μs   |
| Peripheral Data Delay                | tPDW     | —   | —   | 1.0 | μs   |
| Peripheral Data Setup Time for Latch | tPSU     | 100 | —   | —   | ns   |
| Peripheral Data Hold Time for Latch  | tPDH     | 15  | —   | —   | ns   |

### Timer-Counter Lines

|                                               |                 |                        |   |   |     |    |
|-----------------------------------------------|-----------------|------------------------|---|---|-----|----|
| Input Rise and Fall Time                      | CTC and CTG     | tCR, tCF               | — | — | 100 | ns |
| Input Pulse Width High<br>(Asynchronous Mode) | tPWH            | t <sub>cyc</sub> + 250 | — | — | —   | ns |
| Input Pulse Width Low<br>(Asynchronous Mode)  | tPWL            | t <sub>cyc</sub> + 250 | — | — | —   | ns |
| Input Setup Time<br>(Synchronous Mode)        | t <sub>su</sub> | 200                    | — | — | —   | ns |
| Input Hold Time<br>(Synchronous Mode)         | t <sub>hd</sub> | 50                     | — | — | —   | ns |
| Output Delay                                  | tCTO            | —                      | — | — | 1.0 | μs |

FIGURE 3 – BUS READ TIMING  
Read Information from MC6846



FIGURE 4 – BUS WRITE TIMING  
Write Information from MPU



FIGURE 5 – PERIPHERAL PORT LATCH SETUP AND HOLD TIME



**MOTOROLA** Semiconductor Products Inc.

## Chapter 10

# THE MOS TECHNOLOGY MCS6500

In many ways the MCS6500 microcomputer systems can be compared to the Zilog Z80, which we described in Chapter 7. Just as the Z80 is an enhancement of the 8080A, which is described in Chapter 4, so MOS Technology's products are enhancements of the MC6800, which we described in Chapter 9.

But there are some interesting conceptual differences between the way MOS Technology went about enhancing the MC6800, as compared to the product enhancement philosophy adopted by Zilog.

The Z80 is indeed an enhancement of the 8080A, but only to the extent that the 8080A instruction set is a subset of the Z80 instruction set; there are architectural similarities between the Z80 and the 8080A, but System Bus philosophies are markedly different. It would be hard to look upon the Z80 as simply another member of the 8080A family of microcomputer devices.

The MCS6500 product line, by way of contrast, can be looked upon as a CPU whose philosophical concepts agree closely with the MC6800 product line—without being in any way compatible, either in terms of instruction set or System Bus philosophy. While on the surface it may appear as though MCS6500 CPUs represent some form of an MC6800 superset, this is not the case. System Busses are sufficiently different that you could not consider replacing an MC6800 CPU with an MCS6500 equivalent, leaving other logic unaltered. Instruction sets are similar, but deceptively so. In reality, the instruction sets are sufficiently different that converting an MC6800 source program to its MCS6500 equivalent is no simple task. It would be completely impossible to take an MC6800 program ROM and use it to drive an MCS6500 CPU. Recall that you can take an 8080A program ROM and use it to drive a Z80 CPU.

Since this chapter is devoted to the MOS Technology product line, let us begin by summarizing the components of this product line, and the principal CPU enhancements that have been made.

The MOS Technology devices described in this chapter consist of nine CPUs, plus two support circuits. A third support circuit is described in Chapter 9.

The nine CPUs share the same instruction set and addressing modes, but have minor differences in packaging and system interface. Table 10-1 summarizes the nine CPUs.

The two support circuits which are described in this chapter are the MCS6522 Peripheral Interface Adapter and the MCS6530 combination logic device. Another PIA, the MCS6520 PIA, is identical to the MC6852 PIA; for a description of this device see Chapter 9.

MCS6500 support devices are described in this chapter rather than in Volume 3, because, like the MC6800, the MCS6500 relies on a synchronizing clock signal. While it would be possible to use MCS6500 support devices with other microprocessors, the extra logic needed in order to create MCS6500 compatible bus interfaces would not be sufficiently rewarded by the specific capabilities of the support parts themselves. MCS6500 support devices can be used with MC6800 microprocessors and, conversely, MC6800 support devices can be used with the MCS6500 CPU.

In order to enhance the MC6800 CPU, MOS Technology made a number of useful yet obvious instruction set changes; they also made a number of subjective architectural changes which might have significant impact in particular applications, but which in general result in products that adhere quite closely to MC6800 philosophy.

The most important enhancement that MOS Technology has made is to develop a whole family of CPU devices.

The second most important feature of the MCS6500 line of CPU devices is the fact that the MCS650X series CPUs contain on-chip clock logic; therefore, when using these CPUs, you do not need an MC6870 series clock device. However, you will need an external crystal oscillator or RC network—which is typical of any microprocessor with on-chip clock logic.

Another important feature of all MCS6500 series CPUs is that you cannot float the Address and Data Busses separately during  $\Phi_1$  high and  $\Phi_1$  low clock pulses, and there is no HALT condition. Also, you cannot stretch clock pulses. Slow memories are accommodated in the more traditional manner, by allowing you to insert extra machine cycles, equivalent to 8080A Wait states.

If you are making extensive use of clock stretching, or DMA data transfers during Halt states, in an MC6800 microcomputer system, switching to an MCS6500 CPU will require considerable system redesign.

**In order to refresh dynamic memory in an MCS6500 system, you must "steal" machine cycles by inserting Wait states, as you would for slow memories.**

**MOS Technology, the principal manufacturer of the MCS6500 product line, is located at:**

MOS TECHNOLOGY, INC.  
950 Rittenhouse Road  
Norristown, PA 19401

Second sources are:

SYNERTEK, INC.  
1901 Old Middlefield Way  
Mountain View, CA 94043

ROCKWELL INTERNATIONAL  
Microcomputer Division  
337 Miraloma Avenue  
Anaheim, CA 92803

**The MCS6500 devices use a single +5V power supply. Using a 1 microsecond clock, instruction execution times range from 2 to 12 microseconds.**

All MCS6500 devices have TTL compatible signals.

N-channel, silicon gate, depletion load MOS technology is used for MCS6500 devices.

## THE MCS6500 SERIES CPUs

Functions implemented on each of the MCS6500 CPUs are illustrated in Figure 10-1. As this figure would imply, capabilities offered by the various MCS6500 CPUs differ in scope rather than function.

Table 10-1. A Comparison of MCS6500 Series and the MC6800 CPU Devices

| CPU    | CPU PINS AND SIGNALS |          |          |          |          |     |     |     |      |        |    |     |     |    | PINS                                                                                                                             | COMMENTS |
|--------|----------------------|----------|----------|----------|----------|-----|-----|-----|------|--------|----|-----|-----|----|----------------------------------------------------------------------------------------------------------------------------------|----------|
|        | ADDRESS BUS          | DATA BUS | $\Phi_0$ | $\Phi_1$ | $\Phi_2$ | RDY | IRQ | NMI | SYNC | RESET* | SO | R/W | DBE |    |                                                                                                                                  |          |
| 6502   | A0-A15               | D0-D7    | I        | O        | O        | I   | I   | I   | O    | I      | I  | O   |     | 40 | This is the on-chip-clock version of the 6512.                                                                                   |          |
| 6503   | A0-A11               | D0-D7    | I        |          | O        | I   | I   | I   |      | I      | I  | O   |     | 28 | This is the on-chip-clock version of the 6513.                                                                                   |          |
| 6504   | A0-A12               | D0-D7    | I        |          | O        | I   | I   | I   |      | I      | I  | O   |     | 28 | This is the on-chip-clock version of the 6514.                                                                                   |          |
| 6505   | A0-A11               | D0-D7    | I        |          | O        | I   | I   | I   |      | I      | I  | O   |     | 28 | This is the on-chip-clock version of the 6515.                                                                                   |          |
| 6506   | A0-A11               | D0-D7    | I        | O        | O        | I   | I   | I   | O    | I      | I  | O   |     | 28 | On-chip-clock version, 4K memory, IRQ, $\Phi_1$ (out) and $\Phi_2$ (out).                                                        |          |
| 6512   | A0-A15               | D0-D7    | I        | I/O      | I        | I   | I   | I   | O    | I      | I  | O   | I   | 40 | This CPU is most like the MC6800. The HALT, VMA, TSC and BA signals are not present. SYNC, SO, $\Phi_2$ (out) and RDY are added. |          |
| 6513   | A0-A11               | D0-D7    | I        | I        | I        | I   | I   | I   |      | I      | I  | O   |     | 28 | 4K memory with IRQ and NMI.                                                                                                      |          |
| 6514   | A0-A11               | D0-D7    | I        | I        | I        | I   | I   | I   |      | I      | I  | O   |     | 28 | 8K memory with IRQ.                                                                                                              |          |
| 6515   | A0-A11               | D0-D7    | I        | I        | I        | I   | I   | I   |      | I      | I  | O   |     | 28 | 4K memory with IRQ and RDY.                                                                                                      |          |
| MC6800 | A0-A15               | D0-D7    | I        | I        | I        | I   | I   | I   |      | I      | I  | O   | I   | 40 | The MC6800 TSC, VMA, BA and HALT signals are not implemented on any MCS6500 CPU.                                                 |          |

\*The second name is the name used by MC6800 literature for the same signal.

Within CPU PINS AND SIGNALS columns, I identifies an input signal present, O identifies an output signal present, I/O identifies a signal that appears twice, at two pins, one as an input, the other as an output.



Figure 10-1. Logic of MCS6500 Series CPU Devices

## MCS6500 SERIES CPU PROGRAMMABLE REGISTERS

**The MCS6500 series CPUs all have the same programmable registers; they may be illustrated as follows:**



The MC6800 has two Accumulators; the MCS6500 has just one.

The Index register represents a significant departure from the MC6800. The MCS6500 breaks one 16-bit Index register into two 8-bit Index registers.

The MCS6500 Stack Pointer also represents a significant departure from MC6800 architecture. The MC6800 Stack Pointer is 16 bits wide, which means that the Stack may be located anywhere in memory, and may be of any length.

**The MCS6500 Stack Pointer is 8 bits wide, which means that maximum Stack length is 256 bytes.** The CPU always inserts 01<sub>16</sub> as the high-order byte of any Stack address, which means that memory locations 0100<sub>16</sub> through 01FF<sub>16</sub> are permanently assigned to the Stack:



01XX is the Stack address

**There is nothing very significant about the shorter MCS6500 Stack Pointer if you are using this CPU as a stand-alone product.** A 256-byte Stack is usually sufficient for any typical microcomputer application; and its location in early memory simply means that low memory addresses must be implemented as read/write memory. **If you are transferring from an MC6800 to an MCS6500, however, there are two very important consequences of the shorter MCS6500 Stack Pointer.**

The first and most important consequence is that you are unlikely to be so lucky as to have implemented the MC6800 Stack within the address space that the MCS6500 requires. Therefore, you will have to reassemble MC6800 programs, repartitioning memory in order to run the same programs in an MCS6500 microcomputer system.

A less obvious consequence of a shorter MCS6500 Stack Pointer is the fact that many MC6800 programs use the Stack Pointer as an alternate Index register. If you have used the Stack Pointer in this way when writing programs for an MC6800 microcomputer system, the program conversion, when going to an MCS6500 system, could be significant.

**The MCS6500 Program Counter is a typical program counter, identical to the MC6800 implementation.**

## MCS6500 MEMORY ADDRESSING MODES

**MCS6500 memory reference instructions use direct addressing, indexed addressing, and indirect addressing. The MC6800 has no indirect addressing and different indexed addressing.**

**The MC6800 and MCS6500 have identical direct addressing.** Three-byte instructions use the second and third bytes of the object code to provide a direct, 16-bit address; therefore, 65,536 bytes of memory can be addressed directly. The commonly used memory reference instructions also have a two-byte object code variation, where the second byte directly addresses one of the first 256 bytes of memory.

**MCS6500 direct indexed addressing differs markedly from MC6800 indexed addressing.**

**The MCS6500 offers base page, indexed addressing.** In this case, the instruction has two bytes of object code. The contents of either the X or Y Index registers are added to the second object code byte in order to compute a memory address. This may be illustrated as follows:



Base page, indexed addressing, as illustrated above, is wraparound — which means that there is no carry. If the sum of the Index register and second object code byte contents is more than FF<sub>16</sub>, the carry bit will be discarded. This may be illustrated as follows:



**Absolute indexed addressing is also provided.** In this case, the contents of either the X or the Y Index register are added to a 16-bit direct address provided by the second and third bytes of an instruction's object code. This may be illustrated as follows:



**Indirect addressing represents a feature of the MCS6500 which the MC6800 does not have.** Instructions that use simple indirect addressing have three bytes of object code. The second and third object code bytes provide a 16-bit address; therefore, the indirect address can be located anywhere in memory. This is straightforward indirect addressing, as described in Volume 1, Chapter 6.

**MCS6500 indirect, indexed addressing comes in two forms: there is pre-indexed indirect addressing and there is post-indexed indirect addressing.**

In each case the instruction object code is two bytes long and the second object code byte provides an 8-bit address.

**Instructions with pre-indexed indirect addressing add the contents of the X Index register and the second object code byte** to access a memory location in the first 256 bytes of memory, where the indirect address will be found:



When using pre-indexed indirect addressing, once again wraparound addition is used, which means that when the X Index register contents are added to the second object code byte, any carry will be discarded. Note that only the X Index register can be used with pre-indexed indirect addressing.

**The Y Index register is used for post-indexed indirect addressing:** now the second object code byte identifies a location in the first 256 bytes of memory where an indirect address will be found. The contents of the Y Index register are added to this indirect address. This may be illustrated as follows:



Note that only the Y Index register can be used with post-indexed indirect addressing.

**MCS6500 Branch and Branch-on-Condition instructions use program relative, direct addressing as described for the MC6800.** These instructions have two bytes of object code. The second object code byte is treated as an 8-bit, signed binary number, which is added to the Program Counter after the Program Counter contents have been incremented to address the next sequential instruction. This allows displacements in the range +127 through -128 bytes from the next instruction.

The MCS6500 literature uses the term implied addressing, as Motorola's MC6800 literature does, to describe instructions that identify one of the programmable registers. **The MCS6500 does not have implied addressing as the term is used in this book.**

## MCS6500 STATUS FLAGS

The MCS6500 has a Status register which maintains six status flags and a master interrupt control bit. These are the six status flags:

- Carry (C)
- Zero (Z)
- Overflow (O)
- Sign (S)
- Decimal Mode (D)
- Break (B)

Statuses are assigned bit positions within the Status register as follows:



In the illustration above, MCS6500 statuses and status bit assignments that differ from MC6800 equivalents have been shaded.

The Carry, Zero and Sign statuses are standard and are identical in function to those of the MC6800.

Carry represents any carry out of bit 7 during arithmetic or logical operations.

Zero is set to 1 when any arithmetic or logical operation results in a 0 value. Zero is set to 0 otherwise.

The Sign status will acquire the value of the high-order (Sign) bit of any arithmetic operation result. Thus, a Sign status value of 1 identifies a negative result and a Sign status of 0 identifies a positive result. The Sign status will be set or reset on the assumption that you are using signed binary arithmetic. If you are not using signed binary arithmetic, you can ignore the Sign status, or you can use it to identify the value of the high-order result bit.

The Decimal Mode and Break statuses have no MC6800 equivalent.

**The Decimal Mode status, when set, causes the Add-with-Carry and Subtract-with-Carry instructions to perform BCD operations.** Thus, when the Decimal Mode status is set and an Add-with-Carry or Subtract-with-Carry instruction is executed, CPU logic assumes that both source 8-bit values are valid BCD numbers — and the result generated will also be a valid BCD number. Because MCS6500 CPUs perform decimal addition and subtraction, there is no need for an Intermediate Carry status. This status is used for decimal adjust operations only, as described in Volume 1.

**The Break status pertains to software interrupts.** MCS6500 supports software interrupts, just as the MC6800 does. When a software interrupt is executed, however, MCS6500 CPU logic will set the Break status flag.

**I is a standard master interrupt enable/disable flag.** When I equals 1, interrupts are disabled; when I equals 0, interrupts are enabled.

**The Overflow status is a typical overflow, except that it can also be used as a control input.** Recall that an Overflow status represents a carry when performing signed binary arithmetic. The Overflow status has been discussed in detail in Volume 1; it equals the exclusive-OR of carries out of bits 6 and 7 when performing arithmetic operations. Some MCS6500 CPUs allow external logic to set or reset the Overflow status, in which case it can be used subsequently as a general logic indicator; you must be very careful when using the Overflow status in this way, since the same status flag will be modified by arithmetic instructions. It is up to you, as a programmer, to make sure that an instruction which modifies the Overflow status is not executed in between the time external logic sets or resets this status, and subsequent program logic tests it.

## MCS6500 CPU PINS AND SIGNALS

Figures 10-2 through 10-10 illustrate pins and signals for the nine CPUs of the MCS6500 family. Shaded pins in Figures 10-2 and 10-7 identify signals which are identical to the MC6800, both in pin location and signal type. Most of the 28-pin MCS6500 series CPUs have signals which are identical to those of the MC6800; however, between a 40-pin DIP and a 28-pin DIP, it is impossible to talk about pin compatibility.

MCS6500 signals may be divided between those that have MC6800 equivalents and those that do not. We are going to describe all of the MCS6500 series signals, as a group. **In order to determine which signals are available on the different MCS6500 CPUs, see Table 10-1.**

Let us begin with the signals which are direct reproductions of MC6800 signals.



Figure 10-2. MCS6502 Signals and Pin Assignments



Figure 10-3. MCS6503 Signals and Pin Assignments



| Pin Name   | Description        | Type                    |
|------------|--------------------|-------------------------|
| R/W        | Read/Write control | Output                  |
| IRQ        | Interrupt request  | Input                   |
| RESET      | Reset              | Input                   |
| $\phi_0$   | CPU clock          | Input                   |
| $\phi_2$   | System clock       | Output                  |
| DB0 - DB7  | Data Bus           | Tristate, bidirectional |
| AB0 - AB12 | Address Bus        | Output                  |
| VCC, VSS   | Power and Ground   |                         |

Figure 10-4. MCS6504 Signals and Pin Assignments



| Pin Name   | Description          | Type                    |
|------------|----------------------|-------------------------|
| R/W        | Read/Write control   | Output                  |
| IRQ        | Interrupt request    | Input                   |
| RESET      | Reset                | Input                   |
| $\phi_0$   | CPU clock            | Input                   |
| $\phi_2$   | System clock         | Output                  |
| DB0 - DB7  | Data Bus             | Tristate, bidirectional |
| AB0 - AB11 | Address Bus          | Output                  |
| RDY        | Single cycle control | Input                   |
| VCC, VSS   | Power and Ground     |                         |

Figure 10-5. MCS6505 Signals and Pin Assignments



| Pin Name            | Description        | Type                    |
|---------------------|--------------------|-------------------------|
| R/W                 | Read/Write control | Output                  |
| IRQ                 | Interrupt request  | Input                   |
| RESET               | Reset              | Input                   |
| $\Phi_0$            | CPU clock          | Input                   |
| $\Phi_1$ , $\Phi_2$ | System clocks      | Output                  |
| DB0 - DB7           | Data Bus           | Tristate, bidirectional |
| AB0 - AB11          | Address Bus        | Output                  |
| VCC, VSS            | Power and Ground   |                         |

Figure 10-6. MCS6506 Signals and Pin Assignments



| Pin Name            | Description                  | Type                    |
|---------------------|------------------------------|-------------------------|
| DBE                 | Data Bus Enable              | Input                   |
| R/W                 | Read/Write control           | Output                  |
| IRQ                 | Interrupt request            | Input                   |
| NMI                 | Non-maskable interrupt       | Input                   |
| RESET               | Reset                        | Input                   |
| $\Phi_1$ , $\Phi_2$ | CPU clocks                   | Input                   |
| $\Phi_2$ (OUT)      | System clock                 | Output                  |
| DB0 - DB7           | Data Bus                     | Tristate, bidirectional |
| AB0 - AB15          | Address Bus                  | Output                  |
| RDY                 | Single cycle control         | Input                   |
| SO                  | Set Overflow flag            | Input                   |
| SYNC                | Identify op code fetch cycle | Output                  |
| VCC, VSS            | Power and Ground             |                         |

Figure 10-7. MCS6512 Signals and Pin Assignments



| Pin Name            | Description            | Type                    |
|---------------------|------------------------|-------------------------|
| R/W                 | Read/Write control     | Output                  |
| IRQ                 | Interrupt request      | Input                   |
| NMI                 | Non-maskable interrupt | Input                   |
| RESET               | Reset                  | Input                   |
| $\Phi_1$ , $\Phi_2$ | CPU clocks             | Input                   |
| DB0 - DB7           | Data Bus               | Tristate, bidirectional |
| AB0 - AB11          | Address Bus            | Output                  |
| VCC, VSS            | Power and Ground       |                         |

Figure 10-8. MCS6513 Signals and Pin Assignments



| Pin Name            | Description        | Type                    |
|---------------------|--------------------|-------------------------|
| R/W                 | Read/Write control | Output                  |
| IRQ                 | Interrupt request  | Input                   |
| RESET               | Reset              | Input                   |
| $\Phi_1$ , $\Phi_2$ | CPU clocks         | Input                   |
| DB0 - DB7           | Data Bus           | Tristate, bidirectional |
| AB0 - AB12          | Address Bus        | Output                  |
| VCC, VSS            | Power and Ground   |                         |

Figure 10-9. MCS6514 Signals and Pin Assignments



| Pin Name   | Description          | Type                    |
|------------|----------------------|-------------------------|
| R/W        | Read/Write control   | Output                  |
| IRQ        | Interrupt request    | Input                   |
| RESET      | Reset                | Input                   |
| Φ1, Φ2     | CPU clocks           | Input                   |
| DB0 - DB7  | Data Bus             | Tristate, bidirectional |
| AB0 - AB11 | Address Bus          | Output                  |
| RDY        | Single cycle control | Input                   |
| VCC, VSS   | Power and Ground     |                         |

Figure 10-10. MCS6515 Signals and Pin Assignments

**DATA BUS ENABLE (DBE).** Only the MCS6512 CPU supports this signal. This signal is input low in order to float the Data Bus. DBE is frequently tied to the Φ2 clock input, in which case Φ2 and DBE are identical signals.

**READ/WRITE (R/W).** When high, this signal indicates that the CPU wishes to read data off the Data Bus; when low, this signal indicates that the CPU is outputting data on the Data Bus. The normal standby state for this signal is "read" (high).

**INTERRUPT REQUEST (IRQ).** This signal is used by external logic to request an interrupt. If interrupts have been enabled, then the CPU will acknowledge an interrupt at the end of the currently executing instruction. There is a small difference between MCS6500 and MC6800 interrupt acknowledge logic. **The MC6800 cannot acknowledge an interrupt while it is in the Halt state. The MCS6500 has no Halt state,** therefore this situation cannot arise.

**NONMASKABLE INTERRUPT (NMI).** This signal differs from IRQ in that it cannot be inhibited. Typically this input is used for catastrophic interrupts such as power failure.

**RESET.** This is a typical RESET signal. Reset logic within an MCS6500 microcomputer system is identical to Reset logic within an MC6800 microcomputer system.

Next consider MC6800 signals which are the same on some MCS6500 CPUs, but not on others.

The clock signals Φ1 and Φ2 are identical to MC6800 clock signals for the MCS651X series CPUs. These CPUs require external clock signals whose waveforms are identical to the MC6800. **The MCS650X series CPUs have clock logic on the CPU chip; these CPUs output Φ2;** the MCS6502 and the MCS6506 output Φ1 as well.

The Data Bus of the MCS6500 series CPUs is identical to that of the MC6800. The Data Bus is a tristate, 8-bit bidirectional bus via which data is transferred between memory and all MCS6500 microcomputer system devices. However, only the MCS6512 has a DBE input for external control of the bus. On MCS6500 CPUs other than the MCS6512, an internal Data Bus Enable is connected to Φ2; in these devices the Data Bus is always floated during the first part of a machine cycle.

We will now look at the CPU signals which are unique to the MCS6500 microcomputer system.

The Address Bus in MCS6500 microcomputer systems is not a tristate bus and cannot be floated. Also, the 28-pin MCS6500 series CPUs have either 12 or 13 Address Bus lines, allowing a total memory space of either 4K or 8K bytes. The Address Bus is used in the normal way by the CPU to output memory addresses.

**READY (RDY)** is an input control signal which, in MCS6500 microcomputer systems, performs the task of MC6800 TSC, DBE and HALT signals. The RDY input causes the equivalent of a Wait machine cycle to be inserted within the normal machine cycle sequence. In order to generate a Wait machine cycle, RDY must make a high-to-low transition

during a  $\Phi_1$  high clock pulse in any machine cycle other than a write. We will illustrate the use of the RDY signal, and discuss a number of its non-obvious ramifications, following this summary description of MCS6500 signals.

**The Set Overflow flag (SO) signal can be used to set to 1 the Overflow bit of the Status register.** When the SO input makes a high-to-low transition, the Overflow status is set to 1. The SO input can make a high-to-low transition at any time; this is an asynchronous input.

You cannot use the SO input signal to reset the Overflow bit of the Status register to 0.

**The SYNC signal is used to identify instruction fetch machine cycles.** There are a number of important uses for this signal, which we will discuss along with general instruction timing.

## MCS6500 TIMING AND INSTRUCTION EXECUTION

MCS6500 CPUs execute instructions using exactly the same clock signals, machine cycles and machine cycle types as described for the MC6800 in Chapter 8.

Recall that the two clock signals,  $\Phi_1$  and  $\Phi_2$ , define machine cycles as follows:



So far as external logic is concerned, there are only three types of machine cycles which can occur during an instruction's execution:

- 1) A **read operation** during which a byte of data must be input to the CPU.
- 2) A **write operation** during which a byte of data is output by the CPU.
- 3) An **internal operation** during which no activity occurs on the System Bus.

As was the case with the MC6800, all MCS6500 instructions have timing which is a simple concatenation of the three basic machine cycle types. See Figures 9-3 and 9-4 and the accompanying text in Chapter 9 for a description of these three basic machine cycles.

Instruction execution differences between the MC6800 and MCS6500 arise only when we depart from simple instruction execution logic. The MCS6500 SYNC signal is also a difference to be noted; the SYNC signal identifies MCS6500 machine cycles during which any instruction object code is being fetched. SYNC timing may be illustrated as follows:



MCS6500 CPUs do not allow the  $\Phi_1$  and  $\Phi_2$  clocks to be stretched, nor do they allow the Address Bus to be floated; some MCS6500 CPU versions do not allow the Data Bus to be floated. Also, there is no Halt state. **The single RDY signal is used to interface slow memories, to refresh dynamic memories or to perform Direct Memory Access operations.**

What the RDY input signal does is allow you to insert one or more Wait machine cycles in between two normal instruction execution machine cycles:

MCS6500  
WAIT  
STATE



The RDY input allows Wait machine cycles to be inserted within any instruction's normal sequence of machine cycles. For Wait machine cycles to occur, the RDY input must make a high-to-low transition during a  $\Phi_1$  high clock pulse. This transition may occur during any nonwrite machine cycle. Timing may be illustrated as follows:



Wait machine cycles will be inserted until RDY is sensed high during a  $\Phi_2$  high pulse.

If a RDY high-to-low transition occurs during a write machine cycle, then the Wait states will still be inserted, but the insertion will occur following the next nonwrite machine cycle.

**A non-obvious feature of the MCS6500 RDY signal is the fact that there is no acknowledge response from the CPU to external logic.** This can be a problem. To guarantee that the machine cycle following the RDY high-to-low transition will be a Wait, you must make sure that RDY never makes a high-to-low transition during a write cycle. Fortunately, you can use the R/W output to detect write cycles and thus generate a safe RDY input. Here is simple sample logic:



Since the same  $\Phi_2$  clock pulse that triggers the 7474 flip-flop also triggers any change in R/W signal level, R/W is NANDed with Q after taking the 7474 settling delay — which also gives R/W time to acquire its new level.

If you are interfacing slow memories, performing Direct Memory Access or refreshing dynamic memories, in each case the extra time provided for the secondary operation is the Wait state generated via the RDY input, as we have just described.

**When interfacing slow memories,** the logic of the Wait state is self-evident. The slow memory simply has additional machine cycles in which to respond to the memory access, and memory select logic holds RDY low for any required time delay.

**MCS6500  
SLOW MEMORY  
INTERFACE**

**When using a Wait state to perform Direct Memory Access or dynamic memory refresh operations,** there is a further complication. During the Wait state, the Data and Address Busses are not floated. Alternate Data and Address Busses must therefore be provided, connected via a tristate buffer to any memory device which is being accessed.

## INTERRUPT PROCESSING AND SYSTEM RESET

The MCS6500 microcomputer system handles interrupts and resets exactly as the MC6800. For a discussion of this subject, therefore, see Chapter 9 — with the following provisos:

- 1) Neither the MCS6500 nor the MC6800 will acknowledge an interrupt if the interrupt enable status bit has been set to 1. Additionally, the MC6800 will not acknowledge an interrupt while in the Halt state. The MCS6500 has no Halt state, but Wait states induced by the RDY line may be looked upon as equivalent. If an interrupt request occurs while Wait states are being created by an MCS6500 CPU in response to the RDY control input, then the interrupt acknowledge process will begin with the first non-Wait machine cycle.
- 2) When the MCS6500 executes a software interrupt, the Break status is set. The MC6800 has no such status flag.
- 3) The MCS6500 Stack is 256 bytes long and is implemented in memory locations 0100<sub>16</sub> through 01FF<sub>16</sub>. The MC6800 Stack can have any length within the allowed memory space, and can be located anywhere in memory.

**The MCS6500 series microcomputers have no interrupt acknowledge signal.** You must create this signal by decoding off the Address Bus the interrupt acknowledge address FFF9<sub>16</sub>, which is the second address to be output during the interrupt acknowledge sequence. Creating an interrupt acknowledge signal in this fashion is described later in this chapter.

## MCS6500 CPU CLOCK LOGIC

Clock logic required by the MCS651X series of CPUs is identical to that which has already been described for the MC6800 in Chapter 9. Indeed, you can use any of the MC6870 series clock devices in order to create timing inputs.

The MCS650X series CPUs have on-chip logic; all they need is an external crystal or RC network. A number of possible circuits, described in MOS Technology literature, are reproduced in Figure 10-11.

## MCS6500 CPU INTERFACE LOGIC

Look again at Table 10-1 and you will see that the 28-pin CPUs are remarkable in that they output so few control signals; in fact, the MCS6513, MCS6514, and MCS6515 output just one control signal: R/W. The remaining 28-pin CPUs additionally output clock signals only. There is no interrupt acknowledge, no synchronization output, nor any control signal which external logic can use to determine what is going on within the CPU. **Of all the microprocessors described in this book, none provides so few control output signals.** So long as you are building relatively straightforward microcomputer systems, this does not present a problem. The Address and Data Busses are never floated by 28-pin CPUs; therefore, external logic, upon detecting a select address on the Address Bus, will simply respond by reading or writing — depending upon the level of the R/W signal. The fact that this signal is high in its idle state, indicating a read, simply means that selected external logic will place the contents of its addressed memory location on the Data Bus. If the R/W signal is really in its standby state, then the CPU will ignore the Data Bus contents and no harm is done. Thus, for simple microcomputer systems, the MCS6500 series CPUs are remarkably simple devices to work with. If a microcomputer system becomes complex, however, problems may arise. **DMA logic must account for the fact that there is no detectable standby state for memory or I/O devices to detect; any device selected by the address of the Address Bus is continuously responding to a read or write command.**



X is pin 39 for the MCS6502, or pin 28  
for any other MCS650X CPU  
Y is pin 37 for the MCS6502, or pin 27  
for any other MCS650X CPU

Figure 10-11. Time Base Generation for MCS650X CPU Input Clocks

**When designing microcomputer systems around an MCS6500 CPU, if you are going to share the System Bus in any way, you must be very cautious about ensuring that you have accounted for the passive role of support logic surrounding the CPU.**

Despite the paucity of control signals on the MCS6500 bus, you can, in fact, do anything that you could do on any other bus. Using the MCS6500, it is simply going to take a little more logic. Some suggestions are given later in this chapter, when we explain how you can use non-6500 support devices (in particular 8080A support devices) with a 6500 CPU.

## THE MCS6500 INSTRUCTION SET

Table 10-2 summarizes the MCS6500 instruction set. This instruction set follows the philosophy of the MC6800 very closely.

## THE BENCHMARK PROGRAM

The benchmark program is coded for the MCS6500 as follows:

|      |               |                                 |
|------|---------------|---------------------------------|
| LDY  | IOCNT         | LOAD BUFFER LENGTH INTO Y INDEX |
| LOOP | LDA (IOBUF),Y | LOAD NEXT SOURCE BYTE           |
| STA  | (TABLE),Y     | STORE IN NEXT DESTINATION BYTE  |
| DEY  |               | DECREMENT Y                     |
| BNE  | LOOP          | RETURN FOR MORE BYTES           |
| LDA  | IOCNT         | AT END ADD NUMBER OF BYTES      |
| CLC  |               | TO CURRENT TABLE BASE ADDRESS   |
| ADC  | TABLE+1       |                                 |
| STA  | TABLE+1       |                                 |

This is the memory map assumed:



The programming example illustrated above makes use of indirect addressing. Somewhere in the first 256 bytes of memory we store the number of bytes to be transferred, the beginning address for the source table, and the address for the first free destination table byte. By loading the byte count into the Y Index register, we can use this register both as an index for moving data from source to destination, and as a counter.

After moving the block of data, we must add the number of moved data bytes to the destination table first free byte address; this accounts for the fact that the destination table has been incrementally filled.

**When comparing the MCS6500 with the MC6800, we see that we have indeed reduced the number of instructions** from 11 to 9; the number of instructions within the iterative loop has been reduced from 5 to 4. We cannot make a more substantial reduction in the number of instructions because the MC6800 program uses the Stack Pointer as an Index register — which is not an option with the MCS6500. We might argue that the MCS6500 has an advantage by not immobilizing the Stack while the instruction sequence is executed; however, the MCS6500 has the disadvantage of requiring both the source and destination tables to have a maximum length of 256 bytes; the MC6800 program makes no such demand.

Symbols are used in Table 10-2 as follows:

Registers:    A Accumulator  
               X Index Register X  
               Y Index Register Y  
               PC Program Counter  
               SP Stack Pointer  
               SR Status register, with bits assigned as follows:



Statuses:    S Sign status  
               Z Zero status  
               C Carry status  
               O Overflow status

Symbols in the column labeled STATUSES:

- (blank) operation does not affect status
- X operation affects status
- 0 operation clears status
- 1 operation sets status
- 6 status reflects bit 6 of memory location
- 7 status reflects bit 7 of memory location

ADR    8 bits of immediate or base address  
  ADR16    16 bits of immediate or base address  
  a8    Any of the following operands and addressing modes:  
         ADR    Base Page Direct  
         ADR,X    Base Page Indexed via Register X  
         (ADR,X)    Pre-Indexed Indirect  
         (ADR),Y    Post-Indexed Indirect  
  a16    Any of the following operands and addressing modes:  
         ADR16    Extended Direct  
         ADR16,X    Absolute Indexed via Register X  
         ADR16,Y    Absolute Indexed via Register Y  
  B    Break status  
  D    Decimal Mode status  
  DATA    8 bits of immediate data  
  DISP    An 8-bit, signed address displacement  
  I    Interrupt disable status  
  LABEL    16-bit immediate address, destination of Jump-on-Subroutine call  
  M( )    The memory location addressed via the mode specified in parenthesis  
  PC(HI)    The most significant 8 bits of the Program Counter  
  PC(LO)    The least significant 8 bits of the Program Counter  
  [ ]    Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.

- [[ ]] Implied memory addressing; the contents of the memory location designated by the contents of a register or address calculation.
- Λ Logical AND
- ∨ Logical OR
- ✗ Logical Exclusive-OR
- Data is transferred in the direction of the arrow
- ↔ Data is exchanged between the two locations designated on either side of the arrow

Table 10-2. A Summary of the MCS6500 Microcomputer Instruction Set

| TYPE                             | MNEMONIC | OPERAND(S)                                                        | BYTES                           | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------|----------|-------------------------------------------------------------------|---------------------------------|----------|---|---|---|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  |          |                                                                   |                                 | S        | Z | C | O |  |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| I/O AND PRIMARY MEMORY REFERENCE | LDA      | ADR<br>ADR,X<br>(ADR,X)<br>(ADR),Y<br>ADR16<br>ADR16,X<br>ADR16,Y | 2<br>2<br>2<br>2<br>3<br>3<br>3 | X        | X |   |   |  | [A]—[ADR] or<br>[A]—[(X)+ADR] or<br>[A]—([(X)+ADR]) or<br>[A]—[[ADR+1,ADR]+[Y]] or<br>[A]—[ADR16] or<br>[A]—[ADR16+[X]] or<br>[A]—[ADR16+[Y]]<br><br>Load Accumulator from memory using any of the following addressing modes:<br>Base page direct<br>Base page indexed (X register)<br>Pre-indexed indirect<br>Post-indexed indirect<br>Extended direct<br>Absolute indexed (Register X or Register Y)<br>M(a8)—[A] or M(a16)—[A] |
|                                  | STA      | a8<br>a16                                                         | 2<br>3                          |          |   |   |   |  | Store Accumulator to memory using any of the addressing modes permitted with LDA.<br>[X]—[ADR] or [X]—[ADR16] or<br>[X]—[(Y)+ADR] or [X]—[ADR16+[Y]]                                                                                                                                                                                                                                                                               |
|                                  | LDX      | ADR or ADR,Y<br>ADR16 or ADR16,Y                                  | 2<br>3                          | X        | X |   |   |  | Load Index Register X from memory using direct, extended, base page indexed or absolute indexed addressing, indexing through Register Y.<br>[ADR]—[X] or [ADR16]—[X] or<br>[(Y)+ADR]—[X]                                                                                                                                                                                                                                           |
|                                  | STX      | ADR or ADR,Y<br>ADR16                                             | 2<br>3                          |          |   |   |   |  | Store Index Register X to memory using direct, extended or base page indexed addressing, indexing through Register Y.<br>[Y]—[ADR] or [Y]—[ADR16] or<br>[Y]—[(X)+ADR] or [Y]—[ADR16+[X]]                                                                                                                                                                                                                                           |
|                                  | LDY      | ADR or ADR,X<br>ADR16 or ADR16,X                                  | 2<br>3                          | X        | X |   |   |  | Load Index Register Y from memory using direct, extended, base page indexed or absolute indexed addressing, indexing through Register Y.<br>[ADR]—[Y] or [ADR16]—[Y] or<br>[(X)+ADR]—[Y]                                                                                                                                                                                                                                           |
|                                  | STY      | ADR or ADR,X<br>ADR16                                             | 2                               |          |   |   |   |  | Store Index Register Y to memory using direct, extended, or base page indexed addressing, indexing through Register X                                                                                                                                                                                                                                                                                                              |
|                                  |          |                                                                   |                                 |          |   |   |   |  |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MEMORY OPERATE                   | ADC      | a8<br>a16                                                         | 2<br>3                          | X        | X | X | X |  | [A]—[A]+M(a8)+C or<br>[A]—[A]+M(a16)+C<br><br>Add contents of memory location, with carry, to those of Accumulator, using any of the addressing modes permitted with LDA. Zero flag is not valid in Decimal Mode.                                                                                                                                                                                                                  |
|                                  | AND      | a8<br>a16                                                         | 2<br>3                          | X        | X |   |   |  | [A]—[A]Λ M(a8) or [A]—[A]Λ M(a16)<br><br>AND contents of Accumulator with those of memory location addressed via any of the modes permitted with LDA.                                                                                                                                                                                                                                                                              |
|                                  | BIT      | ADR8<br>ADR16                                                     | 2<br>3                          | 7        | X |   | 6 |  | [A]Λ [ADR8] or [A]Λ [ADR16]<br><br>AND contents of Accumulator with those of memory location. Only the status bits are affected. Direct or extended addressing modes may be used.                                                                                                                                                                                                                                                  |

Table 10-2. A Summary of the MCS6500 Microcomputer Instruction Set (Continued)

| TYPE                                                       | MNEMONIC | OPERAND(S)                        | BYTES  | STATUSES |     |   |   |  | OPERATION PERFORMED                                                                                                                                                                                                                                                                                              |
|------------------------------------------------------------|----------|-----------------------------------|--------|----------|-----|---|---|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                            |          |                                   |        | S        | Z   | C | O |  |                                                                                                                                                                                                                                                                                                                  |
| SECONDARY MEMORY REFERENCE (MEMORY OPERATE)<br>(CONTINUED) | CMP      | a8<br>a16                         | 2<br>3 | X        | X   | X |   |  | [A] - M(a8) or [A] - M(a16)<br>Compare contents of Accumulator with those of memory location, affecting status bit only. Any of the addressing modes permitted with LDA may be used.                                                                                                                             |
|                                                            | EOR      | a8<br>a16                         | 2<br>3 | X        | X   |   |   |  | [A] - [A] $\vee$ M(a8) or [A] - [A] $\vee$ M(a16)<br>Exclusive-OR contents of Accumulator with those of memory location, using any of the addressing modes permitted with LDA.                                                                                                                                   |
|                                                            | ORA      | a8<br>a16                         | 2<br>3 | X        | X   |   |   |  | [A] - [A] V M(a8) or [A] - [A] V M(a16)<br>OR contents of Accumulator with those of memory location, using any of the addressing modes permitted with LDA.                                                                                                                                                       |
|                                                            | SBC      | a8<br>a16                         | 2<br>3 | X        | 'X' | X | X |  | [A] - [A] - M(a8) - C or [A] - [A] - M(a16) - C<br>Subtract contents of memory location, with borrow, from contents of Accumulator. Any addressing mode permitted with LDA may be used. Note that Carry reflects the complement of the borrow.                                                                   |
|                                                            | INC      | ADR8 or ADR,X<br>ADR16 or ADR16,X | 2<br>3 | X        | X   |   |   |  | [ADR] - [ADR] + 1 or [ADR16] - [ADR16] + 1 or<br>[[X] + ADR] - [[X] + ADR] + 1 or<br>[ADR16 + [X]] - [ADR16 + [X]] + 1<br>Increment contents of memory location using direct, extended, base page indexed or absolute indexed addressing, indexing through Register X.                                           |
|                                                            | DEC      | ADR or ADR,X<br>ADR16 or ADR16,X  | 2<br>3 | X        | 'X' |   |   |  | [ADR] - [ADR] - 1 or [ADR16] - [ADR16] - 1 or<br>[[X] + ADR] - [[X] + ADR] - 1 or<br>[ADR16 + [X]] - [ADR16 + [X]] - 1<br>Decrement contents of memory location using direct, extended, base page indexed or absolute indexed addressing, indexing through Register X.                                           |
|                                                            | CPX      | ADR<br>ADR16                      | 2<br>3 | X        | X   | X |   |  | [X] - [ADR] or [X] - [ADR16]<br>Compare contents of X register with those of memory location, using direct or extended addressing. Only the status flags are affected.                                                                                                                                           |
|                                                            | CPY      | ADR<br>ADR16                      | 2<br>3 | X        | X   | X |   |  | [Y] - [ADR] or [Y] - [ADR16]<br>Compare contents of Y register with those of memory location using direct or extended addressing. Only the status flags are affected.                                                                                                                                            |
|                                                            | ROL      | ADR or ADR,X<br>ADR16 or ADR16,X  | 2<br>3 | X        | X   | X |   |  | [ADR] or [ADR16] or<br><br>[[X] + ADR] or<br>[ADR16 + [X]]<br>Rotate contents of memory location left through Carry, using direct, extended, base page indexed or absolute indexed addressing, indexing through Register X.    |
|                                                            | ASL      | ADR or ADR,X<br>ADR16 or ADR16,X  | 2<br>3 | X        | X   | X |   |  | [ADR] or [ADR16] or<br><br>[[X] + ADR] or [ADR16 + [X]]<br>Arithmetic shift left contents of memory location using direct, extended, base page indexed or absolute indexed addressing, indexing through Register X.           |
|                                                            | LSR      | ADR or ADR,X<br>ADR16 or ADR16,X  | 2<br>3 | 0        | X   | X |   |  | 0 ->  -> C<br>[ADR] or [ADR16] or<br>[[X] + ADR] or [ADR16 + [X]]<br>Logical shift right contents of memory location, using direct, extended, base page indexed or absolute indexed addressing, indexing through Register X. |

Table 10-2. A Summary of the MCS6500 Microcomputer Instruction Set (Continued)

| TYPE                | MNEMONIC | OPERAND(S)       | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                                             |
|---------------------|----------|------------------|-------|----------|---|---|---|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |          |                  |       | S        | Z | C | O |  |                                                                                                                                                                 |
| IMMEDIATE           | LDA      | DATA             | 2     | X        | X |   |   |  | [A]— DATA<br>Load Accumulator with immediate data.                                                                                                              |
|                     | LDX      | DATA             | 2     | X        | X |   |   |  | [X]— DATA<br>Load Index Register X with immediate data.                                                                                                         |
|                     | LDY      | DATA             | 2     | X        | X |   |   |  | [Y]— DATA<br>Load Index Register Y with immediate data.                                                                                                         |
| IMMEDIATE OPERATE   | ADC      | DATA             | 2     | X        | X | X | X |  | [A]—[A] + DATA + C<br>Add immediate, with Carry, to Accumulator. The Zero flag is not valid in Decimal Mode.                                                    |
|                     | AND      | DATA             | 2     | X        | X |   |   |  | [A]—[A] $\wedge$ DATA<br>AND immediate with Accumulator.                                                                                                        |
|                     | CMP      | DATA             | 2     | X        | X | X |   |  | [A]— DATA<br>Compare immediate with Accumulator. Only the status flags are affected.                                                                            |
|                     | EOR      | DATA             | 2     | X        | X |   |   |  | [A]—[A] $\vee$ DATA<br>Exclusive-OR immediate with Accumulator.                                                                                                 |
|                     | ORA      | DATA             | 2     | X        | X |   |   |  | [A]—[A] V DATA<br>OR immediate with Accumulator.                                                                                                                |
|                     | SBC      | DATA             | 2     | X        | X | X | X |  | [A]—[A] - DATA - C<br>Subtract immediate, with borrow, from Accumulator. Note that Carry reflects the complement of the borrow.                                 |
|                     | CPX      | DATA             | 2     | X        | X | X |   |  | [X]— DATA<br>Compare immediate with Index Register X. Only the status flags are affected.                                                                       |
|                     | CPY      | DATA             | 2     | X        | X | X |   |  | [Y]— DATA<br>Compare immediate with Index Register Y. Only the status flags are affected.                                                                       |
| JUMP                | JMP      | LABEL<br>(LABEL) | 3     |          |   |   |   |  | [PC]— LABEL or [PC]—[LABEL]<br>Jump to new location, using extended or indirect addressing.                                                                     |
|                     | JSR      | LABEL            | 3     |          |   |   |   |  | [([SP])—[PC(HI)]],<br>[([SP]-1)—[PC(LO)]],<br>[SP]—[SP]-2,<br>[PC]— LABEL<br>Jump to subroutine beginning at address given in bytes 2 and 3 of the instruction. |
| BRANCH ON CONDITION | BCC      | DISP             | 2     |          |   |   |   |  | If C = 0, then [PC]—[PC] + 1 + DISP<br>Branch relative if Carry flag is cleared.                                                                                |
|                     | BCS      | DISP             | 2     |          |   |   |   |  | If C = 1, then [PC]—[PC] + 1 + DISP<br>Branch relative if Carry flag is set.                                                                                    |
|                     | BEQ      | DISP             | 2     |          |   |   |   |  | If Z = 1, then [PC]—[PC] + 1 + DISP<br>Branch relative if result is equal to zero.                                                                              |
|                     | BMI      | DISP             | 2     |          |   |   |   |  | If S = 1, then [PC]—[PC] + 1 + DISP<br>Branch relative if result is negative.                                                                                   |
|                     | BNE      | DISP             | 2     |          |   |   |   |  | If Z = 0, then [PC]—[PC] + 1 + DISP<br>Branch relative if result is not zero.                                                                                   |
|                     | BPL      | DISP             | 2     |          |   |   |   |  | If S = 0, then [PC]—[PC] + 1 + DISP<br>Branch relative if result is positive.                                                                                   |
|                     | BVC      | DISP             | 2     |          |   |   |   |  | If O = 0, then [PC]—[PC] + 1 + DISP<br>Branch relative if Overflow flag is cleared.                                                                             |

Table 10-2. A Summary of the MCS6500 Microcomputer Instruction Set (Continued)

| TYPE                            | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                      |
|---------------------------------|----------|------------|-------|----------|---|---|---|--|------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |          |            |       | S        | Z | C | O |  |                                                                                                                                          |
| BRANCH ON CONDITION (CONTINUED) | BVS      | DISP       | 2     |          |   |   |   |  | If O = 1, then [PC]—[PC]+1+DISP<br>Branch relative if Overflow flag is set.                                                              |
| REGISTER-REGISTER MOVE          | TAX      |            | 1     | X        | X |   |   |  | [A]—[X]<br>Move Accumulator contents to Index Register X.                                                                                |
|                                 | TXA      |            | 1     | X        | X |   |   |  | [X]—[A]<br>Move contents of Index Register X to Accumulator.                                                                             |
|                                 | TAY      |            | 1     | X        | X |   |   |  | [A]—[Y]<br>Move Accumulator contents to Index Register Y.                                                                                |
|                                 | TYA      |            | 1     | X        | X |   |   |  | [Y]—[A]<br>Move contents of Index Register Y to Accumulator.                                                                             |
|                                 | TSX      |            | 1     | X        | X |   |   |  | [SP]—[X]<br>Move contents of Stack Pointer to Index Register X.                                                                          |
|                                 | TXS      |            | 1     |          |   |   |   |  | [X]—[SP]<br>Move contents of Index Register X to Stack Pointer.                                                                          |
| REGISTER OPERATE                | DEX      |            | 1     | X        | X |   |   |  | [X]—[X]-1<br>Decrement contents of Index Register X.                                                                                     |
|                                 | DEY      |            | 1     | X        | X |   |   |  | [Y]—[Y]-1<br>Decrement contents of Index Register Y.                                                                                     |
|                                 | INX      |            | 1     | X        | X |   |   |  | [X]—[X]+1<br>Increment contents of Index Register X.                                                                                     |
|                                 | INY      |            | 1     | X        | X |   |   |  | [Y]—[Y]+1<br>Increment contents of Index Register Y.                                                                                     |
|                                 | ROL      | A          | 1     | X        | X | X |   |  | <br>Rotate contents of Accumulator left through Carry. |
|                                 | ASL      |            | 1     | X        | X | X |   |  | <br>Arithmetic shift left contents of Accumulator.     |
|                                 | LSR      | A          | 1     | 0        | X | X |   |  | <br>Logical shift right contents of Accumulator.      |
| STACK                           | PHA      |            | 1     |          |   |   |   |  | [SP]—[A], [SP]—[SP]-1<br>Push Accumulator contents onto Stack.                                                                           |
|                                 | PLA      |            | 1     | X        | X |   |   |  | [A]—[SP]+1, [SP]—[SP]+1<br>Load Accumulator from top of Stack (PULL).                                                                    |
|                                 | PHP      |            | 1     |          |   |   |   |  | [SP]—[SR], [SP]—[SP]-1<br>Push Status register contents onto Stack.                                                                      |

Table 10-2. A Summary of the MCS6500 Microcomputer Instruction Set (Continued)

| TYPE                 | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |  | OPERATION PERFORMED                                                                                                                                                                                                                                                 |
|----------------------|----------|------------|-------|----------|---|---|---|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      |          |            |       | S        | Z | C | O |  |                                                                                                                                                                                                                                                                     |
| STACK<br>(CONTINUED) | PLP      |            | 1     | X        | X | X | X |  | [SR]—[[SP]+1], [SP]—[SP]+1<br>Load Status register from top of Stack (PULL).<br>[PC(LO)]—[[SP]+1]<br>[PC(HI)]—[[SP]+2],<br>[SP]—[SP]+2,<br>[PC]—[PC]+1                                                                                                              |
|                      | RTS      |            | 1     |          |   |   |   |  | Return from subroutine.                                                                                                                                                                                                                                             |
| INTERRUPT            | CLI      |            | 1     |          |   |   |   |  | I—0<br>Enable interrupts by clearing interrupt disable bit of Status register.                                                                                                                                                                                      |
|                      | SEI      |            | 1     |          |   |   |   |  | I—1<br>Disable interrupts.                                                                                                                                                                                                                                          |
|                      | RTI      |            | 1     | X        | X | X | X |  | [SR]—[[SP]+1],<br>[PC(LO)]—[[SP]+2],<br>[PC(HI)]—[[SP]+3],<br>[SP]—[SP]+3,<br>[PC]—[PC]+1                                                                                                                                                                           |
|                      | BRK      |            | 1     |          |   |   |   |  | Return from interrupt; restore Status register and Program Counter from top of Stack.<br>[[SP]]—[PC(HI)],<br>[[SP]-1]—[PC(LO)],<br>[[SP]-2]—[SR],<br>[SP]—[SP]-3,<br>[PC(LO)]—[FFFE], [PC(HI)]—[FFFF],<br>I—1, B—1<br>Programmed interrupt. BRK cannot be disabled. |
| STATUS               | CLC      |            | 1     |          |   | 0 |   |  | C—0<br>Clear Carry flag.                                                                                                                                                                                                                                            |
|                      | SEC      |            | 1     |          |   | 1 |   |  | C—1<br>Set Carry flag.                                                                                                                                                                                                                                              |
|                      | CLD      |            | 1     |          |   |   |   |  | D—0<br>Clear Decimal Mode.                                                                                                                                                                                                                                          |
|                      | SED      |            | 1     |          |   | 0 |   |  | D—1<br>Set Decimal Mode.                                                                                                                                                                                                                                            |
|                      | CLV      |            | 1     |          |   |   |   |  | O—0<br>Clear Overflow flag.                                                                                                                                                                                                                                         |
|                      | NOP      |            | 1     |          |   |   |   |  | No Operation.                                                                                                                                                                                                                                                       |

The following symbols are used in the object codes in Table 10-3.

Address mode selection:

aaa

|     |                                 |
|-----|---------------------------------|
| 000 | pre-indexed indirect — (ADR,X)  |
| 001 | direct — ADR                    |
| 010 | immediate — DATA                |
| 011 | extended direct — ADR16         |
| 100 | post-indexed indirect — (ADR),Y |
| 101 | base page indexed — ADR,X       |
| 110 | absolute indexed — ADR16,Y      |
| 111 | absolute indexed — ADR16,X      |

bb

|    |                            |
|----|----------------------------|
| 00 | direct — ADR               |
| 01 | extended direct — ADR16    |
| 10 | base page indexed — ADR,X  |
| 11 | absolute indexed — ADR16,X |

bbb

|     |                            |
|-----|----------------------------|
| 001 | direct — ADR               |
| 010 | accumulator — A            |
| 011 | extended direct — ADR16    |
| 101 | base page indexed — ADR,X  |
| 111 | absolute indexed — ADR16,X |

cc

|    |                         |
|----|-------------------------|
| 00 | immediate — DATA        |
| 01 | direct — ADR            |
| 11 | extended direct — ADR16 |

ddd

|     |                                                   |
|-----|---------------------------------------------------|
| 000 | immediate — DATA                                  |
| 001 | direct — ADR                                      |
| 011 | extended direct — ADR16                           |
| 101 | base page indexed — ADR,Y in LDX; ADR,X in LDY    |
| 111 | absolute indexed — ADR16,Y in LDX; ADR16,X in LDY |

pp the second byte of a two- or three-byte instruction.

qq the third byte of a three-byte instruction.

x one bit choosing the address mode.

Two numbers in the "Machine Cycles" column (for example, 2 - 6) indicate that execution time depends on the addressing mode.

Table 10-3. Summary of MCS6500 Object Codes, with MC6800 Mnemonics

| MNEMONIC | OPERAND(S)                        | OBJECT CODE          | BYTES  | MACHINE CYCLES | MC6800 INSTRUCTION            | MNEMONIC   | OPERAND(S)                                                                                         | OBJECT CODE                            | BYTES            | MACHINE CYCLES       | MC6800 INSTRUCTION            |
|----------|-----------------------------------|----------------------|--------|----------------|-------------------------------|------------|----------------------------------------------------------------------------------------------------|----------------------------------------|------------------|----------------------|-------------------------------|
| ADC      | DATA or a8<br>a16                 | 011aaa01<br>pp<br>qq | 2<br>3 | 2-6<br>4       | ADCA<br>ADR8 or DATA<br>ADR16 | JMP        | LABEL (x=0)<br>or (LABEL(x-1))                                                                     | 01x01100<br>ppqq                       | 3                | 3-5                  | JMP ADR16                     |
|          |                                   | 001aaa01             |        |                | ANDA                          | JSR        | LABEL                                                                                              | 20 ppqq<br>101aaa01                    | 3                | 6                    | JSR ADR16                     |
| AND      | DATA or a8<br>a16                 | 001aaa01<br>pp<br>qq | 2<br>3 | 2-6<br>4       | ADR8 or DATA<br>ADR16         | LDA        | DATA or a8<br>a16<br>DATA or                                                                       | pp<br>qq                               | 2<br>3           | 2-6<br>4             | LDAA<br>ADR8 or DATA<br>ADR16 |
|          | A                                 | 000bbb10             | 1      | 2              | ASL A                         | LDX        | ADR or ADR,Y<br>ADR16 or ADR16,Y                                                                   | 101ddd10<br>pp<br>qq                   | 2<br>3           | 2-4<br>4             | ADR8<br>ADR16 or DATA16       |
| ASL      | ADR or ADR,X<br>ADR16 or ADR16,X  | 000bbb10<br>pp<br>qq | 2<br>3 | 5-6<br>6-7     | ADR8<br>ADR16                 | DY         | DATA or<br>ADR or ADR,X<br>ADR16 or ADR16,Y                                                        | 101ddd00<br>pp<br>qq                   | 2<br>3           | 2-4<br>4             | ADR8<br>ADR16 or DATA16       |
|          |                                   |                      |        |                |                               | LSR        | A<br>ADR of ADR,X<br>ADR16 or ADR16,X                                                              | 010bbb10<br>pp<br>qq<br>EA<br>000aaa01 | 1<br>2<br>3<br>1 | 2<br>5-6<br>6-7<br>2 | LSR A<br>ADR8<br>ADR16        |
| BCC      | DISP                              | 90 pp                | 2      | 2              | BCC DISP                      | NOP        | DATA or a8<br>a16                                                                                  | pp                                     | 2                | 2-6                  | ADR8 or DATA                  |
| BCS      | DISP                              | 80 pp                | 2      | 2              | BCS DISP                      | ORA        | pp                                                                                                 | 2                                      | 2                | 4                    | ADR16                         |
| BEQ      | DISP                              | F0 pp                | 2      | 2              | BEQ DISP                      |            | qq                                                                                                 | 3                                      | 3                | 4                    |                               |
| BIT      |                                   | 0010xx00             |        |                | BITA                          |            |                                                                                                    |                                        |                  |                      |                               |
| BMI      | ADR (x=0)                         | pp                   | 2      | 3              | ADR8 or DATA                  | PHB        | 48                                                                                                 | 1                                      | 1                | 3                    |                               |
|          | ADR16 (x=-1)                      | qq                   | 3      | 4              | ADR16                         | PHP        | 08                                                                                                 | 1                                      | 1                | 3                    | PSHA                          |
| BMI      | DISP                              | 30 pp                | 2      | 2              | BMI DISP                      | PLA        | 68                                                                                                 | 1                                      | 1                | 4                    | PULA                          |
| BNE      | DISP                              | 30 pp                | 2      | 2              | BMI DISP                      | PLP<br>ROL | 28<br>001bbb10<br>ADR or ADR,X<br>ADR16 or ADR16,X                                                 | pp<br>1                                | 2                | 5-6                  | ADR8                          |
| BPL      | DISP                              | 10 pp                | 2      | 2              | BPL DISP                      |            | qq                                                                                                 | 3                                      | 3                | 6-7                  | ADR16                         |
| BRK      |                                   | 00                   | 1      | 7              | (SWI)                         | RTI        | 40                                                                                                 | 1                                      | 1                | 6                    | RTI                           |
| BVC      | DISP                              | 50 pp                | 2      | 2              | BVC DISP                      | RTS        | 60                                                                                                 | 1                                      | 1                | 6                    | RTS                           |
| BVS      | DISP                              | 70 pp                | 2      | 2              | BVS DISP                      | SBC        | 111aaa01                                                                                           |                                        |                  |                      | SBCA                          |
| CLC      |                                   | 18                   | 1      | 2              | CLC                           |            |                                                                                                    |                                        |                  |                      | ADR8 or DATA                  |
| CLD      |                                   | D8                   | 1      | 2              |                               |            |                                                                                                    |                                        |                  |                      | ADR16                         |
| CLI      |                                   | 58                   | 1      | 2              | CLI                           | SEC        | pp                                                                                                 | 2                                      | 2                | 4                    |                               |
| CLV      |                                   | B8                   | 1      | 2              | CLV                           | SED        | qq                                                                                                 | 3                                      | 3                | 2                    |                               |
| CMP      |                                   | 110aaa01             |        |                | CMPA                          | SEI<br>STA | 38<br>F8<br>(aaa=010)<br>a8<br>a16                                                                 | 1                                      | 1                | 2                    | SEC                           |
| CPX      | DATA or a8<br>a16                 | pp<br>qq             | 2<br>3 | 2-6<br>4       | ADR8 or DATA<br>ADR16         | STX        | ADR(bb=00)<br>or ADR,Y(bb=10)<br>ADR16 (bb=01)<br>ADR (bb=00)<br>or ADR,X (bb=10)<br>ADR16 (bb=01) | 100bb110                               | 2<br>3           | 3-6<br>4-5           | SEI<br>STAA<br>ADR8<br>ADR16  |
|          |                                   | 1110cc00             |        |                | CPX                           | STY        | pp<br>qq<br>100aaa01                                                                               | 100bb100                               | 2<br>3           | 3-4<br>4             | ADR8<br>ADR16                 |
| CPY      | DATA or ADR<br>ADR16              | pp<br>qq             | 2<br>3 | 2-3<br>4       | ADR8<br>DATA 16 or ADR16      | TAX        | AA<br>A8                                                                                           | 1<br>1                                 | 1                | 2                    | STX                           |
|          |                                   | 1100cc00             |        |                |                               | TAY        | BA<br>8A                                                                                           | 1<br>1                                 | 1                | 2                    | ADR8<br>ADR16                 |
| DEC      | DATA or ADR,X<br>ADR16 or ADR16,X | 110bb110             | 2      | 5-6            | DEC                           | TSX        | 9A                                                                                                 | 1                                      | 1                | 2                    | TSX                           |
|          |                                   | pp<br>qq             | 3      | 6-7            | ADR8<br>ADR16                 | TXA        | 98                                                                                                 | 1                                      | 1                | 2                    | TXS                           |
| DEX      |                                   | CA                   | 1      | 2              | DEX                           | TXS        |                                                                                                    |                                        |                  |                      |                               |
| DEY      |                                   | 88                   | 1      | 2              |                               | TYA        |                                                                                                    |                                        |                  |                      |                               |
| EOR      |                                   | 010aaa01             |        |                | EORA                          |            |                                                                                                    |                                        |                  |                      |                               |
| INC      | DATA or a8<br>a16                 | pp<br>qq             | 2<br>3 | 2-6<br>4       | ADR8 or DATA<br>ADR16         |            |                                                                                                    |                                        |                  |                      |                               |
|          |                                   | 111bb110             | 2      | 5-6            | INC                           |            |                                                                                                    |                                        |                  |                      |                               |
| JNX      | ADR or ADR,X<br>ADR16 or ADR16,X  | pp<br>qq             | 2<br>3 | 6-7            | ADR8<br>ADR16                 |            |                                                                                                    |                                        |                  |                      |                               |
|          |                                   | E8<br>C8             | 1<br>1 | 2              | INX                           |            |                                                                                                    |                                        |                  |                      |                               |

## SUPPORT DEVICES THAT MAY BE USED WITH THE MCS6500 SERIES MICROPROCESSORS

The MCS6500 and MC6800 microprocessors are similar enough for MC6800 support devices to be used with an MCS6500 series central processing unit.

The similarities between the MC6800 and MCS6500 extend also to the way in which you use other support devices with these two microprocessors. Therefore, you should read the MC6800 section in Chapter 9 that describes using the MC6800 CPU with other support devices before you read this text. Comments regarding 8080A and Z80 support devices being used with the MC6800 apply for the most part to the MCS6500.

**But the MCS6500 does have some limitations.** The most prominent limitation is the fact that no MCS6500 microprocessor floats its System Bus. Only the MCS6512 has any bus floating capability at all; you can float its Data Bus. Within an MCS6500 microcomputer system, if you wish to float the System Bus or perform direct memory access operations, you must have an external tristate buffer. This tristate buffer receives as inputs the System Bus from the MCS6500; it creates as outputs the System Bus which will be used by support devices. This may be illustrated as follows:



If you are going to use an MCS6500 CPU with support devices from other microprocessor families, you will in all probability use the MCS6502 or the MCS6512. It would make little sense to begin with the limitations of a 28-pin 6500 CPU and then expand it to interface with non-6500 support devices. We will therefore consider only MCS6502 and MCS6512 busses expanded to generate 8080A compatible interfaces. Logic may be illustrated as follows:



The logic illustrated above is quite similar to that which we described for the MC6800 in Chapter 9. The Read (RD) and Write ( $\overline{W}$ ) control signals are generated by separating out  $R/\overline{W}$  via two NAND gates that are conditioned by  $\Phi_2$  (TTL). This is the same logic that we illustrated for the MC6800.

HOLD and Bus Enable (BUSEN) signals require more complex generation out of an MCS6500 bus — but still the logic is quite simple. Since the MCS6500 has no Hold condition, we must use the Wait State created in response to a RDY input. The 7474 D-type flip-flop marked (A) synchronizes an asynchronous RDY input to ensure that it makes a high-to-low transition while  $\Phi_1$  is high, as is required by MCS6500 logic. To ensure that the synchronous Ready output does not occur during a Write cycle, the (A) flip-flop output is NANDed with  $R/\overline{W}$  to create a valid MCS6500 RDY input. We use the next high-to-low transition of  $\Phi_2$  (TTL) to identify the beginning of the Wait State. Timing may be illustrated as follows:



As illustrated by the timing above, the HOLD and BUSEN signals will accurately identify time intervals when the MCS6500 CPU is in a Wait State. But remember, busses are not floated by the MCS6500 CPU while it is in the Wait State. You must therefore use either the HOLD or BUSEN signal as a float control strobe on a tristate buffer (as illustrated earlier).

If we look at the interrupt request and acknowledge signals of the 8080A bus, the interrupt request represents no problem; we simply invert INT to create IRQ. Generating an interrupt acknowledge is not so straightforward. We must decode the second address byte of the interrupt acknowledge sequence (FFF9<sub>16</sub>) off the Address Bus, without the comfort of a valid memory address (VMA) signal. The logic shown uses the combination of  $R/\overline{W}$  high, indicating a necessary read condition, together with the initial asynchronous RDY high, indicating no Wait request, to validate the FFF9<sub>16</sub> address on the Address Bus.

Thus, a 7474 D-type flip-flop together with four NAND gates and two inverters will create an 8080A-compatible System Bus for an MCS6502 or MCS6512 CPU.

You can generate an 8080A-compatible system clock from  $\Phi_2$  (TTL) as follows:



The clock logic illustrated above is identical to that which we described for the MC6800.

## THE MCS6522 PERIPHERAL INTERFACE ADAPTER

The MCS6522 PIA is an enhanced version of the MC6820, which is also manufactured by MOS Technology as the MCS6520 Peripheral Interface Adapter. As such, the MCS6522 PIA can be used interchangeably in MC6800 or MCS6500 microcomputer systems.

This description of the MCS6522 will concentrate on highlighting device enhancements, relying on the discussion of the MC6820, given in Chapter 9, for a detailed explanation of functions common to both parts.

The MCS6522 PIA is a general purpose I/O device which, like the MC6820 PIA provides 16 I/O pins, configured as two 8-bit I/O ports. As compared to the MC6820 PIA the MCS6522 provides more handshaking logic associated with parallel data transfers occurring via I/O Port A. Counter/timer and elementary serial I/O logic have been added to MCS6522 Port B.

Figure 10-12 illustrates that part of our general purpose microcomputer system logic which has been implemented on the MCS6522 PIA.



Figure 10-12. Logic of the MCS6522 PIA

The MCS6522 PIA is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL compatible. I/O Port A and B pins are also CMOS logic compatible. I/O Port B pins may be used as a power source to directly drive the base of a transistor switch.

The device is implemented using N-channel, silicon gate MOS technology.

## THE MCS6522 PIA PINS AND SIGNALS

The MCS6522 PIA pins and signals are illustrated in Figure 10-13. Signals which are identical to the MC6820, both in function and pin assignment, are shaded.

We will summarize all signal functions, those which are unique to the MCS6522 as well as those which are common to the MC6820, before describing the various MCS6522 PIA operations which can be performed.

Consider first the various Data Busses.

D0 - D7 represents the bidirectional Data Bus via which all communications between the CPU and the MCS6522 occur. This Data Bus is identical to that of the MC6820. When the MCS6522 is not selected, the Data Bus buffer is placed in a high impedance state — which is absolutely necessary, since MCS6500 CPUs (with the exception of the MCS6512) cannot float the System Data Bus.

PA0 - PA7 and PB0 - PB7 represent Data Busses connecting I/O Ports A and B with external logic. In terms of simple data transfers, these two I/O ports are identical on the MCS6522 and MC6820 devices. In each case the 16 I/O port pins may be looked upon as 16 individual signal lines, or as two 8-bit I/O busses. Each I/O port pin can be individually assigned to input or output, but an individual pin cannot support bidirectional data transfers.

There are differences between I/O Ports A and B. Some of these differences are found in MC6800 I/O ports; others represent enhancements of the MCS6522. Let us first look at I/O port differences which are common to the MC6820 as well as the MCS6522:

- 1) An I/O Port B pin which has been assigned to output will enter a tristate condition during an input operation, this is not the case for an I/O Port A pin. This means that loads placed on I/O Port B pins will not modify data waiting to be read by the CPU.
- 2) I/O Port A pins will register logical 1 when +2V or more are input; logical 0 results from an input of +0.4V or less. I/O Port B pins will register logical 1 when power levels below +2V are input.
- 3) As outputs, I/O Port B pins may be used as a source of up to a milliampere, at +1.5V, to directly drive the base of a transistor switch. This is not feasible using I/O Port A pins.

The different I/O Port A and B characteristics are a function of port pin design.

I/O Port A pins contain "passive" pullups which are resistive and allow the output voltage to go to +5V for logic 1:



The PA pins can drive two standard TTL loads.

I/O Port B pins are push-pull devices; the pullup is switched "off" in the 0 state and "on" for a logic 1:



The pullup can source up to 3 ma at 1.5V; that is why an I/O Port B pin can drive a diode, LED or similar device.



Figure 10-13. MCS6522 PIA Signals and Pin Assignments

**Let us now look at differences between MCS6522 I/O Port A and B pins which are the result of MCS6522 logic enhancements:**

- 1) There are two programmable counters connected to I/O Port B logic. The MC6820 has no counter logic.
- 2) There is an 8-bit Shift register associated with I/O Port B logic. The Shift register provides an elementary serial I/O capability which may be adequate for certain types of control logic, but falls short of what is needed to support serial data communications. The MC6820 has no serial I/O capability whatsoever.
- 3) I/O Port A provides CA2 as an output control signal when the CPU reads or writes data. I/O Port B provides CB2 as an output control signal when the CPU writes data only.

**The MCS6522 PIA has six device select pins.**

**CS1 and CS2 are two typical select signals, exactly equivalent to MC6820 signals bearing the same names.** Note that the MCS6522 has no CS0 select. For the MCS6522 device to be selected, CS1 must receive a high input while CS2 simultaneously receives a low input.

**RS0, RS1, RS2 and RS3 address one of 16 locations within the MCS6522.** Thus an MCS6522 device will appear to a programmer as 16 memory locations. Note that the **MC6820** has only two address lines, RS0 and RS1, and appears to a programmer as four memory locations.

Addressing logic associated with the MCS6522 is, in fact, quite simple. Combining the two chip select signals, CS1 and CS2, with the four address select signals, R0, R1, R2 and R3, simply means that total device logic will be derived from six of the 16 Address Bus lines — and to the programmer, the **MCS6522 PIA will appear as 16 contiguous memory locations.** Table 10-4 identifies the 16 addressable

**MCS6522  
ADDRESSING**

locations of the MCS6522. For the moment it is not important that you understand the nature of these addressable locations; rather, let us concentrate on the select lines R<sub>0</sub> - R<sub>3</sub>. Throughout this description of the MCS6522, we are going to identify addressable locations by a label and a "select code". The "select code" consists of the signal levels given in the left-hand column of Table 10-4. To a programmer, a "select code" will simply become some index which must be added to a base address. Suppose, for example, that your interfacing logic will cause an MCS6522 to consider itself selected when any address is output in the range C000<sub>16</sub> through C00F<sub>16</sub>. Select code 0000<sub>2</sub> now corresponds to memory address C000<sub>16</sub>; select code 0111<sub>2</sub> now corresponds to memory address C007<sub>16</sub>. That is the relationship between select code and memory address.

**There are four timing and control signals which interface an MCS6522 with external logic. These four signals are CA1, CA2, CB1 and CB2. Superficially, these four signals are identical to their MC6820 equivalents. But there are some secondary differences.**

CA1 and CA2 are control signals associated with I/O Port A. CA1 is an input signal whereas CA2 is bidirectional. CB1 and CB2 are equivalent signals associated with I/O Port B, however, CB1 is bidirectional, although it is used as an input by Shift register logic only.

**There are two control signals associated with the MCS6522 CPU interface.**

$\Phi_2$  is the phase two clock which is output by any of the MCS6500 CPUs. The **MCS6522 uses  $\Phi_2$  as a standard synchronization signal, equivalent to the E signal used by the MC6820**. The trailing edge of each  $\Phi_2$  pulse synchronizes all logic and timing within the MCS6522.  $\Phi_2$  is used optionally by Shift register logic to clock serial input or output data.

**R/W is the standard read/write control signal output by all MCS6500 CPUs. This signal is identical to that on the MC6820.** Recall that when R/W is high, a read operation is specified and data transfer from the MCS6522 PIA to the CPU will occur. When R/W is low, a write operation is specified and data transfer from the CPU to the PIA will occur.

**The MCS6522 has a single interrupt request signal  $\overline{IRQ}$ . In contrast, the MC6820 has two interrupt requests  $\overline{IRQ_A}$  and  $\overline{IRQ_B}$ .** If you are simply going to wire-OR interrupt requests and connect them to the CPU  $\overline{IRQ}$  pin, then having two requests,  $\overline{IRQ_A}$  and  $\overline{IRQ_B}$ , makes no sense; combining them is preferable. On the other hand, if you are going to include any type of interrupt priority arbitration logic, such as the MC6828, then by combining  $\overline{IRQ_A}$  and  $\overline{IRQ_B}$  into a single interrupt request, you can no longer vector separately to interrupt requests arising at either I/O Port A or I/O Port B logic. You must vector a single interrupt request, arising from either of these ports; then you must execute instructions to test status bits and determine the exact interrupt source.

Table 10-4. Addressing MCS6522 Internal Registers

| LABEL | SELECT LINES<br>RS3, RS2, RS1, RS0 | ADDRESSED LOCATION                                                  |
|-------|------------------------------------|---------------------------------------------------------------------|
| DEV   | 0000                               | Output register for I/O Port B                                      |
| DEV+1 | 0001                               | Output register for I/O Port A, with handshaking                    |
| DEV+2 | 0010                               | I/O Port B Data Direction register                                  |
| DEV+3 | 0011                               | I/O Port A Data Direction register                                  |
| DEV+4 | 0100                               | Read Timer 1 Counter low-order byte                                 |
|       |                                    | Write to Timer 1 Latch low-order byte                               |
| DEV+5 | 0101                               | Read Timer 1 Counter high-order byte                                |
|       |                                    | Write to Timer 1 Latch high-order byte and initiate count           |
| DEV+6 | 0110                               | Access Timer 1 Latch low-order byte                                 |
| DEV+7 | 0111                               | Access Timer 1 Latch high-order byte                                |
| DEV+8 | 1000                               | Read low-order byte of Timer 2 and reset Counter interrupt          |
|       |                                    | Write to low-order byte of Timer 2 but do not reset interrupt       |
| DEV+9 | 1001                               | Access high-order byte of Timer 2; reset Counter interrupt on write |
| DEV+A | 1010                               | Serial I/O Shift register                                           |
| DEV+B | 1011                               | Auxiliary Control register                                          |
| DEV+C | 1100                               | Peripheral Control register                                         |
| DEV+D | 1101                               | Interrupt Flag register                                             |
| DEV+E | 1110                               | Interrupt Enable register                                           |
| DEV+F | 1111                               | Output register for I/O Port A, without handshaking                 |

**RESET** is a standard Reset input. When input low, the contents of all MCS6522 registers will be set to 0. Reset logic of the MCS6522 and MC6820 is identical.

## MCS6522 PARALLEL DATA TRANSFER OPERATIONS

Because there are significant differences between the logic associated with MCS6522 I/O Ports A and B, we will begin by examining I/O Port A operations.

When you examine I/O Port A operations, the first addressable location to look at is 0011<sub>2</sub> (DEV+3) — the I/O Port A Data Direction register. You must load a mask into this register in order to assign individual I/O port pins to input or output. A 0 in any bit of the Data Direction register will cause the corresponding I/O Port A pin to input data only. A 1 in any bit position will cause the corresponding I/O Port A pin to output data only.

**MCS6522  
I/O PORT A  
DATA TRANSFER**

You access I/O Port A, either to read or write data, via select code 0001<sub>2</sub> (DEV+1) or 1111<sub>2</sub> (DEV+F).

But before we discuss why I/O Port A has two select codes, we must describe the way in which read and write operations occur in conjunction with pins having been assigned to input or output. Read and write logic is best illustrated as follows:



Data being output is written to the I/O Output buffer; signal levels are created immediately at those I/O pins which have been declared as output pins. I/O pins which have been declared as input pins are, in effect, disconnected from the I/O Output buffer — and are in no way affected by I/O Output buffer contents.

I/O Input latches will reflect the signal level of every I/O Port A pin, whether it has been assigned to input or output; I/O Input latches will acquire I/O Port A pin levels when latched by an active transition of the CA1 control input.

For the most part, this scheme is inconsequential to you as an MCS6522 user, since whatever you write to output pins will be output, and you will read whatever external logic inputs to input pins. The only caution is that you cannot read back what you write to output pins. Latch timing and transient signal levels at output pins can modify data as it travels from I/O Output buffers to I/O Input latches.

Irrespective of whether I/O Port A pins have been assigned to input or output, control signals CA1 and CA2 can be used to provide handshaking. External logic uses CA1 to communicate with the microcomputer system; CA2 may be a control input or a control output signal.

First you must enable I/O Port A by writing a 1 into bit 0 of the Auxiliary Control register (select code 1011 or location DEV+B), which is illustrated in Figure 10-14. Next you select your CA1 and CA2 control options by writing appropriate codes into bits 0 - 3 of the Peripheral Control register, which is illustrated in Figure 10-15.

When you access I/O Port A via select code 0001<sub>2</sub> (DEV+1), then as soon as data is written into the I/O Port A buffer, the CA2 signal may output low, or it may pulse low; you determine how CA2 will respond by the code you load into the Peripheral Control register. Bits 1, 2 and 3 of the Peripheral Control register determine the way in which control signal CA2 will function. If these three bits are 100, then when you address I/O Port A via select code 0001<sub>2</sub>, CA2 will go low as soon as the I/O port is accessed:



Figure 10-14. Auxiliary Control Register Bit Assignments



Figure 10-15. Peripheral Control Register Bit Assignments

If bits 3, 2 and 1 of the Peripheral Control register contain 101, then CA2 will pulse low for one clock period when you access the I/O Port via the select code 0001<sub>2</sub>:



If bits 3, 2 and 1 of the Peripheral Control register contain any other values, CA2 will not be affected by the CPU accessing I/O Port A via select code 0001<sub>2</sub> (DEV+1).

**If CA2 makes an active transition when you access I/O Port A, then any interrupts pending for CA1 or CA2 will be cleared.**

If you access I/O Port A via the select code 1111<sub>2</sub> (DEV+F), then CA2 is unaffected, whatever Peripheral Control register bits 3, 2 and 1 contain.

Notice that bits 3, 2 and 1 of the Peripheral Control register primarily determine whether control signal CA2 will be an input or an output control. We have seen two of the output control options. The remaining two output options force CA2 to be either output high or low.

Let us look at the CA2 input options, which are also specified via Peripheral Control register bits 3, 2 and 1. If any input option has been specified, then it makes no difference whether you access I/O Port A via the select code 0001<sub>2</sub> (DEV+1) or 1111<sub>2</sub> (DEV+F); since CA2 has been specified as input control, it cannot be output low or pulsed low when you access I/O Port A.

The CA2 input options available to you are as follows:

- 1) You can specify that a CA2 input high-to-low, or low-to-high transition will generate an interrupt request.
- 2) You can specify that any interrupt pending from a CA2 active transition will, or will not be cleared when I/O Port A is accessed via the select code 0001<sub>2</sub> (DEV+1). Accessing I/O Port A via the select code 1111<sub>2</sub> (DEV+F) will never affect any pending interrupt statuses. **In Figure 10-15, CA2 "input mode" means prior CA2 active transition interrupt requests are cleared when you access I/O Port A via select code 0001<sub>2</sub> (DEV+1); no such interrupt reset occurs in "independent input" mode.**

Peripheral Control register bit 0 determines whether input control signal CA1 will generate an interrupt request on a high-to-low, or a low-to-high transition. One or the other transition will always cause an interrupt — and the only way of ignoring CA1 interrupts is to individually disable them. We will describe how this is done later when we discuss interrupt logic in general.

If you access I/O Port A via the select code 0001<sub>2</sub> (DEV+1), and you cause CA2 to output low by storing 100 in bits 3, 2 and 1 of the Peripheral Control register, then CA2 will return high again when CA1 makes its active transition. This may be illustrated as follows:



**While handshaking options available with I/O Port A may seem complex, in reality they are quite simple. For easy reference, options are summarized in Table 10-5.**

Next, consider I/O Port B.

**If you look upon I/O Port B simply as a data transfer conduit, then it is very similar to I/O Port A, simply lacking a few I/O Port A features.**

MCS6522  
I/O PORT B  
DATA TRANSFER

Like I/O Port A, I/O Port B has a Data Direction register (select code 0010<sub>2</sub> or label DEV+2), which you use to identify input and output pins. You must load a mask into this register in order to assign individual I/O port pins to input or output. A 0 in any bit of the Data Direction register will cause the corresponding I/O Port B pin to input data only. A 1 in any bit position will cause the corresponding I/O Port B pin to output data only.

Table 10-5. Summary of I/O Port A Handshaking Control Signals

| I/O Port A<br>Select<br>Code<br>(Binary) | Peripheral<br>Control<br>Register<br>Bits<br>3 2 1 0 | CONTROL SIGNALS |       | Interrupt<br>Reset                                         |
|------------------------------------------|------------------------------------------------------|-----------------|-------|------------------------------------------------------------|
|                                          |                                                      | CA1             | CA2   |                                                            |
| 0001<br>or<br>1111                       | 0 0 0 0                                              | CA1 ←           | CA2 ← | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 0 0 0 1                                              | CA1 ←           | CA2 ← | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 0 0 1 0                                              | CA1 ←           | CA2 ← | Programmed<br>reset only                                   |
| 0001<br>or<br>1111                       | 0 0 1 1                                              | CA1 ←           | CA2 ← | Programmed<br>reset only                                   |
| 0001<br>or<br>1111                       | 0 1 0 0                                              | CA1 ←           | CA2 ← | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 0 1 0 1                                              | CA1 ←           | CA2 ← | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 0 1 1 0                                              | CA1 ←           | CA2 ← | Programmed<br>reset only                                   |
| 0001<br>or<br>1111                       | 0 1 1 1                                              | CA1 ←           | CA2 ← | Programmed<br>reset only                                   |
| 0001                                     | 1 0 0 0                                              | CA1 ←           | CA2 → | At A or<br>programmed<br>reset                             |
| 1111                                     | 1 0 0 0                                              | CA1 ←           | CA2 → | Programmed<br>reset only                                   |

Table 10-5. Summary of I/O Port A Handshaking Control Signals (Continued)

| I/O Port A<br>Select<br>Code<br>(Binary) | Peripheral<br>Control<br>Register<br>Bits<br>3 2 1 0 | CONTROL SIGNALS |                   | Interrupt<br>Reset                                         |
|------------------------------------------|------------------------------------------------------|-----------------|-------------------|------------------------------------------------------------|
|                                          |                                                      | CA1             | CA2               |                                                            |
| 0001                                     | 1 0 0 1                                              | CA1 ←           | CA2 → (A)         | At (A) or<br>programmed<br>reset                           |
| 1111                                     | 1 0 0 1                                              | CA1 ←           | CA2 → (A)         | Programmed<br>reset only                                   |
| 0001                                     | 1 0 1 0                                              | CA1 ←           | CA2 → (A)         | At (A) or<br>programmed<br>reset                           |
| 1111                                     | 1 0 1 0                                              | CA1 ←           | CA2 → unaffected  | Programmed<br>reset only                                   |
| 0001                                     | 1 0 1 1                                              | CA1 ←           | CA2 → (A)         | At (A) or<br>programmed<br>reset                           |
| 1111                                     | 1 0 1 1                                              | CA1 ←           | CA2 → unaffected  | Programmed<br>reset only                                   |
| 0001<br>or<br>1111                       | 1 1 0 0                                              | CA1 ← (I)       | CA2 → (Held low)  | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 1 1 0 1                                              | CA1 ← (I)       | CA2 → (Held low)  | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 1 1 1 0                                              | CA1 ← (I)       | CA2 → (Held high) | On 0001<br>select code<br>access or<br>programmed<br>reset |
| 0001<br>or<br>1111                       | 1 1 1 1                                              | CA1 ← (I)       | CA2 → (Held high) | On 0001<br>select code<br>access or<br>programmed<br>reset |

(I) Interrupt request

(A) CPU access

You must enable I/O Port B by loading a 1 into bit 1 of the Auxiliary Control register, just as you had to enable I/O Port A.

Subsequently, you access I/O Port B via the single select code 0000<sub>2</sub>.

You have to load an appropriate code into bits 4 - 7 of the Peripheral Control register to define the way in which control signals CB1 and CB2 will operate, just as you had to load a code into bits 3 - 0 of the Peripheral Control register to define control signal CA1 and CA2 operations. The only difference between control signals CB1 and CB2, as compared to control signals CA1 and CA2, pertains to codes 100 and 101 in bits 7, 6, 5 or 3, 2, 1 of the Peripheral Control register. Code 100 causes CA2 or CB2 to output low when appropriate conditions exist, while code 101 causes the signal to pulse. For I/O Port A, "appropriate conditions" consist of the CPU reading or writing, while selecting I/O Port A via the select code 0001<sub>2</sub> (DEV+1). For I/O Port B, "appropriate conditions" consist of the CPU writing, but not reading, accessing I/O Port B via the select code 0000<sub>2</sub> (DEV) — the only select code available for I/O Port B.

I/O Port B also has a simpler interface with the CPU Data Bus. Rather than having separate output buffer and input latches, there is a single output buffer, which is accessed by the CPU when reading from, or writing to I/O Port B. Coupled with the different pin configuration, which we have already described for I/O Port B, you can guarantee that bit levels written to I/O Port B output pins will subsequently be read back accurately.

The more limited capabilities of I/O Port B reflect the fact that pins 7 and 6 of this I/O port may be used by Interval Timer logic. Thus, the MCS6522 will frequently be configured with I/O Port A providing parallel I/O, while I/O Port B provides various types of control dialogue.

## MCS6522 INTERVAL TIMER LOGIC

**The most important point to note regarding the additional functions associated with I/O Port B is that they have logical priority over simple data transfers;** what this means is that the Interval Timers and Shift register may, under some circumstances, use I/O Port B pins, control signals and interrupt logic. When Interval Timer or Shift register requirements are in conflict with simple data transfer, then Interval Timer or Shift register requirements will prevail.

Let us look at a specific example: **pins of I/O Port B are used by Interval Timer logic as follows:**



Suppose you have identified I/O Port B pin 7, via the Data Direction register, as an input pin; Interval Timer 1 uses this pin to output pulses or square waves and will override the Data Direction register.

**It is a good idea not to use I/O Port B for parallel data transfer while you are using Interval Timer or Shift register logic. Also, exercise caution when using both Interval Timers, or when using the Serial Shift register in conjunction with Interval Timers.**

Let us first examine Interval Timer 1. This is the more versatile of the two MCS6522 Interval Timers; it is most easily understood if visualized as follows:

**MCS6522  
INTERVAL  
TIMER 1**



You select from among its many functions by appropriately loading bits 7 and 6 of the Auxiliary Control register (ACR).

Interval Timer 1 addressing via select codes may be illustrated as follows:



Select codes  $0110_2$  (DEV+6) and  $0111_2$  (DEV+7) are quite straightforward. The former accesses the low order Latch byte to read or write; the latter accesses the high order Latch byte to read or write.

Select codes  $0100_2$  (DEV+4) and  $0101_2$  (DEV+5) are not so straightforward. If you access the MCS6522 PIA with select code  $0100_2$  (DEV+4), you will write into the low-order Latch byte, but you will read the contents of the low-order Counter byte.

If you access the MCS6522 PIA with select code  $0101_2$  (DEV+5), you will read the contents of the high-order Counter byte; but upon writing, you will access the high-order Latch byte and the high order Counter byte, while simultaneously transferring the low-order Latch byte contents to the low-order Counter byte. This allows a clean method of loading 16 bits of data into the Counter byte following the execution of a single instruction.

Writing to select code  $0101_2$  (DEV+5) will also initiate a new Timer interval.

The two Counter registers constitute a 16-bit entity which is decremented on the trailing edges of the  $\Phi_2$  clock pulse. The initial value loaded into the Counter registers identifies the interval of the Counter. An active time-out of the Counter is marked by an interrupt request.

If the Counter is connected to pin 7 of I/O Port B, then an active time-out will also cause the signal output at pin 7 of I/O Port B to invert or pulse low, depending on the mode in which the Interval Timer is operating.

A 1 in bit 6 of the Auxiliary Control register will connect Counter logic to pin 7 of I/O Port B. A 0 in bit 6 of the Auxiliary Control register disconnects Counter logic from pin 7.

Via bit 7 of the Auxiliary Control register, you can connect or disconnect Counter and Latch logic. A 0 in bit 7 of the Auxiliary Control register is a disconnect, whereas a 1 is a connect.

**Referring to Figure 10-14, "One-Shot Mode" refers to disconnected Latch and Counter logic, while "Free Running Mode" refers to connected Latch and Counter logic.**

If Counter logic is disconnected from the Latch registers, then following Counter initiation there will be one active time-out, after which the Counter will continuously redectrement from  $0000_{16}$  through  $FFFF_{16}$ , and back to  $0000_{16}$ . Subsequent counts are inactive — which means that no interrupt will be requested, and if connected to pin 7 of I/O Port B, no signal changes will be output.

If Counter logic is connected to the two Latch registers, then every time the Counter times out, it is immediately reloaded with the contents of the Latch registers — and begins another active time out. Under these circumstances, every Counter time out is active — and will be marked by an interrupt request, plus a signal level change at pin 7 of I/O Port B, if this pin is connected to Counter logic.

**While the Interval Timer 1 options may appear complicated, in fact they are very simple.**

**To you, as a programmer, there is only one option that you must define when using Interval Timer 1 of the MCS6522: do you want the Interval Timer to operate in one-shot or free running mode?**

**Let us first consider One-Shot Mode, which is selected by having a 0 in bit 7 of the Auxiliary Control register.**

Recall that in One-Shot Mode the Counter is disconnected from the Latch registers. For practical reasons, however, this disconnection is not complete: you have to initiate a time out by loading an initial value into the high-order and low-order Counter bytes; but the Counter is continuously running. Were you to load the low-order byte, and then the high-order byte to the Counter register, problems could arise, because the low-order byte would start decrementing before you had completed loading the high-order byte. To resolve this problem, you initially load the low-order Counter register byte value into the low-order Latch register byte; then you directly load the high-order Counter register byte. You do this by writing into the memory addresses associated with select codes  $0100_2$  (DEV+4) and  $0101_2$  (DEV+5). When you write into select code  $0100_2$  (DEV+4), you load the low-order byte of the initial Counter value into the low-order Latch register byte. When you write into select code  $0101_2$  (DEV+5), you load the high-order Latch register byte, but immediately the 16 Latch register bits are loaded into the Counter, which starts decrementing. As soon as the Counter times out, an interrupt is requested; and if, via Auxiliary Control register bit 6, you have connected I/O port pin 7 to the Counter, then a low pulse will be output via pin 7. the low pulse will have a width of one  $\Phi_2$  clock period:



MCS6522  
INTERVAL  
TIMER 1  
ONE-SHOT  
MODE

Note that when using an MCS6522, the onus is upon you to make sure that all programmable signal levels are at their correct level. In the illustration above,  $\Phi_2$  is not a programmable signal, so you can ignore it. The pin 7 level is programmable; it is up to you to make sure that a high level is being output at pin 7, or else a low pulse will not occur.

What we are saying is that Interval Timer 1 logic will not insure that pin 7 is normally outputting a high level. You must first define pin 7 as an output by writing a 0 into bit 7 of the I/O Port B Data Direction register. Then you must output a 1 to bit 7 of I/O Port B. Having thus established a continuous high level being output at pin 7; you can be sure of a low pulse marking an active time out.

Following a time out in the One-Shot Mode, the Counter decrements continuously via FFFF<sub>16</sub> to 0000<sub>16</sub>. On subsequent time outs no interrupt request occurs and no low pulse is output via pin 7 of I/O Port B.

If you have specified the free running mode by loading 1 into bit 7 of the Auxiliary Control register, then as soon as the Counter times out, Latch register contents are immediately transferred to the Counter register, which again decrements to an active time out. Thus a sequence of interrupt requests, with optional signal output via pin 7 of I/O Port B will occur — but there are some differences.

**MCS6522  
INTERVAL  
TIMER 1 FREE  
RUNNING MODE**

When using Interval Timer 1 in free running mode, you initialize exactly as you do for the one-shot mode; you load the low-order and high-order Counter bytes via select codes 0100<sub>2</sub> (DEV+4) and 0101<sub>2</sub> (DEV+5). As soon as you write into select code 0101<sub>2</sub>, the Latch contents are transferred to the Counter, which starts decrementing. While the Counter is decrementing you can reset the next Counter initial value by writing into the Latch register using select codes 0110<sub>2</sub> (DEV+6) and 0111<sub>2</sub> (DEV+7). Now as soon as the Counter times out, the new value you have loaded into the Latch register becomes the next initial Counter value.

If you have connected I/O Port B pin 7 to the Counter by storing 1 in Auxiliary Control register bit 6, then each time the Counter times out, the signal output via pin 1 of I/O Port B is inverted, generating a square wave; this may be illustrated as follows:



Remember, you can, at any time, read the contents of Interval Timer 1 Counter or Latch registers. This gives you a complete ability to test and modify Timer intervals in any way, under program control, while Interval Timer 1 is operating.

#### Now consider Interval Timer 2.

**MCS6522 Interval Timer 2 has logic which is markedly different from Interval Timer 1, which we have just described. Interval Timer 2 offers two modes of operation:**

**MCS6522  
INTERVAL  
TIMER 2**

- 1) One-shot mode with no signal output.
- 2) Pulse counting mode.

You select one of the two Interval Timer 2 options by appropriately setting bit 5 of the Auxiliary Control register, as illustrated in Figure 10-14.

One-shot mode, with no signal output, is identical in operation to one-shot mode with no signal output, as described for Interval Timer 1.

Pulse counting mode is an alternative one-shot mode; the Interval Timer 2 Counter decrements on high-to-low transitions of signal input via pin 6 of I/O Port B. Thus, in the pulse count mode, Interval Timer 2 will count out after the number of high-to-low transitions specified by the initial Counter value. For example, if you initially load 2000<sub>16</sub> into the Interval Timer 2 Counter, then after 8192 high-to-low transitions of the signal input via pin 6, an active time out will occur.

Following an active time out, an interrupt is requested. Subsequently, Interval Timer 2 continues to decrement continuously from 0000<sub>16</sub> through FFFF<sub>16</sub> and back to 0000<sub>16</sub>; on subsequent time outs however, no interrupt request is generated. Subsequent time outs are passive.

Since the logic capabilities of Interval Timer 2 differ from Interval Timer 1, as we might expect, the register organization and addressing logic associated with Interval Timer 2 also differs. It may be illustrated as follows:



Interval Timer 2 is accessed via two select codes,  $1000_2$  (DEV+8) and  $1001_2$  (DEV+9); addressing may be illustrated as follows:



Since Interval Timer 2 has no free running option, there is no need for a high order Latch register byte; the sole purpose of such a location is to store a high-order Counter byte, waiting to be loaded into the Counter register when it times out. You do need a low-order Latch register byte, because when loading the Counter register, you still have to make two accesses. You cannot load the low-order Counter byte, and then load the high-order Counter byte; the Counter is continuously decrementing and would start decrementing the low-order Counter byte while you were loading the high-order Counter byte.

The initiation procedure for Interval Timer 2, whether you are in one-shot mode or pulse counting mode, is to write the low-order Counter byte to select code  $1000_2$  (DEV+8), then the high-order Counter byte to select code  $1001_2$  (DEV+9). As soon as you write the high-order Counter byte to select code  $1001_2$  (DEV+9), Interval Timer 2 logic transfers the contents of the low-order Latch byte to the low-order Counter byte — and initiates decrementing.

If you are in one-shot mode, the Counter register is decremented on each high-to-low transition of the  $\Phi 2$  clock pulse.

If you are in pulse counting mode, the Counter decrements on each high-to-low transition of a signal input via pin 6 of I/O Port B.

That is the only difference between the two modes.

## MCS6522 SHIFTER LOGIC

MCS6522 Shifter logic may be illustrated as follows:



As illustrated above, serial data may be shifted into bit 0 or out of the Shift register bit 7. Serial data is transferred via control signal CB2.

When you shift into bit 0 the data transfer is accompanied by a one-bit left shift of the Shifter contents. When you shift out of bit 7, the data transfer is accompanied by a one-bit left rotate of the Shifter contents.

**Every serial bit data transfer is enabled by a strobe signal.** The strobe may be derived from:

- 1) A signal input by external logic via CB1.
- 2) The  $\Phi_2$  clock signal.
- 3) Interval Timer 2 active time-outs.

If the enable strobe is derived from external logic via CB1 or from  $\Phi_2$ , then the high-to-low transition of either signal triggers the enable strobe.

If the shift enable strobe is derived from Interval Timer 2, then only the low-order eight Counter bits for Interval Timer 2 are decremented.

**There are seven modes in which the Shifter can be operated;** three are input modes and four are output modes. You select an appropriate mode by the code loaded into bits 5, 4 and 3 of the Auxiliary Control register. Let us examine the response of Shifter logic to the eight possible Auxiliary Control register bit combinations.

**Mode 000; disable Shift register.** When Auxiliary Control register bits 5, 4 and 3 are 000, the Shift register is disabled. Control signals CB1 and CB2 respond as defined by bits 7, 6 and 5 of the Peripheral Control register. While the Shift register is disabled, the CPU can still write into it and read from it; you, as a programmer, can therefore use it as a storage location for a single data byte.

**Mode 001; input under Interval Timer 2 strobe.** Auxiliary Control register bits 5, 4 and 3 set to 001 specify serial data shifted in, as timed by Interval Timer 2. However, only the low-order byte of Interval Timer 2 is active, which means that 256 is the maximum initial Interval Timer 2 count which can be used. A low pulse with a width of one  $\Phi_2$  clock is output via CB1 on each Interval Timer 2 time-out, as a signal that external logic must provide the next serial data bit to be input. Interrupts are generated, as usual, following each time-out; an additional interrupt is generated after eight bits in the Shift register have been serially output.

When Interval Timer 2 is being used to strobe the Shift register in Mode 001, then it operates in a unique mode which is not available at any other time.

Whenever Interval Timer 2 times-out, the contents of the low-order Latch byte are immediately transferred to the low-order Counter byte — and decrementing resumes. Thus, Interval Timer 2 is operating in a free-running mode, with only the low-order Counter byte active. As this would imply, you must initiate Interval Timer 2 by loading the appropriate initial count into the low-order Timer 2 Latch byte — before enabling the Shift register in Mode 001. Following a time-out you can, of course, reload the Interval Timer 2 low-order Latch byte to modify the next time interval. Timing may be illustrated as follows:



Note that it is your responsibility as a programmer to ensure that all logic needed by the Shifter has been appropriately set for operations illustrated above. This means that you must program Interval Timer 2 to rederecrement following each time-out by writing a 0 into select code 10012 (DEV+9), the high-order Timer 2 Counter byte.

Since control signals CB1 and CB2 are being used by the Shift register in this mode of operation, Shift register requirements will override any CB1 and CB2 control signal specifications that have been made via bits 7, 6, 5, and 4 of the Peripheral Control register.

**Mode 010; input under  $\Phi_2$  clock strobe.** This mode is specified by 010 in bits 5, 4 and 3 of the Auxiliary Control register.

In Mode 010, and in all other Shift register modes that are clocked by  $\Phi_2$ , shifting stops on the eighth shift — which is marked by an interrupt request. Timing may be illustrated as follows:



**Mode 011; input under external pulse strobe.** This mode is specified by 011 in bits 5, 4 and 3 of the Auxiliary Control register. This mode is equivalent to the standard serial input found in most serial I/O devices, where external logic provides the clocking signal which is used to time in serial data. In this case, external logic provides a clocking signal via CB1; a high-to-low transition of CB1 is interpreted by the Shift register as a strobe to input the next serial data bit from CB2.

Timing may be illustrated as follows:



As was the case with Mode 001, shifting is continuous. So far as external logic is concerned it is shifting in an endless stream of serial data bits. Shifter logic generates an interrupt request every eighth shift so that the CPU will know when to read the contents of the Shifter. The CPU has the time interval between a Shifter interrupt and the next high-to-low transition of CB1 within which to read Shifter register contents. If the CPU does not read Shifter register contents in this time interval then an error will occur but no error status will be reported.

Shift register use of control signals CB1 and CB2 overrides specifications made for these signals via bits 7, 6, 5 and 4 of the Peripheral Control register; however, the policy of overriding adopted by the designers of the MCS6522 is somewhat subtle. Since control signal CB2 is used as a serial data input signal, any specifications made for this signal via the Peripheral Control register are totally ignored. Specifications made for control signal CB1, however, remain. If you have enabled I/O Port B via bit 1 of the Auxiliary Control register, then the active transition for control signal CB1 which is

specified by bit 4 of the Peripheral Control register will apply. Thus you will generate an interrupt whenever CB1 makes an active transition in the process of clocking in serial data. The two possibilities may be illustrated as follows:



You can disable interrupts occurring as a result of active CB1 transitions via the Interrupt Enable register, which we have yet to describe.

**Let us now look at the output modes of the Shift register.** In all output modes, the Shift register transfers the contents of bit 7 to control signal CB2. Simultaneously, bit 7 contents are shifted back into bit 0. This may be illustrated as follows:



Depending upon the serial output option you choose, CB1 may or may not be used as a companion control signal.

**Mode 100; free-running output under Interval Timer 2 strobe.** This mode is selected via 100 in bits 5, 4 and 3 of the Auxiliary Control register. Data is shifted out of Shift register bit 7, clocked by Interval Timer 2, as described for input mode 001. Data shifted out appears on CB2. Shifting is continuous, which means that the bit pattern in the Shift register will output endlessly.

**Mode 101; output under Interval Timer 2 strobe.** This mode is specified by 101 in bits 5, 4 and 3 of the Auxiliary Control register. It differs from Mode 100, which we have just described, in that once eight bits have been shifted out of the Shifter, an interrupt is requested and shifting halts.

You can output continuously under Mode 101 by making appropriate use of Shift register interrupts and Interval Timer 2. The Shift register interrupt occurs on the eighth shift out of the Shifter; but within the time it takes for Interval Timer 2 to again time-out, you can reload the Shifter. If you reload the Shifter during this time interval, then on the next time-out of Interval Timer 2, shifting will begin again, and thus become an uninterrupted bit stream on signal CB2.

**Mode 110; shift out under  $\Phi 2$  pulse.** This mode is selected via 110 in bits 5, 4 and 3 of the Auxiliary Control register. In this mode eight bits are shifted out of the Shift register, clocked by  $\Phi 2$ . Then shifting ceases.

These are the steps you must adopt when using the Shifter in Mode 110:

- 1) Disable the Shifter by loading 000 into bits 5, 4 and 3 of the Auxiliary Control register.
- 2) Load a byte of data into the Shifter. Remember the data you load will be shifted high-order bit first.
- 3) Enable the Shifter by loading 110 into bits 5, 4 and 3 of the Auxiliary Control register.
- 4) Again disable the Shifter by loading 000 into bits 5, 4 and 3 of the Auxiliary Control register.

In Mode 110, data will be shifted out on every high-to-low transition of the  $\Phi 2$  clock pulse. Thus the entire shift operation will be completed in eight clock pulses.

**Mode 111; shift out under external pulse strobe.** This mode is identical to Mode 101, except that instead of output being timed by Interval Timer 2, external logic provides the output timing pulse via control signal CB1. As was the case for input mode 011, the high-to-low transition of the external timing signal input via CB1 causes serial data to be shifted out of the Shift register. Once again, unless you have disabled CB1 interrupts via the Interrupt Enable register, the condition of bit 4 in the Peripheral Control register will cause the interrupts to be requested each time control signal CB1 makes a high-to-low or a low-to-high transition.

## MCS6522 INTERRUPT LOGIC

Interrupt logic is one of the first things you must initialize when starting to use an MCS6522. It is the last subject we describe, because in order to understand MCS6522 interrupts, you must first be aware of the numerous ways in which interrupt requests may originate within this device.

There are two addressable locations within the MCS6522 dedicated to interrupt logic:

- 1) The Interrupt Flag register, selected by  $1101_2$  (DEV+D).
- 2) The Interrupt Enable register, selected by  $1110_2$  (DEV+E).

These two registers have individual bits assigned to the different interrupt requesting sources as follows:



**The Interrupt Flag register identifies those interrupts which are active.** A 1 in any bit position indicates an active interrupt, whereas a 0 indicates an inactive interrupt.

**You can selectively enable or disable individual interrupts via the Interrupt Enable register.** You enable individual interrupts by writing to the Interrupt Enable register with a 1 in bit 7. Thus you could enable "time-out for Timer 1" and "active transitions of signal CB1" by outputting C816 to the Interrupt Enable register:



You selectively disable interrupts by writing to the Interrupt Enable register with bit 7 set to 0. Thus you would disable time-outs from Timer 1 and active transitions of signal CB1 by outputting 4816 to the Interrupt Enable register.

If an active interrupt exists in the Interrupt Flag register for an interrupt which has been enabled via the Interrupt Enable register, then bit 7 of the Interrupt Flag register will be set — and an interrupt request will be passed on to the CPU by setting IRQ low. The interrupt service routine executed in response to an interrupt request from the MCS6522 must read the contents of the Interrupt Flag register in order to determine the source of the interrupt, and thus the manner in which the interrupt must be serviced.

You can clear any bit in the Interrupt Flag register, except bit 7, by writing a 1 to that bit. Writing a 0 to a bit has no effect. Thus, if interrupt requests were being made from time-out of Timer 1 and an active transition on CA1:



Writing either 8216 or 0216 (DEV+D) to select code  $1101_2$  (DEV+D) would clear the interrupt due to an active transition on CA1 (bit 1); however, bits 7 and 6 would remain set.

There are a number of ways in which interrupt requests are automatically cleared, and the corresponding Interrupt Flag register bits get reset. These are summarized in Table 10-6.

Table 10-6. A Summary of MCS6522 Interrupt Setting and Resetting

|   | SET                                                  | CLEARED BY                                                                                                     |
|---|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| 6 | Time-out of Timer 1                                  | Reading Timer 1 Low Order Counter or writing T1 High Order Latch                                               |
| 5 | Time-out of Timer 2                                  | Reading Timer 2 Low Order Counter or writing T2 High Order Counter                                             |
| 4 | Completion of eight shifts                           | Reading or writing the Shift register                                                                          |
| 3 | Active transition of the signal on CB1               | Reading from or writing to I/O Port B                                                                          |
| 2 | Active transition of the signal on CB2 (input mode). | Reading from or writing to I/O Port B in input mode only                                                       |
| 1 | Active transition of the signal on CA1               | Reading from or writing to I/O Port A using address 0001 <sub>1</sub>                                          |
| 0 | Active transition of the Signal on CA2 (input mode)  | Reading from or writing to I/O Port A Output register (ORA) using address 0001 <sub>1</sub> in input mode only |

## THE MCS6530 MULTIFUNCTION SUPPORT LOGIC DEVICE

This is a device which appears to have been designed by MOS Technology as an answer to one-chip microcomputers.

In order to compete in low-end, high volume, price sensitive markets, MOS Technology came up with the MCS6530, which provides 1K bytes of ROM, 64 bytes of RAM, two I/O ports, a Programmable Interval Timer and interrupt logic. The realities of the MCS6530 are such that if you use the Interval Timer and interrupt logic, one of the I/O ports is only partially functional. Nevertheless, an MCS6530 multifunction support device, together with an MCS6500 series CPU, can compete effectively with the two-chip microcomputers described in this book.

If we look at the MCS6530 simply as a member of the MCS6500 microcomputer family of devices, it is best visualized as a memory device which, in addition, provides a significant subset of the MCS6522 logic capabilities.

Figure 10-16 illustrates that part of our general purpose microcomputer logic which has been implemented on the MCS6530 multifunction logic device. Figure 10-16 also applies to the MCS6532, which we will describe next.

**The MCS6530 is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL compatible. I/O Port A and B pins are also CMOS compatible. PA0 and PB0 may be used as a power source to directly drive the base of a transistor switch.**

The devices are implemented using N-channel silicon gate MOS technology.

Figure 10-17 illustrates the logic provided by an MCS6530 multifunction logic device.

### THE MCS6530 MULTIFUNCTION DEVICE PINS AND SIGNALS

The MCS6530 multifunction device pins and signals are illustrated in Figure 10-18.

These signals are identical to signals with the same names which we have already described for the MCS6522:

- D0 - D7      the bidirectional Data Bus
- Φ2            the system clock input
- R/W           the Read/Write control output by the CPU
- RESET        which is a standard reset input

I/O port pins PA0 - PA7 and PB0 - PB7 are functionally similar to equivalent I/O port pins of the MCS6522, but there are some differences.

Pin 17 may be specified, when you order the MCS6530, as IRQ only, PB7 only, or as the programmable dual function pin IRQ/PB7.

Electrical characteristics of all 16 MCS6530 I/O port pins are equivalent to MCS6522 I/O Port B pins, rather than I/O Port A pins.

**MCS6530 pins 18 and 19 may implement I/O Port B pins PB6 and PB5, or they may serve as chip select pins.** Note carefully that these are not programmable dual function pins. Each pin will either have one function or the other; and when ordering the part, you must indicate which function the pin is to serve. Pins 18 and 19 are logically independent, and the function assigned to one in no way restricts the choices available to you when assigning functions to the other pins.

If pins 18 and/or 19 have been assigned to chip select logic, then they contribute to device addressing in a unique way.

The **MCS6530 has ten address lines, A0 - A9**; this is sufficient to address 1024 bytes of ROM. In addition, the MCS6530 has 64 bytes of RAM plus assorted I/O and Interval Timer logic which needs to be addressed. RSO, CS1 and CS2 are used to discriminate between ROM addresses, RAM addresses and additional logic addresses. But there is no predefined way in which the different addressable locations of the MCS6530 will be accessed — which is only to be expected since CS1 and CS2 are not permanent features of every MCS6530 device. When RSO is high, ROM will always be selected. When RSO is low, RAM or additional logic may be accessed — and the way in which the access works is entirely up to you.

**MCS6530  
ADDRESSING  
LOGIC**



Figure 10-16. Logic of the MCS6530 and MCS6532 Multifunction Support Devices



Figure 10-17. Logic Provided by the MCS6530 Multifunction Device

RAM and additional logic each have an internal master select; and what you specify is the way in which these master selects will be derived. As you will see upon examining Table 10-7, master selects for RAM and additional logic each will consist of the following:

- 1) RS0 set to 0.
- 2) Address lines A4 - A9 with specific values which you define.
- 3) CS1 and CS2, if implemented, with specific values which you define.

As seen by a programmer, the address space of an MCS6530 can be divided in many flexible ways.



Figure 10-18. MCS6530 Multifunction Device Signals and Pin Assignments

Usually RSO will be connected to a high-order address line; let us assume it is A10, so that we can develop real examples. Now ROM will be accessed by addresses in the range 0400<sub>16</sub> through 07FF<sub>16</sub>.



RAM may respond to any 64 contiguous addresses in the range 0000<sub>16</sub> through 03FF<sub>16</sub>.

Similarly, I/O and timer logic will be selected by 16 contiguous memory addresses in the same address space.

In summary, we may illustrate addressing and select options as follows:



#### **There are a number of aspects to MCS6530 addressing which need clarification.**

First of all, you may well ask why pins 18 and 19 can optionally be assigned as additional chip select inputs. After all, with RSO low, you have more than enough address lines to access RAM plus I/O and timer logic. The purpose of having CS1 and CS2, as additional chip selects, is to allow a number of MCS6530 devices to interface with a single CPU — without requiring complex device select logic. If the additional chip select signals CS1 and CS2 are not available, you can still have more than one MCS6530 connected to a CPU, but additional support logic must selectively suppress  $\Phi_2$  for all but one MCS6530 device. Remember, RSO, R/W and the Address Bus are all signals with two active and no passive states. These signals are always selecting some MCS6530 location.

Since the whole purpose of the MCS6530 is to support very low cost, simple microcomputer configurations, the ability to minimize device select logic becomes very important.

Observe that address logic is used not only to access individual addressable locations within the MCS6530, but also to perform certain programming functions. We will describe these programming functions in greater detail later. It is interesting to note that both the MC6800 and MCS6500 microcomputer devices use address logic to provide control functions in support devices. In contrast, 8080A devices will be very spartan when it comes to device addressing, frequently having two I/O or memory addresses to access numerous different locations — with complex sequencing schemes determining how locations will be accessed.

### **MCS6530 PARALLEL DATA TRANSFER OPERATIONS**

Parallel data transfer operations, when using the MCS6530 are exactly as described for the MCS6522 I/O Port B.

Each I/O port of the MCS6530 has a Data Direction register. Into this register you load a mask which has a 1 in every bit position corresponding to an output I/O port pin and a 0 corresponding to an input I/O port pin. Subsequently the CPU reads and writes data by accessing the assigned I/O port address.

### **MCS6530 INTERVAL TIMER AND INTERRUPT LOGIC**

MCS6530 Interval Timer logic differs significantly from MCS6522 logic. The MCS6530 Interval Timer is a single 8-bit register which can be loaded with any initial value. The initial value decrements on high-to-low transitions of the  $\Phi_2$  clock pulse, or multiples of the  $\Phi_2$  clock pulse; and on decrementing to 0, an interrupt request is generated. Thus the largest time interval is generated by loading 0 into the Interval Timer register.

Table 10-7. Addressing the MCS6530 Multifunction Support Logic Device

| PRIMARY SELECT      |                |                      | ACCESSED LOCATIONS                             |   |   |   |                                                           |
|---------------------|----------------|----------------------|------------------------------------------------|---|---|---|-----------------------------------------------------------|
| RS0                 | RAM<br>SELECT* | I/O TIMER<br>SELECT* |                                                |   |   |   |                                                           |
| 1                   | X              | X                    | A0 - A9 directly address one of 1024 ROM bytes |   |   |   |                                                           |
| 0                   | 1              | 0                    | A0 - A5 directly address one of 64 RAM bytes   |   |   |   |                                                           |
| SECONDARY<br>SELECT |                |                      | INTERPRETATION                                 |   |   |   |                                                           |
| A3                  | A2             | A1                   | A0                                             |   |   |   |                                                           |
| 0                   | 0              | 1                    | X                                              | 0 | 0 | 0 | Access I/O Port A                                         |
| 0                   | 0              | 1                    | X                                              | 0 | 0 | 1 | Access I/O Port A Data Direction register                 |
| 0                   | 0              | 1                    | X                                              | 0 | 1 | 0 | Access I/O Port B                                         |
| 0                   | 0              | 1                    | X                                              | 0 | 1 | 1 | Access I/O Port B Data Direction register                 |
| 0                   | 0              | 1W                   | 0                                              | 1 | X | X | Disable IRQ                                               |
| 0                   | 0              | 1W                   | 1                                              | 1 | X | X | Enable IRQ                                                |
| 0                   | 0              | 1W                   | X                                              | 1 | 0 | 0 | Write to timer, then decrement every $\Phi_2$ pulse       |
| 0                   | 0              | 1W                   | X                                              | 1 | 0 | 1 | Write to timer, then decrement every 8 $\Phi_2$ pulses    |
| 0                   | 0              | 1W                   | X                                              | 1 | 1 | 0 | Write to timer, then decrement every 64 $\Phi_2$ pulses   |
| 0                   | 0              | 1W                   | X                                              | 1 | 1 | 1 | Write to timer, then decrement every 1024 $\Phi_2$ pulses |
| 0                   | 0              | 1R                   | X                                              | 1 | X | 0 | Read timer                                                |
| 0                   | 0              | 1R                   | X                                              | 1 | X | 1 | Read interrupt flag                                       |

\* RAM select and I/O select are "true" if 1, or "false" if 0; true and false are functions of your specification. You specify the combination of address lines that create a "true" line condition.

X represents "don't care". Bits may be 0 or 1.

1R represents Select during a read.

1W represents Select during a write.

As defined in Table 10-7, the Interval Timer has four addresses which you can use when loading an initial timer value. Each address specifies a different decrement interval. The four decrement intervals are 1, 8, 64 or 1024  $\Phi_2$  clock pulses.

Suppose the MCS6500 microcomputer system is being driven by a 500 nanosecond clock. The four decrement options mean that the Interval Timer may be decremented once every 1/2, 4, 32 or 512 microseconds. The timeout will occur anywhere from 1 to 256 decrements following the write into the Interval Timer.

Following a timeout, an interrupt will be requested. When an interrupt request occurs, the interrupt flag will be set. This flag may be read by the CPU using the address shown in Table 10-7.

The interrupt request will appear as a low level on pin 17 if the following conditions are met:

- 1) Address line A3 is 1 when reading from or writing to the timer.
- 2) PB7 has been programmed as an input by loading a 0 into bit 7 of the I/O Port B Data Direction register. (This is not necessary if the pin is factory masked to be IRQ only.)

The interrupt to pin 17 is disabled when address line A3 is 0 on a timer read or write.

The interrupt request is cleared (that is, IRQ returns high) the next time the timer is written or read.

Once the Interval Timer has timed out, it will decrement once more, from 0 back to 0. Then it will stop. Post-interrupt decrementing occurs on every  $\Phi_2$  clock cycle, regardless of whether pre-interrupt decrements occurred every 1, 8, 64 or 1024  $\Phi_2$  clock cycles.



Figure 10-19. Logic Provided by the MCS6532 Multifunction Device

## THE MCS6532 MULTIFUNCTION SUPPORT LOGIC DEVICE

This device is a variation of the MCS6530 which we have just described.

The MCS6532 provides no ROM memory, but twice the RAM — 128 bytes.

External logic can request an interrupt via the MCS6532 using a control signal which may be likened to the MCS6522 CA1 or CB1 control input.

The mask defined addressing options of the MCS6530 have been removed from the MCS6532; otherwise the balance of logic on the two devices is identical.

**Figure 10-16 also illustrates that part of our general purpose microcomputer system logic which has been implemented on the MCS6532 multifunction device. Figure 10-19 illustrates the logic functions provided by the MCS6532.**

The MCS6532 multifunction device is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL compatible. I/O Port A and B pins are also CMOS logic compatible. Pins of I/O Port B may be used as a power source to directly drive the base of a transistor switch.

The device is implemented using N-channel silicon gate MOS technology.



Figure 10-20. MCS6532 Multifunction Device Signals and Pin Assignments

## MCS6532 MULTIFUNCTION DEVICE PINS AND SIGNALS

The MCS6532 multifunction device pins and signals are illustrated in Figure 10-20. These are the only differences between MCS6532 and MCS6530 signals:

- 1) IRQ, CS1 and CS2 are assigned unique pins by the MCS6532; the MCS6530 requires you to choose individually between these three signals and the three high order bits of I/O Port B.
- 2) For the MCS6532 to be selected, RS and CS2 must be low while CS1 is high. Recall that with the MCS6530, RSO is a signal which discriminates between ROM and other addressable locations; you define the way in which CS1 and CS2, if present, will function when you order an MCS6530 part.

Addressing the MCS6532 is a good deal simpler than addressing the MCS6530, since the MCS6532 has no ROM present, and it has separate Chip Select signals. You still must define RAM select and I/O timer select as a function of RS, CS1 and CS2 and address lines A0 - A6. By connecting RS, CS1 and CS2 to higher address lines, you can assign RAM or I/O timer logic various address spaces. This ability to define RAM and I/O Timer select as a mask option is a convenience, where with the MCS6530 it was frequently a necessity. With the MCS6532 you can accept whatever standard "off-the-shelf" option is being provided, and still have enough flexibility using RS, CS1 and CS2 to include a number of MCS6532 devices in a microcomputer configuration.

**MCS6532  
ADDRESSING**

Table 10-8. Addressing the MCS6532 Multifunction Support Logic Device

| PRIMARY SELECT |                     | SECONDARY SELECT |    |    |    |    | INTERPRETATION                                            |
|----------------|---------------------|------------------|----|----|----|----|-----------------------------------------------------------|
| RAM<br>SELECT  | I/O TIMER<br>SELECT | A4               | A3 | A2 | A1 | A0 |                                                           |
| 1              | 0                   | X                | X  | X  | X  | X  | A0 - A6 directly addresses one of 128 RAM bytes.          |
| 0              | 1                   | X                | X  | 0  | 0  | 0  | Access I/O Port A.                                        |
| 0              | 1                   | X                | X  | 0  | 0  | 1  | Access I/O Port A Data Direction register                 |
| 0              | 1                   | X                | X  | 0  | 1  | 0  | Access I/O Port B.                                        |
| 0              | 1                   | X                | X  | 0  | 1  | 1  | Access I/O Port B Data Direction register                 |
| 0              | 1W                  | 1                | 0  | 1  | X  | X  | Disable IRQ                                               |
| 0              | 1W                  | 1                | 1  | 1  | X  | X  | Enable IRQ                                                |
| 0              | 1W                  | 1                | X  | 1  | 0  | 0  | Write to timer, then decrement every $\Phi_2$ pulse       |
| 0              | 1W                  | 1                | X  | 1  | 0  | 1  | Write to timer, then decrement every 8 $\Phi_2$ pulses    |
| 0              | 1W                  | 1                | X  | 1  | 1  | 0  | Write to timer, then decrement every 64 $\Phi_2$ pulses   |
| 0              | 1W                  | 1                | X  | 1  | 1  | 1  | Write to timer, then decrement every 1024 $\Phi_2$ pulses |
| 0              | 1R                  | X                | X  | 1  | X  | 0  | Read timer                                                |
| 0              | 1R                  | X                | X  | 1  | X  | 1  | Read interrupt flags                                      |
| 0              | 1W                  | 0                | X  | 1  | X  | 0  | Request interrupt on high-to-low PA7 transition           |
| 0              | 1W                  | 0                | X  | 1  | X  | 1  | Request interrupt on low-to-high PA7 transition           |
| 0              | 1W                  | 0                | X  | 1  | 0  | X  | Enable PA7 interrupt request                              |
| 0              | 1W                  | 0                | X  | 1  | 1  | X  | Disable PA7 interrupt request                             |

X represents "don't care". Bits may be 0 or 1.

1R represents Read access. 1W represents Write access.

## MCS6532 LOGIC FUNCTIONS

Table 10-8 summarizes the way in which addressing is used both to access locations within the MCS6532 and to provide various logic functions.

The only logic of the MCS6532 which differs from the MCS6530 and needs to be described is the external interrupt request capability.

External logic requests interrupts via I/O Port A pin PA7. I/O Port A pin PA7 must be declared an input pin by loading 0 into bit 7 of the I/O Port A Data Direction register. Data Direction registers have been described in conjunction with the MCS6522. A low-to-high or high-to-low transition on a signal input to PA7 will generate the interrupt request. An interrupt request will be accompanied by bit 6 of the Interrupt Flag register being set. Table 10-8 defines the way in which you select interrupt options.

MCS6532 interrupt acknowledge logic requires the CPU to read the Interrupt Flags register. This read operation resets MCS6532 interrupt logic.

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- MCS6500 Series CPUs
- MCS6530 Multifunction Device

# MCS65XX Microprocessors

## COMMON CHARACTERISTICS

### MAXIMUM RATINGS

| RATING                | SYMBOL           | VALUE        | UNIT |
|-----------------------|------------------|--------------|------|
| SUPPLY VOLTAGE        | V <sub>cc</sub>  | -0.3 to +7.0 | Vdc  |
| INPUT VOLTAGE         | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| OPERATING TEMPERATURE | T <sub>A</sub>   | 0 to +70     | °C   |
| STORAGE TEMPERATURE   | T <sub>STG</sub> | -55 to +150  | °C   |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

ELECTRICAL CHARACTERISTICS (V<sub>cc</sub> = 5.0V ± 5%, V<sub>ss</sub> = 0, T<sub>A</sub> = 25°C)

Φ<sub>1</sub>, Φ<sub>2</sub> applies to MCS6512, 13, 14, 15, Φ<sub>o</sub> (in) applies to MCS6502, 03, 04, 05 and 06

| CHARACTERISTIC                                                                                                                                                       | SYMBOL                                                                                                                                 | MIN.                                           | TYP.                         | MAX.                                           | UNIT           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------------------|------------------------------------------------|----------------|
| Input High Voltage<br>Logic, Φ <sub>o</sub> (in)<br>Φ <sub>1</sub> , Φ <sub>2</sub>                                                                                  | V <sub>IH</sub>                                                                                                                        | V <sub>ss</sub> + 2.4<br>V <sub>cc</sub> - 0.2 | -                            | V <sub>cc</sub><br>V <sub>cc</sub> + 0.25      | Vdc            |
| Input Low Voltage<br>Logic, Φ <sub>o</sub> (in)<br>Φ <sub>1</sub> , Φ <sub>2</sub>                                                                                   | V <sub>IL</sub>                                                                                                                        | V <sub>ss</sub> - 0.3<br>V <sub>ss</sub> - 0.3 | -                            | V <sub>ss</sub> + 0.4<br>V <sub>ss</sub> + 0.2 | Vdc            |
| Input High Threshold Voltage<br>RES,NMI,RDY,IRQ,Data,<br>S.O.                                                                                                        | V <sub>IHT</sub>                                                                                                                       | V <sub>ss</sub> + 2.0                          | -                            | -                                              | Vdc            |
| Input Low Threshold Voltage<br>RES,NMI,RDY,IRQ,Data,<br>S.O.                                                                                                         | V <sub>ILT</sub>                                                                                                                       | -                                              | -                            | V <sub>ss</sub> + 0.8                          | Vdc            |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25V, V <sub>cc</sub> = 0)<br>Logic (Excl.RDY,S.O.)<br>Φ <sub>1</sub> , Φ <sub>2</sub><br>Φ <sub>o</sub> (in)      | I <sub>in</sub>                                                                                                                        | -<br>-<br>-                                    | -<br>-<br>-                  | 2.5<br>100<br>10.0                             | µA<br>µA<br>µA |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4V, V <sub>cc</sub> = 5.25V)<br>Data Lines                                                      | I <sub>TSI</sub>                                                                                                                       | -                                              | -                            | 10                                             | µA             |
| Output High Voltage<br>(I <sub>LOAD</sub> = -100µAdc, V <sub>cc</sub> = 4.75V)<br>SYNC,Data,A0-A15,R/W                                                               | V <sub>OH</sub>                                                                                                                        | V <sub>ss</sub> + 2.4                          | -                            | -                                              | Vdc            |
| Output Low Voltage<br>(I <sub>LOAD</sub> = 1.6mAdc, V <sub>cc</sub> = 4.75V)<br>SYNC,Data,A0-A15, R/W                                                                | V <sub>OL</sub>                                                                                                                        | -                                              | -                            | V <sub>ss</sub> + 0.4                          | Vdc            |
| Power Dissipation                                                                                                                                                    | P <sub>D</sub>                                                                                                                         | -                                              | .25                          | .70                                            | W              |
| Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1MHz)<br>Logic<br>Data<br>A0-A15,R/W,SYNC<br>Φ <sub>o</sub> (in)<br>Φ <sub>1</sub><br>Φ <sub>2</sub> | C<br>C <sub>in</sub><br>C <sub>out</sub><br>C <sub>Φ<sub>o</sub>(in)</sub><br>C <sub>Φ<sub>1</sub></sub><br>C <sub>Φ<sub>2</sub></sub> | -<br>-<br>-<br>-<br>30<br>50                   | -<br>-<br>-<br>-<br>50<br>80 | 10<br>15<br>12<br>15<br>50<br>80               | pF             |

Note: IRQ and NMI require 3K pull-up resistors.

Data sheets on pages 10-D2 through 10-D7 reprinted by permission of MOS Technology, Inc.

## MCS65XX Microprocessors

## COMMON CHARACTERISTICS



Note: "REF." means Reference Points on clocks.

# MCS65XX Microprocessors

## 1 MHz TIMING

## 2 MHz TIMING

### Clock Timing - MCS6512, 13, 14, 15

| CHARACTERISTIC                                                  | SYMBOL                       | MIN.       | TYP. | MAX. | UNIT |
|-----------------------------------------------------------------|------------------------------|------------|------|------|------|
| Cycle Time                                                      | $T_{CYC}$                    | 1000       | ---  | ---  | nsec |
| Clock Pulse Width $\phi_1$<br>(Measured at Vcc = 0.2v) $\phi_2$ | PWH $\phi_1$<br>PWH $\phi_2$ | 430<br>470 | ---  | ---  | nsec |
| Fall Time<br>(Measured from 0.2v to Vcc = 0.2v)                 | $T_F$                        | ---        | ---  | 25   | nsec |
| Delay Time between Clocks<br>(Measured at 0.2v)                 | $T_D$                        | 0          | ---  | ---  | nsec |

### CLOCK TIMING - MCS6502, 03, 04, 05, 06

| CHARACTERISTIC                                                                                        | SYMBOL                    | MIN.                | TYP. | MAX.                | UNITS |
|-------------------------------------------------------------------------------------------------------|---------------------------|---------------------|------|---------------------|-------|
| Cycle Time                                                                                            | $T_{CYC}$                 | 1000                | --   | --                  | ns    |
| $\phi_o$ (IN) Pulse Width (measured at 1.5V)                                                          | PWH $\phi_o$              | 460                 | --   | 520                 | ns    |
| $\phi_o$ (IN) Rise, Fall Time                                                                         | TR $\phi_o$ , TF $\phi_o$ | --                  | --   | 10                  | ns    |
| Delay Time Between Clocks (measured at 1.5V)                                                          | $T_D$                     | 5                   | --   | --                  | ns    |
| $\phi_1$ (OUT) Pulse Width (measured at 1.5V)                                                         | PWH $\phi_1$              | PWH $\phi_{oL}$ -20 | --   | PWH $\phi_{oL}$     | ns    |
| $\phi_2$ (OUT) Pulse Width (measured at 1.5V)                                                         | PWH $\phi_2$              | PWH $\phi_{oH}$ -40 | --   | PWH $\phi_{oH}$ -10 | ns    |
| $\phi_1$ (OUT), $\phi_2$ (OUT) Rise, Fall Time<br>(Load = 30pf<br>(measured .8V to 2.0 V)<br>+ 1 TTL) | $T_R$ , $T_F$             | --                  | --   | .25                 | ns    |

### READ/WRITE TIMING

| CHARACTERISTIC                     | SYMBOL     | MIN. | TYP. | MAX. | UNITS |
|------------------------------------|------------|------|------|------|-------|
| Read/Write Setup Time from MCS6500 | $T_{RWS}$  | --   | 100  | 300  | ns    |
| Address Setup Time from MCS6500    | $T_{ADS}$  | --   | 100  | 300  | ns    |
| Memory Read Access Time            | $T_{ACC}$  | --   | --   | 575  | ns    |
| Data Stability Time Period         | $T_{DSU}$  | 100  | --   | --   | ns    |
| Data Hold Time - Read              | $T_{HR}$   | 10   | --   | --   | ns    |
| Data Hold Time - Write             | $T_{HW}$   | 30   | 60   | --   | ns    |
| Data Setup Time from MCS6500       | $T_{MDS}$  | --   | 150  | 200  | ns    |
| RDY, S.O. Setup Time               | $T_{RDY}$  | 100  | --   | --   | ns    |
| SYNC Setup Time from MCS6500       | $T_{SYNC}$ | --   | --   | 350  | ns    |
| Address Hold Time                  | $T_{AHA}$  | 30   | 60   | --   | ns    |
| R/W Hold Time                      | $T_{HRW}$  | 30   | 60   | --   | ns    |

### Clock Timing - MCS6512, 13, 14, 15, 16

| CHARACTERISTIC                                                  | SYMBOL                       | MIN.       | TYP. | MAX. | UNIT |
|-----------------------------------------------------------------|------------------------------|------------|------|------|------|
| Cycle Time                                                      | $T_{CYC}$                    | 500        | ---  | ---  | nsec |
| Clock Pulse Width $\phi_1$<br>(Measured at Vcc = 0.2v) $\phi_2$ | PWH $\phi_1$<br>PWH $\phi_2$ | 215<br>235 | ---  | ---  | nsec |
| Fall Time<br>(Measured from 0.2v to Vcc = 0.2v)                 | $T_F$                        | ---        | ---  | 12   | nsec |
| Delay Time between Clocks<br>(Measured at 0.2v)                 | $T_D$                        | 0          | ---  | ---  | nsec |

### CLOCK TIMING - MCS6502, 03, 04, 05, 06

| CHARACTERISTIC                                                                                        | SYMBOL                    | MIN.                | TYP. | MAX.                | UNITS |
|-------------------------------------------------------------------------------------------------------|---------------------------|---------------------|------|---------------------|-------|
| Cycle Time                                                                                            | $T_{CYC}$                 | 500                 | --   | --                  | ns    |
| $\phi_o$ (IN) Pulse Width (measured at 1.5V)                                                          | PWH $\phi_o$              | 240                 | --   | 260                 | ns    |
| $\phi_o$ (IN) Rise, Fall Time                                                                         | TR $\phi_o$ , TF $\phi_o$ | --                  | --   | 10                  | ns    |
| Delay Time Between Clocks (measured at 1.5V)                                                          | $T_D$                     | 5                   | --   | --                  | ns    |
| $\phi_1$ (OUT) Pulse Width (measured at 1.5V)                                                         | PWH $\phi_1$              | PWH $\phi_{oL}$ -20 | --   | PWH $\phi_{oL}$     | ns    |
| $\phi_2$ (OUT) Pulse Width (measured at 1.5V)                                                         | PWH $\phi_2$              | PWH $\phi_{oH}$ -40 | --   | PWH $\phi_{oH}$ -10 | ns    |
| $\phi_1$ (OUT), $\phi_2$ (OUT) Rise, Fall Time<br>(Load = 30pf<br>(measured .8V to 2.0 V)<br>+ 1 TTL) | $T_R$ , $T_F$             | --                  | --   | 25                  | ns    |

### READ/WRITE TIMING

| CHARACTERISTIC                      | SYMBOL     | MIN. | TYP. | MAX. | UNITS |
|-------------------------------------|------------|------|------|------|-------|
| Read/Write Setup Time from MCS6500A | $T_{RWS}$  | --   | 100  | .150 | ns    |
| Address Setup Time from MCS6500A    | $T_{ADS}$  | --   | 100  | 150  | ns    |
| Memory Read Access Time             | $T_{ACC}$  | --   | --   | 300  | ns    |
| Data Stability Time Period          | $T_{DSU}$  | 50   | --   | --   | ns    |
| Data Hold Time - Read               | $T_{HR}$   | 10   | --   | --   | ns    |
| Data Hold Time - Write              | $T_{HW}$   | 30   | 60   | --   | ns    |
| Data Setup Time from MCS6500A       | $T_{MDS}$  | --   | 75   | 100  | ns    |
| RDY, S.O. Setup Time                | $T_{RDY}$  | 50   | --   | --   | ns    |
| SYNC Setup Time from MCS6500A       | $T_{SYNC}$ | --   | --   | 175  | ns    |
| Address Hold Time                   | $T_{AHA}$  | 30   | 60   | --   | ns    |
| R/W Hold Time                       | $T_{HRW}$  | 30   | 60   | --   | ns    |

**MCS652X and MCS653X****MAXIMUM RATINGS**

| RATING                      | SYMBOL            | VOLTAGE     | UNIT |
|-----------------------------|-------------------|-------------|------|
| Supply Voltage              | V <sub>C</sub> C  | -.3 to +7.0 | V    |
| Input/Output Voltage        | V <sub>I</sub> N  | -.3 to +7.0 | V    |
| Operating Temperature Range | T <sub>O</sub> P  | 0 to 70     | °C   |
| Storage Temperature Range   | T <sub>S</sub> TG | -55 to +150 | °C   |

All inputs contain protection circuitry to prevent damage due to high static charges. Care should be exercised to prevent unnecessary application of voltage outside the specification range.

**ELECTRICAL CHARACTERISTICS (V<sub>C</sub>C = 5.0v ± 5%, V<sub>S</sub>S = 0v, T<sub>A</sub> = 25° C)**

| CHARACTERISTIC                                                                                                                                                                                                                                      | SYMBOL            | MIN.                                             | TYP.          | MAX.                  | UNIT     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------------------------------|---------------|-----------------------|----------|
| Input High Voltage                                                                                                                                                                                                                                  | V <sub>I</sub> H  | V <sub>S</sub> S + 2.4                           |               | V <sub>C</sub> C      | V        |
| Input Low Voltage                                                                                                                                                                                                                                   | V <sub>I</sub> L  | V <sub>S</sub> S - .3                            |               | V <sub>S</sub> S + .4 | V        |
| Input Leakage Current; V <sub>I</sub> N = V <sub>S</sub> S + 5v<br>A <sub>0</sub> -A <sub>9</sub> , RS, R/W, RES, Ø2, PB6*, PB5*                                                                                                                    | I <sub>I</sub> N  |                                                  | 1.0           | 2.5                   | µA       |
| Input Leakage Current for High Impedance State<br>(Three State); V <sub>I</sub> N = .4v to 2.4v; D <sub>0</sub> -D <sub>7</sub>                                                                                                                     | I <sub>TSI</sub>  |                                                  | ±1.0          | ±10.0                 | µA       |
| Input High Current; V <sub>I</sub> N = 2.4v<br>PA <sub>0</sub> -PA <sub>7</sub> , PB <sub>0</sub> -PB <sub>7</sub>                                                                                                                                  | I <sub>I</sub> H  | -100.                                            | -300.         |                       | µA       |
| Input Low Current; V <sub>I</sub> N = .4v<br>PA <sub>0</sub> -PA <sub>7</sub> , PB <sub>0</sub> -PB <sub>7</sub>                                                                                                                                    | I <sub>I</sub> L  |                                                  | -1.0          | -1.6                  | MA       |
| Output High Voltage<br>V <sub>C</sub> C = MIN, I <sub>LOAD</sub> ≤ -100µA(PA <sub>0</sub> -PA <sub>7</sub> , PB <sub>0</sub> -PB <sub>7</sub> , D <sub>0</sub> -D <sub>7</sub> )<br>I <sub>LOAD</sub> ≤ -3 MA (PA <sub>0</sub> , PB <sub>0</sub> )  | V <sub>O</sub> H  | V <sub>S</sub> S + 2.4<br>V <sub>S</sub> S + 1.5 |               |                       | V        |
| Output Low Voltage<br>V <sub>C</sub> C = MIN, I <sub>LOAD</sub> ≤ 1.6MA                                                                                                                                                                             | V <sub>O</sub> L  |                                                  |               | V <sub>S</sub> S + .4 | V        |
| Output High Current (Sourcing);<br>VOH ≥ 2.4v (PA <sub>0</sub> -PA <sub>7</sub> , PB <sub>0</sub> -PB <sub>7</sub> , D <sub>0</sub> -D <sub>7</sub> )<br>≥ 1.5v Available for other than TTL<br>(Darlingtions) (PA <sub>0</sub> , PB <sub>0</sub> ) | I <sub>O</sub> H  | -100<br>-3.0                                     | -1000<br>-5.0 |                       | µA<br>MA |
| Output Low Current (Sinking); VOL ≤ .4v (PA <sub>0</sub> -PA <sub>7</sub> )<br>(PB <sub>0</sub> -PB <sub>7</sub> )                                                                                                                                  | I <sub>O</sub> L  | 1.6                                              |               |                       | MA       |
| Clock Input Capacitance                                                                                                                                                                                                                             | C <sub>C</sub> lk |                                                  |               | 30                    | pF       |
| Input Capacitance                                                                                                                                                                                                                                   | C <sub>I</sub> N  |                                                  |               | 10                    | pF       |
| Output Capacitance                                                                                                                                                                                                                                  | C <sub>O</sub> UT |                                                  |               | 10                    | pF       |
| Power Dissipation                                                                                                                                                                                                                                   | P <sub>D</sub>    |                                                  | 500           | 1000                  | MW       |

\*When programmed as address pins

All values are D.C. readings

# MCS652X and MCS6536

## WRITE TIMING CHARACTERISTICS

| CHARACTERISTIC                                                                        | SYMBOL    | MIN. | TYP. | MAX. | UNIT    |
|---------------------------------------------------------------------------------------|-----------|------|------|------|---------|
| Clock Period                                                                          | $T_{CYC}$ | 1    |      | 10   | $\mu S$ |
| Rise & Fall Times                                                                     | TR, TF    |      |      | 25   | NS      |
| Clock Pulse Width                                                                     | TC        | 470  |      |      | NS      |
| R/W valid before positive transition of clock                                         | TWCW      | 180  |      |      | NS      |
| Address valid before positive transition of clock                                     | TACW      | 180  |      |      | NS      |
| Data Bus valid before negative transition of clock                                    | TDCW      | 300  |      |      | NS      |
| Data Bus Hold Time                                                                    | THW       | 10   |      |      | NS      |
| Peripheral data valid after negative transition of clock                              | TCPW      |      |      | 1    | $\mu S$ |
| Peripheral data valid after negative transition of clock driving CMOS (Level=VCC-30%) | TCMOS     |      |      | 2    | $\mu S$ |

## READ TIMING CHARACTERISTICS

| CHARACTERISTIC                                                           | SYMBOL | MIN. | TYP. | MAX. | UNIT |
|--------------------------------------------------------------------------|--------|------|------|------|------|
| R/W valid before positive transition of clock                            | TWCR   | 180  |      |      | NS   |
| Address valid before positive transition of clock                        | TACR   | 180  |      |      | NS   |
| Peripheral data valid before positive transition of clock                | TPCR   | 300  |      |      | NS   |
| Data Bus valid after positive transition of clock                        | TCDR   |      |      | 395  | NS   |
| Data Bus Hold Time                                                       | THR    | 10   |      |      | NS   |
| IRQ (Interval Timer Interrupt) valid before positive transition of clock | TIC    | 200  |      |      | NS   |

Loading = 30 pf + 1 TTL load for PA0-PA7, PB0-PB7

=130 pf + 1 TTL load for D0-D7

## MCS652X and MCS653X



WRITE TIMING CHARACTERISTICS

Figure 2



READ TIMING CHARACTERISTICS

Figure 3

# Chapter 11

## THE SIGNETICS 2650A

The 2650A is functionally identical to the 2650 microprocessor which has been described in previous editions of this book. The 2650A is a redesigned chip that is smaller and cheaper to produce than the old 2650.

The 2650A-1 is a new higher-speed version of the 2650A.

Within the frame of reference of the microcomputers being described in this book, the Signetics 2650A is a very minicomputer-like device.

The Signetics 2650A has a wealth of memory addressing modes; a large number of CPU-generated control signals are aimed at allowing TTL logic to surround the microcomputer device itself, rather than requiring a family of support devices, as do most products described in this book. However, you will have very little trouble using support devices of the 8080A with the Signetics 2650A CPU. MC6800 support devices can be used with the Signetics 2650A — but with more difficulty.

There are two support devices designed by Signetics specifically for the 2650A. They are:

- 1) **The 2656 System Memory Interface (SMI).** This is a multifunction support device that provides read-only memory, read/write memory and parallel I/O logic on a single chip.
- 2) **The 2651 Programmable Communications Interface (PCI).** This is a universal synchronous/asynchronous data communications controller.

The 2656 and 2651 are both described in Volume 3. This is because the two devices can be used as easily with a 2650A, or with any other microprocessor.

Interesting features of the 2650A, which are described on the following pages, are the imaginative use of status flags, a rich variety of very informative control signals, and the use of the second object code byte, in multibyte instructions, to encode memory addressing options.

Figure 11-1 illustrates the logical functions implemented on the 2650A CPU chip. Memory and other external logic will connect directly to the 2650A address, data and control lines, without need for interface devices (other than buffer amplifiers needed to meet signal loads).

The 2650A uses a single +5V power supply.

Using a clock with a 0.8 microsecond period, 2650A instruction execution times vary between 4.8 and 9.6 microseconds. Using a clock with a 0.5 microsecond period, instruction execution times vary between 3.0 and 6.0 microseconds.

All 2650A signals are TTL compatible.

Signetics has a second sourcing agreement with National Semiconductor, whereby National Semiconductor is supposed to second source the 2650A. At the present time it does not look as though National Semiconductor will exercise this second source option.

### THE 2650A CPU LOGIC

The 2650A CPU has a typical microcomputer organization. The Arithmetic and Logic Unit, the Control Unit and programmable registers are all implemented on the 2650A CPU.

The additions and omissions shown in Figure 11-1, as compared to typical CPU logic, need some preliminary explanation.

Although the 2650A has just one interrupt request line and one interrupt acknowledge line, CPU logic allows every interrupting device to force a vectored branch to its own unique interrupt service routine; for this reason, logic to handle interrupt requests is shown as an integral part of CPU chip logic.



Figure 11-1. Logic of the 2650A Microcomputer CPU

Standard ROM and RAM devices can be connected directly to 2650A bus lines; therefore, the 2650A is shown as providing complete memory interface logic. Note, however, that TTL load levels will almost certainly require that signal buffer amplifiers interface memory devices to the 2650A CPU.

I/O port interface logic is shown as only partially implemented on the 2650A CPU chip. A 2650A-based microcomputer system with one or two I/O ports will require no special I/O port logic; control signals allow the Data Bus to be used either as a conduit to external devices or to memory. But if a 2650A-based microcomputer system has more than two separately addressable I/O ports, external I/O port select logic must be added.

Figure 11-1 excludes clock logic from the CPU chip. The 2650A CPU does indeed require external logic to create its clock signal; however, a single TTL level clock signal with relatively lax tolerances is required. Therefore, external generation of the clock signal will be both inexpensive and free of problems.

## 2650A PROGRAMMABLE REGISTERS

In addition to a 15-bit Program Counter, the 2650A has seven 8-bit programmable registers which may be illustrated as follows:



**R0 is a primary Accumulator. This register is always accessible.**

**The remaining six 8-bit registers form two 3-register banks.** A status bit (which will be described later) is used to identify one of the two register banks as accessible at any given time. Thus, depending on the status bit setting, Registers R0, R1A, R2A and R3A may be accessible, or else Registers R0, R1B, R2B and R3B may be accessible.

|                                  |
|----------------------------------|
| <b>2650A<br/>ACCUMULATOR</b>     |
| <b>2650A INDEX<br/>REGISTERS</b> |

**The six secondary registers serve as both secondary Accumulators and Index registers.**

The 2650A has no Data Counters, as do most microcomputers; rather, it uses the minicomputer philosophy of adding an index, out of an Index register, to a memory address which is computed from information provided by every Memory Reference instruction.

**The Program Counter is 15 bits wide;** therefore up to 32,768 bytes of memory may be addressed in the normal course of events.

|                                   |
|-----------------------------------|
| <b>2650A PROGRAM<br/>COUNTER</b>  |
| <b>2650A<br/>MEMORY<br/>PAGES</b> |

**The two high-order bits of the Program Counter represent page select bits.** 2650A memory is divided into four pages with 8192 bytes of memory per page; this scheme is illustrated as follows:



Pages are selected by Branch instructions, but we will defer to the discussion of addressing modes a description of how this is done.

The 2650A has a primitive Stack, implemented on the CPU chip; this Stack is eight addresses deep, and its use is limited to storing subroutine return addresses and interrupt return addresses.

Subroutines and interrupts may therefore be combined to a nested level of eight. There are no Push and Pop type instructions, and the Stack is indexed via three bits of a Status register.

### 2650A STACK

## THE 2650A MEMORY ADDRESSING MODES

The 2650A has an extensive and versatile range of memory addressing modes.

Primary and secondary memory referencing instructions each provide two sets of addressing options, one based on program relative addressing and a two-byte instruction code, the other based on direct addressing and a three-byte instruction code. These options are referred to in Table 11-1 as the program relative addressing options and the extended addressing options.

Instructions with program relative addressing options have the following object code:

### 2650A PROGRAM RELATIVE ADDRESSING OPTIONS



In the above illustration, the second byte of the instruction code provides a program relative displacement in the range +63 to -64. The displacement is provided as a 7-bit signed binary number; bit 6 is treated as the sign bit. The high-order bit of the displacement byte specifies direct or indirect addressing.

If direct program relative addressing is specified, then the effective memory address is created by adding the 7-bit signed binary displacement to the Program Counter contents — after the Program Counter contents have been incremented. Direct and indirect program relative addressing have been described in Volume I, Chapter 6; 2650A program relative addressing differs only in the shorter displacement which is allowed.

If we are to relate the 2650A to our hypothetical microcomputer of Volume I, Chapter 7, or to any of the other microcomputers described in this book, then the task of specifying direct or indirect addressing should fall to a bit within the first object program byte. The fact that the 2650A uses a bit of the displacement byte to specify direct or indirect addressing means that, in effect, the 2650A instruction set has more than 256 object code options available to it. This feature of the 2650A allows it to have a much more powerful instruction set — in the minicomputer sense of the word — than any of the other devices described in this chapter. The price paid is that most instructions generate two or three bytes of object code. There are very few one-byte object codes. Consequently, memory utilization is not as efficient as it might initially appear to be.

In all probability, indirect, program relative addressing will be more commonly used than direct, program relative addressing. This is because microcomputer programs usually reside in read-only memory. If direct, program relative addressing is used, then data bytes must be located within 64 bytes of the memory reference instruction. That excludes having instructions in ROM and data in RAM; therefore, only unalterable constants can be addressed using program relative direct addressing.



Indirect, program relative addressing, on the other hand, only requires memory addresses to be positioned within 64 bytes of the memory reference instruction; this is illustrated as follows, using arbitrary memory addresses to make the illustration easier to understand:



Extended addressing options of the 2650A microcomputer may be illustrated as follows:

**2650A EXTENDED ADDRESSING OPTIONS**



All of the addressing options illustrated above have been described in Volume I, Chapter 6. To summarize, however, these are the addressing combinations which are allowed:

- 1) Direct addressing (absolute or program relative)
- 2) Direct indexed addressing
- 3) Direct indexed addressing with auto-increment
- 4) Direct indexed addressing with auto-decrement
- 5) Indirect addressing
- 6) Indirect addressing with post-index
- 7) Indirect addressing with post-index and auto-increment
- 8) Indirect addressing with post-index and auto-decrement

There is a small difference between indexed addressing as described in Volume I, Chapter 6, and indexed addressing as implemented by the 2650A. The 2650A memory reference instructions provide a 13-bit absolute address, which represents the full addressing range of any memory bank; an 8-bit index value is added to this displacement, as follows:



Effective address = 13-bit absolute address + 8-bit index.

If you are not clear on the difference between pre-indexed, indirect addressing and post-indexed, indirect addressing, refer again to Volume I, Chapter 6, before proceeding with this discussion of the 2650A microcomputer.

The fact that the 2650A has a 13-bit absolute address and an 8-bit index means that post-indexed, indirect addressing is very viable. The 13-bit absolute address identifies the memory location, anywhere within an 8192-byte program page, where an indirect address will be found. The indirect address becomes the base of a 256-byte table, which may be indexed via any one of the six Index registers. The Index register contents are treated as an unsigned binary number.

Now look again at indexed addressing the way it is in most microcomputers, and the way it is described in Volume I, Chapter 6. A 16-bit Index register indexes tables that are up to 65,536 bytes in length, and that is clearly ridiculous in microcomputers. The usual programming procedure, when using microcomputers that have a 16-bit Index register, is to use only the low-order byte of the Index register for indexing. The base address is created out of the high-order byte of the Index register, plus the displacement:



If the base address is created half out of an Index register and half out of a displacement, then clearly post-indexed, indirect addressing is impossible.

Any minicomputer programmer will attest to the fact that post-indexed, indirect addressing is far more useful than pre-indexed, indirect addressing.

**The 2650A has a wide variety of Branch and Branch-on-Condition instructions, which have the following object code and format:**

**2650A  
BRANCH  
INSTRUCTION  
ADDRESSING**



**Most 2650A Jump and Branch instructions are conditional; that means that only direct or indirect addressing may be used.**

**Notice that the branch direct address is 15 bits wide. Therefore, a Branch instruction may reference any byte within the maximum 32K-byte memory allowed by the 2650A.**

**Branch instructions are, in fact, the means provided by the 2650A microcomputer to select a page of memory.** The two high-order bits of a Branch instruction's direct address select an 8K-byte memory bank, which remains selected until another Branch instruction modifies the selection.

**2650A  
MEMORY  
PAGE  
SELECTION**

The 2650A has two unconditional Branch instructions. These instructions also have a 15-bit direct address; therefore, they also select a memory page. In addition to allowing direct or indirect addressing, these two instructions allow indexed addressing to be specified, as described for the extended addressing options.

Since Branch instructions specify a 15-bit direct address, in the vast majority of cases simple direct addressing will be used. Indexed addressing will be valuable only in special logic sequences, such as branch tables. Branch instructions with indirect addressing will rarely have any justifiable value.

Conditional Branch instructions use bits 0 and 1 of byte 0 to determine if a test condition has been met. The way in which these two bits are used is discussed below, along with the description of 2650A Status registers.

## THE 2650A STATUS FLAGS

**The 2650A microcomputer has two 8-bit Status registers as follows:**



**S and F represent a Sense Input bit and a Flag Output bit**, both of which are connected directly to two CPU device pins. These two bits allow one input and one output signal to directly interface external devices to the CPU, under program control.

**The Interrupt Inhibit bit is the master interrupt disable flag for the 2650A microcomputer system.**

**SP0, SP1 and SP2 constitute a 3-bit Stack Pointer.** Recall that the 2650A has a Stack eight addresses deep; the current top-of-Stack is addressed by this 3-bit Stack Pointer.

**The two Condition Codes CC1 and CC0 report the condition of a data byte as zero, positive or negative.** The zero condition represents a byte containing eight binary zeros. The positive condition represents a byte with 0 in the high-order bit. The negative condition represents a byte with 1 in the high-order bit. These Condition Codes are set following the execution of any instruction which loads a byte of data into a register or modifies the register's contents. These two Condition bits represent a minor variation of the more common technique, in which a conditional instruction tests a register's contents directly, at the time the conditional instruction is executed.

The CC1 and CC0 flags should be interpreted as follows:

| CC1 | CC0 | Interpretation              |
|-----|-----|-----------------------------|
| 0   | 0   | Zero result: 00000000       |
| 0   | 1   | Positive result: 0XXXXXXXXX |
| 1   | 0   | Negative result: 1XXXXXXXXX |
| 1   | 1   | Not significant             |

For Compare instructions, CC1 and CC0 should be interpreted as follows:

| CC1 | CC0 | Register-Register Compare | Register-Memory Compare |
|-----|-----|---------------------------|-------------------------|
| 0   | 0   | Register 0 = Register X   | Register X = Memory     |
| 0   | 1   | Register 0 > Register X   | Register X > Memory     |
| 1   | 0   | Register 0 < Register X   | Register X < Memory     |

**IDC** is a standard intermediate Carry bit, reflecting the carry out of bit 3.

**O**, the Overflow bit, and **C**, the Carry/Borrow bit, are standard Overflow and Carry statuses as described in Volume I, Chapter 2.



Figure 11-2. 2650A CPU Signals and Pin Assignments

**RS**, the Register Bank Select bit, specifies the current bank of Accumulator/Index registers: either R1A, R2A and R3A or R1B, R2B and R3B.

Recall that addition, subtraction, shift and rotate instructions optionally may or may not include the Carry status; in other words, a microcomputer may have an Add-with-Carry or an Add-without-Carry instruction; it may have a Rotate-simple or a Rotate-through-Carry instruction. **The WC bit specifies whether the Carry will or will not be included in 2650A instructions of this type. If the C status is included in a rotate, the IDC status will also be included**, operating as a branch carry out of bit 3. This is a unique 2650A feature.

**The Compare status determines whether Compare instructions will treat data as signed or unsigned binary numbers.** Consider an instruction which compares the contents of Register R0 with the contents of a memory byte. Clearly the result of the comparison will differ significantly, depending on whether the high-order bit of each byte is being interpreted as a sign bit, or whether positive numbers only are being compared. If the COM status flag is set to 1, the two bytes are assumed to be positive numbers. If the COM status is set to 0, the two bytes are assumed to contain signed binary numbers.

**The WC and COM statuses of the 2650A microcomputer are very powerful features; their significance is that they double the available number of Arithmetic and Compare instructions, respectively, without increasing the number of instruction object codes.**

## THE 2650A CPU PINS AND SIGNALS

The 2650A CPU pins and signals are illustrated in Figure 11-2. A description of these signals will highlight the underlying philosophy of the 2650A chip design: that this device can be used with standard off-the-shelf TTL logic, rather than requiring a family of support devices. There are applications where the Signetics philosophy is viable and will work; there are other applications where the specialized devices provided by Signetics and other microcomputer manufacturers cannot be reproduced at equivalently low cost.

**The Address Bus is 13 lines wide;** it is used to address a single byte within 8192 bytes of memory. The low-order eight address lines may also be used to address an external device.

**A13 and A14 are page select lines.** As described in the discussion of addressing modes, only Branch instructions provide 15-bit memory addresses. When a Branch instruction is executed, the two high-order bits of the address, output on pins 18 and 19, are used by external memory to select or deselect 8K memory pages. Subsequent memory reference instructions that provide only a 13-bit memory address will reference the most recently selected 8K memory bank. This may be illustrated as follows:



**Control lines of the 2650A microcomputer may be grouped into categories as follows:**

- 1) CPU execution control
- 2) Data and Address Bus access control
- 3) Data and Address Bus contents identification
- 4) Interrupt processing
- 5) Direct, external device interface

**CPU execution control signals, being of primary importance, will be discussed first.**

**2650A CPU EXECUTION CONTROL SIGNALS**

**CLOCK** is the master timing signal required by the 2650A CPU. Depending upon the way in which external logic is implemented, CLOCK may or may not be needed by other devices that surround the 2650A; in most cases CLOCK will not be needed by other devices, since system control will normally be handled by 2650A control inputs and outputs.

**RESET** is the master reset input which every microcomputer has. As is standard for most microcomputers, when the CPU is reset, the Program Counter is cleared, with the result that the instruction stored in memory location 0 is executed. The CPU will typically be reset when first powered up.

**PAUSE** causes the CPU to enter a Wait state. PAUSE is an input signal which may be used by external direct memory access logic to stop the CPU while memory is being accessed. The Halt instruction also causes the CPU to enter the Wait state. A Wait state will be terminated by a Reset or by external logic removing its PAUSE input.

**There are two bus access control signals on the 2650A: DBUSEN and ADREN. These two signals float the Data and Address Busses, respectively.** On the Address Bus, only the 13 Address Bus lines A0 - A12 are floated; the two page select lines A13 and A14 are not floated.

**2650A BUS ACCESS CONTROL SIGNALS**

The most interesting feature of 2650A control signals is the scheme employed for identifying events on the Data and Address Busses.

**2650A BUS CONTENTS IDENTIFICATION SIGNALS**

The inception of any operation which will involve external devices is identified by OPREQ going high.

Normally, the first step in any operation that involves external logic is for an address to be output on the Address Bus. If memory is being accessed, then M/IO is output high. R/W is output high to identify a write operation or low to identify a read operation. As soon as memory has responded to the memory read or write operation, it inputs OPACK low. If OPACK low does not arrive in time for the CPU to continue processing the current instruction at the next clock cycle, then the CPU temporarily enters the Wait state and outputs RUN/WAIT low to indicate this condition. Now as soon as OPACK is input low, the Wait state will end and the CPU will continue execution.

The CPU will also output a write strobe, WRP, when writing to memory. This strobe is output when data is steady on the Data Bus.

When an I/O device is being accessed by one of the I/O instructions, M/IO is output low. You will see in Table 11-1 that the 2650A instruction set includes two sets of I/O instructions: one set does not identify an I/O port, and has a one-byte object code; the other set identifies an I/O port via a second byte of object code. Let us assume that the short I/O instructions will always reference I/O Port 0, while the long I/O instructions will specify one of 256 I/O ports. The E/NE signal, if low, identifies a short I/O instruction, therefore an instruction which accesses I/O Port 0; if high, this signal indicates that the current contents of the low-order eight address lines contain an I/O port address, and should be so decoded. In fact, the I/O port which is selected by a short I/O instruction can be defined by you. You can look upon E/NE as a signal which, when low, is a unique select line. When high, E/NE identifies the low-order eight Address Bus lines as providing the I/O port address. Thus, you can generate I/O port select logic as follows:



Once an I/O port has been selected, and external logic knows from the M/IO and E/NE controls which I/O port is selected, I/O logic needs to know whether an input or output I/O operation is to occur, and whether data or control/status information is to be transmitted. (Volume I, Chapter 5 discusses at length the difference between data, controls and status.) The R/W control indicates whether data is being transmitted from the CPU to external devices, or whether external devices are supposed to transmit data to the CPU; then D/C identifies the output as either data or control information. Conversely, when R/W identifies the CPU as requiring input from an I/O device, D/C indicates whether the input should be data or status.

**When external device logic responds to the I/O request, it concludes by inputting OPACK low.** Figure 11-3 illustrates how control signals may be used to interpret events on the Address and Data Busses.

**2650A interrupt handling is very straightforward. An interrupt is requested by setting INTREQ low. The interrupt is acknowledged by the CPU outputting INTACK high.**

**The SENSE and FLAG signals allow the 2650A to directly control external devices.** The condition of a SENSE input is immediately translated into a 0 or 1 within the Sense bit of the 2650A Status register. A 0 or 1 in the Flag bit of the 2650A Status register is immediately reflected by a low or high signal output at the Flag pin.

## INTERFACING MEMORY TO THE 2650A MICROCOMPUTER



**Given the wealth of control signals provided by the 2650A microcomputer, most types of memory can be interfaced with very little difficulty.** The only peculiarity of the 2650A which external logic must be able to cope with is the fact that memory is paged into 8192-byte pages. Any memory device whose addressing range is smaller than a page must have select logic which takes into account not only high-order address lines on the 13-line Address Bus but, in addition, the two page select lines. The two page select lines change status occasionally when a new page is being selected; therefore, page select must be stored in an external buffer.

The 2650A CPU also expects to receive an OPACK acknowledgement from memory. If memory can respond to an access within the allowed time, then you can simply tie OPACK to ground for all memory accesses. I/O accesses must still be able to respond with a high or low OPACK, depending upon prevailing conditions. Here is appropriate logic:



I/O OPACK is normally low. I/O logic drives OPACK high at the beginning of an I/O access if the I/O device requires extra time to respond to OPREQ.

The OPACK input during memory access operations is equivalent to the 8080A READY input. You should refer to the extensive discussion of the 8080A READY input given in Chapter 4 in order to find ways of using OPACK logic in a 2650A microcomputer system.

## INTERFACING I/O DEVICES TO THE 2650A MICROCOMPUTER

**The simplest way of interfacing external devices to the 2650A microcomputer is to use the microcomputer's I/O instructions, plus the control signals which identify I/O operations.**

A very small microcomputer system may only have one I/O port. In this case the I/O port can connect directly to the Data Bus and can always consider itself selected. A larger system may have up to 257 8-bit ports, with select lines that simply connect to the Data Bus and use E/NE as a select enable signal.

## THE 2650A MICROCOMPUTER INTERRUPT PROCESS

**The 2650A has a single interrupt request line and a single interrupt acknowledge line. Interrupt priorities will therefore be handled via a daisy chain.**

**When the CPU acknowledges an interrupt, first it disables all further interrupts. Next, it pushes the contents of the Program Counter onto the address Stack and zeros the Program Counter.**

**The CPU will now insert the first byte of a ZBSR instruction code into the Instruction register; this instruction code is a Branch-to-Subroutine using program relative addressing. The interrupting device must submit a byte of data on the Data Bus, which will be interpreted as the second byte of the ZBSR instruction.**



Figure 11-3. How Control Signals Identify Address and Data Bus Use for the 2650A Microcomputer

Look again at the discussion of 2650A addressing modes and you will see that with the Program Counter set to 0, the byte of data input by the interrupting device becomes a displacement vector.

Assume that each external device has the beginning address of its interrupt service routine stored somewhere within the first 64 bytes of the zero memory page. The interrupting device must input the following byte of data:



This byte of data causes an indirect program relative jump to the interrupting device's interrupt service routine, as follows:



## 2650A MICROCOMPUTER DIRECT MEMORY ACCESS

Direct memory access in a 2650A system is left up to external logic. Two schemes are possible.

External logic may stop the CPU, using the PAUSE input; while the CPU is disabled, external logic may take control of Data and Address Busses to access memory in any way.

Alternatively, DMA logic may be implemented to operate in parallel with the CPU. The 2650A has periods when both the Data Bus and the Address Bus are floated. Handling DMA in parallel with normal instruction execution is made possible if you combine the OPREQ and OPACK handshake signals with normal timing sequences.

The only economical way of handling direct memory access in a 2650A microcomputer system is to use one of the direct memory access control devices described in Volume 3. Timing requirements are given with the discussions of these devices. The flexibility of the 2650A System Bus is such that you will have very little difficulty generating an interface with any of these direct memory access control parts.

## THE 2650A MICROCOMPUTER INSTRUCTION SET

The 2650A microcomputer instruction set is the most minicomputer-like of the microcomputers discussed in this book. It is particularly rich in addressing modes and memory reference instructions. The instruction set is listed in Table 11-1.

Memory reference instructions are shown as offering program relative addressing options or extended addressing options. See the discussion of 2650A addressing options for a definition of these terms.

Note that in the statuses column, CC identifies the CCO and CC1 statuses. These two statuses are used to test for a zero, positive or negative branch condition; these two statuses are described along with the 2650A Status registers.

The TMI Immediate Operate instruction compares a register's contents with a mask provided by the instruction operand. This instruction allows any bit combination to be tested for, in any CPU register.

The Decimal Adjust (DAR) instruction of the 2650A differs from the instructions with the same name as implemented on a number of other microcomputers. The Decimal Adjust instruction can be used to perform binary decimal arithmetic. Referring to the discussion of binary decimal arithmetic given in Volume I, the 2650A DAR instruction performs Step 3 of the binary-coded-decimal addition operation described in Chapter 3.

## THE 2650A BENCHMARK PROGRAM

This is how the 2650A may implement our benchmark program:

|         |             |                                            |
|---------|-------------|--------------------------------------------|
| LODA,R1 | TLENGTH     | LOAD DISPLACEMENT TO FIRST FREE TABLE BYTE |
| LODA,R2 | IOBFL       | LOAD I/O BUFFER FILLED LENGTH              |
| LOOP    | LODA,R0     | LOAD NEXT I/O BUFFER BYTE                  |
|         | *IOBUF,R2   |                                            |
|         | STR,A,R0    | STORE IN TABLE, AUTO-INCREMENT R1          |
|         | *TABLE,R1,+ |                                            |
|         | BDRR,R2     | DECREMENT R2, RETURN TO LOOP ON NON-ZERO   |
|         | LOOP        |                                            |
|         | STRA,R1     | AT END, RESTORE NEW TABLE LENGTH           |
|         | TLENGTH     |                                            |

The benchmark program, as illustrated for the 2650A, assumes that both the data table and the I/O buffer have maximum lengths of 256 bytes.

The displacement to the first free byte of the data table is stored in a memory location identified by the label TLENGTH.

The number of filled I/O buffer bytes is stored in a memory location identified by the label IOBFL. It is assumed that the I/O buffer can be read backwards; in other words, the last I/O buffer byte becomes the first byte stored in the permanent data table.

The instruction with label LOOP begins by loading the last byte in the I/O buffer, using indirect, indexed addressing without auto-increment or auto-decrement. Subsequently, Index Register R2 is decremented; if it does not decrement to 0, execution returns to the instruction labeled LOOP.

The instruction which stores data in TABLE uses indirect, post-indexed addressing, with the contents of Index Register R1 auto-incremented. Thus, at the conclusion of data movement, Index Register R1 contains the displacement to the next free byte of TABLE.

Comparing the 2650A benchmark program with other benchmark programs shown in this book might suggest that the 2650A has the shortest, and therefore the fastest and most efficient benchmark program. This is not necessarily the case. Certainly the 2650A instruction set provides a source program which is likely to be shorter than any other microcomputer's source program, but that is because instructions are very minicomputer-like. The number of bytes required to implement the 2650A object program, and the time taken to execute the program, may bear no relationship to the length of the source program. For example, the program loop, although it contains only three instructions (LODA, STRA and BDRR), will require eight bytes of object program.

Once again, we caution against drawing fast conclusions from benchmark programs.

The following symbols are used in Table 11-1:

\*ADDR(X) 16-bit extended addressing mode:



- \* 1 for indirection
- (X) 00 for non-indexed
- 01 for indexed with auto-increment
- 10 for indexed with auto-decrement
- 11 for indexed only

ADDR 13-bit absolute address

\*BADD 16-bit absolute addressing mode:



- \* 1 for indirection
- BADD 15-bit absolute address

C Carry status

|                       |                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CC                    | The two Condition Code bits CC1 and CC0                                                                                                                                                                                                                                                                                                                                             |
| CC1                   |                                                                                                                                                                                                                                                                                                    |
| CIDC                  | The Carry and Inter-Digit Carry                                                                                                                                                                                                                                                                                                                                                     |
| C                     |                                                                                                                                                                                                                                                                                                    |
| dataNE                | The non-extended data port                                                                                                                                                                                                                                                                                                                                                          |
| DATA2                 | 2-bit data unit                                                                                                                                                                                                                                                                                                                                                                     |
| DATA8                 | 8-bit data unit                                                                                                                                                                                                                                                                                                                                                                     |
| *DISP                 | 8-bit relative addressing mode:<br> <ul style="list-style-type: none"><li>* DISP</li><li>* 1 for indirection</li></ul> DISP      7-bit signed displacement                                                                                                                                         |
| EAA                   | Effective address generated by *BADD                                                                                                                                                                                                                                                                                                                                                |
| EAD                   | Effective address generated by *ADDR(X)                                                                                                                                                                                                                                                                                                                                             |
| EAR                   | PC relative address generated by *DISP                                                                                                                                                                                                                                                                                                                                              |
| IDC                   | Inter-Digit Carry status                                                                                                                                                                                                                                                                                                                                                            |
| O                     | Overflow status                                                                                                                                                                                                                                                                                                                                                                     |
| P                     | An 8-bit port number                                                                                                                                                                                                                                                                                                                                                                |
| PC                    | Program Counter                                                                                                                                                                                                                                                                                                                                                                     |
| PSU                   | Upper byte of Program Status Word                                                                                                                                                                                                                                                                                                                                                   |
| PSL                   | Lower byte of Program Status Word                                                                                                                                                                                                                                                                                                                                                   |
| r                     | One of the seven CPU registers                                                                                                                                                                                                                                                                                                                                                      |
| RAS(SP)               | The Return Address Stack location indicated by the Stack Pointer                                                                                                                                                                                                                                                                                                                    |
| R0                    | Accumulator                                                                                                                                                                                                                                                                                                                                                                         |
| SP                    | Stack Pointer                                                                                                                                                                                                                                                                                                                                                                       |
| status NE             | The Non-Extended status port                                                                                                                                                                                                                                                                                                                                                        |
| ZEA                   | A zero page relative address generated by DISP                                                                                                                                                                                                                                                                                                                                      |
| x<y,z>                | Bits y through z of the quantity x; for example, R0<3,0> represents the lower 4 bits of the Accumulator.                                                                                                                                                                                                                                                                            |
| [ ]                   | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If an I/O port number is enclosed within the brackets, then the I/O contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified. |
| [[ ]]                 | Implied memory addressing; the contents of the memory location designated by the contents of a register.                                                                                                                                                                                                                                                                            |
| $\wedge$              | Logical AND                                                                                                                                                                                                                                                                                                                                                                         |
| $\vee$                | Logical OR                                                                                                                                                                                                                                                                                                                                                                          |
| $\neq$                | Logical Exclusive-OR                                                                                                                                                                                                                                                                                                                                                                |
| $\leftarrow$          | Data is transferred in the direction of the arrow                                                                                                                                                                                                                                                                                                                                   |
| $\longleftrightarrow$ | Data is exchanged between the two locations designated on either side of the arrow.                                                                                                                                                                                                                                                                                                 |

Under the heading of STATUSES in Table 11-1, an X indicates statuses which are modified in the course of the instruction's execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

Table 11-1. Summary of Signetics 2650A Instruction Set

| TYPE                                              | MNEMONIC | OPERAND(S)  | BYTES | STATUSES |   |     |    |   | OPERATION PERFORMED                                                                             |
|---------------------------------------------------|----------|-------------|-------|----------|---|-----|----|---|-------------------------------------------------------------------------------------------------|
|                                                   |          |             |       | C        | O | IDC | CC |   |                                                                                                 |
| I/O                                               | REDD     | ,r          | 1     |          |   |     | X  |   | [r]—[dataNE]<br>Read data at non-extended port into specified register.                         |
|                                                   | REDC     | ,r          | 1     |          |   |     | X  |   | [r]—[statusNE]<br>Read non-extended status into specified register.                             |
|                                                   | REDE     | ,r P        | 2     |          |   |     | X  |   | [r]—[P]<br>Read into specified register from Port P.                                            |
|                                                   | WRTD     | ,r          | 1     |          |   |     |    |   | [dataNE]—[r]<br>Write specified register contents to non-extended data port.                    |
|                                                   | WRTC     | ,r          | 1     |          |   |     |    |   | [statusNE]—[r]<br>Write specified register contents to non-extended status port.                |
|                                                   | WRTE     | ,r P        | 2     |          |   |     |    |   | [P]—[r]<br>Write specified register contents to Port P.                                         |
| PRIMARY MEMORY<br>REFERENCE                       | LODR     | ,r *DISP    | 2     |          |   |     | X  |   | [r]—[EAR]<br>Load specified register from relative location.                                    |
|                                                   | LODA     | ,r *ADDR(X) | 3     |          |   |     | X  |   | [r]—[EAD]<br>Load specified register from extended location.                                    |
|                                                   | STRR     | ,r *DISP    | 2     |          |   |     |    |   | [EAR]—[r]<br>Store specified register contents in relative location.                            |
|                                                   | STRA     | ,r *ADDR(X) | 3     |          |   |     |    |   | [EAD]—[r]<br>Store specified register contents in extended location.                            |
| SECONDARY<br>MEMORY REFERENCE<br>(MEMORY OPERATE) | ADDR     | ,r *DISP    | 2     | X        | X | X   | X  |   | [r]—[r] + [EAR]<br>Add contents of relative location to specified register.                     |
|                                                   | ADDA     | ,r *ADDR(X) | 3     | X        | X | X   | X  |   | [r]—[r] + [EAD]<br>Add contents of extended location to specified register.                     |
|                                                   | SUBR     | ,r *DISP    | 2     | X        | X | X   | X  |   | [r]—[r] - [EAR]<br>Subtract contents of relative location from specified register.              |
|                                                   | SUBA     | ,r *ADDR(X) | 3     | X        | X | X   | X  |   | [r]—[r] - [EAD]<br>Subtract contents of extended location from specified register.              |
|                                                   | ANDR     | ,r *DISP    | 2     |          |   |     |    | X | [r]—[r] A [EAR]<br>AND contents of relative location with those of specified register.          |
|                                                   | ANDA     | ,r *ADDR(X) | 3     |          |   |     |    | X | [r]—[r] A [EAD]<br>AND contents of extended location with those of specified register.          |
|                                                   | IORR     | ,r *DISP    | 2     |          |   |     |    | X | [r]—[r] V [EAR]<br>OR contents of relative location with those of specified register.           |
|                                                   | IORA     | ,r *ADDR(X) | 3     |          |   |     |    | X | [r]—[r] V [EAD]<br>OR contents of extended location with those of specified register.           |
|                                                   | EORR     | ,r *DISP    | 2     |          |   |     |    | X | [r]—[r] V [EAR]<br>Exclusive-OR contents of relative location with those of specified register. |
|                                                   | EORA     | ,r *ADDR(X) | 3     |          |   |     |    | X | [r]—[r] V [EAD]<br>Exclusive-OR contents of extended location with those of specified register. |

Table 11-1. Summary of Signetics 2650A Instruction Set (Continued)

| TYPE                                                          | MNEMONIC | OPERAND(S)  | BYTES | STATUSES |   |     |    |  | OPERATION PERFORMED                                                                                                                                                                                                                                    |
|---------------------------------------------------------------|----------|-------------|-------|----------|---|-----|----|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                               |          |             |       | C        | O | IDC | CC |  |                                                                                                                                                                                                                                                        |
| SECONDARY MEMORY<br>REFERENCE (MEMORY<br>OPERATE) (CONTINUED) | COMR     | ,r *DISP    | 2     |          |   |     | X  |  | If [r] > [EAR]; then CC = 01<br>If [r] = [EAR]; then CC = 00<br>If [r] < [EAR]; then CC = 10<br>Compare contents of relative location with those of specified register; set the CC accordingly.                                                        |
|                                                               | COMA     | ,r,*ADDR(X) | 3     |          |   |     | X  |  | If [r] > [EAD]; then CC = 01<br>If [r] = [EAD]; then CC = 00<br>If [r] < [EAD]; then CC = 10<br>Compare contents of extended location with those of specified register; set the CC accordingly.                                                        |
| IMMEDIATE                                                     | LODI     | ,r DATA8    | 2     |          |   |     | X  |  | [r]—DATA8<br>Load immediate into specified register.                                                                                                                                                                                                   |
| IMMEDIATE OPERATE                                             | ADDI     | ,r DATA8    | 2     | X        | X | X   | X  |  | [r]—[r] + DATA8<br>Add immediate to specified register contents.                                                                                                                                                                                       |
|                                                               | SUBI     | ,r DATA8    | 2     | X        | X | X   | X  |  | [r]—[r] - DATA8<br>Subtract immediate from specified registers contents.                                                                                                                                                                               |
|                                                               | ANDI     | ,r DATA8    | 2     |          |   |     | X  |  | [r]—[r] $\wedge$ DATA8<br>AND immediate with specified register contents.                                                                                                                                                                              |
|                                                               | IORI     | ,r DATA8    | 2     |          |   |     | X  |  | [r]—[r] V DATA8<br>OR immediate with specified register contents.                                                                                                                                                                                      |
|                                                               | EORI     | ,r DATA8    | 2     |          |   |     | X  |  | [r]—[r] $\vee$ DATA8<br>Exclusive-OR immediate with specified register contents.                                                                                                                                                                       |
|                                                               | COMI     | ,r DATA8    | 2     |          |   |     | X  |  | If [r] > DATA8; [CC]—01.<br>If [r] = DATA8; [CC]—00<br>If [r] < DATA8; [CC]—10                                                                                                                                                                         |
|                                                               | TMI      | ,r DATA8    | 2     |          |   |     | X  |  | Compare immediate with specified register; set the CC accordingly.<br>If all selected bits are set, CC = 00; otherwise CC = 10<br>Test bits in specified register corresponding to 1s in immediate data. If all tested bits are 1s set CC accordingly. |
| JUMP                                                          | ZBRR     | *DISP       | 2     |          |   |     |    |  | [PC]—ZEA<br>Branch to zero page address.                                                                                                                                                                                                               |
|                                                               | BXA      | *BADD       | 3     |          |   |     |    |  | [PC]—EAA<br>Branch to extended address.                                                                                                                                                                                                                |
|                                                               | ZBSR     | *DISP       | 2     |          |   |     |    |  | [SP]—[SP] + 1<br>[RAS(SP)]—[PC] + 2<br>[PC]—ZEA<br>Call zero page subroutine.                                                                                                                                                                          |
|                                                               | BSXA     | *BADD       | 3     |          |   |     |    |  | [SP]—[SP] + 1<br>[RAS(SP)]—[PC] + 3<br>[PC]—EAA<br>Call extended subroutine.                                                                                                                                                                           |

Table 11-1. Summary of Signetics 2650A Instruction Set (Continued)

| TYPE                          | MNEMONIC | OPERAND(S)   | BYTES | STATUSES |   |     |    |  | OPERATION PERFORMED                                                                                                                                  |
|-------------------------------|----------|--------------|-------|----------|---|-----|----|--|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               |          |              |       | C        | O | IDC | CC |  |                                                                                                                                                      |
| BRANCH ON CONDITION           | BCTR     | ,DATA2 *DISP | 2     |          |   |     |    |  | If DATA2 = CC, then [PC]—EAR<br>Branch relative if DATA2 equals CC.                                                                                  |
|                               | BCTA     | ,DATA2 *DISP | 3     |          |   |     |    |  | If DATA2 = CC, then [PC]—EAA<br>Branch absolute if DATA2 equals CC.                                                                                  |
|                               | BCFR     | ,DATA2 *DISP | 2     |          |   |     |    |  | If DATA2 ≠ CC, then [PC]—EAR                                                                                                                         |
|                               | BCFA     | ,DATA2 *BADD | 3     |          |   |     |    |  | Branch relative if DATA2 is not equal to CC.<br>If DATA2 ≠ CC, then [PC]—EAA                                                                         |
|                               | BIRR     | ,r *DISP     | 2     |          |   |     |    |  | Branch absolute if DATA2 is not equal to CC.<br>[r]—[r] + 1<br>If [r] ≠ 0, [PC]—EAR                                                                  |
|                               | BIRA     | ,r *BADD     | 3     |          |   |     |    |  | Increment specified register. If nonzero result, branch relative.<br>[r]—[r] + 1<br>If [r] ≠ 0, then [PC]—EAA                                        |
|                               | BDRR     | ,r *DISP     | 2     |          |   |     |    |  | Increment specified register. If nonzero result, branch absolute.<br>[r]—[r] - 1<br>If [r] ≠ 0, then [PC]—EAR                                        |
|                               | BDRA     | ,r *BADD     | 3     |          |   |     |    |  | Decrement specified register. If nonzero result, branch relative.<br>[r]—[r] - 1<br>If [r] ≠ 0; then [PC]—EAA                                        |
|                               | BRNR     | ,r *DISP     | 2     |          |   |     |    |  | Decrement specified register. If nonzero result, branch absolute.<br>If [r] ≠ 0; then [PC]—EAR<br>If specified register is nonzero, branch relative. |
|                               | BRNA     | ,r *BADD     | 3     |          |   |     |    |  | If [r] ≠ 0; then [PC]—EAA<br>If specified register is nonzero, branch absolute.                                                                      |
| CONDITIONAL SUBROUTINE BRANCH | BSTR     | ,DATA2,*DISP | 2     |          |   |     |    |  | If DATA2 = CC; then [SP]—[SP] + 1<br>[RAS(SP)]—[PC] + 2<br>[PC]—EAR<br>If DATA2 equals CC, then call subroutine at relative address.                 |
|                               | BSTA     | ,DATA2 *BADD | 3     |          |   |     |    |  | If DATA2 = CC; then [SP]—[SP] + 1<br>[RAS(SP)]—[PC] + 3<br>[PC]—EAA<br>If DATA2 equals CC, then call subroutine at absolute address.                 |
|                               | BSFR     | ,DATA2 *DISP | 2     |          |   |     |    |  | If DATA2 ≠ CC; then [SP]—[SP] + 1<br>[RAS(SP)]—[PC] + 2<br>[PC]—EAR<br>If DATA2 not equal to CC, then call subroutine at relative address.           |
|                               | BSFA     | ,DATA2 *BADD | 3     |          |   |     |    |  | If DATA2 ≠ CC; then [SP]—[SP] + 1<br>[RAS(SP)]—[PC] + 3<br>[PC]—EAA<br>If DATA2 not equal to CC, call subroutine at absolute address.                |

Table 11-1. Summary of Signetics 2650A Instruction Set (Continued)

| TYPE                                         | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |     |    |  | OPERATION PERFORMED                                                                                                                                                                                            |
|----------------------------------------------|----------|------------|-------|----------|---|-----|----|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              |          |            |       | C        | O | IDC | CC |  |                                                                                                                                                                                                                |
| CONDITIONAL SUBROUTINE<br>BRANCH (CONTINUED) | BSNR     | ,r *DISP   | 2     |          |   |     |    |  | If '[r] ≠ 0; then [SP]←[SP]+1<br>[RAS(SP)]←[PC]+2<br>[PC]←EAR<br>If specified register is nonzero, call subroutine at relative address.                                                                        |
|                                              | BSNA     | ,r *BADD   | 3     |          |   |     |    |  | If '[r] ≠ 0; then [SP]←[SP]+1<br>[RAS(SP)]←[PC]+3<br>[PC]←EAA<br>If specified register is nonzero, call subroutine at absolute address.                                                                        |
|                                              | RETC     | ,DATA2     | 1     |          |   |     |    |  | If DATA2 = CC, then [PC]←[RAS(SP)]<br>[SP]←[SP]-1<br>If DATA2 equals CC, then return from subroutine.                                                                                                          |
| REGISTER-<br>REGISTER MOVE                   | LODZ     | r          | 1     |          |   | X   |    |  | [R0]←[r]<br>Load Accumulator (Register 0) with specified register contents.                                                                                                                                    |
|                                              | STRZ     | r          | 1     |          |   | X   |    |  | [r]←[R0]<br>Store contents of Accumulator (Register 0) into specified register.                                                                                                                                |
| REGISTER-REGISTER OPERATE                    | ADDZ     | ,r         | 1     | X        | X | X   | X  |  | [R0]←[R0]+[r]<br>Add specified register to Register 0.                                                                                                                                                         |
|                                              | SUBZ     | ,r         | 1     | X        | X | X   | X  |  | [R0]←[R0]-[r]<br>Subtract specified register from Register 0.                                                                                                                                                  |
|                                              | ANDZ     | ,r         | 1     |          |   | X   |    |  | [R0]←[R0] ∧ [r]<br>AND specified register with Register 0.                                                                                                                                                     |
|                                              | IORZ     | ,r         | 1     |          |   | X   |    |  | [R0]←[R0] V [r]<br>OR specified register with Register 0.                                                                                                                                                      |
|                                              | EORZ     | ,r         | 1     |          |   | X   |    |  | [R0]←[R0] ∨ [r]<br>Exclusive-OR specified register with Register 0.                                                                                                                                            |
|                                              | COMZ     | ,r         | 1     |          |   | X   |    |  | If [R0] > [r]; then CC = 01<br>If [R0] = [r]; then CC = 00<br>If [R0] < [r]; then CC = 10<br>Compare specified register with Register 0; set the CC accordingly.                                               |
| REGISTER OPERATE                             | RRL      | ,r         | 1     | X        | X | X   | X  |  |  <p>Or</p>  <p>WC = 0</p> <p>WC = 1</p> |

If WC is 0, rotate the specified register left. If WC is 1, rotate through Carry and Intermediate Carry.

Table 11-1. Summary of Signetics 2650A Instruction Set (Continued)

| TYPE                         | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |     |    |  | OPERATION PERFORMED                                                                                                                                             |
|------------------------------|----------|------------|-------|----------|---|-----|----|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |          |            |       | C        | O | IDC | CC |  |                                                                                                                                                                 |
| REGISTER OPERATE (CONTINUED) | RRR      | ,R         | 1     | X        | X | X   | X  |  | <p>If WC is 0, rotate the specified register right. If WC is 1, rotate through Carry and Intermediate Carry.</p>                                                |
|                              | DAR      | ,R         | 1     |          |   |     |    |  | Decimal adjust the specified register.                                                                                                                          |
| INTERRUPT                    | RETE     | ,DATA2     | 1     |          |   |     |    |  | <p>If DATA2 = CC; then [PC]—[RAS(SP)]<br/> [SP]—[SP]-1<br/> Enable interrupts</p> <p>If DATA2 equals CC, then return from subroutine and enable interrupts.</p> |
| STATUS                       | LPSU     |            | 1     |          |   |     |    |  | [PSU]—[R0]<br>Load Register 0 into PSU.                                                                                                                         |
|                              | LPSL     |            | 1     |          |   |     |    |  | [PSL]—[R0]<br>Load Register 0 into PSL.                                                                                                                         |
|                              | SPSU     |            | 1     |          |   |     |    |  | [R0]—[PSU]<br>Load PSU into Register 0.                                                                                                                         |
|                              | SPSL     |            | 1     |          |   |     |    |  | [R0]—[PSL]<br>Load PSL into Register 0.                                                                                                                         |
|                              | PPSU     | DATA8      | 2     |          |   |     |    |  | If [DATA8<1>]=1; then [PSU<1>]—1<br>Set bits in PSU which correspond to 1s in immediate data.                                                                   |
|                              | PPSL     | DATA8      | 2     |          |   |     |    |  | If [DATA8<1>]=1; then [PSL<1>]—1<br>Set bits in PSL which correspond to 1s in immediate data.                                                                   |
|                              | CPSU     | DATA8      | 2     |          |   |     |    |  | If [DATA8<1>]=1 then [PSU<1>]—0<br>Clear bits of PSU which correspond to 1s in immediate data.                                                                  |
|                              | CPSL     | DATA8      | 2     |          |   |     |    |  | If [DATA8<1>]=1 then [PSL<1>]—0<br>Clear bits of PSL which correspond to 1s in immediate data.                                                                  |
|                              | TPSU     | DATA8      | 2     |          |   | X   |    |  | If DATA8 = [PSU], then CC = 00; else CC = 10.<br>Compare immediate with PSU; set CC accordingly.                                                                |
|                              | TPSL     | DATA8      | 2     |          |   | X   |    |  | If DATA8 = [PSL], then CC = 00; else CC = 10.<br>Compare immediate with PSL; set CC accordingly.                                                                |
|                              | NOP      |            | 1     |          |   |     |    |  | No Operation.                                                                                                                                                   |
|                              | HALT     |            | 1     |          |   |     |    |  | Processor enters Wait.state.                                                                                                                                    |

Table 11-2. Signetics 2650A Instruction Object Codes

| INSTRUCTION      | OBJECT CODE                | BYTES | MACHINE CYCLES | INSTRUCTION            | OBJECT CODE                            | BYTES | MACHINE CYCLES |
|------------------|----------------------------|-------|----------------|------------------------|----------------------------------------|-------|----------------|
| ADDA,r *ADDR(X)  | 100011aa<br>bccqqqqq<br>QQ | 3     | 4              | COMA,r *ADDR(X)        | 111011aa<br>bccqqqqq<br>QQ             | 3     | 4              |
| ADDI,r DATA8     | 100001aa<br>PP             | 2     | 2              | COMI,r DATA8           | 111001aa<br>PP                         | 2     | 2              |
| ADDR,r *DISP     | 100010aa<br>beeeeeee       | 2     | 3              | COMR,r *DISP           | 111010aa<br>beeeeeee                   | 2     | 3              |
| ADDZ,r           | 100000aa                   | 1     | 2              | COMZ,r DATA8           | 111000aa<br>75                         | 1     | 2              |
| ANDA,r *ADDR(X)  | 010011aa<br>bccqqqqq<br>QQ | 3     | 4              | CPSL DATA8             | PP                                     | 2     | 3              |
| ANDI,r DATA8     | 010001aa<br>PP             | 2     | 2              | CPSU DATA8             | 74<br>PP                               | 2     | 3              |
| ANDR,r *DISP     | 010010aa<br>beeeeeee       | 2     | 3              | DAR,r                  | 100101aa<br>001011aa                   | 1     | 3              |
| ANDZ,r           | 010000aa                   | 1     | 2              | EORA,r *ADDR(X)        | bccqqqqq<br>QQ                         | 3     | 4              |
| BCFA,DATA2 *BADD | 100111ff<br>bqqqqqqq<br>QQ | 3     | 3              | EORI,r DATA8           | 001001aa<br>PP                         | 2     | 2              |
| BCFR,DATA2 *DISP | 100110ff<br>beeeeeee       | 2     | 3              | EORR,r *DISP           | 001010aa<br>beeeeeee                   | 2     | 3              |
| BCTA,DATA2 *BADD | 000111ff<br>bqqqqqqq<br>QQ | 3     | 3              | EORZ,r HALT            | 001000aa<br>40                         | 1     | 2              |
| BCTR,DATA2,*DISP | 000110ff<br>beeeeeee       | 2     | 3              | IORA,r *ADDR(X)        | 011011aa<br>bccqqqqq<br>QQ             | 3     | 4              |
| BDRA,r *BADD     | 111111aa<br>bqqqqqqq<br>QQ | 3     | 3              | IORI,r DATA8           | 011001aa<br>PP                         | 2     | 2              |
| BDRR,r *DISP     | 111110aa<br>beeeeeee       | 2     | 3              | IORR,r *DISP           | 011010aa<br>beeeeeee                   | 2     | 3              |
| BIRA,r *BADD     | 110111aa<br>bqqqqqqq<br>QQ | 3     | 3              | IORZ,r LODA,r *ADDR(X) | 011000aa<br>000011aa<br>bccqqqqq<br>QQ | 1     | 2              |
| BIRR,r *DISP     | 110110aa<br>beeeeeee       | 2     | 3              | LODI,r DATA8           | 000001aa<br>PP                         | 2     | 2              |
| BRNA,r *BADD     | 010111aa<br>bqqqqqqq<br>QQ | 3     | 3              | LODR,r *DISP           | 000010aa<br>beeeeeee                   | 2     | 3              |
| BRNR,r *DISP     | 010110aa<br>beeeeeee       | 2     | 3              | LODZ,r                 | 000000aa<br>LPSL                       | 1     | 2              |
| BSFA,DATA2 *BADD | 101111ff<br>bqqqqqqq<br>QQ | 3     | 3              | LPSU                   | 93                                     | 1     | 2              |
| BSFR,DATA2 *DISP | 101110ff<br>beeeeeee       | 2     | 3              | NOP                    | 92                                     | 1     | 2              |
| BSNA,r *BADD     | 011111aa<br>bqqqqqqq<br>QQ | 3     | 3              | PPSL DATA8             | 77<br>PP                               | 1     | 2              |
| BSNR,r *DISP     | 011110aa<br>beeeeeee       | 2     | 3              | PPSU DATA8             | 76<br>PP                               | 2     | 3              |
| BSTA,DATA2 *BADD | 001111ff<br>bqqqqqqq<br>QQ | 3     | 3              | REDC,r                 | 001100aa<br>REDD,r                     | 1     | 2              |
| BSTR,DATA2 *DISP | 001110ff<br>beeeeeee       | 2     | 3              | REDE,r P               | 010101aa<br>PP                         | 2     | 3              |
| BSXA *BADD       | BF<br>bqqqqqqq<br>QQ       | 3     | 3              | RETC,DATA2             | 000101ff<br>RETE,DATA2                 | 1     | 3              |
| BXA *BADD        | 9F<br>bqqqqqqq<br>QQ       | 3     | 3              | RRL,r                  | 110100aa<br>RRR,r                      | 1     | 2              |
|                  |                            |       |                | SPSL                   | 13                                     | 1     | 2              |
|                  |                            |       |                | SPSU                   | 12                                     | 1     | 2              |
|                  |                            |       |                | STRA,r *ADDR(X)        | 110011aa<br>bccqqqqq<br>QQ             | 3     | 4              |
|                  |                            |       |                | STRR,r *DISP           | 110010aa<br>beeeeeee                   | 2     | 3              |
|                  |                            |       |                | STRZ,r                 | 110000aa                               | 1     | 2              |

Table 11-2. Signetics 2650A Instruction Object Codes (Continued)

| INSTRUCTION     | OBJECT CODE                | BYTES | MACHINE CYCLES | INSTRUCTION | OBJECT CODE | BYTES          | MACHINE CYCLES |   |
|-----------------|----------------------------|-------|----------------|-------------|-------------|----------------|----------------|---|
| SUBA,r *ADDR(X) | 101011aa<br>bccqqqqq<br>QQ | 3     | 4              | TPSU        | DATA8       | B4<br>PP       | 2              | 3 |
| SUBI,r DATA8    | 101001aa<br>PP             | 2     | 2              | WRTC,r      |             | 101100aa       | 1              | 2 |
| SUBR,r *DISP    | 101010aa<br>beeeeeee       | 2     | 3              | WRTD,r      |             | 111100aa       | 1              | 2 |
| SUBZ,r          | 101000aa                   | 1     | 2              | WRTE,r      | P           | 110101aa<br>PP | 2              | 3 |
| TMI,r DATA8     | 111101aa<br>PP             | 2     | 3              | ZBRR        | *DISP       | 9B<br>beeeeeee | 2              | 3 |
| TPSL            | DATA8<br>B5<br>PP          | 2     | 3              | ZBSR        | *DISP       | BB<br>beeeeeee | 2              | 3 |

The following symbols are used in Table 11-2:

- aa Two bits which, in conjunction with the Register Bank Select bit in the PSL, choose the register
- b One bit selecting the indirection option
- cc Two bits choosing the indexing mode:
  - 00 No indexing
  - 01 Indexing with auto-increment
  - 10 Indexing with auto-decrement
  - 11 Indexing only
- eeeeeee 7-bit signed address displacement
- ff 2-bit test value
- PP eight bits of immediate data
- q One bit of absolute or extended address
- Q One byte (eight bits) of absolute or extended address

## SUPPORT DEVICES THAT MAY BE USED WITH THE 2650A MICROPROCESSOR

Interfacing the 2650A with 8080A support devices is very straightforward. Figure 11-4 shows how 8080A control signals may be generated from 2650A control signals. Figure 11-5 provides the same information for the MC6800.

But there are some ambiguities not immediately apparent when you look at Figure 11-4. To begin with, the 2650A uses a request/acknowledge handshaking control protocol which is alien to an 8080A-based system. Thus OPACK, which is shown creating RDYIN in Figure 11-4, may well be grounded in a configuration that is not going to insert Wait states into 2650A instruction execution cycles. OPREQ will be used as a contributor to the chip select logic of 8080A support devices. M/I/O, which is shown discriminating between memory and I/O control signals in Figure 11-4, may alternatively be used as a contributor to chip select logic. Figures 11-6 through 11-9 illustrate 8251 and 8255 devices connected to a 2650A CPU, being selected within memory or I/O spaces. Note that where devices are selected within the 2650A I/O space, C/D could be generated from the 2650A C/D control output rather than using address line ADRO.

Figure 11-10 shows how 2650A priority interrupts may be generated using an 8214 Priority Interrupt Control Unit.

Interfacing MC6800 support devices to a 2650A CPU is again complicated by the synchronizing signal required by MC6800 support devices. But the 2650A is flexible enough to make this interface possible.

We must use OPREQ in order to generate the synchronizing enable signal for MC6800 support devices. Unfortunately, there is a significant variation in the leading edge of OPREQ. Therefore, logic to create an ENABLE synchronizing signal must have the following three parts:

- 1) Create a continuous clock signal to substitute for the MC6800 ENABLE synchronizing signal.
- 2) Make sure that during a write cycle MC6800 device select logic is true across one pulse of the ENABLE signal. Chip select logic must be true from shortly before the beginning of the ENABLE signal positive transition until shortly after the end of the negative transition.

- 3) During a read cycle, again make sure that chip select logic for the MC6800 support device is valid for one ENABLE cycle only; but this time stretch the ENABLE true pulse so that the 2650A CPU can latch the data on the negative transition of OPREQ before ENABLE goes low.

**Timing for the above three conditions is illustrated in Figure 11-11.** But note that since the minimum cycle time for MC6800 support devices is 1 microsecond, the 2650A CPU must also operate at this frequency — rather than using a 0.8 microsecond clock, which is the fastest allowed.

**Figure 11-12 illustrates a 2650A-6850 ACIA interface. Figure 11-13 illustrates a 2650A-6820 PIA interface.**

Important aspects of 2650A interface timing are defined in Figure 11-14.



Figure 11-4. 2650A-8080A Signal Equivalents



Figure 11-5. 2650A-MC6800 Signal Equivalents



Figure 11-6. An 8251 USART Accessed by a 2650A as an I/O Device



Figure 11-7. An 8251 USART Accessed by a 2650A as a Memory Device



Figure 11-8. An 8255 PPI Accessed by a 2650A as an I/O Device



Figure 11-9. An 8255 PPI Accessed by a 2650A as a Memory Device



Figure 11-10. Vectored Interrupt Using the 8214 PICU with a 2650A CPU



Figure 11-11. Synchronization Circuits in a 2650A-MC68XX Interface



Figure 11-12. An MC6850 ACIA Connected to a 2650A



Figure 11-13. An MC6820 PIA Connected to a 2650A



- 1) MC68XX latches data internally on negative transition.
  - 2) Processor latches data on the negative transition of OPREQ; thereafter LOR and EN go to zero (but NOT before).
- \*OPREQ can make a transition any time within this 600 nsec. region.

Figure 11-14. Important Timing Considerations When Interfacing a 2650A CPU with MC68XX Series Devices

## **DATA SHEETS**

This section contains specific electrical and timing data for the 2650A.

# 2650A, 2650A-1

## PRELIMINARY SPECIFICATION

### ABSOLUTE MAXIMUM RATINGS<sup>1</sup>

| PARAMETER                                                               | RATING      | UNIT |
|-------------------------------------------------------------------------|-------------|------|
| T <sub>A</sub> Operating temperature                                    | 0 to 70     | °C   |
| T <sub>TSG</sub> Storage temperature                                    | -65 to +150 | °C   |
| P <sub>D</sub> Package power dissipation <sup>2</sup>                   | 1.6         | W    |
| All input, output, and supply voltages with respect to GND <sup>3</sup> | -5 to +6    | V    |

### DC ELECTRICAL CHARACTERISTICS T<sub>A</sub> = 0°C to 70°C, V<sub>CC</sub> = 5V ± 5%.

| PARAMETER                            | TEST CONDITIONS                               | LIMITS |     |      | UNIT |
|--------------------------------------|-----------------------------------------------|--------|-----|------|------|
|                                      |                                               | Min    | Typ | Max  |      |
| I <sub>IL</sub> Current              |                                               |        |     | 10   | µA   |
| I <sub>LOH</sub> Input load          | V <sub>IN</sub> = 0 to 5.25V                  |        |     | 10   |      |
| I <sub>LOL</sub> Output high leakage | ADREN, DBUSEN = 2.2V V <sub>OUT</sub> = 4V    |        |     | 10   |      |
| I <sub>OL</sub> Output low leakage   | ADREN, DBUSEN = 2.2V V <sub>OUT</sub> = 0.45V |        |     | 10   |      |
| V <sub>IH</sub> Voltage levels       |                                               |        |     |      |      |
| I <sub>VL</sub> Input high           |                                               | 2.2    |     |      |      |
| V <sub>IL</sub> Input low            |                                               | -0.5   |     |      |      |
| V <sub>OH</sub> Output high          | I <sub>OH</sub> = -100µA                      | 2.4    |     |      | V    |
| V <sub>OL</sub> Output low           | I <sub>OL</sub> = 1.6mA                       | 0.0    |     | 0.45 |      |
| I <sub>CC</sub> Power supply current | V <sub>CC</sub> = 5.25V T <sub>A</sub> = 0°C  |        |     | 150  |      |
| C <sub>IN</sub> Capacitance          |                                               |        |     | 10   | mA   |
| C <sub>OUT</sub> Input               | V <sub>IN</sub> = 0V                          |        |     | 10   |      |
|                                      | V <sub>OUT</sub> = 0V                         |        |     | 10   | pf   |

#### NOTES

1. Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operation sections of this specification is not implied.
2. For operating at elevated temperatures the device must be derated based on +150°C maximum junction temperature and thermal resistance of 50°C/W junction to ambient (40 pin I<sup>W</sup> package).
3. This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. However, it is suggested that conventional precautions be taken to avoid applying any voltages larger than the rated maxima.
4. Parameters valid over operating temperature range unless otherwise specified.
5. All voltage measurements are referenced to ground.
6. Preliminary specification.
7. Manufacturer reserves the right to make design and process changes and improvements.

We reprint data sheets on pages 11-D2 through 11-D6 by permission of Signetics Corporation.

**2650A, 2650A-1**

## PRELIMINARY SPECIFICATION

**AC ELECTRICAL CHARACTERISTICS**  $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{CC} = +5V \pm 5\%$ .

| PARAMETER   |                                           | LIMITS       |                          | UNIT                     |
|-------------|-------------------------------------------|--------------|--------------------------|--------------------------|
|             |                                           | Min          | Max                      |                          |
| $T_{AH}$    | Address hold<br>2650A-1<br>2650A          | 180<br>220   | -                        | ns                       |
| $T_{AS}$    | Address stable                            | 50           | -                        | ns                       |
| $T_{ABD}$   | Address bus delay                         | -            | 180                      | ns                       |
| $T_{DH}$    | Data out hold<br>2650A-1<br>2650A         | 160<br>200   | -                        | ns                       |
| $T_{DIS}$   | Data in stable                            | -            | $2T_{CH} + T_{CL} - 200$ | ns                       |
| $T_{DS}$    | Data stable                               | 50           | -                        | ns                       |
| $T_{DIH}$   | Data in hold                              | 50           | -                        | ns                       |
| $T_{DBD}$   | Data bus delay                            | -            | 150                      | ns                       |
| $T_{CH}$    | Clock high phase<br>2650A-1<br>2650A      | 250<br>400   | -                        | ns                       |
| $T_{CL}$    | Clock low phase<br>2650A-1<br>2650A       | 250<br>400   | -                        | ns                       |
| $T_{CP}$    | Clock period<br>2650A-1<br>2650A          | 500<br>800   | -                        | ns                       |
| $T_{PC(5)}$ | Processor cycle time<br>2650A-1<br>2650A  | 1500<br>2400 | -                        | ns                       |
| $T_{OPR}$   | OPREQ pulse width?                        |              | $2T_{CH} + T_{CL}$       | $2T_{CH} + T_{CL} + 100$ |
| $T_{COR}$   | Clock to OPREQ time<br>2650A-1<br>2650A   | 100<br>150   | 200<br>300               | ns                       |
| $T_{OSD}$   | OPREQ signal delay                        | -            | 230                      | ns                       |
| $T_{OAD}$   | OPACK delay time                          | 0            | -                        | ns                       |
| $T_{OAS}$   | OPACK setup time                          | 50           | -                        | ns                       |
| $T_{OAH}$   | OPACK hold time                           | 50           | -                        | ns                       |
| $T_{CSS}$   | Control signal stable<br>2650A-1<br>2650A | 100<br>100   | 400<br>500               | ns                       |
| $T_{CSA}$   | Control signal available                  | 200          | -                        | ns                       |
| $T_{WPD}$   | Write pulse delay<br>2650A-1<br>2650A     | 100<br>100   | 200<br>300               | ns                       |
| $T_{WPW}$   | Write pulse width?                        |              | $T_{CH} - 100$           | $T_{CH} + 150$           |
| $T_{IRS}$   | INTREQ set up time                        | -            | 150                      | ns                       |
| $T_{IRH}$   | INTREQ hold time                          | 0            | -                        | ns                       |
| $T_{CSD}$   | Control signal delay                      | -            | 180                      | ns                       |

## NOTES

1. Input levels swing between 0.80 and 2.2 volts.
2. Input signal transition times are 20ns.
3. Timing reference level is 1.5 volts.
4. Output load is  $-100 \mu\text{A}$  at 100pf and 1 TTL load.
5. Processor cycle time consists of three clock periods.
6. Output buffer rise time is 150ns maximum.
7. These values assume that OPACK is returned in time to not cause the processor to idle. Otherwise, the specified maximum will increase by an internal number of clock cycles.

# 2650A, 2650A-1

## PRELIMINARY SPECIFICATION



# 2650A, 2650A-1

## PRELIMINARY SPECIFICATION

© ADAM OSBORNE & ASSOCIATES, INCORPORATED



# 2650A, 2650A-1

## PRELIMINARY SPECIFICATION



## Chapter 12 THE RCA COSMAC

We are going to describe the single-chip CPU referred to as the CDP1802. This is a one-chip implementation of the previous two-chip CPU, consisting of the CDP1801 and CDP18101.

COSMAC is a "low end" microprocessor; it is well suited to simple, high-volume applications with limited programming needs. As compared to many other microprocessors described in this book, COSMAC is a poor choice for low-volume, program intensive applications; this is because COSMAC is relatively difficult to program optimally.

But where does the transition from a simple application to a complex application occur? For COSMAC, it is sudden — an application either is or is not suited to COSMAC, with very little grey area.

**The principal advantage of COSMAC is that it requires very little power, since it is fabricated using CMOS technology. If your application is going to be battery powered for any length of time, CMOS logic is strongly favored.** In addition, if speed is not essential in your application, then power consumption can be further reduced by using a lower clock frequency. The advent of one-chip microcomputers has clouded the previously clear-cut power supply advantage associated with CMOS technology. **There are occasions when a multi-chip COSMAC (or IM6100) microcomputer system, even though it is all CMOS, will use approximately the same amount of power as a single-chip NMOS microcomputer;** the single-chip microcomputer will be capable of doing the same job. **Before immediately assuming that your application demands CMOS technology for power supply purposes, it is worth checking the power supply requirements of an equivalent NMOS one-chip microcomputer.**

Both the power and the inflexibility of COSMAC are based on a subtly clever use of CPU logic, coupled with a somewhat primitive interface between CPU and external memory. Providing you can accommodate all "program housekeeping" using CPU registers for your read/write memory, COSMAC is a superb microprocessor. "Program housekeeping" includes maintaining the program and data memory address required by subroutines, interrupts, and data accesses in general. A large class of microprocessor applications fit these restrictions and are well suited to COSMAC.

Devices described in this chapter include the CDP1802 Central Processing Unit and the CDP1852 8-bit input/output port. There is also a CMOS Universal Asynchronous Receiver/Transmitter (UART) — the CDP1854 device. This part is described in Volume 3.

COSMAC is fabricated using CMOS technology. It operates with a single power supply and is very insensitive to noise. The power supply can vary between +3V and +12V.

CMOS technology also results in COSMAC having a very low power consumption and a broad operating temperature range. It is one of the few products described in this book that operates within the full military specification temperature range of -55°C to +125°C.

**You should be cautious with your power supply when using COSMAC.** CMOS is indeed immune to noise in the power supply; the power supply can swing wildly between +3V and +12V without affecting the 1 and 0 levels at individual gates. However, timing swings accompany power supply swings. This would not be a problem if all signals changed frequency together; however, as we will discuss later in this chapter, signals do not change in unison. Thus, **it is quite possible that a COSMAC system which works perfectly well with a +5V power supply is inoperable with a +8V power supply, because signal transitions have shifted sufficiently for +5V logic to no longer apply.**

Using a +10V power supply, a 155 nanosecond clock results in instruction execution times of 2.5 or 3.75 microseconds. In reality, a 200 nanosecond (or slower) clock should be used. Even though faster clocks are allowed, **users have experienced design problems when attempting to run COSMAC microcomputer systems with clocks that are faster than 200 nanoseconds.**

The principal manufacturer for the COSMAC is:

RCA SOLID STATE DIVISION  
P.O. Box 3200  
Somerville, N.J. 08876

The second sources are:

HUGHES AIRCRAFT INC.  
Industrial Electronics Group  
500 Superior Avenue  
Newport Beach, CA 92663

SOLID STATE SCIENTIFIC INC.  
Montgomeryville Industrial Park  
Montgomeryville, PA 18936

## THE COSMAC CPU

**Functions implemented on the CDP1802 CPU are illustrated in Figure 12-1.**

Logic to handle an external interrupt request is provided by the COSMAC CPU, along with an elementary ability to handle interrupt priority arbitration.

An unusual feature of COSMAC, as compared to other CPUs described in this book, is the fact that COSMAC provides an elementary DMA capability using CPU logic.

### COSMAC PROGRAMMABLE REGISTERS

These are the programmable registers of the COSMAC CPU:



**The D register functions as a primary Accumulator.**

**The sixteen 16-bit registers may serve as Program Counters, Data Counters, or scratchpad memory.**

As scratchpad memory, each 16-bit register consists of two 8-bit registers whose contents can be transferred to or from the primary Accumulator (D register).

The nomenclature RN is used to define a 16-bit general purpose register. N may be any number in the range 0 - 15. When general purpose registers are being treated as 8-bit data storage units, R(N).1 is used to identify the high-order byte of General Purpose Register RN and R(N).0 is used to identify the low-order byte of General Purpose Register RN. For example, R6 identifies the seventh 16-bit general purpose register. This general purpose register contains a high-order byte, identified as R(6).1 and a low-order byte, identified as R(6).0.



Figure 12-1. Logic of the CDP1802 COSMAC CPU and the CDP1852 I/O Port

**The 4-bit P register identifies the 16-bit register which at any point in time is functioning as the Program Counter.**

**The 4-bit X register identifies the 16-bit register which at any point in time is functioning as the Data Counter.**

**The T register is a simple, 8-bit buffer within which X and P register contents are stored following an interrupt.**

**COSMAC literature identifies a third 4-bit register, called the N register.** On first reading, the N register may look like the X register, but in reality, the N register represents the low-order four bits of the Instruction register. The N register is not a programmable register as we define it.

**The first three 16-bit registers have dedicated functions.**

**Register R0 is the Memory Address register used by the DMA logic of COSMAC.**

**Following an interrupt acknowledge, Register R1 is assumed to contain the beginning address for the interrupt service routine; General Purpose Register R2 serves as a primitive Stack Pointer.** A single instruction allows you to push the contents of the T register into the memory location addressed by General Purpose Register R2. Another single instruction loads P and X with the contents of the memory location addressed by General Purpose Register R2.

## COSMAC MEMORY ADDRESSING MODES

**COSMAC offers implied addressing of data memory and direct addressing of program memory.**

Any COSMAC instruction that accesses data memory indicates one of the sixteen General Purpose registers as providing the required memory address. Implied memory addressing with auto-increment or auto-decrement is also available in a limited number of cases.

An instruction that accesses data memory may directly identify the general purpose register wherein the implied data memory address will be found:



Alternatively, an instruction may specify that the X register points to the general purpose register which is to be used as a Data Counter:



Branch instructions use direct memory addressing. COSMAC has two-byte and three-byte Branch instructions. A two-byte Branch instruction uses paged, direct addressing; the second byte of object code replaces the low-order byte of the 16-bit general purpose register currently serving as Program Counter:



In the illustration above, the P register contains a hexadecimal digit represented by J. General Purpose Register RJ is therefore currently serving as the Program Counter. A two-byte Branch instruction contains an 8-bit value, represented by KK, in the second object program byte. When a branch is executed, KK is loaded into R(J).0, the low-order byte of General Purpose Register RJ. This represents straightforward, absolute paged direct addressing as described in Volume 1.

The second and third object code bytes of a three-byte Branch instruction provide a 16-bit address which replaces the entire contents of the general purpose register currently serving as Program Counter. This is equivalent to simple non-paged direct addressing as described in Volume 1. When a 16-bit address is stored in memory, the high-order address byte precedes the low-order address byte as follows:



**Program and data memory in a COSMAC microcomputer system may be common or separate.** Because COSMAC has a wealth of control signals, it is almost as easy to implement program and data memory with duplicated memory addresses and address spaces as it is to implement program and data memory with separate addresses and address spaces. Thus COSMAC can have separate program and data memories, as described for the SMS300, or it can have a shared address space, as is the case for all other microcomputers described in this book.

## COSMAC STATUS FLAGS

**COSMAC has no Status register, but it does have seven flags which, in a rather unusual way, provide status information.**

**Two of the seven status flags are orthodox:**

**There is the Data Flag (DF), which is equivalent to the Carry status as we describe it.**

**There is an Interrupt Enable flag which must be set to 1 if interrupts are enabled; this flag is reset to 0 in order to disable interrupts.**

**Five of the seven status flags are direct logic control statuses.**

**There are four I/O flags (EF1 - EF4) which are connected through inverters to CPU input pins. External logic can input high or low signals at these four pins. Subsequently, COSMAC Branch-on-Condition instructions can test any one of these four pins, then branch or not branch, depending on the status of the pin.**

The fifth condition status is referred to as the **Q status**. This status **can be set or reset directly by appropriate COSMAC instructions**. Subsequent Branch-on-Condition instructions will test the Q status in order to determine whether or not the branch will occur. In addition, the Q status is output to a pin which external logic can use in any way.

We may summarize the I/O and Q statuses as follows:



In addition, there are three I/O control signals output by COSMAC (N0, N1, and N2). These three signals can be used as control/status outputs to external logic. These three signals are described below, together with other COSMAC signals.

## COSMAC CPU PINS AND SIGNALS

**COSMAC CPU pins and signals are illustrated in Figure 12-2. A description of these signals is useful as a guide to the way in which the COSMAC microprocessor works. Signal names in Figure 12-2 conform with those used by COSMAC literature.**

**BUS0 - BUS7** is a standard bidirectional parallel Data Bus, usually called D0 - D7 for other microprocessors described in this book. All parallel data communications between the COSMAC CPU and external logic, memory, or I/O occur via this Data Bus.

**MA0 - MA7** represent an 8-bit Address Bus. Most other microprocessors described in this book use the symbols A0 - A7 for equivalent Address Bus lines. The fact that COSMAC has only eight address lines is very important. On the one hand, it frees up eight CPU DIP pins, which are used to provide extra control signals. The disadvantage of having just eight Address Bus lines is that all addresses must be multiplexed; the high-order address byte is output, followed by the low-order address byte. RCA provides memory devices that include address decode logic. An additional advantage of multiplexed address lines is that ROMs of varying sizes but identical pinouts can be constructed to recognize their own address space, thus giving users extra flexibility in constructing custom products.

The remaining signals may be divided into timing, status, and control signals.

The timing signals are **CLOCK**, **XTAL**, **TPA**, and **TPB**.



Figure 12-2. CDP1802 COSMAC CPU Signals and Pin Assignments

**CLOCK** is the principal timing signal input by external clock logic. Any frequency up to 6.4 MHz, when using a +10V power supply, is advertised, but frequencies above 5 MHz are not recommended.

If you are using the on-chip clock logic, then you must connect an external crystal, with a parallel resistor, to the **XTAL** and **CLOCK** pins.

**TPA and TPB are timing pulses output by the CPU to control external logic.**

**CLOCK, TPA, and TPB timing is illustrated in Figure 12-3.**

**The status signals are EF1 - EF4, Q, and SC0 - SC1.**

We have already encountered signals **EF1 - EF4**. These are four signals which external logic can input high or low; they are tested by conditional Branch instructions.

**Q is output continuously, reflecting the level of the Q status flag**, which you can set or reset by executing appropriate COSMAC instructions. External logic can use the Q output signal in any way.

**The two state signals SC0 and SC1 are output by the CPU to identify the type of machine cycle which is in progress. SC0 and SC1 are output as follows:**

| SC1 | SC0 | Machine Cycle Operation |
|-----|-----|-------------------------|
| 0   | 0   | Instruction Fetch       |
| 0   | 1   | Instruction Execute     |
| 1   | 0   | DMA Access              |
| 1   | 1   | Interrupt Acknowledge   |

Typically, external logic will use the SC0 and SC1 signals as an integral part of device select logic in order to ensure that no device considers itself selected inappropriately.

**Remaining signals may be classified generally as controls.**

**A low MWR pulse identifies a memory write operation, an I/O data input operation, or the two operations occurring simultaneously.**

**MRD low identifies a memory read operation, an I/O data output operation, or the two operations occurring simultaneously.**

You should always keep in mind the possibility of using the high **MWR** and **MRD** signal levels in a COSMAC microcomputer system. This is because the delays between signal transitions can vary markedly with clock frequency. Sometimes you will find it easier to use the NOT **MWR** or the NOT **MRD** condition to generate a strobe, rather than relying on the low pulse.

**When an Input or Output instruction is executed, as against a Memory Reference instruction, a nonzero value is output via the three I/O command pins N0, N1, and N2.** If all three pins are low, no I/O operation is in progress. How you use the three I/O command pins is up to you. They can, if you wish, identify an I/O port, in which case you can immediately address up to seven I/O ports. Alternatively, you can use these pins to distinguish between command, status or data.

**External logic can control the CPU via the WAIT and CLEAR inputs. These two inputs combine to force the CPU into the following states:**

| CLEAR | WAIT | CPU State |
|-------|------|-----------|
| 0     | 0    | Load      |
| 0     | 1    | Reset     |
| 1     | 0    | Pause     |
| 1     | 1    | Run       |

**In the Load state**, the CPU is idled and external logic can load memory directly, using the direct memory access logic provided by the CPU itself. That is to say, no instructions are executed and output signals are inactive; however, if DMA-IN is input low, then a DMA-IN machine cycle will be executed, as described later in this chapter.

**The Reset state is a typical reset.** During a reset, the Instruction register, the X and P registers, R0, and the Q status are all reset to zero. The Reset state must last for at least nine clock pulses. You should end the Reset state by entering the Run state. Thus, you may look upon **WAIT** as a signal which is maintained high during a normal sequence of Run and Reset states; **CLEAR** then becomes equivalent to the single **RESET** signal provided by other microprocessors.

When you enter the Run state following a Reset, the P register will contain 0; therefore, General Purpose Register R0 acts as a Program Counter. General Purpose Register R0 contains 0000; therefore, the first instruction fetched following a Reset will have its object code stored in memory location 0000. When the COSMAC CPU is reset, interrupts are enabled. **You must therefore disable interrupts with the first instruction of your bootstrap program.** If you do not do this, any stray interrupts will be acknowledged with unpredictable results.

**The Pause mode stops all internal CPU operations other than the CLOCK signal.** Note that COSMAC is a static device. CPU operations can halt for any length of time with no loss of data.

**The Run mode is the condition in which the CPU will normally operate.**

**DMA-IN** and **DMA-OUT** are control signals input by external logic in order to perform direct memory access operations. **DMA-IN** requests a data transfer from external logic to memory; **DMA-OUT** requests a data transfer from memory to external logic. In each case, memory is addressed by General Purpose Register R0. External logic is implicitly identified — it is the source of the **DMA-IN** and **DMA-OUT** signals. Following a DMA transfer, General Purpose Register R0 contents are incremented.

**INT** is a standard interrupt request input.



Figure 12-3. COSMAC Machine Cycle Timing

## COSMAC TIMING AND INSTRUCTION EXECUTION

COSMAC signal timing varies with the frequency of the clock signal. Variations are non-linear. In the data sheets at the end of this chapter, delays are given for various clock frequencies. We recommend that you use one of the clock frequencies shown in the data sheets; you cannot accurately predict delays for other clock frequencies by interpolation or extrapolation. If you are using a clock frequency that is not shown in the data sheets, you should create your own data sheets by viewing waveforms on an oscilloscope and measuring delays experimentally.

In the timing diagrams which follow, we have made some attempt to highlight the wide variations in timing that can separate a trigger signal transition and a subsequent dependent signal transition. In an NMOS device we might show a control pulse dependent on a clock signal as follows:

**COSMAC  
TIMING  
VARIATIONS**



The same clock pulse might be more accurately illustrated for COSMAC as follows:



All COSMAC instructions are executed as a sequence of machine cycles. Each machine cycle has eight clock periods, as illustrated in Figure 12-3. Two timing signals, TPA and TPB, are output as an integral part of every machine cycle's timing.

**COSMAC  
INSTRUCTION  
MACHINE  
CYCLE**

Most COSMAC instructions execute in two machine cycles: an instruction fetch machine cycle and an instruction execute machine cycle. A few three-byte instructions execute in three machine cycles.

For any memory reference instruction, a 16-bit memory address is output, one byte at a time, on the 8-bit Address Bus, as illustrated in Figure 12-4. The high-order address byte appears first and should be read on the trailing edge of TPA. The low-order address byte is read with the accompanying data strobe.

When using certain clock frequencies, the high-order address byte does not appear on the Address Bus until some time after the trailing edge of TPA. This is identified in the data sheets by a negative set-up time, which may be illustrated as follows:

**COSMAC  
NEGATIVE  
SET-UP  
TIME**





Figure 12-4. COSMAC Memory Read Instruction Timing

If your clock frequency results in negative set-up times, then you must be sure to include extra logic that accounts for this fact. Note carefully that negative set-up times occur in a number of different places within any machine cycle.

## COSMAC MEMORY READ TIMING

**Figure 12-4 illustrates timing for a two-machine cycle memory read instruction's execution.** An instruction fetch operation occurs in the first machine cycle and a memory read operation occurs in the second machine cycle. The only difference between these two machine cycles is the level of the SCO control output and the source of the memory address which appears on the Address Bus.

The trailing edge of TPA is normally used as the high-order address byte strobe. When there is a negative set-up time, the trailing edge of TPA occurs before the high-order address byte is stable on the Address Bus. You will now have to use some clock signal transition occurring after TPA as your high-order address byte strobe.

MRD low occurs early on in a memory read or instruction fetch machine cycle. Therefore, as soon as the low-order address byte has been read by a memory device, it can immediately respond to a read request. The combination of MRD low and some appropriate clock signal transition must be used to generate a low-order address byte strobe. This strobe logic will be highly dependent on your clock frequency. The CPU reads data off the Data Bus on the rising edge of the T7 clock pulse. At this time, data on the Data Bus must be stable.

## COSMAC MEMORY WRITE INSTRUCTION TIMING

**A two-machine-cycle memory write instruction's timing is illustrated in Figure 12-5.** Memory strobes the high-order address byte exactly as it would for a memory read. A low MWR pulse acts as the low-order address byte strobe and a data output strobe. The CPU has valid data on the Data Bus before the high-order address byte output is complete; since the low-order address byte is stable on the Address Bus for a considerable time, there are no timing problems associated with the low-order address byte or data output.



Figure 12-5. COSMAC Memory Write Instruction Timing

## COSMAC DATA INPUT, DATA OUTPUT, AND DIRECT MEMORY ACCESS

COSMAC DMA and I/O logic are combined. We will therefore describe them together, beginning with direct memory access.

**External logic initiates a DMA-IN or DMA-OUT operation by inputting the appropriate DMA control signal low.** As illustrated in Figure 12-3, the CPU samples the DMA-IN and DMA-OUT lines at the end of T6 in non-instruction fetch machine cycles. Upon detecting one or the other of these two signals low, the CPU performs a direct memory access operation during the next machine cycle. **Figure 12-6 illustrates timing for a DMA-IN machine cycle; Figure 12-7 illustrates timing for a DMA-OUT machine cycle.** As illustrated in these two figures, a DMA machine cycle consists of a simultaneous memory and I/O access.

**Consider first the DMA-IN machine cycle illustrated in Figure 12-6.** As "DMA-IN" would imply, data is to flow from an external device to memory. The external device is implicitly identified; it is the device which drove the DMA-IN control signal low in the previous machine cycle. The memory location to be accessed is addressed by Register R0. A DMA-IN machine cycle therefore consists of a data input machine cycle superimposed on a memory write machine cycle. In many microprocessors, superimposing these two operations within a single machine cycle would be impossible, since the Address Bus is used to identify memory locations and I/O devices; also, memory and I/O accesses occur during the same part of a machine cycle. In the case of COSMAC, the two operations can occur within a single machine cycle. The memory location to be accessed is identified in the usual way by outputting a memory address on the 8-bit Address Bus. Memory interface logic selects a memory location and writes into it as it would for any memory write machine cycle. Timing is illustrated in Figure 12-5. The external device which requested the DMA-IN can use the combination of a high TPA pulse together with SC0 low, SC1 high, and MRD high as a control signal forcing data onto the Data Bus. By the time TPA is high, MRD will have been driven low for a data out machine cycle. The DMA machine cycle is itself identified by SC0 low and SC1 high.



Figure 12-6. COSMAC DMA-IN Machine Cycle



Figure 12-7. COSMAC DMA-OUT Machine Cycle

For the DMA-OUT machine cycle, illustrated in Figure 12-7, the memory access portion of the machine cycle does not differ from a memory read, as illustrated in Figure 12-4. The signal causing the addressed memory location to place data on the Data Bus will be generated, as shown in Figure 12-7, from the combination of MRD low and some appropriate clock transition; the appropriate clock transition will depend on the clock frequency you are using. The I/O device requesting the DMA-OUT machine cycle can use the high TPB pulse as a strobe to read data off the Data Bus.

External logic may know whether a DMA-IN or a DMA-OUT operation is being performed, since the I/O device generated the initial DMA request. In this case, external logic does need a CPU control signal identifying the direction of the DMA transfer. In Figure 12-6 we could show input data appearing on the Data Bus soon after the beginning of the DMA-IN machine cycle, as identified by SCO low and SC1 high. It is only necessary for the data to be stable on the Data Bus while the MWR pulse is low, since this is the memory write strobe which will cause the input data to be written into memory.

During any DMA machine cycle, the address output on the Address Bus comes from Register R0, which is then incremented so as to point to the next memory location; this is in anticipation of a data block being transferred via direct memory access.

If more than one device is capable of generating a DMA request, the CPU does nothing to help you resolve priority conflicts. In every DMA machine cycle, the CPU assumes that only one external device is requesting direct memory access, and that this device can uniquely identify itself. If more than one device is capable of requesting direct

memory access, then you must have your own external DMA arbitration logic. You must also be sure that the program has placed the correct value in the single DMA Address register (R0). Some variation of daisy-chaining is the simplest and most obvious scheme; it may be illustrated as follows:



In the primitive logic illustrated above, DMARQ may be the DMA-IN or the DMA-OUT request line. In each case, the signal input to the CPU is simply the wire-OR of all DMA requests from external devices. Thus, if one or more devices is requesting DMA access, a high DMARQn input will cause a low DMA-IN or DMA-OUT to occur at the CPU.

Device 0 is considered to have highest priority. This device has no DMA acknowledge input. If Device 0 is requesting DMA access, it will assume that it is being serviced by the next DMA machine cycle. Lower priority devices require a DMA acknowledge signal. This signal can be the NOR of all higher priority DMA requests. Providing all higher priority DMA requests are low, no higher priority device is requesting DMA service; therefore the DMA acknowledge will be true.

One problem can arise with the scheme illustrated above. If a DMA-IN and a DMA-OUT request occur simultaneously, the CPU gives the DMA-IN request priority over the DMA-OUT request. You must therefore couple the DMA-IN and DMA-OUT requests in order to generate the DMA acknowledge signals returned to lower priority devices. You have two options. In the simpler case, DMA-IN requests from all devices can have priority over DMA-OUT requests from any device; that is to say, Device 3 DMA-IN requests will have priority over Device 0 DMA-OUT requests. Here is appropriate logic:



A more reasonable scheme would be to give Device 0 DMA-IN and DMA-OUT requests priority over Device 1 DMA-IN and DMA-OUT requests, and so on. This can be accomplished as follows:



Figure 12-8. COSMAC I/O Data Input Instruction Execution Timing



Figure 12-9. COSMAC I/O Data Output Instruction Execution Timing

I/O instruction execution timing is illustrated in Figures 12-8 and 12-9. I/O machine cycles do have one additional piece of logic not present in a DMA machine cycle: the N0, N1, and N2 signals identify the I/O machine cycle, and the I/O device being accessed. During any I/O machine cycle, one or more of these three signals will be high; thus, seven I/O devices may be identified. If you have fewer than seven I/O devices, then you can use the three signals N0, N1, and N2 to differentiate between data and control information. For a COSMAC system with three I/O devices, here is one possibility:



**The fact that I/O operations are in reality half of a DMA operation results in an anomaly.** The MRD and MWR control signals are logically inverted during an I/O operation if you think of them as I/O control signals. MRD low, which signals a memory read operation, identifies an I/O output operation. MWR low, which signals a memory write operation, identifies an I/O input operation.

**When an output instruction is executed, the Data Counter is incremented. The Data Counter is not affected when an input instruction is executed.** The programming ramifications of COSMAC I/O instructions are discussed in more detail later in this chapter.

## A SUMMARY OF COSMAC INTERRUPT PROCESSING

External logic can, at any time, request an interrupt by inputting a low signal at INT. INT signal timing is given in Figure 12-3. Providing interrupts are enabled, following execution of the current instruction **the CPU will respond to the interrupt request with these three steps:**

- 1) The contents of the X and P registers are moved to the T register.
- 2) 1 is loaded into the P register and 2 is loaded into the X register.
- 3) Interrupts are disabled.

Steps 1 and 2 may be illustrated as follows:



The interrupt service routine now begins executing with the instruction addressed by General Purpose Register R1. Any data accessed by the interrupt service routine must be addressed by General Purpose Register R2.

In the event that an interrupt service routine may itself be interrupted, you can store the T register contents in memory, at the location addressed by General Purpose Register R2 (which is now pointed to by X).

**The four input signals, EF1 - EF4, are the only means directly available for external logic to identify itself when more than one external device can request an interrupt.** Use of these external flag signals means that the interrupt service routine must begin with a number of Branch-on-Condition instructions that test the input flags to determine which is high.

More complex interrupt priority arbitration schemes must rely upon external logic to create an identifying code for the CPU to read out of an I/O port.

## THE COSMAC INSTRUCTION SET

**Table 12-1 summarizes the COSMAC instruction set.**

**You should allow for some anomalies in the COSMAC instruction set before starting to write programs.**

**There are four instructions which access the Data Counter.** They are:

- 1) LDX - transfer the contents of the memory location addressed by the Data Counter to the CPU Accumulator (D register).
- 2) LDXA - same as LDX, but post-increment the Data Counter.
- 3) IRX - increment the Data Counter.
- 4) STXD - store the CPU Accumulator (D register) contents in the memory location addressed by the Data Counter, then post-decrement the Data Counter.

**These four instructions are sometimes difficult to use.** Usually, a pair of instructions that increment and decrement a memory address will pre-increment and post-decrement, or post-increment and pre-decrement. In either case you can use the Data Counter as a Stack Pointer. Post-increment and post-decrement logic simply makes programming more difficult. The problem is further compounded by the fact that there is an LDX instruction, but no STX instruction;

also, there is an Increment Data Counter (IRX) instruction, but no Decrement Data Counter instruction. The fact that there is no Decrement Data Counter instruction is annoying, since every output instruction increments the Data Counter - something you don't always wish to do.

**COSMAC has no Jump-to-Subroutine instructions. You must maintain a separate Program Counter within the CPU registers in order to address subroutines. In very simple programs, this is a perfectly workable scheme;** what it means is that all subroutines are single level (that is to say, a subroutine will be called by a main program and never by another subroutine).

Consider the following register/memory scheme in a small COSMAC microcomputer system:



The scheme illustrated above shows data memory being divided into four stacks, each of which has its own Data Counter. The program consists of a main program and six subroutines. The main program has a Program Counter, and each subroutine has its own Program Counter. In order to call a subroutine, you simply switch from the main Program Counter to a subroutine Program Counter. In order to return from a subroutine, you simply switch from the subroutine Program Counter to the main Program Counter. This may be illustrated as follows:

..MAIN PROGRAM. IT USES DATA BUFFER 1.

```
SETP      5      ..CALL SUBROUTINE 2
                  ..SUBROUTINE 2 RETURNS HERE
```

..SUBROUTINE 2 BEGINS AT INSTRUCTION START

|       |      |     |                                     |
|-------|------|-----|-------------------------------------|
| RET   | SETP | 3   | ..RETURN TO MAIN PROGRAM            |
| START | SETX | 11  | ..SUBROUTINE 2 USES DATA BUFFER 2   |
|       |      |     | -                                   |
|       |      |     | -                                   |
|       | SETX | 10  | ..RESTORE MAIN PROGRAM DATA COUNTER |
|       | BR   | RET | ..BRANCH TO RETURN INSTRUCTION      |

Subroutine 2 program logic illustrated above is self-evident, except for the return procedure.

Initially, Register 5 holds the address of the subroutine 2 instruction labeled START (that is, the SETX 11 instruction). Therefore, when the SETP 5 instruction is executed in the main program, execution branches to instruction START within subroutine 2. This instruction selects Register 11 as the Data Counter for subroutine 2. After the body of subroutine 2 has been executed, the return procedure begins with the SETX 10 instruction, which restores the Data Counter pointer required by the main program. This is assumed to be Register 10. The next instruction branches to RET, which is the instruction preceding the start of subroutine 2. This instruction loads the value 3 into the P register, thus selecting Register R3 as the next Program Counter — this causes execution to return to the main program. But notice that Register R5, which was the Program Counter for subroutine 2, is left addressing START, since R5 will have been incremented while executing instruction RET. Thus, the next time the main program calls subroutine 2, Register R5 will be pointing to START, which is the correct entry point for subroutine 2. The instruction execution path may now be illustrated as follows:

..MAIN PROGRAM. IT USES DATA BUFFER 1.



Note that when the SETP 5 instruction is executed, Register 3 is left pointing at the next memory location. If desired, a list of parameters can be stored following the SETP 5 instruction and then picked up by the subroutine via LDA 3 instructions. For example,

|       |      |                   |
|-------|------|-------------------|
| SETP  | 5    |                   |
| 06    |      | ..NUMBER OF BYTES |
| 'S'   |      | ..ASCII MESSAGE   |
| 'I'   |      |                   |
| 'G'   |      |                   |
| 'N'   |      |                   |
| 'C'   |      |                   |
| 'N'   |      |                   |
| RET   | SETP | 3                 |
| START | LDA  | 3                 |
|       | PLO  | 6                 |
|       | SETX | 3                 |
| LOOP  | OUT  | PORT\$NUMBER      |
|       | DEC  | 6                 |
|       | GLO  | 6                 |
|       | BNZ  | LOOP              |
|       | BR   | RET               |

By keeping a number of short subroutines on a single 256-byte page of memory, you can increase the number of addressable subroutines. Consider the following scheme:



In order to call one of the seven subroutines held on Page 1F16, you must load the correct subroutine starting address into the low-order byte of Register R5 prior to calling the subroutine. This may be illustrated as follows:

..MAIN PROGRAM. IT USES DATA BUFFER 1.

```

LDI    61H      ..INITIALIZE R(5).0 FOR SUBROUTINE 2.3
PLO    5
SETP   5      ..CALL SUBROUTINE 2.3
              ..SUBROUTINE 2.3 RETURNS HERE

```

..SUBROUTINE 2.3 IS ORIGINATED AT 1F61H

```

ORG   1F60H
RET   SETP  3      ..RETURN TO MAIN PROGRAM
START SETX 11      ..SUBROUTINE 2.3 USES DATA BUFFER 2

```

```

SETX   10      ..RESTORE MAIN PROGRAM DATA COUNTER
BR     RET      ..BRANCH TO RETURN INSTRUCTION

```

You can use a similar scheme to increase the number of addressable data buffers. For example, you could have a large number of short data buffers on a single 256-byte page of data memory. This may be illustrated as follows:



We must now modify our instruction sequence as follows:

..MAIN PROGRAM. IT USES DATA BUFFER 1

```
LDI    61H    ..INITIALIZE R(5).0 FOR SUBROUTINE 2.3
PLO    5
SETP   5    ..CALL SUBROUTINE 2.3
           ..SUBROUTINE 2.3 RETURNS HERE
```

..SUBROUTINE 2.3 IS ORIGINATED AT 1F61H. IT USES DATA BUFFER 2.3

```
ORG   1F60H
RET   SETP  3    ..RETURN TO MAIN PROGRAM
START LDI    30H    ..INITIALIZE R(11).0 FOR DATA COUNTER
PLO    11
SETX   11
           ..
           ..
SETX   10    ..RESTORE MAIN PROGRAM DATA COUNTER
BR    RET    ..BRANCH TO RETURN INSTRUCTION
```

**There is no simple way of handling nested subroutines using the COSMAC instruction set.**

The problem is that if a subroutine can be called by another subroutine, then you have no obvious return logic. Suppose, for example, that subroutine X can be called by subroutine A, B, or C, or by the main program. If subroutines A, B, and C each have their own Program Counter, then how is subroutine X going to know which Program Counter to select when returning? In order to resolve this problem, you will need a special subroutine to call subroutines, with another special subroutine to return from subroutines. Consider the following register assignments:

**COSMAC  
NESTED  
SUBROUTINE**

|     |                                   |
|-----|-----------------------------------|
| R0  | DMA memory address                |
| R1  | Interrupt Program Counter         |
| R2  | Interrupt Data Counter            |
| R3  | Main Program Counter              |
| R4  | Call subroutine Program Counter   |
| R5  | Return subroutine Program Counter |
| R6  | Stack Pointer                     |
| R7  |                                   |
| R8  |                                   |
| R9  |                                   |
| R10 |                                   |
| R11 |                                   |
| R12 |                                   |
| R13 |                                   |
| R14 |                                   |
| R15 |                                   |

Every time a subroutine is called, Register R4 must be selected as the new Program Counter. Register R4 switches to a special subroutine whose only purpose is to save the contents of Register R3 in an external stack, which is addressed by R6. If additional registers are dedicated to serving as Data Counters, then the contents of these registers may also have to be saved on the external stack. After register contents have been appropriately saved, the CALL subroutine must select the required subroutine. There are many ways in which you can identify the required subroutine; one technique would be to use an additional register as a pointer to a data table within which all subroutine addresses are

stored. For example, R7 might point to such a data table. Now the calling program must load into R7 the address of the location in the data table where the required subroutine address is stored. Now the CALL subroutine will use R7 as a pointer to two bytes of data, which must be loaded into R3 before the CALL subroutine terminates execution by selecting R3 as the next Program Counter.

When a subroutine completes execution, it returns by selecting Register R5 as the Program Counter in order to call a RETURN subroutine. The RETURN subroutine must reload R3, and any dedicated Data Counter registers' contents from the external stack, which is addressed by R6. Having done this, the RETURN subroutine selects R3 as the next Program Counter, thus affecting a return from subroutine.

It takes 128 microseconds to execute a well-written CALL subroutine. It takes 112 microseconds to execute a well-written RETURN subroutine. These times assume a 2 MHz clock.

#### RCA's COSMAC Programming Manual describes some additional techniques for handling nested subroutines.

**Programming interrupt service routines is quite simple — providing you do not use subroutines within the interrupt service routine.** Remember, as soon as an interrupt is acknowledged, R1 becomes the Program Counter and R2 becomes the Data Counter; the previous Program Counter and Data Counter pointers are stored in the memory location which was addressed by the Data Counter when the interrupt occurred. Now, providing there are no subroutines in the interrupt service routine, you can simply execute a program which is addressed by R1, while using R2 to access data memory. **If you do execute subroutines, you must consider all of the problems associated with using subroutines in a main program, but you must add a new complication: R1 is now the main Program Counter.** You must either have special subroutines that are called only by the interrupt service routine, or you must write some type of instruction sequence which switches to using the main Program Counter register within the interrupt service routine before you start calling subroutines.

COSMAC  
INTERRUPT  
SERVICE  
ROUTINE  
PROGRAMS

#### COSMAC I/O instructions are quite unusual. The most unusual (and useful) aspect of COSMAC I/O instructions is the fact that they transfer data between memory and an I/O device.

Most microprocessors transfer data between the CPU and I/O devices. When you are inputting or outputting one byte of data at a time, it makes more sense for the data transfer to occur between the CPU and the I/O device, since the single byte of data is likely to be generated in the CPU for an output operation, or is likely to be operated on by the CPU after being input. When blocks of data are being input or output, it makes more sense for the data transfer to occur between memory and an I/O device, since the block of data must be held in a memory buffer.

COSMAC  
INPUT/  
OUTPUT  
PROGRAMS

COSMAC input instructions transfer the data to the CPU Accumulator and the memory location addressed by the Data Counter, thus giving you the benefit of both possibilities. If your program is in read-only memory, you can avoid input data being written into memory by selecting the same register to act as Program Counter and Data Counter. Now the input data will be stored in the Accumulator (D register), but the attempt to write the input byte into memory will be thwarted, since the selected memory location will be a read-only memory location.

COSMAC output instructions increment the Data Counter after performing the output operation. This makes it easy to output a block of data from data memory.

If you select the same register to act as Program Counter and Data Counter during an output operation, then the Program Counter will be incremented twice: once for the normal instruction fetch increment, and a second time for the data output. This allows you to perform immediate output operations.

### THE BENCHMARK PROGRAM

Now consider our benchmark program; for COSMAC it looks like this:

|           |        |                                            |
|-----------|--------|--------------------------------------------|
| LDI       | TABHI  | ..LOAD TABLE BASE ADDRESS HIGH ORDER BYTE  |
| PHI       | R15    | ..INTO R15 AND R13                         |
| PHI       | R13    | ..R15 POINTS TO NEXT FREE TABLE BYTE       |
| LDI       | 00     |                                            |
| PLO       | R13    | ..R13 POINTS TO FIRST BYTE IN TABLE        |
| PLO       | R14    |                                            |
| LDN       | R13    | ..ASSUME THAT DISPLACEMENT TO FIRST        |
| PLO       | R15    | ..FREE BYTE IS STORED IN FIRST TABLE BYTE  |
| LDI       | IOBFHI | ..LOAD IOBUF START ADDRESS INTO R14        |
| PHI       | R14    |                                            |
| LDN       | R14    | ..LOAD DISPLACEMENT TO END OF FILLED IOBUF |
| PLO       | R14    |                                            |
| LOOP: LDI | R14    | ..LOAD NEXT BYTE FROM IOBUF                |
| STR       | R15    | ..STORE IN NEXT FREE TABLE BYTE            |

|     |      |                                        |
|-----|------|----------------------------------------|
| INC | R15  | ..INCREMENT R15                        |
| DEC | R14  | ..DECREMENT R14                        |
| GLO | R14  | ..TEST LOW ORDER BYTE OF R14           |
| BNZ | LOOP | ..IF NOT ZERO RETURN TO LOOP           |
| GLO | R15  | ..AT END RESET FIRST BYTE OF           |
| STR | R13  | ..TABLE TO NEW FIRST FREE BYTE ADDRESS |

This is the memory map assumed by the benchmark program above:



Tables IOBUF and TABLE are both originated on page boundaries; that is to say, the low-order eight bits of the origin address are zeros. Data in table IOBUF is stored backwards. The first byte of data to be moved from IOBUF to TABLE is stored at the highest memory address of IOBUF. This highest memory address, illustrated above by XXPP, is derived by adding the contents of the first IOBUF table byte to the origin address. Thus, the first byte of IOBUF stores that length of table IOBUF which is currently filled. COSMAC program logic can now decrement the initial IOBUF address from XXPP and, upon testing the low-order byte equal to zero, logic knows that all data has been transferred.

The destination table stores the displacement to the first free table byte in the first byte of TABLE. Thus the address of the first free byte equals the origin plus the contents of the first TABLE byte.

Since the displacement to the first free byte of TABLE is stored in a single data byte, clearly TABLE cannot be more than 256 bytes long. Thus, IOBUF must contain less than 256 bytes at any time.

If you look at the COSMAC program, it appears rather long. The instruction loop itself contains only six instructions, which compares well with many other benchmark programs. What is deceptive about the benchmark program is the fact that we have taken a large number of instructions in order to load initial addresses into general purpose registers. Remember, COSMAC has sixteen such general purpose registers, and the whole programming philosophy of this microcomputer is that you load addresses into general purpose registers once, at the beginning of the program, and never again. In fact, the benchmark program points up both the strength and the weakness of the COSMAC instruction set. Its strength is that large numbers of addresses can be permanently stored within CPU registers, thence memory access becomes a trivial task. Its weakness is that it takes a lot of instructions to get memory addresses into general purpose registers in the first place — and that becomes a liability if you have to re-use the same general purpose register in a number of different ways within one program.

The following symbols are used in Table 12-1:

|       |                                   |
|-------|-----------------------------------|
| ADR8  | 8-bit address                     |
| ADR16 | 16-bit address                    |
| D     | D register                        |
| DATA8 | 8-bit data unit                   |
| DEV   | 3-bit code: 1 through 7           |
| DF    | Data Flag or Carry                |
| EFn   | Pin status: EF1, EF2, EF3, or EF4 |
| IE    | Interrupt Enable bit              |

- n One of the numbers 1, 2, 3, 4
- N 4-bit register select unit
- N210 Three output pins, N2, N1, NO
- P 4-bit Program Counter Pointer register
- Q status output flip-flop
- R(z) Specifies a register:
  - if z is N the instruction operand specifies the register
    - P the contents of the P register specify the register
    - X the contents of the X register specify the register
- T T register
- X 4-bit Data Counter Pointer register
- x<y,z> Bits y through z of a register or memory location. For example, T<7,4> represents the high-order four bits of the T register.
- [] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If an I/O port number is enclosed within the brackets, then the I/O port contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.
- [[]] Implied memory addressing: the contents of the memory location designated by the contents of a register.
- Λ Logical AND
- ∨ Logical OR
- ✗ Logical Exclusive-OR
- Data is transferred in the direction of the arrow.

Under the heading of STATUSES in Table 12-1, an X indicates statuses which are modified in the course of the instruction's execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

Table 12-1. COSMAC Instruction Set Summary

| TYPE                                         | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |  |  |  | OPERATION PERFORMED                                                                                                                                                                                                                |
|----------------------------------------------|----------|------------|-------|----------|----|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              |          |            |       | OF       | IE |  |  |  |                                                                                                                                                                                                                                    |
| I/O                                          | INP      | DEV        | 1     |          |    |  |  |  | $[[R(X)]] \rightarrow [D] \rightarrow \text{BUS}$<br>$N210 \rightarrow [N <2,0>]$<br>Input data from Bus to Register D and memory. Output device number (DEV) at pins N2, N1, N0.                                                  |
|                                              | OUT      | DEV        | 1     |          |    |  |  |  | $\text{BUS} \rightarrow [[R(X)]], [R(X)] \leftarrow [R(X)] + 1$<br>$N210 \rightarrow [N <2,0>]$<br>$[R(X)] \rightarrow [R(X)] + 1$<br>Output memory to Bus; output device number (DEV) at pins N2, N1, N0; increment Data Counter. |
| PRIMARY MEMORY REFERENCE                     | LDN      | N          | 1     |          |    |  |  |  | $[D] \rightarrow [[R(N)]]$<br>Load D register via specified register. N may not be 0.                                                                                                                                              |
|                                              | LDA      | N          | 1     |          |    |  |  |  | $[D] \rightarrow [[R(N)]]$<br>$[R(N)] \rightarrow [R(N)] + 1$<br>Load D register via specified register. Increment specified register.                                                                                             |
|                                              | STR      | N          | 1     |          |    |  |  |  | $[[R(N)]] \rightarrow [D]$<br>Store D register via specified register.                                                                                                                                                             |
|                                              | LDX      |            | 1     |          |    |  |  |  | $[D] \rightarrow [[R(X)]]$<br>Load D register using implied addressing.                                                                                                                                                            |
|                                              | LDXA     |            | 1     |          |    |  |  |  | $[D] \rightarrow [[R(X)]]$<br>$[R(X)] \rightarrow [R(X)] + 1$<br>Load D register using implied addressing. Increment Data Counter.                                                                                                 |
|                                              | STXD     |            | 1     |          |    |  |  |  | $[[R(X)]] \rightarrow [D]$<br>$[R(X)] \rightarrow [R(X)] - 1$<br>Store D register using implied addressing. Decrement Data Counter.                                                                                                |
| SECONDARY MEMORY REFERENCE<br>MEMORY OPERATE | OR       |            | 1     |          |    |  |  |  | $[D] \rightarrow [[R(X)]] \vee [D]$<br>OR with D register using implied addressing.                                                                                                                                                |
|                                              | XOR      |            | 1     |          |    |  |  |  | $[D] \rightarrow [[R(X)]] \vee \neg [D]$<br>Exclusive-OR with D register using implied addressing.                                                                                                                                 |
|                                              | AND      |            | 1     |          |    |  |  |  | $[D] \rightarrow [[R(X)]] \wedge [D]$<br>AND with D register using implied addressing.                                                                                                                                             |
|                                              | ADD      |            | 1     | X        |    |  |  |  | $[D] \rightarrow [[R(X)]] + [D]$<br>Add to D register using implied addressing.                                                                                                                                                    |
|                                              | ADC      |            | 1     | X        |    |  |  |  | $[D] \rightarrow [[R(X)]] + [D] + [DF]$<br>Add with Carry to D register using implied addressing.                                                                                                                                  |
|                                              | SD       |            | 1     | X        |    |  |  |  | $[D] \rightarrow [[R(X)]] - [D]$<br>Subtract D from memory using implied addressing.                                                                                                                                               |
|                                              | SDB      |            | 1     | X        |    |  |  |  | $[D] \rightarrow [[R(X)]] - [D]; [DF]$<br>Subtract with borrow from memory using implied addressing.                                                                                                                               |
|                                              | SM       |            | 1     | X        |    |  |  |  | $[D] \rightarrow [D] - [[R(X)]]$<br>Subtract memory from D using implied addressing.                                                                                                                                               |
|                                              | SMB      |            | 1     | X        |    |  |  |  | $[D] \rightarrow [D] - [[R(X)]] - [DF]$<br>Subtract memory with borrow from D using implied addressing.                                                                                                                            |

Table 12-1. COSMAC Instruction Set Summary (Continued)

| TYPE                         | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |  |  |  | OPERATION PERFORMED                                                               |
|------------------------------|----------|------------|-------|----------|----|--|--|--|-----------------------------------------------------------------------------------|
|                              |          |            |       | OF       | IE |  |  |  |                                                                                   |
| IMMEDIATE                    | LDI      | DATA8      | 2     |          |    |  |  |  | [D]—DATA8<br>Load immediate to D register.                                        |
| IMMEDIATE OPERATE            | ORI      | DATA8      | 2     |          |    |  |  |  | [D]—DATA8 V [D]<br>OR immediate with D register.                                  |
|                              | XRI      | DATA8      | 2     |          |    |  |  |  | [D]—DATA8 V [D]<br>Exclusive-OR immediate with D register.                        |
|                              | ANI      | DATA8      | 2     |          |    |  |  |  | [D]—DATA8 A [D]<br>AND immediate with D register.                                 |
|                              | ADI      | DATA8      | 2     | X        |    |  |  |  | [D]—DATA8 + [D]<br>Add immediate to D register.                                   |
|                              | ADCI     | DATA8      | 2     | X        |    |  |  |  | [D]—DATA8 + [D]+ [DF]<br>Add immediate with Carry to D register.                  |
|                              | SDI      | DATA8      | 2     | X        |    |  |  |  | [D]—DATA8-[D]<br>Subtract D register from immediate data.                         |
|                              | SOBI     | DATA8      | 2     | X        |    |  |  |  | [D]—DATA8-[D]-[DF]<br>Subtract D register with borrow from immediate data.        |
|                              | SMI      | DATA8      | 2     | X        |    |  |  |  | [D]—[D]-DATA8<br>Subtract immediate from D register.                              |
|                              | SMBI     | DATA8      | 2     | X        |    |  |  |  | [D]—[D]-DATA8-[DF]<br>Subtract immediate with borrow from D register.             |
| BRANCH AND SKIP              | BR       | ADR8       | 2     |          |    |  |  |  | [R(P)<7,0>]—ADRB<br>Branch within same page to given address.                     |
|                              | LBR      | ADR16      | 3     |          |    |  |  |  | [R(P)]—ADR16<br>Branch to given address                                           |
|                              | SKP      |            | 1     |          |    |  |  |  | [R(P)]—[R(P)] + 1<br>Skip next byte.                                              |
|                              | LSKP     |            | 1     |          |    |  |  |  | [R(P)]—[R(P)] + 2<br>Skip next two bytes.                                         |
|                              | NBR      | ADR8       | 2     |          |    |  |  |  | Same as SKIP                                                                      |
|                              | NLBR     | ADR16      | 3     |          |    |  |  |  | Same as LSKP                                                                      |
| BRANCH AND SKIP ON CONDITION | BZ       | ADR8       | 2     |          |    |  |  |  | If [D]=0; then [R(P)<7,0>]—ADRB<br>Branch within same page on D register zero.    |
|                              | BNZ      | ADR8       | 2     |          |    |  |  |  | If [D]≠0; then [R(P)<7,0>]—ADRB<br>Branch within same page on D register nonzero. |
|                              | BDF      | ADR8       | 2     |          |    |  |  |  | If [DF]=1; then [R(P)<7,0>]—ADRB<br>Branch within same page on Carry set.         |

Table 12-1. COSMAC Instruction Set Summary (Continued)

| TYPE                                        | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |  |  |  | OPERATION PERFORMED                                                                          |
|---------------------------------------------|----------|------------|-------|----------|----|--|--|--|----------------------------------------------------------------------------------------------|
|                                             |          |            |       | OF       | IE |  |  |  |                                                                                              |
| BRANCH AND TEST ON CONDITION<br>(CONTINUED) | BNF      | ADR8       | 2     |          |    |  |  |  | If [DF]=0; then [R(P)<7,0>]—ADR8<br>Branch within same page on Carry reset.                  |
|                                             | BQ       | ADR8       | 2     |          |    |  |  |  | If Q=1; then [R(P)<7,0>]—ADR8<br>Branch within same page on output flip-flop set.            |
|                                             | BNQ      | ADR8       | 2     |          |    |  |  |  | If Q=0; then [R(P)<7,0>]—ADR8<br>Branch within same page on output flip-flop reset.          |
|                                             | Bn       | ADR8       | 2     |          |    |  |  |  | If EFn=1; then [R(P)<7,0>]—ADR8<br>Branch within same page on specified external flag set.   |
|                                             | BFn      | ADR8       | 2     |          |    |  |  |  | If EFn=0; then [R(P)<7,0>]—ADR8<br>Branch within same page on specified external flag reset. |
|                                             | LBZ      | ADR16      | 3     |          |    |  |  |  | If [D]=0; then [R(P)]—ADR16<br>Branch absolute on D register zero.                           |
|                                             | LBNZ     | ADR16      | 3     |          |    |  |  |  | If [D]≠0; then [R(P)]—ADR16<br>Branch absolute on D register nonzero.                        |
|                                             | LBDF     | ADR16      | 3     |          |    |  |  |  | If [DF]=1; then [R(P)]—ADR16<br>Branch absolute on Carry set.                                |
|                                             | LBNF     | ADR16      | 3     |          |    |  |  |  | If [DF]=0; then [R(P)]—ADR16<br>Branch absolute on Carry reset.                              |
|                                             | LBQ      | ADR16      | 3     |          |    |  |  |  | If [Q]=1; then [R(P)]—ADR16<br>Branch absolute on output flip-flop set.                      |
|                                             | LBNQ     | ADR16      | 3     |          |    |  |  |  | If [Q]=0; then [R(P)]—ADR16<br>Branch absolute on output flip-flop reset.                    |
|                                             | LSZ      |            | 1     |          |    |  |  |  | If [D]=0; then [R(P)]—[R(P)] + 2<br>Skip two bytes if D register zero.                       |
|                                             | LSNZ     |            | 1     |          |    |  |  |  | If [D]≠0; then [R(P)]—[R(P)] + 2<br>Skip two bytes if D register nonzero.                    |
|                                             | LSDF     |            | 1     |          |    |  |  |  | If [DF]=1; then [R(P)]—[R(P)] + 2<br>Skip two bytes if Carry set.                            |
|                                             | LSNF     |            | 1     |          |    |  |  |  | If [DF]=0; then [R(P)]—[R(P)] + 2<br>Skip two bytes if Carry reset.                          |
|                                             | LSQ      |            | 1     |          |    |  |  |  | If [Q]=1; then [R(P)]—[R(P)] + 2<br>Skip two bytes if output flip-flop set.                  |
|                                             | LSNQ     |            | 1     |          |    |  |  |  | If [Q]=0; then [R(P)]—[R(P)] + 2<br>Skip two bytes if output flip-flop reset.                |
|                                             | LSIE     |            | 1     |          |    |  |  |  | If [IE]=1; then [R(P)]—[R(P)] + 2<br>Skip two bytes if interrupts are enabled.               |

Table 12-1. COSMAC Instruction Set Summary (Continued)

| TYPE                   | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |  |  |  | OPERATION PERFORMED                                                                                                                                        |
|------------------------|----------|------------|-------|----------|----|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |          |            |       | OF       | IE |  |  |  |                                                                                                                                                            |
| REGISTER-REGISTER MOVE | GLO      | N          | 1     |          |    |  |  |  | [D]—[R(N)<7,0>]<br>Load D with low byte of specified register.                                                                                             |
|                        | GHI      | N          | 1     |          |    |  |  |  | [D]—[R(N)<15,8>]<br>Load D with high byte of specified register.                                                                                           |
|                        | PLO      | N          | 1     |          |    |  |  |  | [R(N)<7,0>]—[D]<br>Store D to low byte of specified register.                                                                                              |
|                        | PHI      | N          | 1     |          |    |  |  |  | [R(N)<15,8>]—[D]<br>Store D to high byte of specified register.                                                                                            |
| REGISTER OPERATE       | INC      | N          | 1     |          |    |  |  |  | [R(N)]—[R(N)] + 1<br>Increment specified register.                                                                                                         |
|                        | DEC      | N          | 1     |          |    |  |  |  | [R(N)]—[R(N)] - 1<br>Decrement specified register.                                                                                                         |
|                        | IRX      |            |       |          |    |  |  |  | [R(X)]—[R(X)] + 1<br>Increment Data Counter.                                                                                                               |
|                        | SHR      |            | 1     | X        |    |  |  |  | <br>Shift D register right one bit. Shift bit 0 into Carry; reset bit 7. |
|                        | SHRC     |            | 1     | X        |    |  |  |  | <br>Shift D register right one bit through Carry.                        |
|                        | SHL      |            | 1     | X        |    |  |  |  | <br>Shift D register left one bit. Shift bit 7 into Carry; reset bit 0.  |
|                        | SHLC     |            | 1     | X        |    |  |  |  | <br>Shift D register left one bit through Carry.                         |

Table 12-1. COSMAC Instruction Set Summary (Continued)

| TYPE   | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |  |  |  | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                  |
|--------|----------|------------|-------|----------|----|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |            |       | OF       | IE |  |  |  |                                                                                                                                                                                                                                                                                                                                      |
| STACK  | SAV      |            | 1     |          |    |  |  |  | $[[R(X)]] \rightarrow [T]$<br>Save T register in memory.                                                                                                                                                                                                                                                                             |
|        | MARK     |            | 1     |          |    |  |  |  | $[T < 7,4>] \rightarrow [X]$<br>$[T < 3,0>] \rightarrow [P]$<br>$[[R(2)]] \rightarrow [T]$<br>$[R(2)] \rightarrow [R(2)] - 1$<br>$[X] \rightarrow [P]$                                                                                                                                                                               |
|        | RET      |            | 1     |          |    |  |  |  | Save X and P in T; then push onto Stack via Register 2. Decrement Register 2. Move P to X.<br>$[X] \rightarrow [[R(X)] < 7,4 >]$<br>$[P] \rightarrow [[R(X)] < 3,0 >]$<br>$[R(X)] \rightarrow [R(X)] + 1$<br>$[IE] \rightarrow 1$                                                                                                    |
|        | DIS      |            | 1     |          |    |  |  |  | Pop memory into X and P using implied addressing. Increment Data Counter. Enable interrupts.<br>$[X] \rightarrow [[R(X)] < 7,4 >]$<br>$[P] \rightarrow [[R(X)] < 3,0 >]$<br>$[R(X)] \rightarrow [R(X)] + 1$<br>$[IE] \rightarrow 0$<br>Pop memory into X and P using implied addressing. Increment Data Counter. Disable interrupts. |
| STATUS | SEP      | N          | 1     |          |    |  |  |  | $[P] \rightarrow N$<br>Set P register to N.                                                                                                                                                                                                                                                                                          |
|        | SEX      | N          | 1     |          |    |  |  |  | $[X] \rightarrow N$<br>Set X register to N.                                                                                                                                                                                                                                                                                          |
|        | SEQ      |            | 1     |          |    |  |  |  | $[Q] \rightarrow 1$<br>Set output flip-flop.                                                                                                                                                                                                                                                                                         |
|        | REQ      |            | 1     |          |    |  |  |  | $[Q] \rightarrow 0$<br>Reset output flip-flop.                                                                                                                                                                                                                                                                                       |
|        | IDL      |            | 1     |          |    |  |  |  | Idle CPU. Wait for interrupt/DMA-IN/DMA-OUT.                                                                                                                                                                                                                                                                                         |
|        | NOP      |            | 1     |          |    |  |  |  | No Operation                                                                                                                                                                                                                                                                                                                         |

The following symbols are used in Table 12-2:

- aaaa 4 bits selecting one of the 16 registers
- bbb 3-bit data unit output to N2, N1, NO lines
- PP 8-bit address
- QQ Second 8 bits of a 16-bit address
- XX 8-bit immediate data unit

Table 12-2. COSMAC Instruction Set Object Codes

| INSTRUCTION | OBJECT CODE | BYTES | MACHINE CYCLES | INSTRUCTION | OBJECT CODE | BYTES | MACHINE CYCLES |
|-------------|-------------|-------|----------------|-------------|-------------|-------|----------------|
| ADC         | 74          | 1     | 2              | LBNF ADR16  | C3          | 3     | 3              |
| ADCI DATA8  | 7C          | 2     | 2              |             | PP          |       |                |
|             | XX          |       |                |             | QQ          |       |                |
| ADD         | F4          | 1     | 2              | LBNQ ADR16  | C9          | 3     | 3              |
| ADI DATA8   | FC          | 2     | 2              |             | PP          |       |                |
|             | XX          |       |                |             | QQ          |       |                |
| AND         | F2          | 1     | 2              | LBNZ ADR16  | CA          | 3     | 3              |
| ANI DATA8   | FA          | 2     | 2              |             | PP          |       |                |
|             | XX          |       |                |             | QQ          |       |                |
| BDF ADR8    | 33          | 2     | 2              | LBQ ADR16   | C1          | 3     | 3              |
|             | PP          |       |                |             | PP          |       |                |
| BNF ADR8    | 3B          | 2     | 2              | LBR ADR16   | C0          | 3     | 3              |
|             | PP          |       |                |             | PP          |       |                |
| BNQ ADR8    | 39          | 2     | 2              | LBZ ADR16   | C2          | 3     | 3              |
|             | PP          |       |                |             | PP          |       |                |
| BNZ ADR8    | 3A          | 2     | 2              |             | QQ          |       |                |
|             | PP          |       |                | LDA N       | 0100aaaa    | 1     | 2              |
| BNI ADR8    | 3C          | 2     | 2              | LDI DATA8   | F8          | 2     | 2              |
|             | PP          |       |                |             | XX          |       |                |
| BNZ ADR8    | 3D          | 2     | 2              | LDN N       | 0000aaaa    | 1     | 2              |
|             | PP          |       |                | LDX         | F0          | 1     | 2              |
| BN3 ADR8    | 3E          | 2     | 2              | LDXA        | 72          | 1     | 2              |
|             | PP          |       |                | LSDF        | CF          | 1     | 3              |
| BN4 ADR8    | 3F          | 2     | 2              | LSIE        | CC          | 1     | 3              |
|             | PP          |       |                | LSNF        | C7          | 1     | 3              |
| BQ ADR8     | 31          | 2     | 2              | LSNQ        | C5          | 1     | 3              |
|             | PP          |       |                | LSNZ        | C6          | 1     | 3              |
| BR ADR8     | 30          | 2     | 2              | LSQ         | CD          | 1     | 3              |
|             | PP          |       |                | LSKP        | C8          | 1     | 3              |
| BZ ADR8     | 32          | 2     | 2              | LSZ         | CF          | 1     | 3              |
|             | PP          |       |                | MARK        | 79          |       | 2              |
| B1 ADR8     | 34          | 2     | 2              | NBR         | 38          | 2     | 2              |
|             | PP          |       |                | NLBR        | C8          | 3     | 3              |
| B2 ADR8     | 35          | 2     | 2              | NOP         | C4          | 1     | 3              |
|             | PP          |       |                | OR          | F1          | 1     | 2              |
| B3 ADR8     | 36          | 2     | 2              | ORI DATA8   | F9          | 2     | 2              |
|             | PP          |       |                |             | XX          |       |                |
| B4 ADR8     | 37          | 2     | 2              | OUT P       | 01100bbb    | 1     | 2              |
|             | PP          |       |                | PHI N       | 1011aaaa    | 1     | 2              |
| DEC N       | 0010aaaa    | 1     | 2              | PLO N       | 1010aaaa    | 1     | 2              |
| DIS         | 71          | 1     | 2              | REQ         | 7B          | 1     | 2              |
| GHI N       | 1001aaaa    | 1     | 2              | RET         | 70          | 1     | 2              |
| GLO N       | 1000aaaa    | 1     | 2              | SAV         | 78          | 1     | 2              |
| IDL         | 00          | 1     | 2              | SEQ         | 7A          | 1     | 2              |
| INC N       | 0001aaaa    | 1     | 2              | SEP N       | 1101aaaa    | 1     | 2              |
| INP P       | 01101bbb    | 1     | 2              | SEX N       | 1110aaaa    | 1     | 2              |
| IRX         | 60          | 1     | 2              |             |             |       |                |
| LBDF ADR16  | C3          | 3     | 3              |             |             |       |                |
|             | PP          |       |                |             |             |       |                |
|             | QQ          |       |                |             |             |       |                |

Table 12-2. COSMAC Instruction Set Object Codes (Continued)

| INSTRUCTION | OBJECT CODE | BYTES | MACHINE CYCLES | INSTRUCTION | OBJECT CODE | BYTES | MACHINE CYCLES |
|-------------|-------------|-------|----------------|-------------|-------------|-------|----------------|
| SD          | F5          | 1     | 2              | SM          | F7          | 1     | 2              |
| SDB         | 75          | 1     | 2              | SMB         | 77          | 1     | 2              |
| SDBI DATA8  | 7D          | 2     | 2              | SMBI DATA8  | 7F          | 2     | 2              |
|             | XX          |       |                |             | XX          |       |                |
| SDI DATA8   | FD          | 2     | 2              | SMI         | FF          | 2     | 2              |
|             | XX          |       |                |             | XX          |       |                |
| SHL         | FE          | 1     | 2              | STR N       | 0101aaaa    | 1     | 2              |
| SHLC        | 7E          | 1     | 2              | STXD        | 73          | 1     | 2              |
| SHR         | F6          | 1     | 2              | XOR         | F3          | 1     | 2              |
| SHRC        | 76          | 1     | 2              | XRI DATA8   | FB          | 2     | 2              |
| SKP         | 38          | 1     | 2              |             | XX          |       |                |

## USING COSMAC WITH OTHER MICROPROCESSOR SUPPORT DEVICES

Using the COSMAC microprocessor with other microprocessor support devices will rarely make economic sense. We are therefore not going to describe how other microprocessor system busses can be generated from the COSMAC System Bus.

The principal advantage of COSMAC is its CMOS technology. The architecture, instruction set, and signal timing of COSMAC are not in themselves attractive enough to warrant selecting this CPU, as compared to many other popular 8-bit microprocessors described in this book. Thus, the principal reason for describing bus-to-bus conversion logic does not exist in this case. If you are going to use 8080A or 6800 support devices in your microcomputer application, you will almost certainly want to use the 8080A or 6800 CPU in preference to COSMAC.

The one other CMOS microprocessor described in this book, the IM6100, has support devices which are very dependent on the peculiarities of the IM6100; therefore, they are not useful in a COSMAC microcomputer system.



| Pin Name                          | Description                      | Type                     |
|-----------------------------------|----------------------------------|--------------------------|
| DIO - DI7                         | Data Input                       | Input or high impedance  |
| D00 - D07                         | Data Output                      | Output or high impedance |
| MODE                              | Input or Output mode select      | Input                    |
| CS1, CS2                          | Device Select                    | Input                    |
| CLK                               | External logic data input strobe | Input                    |
| SR/SR                             | Service Request                  | Output                   |
| CLEAR                             | Master Reset                     | Input                    |
| V <sub>DD</sub> , V <sub>SS</sub> | Power, Ground                    |                          |

Figure 12-10. CDP1852 I/O Port Pins and Signals

## THE CDP1852 PARALLEL I/O PORT

The CDP1852 parallel I/O port provides a COSMAC microcomputer system with bidirectional parallel I/O logic. Although we classify the device as bidirectional, it must be operated in input mode or output mode at any given time.

Figure 12-1 illustrates that part of our general microcomputer functional logic which is implemented by the CDP1852 device.

The CDP1852 is fabricated using CMOS technology; it is packaged as a 24-pin DIP.

There are two versions of the CDP1852 I/O port, differentiated by their power supplies. The CDP1852D will operate with power supplies ranging between +3 and +12 volts. The CDP1852CD requires a power supply ranging between +4 and +6 volts.

### CDP1852 PINS AND SIGNALS

CDP1852 I/O port pins and signals are illustrated in Figure 12-10.

**There are two Data Busses.** Data is input to the CDP1852 device via DI0-DI7; data output occurs at DO0-DO7. If the CDP1852 device is operating in input mode, then DO0-DO7 will be connected to the CPU Data Bus (BUS0-BUS7). If the CDP1852 device is operating in output mode, then DI0-DI7 will be connected to the CPU Data Bus (BUS0-BUS7).

**The mode of the CDP1852 device is determined by the MODE input.** If MODE is low, then the CDP1852 device is operating in input mode. In this mode, data will be transferred from external logic to the CDP1852 device via the DI0-DI7 signals; this data will be read by the CPU via the DO0-DO7 signals. When MODE is high, the CDP1852 device is operating in output mode. In output mode data will flow from the CPU to the CDP1852 device via the DI0-DI7 signals, while external logic will read this data via the DO0-DO7 signals.

**External logic strobes data into the CDP1852 device via a high-to-low transition of the CLK signal in input mode. CLK high is a prerequisite for data input when the CDP1852 device is operated in output mode.**

**CS1 and CS2 are select signals used by the CPU to access a CDP1852 device.** CS1 is high true in input mode and low true in output mode. CS2 is always high true.

**SR/SR is a handshaking control signal;** in input mode SR is used by the CPU, while in output mode SR is used by external logic.

**CLEAR is a master reset input.** When input low, it resets all data bits within the CDP1852 to 0 and it outputs SR low.

### CDP1852 OPERATIONS OVERVIEW

**The CDP1852 I/O port can operate in input mode or output mode.** Input mode is specified by a low MODE input and output is specified by a high MODE input.

In input mode, external logic transmits data to the CDP1852 I/O port via DI0-DI7. External logic uses CLK to strobe data into the I/O port. Data is output via DO0-DO7, which holds valid data whenever CS1 and CS2 are both high. **In the general case, input mode timing may be illustrated as follows:**



SR is an acknowledge signal sent back to external logic. SR goes low as soon as external logic provides a high-to-low CLK transition. SR returns high as soon as the CDP1852 I/O port ceases to be selected via CS1 and CS2. Thus, external logic can look upon SR low as a "device busy" signal, and the low-to-high SR transition as an input acknowledgement.

**When the CDP1852 I/O port is operated in output mode,** the CPU Data Bus is connected to DIO-DI7. The combination of CS1 low, CS2 high, and CLK high latches data input into the CDP1852 I/O port. The output lines D00-D07 are always enabled; therefore, as soon as new data is latched into the I/O port, this data appears at the output pins. **Timing may be illustrated as follows:**



SR is pulsed high in output mode. SR goes high as soon as new data is strobed into the CDP1852 I/O port, and remains high until the next high-to-low CLK transition. External logic can use the SR high pulse as a data input strobe.

## CDP1852 INPUT OPERATIONS

**The CDP1852 can be operated as an input port using programmed input or DMA input. We will first examine programmed input.**

**Figure 12-11 illustrates the CDP1852 I/O port operating in input mode with programmed input. Before examining this figure, you should be familiar with Figure 12-8 and its associated text.**

The logic in Figure 12-11 assumes that external logic uses the eight data input lines DIO-DI7 and two control lines CLK and SR.

When external logic has new data available, it will place the data on DIO-DI7 and pulse CLK high. This latches the data into the CDP1852 I/O port and simultaneously sets SR low. External logic will not attempt to input more data until SR is no longer low.

Since the SR signal is connected to one of the flag inputs EF1-EF4 of the CPU, program logic can monitor the SR signal by testing the proper status flag. When an input instruction is executed by the COSMAC CPU, the CDP1852 I/O port will respond by gating data onto the CPU Data Bus. This gating is controlled by the two chip select inputs CS1 and CS2. The CPU reads this data on the low MWR strobe. External logic can use the low SR pulse as its acknowledgement and "device busy" signal; SR is pulsed low from the time that the external logic data is strobed into the CDP1852 I/O port until the time that this I/O port ceases to be selected after being selected for an input operation. Thus, when SR goes high again, external logic knows that its data has been input to the CPU.



Figure 12-11. CDP1852 I/O Port in Input Mode with Programmed Input

CDP1852 input mode with DMA operation is illustrated in Figure 12-12. This figure is a variation of the DMA-IN machine cycle timing illustrated in Figure 12-6. You should be familiar with Figure 12-6 before looking at Figure 12-12 and the text below.



Figure 12-12. CDP1852 I/O Port in Input Mode with DMA Input

External logic initiates a data input operation by placing data at the D10-DI7 pins of the CDP1852 device and applying the CLK strobe. On the trailing edge of the CLK strobe, data is latched into the CDP1852 I/O port and SR is output low.

The DMA-IN signal is input low when SR goes low. But we only want one DMA-IN machine cycle to occur at a time. If you examine Figure 12-3, you will see that the DMA-IN signal is sampled at the end of the T6 clock pulse in all non-instruction fetch machine cycles. In addition, we now want to suppress DMA-IN during a DMA machine cycle. We therefore create DMA-IN as the NAND of SR and SC0. SC0 will be low only for instruction fetch and DMA machine cycles. Since DMA is not sampled during instruction fetch, the net effect of our logic is to disable DMA-IN during a DMA machine cycle. Thus, in Figure 12-12, DMA-IN will be sampled low at the end of T6, which means that the next machine cycle becomes a DMA-IN machine cycle. During this machine cycle SR remains low; however, DMA-IN goes high shortly after SC0 goes low.

We use SC0 and SC1 to create the CDP1852 select inputs. SC1 is tied directly to CS2, while CS0 is inverted and then becomes SC1. Therefore, shortly after the beginning of the DMA-IN machine cycle, the data that was input via D10-DI7 appears at D00-D07, which are connected to the COSMAC Data Bus (BUS0-BUS7). Data remains stable on the bus for almost the entire DMA-IN machine cycle. The MWR low pulse, when it appears, strobes the data from the Data Bus into the memory location addressed by Register R0.

External logic can use SR as its handshaking signal. When SR goes low, external logic knows that the CPU has been informed of data present at the CDP1852 I/O port. When SR goes high again, external logic knows that the DMA-IN machine cycle is complete; therefore, external logic is free to input the next byte of data.

## CDP1852 OUTPUT OPERATIONS

Now consider a CDP1852 device operating in output mode.

There are two ways in which it would make sense to operate the CDP1852 device in output mode: the CPU could initiate the operation by executing an output instruction, or external logic could initiate the operation by applying a low signal at DMA-OUT. Figure 12-13 provides timing and signal connections for the CPU initiating the output operation with an output instruction. Figure 12-14 provides timing and signal connections for external logic initiating the output operation by applying a low signal at DMA-OUT.



Figure 12-13. CDP1852 I/O Port in Output Mode with Programmed Output

First consider the CDP1852 I/O port operating in output mode with programmed output, as illustrated in Figure 12-13. Before looking at this figure in detail, you should be familiar with Figure 12-9 and its associated text.

When a CDP1852 I/O port is being operated in output mode, the output lines D00-D07 are always active, outputting the contents of the I/O port. Data input via DIO-DI7 is latched into the I/O port by the combination of CLK high, CS2 high, and CS1 low. In Figure 12-13 we connect CLK to TPB; this becomes the actual data strobe. This data strobe is conditioned by CS2 being high and CS1 being low. CS1 is tied to the memory read control signal MRD, which must be low during an output operation. CS2 is connected to the I/O select lines N0, N1, and N2, thus creating the required device select when more than one CDP1852 I/O port is present. As soon as the

data input is strobed into the CDP1852 I/O port, it is output via D00-D07, and the service request signal SR goes high. SR is held high until the falling edge of TPB during the next machine cycle, which will be an instruction fetch. The fact that the next machine cycle is an instruction fetch is not relevant to external logic, which simply knows that it is going to receive a signal pulsed high for one machine cycle to identify the presence of new output data.

There are certain frequencies of operation where TPB is not pulsed high while the CPU is outputting stable data on the Data Bus. Under these circumstances, you will have to use some alternative logic to generate CLK.

**Figure 12-14 illustrates CDP1852 output mode operation using the CPU direct memory access logic. Before looking at this figure, you should be familiar with Figure 12-7 and associated discussion.**



Figure 12-14. CDP1852 I/O Port in Output Mode with DMA Output

External logic initiates the data output in Figure 12-14 by inputting a low signal via DMA-OUT. This signal must be low at the end of T6 in a non-instruction fetch machine cycle. The DMA-OUT machine cycle is identified by SC0 high and SC1 low; this combination is sent back to external logic as a DMA acknowledge. External logic must use this DMA acknowledge in order to set DMA-OUT high again. If DMA-OUT remains low for the DMA-OUT machine cycle, then a number of DMA-OUT machine cycles will be executed.

During the DMA-OUT machine cycle, valid data is output from the memory location addressed by R0. The presence of valid data on the Data Bus is identified by the TPB high pulse with MRD low. The CPU Data Bus is connected to the CDP1852 D10-D17 input lines. This data input is clocked into the CDP1852 device by CLK high, CS2 high, and CS1 low. In order to achieve these conditions, we once again connect CLK to TPB and CS1 to MRD. CS2, which was generated from N0, N1, and N2 in Figure 12-13, is now generated from SC0 and SC1. When these two signals identify a DMA machine cycle, CS2 is true. CS2 also becomes the DMA acknowledge signal which is sent back to external logic.

As soon as CLK is high, SC0 is high, and SC1 is low, data input via D10-D17 is strobed into the CDP1852 I/O port. This data immediately appears at D00-D07, and SR is output high. As illustrated in Figure 12-13, SR will remain high until the next high-to-low transition of CLK — which will occur at the end of the next machine cycle.

As seen by external logic, the output operation illustrated in Figure 12-14 begins when external logic inputs DMA-OUT low. Upon receiving DMACK high, external logic must set DMA-OUT high again. When SR subsequently is output high, external logic knows that new data has been output and must be read.

## DATA SHEETS

This section contains specific electrical and timing data for the following devices:

- COSMAC CDP1802
- COSMAC CDP1852

## RECOMMENDED OPERATING CONDITIONS

| CHARACTERISTIC                                                          | CONDITIONS                          |                        | LIMITS AT 25°C                     |                                    | UNITS      |
|-------------------------------------------------------------------------|-------------------------------------|------------------------|------------------------------------|------------------------------------|------------|
|                                                                         | V <sub>CC</sub> <sup>1</sup><br>(V) | V <sub>DD</sub><br>(V) | CDP1802D                           | CDP1802CD                          |            |
| Supply-Voltage Range                                                    | —                                   | —                      | 4 to 12                            | 4 to 6                             | V          |
| Input Voltage Range                                                     | —                                   | —                      | V <sub>SS</sub> to V <sub>CC</sub> | V <sub>SS</sub> to V <sub>CC</sub> | V          |
| Maximum Clock Input Rise or Fall Time, t <sub>r</sub> or t <sub>f</sub> | 4–12                                | 4–12                   | 1                                  | 1                                  | μs         |
| Instruction Time <sup>2</sup>                                           | 5                                   | 5                      | 5                                  | 5                                  | μs         |
|                                                                         | 5                                   | 10                     | 4                                  | —                                  |            |
|                                                                         | 10                                  | 10                     | 2.5                                | —                                  |            |
| Maximum DMA Transfer Rate                                               | 5                                   | 5                      | 400                                | 400                                | KBytes/sec |
|                                                                         | 5                                   | 10                     | 500                                | —                                  |            |
|                                                                         | 10                                  | 10                     | 800                                | —                                  |            |
| Maximum Clock Input Frequency, f <sub>CL</sub> <sup>3</sup>             | 5                                   | 5                      | DC – 3.2                           | DC – 3.2                           | MHz        |
|                                                                         | 5                                   | 10                     | DC – 4                             | —                                  |            |
|                                                                         | 10                                  | 10                     | DC – 6.4                           | —                                  |            |

## NOTES:

1. V<sub>CC</sub> < V<sub>DD</sub>; for CDP1802CD V<sub>CC</sub> = V<sub>DD</sub> = 5 volts.
2. Equals 2 machine cycles—one Fetch and one Execute operation for all instructions except Long Branch and Long Skip, which require 3 machine cycles—one Fetch and two Execute operations.
3. Load Capacitance (C<sub>L</sub>) = 50 pF.



CDP 1802  
Typical power dissipation as a function of clock frequency for BRANCH instruction and IDLE instruction for CDP1802D.

## CDP 1802

## ELECTRICAL CHARACTERISTICS

## Static

| CHARACTERISTIC                                                 | CONDITIONS |              |                      | LIMITS AT INDICATED TEMPERATURES (°C) |       |       |       |       |       |      | UNITS |  |
|----------------------------------------------------------------|------------|--------------|----------------------|---------------------------------------|-------|-------|-------|-------|-------|------|-------|--|
|                                                                | $V_O$ (V)  | $V_{IN}$ (V) | $V_{CC}, V_{DD}$ (V) | VALUES                                |       |       |       | +25   |       |      |       |  |
|                                                                |            |              |                      | -55                                   | -40   | +85   | +125  | Min.  | Typ.  | Max. |       |  |
| Quiescent Device Current, $I_L$ Max.                           | —          | —            | 5                    | —                                     | —     | —     | —     | —     | 1     | 100  | μA    |  |
|                                                                | —          | —            | 10                   | —                                     | —     | —     | —     | —     | 10    | 500  |       |  |
|                                                                | —          | —            | 15                   | —                                     | —     | —     | —     | —     | —     | 1000 |       |  |
|                                                                | —          | —            | 5                    | —                                     | —     | —     | —     | —     | —     | 500  |       |  |
| Output Low Drive (Sink) Current, $I_{OL}$ Min. (Except XTAL)   | 0.4        | 0.5          | 5                    | 1.98                                  | 1.89  | 1.14  | 0.90  | 1.5   | 2.2   | —    | mA    |  |
|                                                                | 0.5        | 0.10         | 10                   | 3.70                                  | 3.53  | 2.13  | 1.68  | 2.8   | 5.2   | —    |       |  |
| XTAL Output $I_{OL}$ Min.                                      | 0.4        | 5            | 5                    | 132                                   | 126   | 76    | 60    | 100   | —     | —    | μA    |  |
| Output High Drive (Source Current) $I_{OH}$ Min. (Except XTAL) | 4.6        | 0.5          | 5                    | -0.46                                 | -0.44 | -0.27 | -0.21 | -0.35 | -0.51 | —    | mA    |  |
|                                                                | 9.5        | 0.10         | 10                   | -1.12                                 | -1.07 | -0.65 | -0.51 | -0.85 | -1.3  | —    |       |  |
| XTAL Output $I_{OH}$ Min.                                      | 4.6        | 0            | 5                    | 66                                    | 63    | 38    | 30    | -50   | —     | —    | μA    |  |
| Output Voltage Low-Level $V_{OL}$ Max.                         | —          | 0.5          | 5                    | 0.00                                  |       |       |       | —     | 0     | 0.05 | V     |  |
|                                                                | —          | 0.10         | 10                   | 0.05                                  |       |       |       | —     | 0     | 0.05 |       |  |
| Output Voltage High Level, $V_{OH}$ Min.                       | —          | 0.5          | 5                    | 4.95                                  |       |       |       | 4.95  | 5     | —    | V     |  |
|                                                                | —          | 0.10         | 10                   | 9.95                                  |       |       |       | 9.95  | 10    | —    |       |  |
| Input Low Voltage $V_{IL}$ Max.                                | 0.5,4.5    | —            | 5                    | 1.5                                   |       |       |       | —     | —     | 1.5  | V     |  |
|                                                                | 0.5,4.5    | —            | 5,10                 | 1                                     |       |       |       | —     | —     | 1    |       |  |
|                                                                | 1.9        | —            | 10                   | 3                                     |       |       |       | —     | —     | 3    |       |  |
| Input High Voltage $V_{IH}$ Max.                               | 0.5,4.5    | —            | 5                    | 3.5                                   |       |       |       | 3.5   | —     | —    | V     |  |
|                                                                | 0.5,4.5    | —            | 5,10                 | 4                                     |       |       |       | 4     | —     | —    |       |  |
|                                                                | 1.9        | —            | 10                   | 7                                     |       |       |       | 7     | —     | —    |       |  |

# CDP 1802

## CDP1802 Timing Diagram



### NOTES:

1. THIS TIMING DIAGRAM IS USED TO SHOW SIGNAL RELATIONSHIPS ONLY AND DOES NOT REPRESENT ANY SPECIFIC MACHINE CYCLE
2. ALL MEASUREMENTS ARE REFERENCED TO 50% POINT OF THE WAVEFORMS
3. SHADeD AREAS INDICATE "DON'T CARE" OR UNDEFINED STATE; MULTIPLE TRANSITIONS MAY OCCUR DURING THIS PERIOD

### CDP1802 INSTRUCTION EXECUTION TIMES

1-Byte instructions require 2 Machine Cycles: 1 Fetch, 1 Execute.

2-Byte instructions also require 2 Machine Cycles: 1 Fetch, 1 Execute.

3-Byte instructions require 3 Machine Cycles: 1 Fetch, 2 Executes.

| INSTRUCTION SIZE                   |                          |                       | % OF TOTAL REPERTOIRE | INSTRUCTION TIME @ f = |             |              |
|------------------------------------|--------------------------|-----------------------|-----------------------|------------------------|-------------|--------------|
| Bytes of Op. Code                  | Bytes of Address or Data | Total Bytes of Memory |                       | 6.4 MHz                | 3.2 MHz     | 2 MHz        |
| 1                                  | 0                        | 1                     | 93                    | 2.5 $\mu$ s            | 5 $\mu$ s   | 8 $\mu$ s    |
| 1                                  | 1                        | 2                     |                       | 3.75 $\mu$ s           | 7.5 $\mu$ s | 12.1 $\mu$ s |
| 1                                  | 2                        | 3                     |                       | —                      | 2.6 $\mu$ s | 5.2 $\mu$ s  |
| Average Instruction Execution Time |                          |                       | 8.3 $\mu$ s           |                        |             |              |

## CDP 1852

## 8-Bit Byte I/O Port

## CDP1852



- 8-bit data latch
- Directly interfaces with CDP1802
- Industry standard 24-pin packages
- 3-state outputs
- Clear input
- Designed for use in 8-bit microprocessor systems
- Fully static
- Mode selectable

## N-Bit Decoder

## CDP1853



- Allows easy expansion of I/O systems
- Buffered inputs and outputs
- Functions at full microprocessor speed
- Ties directly to "N" lines on CDP1802
- Strobed outputs for spike-free decoding
- Low power dissipation
- Provides control of up to 14 I/O devices

## RECOMMENDED OPERATING CONDITIONS

| CHARACTERISTIC       | CONDITIONS |               | LIMITS |           |      |   | UNITS |  |
|----------------------|------------|---------------|--------|-----------|------|---|-------|--|
|                      | VDD<br>(V) | Non-"C" Types |        | "C" Types |      |   |       |  |
|                      |            | Min.          | Max.   | Min.      | Max. |   |       |  |
| Supply-Voltage Range | —          | 4             | 12     | 4         | 6    | — | V     |  |
| Input Voltage Range  | —          | VSS           | VDD    | VSS       | VDD  | — | V     |  |

## ELECTRICAL CHARACTERISTICS

| CHARACTERISTIC                                                               | TEST CONDITIONS | TYPICAL VALUES AT TA = 25°C |            |               |                |               |                | UNITS |
|------------------------------------------------------------------------------|-----------------|-----------------------------|------------|---------------|----------------|---------------|----------------|-------|
|                                                                              |                 | VO<br>(V)                   | VDD<br>(V) | CDP-<br>1852D | CDP-<br>1852CD | CDP-<br>1853D | CDP-<br>1853CD |       |
| <b>Static</b>                                                                |                 |                             |            |               |                |               |                |       |
| Quiescent Device Current,<br>I <sub>L</sub> Max.                             |                 | —                           | 5          | 50            | 100            | 50            | 100            | —     |
|                                                                              |                 | —                           | 10         | 100           | —              | 100           | —              | μA    |
|                                                                              |                 | —                           | 15         | 500           | —              | 500           | —              |       |
| Output Low (Sink)<br>Current, I <sub>OL</sub> Min.                           | Any Output      | 0.4<br>0.5                  | 5<br>10    | 1.6<br>3.6    | 1.6<br>—       | 1.6<br>3.6    | 1.6<br>—       | mA    |
| Output High (Source)<br>Current, I <sub>OH</sub> Min.                        | Any Output      | 4.6<br>9.5                  | 5<br>10    | -1.6<br>-3.6  | -1.6<br>—      | -1.6<br>-3.6  | -1.6<br>—      |       |
| <b>Dynamic: t<sub>r</sub>, t<sub>f</sub> = 10 ns, C<sub>L</sub> = 100 pF</b> |                 |                             |            |               |                |               |                |       |
| Propagation Delay Time:<br>Output from CS, t <sub>CA</sub>                   |                 | —                           | 5<br>10    | 200<br>100    | 200<br>—       | —             | —              | ns    |
| Data to Output, t <sub>QD</sub>                                              |                 | —                           | 5<br>10    | 200<br>100    | 200<br>—       | —             | —              | ns    |
| CE to Output, t <sub>EOH</sub> ,<br>t <sub>EOL</sub>                         |                 | —                           | 5<br>10    | —<br>—        | —<br>—         | 200<br>100    | 200<br>—       | ns    |
| N to Outputs, t <sub>NOH</sub> ,<br>t <sub>NOL</sub>                         |                 | —                           | 5<br>10    | —<br>—        | —<br>—         | 250<br>120    | 120<br>—       | ns    |

## Chapter 13

# IM6100 MICROCOMPUTER DEVICES

**The IM6100 is an almost exact reproduction of the PDP-8E minicomputer.** The IM6100 has the same instruction set as the PDP-8E; however, there are differences in direct memory access logic. Also, the IM6100 cannot use the PDP-8E extended arithmetic element or user flag options.

Rather than concentrating on differences between the IM6100 and the PDP-8E, we will in this chapter relate the IM6100 to other microprocessors described in this book. This reflects the fact that minicomputer concepts are simply not viable in the microcomputer world. The PDP-8E was developed at a time when Central Processing Units were very expensive and it was reasonable to demand that controllers surrounding the Central Processing Unit contain a lot of internal intelligence. This intelligence, in turn, demanded complex System Bus signals that identified the state of the CPU as it progressed through an instruction's execution. Microcomputers are inexpensive, and their low cost is defeated if they have to be surrounded by expensive device controllers. Therefore, it will be more valuable in this chapter to show how the IM6100 can be used in a microcomputer system with a simple bus and standard microcomputer support devices, rather than comparing it with the PDP-8E minicomputer.

**The PDP-8 is a 12-bit minicomputer, therefore the IM6100 is a 12-bit microcomputer.**

The very existence of the IM6100 is testimony to one of the less well understood aspects of minicomputers versus microcomputers: people tend to place too much emphasis on "creeping featurism". The majority of applications that are going to use a microcomputer could be implemented with almost any microcomputer described in this book. The economics of exact chip counts and product development expense is worth exploring, but in most cases detailed comparative evaluations of instruction sets and addressing modes are a waste of time and money; enhancement of one product as compared to another will rarely have any significant economic impact. This is true of microcomputers today, and it was also true of minicomputers yesterday. The PDP-8 was the first popular minicomputer. Compared to nearly any other minicomputer on the market today, the PDP-8 is a very primitive device. Yet there are more PDP-8s in the world than any other minicomputer. Despite the large number of new, more powerful minicomputers that are available, the PDP-8 continues, from year to year, to rank among the leaders in minicomputer sales volume.

It is this popularity of the PDP-8, for all its shortcomings as a minicomputer, that has given birth to the IM6100. Many design features of the IM6100 are dubious, when looked upon from the microcomputer user's point of view. It is safe to say that no microcomputer designer would have seen fit to develop a product even remotely like the IM6100, but for the predecessor PDP-8. The IM6100 exists to participate in the continuing sales volume of PDP-8, and to take advantage of the huge library of PDP-8 software which is available — much of it at no cost.

You must look at the IM6100 (and the microNOVA) from a totally different perspective, as compared to any other microcomputer described in this book: do not look for justification of IM6100 design features in terms of a microcomputer application's needs; rather, accept the IM6100 for what it is — a very low-cost reproduction of something which already exists; a product whose existence is justified by a large established product market and a prior base of existing software.

**In addition to the IM6100 CPU, we are going to describe the IM6101 Parallel Interface Element and the IM6102 MEDIC multifunction support device. The IM6402 UART is also available; it is described in Volume 3.**

All IM6100 microcomputer devices use a single power supply which may range between +4V and +11V.

Using a 250 nanosecond clock input, instruction execution times range from 5 to 11 microseconds.

All IM6100 microcomputer devices use CMOS technology, which means that they are highly immune to noise in the power supply and they consume very little power. Recall that COSMAC is the only other microprocessor described in this book that offers CMOS technology.

The principal manufacturer of the IM6100 is:

INTERSIL, INC.  
10900 North Tantau Avenue  
Cupertino, CA 95014

The second source is:

HARRIS SEMICONDUCTOR DIVISION  
P.O. Box 883  
Melbourne, FLA 32901

## THE IM6100 CPU

Functions implemented on the IM6100 CPU are illustrated in Figure 13-1. IM6101 Parallel Interface Element logic is also shown.



Figure 13-1. Logic of the IM6100 CPU and the IM6101 Parallel Interface Element

Bus interface logic is shown as implemented by the IM6101. This is because the bus control signals input to and output by the CPU do not conform with the standard PDP-8 bus, or with typical microcomputer busses. You are going to need additional logic either to create a PDP-8 bus equivalent, or to reduce IM6100 control signals to manageable microcomputer bus proportions. The IM6101 creates a microcomputer type of System Bus.

Direct memory access control logic is shown as absent. The CPU has logic which will respond to a DMA request by floating the System Bus; however, the actual DMA transfer, including creation of memory addresses, is the responsibility of external logic.

Observe that clock logic is provided on the CPU chip.

## IM6100 PROGRAMMABLE REGISTERS

The IM6100 has just three programmable registers as we define them: an Accumulator, a Program Counter and the MQ register. All three registers are twelve bits wide.

**The Accumulator** is a typical primary Accumulator. With a single exception, it is the only source or destination within the CPU for data being operated on.

**The MQ register** is a simple buffer for the Accumulator. The only operation you can perform on the MQ register contents is to OR them with the Accumulator contents; the result is returned to the Accumulator. You may also exchange the contents of the Accumulator and the MQ register.

**The Program Counter, being 12 bits wide, limits the IM6100 to an address space of 4096 memory words.** The IM6102 allows this address space to be expanded to 32,768 memory words.

**Intersil literature describes additional registers, but these are not programmable registers as we define them.**

The IM6100 has no Data Counter. There is a Memory Address register within the CPU, but you have no direct access to this register. It is a simple depository for addresses which are automatically computed by CPU logic during the execution of memory reference instructions.

## IM6100 MEMORY SPACE

Memory addressing modes that we are about to describe apply to a single 4096-word memory bank. If you have more than one such memory bank, then each one must be considered as a separate and distinct entity. This is important, because the nature of the IM6100 demands that if program memory is in ROM, then both ROM and RAM must be present in external memory. Thus, if you have more than one bank, each memory bank must include ROM and RAM.

## IM6100 MEMORY ADDRESSING MODES

**IM6100 memory reference instructions use absolute, paged, direct addressing and indirect addressing.**

All IM6100 instruction object codes occupy a single 12-bit word. There are no two-word or three-word object codes. All memory reference instructions have the following object code format:



A memory reference instruction that uses direct addressing has seven address bits; thus memory is divided into 128-word pages. The memory page bit gives you the option of directly addressing a memory word on Page 0, or within the instruction's page:



This is standard, absolute paged direct addressing, as described in Volume 1, Chapter 6.

A memory reference instruction with indirect addressing simply takes the 12-bit word accessed by the direct memory address and interprets this 12-bit word's contents as the effective memory address. This is standard indirect addressing. In the case of the IM6100, a **memory reference instruction can access an indirect memory address either on the base page or on the instruction's current page**.

You can use indirect addressing to create the equivalent of a two-word, nonpaged direct addressing Jump instruction.

To do this, store the 12-bit absolute direct address directly following the Jump Indirect instruction. This may be illustrated as follows:



You cannot use this technique with any memory reference instruction other than a Jump. That is because any other instruction would leave the Program Counter pointing to the indirect address as the next object code to be executed.

For memory reference instructions other than a Jump, reserve a few memory words at the end of the current page to store indirect addresses. This may be illustrated as follows:



**The IM6100 also has auto-indexed indirect addressing.** If you store an indirect address in any one of the eight memory words with addresses 008<sub>16</sub> through 00F<sub>16</sub> then, when the IM6100 CPU fetches this address, it will also increment and return it.

For example, you can store the beginning address of a table in memory location 008<sub>16</sub>. You can subsequently read sequential table words by indirectly accessing the table. The IM6100 benchmark program illustrates this use of auto-indexing.

It is just as well that the IM6100 has indirect addressing with auto-increment, because it has no Data Counter or implied memory addressing. Volume 1, Chapter 6 discusses the problems that result from using direct addressing to access sequential memory locations when programs are stored in read-only memory.

**Note that the IM6100 makes no distinction between program and data memory.** Thus Jump instructions use exactly the same memory addressing options as memory read or write instructions. The concept of separate program and

data memory is a microcomputer phenomenon, because it was only with the advent of the microcomputer that programs started to be stored in read-only memory. Minicomputers use read/write memory for programs and data — and frequently a minicomputer will make no clear separation between the memory spaces that will be assigned to programs as against data.

**The way in which the IM6100 handles subroutine calls represents an excellent illustration of the fact that minicomputer concepts can run into trouble in the world of microcomputers.**

**When a JMS instruction is executed, the return address is stored in the first word of the subroutine's object code.**

The scheme certainly made sense to the PDP-8 designers: they visualized memory as a general read/write depository for programs and data. This scheme is nonviable when programs are stored in read-only memory, since you cannot write a return address in read-only memory. In order to use subroutines with an IM6100, you must origin all subroutines in read/write memory, then jump to a program sequence stored in read-only memory. This may be illustrated as follows:

**IM6100  
SUBROUTINES  
IN READ-ONLY  
MEMORY**

/BASE PAGE STARTS HERE

```
-  
-  
SUBA 0      /FIRST WORD OF SUBROUTINE SUBA  
JMP I .+1    /JUMP INDIRECT TO SUBROUTINE IN ROM  
PPQ      /PPQ REPRESENTS THE STARTING ADDRESS IN ROM
```

```
-  
-  
-  
*PPQ      /SUBROUTINE ORIGIN IN ROM
```

```
-  
-  
-  
-  
JMP I SUBA  /LAST INSTRUCTION OF SUBROUTINE IN ROM
```

/MAIN PROGRAM WHICH CALLS SUBROUTINE SUBA

```
-  
-  
-  
JMS  SUBA  /SUBROUTINE CALL  
DCA  DATA   /EVENTUAL SUBROUTINE RETURN
```

Let us examine the path of instruction execution illustrated above.

Begin by looking at the JMS SUBA instruction in the main program which calls subroutine SUBA. SUBA is a label representing a location in the base page of memory. When the JMS SUBA instruction is executed, the address of the next instruction, arbitrarily illustrated above as a DCA instruction, will be stored in the memory word with label SUBA. The first instruction executed following the Jump-to-Subroutine is the instruction stored in the memory location following SUBA; this is the JMP I .+1 instruction. This instruction jumps indirect via the address stored in the next memory location; we represent this memory location's contents with PPQ. PPQ is the address of the first instruction to be executed within the subroutine. This instruction, and all subsequent subroutine instructions are stored in read-only memory. The last instruction executed by the subroutine in read-only memory is the JMP I SUBA instruction. This instruction per-

forms an indirect jump via the address stored at SUBA. This is the address of the DCA DATA instruction. This execution sequence may be illustrated as follows:

/BASE PAGE STARTS HERE



#### **Handling subroutine calls through RAM has some non-obvious repercussions.**

First of all, at least the first page of every 4096-word memory bank must be read/write memory; this is due to the way the IM6100 handles interrupts, which we will discuss later. In all probability, there will be more than one page of read/write memory.

Next, if you are going to initiate subroutines in Page 0 RAM, then when you power up the system, you must load this RAM from ROM. This is because RAM will lose its contents when powered down. Thus, every restart or reset procedure must include the execution of an instruction sequence which moves a block of data from ROM to Page 0 RAM.

Possibly the most serious problem associated with calling subroutines through Page 0 RAM is the fact that, apart from interrupt handling, existing PDP-8 software does not do that. Thus, if you are going to implement programs in read-only memory, the existing PDP-8 software base is not available to you — and that is one of the principal reasons for the IM6100's existence. Converting existing PDP-8 programs, so that subroutines are called through Page 0 RAM, is not a simple task. If you look again at the discussion of direct, paged addressing given in Volume 1, Chapter 6, you will see that there are very significant problems associated with memory mapping. Programs cannot lie across page boundaries; therefore, the addition of a few instructions to any one program can have serious consequences. In some cases it may be possible to generate special assemblers and compilers that convert existing source programs into object programs which partition memory into ROM for programs and RAM for data, allowing subroutines to be called via the base page — but that assumes the base page has free space available for this purpose.

**There is a hardware solution to the IM6100 Jump-to-Subroutine problem.** This solution uses an external read/write memory Stack to store subroutine return addresses in the manner of a conventional stack. Necessary logic and minor programming ramifications are described later in this chapter.

### **IM6100 STATUS FLAGS**

The IM6100 has a single Carry status; it is called the Link or L status in PDP-8 and IM6100 literature.

### **IM6100 CPU PINS AND SIGNALS**

**IM6100 CPU pins and signals are illustrated in Figure 13-2.** Once again, the minicomputer ancestry of the IM6100 is evident from the complex control signals input and output by the CPU. Minicomputer designers favor a rich variety of control signals on a System Bus because that makes the job of designing peripheral device controllers easier. Microcomputers rely on low-cost support devices, and complex System Busses simply increase the complexity and cost of surrounding the CPU with support logic. After reading this summary of IM6100 pins and signals, compare it to the 8080A described in Chapter 4; then compare it with the MCS6500 described in Chapter 10. The MCS6500 represents the ultimate in simplicity.



| Pin Name        | Description                                        | Type          |
|-----------------|----------------------------------------------------|---------------|
| DX0 - DX11      | Data and Address Bus                               | Bidirectional |
| OSC OUT         | Crystal or external clock                          | Input         |
| OSC IN          | Crystal or external clock ground                   | Input         |
| XTA, XTB, XTC   | Machine cycle timing                               | Output        |
| LXMAR           | External memory address strobe                     | Output        |
| DEVSEL          | I/O device select strobe                           | Output        |
| IFETCH          | Instruction Fetch machine cycle identifier         | Output        |
| MEMSEL          | Memory select strobe                               | Output        |
| DATAF           | Execution phase of indirect addressing instruction | Output        |
| LINK            | Link status                                        | Output        |
| RUN/HLT         | Run/Halt control                                   | Input         |
| RUN             | CPU running status                                 | Output        |
| RESET           | Reset                                              | Input         |
| WAIT            | Wait state control                                 | Input         |
| C0, C1, C2, SKP | CPU control during I/O operation                   | Input         |
| DMAREQ          | DMA request                                        | Input         |
| DMAGNT          | DMA grant                                          | Output        |
| INTREQ          | Interrupt request                                  | Input         |
| INTGNT          | Interrupt grant                                    | Output        |
| CPREQ           | Control panel interrupt request                    | Input         |
| CPSL            | Control panel memory select                        | Output        |
| SWSEL           | Switch register select                             | Output        |
| VCC, GND        | Power and Ground                                   |               |

Figure 13-2. IM6100 CPU Signals and Pin Assignments

The IM6100 has a single 12-bit multiplexed Data and Address Bus, represented by pins DX0 - DX11. Memory and I/O interface logic must use appropriate control signals in order to demultiplex data and addresses off this single bus.

Intersil literature numbers the bits of registers and memory words from left to right; that is to say, with the 0 bit representing the high-order bit. In this book we consistently number bits of registers and words from right to left; that is to say, with the low-order bit represented by the 0 bit. Data/Address Bus lines are confusing when you compare the discussion in this chapter with Intersil literature. In Figure 13-2, DX0 - DX11 signals are identified first with labels that conform to Intersil literature; the bracketed labels that

IM6100 BIT  
NUMBERING

follow show the signal name that agrees with bit numbering as used in this book. The two bit-numbering and signal-naming systems may be compared as follows:



The remaining signals can be divided into timing, bus control, CPU control, DMA and interrupt control.

Let us consider timing signals first.

**OSC IN** and **OSC OUT** are clock signal pins. If you are using the internal clock logic, then a crystal must be connected across these two pins. If you are using an externally generated clock signal, then it must be input via OSC OUT — OSC IN must be grounded.

**XTA, XTB and XTC** are three timing signals which are output for external logic to identify the state of an instruction's execution. Timing and states are illustrated in Figure 13-3.



Figure 13-3. IM6100 Machine Cycles and Clock Periods

Let us now look at the signals output by the CPU to define events on the System Bus.

**LXMAR** is output as a high pulse which external logic can use to strobe an address off the Data/Address Bus.

**DEVSEL** is output as a low pulse when information on the Address/Data Bus must be interpreted by I/O devices as device identification or I/O operation control.

**IFETCH** is output high for the duration of an instruction fetch machine cycle. IFETCH may be used as a synchronization signal identifying the beginning of a new instruction cycle.

**MEMSEL** is output as a low pulse during a memory reference operation. Memory interface logic determines whether a memory read or a memory write is in progress via the condition of the XTA, XTB and XTC signals. (Only XTB is really necessary for this purpose.)

**DATAF** is a signal output high during the execute phase of an instruction that uses indirect addressing.

**LINK** is a signal output at all times to represent the level of the Link status. We include this signal among control outputs because you can use it as a direct external logic control signal. By executing instructions to set or reset the Link status you can modify the level of this control signal on a real time basis.

**Let us now consider the control signals input by external logic to control CPU operations.**

**RUN/HLT** is a control input which allows external logic to halt the CPU. This signal is similar to the Halt input which some 8-bit microcomputers have, but its purpose in the IM6100 is to give control panel logic some means of executing program instructions one at a time. This helps in debugging.

**RUN** is output high when the CPU is running; it is output low when the CPU has been halted.

**RESET** is a typical reset input. When input low, it clears all CPU registers except the Program Counter, which is loaded with FFF16.

**WAIT** is used by slow external logic which needs to acquire more time to respond to a memory or I/O access. As long as **WAIT** is input low, the CPU will maintain register and signal levels, but not advance the state of an instruction's execution.

**C0, C1, C2 and SKP** are very unusual input control signals. During an I/O operation (that is, while an IOT instruction is being executed), **external logic can use these four control signals in order to determine CPU operations.**

Control signals **C0**, **C1** and **C2** are interpreted by the CPU as follows:

| <b>C2</b> | <b>C1</b> | <b>C0</b> |                                                                             |
|-----------|-----------|-----------|-----------------------------------------------------------------------------|
| L         | L         | X         | Transfer data from DX0 - DX11 to Program Counter (execute an absolute jump) |
| L         | H         | X         | Add data on DX0 - DX11 to Program Counter (execute a program relative jump) |
| H         | L         | L         | Load data from DX0 - DX11 to Accumulator                                    |
| H         | L         | H         | OR data from DX0 - DX11 with Accumulator                                    |
| H         | H         | L         | Transfer Accumulator contents to DX0 - DX11, then clear Accumulator         |
| H         | H         | H         | Transfer Accumulator contents to DX0 - DX11 but do not clear Accumulator    |

X represents "don't care"; **C0** may be low or high.

If external logic inputs **SKP** low during an IOT instruction, then the CPU will skip the instruction which immediately follows the IOT. **SKP** logic is separate and distinct from **C0**, **C1** and **C2** logic.

Two signals support DMA operation. **External logic requests DMA access by inputting a low signal via DMAREQ.** As soon as the current instruction has completed execution, **the CPU responds by outputting DMAGNT high.** At this point the Data/Address Bus is floated. External logic must provide all DMA transfer signals; the only thing the CPU does in response to a DMA request is float the Data/Address Bus for a single instruction cycle. The bus is floated for as long as **DMAREQ** is held low. **DMAREQ** and **DMAGNT** are rarely used. The IM6102 provides simultaneous DMA logic, which is preferred.

Interrupt logic reflects the IM6100's minicomputer heritage. **Normal interrupts are requested via INTREQ being input low. Upon acknowledging an interrupt, the CPU will output INTGNT high.** Microcomputers are no different; but an IM6100 control panel interrupt request has its own dedicated **CPREQ** signal. Microcomputers do not assume the possible presence of a control panel.

Two additional control signals are provided to support the presence of a control panel. The IM6100 control panel will have its own memory in order to support logic required by switches and indicators of the control panel. **Following a control panel interrupt, CPSEL is output low instead of MEMSEL, so that programs can be executed out of control panel memory, rather than out of main memory.**

There is also an instruction which reads the contents of control panel switches and ORs them with the contents of the Accumulator. **SWSEL is output low in order to inform control panel logic that switch levels must be returned as data on the Data/Address Bus.**

## IM6100 TIMING AND INSTRUCTION EXECUTION

An IM6100 instruction's execution is timed by a sequence of machine cycles, each of which is subdivided into clock periods. A machine cycle may have five or six clock periods. Machine cycles and clock periods are identified by the CLOCK, XTA, XTB, and XTC signals, as illustrated in Figure 13-3. Note that each clock period consists of two external clock cycles.

IM6100 machine cycles, like those of almost any other microcomputer, consist of memory or I/O read cycles,

**memory or I/O write cycles and CPU operation cycles. Specific events occur only during specific clock periods of a machine cycle.**

A memory or I/O device address is output during T1.

Data is input during T2. The I/O control input lines C0, C1, C2 and SKP must be input during T2, with timing conforming to data input.

Internal CPU operations occur during T3, T4 and T5.

Data is output during T6.

**IM6100  
CLOCK  
PERIOD  
ASSIGNMENTS**

In order to best understand the nature of different IM6100 machine cycles, we will begin by looking at the basic data input, data output and no operation machine cycles. Then we will look at specific interpretations of these machine cycles for various types of instruction execution.

### **IM6100 NO OPERATION MACHINE CYCLE**

An IM6100 "no operation" machine cycle may have five or six clock periods. Only the XTA, XTB and XTC signals change levels during a no operation machine cycle, therefore **Figure 13-3** (excluding the sixth clock period) illustrates a no operation machine cycle.

### **IM6100 DATA INPUT MACHINE CYCLE**

**Data input machine cycle timing is illustrated in Figure 13-4.** Observe that there are four different sources for data being input to the CPU. The four different sources are identified by individual select lines.

### **IM6100 DATA OUTPUT MACHINE CYCLE**

**Data output machine cycle timing is illustrated in Figure 13-5.** Data output occurs during the T6 clock period of the machine cycle, and is identified by a low Select pulse; otherwise, timing is the same as illustrated in Figure 13-4.



Figure 13-4. IM6100 Data Input Machine Cycle Timing



Figure 13-5. IM6100 Data Output Machine Cycle Timing

## IM6100 ADDRESS DEMULTIPLEXING

The minicomputer flavor of the IM6100 can cause some initial confusion when you try to interface devices to its System Bus. **Normally, if we encounter a multiplexed Data and Address Bus, we immediately demultiplex the bus to create separate Data and Address Busses.** Indeed, this is easy enough to do when working **with the IM6100**, but it is not necessary. Providing the address stable time on the Data/Address Bus is satisfactory, memory and I/O devices can simultaneously use the LXMAR high pulse as an address or device select strobe. Since there are separate subsequent control strobes for memory, I/O devices and control panel logic, the fact that an ambiguous address appeared earlier is irrelevant. Without the subsequent control strobe, a memory device that was spuriously selected by an I/O instruction, for example, will not perform a read or write operation. Moreover, the IM6101 Parallel Interface Element creates unique select strobes for individual I/O devices, as we will see later in this chapter. **The only occasion when you will almost certainly want to demultiplex the IM6100 Data/Address Bus is if you are creating a System Bus which is compatible with some other microcomputer — for example, the 8080A.**



Figure 13-6. IM6100 Memory Read Machine Cycle Timing



Figure 13-7. IM6100 Instruction Fetch Machine Cycle



Figure 13-8. Machine Cycle Timing for Memory Read from Indirectly Addressed Location

## IM6100 MEMORY READ MACHINE CYCLE TIMING

Figure 13-6 represents the memory read variation of Figure 13-4. **MEMSEL** is pulsed low for a select, but otherwise the two figures are identical.

Logically there is no difference between an instruction fetch machine cycle and a memory read machine cycle; however, the IM6100 outputs **IFETCH** high for the duration of the instruction fetch, memory read machine cycle. Timing is illustrated in Figure 13-7.

There is one additional memory read machine cycle which is specifically identified via its own signal. Memory reference instructions AND, TAD, and ISZ, if they specify indirect addressing, output **DATAF** high for the duration of the machine cycle that carries the indirect address as an address, rather than data. Figure 13-8 illustrates timing for a machine cycle during which the CPU reads from an indirectly addressed memory location. **DATAF** is not output high when JMP or JMS instructions specifying indirect addressing are executed.

The IM6100 has two instructions that read data from memory to the Accumulator: the AND and TAD instructions. Without indirect addressing, each of these instructions will be executed in two machine cycles: the first machine cycle will be an instruction fetch, as illustrated in Figure 13-7, while the second machine cycle will be a memory read, as illustrated in Figure 13-6. If either of these instructions specifies indirect addressing, then the instruction will be executed in three machine cycles. The first machine cycle will be a simple instruction fetch, as illustrated in Figure 13-7. The second machine cycle will be a simple memory read, as illustrated in Figure 13-6; however, during this machine cycle the effective memory address will be read as data. The third machine cycle will be an indirect addressing memory read, as illustrated in Figure 13-8. The data input during the second machine cycle will be output as an address during the third machine cycle.

The ISZ instruction reads from memory, increments the data just read, and writes it back. The sequence of machine cycles used to execute ISZ is almost the same as sequences for AND and TAD; the only difference is that, for ISZ, a

|                                                                      |
|----------------------------------------------------------------------|
| <b>IM6100<br/>INSTRUCTION<br/>FETCH MACHINE<br/>CYCLE</b>            |
| <b>IM6100<br/>INDIRECTLY<br/>ADDRESSED<br/>MEMORY<br/>READ CYCLE</b> |

memory write cycle follows the last memory read cycle. Thus, the CPU executes an ISZ without indirection in three machine cycles: an instruction fetch, a memory read, and a memory write. If indirect addressing has been specified, there will be four machine cycles: an instruction fetch followed by a memory read, an indirect addressing memory read, and a memory write. Figure 13-9 shows ordinary memory write timing.



Figure 13-9. IM6100 Memory Write Machine Cycle Timing

### IM6100 MEMORY WRITE MACHINE CYCLE

A simple IM6100 memory write machine cycle is illustrated in Figure 13-9. This figure is identical to Figure 13-5, except that MEMSEL is shown generating a low strobe in T6.

The IM6100 has two instructions that write to memory: the DCA and the ISZ instructions. Also, any memory reference instruction that specifies indirect addressing with auto-increment must write into memory. This is because when auto-increment addressing is specified, the indirect address which is fetched from one of the memory locations 0816 through OF16 is incremented, then written back to the same memory location.

A simple memory write machine cycle with indirect addressing will have timing identical to Figure 13-9, except that DATAF will pulse high for the duration of the machine cycle, as illustrated in Figure 13-10. The memory address, output during this indirect addressing, memory write machine cycle will have been input as data during the previous machine cycle, which will be a simple memory read machine cycle with timing as illustrated in Figure 13-6.

Any memory reference instruction that specifies indirect addressing with auto-increment will insert a write during T6 of the second machine cycle. During this machine cycle, the indirect address will be fetched from one of the memory locations with addresses 0816 through OF16. During the T6 clock period this address, having been incremented, is written back to the same memory location. During a third machine cycle, the memory read or write required by the instruction will occur. Figure 13-11 illustrates timing for an indirect addressing with auto-increment machine cycle. Observe that a memory read and a memory write occur in this single machine cycle, albeit to and from the same memory location.

**IM6100  
INDIRECTLY  
ADDRESSED  
MEMORY  
WRITE CYCLE**

**IM6100  
INDIRECT  
ADDRESSING  
WITH AUTO-  
INCREMENT  
TIMING**



Figure 13-10. Machine Cycle Timing for Memory Write to Indirectly Addressed Location



Figure 13-11. Auto-Increment Machine Cycle for an IM6100 Memory Reference Instruction that Specifies Indirect Addressing with Auto-Increment



Figure 13-12. IM6100 DCA Instruction Timing with Indirect Addressing



Figure 13-13. IM6100 DCA Instruction Timing with Indirect Addressing and Auto-Increment



Figure 13-14. IM6100 I/O Data Input Machine Cycle

Timing for execution of a DCA instruction with indirect addressing is given in Figure 13-12. Timing for this same instruction with indirect addressing and auto-increment is given in Figure 13-13.

### IM6100 INPUT/OUTPUT TIMING

A peculiarity of IM6100 input/output instructions is that they are undefined. The instruction object code's three high-order bits identify the instruction as an I/O instruction, but they do not identify the type of I/O instruction. By convention, six object code bits constitute an I/O device code, and the three remaining bits are interpreted as a control code (this is illustrated later). In reality, the I/O instruction object code must contain 110 in the three high-order bits, but the manner in which the remaining nine bits are interpreted is entirely up to external logic, which may or may not divide these nine bits into six device select bits and three I/O operation control bits. As far as the CPU is concerned, when it executes an I/O instruction, it outputs **DEVSEL** low instead of outputting **MEMSEL** low, but otherwise the CPU has no idea what is going to happen in the course of the I/O instruction's execution. The external device which considers itself selected by the I/O instruction object code determines the I/O operations which are to occur by appropriately inputting to the CPU the control signals **C0**, **C1**, **C2** and **SKP**.

If you are familiar with standard microprocessors such as the 8080A, this IM6100 I/O logic will appear very strange. The I/O device must tell the CPU what is to happen during the course of the I/O instruction's execution. All the CPU knows is that an I/O operation is in progress.



Figure 13-15. IM6100 I/O Data Output Machine Cycle

**Every IM6100 I/O instruction executes in three machine cycles.**

**The first machine cycle is a standard instruction fetch, as illustrated in Figure 13-7.**

**The second machine cycle is a variation of the data input or data output machine cycle, as illustrated in Figures 13-14 and 13-15.**

**The third I/O instruction machine cycle is a “no operation” machine cycle. The no operation machine cycle has six clock periods.** The clock, XTA, XTB, XTC, and LXMAR signals are active, but the Select lines and the Data/Address Bus are not.

The most important difference between the I/O input and output machine cycles illustrated in Figures 13-14 and 13-15, as against the standard input and output machine cycles illustrated in Figures 13-5 and 13-6, is the fact that the control inputs C<sub>0</sub>, C<sub>1</sub>, C<sub>2</sub> and SKP must be accounted for. Timing for these four signals, as inputs, must conform to data input timing. Thus, every I/O machine cycle must include a DEVSEL low pulse at read time so that the selected I/O device knows when to input the four control signals. The CPU uses these control inputs to determine whether a data input or a data output is to occur. **I/O logic will normally hold C<sub>1</sub> and C<sub>2</sub> high in between I/O operations so the default IOC instruction is a data output.** This is necessary since there is very little time separating the LXMAR high pulse and data output. C<sub>0</sub> may normally be held low or high, depending on whether the Accumulator is to be cleared or not following data output.

The I/O instruction object code, rather than an address, is output on the Data/Address Bus during T1 of any I/O instruction's second machine cycle.

By PDP-8E convention, the I/O instruction object code has the following format:



The interpretation of bits 0 through 8 is, in reality, undefined. The illustration above shows standard PDP-8E format using this convention; I/O devices must decode lines 3 through 8 to determine if they have been selected; lines 0, 1 and 2 identify operations which must be performed by the selected I/O device. The operations which the selected I/O device must perform include returning  $\overline{C0}$ ,  $\overline{C1}$ ,  $\overline{C2}$  and  $\overline{SKP}$  levels, which determine the nature of the I/O instruction for the CPU and for the selected I/O device.

A complete I/O instruction's timing is given in Figure 13-16.



Figure 13-16. IM6100 I/O Instruction Timing

## THE IM6100 WAIT STATE

External logic may insert Wait states within a data input or data output machine cycle. In each case, external logic requests the Wait state via a low WAIT input. The Wait state will generate additional T2 clock periods during a data input operation. Timing is illustrated in Figure 13-17. Additional T6 clock periods will be generated during a data output operation, as illustrated in Figure 13-18.



Figure 13-17. Wait States within an IM6100 Data Input Machine Cycle



Figure 13-18. Wait States within an IM6100 Data Output Machine Cycle

In Chapter 4, we described ways in which READY input signals can be generated in order to create Wait states of one, or of a few clock periods. Although the Chapter 4 discussion is for the 8080A microprocessor, the logic applies equally well for the IM6100.

### IM6100 HOLD AND HALT CONDITIONS

The IM6100 has a single Halt state which is equivalent to the Hold and Halt conditions of other microprocessors. The Halt state can be initiated by executing a Halt instruction, or by inputting a low signal via RUN/HLT.

The IM6100 has two control signals associated with its Halt state. **RUN/HLT** is an input which can be used to initiate and terminate Halt states. What is unusual about the RUN/HLT control input is that the low-to-high transition of this signal is active. This may be illustrated as follows:





Figure 13-19. An IM6100 Halt State Initiated by Execution  
of a HLT Instruction



Figure 13-20. An IM6100 Halt State Initiated and Terminated by the RUN/HLT Input

**The RUN output signal always indicates whether the CPU is running or has been halted.** RUN is output high while the CPU is running; RUN is output low when the CPU has halted. **Figures 13-19 and 13-20 illustrate Halt state timing.** Note that once a Halt state has been initiated, either by executing the Halt instruction or by inputting RUN/HLT low, the **Halt state will last some integral number of five-clock-period machine cycles.**

If a Halt state is initiated by the RUN/HLT input, then as soon as this input makes a low-to-high transition, an internal Run flip-flop is reset to 0. This internal flip-flop is sampled in the middle of the first clock period during the last machine cycle of the currently executing instruction. If the internal flip-flop is reset at this time, then a Halt state will begin with the next machine cycle. This internal flip-flop remains reset until the next low-to-high transition of the RUN/HLT input. During every Halt machine cycle the internal Halt flip-flop is sampled in the middle of the first Halt machine cycle clock period. As soon as the internal flip-flop is detected high again, the Halt state terminates at the end of the current Halt machine cycle with a "transition" Halt cycle, during which DMAGNT is held high. Program execution then continues with an instruction fetch on the next machine cycle. Figure 13-20 shows Halt state termination timing.

**Observe that the three clock signals XTA, XTB, and XTC continue to be output in the normal way during Halt machine cycles.**

## IM6100 DIRECT MEMORY ACCESS

**There are two ways in which direct memory access operations can be performed in an IM6100 microcomputer system.**

**You can put the IM6100 CPU into a Hold state,** during which DMA operations are being performed. In this case the CPU will slow down in order to accommodate direct memory access.

**Alternatively, direct memory access operations may occur in parallel with instruction execution** by exploiting clock periods T3, T4 and T5 of machine cycles within which no write operation occurs. This type of parallel direct memory access does not slow down the CPU.

The IM6102 MEDIC device, described later in this chapter, enables parallel direct memory access in an IM6100 microcomputer system. For a discussion of this type of direct memory access, refer to the IM6102 device description. **In the text below we will consider only the use of the Hold state to implement direct memory access operations.**

**Note that parallel direct memory access using the IM6102 MEDIC is definitely preferred.**

IM6100 Hold state DMA logic is similar to that which we have described for the 8080A in Chapter 4. **External logic that wishes to take control of the System Bus makes a DMA request by inputting DMAREQ low.** The CPU samples DMAREQ in the middle of the first clock period of a machine cycle. Upon sensing DMAREQ low, the CPU acknowledges the DMA request at the end of the currently executing instruction, providing no higher priority control input exists. Table 13-1 and associated text summarize control priorities. **When the CPU acknowledges a DMA request, it outputs DMAGNT high and suspends program execution.** The Data/Address Bus is floated and all select lines are output high; the clock signals XTA, XTB and XTC continue to function, clocking five-clock-period machine cycles. External logic must now use the System Bus to perform all DMA transfers. **Figures 13-21 and 13-22 illustrate DMA initiation and termination timing, respectively.**

DMAREQ is sampled in the middle of the first clock period of every DMA machine cycle. Upon sensing DMAREQ high, the CPU will terminate DMA operations at the conclusion of the current DMA machine cycle, and will then proceed with the next scheduled instruction fetch.

**External DMA logic is responsible for all events associated with the DMA transfer.** This includes having special device select lines. The device select lines output by the CPU cannot be used, since these are held high during a DMA transfer. This is not a significant problem; you can simply AND the DMA Select with the CPU Select in order to generate a valid memory or I/O device Select. This is possible since the inactive select input will always be held high while the active select input is pulsed low. You will have a negative-logic OR:



the select line will be active (that is, low) if either the DMA Select line or the CPU Select line is active.

**Since all DMA machine cycles have five clock periods, memory write timing during a DMA transfer cannot agree exactly with memory write timing during normal program execution.** This is not a problem, since there is sufficient time within a machine cycle to execute a memory write. Logic beyond the IM6100 does not know the difference between one clock period and another, therefore the DMA memory write can occur at any time within the DMA machine cycle.



Figure 13-21. IM6100 DMA Initiation Timing



Figure 13-22. IM6100 DMA Termination Timing

**The Halt state has priority over the DMA state.** Thus, a DMA request will not be acknowledged while the CPU is in a Halt state; however, while the CPU has acknowledged a DMA request and is executing DMA machine cycles, it will respond to a Halt request generated by a low-to-high transition of the RUN/HLT input. In the Halt state the Data/Address Bus is not floated, therefore **you must make sure that RUN/HLT does not pulse low while the CPU is acknowledging a DMA request.** This is simple enough to do. Here is appropriate logic:



**Table 13-1 summarizes operation priorities within IM6100 CPU logic.**

**You will have no trouble using the DMA control devices described in Volume 3 in order to implement direct memory access in an IM6100 microcomputer system;** however, the IM6102 is preferred in IM6100 microcomputer systems. The DMA control devices described in Volume 3 are all NMOS devices, therefore you will need CMOS-to-NMOS bidirectional drivers. These drivers may buffer the CPU from the rest of the system, or, if most of the system is implemented using CMOS technology, these buffers will isolate the DMA logic from the rest of the system.

## THE IM6100 RESET

**You must input the RESET signal low in order to reset the IM6100 CPU.** The CPU samples this signal in the middle of the first clock period during the last machine cycle of an instruction's execution. Upon detecting RESET low, the CPU enters a Reset condition beginning with the next machine cycle. The Reset condition is maintained for an exact number of five-clock-period machine cycles while the RESET input is low. When the CPU detects RESET high in the middle of the first clock period of a Reset machine cycle, the processor will begin program execution at the end of that Reset machine cycle, thus terminating the Reset state.

**Timing for the initiation and termination of a Reset condition is identical to timing for DMA initiation and termination, as illustrated in Figures 13-21 and 13-22. In these two figures, by substituting RESET for DMAREQ, and by eliminating the DMAGNT signal, you create Reset initiation and termination timing.**

**During a Reset condition the following events occur:**

- 1) The Program Counter is set to FFF16.
- 2) The Accumulator and Link flag are cleared.
- 3) The Data/Address Bus is floated.
- 4) All Select lines are output high.
- 5) The three clock signals, XTA, XTB, and XTC, continue to output, timing five-clock-period machine cycles.

The only difference between a Reset condition and a DMA condition is the fact that during the Reset condition the Accumulator and flags are cleared and the Program Counter is set to FFF16. You will normally initiate a bootstrap loader program at memory location FFF16 in order to restart the microcomputer system following a reset.

## IM6100 INTERRUPT LOGIC

**The IM6100 has two separate and distinct interrupt requests, one for the control panel and another for external devices in general. We will now discuss external devices' interrupt request logic, leaving control panel interrupt request logic to the control panel discussion which follows.**

**Any external device wishing to request an interrupt does so by inputting a low signal via INTREQ.** The CPU samples this signal in the middle of the first clock period, during the last machine cycle of the current instruction's execution. Upon detecting INTREQ low, the CPU will acknowledge the interrupt at the conclusion of the current instruction's execution, providing no high priority control input exists. Priorities are summarized in Table 13-1. **Upon acknowledging a valid interrupt request, the IM6100 CPU goes through these steps:**

- 1) The interrupt grant signal INTGNT is output high.
- 2) Interrupt acknowledge logic is disabled.
- 3) Program Counter contents are stored in memory location 000.
- 4) An instruction fetch machine cycle is executed, with the next instruction's object code fetched from memory location 001.

**Timing is illustrated in Figure 13-22a.**

**IM6100 interrupt logic is, by microprocessor standards, quite primitive.** A single interrupt service routine, originated at memory location 001, must be executed in response to every external interrupt request.



Figure 13-22a. IM6100 Interrupt Acknowledge Timing

**There is a group of eight I/O instructions which are treated as interrupt processing instructions.** These are:

- SKON - Skip if interrupt On
- ION - Enable interrupts
- IOF - Disable interrupts
- SRQ - Skip if there is an active interrupt request
- GTF - Get flags
- RTF - Return flags
- SGT - Undefined I/O operation
- CAF - Clear all flags

|                                                             |
|-------------------------------------------------------------|
| <b>IM6100<br/>INTERRUPT<br/>PROCESSING<br/>INSTRUCTIONS</b> |
|-------------------------------------------------------------|

**Figure 13-16 illustrates instruction execution timing for these eight instructions.**

**When any I/O instruction, including the eight instructions above, is executed, the INTGNT signal is reset low.** INTGNT reset timing is illustrated in Figure 13-16.

In the simplest case, here is an appropriate interrupt service routine that can be used to determine device priorities:

```
*001          /INTERRUPT SERVICE ROUTINE ORIGINATED AT 001
JMP I      +1          /JUMP INDIRECT VIA ADDRESS IN NEXT WORD
INTS          /LABEL OF INTERRUPT SERVICE ROUTINE
-
-
INTS    IOT    DEV1,INT   /ACTUAL INTERRUPT SERVICE ROUTINE ORIGIN
JMP I    DEV1A
IOT    DEV2,INT
JMP I    DEV2A
IOT    DEV3,INT
JMP I    DEV3A
-
-
etc
DEV1A  ADDR1
DEV2A  ADDR2
DEV3A  ADDR3
```

The instruction sequence above begins (at memory location 1) with a Jump Indirect instruction that holds the start of the interrupt service routine in memory location 2. This interrupt service routine origin is identified by the label INTS. INTS may be anywhere in program memory.

The instruction sequence beginning at INTS is a sequence of I/O and Jump Indirect instructions. The I/O instructions identify, sequentially, the devices that can request an interrupt. Each identified device is provided with a control code given the label INT. This control code must be interpreted by the addressed device as a command to return a low pulse via SKP during I/O data input time, if the device is not requesting an interrupt. Thus, the next instruction, which is a Jump Indirect instruction, will be skipped if the device is not requesting an interrupt. The IOT instruction may thus be illustrated as follows:



Thus, the first device in the program chain which has an active interrupt request will return SKP high, which means that the next Jump Indirect instruction will be executed.

All of the Jump Indirect instructions identify a location which must be on the same page of memory. Within this location the actual address of the interrupt service routine for the selected device is stored.

The problem with the polling scheme described above is that it demands a certain amount of intelligence from the peripheral controller. We could eliminate this intelligence by reading the contents of a device Status register, then jumping or not jumping, based upon a particular bit setting within the status register.

But remember, as the interrupt service routine increases in length, interrupt response time also goes up.

**You can implement a vectored interrupt acknowledge using daisy chain logic, as illustrated for the 8048 microcomputer in Chapter 6.** Consider Figure 13-23. Eight separate interrupt acknowledge signals are generated together with a three-bit code identifying the acknowledged device — which is the highest priority device requesting an interrupt. This three-bit code could be held in a 12-bit buffer, which the CPU reads as an I/O port. If logic associated with this I/O port, upon being accessed, inputs control signals C2 low and C1 high, then the three-bit code (shifted left appropriately to meet the needs of Branch logic) will be added to the Program Counter. This implements a program relative jump, and then a vectored branch. **Figure 13-23 illustrates an appropriate instruction sequence.**

**IM6100  
VECTORED  
INTERRUPT  
ACKNOWLEDGE**



Figure 13-23. Logic and Instruction Sequence for an IM6100 Vectored Interrupt Acknowledge

Let us examine Figure 13-23.

When the interrupt is acknowledged, the Indirect Jump instruction stored in memory location 1 is fetched. This instruction causes program execution to jump to the memory location whose address is stored in the next memory word, which is assigned the label NEXT, but is location 2. The address stored in location 2 is referred to by the label INTS.

The main interrupt service routine is stored in memory, originated at INTS. The first instruction to be executed is an IOT instruction, which inputs data from a location identified by the label IBUF. IBUF is assumed to be the label of the 12-bit buffer which has the 3-bit device vector stored in bits 1, 2 and 3. During the IOTA machine cycle, this buffer's contents will be transmitted to the CPU. Simultaneously, C2 is input low while C1 is input high; therefore, the buffer contents will be added to the Program Counter. Adding the buffer contents to the Program Counter will cause one of eight instructions to be executed next. These eight instructions are all Indirect Jump instructions, which are immediately followed by the address to be jumped to indirectly. Thus, one of eight routines originated at ADR1 through ADR8 will be executed.

Although INTGNT is reset low with the first I/O instruction executed within an interrupt service routine, note that once you acknowledge an interrupt, all further interrupts are disabled until you execute an ION instruction. The ION instruction re-enables interrupts, but not until the conclusion of the instruction fetch for the next instruction to be executed. You will therefore normally leave interrupts disabled for the duration of an interrupt service routine, re-enabling the interrupts by executing an ION instruction directly before you exit the interrupt service routine via a Jump Indirect instruction. Thus the following two instructions will normally conclude an interrupt service routine:

```
-  
-  
-  
ION      /RE-ENABLE INTERRUPTS  
JMP I    0      /RETURN FROM INTERRUPT SERVICE ROUTINE
```

Since interrupts will not be re-enabled until after the Jump Indirect instruction object code has been fetched, you will succeed in returning from the interrupt before another interrupt request gets acknowledged, if pending.

**You can, if you wish, re-enable interrupts within an interrupt service routine in order to accommodate nested interrupts.** If you do this, then prior to re-enabling interrupts within the interrupt service routine, you must save the return address, which is stored in memory location 0, in a software stack. But remember, nested interrupts rarely make sense in a microcomputer system. The low cost of microprocessor Central Processing Units invariably makes it more economical to generate multi-CPU configurations in preference to time sharing a single CPU with nested interrupts.

**The preferred method of handling multiple interrupts in an IM6100 microcomputer system is to use the IM6102 MEDIC, together with IM6101 PIE devices.** These devices automatically implement daisy-chain interrupt priorities with vectored interrupt logic. That is to say, you obtain the same result illustrated in Figure 13-23, but without any of the complexities associated with special logic of the type illustrated in Figure 6-14.

### IM6100 CONTROL PANEL LOGIC

**Since the IM6100 reproduces the logic of a microcomputer, the possible presence of a minicomputer control panel is assumed.** Control panel logic for a minicomputer can be quite complex; given the limitations of the IM6100 CPU, this could present problems. These problems are resolved, however, by allowing the control panel to have its own memory. Control panel memory is used to store programs that implement control panel logic. **Control panel memory is separate and distinct from main memory. Control panel memory addresses can (and usually do) overlap with main memory addresses. External logic can discriminate between a main memory location and a control panel memory location with the same address because control panel memory locations are selected by the CPSEL strobe, whereas main memory locations are selected by the MEMSEL strobe. Timing for control panel memory and main memory accesses are identical, with the exception of the different select strobes.**

**There is a single instruction, the OSR instruction, which accesses a control panel switch register.** The switch register is assumed to be a 12-bit register holding data that is input via control panel switches. The OSR instruction reads the switch register contents and ORs this data on a bit-by-bit basis with the contents of the CPU Accumulator. When the **OSR instruction** is executed, timing is a variation of a memory read instruction with direct addressing. **Timing is illustrated in Figure 13-24.**

|                                                  |
|--------------------------------------------------|
| IM6100<br>CONTROL<br>PANEL<br>SWITCH<br>REGISTER |
|--------------------------------------------------|



Figure 13-24. IM6100 OSR Instruction Timing

There is nothing very complex about accessing the Switch register; it is a single location, accessible via a single instruction. The same is not true for control panel memory, which can be accessed by any memory reference instruction, although its address space is parallel with main memory (i.e., control panel memory and main memory use the same memory addresses). **You must therefore execute a special control panel interrupt request in order to initiate execution of any program that is stored in control panel memory.**

Following a control panel interrupt request, all direct memory accesses are identified by a low CPSEL pulse instead of a low MEMSEL pulse. This means that all instruction fetch machine cycles will fetch an instruction object code out of control panel memory, not out of main memory. Thus as soon as a control panel interrupt request has been acknowledged, a program stored in control panel memory will be executed. Furthermore, all direct memory reference instructions contained within this program will also access data locations within control panel memory, not within main memory.

**You request a control panel interrupt by inputting a low signal via CPREQ. Timing for the request acknowledgement sequence is identical to the general interrupt timing given in Figure 13-22a, providing you substitute CPREQ for INTREQ.**

A control panel interrupt request is a higher priority interrupt request than the general external interrupt request. (See Table 13-1 for a summary of priorities). If the two interrupt requests occur simultaneously, the control panel interrupt request will be acknowledged, while the external interrupt request will not be acknowledged. In fact, only a Reset has higher priority than a control panel interrupt request, therefore **no INTGNT output occurs following a control panel interrupt request.**

**A control panel interrupt request** has higher priority than Halt or DMA, therefore the control panel interrupt request **will be acknowledged while the CPU is halted.** The Halt condition will be terminated and the CPU will enter a run condition as soon as the control panel interrupt request is acknowledged. At the end of the control panel interrupt service routine the CPU will return to the Halt state.

The control panel interrupt's priority over external interrupts extends for the duration of the external interrupt service routine. **A control panel interrupt request will be acknowledged even if it occurs while an external interrupt service routine is being executed.** That is to say, if you disable external interrupts, this has no effect on control panel interrupt logic; a control panel interrupt request will, nonetheless, be acknowledged.

**When a control panel interrupt request is acknowledged, the following events occur:**

- 1) Program Counter contents are stored in control panel memory location 0. This is not the same as main memory location 0; therefore, if a control panel interrupt request is acknowledged while an external interrupt service routine is being executed, no harm is done. A control panel interrupt can be nested within an external interrupt.
- 2) All interrupts are disabled. External interrupts and further control panel interrupts will be ignored.
- 3) The Program Counter is set to FFF16. Thus the control panel interrupt service routine must be originated at control panel memory location FFF16.
- 4) The CPU will output CPSEL instead of MEMSEL for all memory accesses (except as explained below).

**When an AND, TAD, ISZ or DCA instruction is executed within a control panel interrupt service routine, if indirect addressing is specified, then control panel memory is accessed for the direct addressing machine cycle; however, main memory is accessed for the indirect addressing machine cycle — that is, for the machine cycle during which DATAF is high. We can reproduce Figure 13-12 for execution of an indirect addressing DCA instruction within a control panel interrupt service routine, as shown in Figure 13-25.** Thus, you cannot indirectly address control panel memory. If you are going to indirectly access data within a control panel interrupt service routine, the address of the data can be held in control panel memory, but the data itself must be held in main memory.



Figure 13-25. IM6100 DCA Instruction in Control Panel Memory — Timing with Indirect Addressing

**You must leave all interrupts disabled while executing the control panel interrupt service routine.** This is a prerequisite for the CPU to output CPSEL pulses instead of MEMSEL pulses. If you enable interrupts within a control panel interrupt service routine, you will immediately disable CPSEL and re-enable MEMSEL, and therefore program logic will exit the control panel service routine. When you execute any I/O instruction, you re-enable control panel interrupts and external interrupts. Thus, executing any I/O instruction will also cause you to exit the control panel interrupt service routine. Therefore, **you cannot use I/O instructions within a control panel interrupt service routine.**

**In order to return from a control panel memory interrupt service routine, therefore, you simply re-enable interrupts and execute an indirect jump via memory location 0.** The following two instructions will terminate the control panel interrupt service routine:

|       |                          |
|-------|--------------------------|
| ION   | /ENABLE INTERRUPTS       |
| JMP I | 0 /RETURN FROM INTERRUPT |

When the ION instruction is executed, all interrupts are re-enabled; however, this does not happen until the following instruction object code has been fetched. This instruction is a Jump Indirect. When the direct address (000) is output, CPSEL is pulsed low; therefore the contents of control panel memory location 0 are fetched. But when the indirect address which was fetched from control panel memory location 000 is output, MEMSEL is pulsed low; therefore we branch back to main memory for the next instruction fetch. ION disables CPSEL, so all future memory accesses select main memory.

The RTF instruction is another I/O instruction which is frequently used (instead of ION) in the control panel interrupt service routine exit sequence.

**Note that a Reset enables all interrupts; therefore, if a reset occurs in the middle of a control panel interrupt service routine, then when program execution restarts, it will restart out of main memory, as described earlier in this chapter for the reset operation.**

Table 13-1. IM6100 External Signal Sampling Priorities

| Priority        | Operation                       | Associated Signals |
|-----------------|---------------------------------|--------------------|
| First (highest) | Reset                           | RESET              |
| Second          | Control panel interrupt request | CPREQ, CPSEL       |
| Third           | Halt                            | RUN/HLT, RUN       |
| Fourth          | DMA                             | DMAREQ, DMAGNT     |
| Fifth (lowest)  | External interrupt request      | INTREQ, INTGNT     |

## EXTERNAL CONTROL SIGNAL PRIORITIES

**Table 13-1 summarizes the sequence in which external control signals are sampled by the IM6100 CPU.** As a consequence of these priorities, a RESET input will always be accepted and the IM6100 CPU will always be reset, irrespective of what operations the CPU happens to be performing.

A control panel interrupt request will be acknowledged unless the CPU is in the process of being reset. Thus, if the CPU is in a Halt state, the Halt state will be terminated and the CPU will enter a Run state while the control panel interrupt service routine is executed. If a Hold state DMA operation is in progress, then the DMA operation will be suspended for the duration of the control panel interrupt service routine.

The third highest priority condition is the Halt state. This means that a Halt condition will be terminated to execute a control panel interrupt service routine; however, a Halt condition has priority over DMA.

An external device interrupt request is acknowledged as the lowest priority external control input. Thus an external device's interrupt service routine will be slowed down by DMA logic, it will be stopped by a Halt and it will be interrupted by a control panel interrupt service routine.

## IM6100 INSTRUCTION SET

The IM6100 instruction set is unusual because of limitations imposed by the fact that every single instruction generates a single 12-bit object code.

The IM6100 is very deficient in memory reference instructions; it has absolutely no immediate instructions, but it has an incredible wealth of register operate instructions and I/O instructions. **Instructions are summarized in Table 13-2.**

Look first at the memory reference instructions. There is no simple memory read instruction or memory write instruction. The TAD instruction performs a binary add of memory with the Accumulator, leaving the result in the Accumulator. In order to read the contents of a memory word, you must clear the Accumulator, and then add memory to the Accumulator.

DCA is a deposit and clear instruction which is close to a memory write. When this instruction is executed the contents of the Accumulator are written to memory and the Accumulator is then cleared.

The only Boolean logic instructions provided AND the contents of memory with the Accumulator. You can also OR the MQ register and Accumulator contents. If you require XOR, you must create it using the operations available.

There is a single Jump instruction which uses absolute, paged direct or indirect addressing. There are no conditional Jump instructions; however, there are a wealth of conditional Skip instructions. In order to perform conditional branches, you must use skip logic.

The total absence of immediate instructions results from the fact that no instructions have two words of object code. Where you would have used an immediate instruction, you must instead use the TAD instruction to add a constant to the zeroed Accumulator. It is important to note that given the architecture of the IM6100 CPU, immediate instructions are not very valuable — and the lack of them is not consequential. Since you only have one Accumulator and no Data Counters, you do not need immediate instructions in order to load initial addresses or data.

IM6100 I/O instructions are also unusual. At one extreme, you could say that the IM6100 only has one I/O instruction, which outputs a 9-bit code on the Data/Address Bus, which external logic can interpret in any way. In practice, the PDP-8 minicomputer interprets this 9-bit code as follows:



If you are designing a product from scratch, there is no reason why you must use the 9-bit code output by an IOT instruction as illustrated above. If you are using existing PDP-8 software, you are forced to conform to the above IOT instruction interpretation.

The most unusual feature of IM6100 I/O instructions is the fact that external devices can talk back and control the CPU via the C0, C1, C2 and SKP control inputs which we have already described.

## THE IM6100 BENCHMARK PROGRAM

The IM6100 benchmark program may be illustrated as follows:

|      |       |                                        |
|------|-------|----------------------------------------|
| CLA  |       | /CLEAR THE ACCUMULATOR                 |
| TAD  | IOBUF | /LOAD IO BUF BASE ADDRESS INTO         |
| DCA  | 8     | /AUTO-INCREMENT LOCATION               |
| TAD  | TABLE | /LOAD TABLE FIRST FREE BYTE ADDRESS    |
| DCA  | 9     | /INTO AUTO-INCREMENT LOCATION          |
| TAD  | CNT   | /LOAD BYTE COUNT                       |
| CIA  |       | /COMPLEMENT AC AND INCREMENT           |
| DCA  | INDEX | /SAVE IN RAM                           |
| LOOP | TADI  | 8 /LOAD NEXT WORD FROM IOBUF           |
|      | DCAI  | 9 /STORE IN NEXT FREE TABLE WORD       |
|      | ISZ   | INDEX /INCREMENT BYTE COUNT COMPLEMENT |
|      | JMP   | LOOP /RETURN FOR MORE                  |
|      | TAD   | 9 /AT END RESTORE NEW TABLE FIRST      |
|      | DCA   | TABLE /FREE BYTE ADDRESS               |

The benchmark program illustrated above uses auto-increment memory locations 8 and 9 to indirectly address IOBUF and TABLE. These two tables can be of any length within the constraints of the available 4096-word address space. Three other words in the base page are reserved to store the IOBUF base address, the address of the first free byte in TABLE and the byte count. An additional memory word in the base page is used to store the complement of the byte count. This location is represented by the label INDEX.

The following symbols are used in Table 13-2.

|       |                                                                                                                                                                                                                                                                                         |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A     | Accumulator                                                                                                                                                                                                                                                                             |
| *ADDR | Addressing operands. * indicates indirect mode specified. ADDR may be zero page or current page address as described in the text.                                                                                                                                                       |
| CMND  | Three-bit I/O command.                                                                                                                                                                                                                                                                  |
| DEV   | Six-bit Device address                                                                                                                                                                                                                                                                  |
| EA    | Effective Address generated by *ADDR operands.                                                                                                                                                                                                                                          |
| IE    | Interrupt Enable flip-flop                                                                                                                                                                                                                                                              |
| L     | Link status                                                                                                                                                                                                                                                                             |
| MQ    | MQ register                                                                                                                                                                                                                                                                             |
| PC    | Program Counter                                                                                                                                                                                                                                                                         |
| SR    | Switch register — a 12-bit register external to the CPU.                                                                                                                                                                                                                                |
| x<y>  | The yth bit of the quantity x. For example, A<0> specifies the low bit of the Accumulator.                                                                                                                                                                                              |
| [ ]   | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified. |
| Λ     | Logical AND                                                                                                                                                                                                                                                                             |
| ∨     | Logical OR                                                                                                                                                                                                                                                                              |
| ←     | Data is transferred in the direction of the arrow.                                                                                                                                                                                                                                      |

Under the heading of STATUS in Table 13-2, an X indicates that the Link is modified in the course of the instruction's execution. If there is no X, it means that the Link maintains the value it had before the instruction was executed.

Table 13-2. IM6100 Instruction Set Summary

| TYPE                   | MNEMONIC | OPERAND(S) | 12-BIT WORDS | STATUS |  |  |  |  |  | OPERATION PERFORMED                                                             |
|------------------------|----------|------------|--------------|--------|--|--|--|--|--|---------------------------------------------------------------------------------|
|                        |          |            |              | C      |  |  |  |  |  |                                                                                 |
|                        | IOT      | DEV,CMND   | 1            |        |  |  |  |  |  | [DEV]—[CMND]<br>Issue the command to the device.                                |
|                        | DCA      | *ADDR      |              |        |  |  |  |  |  | [EA]—[A]<br>[A]—0<br>Deposit the Accumulator in memory; then clear Accumulator. |
| PRIMARY MEMORY OPERATE | AND      | *ADDR      | 1            |        |  |  |  |  |  | [A]—[A] $\wedge$ [EA]<br>AND Accumulator with memory.                           |
|                        | TAD      | *ADDR      | 1            | X      |  |  |  |  |  | [A]—[A] + [EA]<br>Add memory to Accumulator.                                    |
|                        | ISZ      | *ADDR      | 1            |        |  |  |  |  |  | [EA]—[EA] + 1<br>If [EA] = 0; skip<br>Increment memory and skip if zero.        |
| JUMP                   | JMP      | *ADDR      |              |        |  |  |  |  |  | [PC]—EA<br>Branch unconditional.                                                |
|                        | JMS      | *ADDR      |              |        |  |  |  |  |  | [EA]—[PC] + 1<br>[PC]—EA + 1<br>Jump to subroutine unconditional.               |
| REGISTER OPERATE       | IAC      | 1          |              | X      |  |  |  |  |  | [A]—[A] + 1<br>Increment Accumulator.                                           |
|                        | RAL      | 1          |              | X      |  |  |  |  |  |                                                                                 |
|                        | RTL      |            | 1            | X      |  |  |  |  |  |                                                                                 |
|                        | RAR      |            | 1            | X      |  |  |  |  |  |                                                                                 |

Table 13-2. IM6100 Instruction Set Summary (Continued)

| TYPE                            | MNEMONIC | OPERAND(S) | 12-BIT WORDS | STATUS |  |  |  |  |  |  | OPERATION PERFORMED                                                                                      |
|---------------------------------|----------|------------|--------------|--------|--|--|--|--|--|--|----------------------------------------------------------------------------------------------------------|
|                                 |          |            |              | C      |  |  |  |  |  |  |                                                                                                          |
| REGISTER OPERATE<br>(CONTINUED) | RTR      |            | 1            | X      |  |  |  |  |  |  |                        |
|                                 | BSW      |            | 1            |        |  |  |  |  |  |  |                       |
|                                 | CMA      |            | 1            |        |  |  |  |  |  |  | $[A] \rightarrow \overline{[A]}$<br>Complement Accumulator contents.                                     |
|                                 | CIA      |            | 1            |        |  |  |  |  |  |  | $[A] \rightarrow \overline{[A]} + 1$<br>Negate (twos complement) Accumulator contents. (same as CMA IAC) |
|                                 | CLA      |            | 1            |        |  |  |  |  |  |  | $[A] \rightarrow 0$<br>Clear Accumulator.                                                                |
|                                 | CLA IAC  |            | 1            |        |  |  |  |  |  |  | $[A] \rightarrow 1$<br>Clear, then increment Accumulator.                                                |
| BRANCH ON CONDITION             | STA      |            | 1            |        |  |  |  |  |  |  | $[A] \rightarrow \text{FFF}_{16}$<br>Set Accumulator bits to all ones. (same as CLA CMA)                 |
|                                 | SNL      |            | 1            |        |  |  |  |  |  |  | If $[L]=1$ ; $[PC] \rightarrow [PC] + 2$<br>Skip on Link set.                                            |
|                                 | SZL      |            | 1            |        |  |  |  |  |  |  | If $[L]=0$ ; $[PC] \rightarrow [PC] + 2$<br>Skip on Link reset.                                          |
|                                 | SZA      |            | 1            |        |  |  |  |  |  |  | If $[A]=0$ ; $[PC] \rightarrow [PC] + 2$<br>Skip on Accumulator zero.                                    |
|                                 | SNA      |            | 1            |        |  |  |  |  |  |  | If $[A] \neq 0$ ; $[PC] \rightarrow [PC] + 2$<br>Skip on Accumulator nonzero.                            |
|                                 | SZA SNL  |            | 1            |        |  |  |  |  |  |  | If $[A]=0$ or $[L]=1$ ; $[PC] \rightarrow [PC] + 2$<br>Skip if either Accumulator zero or Link set.      |
|                                 | SNA SZL  |            | 1            |        |  |  |  |  |  |  | If $[A] \neq 0$ and $[L]=0$ ; $[PC] \rightarrow [PC] + 2$<br>Skip if Accumulator nonzero and Link reset. |
|                                 | SMA      |            | 1            |        |  |  |  |  |  |  | If $A<11>=1$ ; $[PC] \rightarrow [PC] + 2$<br>Skip if Accumulator negative.                              |
|                                 | SPA      |            | 1            |        |  |  |  |  |  |  | If $A<11>=0$ ; $[PC] \rightarrow [PC] + 2$<br>Skip if Accumulator positive or zero.                      |

Table 13-2. IM6100 Instruction Set Summary (Continued)

| TYPE                               | MNEMONIC    | OPERAND(S) | 12-BIT WORDS | STATUS |  |  |  |  |  | OPERATION PERFORMED                                                                                              |
|------------------------------------|-------------|------------|--------------|--------|--|--|--|--|--|------------------------------------------------------------------------------------------------------------------|
|                                    |             |            |              | C      |  |  |  |  |  |                                                                                                                  |
| BRANCH ON CONDITION<br>(CONTINUED) | SMA SNL     |            | 1            |        |  |  |  |  |  | If $A < 11> = 1$ or $[L] = 1$ ; then $[PC] \leftarrow [PC] + 2$<br>Skip if Accumulator negative or Link set.     |
|                                    | SPA SZL     |            | 1            |        |  |  |  |  |  | If $A < 11> = 0$ and $[L] = 0$ ; then $[PC] \leftarrow [PC] + 2$<br>Skip if Accumulator positive and Link reset. |
|                                    | SMA SZA     |            | 1            |        |  |  |  |  |  | If $[A] \leq 0$ ; then $[PC] \leftarrow [PC] + 2$<br>Skip if Accumulator zero or negative.                       |
|                                    | SPA SNA     |            | 1            |        |  |  |  |  |  | If $[A] > 0$ ; then $[PC] \leftarrow [PC] + 2$<br>Skip if Accumulator positive.                                  |
|                                    | SMA SZA SNL |            | 1            |        |  |  |  |  |  | If $[A] \leq 0$ or $[L] = 1$<br>Skip if Accumulator less than or equal to zero or if Link set.                   |
|                                    | SPA SNA SZL |            | 1            |        |  |  |  |  |  | If $[A] > 0$ and $L = 0$<br>Skip if Accumulator positive and Link reset.                                         |
| BRANCH ON CONDITION<br>AND OPERATE | SZA CLA     |            | 1            |        |  |  |  |  |  | If $[A] = 0$ ; $[PC] \leftarrow [PC] + 2$ .<br>$[A] = 0$<br>Skip on Accumulator zero. Clear Accumulator.         |
|                                    | SNA CLA     |            | 1            |        |  |  |  |  |  | If $[A] \neq 0$ ; $[PC] \leftarrow [PC] + 2$ .                                                                   |
|                                    | SMA CLA     |            | 1            |        |  |  |  |  |  | $[A] = 0$<br>Skip on Accumulator nonzero. Clear Accumulator.                                                     |
|                                    | SPA CLA     |            | 1            |        |  |  |  |  |  | If $[A] < 0$ ; $[PC] \leftarrow [PC] + 2$ .<br>$[A] = 0$<br>Skip on Accumulator negative. Clear Accumulator.     |
| REGISTER-<br>REGISTER MOVE         | LAS         |            | 1            |        |  |  |  |  |  | $[A] \leftarrow [SR]$<br>Load Accumulator from Switch register (same as CLA OSR).                                |
|                                    | MQL         |            | 1            |        |  |  |  |  |  | $[MQ] \leftarrow [A]$<br>$[A] = 0$<br>Load MQ register from Accumulator. Clear Accumulator.                      |
|                                    | SWP         |            | 1            |        |  |  |  |  |  | $[A] \leftarrow [MQ]$<br>Exchange Accumulator and MQ (same as MQA MQL).                                          |
|                                    | CAM         |            | 1            |        |  |  |  |  |  | $[A] = 0$<br>$[MQ] = 0$<br>Clear Accumulator and MQ (same as CLA MQL).                                           |
|                                    | ACL         |            | 1            |        |  |  |  |  |  | $[A] \leftarrow [MQ]$<br>Load MQ into Accumulator (same as CLA MQA).                                             |
|                                    | CLA SWP     |            | 1            |        |  |  |  |  |  | $[A] = 0$<br>$[A] \leftarrow [MQ]$<br>Clear Accumulator; then swap Accumulator and MQ.                           |

Table 13-2. IM6100 Instruction Set Summary (Continued)

| TYPE                        | MNEMONIC   | OPERAND(S) | 12-BIT WORDS | STATUS |  |  |  |  |  | OPERATION PERFORMED                                                                                                                                             |
|-----------------------------|------------|------------|--------------|--------|--|--|--|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |            |            |              | C      |  |  |  |  |  |                                                                                                                                                                 |
| REGISTER-REGISTER OPERATE   | OSR<br>MQA |            | 1<br>1       |        |  |  |  |  |  | [A]—[A]V [SR]<br>OR Accumulator with Switch register.<br>[A]—[A]V [MQ]<br>OR Accumulator with MQ.                                                               |
| STATUS AND REGISTER OPERATE | CLL RAL    |            | 1            | X      |  |  |  |  |  | [L]—0<br><br>Clear Link, then rotate Accumulator left one bit through Link.   |
|                             | CLL RTL    |            | 1            | X      |  |  |  |  |  | [L]—0<br><br>Clear Link, then rotate Accumulator left two bits through Link.  |
|                             | CLL RAR    |            | 1            | X      |  |  |  |  |  | [L]—0<br><br>Clear Link, then rotate Accumulator right one bit through Link.  |
|                             | CLL RTR    |            | 1            | X      |  |  |  |  |  | [L]—0<br><br>Clear Link, then rotate Accumulator right two bits through Link. |
|                             | CLA CLL    |            | 1            |        |  |  |  |  |  | [A]—0<br>[L]—0<br>Clear Accumulator and Link.                                                                                                                   |
|                             | GTL        |            | 1            |        |  |  |  |  |  | [A]—0<br>[A<0>]—[L]<br>Clear Accumulator, then rotate Link into low bit (same as CLA RAL).                                                                      |

Table 13-2. IM6100 Instruction Set Summary (Continued)

| TYPE      | MNEMONIC   | OPERAND(S) | 12-BIT WORDS | STATUS |  |  |  |  |  | OPERATION PERFORMED                                                                                                                                                   |
|-----------|------------|------------|--------------|--------|--|--|--|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |            |            |              | C      |  |  |  |  |  |                                                                                                                                                                       |
| BRANCH    | SKP        |            | 1            |        |  |  |  |  |  | [PC]—[PC]+2<br>Skip next instruction.                                                                                                                                 |
| INTERRUPT | SKON       |            | 1            |        |  |  |  |  |  | Execution of any of the following instructions will reset INTGNT.                                                                                                     |
|           | ION        |            | 1            |        |  |  |  |  |  | If [IE]=1; [PC]—[PC]+2<br>If interrupts enabled, skip next instruction.                                                                                               |
|           | IOF        |            | 1            |        |  |  |  |  |  | [IE]—1<br>Enable interrupts.                                                                                                                                          |
|           | SRQ        |            | 1            |        |  |  |  |  |  | [IE]—0<br>Disable interrupts.                                                                                                                                         |
|           | GTF        |            | 1            |        |  |  |  |  |  | Skip next instruction if Interrupt Request bus is low.                                                                                                                |
|           | RTF        |            | 1            | X      |  |  |  |  |  | A<11>—[L]<br>A<9>—INTREQ<br>A<7>—[IE]<br>Get flags.<br>[L]—A<11>; [IE]—1<br>Return Link and enable interrupts after the execution of the next sequential instruction. |
|           | SGT        |            | 1            | X      |  |  |  |  |  | I/O device logic determines operation                                                                                                                                 |
|           | CAF        |            | 1            | X      |  |  |  |  |  | [L]—0<br>[A]—0<br>[IE]—0<br>Clear all flags.                                                                                                                          |
| STATUS    | CML        |            | 1            | X      |  |  |  |  |  | [L]—[L]<br>Complement Link.                                                                                                                                           |
|           | CLL        |            | 1            | X      |  |  |  |  |  | [L]—0<br>Reset Link.                                                                                                                                                  |
|           | STL        |            | 1            | X      |  |  |  |  |  | [L]—1<br>Set Link.                                                                                                                                                    |
|           | HLT<br>NOP |            | 1<br>1       |        |  |  |  |  |  | Halt<br>No Operation                                                                                                                                                  |

The following symbols are used in Table 13-3:

- a One bit which determines if indirect addressing is used.
- b One bit which determines if current or zero page is used.
- cccccc Seven-bit page address.
- dddddd Six-bit device code.
- eee Three-bit I/O command.

Most instructions are described in this manner:

mnemonic xxxx  
      yyy

where xxxx is the octal object code associated with the mnemonic and yyy is the hexadecimal object code associated with the mnemonic. IM6100 literature uses octal notation.

Some instructions have this form in the input clock cycles column:

a/b/c

- a is the number of cycles required using direct addressing.
- b is the number of cycles required using indirect addressing.
- c is the number of cycles required using auto-indexed addressing.

Table 13-3. IM6100 Instruction Set Object Codes

| INSTRUCTION  | OBJECT CODE   | 12-BIT WORDS | INPUT CLOCK CYCLES | INSTRUCTION | OBJECT CODE  | 12-BIT WORDS | INPUT CLOCK CYCLES |
|--------------|---------------|--------------|--------------------|-------------|--------------|--------------|--------------------|
| ACL          | 7701<br>FC1   | 1            | 20                 | RTF         | 6005<br>C05  | 1            | 34                 |
| AND *ADDR    | 000abccccccc  | 1            | 20/30/32           | RTL         | 7006<br>E06  | 1            | 30                 |
| BSW          | 7002<br>E02   | 1            | 30                 | RTR         | 7012<br>E0A  | 1            | 30                 |
| CAF          | 6007<br>C07   | 1            | 34                 | SGT         | 6006<br>C06  | 1            | 34                 |
| CAM          | 7621<br>F91   | 1            | 20                 | SKON        | 6000<br>C00  | 1            | 34                 |
| CIA          | 7041<br>E21   | 1            | 20                 | SKP         | 7410<br>F08  | 1            | 20                 |
| CLA          | 7200<br>E80   | 1            | 20                 | SMA         | 7500<br>F40  | 1            | 20                 |
| CLA CLL      | 7300<br>EC0   | 1            | 20                 | SMA CLA     | 7700<br>FC0  | 1            | 20                 |
| CLA IAC      | 7201<br>E81   | 1            | 20                 | SMA SNL     | 7520<br>F50  | 1            | 20                 |
| CLA SWP      | 7721<br>FD1   | 1            | 20                 | SMA SZA     | 7540<br>F60  | 1            | 20                 |
| CLL          | 7100<br>E40   | 1            | 20                 | SMA SZA SNL | 7560<br>F70  | 1            | 20                 |
| CLL RAL      | 7104<br>E44   | 1            | 30                 | SNA         | 7450<br>F28  | 1            | 20                 |
| CLL RAR      | 7110<br>E48   | 1            | 30                 | SNA CLA     | 7650<br>FA8  | 1            | 20                 |
| CLL RTL      | 7106<br>E46   | 1            | 30                 | SNA SZL     | 7470<br>F38  | 1            | 20                 |
| CLL RTR      | 7112<br>E4A   | 1            | 30                 | SNL         | 7420<br>F48  | 1            | 20                 |
| CMA          | 7040<br>E20   | 1            | 20                 | SPA         | 7510<br>F10  | 1            | 20                 |
| CML          | 7020<br>E10   | 1            | 20                 | SPA CLA     | 7710<br>FC8  | 1            | 20                 |
| DCA *ADDR    | 011abccccccc  | 1            | 22/32/34           | SPA SNA     | 7550<br>F68  | 1            | 20                 |
| GTF          | 6004<br>C04   | 1            | 34                 | SPA SNA SZL | 7570<br>F78  | 1            | 20                 |
| GTL          | 7204<br>E84   | 1            | 20                 | SPA SZL     | 7530<br>F58  | 1            | 20                 |
| HLT          | 7402<br>F02   | 1            | 20                 | SRQ         | 6003<br>C03  | 1            | 34                 |
| IAC          | 7001<br>E01   | 1            | 20                 | STA         | 7240<br>EA0  | 1            | 20                 |
| IOF          | 6002<br>C02   | 1            | 34                 | STL         | 7120<br>E50  | 1            | 20                 |
| ION          | 6001<br>C01   | 1            | 34                 | SWP         | 7521<br>F51  | 1            | 20                 |
| IOT DEV,CMND | 110dddddddeee | 1            | 20                 | SZA         | 7440<br>F20  | 1            | 20                 |
| ISZ *ADDR    | 010abccccccc  | 1            | 20                 | SZA CLA     | 7640<br>FA0  | 1            | 20                 |
| JMP *ADDR    | 101abccccccc  | 1            | 20/30/32           | SZA SNL     | 7460<br>F30  | 1            | 20                 |
| JMS *ADDR    | 100abccccccc  | 1            | 22/32/34           | SZL         | 7430<br>F18  | 1            | 20                 |
| LAS          | 7604<br>F84   | 1            | 30                 | TAD *ADDR   | 001abccccccc | 1            | 20/30/32           |
| MQA          | 7501<br>F41   | 1            | 20                 |             |              |              |                    |
| MQL          | 7421<br>F11   | 1            | 20                 |             |              |              |                    |
| NOP          | 7000<br>E00   | 1            | 20                 |             |              |              |                    |
| OSR          | 7404<br>F04   | 1            | 30                 |             |              |              |                    |
| RAL          | 7004<br>E04   | 1            | 30                 |             |              |              |                    |
| RAR          | 7010<br>E08   | 1            | 30                 |             |              |              |                    |

## SOME SPECIAL IM6100 HARDWARE CONSIDERATIONS

The apparently complex System Bus of the IM6100 has some non-obvious advantages. The wealth of bus signals makes it very easy to generate System Busses compatible with other microprocessors and to circumvent certain limitations of the IM6100 instruction set.

### IMPLEMENTING A HARDWARE STACK

Consider first the problem of the **Jump-to-Subroutine instruction**, which we described earlier in this chapter. Recall that the IM6100 Jump-to-Subroutine instruction cannot work when programs are stored in read-only memory, because the subroutine return address is stored in the first word of the subroutine — which will be a read-only memory location. We can circumvent this problem by creating a special read/write memory stack which is addressed by an up-down counter. Appropriate logic is illustrated in Figure 13-28.

Before examining the logic in this figure, let us look at what we are trying to accomplish.

Remember, a Jump-to-Subroutine instruction contains a write machine cycle during which the Program Counter contents are stored in the first memory location of the subroutine. **Timing for execution of the Jump-to-Subroutine instruction with indirect addressing, along with the logic that accompanies the instruction's execution, is illustrated in Figure 13-26.** Timing for direct addressing or auto-increment addressing variations of the Jump-to-Subroutine instruction can be readily deduced from Figures 13-12 and 13-13.

We are going to identify the **Jump-to-Subroutine object code**; then, for the rest of the **Jump-to-Subroutine instruction's execution**, we will deflect memory write accesses to an external read/write memory stack. Timing and an appropriate event sequence are illustrated in Figure 13-27. Figure 13-28 illustrates the logic used to implement timing in Figure 13-27. Figure 13-28 also shows the logic used to return from subroutines; we will describe this later.

In Figures 13-27 and 13-28 we use a 7474 D-type flip-flop to generate a low true select signal (**QSEL**). This select signal is used to differentiate between stack and normal memory accesses; the trailing low-to-high transition of this select signal is also used to increment the up-down counter, which generates the stack address. Thus, any "write to stack" operation will be a "write and then increment address" operation. The write select signal **QSEL** is generated low true by decoding 100 on Data/Address Bus lines 11, 10 and 9, while the Data/Address Bus is carrying an instruction object code. We can identify this condition by the combination of IFETCH high and XTC high. This combination generates the DIN input to the 7474 flip-flop, which is clocked by DCLK, the AND of **MEMSEL** and IFETCH. Since the low-to-high clock transition is active, it is very important that data be stable on the Data/Address Bus until well after **MEMSEL** has made its low-to-high transition. This may be illustrated as follows:





Figure 13-26. IM6100 Jump-to-Subroutine Instruction Timing with Indirect Addressing



Figure 13-27. IM6100 Jump-to-Subroutine Instruction Timing with Stack Access Logic



Figure 13-28. Using an External Stack Memory to Avoid IM6100 JMS ROM Problems

Once QSEL has gone low, it will remain low until the next instruction fetch. DCLK will make its next low-to-high transition at the beginning of T1 for the next instruction fetch machine cycle, at which time DIN will be high again. QSEL will then go high, which is what we require. That is to say, QSEL remains low only for the non-instruction fetch machine cycles of the Jump-to-Subroutine instruction.

While QSEL is low, we want to divert all memory write select pulses from MEMSEL to the stack. We do this by generating EXMSEL for standard memory selects. EXMSEL is generated as the OR of MEMSEL with two conditioning inputs. The truth table for EXMSEL may be illustrated as follows:

| <u>DESL</u> | <u>XTC</u> | <u>QSEL</u> | <u>EXMSEL</u> | <u>Condition</u>                                       |
|-------------|------------|-------------|---------------|--------------------------------------------------------|
| L           | L          | L           | <u>MEMSEL</u> | Will never arise                                       |
| L           | L          | H           | <u>MEMSEL</u> | Return from subroutine; non-read part of machine cycle |
| L           | H          | L           | <u>MEMSEL</u> | Will never arise                                       |
| L           | H          | H           | H             | Return from subroutine; read part of machine cycle     |
| H           | L          | L           | H             | JMS, write part of machine cycle                       |
| H           | L          | H           | <u>MEMSEL</u> | Normal machine cycle                                   |
| H           | H          | L           | <u>MEMSEL</u> | JMS, read part of machine cycle                        |
| H           | H          | H           | <u>MEMSEL</u> | Normal machine cycle                                   |

A memory read that implements indirect addressing for a JMS instruction will access normal memory; however, you cannot use a Jump-to-Subroutine instruction with auto-increment memory addressing, since the incremented address will be written back to the stack instead of being written to the auto-increment location in Page 0.

**A return from subroutine is executed via a Jump Indirect instruction.** The Jump Indirect instruction in a normal PDP-8E program will reference the first subroutine word as the location in which the indirect address is stored. For our adaptation, we must select one memory address that is referenced by all Jump Indirect instructions that return from subroutines. This may be illustrated as follows:

We have shown the address FFF16 being used as the single address which will always be referenced by Jump Indirect instructions which are returning from an IM6100 subroutine. Our logic in Figure 13-28 will decode the address selected (in this case FFF16) using the LXMAR high pulse as a strobe. Whenever the required address is detected while LXMAR is high,  $\overline{DSEL}$  will be output low. The leading high-to-low transition of  $DSEL$  must be used as a down count trigger for the up-down counter. Thus, all "read from stack" operations will be "decrement and then read" operations. The  $\overline{DSEL}$  signal will remain low until another address is detected — that is to say, until the next occurrence of a high LXMAR pulse with another address on the Data/Address Bus. While  $\overline{DSEL}$  is low, all memory read operations will be deflected to the stack and away from normal memory. See the truth table given earlier, and the logic of Figure 13-28 for verification of this logic.

The net effect of Figure 13-28 logic is that all subroutine return addresses will be stored in an external stack. IM6100 and PDP-8E Jump-to-Subroutine instructions will be identical. There will, however, be differences in the Return-from-Subroutine instructions within an IM6100 program as compared to a PDP-8E program. A PDP-8E program which is to run on an IM6100 must have all Return-from-Subroutine Jump Indirect instructions modified to access the single memory location which has been assigned to identify the external stack.

## **SUPPORT DEVICES THAT MAY BE USED WITH THE IM6100**

Since the 8080A System Bus is the most useful, in that it supports the most readily available support devices, we will begin by looking at how 8080A-compatible signals may be generated from the standard IM6100 System Bus. Figure 13-29 provides necessary bus conversion logic. The bus conversion is quite simple.

The most complex portion of Figure 13-29 is the logic which demultiplexes the Address and Data Busses. A 12-bit address buffer must be present, using LXMAR as a latching strobe. This buffer will create the Address Bus, while DX0 - DX11 otherwise implements the Data Bus. Remaining control signals are generated using simple gates. Note that no

attempt is made to generate signals that reproduce 8080A clock signals or exact machine cycle timing. Since the 8080A System Bus is asynchronous, this presents no problem. So long as control signals have the required pulse widths and logic levels, they will work with 8080A support devices. Thus an 8080A System Bus as illustrated in Figure 13-29 can be used in a microcomputer system where the IM6100 is the CPU and 8080A support devices provide additional logic; however, Figure 13-29 does not generate a System Bus which could be used in a microcomputer system where an IM6100 and an 8080A were communicating with each other. For those 8080A support devices that do need a clock signal, one can be derived from XTA, XTB and/or XTC.



Figure 13-29. IM6100 System Bus Converted to an 8080A-Compatible System Bus

**Generating 8085-compatible signals from the IM6100 bus is not so straightforward.** This is because the 8085 generates state signals S0 and S1, and an IO/Memory discriminator (IO/M) whose levels must be specified for the entire duration of read and write machine cycles that access memory or I/O devices. The IM6100 generates RUN and IFETCH signals that extend for the duration of a machine cycle, but memory or I/O access control signals are not generated in this fashion. If you look at timing for the 8085 support devices — the 8155, the 8355 and the 8755 — it would appear that the IM6100 System Bus can generate adequate control inputs for these support devices. However, we have no experimental verification of this fact.

We do not recommend using MC6800 or MCS6500 support devices with the IM6100 because of the peculiar synchronous nature of the MC6800 and MCS6500 microcomputer systems. It would be very hard to make IM6100 machine cycle timing conform to MC6800 or MCS6500 machine cycle timing. Moreover, MC6800 and MCS6500 support devices are not attractive enough to make this logic exercise worthwhile.

## THE IM6101 PARALLEL INTERFACE ELEMENT (PIE)

The IM6100 CPU, being a copy of the PDP-8 minicomputer, has a number of features which are not well suited to the average microcomputer application; but that is no fault of the IM6100 chip designer — his product was specified for him. The IM6101, on the other hand, is a well thought out part that goes a long way towards rectifying the problems that you are likely to encounter if you try to design logic around the IM6100 CPU.

The IM6101 is best visualized as a control signal interface on the IM6100 System Bus, connecting an IM6100 CPU and its support devices. This concept may be illustrated as follows:



Conceptually, what is important about the illustration above is the fact that the IM6101 does not lie on the address or data path of the microcomputer system. Like a typical DMA controller, the IM6101 generates and receives control signals, while memory and I/O devices communicate directly with the System Data and Address Busses.

**Functionally, Figure 13-1 illustrates that part of our general microcomputer system logic which is implemented on the IM6101 Parallel Interface Element (PIE).**

The IM6101, like all members of the IM6100 family, is fabricated using CMOS technology; it requires a single power supply that may range between +4V and +10V and is packaged as a 40-pin DIP.



| Pin Name              | Description                   | Type               |
|-----------------------|-------------------------------|--------------------|
| DX0 - DX11            | Data and Address Bus          | Bidirectional      |
| LXMAR, DEVSEL, XTC    | Control signals from CPU      | Input              |
| SKP/INTREQ            | CPU control/interrupt request | Output, open drain |
| INTGNT                | Interrupt acknowledge         | Input              |
| C1, C2                | CPU control signals           | Output, open drain |
| READT, READ2          | Read pulse lines              | Output             |
| WRITE1, WRITE2        | Write pulse lines             | Output             |
| SEL3 - SEL7           | Individual IM6101 select      | Input              |
| FLAG1 - FLAG4         | Control flags                 | Output             |
| SENSE1 - SENSE4       | Status lines                  | Input              |
| PRIN                  | Priority in                   | Input              |
| POUT                  | Priority out                  | Output             |
| V <sub>CC</sub> , GND | Power and Ground              |                    |

Figure 13-30. IM6101 Parallel Interface Element Signals and Pin Assignments



Figure 13-31. Logic of the IM6101 PIE

## IM6101 PARALLEL INTERFACE ELEMENT PINS AND SIGNALS

Figure 13-30 illustrates the pins and signals of the IM6101 Parallel Interface Element. Figure 13-31 illustrates the important logic components of the IM6101.

We will begin by summarizing IM6101 signals.

The IM6101 communicates directly with the IM6100 CPU via the Data/Address Bus (DX0 - DX11) together with the three control signals LXMAR, DEVSEL and XTC. As per our discussion of the IM6100 Data/Address Bus, remember that we number bus lines, register bits and word bits in an opposite sense to Intersil literature. Thus, in Figure 13-30, Data/Address Bus line signals are shown as they appear in Intersil literature, with our equivalents, in brackets, adjacent to them.

Interrupt requests are transmitted to the CPU via INTREQ (which shares a pin with SKP). The IM6101 receives in response the CPU interrupt acknowledge signal INTGNT.

The CPU communicates with the IM6101 PIE via IOT instructions. The IM6101 therefore returns C1, C2 and SKP as I/O controls. Recall that IM6100 I/O logic demands that the selected I/O device return I/O control signals which specify the I/O operations to occur. The IM6101 does not return C0; this signal must be generated externally. SKP shares a pin with INTREQ.

The fact that INTREQ and SKP outputs share a pin presents no problem since the two signals are active at different times in any machine cycle. You could, if you wish, separate the two signals via the following logic:



There is, in fact, no need for SKP/INTREQ to be separated as illustrated above. The CPU distinguishes the two signals on the single line via instruction timing.

**External devices capable of transmitting data to or from the IM6100 CPU use the IM6101 READ1, READ2, WRITE1 and WRITE2 control outputs as read/write strobes and device select signals.** That is to say, each of these signals will connect to a single device. A READ signal pulse will cause data to transfer from the connected device to the IM6100 CPU. A WRITE pulse will cause data to flow from the CPU to the connected device. **This may be illustrated as follows:**



**The IM6101 has five select inputs, SEL3 - SEL7.** Internal logic compares the levels at these five signals with five I/O instruction object code bit levels (described in detail later) in order to determine whether the IM6101 is or is not selected when an I/O instruction is being executed. In other words, the five signals SEL3 - SEL7 allow you to specify a unique device code for the IM6101 by tying signals selectively to power or ground. A device code of 0 is not allowed, since special internal CPU I/O instructions use this device code. The five select lines SEL3 - SEL7 therefore allow 31 unique device codes to be specified for IM6101 devices.

#### IM6101 SELECT LOGIC

**The IM6101 PIE provides eight any-purpose control signals.** FLAG1 - FLAG4 constitute four flag outputs which may be set or reset under program control. SENSE1 - SENSE4 represent four status inputs which may optionally be used as interrupt request lines.

When more than one IM6101 PIE is present in a microcomputer system, the PRIN and POUT signals allow daisy-chained priority interrupt logic to be generated. For a discussion of daisy-chain logic, see Volume 1.

**Figure 13-36 illustrates a large IM6100 microcomputer system that includes more than one IM6101 PIE.**

### IM6101 FUNCTIONAL LOGIC

**You access an IM6101 Parallel Interface Element using I/O instructions;** this is how the IM6101 will interpret an I/O instruction code as it appears on the Data/Address Bus:

#### IM6101 PROGRAMMING



Note that the IM6101 and the PDP-8 differ in their interpretation of the I/O instruction code.

**IM6101 logic identifies an I/O instruction object code by examining Data/Address Bus bits 9, 10 and 11 during an IOTA machine cycle. Timing is illustrated in Figure 13-16.**

Now, if you look at Figure 13-16 and then examine the signals input to the IM6101, there appears to be a possibility for confusion. The only control inputs received by the IM6101 are LXMAR, DEVSEL and XTC. What is to stop the IM6101 from being confused by an address output during the instruction fetch machine cycle? LXMAR will be high at this time. An address can certainly look like an I/O instruction object code; in fact, any address in the range C1016 through DFF16 will look like an I/O instruction object code. Since the IM6101 does not receive the IFETCH signal as an input, it cannot identify an instruction fetch machine cycle. There is no problem, however, because the PIE detects the subsequent DEVSEL low pulse — or lack of low pulse. Indeed, an address in the range mentioned above, output during an instruction fetch machine cycle, may match an IM6101 selection code; however, without the subsequent low DEVSEL pulse, the IM6101 will not respond to this selection. Since DEVSEL is pulsed low during IOTA, but not during an instruction fetch machine cycle, possible problems of ambiguity are resolved.

In order to determine whether or not it is selected, IM6101 logic compares I/O instruction object code bits 8 through 4 with select inputs SEL3 through SEL7, as described earlier.

Here is how the bits are compared:



**The low-order four bits of the I/O instruction object code are used by IM6101 logic to generate 16 specific I/O instructions, which are defined in Table 13-4. This table shows the standard instruction mnemonics recognized by the Intersil assembler, together with the low-order four object code bits' settings.**

Table 13-4. IM6101 Interpretation of I/O Instruction Control Bits 3-0

| Instruction Mnemonic | Control Bit |   |   |   | Interpretation                                                                                                                                      |
|----------------------|-------------|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | 3           | 2 | 1 | 0 |                                                                                                                                                     |
| READ1                | 0           | 0 | 0 | 0 | Generate a low pulse output on READ1.                                                                                                               |
| READ2                | 1           | 0 | 0 | 0 | Generate a low pulse output on READ2.                                                                                                               |
| WRITE1               | 0           | 0 | 0 | 1 | Generate an active pulse output on WRITE1.                                                                                                          |
| WRITE2               | 1           | 0 | 0 | 1 | Generate an active pulse output on WRITE2.                                                                                                          |
| SKIP1                | 0           | 0 | 1 | 0 | Test the SENSE1 status. If it is active, output a low pulse via SKP/INTREQ, to be interpreted by the IM6100 CPU as an SKP pulse.                    |
| SKIP2                | 0           | 0 | 1 | 1 | Test the SENSE2 status. If it is active, output a low pulse via SKP/INTREQ, to be interpreted by the IM6100 CPU as an SKP pulse.                    |
| SKIP3                | 1           | 0 | 1 | 0 | Test the SENSE3 status. If it is active, output a low pulse via SKP/INTREQ, to be interpreted by the IM6100 CPU as an SKP pulse.                    |
| SKIP4                | 1           | 0 | 1 | 1 | Test the SENSE4 status. If it is active, output a low pulse via SKP/INTREQ, to be interpreted by the IM6100 CPU as an SKP pulse.                    |
| RCRA                 | 0           | 1 | 0 | 0 | Place the contents of Control Register A on the Data Bus as data. The IM6100 CPU will OR Control Register A contents with the Accumulator contents. |
| WCRA                 | 0           | 1 | 0 | 1 | Write the contents of the Accumulator to Control Register A.                                                                                        |
| WCRB                 | 1           | 1 | 0 | 1 | Write the contents of the Accumulator to Control Register B.                                                                                        |
| WVR                  | 1           | 1 | 0 | 0 | Write the contents of the Accumulator to the Interrupt Vector register.                                                                             |
| SFLAG1               | 0           | 1 | 1 | 0 | Set Output Signal FLAG1 high and set Control Register A bit 8 to one.                                                                               |
| SFLAG3               | 1           | 1 | 1 | 0 | Set Output Signal FLAG3 high and set Control Register A bit 10 to one.                                                                              |
| CFLAG1               | 0           | 1 | 1 | 1 | Reset Output Signal FLAG1 low and reset Control Register A bit 8 to zero.                                                                           |
| CFLAG3               | 1           | 1 | 1 | 1 | Reset Output Signal FLAG3 low and reset bit 10 of Control Register A to zero.                                                                       |

Let us look at the operations which may be performed when the instructions identified in Table 13-4 are executed.

**IM6101 I/O INSTRUCTIONS**

**IM6101 READ INSTRUCTION**

The two read instructions, READ1 and READ2, cause data to be transferred from an external device to the CPU. Timing is illustrated in Figure 13-32. The IM6101 outputs a low READ1 or READ2 pulse, which acts as both a select signal and a strobe signal for the external device which is to transmit data to the IM6100 CPU. The IM6101 transmits C1 low and C2 high to the CPU in order to identify the I/O instruction as a Read. The actual data transfer occurs directly between the selected device and the IM6100 CPU via the Data/Address Bus.

**IM6101 WRITE OPERATION**

The two write instructions, WRITE1 and WRITE2, cause the IM6101 to send back C1 and C2 high at data input time in order to signal a write operation to the IM6100 CPU. Subsequently the IM6101 outputs a WRITE pulse via WRITE1 or WRITE2. Under program control you may select a high write pulse or a low write pulse. An external device will use the write pulse both as a select and as a signal identifying stable data on the Data/Address Bus, which is to be read by the selected device. Timing is illustrated in Figure 13-33.

Remaining IM6101 I/O instructions affect control signals and interrupt logic.

The IM6101 has eight control signals: four Flag outputs and four Sense inputs. The Flag outputs, FLAG1 through FLAG4, are simple control outputs. Under program control, the levels of these four outputs can be set or reset, but the manner in which external logic uses these four signals is undefined.

**IM6101 FLAG OUTPUTS**

**IM6101 SENSE INPUTS**

The four Sense inputs, SENSE1 through SENSE4, are shared by interrupt logic and control logic. These signals can be used by external devices to transmit control information to an IM6101, and/or they can be used to generate interrupt requests. When used to generate interrupt requests, the four Sense inputs constitute four independent interrupt request lines which can be individually enabled and disabled. Under program control, you can specify that an interrupt request will occur when a sense line is high, low, makes a high-to-low transition, or makes a low-to-high transition.

**IM6101 CONTROL REGISTERS**

The various programmable options of the IM6101 are specified by writing control codes to two control registers.

Control Register A can be written into (by WCRA) or its contents can be read (by RCRA).

Control Register A contents are interpreted as follows:





Figure 13-32. An IM6101 I/O Read Instruction's Timing



Figure 13-33. An IM6101 I/O Write Instruction's Timing

The levels of the four Flag outputs, FLAG1 - FLAG4, are determined by the contents of the four high-order Control Register A bits. In addition, specific control instructions shown in Table 13-4 allow FLAG1 and FLAG3 to be set or reset (by SFLAG1, SFLAG2, CFLAG1, CFLAG2). You can therefore modify FLAG1 and FLAG3 in two ways — by executing specific I/O instructions, or by loading appropriate information into the flag bits of Control Register A.

Bits 5 and 7 of Control Register A determine whether the Write output signals WRITE1 and WRITE2 will pulse high or low when a write IOT instruction is executed. Note that you cannot program read pulse levels; a read IOT instruction pulses one of the read lines low.

**You use bits 0 through 3 of Control Register A to determine whether the status inputs SENSE1 - SENSE4 are to function as interrupt requests or as statuses which will trigger IM6100 CPU skip control logic.** You can define the function of each signal in any way and thus create any combination of interrupt requests and skip controls.

**Control Register B determines what will constitute an "active" state for each of the four individual sense inputs.** Each sense input has two control bits in Control Register B, one of which determines whether signal level or transition will constitute the active state; the other control bit determines polarity. Here is Control Register B format:



By appropriately setting the two bits of Control Register B which are assigned to any sense input, you can cause a high level, a low level, a high-to-low transition or a low-to-high transition to be the active sense signal state.

Note carefully that Control Register B determines only what will constitute an active sense condition. Control Register B does not hold sense input information.

**You write to Control Registers A and B by executing the WCRA and WCRB instructions, respectively. Timing is as illustrated in Figure 13-15 for a standard device output operation.**

**You can read the contents of Control Register A by executing the RCRA instruction, but you cannot read the contents of Control Register B.** When the RCRA instruction is executed, timing conforms to Figure 13-14.

Recall that instructions which transfer data between the IM6100 CPU and the IM6101 PIE treat the IM6101 PIE as a standard I/O device — selected by a 5-bit device code. READ1, READ2, WRITE1 and WRITE2 instructions, in contrast, select an IM6101 via a 5-bit device code, but subsequently cause a data transfer to occur between the IM6100 and the I/O device which is connected to the selected IM6101 READ or WRITE control signal.

**There are four instructions which directly control the level of FLAG1 and FLAG3 flag outputs. These four instructions are SFLAG1, SFLAG3, CFLAG1 and CFLAG3.** When any one of these four instructions is executed, the flag output changes state during T2 of IOTA, as illustrated in Figure 13-32. In addition to changing the level of the flag output, these instructions modify the associated Control Register A bit.

#### IM6101 FLAG INSTRUCTIONS

**When you write to Control Register A (via a WCRA instruction) you can modify all four flag output levels,** since the four flag outputs reflect associated bit levels in Control Register A. However, any changes in flag levels will occur during T6 of IOTA, as illustrated in Figure 13-33.

You cannot sample the level of the Sense inputs, since there is no register which stores Sense input levels in the form of binary data. **You must execute a SKIP instruction in order to test a Sense input's level.** A SKIP instruction tests for an "active" Sense signal condition. This "active" condition is defined within Control Register B. As explained for Control Register B, the "active" Sense signal condition may be a high level, a low level, a high-to-low transition, or a low-to-high transition.

#### IM6101 SKIP INSTRUCTIONS

**A particular Sense line can be used with skip logic or with interrupt logic.** If interrupt logic has been enabled for the Sense line, then as soon as the active condition occurs at the Sense line, an interrupt will be requested. If interrupt logic has not been enabled for the Sense line, then the active condition of the Sense input will be recorded in an internal flip-flop. Subsequently, when a SKIP instruction identifying the Sense line is executed, a skip pulse will be returned to the IM6100 CPU if the "active" Sense input has occurred. The Sense flip-flop is then cleared.

## IM6101 INTERRUPT HANDLING LOGIC

The IM6101 has typical daisy-chain priority interrupt logic, implemented via the PRIN and POUT signals.

PRIN must be a high input if an IM6101 is to generate an interrupt request based on one of the four sense lines. Therefore, the IM6101 electrically closest to the CPU must have its PRIN input connected to a high logic level so that its interrupt request logic will always be enabled. So long as no interrupt request is active at this highest priority IM6101, a high signal will be output via POUT; it becomes the PRIN input for the next IM6101 in the daisy chain.



As soon as an interrupt request occurs via one of the sense lines at an IM6101, it immediately sends an out interrupt request low level via SKP/INTREQ; simultaneously, the IM6101 outputs POUT low, thus disabling all interrupt request logic at lower priority PIEs in the daisy chain.

The IM6100 CPU acknowledges the interrupt request, providing interrupts are enabled at the CPU, by executing a "Jump-to-Subroutine at memory address 000" instruction. Thus, the interrupt return address is stored in memory location 000, and the instruction object code stored in memory location 001 becomes the first instruction executed following the interrupt acknowledge. Upon acknowledging an interrupt, the IM6100 outputs INTGNT high. The first IOT instruction executed, of any type or to any device, resets INTGNT low. We have described IM6100 interrupt logic earlier in this chapter.

**The IM6101 has an Interrupt Vector register which you write into via the WVR instruction.** The Vector register contents are interpreted as follows:



**When an "active" condition occurs at one of the Sense inputs, and interrupt logic for this Sense input has been enabled, then the IM6101 will generate an interrupt request by outputting SKP/INTREQ low.** As soon as the CPU acknowledges the interrupt by outputting INTGNT high, the IM6101 device which has highest priority in the daisy chain (and is requesting an interrupt) will trap the INTGNT signal. When the next I/O instruction is executed, this IM6101 device will place on the Data Bus the contents of the Interrupt Vector register, while simultaneously outputting C1 and C2 low. This causes an absolute Jump to be executed, with the contents of the interrupt vector becoming the address of the instruction that program logic jumps to. The location addressed by the interrupt vector should contain a

Jump Indirect instruction, since a single word in the interrupt service routine is allocated to each Sense line of an individual IM6101. This may be illustrated as follows:



As we have just stated, the INTGNT signal output by the IM6100 CPU remains high from the time the interrupt is acknowledged until an I/O instruction is subsequently executed by the CPU. **While the INTGNT signal is high, the acknowledged IM6101 device freezes its internal interrupt logic;** that is to say, no further active transitions at Sense inputs will be recognized. Therefore, the Sense input which will be acknowledged is the highest priority Sense input at the instant that INTGNT goes high. **Sense inputs have the following priority at any single IM6101 device:**

Highest Priority: SENSE1  
SENSE2  
SENSE3

Lowest Priority: SENSE4

Normally, an IOF instruction will be the first I/O instruction executed by the CPU within an interrupt service routine. This instruction disables interrupts at the CPU, where they are already disabled; therefore, it constitutes a no operation

**IM6101  
SENSE  
INTERRUPT  
PRIORITY**

I/O instruction which simply serves to reset the INTGNT signal low. Thus, the interrupt acknowledge routine which will service one or more IM6101 devices may be illustrated as follows:

```
*1  
IOF          /Interrupt acknowledge I/O instruction  
*INAK  
/Interrupt acknowledge routine origin  
JMP I    P1S1    /PIE1, SENSE1 interrupt  
JMP I    P1S2    /PIE1, SENSE2 interrupt  
JMP I    P1S3    /PIE1, SENSE3 interrupt  
JMP I    P1S4    /PIE1, SENSE4 interrupt  
JMP I    P2S1    /PIE2, SENSE1 interrupt  
JMP I    P2S2    /PIE2, SENSE2 interrupt  
JMP I    P2S3    /PIE2, SENSE3 interrupt  
JMP I    P2S4    /PIE2, SENSE4 interrupt
```

|      |      |
|------|------|
| P1S1 | ADR1 |
| P1S2 | ADR2 |
| P1S3 | ADR3 |
| P1S4 | ADR4 |
| P2S1 | ADR5 |
| P2S2 | ADR6 |
| P2S3 | ADR7 |
| P2S4 | ADR8 |

In the instruction sequence above, INAK is the address for the first Jump Indirect instruction — the JMP IP1S1 instruction. All of the Jump Indirect instructions address memory locations which must reside on the same 128-word page of memory. The actual starting address for the interrupt service routine will be stored in the memory location addressed by the Jump Indirect instruction.

**You will return from an IM6101 device's interrupt service routine as described for the IM6100. You can either execute a CAF (Clear All Flags) instruction, an RTF (Return Flags) instruction, or an ION (Enable Interrupts) instruction. Whichever one of these three instructions you select, it must be followed by a Jump Indirect via memory location 0 instruction.**

## THE IM6102 MEDIC

**The IM6102 MEDIC allows an IM6100 microcomputer system to access up to 32,768 words of memory. It also provides bus sharing direct memory access logic, dynamic memory refresh logic and real-time clock logic.**

Memory expansion logic of the IM6102 is compatible with the DEC PDP-8/E, KM8-E memory extension option.

The real-time clock logic of the IM6102 is compatible with the DEC PDP-8/E, DK8-EP programmable real-time clock option.

IM6102 direct memory access logic is not a reproduction of any PDP-8E option.

**Figure 13-34 illustrates that part of our general microcomputer functional logic which is implemented on the IM6102 MEDIC.**



Figure 13-34. Logic of the IM6102 MEDIC

The IM6102, like all members of the IM6100 family, is fabricated using CMOS technology; it requires a single power supply that may range between +4V and +10V. The IM6102 is packaged as a 40-pin DIP.

### IM6102 MEDIC PINS AND SIGNALS

Figure 13-35 illustrates the pins and signals of the IM6102 MEDIC. We will summarize these pins and signals before proceeding to examine their functions in detail.

Table 13-5 identifies selected pins of the IM6102 that should be tied to power or ground when specific functions of the device are not used.



| Pin Name         | Description                                                 | Type                        |
|------------------|-------------------------------------------------------------|-----------------------------|
| DX0 - DX11       | Data/Address Bus                                            | Bidirectional, tristate     |
| XTA, XTC         | Machine cycle timing                                        | Input                       |
| LXMAR            | External memory address strobe                              | Input                       |
| DEVSEL           | I/O Device select strobe                                    | Input                       |
| IFETCH           | Instruction fetch machine cycle identifier                  | Input                       |
| MEMSEL           | Memory select strobe                                        | Input with pullup           |
| RESET            | Reset                                                       | Input                       |
| C0, C1, C2       | CPU control during I/O operation                            | Output with open drain      |
| SKP/INT          | Skip control input to CPU and interrupt request             | Output with pullup          |
| EMA0, EMA1, EMA2 | Extended memory address                                     | Output                      |
| SKP/INTX         | Skip control input and interrupt request output from IM6101 | Input with resistive pullup |
| PROUT            | Daisy chain priority out                                    | Output with pullup          |
| XLXMAR           | DMA external memory address strobe                          | Output with pullup          |
| XXTC             | DMA machine cycle timing                                    | Output with pullup          |
| UP               | DMA user pulse                                              | Output with pullup          |
| DMAEN            | DMA enable                                                  | Input                       |
| DMAGNT           | DMA grant from CPU                                          | Input                       |
| XMEMSEL          | DMA memory select                                           | Output                      |
| INTGNT           | Interrupt grant from CPU                                    | Input                       |
| CLOCK            | System Clock                                                | Input                       |
| OSC IN, OSC OUT  | Counter Clock                                               | Input                       |
| VCC, GND         | Power, Ground                                               |                             |

Figure 13-35. IM6102 MEDIC Signals and Pin Assignments

Table 13-5. IM6102 MEDIC Pins that should be Tied to Power or Ground when Certain Functions are Unused

| PIN NUMBER | PIN NAME        | REAL-TIME CLOCK ONLY | DMA ONLY        | EXTENDED MEMORY CONTROL ONLY | EXTENDED MEMORY CONTROL AND DYNAMIC MEMORY REFRESH |
|------------|-----------------|----------------------|-----------------|------------------------------|----------------------------------------------------|
| 2          | <u>DMAEN</u>    | GND                  | USED            | GND                          | GND                                                |
| 3          | <u>DMAGNT</u>   | USED                 | USED            | USED                         | USED                                               |
| 6          | <u>XMEMSEL</u>  | N/C                  | USED            | N/C                          | USED                                               |
| 8          | <u>UP</u>       | N/C                  | USED            | N/C                          | N/C                                                |
| 11         | <u>XLXMAR</u>   | N/C                  | USED            | N/C                          | USED                                               |
| 12         | <u>XXTC</u>     | N/C                  | USED            | N/C                          | USED                                               |
| 15         | <u>SKP/INTX</u> | V <sub>CC</sub>      | V <sub>CC</sub> | USED                         | USED                                               |
| 29         | <u>OSC IN</u>   | USED                 | GND             | GND                          | GND                                                |
| 31         | <u>OSC OUT</u>  | USED                 | N/C             | N/C                          | N/C                                                |
| 34         | <u>C2</u>       | USED                 | USED            | N/C                          | N/C                                                |
| 36         | <u>EMA0</u>     | N/C                  | N/C             | USED                         | USED                                               |
| 37         | <u>EMA1</u>     | N/C                  | N/C             | USED                         | USED                                               |
| 38         | <u>EMA2</u>     | N/C                  | N/C             | USED                         | USED                                               |
| 40         | <u>PROUT</u>    | USED                 | USED            | N/C                          | N/C                                                |

Only one IM6102 MEDIC can be present in an IM6100 system.

Let us first look at the IM6102 signals which connect directly with the IM6100 CPU.

**DX0 - DX11** is the system Data/Address Bus. As in the IM6100 and IM6101 descriptions, our Data/Address Bus signal names are shown in brackets next to names used in Intersil literature. Addresses and data will flow directly between the IM6102 and the IM6100, via the Data/Address Bus, when the CPU is accessing the IM6102 via the I/O instructions described in Table 13-6.

Of the IM6100 control and timing signals, **XTA**, **XTC**, **LXMAR**, **DEVSEL**, **IFETCH** and **MEMSEL** are input to the **IM6102**. Note specifically that XTB and DATAF are not transmitted to the IM6102; functions performed by these signals are implied by logic within the IM6102.

**RESET** is a standard reset input. RESET input timing must conform to IM6100 reset timing.  
When the IM6102 is reset, all of its internal registers and flags are cleared.

**IM6102  
RESET**

The IM6102 generates the four I/O control signals required by the CPU: **C0**, **C1**, **C2** and **SKP**.

However, SKP and the interrupt request signal INT share a single pin, as is the case with the IM6101 devices.

If IM6102 and IM6101 devices are present together in an IM6100 microcomputer system, then the IM6102 must be the device with highest interrupt priority. IM6101 devices having lower priority will use the PROUT output of the IM6102 to initiate interrupt priority daisy chain logic. Interrupt requests from IM6101 devices must be input to the IM6102 via SKP/INTX. The IM6102 will pass the interrupt request on to the IM6100 via SKP/INT at the proper time. This is illustrated in Figure 13-36.

In order to address additional "fields" of memory, EMA0, EMA1, and EMA2 act as three high-order address lines, extending the normal 12-bit memory address available on DX0 - DX11 to a 15-bit address as follows:





Figure 13-36. An IM6100 Microcomputer System that Includes an IM6102 MEDIC and IM6101 PIE Device

**Any interrupt request from the IM6102 is acknowledged by the CPU via INTGNT**, the standard interrupt acknowledge signal output by the CPU.

For direct memory access and dynamic memory refresh functions, the **IM6102 generates XLXMAR, XXT<sub>C</sub>, and XMEMSEL**, signals derived from LXMAR, XTC and MEMSEL, respectively. In addition, **UP is generated as an I/O device pulse**.

**DMAEN** is a master DMA enable which must be input low to the IM6102 to enable any DMA operation. **DMAGNT** is the standard DMA grant output by the CPU; DMAGNT is received by the IM6102, which suspends DMA operations if DMAGNT is high — in which case some other DMA operation, not initiated by the IM6102, is in progress.

**Counter/timer logic of the IM6102 is driven by an external crystal which must be connected across OSC IN and OSC OUT.**

**The IM6102 MEDIC requires two sets of clock logic. A crystal must be connected across OSC IN and OSC OUT: this crystal is used by the IM6102 real-time logic only. The master IM6100 microcomputer system clock signal must also be input to the IM6102.** Since no such clock signal is output by the IM6100 CPU, you must generate this clock signal externally. This means you cannot use the IM6100 internal clock logic if you are also using an IM6102 MEDIC. External logic must generate the clock signal, which is input to the OSC OUT pin of the IM6100 CPU, and to the CLOCK input of the IM6102 MEDIC.

**The crystal connecting the OSC IN and OSC OUT pins of the IM6102 should have the following characteristics:**

$$\begin{aligned} R_S &\leq 150 \text{ ohms} \\ C_M &= 3 \text{ to } 30 \text{ fF (10-15 F)} \\ C_O &= 10 \text{ to } 50 \text{ pF (12 pF preferred)} \\ \text{Static capacitance} &\approx 5 \text{ pF} \end{aligned}$$

## THE IM6100 - IM6102 INTERFACE

Figure 13-36 illustrates an IM6100 microcomputer system that includes an IM6102 MEDIC and a number of IM6101 devices (two are shown). The IM6102 has been designed on the assumption that there will be no more than one of these devices in a single IM6100 microcomputer system. The IM6102 will be the highest priority device in an interrupt daisy chain.

**The CPU communicates with the IM6102 device via a specific set of I/O instructions, which are summarized in Table 13-6.** A few of the I/O instructions shown in Table 13-6 are general instructions that affect all devices connected to an IM6100 CPU, but most of the instructions in Table 13-6 are specific to the single IM6102 device that can be present in the system. If you look at Table 13-6, you may notice the possibility for confusion in instruction object codes. First of all, none of the instruction object codes identify an I/O device — yet in our earlier discussion of IM6100 I/O instruction object codes we saw that five or six object code bits were set aside to provide device identification. This problem is resolved in two ways:

- 1) A few of the instructions shown in Table 13-6 are general I/O instructions which must be acted upon by all I/O devices in the IM6100 microcomputer system. Since all I/O devices will respond to these instructions, the lack of an I/O device code presents no problem.
- 2) There is only one IM6102 device allowed per IM6100 microcomputer system. Therefore, the I/O device numbers which happen to be usurped by IM6102 I/O instruction object codes given in Table 13-6 must not be used for IM6101 devices, or any other I/O devices in the IM6100 microcomputer system. That is to say, **the following I/O device codes cannot be used if an IM6102 is present:**

| Instruction<br>Mnemonics                          | Binary Device Code<br>Used by IM6102 |
|---------------------------------------------------|--------------------------------------|
| CLZE, CLSK, CLDE, CLAB,<br>CLEN, CLSA, CLBA, CLCA | xxx00101xxxx                         |
| CDF, CIF, RDF, RIF,<br>RIB, RMF, LIF, LCAR,       | { xxx01000xxxx                       |
| RCAR, LWCR, LEAR, REAR,                           | xxx01001xxxx                         |
| LFSR, RFSR, SKOF, WRVR                            | { xxx01010xxxx<br>xxx01011xxxx       |

Five of the 31 allowed IM6101 device codes are used by the IM6102 IOT instructions, therefore a maximum of 26 IM6101 devices may be present in an IM6100 microcomputer system that includes an IM6102.

## IM6102 EXTENDED MEMORY CONTROL

The IM6102 implements extended memory addressing via the simple expedient of creating three additional high-order address lines, over and above the 12 address lines output on the Data/Address Bus. These three high-order address lines are EMA0, EMA1 and EMA2. Together with the address output on the Data/Address Bus, these

three address lines create 15-bit memory addresses, as illustrated earlier in our discussion of IM6102 signals. Note again that since we number signals and bits in the opposite sense to Intersil literature, **our signal names compare with Intersil signal names as follows:**

|                       | Highest<br>order<br>bit | Lowest<br>order<br>bit |
|-----------------------|-------------------------|------------------------|
| Intersil signal name: | EMA0                    | EMA1                   |
| Our signal name:      | EMA2                    | EMA1                   |
|                       |                         | EMA0                   |

**There are two 3-bit registers within the IM6102 which hold the value to be output via EMA2, EMA1 and EMA0. These are the Instruction Field register and the Data Field register.** The EMA2, EMA1 and EMA0 outputs will always come from one of these two registers.

**The Instruction Field register contents are output as three high-order address lines most of the time. The Data Field register contents are output as the three high-order address lines only during the third machine cycle of an AND, TAD, ISZ or DCA instruction — when the instruction is using indirect addressing to reference memory.** This machine cycle is identified by the DATAF signal. See Figure 13-13 for DATAF signal timing.

The DATAF signal is not input to the IM6102; logic internal to the device recognizes the third, direct addressing machine cycle of an AND, TAD, ISZ or DCA instruction that specifies indirect addressing. **Figure 13-40 is a reproduction of Figure 13-13, including EMA outputs of the IM6102.**

**Neither the Instruction Field register nor the Data Field register contents increment along with the Program Counter.** Suppose, for example, the Instruction Field register contains the value 3. If the Program Counter contents increment from FFF16 to 00016, the effective address will change from 3FFF16 to 300016. The effective address will not increment from 3FFF16 to 400016. This means that the **IM6102 memory extension logic divides memory into separate and distinct 4096-word "fields"**. Since there are three extended memory address lines, there can be a total of eight 4096-word "fields", for a maximum of 32,768 words of memory.

There are some important programming implications in the fact that the Instruction Field and Data Field register contents do not increment. We will examine these programming implications later.

**When the IM6102 is reset, the Data Field and Instruction Field registers both contain 0.** But the Program Counter is initialized with the value FFF16 when the IM6100 is reset. Therefore, initial program execution begins with a bootstrap program originated at location FFF16, the highest address within the first 4096-word memory field.

**Following an interrupt acknowledge, the Instruction Field and Data Field registers' contents are saved in the Save Field register, then zeros are loaded into the Instruction Field and Data Field registers.** Thus, interrupt service routines will be originated at memory location 1 of the first 4096-word memory field and the interrupt service routine return address will be stored in location 0 of this same memory field, just as though there were no additional memory fields present. Thus, additional memory fields have no effect on restart logic or interrupt acknowledge logic.

**Base page logic is reproduced in every 4096-word memory field** of an IM6100 microcomputer system. That is to say, a memory reference instruction that specifies base page addressing will access one of the first 128 words within the current memory field. Moreover, auto-increment memory addressing logic will apply to addresses stored in memory words 00816 through 00F16 of every 4096-word memory field.

**Let us examine the way in which you will use the Instruction Field, Data Field and associated registers of the IM6102 extended memory address control logic. These registers, and instructions which access them, are illustrated in Figure 13-37.**

**IM6102 DATA FIELD REGISTER**

**IM6102 INSTRUCTION FIELD REGISTER**

**IM6100 MEMORY FIELDS**

**IM6100-IM6102 RESET BOOTSTRAP**

**IM6100-IM6102 INTERRUPT ACKNOWLEDGE**

**IM6100 BASE PAGE IN EXTENDED MEMORY**

**IM6102 EXTENDED MEMORY ADDRESSING REGISTERS**



Figure 13-37. IM6102 Extended Memory Addressing Registers and Data Paths

Note that the **Instruction Field register has a Buffer register**. This is necessary, since the instruction that loads a new value into the Instruction Field register would otherwise cause an immediate branch into the next sequential memory location of a new memory field. Using arbitrary memory addresses, this may be illustrated as follows:

**IM6102  
INSTRUCTION  
BUFFER  
REGISTER**

The LIF instruction loads an immediate value, here assumed to be "4", directly into the Instruction Field register



A scheme such as the one illustrated above is feasible, using the LIF instruction, but, without other options, program logic would be difficult to handle and would severely reduce the value of extended memory. By buffering the Instruction Field register, we can load a new memory field identifier into the Instruction Buffer register, then hold it there until the next Jump instruction is executed — which is supposed to cause non-sequential instruction execution anyway. Using arbitrary memory addresses and real instructions, this may be illustrated as follows:



**Let us now examine the ways in which we can access the Instruction Field and Data Field registers of the IM6102.**

Special IM6102 I/O instructions transfer data to or from IM6102 extended memory addressing registers.

The CDF and CIF instructions are equivalent to I/O instructions with immediate addressing. These instructions specify (as part of the instruction object code) a 3-bit value which is to be loaded into the Data Field register or the Instruction Buffer register. The instruction operand must equal the immediate 3-bit value left shifted three times to reflect the operand bit positions in the instruction object code. For the CDF instruction this may be illustrated as follows:



This is a quirk of the Intersil assembler; it has nothing to do with IM6102 device logic.

Timing for execution of these instructions is as illustrated in Figure 13-15.

AND, TAD, ISZ and DCA instructions that specify indirect memory addressing go to the memory field identified by the Data Field register for the direct access of memory that occurs during the third machine cycle of the instruction's execution; this is illustrated in Figures 13-39 and 13-40.

When you load a new value into the Instruction Buffer register, the Instruction Field register does not change, and therefore program execution continues in the currently specified memory field. But when the next Jump or Jump-to-Subroutine instruction is executed, as part of the instruction execution logic, the Instruction Buffer register contents are transferred to the Instruction Field register, so the Jump or Jump-to-Subroutine occurs across memory field boundaries, as previously illustrated.

**IM6102  
JUMP  
ACROSS  
MEMORY  
FIELDS**



Figure 13-38. IM6100 DCA Instruction Timing with Direct Addressing Using Extended Memory Addressing

You do have the option, via the LIS instruction, of directly transferring the Instruction Buffer register contents to the Instruction Field register. This will cause program execution to branch to the next sequential memory location in the newly specified memory field, as previously illustrated.

**Having examined the extended memory addressing registers in general, let us now look at some of the specific ways in which these registers work.**

First of all, recall that the Instruction Field and Data Field registers do not increment with the Program Counter. Thus, program memory is divided rigidly into 4096-word fields, where you can only move from one field to another via a Jump or Jump-to-Subroutine instruction, or by executing an LIS instruction.

**Let us examine some of the ways in which instructions will execute out of fields other than field 0. Consider the DCA instruction.**

Using direct memory addressing, the instruction and the word that is referenced must lie in the same memory field; the referenced word may be in page 0 of the field, or in the instruction's page of the field. Timing is illustrated in Figure 13-38.

Now consider a DCA instruction that specifies indirect addressing. The instruction and the word that contains the indirect address must lie in the same memory field, but the ultimately accessed memory word will lie in the field specified by the Data Field register — which may or may not be the same field. Timing is illustrated in Figure 13-39.

A DCA instruction that specifies indirect addressing with auto-increment will directly reference one of the memory words with address 0816 through 0F16 in the current field of memory. The contents of this memory location will be incremented and written back; the incremented value will become the address of the memory word ultimately accessed. However, this memory word will be in the field identified by the Data Field register. Timing is illustrated in Figure 13-40.

You also have register-to-register type instructions that access the Instruction Buffer register and the Data Field register. This is because the IM6100 CPU treats IM6102 extended memory addressing registers' contents as status flags. The GTF instruction loads the Data Field and Instruction Buffer registers' contents into the low-order CPU Accumulator bits, while the RTF instruction transfers the low-order six CPU Accumulator bits to the Instruction Buffer and Data Field registers. Results of these instructions are illustrated in Table 13-6.



Figure 13-39. IM6100 DCA Instruction Timing with Indirect Addressing Using Extended Memory Addressing



Figure 13-40. IM6100 DCA Instruction Timing with Indirect Addressing and Auto-Increment Using Extended Memory Addressing

## IM6102 EXTENDED MEMORY PROGRAMMING CONSIDERATIONS

Here is the necessary instruction sequence for program logic to branch from any memory field into memory field 3:

**IM6100  
EXTENDED  
MEMORY  
JUMP**

```
CIF    30      /PREPARE TO JUMP TO MEMORY FIELD 3
-
-
-
CDF    20      /SET DATA FIELD TO 2
JMP I  +1      /JUMP TO LOCATION ADDR IN FIELD 3
ADDR
-
```

Observe that the CIF and CDF instruction operands require the field number to be specified in bit positions 3, 4 and 5:



The Intersil assembler assumes octal data in the operand field unless otherwise defined.

**Calling subroutines and returning from subroutines across field boundaries is not nearly as simple as the Jump illustrated above.** The problem is that a subroutine has no way of knowing out of which field it was called. Thus, when it is time to return from the subroutine, the normal return sequence will not work. Your program logic must therefore include special instructions that transmit to the subroutine the field number out of which the subroutine was called. The technique most commonly used is to load the program field number into the Data Field register before calling the subroutine. If we arbitrarily assume that a subroutine in memory field 1 is to be called by a program in memory field 4, accessing data in memory field 5, then the subroutine calling sequence can be illustrated as follows:

**IM6100  
EXTENDED  
MEMORY  
SUBROUTINE  
ACCESES**

/Below is the subroutine calling sequence

```
CDF    40      /LOAD PROGRAM FIELD INTO DATA FIELD REGISTER
CIF    10      /LOAD SUBROUTINE FIELD INTO INSTRUCTION BUFFER REGISTER
JMS I  SADR   /JUMP TO SUBROUTINE IN MEMORY FIELD 1
CDF    50      /AFTER RETURNING FROM SUBROUTINE, RESTORE DATA FIELD REGISTER
```

```
SADR  SUBR      /12-BIT SUBROUTINE ADDRESS
/SUBROUTINE IN MEMORY FIELD 1 BEGINS BELOW
SUBR  0         /RETURN ADDRESS IS STORED HERE
      CLA       /CLEAR ACCUMULATOR AND INPUT DATA FIELD REGISTER CONTENTS
      RDF
      TAD  RET     /ADD 110010000010 TO CREATE INSTRUCTION FIELD REGISTER RESTORATION
                  /INSTRUCTION
      DCA  EXIT    /AND INSERT AT EXIT
      {           Body of subroutine occurs here
      }
      EXIT 0       /THIS BECOMES A CIF N INSTRUCTION
      JMP I  SUBR   /RETURN TO CALLING PROGRAM
      RET   CIF  00   /DATA USED TO CREATE INSTRUCTION AT EXIT
```

Before executing a Jump-to-Subroutine instruction, the CDF instruction loads the current program memory field number into the Data Field register. Next, the CIF instruction loads the subroutine's memory field into the Instruction Buffer

register. Now when the Jump-to-Subroutine instruction is executed, a subroutine in field 1 will be accessed, since the Instruction Buffer register contents are transferred to the Instruction Field register.

Instructions at the beginning of the subroutine must load the Data Field register contents into the Accumulator, then add the appropriate binary digit pattern to create a CIF instruction which will restore the correct Instruction Field register contents prior to returning from the subroutine. A memory word at location EXIT is reserved for this instruction. This memory word occurs directly in front of the Jump Indirect instruction, which actually causes the return to occur.

**There are two problems with the subroutine logic illustrated above.** They are:

- 1) A subroutine's object code must reside in read/write memory, since the return address and the memory word labeled EXIT are both going to be written into.
- 2) Subroutines must be rewritten as soon as you add extended memory. But note that a subroutine which has been written to work with extended memory will also work in the absence of extended memory, providing you do not pass parameters to the subroutine via the Accumulator.

If you want to store subroutines in read-only memory and have these subroutines called out of extended memory, then you must use an external read/write memory stack as described earlier in this chapter. You could locate the word labeled EXIT on page 0, but this is a very expensive solution to the problem, since page 0 has just 128 memory locations — and these get used up very quickly.

## IM6102 EXTENDED MEMORY INTERRUPT CONSIDERATIONS

**When an interrupt is acknowledged in an IM6100 microcomputer system that is using extended memory addressing, the following events occur:**

- 1) The contents of the Instruction Buffer register and the Data Field register are transferred to the Save Field register. Note that the Instruction Field register contents are not saved.
- 2) Zero values are loaded into the Instruction Field register and the Data Field register.
- 3) The Program Counter contents are saved in memory word 0 of memory field 0.
- 4) The instruction located in memory word 1 of memory field 0 is fetched and executed.

Thus, **the interrupt acknowledge scheme is the same whether or not the IM6100 microcomputer system uses extended memory addressing.**

The standard IM6100 interrupt acknowledge procedure would appear to pose a problem.

From our earlier discussion of programming logic that jumps from one memory field to another, recall that you will normally load the Instruction Buffer register with the number of the destination memory field. This number is held in the Instruction Buffer register until a Jump or Jump-to-Subroutine instruction is executed, at which time the Instruction Buffer register contents are moved to the Instruction Field register. Thus, the Instruction Buffer register and the Instruction Field register contents will differ from the time you load a new value into the Instruction Buffer register until you subsequently execute a Jump or Jump-to-Subroutine instruction. During this time, if an interrupt were to be acknowledged, the Instruction Buffer register contents would be saved and the Instruction Field register contents would be lost. Subsequently, upon returning from the interrupt, you would return to the memory field identified by the Instruction Buffer register — which would be the wrong memory field. The memory field within which the program was executing when the interrupt was acknowledged was the memory field identified by the Instruction Field register. In order to overcome this problem, **IM6102 logic disables external device interrupts (but not control panel interrupts) when any instruction that loads data into the Instruction Buffer register is executed. The IM6102 keeps external device interrupts disabled until a Jump or Jump-to-Subroutine is subsequently executed. Interrupts are also re-enabled when an LIF instruction is executed.**

**The IM6102 has vectored interrupt acknowledge logic, as is the case for the IM6101 devices.** The IM6102 has an 11-bit Interrupt Vector register. The WRVR instruction transfers the contents of the CPU Accumulator to the Interrupt Vector register, but the low-order Interrupt Vector register bit is automatically set or reset by the IM6102 counter/timer logic, as described later.

**IM6102  
INTERRUPT  
VECTOR  
REGISTER**

From the discussion of IM6100 interrupt acknowledge logic given early in this chapter, recall that the INTGNT signal is output high by the CPU from the time an interrupt is acknowledged until the end of the second machine cycle for the first I/O instruction executed following the interrupt acknowledge. **IM6102 interrupt acknowledge logic uses the INTGNT high signal occurring during an I/O instruction's execution as a signal to output the Interrupt Vector register contents with C1 and C2 I/O control inputs both low. Timing conforms to standard I/O data input timing.**

**The interrupt service routine initiation instruction sequence described earlier in this chapter for the IM6101 applies also for the IM6102.** However, the IM6102 generates only two vector addresses, whereas the IM6101 generates four vector addresses.

The logic used to return from interrupt service routines is also identical in IM6100 microcomputer systems that do and do not employ extended memory addressing. In both cases you return from an interrupt service routine by jumping indirect via the address stored in memory location 0 of memory field 0. But in a microcomputer system that employs extended memory addressing, your interrupt service routine's return logic must restore the Instruction Buffer and Data Field registers' contents from the Save Field register prior to returning from the interrupt. This is done via the RMF instruction, as follows:

|         |                                                                       |
|---------|-----------------------------------------------------------------------|
| RMF     | /LOAD INSTRUCTION BUFFER AND DATA FIELD REGISTERS FROM THE SAVE FIELD |
| ION     | /RE-ENABLE INTERRUPTS                                                 |
| JMP I 0 | /JUMP INDIRECT VIA SAVED ADDRESS IN LOCATION 0 OF FIELD 0             |

When the RMF instruction is executed, the Save Field register contents are transferred to the Instruction Buffer and Data Field registers, and interrupts are disabled. When the subsequent Jump Indirect instruction is executed, the Instruction Buffer register contents are transferred to the Instruction Field register. Interrupts are enabled by the ION instruction. Thus, program execution returns to the point of interrupt — which may be within an instruction sequence stored in any memory field.

## IM6102 DYNAMIC MEMORY REFRESH AND DIRECT MEMORY ACCESS LOGIC

If you look again at the various machine cycle timing diagrams, you will see that with the exception of data output machine cycles, the second half of the machine cycle is used for operations internal to the CPU. This time is therefore available to perform a second memory access. The IM6102 uses the second half of non-data output machine cycles in order to perform a second memory access, either to refresh dynamic memory or to perform a direct memory access operation. Figures 13-41 and 13-42 illustrate timing for a DMA read and a DMA write, respectively. A memory refresh machine cycle differs from a DMA machine cycle only in pulse timing, as defined in the data sheets at the end of this chapter. Also, there is no low UP pulse during a memory refresh machine cycle.

External devices that are accessed during a DMA operation use the Data/Address Bus (including the three extended memory address signals) and three control signals: XXTC, XMEMSEL, and UP. XXTC becomes, in effect, a single read/write control. If this signal is high, then it identifies data being transferred from memory to an external device — a DMA read machine cycle. If XXTC is low, then a DMA write machine cycle is specified — data being transferred from an external device to memory. In either case, the low XMEMSEL pulse is interpreted as a memory enable strobe, while the low UP pulse is interpreted as an I/O device strobe. A DMA operation will occur in an allowed machine cycle only if DMAEN is low on the rising edge of XTA. DMAEN is a master external DMA enable/disable control.

**IM6102 DMA CONTROL SIGNALS**

### IM6102 DMA logic uses these four registers:

**IM6102 DMA REGISTERS**

A 12-bit Word Count register.

A 12-bit Current Address register.

A 3-bit Extended Current Address register.

A 7-bit Status register.

The Current Address register identifies the memory location which is to be accessed during the next DMA or dynamic memory refresh operation. The contents of this register are incremented after each DMA or dynamic memory refresh operation.

The Extended Current Address register is a 3-bit register which creates the three high-order address lines of a 15-bit address. The Extended Current Address register is equivalent to the Instruction Field register of extended memory address control logic. Thus, during DMA or dynamic memory refresh operations, the 15-bit address seen by external memory is created as follows:





Figure 13-41. IM6102 DMA Read Timing



Figure 13-42. IM6102 DMA Write Timing

But there is a significant difference between the Extended Current Address register and the Instruction Field register of extended memory address control logic. **Under program control you can specify that the Extended Current Address register will increment** along with the Current Address register. That is to say, when the Current Address register increments from  $\text{FFF}_{16}$  to  $\text{000}_{16}$ , the Extended Current Address register can be forced to increment. Extended memory address control logic, in contrast, does not allow the Instruction Field register to increment when the Program Counter increments from  $\text{FFF}_{16}$  to  $\text{000}_{16}$ .

Dynamic memory refresh logic requires that the Extended Current Address register be allowed to increment along with the Current Address register. Dynamic memory refresh requires that you load 0 into the Extended Current Address and

Current Address registers, which then increment as a single 15-bit Address register. Thus, dynamic memory refresh logic automatically moves from one memory field to the next. If the Extended Current Address register did not increment, then in order to refresh more than one memory field, you would have to execute instructions between each memory field to increment the Extended Current Address register and thus select the new dynamic memory field to be refreshed.

Direct memory access logic does not benefit from the fact that the Extended Current Address register contents can increment automatically. A block of data that is moved via direct memory access logic will rarely be more than 4096 words in length.

**The Word Count register is a 12-bit register that must initially be loaded with the two's complement of the DMA block length. The Word Count register is inactive during dynamic memory refresh operations.** The Word Count register's contents are incremented after every DMA operation. When this register's contents increment from FFF<sub>16</sub> to 000<sub>16</sub>, an end of DMA is signaled via an appropriate Status register bit setting; optionally, an interrupt request may be generated. Depending on the DMA mode, DMA operations may cease at the end of a DMA block transfer, or the DMA operation may restart.

The DMA Status and Control register is a 7-bit register whose contents are interpreted as follows:



Status/Control register bit 0 is an interrupt enable/disable bit which allows interrupt requests to be generated when error conditions associated with bits 5 or 6 of the Status/Control register occur.

Status/Control register bit 1 determines whether the DMA operation will be a Read or a Write. A DMA Read constitutes a transfer from memory to an I/O device, while a Write constitutes a transfer from the I/O device to memory.

Status/Control register bit 2 determines whether the Extended Current Address register increments as part of a 15-bit address. If this bit is 0, then the Extended Current Address register does not increment. If this bit is 1, then when the Current Address register increments from FFF<sub>16</sub> to 000<sub>16</sub> the Extended Current Address register increments by 1. When the Extended Current Address register contains 111, however, it cannot increment to 000. If the Extended Current Address register is supposed to increment when it contains 111, then instead a "field 7 wrap around error" occurs and Status/Control register bit 6 is set to 1. At this time an interrupt request will also occur if Status/Control register bit 0 has been set to 1. Once a field 7 wrap around error occurs, Status/Control register bit 6 can be reset to 0 by execution of a CAF or an RFSR instruction. A reset operation resets all Status/Control register bits to 0.

Whenever the Word Count register increments from FFF<sub>16</sub> to 000<sub>16</sub>, Status/Control register bit 5 is set to 1. If Status/Control register bit 0 has also been set to 1, then an interrupt request will accompany the Word Count register incrementing from FFF<sub>16</sub> to 000<sub>16</sub>. If you want to identify the end of a DMA data transfer with an interrupt request, you do so by enabling interrupts via bit 0 of the DMA Status/Control register. When the Word Count register incre-

ments from FFF16 to 00016, you have, in effect, reached the end of a DMA block — which will be identified with an interrupt request, providing the DMA Status/Control register bit 0 is 1.

**Status/Control register bits 3 and 4 allow IM6102 DMA logic to be disabled, or one of three modes to be selected.**

### IM6102 DMA MODES

**In Refresh mode, a sequence of DMA Read machine cycles is executed;** however, the UP signal is not output and DMAEN as an input is ignored. Thus external logic cannot suppress dynamic memory refresh by inputting DMAEN low. But in refresh mode the rest of the Status/Control register is active, which means that you must set bit 2 to 1 if the Extended Current Address register is to increment, in which case a field 7 wrap around error will occur if the Extended Current Address register attempts to increment from 111 to 000.

**In normal DMA mode, a DMA operation will be performed during every allowed machine cycle, providing DMAEN is low at the beginning of the machine cycle.** However, an LWCR instruction must be executed to start a normal DMA mode operation. As illustrated in Figures 13-41 and 13-42, DMAEN is sampled on the rising edge of XTA. If DMAEN is high at this time, then no DMA operation will occur. Logic internal to the IM6102 decodes the instruction object code which the IM6102 receives along with the IM6100 in order to identify machine cycles when no memory write operation is scheduled and a DMA operation can therefore be performed. When the Word Count register increments from FFF16 to 00016, a normal DMA operation stops, Status/Control register bit 5 is set (as already described) and if interrupts have been enabled, an interrupt request is generated. IM6102 DMA logic remains in normal mode at this time; however, it must be restarted under program control by executing another LWCR instruction. Thus, the following instruction sequence will initiate normal DMA mode:

|      |      |                                                         |
|------|------|---------------------------------------------------------|
| CLA  |      | /CLEAR ACCUMULATOR                                      |
| TAD  | DMAD | /FETCH STARTING DMA ADDRESS                             |
| LCAR |      | /LOAD INTO CURRENT ADDRESS REGISTER. CLEAR ACCUMULATOR  |
| TAD  | SR   | /FETCH STATUS/CONTROL REGISTER SETTINGS                 |
| LFSR |      | /LOAD INTO STATUS/CONTROL REGISTER. CLEAR ACCUMULATOR   |
| TAD  | WC   | /FETCH TWOS COMPLEMENT OF WORD COUNT                    |
| LWCR |      | /LOAD INTO WORD COUNT REGISTER AND START DMA OPERATION. |

**Burst DMA mode is identical to normal DMA mode, except that when the Word Count register increments from FFF16 to 00016 the mode immediately reverts to dynamic memory refresh.** Burst mode is used when DMA operations are being performed with dynamic memory, in which case you must be careful to keep DMA transfer blocks short enough not to interfere with dynamic memory decay times. Remember, while a DMA operation is being performed, no dynamic memory refreshes are occurring.

**In Stop mode, no DMA or dynamic memory refresh operations occur;** however, any of the DMA registers may be accessed.

## IM6102 PROGRAMMABLE REAL-TIME CLOCK LOGIC

The IM6102 has relatively simple real-time clock logic, which computes time intervals using pulses generated by an external crystal. The crystal is connected across the OSC IN and OSC OUT pins of the IM6102 device. Crystal characteristics were defined earlier, together with the description of IM6102 pins.

**A 12-bit Clock Counter register is at the heart of IM6102 real-time clock logic.** The contents of this register are incremented at time intervals which you select under program control. By selecting the appropriate increment time interval and initial Clock Counter register value, you can compute almost any time interval up to 40,950 milliseconds.

**The Clock Counter register has an associated Clock Buffer register.** You actually transfer data between the Clock Buffer register and the CPU Accumulator. The Clock Buffer register contents are transferred to the Clock Counter register to start computing a time interval. While the Clock Counter register is incrementing, you can, under program control, load a new value into the Clock Buffer register; the next time interval computed will then differ from the time interval currently being computed.

**IM6102 real-time clock registers and the instructions which access them may be illustrated as follows:**



**The programmable options of the IM6102 real-time clock logic are selected by loading appropriate bits into the Clock Enable register. This register's bits are assigned as follows:**



Clock Enable register bit 4 is a master enable/disable control. When set to 1, this bit stops IM6102 real-time clock logic. When the IM6102 is reset, this bit is cleared; after a reset, therefore, real-time clock logic can run. The CAF instruction resets bit 4 to 0.

Clock Enable register bits 6, 7 and 8 select the interval between increment pulses. With a 4 MHz oscillator, the time interval between Clock Counter register increments may vary between 1 microsecond and 10 milliseconds, as follows:

| Bits  | Time interval between increments |
|-------|----------------------------------|
| 8 7 6 |                                  |
| 0 1 0 | 10 msec                          |
| 0 1 1 | 1 msec                           |
| 1 0 0 | 100 $\mu$ sec                    |
| 1 0 1 | 10 $\mu$ sec                     |
| 1 1 0 | 1 $\mu$ sec                      |

**Following a reset, or execution of a CAF instruction,** all Clock Enable register bits are reset to 0; therefore **real-time clock logic is effectively disabled.** This is because the Clock Counter register increment logic is stopped, even though clock logic in general has been enabled by bit 4.

**Clock Enable register bit 9 is used to select One-shot mode or Continuous mode.** If this bit is 0, then **One-shot mode is selected; as soon as the Clock Counter register increments from FFF<sub>16</sub> to 000<sub>16</sub>, a clock overflow flag is set and the clock stops.** If bit 9 is 1, then when the Clock Counter register increments from FFF<sub>16</sub> to 000<sub>16</sub>, the clock overflow flag is set, but the Clock Buffer register contents transfer to the Clock Counter register, which starts incrementing again.

**Clock Enable register bit 11 enables or disables timer interrupts.** Timer interrupts can occur when the Clock Counter register overflows. From our earlier discussion of the IM6102 Interrupt Vector register, recall that the low-order bit of this register is set in response to an interrupt request coming from real-time clock logic. Thus, if Clock Enable register bit 11 is set to 1, then an interrupt request will occur whenever the Clock Counter register increments from FFF<sub>16</sub> to 000<sub>16</sub>. In response to an interrupt acknowledge, the address vector transmitted to the CPU will uniquely identify IM6102 real-time clock logic.

Programming the IM6102 real-time clock logic is very straightforward; it may be illustrated by the following instruction sequence:

|          |                                      |
|----------|--------------------------------------|
| CLA      | /CLEAR THE ACCUMULATOR               |
| TAD INIT | /LOAD STARTING VALUE INTO THE CLOCK  |
| CLAB     | /COUNTER BUFFER                      |
| TAD ENAB | /LOAD CONTROL CODE INTO THE CLOCK    |
| CLDE     | /ENABLE REGISTER AND START THE CLOCK |

## IM6102 MEDIC INSTRUCTIONS

There are a number of special I/O instructions recognized by an IM6102 MEDIC. These instructions, together with their object codes and operands, are listed in Table 13-6. Note carefully that the operands (where they occur) consist of two octal digits. The high-order octal digit can have any value in the range 0 through 7. The low-order octal digit must be 0.

The following abbreviations are used in Table 13-6:

|          |                                                                                                                            |
|----------|----------------------------------------------------------------------------------------------------------------------------|
| AC       | CPU Accumulator                                                                                                            |
| AC <x-y> | CPU Accumulator bits x through y inclusive. For example, AC <4-0> represents bits 4, 3, 2, 1, and 0 of the CPU Accumulator |
| CAR      | Current Address register                                                                                                   |
| CBR      | Clock Buffer register                                                                                                      |
| CC       | Clock Counter register                                                                                                     |
| COF      | Clock Overflow status                                                                                                      |
| DF       | Data Field register                                                                                                        |
| ECAR     | Extended Current Address register                                                                                          |
| EN       | Clock Enable register                                                                                                      |
| H        | High level voltage — positive logic "1"                                                                                    |
| IB       | Instruction Field buffer                                                                                                   |
| IE       | CPU Interrupt Enable status                                                                                                |
| IF       | Instruction Field register                                                                                                 |

|              |                                                                               |
|--------------|-------------------------------------------------------------------------------|
| IIFF         | Interrupt Inhibit Flip-Flop (IM6102 internal interrupt enable/disable status) |
| L            | Low level voltage — positive logic "0"                                        |
| LINK         | CPU Link status bit                                                           |
| n            | An octal operand digit in the range 0 through 7                               |
| SF           | Save Field register                                                           |
| SF <2,1,0>   | Save Field register bits 2, 1, 0                                              |
| SF <5,4,3>   | Save Field register bits 5, 4, 3                                              |
| SR           | DMA Status register                                                           |
| SR6          | DMA Status register bit 6 — the Field 7 wrap around carry error bit           |
| SR5          | DMA Status register bit 5 — the Word Count Overflow error bit                 |
| VR           | Interrupt Vector register                                                     |
| WCR          | DMA Word Count register                                                       |
| xxx          | Three bits of object code corresponding to "n", described above               |
| [ ]          | Contents of location enclosed within brackets                                 |
| $\wedge$     | Logical AND                                                                   |
| $\vee$       | Logical OR                                                                    |
| $\leftarrow$ | Data is transferred in the direction of the arrow                             |

Table 13-6. IM6102 MEDIC I/O Instructions

| TYPE                            | MNEMONIC | OPERAND | OBJECT CODE          | CONTROLS TO - CPU |    |    |     |  | OPERATION PERFORMED                                                                                                                                                                                             |
|---------------------------------|----------|---------|----------------------|-------------------|----|----|-----|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |          |         |                      | C0                | C1 | C2 | SKP |  |                                                                                                                                                                                                                 |
| GENERAL                         | CAF      |         | 6007<br>C07          | H                 | H  | H  | H   |  | [SR5]—0, [SR6]—0, [COF]—0, [EN]—0, [CBR]—0<br>Clear all flags: clear Word Count Overflow error bit, Field 7 wrap around carry error bit, and Clock Overflow flag; clear Clock Enable register and Clock Buffer. |
| EXTENDED MEMORY ADDRESS CONTROL | CDF      | n0      | 62n1<br>110010xxx001 | H                 | H  | H  | H   |  | [DF]—n<br>Load Data Field register immediate                                                                                                                                                                    |
|                                 | CIF      | n0      | 62n2<br>110010xxx010 | H                 | H  | H  | H   |  | [IB]—n<br>Load Instruction Field buffer immediate                                                                                                                                                               |
|                                 | CDF,CIF  | n0      | 62n3<br>110010xxx011 | H                 | H  | H  | H   |  | [DF]—n, [IB]—n<br>Load Data Field register and Instruction Field buffer immediate                                                                                                                               |
|                                 | GTF      |         | 6004<br>C04          | L                 | L  | H  | H   |  | Read flags into CPU Accumulator as follows:<br><br>                                                                           |
|                                 | LIF      |         | 6254                 | H                 | H  | H  | H   |  | [IF]—[IB]<br>Load Instruction Field register, re-enable interrupts                                                                                                                                              |
|                                 | RDF      |         | CAC<br>6214          | H                 | L  | H  | H   |  | [AC<5-3>]—[AC<5-3>]V [DF]<br>OR Data Field register into bits 6, 5, 4, and 3 of the CPU Accumulator                                                                                                             |
|                                 | RIB      |         | C8C<br>6234          | H                 | L  | H  | H   |  | [AC<5-0>]—[AC<5-0>]V [SF]<br>Save Field register into the low-order 6 bits of the CPU Accumulator                                                                                                               |
|                                 | RIF      |         | C9C<br>6224          | H                 | L  | H  | H   |  | [AC<5-3>]—[AC<5-3>]V [IF]<br>OR Instruction Field register into bits 5, 4, and 3 of the CPU Accumulator.                                                                                                        |
|                                 | RMF      |         | C94<br>6244          | H                 | H  | H  | H   |  | [IB]—[SF<5,4,3>], [DF]—[SF<2,1,0>]<br>Restore memory field. The Instruction Buffer will load the Instruction Field after the next JMP, JMS, or LIF instruction.                                                 |
|                                 | RTF      |         | CA4<br>6005<br>C05   | H                 | H  | H  | H   |  | Return flags from CPU as follows:<br><br>                                                                                    |
|                                 |          |         |                      |                   |    |    |     |  | After the next JMS, JMP, or LIF instruction, interrupts will be enabled and the Instruction Buffer will load the Instruction Field.                                                                             |

Table 13-6. IM6102 MEDIC I/O Instructions (Continued).

| TYPE                         | MNEMONIC | OPERAND            | OBJECT CODE         | CONTROLS TO CPU |    |    |     |  | OPERATION PERFORMED                                                                                                                                                           |
|------------------------------|----------|--------------------|---------------------|-----------------|----|----|-----|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |          |                    |                     | C0              | C1 | C2 | SKP |  |                                                                                                                                                                               |
| DIRECT MEMORY ACCESS CONTROL | LCAR     | n0<br>110010xxx110 | 6205<br>C85<br>62n6 | L               | H  | H  | H   |  | [CAR]—[AC]; [AC]—0<br>Transfer CPU Accumulator contents to Current Address register, then clear Accumulator.                                                                  |
|                              | LEAR     |                    | 6245                | H               | H  | H  | H   |  | [ECAR]—n<br>Load the Extended Current Address register immediate.                                                                                                             |
|                              | LFSR     |                    | CA5                 | L               | H  | H  | H   |  | [SR]—[AC<4-0>]; [AC]—0<br>Transfer low-order five bits of CPU Accumulator contents to DMA Status register, then clear Accumulator.                                            |
|                              | LWCR     |                    | 6225<br>C95         | L               | H  | H  | H   |  | [WCR]—[AC]; [AC]—0<br>Start DMA and clear Word Count Overflow status. Transfer CPU Accumulator to DMA Word Count register then clear Accumulator.                             |
|                              | RCAR     |                    | 6215<br>C8D         | L               | L  | H  | H   |  | [AC]—[CAR]<br>Transfer Current Address register contents to the CPU.                                                                                                          |
|                              | REAR     |                    | 6235<br>C9D         | H               | L  | H  | H   |  | [AC<5-3>]—[AC<5-3>] V [ECAR]<br>OR Extended Current Address register contents with CPU Accumulator bits 5, 4, and 3.                                                          |
|                              | RFSR     |                    | 6255<br>CAD         | H               | L  | H  | H   |  | [AC<6-0>]—[AC<6-0>] V [SR]; [SR6]—0<br>OR DMA Status register contents with CPU Accumulator bits 6-0; then clear bit 6 of the DMA Status register.                            |
|                              | SKOF     |                    | 6265<br>CB5         | H               | H  | H  | L/H |  | If DMA Word Count register has overflowed, return low SKP pulse.                                                                                                              |
| REAL-TIME CLOCK CONTROL      | CLAB     |                    | 6133<br>C5B         | H               | H  | H  | H   |  | [CBR]—[AC]; [CC]—[CBR]<br>Transfer the CPU Accumulator contents to the Clock Buffer register, then transfer the Clock Buffer register contents to the Clock Counter register. |
|                              | CLBA     |                    | 6136<br>C5E         | L               | L  | H  | H   |  | [AC]—[CBR]<br>Transfer the Clock Buffer register contents to the CPU Accumulator                                                                                              |
|                              | CLCA     |                    | 6137<br>C5F         | L               | L  | H  | H   |  | [CBR]—[CC]; [AC]—[CBR]<br>Transfer the Clock Counter register contents to the Clock Buffer register, then transfer the Clock Buffer register contents to the CPU Accumulator. |
|                              | CLDE     |                    | 6132<br>C5A         | H               | H  | H  | H   |  | [EN]—[EN] V [AC]<br>Set to 1 all Clock Enable register bits which correspond to 1 bits in the CPU Accumulator                                                                 |
|                              | CLEN     |                    | 6134<br>C5C         | L               | L  | H  | H   |  | [AC]—[EN]<br>Transfer Clock Enable register contents to the CPU Accumulator                                                                                                   |
|                              | CLSA     |                    | 6135<br>C5D         | L               | L  | H  | H   |  | [AC]—0; [AC<11>]—[COF]; [COF]—0<br>Clear CPU Accumulator, transfer Clock Overflow Flag to high bit of Accumulator, and then reset Clock Overflow Flag                         |
|                              | CLSK     |                    | 6131<br>C59         | H               | H  | H  | L/H |  | If Clock Overflow Flag is set return a low SKP pulse.                                                                                                                         |
|                              | CLZE     |                    | 6130<br>C58         | H               | H  | H  | H   |  | [EN]—[EN] ^ [AC]<br>Reset to 0 all Clock Enable register bits which correspond to 1 bits in the CPU Accumulator.                                                              |
| INTERRUPT CONTROL            | WRVR     |                    | 6275<br>CBD         | L               | H  | H  | H   |  | [VR]—[AC<11-1>]; [AC]—0<br>Transfer upper 10 bits of CPU Accumulator to the Interrupt Vector register, then clear Accumulator.                                                |

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- IM6100 CPU
- IM6101 PIE
- IM6102 MEDIC

# IM6100

## ABSOLUTE MAXIMUM RATINGS

|                                 |          |                         |                             |                 |              |
|---------------------------------|----------|-------------------------|-----------------------------|-----------------|--------------|
| Supply Voltage                  | IM6100/C | +4.0V to +7.0V          | Operating Temperature Range | Commercial      | 0°C to +75°C |
| Input or Output Voltage Applied | IM6100A  | +4.0V to 11.0V          | Industrial                  | -40°C to +85°C  |              |
| Storage Temperature Range       | GND      | -0.3V to $V_{cc}$ +0.3V | Military                    | -55°C to +125°C |              |
|                                 |          | -65°C to +125°C         |                             |                 |              |

DC CHARACTERISTICS  $V_{cc} = 5.0V \pm 10\%$  (IM6100),  $10.0V \pm 10\%$  (IM6100A),  $T_A = \text{Commercial, Industrial or Military}$

| PARAMETER                  | SYMBOL    | CONDITIONS                                                                                                                                       | MIN           | TYP | MAX          | UNITS   |
|----------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----|--------------|---------|
| Logical "1" Input Voltage  | $V_{IH}$  |                                                                                                                                                  |               |     |              | V       |
| Logical "0" Input Voltage  | $V_{IL}$  |                                                                                                                                                  |               |     |              | V       |
| Input Leakage              | $I_{IL}$  | $OV \leq V_{IN} \leq V_{cc}$                                                                                                                     | -1.0          |     | 20% $V_{cc}$ | $\mu A$ |
| Logical "1" Output Voltage | $V_{OH2}$ | $I_{out}=0$                                                                                                                                      | $V_{cc}-0.01$ |     | 1.0          | V       |
| Logical "1" Output Voltage | $V_{OH1}$ | $I_{out}=-0.2mA$                                                                                                                                 | 2.4           |     |              | V       |
| Logical "0" Output Voltage | $V_{OL2}$ | $I_{out}=0$                                                                                                                                      |               |     |              | V       |
| Logical "0" Output Voltage | $V_{OL1}$ | $I_{OL}=1.6\text{ mA}$                                                                                                                           |               |     |              | V       |
| Output Leakage             | $I_o$     | $OV \leq V_o \leq V_{cc}$                                                                                                                        | -1.0          |     | GND +0.01    | $\mu A$ |
| Supply Current             | $I_{CC}$  | $V_{cc} = 5.0\text{ volts}$<br>$V_{cc} = 10.0\text{ volts}$<br>$C_L = 50\text{ pF}; TA = 25^\circ C$<br>$f_{clock} = \text{Operating Frequency}$ | 0.45          | 1.0 | 2.5          | $\mu A$ |
|                            |           |                                                                                                                                                  |               |     | 10.0         | mA      |
| Input Capacitance          | $C_{IN}$  |                                                                                                                                                  |               | 5.0 |              | pF      |
| Output Capacitance         | $C_O$     |                                                                                                                                                  |               | 8.0 |              | pF      |



IM6100 TIMING AND STATE SIGNALS

AC CHARACTERISTICS ( $T_A = 25^\circ C$ ), Derate 0.390/ $^\circ C$

| PARAMETER                | SYMBOL   | IM6100<br>$V_{cc} = 5.0$<br>$f_c = 4MHz$ | IM6100A<br>$V_{cc} = 10.0$<br>$f_c = 8 MHz$ | IM6100C<br>$V_{cc} = 5.0$<br>$f_c = 3.3MHz$ | UNITS |
|--------------------------|----------|------------------------------------------|---------------------------------------------|---------------------------------------------|-------|
| Major State Time         | $T_s$    | 500                                      | 250                                         | 600                                         | ns    |
| LXMAR Pulse Width        | $t_L$    | 240                                      | 120                                         | 280                                         | ns    |
| Address Setup Time       | $t_{AS}$ | 50                                       | 30                                          | 50                                          | ns    |
| Address Hold Time        | $t_{AH}$ | 250                                      | 125                                         | 280                                         | ns    |
| 'Access Time From LXMAR' | $t_{AL}$ | 500                                      | 250                                         | 600                                         | ns    |
| Output Enable Time       | $t_{EN}$ | 240                                      | 120                                         | 280                                         | ns    |
| Read Pulse Width         | $t_{RP}$ | 700                                      | 350                                         | 800                                         | ns    |
| Write Pulse Width        | $t_{WP}$ | 240                                      | 120                                         | 280                                         | ns    |
| Data Setup Time          | $t_{DS}$ | 120                                      | 50                                          | 280                                         | ns    |
| Data Hold Time           | $t_{DH}$ | 100                                      | 50                                          | 160                                         | ns    |

Data sheets on pages 13-D2 through 13-D6 reprinted by permission of Intersil, Incorporated.

**IM6101****ABSOLUTE MAXIMUM RATINGS**

| Supply Voltage                  |                          | Operating Temperature Range |                |  |
|---------------------------------|--------------------------|-----------------------------|----------------|--|
| IM6101                          | +8.0V                    | Industrial                  | -40°C to 85°C  |  |
| IM6101A                         | +12.0V                   | Military                    | -55°C to 125°C |  |
| Applied Input or Output Voltage |                          | Operating Voltage Range     |                |  |
| GND                             | -0.3V to V <sub>CC</sub> | IM6101                      | 4V to 7V       |  |
|                                 | +0.3V                    | IM6101A                     | 4V to 11V      |  |
| Storage Temperature Range       |                          | -65°C to 150°C              |                |  |

**DC CHARACTERISTICS** V<sub>CC</sub> = Operating Voltage Range TA = Temperature Range

| PARAMETER                  | SYMBOL           | CONDITIONS                                       | MIN                    | TYP | MAX                 | UNITS |
|----------------------------|------------------|--------------------------------------------------|------------------------|-----|---------------------|-------|
| Logical "1" Input Voltage  | V <sub>IH</sub>  |                                                  | 70% V <sub>CC</sub>    |     |                     | V     |
| Logical "0" Input Voltage  | V <sub>IL</sub>  |                                                  |                        |     | 20% V <sub>CC</sub> | V     |
| Input Leakage              | I <sub>IL</sub>  | 0V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub>           | -1.0                   |     | 1.0                 | µA    |
| Logical "1" Output Voltage | V <sub>OH2</sub> | I <sub>OUT</sub> = 0                             | V <sub>CC</sub> - 0.01 |     |                     | V     |
| Logical "1" Output Voltage | V <sub>OH1</sub> | I <sub>OH</sub> = -0.2 mA                        | 2.4                    |     |                     | V     |
| Logical "0" Output Voltage | V <sub>OZ2</sub> | I <sub>OUT</sub> = 0                             |                        |     | GND + 0.01          | V     |
| Logical "0" Output Voltage | V <sub>OZ1</sub> | I <sub>OL</sub> = 2.0 mA                         |                        |     | 0.45                | V     |
| Output Leakage             | I <sub>O</sub>   | QV ≤ V <sub>O</sub> ≤ V <sub>CC</sub>            | -1.0                   |     | 1.0                 | µA    |
| Supply Current             | I <sub>CC1</sub> | V <sub>IN</sub> = V <sub>CC</sub>                |                        | 1.0 |                     | µA    |
|                            | I <sub>CC2</sub> | V <sub>CC</sub> = 5V f <sub>IM6100</sub> = 4 MHz |                        | 1.0 |                     | mA    |
| Input Capacitance          | C <sub>I</sub>   |                                                  |                        | 5   | 7                   | pf    |
| Output Capacitance         | C <sub>O</sub>   |                                                  |                        | 8   | 10                  | pf    |
| Input/Output Capacitance   | C <sub>ID</sub>  |                                                  |                        | 8   | 10                  | pf    |

**AC CHARACTERISTICS** TA = 25°C CL = 50pf

| PARAMETER                    | SYMBOL             | CONDITIONS                                                   | MIN | TYP        | MAX | UNITS    |
|------------------------------|--------------------|--------------------------------------------------------------|-----|------------|-----|----------|
| Delay from DEVSEL to READ    | t <sub>DR</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 150<br>75  |     | ns<br>ns |
| Delay from DEVSEL to WRITE   | t <sub>DW</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 150<br>75  |     | ns<br>ns |
| Delay from DEVSEL to FLAG    | t <sub>DF</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 200<br>100 |     | ns<br>ns |
| Delay from DEVSEL to C1, C2  | t <sub>DC</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 200<br>100 |     | ns<br>ns |
| Delay from DEVSEL to SKP/INT | t <sub>DI</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 200<br>100 |     | ns<br>ns |
| Delay from DEVSEL to DX      | t <sub>DA</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 200<br>100 |     | ns<br>ns |
| LXMAR pulse width            | t <sub>LXMAR</sub> | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 200<br>100 |     | ns<br>ns |
| Address setup time           | t <sub>ADDS</sub>  | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 50<br>25   |     | ns<br>ns |
| Address hold time            | t <sub>ADDH</sub>  | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 100<br>50  |     | ns<br>ns |
| Data setup time              | t <sub>DS</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 200<br>100 |     | ns<br>ns |
| Data hold time               | t <sub>DH</sub>    | IM6101 V <sub>CC</sub> = 5V<br>IM6101A V <sub>CC</sub> = 10V |     | 50<br>25   |     | ns<br>ns |

## TIMING DIAGRAM

Timing for a typical IOT transfer is shown below. During IFETCH the processor obtains from memory an IOT instruction of the form 6XXX. During the IOTA the processor places that instruction back on the DX lines ③ and pulses LXMAR transferring address and control information for the IOT transfer to all peripheral devices. A low going pulse on DEVSEL while XTC is high ④ is used by the addressed PIE along with decoded control

information to generate C1, C2, SKP and controls for data transfers to the processor. Control outputs READ1 and READ2 are used to gate peripheral data to the DX lines during this time. A low going pulse on DEVSEL while XTC is low ⑤ is used to generate WRITE1 and WRITE2 controls. These signals are used to clock processor accumulator instruction data into peripheral devices.



All PIE timing is generated from IM6100 signals LXMAR, DEVSEL, and XTC. No additional timing signals, clocks, or one shots are required. Propagation delays, pulse width, data setup and hold times are specified for direct interfacing with the IM6100.

**IM6102**

| ABSOLUTE MAXIMUM RATINGS                                                                                                                 |                   |                                                               |     |                                     |                                                        |                   | IM6102I<br>IM6102M |       |     |  |
|------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------------------------|-----|-------------------------------------|--------------------------------------------------------|-------------------|--------------------|-------|-----|--|
| Supply Voltage                                                                                                                           |                   |                                                               |     |                                     |                                                        | 8V                |                    |       |     |  |
| Input or Output Voltage applied                                                                                                          |                   |                                                               |     | GND -0.3V to V <sub>CC</sub> + 0.3V |                                                        |                   |                    |       |     |  |
| Storage Temperature Range                                                                                                                |                   |                                                               |     | -65°C to +150°C                     |                                                        |                   |                    |       |     |  |
| Operating Temperature Range                                                                                                              |                   |                                                               |     | IM6102I -40°C to +85°C              |                                                        |                   |                    |       |     |  |
| Operating Voltage Range                                                                                                                  |                   |                                                               |     | IM6102M -55°C to +125°C             |                                                        |                   |                    |       |     |  |
|                                                                                                                                          |                   |                                                               |     | 4-7V                                |                                                        |                   |                    |       |     |  |
| DC CHARACTERISTICS      V <sub>CC</sub> = 5.0V ± 10%    T <sub>A</sub> = Industrial or Military                                          |                   |                                                               |     |                                     |                                                        |                   |                    |       |     |  |
| PARAMETER                                                                                                                                | SYMBOL            | CONDITIONS                                                    |     |                                     | MIN                                                    | TYP               | MAX                | UNITS |     |  |
| Logical "1" Input Voltage                                                                                                                | V <sub>IH</sub>   | OV ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> except pins 15, 29, 31 |     |                                     | V <sub>CC</sub> -2.0                                   |                   |                    | V     |     |  |
| Logical "0" Input Voltage                                                                                                                | V <sub>IL</sub>   | I <sub>OH</sub> = -0.2 mA except pins 32, 33, 34              |     |                                     | -1.0                                                   |                   | 0.8                | V     |     |  |
| Input Leakage                                                                                                                            | I <sub>IL</sub>   | I <sub>OL</sub> = 2.0mA                                       |     |                                     | 2.4                                                    |                   | 1.0                | μA    |     |  |
| Logical "1" Output Voltage                                                                                                               | V <sub>OH</sub>   | OV ≤ V <sub>O</sub> ≤ V <sub>CC</sub>                         |     |                                     |                                                        |                   | 0.45               | V     |     |  |
| Logical "0" Output Voltage                                                                                                               | V <sub>OL</sub>   | V <sub>CC</sub> = 5.0V                                        |     |                                     |                                                        |                   | 1.0                | V     |     |  |
| Output Leakage                                                                                                                           | I <sub>O</sub>    | CL = 50 pF; TA = 25°C                                         |     |                                     | -1.0                                                   |                   | 2.5                | μA    |     |  |
| Supply Current                                                                                                                           | I <sub>CC</sub>   | FCLOCK = Operating Frequency                                  |     |                                     |                                                        |                   |                    | mA    |     |  |
| Input Capacitance                                                                                                                        | C <sub>IN</sub>   |                                                               |     |                                     |                                                        | 7.0               | 8.0                | pF    |     |  |
| Output Capacitance                                                                                                                       | C <sub>CO</sub>   |                                                               |     |                                     |                                                        | 8.0               | 10.0               | pF    |     |  |
| AC CHARACTERISTICS                                                                                                                       |                   |                                                               |     |                                     |                                                        |                   |                    |       |     |  |
| V <sub>CC</sub> = 5.0V ± 10%    T <sub>A</sub> = Industrial or Military    CL = 50pF    fc = 4MHZ : TS = 2/fc = 500ns    All times in ns |                   |                                                               |     |                                     |                                                        |                   |                    |       |     |  |
| PARAMETER                                                                                                                                | SYMBOL            | MIN                                                           | TYP | MAX                                 | PARAMETER                                              | SYMBOL            | MIN                | TYP   | MAX |  |
| LXMAR pulse width IN                                                                                                                     | t <sub>LIN</sub>  | 250                                                           |     |                                     | LXMAR* pulse width                                     | t <sub>LD</sub>   |                    | 250   |     |  |
| XTA pulse width IN                                                                                                                       | t <sub>TAI</sub>  | 500                                                           | 150 |                                     | DMA READ access time:<br>LXMAR* (↓)-UP (↑)             | t <sub>DRAT</sub> |                    | 500   |     |  |
| Address setup time IN: DX-LXMAR (↓)                                                                                                      | t <sub>AIS</sub>  |                                                               | 100 |                                     | DX & EMA address setup time<br>wrt LXMAR* (↓)          | t <sub>DXAS</sub> |                    | 375   |     |  |
| Address hold time IN: LXMAR (↓)-DX                                                                                                       | t <sub>AIH</sub>  |                                                               | 100 |                                     | DX & EMA address hold time<br>wrt LXMAR* (↓)           | t <sub>EMAS</sub> |                    | 375   |     |  |
| Data output enable time:<br>DEVSEL (↓)-DX                                                                                                | t <sub>DEN</sub>  |                                                               | 200 |                                     | DMA READ enable time:<br>MEMSEL* (↓)-UP (↑)            | t <sub>DREN</sub> |                    | 375   |     |  |
| Controls output enable time:<br>DEVSEL (↓)-lines C0, C1, C2, S/I                                                                         | t <sub>CEN</sub>  |                                                               | 100 |                                     | UP pulse width DMA READ                                | t <sub>RUP</sub>  |                    | 250   |     |  |
| Write pulse width IN                                                                                                                     | t <sub>DVW</sub>  |                                                               | 75  |                                     | DMA WRITE access time:<br>LXMAR* (↓)-MEMSEL* (↑)       | t <sub>DWAT</sub> |                    | 500   |     |  |
| Data input setup time: DX-DEVSEL (↑)                                                                                                     | t <sub>DIS</sub>  |                                                               | 0   |                                     | DMA WRITE enable time:<br>UP (↓)-MEMSEL* (↑)           | t <sub>DWEN</sub> |                    | 375   |     |  |
| Data input hold time: DEVSEL (↑)-DX                                                                                                      | t <sub>DIH</sub>  |                                                               | 50  |                                     | MEMSEL* setup time DMA WRITE<br>MEMSEL* (↓)-LXMAR* (↑) | t <sub>MWS</sub>  |                    | 125   |     |  |
| RESET input pulse width                                                                                                                  | t <sub>RST</sub>  |                                                               | 100 |                                     | DMAEN setup time w.r.t. XTA (↑)                        | t <sub>DMS</sub>  |                    | 50    |     |  |
| SKP/INTX to SKP/INT<br>propagation delay                                                                                                 | t <sub>SID</sub>  |                                                               | 100 |                                     | DMAEN hold time w.r.t. XTA (↑)                         | t <sub>DMH</sub>  |                    | 50    |     |  |
| DMA control signals delay: XTC-XTC*:<br>MEMSEL-MEMSEL*, LXMAR-<br>LXMAR*                                                                 | t <sub>DMLX</sub> |                                                               | 100 |                                     | UP pulse width DMA WRITE                               | t <sub>WUP</sub>  |                    | 500   |     |  |
| Enable/Disable time from<br>DMAGNT to EMA lines                                                                                          | t <sub>DEM</sub>  |                                                               | 100 |                                     |                                                        |                   |                    |       |     |  |
| MEMSEL* pulse width - DMA READ                                                                                                           | t <sub>MDR</sub>  |                                                               | 500 |                                     |                                                        |                   |                    |       |     |  |
| MEMSEL* pulse width - DMA WRITE                                                                                                          | t <sub>MDW</sub>  |                                                               | 625 |                                     |                                                        |                   |                    |       |     |  |
| MEMSEL* pulse width -<br>DMA READ/REFSH                                                                                                  | t <sub>MDRR</sub> |                                                               | 500 |                                     |                                                        |                   |                    |       |     |  |
| MEMSEL* pulse width -<br>DMA WRITE/REFSH                                                                                                 | t <sub>MDWR</sub> |                                                               | 375 |                                     |                                                        |                   |                    |       |     |  |

## SDMA OPERATIONS TIMING

## DMA READ



## DMA WRITE

DMA  
READ/REFRESHDMA  
WRITE/REFRESH

## Chapter 14 THE 8X300 (OR SMS300)

We have described this product in previous editions under the designation SMS300. However, its manufacturer now calls it 8X300, and that is the standard part number.

The 8X300 is described by its manufacturer as a "microcontroller" rather than a "microprocessor". This distinction draws attention to the unique capabilities of the 8X300 which make it the most remarkable device described in this book.

The 8X300 is designed to serve as a signal processor or logic controller, operating at very high speed. The 8X300 can handle applications of this type at more than ten times the speed of most other devices described in this book. On the other hand, the 8X300 has a very limited ability to access read/write memory, or to perform arithmetic operations — particularly when handling multibyte arithmetic.

If yours is a high-speed, signal processing application, then give the 8X300 serious consideration; otherwise, the 8X300 is probably not for you.

We describe the 8X300 in Chapter 14 because it lies between the 8-bit microcomputers, which we have just described, and the 16-bit devices described beginning with Chapter 15. The 8X300 accesses program memory as 16-bit words, while accessing data in 8-bit units.

Although Scientific Micro Systems was originally considered the prime source for the 8X300 (then known as the SMS300), the only manufacturer of 8X300 parts to date has been Signetics. Signetics has always manufactured parts for itself and for Scientific Micro Systems, even though Signetics was looked upon as the second source. The second source designation came from the fact that the part was initially designed by Scientific Micro Systems, which contracted with Signetics for production. Scientific Micro Systems no longer sells the 8X300 or related components.

All 8X300 devices are manufactured using bipolar technology. For this reason, devices have very fast logic; but conversely, they consume a great deal of power.

At present, the sole source for 8X300 components is:

SINETICS  
P.O. Box 9052  
811 E. Arques Avenue  
Sunnyvale, CA 94086

### THE 8X300 MICROCONTROLLER

Figure 14-1 illustrates that part of our general microcomputer logic which is implemented by the 8X300 Microcontroller. Figure 14-2 provides a functional overview of this device.



**Figure 14-1. Logic of the 8X300 Microcontroller and 8T32/3/5/6**

The 8X300 is manufactured using bipolar LSI technology; it is packaged as a 50-pin DIP. A single +5V power supply is required.

Using a 150 nanosecond clock, instructions execute in 250 nanoseconds. However, comparing 8X300 instruction execution times with other microcomputer instruction times can be misleading. A single 8X300 instruction, when simply manipulating data, can be the equivalent of five "typical" microcomputer instructions; on the other hand, it may take four or more 8X300 instructions to perform a memory access which could be accomplished using one "typical" microcomputer instruction.

It is important to note that the very fast 8X300 clock demands external logic with appropriately fast response times. You are therefore highly restricted in the size of memory, and the type of I/O device which you can include in an 8X300 microcomputer system.



Figure 14-2. A Logic Overview of the 8X300 Microcontroller

## 8X300 ADDRESSABLE REGISTERS

Addressable registers of the 8X300 may be illustrated as follows:



**The seven General Purpose registers and the Auxiliary register constitute eight primary Accumulators.** The result of any ALU operation may be stored in the Auxiliary register, or in any one of the seven General Purpose registers. ALU operations that require a single data input may receive this input from any General Purpose register, or from the Auxiliary register. ALU operations that require two data inputs will receive the second data input from the Auxiliary register only.

**The 8X300 IVB Bus is equivalent to a microprocessor Data Bus.** The IVB Bus buffer operates as a source or destination for data in the same way as a general purpose register; it can be the destination of an ALU operation, or it can be the source for one ALU input. Strictly speaking, the IVB Bus buffer is not a programmable register, in that there are no instructions that will simply load data into the IVB Bus buffer or read data out of the IVB Bus buffer. However, **any instruction that outputs data on the IVB Bus or reads data off the IVB Bus will also write into the IVB Bus buffer.**

The strange general purpose register numbering reflects instruction object code interpretations which we will describe later in this chapter. 8X300 assembly language uses register designations to identify a number of operations that have nothing to do with programmable registers; do not be confused.

**The Program Counter is thirteen bits wide; thus, a total of 8192 program memory words may be addressed.** The Program Counter is one feature of 8X300 logic which is not unusual; at all times, this register addresses the next program memory location from which an instruction code will be fetched.

Manufacturer's literature describes an Instruction Address register, but this is not a programmable register; it is simply a location within which effective program memory addresses are computed before being output to the program memory.

**Observe that the 8X300 has no Data Counter, Stack Pointer, or other logic via which external data memory can be addressed.**

## 8X300 STATUS FLAGS

**The 8X300 has a single status flag,** referred to in the manufacturer's literature as the Overflow (OVF) flag. This flag is, in fact, a Carry status, as we would define it.

In keeping with the generally unusual architecture of the 8X300, the Overflow status flag is addressed as though it were the low order bit of General Purpose Register 8 (10 octal).

## 8X300 MEMORY ADDRESSING

**The 8X300 can access program memory and I/O devices; the 8X300 has no logic capable of addressing data memory.**

Program memory is addressed in 16-bit words; up to 8192 words of program memory can be addressed. You can address program memory in order to fetch instruction object codes, but that is all. You cannot store data tables in program memory, because there is absolutely no way of transferring the contents of a program memory word to any data register. Also, there is absolutely no way in which you can write into program memory.

8X300  
PROGRAM  
MEMORY  
ADDRESSING

**All data and external logic is addressed as 8-bit data units, via 512 I/O port addresses.** If you want to have read/write memory present in an 8X300 system, you must set aside a block of contiguous I/O port addresses in order to select individual bytes of read/write memory; alternatively, you must access 8-bit buffers, via I/O port addresses, in order to create the memory address and Data Busses which are needed by external read/write memory. For example, you could address 65,536 bytes of external read/write memory by allocating two 8-bit I/O ports to hold 16 bits of data which will create a memory Address Bus; a third 8-bit I/O port must be set aside as a buffer, holding data being written out to external memory or being read from external memory.

8X300  
DATA AND I/O  
ADDRESSING

The 8T32/3/5/6 Interface Vector Bytes (IV Bytes), which are described later in this chapter, have been designed to operate as I/O ports, read/write memory and the 8X300 Microcontroller external logic interface. Because of the unique architecture of the 8X300, and particularly because of its very high speed, you will probably find that the IV Bytes currently have no substitutes in any 8X300 microcomputer system.

8T32/3/5/6  
IV BYTES

Looking at the 8X300 from the frame of reference of any other microcomputer described in this book, an IV Byte is a simple, 8-bit parallel I/O port. But unlike the I/O ports of other microprocessors, 8X300 instructions that access an I/O port do not identify the I/O port that is to be accessed. You must first execute an instruction which selects an I/O port; then any instruction which specifies an I/O port access will access the most recently selected I/O port. You can have two I/O ports simultaneously selected, since the 8X300 divides a total of 512 addressable I/O ports into a left bank and a right bank — within each bank a single IV Byte can be selected.

8T32/3/5/6  
IV BYTE  
ADDRESSING

As we have already stated, if you want to have read/write memory present in an 8X300 microcomputer system, you must create the address and Data Bus required by the external read/write memory using IV bytes. This is no different than using I/O ports of any other microcomputer system described in this book in order to create Address and Data Busses. The reason the 8X300 can get away with such an apparently clumsy method of accessing read/write memory is because of the very high speed of instruction execution — and because of the fact that the 8X300 is simply not designed for data manipulations that use a lot of read/write memory. For the type of signal processing and logic control applications that are well suited to an 8X300, 512 bytes of external read/write memory will be more than sufficient.



Figure 14-3. 8X300 Microcontroller Signals and Pin Assignments

## 8X300 PINS AND SIGNALS

8X300 pins and signals are illustrated in Figure 14-3.

Signetics literature numbers bits and busses beginning with 0 for the high-order bit or line. We number bits and busses in the opposite direction, with 0 representing the low-order bit or line. In Figure 14-3, therefore, signals are identified first with the nomenclature used by Signetics documentation, then in parentheses with the signal name using our numbering system. Furthermore, all bit numbers throughout this chapter refer to our numbering system.

All addresses are output to program memory via the Address Bus lines A0 - A12. Note carefully that addresses cannot be output via A0 - A12 to data memory. The only time an address will be output via the Address Bus is during an instruction fetch operation. The fetched instruction object code will be returned via the sixteen instruction pins, I0 - I15.

IV0 - IV7 is a combined Address and Data Bus via which external logic is accessed by the 8X300. You will find it easiest to understand this bus if you visualize it as a multiplex I/O port address and I/O Data Bus.

**The two control signals, RB and LB, may be looked upon as an extension to the IVB Bus** when an I/O port address is being output via this bus. Whenever an address is being output on the IVB Bus, either RB or LB will be low, while the other signal is high. You can use these two signals in order to decode the address on the IVB Bus as selecting one or two of the 256 I/O port banks. We will describe how to output I/O port addresses, as against data, later in this chapter.

**The WC and SC control outputs further define the contents of the IVB Bus as follows:**

| SC | WC |                                                           |
|----|----|-----------------------------------------------------------|
| 0  | 0  | Data is input to the 8X300 via the IVB Bus                |
| 0  | 1  | Data is output on the IVB Bus by the 8X300                |
| 1  | 0  | An I/O port address is output on the IVB Bus by the 8X300 |
| 1  | 1  | Never output                                              |

**MCLK** is a **synchronizing clock signal** which is output as a high pulse during the last quarter of every instruction cycle.

**The HALT and RESET signals are absolutely standard.**

When HALT is input low, the 8X300 will cease executing instructions until HALT is input high again.

When RESET is input low and is held low for at least one machine cycle, the Program Counter contents are set to zero; subsequently, program execution will begin again with execution of the instruction stored in memory location zero.

**The two inputs X1 and X2 are used either to connect a crystal or a capacitor.** If the 8X300 Microcontroller is being used at maximum speed (125 nanosecond signal frequency) then you must connect a crystal across X1 and X2. If you are using a slower clock, then a capacitor connected across these two inputs will suffice.

## 8X300 INSTRUCTION EXECUTION AND TIMING

**8X300 instructions are executed in either one or two machine cycles. Minimum instruction cycle time is 250 nanoseconds. Each instruction cycle is divided into 62.5 nanosecond quarters as follows:**



During the fourth quarter of a machine cycle, the address for the next machine cycle's instruction object code is output via the Address Bus, A0 - A12.

During the first quarter of the next machine cycle, the addressed instruction object code is input via the Instruction Bus, IO - I15.

During the second and third quarters of a machine cycle, data is input off the IVB Bus by the 8X300, if necessary; then any internal operations on data are performed.

During the fourth quarter, in addition to the next address being output to program memory, data is output to the IVB Bus, if necessary.

Within the rather simple-looking instruction timing illustrated above, some very complex event sequences can occur as a result of the 8X300 Microcontroller's unique internal logic organization. Timing and propagation delays are quite complex and must be examined with care using vendor data sheets as your guide.

The 8X300 Microcontroller's internal logic is unique because **a good deal of it is distributed along various data paths. This is illustrated in Figure 14-2.**

Consider the implications of the shift, merge, rotate and mask logic positions.

Data entering the Arithmetic and Logic Unit, either from the IVB Bus Buffer, or from a general purpose register, must pass through both the rotate and mask logic. The rotate logic optionally allows the entering eight data bits to be right-rotated by any number of bit positions:

**8X300  
ROTATE  
AND MASK  
LOGIC**



The mask logic optionally allows you to take the output from the rotate logic and mask off any number of bits, beginning with the high-order bit:



Thus, the data entering the ALU from either a general purpose register or the IVB Bus register may be rotated and/or masked before being operated on.

Combining the rotate and mask logic that we have just described, the input to the ALU may be illustrated as follows:



Suppose an input is right-rotated three bit positions, then the two high-order bits are masked off; this would be the result:

| 7                      | 6  | 5  | 4  | 3  | 2  | 1  | 0  | Bit No. |
|------------------------|----|----|----|----|----|----|----|---------|
| Initial value: A7      | A6 | A5 | A4 | A3 | A2 | A1 | A0 |         |
| After right rotate: A2 | A1 | A0 | A7 | A6 | A5 | A4 | A3 |         |
| After mask: 0          | 0  | A0 | A7 | A6 | A5 | A4 | A3 |         |

The result of the rotate/mask logic illustrated above becomes an Arithmetic and Logic Unit (ALU) input; it may be the only ALU input, or it may be one of two ALU inputs. If it is the only ALU input, it will simply be passed through the ALU.

If it is one of two ALU inputs, then the second input is the unmodified contents of an 8-bit Auxiliary register. You may Add, AND or XOR the two operands:



Thus, the ALU output may be the unmodified result of rotate and mask logic, or it may be the output from an arithmetic or logical operation, as illustrated above. In either case, the ALU output may be stored in the Auxiliary register, or in one of the general purpose registers; or it may be output to the IVB Bus.

Data being transferred to the IVB Bus passes through shift and merge logic. This shift and merge logic combines in a very unusual way. ALU output, if shifted, may be shifted left from one to seven bits. However, zeros are not shifted in to the low-order bits; rather, any prior contents of the IVB Buffer are moved into the vacated bit positions.

**8X300  
SHIFT AND  
MERGE LOGIC**

In addition, you can specify the number of high-order bits which will retain their IVB Buffer values. This may be illustrated as follows:



Thus you create a new IVB Bus output by inserting from one to eight new data bits anywhere in the old data bit field. In the illustration above, A<sub>i</sub> represents new data bits; B<sub>j</sub> represents old IVB Buffer bits.

Suppose you specify a 2-bit left shift and a 3-bit merge; this would be the result:



Figures 14-4 through 14-7 illustrate the four possible data paths that may be specified by 8X300 instructions. In all four figures, data entering the ALU from the Auxiliary register is optional, but, if present, requires an Add, AND or XOR operation to be performed.

## THE 8X300 INSTRUCTION SET

We cannot neatly categorize instructions as we have done for any other product described in this book; one 8X300 instruction may perform a data move, plus five additional operations. Therefore, in order to summarize the 8X300 instruction set in Table 14-2, we list individual instructions that perform many operations under each of the instruction classes that may apply.

Table 14-2 will help you understand what the true comparison is between the 8X300 instruction set and other microcomputer instruction sets. However, **Table 14-2 will do nothing to help you understand 8X300 assembly language.** This is because of the strange assembly language mnemonics adopted by Scientific Micro Systems for the 8X300 Assembler. But without some understanding of 8X300 instruction codes, any further discussion of assembly language mnemonics will have little meaning; therefore let us take a look at these object codes, and simultaneously look at the assembly language syntax that goes with them.

**The one general statement that can be made for all 8X300 instructions is that every instruction has a single, 16-bit object code; the 3 high-order object code bits define the instruction class, while the next 13 bits provide additional operand or qualifying data. This may be illustrated as follows:**



Now we are going to make the discussion which follows conform to the rest of this book by numbering instruction words and data byte bits from right to left; and we are going to use hexadecimal object code notation. Signetics' literature, by way of contrast, numbers data words from left to right, and uses a form of bastardized octal notation to describe instruction object codes.

**The first four classes of 8X300 instructions have identical object code formats which may be illustrated as follows:**



The "Source definition" and "Destination definition" are defined as register numbers; since each definition is five bits wide, a register number in the range  $00_{16}$  through  $1F_{16}$  ( $00g$  through  $37g$ ) may be specified. But you get to specify a lot more than a source or destination register. Table 14-1 summarizes the possibilities.

Table 14-1. 8X300 Source and Destination Object Code Interpretations

| CODE                   |          |                | INTERPRETATION                                                                                                                                                                                       |                                                                                                                                                                                                    |
|------------------------|----------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BINARY                 | OCTAL    | HEX            | SOURCE DEFINITION                                                                                                                                                                                    | DESTINATION DEFINITION                                                                                                                                                                             |
| 00000                  | 00       | 00             |                                                                                                                                                                                                      | Auxiliary register                                                                                                                                                                                 |
| 00001                  | 01       | 01             |                                                                                                                                                                                                      | General Purpose Register R1                                                                                                                                                                        |
| 00010                  | 02       | 02             |                                                                                                                                                                                                      | General Purpose Register R2                                                                                                                                                                        |
| 00011                  | 03       | 03             |                                                                                                                                                                                                      | General Purpose Register R3                                                                                                                                                                        |
| 00100                  | 04       | 04             |                                                                                                                                                                                                      | General Purpose Register R4                                                                                                                                                                        |
| 00101                  | 05       | 05             |                                                                                                                                                                                                      | General Purpose Register R5                                                                                                                                                                        |
| 00110                  | 06       | 06             |                                                                                                                                                                                                      | General Purpose Register R6                                                                                                                                                                        |
| 00111                  | 07       | 07             | All zero input                                                                                                                                                                                       | Output an 8-bit I/O port address to a left bank IV Byte                                                                                                                                            |
| 01000                  | 10       | 08             | OVF status (low-order bit only)                                                                                                                                                                      | Not allowed                                                                                                                                                                                        |
| 01001                  | 11       | 09             |                                                                                                                                                                                                      | General Purpose Register R11                                                                                                                                                                       |
| 01010 through<br>01110 | 12<br>16 | 0A<br>0E       | { All zero input }                                                                                                                                                                                   | No operation                                                                                                                                                                                       |
| 01111                  | 17       | 0F             |                                                                                                                                                                                                      | Output an 8-bit I/O port address to a right bank IV Byte.                                                                                                                                          |
| 10XXX                  | 2X       | 10<br>to<br>17 | Contents of left bank IV Byte selected by most recent 07 output is loaded into IVB buffer; this data is then right rotated X bit positions, or its way to the ALU. IVB buffer holds unrotated input. | ALU output is shifted left 7-X bit positions. After passing through merge logic, merge logic output will be stored in IVB buffer, and in left bank IV Byte most recently selected by an 07 output. |
| 11XXX                  | 3X       | 18<br>to<br>1F | Identical to 10XXX, except that right bank IV Byte most recently selected by a 0F (or 17) output is accessed.                                                                                        |                                                                                                                                                                                                    |

**8X300 assembly language syntax closely follows the object code format; this may be illustrated as follows:**

LABEL OP S, N, D

LABEL represents any normal assembly language instruction label; as usual. LABEL is optional.

OP represents the operation or instruction mnemonic. OP may be MOVE, ADD, AND, or XOR, depending on which of the four instructions is being executed. OP corresponds to bits 15, 14 and 13 of the instruction code.

The assembly language operand field consists of three terms: S, N and D.

With reference to the instruction object code we have illustrated above. S represents bits 8 through 12, the source definition.

N represents bits 5 through 7 which may provide rotation, mask or merge parameters, depending on the nature of S and D.

D represents bits 0 through 4 of the instruction object code and provides the destination definition.

The problem with the S, N and D terms of the operand field is that they are not really operands as one would normally define them in an assembly language instruction set. These three fields also help identify part of the instruction operation, or mnemonic. If you approach 8X300 assembly language realizing that its operand field is really an extension of the mnemonic field, you will have less trouble understanding individual instructions.

The various ways in which a Move, Add, AND, or XOR instruction may be executed are illustrated in Figures 14-4 through 14-7. Let us look at these possibilities in more detail.

**When a register is specified as both the source and destination of data, Figure 14-4 defines the operation.** Referring to this figure, note that the source data is rotated, but it is not masked. The second ALU input will only occur if you are executing an Add, AND, or XOR instruction; and in each case the second ALU input will be the unmodified contents of the Auxiliary register.

The classes of instruction illustrated in Figure 14-4 can be listed under the following categories:

- 1) A Register-Register Move. This involves specifying a Move instruction with different registers as the data source and destination, but no right rotate.
- 2) Register Operate. By specifying the same register as the source and destination for a MOVE, you can create a Register Operate instruction if you also specify some degree of right rotation. You can create additional Register Operate instructions by specifying the Auxiliary register as both source and destination for an Add, AND or XOR instruction.
- 3) Register-Register Operate. By specifying an Add, AND or XOR operation that does not use the Auxiliary register as both source and destination, you create Register-Register Operate instructions.

Consider some possibilities.

In order to complement any register's contents, load FF16 into the Auxiliary register (using an XMIT instruction), then XOR the General Purpose register contents with the Auxiliary register contents, returning the results to the General Purpose register. These two instructions can be executed in 500 nanoseconds.

You can AND or XOR Auxiliary register bits with other data bits from the same Auxiliary register by specifying the Auxiliary register as the source and destination for an AND or XOR instruction with right rotate. The ability to perform logical operations on bits within a single 8-bit unit is very useful if you are treating the contents of a register as status, representing individual signal levels rather than treating the bits contiguously, as data items.

Apparently absent instructions, such as Register Increment, Register Decrement, OR and Compare, can be generated by using the Auxiliary register to hold appropriate intermediate data.



Figure 14-4. An 8X300 Register-to-Register Instruction's Execution

**Figure 14-5 illustrates Move, Add, AND and XOR instructions where the IVB Bus is the data source and a general purpose register is the data destination.** Referring to Figure 14-5, observe that the mask and right rotate logic are both involved. Bits 5, 6 and 7 of the instruction object code, which in Figure 14-4 specify the amount of right rotation, in Figure 14-5 specify the degree of masking which will occur. Bits 8, 9 and 10 in Figure 14-5 specify the amount of right rotation which will occur.

8X300 assembly language mnemonics do not discriminate between this new use of bits 5, 6 and 7. You will still write assembly language instructions with the format:

LABEL OP S, N, D

S now defines the right rotate while N defines the masking operation.

Now consider instructions which specify an IV byte as the data destination. **Figure 14-6 illustrates instructions where a General Purpose register is the instruction source; Figure 14-7 illustrates IV byte-to-IV byte operations.**



Figure 14-5. An 8X300 IV Byte-to-Register Instruction's Execution

**There are three instruction classes which include immediate data.**

**The XEC instruction,** identified by 100 in the three high-order object code bits, uses the 13 operand bits to compute a temporary program memory address out of which the next instruction object code will be fetched. When an XEC instruction is executed the Program Counter contents are not incremented.

The NZT instruction, specified by 101 in the three high-order object code bits, provides the 8X300 with its conditional logic.

The XMIT instruction, represented by 110 in the three high-order object code bits, provides the 8X300 with its immediate instructions.



Figure 14-6. An 8X300 Register-to-IV Byte Instruction's Execution



Figure 14-7. An 8X300 IV Byte-to-IV Byte Instruction's Execution

All three instructions, XEC, NZT and XMIT, use one of the two following instruction object code formats:

Format A:



Format B:



For all three instructions, XEC, NZT and XMIT, the Format A object code uses bits 8 through 12 to specify a General Purpose register, or the Auxiliary register.

The Format B instruction object code uses bits 5 through 12 to specify the currently selected left bank or right bank IV byte, where byte contents will be subject to a mask and a rotate, as illustrated in Figure 14-5.

**Let us take another look at how the XEC, NZT and XMIT instructions use the data generated by their operand bits.**

**The XEC instruction** allows you to stay at one object code, continuously re-executing this single object code, while it points to another object code which actually gets executed. The address of the object code which actually gets executed is computed in one of two ways:

- 1) For the Format A object code, the current five high-order Program Counter bits are concatenated with the 8-bit sum of the specified register contents, plus the immediate data:



- 2) With the second object code format, the 8 high-order current Program Counter bits are concatenated with the 5-bit sum of the immediate data, plus the rotated and masked IV byte data:



You may use XEC instructions in one of two ways:

- 1) You may create a branch table of Jump instructions: based on the contents of any General Purpose register or IV byte, you may jump to one of 256 locations using Format A instruction object code, or one of 32 locations using Format B instruction object code.
- 2) External logic may directly control the sequence in which instructions are executed. The XEC instruction is equivalent to a single instruction which requires 500 nanoseconds to execute: 250 nanoseconds to process the XEC instruction's object code and another 250 nanoseconds to execute the object code fetched in response to the XEC instruction. If you are using the Format B instruction, external logic can use the second 250 nanosecond time interval to load new data into the selected IV byte. Thus, external logic can indefinitely control instruction execution sequence within an 8X300 microcomputer system.

**The NZT instruction** uses the 13 operand bits to identify a data byte that will be tested for a zero or a nonzero value. Additional operand bits are used to identify a branch address. If the identified data has a nonzero value, then the branch address is used to generate an absolute paged jump.

The Format A NZT instruction object code tests the contents of a general purpose register; upon detecting a nonzero value, the eight immediate data bits are loaded into the eight low-order Program Counter bits — thus causing an absolute paged branch to occur within a 256-word program memory page. For zero general purpose register contents, the next sequential instruction is executed in the normal way.

The Format B NZT instruction tests the contents of a selected IV byte, subject to rotate and mask logic. Upon detecting a nonzero result, the five immediate data bits are loaded into the low-order five Program Counter bits thus causing an absolute, paged branch to occur within a 32-word program memory page. If a zero result is detected, program execution continues with the next sequential instruction.

Thus the NZT instruction allows you to base branch logic on the contents of the Overflow status, or on any bit field, in any general purpose register, auxiliary register or external addressable location. We cannot classify such a wide-ranging instruction as a single instruction; it would not conform with the definition of a single assembly language instruction as used by any other microcomputer described in this book.

**In the case of the XMIT instruction,** the immediate data gets loaded into the general purpose register specified by a Format A instruction, or the external IV byte specified by a Format B instruction. In the case of a Format B instruction, the immediate data is shifted and merged, as illustrated in Figure 14-7, before being output to the identified IV byte. Recall that the identified IV byte will be the byte most recently selected by a Move instruction that specifies Register 7 or F as the destination.

**The Jump instruction** is the only one which remains to be described; it is also the simplest to describe. When this instruction is executed, the 13 operand bits are loaded directly into the Program Counter; thus you perform a simple unconditional jump to any location in program memory.

**Observe that the 8X300 has no subroutine or interrupt handling logic.**

Subroutine logic can be created using the XEC instruction and an appropriate jump table, but this is rather clumsy. In most cases it will be simpler to do without subroutines.

The lack of interrupt logic is probably inconsequential. Given the fact that the 8X300 can execute instructions in 300 nanoseconds, polling on status will invariably be a satisfactory way of allowing external logic to control events within the 8X300 microcomputer system.

A very effective way of allowing external logic to control the 8X300 microcomputer system is to have the system continuously re-execute an ineffective instruction as the result of an XEC. For example, the XEC could point to an instruction which simply moves the contents of a General Purpose register back into itself. Using Format B for the XEC instruction, external logic could modify the contents of the selected external IV byte in order to force program execution to branch in one of 31 different directions.

## THE 8X300 BENCHMARK PROGRAM

The benchmark program we have been using throughout this book is particularly ill suited to the 8X300; in fact, it could well illustrate a benchmark program that a competitor would select in order to make the 8X300 look bad. This is because the 8X300 is not good at memory addressing. The 8X300 would never be used in an application that principally reads blocks of data into read/write memory, then moves blocks of data around read/write memory.

The 8X300 has no ability to address read/write memory; as we have already described earlier in this chapter, should you require the presence of read/write memory in an 8X300 system, you are going to have to create a memory Address Bus and Data Bus for the external read/write memory; IV bytes must be used to create these busses.

We will therefore change the benchmark program so that a sequence of data bytes entering via the left bank IV byte must immediately be output via a right bank IV byte. The first byte read will be interpreted as identifying the number of data bytes to follow. Now the benchmark will appear as follows:

|      |           |                                                                 |
|------|-----------|-----------------------------------------------------------------|
| XMIT | AUX,377   | LOAD 377 OCTAL INTO THE AUXILIARY REGISTER TO DECREMENT COUNTER |
| XMIT | 20,0,SRCE | SELECT SOURCE IV BYTE IN LEFT BANK                              |
| XMIT | 30,0,DST  | SELECT DESTINATION IV BYTE IN RIGHT BANK                        |
| MOVE | R1,0,SRCE | LOAD COUNTER INTO R1                                            |
| LOOP | MOVE      | SRCE,0,DST MOVE NEXT DATA BYTE                                  |
|      | ADD       | R1,0,R1 DECREMENT COUNTER                                       |
|      | NZT       | R1,LOOP                                                         |

The following symbols are used in Table 14-2:

|          |                                                                                                                                                                                                                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A        | Auxiliary register                                                                                                                                                                                                                                                                      |
| ADDR     | 13-bit address value                                                                                                                                                                                                                                                                    |
| DATA5    | 5-bit data unit                                                                                                                                                                                                                                                                         |
| DATA8    | 8-bit data unit                                                                                                                                                                                                                                                                         |
| DISP5    | 5-bit address value                                                                                                                                                                                                                                                                     |
| DISP8    | 8-bit address value                                                                                                                                                                                                                                                                     |
| IV1, IV2 | IV Byte                                                                                                                                                                                                                                                                                 |
| (L)      | Optional Field length for IV Byte                                                                                                                                                                                                                                                       |
| PC       | Program Counter                                                                                                                                                                                                                                                                         |
| (R)      | Optional rotate value for register                                                                                                                                                                                                                                                      |
| RX, RY   | Any General Purpose registers                                                                                                                                                                                                                                                           |
| x<y,z>   | Bits y through z of the specified value. For example, PC<7,0> is the low byte of the Program Counter.                                                                                                                                                                                   |
| [[ ]]    | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified. |
| Λ        | Logical AND                                                                                                                                                                                                                                                                             |
| ¬Λ       | Logical Exclusive-OR                                                                                                                                                                                                                                                                    |
| →        | Data is transferred in the direction of the arrow.                                                                                                                                                                                                                                      |

Under the heading of STATUS in Table 14-2, an X indicates OVF is modified in the course of the instructions execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

Table 14-2. 8X300 Instruction Set

| Type                   | Mnemonic | Operand(s)    | Bytes | Status | Operation Performed                                                                         |
|------------------------|----------|---------------|-------|--------|---------------------------------------------------------------------------------------------|
| I/O                    | MOVE     | IV1,(L),IV2   | 2     |        | [IV2]—[IV1]<br>Move data from IV Byte to IV Byte.<br>[RX]—[IV1]                             |
|                        | MOVE     | IV1,(L),RX    | 2     |        | Move data from IV Byte to register.<br>[IV1]—[RX]                                           |
|                        | MOVE     | RX,(L),IV1    | 2     |        | Move data from register to IV Byte.<br>[IV2]—[IV1]+[A]                                      |
|                        | ADD      | IV1,(L),IV2   | 2     | X      | Add IV Byte to Auxiliary register, store result in IV Byte.<br>[RX]—[IV1]+[A]               |
|                        | ADD      | IV1,(L),RX    | 2     | X      | Add IV Byte to Auxiliary register, store result in register.<br>[IV1]—[RX]+[A]              |
|                        | ADD      | RX,(L),IV1    | 2     | X      | Add register to Auxiliary register, store result in IV Byte.<br>[IV2]—[IV1] A [A]           |
|                        | AND      | IV1,(L),IV2   | 2     |        | AND IV Byte with Auxiliary register, store result in IV Byte.<br>[RX]—[IV1] A [A]           |
|                        | AND      | IV1,(L),RX    | 2     |        | AND IV Byte with Auxiliary register, store result in register.<br>[IV1]—[RX] A [A]          |
|                        | AND      | RX,(L),IV1    | 2     |        | AND register with Auxiliary register, store result in IV Byte.<br>[IV2]—[IV1] A [A]         |
|                        | XOR      | IV1,(L),IV2   | 2     |        | Exclusive-OR IV Byte with Auxiliary register, store result in IV Byte.<br>[RX]—[IV1] ^ [A]  |
|                        | XOR      | IV1,(L),RX    | 2     |        | Exclusive-OR IV Byte with Auxiliary register, store result in register.<br>[IV1]—[RX] ^ [A] |
|                        | XOR      | RX,(L),IV1    | 2     |        | Exclusive-OR register with Auxiliary register, store result in IV Byte.<br>[IV1]—DATA5      |
| REGISTER-REGISTER MOVE | XMIT     | DATA5,(L),IV1 | 2     |        | Transmit immediate to IV Byte.                                                              |
|                        | MOVE     | RX,(R),RY     | 2     |        | [RY]—[RX]<br>Move contents of one General Purpose register to another.                      |

Table 14-2. 8X300 Instruction Set (Continued).

| TYPE                      | MNEMONIC | OPERAND(S)    | BYTES | STATUS<br>OV | OPERATION PERFORMED                                                                                                                 |
|---------------------------|----------|---------------|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| REGISTER-REGISTER OPERATE | MOVE     | RX,(R),RX     | 2     |              | Rotate contents of a general purpose register and store result in the same register.                                                |
|                           | ADD      | RX,(R),RY     | 2     | X            | [RY]—[RX] + [A]<br>Add Register X to Auxiliary register, store result in Register Y.                                                |
|                           | AND      | RX,(R),RY     | 2     | X            | [RY]—[RX] $\wedge$ [A]<br>AND Register X with Auxiliary register, store result in Register Y.                                       |
|                           | XOR      | RX,(R),RY     | 2     | X            | [RY]—[RX] $\vee$ [A]<br>Exclusive-OR Register X with Auxiliary register, store result in Register Y.                                |
| REGISTER-IMMEDIATE        | XMIT     | DATA8,RX      | 2     |              | [RX]—DATA8<br>Load immediate to General Purpose register.                                                                           |
| BRANCH ON CONDITION       | NZT      | RX,DISP8      | 2     |              | If [RX] $\neq$ 0; [PC < 7,0>]—DISP8<br>Branch if register contents nonzero.                                                         |
|                           | NZT      | IV1,(L),DISP5 | 2     |              | If [IV1] $\neq$ 0; [PC < 4,0>]—DISP5<br>Branch if IV Byte is nonzero.                                                               |
| JUMP                      | JMP      | ADDR          | 2     |              | [PC]—ADDR<br>Unconditional jump.                                                                                                    |
|                           | XEC      | RX,DISP8      | 2     |              | Execute instruction at the following address:<br>[ADDR < 12,8>]—[PC < 12,8>]<br>[ADDR < 7,0>]—[RX] + DISP8.<br>Do not increment PC. |
|                           | XEC      | IV1,(L),DISP5 | 2     |              | Execute instruction at the following address:<br>[ADDR < 12,5>]—[PC < 12,5>]<br>[ADDR < 4,0>]—[IV1] + DISP5<br>Do not increment PC  |

The following symbols are used in Table 14-3.

- a one bit of immediate address.
- ddddd 5 bits choosing destination register or IV Byte.
- i one bit of immediate data
- !!! three bits specifying length of IV Byte field.
- rrr three bits specifying the number of rotates performed.
- sssss 5 bits choosing source register or IV Byte.

The sssss and dddddd fields are restricted in the following ways:

- If sssss or dddddd represents a register, it must be in the range 008 — 178
- If sssss or dddddd represents an IV Byte, it must be in the range of 208 — 378

Table 14-3. 8X300 Instruction Set Object Codes

| INSTRUCTION       | OBJECT CODE       | BYTES | MACHINE CYCLES |
|-------------------|-------------------|-------|----------------|
| ADD IV1,(L),IV2   | 001ssssslldddddd  | 2     | 1              |
| IV1,(L),RX        |                   |       |                |
| RX,(L),IV1        |                   |       |                |
| ADD RX,(R),RY     | 001ssssrrrdffff   | 2     | 1              |
| AND IV1,(L),V2    | 010ssssslldddddd  | 2     | 1              |
| IV1,(L),RX        |                   |       |                |
| RX,(L),IV1        |                   |       |                |
| AND RX,(R),RY     | 010ssssrrrdffff   | 2     | 1              |
| JMP ADDR          | 111aaaaaaaaaaaaaa | 2     | 1              |
| MOVE IV1,(L),V2   | 000ssssslldddddd  | 2     | 1              |
| IV1,(L),RX        |                   |       |                |
| RX,(L),IV1        |                   |       |                |
| MOVE RX,(R),RX    | 000ssssrrrrssss   | 2     | 1              |
| MOVE RX,(R),RY    | 000ssssrrrdffff   | 2     | 1              |
| NZT IV1,(L),DISP5 | 101ssssllaaaaaa   | 2     | 1              |
| NZT RX,DISP8      | 101ssssaaaaaaaa   | 2     | 1              |
| XEC IV1,(L),DISP  | 100ssssllaaaaaa   | 2     | 1              |
| XEC RX,DISP       | 100ssssaaaaaaaa   | 2     | 1              |
| XMIT DATA5,IV1    | 110dddddlliilli   | 2     | 1              |
| XMIT DATA8        | 110dddddlliilli   | 2     | 1              |
| XOR IV1,(L),V2    | 011ssssslldddddd  | 2     | 1              |
| IV1,(L),RX        |                   |       |                |
| RX,(L),IV1        |                   |       |                |
| XOR RX,(R),RY     | 011ssssrrrdffff   | 2     | 1              |



Figure 14-8. 8T32/3/5/6 Interface Vector Byte Signals and Pin Assignments

## THE 8T32, 8T33, 8T35, AND 8T36 INTERFACE VECTOR BYTE (IV BYTE)

This device serves as an I/O port and IVB Bus interface for all external logic communicating with the 8X300 Microcontroller.

The various Interface Vector Bytes are summarized in Table 14-4. This table identifies part differences.

Table 14-4. Interface Vector Byte Options

| Part Name | Data Input via UDO - UD7          | UD Pins Logic  | IV Byte Address Logic |
|-----------|-----------------------------------|----------------|-----------------------|
| 8T31      | Synchronous, when MCLK is high    | Tristate       | None                  |
| 8T32      | Synchronous, when MCLK is high    | Tristate       | Present               |
| 8T33      | Synchronous, when MCLK is high    | Open Collector | Present               |
| 8T35      | Asynchronous, independent of MCLK | Open Collector | Present               |
| 8T36      | Asynchronous, independent of MCLK | Tristate       | Present               |

The IV Byte is implemented using bipolar LSI technology and is packaged as a 24-pin DIP. It requires a single +5V power supply.

### 8T32/3/5/6 IV BYTE PINS AND SIGNALS

Figure 14-8 illustrates the pins and signals of the IV Byte. Figure 14-9 illustrates how an IV Byte will normally be used.

As described for Figure 14-3, we show signal numbers in Figure 14-8 first as given in Signetics literature, then in brackets as we would number these signals.

**IV0 - IV7** represent the pins via which the IV Byte communicates with the IVB Bus. These pins represent the IV Byte interface with the 8X300 microcomputer system.

**Pins UD0 - UD7** represent the 8-bit bus via which the IV Byte communicates with logic beyond the 8X300 microcomputer system. These pins may be tristate or open collector, as defined in Table 14-4.

**ME** is a master enable signal. This signal is connected to  $\overline{LB}$  or  $\overline{RB}$ , output by the 8X300 Microcontroller to distinguish between two banks of I/O ports with 256 I/O ports addressable in each bank. **ME** is just one contributor to device select logic; we will describe the whole IV Byte select process later.



Figure 14-9. 8T32/3/5/6 IV Byte Control Signals and Interfaces

**BIC** and **BOC** are signals which control data flow between the IV Byte and external logic, via the UD Bus. **BIC** and **BOC** must be input to the IV Byte by external logic. **MCLK**, output by the 8X300 Microcontroller, synchronizes actual data transfers. **BIC**, **BOC**, and **MCLK** combine to control events on the UD Bus as follows:

| BIC | BOC | MCLK |                                                                           |
|-----|-----|------|---------------------------------------------------------------------------|
| 1   | 0   | X    | IV Byte output data to external logic                                     |
| 0   | X   | 1    | External logic input data to IV Byte (synchronous parts)                  |
| 0   | X   | X    | External logic input data to IV Byte (asynchronous parts)                 |
| 0   | X   | 0    | Disable UD Bus for 8T31, 8T32, 8T33. Input data to IV Byte for 8T35, 8T36 |
| 1   | 1   | X    | No operation                                                              |

X signifies "don't care"; the signal may be low or high.

**SC and WC control the IVB Bus which connects all IVB bytes with the 8X300 Microcontroller.** Control signals **SC** and **WC** are automatically output by the 8X300 Interpreter. **BIC** contributes to IVB Bus logic in order to resolve access conflicts; external logic accessing the IV Byte via the UD Bus will have priority over an 8X300 Microcontroller access occurring via the IVB Bus. **MCLK** synchronizes data transfers occurring via the IVB Bus for synchronous and

asynchronous parts. IVB Bus control logic also requires ME to be low; observe that UD Bus logic ignores ME. Combining SC, WC, BIC, MCLK and ME, this is how IVB Bus interface logic responds to control signals:

| SC | WC | <u>BIC</u> | MCLK | <u>ME</u> |                                                         |
|----|----|------------|------|-----------|---------------------------------------------------------|
| X  | X  | X          | X    | 1         | IV Byte not selected; no operation.                     |
| 0  | 0  | X          | X    | 0         | IV Byte must place data contents on IVB Bus.            |
| 0  | 1  | 1          | 1    | 0         | IV Byte reads IVB Bus as data.                          |
| 1  | 0  | X          | 1    | 0         | IV Byte reads IVB Bus as a select address. (not 8T31).  |
| 1  | 1  | 0          | 1    | 0         | IV Byte reads IVB Bus as a select address, and as data. |
| 1  | 1  | 1          | 1    | 0         | 8T31 reads IVB Bus as data only.                        |

**Data is inverted when it flows across an IV Byte.** If data is input by external logic via UDO - UD7, then the complement of this data will be read by the 8X300 on IVB0 - IVB7. Conversely, if the 8X300 outputs data via IVB0 - IVB7, then external logic will read the complement of this data via UDO - UD7.

If the 8X300 Microcontroller reads back data which it wrote out, then it reads back the exact data it wrote out, and not the complement of the data it wrote out. Conversely, if external logic reads back the data it wrote out, then it too will read back the exact data it wrote out, and not the complement of the data it wrote out.

## 8T32/3/5/6 IV BYTE OPERATION

**There is no device address logic on the external logic interface of any IV Byte. The IV Byte inputs and outputs data via the UDO - UD7 lines depending on the condition of the BIC and BOC signals.** Synchronous IV Bytes, as identified in Table 14-4, will input data via UDO - UD7 only while MCLK is high. Asynchronous IV Bytes ignore MCLK when receiving data input from external logic. All data output via UDO - UD7 is asynchronous.

**On the Microcontroller interface of an IV Byte, all devices (with the exception of the 8T31) have address logic and select logic.** The 8T31 will always respond on the Microcontroller interface if the SC, WC, ME, BIC, and MCLK signals are at the correct levels.

**All IV Bytes (with the exception of the 8T31) have an internal Address register.** The contents of this internal Address register are usually created when the IV Byte is manufactured. You can buy an IV Byte whose internal address has not been set, in which case you may set the address following a procedure described later.

The Microcontroller must output select addresses to select IV Bytes. Any IV Byte that detects a select address coinciding with its internal address will consider itself selected. It will remain selected until a new select address that does not coincide with its internal address is detected. Once an IV Byte has been selected, it will respond to data input or output operations specified by control signals on the Interpreter interface. An IV Byte which is not selected will not respond to input or output operations specified by control signals on the Interpreter interface. Select logic has no effect on the external logic interface of the IV Byte.

Address and select logic does not exist in the 8T31 IV Byte, which will therefore always respond to control signal levels on the Interpreter interface.

**Let us now look at dialogue occurring between an IV Byte and the 8X300 Interpreter via the IVB Bus.** Note carefully that the following discussion applies only to the IV Byte-8X300 interface. The IV Byte-external logic interface is controlled entirely by external logic manipulating the BIC and BOC control signals.

**8T32/3/5/6  
IV BYTE  
ACCESS  
LOGIC**

At any time, just one IV Byte should consider itself selected on the left bank of IV Bytes, and just one IV Byte should consider itself selected on the right bank of IV Bytes. In order to select an IV Byte, you execute a Move instruction which outputs data to Register 7 for the left bank, or F for the right bank. There is no Register 7 or F; in response to either of these Move instruction destination definitions, the 8X300 outputs data on the IVB Bus, just as it would for any normal data output operation, but control signals SC and WC are set to 1 and 0, respectively. A destination Register of 7 causes LB to be output low, while the destination address F causes RB to be output low. Thus, the net effect of executing a Move instruction specifying Register 7 or F as the destination is that the data moved is the address of the IV Byte which is going to consider itself selected; all other IV Bytes will at this time deselect themselves. If no IV Byte has a select address equal to the address output, then all IV Bytes will be deselected.

Once an IV Byte selects itself, it will remain selected until a subsequent Move to Register 7 or F causes a new Byte to select itself.

Remember, the 8T31 has no select logic; it always considers itself selected.

All 8X300 instructions that specify the IVB Bus as the source or destination of data will automatically access the single selected IV Byte — on the left or right bank of IV Bytes, whichever is being accessed by the Move instruction. Table 14-1 describes the way in which you specify whether the IV Byte selected on the left bank or right bank will be accessed.

Observe that external logic will always have priority over the 8X300, should both simultaneously attempt to output data to an IV Byte. BIC will be input low by external logic whenever it is attempting to write to the IV Byte; but BIC low inhibits any attempt by the 8X300 Microcontroller to write data into the IV Byte.

When inputting data from external logic using a synchronous IV Byte, you will have no timing problems. Data will be input only while MCLK is high, at which time the 8X300 is guaranteed not to be accessing the IV Byte.

When using asynchronous IV Bytes, data will be input by external logic to the IV Byte at any time. Unless you provide your own logic to guard against it, there is nothing to prevent external logic from inputting data to an asynchronous IV Byte while the 8X300 is partway through accessing the same IV Byte, in which case the 8X300 operation will be inaccurate.

## 8T32/3/5/6 IV BYTE ADDRESSES

**IV Bytes can be bought from Signetics with predefined addresses 01 through 0A16. IV Bytes with addresses 0B16 through 3216 are held in smaller quantities. You can, if you wish, buy an IV Byte whose address has not been set.** This IV Byte will, in fact, have an address of FF16. You must create the address you want by resetting individual address bits to 0. This is an operation you can do just once. Once an address bit has been reset to 0, it cannot be set to 1 again. **The following procedure is described by Signetics for resetting individual address bits to 0:**

Table 14-5. Specifications for Signals Illustrated in Figures 14-10 and 14-11.

| PARAMETER        | TEST CONDITIONS                                                                                              | LIMITS                  |           |              | UNITS          |
|------------------|--------------------------------------------------------------------------------------------------------------|-------------------------|-----------|--------------|----------------|
|                  |                                                                                                              | Min                     | Typ       | Max          |                |
| V <sub>CCP</sub> | Programming supply voltage<br>Address<br>Protect                                                             | 7.5                     | 0         | 8.0          | V              |
| I <sub>CCP</sub> | Programming supply current<br>Max time V <sub>CCP</sub> > 5.25V<br>Programming voltage<br>Address<br>Protect | V <sub>CCP</sub> = 8.0V |           | 250<br>1.0   | mA<br>s        |
|                  | Programming current<br>Address<br>Protect                                                                    | 17.5<br>13.5            |           | 18.0<br>14.0 | V<br>V         |
|                  | Programming pulse rise time<br>Address<br>Protect                                                            |                         | 75<br>150 |              | mA<br>mA       |
|                  | Programming pulse width                                                                                      | 1<br>100<br>5           |           | 1<br>1       | μs<br>μs<br>ms |



Figure 14-10. 8T32/3/5/6 IV Byte Address Programming Pulse



Figure 14-11. 8T32/3/5/6 IV Byte Protect Programming Pulse

- 1) Set all control signals to their inactive state.  $\overline{BIC}$ ,  $\overline{BOC}$ , and  $\overline{ME}$  must be tied to power while  $SC$ ,  $WC$ , and  $MCLK$  are held at ground. Leave all IVB Bus pins open.
- 2) Increase  $V_{CC}$  to  $7.75V \pm 0.25V$ .
- 3) After  $V_{CC}$  has stabilized, apply a single programming pulse at the UB Bus line corresponding to the bit which must be reset to 0. Figure 14-10 provides timing for the Address Programming pulse. The current should be limited to 75mA.
- 4) If the entire programming operation occurs in less than one second, return  $V_{CC}$  to  $7.75V$ . If the programming operation takes more than one second,  $V_{CC}$  must now be reduced to 0V.
- 5) Repeat Steps 3 and 4 for each additional UD line whose corresponding address bit must be reset to zero.
- 6) Verify that the proper address exists by inserting this address via the IVB Bus, with  $\overline{ME}$  and  $WC$  low, while  $SC$  and  $MCLK$  are high. Next, input data via the IVB Bus and read it via the UD Bus. If the correct address exists within the IV-Byte, the inverted data will appear at the UD Bus.
- 7) If the address is correct, proceed to Step 8. If the address is incorrect, you may be able to save the IV Byte by hunting for the actual address using trial and error. If the actual address has one or more bits high which should be low, then you can repeat Steps 2 and 3 in an attempt to pull these bits low. If an incorrect bit has been pulled low, then you must either modify the address that you were seeking to create, or you must throw away the IV Byte.
- 8) Set  $V_{CC}$  and all control inputs to 0 volts. Leave IVB and UD Bus line pins open.
- 9) Apply a protect programming pulse as illustrated in Figure 14-11 to every UD Bus pin. This includes UD Bus pins which were accessed during Steps 2 and 3, as well as UD Bus pins which were not accessed during Steps 2 and 3. The current should be limited to 150mA.
- 10) Apply  $+7V$  to each UD Bus pin and measure the amperage. It must be less than 1mA. If it is more than 1mA, then the particular line has been damaged and the IV Byte should be discarded.

Table 14-5 provides specifications for the pulses illustrated in Figures 14-10 and 14-11.



Figure 14-12. 8T39 and 8T58 Bus Expander Signals and Pin Assignments

## THE 8T39 AND 8T58 BUS EXPANDERS

These two devices buffer the IVB Bus and control signals output by the 8X300 Microcontroller. Up to 16 IV Bytes may be connected to one Bus Expander, which will present a load equivalent to one IV Byte on the 8X300 Bus. The 8T39 Bus Expander contains internal address and select logic, while the 8T58 Bus Expander does not.

The two Bus Expander parts are implemented using bipolar LSI technology and are packaged in 28-pin DIPs. These parts require a +5V power supply.

Figure 14-12 identifies the pins and signals of the two Bus Expander parts. These signals are not described, since they are identical to the signals with the same names as already described for the Microcontroller and IV Bytes. Notice that the signals are input on one side of the Bus Expander and output on the other side of the Bus Expander. The input signals will connect to the 8X300 Microcontroller, while the output signals will generate a bus to which up to 16 IV Bytes may be connected.

A 15 nanosecond propagation delay will occur across each Bus Expander for signals input and then output. You must make sure that you add this delay time when computing the total access time for external logic responding to an 8X300 Microcontroller access.

The 8T39 Bus Expander has internal addressing and select logic. The 8T58 Bus Expander has no internal addressing or select logic. For the 8T39 only, the four high-order address lines are examined when the 8X300 outputs an IV Byte address. The actual response of the 8T39 to addresses is identical to that which we have described for IV Bytes. The 16 IV Bytes connected to an 8T39 Bus Expander must have addresses corresponding to the fixed four high-order address bits specified by the Bus Expander.

There are four address options available to you when buying an 8T39 Bus Expander. These four address options, and the allowed IV Byte addresses that may be connected to each option, are identified in Table 14-6.

Table 14-6. 8T39 Bus Expander Addresses and IV Byte Addresses That May Be Connected

| Part Number | 8T39 Internal Address | IV Byte addresses that may be connected                                                                                                       |
|-------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 8T39-00     | 0000XXXX              | 00-0F <sub>16</sub>                                                                                                                           |
| 8T39-01     | 0001XXXX              | 1016-1F <sub>16</sub> , 2016-2F <sub>16</sub> , 4016-4F <sub>16</sub> , 8016-8F <sub>16</sub>                                                 |
| 8T39-03     | 0011XXXX              | 3016-3F <sub>16</sub> , 5016-5F <sub>16</sub> , 6016-6F <sub>16</sub> , 9016-9F <sub>16</sub> , A016-AF <sub>16</sub> , C016-CF <sub>16</sub> |
| 8T39-07     | 0111XXXX              | 7016-7F <sub>16</sub> , B016-BF <sub>16</sub> , D016-DF <sub>16</sub> , E016-EF <sub>16</sub>                                                 |
| 8T39-17     | 1111XXXX              | F016-FF <sub>16</sub>                                                                                                                         |

## **DATA SHEETS**

The following section contains specific electrical and timing data for the following devices:

- 8X300 Interpreter
- 8T32 IV Byte
- 8T39 Bus Expander

## 8X300 INTERPRETER

### DC ELECTRICAL CHARACTERISTICS

| PARAMETER | TEST CONDITIONS                                                                | LIMITS                                                                                                                                               |               |                               | UNIT                                     |
|-----------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------------------|------------------------------------------|
|           |                                                                                | Min                                                                                                                                                  | Typ           | Max                           |                                          |
| $V_{IH}$  | High level input voltage<br>X1,X2<br>All others                                |                                                                                                                                                      | .6<br>2       |                               | V<br>V                                   |
| $V_{IL}$  | Low level input voltage<br>X1,X2<br>All others                                 |                                                                                                                                                      |               | .4<br>.8                      | V<br>V                                   |
| $V_{CL}$  | Input clamp voltage<br>(Note 1)                                                | $V_{CC} = 4.75V$<br>$I_I = -10mA$                                                                                                                    |               | -1.5                          | V                                        |
| $I_{IH}$  | High level input current<br>X1,X2<br>All others                                | $V_{CC} = 5.25V$<br>$V_{IH} = .6V$<br>$V_{CC} = 5.25V$<br>$V_{IH} = 4.5V$                                                                            | 2700          | <1<br>50                      | $\mu A$<br>$\mu A$                       |
| $I_{IL}$  | Low level input current<br>X1,X2<br>$IVBO-7$<br>$IO-I15$<br><u>HALT, RESET</u> | $V_{CC} = 5.25V$<br>$V_{IL} = .4V$<br>$V_{CC} = 5.25V$<br>$V_{IL} = .4V$<br>$V_{CC} = 5.25V$<br>$V_{IL} = .4V$<br>$V_{CC} = 5.25V$<br>$V_{IL} = .4V$ | -2500<br>-140 | -200<br>-1600<br>-230<br>-400 | $\mu A$<br>$\mu A$<br>$\mu A$<br>$\mu A$ |
| $V_{OL}$  | Low level output voltage<br>A0-A12<br>All others                               | $V_{CC} = 4.75V$<br>$I_{OL} = 4.25mA$<br>$V_{CC} = 4.75V$<br>$I_{OL} = 16mA$                                                                         | .35           | .55                           | V                                        |
| $V_{OH}$  | High level output voltage                                                      | $V_{CC} = 4.75V$<br>$I_{OH} = 3mA$                                                                                                                   | 2.4           |                               | V                                        |
| $I_{OS}$  | Short circuit output current<br>(Note 2)                                       | $V_{CC} = 5.25V$                                                                                                                                     | -30           | -140                          | mA                                       |
| $V_{CC}$  | Supply voltage                                                                 |                                                                                                                                                      | 4.75          | 5                             | 5.25                                     |
| $I_{CC}$  | Supply current                                                                 | $V_{CC} = 5.25V$                                                                                                                                     | 300           | 450                           | mA                                       |
| $I_{REG}$ | Regulator control                                                              | $V_{CC} = 5.0V$                                                                                                                                      | -14           | -21                           | mA                                       |
| $I_{CR}$  | Regulator current (Note 3)                                                     | $V_{CR} = 0$                                                                                                                                         |               | 290                           | mA                                       |
| $V_{CR}$  | Regulator voltage (Note 3)                                                     | $V_{REG} = 0V$                                                                                                                                       | 2.2           | 3.2                           | V                                        |

#### NOTES

1. Crystal inputs X1 and X2 do not have clamp diodes.
2. Only one output may be grounded at a time.
3. (Limits apply for  $V_{CC} = 5V \pm 5\%$  and  $0^\circ C < T_A < 70^\circ C$  unless specified otherwise.)

**Signetics**

Data sheets on pages 14-D2 through 14-D12 reprinted by permission of Signetics Corporation. Copyright © 1977 by Signetics Corporation, 811 East Arques Avenue, Sunnyvale, California.

## 8X300 INTERPRETER



Figure 10

## ABSOLUTE MAXIMUM RATINGS

|                                |            |
|--------------------------------|------------|
| Supply Voltage V <sub>CC</sub> | ..... 7V   |
| Logic Input Voltage            | ..... 5.5V |
| Crystal Input Voltage          | ..... 2V   |

AC ELECTRICAL CHARACTERISTICS  $V_{CC} = 5V \pm 5\%$  and  $0^\circ C \leq T_A < 70^\circ C$ 

| DELAY DESCRIPTION                                              | PROPAGATION DELAY TIME | CYCLE TIME LIMIT           |
|----------------------------------------------------------------|------------------------|----------------------------|
| X1 falling edge to MCLK (driven from external pulse generator) | 75ns                   |                            |
| MCLK to SC/WC falling edge (input phase)                       | 25ns                   |                            |
| MCLK to SC/WC rising edge (output phase)                       |                        | $\frac{1}{2}$ cycle + 25ns |
| MCLK to LB/RB (input phase)                                    | 35ns                   |                            |
| Instruction to LB/RB output (input phase)                      | 35ns                   |                            |
| MCLK to LB/RB (output phase)                                   |                        | $\frac{1}{4}$ cycle + 35ns |
| MCLK to IV data (output phase)                                 | 185ns                  | $\frac{1}{2}$ cycle + 60ns |
| IV data (input phase) to IV data (output phase)                | 115ns                  |                            |
| Instruction to Address                                         | 185ns                  | $\frac{1}{2}$ cycle + 40ns |
| MCLK to Address                                                | 185ns                  | $\frac{1}{2}$ cycle + 40ns |
| IV data (input phase) to Address                               | 115ns                  |                            |
| MCLK to IV data (input phase)                                  |                        | $\frac{1}{2}$ cycle - 55ns |
| MCLK to Halt falling edge to prevent current cycle             |                        | $\frac{1}{4}$ cycle - 40ns |
| Reset rising edge to first MCLK                                |                        | 0 to 1 cycle               |

## NOTE

1. Reference to MCLK is to the falling edge when loaded with 300pF.
2. Loading on Address lines is 150pF.

signetics

## 8X300 INTERPRETER



**signetics**

# 8T32/8T33/8T35/8T36

**DC ELECTRICAL CHARACTERISTICS**  $V_{CC} = 5V \pm 5\%$ ,  $0^\circ C \leq T_A \leq 70^\circ C$  unless otherwise specified

| PARAMETER | TEST CONDITIONS                              | LIMITS                               |             |      | UNIT    |
|-----------|----------------------------------------------|--------------------------------------|-------------|------|---------|
|           |                                              | Min                                  | Typ         | Max  |         |
| $V_{IH}$  | Input voltage<br>High                        |                                      |             |      | V       |
| $V_{IL}$  | Low                                          | 2.0                                  |             | .8   |         |
| $V_{IC}$  | Clamp                                        |                                      |             | -1   |         |
| $V_{OH}$  | Output voltage<br>High                       | $I_I = -5mA$<br>$V_{CC} = 4.75V$     |             |      | V       |
| $V_{OL}$  | Low                                          | 2.4                                  |             | .55  |         |
| $I_{IH}$  | Input current <sup>3</sup><br>High           | $V_{CC} = 5.25V$<br>$V_{IH} = 5.25V$ |             | 100  | $\mu A$ |
| $I_{IL}$  | Low                                          | $V_{IL} = .5V$                       | <10<br>-350 | -550 |         |
| $I_{OS}$  | Output current <sup>4</sup><br>Short circuit | $V_{CC} = 4.75V$                     | 10<br>20    |      | mA      |
|           | UD bus                                       |                                      |             |      |         |
|           | IV bus                                       |                                      |             |      |         |
| $I_{CC}$  | $V_{CC}$ supply current                      | $V_{CC} = 5.25V$                     | 100         | 150  | mA      |

## PROGRAMMING SPECIFICATIONS<sup>5</sup>

| PARAMETER | TEST CONDITIONS                                          | LIMITS           |     |                     | UNITS              |
|-----------|----------------------------------------------------------|------------------|-----|---------------------|--------------------|
|           |                                                          | Min              | Typ | Max                 |                    |
| $V_{CCP}$ | Programming supply voltage<br>Address<br>Protect         | 7.5              | 0   | 8.0                 | V                  |
| $I_{CCP}$ | Programming supply current<br>Max time $V_{CCP} > 5.25V$ | $V_{CCP} = 8.0V$ |     | 250                 | $mA$               |
|           | Programming voltage<br>Address<br>Protect                | 17.5<br>13.5     |     | 1.0<br>18.0<br>14.0 | V<br>V             |
|           | Programming current<br>Address<br>Protect                |                  |     | 75<br>150           | $mA$<br>$mA$       |
|           | Programming pulse rise time<br>Address<br>Protect        | .1<br>100        |     | 1                   | $\mu s$<br>$\mu s$ |
|           | Programming pulse width                                  | .5               |     | 1                   | ms                 |

### NOTES

3. The input current includes the tri-state/open collector leakage current of the output driver on the data lines.
4. Only one output may be shorted at a time.
5. If all programming can be done in less than 1 second,  $V_{CC}$  may remain at 7.75V for the entire programming cycle.

**signetics**

**8T32/8T33/8T35/8T36**  
**8T32/8T33/8T35/8T36-NA,F**  
**AC ELECTRICAL CHARACTERISTICS**

| PARAMETER                         | INPUT                                 | TEST CONDITION      | LIMITS                           |                |                | UNIT |
|-----------------------------------|---------------------------------------|---------------------|----------------------------------|----------------|----------------|------|
|                                   |                                       |                     | Min                              | Typ            | Max            |      |
| $t_{PD}$ User data delay (Note 1) | UDX<br>MCLK*<br>BIC†                  | $C_L = 50\text{pF}$ |                                  | 25<br>45<br>40 | 38<br>61<br>55 | ns   |
| $t_{OE}$ User output enable       | BOC                                   | $C_L = 50\text{pF}$ | 18                               | 26             | 47             | ns   |
| $t_{OD}$ User output disable      | BIC<br>BOC                            | $C_L = 50\text{pF}$ | 18<br>16                         | 28<br>23       | 35<br>33       | ns   |
| $t_{PD}$ IV data delay (Note 1)   | IVBX<br>MCLK                          | $C_L = 50\text{pF}$ |                                  | 38<br>48       | 53<br>61       | ns   |
| $t_{OE}$ IV output enable         | ME<br>SC<br>WC                        | $C_L = 50\text{pF}$ | 14                               | 19             | 25             | ns   |
| $t_{OD}$ IV output disable        | ME<br>SC<br>WC                        | $C_L = 50\text{pF}$ | 13                               | 17             | 32             | ns   |
| $t_W$ Minimum pulse width         | MCLK<br>BIC†                          |                     | 40<br>35                         |                |                | ns   |
| $t_{SETUP}$ Minimum setup time    | UD□<br>BIC*<br>IVX<br>ME<br>SC<br>WC  | (Note 2)            | 15<br>25<br>55<br>30<br>30<br>30 |                |                | ns   |
| $t_{HOLD}$ Minimum hold time      | UDX□<br>BIC*<br>IVX<br>ME<br>SC<br>SC | (Note 2)            | 25<br>10<br>10<br>5<br>5<br>5    |                |                | ns   |

\* Applies for 8T32 and 8T33 only.

† Applies for 8T35 and 8T36 only.

□ Times are referenced to MCLK for 8T32 and 8T33, and are referenced to BIC for 8T35 and 8T36.

NOTES:

1. Data delays referenced to the clock are valid only if the input data is stable at the arrival of the clock and the hold time requirement is met.
2. Set up and hold times given are for "normal" operation. BIC setup and hold times are for a user write operation. SC setup and hold times are for an IV Byte select operation. WC setup and hold times are for an IV Bus write operation. ME setup and hold times are for both IV write and select operations.

**signetics**

**ABSOLUTE MAXIMUM RATINGS**

| PARAMETER | RATING                      | UNIT         |
|-----------|-----------------------------|--------------|
| $V_{CC}$  | Power supply voltage        | -0.5 to +7   |
| $V_{IN}$  | Input voltage               | -0.5 to +5.5 |
| $V_O$     | Off-state output voltage    | -0.5 to +5.5 |
| $T_A$     | Operating temperature range | -55 to +125  |
| $T_{stg}$ | Storage temperature range   | -65 to +150  |



**8T32/8T33/8T35/8T36  
8T32/8T33/8T35/8T36-NA, F**

**PARAMETER MEASUREMENT INFORMATION**

**LOAD CIRCUIT FOR OPEN COLLECTOR OUTPUTS**



**LOAD CIRCUIT FOR TRI-STATE OUTPUTS**



NOTE:  $C_L$  includes fixture capacitance.

**INPUT WAVEFORM**



**CLOCK PULSE WIDTH**



**DATA DELAY TIMES**  
Input Data Reference



**DATA DELAY TIMES**  
Clock Referenced



**8T32/8T33/8T35/8T36  
8T32/8T33/8T35/8T36-NA,F**

**PARAMETER MEASUREMENT INFORMATION (Cont'd)**



WAVEFORM #1 IS FOR AN OUTPUT WITH INTERNAL CONDITIONS SUCH THAT THE OUTPUT IS LOW WHEN THE TRISTATE DRIVER IS ENABLED. WAVEFORM #2 IS FOR THE OPPOSITE CONDITION.

# 8T39 BUS EXPANDER

## TEST LOAD CIRCUIT



### DC ELECTRICAL CHARACTERISTICS $V_{CC} = 5V \pm 5\%$ , $0^\circ C \leq T_A \leq 70^\circ C$

| PARAMETER                                                              | TEST CONDITIONS                                          | LIMITS |      |             | UNIT     |
|------------------------------------------------------------------------|----------------------------------------------------------|--------|------|-------------|----------|
|                                                                        |                                                          | Min    | Typ  | Max         |          |
| $V_{IL}$<br>Low<br>$V_{IH}$<br>High<br>$V_{IC}$<br>Clamp               |                                                          | 2.0    |      | .8<br>-1    | V        |
| $V_{OL}$<br>$V_{OH}$<br>Output voltage<br>Low<br>High                  | $V_{CC} = 4.75V$<br>$I_{OL} = 16mA$<br>$I_{OH} = -3.2mA$ | 2.4    |      | .55         | V        |
| $I_{IL}$<br>$I_{IH}$<br>Input current<br>Low<br>High                   | $V_{CC} = 5.25V$<br>$V_{IL} = .5V$<br>$V_{IH} = 5.25V$   |        | < 10 | -250<br>100 | uA       |
| $I_{OS}$<br>$I_{CC}$<br>Short circuit output current<br>Supply current | $V_{CC} = 4.75V$<br>$V_{CC} = 5.25V$                     | -40    |      | 200         | mA<br>mA |

### AC ELECTRICAL CHARACTERISTICS $V_{CC} = 5V \pm 5\%$ , $0^\circ C \leq T_A \leq 70^\circ C$ , $C_L = 300pF$

| PARAMETER           | TO                                                          | FROM                                         | TEST CONDITIONS | LIMITS |     |     | UNIT |
|---------------------|-------------------------------------------------------------|----------------------------------------------|-----------------|--------|-----|-----|------|
|                     |                                                             |                                              |                 | Min    | Typ | Max |      |
| $t_{pd}$<br>Data    | DOX<br>DIX                                                  | DIX<br>DOX                                   |                 |        |     | 15  | ns   |
| $t_{pd}$<br>Control | $\overline{ME}$ (out)<br>MCLK (out)<br>SC (out)<br>WC (out) | $ME$ (in)<br>MCLK (in)<br>SC (in)<br>WC (in) |                 |        |     | 15  |      |

Signetics

## 8T39BUS EXPANDER VOLTAGE WAVEFORMS



## 8T58 TRANSPARENT BUS EXPANDER

### ABSOLUTE MAXIMUM RATINGS

| PARAMETER                                  | RATING      | UNIT |
|--------------------------------------------|-------------|------|
| V <sub>CC</sub> Power supply voltage       | +7          | Vdc  |
| V <sub>IN</sub> Input voltage              | +5.5        | Vdc  |
| V <sub>O</sub> Off-state output voltage    | +5.5        | Vdc  |
| T <sub>A</sub> Operating temperature range | 0 to +70    | °C   |
| T <sub>STG</sub> Storage temperature range | -65 to +150 | °C   |

NOTE Includes tri-state leakage.

### AC ELECTRICAL CHARACTERISTICS $V_{CC} = 5V \pm 5\%$ , $0^\circ C \leq T_A \leq 70^\circ C$ , $C_L = 300pF$

| PARAMETER                           | TO                                           | FROM                                    | TEST CONDITIONS | LIMITS |     |     | UNIT |
|-------------------------------------|----------------------------------------------|-----------------------------------------|-----------------|--------|-----|-----|------|
|                                     |                                              |                                         |                 | Min    | Typ | Max |      |
| t <sub>pd</sub> Path delay Data     | DOX<br>DIX                                   | DIX<br>DOX                              |                 |        |     | 15  | ns   |
| t <sub>pd</sub> Control             | M̄E(OUT)<br>MCLK(OUT)<br>SCI(OUT)<br>WC(OUT) | M̄E(IN)<br>MCLK(IN)<br>SC(IN)<br>WC(IN) |                 |        |     | 15  | ns   |
| t <sub>oe</sub> Data Output Enable  | DIX<br>DOX                                   | M̄E(IN)<br>SC(IN)<br>WC(IN)             |                 | 28     |     | 56  | ns   |
| t <sub>od</sub> Data Output Disable | DIX<br>DOX                                   | M̄E(IN)<br>SC(IN)<br>WC(IN)             |                 | 15     |     |     |      |

**Signetics**

## 8T58 TRANSPARENT BUS EXPANDER

| PARAMETER                                             | TEST CONDITIONS                                        | LIMITS                                                                        |     |                    | UNIT     |
|-------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------|-----|--------------------|----------|
|                                                       |                                                        | Min                                                                           | Typ | Max                |          |
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IC</sub> | Input voltage<br>Low<br>High<br>Clamp                  | -5mA at V <sub>CC</sub> min                                                   | 2.0 | .8<br>-1           | V        |
| V <sub>OL</sub><br>V <sub>OH</sub>                    | Output voltage<br>Low<br>High                          | V <sub>CC</sub> = 4.75V<br>I <sub>OL</sub> = 50mA<br>I <sub>OH</sub> = -3.2mA | 2.4 | .55                | V        |
| I <sub>IL</sub><br>I <sub>IH</sub>                    | Input current<br>Low <sup>1</sup><br>High <sup>1</sup> | V <sub>CC</sub> = 5.25V<br>V <sub>IL</sub> = .5V<br>V <sub>IH</sub> = 5.25V   |     | <10<br>-250<br>100 | μA       |
| I <sub>OS</sub><br>I <sub>CC</sub>                    | Short circuit output current<br>Supply current         | V <sub>CC</sub> = 4.75V<br>V <sub>CC</sub> = 5.25V                            | -40 | 200                | mA<br>mA |

### VOLTAGE WAVEFORMS



### TEST LOAD CIRCUIT



### TYPICAL APPLICATION



**Signetics**

# Chapter 15

## THE NATIONAL SEMICONDUCTOR PACE AND INS8900

PACE was developed by National Semiconductor as a single-chip implementation of the multi-chip IMP-16. Since it was the first 16-bit, single-chip microprocessor, PACE is the first 16-bit microprocessor described in this book.

As might be expected of an early entry product, PACE had a number of problems — both in design and fabrication technology — which limited its acceptance. Therefore the INS8900 was recently introduced by National Semiconductor. The INS8900 is a redesigned, NMOS PACE, with internal logic problems resolved.

In this chapter we will describe both PACE and the INS8900. Specifically, we will identify the problems faced by a PACE user, which have been eliminated in the INS8900.

PACE and the INS8900 are 16-bit microprocessors because they handle data in 16-bit units. In many ways, however, the internal architecture of PACE and the INS8900 have an 8-bit orientation; this is something you should keep in mind while reading this chapter, because it does result in PACE and the INS8900 having program execution speeds that are comparable to, rather than being significantly faster than, the 8-bit microprocessors we have described in earlier chapters.

The only current manufacturer for PACE and the INS8900 is:

NATIONAL SEMICONDUCTOR, INC.  
2900 Semiconductor Drive  
Santa Clara, CA 95050

There are agreements between Rockwell International and National Semiconductor and between Signetics and National Semiconductor to exchange microcomputer technical information and to produce each other's products. At the present time, neither Signetics nor Rockwell International has elected to second source PACE or the INS8900.

As shown in Figure 15-1, a typical PACE microcomputer will consist of a mixture of special-purpose PACE support devices and standard devices. The PACE microcomputer devices described in this chapter consist of:

- The PACE CPU
- The System Timing Element (STE), which generates clock signals for PACE and the system.
- The Bidirectional Transceiver Element (BTE), which converts the MOS-level PACE signals to TTL-level signals for other devices. The BTE is 8 bits wide.

The Microprocessor Interface Latch Element (MILE), which provides an 8-bit, bidirectional latched interface between the PACE System Bus and external devices, is described in Volume 3.

The INS8900 needs a clock generator; a 2 MHz crystal and a 74C04 inverter are recommended. Otherwise, there are no special INS8900 support devices; in fact, **you can easily use any NMOS support devices described in Volume 3 with the INS8900.** Specifically, the STE and BTE devices cannot be used with the INS8900, because they provide MOS-to-TTL signal level conversions for PACE. The MILE can be used with either PACE or the INS8900.

PACE requires +5V, +8V and -12V power supplies. The +8V is a substrate voltage requirement of the CPU and can be derived from the +5V power using a few discrete components. Therefore, a system can be implemented using only two primary power supplies: +5V and -12V. The INS8900 also uses three power supplies: +12V, +5V and -8V.

|                              |
|------------------------------|
| PAGE/INS8900<br>POWER SUPPLY |
| EXECUTION<br>SPEED           |

The INS8900 uses a 500 nanosecond clock to provide typical instruction execution times in the range of 8 to 20 microseconds. **PACE (IPC-16A/520D) uses a 750 nanosecond clock to provide typical instruction execution times in the range of 12 to 30 microseconds.**

Before making direct comparisons of these instruction execution times with those of other devices, however, note carefully that because of the 16-bit architecture of PACE and the INS8900, it may take many instructions on another microcomputer to perform the same operations as a single INS8900/PACE instruction.

MOS level signals are input and output by PACE. TTL level signals are input and output by the INS8900.

PAGE/INS8900  
LOGIC LEVEL

P-channel silicon gate. MOS/LSI technology is used with PACE. N-channel MOS technology is used by the INS8900.

## PAGE AND INS8900 MICROCOMPUTER SYSTEM OVERVIEWS

Figure 15-1 conceptually illustrates a PACE system. Figure 15-2 conceptually illustrates an INS8900 system. As with any mini- or microcomputer system, the CPU outputs data, address, and control signals. In the case of PACE and the INS8900, the data and address signals use the same bus lines; therefore, they are said to be multiplexed.

Timing signals needed by PACE are generated by the System Timing Element (STE). PACE signals are all MOS level; the STE therefore generates two sets of timing signals; one set are MOS level for PACE, the other set are TTL level for external logic.

SYSTEM TIMING  
ELEMENT (STE)  
BIDIRECTIONAL  
TRANSCEIVER  
ELEMENT (BTE)

Since PACE signals are MOS level, Bidirectional Transceiver Elements (BTEs) must be present to translate outgoing signals from MOS to TTL levels, and to translate incoming signals from TTL to MOS levels. BTEs are quite indiscriminating in the signals they translate; in either direction, any signal arriving at an input pin is faithfully reproduced at the corresponding output pin. Control signal options allow a BTE to operate bidirectionally, to drive output signals only, or to place both the MOS and TTL outputs in a high-impedance mode. Since the BTE is 8 bits wide, two BTEs operating bidirectionally provide buffering for the 16-bit Address/Data Bus. A third BTE, operating in the drive-only mode, provides buffering for the PACE control signals (NADS, ODS, IDS, and Flags).

A complete TTL level bus is created by combining BTE outputs with the TTL level timing signals output by the STE. Remember, though, that the 16 address/data lines are multiplexed.

TTL LEVEL  
PACE BUS

External logic that can demultiplex these lines and that can respond to the PACE timing and control signal logic can connect directly to the TTL level address/data lines. For example, National Semiconductor provides ROM and RAM devices with on-chip address latches; these devices can interface directly to the TTL level bus.

ADDRESS  
LATCHES  
AND  
DECODERS

If memory devices or I/O ports are used that cannot demultiplex the address/data lines, you must provide separate logic to perform this function. No special PACE family devices are available for this purpose; however, standard logic devices can be used. For example, two hex flip-flop devices and a quad flip-flop device would provide a latched 16-bit Address Bus. Two 8212 I/O ports could also be used to latch the 16 bits of address information. The PACE Address Data Strobe (NADS) signal can be used as the CLK input to the flip-flops or as the STB input to the 8212s. The PACE Address Data Strobe (NADS) signal can be used as the CLK input to the flip-flops. In many systems this is the most effective approach since a latched Address Bus allows you to use simpler address decoding techniques to generate memory chip enable and I/O port select signals.

Figure 15-2 illustrates an INS8900 microcomputer system. Logic is quite elementary — and equivalent to that which you would expect with any other microcomputer. Control Bus, Data Bus, and Address Bus lines are buffered using INS8208 bidirectional buffers. These are National Semiconductor standard catalog devices, recommended by National Semiconductor and illustrated in their literature; however, any other buffer would do equally well. The Data/Address Bus is shown being demultiplexed by 8212s to create separate Data and Address Busses. This again is straightforward logic.



Figure 15-1. A National Semiconductor PACE Microcomputer System



Figure 15-2. A National Semiconductor INS8900 Microcomputer System

### INS8900 PROGRAMMABLE REGISTERS

The INS8900 (and PACE) has four 16-bit Accumulators and a 16-bit Program Counter; these registers may be illustrated as follows:



Accumulator AC0 may be likened to a primary Accumulator as described for our hypothetical microcomputer in Volume 1.

Accumulator AC1 is a secondary Accumulator.

Accumulators AC2 and AC3 are equivalent to a combination of secondary Accumulators and Index registers.

Recall from Volume 1, Chapter 6 that an Index register differs from a Data Counter in that the Index register contents are added to a displacement (which is provided by a memory reference instruction) in order to determine the effective memory address.

The Program Counter serves the same function in an INS8900 system as it does in our hypothetical microcomputer described in Volume 1.

Figure 15-3 illustrates that part of our general microcomputer system logic which has been implemented in the INS8900 microprocessor.



Figure 15-3. Logic of the INS8900 Microprocessor

## INS8900 STACK

**A Stack is provided on the INS8900 (and PACE) chip. The Stack is 16 bits wide and 10 words deep.** The Stack is not a cascade stack, as described in Volume 1, Chapter 6; rather, chip logic maintains its own Stack Pointer to identify the next free Stack word. The Stack Pointer is automatically incremented and decremented in response to Push and Pull operations. Stack Push and Pull operations are initiated by CPU logic during execution of Jump-to-Subroutine (JSR) and Return-from-Subroutine (RTS) instructions, and during interrupt processing, to automatically save and restore the Program Counter.

In addition, the Stack can be used for temporary storage of data or status information. There are instructions which allow you to transfer words between the Stack and any Accumulator, or the Status and Control Flag register. This capability can significantly reduce the number of memory accesses required (thus increasing system speed) and can also reduce read/write memory requirements since intermediate values can be stored on the Stack.

Whenever the Stack becomes completely filled or emptied, an Interrupt Request is generated on the INS8900 chip. If you have enabled Stack Interrupts, program execution will be suspended, allowing you to deal with the situation. A Stack Full condition will indicate that it is time to dump data accumulated on the Stack out to read/write memory.

**INS8900 AND  
PACE STACK  
INTERRUPTS**

## INS8900 AND PACE ADDRESSING MODES

Most INS8900 (and PACE) memory reference instructions use either direct or direct, indexed addressing. A few instructions also offer indirect addressing and pre-indexed, indirect addressing. Refer to Volume 1, Chapter 6 for a description of these addressing modes.

All memory reference instructions have the following object code format:



The 2-bit XR field lets you specify with each instruction the type of direct addressing you want used: base page, program relative or indexed (AC2- or AC3-relative). Since the address displacement is an 8-bit field in the instruction word, direct addresses are paged and each page consists of 256 words. Indexed and paged addressing variations have been described in Volume 1, Chapter 6.

In addition, the INS8900 (and PACE) offers a variation of base page addressing, which is not described in Volume 1, Chapter 6. There is a control input signal (BPS) which allows the base page to be split between the top and bottom 128 words of memory, as follows:

**INS8900 AND  
PACE SPLIT  
BASE PAGE**



BPS high splits the base page; BPS low keeps the base page as the bottom 256 words of memory.

Depending on how an INS8900 system has been configured, the base page may be permanently defined as split or as normal; or the base page may be varied between the two options under program control. There are a number of output control flags (which are described next) that may be set or reset under program control. If one of these flags is connected to the base page select pin, then setting or resetting this flag determines which base page option will be in effect:



Splitting the base page between the top and bottom of memory is useful in an INS8900 microcomputer system because it simplifies external device addressing. If we reserve all memory addresses in the range FF80<sub>16</sub> - FFFF<sub>16</sub> for external devices, then external logic merely has to AND the top nine bits of an address and thus determine if an external device (rather than a memory location) is being addressed:



Splitting the base page also makes it easy to implement half of the base page in ROM, leaving the other half in RAM.

To a programmer, this scheme provides an easy way of generating 128 external device addresses. If the split base page option is in effect, then base page, direct addressing can be interpreted as external device addressing, so long as the high-order bit of the displacement is 1:

**INS8900/PACE  
SPLIT BASE  
PAGE TO  
ADDRESS I/O**



The base page and program relative options do not apply when the displacement is part of a direct indexed address. When indexed addressing is specified, the INS8900 adds the contents of the displacement, as a signed binary number, to the contents of the identified Index register (AC2 or AC3). The sum becomes the effective address. Here are some examples:

**INS8900/PACE  
DIRECT INDEXED  
ADDRESSING**

| Index Register<br>Contents | Displacement<br>Value | Effective                                                    |
|----------------------------|-----------------------|--------------------------------------------------------------|
| 213A <sub>16</sub>         | 4C <sub>16</sub>      | $\begin{array}{r} 213A \\ + 004C \\ \hline 2186 \end{array}$ |
| 213A <sub>16</sub>         | C4 <sub>16</sub>      | $\begin{array}{r} 213A \\ + FFC4 \\ \hline 20FE \end{array}$ |

Propagated Sign Bit

Observe that the high-order bit of the displacement, being a sign bit, is propagated through the missing high-order displacement byte.

**Instructions that allow indirect addressing simply superimpose indirect addressing logic on the preceding direct address generation logic.** For example, if indirect addressing without indexing is specified, then a base page or program relative direct address will be computed in the normal way, but the effective address is contained in the memory location identified by the direct address.

This illustration shows base page indirect addressing; arbitrary memory addresses are used to make the illustration easier to understand:



This illustration shows program relative indirect addressing; again using arbitrary memory addresses:



If indirect addressing with indexing is specified, then a direct address is first computed by adding the displacement, as a signed binary number, to the contents of the specified Index register; the direct indexed address thus computed provides the memory location where the indirect address will be found. This is illustrated as follows:



## INS8900 AND PACE STATUS AND CONTROL FLAGS

The INS8900 has a 16-bit Status and Control Flag register. This register is on the CPU chip and is illustrated as follows:



Fourteen of the 16 register bits are used. Three of the 14 bits are status flags as we define a status flag. These three flags are:

**Overflow (OVF)**, which is a typical Overflow status.

**Carry (CRY)**, which is set and reset by arithmetic operations, as described for a typical Carry status.

**Link (LINK)**, which is set and reset by Shift and Rotate instructions, as described for the hypothetical microcomputer's Carry status in Volume 1, Chapter 7.

The separation of **Carry** into two statuses, one for shift and rotate operations, and the other for arithmetic operations, is a fairly common minicomputer feature; the advantage of separating these two statuses is that the results of arithmetic operations can be preserved across subsequent Shift and Rotate instructions.

**BYTE** causes data to be accessed in 8-bit lengths when this status is set to 1, or in 16-bit lengths when this status is set to 0.

**Five bits (IE1 through IE5) are reserved for interrupt processing.** These five bits selectively enable and disable five interrupt lines. One of these lines (IE1) is reserved for the Stack Overflow interrupt, the other four lines are available for external device interrupt requests. There is also a master interrupt enable and disable bit (INT EN).

**Bits F11, F12, F13 and F14 are control flags** which are output directly to INS8900 and PACE device pins; they can be used in any way to control external devices. One use, to select normal or split base page addressing, has already been described.

**Only the three status flags OVF, CRY and LINK are automatically set or reset in the course of instruction execution.** The remaining 11 bits of the Status and Control Flags register are set and reset by instructions or instruction sequences that read data into, or write data out of, the Status and Control Flags register.

## INS8900 AND PACE CPU PINS AND SIGNALS

Pins and signals are illustrated in Figure 15-4 for the INS8900 and PACE devices. There are some small differences between the two sets of pin outs. These differences are shaded in Figure 15-4. Within the shaded areas, the INS8900 signal is shown closest to the arrow. The PACE signal is shown in brackets further out. Here is a summary of pins that differ:

**INS8900  
AND PACE  
SIGNAL  
DIFFERENCES**

| Pin Number | INS8900 Signal         | PACE Signal            |
|------------|------------------------|------------------------|
| 20         | GND                    | V <sub>SS</sub> (+5V)  |
| 23         | V <sub>BB</sub> (-8V)  | V <sub>BB</sub> (+8V)  |
| 24         | CLKX                   | NCLK                   |
| 25         | V <sub>CC</sub> (+5V)  | CLK                    |
| 29         | V <sub>DD</sub> (+12V) | V <sub>GG</sub> (-12V) |

The pin out differences between PACE and the INS8900 are not surprising. Since PACE uses P-channel MOS technology, while the INS8900 uses N-channel MOS technology, we would expect power supply differences. Also, the INS8900, being a newer product, requires just one clock signal input (CLKX), compared to the two required by PACE (CLK and NCLK).

Let us examine the pins and signals in detail.



Figure 15-4. INS8900 and PACE CPU Signals and Pin Assignments

There are 16 data and address lines (D0 - D15), which are multiplexed for data input, data output and address output. Two control lines, ODS and NADS, identify output on the data and address lines as either data (ODS) or addresses (NADS). A further control line, IDS, is used to strobe data input.

The EXTEND control input is used by slow memories or external devices to lengthen an instruction's execution time by increasing the duration of a data input/output cycle: this extends the time available for memories or external devices to capture data output, or to present input data.

The NINIT input control initializes PACE; the Program Counter is set to 0. The Stack Pointer, the Stack and the Status and Control Flags register are cleared.

BPS has already been described; it is used to select either normal or split base page, for base page direct addressing.

NHALT is a bidirectional control signal used by interrupt and halt logic. As an input, NHALT can induce a Halt state, or in conjunction with CONTIN, it can generate a level 0 (highest priority) interrupt request. When the CPU executes a Halt instruction, NHALT is output high to identify the Halt state. The various uses of NHALT and its interaction with CONTIN are described in detail later in this chapter.

The CONTIN signal is used to terminate a Halt condition and is also used as an output interrupt acknowledge signal. When CONTIN is properly sequenced with the NHALT signal, it initiates a high priority interrupt, as we mentioned in the preceding paragraph. CONTIN can also be used as a Jump condition input in the same way as JC13, 14 and 15, which are described next.

JC13, 14 and 15 provide an interesting capability found in very few microcomputers discussed in this book; the condition of these three inputs can be tested by a Branch-on-Condition (BOC) instruction, thus allowing external control signals to directly manipulate PACE program instruction sequences.

F11, 12, 13 and 14 are the outputs for the corresponding flag bits in the Status and Control Flags register.

NIR2, 3, 4 and 5 are the external interrupt request lines. Interrupt priority arbitration logic is included on the INS8900 (and PACE) chip. NIR2 has the highest priority of the external interrupt lines, and NIR5 has the lowest priority.

## INS8900 AND PACE TIMING AND INSTRUCTION EXECUTION

PACE uses a combination of two clock signal inputs to time events internally within the microprocessor CPU. The clock signals and the resultant internal clock phases can be illustrated as follows:

PACE  
CLOCK  
SIGNALS



The INS8900 clock logic has been simplified. A single, uniform clock signal generates all timing as follows:



Several points should be noted regarding INS8900 and PACE timing. **The internal clock phases (T1 through T8) are meaningless to external logic since they are not accessible, nor are they needed for any external synchronization purposes.** We have shown them merely because they will simplify later discussions of data input/output operations. **Four clock periods constitute a single machine cycle.** Most instructions require between four and seven machine cycles for execution.

**INS8900 AND PACE MACHINE CYCLE**

So far as external logic is concerned, there are only three types of machine cycles which can occur during execution of an instruction:

- 1) **A data input operation (read)** during which external logic must present a word of data to the CPU.
- 2) **A data output operation (write)** during which the CPU transmits a word of data to external logic.
- 3) **An internal operation** during which no CPU-initiated activity occurs on the System Bus.

**INS8900 AND PACE MACHINE CYCLE TYPES**

All instructions include one or more data input machine cycles, and two or more internal operation machine cycles. Only a few instructions include data output machine cycles. The first machine cycle of any instruction's execution must, of course, be an instruction fetch operation — which to external logic is simply a data input cycle. Let us therefore begin by examining the data input machine cycle.

Figure 15-5 illustrates timing for a standard data input machine cycle. Notice that the address is only present on the data lines for the first portion of the machine cycle. The NADS signal is sent out approximately in the center of the time interval during which the address data is valid; therefore, either the leading edge or trailing edge of NADS can be used to clock the address data. The IDS signal is sent out at about the same time as the address information is taken off the data lines — well before the time when input data is expected by the CPU. This gives external logic time to prepare the input data. The input data needs to be valid only for a short time interval later in the machine cycle. Exact timing is given in the data sheets at the end of this chapter.

**INS8900 AND PACE DATA INPUT CYCLE**



Figure 15-5. INS8900 and PACE Data Input Timing

**Figure 15-6 illustrates timing for a standard data output cycle.** The address-output portion of the cycle is identical to that of the data input cycle just described: the ODS signal is sent out at the same part of the cycle as IDS was. At approximately the same time that ODS is sent out, the output data word is placed on the data lines. The output data remains valid beyond the end of the ODS signal so that the trailing edge of ODS can be used as the clock for external data latches.

**INS8900 AND  
PACE DATA  
OUTPUT  
CYCLE**


Figure 15-6. INS8900 and PACE Data Output Timing

The data input/output cycles just described allow approximately two clock periods for external logic to respond. If this time interval is too short, the EXTEND signal input to the CPU can be used to lengthen the I/O cycle by multiples of the clock period (one clock period equals two internal clock phases). The EXTEND signal can be placed high during address time or immediately after the start of IDS or ODS, but it must be high before the end of internal clock phase 6 as shown in Figure 15-7.

**INS8900 AND  
PACE EXTEND  
SIGNAL FOR  
SLOW I/O  
OPERATIONS**


Figure 15-7. Using the EXTEND Signal to Lengthen I/O Cycles

The timing shown in Figure 15-7 provides the minimum I/O cycle extension of one clock period.

**The maximum extension permitted by PACE is 2 microseconds;** so with a clock period of 750 nanoseconds, this means that only two clock period extensions can be added to an input/output cycle. The second clock period extension is achieved by holding the EXTEND signal high for one additional clock period beyond the timing shown in Figure 15-7. The INS8900 has no maximum permitted extension.

Notice that the EXTEND signal does just what its name implies; it simply extends the duration of the data transfer portion of an I/O machine cycle. The trailing edge of the IDS or ODS signal is delayed and, for data input, the time until valid input data must be present is delayed. On data output cycles, the valid data is simply maintained on the data lines by the CPU for an extended period of time.

**The EXTEND signal can also be used to suspend CPU input activity.** This use of EXTEND will be described later under the heading of Direct Memory Access.

## THE INITIALIZATION OPERATION

**A NINIT low signal input to the CPU initializes the microprocessor.** The NINIT signal is the equivalent of the Reset signal described for other microcomputers in this book. While NINIT is held low, CPU operations are suspended; IDS and ODS are reset low. NINIT must be held low for a minimum of eight clock periods to give the CPU time to respond. After NINIT goes high again, this is what happens:

- 1) The internal Stack Pointer is cleared.
- 2) All flags and interrupt enables are set low (except Level 0 Interrupt Enable which is set high).
- 3) The Accumulators contain arbitrary values.
- 4) The Program Counter is set to zero.
- 5) 16 to 24 clock periods after NINIT returns high, the NADS signal is output high. The first instruction is thus fetched from memory location zero ( $0000_{16}$ ).

**Figure 15-8 illustrates the timing for the initialization operation.** Note that the NINIT signal is shown going low after power and clocks are both stable. The NINIT signal must be applied whenever the CPU is powered-up; if NINIT is held low before clocks and/or power have stabilized, the NADS and NHALT output signals may have undefined states for eight clock pulses after the trailing edge of NINIT.



Figure 15-8. INS8900 and PACE Initialization Timing

## THE HALT STATE AND PROCESSOR STALL OPERATIONS

Most microprocessors described in this book have a Hold state, which typically describes a CPU condition during which there is no CPU-initiated activity on the System Busses; external logic can then perform Direct Memory Access operations. The INS8900 and PACE CPUs have an equivalent state that can be initiated under program control or by external logic. When this state is initiated under program control (by executing a Halt instruction) INS8900 and PACE literature calls it the Halt state; when initiated by external logic, it is called a Processor Stall.

During normal program execution, the CPU NHALT control line provides a high output. When a Halt instruction is executed, the NHALT output is driven low to indicate that CPU activity is suspended. While in the Halt state, the NHALT output has a 7/8 duty cycle; that is, every eighth clock phase, the NHALT output goes high. If the NHALT output is merely used to drive an indicator on a

**INS8900 AND  
THE PACE  
HALT STATE**

control panel, this 7/8 duty cycle is of little concern; but, if the NHALT signal is used as a logic signal, the 7/8 duty cycle must be accounted for. **The Halt state is terminated by setting the CONTIN input signal high for a minimum of 16 clock cycles, and then resetting it low for at least four clock cycles, as shown in Figure 15-9.** CPU operation then resumes by executing the next instruction, that is, the instruction that follows the Halt instruction.



Figure 15-9. Terminating INS8900 or PACE Halt State

As we have just seen, **the PACE NHALT and CONTIN signals are interrelated**. We mentioned earlier that **these signals are also multifunctional**. We will describe separately each of the functions that can be implemented with NHALT and CONTIN. **Do not use these signals to implement more than one function unless your application absolutely requires the additional functions.** Critical and complicated timing relationships are required by the CPU to differentiate between various functions. For PACE, but not the INS8900, timing is further complicated by some circuit problems in the CPU's interrupt system, which we will describe later.

#### NHALT AND CONTIN SIGNALS ARE MULTIFUNCTIONAL

**The INS8900 and PACE CPU can be forced into the Halt state by external logic. INS8900 and PACE literature defines this operation as a Processor Stall. A Processor Stall uses both NHALT and CONTIN as control signal inputs. Figure 15-10 shows the timing sequence required.** The NHALT input must be driven low by external logic to initiate the sequence. CPU operation is then suspended after execution of the current instruction is completed. The minimum response time is five clock cycles. The maximum response time is equal to the longest instruction execution time (refer to Table 15-2). There is no maximum time limit for a Processor Stall. The CPU simply remains in the Halt state until it is terminated by the CONTIN input signal, which must be properly sequenced with the removal of the NHALT input, as shown in Figure 15-10.

#### INS8900 AND PACE PROCESSOR STALL

Let us take another look at the beginning of the Processor Stall timing sequence. **Notice that when the CPU has completed the current instruction and recognized the stall request, the CONTIN output signal is briefly driven low by the CPU.** This pulse is referred to as ACK INT (Acknowledge Interrupt) and can be used to let external logic know that the CPU is responding to the stall request. It may seem inappropriate for the CPU to provide an Acknowledge Interrupt response when we are initiating a Processor Stall. However, as we shall see later in this chapter, **a Level 0 Interrupt request begins with exactly the same timing sequence as a Processor Stall; in fact, the reaction of the CPU is the same for both operations until that point in the sequence where NHALT goes high.** Therefore, the initial response of ACK INT is always sent out after NHALT is driven low.

#### PROCESSOR STALL AND LEVEL 0 INTERRUPT SIMILARITIES

### DIRECT MEMORY ACCESS OPERATIONS

At the beginning of our Halt state and Processor Stall discussion we mentioned that these are the equivalent of Hold states provided by other microprocessors. But **there are some significant differences between the INS8900 and PACE Halt state, and the Hold state described for other microprocessors in this book. Because of these differences, Direct Memory Access operations with PACE or the INS8900 are not straightforward.**

**The INS8900 and PACE CPUs never float their Data or Control Busses.** But remember that the design of any realistic INS8900 or PACE system is going to require buffer/drivers for the data lines and control signals. The BTE, which is part of the PACE microcomputer family, performs this buffering function.

#### FLOATING INS8900 AND PACE SYSTEM BUSSES

**Any bidirectional three-state buffer can be used to float INS8900 bus lines.** In Figure 15-2, INS8208 devices are shown performing this function. Thus it is the control signals input to the BTE by PACE or to the INS8208 by the INS8900 that actually float bus lines at the proper time, in order to allow DMA operations.



Figure 15-10. Timing Diagram for Processor Stall Using NHALT and CONTIN Signals

But we must have a way of determining whether the CPU is going to be using the System Busses. There are several methods of making this determination; we will conceptually examine each of them within the context of three different DMA schemes:

- 1) DMA block data transfers initiated by the CPU
- 2) DMA block data transfers initiated by external logic
- 3) Cycle-stealing DMA transfers

From a hardware point of view, the simplest method of implementing DMA in a PACE or INS8900 system is to have the CPU initiate block transfers of data. Consider the following approach. The CPU will treat an external DMA controller as a peripheral device and will establish initial conditions such as starting address, word count, and direction (memory read or write). This information can be passed to the controller by treating its registers as memory locations and using Store instructions to write into the registers. When the required information has been passed, the CPU simply executes a Halt instruction. As we described earlier, when a Halt instruction is executed, the NHALT control output line from the CPU is driven low (7/8 duty cycle). This signal could thus be used by the DMA controller as an indication that the CPU will not be using the System Bus and the DMA transfer can begin. When the transfer is completed, the DMA controller will use the CONTIN input to the CPU, as shown in Figure 15-9, to terminate the Halt instruction. Normal CPU operation will then resume.

|                                                 |
|-------------------------------------------------|
| CPU<br>INITIATED<br>DMA BLOCK<br>DATA TRANSFERS |
|-------------------------------------------------|

Most microprocessors have a Bus Request input signal that can be used by external logic to request access to the System Busses. In a PACE or INS8900 system, the NHALT input signal can be used to force the CPU into a Processor Stall, as described earlier, and thus free the System Busses for DMA operations. The Acknowledge Interrupt (ACK INT) pulse on the CONTIN output line shown in Figure 15-10 is then equivalent to a Bus Grant signal, and the DMA controller may begin the data transfer. When the transfer is complete, the CONTIN line is used as a control input line to the CPU to terminate the Processor Stall.

Cycle-stealing DMA operations typically transfer a single word via the System Busses during a brief interval when the CPU is not using the busses. With this method, CPU operations need not be stopped; instead, they are only slowed down slightly, or in some cases not affected at all. In order to implement cycle-stealing DMA, external logic must have a way of detecting those time intervals when the CPU will not be using the System Busses. There are two ways that this can be accomplished with the INS8900 or PACE CPU. The first method involves the use of the EXTEND input signal to the CPU to suppress or suspend input/output operations; the second method uses a special technique to sense when the CPU is beginning an internal (non-I/O) machine cycle.

Earlier we described how to use the EXTEND input signal to lengthen the CPU input/output cycles. The EXTEND signal can also be used to prevent the CPU from beginning an I/O cycle, and thus ensure that the System Busses will be available to external devices for DMA operations.

Figure 15-11 illustrates both uses of the EXTEND signal. The CPU looks at the EXTEND input signal at internal clock phases T1 and T6. Notice that during I/O cycles the IDS or ODS signal goes high at the beginning of T6 and low at the beginning of T1. If EXTEND is high during T6, then extra clock cycles are inserted after T8; this is the method that would be used to lengthen an I/O cycle. If EXTEND is high during T1, then extra clock cycles are inserted between T3 and T4; this is the method we would use for DMA operations.

The trailing edge of IDS/ODS indicates that the CPU has just completed an I/O cycle and is therefore not using the System Busses at this instant. By setting EXTEND high at this time, we suppress the beginning of another I/O cycle while we use the busses for a DMA transfer.

Notice that we are merely lengthening the beginning of the machine cycle, and thus delaying that part of the machine cycle where the CPU might begin I/O activity. We do not know whether the current machine cycle will be an internal machine cycle or an I/O cycle, and we do not care. We have merely stolen the busses by slowing down the CPU.

**DMA BLOCK DATA TRANSFERS INITIATED BY EXTERNAL LOGIC IN PACE AND INS8900 SYSTEMS**

**CYCLE-STEALING DMA IN PACE AND INS8900 SYSTEMS**

**EXTEND USED TO SUSPEND INS8900 AND PACE I/O DURING DMA OPERATIONS**



Figure 15-11. Using PACE EXTEND Signal for Cycle-Stealing DMA

There are two drawbacks inherent in the EXTEND method of cycle-stealing DMA. First, whenever we use the System Busses for a DMA transfer, we slow down the operation of the CPU. Second, we must wait until the CPU has just completed an input/output cycle before we can perform the cycle steal. Since only about one-third of the CPU machine cycles are used for I/O, this means that bus access for DMA will be quite limited. Both of these drawbacks can be eliminated if we can find some technique for determining when the CPU is performing an internal (non-I/O) machine cycle. **We could then use the System Buses any time that the CPU is not using them (which is more than 60% of the time) and we could perform the DMA transfer without slowing down CPU operations. We shall now describe just such a technique.**

We stated earlier in this chapter that the internal clock phases (T1 through T8) are not available to external logic. However, National Semiconductor data sheets include a figure that shows circuits for internal drivers and receivers. A detailed examination of this figure reveals a very interesting and useful fact: the JC13 (Jump Condition 13) pin on the CPU is intended as an input signal; but, because of the way in which the receiver for this signal is designed, it also produces an output pulse on the JC13 pin during every machine cycle. The output pulse occurs during T4 of each machine cycle, and we can use this fact to design a very efficient cycle-stealing DMA arrangement.

**CYCLE-STEALING  
DMA DURING  
INS8900 AND  
PACE INTERNAL  
MACHINE CYCLES**



Figure 15-12. Idealized Circuit for Cycle-Stealing DMA During INS8900 and PACE Internal Machine Cycles

Figure 15-12 shows a circuit that uses the output pulse provided by JC13 to implement cycle-stealing DMA. Recall that the CPU sends out a negative-going NADS pulse at T4 of every input/output cycle. This NADS signal is ANDed in our circuit with an external device's DMA Bus Request and applied to the D input of a flip-flop. The JC13 output pulse, which also occurs at T4, is inverted via a transistor and applied to the clock input of the flip-flop. Thus, if NADS is high at T4 (indicating that the current CPU machine cycle is not an I/O cycle) the flip-flop will be set if there is a Bus Request present. The output of this flip-flop is then used by external logic as a Bus Grant signal and the DMA transfer can be in-

itiated. Since we do not know whether or not the next cycle will be a CPU I/O cycle, we must terminate DMA activity on the bus prior to the next T4 time. In Figure 15-12, this is accomplished using a divide-by-four counter.

The CLK input to the counter is a combination of the Bus Grant signal and the TCLK signal which is available from the PACE STE. This results in the timing shown in Figure 15-13. Notice that this scheme makes the bus available for about 7/8 of a machine cycle, or approximately 2.25 microseconds. If you refer back to Figure 14-10 you will notice that this is about the same length of time as was obtained by using the maximum duration of EXTEND. So, we have not increased the maximum time available for a DMA transfer. But, we have made two significant gains: DMA transfers can occur more frequently, and these transfers do not slow down CPU operations.

We must add a final note of caution to the description of this otherwise straightforward DMA technique. There are several critical timing paths in the idealized circuit shown in Figure 15-12. Both the JC13 pulse and the NADS signal occur at T4, although the trailing edge of NADS does occur slightly after the trailing edge of JC13. Therefore, the components used to provide CLK and D inputs to the flip-flop must be selected carefully to ensure that there is not a race condition. Additionally, we have shown the Bus Grant signal being reset at the end of T3. Since the leading edge of NADS occurs at T4, this timing relationship can be critical. However, if external devices such as address latches and decoders use the trailing edge of NADS, this timing should present no problems.



Figure 15-13. Timing for Cycle-Stealing DMA During INS8900 and PACE Internal Machine Cycle

## THE INS8900 AND PACE INTERRUPT SYSTEM

The INS8900 and PACE CPUs have complete on-chip interrupt systems. Six separate levels of interrupts are provided: one internal and five external interrupt request inputs, including a non-maskable input. Priority logic is provided on the CPU, and all interrupts are vectored, thus eliminating any polling requirements. Because of the various ways in which interrupts can be initiated, and also because of a few problems that exist in the PACE interrupt system, we will divide our description of the system into three parts:

- 1) Low priority external interrupts
- 2) Internal (Stack) interrupts
- 3) Non-maskable (Level 0) interrupts

But first, let us take an overview of the INS8900 and PACE interrupt system.



Figure 15-14. Internal View of INS8900 and PACE Interrupt System

Figure 15-14 depicts the interrupt logic that is contained on the CPU. The highest priority interrupt request is the non-maskable Level 0 interrupt request, which is initiated using the NHALT control input to the CPU. The lowest priority interrupt request is NIR5.

The Stack Interrupt and each of the four lower-priority external interrupt requests can be individually enabled or disabled by setting or clearing associated bits (IE1 - IE5) in the Status and Control Flag register. Notice in Figure 15-14 that these bits are shown as providing the 'R' input to a latch. The 'S' input to each of these latches is the actual interrupt request line. The significance of this is rather subtle. It means that an interrupt request need not supply a continuous low level until it is acknowledged. Instead, any pulse exceeding one PACE clock period will set the associated interrupt request latch: this allows narrow timing or control pulses to be used as interrupt request inputs. Note, however, that the 'R' input to the latches overrides the 'S' input. Therefore, if the individual Interrupt Enable flag is reset, it not only prevents the latch from being set by interrupt requests, it will also clear a previously latched request that may or may not have been serviced. If this logic is not clear to you, you should study the characteristics of the RS flip-flop.

A master interrupt enable (IEN) flag is also provided in the Status and Control Flag register. IEN must be set true to allow any of the latched interrupt requests to be recognized by the CPU.

The CPU checks for interrupts at the beginning of every instruction fetch. If an interrupt request is present (and enabled), the instruction fetch is aborted, the contents of the Program Counter are pushed onto the Stack, and the master interrupt enable (IEN) is set low. The CPU then loads the Program Counter with the address vector for your interrupt service routine and executes the instruction contained at that address. (We'll describe the address vectors in the next paragraph.) The interrupt request just described requires a total of 28 clock cycles from the time the interrupt is recognized by the CPU until the time when the first instruction of your interrupt service routine begins execution.

**Memory locations 0002<sub>16</sub> through 0008<sub>16</sub> are used as pointer locations or address vectors.** You load each of these locations with the starting address of the interrupt service routine for each interrupt as follows:

| MEMORY LOCATION | INTERRUPT POINTER FOR           |
|-----------------|---------------------------------|
| 2               | Stack Interrupt                 |
| 3               | NIR2                            |
| 4               | NIR3                            |
| 5               | NIR4                            |
| 6               | NIR5                            |
| 7               | Level 0 Program Counter Pointer |
| 8               | Level 0 Interrupt Origin        |
|                 | Special case                    |

**The level 0 interrupt is a special case which we will describe on its own. But first let us look at interrupts in general.**

When the CPU responds to an interrupt, it loads the Program Counter with the contents of memory locations 2 through 6, depending on the specific level of interrupt that is being acknowledged. Control is thus vectored to the proper service routine. Suppose, for example, memory location 4 contains the value 2A30<sub>16</sub>. If an interrupt request occurring at pin NIR3 is acknowledged, then during the acknowledge process the contents of the Program Counter are saved on the Stack, following which the value 2A30<sub>16</sub> is loaded into the Program Counter. Had the value 4728<sub>16</sub> been in memory location 4, then 4728<sub>16</sub> would have been loaded into the Program Counter instead of 2A30<sub>16</sub>. Thus, whatever memory address is stored in the memory location associated with the interrupt being acknowledged, this address will be loaded into the Program Counter, becoming the starting address for the specific interrupt service routine to be executed.

As part of the interrupt response we've just described, the CPU sends out a low-going pulse on the CONTIN line. Refer back to Figure 15-10 and associated text for a description of the ACK INT pulse. The last instruction executed by your interrupt service routine must be a Return-from-Interrupt (RTI) instruction. This instruction sets IEN high to re-enable interrupts, then pulls the top of the Stack into the Program Counter. This returns program control to the point where it was interrupted. The RTI instruction does not clear the internal Interrupt Request latch; therefore your interrupt service routine must reset the latch (using a Pulse Flag instruction), or the same interrupt request will still be present after the RTI instruction has been executed. Once the latch has been cleared, it can then be re-enabled for subsequent interrupt requests.

**INS8900 AND PACE INTERRUPT PRIORITIES**

**ENABLING AND DISABLING INS8900 AND PACE INTERRUPTS**

**INS8900 AND PACE INTERRUPT RESPONSE**

**INS8900 AND PACE INTERRUPT POINTERS**

**INS8900 AND PACE INTERRUPT ACKNOWLEDGE AND RETURN FROM INTERRUPT**

The interrupt sequence does not save the contents of any registers except the Program Counter. If the program that was interrupted requires that the contents of CPU registers be saved and then restored, your interrupt service routine must perform these operations.

The CPU's response to a Stack interrupt is as described for external interrupts. However, the interrupt request is generated internally by the CPU chip; it can be caused either by a Stack Full or a Stack Empty condition. Remember that the 10-word Stack is part of the CPU chip. It consists of an internal RAM and a pointer that can address Stack words 0 through 9. A Stack Empty interrupt request is generated whenever the pointer is at 0 and a Pull instruction is executed. A Stack Full interrupt request occurs when the pointer is at 7 (eight entries on the Stack) and a Push instruction is executed to fill the ninth word. The tenth word of the Stack will then be used as part of the interrupt response to store the Program Counter contents. Unless you intend to extend the Stack out into main memory, your application program will not require a Stack Empty or Full interrupt. These interrupts become error conditions and can be avoided by careful programming.

#### SAVING INS8900 AND PACE CPU REGISTERS DURING INTERRUPTS

#### INS8900 AND PACE STACK INTERRUPTS

If your program is treating the Stack Empty and Stack Full interrupts as error conditions, then you can disable Stack interrupts, in which case the full ten words of the Stack are available for nested interrupts and subroutines. Of course, this means that a Stack Full or Empty condition, should it occur, will become an undetected error, with unpredictable consequences.

#### PACE STACK INTERRUPT PROBLEMS

When using PACE, but not the INS8900, there is an additional reason for not using the Stack interrupt capability unless you really need it. **PACE has an internal circuit problem that can cause improper interrupt response. If a Stack interrupt request occurs at the same time as an NIR3 or NIR5 interrupt request, the Stack interrupt address vector will be incorrectly accessed from location 0 instead of location 2.** The solution recommended in PACE literature is to load both of these locations with the Stack interrupt vector. This apparently straightforward solution is complicated by the fact that location 0 also happens to be the initialization address; whenever the CPU is initialized, the first instruction executed is the one that is contained in location 0. Thus, the word in location 0 must serve a dual purpose:

- 1) It serves as an instruction whenever the CPU is initialized.
- 2) It serves as an address vector if a Stack interrupt occurs at the same time as NIR3 or NIR4.

Here's an example. The object code for a Copy Flags to Register (CFR) instruction is 040016. So, if locations 0 and 2 both contain a value of 040016 the problem is solved. Your Stack interrupt service routine would have to begin at memory address 040016, but you would be correctly vectored to that address regardless of whether or not the interrupt error we've just described occurs. On initialization, the first instruction executed would be the CFR instruction: this is not a very useful initialization instruction, but at least no damage is done.

For a fuller discussion of this interrupt problem and the solution, refer to PACE literature. Also keep in mind that the problem has been fixed in the INS8900.

The non-maskable (Level 0) interrupt cannot be disabled and differs from the other interrupt levels both in the way it is initiated and in the way the CPU responds to it.

#### INS8900 AND PACE NON-MASKABLE (LEVEL 0) INTERRUPT

The Level 0 interrupt request is initiated using the NHALT control input signal in combination with the CONTIN input line. Figure 15-15 shows the timing relationships between NHALT and CONTIN that are required to initiate the non-maskable interrupt. If you compare this figure with Figure 15-10, you will notice that the Level 0 interrupt request and the Processor Stall begin in exactly the same way; NHALT is driven low by external logic and held low for some time after a low-going pulse (ACK INT) has been sent out on the CONTIN line. The only difference between the two operations is towards the end of the timing sequence. For a Processor Stall, NHALT is allowed to return high while CONTIN is still high; for a Level 0 interrupt, the CONTIN line must be driven low by external logic before the NHALT line is allowed to go high. This critical timing sequence is the only way that the CPU has to differentiate between a Processor Stall and a Level 0 interrupt. Notice that this Level 0 interrupt timing sequence never requires external logic to drive CONTIN high. Therefore, if you're using the CONTIN line for any of its other multiple functions (including the ACK INT output pulse) you can merely tie CONTIN to ground and use NHALT to initiate the Level 0 interrupt.

#### INS8900 AND PACE LEVEL 0 INTERRUPT RESPONSE

The response of the CPU to the Level 0 interrupt is subtly different from its response to other interrupts. These subtle differences are related to the slightly different purpose of a non-maskable interrupt versus a normal program interrupt request. A non-maskable interrupt is typically used only when there is a catastrophic error or failure (such as loss of power) or to implement a control panel for program development or debug purposes. Both of these uses require that an asynchronous, unplanned program termination have a minimum effect upon system status; that is, you want to leave behind a picture of the system as it looked immediately before the program termination occurred.



Figure 15-15. Initiating INS8900 and PACE Level 0 Interrupt  
Using NHALT and CONTIN Signals

Remember that other levels of interrupts store the contents of the Program Counter or the Stack and reset the IEN flag in the Status and Control Flag register. This sequence obviously alters the "picture" of the CPU, since both Stack contents and Status and Control Flag register contents are changed. To avoid this, the Level 0 interrupt response by the CPU uses an external memory location to store the contents of the Program Counter. Memory location 0007<sub>16</sub> holds the address of the memory word where the Program Counter will be stored. The contents of the Status and Control Flag register are unaltered. CPU internal circuitry resets an "IRO INT ENABLE" flag to prevent another interrupt from being recognized (refer to Figure 15-16), but this is not discernible to you. After the Program Counter has been saved in the designated memory location, the instruction contained in memory location 0008<sub>16</sub> is executed; this is the first instruction of your Level 0 interrupt service routine. Suppose, for example, that memory location 0007<sub>16</sub> contains the value FF00<sub>16</sub>. Following a Level 0 interrupt request, the Program Counter contents will be stored in location FF00<sub>16</sub>. Following the Level 0 interrupt acknowledge, the actual instruction stored in memory location 0008<sub>16</sub> is executed.

Note that the Level 0 interrupt acknowledge sequence has not altered anything within the CPU that is discernible to you or to a program; the Stack, Accumulators, and Status and Control Flag register are all unchanged. Additionally, avoiding use of the Stack ensures that there will not be a Stack overflow — and in consequence a Stack interrupt will not be generated by this interrupt response sequence.

The normal Return-from-Interrupt (RTI) instruction that must be executed at the end of your interrupt service routine causes the Program Counter to be restored from the Stack. **Since the Level 0 interrupt sequence does not utilize the Stack to store the Program Counter, a different technique must be used to return control to the interrupted program.** First you must execute a Set Flag (SFLG) or Pulse Flag (PFLG) instruction, referencing bit 15 in the Status and Control Flag register. This bit always appears to be set to a '1', but must be referenced in this case to enable lower levels of interrupts. Next you must ex-

**RETURN FROM  
PACE LEVEL 0  
INTERRUPT**

ecute a Jump Indirect (JMP@) through the location pointed to by the contents of memory location 000716 to restore the original Program Counter contents.

PACE, but not the INS8900, has some Level 0 interrupt circuit problems.

If a Level 0 interrupt occurs within the 12-clock-cycle period following the recognition of any other interrupt, PACE will either perform a Processor Stall (which we described earlier) or PACE will execute the Level 0 interrupt — but using the wrong pointer address.

In short, you don't know what might happen under these circumstances. There is a solution for this problem. It requires that external logic allow NHALT to be applied to the PACE CPU only while the NADS signal is present, provided no Acknowledge Interrupt (ACK INT) has occurred since the last NADS pulse. ACK INT is accompanied by a negative-going pulse on the CONTIN line. Sound complicated? It is.

PACE  
LEVEL 0  
INTERRUPT  
PROBLEMS

The circuit shown in Figure 15-16 is reproduced from PACE literature and solves the problem we've just described. We won't attempt to describe here how this circuit solves the problem. Note that this circuit only takes care of Level 0 interrupt problems; if you also want to use NHALT and CONTIN to cause a Processor Stall, you must design additional external logic.

Once again, we must advise that these interrupt system problems exist in PACE CPU chips. The INS8900 has none of these problems.

## THE INS8900 AND PACE INSTRUCTION SET

Table 15-1 summarizes the INS8900 and PACE instruction set.

The primary memory reference instructions have typical minicomputer addressing modes. These instructions will also be used as I/O instructions, since external devices are identified via selected memory addresses.

In Table 15-1, "direct addressing options" means the instruction can reference memory using any of the direct or direct indexed addressing options described earlier.

"Indirect addressing options" similarly specifies any of the indirect addressing options described earlier.

Both Branch and Skip instructions are provided, and each differs significantly from the philosophies described in Volume 1, Chapter 6.

There are 16 conditions that can cause a Branch, as shown in Table 15-3. Notice that three of the conditions are determined by external inputs JC13, 14, and 15. If a Branch-on-Condition is true, then the displacement which is added to the Program Counter is an 8-bit signed binary number as described in Volume 1, Chapter 6.

There are three varieties of Skip-on-Condition instructions. SKNE, SKG and SKAZ compare the contents of an Accumulator to a memory location which is addressed using direct or direct indexed addressing. Based on the results of the comparison, the instruction following the Skip may or may not be executed. These three instructions are therefore combined Skip and Memory Reference instructions.

ISZ and DSZ identify a memory location using direct or direct indexed addressing; the contents of the addressed memory location are incremented (ISZ) or decremented (for DSZ); if after the increment or decrement operation the memory location contains a 0 value, then the Skip is performed.

The AISZ instruction adds an 8-bit signed binary number to the contents of an Accumulator; if the result is 0, a Skip is performed.

These Skip instructions will be very familiar to minicomputer programmers, and on most microcomputers are equivalent to a secondary Memory Reference or Immediate Operate instruction, followed by a Branch-on-Condition instruction.

INS8900  
AND PACE  
DIRECT  
ADDRESSING  
OPTIONS



Figure 15-16. Circuit to Prevent Conflicts Between PACE Level 0 Interrupts and Lower Priority Interrupts

The following symbols are used in Table 15-1:

|          |                                                                                                                                                                                                                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AC0      | Accumulator 0                                                                                                                                                                                                                                                                           |
| C        | Carry status                                                                                                                                                                                                                                                                            |
| CC       | 4-bit Condition Code described in Table 15-3                                                                                                                                                                                                                                            |
| D        | Any Destination register                                                                                                                                                                                                                                                                |
| DATA8    | 8-bit binary data unit                                                                                                                                                                                                                                                                  |
| DISP(X)  | Direct or indexed addressing operands as explained in the text.                                                                                                                                                                                                                         |
| @DISP(X) | Indirect addressing operands as explained in the text.                                                                                                                                                                                                                                  |
| EA       | The effective address generated by the specified operands.                                                                                                                                                                                                                              |
| f        | 4-bit quantity selecting a bit in the Flag Word.                                                                                                                                                                                                                                        |
| FW       | Flag Word described in the text.                                                                                                                                                                                                                                                        |
| IEN      | Interrupt Enable status                                                                                                                                                                                                                                                                 |
| I        | A 1-bit unit determining whether LINK is included in the shift/rotate.                                                                                                                                                                                                                  |
| L        | Link status                                                                                                                                                                                                                                                                             |
| n        | Seven bits determining how many single bit shift/rotates are performed.                                                                                                                                                                                                                 |
| O        | Overflow status                                                                                                                                                                                                                                                                         |
| PC       | Program Counter                                                                                                                                                                                                                                                                         |
| r        | Any register of the Accumulator: AC0, AC1, AC2 or AC3                                                                                                                                                                                                                                   |
| S        | Any Source register                                                                                                                                                                                                                                                                     |
| ST       | Top word of on-chip Stack.                                                                                                                                                                                                                                                              |
| x<y,z>   | Bits y through z of the quantity x. For example, r<7,0> is the low-order byte of the specified register.                                                                                                                                                                                |
| [ ]      | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified. |
| [[ ]]    | Implied memory addressing: the contents of the memory location designated by the contents of a register.                                                                                                                                                                                |
| Λ        | Logical AND                                                                                                                                                                                                                                                                             |
| ∨        | Logical OR                                                                                                                                                                                                                                                                              |
| ⊕        | Logical Exclusive-OR                                                                                                                                                                                                                                                                    |
| →        | Data is transferred in the direction of the arrow.                                                                                                                                                                                                                                      |
| ↔        | Data is exchanged between the two locations designated on either side of the arrow.                                                                                                                                                                                                     |

Under the heading of STATUSES in Table 15-1, an X indicates statuses which are modified in the course of the instruction's execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

Table 15-1. INS8900 and PACE Instruction Set Summary

| TYPE                                              | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   | OPERATION PERFORMED                                                                                                                                                  |
|---------------------------------------------------|----------|------------|-------|----------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                   |          |            |       | C        | O | L |                                                                                                                                                                      |
| PRIMARY<br>MEMORY REFERENCE<br>AND I/O            | LD       | r.DISP(X)  | 2     |          |   |   | [r]—[EA]<br>Load any Accumulator, direct addressing options.<br>[AC0]—[EA]                                                                                           |
|                                                   | LD       | 0,@DISP(X) | 2     |          |   |   | Load Primary Accumulator, indirect addressing options.<br>[EA]—[r]                                                                                                   |
|                                                   | ST       | r.DISP(X)  | 2     |          |   |   | Store any Accumulator, direct addressing options.<br>[EA]—[AC0]                                                                                                      |
|                                                   | ST       | 0,@DISP(X) | 2     |          |   |   | Store Primary Accumulator, indirect addressing options.<br>[AC0]—[EA]sign extended                                                                                   |
|                                                   | LSEX     | 0,DISP(X)  | 2     |          |   |   | Load a signed byte into Primary Accumulator; extend sign bit into high order byte. Direct addressing options.                                                        |
| SECONDARY<br>MEMORY REFERENCE<br>(MEMORY OPERATE) | ADD      | r.DISP(X)  | 2     | X        | X |   | [r]—[r]+[EA]<br>Add to any Accumulator, direct addressing options.<br>[AC0]—[AC0]+[EA]+[C]                                                                           |
|                                                   | DECA     | 0,DISP(X)  | 2     | X        | X |   | Add decimal with Carry to any Accumulator, direct addressing options.<br>[AC0]—[AC0]-[EA]+[C]                                                                        |
|                                                   | SUBB     | 0,DISP(X)  | 2     | X        | X |   | Subtract from Primary Accumulator with borrow, direct addressing options.<br>[AC0]—[AC0] A [EA]                                                                      |
|                                                   | AND      | 0,DISP(X)  | 2     |          |   |   | AND with Primary Accumulator, direct addressing options.<br>[AC0]—[AC0] V [EA]                                                                                       |
|                                                   | OR       | 0,DISP(X)  | 2     |          |   |   | OR with Primary Accumulator, direct addressing options.                                                                                                              |
| IMMEDIATE                                         | LI       | r,DATA8    | 2     |          |   |   | [r<7,0>]— DATA8 (sign extended)<br>Load immediate into any Accumulator. DATA8 is an 8-bit signed binary value. The sign bit is propagated through 8 high order bits. |
|                                                   | JMP      | DISP(X)    | 2     |          |   |   | [PC]— EA<br>Jump by loading the effective direct address into the Program Counter.                                                                                   |
|                                                   | JMP      | @DISP(X)   | 2     |          |   |   | [PC]— EA<br>Jump by loading the effective indirect address into the Program Counter.                                                                                 |

Table 15-1. INS8900 and PACE Instruction Set Summary (Continued)

| TYPE                                       | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   | OPERATION PERFORMED                                                                                                     |
|--------------------------------------------|----------|------------|-------|----------|---|---|-------------------------------------------------------------------------------------------------------------------------|
|                                            |          |            |       | C        | O | L |                                                                                                                         |
| IMMEDIATE<br>(CONTINUED)                   | JSR      | DISP(X)    | 2     |          |   |   | [ST]—[PC]<br>[PC]—EA<br>Jump to subroutine direct. As JMP direct, but push old Program Counter contents onto Stack.     |
|                                            | JSR      | @DISP(X)   | 2     |          |   |   | [ST]—[PC]<br>[PC]—EA<br>Jump to subroutine indirect. As JMP indirect, but push old Program Counter contents onto Stack. |
| IMMEDIATE<br>OPERATE                       | CAI      | r,DATA8    | 2     |          |   |   | [r]—[r]+DATA8 (sign extended)<br>Complement contents of any register, then add immediate data.                          |
| BRANCH ON<br>CONDITION                     | BOC      | CC,DISP    | 2     |          |   |   | If CC true; then [PC]— EA<br>Branch on CC true, as defined in Table 14-3.                                               |
| MEMORY REFERENCE<br>AND SKIP<br>(SEE TEXT) | SKNE     | r,DISP(X)  | 2     |          |   |   | If [r] ≠ [EA]; then [PC]—[PC]+1<br>Skip if any Accumulator not equal.                                                   |
|                                            | SKG      | 0,DISP(X)  | 2     |          |   |   | If [AC0] > [EA]; then [PC]—[PC]+1<br>Skip if Primary Accumulator greater.                                               |
|                                            | SKAZ     | 0,DISP(X)  | 2     |          |   |   | If ([AC0] ∧ [EA]) = 0; then [PC]—[PC]+1<br>Skip if AND with Primary Accumulator is zero.                                |

Table 15-1. INS8900 and PACE Instruction Set Summary (Continued)

| TYPE                                       | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   | OPERATION PERFORMED                                                                                                                                    |
|--------------------------------------------|----------|------------|-------|----------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            |          |            |       | C        | O | L |                                                                                                                                                        |
| MEMORY<br>REFERENCE<br>OPERATE<br>AND SKIP | ISZ      | DISP(X)    | 2     |          |   |   | [EA]←[EA]+1<br>If [EA] = 0; then [PC]←[PC]+1<br>Increment memory, skip if zero.                                                                        |
|                                            | DSZ      | DISP(X)    | 2     |          |   |   | [EA]←[EA]-1<br>If [EA] = 0; then [PC]←[PC]+1<br>Decrement memory, skip if zero.                                                                        |
| IMMEDIATE<br>OPERATE<br>AND SKIP           | AISZ     | r,DATA8    | 2     |          |   |   | [r]←[r]+DATA8<br>If [r] = 0; then [PC]←[PC]+1<br>Add immediate to any Accumulator. Skip if zero. DATA8 is an 8-bit signed binary immediate data value. |
| REGISTER-<br>REGISTER MOVE                 | RCPY     | S,D        | 2     |          |   |   | [D]←[S]<br>Move contents of any Accumulator (S) to any Accumulator (D).                                                                                |
|                                            | RXCH     | S,D        | 2     |          |   |   | [D]←[S]<br>Exchange contents of any Accumulators.                                                                                                      |
| REGISTER-<br>REGISTER OPERATE              | RADD     | S,D        | 2     | X        | X |   | [D]←[S]+[D]<br>Binary add any Accumulator to any Accumulator.                                                                                          |
|                                            | RADC     | S,D        | 2     | X        | X |   | [D]←[S]+[D]+[C]<br>Binary add with Carry any Accumulator to any Accumulator.                                                                           |
|                                            | RAND     | S,D        | 2     |          |   |   | [D]←[S] ∧ [D]<br>AND any Accumulator with any Accumulator.                                                                                             |
|                                            | RXOR     | S,D        | 2     |          |   |   | [D]←[S] ⊕ [D]<br>Exclusive-OR any Accumulator with any Accumulator.                                                                                    |
| REGISTER<br>OPERATE                        | SHL      | r,n,1      | 2     |          |   | X | Shift any Accumulator left n bits. Simple if 1 = 0; through Link if 1 = 1.                                                                             |
|                                            | SHR      | r,n,1      | 2     |          |   | X | Shift any Accumulator left n bits. Simple if 1 = 0, through Link if 1 = 1.                                                                             |
|                                            | ROL      | r,n,1      | 2     |          |   | X | As SHL, but rotate.                                                                                                                                    |
|                                            | ROR      | r,n,1      | 2     |          |   | X | As SHR, but rotate.                                                                                                                                    |

Table 15-1. INS8900 and PACE Instruction Set Summary (Continued)

| TYPE      | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   | OPERATION PERFORMED                                                                                                           |
|-----------|----------|------------|-------|----------|---|---|-------------------------------------------------------------------------------------------------------------------------------|
|           |          |            |       | C        | O | L |                                                                                                                               |
| STACK     | PUSH     | r          | 2     |          |   |   | [ ST]—[ r]<br>Push any Accumulator contents onto Stack.                                                                       |
|           | PUSHF    |            | 2     |          |   |   | [ ST]—[ FW]<br>Push flags onto Stack.                                                                                         |
|           | PULL     | r          | 2     |          |   |   | [ r]—[ ST]<br>Pull top of Stack into any Accumulator.                                                                         |
|           | PULLF    |            | 2     | X        | X | X | [ FW]—[ ST]<br>Pull top of Stack into flags.                                                                                  |
|           | XCHRS    | r          | 2     |          |   |   | [ ST]—[ r]<br>Exchange contents of any Accumulator with top of Stack.                                                         |
|           | RTS      | DISP       | 2     |          |   |   | [ PC]—[ ST] + DISP<br>Return from subroutine. Move sum of DISP and top of Stack to PC. DISP is an 8-bit signed binary number. |
| INTERRUPT | RTI      | DISP       | 2     |          |   |   | [ PC]—[ ST]+ DISP<br>[ IEN]— 1<br>Return from interrupt. Like RTS, but enable interrupts.                                     |
| STATUS    | CFR      | r          | 2     |          |   |   | [ r]—[ FW]<br>Copy flags to any Accumulator.                                                                                  |
|           | CRF      | r          | 2     | X        | X | X | [ FW]—[ r]<br>Move any Accumulator contents to flags.                                                                         |
|           | SFLG     | f          | 2     |          |   |   | [ FW< f> ]— 1<br>Set flag f to 1. (f = 0 to 15).                                                                              |
|           | PFLG     | f          | 2     |          |   |   | [ FW< f> ]— 1 for four clock periods<br>Pulse flag f (invert flag status for four clock periods). (f = 0 to 15).              |
|           | HALT     |            | 2     |          |   |   | Halt                                                                                                                          |

The following symbols are used in Table 15-2:

|         |                                                                             |
|---------|-----------------------------------------------------------------------------|
| aa      | Two bits choosing the destination register.                                 |
| bb      | Two bits choosing the Index register                                        |
| cccc    | Four bits choosing the Condition Code. See Table 15-3.                      |
| ee      | Two bits choosing the source register.                                      |
| ffff    | Four bits selecting a bit in the Flag Word.                                 |
| I       | One bit determining whether Link is included in a shift or rotate.          |
| nnnnnnn | Seven bits determining how many single bit shifts or rotates are performed. |
| PP      | 8-bit signed displacement                                                   |
| QQ      | Eight bits of immediate data                                                |
| x       | A "don't care" bit                                                          |
| XX      | A "don't care" byte                                                         |

Table 15-2. INS8900 and PACE Instruction Set Object Codes

| INSTRUCTION    | OBJECT CODE    | BYTES | MACHINE CYCLES |          |       |        |
|----------------|----------------|-------|----------------|----------|-------|--------|
|                |                |       | TOTAL          | INTERNAL | INPUT | OUTPUT |
| ADD r,DISP(X)  | 1110aabb<br>PP | 2     | 4              | 2        | 2     |        |
| AISZ r,DATA8   | 011110aa<br>QQ | 2     | 5/6            | 4/5      | 1     |        |
| AND 0,DISP(X)  | 101010bb<br>PP | 2     | 4              | 2        | 2     |        |
| BOC CC,DISP    | 0100cccc<br>PP | 2     | 5/6            | 4/5      | 1     |        |
| CAI r,DATA8    | 011100aa<br>QQ | 2     | 5              | 4        | 1     |        |
| CFR f          | 000001aa<br>XX | 2     | 4              | 3        | 1     |        |
| CRF f          | 000010aa<br>XX | 2     | 4              | 3        | 1     |        |
| DECA 0,DISP(X) | 100010bb<br>PP | 2     | 7              | 5        | 2     |        |
| DSZ DISP(X)    | 101011bb<br>PP | 2     | 7/8            | 4/5      | 2     | 1      |
| HALT           | 000000xx<br>XX | 2     | -              | -        | 1     |        |
| ISZ DISP(X)    | 100011bb<br>PP | 2     | 7/8            | 4/5      | 2     | 1      |
| JMP DISP(X)    | 000110bb<br>PP | 2     | 4              | 3        | 1     |        |
| JMP @DISP(X)   | 100110bb<br>PP | 2     | 4              | 2        | 2     |        |
| JSR DISP(X)    | 000101bb<br>PP | 2     | 5              | 4        | 1     |        |
| JSR @DISP(X)   | 100101bb<br>PP | 2     | 5              | 3        | 2     |        |
| LD r,DISP(X)   | 1100aabb<br>PP | 2     | 4              | 2        | 2     |        |
| LD 0,@DISP(X)  | 101000bb<br>PP | 2     | 5              | 2        | 3     |        |
| LI r,DATA8     | 010100aa<br>QQ | 2     | 4              | 3        | 1     |        |
| LSEX 0,DISP(X) | 101111bb<br>PP | 2     | 4              | 2        | 2     |        |
| OR 0,DISP(X)   | 101001bb<br>PP | 2     | 4              | 2        | 2     |        |

Table 15-2. INS8900 and PACE Instruction Set Object Codes (Continued)

| INSTRUCTION    | OBJECT CODE           | BYTES | MACHINE CYCLES |          |       |        |
|----------------|-----------------------|-------|----------------|----------|-------|--------|
|                |                       |       | TOTAL          | INTERNAL | INPUT | OUTPUT |
| PFLG f         | 0011ffff<br>0xxxxxx   | 2     | 6              | 5        | 1     |        |
| PULL r         | 011001aa<br>XX        | 2     | 4              | 3        | 1     |        |
| PULLF          | 000100xx<br>XX        | 2     | 4              | 3        | 1     |        |
| PUSH r         | 011000aa<br>XX        | 2     | 4              | 3        | 1     |        |
| PUSHF          | 000011xx<br>XX        | 2     | 4              | 3        | 1     |        |
| RADC S,D       | 0011101aa<br>eexxxxxx | 2     | 4              | 3        | 1     |        |
| RADD S,D       | 011010aa<br>eexxxxxx  | 2     | 4              | 3        | 1     |        |
| RAND S,D       | 010101aa<br>eexxxxxx  | 2     | 4              | 3        | 1     |        |
| RCPY S,D       | 010111aa<br>eexxxxxx  | 2     | 4              | 3        | 1     |        |
| ROL r,n,l      | 001000aa<br>nnnnnnnl  | 2     | 5 + 3n         | 4 + 3n   | 1     |        |
| ROR r,n,l      | 001001aa<br>nnnnnnnl  | 2     | 5 + 3n         | 4 + 3n   | 1     |        |
| RTI            | 011111xx<br>PP        | 2     | 6              | 5        | 1     |        |
| RTS            | 100000xx<br>PP        | 2     | 5              | 4        | 1     |        |
| RXCH S,D       | 011011aa<br>eexxxxxx  | 2     | 6              | 5        | 1     |        |
| RXOR S,D       | 010110aa<br>eexxxxxx  | 2     | 4              | 3        | 1     |        |
| SFLG f         | 0011ffff<br>1xxxxxx   | 2     | 5              | 4        | 1     |        |
| SHL r,n,l      | 001010aa<br>nnnnnnnl  | 2     | 5 + 3n         | 4 + 3n   | 1     |        |
| SHR r,n,l      | 001011aa<br>nnnnnnnl  | 2     | 5 + 3n         | 4 + 3n   | 1     |        |
| SKAZ 0,DISP(X) | 101110bb<br>PP        | 2     | 5/6            | 3/4      | 2     |        |
| SKG 0,DISP(X)  | 100111bb<br>PP        | 2     | 7/8            | 5/6      | 2     |        |
| SKNE r,DISP(X) | 1111aabbb<br>PP       | 2     | 5/6            | 3/4      | 2     |        |
| ST r,DISP(X)   | 1101aabbb<br>PP       | 2     | 4              | 2        | 1     | 1      |
| ST 0,@DISP(X)  | 101100bb<br>PP        | 2     | 4              | 1        | 2     | 1      |
| SUBB 0,DISP(X) | 100100bb<br>PP        | 2     | 4              | 2        | 2     |        |
| XCHR r         | 000111aa<br>XX        | 2     | 6              | 5        | 1     |        |

\*All instructions may take additional cycles if Extend Read and Extend Write are implemented.

Table 15-3. Branch Conditions for INS8900 and PACE BOC Instruction

| Condition Code (CC) | Mnemonic | Condition                                 |
|---------------------|----------|-------------------------------------------|
| 0000                | STFL     | Stack Full (contains nine or more words). |
| 0001                | REQ0     | (AC0) equal to zero (see Note 1).         |
| 0010                | PSIGN    | (AC0) has positive sign (see Note 2).     |
| 0011                | BIT0     | Bit 0 of AC0 true.                        |
| 0100                | BIT1     | Bit 1 of AC0 true.                        |
| 0101                | NREQ0    | (AC0) is nonzero (see Note 1).            |
| 0110                | BIT2     | Bit 2 of AC0 is true.                     |
| 0111                | CONTIN   | CONTIN (continue) input is true.          |
| 1000                | LINK     | LINK is true.                             |
| 1001                | IEN      | IEN is true.                              |
| 1010                | CARRY    | CARRY is true.                            |
| 1011                | NSIGN    | (AC0) has negative sign (see Note 2).     |
| 1100                | OVF      | OVF is true.                              |
| 1101                | JC13     | JC13 input is true (see Note 3).          |
| 1110                | JC14     | JC14 input is true.                       |
| 1111                | JC15     | JC15 input is true.                       |

## NOTES:

1. If selected data length is 8 bits, only bits 0 through 7 of AC0 are tested.
2. Bit 7 is sign bit (instead of bit 15) if selected data length is 8 bits.
3. JC13 is used by INS8900 and PACE Microprocessor Development System and is not accessible during prototyping.

**THE BENCHMARK PROGRAM**

For PACE, our standard benchmark program adopts this modified form:

|      |          |                                           |                                |
|------|----------|-------------------------------------------|--------------------------------|
| LD   | 2,IOBUF  | LOAD I/O BUFFER ADDRESS INTO AC2          |                                |
| LD   | 0,@TABLE | LOAD ADDRESS OF FIRST FREE TABLE BYTE     |                                |
| RCPY | 0,3      | MOVE TO AC3                               |                                |
| LOOP | LD       | 0,0(2)                                    | LOAD NEXT BYTE FROM I/O BUFFER |
|      | ST       | 0,0(3)                                    | STORE IN NEXT TABLE BYTE       |
| AISZ | 2,1      | INCREMENT AC2                             |                                |
| AISZ | 3,1      | INCREMENT AC3                             |                                |
| DSZ  | IOCNT    | DECREMENT I/O BUFFER LENGTH. SKIP IF ZERO |                                |
| JMP  | LOOP     | RETURN FOR MORE BYTES                     |                                |
| RCPY | 3,0      | MOVE AC3 CONTENTS TO AC0                  |                                |
| ST   | 0,@TABLE | RESTORE ADDRESS OF FIRST FREE TABLE BYTE  |                                |

In order to take advantage of INS8900 and PACE indirect addressing, three memory locations are reserved on page 0 as follows:

IOBUF holds the beginning address of the I/O buffer.

TABLE holds the address of the first free byte in the permanent data table.

IOCNT holds the number of data words in the I/O buffer.

Memory, as organized for the benchmark program will look like this:



Suppose the benchmark program rules arbitrarily require that a displacement be stored in the first word of the data table, and that this displacement be added to the address of the first word of the data table in order to compute the address of the first free data table word:



Now the instructions:

|      |          |                                       |
|------|----------|---------------------------------------|
| LD   | 0,@TABLE | LOAD ADDRESS OF FIRST FREE TABLE BYTE |
| RCPY | 0,3      | MOVE TO AC3                           |

must be replaced by these instructions:

|      |          |                                            |
|------|----------|--------------------------------------------|
| LD   | 3, TABLE | LOAD BEGINNING ADDRESS OF DATA TABLE       |
| LD   | 0,0(3)   | LOAD DISPLACEMENT TO FIRST FREE TABLE WORD |
| RADD | 0,3      | ADD DISPLACEMENT TO AC3                    |

The new displacement must be restored to the first data table word. The instructions:

|      |          |                                          |
|------|----------|------------------------------------------|
| RCPY | 3,0      | MOVE AC3 CONTENTS TO AC0                 |
| ST   | 0,@TABLE | RESTORE ADDRESS OF FIRST FREE TABLE BYTE |

must be replaced by these instructions:

|      |          |                                             |
|------|----------|---------------------------------------------|
| LD   | 0, TABLE | LOAD BEGINNING ADDRESS OF DATA TABLE IN AC0 |
| CAI  | 0,1      | FORM TWOS COMPLEMENT                        |
| RADD | 0,3      | SUBTRACT AC0 FROM AC3 TO FORM DISPLACEMENT  |
| RCPY | 3,0      | MOVE DISPLACEMENT TO AC0                    |
| LD   | 3, TABLE | LOAD BEGINNING ADDRESS OF DATA TABLE IN AC3 |
| ST   | 0,0(3)   | SAVE DISPLACEMENT IN FIRST FREE TABLE WORD  |

Forcing an INS8900/PACE programmer to conform to programming logic suited to some other microcomputer's instruction set only proves that the two microcomputers have different instruction sets.

## THE PACE DP8302 SYSTEM TIMING ELEMENT (STE)

The STE is a very elementary clock device used with PACE, but not with the INS8900; it accepts inputs from an external crystal and generates the MOS clock signals for PACE, plus a pair of TTL-level clock outputs that can be used for synchronizing system operations. Figure 15-17 illustrates the pin assignments of the STE.



Figure 15-17. DP8302 System Timing Element (STE) Pins and Signals

The frequency of the MOS clocks output by the STE is one-half the input crystal frequency. The STE is designed to operate with a 2.6667 MHz crystal. The MOS clock frequency is thus 1.3333 MHz which results in a clock period ( $t_p$ ) of 750 nanoseconds ( $t_p = 1/f$ ); this is the optimal clock period for the PACE CPU.

### STE CLOCK FREQUENCY

**Two pairs of MOS clock outputs are generated by the STE; NCLK/NCLK\* and NCK/NCK\*.** The first pair of outputs contain a  $25\ \Omega$  series of damping resistor; typically, these outputs will be used in circuit board layouts where the STE-to-PACE interconnect lines are less than two inches. The other MOS outputs, NCK and NCK\*, are undamped, and you can select some other value of series damping resistors that might be better suited for your particular board layout.

**In addition to the +5V and -12V power supplies typically needed with MOS devices, the PACE CPU has a third power supply requirement: a substrate bias voltage ( $V_{BB}$ ) of +8V must be applied to the CPU chip.** Since it is unlikely that any other devices in your microcomputer system would require this voltage level, the need for a third external system power source can be eliminated by providing a voltage converter circuit. **Figure 15-18 shows a circuit that generates the required  $V_{BB}$  voltage level;** the circuit requires only a few components and uses one of the STE's TTL clock outputs as a 'charge pump' for the circuit.

### GENERATING THE PACE SUBSTRATE BIAS VOLTAGE



Figure 15-18. Circuit to Generate Substrate Bias Voltage ( $V_{BB}$ ) for PACE CPU

## THE PACE BIDIRECTIONAL TRANSCEIVER ELEMENT (BTE)

The DP8300 BTE is an 8-bit device that provides an interface between the PACE MOS-level signals and the TTL-level signals required by other devices in a microcomputer system (the BTE is not used in INS8900 systems). If you refer to Figure 15-1 at the beginning of this chapter, you will see that a typical PACE microcomputer system requires three BTEs: two are used to buffer the CPU's 16 address/data lines, and the third is used as a TTL driver for the CPU's control signal outputs (NADS, ODS, IDS, F11 - F14).

Figure 15-19 shows the pin assignments for the BTE.



| PIN NAME                 | DESCRIPTION           | TYPE         |
|--------------------------|-----------------------|--------------|
| MBI/O 00 - 07            | MOS Bus Data Lines    | Input/Output |
| BDI/O 00 - 07            | TTL Bus Data Lines    | Input/Output |
| CE1, CE2*,<br>STR*, WBD* | Mode Control Signals  | Input        |
| V <sub>CC</sub> , GND    | + 5V Power and Ground |              |

Figure 15-19. BTE Signals and Pin Assignments

**Table 15-4 summarizes the operating modes of the BTE.**

**WBD\*** is the main mode control signal; when this signal is low, the other control signals are ignored and the BTE simply converts the MOS signals from the CPU into TTL-level output signals. The TTL outputs have a high fan-out capability and can service up to thirty 50 millampere loads.

The BTE used to buffer the PACE control signals normally operates continuously in this 'drive-only' mode (Mode 1) and is kept in this mode by simply connecting the WBD\* signal to ground.

**BTE MODE  
CONTROL  
SIGNALS**

The BTEs used to buffer bidirectional (address/data) lines must be switched back and forth between Modes 1 and 2; Mode 1 is used for CPU data output and Mode 2 for CPU data input. The simplest way of accomplishing this is to continuously enable the CE1, CE2\*, and STR\* controls by connecting them to appropriate logic levels (+5V or ground) and then use the WBD\* signal for directional control. For example, in a PACE system, the IDS signal from the CPU could be used as the input to WBD\*. During a PACE data input cycle, IDS will go high at the appropriate portion of the cycle and place the BTE in Mode 2; IDS is low at all other times and the BTE will operate in Mode 1.

Table 15-4. PACE BTE Truth Table

| MODE # | CONTROL INPUTS |      |      |      | MODE DESCRIPTION                                                                                   |
|--------|----------------|------|------|------|----------------------------------------------------------------------------------------------------|
|        | CE1            | CE2* | STR* | WBD* |                                                                                                    |
| 1      | X              | X    | X    | 0    | Receive MOS signals and drive TTL signals                                                          |
| 2      | 1              | 0    | 0    | 1    | Receive TTL signals and drive MOS signals                                                          |
| 3      | 0              | 0    | 0    | 1    | Outputs in high-impedance state                                                                    |
|        | 0              | 1    | 0    | 1    |                                                                                                    |
|        | 1              | 1    | 0    | 1    |                                                                                                    |
| 4      | X              | X    | 1    | 1    | On positive-edge transition of STR*, latch into Mode 2 or 3 as determined by state of CE1 and CE2* |

X = don't care



Figure 15-20. Signal Connections to Control BTE in a DMA System

**In a DMA or multiprocessor we will need to use BTE Mode 3 to place the BTE outputs in a high-impedance state and thus free the System Busses for use by other devices.** In such a system an externally generated Bus Grant signal could be used to place the BTE in Mode 3. Figure 15-20 illustrates one method of doing this: whenever the BUS GRANT signal is high, the BTE is in Mode 3. At other times the IDS signal operates as we've just described to switch the BTE back and forth between Modes 1 and 2.

**The fourth BTE mode uses a negative-to-positive transition on the STR\* input to latch the state of CE1 and CE2\*, and then places the BTE in either Mode 2 or Mode 3.** This latch mode function might be useful when the BTE is used as a simple input buffer. For example, in a system with multiplexed address/data lines (such as PACE), address outputs could be applied to CE1 and CE2\*, and an address strobe signal (such as NADS) connected to STR\*. Then, when the BTE is selected by the appropriate address bits, the trailing edge of the strobe signal will gate TTL data through the BTE and apply the data to the MOS lines of the CPU. When the BTE is not selected (addressed), its outputs will be in the high impedance state (Mode 3).

## USING OTHER MICROCOMPUTER SUPPORT DEVICES WITH THE PACE AND INS8900

The INS8900 CPU has numerous control signals which allow general purpose microcomputer support devices to be included in an INS8900 system.

Let us see how 8080A support devices might be used with the INS8900 CPU. First, we'll take an overview of the general CPU-to-device interface that all the 8080A family of devices expect.

All of the 8080A family devices require that address information (or enabling/select signals derived from the address lines) be valid during the data transfer (read/write) portion of an input/output cycle. Recall that the INS8900 data lines are multiplexed: at the beginning of an input/output cycle, the data lines are used to output address information; the address information is then removed and the data lines are used for the actual input or output of data during the latter portion of the I/O cycle.

Thus, the first thing we must do to interface the INS8900 to an 8080A family device is to demultiplex the INS8900 address/data lines. (This must also be done even with the MILE device, described in Volume 3, which was specifically designed to operate with the INS8900 CPU. There are several different approaches that we can use to accomplish the required demultiplexing.

DEMULITPLEXING  
THE INS8900  
ADDRESS/DATA  
LINES

The most obvious way is to use D-type flip-flops or data registers with the INS8900 NADS signal as the clock pulse. Here are some of the standard 7400 family devices that might be used:

- 7475 Double 2-Bit Gated Latches with Q and Q Outputs
- 7477 Double 2-Bit Gated Latches with Q Output Only
- 74100 Double 4-Bit Gated Latches
- 74166 Dual 4-Bit Gated Latches with Clear
- 74174 Hex D-Type Flip-Flops with Common Clock and Clear
- 74175 Quad D-Type Flip-Flops with Common Clock and Clear

Some of these devices require that the NADS signal be inverted to provide the necessary clocking signal. Remember, though, that PACE address information is valid during both the leading edge (high-to-low transition) and trailing edge (low-to-high transition) of NADS; this generally simplifies the demultiplexing operation.

In many systems you will not need to latch all 16 bits of address information since it would be an unusual application that required all of the 64K of address space that this provides. There will usually be some tradeoff between system address requirements (how many system devices require a latched Address Bus) and the type and amount of address decoding required. When a fully latched Address Bus is provided, then simpler nonlatched address decoders can be used. In fact, often address bits can then be used directly as device select signals, or simple AND/OR gate combinations can perform the decoding.

The alternative method of demultiplexing the address/data lines is to use address decoding devices that are clocked by the NADS signal and provide latched outputs. These latched outputs can then be used as the device/chip select signals during I/O cycles.

Many systems will use some combination of a fully latched Address Bus and simple or latched address decoders. In the discussions that follow, we will not generally describe in detail the method used to obtain the required addressing or select/enabling signals, since the method used is so dependent on the particular system that you are designing.

Once the INS8900 address/data lines have been demultiplexed, the only major considerations we are left with are to ensure that the input/output control signals are of the proper polarity, and to verify that there are no timing problems. We will see that generally the INS8900 I/O control signals must be inverted to operate with the 8080A family of devices, although the 8212 offers us a choice of using the IDS and ODS signals, in either their original or inverted form.

**INS8900 CONTROL SIGNAL POLARITY CONSIDERATIONS**

Now we will provide a few specific examples of how devices from the 8080A family can be used with the INS8900 CPU.

In our first example the 8212 I/O Port is used as a simple input port by the INS8900 CPU. The interconnections required are shown in the following figure:

**THE 8212 USED AS A SIMPLE INPUT PORT IN AN INS8900 SYSTEM**



Here, the INS8900 Address Strobe signal (NADS) is inverted and used as the STB input to the 8212. Since MD is tied to ground, the STB signal clocks the data into the 8212: this will occur every time the INS8900 performs an input/output cycle, but the latched data will only be placed on the System Bus when the 8212 is selected. We accomplish device selection by applying a negative-true decoded address signal to the DS1 input and then using the INS8900 IDS strobe signal as the DS2 input. Now, whenever the proper address is decoded, the IDS signal will cause the data that was previously latched by NADS to be placed on the System Bus for input to the INS8900. The timing would look like this:



Notice that the data from external logic will be latched whenever NADS occurs. The actual selection of the 8212 and input of the latched data to the INS8900 might not occur for quite some time. Frequently, this arrangement will be completely acceptable. If not, then an input-with-handshaking arrangement, which we will describe next, might provide a better solution.

**Before we proceed to our next example, let us make one more general comment about interfacing devices to the INS8900 CPU.**

**The INS8900 is a 16-bit microcomputer: it can transfer 16 bits of parallel data in a single input or output cycle. All of the other devices that we will be discussing are 8-bit devices. Frequently, you may not need the full width of the 16-bit Data Bus when transferring data between the CPU and external logic. In these cases, you can simply connect the data lines to/from the support device to the less significant data lines (D0 - D7) of the INS8900 System Bus, as we have shown in our first example. Masking of the unused, more significant data bits would then be handled under program control.**

When you are going to utilize the full 16 bits of the Data Bus, you merely connect two 8-bit devices in parallel, as described in more detail for the CP1600 in Chapter 16. One device would be connected as we've already described; the data lines of the other device would then be connected to the more significant bits (D8 - D15) of the System Bus. All other connections to the two devices (device select signals, strobe signals, etc.) would be identical.

In this example, we will use the 8212 interrupt request signal INT to establish an input port with handshaking. The connection diagram is very similar to our first example:

THE 8212 USED  
IN AN INS8900  
SYSTEM FOR  
INPUT WITH  
HANDSHAKING



Here, the device select signals are the same as in our first example. However, instead of using the INS8900 NADS signal to clock data into the latches, we will require external logic to input the STB signal when it has data ready. When the data has been latched, the 8212 will output the INT signal, which will be used as the input to one of the INS8900 CPU interrupt request lines (NIR2 - NIR5) or Jump Condition inputs (JC13 - JC15). The CPU will then execute a service routine program that will include an instruction to read the data from the input port. This instruction will send out the input port's address, thus generating the DS1 signal, and then gate the latched

data onto the System Bus when the IDS signal is generated. When the latched data is read out of the 8212, the INT signal returns high to complete the transaction. This sequence is summarized by the following timing diagram:



Using the 8212 as an output port in an INS8900 system requires a simple reversal of the connections we have described in the two preceding examples, and we will now use the ODS (Output Data Strobe) signal from the INS8900 instead of the IDS signal.

THE 8212 USED AS AN OUTPUT PORT IN AN INS8900 SYSTEM



When the output port's address is sent out and decoded from the Address Bus, one input to the AND gate is enabled. The ODS signal then goes high to generate the STB signal and latch the contents of the system Data Bus into the 8212. This will cause the INT signal to go low and inform external logic that data has been loaded into the output port. The external logic will then generate the DST and DS2 signals to gate the data out of the latches. When the data has been gated out, the INT signal will return high. This low-to-high transition could be used as an interrupt request or jump condition input to an INS8900 to enable output of new data. Notice that if we continuously enable the 8212 outputs by tying DST to ground and DS2 to +5V, then whenever the INS8900 loads a new data word into the latch, it will be immediately output to external logic. This approach may be more advantageous in some applications.

Although the 8255 Programmable Peripheral Interface (PPI) is a more complicated device than the 8212, interfacing the 8255 to an INS8900 CPU is no more complicated (from a hardware point of view) than the INS8900-to-8212 interfaces we've described. This is due to the programmability of the 8255; mode control is performed by your program instead of by hardwired signals. Let us look at an example to illustrate this point:

**8255 PPI  
DEVICES  
USED IN  
AN INS8900  
SYSTEM**



The  $\overline{CS}$  signal selects the 8255 and this signal would typically be the output of an address decoder. The A0 and A1 inputs select one of the three I/O ports (A, B or C) or the 8255 Control registers. The  $\overline{RD}$  and  $\overline{WR}$  control signals are obtained by simply inverting the IDS and ODS signals from PACE. A generalized timing diagram for input/output operations would look like this:



If you refer back to the detailed description of the 8255 in Chapter 4, you will see that Port C can be used to provide handshaking signals for I/O control. Since these signals are fully described in Chapter 4, we will not discuss the various possibilities here. Generally, these signals would be used with the INS8900 CPU in the same ways that we earlier described for the 8212 INT signal.

If two 8255s are used in parallel to provide 16-bit I/O ports, there is one special consideration beyond the general rules that we discussed earlier. Recall that mode control of the 8255 is accomplished by writing data into one 8-bit Control register within the device. When wired in parallel, one 8255 would be connected to bits 0 - 7 of the system Data Bus, and the other 8255 would be connected to bits 8 - 15. Therefore, when we send out a 16-bit control word from the INS8900 CPU to establish the desired mode of operation, the upper and lower bytes of the word must be identical.

From a hardware point of view, interfacing either of these devices to an INS8900 CPU is no different than interfacing an 8255 PPI to the INS8900. All we need to do is invert the IDS and ODS signals from the CPU to obtain RD and WR (or I/OR and I/OW) signals, and provide chip select and latched address bits for input to the devices. All other interfacing and usage considerations are software functions and are described in Chapter 4. We will not describe them here since those portions of the device descriptions apply regardless of the CPU being used.

We will conclude our discussion of the use of 8080A devices in INS8900 systems by comparing INS8900 System Bus signals with those of 8080A systems. This comparison will be a useful guide for interfacing any 8080A device to an INS8900 system. Table 15-5 is a summary of INS8900 System Bus signals and the corresponding signals available in 8080A systems. Two separate columns are provided for 8080A signals: the first applies strictly to the 8080A CPU; the right-hand column refers to the signals present in a typical three-chip 8080A system consisting of the CPU, an 8228 System Controller; and an 8224 Clock Generator and Driver.

Since we have already discussed these signals in preceding paragraphs, we won't perform an item-by-item analysis of the table. Nonetheless, there are a few signals in this table that do need additional explanation.

We have included the INS8900 BPS signal in the I/O Control Signal group although it is not the type of signal you would normally classify within this group. However, you will recall that when the BPS input is high, the INS8900 operates in a Base-Page-Split mode; base page then consists of the top 128 words of memory and the bottom 128 words of memory. In our earlier discussion of the BPS signal, we described how this mode can be used to simplify addressing of I/O devices. If you refer back to that discussion, you will see that by doing a little address decoding we can come up with a signal that will tell us when the INS8900 is addressing an I/O device (as opposed to memory). Let us call this decoded signal I/O Device' (I/OD). Now, we can combine this decoded signal with IDS and ODS as shown below to generate signals equivalent to the 8080A I/OR and I/OW signals.



And if we invert the I/OD signal we can generate the 8080A MEMR and MEMW signals.



### TWO 8255 DEVICES USED FOR 16-BIT I/O PORTS WITH INS8900

### THE 8251 USART AND 8253 PROGRAMMABLE COUNTER/TIMER USED IN INS8900 SYSTEMS

### INS8900 AND 8080A SYSTEM BUSSES COMPARED

One other portion of Table 15-5 requires some explanation. **Notice that we have not drawn a line to separate the I/O control signals from the DMA-Related Signals. We've done this intentionally because there is some overlapping of functions with some of these signals.** For example, the INS8900 EXTEND signal can be used either to extend I/O cycles or to suspend I/O to allow DMA operations. We've also compared the INS8900 NHALT output signal to the 8080A WAIT signal. This comparison is valid if limited to the CPU Halt state initiated in either system by a Halt instruction. However, in 8080A systems the WAIT signal is also an acknowledgement to the READY or RDYIN input signals. There is no comparable EXTEND acknowledgement signal in PACE systems.

The 6800 family includes many devices that might be useful in INS8900 systems. Unfortunately, all of these devices have one common requirement which effectively makes them incompatible for use in an INS8900 system. That requirement is the enabling input signal E which, as we mentioned in Chapter 9, should more accurately be described as a synchronizing signal. In 6800 systems, E is usually generated by ANDing one of the primary system clock signals ( $\Phi_2$ ) with the Valid Memory Address signal (VMA) from the 6800 CPU. The clock period of the resulting E signal can be no less than one microsecond. The clock signals (CLK and NCLK) used in PACE systems, however, cannot have a clock period greater than 850 nanoseconds, and therefore cannot be used to simulate the 6800  $\Phi_2$  signal. Therefore, we cannot recommend using 6800 family devices in an INS8900 system.

**6800 SUPPORT  
DEVICES NOT  
COMPATIBLE  
WITH INS8900**

Table 15-5. Comparing INS8900 System Busses to 8080A System Busses

| SYSTEM BUS             | INS8900 SYSTEM SIGNALS                                                            | 8080A CPU SIGNALS | 8080A SYSTEM (CPU, 8228, 8224) SIGNALS |
|------------------------|-----------------------------------------------------------------------------------|-------------------|----------------------------------------|
| Bidirectional Data Bus | D00 - D15 (16 Bits)                                                               | D0 - D7 (8 Bits)  | DB0 - DB7 (8 Bits)                     |
| Address Bus            | D00 - D15<br>Address information must be demultiplexed from Data Bus              | A0 - A15          | A0 - A15                               |
| Control Bus            |                                                                                   |                   |                                        |
| I/O Control Signals    | NADS<br>Strobe signal used by external logic to demultiplex address from Data Bus | —                 | —                                      |
| DMA-Related Signals    | IDS                                                                               | DBIN              | MEMR and I/OR                          |
|                        | ODS                                                                               | WR                | MEMW and I/OW                          |
|                        | BPS                                                                               | —                 | —                                      |
|                        | EXTEND                                                                            | READY             | RDYIN                                  |
|                        | NHALT (output)                                                                    | WAIT              | WAIT                                   |
|                        | NHALT and CONTIN inputs                                                           | HOLD              | HOLD                                   |
|                        | CONTIN (ACK INT output)                                                           | HLDA              | HLDA                                   |
|                        | —                                                                                 | —                 | BUSEN                                  |
| Interrupt Signals      | NIR2 - NIR5                                                                       | INT               | INT                                    |
|                        | CONTIN (ACK INT output)                                                           | D0 and SYNC       | INTA                                   |
|                        | —                                                                                 | INTE              | INTE                                   |
|                        | Non-maskable Interrupt (CONTIN and NHALT inputs)                                  | —                 | —                                      |
| Initialize             | NINIT                                                                             | RESET             | RESIN                                  |
| Jump Condition Inputs  | JC13 - JC15                                                                       | —                 | —                                      |
| Control Flag Outputs   | F11 - F14                                                                         | —                 | —                                      |

## **DATA SHEETS**

The following section contains specific electrical and timing data for the following devices:

PACE CPU  
INS8900  
PACE STE  
PACE BTE

## PACE CPU



FIGURE 4. PACE Driver and Receiver Equivalent Circuits

### external clock timing

PACE requires non-overlapping true and complemented clock inputs as shown in *Figure 5*. Refer to Electrical Characteristics for timing specifications.



FIGURE 5. External Clock Timing

We reprint data sheets on pages 15-D2 through 15-D17 by permission of National Semiconductor Corporation.

## PACE CPU

For systems utilizing memories with access times greater than 2 clock periods it may be desirable to use the EXTEND input to lengthen the I/O cycle by multiples of the clock period. Timing for this is shown in Figure 9. In the case of either input or output operations, the extend should be brought true prior to the end of internal phase 6. The timing shown in Figure 9 will provide the minimum extend of one clock period. Holding EXTEND true for n additional clock periods longer will cause an extension of n + 1 clock periods.

In DMA or multiprocessor systems it may be desirable to prevent I/O operations by PACE when the bus is in use by another device. This may be done by using the EXTEND signal immediately following an IDS or ODS as shown in Figure 10. Alternatively, the extend timing of Figure 9 may be used, as the extend function occurs independent of whether there is an I/O operation, that is, whenever the internal clock phase 6 occurs.



FIGURE 6. Initialization Timing



Figure 7. Address Output and Data Input Timing



FIGURE 8. Data Output Timing

PACE CPU



**FIGURE 9.** Extend I/O Signal Timing

#### **absolute maximum ratings**

#### All Input or Output Voltages with:

+0.3V to -21.5V

#### **Storage Temperature Range**

-65°C to +150°C

#### Respect to Most Positive Supply

### **Lead Temperature (Soldering, 100°C)**

300°C

Voltage ( $V_{BB}$ )

**electrical characteristics** ( $T_a = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{DD} = \pm 5\text{V} \pm 5\%$ ,  $V_{LSS} = -12\text{V} \pm 5\%$ ,  $V_{HSS} = V_{DD} + 2\text{V} \pm 2.5\%$ )

| PARAMETER                                                                                                                                                                                | CONDITIONS                                                   | MIN                | MAX                  | UNITS |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--------------------|----------------------|-------|
| <b>OUTPUT SPECIFICATIONS</b>                                                                                                                                                             |                                                              |                    |                      |       |
| D00-D15, F11-F14, ODS, IDS, NADS (These are open drain outputs which may be used to drive DS3608 sense amplifiers, or may be used with pull-down resistors to provide a voltage output.) |                                                              |                    |                      |       |
| Logic "1" Output Current (Except F11-F14)                                                                                                                                                | V <sub>OUT</sub> = 2.4V                                      | -1.0               | -5.0                 | mA    |
| Logic "1" Output Current, F11-F14 (Note 7)                                                                                                                                               | V <sub>OUT</sub> = 2.4V                                      | -0.7               | -5.0                 | mA    |
| Logic "0" Output Current                                                                                                                                                                 | V <sub>GG</sub> ≤ V <sub>OUT</sub> ≤ V <sub>SS</sub>         | ±10                |                      | μA    |
| NHALT, CONTIN (Low Power TTL Output.)                                                                                                                                                    |                                                              |                    |                      |       |
| Logic "1" Output Voltage                                                                                                                                                                 | I <sub>OUT</sub> = -650μA                                    | 2.4                |                      | V     |
| Logic "0" Output Voltage                                                                                                                                                                 | I <sub>OUT</sub> = 300μA                                     | 0.4                |                      | V     |
| <b>INPUT SPECIFICATIONS</b>                                                                                                                                                              |                                                              |                    |                      |       |
| D00-D15, NIR2-NIR5, EXTEND, JC13-JC15, CONTIN, NINIT, NHALT (These are TTL compatible inputs.) (Note 2)                                                                                  |                                                              |                    |                      |       |
| Logic "1" Input Voltage                                                                                                                                                                  | V <sub>IN</sub> = V <sub>SS</sub> -1V                        | V <sub>SS</sub> -1 | V <sub>SS</sub> +0.3 | V     |
| Logic "0" Input Voltage                                                                                                                                                                  | V <sub>IN</sub> = V <sub>SS</sub> -7V                        | V <sub>SS</sub> -7 | V <sub>SS</sub> -4   | V     |
| Pullup Transistor "ON" Resistance (D00-D15) (Note 3)                                                                                                                                     | V <sub>IN</sub> = V <sub>SS</sub> -1V                        | 5                  |                      | kΩ    |
| Pullup Transistor "ON" Resistance (all others)                                                                                                                                           | V <sub>IN</sub> = V <sub>SS</sub> -1V                        | 5                  |                      | kΩ    |
| Logic "0" Input Current (D00-D15)                                                                                                                                                        | V <sub>IN</sub> = 0.4                                        |                    | -1.8                 | mA    |
| Logic "0" Input Current (NHALT, CONTIN)                                                                                                                                                  | V <sub>IN</sub> = 0.4                                        |                    | -12                  | mA    |
| Logic "0" Input Current (all others)                                                                                                                                                     | V <sub>IN</sub> = 0.4                                        |                    | -3.6                 | mA    |
| Capacitance, Input and Output (except clocks)                                                                                                                                            | V <sub>IN</sub> = V <sub>SS</sub> , f <sub>T</sub> = 500 kHz | 20                 |                      | pF    |
| BPS (This is a MOS Level Input.) (Note 4)                                                                                                                                                |                                                              |                    |                      |       |
| Logic "1" Input Voltage                                                                                                                                                                  | V <sub>IN</sub> = V <sub>SS</sub> -1V                        | V <sub>SS</sub> -1 | V <sub>SS</sub> +0.3 | V     |
| Logic "0" Input Voltage                                                                                                                                                                  | V <sub>IN</sub> = V <sub>SS</sub> -7V                        | V <sub>SS</sub> -7 | V <sub>SS</sub> -4   | V     |
| Logic "1" Input Current                                                                                                                                                                  | V <sub>IN</sub> = V <sub>SS</sub> -1V                        | 100                |                      | μA    |
| CLK, NCLK (These are MOS Clock Inputs)                                                                                                                                                   |                                                              |                    |                      |       |
| Clock "1" Voltage (Note 5)                                                                                                                                                               | V <sub>GG</sub> = V <sub>SS</sub> +3.0V                      | V <sub>SS</sub> -1 | V <sub>SS</sub> +0.3 | V     |
| Clock "0" Voltage                                                                                                                                                                        | V <sub>GG</sub> = V <sub>SS</sub> -3.0V                      | V <sub>GG</sub>    | V <sub>GG</sub> +1   | V     |
| Input Capacitance (Note 6)                                                                                                                                                               | t <sub>p</sub> = .65μs, T <sub>A</sub> = 25°C                | 30                 | 150                  | pF    |
| Bias Supply Current                                                                                                                                                                      | V <sub>BB</sub> = V <sub>SS</sub> + 3.0V                     |                    | 100                  | μA    |
| V <sub>GG</sub> Supply Current                                                                                                                                                           | t <sub>p</sub> = .65μs, T <sub>A</sub> = 25°C                |                    | 40                   | mA    |
| V <sub>SS</sub> Supply Current                                                                                                                                                           | t <sub>p</sub> = .65μs, T <sub>A</sub> = 25°C                |                    | 85                   | mA    |

## PACE CPU



FIGURE 10. Suspend I/O Signal Timing

## TIMING SPECIFICATIONS (See Figures 5 to 10 for additional timing information.)

| CLK, NCLK (See Figure 5) (Referenced to 10% and 90% Amplitude)       |                       |              |              |               |
|----------------------------------------------------------------------|-----------------------|--------------|--------------|---------------|
| Rise and Fall Time ( $t_r, t_f$ )                                    |                       | 10           | 50           | ns            |
| Clock Width ( $t_W$ CLK, $t_W$ NCLK)                                 |                       | 300          | 375          | ns            |
| Clock Non-Overlap ( $t_{NOVA}, t_{NOVB}$ )                           |                       | 5            |              | ns            |
| Clock Period ( $t_p$ )                                               |                       | .65          | .8           | $\mu s$       |
| EXTEND                                                               |                       |              |              |               |
| Individual Extend Duration                                           |                       |              | 2            | $\mu s$       |
| Extend Setup Time ( $t_{ES}$ ) (Note 10)                             |                       | 100          |              | ns            |
| Extend Hold Time ( $t_{EH}$ ) (Note 13)                              |                       | 20           |              | ns            |
| Propagation Delay ( $t_{DD}$ )                                       |                       |              |              |               |
| NHALT, CONTIN (Note 9)                                               | $C_L = 20 \text{ pF}$ |              | 200          | ns            |
| NADS, IDS, ODS, D00-D15 (Note 8)                                     | $V_{OUT} = 2.4V$      |              | 100          | ns            |
| D00-D15                                                              |                       |              |              |               |
| Input Setup Time ( $t_{DS}$ ) (Note 11)                              |                       | 200          |              | ns            |
| Hold Time ( $t_{DH}$ ) (Note 12)                                     |                       | 0            |              | ns            |
| Turn-on or Turn-off Time of Pullup Transistor ( $t_{DC}$ ) (Note 13) |                       | 150          |              | ns            |
| F11-F14 Pulse Flag (PFLG) Pulse Width                                |                       |              |              |               |
| NINIT Initialization Pulse Width                                     |                       | $4t_p - 300$ | $4t_p + 300$ | ns            |
| NIR2-NIR5 Input Pulse Width to Set Latch                             |                       | 8            |              | clock periods |
|                                                                      |                       | 1            |              | clock periods |

Note 1: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under dc electrical characteristics.

Note 2: Pullup transistor provided on chip (See Figure 4.)

Note 3: Pullup transistors on JC13, JC14, JC15 are turned on one out of 8 clock intervals. Pullup transistors on D00-D15 are turned on during last clock period of Input Data Strobe (IDS). Other pullup transistors are on continuously when in data input mode.

Note 4: Pulldown transistor provided on chip.

Note 5: Clamp diodes and series damping resistors may be required to prevent clock overshoot.

Note 6: Capacitance is not constant and varies with clock voltage and internal state of processor.

Note 7: For  $V_{SS} > V_{OUT} > 2.0V$  output current is a linear function of  $V_{OUT}$ .

Note 8: Delay measured from valid logic level on clock edge initiating change to valid current output level.

Note 9: Delay measured from valid logic level on clock edge initiating change to valid voltage output level.

Note 10: With respect to rising edge of NCLK. (See Figure 9 and 10.)

Note 11: With respect to falling edge of CLK. (See Figure 7.)

Note 12: With respect to the valid "0" level on the falling edge of Input Data Strobe (IDS). (See Figure 7.)

Note 13: With respect to valid logic level of appropriate clock.

# INS8900

## Absolute Maximum Ratings

Voltage at Any Pin with Respect to  
 Most Negative Supply ( $V_{BB}$ ) . . . . . -0.3 V to +20 V  
 Operating Temperature Range . . . . . 0°C to +70°C  
 Storage Temperature Range . . . . . -65°C to +150°C  
 Lead Temperature (soldering, 10 seconds) . . . . . +300°C

## Electrical Characteristics

( $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{SS} = 0\text{ V}$ ,  $V_{DD} = +12\text{ V} \pm 5\%$ ,  $V_{CC} = +5\text{ V} \pm 5\%$ ,  $V_{BB} = -8\text{ V} \pm 5\%$ )

| Symbol                       | Parameter                                                                                                                                                | Conditions                                                | Min                  | Max                  | Units         |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|----------------------|----------------------|---------------|
| <b>OUTPUT SPECIFICATIONS</b> |                                                                                                                                                          |                                                           |                      |                      |               |
| $V_{OH}$<br>$V_{OL}$         | D00-D15, F11-F14, ODS, IDS, NADS<br>(These are low-power Schottky-compatible push-pull outputs.)<br>Logic "1" Output Voltage<br>Logic "0" Output Voltage | $I_{OUT} = -500\mu\text{A}$<br>$I_{OUT} = 900\mu\text{A}$ | 2.4                  | 0.4                  | V<br>V        |
| $V_{OH}$<br>$V_{OL}$         | NHALT, CONTIN (low-power Schottky outputs)<br>Logic "1" Output Voltage<br>Logic "0" Output Voltage                                                       | $I_{OUT} = -250\mu\text{A}$<br>$I_{OUT} = 600\mu\text{A}$ | 2.4                  | 0.4                  | V<br>V        |
| <b>INPUT SPECIFICATIONS</b>  |                                                                                                                                                          |                                                           |                      |                      |               |
| $V_{IH}$<br>$V_{IL}$         | D00-D15, NIR2-NIR5, EXTEND, JC13-JC15, NINIT,<br>CONTIN, NHALT (low-power Schottky inputs)<br>Logic "1" Input Voltage<br>Logic "0" Input Voltage         | $V_{SS} \leq V_{IN} \leq V_{CC} + 1$                      | 2.4<br>-1.0          | $V_{CC} + 1$<br>+0.8 | V<br>V        |
| $I_L$                        | Input Leakage Current (except NHALT, CONTIN, JC13-JC15)                                                                                                  | $V_{IN} = 0.4\text{ V}$                                   | 40                   | $\mu\text{A}$        |               |
| $I_{IL}$                     | Logic "0" Input Current, NHALT, CONTIN (Note 2)                                                                                                          | $V_{IN} = 0.4\text{ V}$                                   | -7.0                 | $\text{mA}$          |               |
| $I_{IL}$                     | Logic "0" Input Current, JC13-JC15 (Note 2)                                                                                                              | $V_{IN} = 0.4\text{ V}$                                   | -3.0                 | $\text{mA}$          |               |
| $V_{IH}$<br>$V_{IL}$         | BPS (This is an MOS level input.)<br>Logic "1" Input Voltage<br>Logic "0" Input Voltage                                                                  | $V_{IN} = 13.6\text{ V}$                                  | $V_{DD} - 1$<br>-1.0 | $V_{DD} + 1$<br>+0.8 | V<br>V        |
| $I_{IH}$                     | Logic "1" Input Current (Note 3)                                                                                                                         | $V_{IN} = 13.6\text{ V}$                                  | 750                  | $\mu\text{A}$        |               |
| $V_{CIL}$<br>$V_{CIH}$       | CLKX (This is an MOS level input.)<br>Clock "0" Voltage<br>Clock "1" Voltage                                                                             |                                                           | -1.0                 | +0.8                 | V<br>V        |
| $C_{IN}$                     | Input Capacitance                                                                                                                                        |                                                           | $V_{DD} - 1$         | $V_{DD} + 1$         | $\text{pF}$   |
| $I_{DD}$                     | Average Supply Current ( $V_{DD}$ ) (Note 4)                                                                                                             | $t_P = 500\text{ ns}, T_A = 25^\circ\text{C}$             | 20                   | 100                  | $\text{mA}$   |
| $I_{CC}$                     | Average Supply Current ( $V_{CC}$ ) (Note 4)                                                                                                             | $t_P = 500\text{ ns}, T_A = 25^\circ\text{C}$             | 10                   | 10                   | $\text{mA}$   |
| $I_{BB}$                     | Average Supply Current ( $V_{BB}$ )                                                                                                                      | $V_{BB} = -8\text{ V}$                                    | -200                 | -200                 | $\mu\text{A}$ |

INS8900

## **Timing Specifications**

| Symbol              | Parameter                                                                     | Conditions                                           | Min           | Max           | Units   |
|---------------------|-------------------------------------------------------------------------------|------------------------------------------------------|---------------|---------------|---------|
| $t_r, t_f$          | CLKX<br>Rise and Fall Times (Note 5)<br>(Referenced to 10% and 90% amplitude) |                                                      | 5             | 30            | ns      |
| $t_P$               | Clock Period                                                                  |                                                      | 500           | 650           | ns      |
| $t_{CLK}, t_{NCLK}$ | Pulse Width (Referenced to 50% amplitude)                                     |                                                      | $t_P/2 - 5\%$ | $t_P/2 + 5\%$ | ns      |
| $t_{ES}$            | EXTEND                                                                        |                                                      |               |               |         |
| $t_{EH}$            | Individual Extend Duration                                                    |                                                      |               | 2             | $\mu s$ |
| $t_{ES}$            | Extend Setup Time (Note 6)                                                    |                                                      | 70            |               | ns      |
| $t_{EH}$            | Extend Hold Time (Note 6)                                                     |                                                      | 120           |               | ns      |
| $t_{DD1}$           | Propagation Delay<br>NHALT, CONTIN (Note 7)                                   | $C_L = 40 \text{ pF}$ ,<br>1 low-power Schottky load |               | 200           | ns      |
| $t_{DD2}$           | NADS, IDS, ODS, D00-D15 (Note 7)                                              | $C_L = 40 \text{ pF}$ , 1 INS8208 load               |               | 200           | ns      |
| $t_{D00-D15}$       | D00-D15                                                                       |                                                      |               |               |         |
| $t_{DS}$            | Input Setup Time (Note 6)                                                     |                                                      | 50            |               | ns      |
| $t_{DH}$            | Hold Time (Note 8)                                                            |                                                      | 0             |               | ns      |
| $t_{FW}$            | F11-F14 Pulse Flag (PFLG) Pulse Width                                         |                                                      | $4t_P - 300$  | $4t_P + 300$  | ns      |
| $t_{NW}$            | NINIT Initialization Pulse Width                                              |                                                      | 8             |               | $t_P$   |
| $t_{IRW}$           | NIR2-NIR5 Input Pulse Width to Set Latch                                      |                                                      | 1             |               | $t_P$   |

**Note 1:** Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under DC electrical characteristics.

**Note 2:** NHALT, CONTIN, and JC13-JC15 logic "0" input currents specified when the internal chip loads are putting out a logic "1."

**Note 3:** Pull-down transistor provided on chip.

**Note 4:** Supply currents measured with 40 pF and INS8208 loads.

**Note 5:** Clamp diode and series damping resistor may be required to prevent clock overshoot.

Note 6: Measured with respect to appropriate valid logic level of C1 KX.

**Note 3:** Delay measured from valid logic level on CLK<sub>X</sub> edge initiation change to valid output voltage level.

**Note 8:** With respect to the valid "0" level on the falling edge of Input Data Strobe (IDS).

**Note 8:** With respect to the valid "0" level on the falling edge of Input D.



**Note 10:** Typical output delay versus load capacitance  $C_L$  for load circuit in Note 9:

**Note 11:** Typical V<sub>DD</sub> supply current versus temperature.



## Timing Waveforms



Figure 1. External Clock Timing (CLKX)



Figure 2. Initialization Timing



\*VIN MUST BE AT THE CORRECT LOGIC LEVEL AT THIS TIME.  
NOTE: SIGNALS ARE REFERENCED TO VALID LOGIC LEVELS ON CLOCK INPUT. INTERNAL CLOCK PHASES ARE SHOWN FOR REFERENCE ONLY; THEY ARE NOT AVAILABLE EXTERNALLY.

Figure 3. Address Output and Data Input Timing

## INS8900

## Timing Waveforms (continued)



Figure 4. Data Output Timing



Figure 5. Extend I/O Signal Timing



Figure 6. Suspend I/O Signal Timing

## Timing Waveforms (continued)



Figure 7. Relative Timing for Level-0 Interrupt Generation



Figure 8. Relative Timing for Processor Stall

The architecture of the INS8900 (shown in Figure 9) features a number of resources to minimize system program and read/write storage, increase throughput, and reduce the amount and cost of external support hardware. Principal resources that allow these efficiencies to be achieved include:

Four 16-bit general purpose working registers available to the user reduce the number of memory load and store operations associated with saving temporary and intermediate results in system memory.

An independent 16-bit status and control flag register automatically and continuously preserves system status. The user may operate on its contents as data, allowing masking, testing, and modification of several bit fields simultaneously.

A ten-word (16-bit) last-in, first-out (LIFO) stack inherently decreases response time to interrupts while eliminating both program and read/write system storage overhead associated with storing stack information outside the microprocessor chip.

**Stack full/stack empty** interrupts are provided to facilitate off-chip stack storage in those applications where additional stack capacity is desirable.

A six-level vectored priority interrupt system internal to the chip provides automatic interrupt identification, eliminating both program storage overhead and the time normally required to poll peripherals in order to identify the interrupting device.

Three sense inputs and four control flag outputs allow the user to respond directly to specific combinations of status present in the microprocessor-based system, thus eliminating costly hardware, program overhead, and throughput associated with implementing these functions over the system data bus.

A comprehensive set of input/output control signals provided by the internal control logic simplifies interfaces to memory and peripherals and allows flexible control of INS8900 operations.

Single-phase 2.0 MHz clock input is easily generated with a minimum of external components.

## PACE STE

### recommended crystal specifications

- AT-cut crystal
- 2.6667 MHz  $\pm$  0.1%, fundamental mode
- 5 mW maximum
- 150  $\Omega$  maximum series resistance

### timing diagram



Figure 2.

## PACE STE

### absolute maximum ratings [1]

|                                                    |                 |
|----------------------------------------------------|-----------------|
| Supply Voltage ( $V_{CC}$ ) . . . . .              | 7.0 V           |
| ( $V_{GG}$ ) . . . . .                             | -15.0 V         |
| Input Voltage . . . . .                            | 5.5 V           |
| Storage Temperature . . . . .                      | -65°C to +150°C |
| Lead Temperature (soldering, 10 seconds) . . . . . | 300°C           |

### operating conditions

|                                       | Min.   | Max.  | Units |
|---------------------------------------|--------|-------|-------|
| Supply Voltage ( $V_{CC}$ ) . . . . . | 4.75   | 5.25  | V     |
| ( $V_{GG}$ ) . . . . .                | -11.40 | -12.6 | V     |

Temperature . . . . .

0      +70      °C

### dc electrical characteristics (Notes 2 and 3)

| Parameter                             | Conditions                                                                                             | Min.                     | Typ.           | Max.            | Units         |    |
|---------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------|----------------|-----------------|---------------|----|
| OUTPUT SPECIFICATIONS:                |                                                                                                        |                          |                |                 |               |    |
| T CLK, T CLK* (TTL Clocks)            |                                                                                                        |                          |                |                 |               |    |
| $V_{OH}$ Logic "1" Output Voltage     | $V_{CC} = 4.75\text{ V}$ $I_{OH} = -1\text{ mA}$                                                       | 3.65                     | 4.25           |                 | V             |    |
| $V_{OL}$ Logic "0" Output Voltage     | $V_{CC} = 4.75\text{ V}$ $I_{OL} = 32\text{ mA}$                                                       |                          | 0.25           | 0.4             | V             |    |
| $I_{OS}$ Output Short Circuit Current | (Note 4), $V_{CC} = 5.25\text{ V}$ , $V_O = 0$                                                         | -10                      | -33            | -55             | mA            |    |
| CK, NCK, CLK, NCLK                    |                                                                                                        |                          |                |                 |               |    |
| $V_{OH}$ Logic "1" Output Voltage     | $I_{OH} = -100\mu\text{A}$                                                                             | $V_{CC} = 0.9$           | 4.5            |                 | V             |    |
| $V_{OL}$ Logic "0" Output Voltage     | $V_{CC} = 4.75\text{ V}$ $I_{OL} = 100\mu\text{A}$<br>$V_{GG} = -11.4\text{ V}$ $I_{OL} = 5\text{ mA}$ |                          | $V_{GG} + 0.1$ | $V_{GG} + 0.25$ | V             |    |
| INPUT SPECIFICATIONS:                 |                                                                                                        |                          |                |                 |               |    |
| EXTC                                  |                                                                                                        |                          |                |                 |               |    |
| $V_{IH}$ Logic "1" Input Voltage      |                                                                                                        | 2.0                      |                |                 | V             |    |
| $I_{IH}$ Logic "1" Input Current      | $V_{CC} = 5.25\text{ V}$                                                                               | $V_{IN} = 2.4\text{ V}$  |                | 40              | $\mu\text{A}$ |    |
|                                       |                                                                                                        | $V_{IN} = 5.5\text{ V}$  |                | 1.0             | mA            |    |
| $V_{IL}$ Logic "0" Input Voltage      |                                                                                                        |                          |                | 0.8             | V             |    |
| $I_{IL}$ Logic "0" Input Current      | $V_{CC} = 5.25\text{ V}$                                                                               | $V_{IL} = 0.4\text{ V}$  |                | -0.9            | -1.6          | mA |
| $V_{CLAMP}$ Input Clamp Diode         | $V_{CC} = 4.75\text{ V}$                                                                               | $I_{IL} = -12\text{ mA}$ |                | -0.8            | -1.5          | V  |
| POWER SUPPLY CURRENT                  |                                                                                                        |                          |                |                 |               |    |
| $I_{CC}$ Supply Current from $V_{CC}$ | $V_{CC} = 5.25\text{ V}$                                                                               |                          | 20             | 30              | mA            |    |
| $I_{GG}$ Supply Current from $V_{GG}$ | $V_{GG} = -12.6\text{ V}$                                                                              |                          | -40            | -55             | mA            |    |

### ac electrical characteristics

Crystal Frequency at 2.6667 MHz     $T_A = 0^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{CC} - V_{GG} = +17\text{ V} \pm 5\%$

| Symbol               | Parameter                                                   | Limits |      |      | Units | Test Conditions |
|----------------------|-------------------------------------------------------------|--------|------|------|-------|-----------------|
|                      |                                                             | Min.   | Typ. | Max. |       |                 |
| $t_{NOV1}, t_{NOV2}$ | Non-Overlap Time                                            | 5      | 12   |      | ns    | See Note 5      |
| $t_{PW}$             | MOS Clocks Pulse Width (NCLK, CLK, NCK, CK)                 | 300    | 320  |      | ns    | See Note 5      |
| $t_R$                | MOS Clocks Rise Time (NCLK, CLK, NCK, CK)                   |        |      | 40   | ns    | See Note 5      |
| $t_F$                | MOS Clocks Fall Time (NCLK, CLK, NCK, CK)                   |        |      | 40   | ns    | See Note 5      |
| $t_{PH1}, t_{PH2}$   | TTL Clocks to MOS Clocks High Level Delay                   | -40    | 40   |      | ns    | See Note 5      |
| $t_{PL1}, t_{PL2}$   | TTL Clocks to MOS Clocks Low Level Delay                    |        |      | 80   | ns    | See Note 5      |
| $t_{TD1}, t_{TD2}$   | TTL Clock to TTL Clock Delay                                | -25    | 25   |      | ns    | See Note 5      |
| $t_{START}$          | Time Delay from Last Power Applied to MOS Clocks Stabilized |        |      | 100  | ms    | See Figure 7    |

#### Notes:

- "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. They are not meant to imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation.
- Unless otherwise specified, min/max limits apply across the  $0^\circ\text{C}$  to  $+70^\circ\text{C}$  temperature range and  $V_{CC} = 4.75\text{ V}$  to  $5.25\text{ V}$ ,  $V_{GG} = -11.4\text{ V}$  to  $-12.6\text{ V}$  power supply range. All typicals are given for  $V_{CC} = 5.0\text{ V}$ ,  $V_{GG} = -12\text{ V}$ , and  $T_A = +25^\circ\text{C}$ .
- All currents into device pins are shown as positive; currents out of device pins are shown as negative. All voltages are references to ground unless otherwise noted.
- Only one output at a time should be shorted.
- The test conditions for measuring AC parameters are shown in Figures 2 and 3, with  $C_1 = C_2 = 60\text{ pF}$ ,  $C_3 = 80\text{ pF}$ ,  $C_{NOV} = 60\text{ pF}$ . Load conditions for MOS clocks and TTL clocks are shown in Figures 4 and 5. Including probe and jig capacitance,  $C_{L1} = 20$  to  $80\text{ pF}$ , and  $C_{L2} = 40\text{ pF}$ .

## PACE STE

### test conditions



Figure 3.

NCLK, NCK, CLK, CK LOAD      TCLK\*, TCLK LOAD



Figure 4.

Figure 5.

### typical characteristics



Figure 6.

I<sub>START</sub> = TIME DELAY FROM LAST  
POWER APPLIED TO MOS CLOCKS  
STABILIZED.



Figure 7.

## PACE BTE/8

### absolute maximum ratings (Note 1)

|                                                      |                     |
|------------------------------------------------------|---------------------|
| Supply Voltage                                       | 7V                  |
| Input Voltage (All Inputs Except MBI/O Input Active) | 5.5V                |
| Output Voltage                                       | 5.5V                |
| MOS Bus Input Current                                | $\pm 10 \text{ mA}$ |
| Storage Temperature                                  | -65°C to +150°C     |
| Lead Temperature (Soldering, 10 seconds)             | 300°C               |

### recommended operating conditions

|                             | MIN  | MAX  | UNITS |
|-----------------------------|------|------|-------|
| Supply Voltage ( $V_{CC}$ ) | 4.75 | 5.25 | V     |
| Temperature ( $T_A$ )       | 0    | +70  | °C    |

### dc electrical characteristics (Notes 2 and 3)

| PARAMETER                                     | CONDITIONS                                                                                                                      | MIN                      | TYP          | MAX  | UNITS   |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------|------|---------|
| <b>TTL BUS PORT (BDI/O 00-07)</b>             |                                                                                                                                 |                          |              |      |         |
| $V_{IH}$                                      | Logical "1" Input Voltage                                                                                                       | 2.0                      |              |      | V       |
| $V_{IL}$                                      | Logical "0" Input Voltage                                                                                                       |                          |              | 0.8  | V       |
| $V_{OH}$                                      | Logical "1" Output Voltage<br>WBD* = 0.8V,<br>MBI/O = 0.5 mA                                                                    | $V_{CC}-1.1$             | $V_{CC}-0.8$ |      | V       |
|                                               | $I_{OH} = -1 \text{ mA}$<br>$I_{OH} = -5.2 \text{ mA}$                                                                          | 2.4                      | 3.7          |      | V       |
| $V_{OL}$                                      | Logical "0" Output Voltage<br>WBD* = 0.8V,<br>MBI/O = 100 $\mu$ A                                                               | $I_{OL} = 20 \text{ mA}$ | 0.25         | 0.4  | V       |
|                                               |                                                                                                                                 | $I_{OL} = 50 \text{ mA}$ | 0.4          | 0.5  | V       |
| $I_{OS}$                                      | Output Short Circuit Current<br>WBD* = 0.8V, MBI/O = 0.5 mA,<br>$V_{OUT} = 0V$ , $V_{CC} = 5.25V$ , (Note 4)                    | -10                      | -35          | -75  | mA      |
| $I_{IH}$                                      | Logical "1" Input Current<br>WBD* = 2V, $V_{IH} = 2.4V$                                                                         |                          |              | 80   | $\mu$ A |
| $I_I$                                         | Input Current at Maximum<br>Input Voltage<br>WBD* = 2V, $V_{IH} = 5.5V$ ,<br>$V_{CC} = 5.25V$                                   |                          |              | 1    | mA      |
| $I_{IL}$                                      | Logical "0" Input Current<br>WBD* = 2V, $V_{IL} = 0.4V$                                                                         |                          | -10          | -250 | $\mu$ A |
| $V_{CLAMP}$                                   | Input Clamp Voltage<br>WBD* = 2V, $I_{IN} = -12 \text{ mA}$                                                                     |                          | -0.2         | -1.5 | V       |
| $I_{OD}$                                      | Output/Input Bus Disable Current<br>WBD* = STR* = 2V, BDI/O = 0.4V<br>to 4V, $V_{CC} = 5.25V$                                   | -80                      |              | 80   | $\mu$ A |
| <b>MOS BUS PORT (MBI/O 00-07)</b>             |                                                                                                                                 |                          |              |      |         |
| $I_O$                                         | Logical "0" Input Current<br>WBD* = 0.8V, $I_{OL(TTL)} = 50 \text{ mA}$ ,<br>$V_{OL} \leq 0.5V$ , (Note 5)                      | -5.0                     |              | 0.10 | mA      |
| $I_1$                                         | Logical "1" Input Current<br>WBD* = 0.8V, $I_{OH(TTL)} = -1 \text{ mA}$ ,<br>$V_{OH} \geq V_{CC} - 1.1V$ , (Notes 5 and 6)      | 0.50                     |              | 5.0  | mA      |
| $V_O$                                         | Logical "0" Input Voltage<br>WBD* = 0.8V, $I_{OL(TTL)} = 50 \text{ mA}$ ,<br>$V_{OL} \leq 0.5V$                                 |                          |              | 0.8  | V       |
| $V_1$                                         | Logical "1" Input Voltage<br>WBD* = 0.8V, $I_{OH(TTL)} = -1 \text{ mA}$ ,<br>$V_{OH} \geq V_{CC} - 1.1V$                        | 2.0                      | 1.5          |      | V       |
| $V_{OH}$                                      | Logical "1" Output Voltage<br>WBD* = CE1 = BDI/O = 2V,<br>$I_{OH(MOS)} = -1 \text{ mA}$ , CE2* =<br>STR* = 0.8V                 | 2.4                      | 3.3          |      | V       |
| $V_{OL}$                                      | Logical "0" Output Voltage<br>WBD* = CE1 = 2V, $I_{OL(MOS)} =$<br>5 mA, CE2* = STR* = BDI/O = 0.8V                              |                          | 0.28         | 0.5  | V       |
| $I_{OS}$                                      | Output Short Circuit Current<br>WBD* = CE1 = BDI/O = 2V,<br>$V_{CC} = 5.25V$ , $V_{OUT} = 0V$ ,<br>STR* = CE2* = 0.8V, (Note 4) | -7                       | -15          | -45  | mA      |
| $V_{CLAMP}$                                   | Input Clamp Voltage<br>$I_{IN} = -12 \text{ mA}$                                                                                |                          |              | -1.5 | V       |
| $I_{OD}$                                      | Output/Input Bus Disable Current<br>MBI/O = 0.4V to 4V, $V_{CC} = 5.25V$                                                        | -80                      |              | 80   | $\mu$ A |
| <b>CONTROL INPUTS (WBD*, CE1, CE2*, STR*)</b> |                                                                                                                                 |                          |              |      |         |
| $V_{IH}$                                      | Logical "1" Input Voltage                                                                                                       | 2.0                      |              |      | V       |
| $V_{IL}$                                      | Logical "0" Input Voltage                                                                                                       |                          |              | 0.8  | V       |
| $I_{IH}$                                      | Logical "1" Input Current<br>$V_{IN} = 2.4V$                                                                                    |                          |              | 20   | $\mu$ A |
| $I_1$                                         | Input Current at Maximum<br>Input Voltage<br>$V_{IN} = 5.5V$                                                                    |                          |              | 1.0  | mA      |

**PACE BTE/8****dc electrical characteristics** (Continued) (Notes 2 and 3)

| PARAMETER                                                 | CONDITIONS                                      | MIN | TYP   | MAX  | UNITS |
|-----------------------------------------------------------|-------------------------------------------------|-----|-------|------|-------|
| <b>CONTROL INPUTS (WBD*, CE1, CE2*, STR*) (continued)</b> |                                                 |     |       |      |       |
| I <sub>IL</sub>                                           | Logical "0" Input Current<br>VIN = 0.4V         |     | -250  | -400 | µA    |
| V <sub>CLAMP</sub>                                        | Input Clamp Voltage<br>I <sub>IN</sub> = -12 mA |     | -0.85 | -1.5 | V     |
| <b>POWER SUPPLY CURRENT</b>                               |                                                 |     |       |      |       |
| I <sub>CC</sub>                                           | Power Supply Current<br>V <sub>CC</sub> = 5.25V |     | 70    | 110  | mA    |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. They are not meant to imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation.

Note 2: Unless otherwise specified, min/max limits apply across the 0°C to +70°C temperature range and the 4.75V to 5.25V power supply range. All typicals are given for V<sub>CC</sub> = 5V and T<sub>A</sub> = 25°C.

Note 3: All currents into device pins are shown as positive, out of device pins are negative. All voltages are referenced to ground unless otherwise noted.

Note 4: Only one output at a time should be shorted.

Note 5: The MBI/O Input Characteristic Graph illustrates this parameter and defines the regions of guaranteed logical "0" and logical "1" outputs. See equivalent input structure for clarification. When the MBI/O input is loaded with a high impedance source (open), the TTL output will be in the logic "0" state.

Note 6: The maximum MOS bus positive input current specification is intended to define the upper limit on guaranteed input clamp operation. At higher input currents (up to the absolute maximum rating) clamp operation is not guaranteed but TTL bus logic state is valid and no device damage will occur.

Note 7: In most applications the MOS bus data lines are higher impedance and more sensitive to noise coupling than TTL bus lines. Conservative design practice would dictate routing MOS bus lines away from high speed, low impedance TTL lines and MOS clock lines or providing a ground shield when they are adjacent.

**ac electrical characteristics** V<sub>CC</sub> = 5V ±5%, T<sub>A</sub> = 0°C to +70°C

| PARAMETER                                | CONDITIONS                                                                                                    | MIN  | TYP | MAX | UNITS |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------|------|-----|-----|-------|
| <b>DATA TRANSFER SPECIFICATIONS</b>      |                                                                                                               |      |     |     |       |
| Receiving Mode (BDI/O Bus to MBI/O Bus)  | WBD* = 3V, C <sub>L</sub> = 15 pF,<br>R <sub>L</sub> = 1 kΩ, (Figures 4 and 6)                                | tpd0 | 17  | 40  | ns    |
|                                          |                                                                                                               | tpd1 | 20  | 40  | ns    |
| Driving Mode (MBI/O Bus to<br>BDI/O Bus) | WBD* = CE1 = 0V,<br>STR* = CE2* = 3V,<br>C <sub>L</sub> = 50 pF, R <sub>L</sub> = 100 Ω,<br>(Figures 3 and 5) | tpd0 | 40  | 60  | ns    |
|                                          |                                                                                                               | tpd1 | 40  | 60  | ns    |
| <b>TRANSCEIVER MODE SPECIFICATIONS</b>   |                                                                                                               |      |     |     |       |
| Select Bus                               |                                                                                                               |      |     |     |       |
| t <sub>DS</sub>                          | Chip Enable Data Set-Up<br>(Figure 1)                                                                         | 45   | 23  |     | ns    |
| t <sub>DH</sub>                          | Chip Enable Data Hold<br>(Figure 1)                                                                           | 0    |     |     | ns    |
| t <sub>ES</sub>                          | Set-Up<br>(Figure 1)                                                                                          | 0    |     |     | ns    |
| <b>TTL Data Bus (BDI/O 00-07)</b>        |                                                                                                               |      |     |     |       |
| t <sub>BDO</sub>                         | Bus Data Output Disable<br>C <sub>L</sub> = 5 pF, R <sub>L</sub> = 100 Ω, (Figure 1)                          | 5    | 20  | 50  | ns    |
| t <sub>BDE</sub>                         | Bus Data Output Enable<br>C <sub>L</sub> = 50 pF, R <sub>L</sub> = 100 Ω, (Figure 1)                          |      | 25  | 80  | ns    |
| t <sub>BIE</sub>                         | Bus Data Input Enable<br>(Figure 1)                                                                           |      | 30  |     | ns    |
| t <sub>BID</sub>                         | Bus Data Input Disable<br>(Figure 1)                                                                          |      | 30  |     | ns    |
| <b>MOS Data Bus (MBI/O 00-07)</b>        |                                                                                                               |      |     |     |       |
| t <sub>MBDO</sub>                        | MOS Bus Output Disable<br>C <sub>L</sub> = 15 pF, R <sub>L</sub> = 1 kΩ, (Figure 1)                           | 15   | 50  | 100 | ns    |
| t <sub>MBDE</sub>                        | MOS Bus Output Enable<br>C <sub>L</sub> = 15 pF, R <sub>L</sub> = 1 kΩ, (Figure 1)                            |      | 50  | 100 | ns    |
| t <sub>MBIE</sub>                        | MOS Bus Input Disable<br>(Figure 1)                                                                           |      | 55  |     | ns    |
| t <sub>MBID</sub>                        | MOS Bus Input Enable<br>(Figure 1)                                                                            |      | 20  |     | ns    |
| Select Bus                               |                                                                                                               |      |     |     |       |
| t <sub>CLR</sub>                         | Clear Previous Chip Enable<br>(Figure 2)                                                                      |      | 25  | 50  | ns    |

# PACE BTE/8

## switching time waveforms and ac test circuits



FIGURE 1



FIGURE 2



FIGURE 3. BDI/O Bus



\*This input network simulates the actual drive characteristic of the PACE outputs  
FIGURE 5. MBI/O to BDI/O ac Loads



FIGURE 4. MBI/O Bus



FIGURE 6. BDI/O to MBI/O ac Loads

Note 1: Freq = 1 MHz, duty cycle = 50%,  $t_R = t_F \leq 10$  ns (refer to Figures 5 and 6).

Note 2: All capacitance values include probe and jig capacitance (refer to Figures 5 and 6).

## PACE BTE/8

### typical performance characteristics



# Chapter 16

## THE GENERAL INSTRUMENT CP1600

**The CP1600 and the TMS 9900 were the first two NMOS 16-bit microprocessors commercially available.** Even a superficial inspection of the CP1600 shows it to be more powerful than the National Semiconductor Pace (or 8900). **yet the CP1600 is not widely used.** This is because General Instrument does not support the CP1600 to the extent that National Semiconductor supports Pace, or most manufacturers support their 8-bit microprocessors.

**General Instrument's marketing philosophy has been to seek out very high-volume customers;** General Instrument supports low-volume customers only to the extent that this support would not require substantial investment on the part of General Instrument.

From the viewpoint of the low-volume microprocessor user, General Instrument's marketing philosophy is unfortunate. The CP1600 is an ideal microprocessor for the more sophisticated video games that are appearing, and its rich instruction set and capable architecture make it an ideal choice for data processing terminals and home computer systems. However, due to its limited support, potential low-volume CP1600 customers are likely to choose another equally capable product.

**Three CP1600 parts are available, differentiated only by the clock speeds for which they have been designed.**

The CP1600 requires a 3.3 MHz, two-phase clock and generates a 600 nanosecond machine cycle time.

The CP1600 requires a 4 MHz, two-phase clock and generates a 500 nanosecond machine cycle time.

The CP1610 requires a 2 MHz, two-phase clock and generates a 1 microsecond cycle time.

**In addition to the CP1600 microprocessors themselves, the CP1680 Input/Output Buffer (IOB) is described in this chapter. Additional support devices for the CP1600 may be found in Volume 3.**

The sole source for the CP1600 is:

GENERAL INSTRUMENT  
Microelectronics Division  
600 West John Street  
Hicksville, New York 11802

**There is no second source for the CP1600.** General Instrument has a policy of discouraging second sources for its product line.

The CP1600 is fabricated using NMOS ion implant LSI technology; the device is packaged as a 40-pin DIP.

Three power supplies are required: +12V, +5V and -3V.

### THE CP1600 MICROCOMPUTER SYSTEM OVERVIEW

**Logic of our general microcomputer system which has been implemented by the CP1600 CPU is illustrated in Figure 16-1.**

**Observe that the CP1600 requires external logic to create its various timing and clock signals.**

**Some bus interface logic is shown as absent because a number of devices must surround the CP1600;** these include:

- 1) An address buffer, since data and addresses are multiplexed on a single 16-bit bus.
- 2) Buffer amplifiers to provide the power required by the type of memory and I/O devices that will normally be connected to a CP1600 CPU.
- 3) A one-of-eight decoder chip to create eight individual control signals out of three controls output by the CP1600.
- 4) A one-of-sixteen multiplex chip to funnel sixteen external status signals into the CP1600 if using external branches.

Were you to compare Figure 16-1 with an equivalent figure for a low-end microprocessor such as the SC/MP (which is described in Chapter 3), the CP1600 might appear to offer fewer logic functions; but within the functions it does provide, the CP1600 provides considerably more logic and program execution capabilities. Where low-end microprocessors choose to condense, onto a single chip, simple implementations of different logic functions, high-end products such as the CP1600 choose to provide more devices — with greater capabilities on each device.



Figure 16-1. Logic of the CP1600 CPU and CP1680 I/O Buffer

## CP1600 PROGRAMMABLE REGISTERS

The CP1600 has eight 16-bit programmable registers, which may be illustrated as follows:



The way in which the registers illustrated above are used is unusual when compared to other microcomputers described in this book. All eight 16-bit registers can be addressed as though they were general purpose registers; however, only Register R0 has no other assigned function. We may therefore look upon Register R0 as the Primary Accumulator for this CPU.

Registers R1, R2, and R3 serve as general purpose registers, but may also be used as Data Counters.

In addition to serving as general purpose registers, R4 and R5 may be used as auto-incrementing Data Counters. Memory reference instructions that identify Register R4 or R5 as holding the implied memory address will cause the contents of Register R4 or R5 to be incremented — after the memory reference instructions have completed execution.

Registers R6 and R7, in addition to being accessible as general purpose registers, also serve as a Stack Pointer and a Program Counter, respectively.

Having the Stack Pointer accessible as a general purpose register makes it quite simple to maintain more than one Stack in external memory; also, you can easily address the Stack as data memory using the Stack Pointer as a Data Counter.

Having the Program Counter accessible as a general purpose register can be useful when executing various types of conditional branch logic.

While having the Stack Pointer and the Program Counter accessible as though they were general purpose registers may appear strange, this is a feature of the PDP-11 minicomputer — and is a very powerful programming tool.

## CP1600 MEMORY ADDRESSING MODE

The CP1600 addresses memory and I/O devices within a single address space.

When referencing external memory, you can use direct addressing, implied addressing, or implied addressing with auto-increment.

Direct addressing instructions are all two or more words long, where the second or last word of the instruction object code provides a 16-bit direct address.

**CP1600 DIRECT ADDRESSING**

CP1600 direct addressing instructions are complicated by the fact that CP1600 program memory is frequently only 10 bits wide. That is to say, even though the CP1600 is a 16-bit microprocessor, its instruction object codes are only 10 bits wide. If program memory is only 10 bits wide, then direct addresses will only be 10 bits wide. A 10-bit direct address will access the first 1024 words of memory only.

Were you to implement a 16-bit wide program memory, then you could directly address up to 65,536 words of memory; however, six bits of the first object program word for every instruction in program memory would be wasted. This may be illustrated as follows:



**Instructions that reference memory using implied addressing identify general purpose Register R1, R2, or R3 as containing the implied address.**

#### CP1600 IMPLIED ADDRESSING

A memory reference instruction which identifies Register R4 or R5 as providing the external memory address will always cause Register R4 or R5 contents to be incremented following the memory access; thus you have implied memory addressing with auto-increment.

**Memory reference instructions that specify implied memory addressing via Register 1, 2, 3, 4, or 5 can access 8-bit memory.** An SDBD instruction executed directly before a valid memory reference instruction forces the memory reference instruction to access memory one byte at a time. If implied memory addressing via Register 1, 2, or 3 is specified, then the same byte of memory will be accessed twice. For an instruction that loads the contents of data memory into Register R0, this may be illustrated as follows:



If Register R4 or R5 provides the implied memory address for the instruction which follows an SDBD instruction, then the implied memory address is incremented twice, and two sequential low-order bytes of data are accessed. For an instruction which loads data into Register R0, this may be illustrated as follows:



The SDBD instruction may also precede an immediate instruction. Now the immediate data will be fetched from the low-order byte of the next two sequential program memory locations. This may be illustrated as follows:



Without the preceding SDBD instruction, an immediate instruction will access the next single program memory word to find the required immediate data. Ten or more bits of immediate data will be accessed, depending on the width of program memory words.

**The CP1600 has no Stack reference instructions such as a Push or Pull; rather, a variety of memory reference instructions can identify Register R6 as providing the implied address.**

When Register R6 provides the implied address, it is treated as an upward migrating Stack Pointer. When a memory write operation specifies Register R6 as providing the implied memory address, Register R6 contents will be incremented following the memory write. A memory read instruction that specifies Register R6 as providing the implied memory address will cause the contents of Register R6 to be decremented before the read operation occurs.

**CP1600  
STACK  
ADDRESSING**

**An unusual feature of the CP1600 is the fact that a variety of secondary memory reference instructions can also reference memory via the Stack Pointer.** When these instructions are executed, Register R6 contents are decremented before the memory access occurs — as though a Pull operation from the Stack were being executed.

Logically, Register R6, the Stack Pointer, is being handled as though it were a Data Counter with post-increment and pre-decrement.

Jump instructions use direct memory addressing. Jump instructions are all three words long. The direct address is computed from the second and third memory words as follows:



AAAAAAABBBBBBBB Jump address (binary)

yy are enable/disable bits for interrupts

xx identify the register where the return address will be stored for JSR

xx and yy are described in detail in Table 16-4.

You can enable or disable interrupts whenever you execute a Jump or Jump-to-Subroutine instruction.

The only difference between a Jump instruction and a Jump-to-Subroutine instruction is that the Jump-to-Subroutine instruction saves the Program Counter contents in Register 4, 5, or 6. The two high-order bits (xx) or the second Jump-to-Subroutine object code word specifies which of the three registers will be used to hold the return address.

Jump-to-Subroutine instructions, like the Jump instruction, allow direct memory addressing only.

## CP1600 STATUS AND CONTROL FLAGS

**The CP1600 CPU has four of the standard status flags; in addition, it has some unusual control signals.**

**These are the four standard status flags:**

Sign (S). This status is set equal to the high-order bit of any arithmetic operation result.

Zero (Z). This status is set to 1 when any instruction's execution creates a zero result. The status is set to 0 for a nonzero result.

The Carry (C) and Overflow (O) statuses are standard carry and overflow, as described in Volume 1.

**Four control signals (EBCA0 - EVCA3) are output during a Branch-on-External (BEXT) instruction.** These four signals are output to reflect the low-order four bits of the BEXT instruction's object code. External logic receives these four signals and (depending on their state), may or may not return a high input via EBCI. If EBCI is returned high, then the BEXT instruction will perform a branch; if EBCI is returned low, then the BEXT instruction will cause the next sequential instruction to be executed. The four control signals EBCA0 - EBCA3 therefore provide the CP1600 with a means of testing 16 external conditions.

## CP1600 CPU PINS AND SIGNALS

**CP1600 CPU pins and signals are illustrated in Figure 16-2.**

**D0 - D15 is a multiplexed Address and Data Bus.** Given a total of 40 pins in a package, CP1600 designers have been forced to share 16 pins between addresses and data. **Three control signals, BDIR, BC1, and BC2, identify the traffic on the Address/Data Bus.** External logic (one MSI chip) must decode these three signals to create eight control signals, as summarized in Table 16-1.

**Remaining signals may be divided into four groups: timing, status/control, interrupt, and DMA.**

**Two timing clock signals are required:  $\Phi 1$  and  $\Phi 2$ .** These are complementary clock signals which may be illustrated as follows:





Figure 16-2. CP1600 CPU Signals and Pin Assignments

**MSYNC** is a somewhat unusual signal, as compared to other microcomputer clock signals in this book. Following powerup, **MSYNC** must be held low for at least 10 milliseconds. On the subsequent rising edge of **MSYNC**, logic internal to the CP1600 CPU will synchronize the  $\Phi_1$  and  $\Phi_2$  clock signals to start a new machine cycle. Most of the CPU devices we have described in this book use a reset signal, or have internal powerup logic which performs this clock synchronization.

#### Now consider the status and control signals.

First of all, there are the four control outputs which we have already described: **EBCA0 - EBCA3**. There is one conditional Branch instruction (**BEXT**) which will only branch if a high signal is input via **EBCI**. When the **BEXT** instruction is executed, the low-order four **BEXT** instruction object code bits are output via **EBCA0 - EBCA3**. External logic is supposed to decode these four signals by whatever means are appropriate — and thence determine whether **EBCI** should be input high or low. A high input, as we have just stated, will result in a branch; a low input will cause the next sequential instruction to be executed.

In reality, there is no connection within CP1600 CPU logic between the **EBCI** input and the four **EBCA0 - EBCA3** outputs. So far as external logic is concerned, the execution of a **BEXT** instruction is identified by signal levels output and maintained on the **EBCA0 - EBCA3** outputs, while the **EBCI** input determines whether a branch will or will not occur. How external logic chooses to determine whether **EBCI** will be set high or low is entirely up to external logic. The only vital function served by **EBCA0 - EBCA3** is to identify the instant at which a **BEXT** instruction is executed.

Another unusual control signal provided by the CP1600 is **PCIT**; this is a bidirectional signal. When input low, this signal prevents the Program Counter from being incremented following an instruction fetch. This signal is also output as a low pulse following execution of a software interrupt instruction. Instruction timing separates the active input and

active output of this signal; providing external logic adheres to timing requirements, a conflict between input and output logic will never arise.

**BDRDY** is equivalent to the **WAIT** signal we have described for a number of other microcomputers. **BDRDY** is input low by any external logic which requires more time in order to respond to an I/O access. Recall that the CP1600 uses a single address space to reference memory or I/O devices. The **BDRDY** signal causes the CPU to enter a Wait state for as long as **BDRDY** is being input low; however, during the Wait state CPU logic is not refreshed. Thus a Wait state cannot last for more than 40 microseconds, or the contents of internal CPU locations will be lost.

**STPST**, a **Halt/Reset** input, is an edge-triggered signal. When external logic inputs a high-to-low transition via **STPST**, the CPU will complete execution of any interrupt instruction, then will enter a Halt state and output **HALT** high. If a non-interruptable instruction is being executed, then the Halt state will not be entered until completion of next interruptable instruction's execution. The Halt state will last until external logic inputs another high-to-low **STPST** transition, at which time the Halt output will be returned low and normal programming execution will continue. Execution of the **HLT** instruction also causes the CP1600 to enter a Halt state, as described above.

#### Let us now look at interrupt signals.

The CP1600 has two interrupt request inputs — **INTR** and **INTRM**. **INTR** has higher priority than **INTRM**. **INTR** cannot be disabled. Typically, **INTR** will be used to trigger an interrupt upon power failure or other catastrophes.

The interrupt acknowledge signal is created by external logic which must decode the **BC1**, **BC2**, and **BDIR** signals, as shown in Table 16-1. Observe that there are, in fact, two interrupt acknowledge signals; the first (**INTAK**) acknowledges the interrupt itself, while the second (**DAB**) is used as a strobe for external logic to return an interrupt address vector. The interrupt sequence is described later in this chapter.

The CP1600 has two additional interrupt-related signals which are unusual when compared to other microcomputers described in this book.

**TCI** is output high when an End-of-Interrupt instruction is executed. This signal makes it easy for external logic to generate interrupt priorities which extend across the execution of an interrupt service routine. We have discussed this subject in some detail while describing the 8259 Priority Interrupt Control Unit in Chapter 4.

Table 16-1. CP1600 Bus Control Signals

| BC1 | BC2 | BDIR | SIGNAL | FUNCTION                                                                                                                                                                                                                |
|-----|-----|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | 0   | 0    | NACT   | The CPU is inactive and the Data/Address Bus is in a high impedance state.                                                                                                                                              |
| 0   | 0   | 1    | BAR    | A memory address must be input to the CPU via the Data/Address Bus.                                                                                                                                                     |
| 0   | 1   | 0    | IAB    | Acknowledged external interrupt requesting logic must place the starting address for the interrupt service routine on the Address Bus.                                                                                  |
| 0   | 1   | 1    | DWS    | Data write strobe for external memory.                                                                                                                                                                                  |
| 1   | 0   | 0    | ADAR   | This signal identifies a time interval during which the Data/Address Bus is floated, while data input on the Data Bus is being interpreted as the effective memory address during a direct memory addressing operation. |
| 1   | 0   | 1    | DW     | The CPU is writing data into external memory. DW will precede DWS by one machine cycle.                                                                                                                                 |
| 1   | 1   | 0    | DTB    | This is a read strobe which external memory or I/O logic can use in order to place data on the Data/Address Bus.                                                                                                        |
| 1   | 1   | 1    | INTAK  | This is an interrupt acknowledge signal. It is followed by IAD which is a strobe telling the external logic which is being acknowledged to identify itself by placing an address vector on the Data/Address Bus.        |



Figure 16-3. CP1600 Machine Cycles and Bus Timing



Figure 16-4. CP1600 Instruction Fetch Timing



Figure 16-5. CP1600 Timing for Memory Read Instruction with Implied Memory Addressing

## CP1600 INSTRUCTION TIMING AND EXECUTION

**CP1600 instructions are executed as a sequence of machine cycles. Each machine cycle has four clock periods, as illustrated in Figure 16-3.** Machine cycles are identified by their cycle number and by the levels of the BC1, BC2, and BDIR signals. Each of the eight level combinations is given a name, taken from Table 16-1. This name becomes the name of the machine cycle. Thus in Figure 16-4, and in subsequent instruction timing illustrations, **each machine cycle is identified by a signal name from Table 16-1.**

Figure 16-3 shows general case timing for data output or input on the Data/Address Bus. In between data input or output operations the bus is floated.

### CP1600 MEMORY ACCESS TIMING

**Figure 16-4 illustrates instruction fetch timing for a CP1600 instruction's execution.** Three machine cycles are required. During the first machine cycle an address is output. Nothing happens during the second machine cycle; it is a "time spacing" machine cycle that routinely separates two CP1600 Bus access machine cycles. The object code for the accessed instruction is returned during the third machine cycle.

**Figure 16-5 illustrates timing for the simplest memory read instruction's execution.** In this case the data memory address is taken from one of the CPU registers. There is no difference between timing for the three machine cycles of an instruction fetch or a data memory read. As illustrated in Figure 16-5, a simple memory read instruction's execution consists of two three-machine cycle memory read operations, separated by a spacing no operation machine cycle.



Figure 16-6. CP1600 Timing for Memory Write Instruction with Implied Memory Addressing

**Figure 16-6 illustrates timing for a simple CP1600 memory write instruction execution.** Data is output for two machine cycles, giving external logic ample time to respond to the data output. External logic uses the DWS machine cycle as a write strobe.

Any memory reference instruction that specifies direct memory addressing will require one three-clock-period machine cycle to fetch each word of the instruction object code; an NACT clock period will separate each machine cycle. After the first instruction fetch machine cycle, an ADAR-NACT clock period combination will be inserted in the second (and third, if present) instruction fetch machine cycle. During an ADAR clock period, BC1 is high, while BC2 and BDIR are low. No other control signals are active. Thus, **for a two-word memory read or memory write instruction that specifies direct addressing, the following clock periods and machine cycles will be required for instruction execution:**





Figure 16-7. CP1600 Wait State Timing

### THE CP1600 WAIT STATE

The CP1600 has a Wait state equivalent to those described for other microcomputers in this book. External logic that requires more time to respond to an access must input BDRDY low before the end of the BAR machine cycle, during which an address is output and the device is selected. **Timing is illustrated in Figure 16-7.**

If you examine Figures 16-4, 16-5 and 16-6, you will see that an address is output during a BAR machine cycle to initiate any external device access. The BAR machine cycle is always followed by an NACT machine cycle; in the middle of T1 during this NACT machine cycle, the CP1600 samples BDRDY. If BDRDY is low, then a sequence of NACT machine cycles occurs. In the middle of T4 for every NACT machine cycle, the CP1600 samples BDRDY again. Upon detecting BDRDY high, the CP1600 resumes instruction execution with a DTB machine cycle.

A Wait state must last for less than 40 microseconds, since the CP1600 is a dynamic device.

### THE CP1600 HALT STATE

The CP1600 has a Halt state which may follow execution of the Halt instruction, or may be initiated by external logic.

When the Halt instruction is executed, then, following the instruction fetch machine cycle, the HALT signal is output high and a sequence of NACT machine cycles is executed.

External logic initiates a Halt state by making the STPST input undergo a high-to-low transition. Following execution of the next interruptable instruction, a Halt state begins. The HALT signal is output high and a sequence of NACT machine cycles is executed.

A Halt state, whether it is initiated by execution of a Halt instruction or by a high-to-low transition of STPST, must be terminated by a high-to-low transition of STPST. This will cause the Halt state to end at the conclusion of the next NACT machine cycle. Timing for a Halt state which is initiated and terminated by STPST may be illustrated as follows:



The **PCIT** signal as an input inhibits CP1600 Program Counter increment logic. Thus, external logic can input PCIT low — in which case the same instruction will be continuously re-executed until PCIT goes high again. However, PCIT should only change levels while the CPU has been halted. Thus, **PCIT** and **STPST** should be used together as follows:

**CP1600  
PCIT  
SIGNAL**



## CP1600 INITIALIZATION SEQUENCE

The CP1600 is initialized by inputting the **MSYNC** signal low for a minimum of 10 milliseconds after power is first applied to the CPU.

MSYNC must make a low-to-high transition, marking the end of the initialization, on a rising edge of the  $\Phi_1$  clock signal. On the next rising edge of  $\Phi_1$ , instruction execution will begin. This may be illustrated as follows:



When instruction execution begins, interrupts are disabled. The following sequence of machine cycles is executed:

|      |     |                                                            |
|------|-----|------------------------------------------------------------|
| NACT | IAB | ← Read Data/Address Bus and load into Program Counter      |
| NACT |     |                                                            |
| NACT |     |                                                            |
| NACT |     |                                                            |
| BAR  | ←   | Output Program Counter contents to fetch first instruction |
| NACT |     |                                                            |
| DTB  |     |                                                            |
| etc  |     |                                                            |

During the IAB machine cycle, external logic must supply a 16-bit address at D0 - D15. Your external logic must provide this address, which in the simplest case may be 0000 by grounding the bus, or FFFF<sub>16</sub> by tying it to +5V following a startup.

The address which is input at IAB is output at BAR, initiating program execution.

## CP1600 DMA LOGIC

CP1600 DMA logic is quite standard. When external logic wishes to transfer data under DMA control, it inputs **BUSRQ** low. At the conclusion of the next interruptable instruction's execution, the CPU floats the Data/Address Bus and enters a Wait state, during which a sequence of **NACT** machine cycles is executed. **BUSAK** is output low at the beginning of the first NACT machine cycle.

The **NACT** machine cycles that occur during a DMA operation refresh the CPU. NACT machine cycles that occur during a Wait state do not refresh the CPU. This means that any number of NACT machine cycles can occur during a DMA break, while a Wait state must be shorter than 40 microseconds.

The DMA break ends when external logic inputs **BUSRQ** high again. **BUSRQ** is sampled during T1 of every DMA NACT machine cycle. When **BUSRQ** is sampled high, two additional NACT machine cycles are executed, then **BUSAK** is output high and normal program execution resumes.

DMA timing is illustrated in Figure 16-8.



Figure 16-8. CP1600 DMA Timing



Figure 16-9. CP1600 Interrupt Service Routine Initialization



Figure 16-10. CP1600 Timing for TCI Instruction's Execution

## THE CP1600 INTERRUPT LOGIC

The CP1600 uses a vectored interrupt processing system.

External logic requests an interrupt by inputting a low signal at either the INTR or INTRM pins.

Following the execution of the next interruptable instruction, the CP1600 acknowledges the interrupt by pushing Register R7 contents (the Program Counter) onto the Stack; then the CP1600 outputs 111, followed by 010 at BC1, BC2, and BDIR. External logic must respond by placing 16 bits of data on the Data/Address Bus. These 16 bits of data will be loaded into Register R7, the Program Counter, thus causing program execution to branch to an interrupt service routine dedicated to the interrupt. **Timing is illustrated in Figure 16-9.**

The PCIT signal is output low following execution of a software interrupt instruction (SIN). This is the only microcomputer described in this book which allows external logic to respond to a software interrupt in this fashion. Allowing external logic to respond to a software interrupt only makes sense when you anticipate your product being used in a minicomputer-like environment. Typically, the software interrupt will interface to logic of a front panel or console. When an SIN instruction is executed, a one-machine cycle low PCIT pulse is output.

You may, if you wish, end an interrupt service routine by executing a Terminate Current Interrupt (TCI) instruction, in which case the TCI signal will be output high.

**Timing for TCI is given in Figure 16-10.**

Following an interrupt acknowledge, the interrupt service routine must execute instructions in order to disable interrupts and save the contents of registers on the Stack. The exception is Register R7, the Program Counter, which is automatically pushed onto the Stack following an interrupt acknowledge.

External logic is entirely responsible for any type of interrupt priority arbitration which may occur, and for the generation of the interrupt vector address which must be input following an interrupt acknowledge.

It is quite easy to generate signals equivalent to other microcomputer system busses from the CP1600 System Bus. Therefore, you can use parts described in Volume 3 to handle CP1600 interrupt requirements.

## THE CP1600 INSTRUCTION SET

The CP1600 instruction set is relatively straightforward. Addressing modes, which we have already described, are simple, and instructions are typical of those we have seen and described for other microcomputers. Unusual features relating to addressing modes available with **individual instructions are summarized in Table 16-2**, which describes the CP1600 instruction set.

**If you have never programmed a PDP-11 minicomputer, then you should pay particular attention to programming techniques that result from the Stack Pointer and Program Counter being accessed as general purpose registers.**

A wide variety of Register Operate instructions allow you to compute data and load the result directly into Register R7, the Program Counter. In effect, these become computed Jump instructions.

The ability to manipulate Register R6, the Stack Pointer, as though it were a general purpose register means that it is easy to maintain a number of different Stacks in external read/write memory.

The Jump-to-Subroutine instruction has a minicomputer flavor to it. Rather than saving the return address on the Stack, Register R7 contents are moved to General Purpose Register R4 or R5. A number of minicomputers will save a subroutine return address in a general purpose register in this fashion. The problem with this logic is that you must execute an additional instruction within the subroutine to save the return address on the Stack if you are going to use nesting subroutines. If you are passing subroutine parameters, however, this is an excellent arrangement, for the Jump-to-Subroutine instruction places the address of the parameter list directly in a Data Counter with auto-increment. We have described the concept of parameter passing in Volume 1, Chapter 7.

Note that the CP1600 instruction set lacks a logical OR.

In Tables 16-2 and 16-4, instruction length is given in terms of "words" rather than "bytes", as we have done in previous chapters. Since only the lower 10 bits of the CP1600 object code are presently used, system configurations need not have the full 16-bit word size. Hence a "word" may be 10 to 16 bits wide, depending on the implementation.

The following notation is used in Table 16-2:

|           |                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDR      | One word of direct address                                                                                                                                                                                                                                                                                                                                                                                      |
| cond      | Condition on which a branch may be taken. Table 16-3 lists all 14 branch conditions.                                                                                                                                                                                                                                                                                                                            |
| DATA      | One word of immediate data.                                                                                                                                                                                                                                                                                                                                                                                     |
| DISP      | One word displacement. See Table 16-4 for location of sign bit.                                                                                                                                                                                                                                                                                                                                                 |
| E         | External branch condition.                                                                                                                                                                                                                                                                                                                                                                                      |
| EBCA0-3   | The external branch condition address lines: EBCA0, EBCA1, EBCA2, and EBCA3.                                                                                                                                                                                                                                                                                                                                    |
| EBCI      | The external branch condition input line.                                                                                                                                                                                                                                                                                                                                                                       |
| LABEL     | A 16-bit direct address, target of a Jump instruction. See Table 16-4 for the bit format.                                                                                                                                                                                                                                                                                                                       |
| PCIT      | The software interrupt output line.                                                                                                                                                                                                                                                                                                                                                                             |
| RB        | General Purpose Register R4, R5, or R6.                                                                                                                                                                                                                                                                                                                                                                         |
| RD        | One of the general purpose registers, used as a destination for operation results.                                                                                                                                                                                                                                                                                                                              |
| RM        | One of the general purpose registers used as a Data Counter, R4 or R5, if specified, is auto-incremented after the memory access. R6 is incremented after a write, and decremented before a read.                                                                                                                                                                                                               |
| RR        | General Purpose Register R0, R1, R2, or R3.                                                                                                                                                                                                                                                                                                                                                                     |
| RS        | One of the general purpose registers, used as the source of an operand.                                                                                                                                                                                                                                                                                                                                         |
| Statuses: | <ul style="list-style-type: none"><li>S the Sign status</li><li>C the Carry status</li><li>Z the Zero status</li><li>O the Overflow status</li></ul>                                                                                                                                                                                                                                                            |
|           | The following symbols are used in the STATUSES column: <ul style="list-style-type: none"><li>X the status flag is affected by the operation<ul style="list-style-type: none"><li>a blank means the status flag is not affected</li></ul></li><li>0 the operation clears the status flag</li><li>1 the operation sets the flag</li><li>2 the Overflow flag is affected only on 2-bit shifts or rotates</li></ul> |

SW      The Status Word, whose bits correspond to the condition of the status flags in the following way:



When the status word is copied into a register, it goes to the upper half of each byte:



When the status word is loaded from a register, it comes from the upper half of the lower byte:



- $x < y.z >$  Bits y through z of the Register x. For example, R7 <15.8> represents the upper byte of the Program Counter
- (.) Indicates that the operand ".2" is optional
- A low pulse
- [ ] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.
- [[ ]]] Implied memory addressing: the contents of the memory location designated by the contents of a register.
- Λ Logical AND
- ✗ Logical Exclusive-OR
- ± Addition or subtraction of a displacement, depending on the sign bit in the object code.
- ↑ Data is transferred in the direction of the arrow.

Table 16-2. CP1600 Instruction Set Summary

| TYPE                               | MNEMONIC | OPERAND(S) | WORDS | STATUSES |   |   |   | OPERATION PERFORMED                                                                                                       |
|------------------------------------|----------|------------|-------|----------|---|---|---|---------------------------------------------------------------------------------------------------------------------------|
|                                    |          |            |       | S        | Z | C | O |                                                                                                                           |
| PRIMARY I/O AND MEMORY REFERENCE   | MVI      | ADDR,RD    | 2     |          |   |   |   | [RD]—[ADDR]<br>Load register from memory, using direct addressing.                                                        |
|                                    | MVI@     | RM,RD      | 1     |          |   |   |   | [RD]—[[RM]]<br>Load register from memory, using implied addressing.                                                       |
|                                    | MVO      | RS,ADDR    | 2     |          |   |   |   | [ADDR]—[RS]<br>Store register to memory, using direct addressing.                                                         |
|                                    | MVO@     | RS,RM      | 1     |          |   |   |   | [[[RM]]]—[RS]<br>Store register to memory, using implied addressing. If RS=R4, R5, R6 or R7, then RS=RM is not supported. |
| SECONDARY I/O AND MEMORY REFERENCE | ADD      | ADDR,RD    | 2     | X        | X | X | X | [RD]—[RD]+[ADDR]<br>Add memory contents to register, using direct addressing.                                             |
|                                    | ADD@     | RM,RD      | 1     | X        | X | X | X | [RD]—[RD]+[[RM]]<br>Add memory contents to register, using implied addressing.                                            |
|                                    | SUB      | ADDR,RD    | 2     | X        | X | X | X | [RD]—[RD]-[ADDR]<br>Subtract memory contents from register, using direct addressing.                                      |
|                                    | SUB@     | RM,RD      | 1     | X        | X | X | X | [RD]—[RD]-[[RM]]<br>Subtract memory contents from register, using implied addressing.                                     |
|                                    | CMP      | ADDR,RS    | 2     | X        | X | X | X | [RS]-[ADDR]<br>Compare memory contents with registers, using direct addressing. Only the status flags are affected.       |
|                                    | CMP@     | RM,RS      | 1     | X        | X | X | X | [RS]-[[RM]]<br>Compare memory contents with register's, using implied addressing. Only the status flags are affected.     |
|                                    | AND      | ADDR,RD    | 2     | X        | X |   |   | [RD]—[RD]Λ[ADDR]<br>AND memory contents with those of register, using direct addressing.                                  |
|                                    | AND@     | RM,RD      | 1     | X        | X |   |   | [RD]—[RD]Λ[[RM]]<br>AND memory contents with those of register, using implied addressing.                                 |
|                                    | XOR      | ADDR,RD    | 2     | X        | X |   |   | [RD]—[RD]∨[ADDR]<br>Exclusive-OR memory contents with those of register, using direct addressing.                         |
|                                    | XOR@     | RM,RD      | 1     | X        | X |   |   | [RD]—[RD]∨[[RM]]<br>Exclusive-OR memory contents with those of register, using implied addressing.                        |

Table 16-2. CP1600 Instruction Set Summary (Continued)

| TYPE                | MNEMONIC | OPERAND(S) | WORDS | STATUSES |   |   |   | OPERATION PERFORMED                                                                                                                                                             |
|---------------------|----------|------------|-------|----------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |          |            |       | S        | Z | C | O |                                                                                                                                                                                 |
| IMMEDIATE           | MVII     | DATA, RD   | 2     |          |   |   |   | [RD]—DATA<br>Load immediate to specified register.                                                                                                                              |
|                     | MVOI     | RS, DATA   | 2     |          |   |   |   | [[R7] + 1]—[RS]<br>Store contents of specified register in immediate field of MVOI instruction. This is only possible if program memory is read/write memory (rather than ROM). |
| IMMEDIATE OPERATE   | ADDI     | DATA, RD   | 2     | X X      | X | X | X | [RD]—[RD] + DATA<br>Add immediate to specified register.                                                                                                                        |
|                     | SUBI     | DATA, RD   | 2     | X X      | X | X | X | [RD]—[RD] - DATA<br>Subtract immediate data from specified register.                                                                                                            |
|                     | CMPI     | DATA, RS   | 2     | X X      | X | X | X | [RD] - DATA<br>Compare immediate data with contents of specified register. Only the status flags are affected.                                                                  |
|                     | ANDI     | DATA, RD   | 2     | X X      |   |   |   | [RD]—[RD] $\wedge$ DATA<br>AND immediate data with contents of specified register.                                                                                              |
|                     | XORI     | DATA, RD   | 2     | X X      |   |   |   | [RD]—[RD] $\vee$ DATA<br>Exclusive-OR immediate data with contents of specified register.                                                                                       |
| JUMP                | J        | LABEL      | 3     |          |   |   |   | [R7]—LABEL<br>Jump to given address.                                                                                                                                            |
|                     | JR       | RS         | 1     |          |   |   |   | [R7]—[RS]<br>Jump to address contained in specified register.                                                                                                                   |
|                     | JSR      | RB, LABEL  | 3     | X        | X |   |   | [RB]—[R7]; [R7]—LABEL<br>Jump to given address, saving Program Counter in R4, R5, or R6.                                                                                        |
|                     | B        | DISP       | 2     |          |   |   |   | [R7]—[R7] + 2 $\pm$ DISP<br>Branch relative to Program Counter contents.                                                                                                        |
| BRANCH ON CONDITION | Bcond    | DISP       | 2     |          |   |   |   | If cond is true, [R7]—[R7] + 2 $\pm$ DISP<br>Branch relative on given condition; otherwise, execute next sequential instruction.                                                |
|                     | BEXT     | DISP,E     | 2     |          |   |   |   | EBCAO-3 — E:<br>If EBCI=1, [R7]—[R7] + 2 $\pm$ DISP<br>Branch relative if external condition is true.                                                                           |

Table 16-2. CP1600 Instruction Set Summary (Continued)

| TYPE                                  | MNEMONIC | OPERAND(S) | WORDS | STATUSES |   |   |   | OPERATION PERFORMED                                                                                                                                                              |
|---------------------------------------|----------|------------|-------|----------|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       |          |            |       | S        | Z | C | O |                                                                                                                                                                                  |
| REGISTER-REGISTER<br>MOVE AND OPERATE | MOVR     | RS,RD      | 1     | X X      |   |   |   | [RD]—[RS]<br>Move contents of source register to destination register.                                                                                                           |
|                                       | ADDR     | RS,RD      | 1     | X X X X  |   |   |   | [RD]—[RS]+[RD]<br>Add contents of specified registers.                                                                                                                           |
|                                       | SUBR     | RS,RD      | 1     | X X X X  |   |   |   | [RD]—[RD]-[RS]<br>Subtract contents of source register from those of destination register.                                                                                       |
|                                       | CMPR     | RS,RD      | 1     | X X X X  |   |   |   | [RD]-[RS]<br>Compare registers' contents. Only the status flags are affected.                                                                                                    |
|                                       | ANDR     | RS,RD      | 1     | X X      |   |   |   | [RD]—[RD]Λ[RS]<br>AND contents of specified registers.                                                                                                                           |
|                                       | XORR     | RS,RD      | 1     | X X      |   |   |   | [RD]—[RD]⊕[RS]<br>Exclusive-OR contents of specified registers.                                                                                                                  |
| REGISTER OPERATE                      | CLRR     | RD         | 1     | 0 1      |   |   |   | [RD]—[RD]∨[RD]<br>Clear specified register.                                                                                                                                      |
|                                       | TSTR     | RS         | 1     | X X      |   |   |   | [RS]—[RS]<br>Test contents of specified register.                                                                                                                                |
|                                       | INCR     | RD         | 1     | X X      |   |   |   | [RD]—[RD]+1<br>Increment contents of specified register.                                                                                                                         |
|                                       | DECR     | RD         | 1     | X X      |   |   |   | [RD]—[RD]-1<br>Decrement contents of specified register.                                                                                                                         |
|                                       | COMR     | RD         | 1     | X X      |   |   |   | [RD]—[RD]<br>Complement contents of specified register (ones complement).                                                                                                        |
|                                       | NEGR     | RD         | 1     | X X X X  |   |   |   | [RD]—[RD]+1<br>Negate contents of specified register (twos complement).                                                                                                          |
|                                       | ADCR     | RD         | 1     | X X X X  |   |   |   | [RD]—[RD]+[C]<br>Add Carry bit to specified register contents.                                                                                                                   |
|                                       | SLL      | RR,(2)     | 1     | X X      |   |   |   | <br>[RR]<br>Shift logical left one or two bits; clearing bit 0 (and bit 1 if shifting twice). |

Table 16-2. CP1600 Instruction Set Summary (Continued)

| TYPE                         | MNEMONIC | OPERAND(S) | WORDS | STATUSES |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                 |
|------------------------------|----------|------------|-------|----------|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |          |            |       | S        | Z | C | O |                                                                                                                                                                                                                                     |
| REGISTER OPERATE (CONTINUED) | RLC      | RR(,2)     | 1     | X X X    | 2 |   |   |  <p>[RR]</p> <p>Rotate left one bit through Carry, or rotate 2 bits left through Overflow and Carry.</p>                                          |
|                              | SLLC     | RR(,2)     | 1     | X X X    | 2 |   |   |  <p>[RR]</p> <p>Shift logical left one bit into Carry, clearing bit 0, or shift left two bits into Overflow and Carry, clearing bits 0 and 1.</p> |
|                              | SLR      | RR(,2)     | 1     | X X      |   |   |   |  <p>[RR]</p> <p>Shift logical right one or two bits, clearing bit 15 (and bit 14 if shifting twice).</p>                                          |
|                              | SAR      | RR(,2)     | 1     | X X      |   |   |   |  <p>[RR]</p> <p>Shift arithmetic right one or two bits, copying high order bit.</p>                                                               |
|                              | RRc      | RR(,2)     | 1     | X X X    | 2 |   |   |  <p>[RR]</p> <p>Rotate right one bit through Carry, or rotate two bits right through Overflow and Carry.</p>                                      |
|                              | SARC     | RR(,2)     | 1     | X X X    | 2 |   |   |  <p>[RR]</p> <p>Shift arithmetic right one bit into Carry, or two bits into Overflow and Carry.</p>                                               |
|                              | SWAP     | RR(,2)     | 1     | X X      |   |   |   |  <p>[RR]</p> <p>Swap bytes of register once, or twice.</p>                                                                                       |

Table 16-2. CP1600 Instruction Set Summary (Continued)

| TYPE      | MNEMONIC                                             | OPERAND(S)                                        | WORDS                                | STATUSES |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|------------------------------------------------------|---------------------------------------------------|--------------------------------------|----------|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |                                                      |                                                   |                                      | S        | Z | C | O |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| STACK     | PSHR<br>PULR                                         | RS<br>RD                                          | 1<br>1                               |          |   |   |   | Separate mnemonics for MVO@ RS,R6.<br>Separate mnemonics for MVI@R6, RD.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| INTERRUPT | SIN<br>EIS<br>DIS<br>TCI<br>JE<br>JD<br>JSRE<br>JSRD | (2)<br><br>LABEL<br>LABEL<br>RB,LABEL<br>RB,LABEL | 1<br>1<br>1<br>1<br>3<br>3<br>3<br>3 |          |   |   |   | PCIT — <br>Software interrupt.<br>Enable interrupt system.<br>Disable interrupt system.<br>Terminate current interrupt.<br>Jump to given address and enable interrupt system.<br>Jump to given address and disable interrupt system.<br>Jump to given address, saving Program Counter in R4, R5 or R6, and enable interrupt system.<br>Jump to given address, saving Program Counter in R4, R5 or R6, and disable interrupt system.                      |
| STATUS    | GSWD                                                 | RD                                                | 1                                    |          |   |   |   | [RD<15,12>]—[SW]; [RD<7,4>]—[SW]<br>Place Status Word in upper half of each byte of the specified register. RD may be R0, R1, R2 or R3.                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | RSPW                                                 | RS                                                | 1                                    | X        | X | X | X | [SW]—[RS<7,4>]<br>Load Status Word from bits 7 through 4 of the specified register.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           | CLRC                                                 |                                                   | 1                                    |          |   | 0 |   | [C]—0<br>Clear Carry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | SETC                                                 |                                                   | 1                                    |          |   | 1 |   | [C]—1<br>Set Carry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           | NOPP<br>NOP<br>HLT<br>SDBD                           | (2)                                               | 2<br>1<br>1                          |          |   |   |   | No Operation.<br>Halt after executing next instruction.<br>Set double byte data mode for next instruction, which must be of one of the following types:<br>Primary or secondary I/O or memory reference<br>Immediate or immediate operate<br>If implied addressing through R1, R2, or R3 is used, the same byte will be accessed twice; addressing through R4, R5, or R7 will give bytes from the addressed location and that addressed after auto-increment. Direct addressing and Stack addressing are not allowed in double byte mode. |

Table 16-3. CP1600 Branch Conditions and Corresponding Codes

| MNEMONIC | BRANCH CONDITION                           | OBJECT CODE<br>DESIGNATION |
|----------|--------------------------------------------|----------------------------|
| C        | C = 1                                      | 0001                       |
| LGT      | Carry<br>(logical greater than)            |                            |
| NC       | C = 0                                      | 1001                       |
| LLT      | No Carry<br>(logical less than)            |                            |
| OV       | O = 1<br>Overflow                          | 0010                       |
| NOV      | O = 0<br>No overflow                       | 1010                       |
| PL       | S = 0<br>Plus                              | 0011                       |
| MI       | S = 1<br>Minus                             | 1011                       |
| ZE       | Z = 1                                      | 0100                       |
| EQ       | Zero (equal)                               |                            |
| NZE      | Z = 0                                      | 1100                       |
| NEQ      | Nonzero (not equal)                        |                            |
| LT       | S $\vee$ O = 1<br>Less than                | 0101                       |
| GE       | S $\vee$ O = 0<br>Greater than or equal    | 1101                       |
| LE       | Z V (S $\vee$ O) = 1<br>Less than or equal | 0110                       |
| GT       | Z V (S $\vee$ O) = 0<br>Greater than       | 1110                       |
| USC      | C $\vee$ S = 1<br>Unequal sign and carry   | 0111                       |
| ESC      | C $\vee$ S = 0<br>Equal sign and carry     | 1111                       |

The following notation is used in Table 16-4:

Where ten digits are shown, they are the ten low-order bits of a 10 to 16-bit word. (Word size depends on the system implementation.) Where four digits are shown, they represent the hexadecimal notation for an entire word (10 to 16 bits).

- bb Two bits indicating one of the first three general purpose registers
- cccc Four bits giving the branch condition, as shown in Table 16-3
- ddd Three bits indicating a destination register, RD
- eeee Four bits giving the external branch condition, E
- llll One word of immediate data
- mmm Three bits indicating a Data Counter Register RM
- m One bit indicating the number of rotates or shifts:
  - 0 one bit position
  - 1 two bit positions
- p One bit of immediate address
- P One hexadecimal digit (4 bits) of immediate address
- rr Two bits indicating one of the first four general purpose registers
- sss Three bits indicating a source register, RS
- z Sign of the displacement:
  - 0 add the displacement to PC contents
  - 1 subtract the displacement from PC contents

In the "Machine Cycles" column, when two numbers are given with one slash between them (e.g., 7/9), execution time depends on whether or not a branch is taken. When two numbers are given, separated by two slashes (such as 8//11), execution time depends on which register contains the implied address.

Table 16-4. CP1600 Instruction Set Object Codes

| INSTRUCTION   | OBJECT CODE                | WORDS | MACHINE CYCLES |
|---------------|----------------------------|-------|----------------|
| ADCR RD       | 0000101ddd                 | 1     | 6              |
| ADD ADDR,RD   | 1011000ddd<br>PPPP         | 2     | 10             |
| ADD@ RM,RD    | 1011mmmmdd                 | 1     | 8//11          |
| ADDI DATA,RD  | 1011111ddd<br>III          | 2     | 8              |
| ADDR RS,RD    | 0011ssssdd                 | 1     | 6              |
| AND ADDR,RD   | 1110000ddd<br>PPPP         | 2     | 10             |
| AND@ RM,RD    | 1110mmmmdd                 | 1     | 8//11          |
| ANDI DATA,RD  | 1110111ddd<br>III          | 2     | 8              |
| ANDR RS,RD    | 0110ssssdd                 | 1     | 6              |
| B DISP        | 1000z000000<br>PPPP        | 2     | 7/9            |
| Bcond DISP    | 1000z0cccc<br>PPPP         | 2     | 7/9            |
| BEXT DISP,E   | 1000z1eeee<br>PPPP         | 2     | 7/9            |
| CLRC          | 0006                       | 1     | 4              |
| CLRR RD       | 0111ddddd                  | 1     | 6              |
| CMP ADDR,RS   | 1101000sss<br>PPPP         | 2     | 10             |
| CMP@ RM,RS    | 1101mmmmss                 | 1     | 8//11          |
| CMPI DATA,RS  | 1101111sss<br>III          | 2     | 8              |
| CMPR RS,RD    | 0101ssssdd                 | 1     | 6              |
| COMR RD       | 0000011ddd                 | 1     | 6              |
| DECR RD       | 0000010ddd                 | 1     | 6              |
| DIS           | 0003                       | 1     | 4              |
| EIS           | 0002                       | 1     | 4              |
| GSWD RR       | 00001100rr                 | 1     | 6              |
| HLT           | 0000                       | 1     | 4              |
| INCR RD       | 0000001ddd                 | 1     | 6              |
| J LABEL       | 0004<br>11pppppp00<br>PPPP | 3     | 12             |
| JD LABEL      | 0004<br>11pppppp10<br>PPPP | 3     | 12             |
| JE LABEL      | 0004<br>11pppppp01<br>PPPP | 3     | 12             |
| JR RS         | 0010sss111                 | 1     | 7              |
| JSR RB,LABEL  | 0004<br>bbpppppp00<br>PPPP | 3     | 12             |
| JSRD RB,LABEL | 0004<br>bbpppppp10<br>PPPP | 3     | 12             |
| JSRE RB,LABEL | 0004<br>bbpppppp01<br>PPPP | 3     | 12             |
| MOVR RS,RD    | 0010ssssdd                 | 1     | 6//7           |
| MVI ADDR,RD   | 1010000ddd<br>PPPP         | 2     | 10             |
| MVI RM,RD     | 1010mmmmdd                 | 1     | 8//11          |

| INSTRUCTION  | OBJECT CODE        | WORDS | MACHINE CYCLES |
|--------------|--------------------|-------|----------------|
| MVII DATA,RD | 1010111ddd<br>III  | 2     | 8              |
| MVO RS,ADDR  | 1001000sss<br>PPPP | 2     | 11             |
| MVO@ RS,RM   | 1001mmmmss         | 1     | 9              |
| MVOI RS,DATA | 1001111sss<br>III  | 2     | 9              |
| NEGR RD      | 0000100ddd         | 1     | 6              |
| NOP (2)      | 000011010m         | 1     | 6              |
| NOPP         | 1000z01000<br>PPPP | 2     | 7              |
| PSHR RS      | 1001110sss         | 1     | 9              |
| PULR RD      | 1010110ddd         | 1     | 11             |
| RLC RRI,(2)  | 0001010mrr         | 1     | 6/8            |
| RRC RRI,(2)  | 0001110mrr         | 1     | 6/8            |
| RSWD RS      | 0000111sss         | 1     | 6              |
| SAR RRI,(2)  | 0001101mrr         | 1     | 6/8            |
| SARC RRI,(2) | 0001111mrr         | 1     | 6/8            |
| SDBD         | 0001               | 1     | 4              |
| SETC         | 0007               | 1     | 4              |
| SIN (2)      | 000011011m         | 1     | 6              |
| SLL RRI,(2)  | 0001001mrr         | 1     | 6/8            |
| SLLC RRI,(2) | 0001011mrr         | 1     | 6/8            |
| SLR RRI,(2)  | 0001100mrr         | 1     | 6/8            |
| SUB ADDR,RD  | 1100000ddd<br>PPPP | 2     | 10             |
| SUB@ RM,RD   | 1100mmmmdd         | 1     | 8//11          |
| SUBT DATA,RD | 1100111ddd<br>III  | 2     | 8              |
| SUBR RS,RD   | 0100ssssdd         | 1     | 6              |
| SWAP RRI,(2) | 0001000nrr         | 1     | 6/8            |
| TCI          | 0005               | 1     | 4              |
| TSTR RS      | 0010ssssss         | 1     | 6//7           |
| XOR ADDR,RD  | 1111000ddd<br>PPPP | 2     | 10             |
| XOR@ RM,RD   | 1111mmmmdd         | 1     | 8//11          |
| XORI DATA,RD | 1111111ddd<br>III  | 2     | 8              |
| XORR RS,RD   | 0111ssssdd         | 1     | 6              |

## THE BENCHMARK PROGRAM

For the CP1600 our benchmark program may be illustrated as follows:

|      |            |                                               |
|------|------------|-----------------------------------------------|
| MVII | IOBUF,R4   | LOAD THE I/O BUFFER STARTING ADDRESS INTO R4  |
| MVII | TABLE,R1   | LOAD THE TABLE STARTING ADDRESS INTO R1       |
| MVI@ | R1,R5      | LOAD ADDRESS OF FIRST FREE TABLE WORD INTO R5 |
| MVII | CNT,R2     | LOAD WORD COUNT INTO R2                       |
| LOOP | MVI@ R4,R0 | LOAD NEXT DATA WORD FROM IOBUF                |
|      | MVO@ R0,R5 | STORE IN NEXT TABLE WORD                      |
|      | DECR R2    | DECREMENT WORD COUNT                          |
|      | BNZE LOOP  | RETURN IF NOT END                             |
|      | MVO@ R5,R1 | RETURN ADDRESS OF NEXT FREE TABLE BYTE        |

This benchmark program makes very few assumptions. The input table IOBUF and the data table TABLE can have any length, and can reside anywhere in memory. The address of the first free word in TABLE is stored in the first word of the TABLE.



Figure 16-11. CP1600 to 8080A Bus Conversion

## SUPPORT DEVICES THAT MAY BE USED WITH THE CP1600

A CP1600 microcomputer system with any significant capabilities will use support devices of some other microprocessor. Parallel I/O capability is available with the CP1680, (described next), but priority interrupt logic, DMA logic, and serial I/O logic, to mention just a few common options, may need additional support devices. Fortunately, it is quite easy to generate an 8080A-compatible system bus from the CP1600 system bus. Logic is illustrated in Figure 16-11.

The CP1600A is the fastest version of the CP1600 CPU; it runs with a 500 nanosecond machine cycle. The CP1600 machine cycle is equivalent to an 8080A clock period. Since the standard 8080A clock period is also 500 nanoseconds, no speed conflicts will arise.

The bus-to-bus interface logic illustrated in Figure 16-11 is self-evident, with the exception of bus demultiplexing logic. The CP1600 Data/Address Bus is shown buffered by a demultiplexing buffer that is connected to two latched buffers. One of the latched buffers accepts the demultiplexer outputs only when a valid address is being output, as identified by BAR high. The second latched buffer may be a bidirectional latched buffer, or it may be two unidirectional latched buffers. Three latching strobes are required: DTB, IAB, and DWS.

DTB and IAB are data input strobes. DTB strobes data input that is to be interpreted as data, while IAB strobes data input that is to be interpreted as an address. So far as external logic is concerned, both of these signals are simple data input strobes. We could therefore generate a single data input strobe as the OR of DTB and IAB. When this data input strobe is high, information on the 8080A System Bus side of the latched data buffer must be input to the buffer; this data must simultaneously be transmitted to the multiplexer.

DWS is the data output strobe. When high, this signal must strobe data from the multiplexer to the latched data buffer; this latched data must immediately appear at the 8080A System Bus side of the latched data buffer.

Since the CP1600 uses a 16-bit Data Bus, you will probably have to generate two external device data busses; a high-order byte bus and a low-order byte bus. All external devices that transmit or receive parallel data must be present in duplicate. For example, were 8255 parallel interface devices to be present, the following connections would be required:



The CP1600 and MC6800 system busses are singularly incompatible. You should not attempt to use MC6800 support devices with the CP1600.



Figure 16-12. CP1680 IOB Signals and Pin Assignments



Figure 16-13. A CP1600-CP1680 Microcomputer Configuration

## THE CP1680 INPUT/OUTPUT BUFFER (IOB)

The CP1680 IOB is a parallel I/O device designed specifically for the CP1600 CPU. This device provides a single 16-bit parallel I/O port, which may optionally be configured as two 8-bit I/O ports. Primitive handshaking control signals are available with the parallel I/O logic. Elementary interval timer and prioritized interrupt logic is also provided.

Figure 16-1 also illustrates that part of our general microcomputer system logic which has been implemented on the CP1680 IOB.

The CP1600 IOB is packaged as a 40-pin DIP. It requires two power supplies, +5V and +12V. All inputs are TTL compatible. The device is implemented using N-channel MOS technology.

Figure 16-13 illustrates a CP1600 microcomputer system with three CP1680 IOB devices in the configuration.

### CP1680 IOB PINS AND SIGNALS

The CP1680 IOB pins and signals are illustrated in Figure 16-12. We will summarize these signals and the functions they serve before examining device operations in detail.

Let us begin by looking at the interface between the CP1680 IOB and the CP1600 CPU.

**D0 - D7 provide an 8-bit parallel Data/Address Bus via which all communications between the CPU and IOB occur.** This bus must connect to the low-order eight bits of the 16-bit CPU Data/Address Bus.

**The three bus control signals, BC1, BC2, and BDIR, connect the CP1680 to the CP1600 as illustrated in Figure 16-13.** The CP1680 IOB decodes these three bus control signals internally.

A clock input is required by the CP1680. This **clock input (CK1)** is used by internal logic to determine when BC1, BC2, and BDIR are valid. CK1 must have the following wave form:



CK1 must be derived from the CP1600 clock signals by external logic.

Let us now look at the interface between external logic and the CP1680 IOB.

**PD0 - PD15 provide a 16-bit parallel I/O port which can optionally be configured as two 8-bit I/O ports.** While PD0 - PD15 are in theory bidirectional, these pins are more accurately described as **pseudo-bidirectional**. This is because when a zero has been written to one of these pins, the output can sink 1.6 mA for an output voltage of +0.5V. External logic will have a hard time overcoming this sink in order to pull the pin high. In contrast, when a 1 is written to one of these pins, the output sources just 100 $\mu$ A at +5V. External logic will have little problem sinking 100 $\mu$ A in order to pull a pin low. Therefore, you should output a 1 to any pin that is subsequently to receive input data. External logic will then leave the pin high when inputting 1, while pulling the pin low to input 0.

### CP1600 I/O PORT PIN CHARACTERISTICS

The handshaking control signals which link the CP1680 IOB with external logic are PE and  $\overline{AR}$ . PE is a control signal which is output by the CP1680, and  $\overline{AR}$  is a control signal which is input to the CP1680.

Now consider CP1680 interrupt signals.

An interrupt request is transmitted to the CP1600 CPU via INTRQ. The CPU acknowledges the interrupt via the INTAK combination of BDIR, BC1, and BC2. TCl must be output low by the CPU at the end of the interrupt service routine. This signal is required by CP1680 interrupt logic, which uses the low TCl pulse in its priority arbitration, as described later in this chapter.

**Interrupts may be generated by** conditions internal to the CP1680, or by a low input at **ERROR**. The **ERROR** input is reserved for error conditions detected by external logic.

**IMSKI** and **IMSK0** are interrupt priority input and interrupt priority output signals, respectively. These signals are used to generate daisy chain interrupt priorities between CP1680. IOB devices, as illustrated in Figure 16-13. We will describe CP1680 interrupt priorities in more detail later in this chapter.

**MCLR** is the master reset control input for the CP1680. This signal must be input low for at least 10 milliseconds in order to reset the CP1680 IOB.

## CP1680 ADDRESSABLE REGISTERS

The CP1680 has eight addressable locations, which may be illustrated as follows:



These eight addressable locations are all 8-bit registers; they are addressed using the first eight addresses in a 256-address block, as follows:

| Register                     | Address |
|------------------------------|---------|
| Control                      | 0       |
| Data buffer, low-order byte  | 1       |
| Data buffer, high-order byte | 2       |
| Timer, low-order byte        | 3       |
| Timer, high-order byte       | 4       |
| I/O interrupt vector         | 5       |
| Timer interrupt vector       | 6       |
| Error interrupt vector       | 7       |

The actual 256 addresses will be identified by the eight high-order CP1600 Data/Address Bus lines, which will be used to create CP1680 device select logic. This device select logic creates  $\overline{CE}$  (the chip enable signal); it may be illustrated as follows:



## THE CP1680 CONTROL REGISTER

We will summarize the individual bits of the CP1680 control register before describing the operations they control.

**Here are CP1680 Control register bit assignments:**



Bit 0 is always the complement of the PE control output. This bit may be interrogated by the CPU. If parallel data transfer interrupts are disabled, this allows the CPU to poll on status when monitoring parallel data transfers. PE signal levels are illustrated in Figures 16-14 and 16-15.

Bit 1 reflects the level of the ERROR input. If parallel data transfer interrupt logic is disabled, then the Error interrupt logic is also disabled. Thus, the CPU must also examine the Error status bit when polling the CP1680.

Bit 2 determines whether PD0 - PD15 will act as a single 16-bit I/O port, or as two 8-bit I/O ports. This is only important when outputting data.

Control register bits 3 and 4 are used to enable and disable parallel data transfer and Error interrupt logic, and timer interrupt logic.

Control register bit 5 is used to enable and disable CP1680 interval timer logic. If this bit is 0, the interval timer will not decrement.

Bits 6 and 7 report the parity of the high-order byte and low-order byte for data that is input or output via PD0 - PD15. 0 indicates even parity while 1 indicates odd parity.

All Control register bits may be written into or read. You should be very careful when setting or resetting individual bits not to simultaneously modify other Control register bits. This means you should use a three-instruction sequence with an AND or OR mask to set or reset any Control register bit. For details see Volume 1, Basic Concepts.

## CP1680 DATA TRANSFER OPERATIONS

The CPU inputs and outputs data via the CP1680 IOB by executing MVI and MVO instructions, respectively.

The CPU must access the CP1680 in byte mode, since an 8-bit Data/Address Bus (D0 - D7) connects the CPU and the CP1680 IOB. Whether the I/O port PD0 - PD15 is configured as a single 16-bit port or as two 8-bit ports has no bearing on the fact that the CPU must access the CP1680 in byte mode.

**The most efficient way of accessing the CP1680 is by using the SDBD instruction with implied memory addressing.** Consider data input. If PD0 - PD15 is configured as two 8-bit I/O ports and you wish to access just one of these I/O ports, then you can use implied memory addressing via R1, R2, or R3. We may illustrate input from the high-order byte of I/O Port PD8 - PD15 as follows:



If PDO - PD15 are configured as two 8-bit I/O ports or as a single 16-bit I/O port, and you want to read both I/O ports, then you should use the SDBD instruction with implied memory addressing via R4 or R5. This may be illustrated as follows:



Control register bit 2 configures PDO - PD15 as a single 16-bit I/O port or as two 8-bit I/O ports.

Given the fact that MVI and MVO instructions (in byte mode) should be used to access the CP1680, when should these accesses occur?

The answer is that the PE and  $\overline{AR}$  signals control event sequences.

**Consider parallel data input, as illustrated in Figure 16-14.**



Figure 16-14. PD1680 Handshaking with Data Input

When the CPU is ready to receive data, it resets Control register bit 0 to 0; this forces the PE control signal high.

When external logic senses PE high, it must transmit data to the PDO - PD15 I/O port. At this point it makes no difference whether pins have been configured as two 8-bit ports or as a single 16-bit port. External logic will pull to ground selected high pins, while leaving other high pins alone. When external logic has completed data input, it signals the fact by inputting AR low. It is the high-to-low transition of the AR control input which indicates the presence of new data for the CPU to read. When AR makes its high-to-low transition, PE also makes a high-to-low transition, and Control register bit 0 is set to 1. If interrupts have been enabled, then an interrupt is requested via INTRO. Figure 16-14 assumes that interrupts have been enabled; therefore INTRO is shown making a high-to-low transition.

The CPU will acknowledge the interrupt request, as described earlier in this chapter, by outputting INTAK via BC1, BC2, and BDIR. Logic internal to the CP1680 uses INTAK to reset INTRO high again.

There are many ways in which external logic can determine when to set AR high again. In Figure 16-14 we show external logic using PE to set AR high. Clearly, when PE makes a low-to-high transition, the CPU must have acknowledged AR low; therefore external logic can now set AR high. Now that AR is high again, external logic can input new data. An alternative scheme would be for external logic to constantly hold AR low, using the level of the PE output to determine when new data could be transmitted. When PE is high, external logic will transmit new data to the CP1680 once. As soon as it transmits new data, external logic will strobe the data with a short, high AR pulse, then wait for PE to go low and high again before inputting more data. This may be illustrated as follows:



Data output handshaking is illustrated in Figure 16-15.



Figure 16-15. PD1680 Handshaking for Data Output

The most important point to note is that there is no control bit which specifies data input mode or data output mode. Thus, the signal sequences we described for data input and those we are about to describe for data output occur automatically; the input or output mode is purely a function of CPU and external logic interpretation.

Whenever the CPU outputs data to the PD1680, the arrival of data forces PE output high. If PD0 - PD15 has been configured as two 8-bit ports, then the arrival of a single data byte to either port will cause PE to be output high. If PD0 - PD15 is configured as a single 16-bit I/O port, then PD will not be output high until two bytes of data have been received from the CPU by the PD1680.

Once PE is output high, nothing more happens until external logic responds. External logic cannot tell by the simple inspection of any control signals whether a data input operation or a data output operation is in progress. It is up to you, when designing your system, to dedicate CP1680 devices to input or output; or you must generate your own identification logic in the event that a CP1680 IOB is bidirectional. In Figure 16-15 we simply assume that external logic knows data is to be read, and knows whether the data is 16 bits or 8 bits wide. Furthermore, if the data is 8 bits wide, external logic must know which 8 bits to read. In any event, when external logic has completed its undefined operations, it must input AR low. The high-to-low transition of AR forces PE low again, and if interrupts are enabled, an interrupt will be requested via INTRO. When the CPU acknowledges the interrupt by outputting INTAK via BC1, BC2, and BDIR, the PD1680 uses the INTAK pulse to reset INTRO high.

The method used by external logic to reset AR high again is undefined. In Figure 16-15, we show PE going high as the trigger which external logic uses to reset AR high. This is clearly a viable scheme; PE will not go high again until fresh data has been output, at which point it is safe to assume that the CPU knows prior data has been read by external logic. It would be equally viable for external logic to hold AR continuously low, transmitting a short, high pulse whenever it reads data. This may be illustrated as follows:



Because there are no control signals which identify the PD1680 operating in input mode or output mode, there is no straightforward scheme for handling bidirectional data transfers with a single PD1680 device.

## THE CP1680 INTERVAL TIMER

The CP1680 has very elementary interval timer logic. A 16-bit Timer register, addressed as two separate 8-bit locations, decrements once every eight CK1 pulses, providing the timer has been enabled. You enable and disable timer logic via Control register bit 5. As a separate event, timer interrupts may be disabled via Control register bit 4. If timer interrupts are enabled, then when the timer decrements to 0, an interrupt request will occur. (Timer interrupt logic is described with other CP1680 interrupt logic later in this chapter.) If timer interrupts are not enabled, then the timer itself is effectively disabled, since you cannot test any timer status flag to see if the timer timed out; nor can you accurately read the contents of the Timer registers on the fly, since there is no protection against reading timer contents while it is in the process of being decremented.

The only timer programmable option you have is to load an initial value before the timer is enabled. The timer has no buffer; therefore, once it times out it begins decrementing again, if still enabled, beginning with the value FFFF<sub>16</sub>. This may be illustrated as follows:



The only accurate long time intervals you can compute are exact multiples of  $\text{FFFF}_{16} * 8 * \text{CK1}$ .

The CP1600A uses a 4MHz two-phase clock, which generates a 500 nanosecond cycle time. Thus, CK1 equals 500 nanoseconds, and long CP1600A time intervals must be an exact multiple of 262.144 milliseconds — the time it will take for the counter to decrement from  $\text{FFFF}_{16}$  to 0000.

The CP1600 uses a 3.3MHz two-phase clock, which generates a 600 nanosecond cycle time; therefore, long time intervals must be exact multiples of 314.572 milliseconds.

The CP1610, which runs on a 2MHz two-phase clock and has a one microsecond cycle time, will compute long time intervals that are exact multiples of 524.288 milliseconds.

You cannot attempt to generate clock periods that are multiples of shorter time intervals by loading some initial value into the timer following each time out; an unknown amount of time will elapse between the interval timer interrupt occurring and being acknowledged. The length of this unknown period of time will depend on the number of non-interruptable instructions which may be executing in sequence when the interrupt request first occurs, plus any higher priority interrupts which may exist. Therefore, if you load an initial value into the timer, it should be to compute an isolated time interval only. Here is an appropriate instruction sequence:

```

MVI    IOB, R0   :INPUT CONTROL REGISTER CONTENTS
ANDI   CFH, R0   :ZERO BITS 4 AND 5
MVO    R0, IOB   :RETURN TO CONTROL REGISTER
MVII   2AH, R0   :TRANSMIT LOW-ORDER TIMER
MVO    R0, IOB+3 :INITIAL BYTE
MVII   34H, R0   :TRANSMIT HIGH-ORDER TIMER
MVO    R0, IOB+4 :INITIAL BYTE
MVI    IOB, R0   :LOAD PRIOR CONTROL REGISTER CONTENTS
ADDI   30H, R0   :SET BITS 4 AND 5
MVO    R0, IOB   :START TIMER

```

The instruction sequence above begins with three instructions that load the CP1680 Control register contents into Register R0. Bits 4 and 5 are zeroed, then the result is returned to the Control register. Thus, the timer and timer interrupts are disabled. We do not bother with an SDBD instruction. Since the data source is eight bits wide, only the low-order byte of Register R0 will be significant. This being the case, we can use an 8-bit immediate AND mask to modify Register R0 contents before returning the low-order byte to the Control register.

Next, we load the initial timer value, one byte at a time, into Register R0. Each byte is written out to the appropriate half of the Control register. Once again we do not need to use the SDBD instruction. Since an 8-bit data path connects the CPU to the 1680 IOB, only the low-order byte of Register R0 will be significant during the data output.

Finally, we start the timer by loading Control register contents into Register R0, setting bits 4 and 5 to 1 and writing back the result.

When you write into the Timer registers, you clear any timer interrupt requests which may at that time be pending.

## CP1680 INTERRUPT LOGIC

**A CP1680 IOB will generate an interrupt request by outputting a low signal at INTRO if any one of these three conditions occurs:**

- 1) A low input at ERROR. External logic can request an interrupt via the CP1680 using the ERROR input.
- 2) The AR handshaking control input makes a high-to-low transition. This is illustrated in Figures 16-14 and 16-15.
- 3) The Interval Timer decrements from 1 to 0.

Recall that there are two separate interrupt enable/disable control bits in the Control register. One control bit applies to the Interval Timer, while the other control bit applies to both the AR handshaking and ERROR interrupts.

**Interrupt priorities among the three sources within a single CP1680 IOB are as follows:**

|              |             |
|--------------|-------------|
| <u>ERROR</u> | highest     |
| <u>AR</u>    | handshaking |
| Timer        | lowest      |

**When more than one CP1680 IOB is present in a CP1600 microcomputer system, then daisy chain priority is implemented** using the MSK1 input signal and the MSK0 output signal. Signal connections are illustrated in Figure 16-13. **The manner in which interrupt priorities are handled by the CP1680 is a little unusual.**

Two or more CP1680 devices may combine their interrupt request signals, which are wired ORed and input to the CP1600 via INTRO. The CP1600 acknowledges an interrupt via the INTAK combination of BC1, BC2, and BDIR. We de-

scribed this process earlier in the chapter. All CP1680 devices simultaneously receive the INTAK combination; however, a CP1680 which is acknowledged raises its IMSKO signal high, causing it to become the IMSKI input to the next CP1680 in the daisy chain. Any device that receives a high IMSKI input ignores the interrupt acknowledge. Thus, only the highest priority, interrupt requesting CP1680 device in the daisy chain will process the interrupt acknowledge. However, it takes a finite amount of time for IMSKO high signals to propagate as IMSKI signals, and thus ripple through the daisy chain. Consequently, a maximum of eight CP1680 devices may be present in the daisy chain. A ninth device will receive its IMSKI high signal too late and will respond to an interrupt acknowledge.

CP1680 IOB devices maintain their interrupt priority status until they receive a high TCI pulse. At that time, prior interrupt priorities are reset at all devices, and new priority arbitration begins. Thus, **when using CP1680 IOB devices, you are required to end all interrupt service routines by executing a TCI instruction.**

Note that if one CP1680 IOB has more than one active interrupt request (for example, an ERROR interrupt request and a timer interrupt request), then this internal interrupt priority will take precedence over the daisy chain interrupt priority. That is to say, the ERROR interrupt request will be acknowledged and serviced first. After the next TCI instruction is executed, the timer interrupt request will be serviced before any interrupt request from a lower priority CP1680 device is acknowledged.

**Every CP1680 device has three 8-bit Interrupt Vector registers, one dedicated to each of the three interrupt sources.** These three Interrupt Vector registers were illustrated earlier in the chapter. **Following an interrupt acknowledge, when the IAB combination appears at BC1, BC2, and BDIR, the contents of the Interrupt Vector register for the highest priority active interrupt will be returned to the CPU.** Interrupt acknowledge timing is illustrated in Figure 16-9. At the interrupt service location a Jump-to-Subroutine instruction will probably be stored. Since the Jump-to-Subroutine object code is three words long, a maximum of 85 interrupts can be originated in the first 256 words of memory. This is more than sufficient, since only eight CP1680 devices with 24 interrupts can be supported in a single daisy chain.

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- CP1600 CPU
- CP1600A CPU
- CP1610 CPU
- IOB1680 I/O Buffer

## BUS TIMING DIAGRAM



## TYPICAL INSTRUCTION SEQUENCE



## BRANCH ON EXTERNAL CONDITION INSTRUCTION

Data sheets on pages 16-D2 through 16-D6 reprinted by permission of General Instrument Corporation.

**CP1600****ELECTRICAL CHARACTERISTICS (CP1600)****Maximum Ratings\***

$V_{DD}$ ,  $V_{CC}$ , GND and all other input/output voltages  
with respect to  $V_{BB}$  . . . . .  $-0.3V$  to  $+18.0V$   
Storage Temperature . . . . .  $-55^{\circ}C$  to  $+150^{\circ}C$   
Operating Temperature . . . . .  $0^{\circ}C$  to  $+70^{\circ}C$

\*Exceeding these ratings could cause permanent damage to these devices. Functional operation at these conditions is not implied—operating conditions are specified below.

**Standard Conditions:** (unless otherwise noted)

$V_{DD}=+12V \pm 5\%$ ,  $70mA$ (typ),  $110mA$ (max.)     $V_{BB}=-3V \pm 10\%$ ,  $0.2mA$ (typ),  $2mA$ (max.)  
 $V_{CC}=+5V \pm 5\%$ ,  $12mA$ (typ),  $25mA$ (max.)    Operating Temperature ( $T_A$ )= $0^{\circ}C$  to  $+70^{\circ}C$

| Characteristic                                                        | Sym                      | Min  | Typ**    | Max      | Units   | Conditions          |
|-----------------------------------------------------------------------|--------------------------|------|----------|----------|---------|---------------------|
| <b>DC CHARACTERISTICS</b>                                             |                          |      |          |          |         |                     |
| <b>Clock Inputs</b>                                                   |                          |      |          |          |         |                     |
| High                                                                  | $V_{IH}$                 | 10.4 | —        | $V_{DD}$ | V       |                     |
| Low                                                                   | $V_{IL}$                 | 0    | —        | 0.6      | V       |                     |
| <b>Logic Inputs</b>                                                   |                          |      |          |          |         |                     |
| Low                                                                   | $V_{IL}$                 | 0    | —        | 0.65     | V       |                     |
| High (All Lines except BDRDY)                                         | $V_{IH}$                 | 2.4  | —        | $V_{CC}$ | V       |                     |
| High (Bus Data Ready Line<br>See Note)                                | $V_{IHB}$                | 3.0  | —        | $V_{CC}$ | V       |                     |
| <b>Logic Outputs</b>                                                  |                          |      |          |          |         |                     |
| High                                                                  | $V_{OH}$                 | 2.4  | $V_{CC}$ | —        | V       |                     |
| Low (Data Bus Lines DO-D15)                                           | $V_{OL}$                 | —    | —        | 0.5      | V       | $I_{OL} = 100\mu A$ |
| Low (Bus Control Lines,<br>BC1,BC2,BDIR)                              | $V_{OL}$                 | —    | —        | 0.45     | V       | $I_{OL} = 1.6mA$    |
| Low (All Others)                                                      | $V_{OL}$                 | —    | —        | 0.45     | V       | $I_{OL} = 2.0mA$    |
| $I_{OL} = 1.6mA$                                                      |                          |      |          |          |         |                     |
| <b>AC CHARACTERISTICS</b>                                             |                          |      |          |          |         |                     |
| <b>Clock Pulse Inputs, <math>\phi_1</math> or <math>\phi_2</math></b> |                          |      |          |          |         |                     |
| Pulse Width                                                           | $t_{\phi 2}, t_{\phi 2}$ | 120  | —        | —        | ns      |                     |
| Skew ( $\phi_1, \phi_2$ delay)                                        | $t_{12}, t_{21}$         | 0    | —        | —        | ns      |                     |
| Clock Period                                                          | $t_{cy}$                 | 0.3  | —        | 2.0      | $\mu s$ |                     |
| Rise & Fall Times                                                     | $t_{rf}$                 | —    | —        | 15       | ns      |                     |
| <b>Master SYNC:</b>                                                   |                          |      |          |          |         |                     |
| Delay from $\phi$                                                     | $t_{ms}$                 | —    | —        | 30       | ns      |                     |
| <b>DO-D15 Bus Signals</b>                                             |                          |      |          |          |         |                     |
| Output delay from $\phi_1$<br>(float to output)                       | $t_{BO}$                 | —    | —        | 120      | ns      |                     |
| Output delay from $\phi_2$<br>(output to float)                       | $t_{BF}$                 | —    | 50       | —        | ns      |                     |
| Input setup time before $\phi_1$                                      | $t_{BI}$                 | 0    | —        | —        | ns      |                     |
| Input hold time after $\phi_1$                                        | $t_{B2}$                 | 10   | —        | —        | ns      |                     |
| <b>Bus Control Signals</b>                                            |                          |      |          |          |         |                     |
| BC1,BC2,BDIR                                                          |                          |      |          |          |         |                     |
| Output delay from $\phi_1$                                            | $t_{DC}$                 | —    | —        | 120      | ns      |                     |
| BUSAK Output delay from $\phi_1$                                      | $t_{BU}$                 | —    | 150      | —        | ns      |                     |
| TCI Output delay from $\phi_1$                                        | $t_{TO}$                 | —    | 200      | —        | ns      |                     |
| TCI Pulse Width                                                       | $t_{TW}$                 | —    | 300      | —        | ns      |                     |
| EBCA output delay from BEXT<br>input                                  | $t_{DE}$                 | —    | —        | 150      | ns      |                     |
| EBCA wait time for EBCI input                                         | $t_{AI}$                 | —    | —        | 400      | ns      |                     |
| <b>CAPACITANCE</b>                                                    |                          |      |          |          |         |                     |
| $\phi_1, \phi_2$ Clock Input capacitance                              | $C_{\phi 1}, C_{\phi 2}$ | —    | 20       | 30       | pF      |                     |
| <b>Input Capacitance</b>                                              |                          |      |          |          |         |                     |
| DO-D15                                                                | $C_{IN}$                 | —    | 6        | 12       | pF      |                     |
| All Other                                                             | —                        | —    | 5        | 10       | pF      |                     |
| <b>Output Capacitance</b>                                             |                          |      |          |          |         |                     |
| DO-D15 in high impedance state                                        | $C_D$                    | —    | 8        | 15       | pF      |                     |

\*\*Typical values are at  $+25^{\circ}C$  and nominal voltages.

**NOTE:**

The Bus Data Ready(BDRDY) line is sampled during time period TSI after a BAR or ADAR bus control signal. BDRDY must go low requesting a wait state 50 ns before the end of TSI and remain low for 50 ns minimum. BDRDY may go high asynchronously. In response to BDRDY, the CPU will extend bus cycles by adding additional microcycles up to a maximum of 40  $\mu s$  duration.

# CP1600A

## ELECTRICAL CHARACTERISTICS (CP1600A)

### Maximum Ratings\*

$V_{DD}$ ,  $V_{CC}$ , GND and all other input/output voltages with respect to  $V_{BB}$  . . . . . -0.3V to +18.0V  
 Storage Temperature . . . . . -55°C to +150°C  
 Operating Temperature . . . . . 0°C to +70°C

\*Exceeding these ratings could cause permanent damage to these devices. Functional operation at these conditions is not implied—operating conditions are specified below.

### Standard Conditions: (unless otherwise noted)

$V_{DD} = +12V \pm 5\%$ , 7mA(typ), 140mA(max.)  $V_{BB} = -3V \pm 10\%$ , 0.2mA(typ), 2mA(max.)  
 $V_{CC} = +5V \pm 5\%$ , 12mA(typ), 25mA(max.) Operating Temperature ( $T_A$ ) = 0°C to +70°C

| Characteristic                                                        | Sym.                     | Min. | Typ**    | Max      | Units   | Conditions          |
|-----------------------------------------------------------------------|--------------------------|------|----------|----------|---------|---------------------|
| <b>DC CHARACTERISTICS</b>                                             |                          |      |          |          |         |                     |
| <b>Clock Inputs</b>                                                   |                          |      |          |          |         |                     |
| High                                                                  | $V_{IH}$                 | 10.4 | —        | $V_{DD}$ | V       |                     |
| Low                                                                   | $V_{IL}$                 | 0    | —        | 0.6      | V       |                     |
| <b>Logic Inputs</b>                                                   |                          |      |          |          |         |                     |
| Low                                                                   | $V_{IL}$                 | 0    | —        | 0.65     | V       |                     |
| High (All Lines except BDRDY)                                         | $V_{IH}$                 | 2.4  | —        | $V_{CC}$ | V       |                     |
| High (Bus Data Ready Line See Note)                                   | $V_{IHB}$                | 3.0  | —        | $V_{CC}$ | V       |                     |
| <b>Logic Outputs</b>                                                  |                          |      |          |          |         |                     |
| High                                                                  | $V_{OH}$                 | 2.4  | $V_{CC}$ | —        | V       | $I_{OH} = 100\mu A$ |
| Low (Data Bus Lines DO-D15)                                           | $V_{OL}$                 | —    | —        | 0.5      | V       | $I_{OL} = 1.6mA$    |
| Low (Bus Control Lines, BC1,BC2,BDIR)                                 | $V_{OL}$                 | —    | —        | 0.45     | V       | $I_{OL} = 2.0mA$    |
| Low (All Others)                                                      | $V_{OL}$                 | —    | —        | 0.45     | V       | $I_{OL} = 1.6mA$    |
| <b>AC CHARACTERISTICS</b>                                             |                          |      |          |          |         |                     |
| <b>Clock Pulse Inputs, <math>\phi 1</math> or <math>\phi 2</math></b> |                          |      |          |          |         |                     |
| Pulse Width                                                           | $t_{\phi 2}, t_{\phi 2}$ | 95   | —        | —        | ns      |                     |
| Skew ( $\phi 1, \phi 2$ delay)                                        | $t_{12}, t_{21}$         | 0    | —        | —        | ns      |                     |
| Clock Period                                                          | $t_{cy}$                 | 0.25 | —        | 2.0      | $\mu s$ |                     |
| Rise & Fall Times                                                     | $t_r, t_f$               | —    | —        | 15       | ns      |                     |
| <b>Master SYNC:</b>                                                   |                          |      |          |          |         |                     |
| Delay from $\phi$                                                     | $t_{MS}$                 | —    | —        | 30       | ns      |                     |
| <b>DO-D15 Bus Signals</b>                                             |                          |      |          |          |         |                     |
| Output delay from $\phi 1$ (float to output)                          | $t_{BO}$                 | —    | —        | 95       | ns      |                     |
| Output delay from $\phi 2$ (output to float)                          | $t_{BF}$                 | —    | 50       | —        | ns      |                     |
| Input setup time before $\phi 1$                                      | $t_{B1}$                 | 0    | —        | —        | ns      |                     |
| Input hold time after $\phi 1$                                        | $t_{B2}$                 | 10   | —        | —        | ns      |                     |
| <b>Bus Control Signals BC1,BC2,BDIR</b>                               |                          |      |          |          |         |                     |
| Output delay from $\phi 1$                                            | $t_{DC}$                 | —    | —        | 200      | ns      |                     |
| BUSAK Output delay from $\phi 1$                                      | $t_{BU}$                 | —    | 150      | —        | ns      |                     |
| TCI Output delay from $\phi 1$                                        | $t_{TO}$                 | —    | 200      | —        | ns      |                     |
| TCI Pulse Width                                                       | $t_{TW}$                 | —    | 300      | —        | ns      |                     |
| EBCA output delay from BEXT input                                     | $t_{DE}$                 | —    | —        | 150      | ns      |                     |
| EBCA wait time for EBCI input                                         | $t_{AI}$                 | —    | —        | 400      | ns      |                     |
| <b>CAPACITANCE</b>                                                    |                          |      |          |          |         |                     |
| $\phi 1, \phi 2$ Clock Input capacitance                              | $C_{\phi 1}, C_{\phi 2}$ | —    | 20       | 30       | pF      |                     |
| <b>Input Capacitance</b>                                              |                          |      |          |          |         |                     |
| DO-D15                                                                | $C_{IN}$                 | —    | 6        | 12       | pF      |                     |
| All Other                                                             | —                        | —    | 5        | 10       | pF      |                     |
| <b>Output Capacitance</b>                                             |                          |      |          |          |         |                     |
| DO-D15 in high impedance state                                        | $C_D$                    | —    | 8        | 15       | pF      |                     |

\*\*Typical values are at +25°C and nominal voltages.

#### NOTE:

The Bus Data ReaDY(BDRDY) line is sampled during time period TSI after a BAR or ADAR bus control signal. BDRDY must go low requesting a wait state 50 ns before the end of TSI and remain low for 50 ns minimum. BDRDY may go high asynchronously. In response to BDRDY, the CPU will extend bus cycles by adding additional microcycles up to a maximum of 40  $\mu$ sec duration.

**CP1610****ELECTRICAL CHARACTERISTICS (CP1610)****Maximum Ratings\***

$V_{DD}$ ,  $V_{CC}$ , GND and all other input/output voltages  
with respect to  $V_{BB}$  . . . . . -0.3V to +18.0V  
Storage Temperature . . . . . -55°C to +150°C  
Operating Temperature . . . . . 0°C to +70°C

\*Exceeding these ratings could cause permanent damage to these devices. Functional operation at these conditions is not implied—operating conditions are specified below.

**Standard Conditions:** (unless otherwise noted)

$V_{DD}=+11V\pm 5\%$ , 70mA(typ), 110mA(max.)  $V_{BB}=-3V\pm 10\%$ , 0.2mA(typ), 2mA(max.)  
 $V_{CC}=+5V\pm 5\%$ , 12mA(typ), 25mA(max.) Operating Temperature ( $T_A$ )=0°C to +70°C

| Characteristic                                                        | Sym                      | Min  | Typ**    | Max      | Units   | Conditions            |
|-----------------------------------------------------------------------|--------------------------|------|----------|----------|---------|-----------------------|
| <b>DC CHARACTERISTICS</b>                                             |                          |      |          |          |         |                       |
| <b>Clock Inputs</b>                                                   |                          |      |          |          |         |                       |
| High                                                                  | $V_{IH}$                 | 10.0 | —        | $V_{DD}$ | V       |                       |
| Low                                                                   | $V_{IL}$                 | 0    | —        | 0.6      | V       |                       |
| Input current                                                         | —                        | —    | —        | 15       | mA      | $V_{IH} = V_{DD} - 1$ |
| <b>Logic Inputs</b>                                                   |                          |      |          |          |         |                       |
| Low                                                                   | $V_{IL}$                 | 0    | —        | 0.65     | V       |                       |
| High (All Lines except BDRDY)                                         | $V_{IH}$                 | 2.4  | —        | $V_{CC}$ | V       |                       |
| High (Bus Data Ready Line See Note)                                   | $V_{IHB}$                | 3.0  | —        | $V_{CC}$ | V       |                       |
| <b>Logic Outputs</b>                                                  |                          |      |          |          |         |                       |
| High                                                                  | $V_{OH}$                 | 2.4  | $V_{CC}$ | —        | V       | $I_{OH} = 100\mu A$   |
| Low (Data Bus Lines DO-D15)                                           | $V_{OL}$                 | —    | —        | 0.5      | V       | $I_{OL} = 1.6mA$      |
| Low (Bus Control Lines, BC1,BC2,BDIR)                                 | $V_{OL}$                 | —    | —        | 0.45     | V       | $I_{OL} = 2.0mA$      |
| Low (All Others)                                                      | $V_{OL}$                 | —    | —        | 0.45     | V       | $I_{OL} = 1.6mA$      |
| <b>AC CHARACTERISTICS</b>                                             |                          |      |          |          |         |                       |
| <b>Clock Pulse Inputs, <math>\phi 1</math> or <math>\phi 2</math></b> |                          |      |          |          |         |                       |
| Pulse Width                                                           | $t_{\phi 2}, t_{\phi 2}$ | 250  | —        | —        | ns      |                       |
| Skew ( $\phi 1, \phi 2$ delay)                                        | $t_{12}, t_{21}$         | 0    | —        | —        | ns      |                       |
| Clock Period                                                          | $t_{cy}$                 | 0.5  | —        | 2.0      | $\mu s$ |                       |
| Rise & Fall Times                                                     | $t_r, t_f$               | —    | —        | 15       | ns      |                       |
| <b>Master SYNC:</b>                                                   |                          |      |          |          |         |                       |
| Delay from $\phi$                                                     | $t_{ms}$                 | —    | —        | 30       | ns      |                       |
| <b>DO-D15 Bus Signals</b>                                             |                          |      |          |          |         |                       |
| Output delay from $\phi 1$ (float to output)                          | $t_{BO}$                 | —    | —        | 200      | ns      | 1 TTL Load & 25 pF    |
| Output delay from $\phi 2$ (output to float)                          | $t_{BF}$                 | —    | 50       | —        | ns      |                       |
| Input setup time before $\phi 1$                                      | $t_{B1}$                 | 0    | —        | —        | ns      |                       |
| Input hold time after $\phi 1$                                        | $t_{B2}$                 | 10   | —        | —        | ns      |                       |
| <b>Bus Control Signals BC1,BC2,BDIR</b>                               |                          |      |          |          |         |                       |
| Output delay from $\phi 1$                                            | $t_{DC}$                 | —    | —        | 200      | ns      |                       |
| BUSAK Output delay from $\phi 1$                                      | $t_{BU}$                 | —    | 150      | —        | ns      |                       |
| TCI Output delay from $\phi 1$                                        | $t_{TO}$                 | —    | 200      | —        | ns      |                       |
| TCI Pulse Width                                                       | $t_{TW}$                 | —    | 300      | —        | ns      |                       |
| EBCA output delay from BEXT input                                     | $t_{DE}$                 | —    | —        | 150      | ns      |                       |
| EBCA wait time for EBCI input                                         | $t_{AI}$                 | —    | —        | 400      | ns      |                       |
| <b>CAPACITANCE</b>                                                    |                          |      |          |          |         |                       |
| $\phi 1, \phi 2$ Clock Input capacitance                              | $C_{\phi 1}, C_{\phi 2}$ | —    | 20       | 30       | pF      |                       |
| <b>Input Capacitance</b>                                              |                          |      |          |          |         |                       |
| DO-D15                                                                | $C_{IN}$                 | —    | 6        | 12       | pF      |                       |
| All Other                                                             | —                        | —    | 5        | 10       | pF      |                       |
| <b>Output Capacitance</b>                                             |                          |      |          |          |         |                       |
| DO-D15 in high impedance state                                        | $C_o$                    | —    | 8        | 15       | pF      |                       |

\*\*Typical values are at +25°C and nominal voltages.

**NOTE:**

The Bus Data ReaDY(BDRDY) line is sampled during time period TSI after a BAR or ADAR bus control signal. BDRDY must go low requesting a wait state 50 ns before the end of TSI and remain low for 50 ns minimum. BDRDY may go high asynchronously. In response to BDRDY, the CPU will extend bus cycles by adding additional microcycles up to a maximum of 40  $\mu$ sec duration.

# IOB1680

## ELECTRICAL CHARACTERISTICS

### Maximum Ratings\*

|                                                                                            |                 |
|--------------------------------------------------------------------------------------------|-----------------|
| $V_{DD}$ and $V_{CC}$ and all other input/output voltages<br>with respect to GND . . . . . | -0.3V to +18V   |
| Storage Temperature . . . . .                                                              | -55°C to +150°C |
| Operating Temperature . . . . .                                                            | 0°C to +70°C    |

\*Exceeding these ratings could cause permanent damage. Functional operation of this device at these conditions is not implied—operating ranges are specified below.

### Standard Conditions (unless otherwise noted)

All voltages referenced to GND  
 $V_{DD} = +12V \pm 5\%$   
 $V_{CC} = +5V \pm 5\%$   
 Operating Temperature ( $T_A$ ) = 0°C to +70°C

| Characteristic                                                                     | Symbol           | Min | Typ**    | Max      | Unit    | Condition           |
|------------------------------------------------------------------------------------|------------------|-----|----------|----------|---------|---------------------|
| <b>DC CHARACTERISTICS</b>                                                          |                  |     |          |          |         |                     |
| Clock Input: High                                                                  | $V_{ihc}$        | 2.4 | —        | $V_{DD}$ | V       |                     |
| Low                                                                                | $V_{ilc}$        | 0   | —        | .5       | V       |                     |
| Logic Inputs: High                                                                 | $V_{ih}$         | 2.4 | —        | $V_{CC}$ | V       |                     |
| Low                                                                                | $V_{il}$         | 0   | —        | .65      | V       |                     |
| Logic Outputs: High                                                                | $V_{oh}$         | 2.4 | $V_{CC}$ | —        | V       | $I_{oh} = 100\mu A$ |
| Low                                                                                | $V_{ol}$         | —   | —        | .5       | V       | $I_{ol} = 1.6mA$    |
| <b>AC CHARACTERISTICS</b>                                                          |                  |     |          |          |         |                     |
| <b>Clock Inputs</b>                                                                |                  |     |          |          |         |                     |
| $\bar{CK}_1$ , Clock period                                                        | $t_{\mu c}$      | 0.4 | —        | 4.0      | $\mu s$ |                     |
| Clock width                                                                        | $t_{cl}$         | 70  | —        | —        | ns      |                     |
| Rise & Fall times                                                                  | $t_{cr}, t_{cf}$ | —   | —        | 10       | ns      |                     |
| <b>CAPACITANCE</b> ( $T_A = 25^\circ C$ ,<br>$V_{DD} = +12V$ ,<br>$V_{CC} = +5V$ ) |                  |     |          |          |         |                     |
| Input Capacitance: D0-D7                                                           | $C_{in}$         | —   | 6        | 12       | pF      | $V_{in} = 0V$       |
| All others                                                                         | —                | —   | 5        | 10       | pF      | $V_{in} = 0V$       |
| Output Capacitance:                                                                | $C_{out}$        | —   | 8        | 15       | pF      |                     |

\*\*Typical values are at +25°C and nominal voltages.



### CIRCUIT DESCRIPTION

This circuit is designed to provide all the data buffering and control functions required when interfacing the Series 1600 Microprocessor System to a simple peripheral device. Data is transferred to and from the peripheral on 16 bidirectional lines, each of which can be considered to be an input or output. The transfer of information with the CP1600 is accomplished via an 8-bit highway, the 16-bits being transferred as two 8-bit bytes. The register addresses are assigned CP1600 memory locations, as follows (N is an arbitrary starting address):

### Register Address Description

|       |                                     |
|-------|-------------------------------------|
| N     | Control Register                    |
| N + 1 | Data Register Low Order 8-bits      |
| N + 2 | Data Register High Order 8-bits     |
| N + 3 | Timer Low Order 8-bits              |
| N + 4 | Timer High Order 8-bits             |
| N + 5 | Peripheral Interrupt Address Vector |
| N + 6 | Timer Interrupt Address Vector      |
| N + 7 | Error Interrupt Address Vector      |

# Chapter 17

## THE GENERAL INSTRUMENT 1650 SERIES MICROCOMPUTERS

The 1650 series of one-chip microcomputers have been manufactured by General Instrument to compete in the high-volume, price sensitive, digital logic replacement market. If we compare the 1650 series of one-chip microcomputers to other one-chip microcomputers, they are most similar to the 3870; in reality, they are copies of no other product. They are unique devices in their own right.

Describing the 1650 family of microcomputers at this point in the book is, perhaps, not strictly accurate, since they are not 16-bit microcomputers, nor do they have any relationship to the CP1600 described in the previous chapter.

The 1650 series have separate on-chip program and data memories. Program memory is 12 bits wide, while data memory is 8 bits wide. Table 17-1 summarizes the 1650 options. None of these microcomputers are expandable. If your application outgrows the 1670, then you must look elsewhere for a replacement.

The prime source for the 1650 series of microcomputers is:

GENERAL INSTRUMENT CORP.  
Microelectronics Division  
600 West John Street  
Hicksville, New York 11802

In Europe a second source for the 1650 is:

INTERMETALL  
19 Hans-Bun Strasse  
7800 Freiburg  
West Germany

The 1650 series microcomputers use a single +5V power supply. With an oscillator frequency of 1 MHz, instructions execute in four or eight microseconds.

1650 series devices are packaged as 18-pin, 28-pin, or 40-pin DIPs. They are manufactured using NMOS ion implantation technology and have TTL-compatible signals.

**Figure 17-1 illustrates that part of our general microcomputer system logic which is implemented on the 1650 series one-chip microcomputers.** Once again, we must warn against making direct comparisons using these figures; logic shown as present says nothing about the extent to which the logic has been implemented. Read/write memory is shown only half present because between 11 and 39 bytes of on-chip read/write memory are provided by the various 1650 options. 64 words is the smallest amount of read/write memory provided by any other one-chip microcomputer.

### A 1650 FUNCTIONAL OVERVIEW

**Logic of the 1650 series microcomputers is illustrated functionally in Figure 17-2.**

The Arithmetic and Logic Unit and the Control Unit are inaccessible to you as a user, therefore we will ignore this portion of the microcomputer.

Table 17-1. 1650 Series One-Chip Microcomputer Options

| Part Number | Program Memory 12-Bit Words | Data Memory Bytes | I/O Lines | Input Only Lines | Output Only Lines | Stack Levels | Interrupts | Power Supply | Package Pins |
|-------------|-----------------------------|-------------------|-----------|------------------|-------------------|--------------|------------|--------------|--------------|
| 1650        | 512                         | 23                | 8 x 4     | -                | -                 | 2            | No         | + 5V         | 40           |
| 1655        | 512                         | 23                | 8 x 1     | 4 x 1            | 8 x 1             | 2            | No         | + 5V         | 28           |
| 1670        | 1024                        | 39                | 8 x 4     | -                | -                 | 4            | Yes        | + 5V         | 40           |
| 1645        | 256                         | 16                | 4 x 1     | 4 x 1            | 4 x 1             | 3            | Yes        | + 5V         | 18           |



Figure 17-1. Logic of the 1650 Series Microcomputers



Figure 17-2. 1650 Functional Logic

**Program memory is 12 bits wide. The 1650 has 512 words of program memory. As illustrated in Table 17-1, other variations may have 256 or 1024 words of program memory.** All program memory is read-only memory. There are currently no EPROM or EAROM program memory versions of the 1650. For development purposes, there is the 1664, which has no on-chip program memory; rather, it generates a memory Address Bus and a program memory Data Bus via a 64-pin DIP, so that external program memory can be accessed. Note that General Instrument has strong EAROM (Electrically Alterable Read-Only Memory) technology, but no significant EPROM (Erasable Programmable Read-Only Memory) technology. EPROMs and EAROMs are described in Volume 3.

**1650  
PROGRAM  
MEMORY**

**I/O ports of 1650 series microcomputers are connected directly to 8-bit registers which can also be accessed as general purpose registers.** In Figure 17-2, Registers R5, R6, R7, and R8 are shown connected to four 8-bit bidirectional I/O ports. **I/O variations for other 1650 options are summarized in Table 17-1. Register connections for these other options are defined in Table 17-2.**

**1650 I/O  
PORT  
REGISTERS**  
**1650 I/O  
PIN LOGIC**

**Those 1650 series microcomputer I/O pins which are defined as bidirectional are, in reality, pseudo-bidirectional. Pin logic is illustrated in Figure 17-3.** The logic illustrated in this figure has become standard pseudo-bidirectional pin logic for one-chip microcomputers. The 3870 and 8048 have similar logic.

When outputting data to a 1650 I/O port pin, the data is applied to the D input of a D-type flip-flop, which is clocked by an internal WRITE control signal. The reason for having two sets of gates on the flip-flop output is to provide a high voltage from  $V_{XX}$  when switching a pin low.  $V_{CC}$  sources 100 microamps. Thus, external logic connected to a high-level pin need only sink 100 microamps in order to pull a high pin low. External logic that attempts to write a 1 to a pin that is outputting 0 must pull-up Q2, which will be on and connected to ground; this is not feasible. Therefore, as was

the case for other one-chip microcomputers, the CPU can output a 0 or a 1 to any pin, but a pin that is going to receive input must first have a 1 written to it. External logic can now leave 1 at the pin, or can pull the 1 to a 0. External logic cannot write a 1 to a pin that is outputting 0.

For a complete discussion of this pseudo-bidirectional logic, refer to the 8048 functional overview presented in Chapter 6.

## 1650 SERIES MICROCOMPUTER PROGRAMMABLE REGISTERS

All of the 1650 series microcomputers have a single 8-bit Accumulator plus a register file, as illustrated in Figure 17-2.

All registers in the register file are eight bits wide, with the exception of the Program Counter and the Status register.

The Accumulator, which is referred to in General Instrument's literature as the W register, is a primary Accumulator, as described for other microcomputers in this book. It is the source of one operand for two-operand instructions, and an optional destination for any instruction that moves or operates on data.

**1650  
ACCUMULATOR**



Figure 17-3. 1650 Series Microcomputer Bidirectional I/O Port Pin Logic

**Register 0 does not exist. When identified by any instruction, implied register addressing via Register 4 is assumed.** That is to say, when Register 0 is specified as a source or destination, the register identified by R4 will be selected instead. For example, suppose R4 contains 0F<sub>16</sub>. An instruction which selects R0 will then, in fact, access R15.

Register R1 can be used as a general purpose register unless you are making use of 1650 real-time clock/counter logic. Every high-to-low transition of the RTCC input increments the contents of R1.

**Register R2 is the Program Counter.** The bit width of Register R2 depends on program memory size. For 1650 series microcomputers that have 512 words of program memory, R2 will be nine bits wide. The 1670 one-chip microcomputer will have a 10-bit R2 register, while the 1645 will have an 8-bit R2 register. **R2 is a write-only location;** however, it is otherwise treated as a general purpose register. Thus, any instruction that specifies a general purpose register as a destination, without

**1650  
PROGRAM  
COUNTER**

specifying the same general purpose register as a source, can select Register R2. But note that all data manipulations operate on eight bits of data only. Thus, to a limited extent, 1650 series microcomputer program memory is divided into 256-word pages.

**Register R3 is the Status register. This register is only three bits wide and contains the following status flags:**

1650  
STATUS  
REGISTER



The Carry status is absolutely standard. It reflects a carry out of the high-order bit following an arithmetic operation. When a subtract instruction is executed, the Carry status is set if two's complement addition causes a carry out of the high-order result bit.

The Digit Carry status is an Auxiliary Carry; it identifies any carry from bit 3 to bit 4:



The Zero status is set to 1 when an arithmetic operation produces a 0 result; it is reset to 0 when an arithmetic operation generates a non-zero result.

Register R3 is a read/write location. Instructions can identify R3 as a source or destination for data. When reading the contents of R3, bits 3 through 7 will be read as 1 bits. When writing to R3, bits 3 through 7 will be lost.

**Register R4 is a register pointer similar to the ISAR register described for the 3870. Register R4 is an 8-bit register; however, the low-order five bits are interpreted as a register select whenever an instruction identifies R0 (which does not exist).**

Table 17-2. 1650 Series Microcomputer Register Designations

| REGISTER | FUNCTION                                                      |                                 |                      |                                  |
|----------|---------------------------------------------------------------|---------------------------------|----------------------|----------------------------------|
|          | 1650                                                          | 1655                            | 1670                 | 1645                             |
| R0       | Not implemented. Specifies implied register addressing via R4 |                                 |                      |                                  |
| R1       | Real-time clock/counter register                              |                                 |                      |                                  |
| R2       | Program Counter                                               |                                 |                      |                                  |
| R3       | Status register                                               |                                 |                      |                                  |
| R4       | File Select register, holds implied register address          |                                 |                      |                                  |
| R5       | I/O Port A                                                    | I/O Port A                      | I/O Port A           | I/O Port A<br>(bits 0-3 only)    |
| R6       | I/O Port B                                                    | Output Port B                   | I/O Port B           | Output Port B<br>(bits 0-3 only) |
| R7       | I/O Port C                                                    | Input Port C<br>(bits 0-3 only) | I/O Port C           | Input Port C<br>(bits 0-3 only)  |
| R8       | I/O Port D                                                    | Scratchpad register             | I/O Port D           | Scratchpad register              |
| R9-R19   | Scratchpad registers present in all versions                  |                                 |                      |                                  |
| R20-R23  | Scratchpad registers                                          |                                 |                      |                                  |
| R24-R31  | Scratchpad registers                                          |                                 |                      |                                  |
| R32-R47  | Not present                                                   |                                 | Scratchpad registers | { Not present                    |

**Registers R5 through R8 are connected to I/O ports in various ways for different members of the 1650 family, as defined in Table 17-2.** When you write to any one of these four registers, associated I/O port pins, if they contain output logic, will generate a high output level for a 1 and a low output level for a 0. When you read the contents of Register R5, R6, R7, or R8, then each register bit that is connected to an I/O port input pin will reflect the level of the most recently input data. For an I/O pin, if no data has been input, then the most recently output data will be read back. Any register bit that is not connected to an I/O port pin becomes a standard Scratchpad register bit. Whatever was most recently written to this bit will be read back.

**Beginning with Register R9, remaining registers are general Scratchpad registers.** Different 1650 versions provide different numbers of Scratchpad registers.

## 1650 SERIES MICROCOMPUTER MEMORY ADDRESSING MODES

Since the 1650 series microcomputers have a very small number of data registers; they have very simple data memory addressing options. Scratchpad registers up to R31 may be identified directly by any instruction that operates on data. If Register R0 is identified, however, then the register selected by the low-order five bits of Register R4 will in fact be selected. This may be illustrated as follows:



For the 1670 only, six bits of Register R4 are active address bits. This is necessary since the 1670 has general purpose registers numbered up to 47<sub>10</sub>. Note that **for the 1670, general-purpose registers R32 through R47 can be accessed only via Register R4, using indirect addressing.**

**Program memory is addressed by Jump instructions and Jump-to-Subroutine instructions, using direct addressing only.**

Jump instructions can identify any 9-bit address — covering the 512 words of program memory.

The Jump-to-Subroutine instruction can directly address only the first 256 words of program memory; all subroutines must therefore be originated in the first 256 words of program memory, although a subroutine can be called from any memory word.

**The 1670 one-chip microcomputer has a four-level Stack; other 1650 series one-chip microcomputers have a two-level or three-level Stack.** Thus, with the exception of the 1670 and the 1645, only a single level of subroutine nesting is allowed. The 1670 allows three levels of subroutine nesting, the 1645, two. For a program that can only be 512 words long, two levels of subroutine nesting are probably quite sufficient.

1650  
STACK

## 1650 SERIES MICROCOMPUTER PINS AND SIGNALS

**Figure 17-4 illustrates pins and signals for the 1650 microcomputer.**

**1645 pin assignments are not available at the present time.**

The 1650 series microcomputers communicate with external logic via their I/O ports. In Figure 17-4, three types of I/O pins are identified: **pseudo-bidirectional**, **input-only**, and **output-only** pins. We have already described the logic of pseudo-bidirectional pins. Input-only and output-only pins, as their names imply, are limited to receiving data from external logic only or transmitting data to external logic only.

The 1650 series microcomputers have just two control signals: **MCLR** and **RTCC**.

**MCLR** is a master reset control input. This signal should be held low for at least 1 millisecond after the power supply is valid. It forces all output pins to a high level and it sets all Program Counter bits to 1. Therefore, the first instruction executed following a reset will be located at the highest program memory location.



Figure 17-4. 1650 Microcomputer Signals and Pin Assignments

On high-to-low transitions of **RTCC**, the contents of Register R1 are incremented. **RTCC** will not respond to a frequency that is greater than 250 KHz. That is all there is to 1650 counter/timer logic. No interrupts are generated on a time-out, nor is there any special logic associated with reading the contents of Register R1 or writing to this register. A program will access Register R1 as it would any other register, and **RTCC** will increment register contents without regard to events internal to the microcomputer.

If you are not using counter/timer logic, it is a good idea to ground the **RTCC** pin.

**TEST** is a control input used to read the contents of program memory as data. General Instrument purposely provides no information on the **TEST** pin or how it is used, since they do not want customers using this pin.

1650  
COUNTER/  
TIMER  
LOGIC

Two pins are associated with clock logic: the OSC input and the CLK OUT output. For very precise execution frequency, an external oscillator signal can be input via OSC. For less precise input, an RC network may generate the input as follows:



$R_{ext}$  and  $C_{ext}$  options are described in the data sheets at the end of this chapter.

**The clock signal which drives the microcomputer is output via CLK OUT.**

**The very simple timing associated with 1650 series one-chip microcomputers is given in the data sheets at the end of this chapter.**

Although you can run any 1650 series one-chip microcomputer with a single +5V power supply, it is sometimes desirable to have an additional +10V power supply connected to the  $V_{XX}$  input. As illustrated in Figure 17-3, this power supply allows the bidirectional I/O port pins to sink more current, typically to drive higher current loads such as LED displays.

#### 1650 TIMING

#### 1650 $V_{XX}$ POWER SUPPLY

**None of the 1650 series microcomputers have any DMA or interrupt logic.** The absence of DMA logic makes a lot of sense; the whole concept of Direct Memory Access is ridiculous when your data memory consists of 39 bytes or less. The absence of interrupt logic is simply a designer's choice. There are plenty of arguments for including interrupt logic in a one-chip microcomputer, since this allows external devices to influence event sequences asynchronously within the one-chip microcomputer. In the absence of interrupt logic, a program executed by a 1650 series microcomputer must test an input pin looking for a high or low level to trigger specific events.

## 1650 SERIES MICROCOMPUTER INSTRUCTION SET

**The 1650 series microcomputer instruction set is summarized in Table 17-3.**

We have arbitrarily chosen to classify instructions which access registers as memory reference instructions. These are also I/O instructions if Register R5, R6, R7, or R8 is identified. If Register R3 is identified, they become status instructions. Furthermore, any of these instructions could also be classified as register-register instructions.

Instructions that test, set, and clear bits become I/O instructions if a bit of Register R5, R6, R7, or R8 is specified; they are Status registers if Register R3 is specified.

The more you look at the 1650 instruction set, the more multifaceted many of the instructions become. General Instrument recognized this fact by creating **assembly language instruction mnemonics to identify special cases** of instructions. These are summarized in Table 17-4.

**There are two anomalies in the 1650 instruction set which you must guard against.**

**There is no Add-with-Carry instruction.** This makes it difficult to handle multi-byte arithmetic. Consider 16-bit binary addition.

You can start off simply enough by adding the two low-order bytes; this will generate a carry for the two high-order bytes:

$$\begin{array}{r}
 1 \quad \leftarrow C \\
 31 \quad EA \\
 24 \quad 6B \\
 \hline
 55
 \end{array}$$

On first inspection, adding the two high-order bytes looks like no problem. You can add the carry to the augend:

$$\begin{array}{r}
 0 \quad \leftarrow C \\
 32 \quad EA \\
 24 \quad 6B \\
 \hline
 55
 \end{array}$$

Then you add the high-order addend byte to the sum of the high-order augend byte plus the carry:

$$\begin{array}{r} 0 \leftarrow C \\ 32 \quad EA \\ 24 \quad 6B \\ \hline 56 \quad 55 \end{array}$$

A problem arises if the high-order augend byte happens to be FF. Now when you add a carry to FF, you get 00 and the carry is reset:

$$\begin{array}{c} 1 \leftarrow C \rightarrow 1 \\ \text{FF} \quad EA \quad 00 \quad EA \\ 24 \quad 6B \quad 24 \quad 6B \\ \hline 55 \quad \quad \quad 55 \end{array}$$

Upon adding the high-order addend byte, the Carry status will be cleared erroneously:

$$\begin{array}{r} 0 \leftarrow C \text{ (should be 1)} \\ 00 \quad EA \\ 24 \quad 6B \\ \hline 24 \quad 55 \end{array}$$

This becomes a significant problem when dealing with numbers that are three or more bytes long, since you can no longer guarantee that the correct carry will be generated for the second and higher-order bytes. There are ways around this problem, but they lead to more complex programs. Fortunately the problem is not particularly severe, since in an application that is limited to a data memory as small as that of the 1650 you are most unlikely to have much multi-byte arithmetic anyway.

Note that **any time you return from a subroutine you will modify the contents of the Accumulator**.

**Table 17-5 summarizes 1650 instruction object codes and execution times.**

## THE 1650 BENCHMARK PROGRAM

Our standard benchmark program is of little use with the 1650 microcomputers. Given the very small amount of data memory available, moving blocks of data around makes no sense. We therefore illustrate a modified benchmark program in which a number of data bytes are input via I/O Port A and then output via I/O Port B. The first data byte input identifies the length of the data block which follows.

We are going to use bit 0 of I/O Port C to provide handshaking controls between the 1650 and external logic. Whenever external logic transmits new data to I/O Port A, it resets bit 0 of I/O Port C low. The 1650 program tests this bit before attempting to read data from I/O Port A. As soon as the program outputs data to I/O Port B, it sets I/O Port C bit 0 high again. Thus, external logic can wait until it detects I/O Port C bit 0 high before attempting to input new data — which will be followed by I/O Port C bit 0 being pulled low by external logic.

Here is the necessary instruction sequence:

|      |        |      |                                            |
|------|--------|------|--------------------------------------------|
|      | MOVLW  | FF   | INITIALIZE PORT A FOR INPUT BY             |
|      | MOVWF  | R5   | OUTPUTTING ALL HIGH BITS                   |
|      | BSF    | R7,0 | SET PORT C BIT 0 HIGH                      |
| L1   | BTFSZ  | R7,0 | IF PORT C BIT 0 IS 0, READ FIRST DATA BYTE |
|      | GOTO   | L1   |                                            |
|      | MOVF   | R5   | INPUT FIRST BYTE                           |
|      | MOVWF  | R9   | STORE AS A COUNTER IN R9                   |
| LOOP | BSF    | R7,0 | SET PORT C BIT 0 HIGH                      |
| L2   | BTFSZ  | R7,0 | IF PORT C BIT 0 IS 0, READ NEXT DATA BYTE  |
|      | GOTO   | L2   |                                            |
|      | MOVF   | R5,0 | INPUT NEXT DATA BYTE FROM PORT A           |
|      | MOVWF  | R6   | OUTPUT VIA PORT B                          |
|      | MOVLW  | FF   | PREPARE PORT A FOR NEW INPUT               |
|      | MOVWF  | R5   |                                            |
|      | DECFSZ | R9   | DECREMENT R9                               |
|      | GOTO   | LOOP | IF NOT ZERO, RETURN FOR NEXT BYTE          |

These abbreviations are used in Tables 17-3 and 17-4:

|          |                                                                                    |
|----------|------------------------------------------------------------------------------------|
| R        | Any register                                                                       |
| W        | Accumulator, or W register                                                         |
| d        | Destination identifier digit; must be 0 or 1.                                      |
| [R]      | Ones complement of Register R contents                                             |
| DATA     | Immediate 8-bit data value                                                         |
| LABEL9   | Program memory address (9 bits)                                                    |
| [STACK]← | Push onto Stack                                                                    |
| →[STACK] | Pop off Stack                                                                      |
| n        | A bit identification number, in the range 0 through 7. (0 low-order, 7 high-order) |

Table 17-3. A Summary of the 1650 Series Microcomputer Instruction Set

| TYPE                                                   | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |  | OPERATION PERFORMED                                                                                                                          |
|--------------------------------------------------------|----------|------------|-------|----------|----|---|--|----------------------------------------------------------------------------------------------------------------------------------------------|
|                                                        |          |            |       | C        | DC | Z |  |                                                                                                                                              |
| I/O, PRIMARY MEMORY<br>REFERENCE AND<br>REGISTER MOVE  | MOVF     | R,O        | 1     |          |    | X |  | [W]—[R]<br>Move register (or I/O port) contents to Accumulator.                                                                              |
|                                                        | MOVWF    | R          | 1     |          |    |   |  | [R]—[W]<br>Move Accumulator contents to register or I/O port.                                                                                |
|                                                        | ADDWF    | R,d        | 1     | X        | X  | X |  | [W]—[W] + [R] if d=0. [R]—[W] + [R] if d=1.<br>Add Accumulator and register contents. Store sum in the Accumulator or source register.       |
|                                                        | ANDWF    | R,d        | 1     |          |    | X |  | [W]—[W] AND [R] if d=0. [R]—[W] AND [R] if d=1<br>AND Accumulator and register contents. Store result in the Accumulator or source register. |
|                                                        | CLRF     | R          | 1     |          |    | 1 |  | [R]—0<br>Zero Register R contents.                                                                                                           |
|                                                        | COMF     | R,d        | 1     |          |    | X |  | [W]—[R] if d=0. [R]—[R] if d=1<br>Store the ones complement of register contents in the Accumulator, or back in the register.                |
|                                                        | DECf     | R,d        | 1     |          |    | X |  | [W]—[R] - 1 if d=0. [R]—[R] - 1 if d=1<br>Store decremented register contents in the Accumulator, or back in the register.                   |
|                                                        | INCF     | R,d        | 1     |          |    | X |  | [W]—[R] + 1 if d=0. [R]—[R] + 1 if d=1<br>Store incremented register contents in the Accumulator, or back in the register.                   |
|                                                        | IORWF    | R,d        | 1     |          |    | X |  | [W]—[R] OR [W] if d=0. [R]—[R] OR [W] if d=1<br>OR Accumulator and register contents. Store result in the Accumulator or Source register.    |
|                                                        | RLF      | R,d        | 1     | X        |    |   |  | Left rotate register contents. Store result in Accumulator if d=0 or in register if d=1.                                                     |
| SECONDARY I/O, MEMORY OR REGISTER<br>REFERENCE/OPERATE | RRF      | R,d        | 1     | X        |    |   |  | Right rotate register contents. Store result in Accumulator if d=0 or in register if d=1.                                                    |



Table 17-3. A Summary of the 1650 Series Microcomputer Instruction Set (Continued)

| TYPE                                                    | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |  |  | OPERATION PERFORMED                                                                                                                                                              |
|---------------------------------------------------------|----------|------------|-------|----------|----|---|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         |          |            |       | C        | DC | Z |  |  |                                                                                                                                                                                  |
| SECONDARY I/O, MEMORY OR REGISTER<br>REFERENCE(OPERATE) | SUBWF    | R,d        | 1     | X        | X  | X |  |  | [W] $\leftarrow$ [R] - [W] if d=0; [R] $\leftarrow$ [R] - [W] if d=1<br>Subtract Accumulator contents from register contents. Store result in Accumulator or source register.    |
|                                                         | SWAPF    | R,d        | 1     |          |    |   |  |  | Swap register nibbles. Store result in Accumulator if d=0 or in register if d=1.                                                                                                 |
|                                                         | XORWF    | R,d        | 1     |          |    | X |  |  | :Exclusive-OR Accumulator and register contents. Store result in Accumulator if d=0 or in register if d=1.                                                                       |
| JUMP IMMEDIATE                                          | MOVLW    | DATA       | 1     |          |    |   |  |  | [W] $\leftarrow$ DATA<br>Load immediate data into Accumulator.                                                                                                                   |
| JUMP                                                    | GOTO     | LABEL9     | 1     |          |    |   |  |  | [R2] $\leftarrow$ LABEL9<br>Jump to instruction LABEL9, anywhere in 512 word program memory.                                                                                     |
| SUBROUTINE<br>CALL AND RETURN                           | CALL     | LABEL8     | 1     |          |    |   |  |  | [STACK] $\leftarrow$ [R2]+1, [R2] $\leftarrow$ LABEL8<br>Jump to subroutine originated at LABEL8, anywhere in first 256 words of program memory. Push return address onto Stack. |
|                                                         | RET      |            | 1     |          |    |   |  |  | [R2] $\leftarrow$ [STACK], [W] $\leftarrow$ 0<br>Return from subroutine and clear Accumulator.                                                                                   |
|                                                         | RETLW    | DATA       | 1     |          |    |   |  |  | [R2] $\leftarrow$ [STACK], [W] $\leftarrow$ DATA<br>Return from subroutine and load immediate data into Accumulator.                                                             |
| IMMEDIATE OPERATE                                       | ANDLW    | DATA       | 1     |          |    | X |  |  | [W] $\leftarrow$ [W] AND DATA<br>AND Accumulator contents with immediate data. Store result in Accumulator.                                                                      |
|                                                         | IORLW    | DATA       | 1     |          |    | X |  |  | [W] $\leftarrow$ [W] OR DATA<br>OR Accumulator contents with immediate data. Store result in Accumulator.                                                                        |
|                                                         | XORLW    | DATA       | 1     |          |    | X |  |  | [W] $\leftarrow$ [W] XOR DATA<br>Exclusive-OR Accumulator contents with immediate data. Store result in Accumulator.                                                             |

Table 17-3. A Summary of the 1650 Series Microcomputer Instruction Set (Continued)

| TYPE                      | MNEMONIC                           | OPERAND(S)               | BYTES            | STATUSES |    |   |  | OPERATION PERFORMED                                                                                                                                                                                                                                                                                          |
|---------------------------|------------------------------------|--------------------------|------------------|----------|----|---|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           |                                    |                          |                  | C        | DC | Z |  |                                                                                                                                                                                                                                                                                                              |
| SKIP ON CONDITION         | BTFSC<br>BTFSZ<br>DECFSZ<br>INCFSZ | R,n<br>R,n<br>R,d<br>R,d | 1<br>1<br>1<br>1 |          |    |   |  | Test bit n of Register R. If it is 0, skip the next instruction.<br>Test bit n of Register R. If it is 1, skip the next instruction.<br>Decrement Register R contents. If the result is zero, skip the next instruction.<br>Increment Register R contents. If the result is zero, skip the next instruction. |
| REGISTER OPERATE          | CLRW                               |                          |                  |          | 1  |   |  | [W]—0<br>Clear Accumulator.                                                                                                                                                                                                                                                                                  |
| STATUS AND BIT OPERATIONS | BCF<br>BSF                         | R,n<br>R,n               |                  |          |    |   |  | Reset bit n of Register R to 0<br>Set bit n of Register R to 1                                                                                                                                                                                                                                               |
|                           | NOP                                |                          |                  |          |    |   |  | No operation.                                                                                                                                                                                                                                                                                                |

Table 17-4. Mnemonics Recognized by the 1650 Assembler for Special Cases of General Instructions

| Special Mnemonic | Equivalent Mnemonic(s) | Status Affected | Function                       |
|------------------|------------------------|-----------------|--------------------------------|
| CLRC             | BCF 3,0                | -               | Clear Carry                    |
| SETC             | BSF 3,0                | -               | Set Carry                      |
| CLRDC            | BCF 3,1                | -               | Clear Digit Carry              |
| SETDC            | BSF 3,1                | -               | Set Digit Carry                |
| CLRZ             | BCF 3,2                | -               | Clear Zero                     |
| SETZ             | BSF 3,2                | -               | Set Zero                       |
| SKPC             | BTFS 3,0               | -               | Skip on Carry                  |
| SKPNC            | BTFS 3,0               | -               | Skip on No Carry               |
| SKPDC            | BTFS 3,1               | -               | Skip on Digit Carry            |
| SKPNDC           | BTFS 3,1               | -               | Skip on No Digit Carry         |
| SKPZ             | BTFS 3,2               | -               | Skip on Zero                   |
| SKPNZ            | BTFS 3,2               | -               | Skip on No Zero                |
| TSTF R           | MOVF R,1               | Z               | Test File                      |
| MOVFW R          | MOVF R,0               | Z               | Move File to W                 |
| NEGF R,d         | COMF R,1               |                 | Negate File                    |
|                  | INCF R,d               | Z               |                                |
| ADDCF R,d        | BTFS 3,0               | Z               | Add Carry to File              |
|                  | INCF R,d               | Z               |                                |
| SUBCF R,d        | BTFS 3,0               |                 | Subtract Carry from File       |
|                  | DEC F R,d              | Z               |                                |
| ADDDCF R,d       | BTFS 3,1               | Z               | Add Digit Carry to File        |
|                  | INCF R,d               | Z               |                                |
| SUBDCF R,d       | BTFS 3,1               | Z               | Subtract Digit Carry from File |
|                  | DEC F R,d              | Z               |                                |
| B LABEL9         | GO TO LABEL9           | -               | Branch                         |
| BC LABEL9        | BTFS 3,0               | -               | Branch on Carry                |
| BN C LABEL9      | GO TO LABEL9           | -               | Branch on No Carry             |
|                  | BTFS 3,0               | -               |                                |
| BN C LABEL9      | GO TO LABEL9           | -               | Branch on Digit Carry          |
| BNDC LABEL9      | BTFS 3,1               | -               | Branch on No Digit Carry       |
| BZ LABEL9        | BTFS 3,2               | -               | Branch on Zero                 |
| BNZ LABEL9       | BTFS 3,2               | -               | Branch on No Zero              |
|                  | GO TO LABEL9           | -               |                                |

The following abbreviations are used in the "Object Code" column of Table 17-5:

C - a "don't care" binary digit

n - binary digits that identify a bit number

r - binary digits that represent a register number

x - any hexadecimal digit

a - binary digits of a nine-bit address

Abbreviations defined for Table 17-3 are preserved in the "Instruction" column of Table 17-5.

Table 17-5. 1650 Instruction Set Object Codes

| Instruction                                                                                                                                                                       | Object Code   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| ADDWF R,d                                                                                                                                                                         | 000111drrrrr  |
| ANDLW DATA                                                                                                                                                                        | Exx           |
| ANDWF R,d                                                                                                                                                                         | 000101drrrrr  |
| BCF R,n                                                                                                                                                                           | 0100nnnnrrrr  |
| BSF R,n                                                                                                                                                                           | 0101nnnnrrrr  |
| BTFSZ R,n                                                                                                                                                                         | 0110nnnnrrrr  |
| BTFSZ R,n                                                                                                                                                                         | 0111nnnnrrrr  |
| CALL LABEL                                                                                                                                                                        | 9xx           |
| CLRF R                                                                                                                                                                            | 0000011rrrrr  |
| CLRW                                                                                                                                                                              | 0000010cccccc |
| COMF R,d                                                                                                                                                                          | 001001drrrrr  |
| DECFSZ R,d                                                                                                                                                                        | 000011drrrrr  |
| GOTO LABEL9                                                                                                                                                                       | 101aaaaaaaaaa |
| INCF R,d                                                                                                                                                                          | 001010drrrrr  |
| INCFSZ R,d                                                                                                                                                                        | 001111dmrrrr  |
| IORLW DATA                                                                                                                                                                        | Dxx           |
| IORWF R,d                                                                                                                                                                         | 000100drrrrr  |
| MOVF R,d                                                                                                                                                                          | 001000drrrrr  |
| MOVLW DATA                                                                                                                                                                        | Cxx           |
| MOVWF R                                                                                                                                                                           | 0000001rrrrr  |
| NOP                                                                                                                                                                               | 000           |
| RET                                                                                                                                                                               | 800           |
| RETLW DATA                                                                                                                                                                        | 8xx           |
| RLF R,d                                                                                                                                                                           | 001101drrrrr  |
| RRF R,d                                                                                                                                                                           | 001100dmrrrr  |
| SUBWF R,d                                                                                                                                                                         | 000010drrrrr  |
| SWAPF R,d                                                                                                                                                                         | 001110drrrrr  |
| XORLW DATA                                                                                                                                                                        | Fxx           |
| All object codes occupy one 12-bit word.                                                                                                                                          |               |
| All instructions execute in one machine cycle, with the exception of conditional Skip instructions, which execute in one machine cycle for no skip or two machine cycles to skip. |               |

## **DATA SHEETS**

The following section contains electrical data for the 1650.

## 1650 ELECTRICAL CHARACTERISTICS

### MAXIMUM RATINGS\*

Storage Temperature .....  $-55^{\circ}\text{C}$  to  $+150^{\circ}\text{C}$   
 Operating Temperature .....  $0^{\circ}\text{C}$  to  $+70^{\circ}\text{C}$   
 $V_{cc}$ ,  $V_{xx}$ , and all other input/output  
 voltages with respect to  $V_{ss}$  .....  $-0.3\text{V}$  to  $+12.0\text{V}$

\*Exceeding these ratings could cause permanent damage. Functional operation of this device at these conditions is not implied—operating ranges are specified below.

### STANDARD CONDITIONS (unless otherwise noted)

$V_{cc}$ :  $+5V \pm 5\%$   
 $V_{xx}$ :  $+4.75\text{V}$  to  $10.0\text{V}$

| Characteristics           | Sym                  | Min     | Typ**   | Max      | Units    | Conditions                                 |
|---------------------------|----------------------|---------|---------|----------|----------|--------------------------------------------|
| <b>DC CHARACTERISTICS</b> |                      |         |         |          |          |                                            |
| Power Supply Currents     | $I_{cc}$<br>$I_{xx}$ | —<br>—  | 35<br>1 | 50<br>5  | mA<br>mA |                                            |
| Logic Inputs              |                      |         |         |          |          |                                            |
| Low                       | $V_{IL}$             | 0       | —       | .65      | V        |                                            |
| High                      | $V_{IH}$             | 2.4     | —       | $V_{cc}$ | V        |                                            |
| Logic Outputs             |                      |         |         |          |          |                                            |
| Low (Note 1)              | $V_{OL}$             | —       | —       | 0.45     | V        | $V_{xx}=5\text{V}$ @ $I_{OL}=1.6\text{mA}$ |
| High                      | $V_{OH}$             | 2.4     | —       | $V_{cc}$ | V        | $I_{OH}=100\mu\text{A}$ min.               |
| <b>AC CHARACTERISTICS</b> |                      |         |         |          |          |                                            |
| OSC Frequency             | $f_{IN}$             | .2      | —       | 1        | MHz      |                                            |
| RTCC Frequency            | —                    | DC      | —       | 200      | KHz      |                                            |
| CLKOUT Frequency          | —                    | .25 fin | —       | —        | —        |                                            |
| CLK OUT                   |                      |         |         |          |          |                                            |
| Rise Time                 | $t_r$                | —       | —       | 200      | ns       |                                            |
| Fall Time                 | $t_f$                | —       | —       | 200      | ns       | 1 TTL load and 100 pF                      |
| I/O Registers A, B, C, D  |                      |         |         |          |          |                                            |
| Output Mode:              |                      |         |         |          |          |                                            |
| Delay From CLKOUT         | $t_{DD}$             | —       | —       | 500      | ns       | 1 TTL load and 100 pF                      |
| Input Mode                |                      |         |         |          |          |                                            |
| Set-Up                    | $t_{IS}$             | 0       | —       | —        | ns       |                                            |
| hold                      | $t_{IH}$             | 100     | —       | —        | ns       |                                            |

### 1650 LED Direct Drive

$V_{xx}$  drives the gate of the output buffer, allowing adjustment of LED drive capability:

| $V_{xx}$ | $V_{OUT}$ | $I_{SINK}$ (typ.) |
|----------|-----------|-------------------|
| 5V       | 0.4V      | 2.5mA             |
| 5V       | 0.7V      | 4.2mA             |
| 10V      | 0.4V      | 5.8mA             |
| 10V      | 0.7V      | 10.0mA            |
| 10V      | 1.0V      | 14.1mA            |

### 1650 OSCILLATOR INPUT

The oscillator input (OSC) can be driven directly by a crystal with compatible output or by an external RC network.



We reprint data sheets on pages 17-D2 through 17-D3 by permission of General Instrument Corporation.

1650 I/O TIMING



## Chapter 18

# THE TEXAS INSTRUMENTS TMS 9900, TMS 9980, AND TMS 9940 PRODUCTS

The TMS 9900 was the first 16-bit microprocessor that could compete effectively in the minicomputer market. In fact, the **TMS 9900 is a one-chip implementation of the TM 990 series minicomputer Central Processing Units.**

**The TMS 9900 is packaged as a 64-pin DIP;** it generates signals for a 15-bit Address Bus and a separate 16-bit Data Bus, whereas other 16-bit microprocessors multiplex their Data and Address Busses. **The TMS 9980 series microprocessors are 40-pin DIP versions of the TMS 9900;** in order to reduce pin counts, the TMS 9980 series microprocessors access external memory via an 8-bit Data Bus and 14-bit Address Bus. **The TMS 9940 is a one-chip microcomputer** containing a subset of the TMS 9900 Central Processing Unit, together with on-chip memory and real-time clock logic.

**The TMS 9900 product line has for some time been one of the enigmas of the microprocessor industry.** Even a casual examination of the TMS 9900 instruction set shows that from the programmer's viewpoint, this microprocessor was at least two years ahead of its time. While it may have had problems competing in high-volume, simple applications, it was certainly the microprocessor of choice for data processing-type, program-intensive applications, yet it was not widely used in these markets.

The reason for this lack of acceptance has been poor support from Texas Instruments.

Texas Instruments initially offered little support for the TMS 9900 because this microprocessor was designed as a low-end product of the TM 990 minicomputer series. That is to say, customers were expected to develop products around the TM 990 minicomputers; then, if they chose to, they could build production models around the TMS 9900 microprocessor. This development path did not call for extensive TMS 9900 support. In all probability, Texas Instruments was caught by surprise by the buoyancy of the microprocessor market — as a market in its own right. Certainly, if Texas Instruments had given the TMS 9900 the same level of support that Intel gave the 8080A, we would see entirely different microprocessor product distributions today. But the TMS 9900 and its derivative products are powerful enough that the belated support they are now receiving from Texas Instruments will give the product line a reasonable share of future markets.

**Texas Instruments now provides full support for the TMS 9900 microprocessor line.**

**TMS 9900 support devices are designed specifically for the TMS 9900; therefore, they are described in this chapter rather than in Volume 3. Support devices can be used with the TMS 9900, TMS 9980, or TMS 9940 products. The following devices are described:**

The TIM 9904 Clock Generator  
The TMS 9901 Programmable System Interface

**Texas Instruments is the primary manufacturer for all of the TMS 9900 series products.** TMS 9900 series products are handled out of the following Texas Instruments office:

TEXAS INSTRUMENTS, INC.  
P.O. Box 1443  
Houston, Texas 77001

Second sources for the TMS 9900 family are:

AMERICAN MICROSYSTEMS, INC.  
3800 Homestead Road  
Santa Clara, California 95051

SMC MICROSYSTEMS CORP. (TMS 9980 series only)  
35 Marcus Blvd.  
Hauppauge, N.Y. 11787

# THE TMS 9900 MICROPROCESSOR

The TMS 9900 is manufactured using N-channel silicon gate MOS technology. It is packaged as a 64-pin DIP. Three power supplies are required: -5V, +5V, and +12V.

Using a 3 MHz clock, instruction execution times range between 3 and 10 microseconds.

## A TMS 9900 FUNCTIONAL OVERVIEW

Figure 18-1 illustrates part of our general microcomputer system logic which is implemented by the TMS 9900 CPU.

The most important features of Figure 18-1 are:

- The absence of programmable registers
- The presence of significant interrupt handling logic
- The presence of serial-to-parallel data conversion logic
- The absence of I/O port interface logic



Figure 18-1. Logic of the TMS 9900 CPU

Let us first consider the manner in which the TMS 9900 handles programmable registers.

## TMS 9900 PROGRAMMABLE REGISTERS

Within the logic of the TMS 9900 itself, there are just three 16-bit programmable registers: a Program Counter, a Workspace register, and a Status register.

**The Program Counter and Status register are straightforward.** The Program Counter contains the address of the next instruction to be executed. The Status register maintains various statuses, which we describe later in this chapter.

**The Workspace register is a unique and powerful programming feature of the TMS 9900. This register identifies the first of sixteen 16-bit memory locations which act as 16 General Purpose registers. This may be illustrated as follows:**



Some of the 16 registers serve special functions, as defined by the text on the right-hand side of the illustration above. For the moment, do not attempt to understand these special functions. They are described later in the chapter.

In TMS 9900 microcomputer systems, external memory consists of 16-bit memory words. Each 16-bit memory word has its own memory address. Within the TMS 9900 CPU, however, memory is addressed as a sequence of 8-bit locations. For this to occur, the CPU

**TMS 9900  
MEMORY  
ADDRESSES**

generates an internal 16-bit memory address; the high-order 15 bits of the internal memory address create the external memory addresses. **This may be illustrated as follows:**



When designing hardware around the TMS 9900, you will implement external memory as 16-bit words, which are addressed by a 15-line Address Bus. That is to say, 32,768 16-bit words may be addressed.

But when you are programming the TMS 9900 you will visualize memory as 65,536 bytes, addressed by a 16-bit address. **An even byte address will access the low-order byte of an external 16-bit memory word, while an odd memory address will access the high-order byte of an external 16-bit memory word.**

Any 16 contiguous words of read/write memory may serve as the current 16 general purpose registers for the TMS 9900.

You may have as many sets of 16-bit registers as you wish, limited only by the size of implemented memory. If you are using more than one set of 16-bit registers, then at any time just one set of 16-bit registers can be selected. The WP register identifies the first of the 16 contiguous memory locations serving as the current 16 general purpose registers.

Each of the 16 general purpose registers may be used to store data or addresses. Thus, each general purpose register may serve as an Accumulator or as a Data Counter.

Registers R11 through R15 are used as special Pointer storage buffers; we will be describing the way in which these registers are used as the chapter proceeds.

Having 16 general purpose registers in read/write memory, rather than in the CPU, is the single most important feature of TMS 9900 architecture. The advantage of having 16 general purpose registers located anywhere in read/write memory is that you can have many sets of 16 general purpose registers. For example, following an interrupt acknowledge, you no longer need to save the contents of general purpose registers — all you need to do is save the contents of the Program Counter, the Workspace register and the Status register, and that is done automatically by TMS 9900 interrupt handling logic. By loading new values into the Program Counter and the Workspace register, you

can begin executing a new program, accessing 16 new memory words — which will be treated as a new set of 16 general purpose registers.

**The disadvantage of having 16 general purpose registers in read/write memory is that no TMS 9900 microcomputer system can be configured without read/write memory;** and if you are going to use many different sets of 16-bit registers, then you are going to require a significant amount of read/write memory. Furthermore, you lose the speed associated with executing register-to-register operations; there are no source and destination locations left in the CPU. Every register access becomes a memory access.

**TMS 9900 literature refers to the process of switching from one set of general purpose registers to another as a context switch.** This terminology reflects the complete change of program environment that results from the switch.

**TMS 9900  
CONTEXT  
SWITCH**

Special instructions allow you to perform a forward context switch or a backward context switch.

During a forward context switch, you load new values into the Workspace register and Program Counter, while simultaneously saving the old Workspace register, Program Counter, and Status register contents in the new General Purpose Registers R13, R14, and R15.

A backward, or reverse context switch loads the current contents of General Purpose Registers R13, R14, and R15 into the Workspace register, Program Counter, and Status register, respectively, thus returning you to your previous set of general purpose registers.

You can perform context switches as often as you like and whenever you like. For example, a very effective way of using context switching is to group data into contiguous memory words which you can identify as a register set. Upon entering a subroutine, you can perform a context switch which automatically creates all necessary initial data and address values in appropriate general purpose registers. This may be illustrated as follows:



As illustrated above, **when you perform a forward context switch**, the current Program Counter contents, Status register contents, and WP register contents are saved in what will become the new Registers R13, R14 and R15, respectively. **Here is the exact sequence in which events occur:**

**TMS 9900  
FORWARD  
CONTEXT  
SWITCH**

- 1) The new WP register contents are loaded into the CPU and held in temporary storage.
- 2) The current Status register contents are written out to the memory location which will become the new Register R15.
- 3) The current Program Counter contents are written out to the memory location which will become the new Register R14.
- 4) The current WP register contents are written out to the memory location which will become the new Register R13.
- 5) The new WP register contents, which were held in temporary storage, are moved into the WP register.
- 6) The new value is loaded into the Program Counter.

Thus, when a forward context switch is performed, an audit trail ensures that program logic knows the exact machine state at the instant of the forward context switch.

**When a backward context switch occurs, the contents of the current General Purpose registers R13, R14, and R15 are loaded into the WP register, the Program Counter, and the Status register, respectively.** Thus, program logic returns to the location of the forward context switch.

**TMS 9900  
BACKWARD  
CONTEXT  
SWITCH**

## **TMS 9900 MEMORY ADDRESSING MODES**

The TMS 9900 provides these four methods of addressing memory:

- 1) **Direct memory addressing**
- 2) **Direct, indexed memory addressing**
- 3) **Implied memory addressing**
- 4) **Implied memory addressing with auto-increment**

The way in which the TMS 9900 implements these four memory addressing modes is exactly as described in Volume 1, Chapter 6. The important point to note is that the TMS 9900 looks upon its address space as consisting of 32,768 16-bit memory words which are addressed using 15, rather than 16, Address Bus lines; yet programs compute all addresses as 16-bit words. This logic was described earlier.

**Direct memory addressing instructions provide the memory address in the second word of an instruction's object code:**

**TMS 9900  
DIRECT  
ADDRESSING**



**Direct, indexed memory addressing instructions provide a base address in the second object code word, but they also identify a general purpose register whose contents are to be added, as a signed binary number, to the base address.** Again, the low-order bit of the computed address is not output via the Address Bus, but is interpreted by CPU logic as a byte identifier.

**TMS 9900  
INDEXED  
ADDRESSING**

General Purpose Register R0 cannot be specified as an index register.

Direct, indexed addressing is very useful in a TMS 9900 microcomputer system. It allows you to address the previous set of general purpose registers, following a context switch, without knowing where the previous registers were. Suppose you want to access the contents of the memory word which was being used as General Purpose Register R5

before you switched to your current set of general purpose registers. Recall that the previous Workspace register contents are stored in your current General Purpose Register R13. You could thus address the previous General Purpose Register R5, without knowing where this general purpose register may have been, by using direct, indexed addressing as follows:



An implied memory addressing instruction will specify one of the 16 current general purpose registers as providing the effective memory address.

**TMS 9900  
IMPLIED  
ADDRESSING**

If you specify implied memory addressing with auto-increment, then the contents of the identified general purpose register will be incremented after the memory access has been performed. If the instruction specifies a byte operation, the register contents will be incremented by one; the register contents will be incremented by two after a full-word operation.

Six object code bits identify the data memory addressing option selected by any TMS 9900 instruction that accesses data memory. The six object code bits are interpreted as follows:



Two-address instructions will include 12 memory addressing option bits:



Some instructions allow a source to be anywhere in memory, but the destination must be a general purpose register. These object codes include TS, RS, and RD, but not TD.

**TMS 9900 Jump instructions use program relative, direct addressing.** These are one-word instructions, where the low-order byte of the instruction object code provides an 8-bit signed binary value, which is added to the incremented contents of the Program Counter. This is straightforward program relative, direct addressing.

**TMS 9900  
PROGRAM  
MEMORY  
ADDRESSING**

### TMS 9900 I/O ADDRESSING

As compared to other microcomputers described in this book, the TMS 9900 has unusual I/O logic. **In addition to addressing I/O devices as memory locations, you can address a separate I/O field of up to 4096 bits. Texas Instruments' literature refers to this field as the "Communications Register Unit" (CRU).** If you are programming a TMS 9900 microcomputer system that has already been configured by Texas Instruments, then it is justifiable to look upon the Communications Register Unit as a form of I/O port. If you are building your own interface to a TMS 9900 CPU, then instructions that are supposed to access the Communications Register Unit in reality simply make alternative use of part of the Address Bus in conjunction with three control signals: CRUCLK, CRUIN, and CRUOUT.

**There are two classes of TMS 9900 CRU instructions. The first class accesses individual bits (or signals), while the second class accesses bit fields that may be between 1 and 16 bits wide.**

**There are three single-bit CRU instructions;** they set, reset, or test the identified CRU bit. This is equivalent to setting, resetting, or testing an external signal or single I/O port bit. When a bit is to be set or reset, the new level is output via CRUOUT, and a CRUCLK pulse indicates that valid data is on the CRUOUT line. When the condition of a bit is to be input or tested, then external logic is required to return the level of the tested bit via CRUIN.

A CRU bit instruction outputs a 12-bit address which is computed as follows:



**The 12-bit address is output on the 12 lower-order address lines; the three higher-order address lines are all 0 to designate a CRU address.**

Now during the execution of a CRU bit instruction, the address which is output is supposed to be a bit address — that is, an address identifying one bit in a possible 4096-bit field. So far as external interface logic is concerned, the address can be interpreted in any way. However, **data output will occur via CRUOUT only; data is input via CRUIN, and stored in the Equal bit of the Status register.**

**There are two multi-bit CRU instructions:** one, LDCR, transfers data from an addressed memory location to any addressed CRU bit field. The other, STCR, transfers data from an addressed CRU bit field to any addressed memory location. Anywhere from 1 to 16 bits of data may be transferred by the LDCR and STCR instructions. **Instruction object codes are interpreted as follows:**



The source/destination memory location is identified as it would be for any memory reference instruction.

The address of the first CRU bit is specified by Register R12. For a multi-bit CRU instruction, the CRU bit address is incremented for each succeeding bit access, but the incremented address is held in a temporary storage location. The contents of Register R12 are not incremented.

Thus, multi-bit CRU instructions may transfer anywhere from 1 to 16 bits between any memory location and any CRU bit field. **Note that memory must be divided into 16-bit words, each of which has identified bit boundaries, but there are no equivalent bit boundaries in the CRU bit field.** That is to say, any CRU bit may be identified via Register R12 as the first bit in a multi-bit field, while the length of the multi-bit field is identified by the instruction object code. This may be illustrated as follows:



If YYYYY is 0000, the CRU bit field is assumed to be 16 bits in length.

**When bits are transferred from a memory location to a CRU bit field,** the contents of the memory location are not actually modified, but the transfer occurs as though bits had been right shifted out of the memory location. Bits arriving within the addressed CRU bit field are stored in sequential CRU bit locations with ascending addresses. This may be illustrated as follows:



Eleven bits have been transferred in the illustration above. If eight or fewer bits are transferred from a general purpose register, only the more significant byte is accessed:



Our illustration shows a transfer of five bits.

If eight or fewer bits are transferred from a memory location, then the memory address will be considered a byte address rather than a word address; that is, the transfer will be from the low-order bits of the addressed byte, which may be either the upper or lower byte of a 16-bit memory word. Thus you can access the lower byte of a general purpose register by addressing it as a memory location.

**A data transfer from the CRU to data memory** occurs as the exact logical reverse of the illustration above, except that high-order bits of the destination data memory word are zeroed if unfilled. This **may be illustrated as follows:**



As with data transfers from memory to the CRU, if eight or fewer bits are transferred, only a byte will be affected. This will be either the addressed memory byte:



or the high-order byte of a general purpose register:



## TMS 9900 STATUS FLAGS

**The TMS 9900 CPU has a 16-bit Status register which may be illustrated as follows:**



**The low-order four bits of the Status register represent an interrupt mask** which identifies the level of interrupt which is currently enabled. As the 4-bit interrupt mask would imply, 16 levels of interrupt are allowed. We will describe interrupt processing later in this chapter.

**The X status is set to 1 while an XOP instruction is being executed.** This instruction allows you to perform a software interrupt — as described later in this chapter.

The P, O, and C are standard Parity, Overflow and Carry statuses.

The Equal status (=) identifies a condition that currently exists, as the result of the execution of a previous instruction, that will cause a Branch-if-Equal instruction to branch. A CRU bit to be tested also gets stored in the Equal status.

The Logical Greater Than and Arithmetic Greater Than statuses are set or reset following arithmetic, logical, or data move operations. **A Logical Greater Than treats the source data as simple, unsigned binary numbers. An Arithmetic Greater Than interprets the operand as signed binary numbers.**

## **TMS 9900 CPU PINS AND SIGNALS**

Figure 18-2 illustrates the pins and signals of the TMS 9900 CPU.

Being a 64-pin DIP, the TMS 9900 can afford to have separate Address and Data Busses.



| Pin Name                                                              | Description                | Type                    |
|-----------------------------------------------------------------------|----------------------------|-------------------------|
| A0 - A14                                                              | Address Bus                | Tristate, output        |
| D0 - D15                                                              | Data Bus                   | Tristate, bidirectional |
| Φ1, Φ2, Φ3, Φ4                                                        | Clock Signals              | Input                   |
| MEMEN                                                                 | Memory Enable              | Tristate, output        |
| IAQ                                                                   | Instruction Fetch          | Output                  |
| DBIN                                                                  | Data Bus In                | Tristate, output        |
| WE                                                                    | Write Enable               | Tristate, output        |
| READY                                                                 | Memory Ready               | Input                   |
| WAIT                                                                  | Wait State Indicator       | Output                  |
| CRUCLK                                                                | I/O Clock                  | Output                  |
| CRUOUT                                                                | Serial I/O Out             | Output                  |
| CRUIN                                                                 | Serial I/O In              | Input                   |
| INTREQ                                                                | Interrupt Request          | Input                   |
| IC0 - IC3                                                             | Interrupt Code             | Input                   |
| HOLD                                                                  | DMA Request                | Input                   |
| HOLDA                                                                 | Hold Acknowledge           | Output                  |
| LOAD                                                                  | Load Interrupt             | Input                   |
| RESET                                                                 | Reset                      | Input                   |
| V <sub>BB</sub> , V <sub>CC</sub> , V <sub>DD</sub> , V <sub>SS</sub> | Power and Ground reference |                         |

Figure 18-2. TMS 9900 Signals and Pin Assignments

Pins A0 - A14 provide the 15-bit Address Bus. Note that Texas Instruments' literature numbers bits and pins from left to right; therefore, address line A0 represents the most significant address bit, whereas address line A14 represents the least significant address bit.

D0 - D15 provide a 16-bit bidirectional Data Bus. Once again, D0 represents the most significant data bit in Texas Instruments' literature.

**Remaining signals may be divided into bus control, interrupt control, and timing.**

**External logic must provide four clock signals,  $\Phi_1$ ,  $\Phi_2$ ,  $\Phi_3$ , and  $\Phi_4$ .** These are provided by the TIM 9904, described later in this chapter.

Any memory access operation begins with an address being output via the Address Bus. **The TMS 9900 CPU identifies a stable address on the Address Bus by outputting MEMEN low.**

**If the memory access operation is an instruction fetch, the IAQ is output high.**

**If the memory access is a read, then the TMS 9900 outputs a high level via DBIN.** Memory interface logic must interpret the high DBIN level as a signal to place data on the Data Bus.

**If the memory access is a memory write, then the TMS 9900 CPU outputs a low pulse via WE.** Memory interface logic must use the low WE pulse to signal that valid data is on the Data Bus, and to store it in the addressed memory location. WE low does not last as long as DBIN high.

**When external logic cannot respond to a memory access in the available time, it requests a Wait state by inputting READY low. The CPU acknowledges by outputting WAIT high.**

**CRUCLK, CRUIN, and CRUOUT are three signals used to implement single-bit or serial data transfers via the CRU interface.**

CRUOUT is used to output bits of data to the I/O devices, and CRUIN is used to retrieve input data from the I/O devices. CRUCLK is active during output operations only, and defines when data bits on CRUOUT are valid.

**Let us now look at interrupt control signals.**

**There is a single interrupt request input, INTREQ, which must be held low by any external device requesting an interrupt. External devices identify themselves via control signals ICO - IC3.** Thus, an interrupt request must be accompanied by the appropriate input at ICO - IC3.

Observe that there is no interrupt acknowledge signal.

**For DMA operations, external logic requests access to the System Bus by inputting HOLD low. The CPU acknowledges the Hold request by outputting HOLDA high.**

**LOAD is a nonmaskable interrupt.**

**RESET is a typical system Reset signal.** However, TMS 9900 Reset logic uses the device's interrupt capabilities; therefore, we will describe the Reset operation in detail when discussing TMS 9900 interrupt capabilities in general.

## TMS 9900 TIMING AND INSTRUCTION EXECUTION

**TMS instructions execute as a sequence of machine cycles, each of which contains two clock periods. Clock periods are timed by four clock signals,  $\Phi_1$ ,  $\Phi_2$ ,  $\Phi_3$ , and  $\Phi_4$ , as illustrated in Figure 18-3.** Note that  $\Phi_2$  is the first phase of each clock period, and that  $\Phi_1$  is the last phase.

**The simplest instruction execution machine cycle is an internal operations cycle.** No external bus signals are active during this machine cycle, and no memory or I/O access occurs. **Timing for an internal operations machine cycle will consist of two clock periods, as illustrated in Figure 18-3.**

**TMS 9900  
INTERNAL  
OPERATIONS  
MACHINE  
CYCLE**

## MEMORY ACCESS OPERATIONS

**TMS 9900 memory access operations may consist of a memory read or a memory write. An instruction fetch is a minor variation of a memory read.**

**Figure 18-4 illustrates memory read machine cycle timing.**

**MEMEN** goes low at the beginning of any memory access machine cycle and stays low for the entire machine cycle.



Figure 18-3. TMS 9900 Clock Periods and Timing Signals as Generated by the TIM 9904



Figure 18-4. A TMS 9900 Memory Read Machine Cycle

DBIN goes high at the beginning of the memory read machine cycle and stays high for the entire machine cycle. External logic can therefore use MEMEN low as a memory address indicator while DBIN high identifies the read operation.

A memory address is output stable on the Address Bus for the entire machine cycle.

**The Data Bus operations during a memory read machine cycle represent the only unusual characteristics of the machine cycle.** Input data needs to be stable during the  $\Phi 1$  high pulse of the second clock period. However, the Data Bus is connected to input logic for the entire memory read machine cycle and for a portion of the next machine cycle. Thus, during a memory read machine cycle, external logic cannot access the Data Bus to perform direct memory access, or any other operations, on the assumption that the Data Bus is free until Data In becomes stable. Moreover, since the Data Bus is held by data input logic of the CPU during the next machine cycle, a memory read machine cycle cannot be followed by a memory write machine cycle. **A memory read machine cycle must be followed by an internal operations machine cycle, or by another memory read machine cycle.**

The only difference between an instruction fetch machine cycle and a memory read machine cycle is the fact that **during an instruction fetch machine cycle, IAQ is output high**, along with DBIN, for the duration of the machine cycle.



Figure 18-5. A TMS 9900 Memory Write Machine Cycle

**Memory write machine cycle timing is illustrated in Figure 18-5.** In this illustration, we see that data is output stable on the Data Bus for the entire duration of the memory write machine cycle. The Data Bus is not held by output logic beyond this single machine cycle. Thus, no restrictions are placed on the type of machine cycle which can follow a memory write machine cycle. Even though data output is stable for the entire memory write machine cycle, the write

enable strobe  $\overline{WE}$  does not go low until close to the end of the first clock period. In many cases it is easier to use NOT DBIN as a write control signal. Here is the necessary logic:



**TMS 9900 instruction execution machine cycle sequences are not always self-evident; therefore, let us look at some memory reference examples.**

Memory address computations make machine cycle sequences quite complex, particularly for two-operand instructions. Fortunately, the exact machine cycle sequences are rarely of any consequence to you as a programmer or logic designer. The eventual number of machine cycles required to execute an instruction (and therefore its execution time) is important.

Generally stated, **instruction execution proceeds as follows:**

- 1) The instruction object code is fetched.
- 2) The first operand address is computed.
- 3) The second operand address (if there is one) is computed.
- 4) Any operation that may be required is performed.
- 5) If a result is generated, it is returned to the second operand address.

**TMS 9900  
INSTRUCTION  
EXECUTION  
SEQUENCES**

Let us look at operand address computations using the ADD instruction (A) as a general example. First consider the instruction in its simplest form — where the contents of one register are added to the contents of another register:

| A      R1,R2 |              |        |                               |
|--------------|--------------|--------|-------------------------------|
| Cycle        | Type         | Figure | Function                      |
| 1            | MEMORY READ  | 18-4   | Fetch instruction object code |
| 2            | ALU          | 18-3   | Decode instruction            |
| 3            | MEMORY READ  | 18-4   | Fetch R1 contents             |
| 4            | ALU          | 18-3   |                               |
| 5            | MEMORY READ  | 18-4   | Fetch R2 contents             |
| 6            | ALU          | 18-3   | Add R1 and R2 contents        |
| 7            | MEMORY WRITE | 18-5   | Store sum in R2               |

Now consider the same instruction's execution, but using implied memory addressing for the first operand:

| A      *R1,R2 |              |        |                                                          |
|---------------|--------------|--------|----------------------------------------------------------|
| Cycle         | Type         | Figure | Function                                                 |
| 1             | MEMORY READ  | 18-4   | Fetch instruction object code                            |
| 2             | ALU          | 18-3   | Decode instruction                                       |
| 3             | MEMORY READ  | 18-4   | Fetch R1 contents                                        |
| 4             | ALU          | 18-3   | Use R1 contents as a memory address (implied addressing) |
| 5             | MEMORY READ  | 18-4   | Fetch contents of implied address location               |
| 6             | ALU          | 18-3   |                                                          |
| 7             | MEMORY READ  | 18-4   | Fetch R2 contents                                        |
| 8             | ALU          | 18-3   | Add data fetched in cycles 5 and 7                       |
| 9             | MEMORY WRITE | 18-5   | Store sum in R2                                          |

If the second (destination) operand uses direct addressing, here is the machine cycle sequence:

| A *R1,@LABEL |              |        |                                                                            |
|--------------|--------------|--------|----------------------------------------------------------------------------|
| Cycle        | Type         | Figure | Function                                                                   |
| 1            | MEMORY READ  | 18-4   | Fetch instruction object code                                              |
| 2            | ALU          | 18-3   | Decode instruction                                                         |
| 3            | MEMORY READ  | 18-4   | Fetch R1 contents                                                          |
| 4            | ALU          | 18-3   | Use R1 contents as a memory address                                        |
| 5            | MEMORY READ  | 18-4   | Fetch contents of implied address location                                 |
| 6,7,8        | ALU          | 18-3   |                                                                            |
| 9            | MEMORY READ  | 18-4   | Fetch the second instruction object code word; it holds the direct address |
| 10           | ALU          | 18-3   |                                                                            |
| 11           | MEMORY READ  | 18-4   | Fetch contents of directly addressed memory word                           |
| 12           | ALU          | 18-3   | Add words fetched in cycles 5 and 11                                       |
| 13           | MEMORY WRITE | 18-5   | Store sum in directly addressed memory word                                |

Indexed, direct addressing results in the following sequence:

| A *R1,@LABEL(5) |              |        |                                                                            |
|-----------------|--------------|--------|----------------------------------------------------------------------------|
| Cycle           | Type         | Figure | Function                                                                   |
| 1               | MEMORY READ  | 18-4   | Fetch instruction object code                                              |
| 2               | ALU          | 18-3   | Decode instruction                                                         |
| 3               | MEMORY READ  | 18-4   | Fetch R1 contents                                                          |
| 4               | ALU          | 18-3   | Use R1 contents as a memory address                                        |
| 5               | MEMORY READ  | 18-4   | Fetch contents of implied address location                                 |
| 6               | ALU          | 18-3   |                                                                            |
| 7               | MEMORY READ  | 18-4   | Fetch the second instruction object code word; it holds the direct address |
| 8               | ALU          | 18-3   |                                                                            |
| 9               | MEMORY READ  | 18-4   | Fetch R5, the Index register contents                                      |
| 10              | ALU          | 18-3   | Add direct address and index                                               |
| 11              | MEMORY READ  | 18-4   | Fetch contents of memory word addressed by cycle 10 addition               |
| 12              | ALU          | 18-3   | Add memory words fetched in cycles 5 and 11                                |
| 13              | MEMORY WRITE | 18-5   | Store sum in memory word addressed by cycle 10 addition                    |

If the first operand-implied address specified an auto-increment, we must add one more machine cycle:

| A *R1+,@LABEL(5) |              |        |                                                                            |
|------------------|--------------|--------|----------------------------------------------------------------------------|
| Cycle            | Type         | Figure | Function                                                                   |
| 1                | MEMORY READ  | 18-4   | Fetch instruction object code                                              |
| 2                | ALU          | 18-3   | Decode instruction                                                         |
| 3                | MEMORY READ  | 18-4   | Fetch R1 contents                                                          |
| 4                | ALU          | 18-3   | Increment fetched R1 contents                                              |
| 5                | MEMORY WRITE | 18-5   | Write incremented R1 contents back to R1                                   |
| 6                | MEMORY READ  | 18-4   | Fetch contents of implied address location                                 |
| 7                | ALU          | 18-3   |                                                                            |
| 8                | MEMORY READ  | 18-4   | Fetch the second instruction object code word; it holds the direct address |
| 9                | ALU          | 18-3   |                                                                            |
| 10               | MEMORY READ  | 18-4   | Fetch R5, the Index register contents                                      |
| 11               | ALU          | 18-3   | Add direct address and index                                               |
| 12               | MEMORY READ  | 18-4   | Fetch contents of memory word addressed by cycle 11 addition               |
| 13               | ALU          | 18-3   | Add memory words fetched in cycles 5 and 12                                |
| 14               | MEMORY WRITE | 18-5   | Store sum in memory word addressed by cycle 11 addition                    |

## MEMORY SELECT LOGIC

**MEMEN** discriminates between memory and I/O accesses. It is therefore very important that **MEMEN** low be a necessary component for any memory select.

You can map I/O into the memory space of the TMS 9900. This is true of any microprocessor. Memory addresses that select I/O devices will, of course, also require **MEMEN** low as a contributor to I/O device select logic.

MEMEN as a contributor to select logic may be illustrated as follows:



The three high-order address lines, A12, A13, and A14, are not used to address CRU bits. When addressing a CRU bit, these lines are all low. They are not low during execution of externally defined I/O instructions; therefore, A12, A13, and A14 low must be a prerequisite for any CRU bit select.

## TMS 9900 I/O INSTRUCTION TIMING

All TMS 9900 I/O instructions transfer serial data via the Communication Register Unit (CRU). (This excludes I/O which is addressed as TMS 9900 memory space.)

**There are four types of TMS 9900 I/O instructions.** They are:

- 1) **Data input.** Anywhere from 1 to 16 bits of data may be transferred from the CRU bit field to memory.
- 2) **Data output.** This is the simple reverse of data input. Anywhere from 1 to 16 bits of data may be output from memory to the CRU bit field.
- 3) **Bit test.** Any bit in the CRU bit field may be tested. The tested bit is input and stored in the Equal bit of the Status register. Thence, condition branch instructions can be used to test the bit level.
- 4) **Externally defined I/O instructions.** These instructions generate I/O control signals, but they transfer no data.

**Timing for CRU output and input machine cycles is illustrated in Figures 18-6 and 18-7, respectively.** Each of these figures shows two bits of data being transferred. (You should not attach any special significance to this fact; depending on the instruction being executed, anywhere from 1 to 16 bits may be transferred.) CRU machine cycles are executed contiguously, one per bit.

Every CRU I/O instruction will require a memory reference machine cycle, together with one or more CRU machine cycles. For example, when an STCR instruction is executed to input data from the CRU to the CPU, the following machine cycle sequence will occur:

| Cycle                               | Type         | Figure | Function                                                                                                 |
|-------------------------------------|--------------|--------|----------------------------------------------------------------------------------------------------------|
| 1                                   | MEMORY READ  | 18-4   | Fetch Instruction Code                                                                                   |
| 2                                   | ALU          | 18-3   | Decode Instruction                                                                                       |
| a Cycles, where $0 \leq a \leq 4$   |              |        | { Obtain Destination Address                                                                             |
| 3 + a                               | MEMORY READ  | 18-4   | Fetch Destination Memory Word Contents                                                                   |
| 4 + a                               | ALU          | 18-3   |                                                                                                          |
| 5 + a                               | MEMORY READ  | 18-4   | Fetch R12                                                                                                |
| 6 + a                               | ALU          | 18-3   | Compute CRU Starting Address and Prepare Control Signals                                                 |
| 7 + a                               | ALU          | 18-3   |                                                                                                          |
| i Cycles                            | CRU IN       | 18-7   | { Input i CRU Bits                                                                                       |
| 8 + a + i                           | ALU          | 18-3   |                                                                                                          |
| 9 + a + i                           | ALU          | 18-3   | Load CRU Bits in Temporary Register                                                                      |
| r Cycles                            |              |        | { Fill Upper Bits of Byte or Word With Zeroes<br>If $i > 8$ , $r = 15 - i$ ; if $i \leq 8$ , $r = 7 - i$ |
| 10 + a + i + r to<br>12 + a + i + r | ALU          | 18-3   | Prepare to Store Memory Word                                                                             |
| 13 + a + i + r                      | MEMORY WRITE | 18-5   | Output Assembled Word to Memory Location Whose Contents Were Fetched in Machine Cycle 3 + a              |



Figure 18-6. Two TMS 9900 Output-to-CRU Machine Cycles



Figure 18-7. Two TMS 9900 Input-from-CRU Machine Cycles

An LDCR instruction outputs a sequence of 1 to 16 data bits to a CRU bit field. Here is the LDCR instruction machine cycle sequence:

| Cycle                            | Type        | Figure | Function                              |
|----------------------------------|-------------|--------|---------------------------------------|
| 1                                | MEMORY READ | 18-4   | Fetch instruction object code         |
| 2                                | ALU         | 18-3   | Decode instruction                    |
| a Cycles where $0 \leq a \leq 4$ |             |        | Obtain source address                 |
| 3+a                              | MEMORY READ | 18-4   | Fetch source memory word contents     |
| 4+a                              | to ALU      | 18-3   | Prepare for data transmission         |
| 7+a                              |             |        |                                       |
| 8+a                              | MEMORY READ | 18-4   | Fetch R12                             |
| 9+a                              | ALU         | 18-3   | Compute CRU starting address          |
| i Cycles                         | CRU OUT     | 18-6   | Output i bits to CRU                  |
| 10+a+i                           | ALU         | 18-3   | Machine cycle to conclude instruction |

The SBO and SBZ instructions set or reset an addressed CRU bit; in essence, these instructions output one data bit. Here is the machine cycle sequence via which the bit output occurs:

| Cycle | Type        | Figure | Function                      |
|-------|-------------|--------|-------------------------------|
| 1     | MEMORY READ | 18-4   | Fetch instruction object code |
| 2     | ALU         | 18-3   | Decode instruction            |
| 3     | ALU         | 18-3   | Decode instruction            |
| 4     | MEMORY READ | 18-4   | Fetch R12                     |
| 5     | ALU         | 18-3   | Compute CRU address           |
| 6     | CRU OUT     | 18-6   | Output to addressed CRU bit   |

The TB instruction inputs one CRU bit; its timing is identical to the SBO and SBZ instructions, except that machine cycle 6 is a CRU IN machine cycle.

**The Address Bus is used in an unusual way during a CRU machine cycle.** As we have already stated, the CRU bit field is 4096 bits wide — addressed by 12 of the 15 Address Bus lines. **The three high-order Address Bus lines are used to identify I/O control instructions, as defined in Table 18-1.** We can conclude from Table 18-1 that when MEMEN is high and the three high-order Address Bus lines are all low, an I/O transfer is occurring. Otherwise, one of five externally defined I/O control instructions is being executed. There are dedicated functions for these five I/O controls in TM 990 minicomputer systems; these are shown in Table 18-1. But to anyone who is simply building a microcomputer system around a TMS 9900, these five I/O states are undefined. **Thus, Figure 18-8 illustrates TMS 9900 systems' bus utilization during both CRU operations and externally defined I/O operations. If CRU SEL and MEMEN are high, CRU Select logic will be active.**

Table 18-1. High-Order Address Bus Line Used by TMS 9900 I/O Instructions

| INSTRUCTION MNEMONIC | INSTRUCTION TYPE | (MSB)<br>A14 A13 A12 | FUNCTION                                                                               |
|----------------------|------------------|----------------------|----------------------------------------------------------------------------------------|
| LDCR                 | Output           | 0 0 0                | Output data to CRU                                                                     |
| SBO                  | Output           | 0 0 0                | Set CRU bit to 1                                                                       |
| SBZ                  | Output           | 0 0 0                | Reset CRU bit to 0                                                                     |
| STCR                 | Input            | 0 0 0                | Input data from CRU                                                                    |
| TB                   | Test (Input)     | 0 0 0                | Input CRU bit to Equal status bit                                                      |
| IDLE                 | Control          | 0 1 0                | Enter HALT condition                                                                   |
| RSET                 | Control          | 0 1 1                | Reset the Interrupt mask                                                               |
| CKOF                 | Control          | 1 0 1                | Real time clock on                                                                     |
| CKON                 | Control          | 1 1 0                | Real time clock off                                                                    |
| LREX                 | Control          | 1 1 1                | Execute bootstrap                                                                      |
|                      |                  |                      | These are<br>TM 990 uses.<br>Instructions<br>are undefined<br>in a TMS 9900<br>system. |

**Externally defined instructions output 0 on the 12 low-order Address Bus lines, A0 - A11; in addition, CRUCLK pulses are output as part of the instruction executions.**

**CRUCLK is an active CRU output strobe only.** This signal pulses high whenever a valid level is present on the CRUOUT signal line. **There is no pulse for CRUIN.** External logic must generate its own strobe if it is needed, by combining MEMEN high with a valid bit pattern on the Address Bus.

CRU instructions that test the level of a bit are, to external logic, no different from CRU input instructions. External logic is required to return, via CRUIN the level of the selected bit. The fact that the CPU interprets this input as status, rather than data, is immaterial to external logic.

## THE WAIT STATE

Additional Wait State clock periods may be inserted between clock periods 1 and 2 of any memory access machine cycle. Timing is illustrated in Figure 18-9. At the rising edge of  $\Phi_1$  of clock period 1, the CPU samples the READY input signal. If this signal is low, then the next clock period is a Wait clock period. During a Wait cycle, the WAIT output signal is high; all other output signals hold the levels they had during clock period 1.

A Wait State can last for any number of clock periods. During the  $\Phi_1$  high pulse of every Wait clock period, the CPU samples the level of the READY input. As soon as READY is sampled high, the Wait State ends. The next clock period becomes clock period 2 of the machine cycle, and the memory operation is completed.



Figure 18-8. TMS 9900 System Bus Utilization During I/O Operations



Figure 18-9. The TMS 9900 Wait State

## THE HOLD STATE

The TMS 9900 has a typical microcomputer Hold State, used to enable direct memory access operations. External logic initiates a Hold State by inputting HOLD low. At the beginning of the next nonmemory reference machine cycle, the CPU floats its Address and Data Busses, together with the DBIN, MEMEN and WE control signals. HOLDA is output high as a Hold Acknowledge. Timing is illustrated in Figure 18-10.



Figure 18-10. TMS 9900 Hold State Timing

The Hold State lasts until external logic raises HOLD high again.

It is up to external logic to perform all operations associated with a DMA transfer. The CPU simply floats the System Bus in response to a Hold request. As soon as the TMS 9911 device is available, this will be the part of choice to use in all TMS 9900 microcomputer systems that use direct memory access logic. Any of the other DMA devices described in Volume 3 may also be used.

The only nonobvious aspect of Figure 18-10 is the fact that Data Bus timing, during normal instruction execution, differs from other System Bus signal timing. Figure 18-10 highlights this fact by showing the Data Bus floating at the beginning of the first HOLD clock period, while other signals float earlier in the preceding clock period. This is not a particularly significant event. The entire System Bus is floating once the HOLD clock period has begun. However, the actual tristate condition for any signal begins at that point in the preceding clock period when the signal is no longer being driven by current operations.

## THE HALT STATE

The TMS 9900 IDLE I/O instruction generates a Halt State. When this instruction is executed, the CPU suspends all program execution and internal operations. You must terminate the Idle condition with an interrupt request or a low LOAD or RESET input. (LOAD and RESET are treated as interrupts as we will describe soon.)

The TMS 9900 CPU does not relinquish the System Bus while halted. That is to say, after an IDLE instruction has been executed, no System Bus lines are floated.

The IDLE instruction is usually executed when program logic requires that the CPU wait for an interrupt, or when external logic is computing a real-time interval — which will be terminated with an interrupt request.

You can, if you wish, initiate a DMA transfer by executing an IDLE instruction. In order to do this, you must create a HOLD request from the Address Bus output characteristic of the IDLE instruction's execution. This may be illustrated as follows:



As illustrated above, the combination of 010 on the three high-order Address Bus lines, along with the CRUCLK pulse, identifies the IDLE instruction. Since the process of floating the System Bus will remove the conditions which generated a Hold request, these conditions are used to clock a flip-flop. Thus, external logic which receives the Hold acknowledge signal and takes control of the System Bus must subsequently reset the Hold request flip-flop in order to remove the Hold condition. That is to say, **program logic can begin a Hold state within a Halt state, but it cannot end this combination. Two steps are needed to terminate a Hold within a Halt. The Hold request must be removed, then an interrupt request must follow to terminate the Halt.**

## TMS 9900 INTERRUPT PROCESSING LOGIC

The TMS 9900 has complex and capable interrupt processing logic. Sixteen levels of external interrupt are available. Sixteen software interrupts are also available. Fifteen of the sixteen external interrupts are maskable; the nonmaskable interrupt has highest priority and is the system Reset interrupt. There is, in addition, a non-maskable Load interrupt. External interrupts may be summarized as follows:

|                                       |             |                                                 |
|---------------------------------------|-------------|-------------------------------------------------|
| LOAD                                  | Priority 0  | Non-maskable, Equal Highest Priority Interrupts |
| RESET                                 |             |                                                 |
| Maskable Levels of External Interrupt | Priority 1  |                                                 |
|                                       | Priority 2  |                                                 |
|                                       | Priority 3  |                                                 |
|                                       | Priority 4  |                                                 |
|                                       | Priority 5  |                                                 |
|                                       | Priority 6  |                                                 |
|                                       | Priority 7  |                                                 |
|                                       | Priority 8  |                                                 |
|                                       | Priority 9  |                                                 |
|                                       | Priority 10 |                                                 |
|                                       | Priority 11 |                                                 |
|                                       | Priority 12 |                                                 |
|                                       | Priority 13 |                                                 |
|                                       | Priority 14 |                                                 |
|                                       | Priority 15 | Lowest Priority Interrupt                       |

External logic identifies the priority of its interrupt request via the IC0, IC1, IC2, and IC3 inputs, as follows:

| IC0 | IC1 | IC2 | IC3 | Priority                                                 |
|-----|-----|-----|-----|----------------------------------------------------------|
| 0   | 0   | 0   | 0   | Should not be input by external logic - highest external |
| 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 lowest external                                       |

**Software interrupts are executed via the XOP instruction. There are, in addition, instructions that parallel the RESET and LOAD interrupts. We will describe these instructions in due course.**

**Each one of the external interrupts has two dedicated memory words via which vectoring is enabled following an interrupt acknowledge. Figure 18-11 illustrates the memory map associated with interrupt vectoring.** The memory addresses in Figure 18-11 are byte addresses as seen by the programmer. Remember, the low-order bit of the address shown in Figure 18-11 is not output on the Address Bus; therefore, you must divide the memory addresses shown in Figure 18-11 by 2 in order to generate the address which will be seen by external memory.

**TMS 9900  
INTERRUPT  
VECTOR MAP**

The memory words dedicated to interrupt vectoring, as illustrated in Figure 18-11, can be read-only memory, read/write memory, or any combination of the two. Obviously, read-only memory will be used in applications that have dedicated interrupt service routines for specific interrupt requests. Read/write memory might be used in minicomputer-type applications where the interrupt response will depend on the application being serviced.

**Interrupt masking and priorities apply only to external interrupt requests. Interrupt masking priorities cannot be applied to software interrupts (the XOP instruction).** Since program logic must generate the software interrupt, program logic can equally be relied on to know which software interrupt is to be executed, and whether the software interrupt is allowed by current program logic. That is to say, from the programmer's viewpoint, a software interrupt is simply the consequence of an XOP instruction's execution; you, as a programmer, can include an XOP instruction anywhere in a program, within or outside an interrupt service routine. XOP instructions might be used in response to error conditions, or to call any frequently used subroutines.

**Let us begin by looking at the way in which external interrupts are processed.**

**Any external device wishing to request an interrupt must pull the INTREQ input low while simultaneously placing a 4-bit code at the IC0 - IC3 inputs. The CPU will acknowledge the interrupt, provided that its priority, as identified by the IC0 - IC3 inputs, is enabled. The interrupt will be acknowledged at the conclusion of the currently executing instruction. The BLWP and XOP instructions are exceptions; for the integrity of program logic, they demand that the next sequential instruction be executed. Therefore, if an interrupt request occurs while either of these two instructions is being executed, the interrupt will not be acknowledged until this instruction and the next instruction have been executed.**



Figure 18-11. TMS 9900 Memory Map

**When an interrupt is acknowledged, the following machine cycles are executed:**

| Cycle | Type         | Figure | Function                                                            |
|-------|--------------|--------|---------------------------------------------------------------------|
| 1     | ALU          | 18-3   |                                                                     |
| 2     | MEMORY READ  | 18-4   | Move new WP register contents from vector word to temporary storage |
| 3     | ALU          | 18-3   |                                                                     |
| 4     | MEMORY WRITE | 18-5   | Store status in new R15                                             |
| 5     | ALU          | 18-3   | Store IC0 - IC3 levels in four low-order Status bits                |
| 6     | MEMORY WRITE | 18-5   | Store incremented PC in new R14                                     |
| 7     | ALU          | 18-3   |                                                                     |
| 8     | MEMORY WRITE | 18-5   | Store old WP register contents in new R13                           |
| 9     | ALU          | 18-3   |                                                                     |
| 10    | MEMORY READ  | 18-4   | Fetch new PC contents from vector word                              |
| 11    | ALU          | 18-3   | Fetch new WP contents from temporary storage                        |

Vector words are illustrated in Figure 18-11.

**TMS 9900  
NESTED  
INTERRUPT  
PRIORITIES**

At the conclusion of the interrupt acknowledge sequence listed above, the priority of the acknowledged interrupt request, less one, is recorded in the four low-order Status register bits. Thus, subsequent interrupt requests will be acknowledged only if their priority is higher than that of the interrupt being serviced. That is to say, whenever an interrupt request occurs, CPU logic compares the levels input at IC0 - IC3 with the levels present in the four low-order Status register bits. If IC0 - IC3 is not greater than the mask, then the interrupt request will be acknowledged. If IC0 - IC3 is higher, then the interrupt request will not be acknowledged. Thus, **in the normal course of events, TMS 9900 interrupt priority logic disables all interrupts of equal or lower priority than an acknowledged interrupt**, while leaving higher priority interrupts enabled. **Priorities are maintained for the duration of the interrupt service routine.** This is illustrated in the following figure, which you should read in the sequence (A) - (B) - (C) - (D) - (E) - (F) - (G) :



The interrupt priority arbitration logic of the TMS 9900 is exceptional among microcomputers. Most microcomputers arbitrate priorities at the instant interrupts are being acknowledged, and once an interrupt has been acknowledged, all interrupts are disabled. That is to say, interrupt priorities apply only during the acknowledge process. In contrast, the TMS 9900 maintains interrupt priorities for the duration of the interrupt service routine, as illustrated above.

The net effect of the interrupt response steps illustrated above is to perform a context switch while disabling all interrupts that have the same priority as the acknowledged interrupt, or that have a lower priority.

**There are some very important and nonobvious advantages to initiating an interrupt service routine with a context switch.**

Since the 16 new memory locations that will be used as general purpose registers may lie anywhere in read/write memory, you can store parameters that will be used by the interrupt service routine, in advance of the interrupt, in those memory locations that are ultimately to serve as general purpose registers for the duration of the interrupt service routine.

You can, if you wish, modify the interrupt priority scheme that will control nested interrupts. As we have already stated, if you do nothing about interrupt priorities, then any interrupt service routine may be interrupted by a higher priority external interrupt, but not by an external interrupt that has the same priority or a lower priority.

If you wish to eliminate nested interrupts entirely, then the first instruction executed within an interrupt service routine must be an LIMI 0 instruction (Load Interrupt Mask Immediate), which clears the four low-order Status register bits, thus disabling all maskable interrupts. A RESET or LOAD interrupt — or a level 0 external interrupt request — will still be acknowledged; these should be alarm conditions and not part of the normal interrupt logic of any microcomputer. You can execute variations of the LIMI instruction to increase or decrease the levels of priority that will be masked for the duration of any interrupt service routine (or for that matter, any subsequent instruction within the interrupt service routine) can load appropriate data into the four low-order bits of the Status register, thus changing the priority level at which all subsequent interrupt requests will be disabled.

**All interrupt service routines should end with an RTWP (Return Workspace Pointer) instruction.** The RTWP instruction performs a reverse context switch, which puts the central processing unit back to the logical environment which was interrupted. Observe that since the Status register is also saved during a forward context switch, the return instruction will restore whatever level of interrupt priorities existed at the instant the interrupt was acknowledged. You can, of course, modify the contents of General Purpose Registers R13, R14, and R15 in the course of an interrupt service routine's execution. This allows program logic to alter the conditions that will be restored when the return instruction executes a reverse context switch.

**The TMS 9901 PSI, which we describe later in this chapter, provides multiple interrupt handling for TMS 9900 series CPUs. If your system does not include a TMS 9901, then external hardware required to support multiple interrupts in a TMS 9900 microcomputer system will not be as straightforward as the software response.**

First of all, we must cope with the fact that if more than one interrupt request occurs simultaneously, then there will be competition on the INTREQ input, but there will also be competition at the four priority inputs, IC0 - IC3. Resolving competition on the INTREQ input is no problem; you can wire-OR interrupt requests from many devices to create the CPU input. But your external logic must make sure that only the highest priority combination of IC0 - IC3 appears at the TMS 9900 inputs. One method of doing this is to use latched decoders that create a 4-bit output corresponding to the highest level input, provided that the decoder is enabled by a latching signal. This may be illustrated functionally as follows:

**TMS 9900  
MULTIPLE  
INTERRUPT  
HARDWARE  
CONSIDERATIONS**



In the illustration above, 15 external interrupt requests are input to a decoder. These interrupt requests are high true. The 15 interrupt requests are buffered, inverted, and wire-ORed to create the master interrupt request INTREQ, which is input to the CPU. This master interrupt request also enables the decoder. That is to say, when the enable input to the

decoder is high, the four outputs, IC0 - IC3 will be low. When the enable input to the decoder is low, IC0 - IC3 will output a 4-bit value as follows:

| IC0 | IC1 | IC2 | IC3 | INT 1 | INT 2 | INT 3 | INT 4 | INT 5 | INT 6 | INT 7 | INT 8 | INT 9 | INT 10 | INT 11 | INT 12 | INT 13 | INT 14 | INT 15 |
|-----|-----|-----|-----|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|--------|--------|--------|--------|--------|
| 0   | 0   | 0   | 0   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      | 0      | 0      |        |
| 0   | 0   | 0   | 1   | 1     | *     | *     | *     | *     | *     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 0   | 0   | 1   | 0   | 0     | 1     | *     | *     | *     | *     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 0   | 0   | 1   | 1   | 0     | 0     | 1     | *     | *     | *     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 0   | 1   | 0   | 0   | 0     | 0     | 1     | *     | *     | *     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 0   | 1   | 0   | 1   | 0     | 0     | 0     | 1     | *     | *     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 0   | 1   | 1   | 0   | 0     | 0     | 0     | 0     | 1     | *     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 0   | 1   | 1   | 1   | 0     | 0     | 0     | 0     | 0     | 1     | *     | *     | *     | *      | *      | *      | *      | *      |        |
| 1   | 0   | 0   | 0   | 0     | 0     | 0     | 0     | 0     | 0     | 1     | *     | *     | *      | *      | *      | *      | *      |        |
| 1   | 0   | 0   | 1   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | *     | *      | *      | *      | *      | *      |        |
| 1   | 0   | 1   | 0   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | *      | *      | *      | *      | *      |        |
| 1   | 0   | 1   | 1   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1      | *      | *      | *      | *      |        |
| 1   | 1   | 0   | 0   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0      | 1      | *      | *      | *      |        |
| 1   | 1   | 0   | 1   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 1      | *      | *      |        |
| 1   | 1   | 1   | 0   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      | 1      | *      |        |
| 1   | 1   | 1   | 1   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0      | 0      | 0      | 0      | 1      |        |

\* REPRESENTS A "DON'T CARE" BIT

If you do not use the TMS 9901, Texas Instruments suggests the following circuit to accomplish priority encoding:



**External logic must maintain its interrupt request until it receives its own specific interrupt acknowledge.** This need is obvious, since an interrupt request may be denied for a long time while higher priority interrupts are being serviced.

**The problem is that the TMS 9900 has no interrupt acknowledge signals.**

**Interrupt acknowledge signals can be generated in one of two ways:**

- 1) By using CRU bit instructions to set and reset external flip-flops that create interrupt acknowledge signals.
- 2) By decoding appropriate addresses on the Address Bus.

**Figure 18-12 illustrates two possible configurations that will allow CRU bit set and reset instructions to generate interrupt acknowledge signals.** The logic in Figure 18-12A generates a short interrupt acknowledge pulse. CRUOUT becomes the input to a flip-flop which is decoded to generate CRU select signals. The CRU bit select and MEMEN are gated to the flip-flop's Clear input. Therefore, when CRU bit "n" is selected, CLR is removed and CRUOUT can be clocked through. A set bit (SBO) instruction switches the flip-flop on. As soon as the flip-flop address is removed at the end of the CRU I/O machine cycle, the flip-flop is cleared, thus terminating the interrupt acknowledge pulse.

The logic illustrated in Figure 18-12A requires that you execute an SBO instruction at the beginning of every interrupt service routine in order to generate an interrupt acknowledge. You could require every interrupt service routine to control the length of the interrupt acknowledge pulse by executing an SBZ instruction to terminate the pulse. Figure 18-12B shows logic to implement this scheme. When the flip-flop is selected by the appropriate CRU address, CRUCLK will clock CRUOUT to INT ACK n. At other times, CRUCLK will merely clock the flip-flop's output through, thus making no change. In this way, only SBO and SBZ instructions which address INT ACK n can set or reset the flip-flop.

**Figure 18-13 illustrates generation of an interrupt acknowledge signal by identifying specific addresses on the Address Bus.** Following any interrupt acknowledge, specific memory locations will be accessed, as identified in Figure 18-11, in order to fetch the new values for the Program Counter and WP register. Figure 18-13 shows a very simple scheme whereby Address Bus lines are combined with MEMEN low to generate high pulses for the duration of a valid address. That is to say, the interrupt acknowledge signal will last for one machine cycle — the time that the valid address exists on the Address Bus.

**External logic which requested an interrupt removes its interrupt request and priority signals upon receiving an interrupt acknowledge.**



Figure 18-12. A TMS 9900 Interrupt Acknowledge Pulse Generated Using an SBO Instruction



Figure 18-13. TMS 9900 Interrupt Acknowledge Generated by Decoding Valid Addresses

## THE TMS 9900 RESET

You reset the 9900 microcomputer system by inputting a low RESET signal. This signal must remain low for at least 3 clock periods. When the low RESET signal is removed, the following machine cycle sequence is executed:

| Cycle | Type         | Figure | Function                                                                    |
|-------|--------------|--------|-----------------------------------------------------------------------------|
| 1     | ALU          | 18-3   | Prepare for Level 0 interrupt                                               |
| 2     | ALU          | 18-3   |                                                                             |
| 3     | ALU          | 18-3   |                                                                             |
| 4     | MEMORY READ  | 18-4   | Fetch new WP register contents from memory word 000016 to temporary storage |
| 5     | ALU          | 18-3   |                                                                             |
| 6     | MEMORY WRITE | 18-5   | Store Status register contents in new R15                                   |
| 7     | ALU          | 18-3   |                                                                             |
| 8     | MEMORY WRITE | 18-5   | Store Program Counter contents in new R14                                   |
| 9     | ALU          | 18-3   |                                                                             |
| 10    | MEMORY WRITE | 18-5   | Store old WP register contents in new R13                                   |
| 11    | ALU          | 18-3   |                                                                             |
| 12    | MEMORY READ  | 18-4   | Fetch new Program Counter contents from memory word 000116                  |
| 13    | ALU          | 18-3   | Load WP register from temporary storage                                     |

Thus, program execution begins with a program whose starting address is stored in memory word 1. The starting address for the 16 general purpose registers is stored in memory word 0.

The TMS 9900 has a Reset instruction (RSET). In reality, this instruction resets only the interrupt mask in the Status register; it also outputs a code on the Address Bus, as identified in Table 18-1 and illustrated in Figure 18-8. TM 9900 minicomputer systems use this signal to generate a program-initiated Reset. If you are designing your own TMS 9900-based microcomputer system, you are free to use the RSET instruction in any way.

## THE TMS 9900 LOAD OPERATION

The LOAD input to the TMS 9900 is a non-maskable, highest priority interrupt. Load must be input low for at least one instruction's duration. Since the length of an instruction can vary, you must use the IAQ signal to control the LOAD input pulse width. Texas Instruments' literature recommends the following circuit:



The CPU checks LOAD at the end of each instruction's execution.

After a valid LOAD input has been acknowledged, the following machine cycle sequence is executed:

| Cycle | Type         | Figure | Function                                                                                |
|-------|--------------|--------|-----------------------------------------------------------------------------------------|
| 1     | ALU          | 18-3   |                                                                                         |
| 2     | MEMORY READ  | 18-4   | Input new WP register contents from memory word 7FFE <sub>16</sub> to temporary storage |
| 3     | ALU          | 18-3   |                                                                                         |
| 4     | MEMORY WRITE | 18-5   | Store in new R15                                                                        |
| 5     | ALU          | 18-3   |                                                                                         |
| 6     | MEMORY WRITE | 18-5   | Store incremented Program Counter contents in new R14                                   |
| 7     | ALU          | 18-3   |                                                                                         |
| 8     | MEMORY WRITE | 18-5   | Store old WP register contents in new R13                                               |
| 9     | ALU          | 18-3   |                                                                                         |
| 10    | MEMORY READ  | 18-4   | Input new Program Counter contents from word 7FFF <sub>16</sub>                         |
| 11    | ALU          | 18-3   | Load WP register from temporary storage                                                 |

**There are two differences between Reset and Load. First, the RESET input provides a true hardware reset, synchronizing internal operations, as well as a level 0 interrupt; LOAD provides only a non-maskable interrupt. Second, the Reset vector in bytes 0 through 3, while the Load vector is in bytes FFFC<sub>16</sub> through FFFF<sub>16</sub>.**

In TM 990 minicomputer systems, the LREX instruction is frequently used as a software load. Output due to LREX is identified in Table 18-1 and Figure 18-8. In a TMS 9900 microcomputer system, you can use the LREX signal in any way.

## THE TMS 9900 INSTRUCTION SET

The TMS 9900 instruction set is extremely powerful when compared to any 16-bit microprocessor described in this book. When you consider that the TMS 9900 was first manufactured in 1976, the power of this instruction set becomes more impressive.

With regard to instructions described in Table 18-2, some explanations are required.

The ABS instruction converts the contents of a memory location to their absolute value. That is to say, this instruction assumes that the memory location contains a signed binary number. If the number is positive, nothing happens. If the number is negative, the twos complement of the number is taken.

A number of instructions act on specific bits within source and destination memory words. These include the **SOC, SOCB, SZC, SZCB, COC, and CZC instructions**. In the OPERATION PERFORMED column of Table 18-2, the word "corresponding" means that the source word bits are affected only if selected by the destination word bit pattern. For example, the SOC instruction will be interpreted as follows:

|              |                                                               |
|--------------|---------------------------------------------------------------|
| Source:      | 1   0   1   1   1   0   1   0   0   1   1   0   1   1   0   1 |
| Destination: | 1   0   1   1   0   0   1   0   1   0   1   0   0   0   1   0 |
| After SOC:   | 1   0   1   1   1   0   1   0   1   1   1   0   1   1   1   1 |

Here are the new destination contents.

This is equivalent to an OR operation.

The SOCB instruction is identical to the SOC instruction, except that only one byte is affected. This may be any memory byte or the high-order byte of a general purpose register.

The SZC instruction may be illustrated as follows:

|              |                                                               |
|--------------|---------------------------------------------------------------|
| Source:      | 1   0   1   0   0   1   1   0   1   0   1   1   1   0   0   1 |
| Destination: | 0   1   0   1   1   0   1   1   1   0   1   0   1   1   0   1 |
| After SZC:   | 0   1   0   1   1   0   0   1   0   0   0   0   0   1   0   0 |

This is equivalent to complementing the source operand and then ANDing the two operands. The SZCB instruction is identical to the S2C instruction, except that only one byte is affected.

The COC instruction compares Source Register 1 bits with general purpose register bits that happen to be in the same bit positions. If all corresponding general purpose register bits are also 1, then the Equal status is set. Matches are not significant in bit positions if the source register bit is 0.

The C2C instruction operates in the same fashion as the COC instruction, except that those source memory word bits that are 0 become significant. That is to say, if every source memory word 0 bit has a corresponding Workspace register 0 bit, then the Equal status is set. Matches are not significant in bit positions if the source register bit is 1.

The BLWP instruction is a subroutine call accompanied by a context switch. The operand memory address identifies the first of two memory words within which the new WP register and Program Counter contents will be stored.

The BLWP instruction is remarkably powerful. The subroutine call and passing parameters to the subroutine become a single operation. The memory words that are to serve as subroutine general purpose registers can be used as general data memory locations prior to the subroutine call. Thus, the subroutine finds its registers pre-loaded with data when it starts executing.

The RTWP instruction should be used to return from a subroutine that is called by the BLWP instruction.

One-bit position arithmetic shifts may be illustrated as follows:



A one-bit-position logical right shift may be illustrated as follows:



A one-bit right rotate (Shift Right Circular) may be illustrated as follows:



You can specify any number of bits, from 1 to 15, as the number of bit positions for any TMS 9900 shift or rotate instruction. If you specify 0 for the bit count, then the actual bit count is taken from the four low-order bits of general purpose Register R0. If these four low-order bits are 0000, then the bit count is assumed to be 16.

The following symbols are used in Table 18-2:

|        |                                                                                                                                                                                                                                                                                                                                                     |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AG     | Arithmetic Greater Than status                                                                                                                                                                                                                                                                                                                      |
| C      | Carry status                                                                                                                                                                                                                                                                                                                                        |
| CNT    | 4-bit count field                                                                                                                                                                                                                                                                                                                                   |
| CRUA   | CRU base address from R12                                                                                                                                                                                                                                                                                                                           |
| d      | Destination memory word. There are five possible options for the destination memory word. They are represented by these combinations of addressing modes:<br>Workspace Register D<br>Implied through Workspace Register D<br>Direct address<br>Direct, indexed address<br>Implied through Workspace Register D, auto-increment Workspace Register D |
| DATA4  | 4-bit data unit                                                                                                                                                                                                                                                                                                                                     |
| DATA16 | 16-bit data unit                                                                                                                                                                                                                                                                                                                                    |
| DISP   | 8-bit signed displacement                                                                                                                                                                                                                                                                                                                           |
| EQ     | Equal status bit of Status register                                                                                                                                                                                                                                                                                                                 |
| G      | Both the AG and LG statuses                                                                                                                                                                                                                                                                                                                         |
| LG     | Logical Greater Than status                                                                                                                                                                                                                                                                                                                         |
| OP     | Odd Parity status                                                                                                                                                                                                                                                                                                                                   |
| OV     | Overflow status                                                                                                                                                                                                                                                                                                                                     |
| PC     | Program Counter                                                                                                                                                                                                                                                                                                                                     |
| R      | Any of the 16 Workspace registers                                                                                                                                                                                                                                                                                                                   |
| Rxx    | Workspace register. For example, R15 is Workspace Register 15                                                                                                                                                                                                                                                                                       |
| S      | Source memory location. Addressing options identical to destination memory location                                                                                                                                                                                                                                                                 |
| ST     | Status register                                                                                                                                                                                                                                                                                                                                     |
| WP     | Workspace Pointer register                                                                                                                                                                                                                                                                                                                          |
| x<y,z> | Bits y through z of the quantity x. For example, ([S] * [R])<31,16> represents the high-order word of the product of the contents of the Source Register S and the Workspace Register R.                                                                                                                                                            |
| [ ]    | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.                                                             |
| *      | Multiplication                                                                                                                                                                                                                                                                                                                                      |
| /      | Division                                                                                                                                                                                                                                                                                                                                            |
| Λ      | Logical AND                                                                                                                                                                                                                                                                                                                                         |
| ∨      | Logical OR                                                                                                                                                                                                                                                                                                                                          |
| ⊕      | Logical Exclusive-OR                                                                                                                                                                                                                                                                                                                                |
| →      | Data is transferred in the direction of the arrow                                                                                                                                                                                                                                                                                                   |

Under the heading of STATUSES in Table 18-2, an X indicates statuses which are modified in the course of the instruction's execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

**Byte-operand instructions will affect half of a 16-bit memory word. If the word is accessed as a general purpose register, then only the high-order byte will be affected. If the word is accessed as non-register memory, then the byte affected is determined by the least significant bit of the 16-bit address: 0 selects the high-order byte; 1 selects the low-order byte.**

Table 18-2. TMS 9900 Instruction Set Summary

| TYPE                                        | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |    |    |  | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------------|----------|------------|-------|----------|----|---|----|----|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |            |       | G        | EQ | C | OV | OP |  |                                                                                                                                                                                                                                                                                                                                             |
| I/O                                         | LDCR     | S,CNT      | 2     | X        | X  |   |    | X* |  | [CRUA] $\leftarrow$ [S<CNT-1,0>]<br>Transfer the specified number of bits from source memory word to the CRU.<br>[D<CNT-1,0>] $\leftarrow$ [CRUA]                                                                                                                                                                                           |
|                                             | STCR     | D,CNT      | 2     | X        | X  |   |    | X* |  | Transfer the specified number of bits from the CRU to destination memory word.                                                                                                                                                                                                                                                              |
|                                             | SBO      | DISP       | 2     |          |    |   |    |    |  | [CRUA + DISP] $\leftarrow$ 1<br>Set bit in CRU to 1.                                                                                                                                                                                                                                                                                        |
|                                             | SBZ      | DISP       | 2     |          |    |   |    |    |  | [CRUA + DISP] $\leftarrow$ 0<br>Set bit in CRU to 0.                                                                                                                                                                                                                                                                                        |
|                                             | TB       | DISP       | 2     |          | X  |   |    |    |  | If [CRUA + DISP] = 0, then [EQ] = 1; or else [EQ] $\leftarrow$ 0<br>Test bit in CRU.                                                                                                                                                                                                                                                        |
| PRIMARY MEMORY REFERENCE                    | MOV      | S,D        | 2     | X        | X  |   |    |    |  | [D] $\leftarrow$ [S]<br>16-bit move contents of source memory word to destination memory word.                                                                                                                                                                                                                                              |
|                                             | MOVB     | S,D        | 2     | X        | X  |   |    | X  |  | [D] $\leftarrow$ [S]<br>8-bit move contents of source memory byte to destination memory byte.                                                                                                                                                                                                                                               |
| SECONDARY MEMORY REFERENCE (MEMORY OPERATE) | A        | S,D        | 2     | X        | X  | X | X  |    |  | [D] $\leftarrow$ [S] + [D]<br>16-bit add contents of source memory word to contents of destination memory word.                                                                                                                                                                                                                             |
|                                             | AB       | S,D        | 2     | X        | X  | X | X  | X  |  | [D] $\leftarrow$ [S] + [D]<br>8-bit add contents of source memory byte to contents of destination memory byte.                                                                                                                                                                                                                              |
|                                             | S        | S,D        | 2     | X        | X  | X | X  |    |  | [D] $\leftarrow$ [D] - [S]<br>16-bit subtract contents of source memory from contents of destination memory word.                                                                                                                                                                                                                           |
|                                             | SB       | S,D        | 2     | X        | X  | X | X  | X  |  | [D] $\leftarrow$ [D] - [S]<br>8-bit subtract contents of source memory byte from contents of destination memory byte.                                                                                                                                                                                                                       |
|                                             | C        | S,D        | 2     | X        | X  |   |    |    |  | Set status flags based on 16-bit comparison of source and destination memory word contents.                                                                                                                                                                                                                                                 |
|                                             | CB       | S,D        | 2     | X        | X  |   |    | X  |  | Set status flags based on 8-bit comparison of source memory byte contents and destination memory byte contents.                                                                                                                                                                                                                             |
|                                             | XOR      | S,R        | 2     | X        | X  |   |    |    |  | [R] $\leftarrow$ [S] $\oplus$ [R]<br>Exclusive-OR contents of source memory word with Workspace Register R.                                                                                                                                                                                                                                 |
|                                             | MPY      | S,R        | 2     |          |    |   |    |    |  | [R] $\leftarrow$ [(S)*[R]]<31,16><br>[R+1] $\leftarrow$ [(S)*[R]]<15,0><br>Multiply the contents of source memory word by contents of Workspace Register R. Store most significant word of result in R. Store least significant word of result in Workspace Register R + 1.                                                                 |
|                                             | DIV      | S,R        | 2     |          |    |   |    | X  |  | [R] $\leftarrow$ (I[R,R+1]/[S])(quotient)<br>[R+1] $\leftarrow$ (I[R,R+1]/[S])(remainder)<br>Divide the 32-bit quantity represented by R (high-order word) concatenated with R + 1 (low order) by the contents of the source memory word. Store the quotient in R, the remainder in R + 1 and set overflow if quotient will exceed 16 bits. |
|                                             | INC      | D          | 2     | X        | X  | X | X  |    |  | [D] $\leftarrow$ [D] + 1<br>Increment contents of memory word by 1.                                                                                                                                                                                                                                                                         |
|                                             | INCT     | D          | 2     | X        | X  | X | X  |    |  | [D] $\leftarrow$ [D] + 2<br>Increment contents of memory word by 2.                                                                                                                                                                                                                                                                         |
|                                             | DEC      | D          | 2     | X        | X  | X | X  |    |  | [D] $\leftarrow$ [D] - 1<br>Decrement contents of memory word by 1.                                                                                                                                                                                                                                                                         |

\*OP status is affected only if between 1 and 8 bits are transferred.

Table 18-2. TMS 9900 Instruction Set Summary (Continued)

| TYPE                                                    | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |    |    |  | OPERATION PERFORMED                                                                                                                                                               |
|---------------------------------------------------------|----------|------------|-------|----------|----|---|----|----|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         |          |            |       | G        | EQ | C | OV | OP |  |                                                                                                                                                                                   |
| SECONDARY MEMORY REFERENCE (MEMORY OPERATE) (CONTINUED) | DECT     | D          | 2     | X        | X  | X | X  |    |  | [D]—[D]-2<br>Decrement contents of memory word by 2.                                                                                                                              |
|                                                         | CLR      | D          | 2     |          |    |   |    |    |  | [D]—0000 <sub>16</sub><br>Clear the destination memory word.                                                                                                                      |
|                                                         | SETO     | D          | 2     |          |    |   |    |    |  | [D]—FFFF <sub>16</sub><br>Set all bits of memory word.                                                                                                                            |
|                                                         | INV      | D          | 2     | X        | X  |   |    |    |  | [D]—[D]<br>Ones complement the destination memory word.                                                                                                                           |
|                                                         | NEG      | D          | 2     | X        | X  | X | X  |    |  | [D]—[D]+1<br>Twos complement the destination memory word.                                                                                                                         |
|                                                         | ABS      | D          | 2     | X        | X  | X | X  |    |  | [D]—  [D] <br>Take the absolute (unsigned) value of the destination memory word's contents.                                                                                       |
|                                                         | SWPB     | D          | 2     |          |    |   |    |    |  | [D<15,8>]—[D<7,0>]<br>Exchange the high and low bytes of the memory word.                                                                                                         |
|                                                         | SOC      | S,D        | 2     | X        | X  |   |    |    |  | If [S<i>]=1, then [D<i>]—1<br>Set the bits in the destination memory word that correspond to 1s in the source memory word for all 16 bits.                                        |
|                                                         | SOCB     | S,D        | 2     | X        | X  |   |    | X  |  | If [S<i>]=1, then [D<i>]—1<br>Set the bits in the destination memory word that correspond to 1s in the source memory word for 8 bits.                                             |
|                                                         | SZC      | S,D        | 2     | X        | X  |   |    |    |  | If [S<i>]=1, then [D<i>]—0<br>Clear the bits in the destination memory word that correspond to 1s in the source memory word for all 16 bits.                                      |
|                                                         | SZCB     | S,D        | 2     | X        | X  |   |    | X  |  | If [S<i>]=1, then [D<i>]—0<br>Clear the bits in the destination memory word that correspond to 1s in the source memory word for 8 bits.                                           |
|                                                         | COC      | S,R        |       |          | X  |   |    |    |  | If for all [S<i>]=1, [R<i>]=1, then [EQ]=1<br>If the bits in the Workspace Register R that correspond to the set bits in the source memory word are all 1s, set the EQUAL status. |
| IMMEDIATE                                               | LI       | R,DATA16   | 4     | X        | X  |   |    |    |  | [R]—DATA16<br>Load immediate to Workspace Register R.                                                                                                                             |
|                                                         | LWPI     | DATA16     | 4     |          |    |   |    |    |  | [WR]—DATA16<br>Load immediate to Workspace Pointer Register, WR.                                                                                                                  |

Table 18-2. TMS 9900 Instruction Set Summary (Continued)

| TYPE                       | MNEMONIC | OPERAND(S) | BYTES | STATUSES |    |   |    |    | OPERATION PERFORMED                                                                                                                                                                                                        |
|----------------------------|----------|------------|-------|----------|----|---|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |          |            |       | G        | EQ | C | OV | OP |                                                                                                                                                                                                                            |
| IMMEDIATE OPERATE          | CI       | R,DATA16   | 4     | X        | X  |   |    |    | Set the status flags based on 16-bit comparison between contents of Workspace Register R and immediate data.<br>[R]←[R] + DATA16                                                                                           |
|                            | AI       | R,DATA16   | 4     | X        | X  | X | X  |    | Add immediate to Workspace Register R contents.<br>[R]←[R] + DATA16                                                                                                                                                        |
|                            | ANDI     | R,DATA16   | 4     | X        | X  |   |    |    | AND immediate with Workspace Register R contents.<br>[R]←[R] & DATA16                                                                                                                                                      |
|                            | ORI      | R,DATA16   | 4     | X        | X  |   |    |    | OR immediate with Workspace Register R contents.<br>[R]←[R] V DATA16                                                                                                                                                       |
| JUMP                       | B        | S          | 2     |          |    |   |    |    | [PC]←[S]<br>Branch unconditional to address in Source memory word.                                                                                                                                                         |
|                            | JMP      | DISP       | 2     |          |    |   |    |    | [PC]←[PC] + DISP<br>Branch unconditional.                                                                                                                                                                                  |
| SUBROUTINE CALL AND RETURN | BL       | S          | 2     |          |    |   |    |    | [R11]←[PC]+1<br>[PC]←[S]<br>Branch to subroutine at address in source memory word.                                                                                                                                         |
|                            | BLWP     | S          | 2     |          |    |   |    |    | [R13]←[WP]<br>[R14]←[PC]<br>[R15]←[ST]<br>[WP]←[S]<br>[PC]←[S+2]                                                                                                                                                           |
|                            | RTWP     |            |       |          | X  | X | X  | X  | Branch to subroutine whose address is stored in source memory word + 1. Perform context switch to R0 address contained in source memory word.<br>[WP]←[R13]<br>[PC]←[R14]<br>[ST]←[R15] Perform a backward context switch. |
|                            |          |            | 2     |          |    |   |    |    |                                                                                                                                                                                                                            |
| BRANCH ON CONDITION        | JEQ      | DISP       | 2     |          |    |   |    |    | If [EQ]=1; then [PC]←[PC] + DISP<br>Branch if equal.                                                                                                                                                                       |
|                            | JNE      | DISP       | 2     |          |    |   |    |    | If [EQ]=0; then [PC]←[PC] + DISP<br>Branch if not equal.                                                                                                                                                                   |
|                            | JGT      | DISP       | 2     |          |    |   |    |    | If [AG]=1; then [PC]←[PC] + DISP<br>Branch on arithmetic greater than.                                                                                                                                                     |
|                            | JLT      | DISP       | 2     |          |    |   |    |    | If [AG]=0 and [EQ]=0; then [PC]←[PC] + DISP<br>Branch on arithmetic less than.                                                                                                                                             |
|                            | JHE      | DISP       | 2     |          |    |   |    |    | If [LG]=1 or [EQ]=1; then [PC]←[PC] + DISP<br>Branch on logical greater than or equal.                                                                                                                                     |
|                            | JH       | DISP       | 2     |          |    |   |    |    | If [LG]=1 and [EQ]=0; then [PC]←[PC] + DISP<br>Branch on logical greater than.                                                                                                                                             |
|                            | JL       | DISP       | 2     |          |    |   |    |    | If [LG]=0 and [EQ]=0; then [PC]←[PC] + DISP<br>Branch on logical less than.                                                                                                                                                |
|                            | JLE      | DISP       | 2     |          |    |   |    |    | If [EQ]=1 or [LG]=0; then [PC]←[PC] + DISP<br>Branch on less than or equal.                                                                                                                                                |

Table 18-2. TMS 9900 Instruction Set Summary (Continued)

| TYPE                            | MNEMONIC                             | OPERAND(S)                       | BYTES            | STATUSES         |                  |                  |    |    | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------|--------------------------------------|----------------------------------|------------------|------------------|------------------|------------------|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |                                      |                                  |                  | G                | EQ               | C                | OV | OP |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| BRANCH ON CONDITION (CONTINUED) | JNC                                  | DISP                             | 2                |                  |                  |                  |    |    | If [C]=0; then [PC]←[PC]+DISP<br>Branch on carry reset.                                                                                                                                                                                                                                                                                                                                                                          |
|                                 | JNO                                  | DISP                             | 2                |                  |                  |                  |    |    | If [OV]=0; then [PC]←[PC]+DISP<br>Branch on overflow reset.                                                                                                                                                                                                                                                                                                                                                                      |
|                                 | JOC                                  | DISP                             | 2                |                  |                  |                  |    |    | If [C]=1; then [PC]←[PC]+DISP<br>Branch on carry set.                                                                                                                                                                                                                                                                                                                                                                            |
|                                 | JOP                                  | DISP                             | 2                |                  |                  |                  |    |    | If [OP]=1; then [PC]←[PC]+DISP<br>Branch on odd parity set.                                                                                                                                                                                                                                                                                                                                                                      |
| REGISTER OPERATE                | SLA<br>SRA<br>SRL<br>SRC             | R,CNT<br>R,CNT<br>R,CNT<br>R,CNT | 2<br>2<br>2<br>2 | X<br>X<br>X<br>X | X<br>X<br>X<br>X | X<br>X<br>X<br>X |    |    | Arithmetic shift the Workspace Register R left the specified number of bits.<br>Arithmetic shift the Workspace Register R right the specified number of bits.<br>Logical shift the Workspace Register R right the specified number of bits.<br>Rotate the Workspace Register R right the specified number of bits.                                                                                                               |
| STATUS AND INTERRUPT            | STST<br>STWP<br>LIMI<br>XOP          | R<br>R<br>DATA4<br>S,R           | 2<br>2<br>4<br>2 |                  |                  |                  |    | X  | [R]←[ST]<br>Store the Status register into Workspace Register R.<br>[R]←[WP]<br>Store the Workspace Pointer into Workspace Register R.<br>[SR<3,0>]←DATA4<br>Load immediate data into the interrupt mask bits of the Status register.<br>[R13]←[WP]<br>[R14]←[PC]<br>[R15]←[ST]<br>[R11]←LS<br>[WP]←[40 <sub>16</sub> +(4*[R])]<br>[PC]←[41 <sub>16</sub> +(4*[R])]<br>Perform a context switch. This is the software interrupt. |
| EXECUTE                         | X                                    | S                                | 2                |                  |                  |                  |    |    | Execute the instruction represented by the data in the source location. If that instruction has immediate operand words, those words must be located directly after the X instruction. The instruction [S] will affect the status flags but its fetch will not cause IAQ to go high.                                                                                                                                             |
| EXTERNALLY DEFINED              | IDLE<br>RSET<br>CKOF<br>CKON<br>LREX |                                  | 2                |                  |                  |                  |    |    | CPU enters Halt state.<br>CPU clears interrupt mask and outputs 001 on three high-order Address Bus lines.<br>011 on three high-order Address Bus lines.<br>110 out on three high-order Address Bus lines.<br>101 out on three high-order Address Bus lines.<br>111 out on three high-order Address Bus lines.                                                                                                                   |

## THE BENCHMARK PROGRAM

For the TMS 9900, our benchmark program may be illustrated as follows:

|      | BLWP | MOVE            | CONTEXT SWITCH TO APPROPRIATE REGISTERS |
|------|------|-----------------|-----------------------------------------|
| LOOP | MOV  | @IOBUF(R1),*R2+ | LOAD NEXT INPUT WORD IN NEXT TABLE WORD |
|      | DEC  | R1              | DECREMENT COUNT                         |
|      | JNE  | LOOP            | RETURN FOR MORE                         |
|      | RTWP |                 | RETURN FROM SUBROUTINE                  |

Let us look at how our benchmark program can collapse to just five instructions.

We assume that there is some set of 16 General Purpose registers within which we store the word count and the address of the first free word in TABLE. We illustrated this idea when describing context switching earlier in the chapter.

Observe that Register R1 contains the word count, and is therefore used as an Index register, while Register R2 addresses the first free word in TABLE. Note that the contents of Register R2 are incremented automatically when the next byte is loaded into the table.

The BLWP instruction will branch to the program which performs the required data move, but simultaneously it loads the Workspace register with the appropriate initial address. We do not need to load any initial addresses or word counts into registers, since we have adopted the memory space where this data is stored to serve as our General Purpose registers.

After the move has been completed, we do not have to update any counters or pointers, because they were updated "in situ". All we have to do upon completing the move is store the contents of the current General Purpose Registers 13 and 14 to the Workspace register and Program Counter.

The following notation is used in Table 18-3:

|          |                                                                          |
|----------|--------------------------------------------------------------------------|
| aa       | Two bits determining the addressing mode for the destination memory word |
| bb       | Two bits determining the addressing mode for the source memory word      |
| cccccccc | 8-bit signed address displacement                                        |
| dddd     | Four bits used with aa to determine the destination memory word          |
| eeee     | 4-bit count field                                                        |
| rrrr     | Four bits choosing the Workspace register                                |
| ssss     | Four bits used with bb to determine the source memory word               |
| xx       | 16 bits of immediate data                                                |

If either aa or bb is  $10_2$ , and the corresponding register specified is  $0_2$ , then an additional 16-bit direct memory address word, used in computing the effective memory address of the operand, will follow the instruction.

If aa and bb are  $10_2$ , and both corresponding register specifications are 0, then two additional 16-bit direct memory addressing words will follow the instruction: the first will be used in computing the source address; the second will be used in computing the destination address.

Table 18-3. TMS 9900 Instruction Set Object Codes

| INSTRUCTION   | OBJECT CODE       | BYTES | CLOCK PERIODS* | INSTRUCTION  | OBJECT CODE       | BYTES | CLOCK PERIODS* |
|---------------|-------------------|-------|----------------|--------------|-------------------|-------|----------------|
| A S,D         | 1010aaddddbssss   | 2     | 14-30 (1)      | JOP DISP     | 00011100ccccccc   | 2     | 8/10(15)       |
| AB S,D        | 1011aaddddbssss   | 2     | 14-30 (1)      | LDCR S,CNT   | 001100eeebbssss   | 2     | 22-52 (11)     |
| ABS D         | 0000011101aadddd  | 2     | 12-20 (6)      | LI R,DATA16  | 000000100000rrr   | 4     | 12 (19)        |
| AI R,DATA16   | 000000100010rrr   | 4     | 14 (17)        |              | XX                |       |                |
|               | XX                |       |                | LIMI DATA4   | 0000001100000000  | 4     | 16 (21)        |
| ANDI R,DATA16 | 000000100100rrr   | 4     | 14 (17)        |              | XX                |       |                |
|               | XX                |       |                | LREX         | 0000001111100000  | 2     | 6 (14)         |
| B S           | 0000010001bbssss  | 2     | 8-16 (7)       | LWPI DATA16  | 0000001011100000  | 4     | 10 (20)        |
| BL S          | 0000011010bbssss  | 2     | 12-20 (9)      |              | XX                |       |                |
| BLWP S        | 0000010000bbssss  | 2     | 26-34 (10)     | MOV S,D      | 1100aaddddbssss   | 2     | 14-30 (1)      |
| C S,D         | 1000aaddddbssss   | 2     | 14-30 (1)      | MOVBD S,D    | 1101aaddddbssss   | 2     | 14-30 (1)      |
| CB S,D        | 1001aaddddbssss   | 2     | 14-30 (1)      | MPY S,R      | 001110rrrbbssss   | 2     | 52-60 (2)      |
| CI S,D        | 0000000101000rrr  | 4     | 14 (18)        | NEG D        | 0000010100aadddd  | 2     | 12-20 (5)      |
|               | XX                |       |                | ORI R,DATA16 | 000000100110rrr   |       | 14 (17)        |
| CKON          | 0000001111000000  | 2     | 6 (14)         |              | XX                |       |                |
| CKOF          | 0000001110100000  | 2     | 6 (14)         | RSET         | 0000001101100000  | 2     | 6 (14)         |
| CLR D         | 0000010011aadddd  | 2     | 10-18 (5)      | RTWP         | 0000001100000000  | 2     | 14 (8)         |
| COC S,R       | 001000rrrrbbssss  | 2     | 10-18 (1)      | S S,D        | 0110aaddddbssss   | 2     | 14-30 (1)      |
| CZC S,R       | 001001rrrrbbssss  | 2     | 14-22 (1)      | SB S,D       | 0111aaddddbssss   | 2     | 14-30 (1)      |
| DEC D         | 00000011000aadddd | 2     | 14-22 (5)      | SBO DISP     | 00011101ccccccc   | 2     | 12 (13)        |
| DECT D        | 00000011001aadddd | 2     | 10-18 (5)      | SBZ DISP     | 00011110ccccccc   | 2     | 12 (13)        |
| DIV S,R       | 001111rrrrbbssss  | 2     | 10-18 (3)      | SETO D       | 0000011100aadddd  | 2     | 10-18 (5)      |
| IDLE          | 0000001101000000  | 2     | 6 (14)         | SLA R,CNT    | 000001010eeeeerrr | 2     | 14-52 (16)     |
| INC D         | 00000010110aadddd | 2     | 16-124 (5)     | SOC S,D      | 1110aaddddbssss   | 2     | 14-30 (1)      |
| INCT D        | 00000010111aadddd | 2     | 10-18 (5)      | SOCB S,D     | 1111aaddddbssss   | 2     | 14-30 (1)      |
| INV D         | 0000010101aadddd  | 2     | 10-18 (5)      | SRA R,CNT    | 00001000eeeeerrr  | 2     | 14-52 (16)     |
| JEQ DISP      | 00010011ccccccc   | 2     | 10-18 (15)     | SRC R,CNT    | 00001011eeeeerrr  | 2     | 14-52 (16)     |
| JGT DISP      | 00010101ccccccc   | 2     | 8/10 (15)      | SRL R,CNT    | 00001001eeeeerrr  | 2     | 14-52 (16)     |
| JH DISP       | 00010101ccccccc   | 2     | 8/10 (15)      | STCR D,CNT   | 001101eeeeaadddd  | 2     | 42-60 (12)     |
| JHE DISP      | 00010100ccccccc   | 2     | 8/10 (15)      | STST R       | 000000101100rrr   | 2     | 8 (23)         |
| JL DISP       | 00010101ccccccc   | 2     | 8/10 (15)      | STWP R       | 000000101010rrr   | 2     | 8 (22)         |
| JLE DISP      | 00010010ccccccc   | 2     | 8/10 (15)      | SWPB D       | 0000011011aadddd  | 2     | 10-18 (23)     |
| JLT DISP      | 00010001ccccccc   | 2     | 8/10 (15)      | SZC S,D      | 0100aaddddbssss   | 2     | 14-30 (1)      |
| JMP DISP      | 00010000ccccccc   | 2     | 10 (15)        | SZCB S,D     | 0101aaddddbssss   | 2     | 14-30 (1)      |
| JNC DISP      | 00010111ccccccc   | 2     | 8/10 (15)      | TB DISP      | 00011111ccccccc   | 2     | 12 (8)         |
| JNE DISP      | 00010110ccccccc   | 2     | 8/10 (15)      | X S          | 0000010010bbssss  | 2     | 8-16 (7)       |
| JNO DISP      | 00011001ccccccc   | 2     | 8/10 (15)      | XOP S,R      | 001011rrrbbssss   | 2     | 44-52 (4)      |
| JOC DISP      | 00011000ccccccc   | 2     | 8/10 (15)      | XOR S,R      | 001010rrrbbssss   | 2     | 14-22 (11)     |

\* The number in brackets identifies the instruction's machine cycle sequence, as defined in the preceding text.

The minimum and maximum number of clock periods for the execution of each instruction are shown in the CLOCK PERIODS column of Table 18-3. Remember that a machine cycle consists of two clock periods. The bracketed number after the number of clock periods identifies the machine cycle sequence. Machine cycle sequences associated with each bracketed number are listed below. In the machine cycle list below, the following abbreviations are used:

R represents a memory read machine cycle as identified in Figure 18-4.

A represents an ALU machine cycle as illustrated in Figure 18-3.

W represents a memory write machine cycle as illustrated in Figure 18-5.

C represents a CRU machine cycle as illustrated in Figures 18-6 and 18-7.

A subscript associated with any machine cycle notation identifies that machine cycle repeated a number of times. Thus A<sub>3</sub> is equivalent to -A-A-A-.

M represents memory address computation machine cycles. Memory address computations were described earlier in this chapter. In summary, here are the various possibilities for M:

Register addressing: R

Implied memory addressing: R-A-R

Implied memory addressing with auto-increment (for byte operand): R-A-W-R

Implied memory addressing with auto-increment (for word operand): R-A-A-W-R

Direct addressing: A-A-R-A-R

Direct indexed addressing: R-A-R-A-R

(1) R-A-M-A-M-A-W R

(2) R-A-M-A-R-A<sub>18</sub>-W-A-W R-A-R

(3) R-A-M-A-R-A-A-R-A<sub>x</sub>-W-A-W (51 ≤ x ≤ 35) R-A-W-R

(4) R-A-M-A<sub>3</sub>-R-A-W-A-W-A-W-A-W-A-R-A A-A-R-A-R

(5) R-A-M-A-W R

(6) R-A-M-A<sub>3</sub>-W-A R-A-R-A-R

(7) R-A-M-A R-A-R-A-R

(8) R-A-A-R-R-R-A R

(9) R-A-M-A-A-W R

(10) R-A-M-A-A-W-A-W-A-W-A-R-A R

(11) R-A-M-A<sub>4</sub>-R-A-C<sub>x</sub>-A (16 ≤ x ≤ 1) R-A-R-A-R-A-A-C

(12) R-A-M-A-R-A-A-C<sub>x</sub>-A<sub>y</sub>-W (16 ≤ x ≤ 1, 11 ≤ y ≤ 5) R-A-A-R-A-C

(13) R-A-A-R-A-C R

(14) R-A-A-C-A-A R

(15) R-A<sub>x</sub> (x=3 or 4) R-A-A-R-A-R-A-A

(16) R-A-R-A-A-R-A<sub>x</sub>-W-A (18 ≤ x ≤ 3) R-A-A-R-A-A-W

(17) R-A-A-R-R-A-W R

(18) R-A-R-A-R-A-A R

(19) R-A-A-R-A-W R

(20) R-A-A-R-A R

(21) R-A-A-R-A<sub>3</sub> R-A-A-R-A-A

(22) R-A-A-W R

(23) R-A-M-A-R-A<sub>4</sub>-W R

## THE TMS 9980A AND THE TMS 9981 MICROPROCESSORS

The TMS 9980A and the TMS 9981 are low-cost variations of the TMS 9900. The principal differences between the TMS 9900 series and TMS 9980 series microprocessors are summarized in Table 18-4. Differences between the TMS 9980A and the TMS 9981 are summarized in Table 18-5.

This discussion of the TMS 9980 series microprocessors covers only differences as compared to the TMS 9900.

The TMS 9980 series microprocessors are manufactured using N-channel silicon gate MOS technology. They are packaged as 40-pin DIPs. The TMS 9980A uses three power supplies: -5V, +5V, and +12V. The TMS 9981 uses two power supplies: +5V and +12V.

Typically, a clock cycle time of 400 nanoseconds will be used with TMS 9980 series microprocessors. This generates instruction execution times ranging between 4 and 14 microseconds.

**Figure 18-14 illustrates that part of general microcomputer system logic which is implemented by the TMS 9980 series microprocessors.** This figure is identical to Figure 18-1, with the exception of clock logic, which is now shown present.

**Programmable registers are implemented and used in exactly the same way the TMS 9900 and TMS 9980 series microprocessors.** Note, however, that the **TMS 9980 series microprocessors address a 2048-bit CRU;** therefore, bits 1 through 11 of Register R12 identify the origin of any CRU bit field. The TMS 9900 uses bits 1 through 12 of Register R12 to identify the CRU origin within a 4096-bit CRU.

Table 18-4. A Summary of Differences Between the TMS 9900 and TMS 9980 Series Microprocessors

| FUNCTION                      | TMS 9900              | TMS 9980A/TMS 9981                             |
|-------------------------------|-----------------------|------------------------------------------------|
| Addressable external memory   | 32,768 x 16-bit words | 16,384 x 8-bit words                           |
| DIP pins                      | 64                    | 40                                             |
| Data Bus                      | 16 bits               | 8 bits                                         |
| Address Bus                   | 15 bits               | 13 bits                                        |
| External interrupt priorities | 15                    | 4                                              |
| CRU field width               | 4096 bits             | 2048 bits                                      |
| Clock logic                   | Four external inputs  | One external input or internal (TMS 9981 only) |

Table 18-5. A Summary of Differences Between the TMS 9980A and TMS 9981 Microprocessors

| FUNCTION                 | TMS 9980A                      | TMS 9981                           |
|--------------------------|--------------------------------|------------------------------------|
| Power supplies           | -5V, +5V, +12V                 | +5V, +12V                          |
| Clock logic              | One external input             | One external input or crystal only |
| Pin incompatibility ties | D0 - D7, INT0 - INT2, $\Phi_3$ |                                    |

**The TMS 9980 series microprocessors have a 14-line Address Bus, used to address up to 16,384 bytes of memory.** In contrast, the TMS 9900 addresses up to 32,768 16-bit words of external memory. Thus, TMS 9980 programs address memory as bytes, while externally generated addresses also select bytes. The TMS 9900, by way of contrast, addresses memory as bytes within the CPU, but as 16-bit words externally.

**The TMS 9980 series microprocessors use exactly the same memory and CRU addressing techniques as the TMS 9900.** General-purpose registers are used in the same way, and instruction object codes are identical.

**The Status register and Status flags used by the TMS 9980 series microprocessors are identical to those which we have already described for the TMS 9900.**

### TMS 9980 SERIES MICROPROCESSOR PINS AND SIGNALS

**Figure 18-15 illustrates pins and signals for the TMS 9980A. Figure 18-16 provides the same information for the TMS 9981.** In both of these illustrations, signal names conform to Texas Instruments nomenclature. For the Data and Address Busses, our notation is given in brackets. Differences result from the fact that we number bits from right to left (0 being the low-order bit), while Texas Instruments numbers bits from left to right (0 becomes the high-order bit). **TMS 9980A/TMS 9981 pin-out differences are shaded in Figures 18-15 and 18-16 so that you can identify them quickly.**

**For descriptions of the individual signals, refer to the earlier TMS 9900 discussion.**



Figure 18-14. Logic of the TMS 9980A and TMS 9981 Microprocessors



| Pin Name                                  | Description                    | Type                    |
|-------------------------------------------|--------------------------------|-------------------------|
| A0-A13                                    | Address Bus                    | Tristate, output        |
| D0-D7                                     | Data Bus                       | Tristate, bidirectional |
| CKIN                                      | Clock signal in                | Input                   |
| $\phi_3$                                  | Synchronizing clock            | Output                  |
| MEMEN                                     | Memory Enable                  | Tristate, output        |
| IAQ                                       | Instruction Fetch              | Output                  |
| DBIN                                      | Data Bus in                    | Tristate, output        |
| WE                                        | Write Enable                   | Tristate, output        |
| READY                                     | Memory Ready                   | Input                   |
| WAIT                                      | Wait State indicator           | Output                  |
| CRUCLK                                    | I/O clock                      | Output                  |
| CRUOUT                                    | Serial I/O out                 | Output                  |
| CRUIN                                     | Serial I/O in                  | Input                   |
| INT0, INT1, INT2                          | Interrupt request and priority | Input                   |
| HOLD                                      | DMA request                    | Input                   |
| HOLDA                                     | Hold acknowledge               | Output                  |
| $V_{BB}$ , $V_{CC}$ , $V_{DD}$ , $V_{SS}$ | Power and Ground reference     |                         |

Figure 18-15. TMS 9980A Signals and Pin Assignments



| Pin Name                                            | Description                    | Type                    |
|-----------------------------------------------------|--------------------------------|-------------------------|
| A0-A13                                              | Address Bus                    | Tristate, output        |
| D0-D7                                               | Data Bus                       | Tristate, bidirectional |
| CKIN                                                | Clock or crystal connection    | Input                   |
| OSCOUT                                              | Crystal connection             | Output                  |
| $\phi_3$                                            | Synchronizing clock            | Output                  |
| MEMEN                                               | Memory Enable                  | Tristate, output        |
| IAQ                                                 | Instruction Fetch              | Output                  |
| DBIN                                                | Data Bus in                    | Tristate, output        |
| WE                                                  | Write Enable                   | Tristate, output        |
| READY                                               | Memory Ready                   | Input                   |
| WAIT                                                | Wait State Indicator           | Output                  |
| CRUCLK                                              | I/O clock                      | Output                  |
| CRUOUT                                              | Serial I/O out                 | Output                  |
| CRUIN                                               | Serial I/O in                  | Input                   |
| INT0, INT1, INT2                                    | Interrupt request and priority | Input                   |
| HOLD                                                | DMA request                    | Input                   |
| HOLDA                                               | Hold acknowledge               | Output                  |
| V <sub>CC</sub> , V <sub>DD</sub> , V <sub>SS</sub> | Power and Ground reference     |                         |

Figure 18-16. TMS 9981 Signals and Pin Assignments

## TMS 9980 SERIES MICROPROCESSOR TIMING AND INSTRUCTION EXECUTION

The TMS 9980A and TMS 9981 microprocessors have the same signal relationships and instruction execution sequences as the TMS 9900. The few minor waveform differences are identified in the data sheets at the end of this chapter.

**The only significant difference between the TMS 9900 and TMS 9980 series is in clock logic.** The TMS 9900 requires four clock inputs, as identified in Figure 18-3.

The TMS 9980A requires a single clock signal, input via CKIN. The frequency of this clock input must be four times the desired clock frequency. That is to say, CKIN will be divided by four in order to create one clock period. The TMS 9981 can operate with the same CKIN input as the TMS 9980A; however, you can also connect a crystal across CKIN and OSCOUT. This may be illustrated as follows:

**TMS 9980  
SERIES  
CLOCK  
LOGIC**



C1 and C2 must have values between 10pf and 25pf, typically 15pf.

The crystal must be of the fundamental frequency type. The frequency will be divided by four in order to create the internal clock frequency.

Both the TMS 9980A and the TMS 9981 output  $\Phi_3$ , a synchronizing clock signal.  $\Phi_3$  is the inverse of the  $\Phi_3$  clock signal shown in Figure 18-3 and in subsequent timing diagrams for the TMS 9900.

Thus you can create the timing diagram for any TMS 9980 operation by looking at the equivalent timing diagram for the TMS 9900 and replacing the four TMS 9900 clock signals by a single timing pulse which will be the complement of  $\Phi_3$ .

### The following operations are identical within TMS 9900 and TMS 9980 systems:

- Memory references. However, note that memory reference will consist of two memory access cycles, as a 16-bit word is handled as two bytes.
- CRU I/O operations (remember that the TMS 9980 series CRU is only 2048 bits wide).
- CRU control operations
- The Wait state
- The Hold state and direct memory access operations
- The Halt state
- The interaction of Hold and Halt states

Refer to the TMS 9900 discussion for any of the above topics.

### TMS 9980 SERIES INTERRUPT LOGIC

The TMS 9980A and TMS 9981 microprocessors support four levels of external interrupt, together with a Reset and a Load. Reset and Load are non-maskable interrupts. In contrast, the TMS 9900 supports 15 levels of external interrupt, along with Reset.

**The TMS 9980 series microprocessors identify external interrupts via the INT0, INT1, and INT2 inputs as shown in Table 18-6. Figure 18-17 shows the interrupt vector map.**

Table 18-6. TMS 9980 Interrupts

| INT0 | INT1 | INT2 | Interrupt Decoded          |
|------|------|------|----------------------------|
| 0    | 0    | 0    | Reset                      |
| 0    | 0    | 1    | Reset                      |
| 0    | 1    | 0    | Load                       |
| 0    | 1    | 1    | Level 1 (Highest Priority) |
| 1    | 0    | 0    | Level 2                    |
| 1    | 0    | 1    | Level 3                    |
| 1    | 1    | 0    | Level 4 (Lowest Priority)  |
| 1    | 1    | 1    | No Interrupts              |

Observe that the TMS 9980A and the TMS 9981 have no INTREQ input. Also, the Reset and Load non-maskable interrupts are decoded from the INT0 - INT2 inputs.

Figure 18-18 shows some pin connections for various levels of interrupt complexity in a TMS 9980 series microcomputer system. The three illustrations shown are self-evident: they simply implement the INT0 - INT2 codes defined above.

The TMS 9980 series microprocessors provide all 16 XOP software interrupts available with a TMS 9900.

Observe that Figure 18-17 shows memory as 8-bit units in contrast to Figure 18-11, which shows memory as 16-bit units. This reflects the fact that external memory is addressed as bytes by the TMS 9980A and the TMS 9981.



Figure 18-17. TMS 9980 Memory Map



Figure 18-18. Some TMS 9980A/TMS 9981 Interrupt Interfaces.

The interrupt acknowledge process and interrupt priority arbitration logic are identical in TMS 9900 and TMS 9980 series microprocessors. For a discussion of these subjects, refer to the earlier TMS 9900 description.

### THE TMS 9980 SERIES INSTRUCTION SET

The TMS 9900 and TMS 9980 series microprocessors have identical instruction sets. Instructions execute in almost the same sequences of machine cycles — the only difference is that each memory reference will have twice as many memory access cycles. Refer to Tables 18-2 and 18-3, together with their accompanying text, for details. Remember to substitute two memory cycles for each TMS 9900 memory cycle.

## THE TMS 9940 SINGLE-CHIP MICROCOMPUTERS

The TMS 9940 is a single-chip microcomputer based on the TMS 9900 microprocessor. Figure 18-19 illustrates that part of our general microcomputer system logic provided by the TMS 9940 series microcomputer.

Specifically, this is the logic provided by the TMS 9940 series microcomputers:

- A Central Processing Unit, essentially equivalent to the TMS 9900 Central Processing Unit
- **2048 bytes of read-only memory.** Erasable Programmable Read-Only Memory (EPROM) is provided by the TMS 9940OE. Normal mask programmable Read-Only Memory (ROM) is available with the TMS 9940M.
- **128 bytes of read/write memory.** This read-write memory is frequently organized as four sets of sixteen 16-bit registers.

- Two levels of external interrupt
- An on-chip timer/event counter with its own interrupt logic
- 32 I/O pins accessed as 32 CRU bits
- A single +5V power supply
- On-chip clock logic



Figure 18-19. Logic of the TMS 9940 Single-Chip Microcomputers

**The TMS 9940 microcomputer has very little expansion logic; 256 external CRU bits can be addressed, but there is no provision for executing programs directly from external memory.**

**But the TMS 9940 is easily included in multiprocessor configurations.** For multiprocessor configurations, the TMS 9940 has internal Hold request/acknowledge logic, together with a serial I/O path via which data can be transferred between processors.

**The TMS 9940 has two +5V power supplies: a standard operating power supply and a standby power supply.** Under program control, it is possible to shut down the TMS 9940, in which case only the standby power supply is active. An external interrupt can subsequently restart the TMS 9940.

The TMS 9940 is manufactured using N-channel silicon gate MOS technology. It is packaged as a 40-pin DIP.

Using a 3 MHz clock, instruction execution times range between 3 and 10 microseconds.

This description of the TMS 9940 microcomputer relies on the preceding detailed description of the TMS 9900. This description of the TMS 9940 does not stand alone, and you should not read it until you understand the TMS 9900 in detail.

## TMS 9940 REGISTERS AND READ/WRITE MEMORY

There are some important conceptual differences between the read/write memory/registers of the TMS 9940 and those of the TMS 9900.

The TMS 9940 has only 128 bytes of read/write memory, with all the read/write on the chip itself, and you cannot create an external Data/Address Bus. Therefore, it makes no difference whether memory is addressed as bytes or words. The only remaining restriction is that 16-bit words must be originated on even byte address boundaries.



Figure 18-20. TMS 9940 Memory Map

The TMS 9940 does introduce one additional read/write memory restriction: the **128 bytes of read/write memory are divided into four non-overlapping sets of sixteen 16-bit registers**, as illustrated in Figure 18-20. Note that the 128 bytes of read/write memory have specifically defined addresses. Both the TMS 9900 and the TMS 9980 series microprocessors allow any sixteen 16-bit words of memory to serve as a set of general purpose registers, whether or not they overlap with another set.

**The TMS 9940 has the same three CPU registers as the TMS 9900:** the Program Counter, the Workspace register, and the Status register. The TMS 9940 sets aside general-purpose registers to serve specific functions, as does the TMS 9900.

Given the configuration of the TMS 9940, many register designations can be justified only as a means of preserving TMS 9900 series compatibility. For example, a 16-bit TMS 9940 Workspace register makes no sense when there are only 64 locations that the Workspace register can possibly address. Moreover, the whole idea of context switching — and tying up three 16-bit registers in order to execute a context switch — is ridiculous, given the few places to which you can context switch.

But there is long-range sense in the TMS 9940 design. Over the next few years, enhancements of the TMS 9940 will appear with substantially more memory — both read-only memory and read/write memory. Since it is absolutely imperative that TMS 9940 programs be compatible with new, enhanced one-chip microcomputers that are likely to appear, it is necessary that addressing modes and architectural features that influence the instruction set be included in the TMS 9940 if they will be useful in later enhancements.

Despite the fact that the TMS 9940 has only 128 bytes of read/write memory and 2048 bytes of read-only memory, the TMS 9940 has all of the TMS 9900 memory addressing modes. Note carefully that so far as memory addressing is concerned, there is no difference between read-only memory and read/write memory. Many one-chip microcomputers have a scratchpad read/write memory which can only be accessed as data memory, while a separate program memory can only store instruction sequences. The TMS 9940 makes no such distinction between its read-only memory and read/write memory. Data and instructions can be stored in read-only memory or in read/write memory.

**The TMS 9940 and TMS 9900 CRU addressing techniques are identical;** however, the TMS 9940 has just 32 external CRU bits, each with its own dedicated pin. By configuring 11 of these pins as address lines and CRU controls, you can expand external CRU to 256 bits.

There are some small differences between the TMS 9930 Status register as compared to the TMS 9900 Status register. The TMS 9940 Status register may be illustrated as follows:



TMS 9940 L, N, =, C, O, and P statuses are the same as those of the TMS 9900.

The TMS 9940 has no XOP instruction executed status, which the TMS 9900 holds in Status register bit 9.

The TMS 9940 has an AC status in bit 8. This is a half-carry status. For byte-oriented instructions, AC represents the carry from the low four bits to the higher four:



For 16-bit instructions, the AC status represents a carry from bit 11 to bit 12:



Since there are just four levels of external interrupt, the TMS 9940 uses Status register bits 0 and 1 for its interrupt mask. In contrast, the TMS 9900 uses Status register bits 0, 1, 2, and 3 for its interrupt mask.

### TMS 9940 CPU PINS AND SIGNAL ASSIGNMENTS

Figure 18-21 illustrates the pins and signals of the TMS 9940 microcomputer.

**P0 - P31** and 32 I/O pins addressed as 32 CRU bits. Some of these pins serve additional functions which can be selected under program control.

The TMS 9940 can, in fact, use standard TMS 9900 CRU instructions to address up to 512 CRU bits. But 512 is the maximum number of CRU bits that the TMS 9940 can address. Therefore, the TMS 9940 uses just 9 bits of General Purpose Register R12 to create CRU bit addresses. For a single-bit CRU instruction, this may be illustrated as follows:





| Pin Name         | Description                              | Type          |
|------------------|------------------------------------------|---------------|
| P0 - P31         | CRU I/O pins                             | Bidirectional |
| INT1/TST         | External interrupt and Test select       | Input         |
| INT2/PROG        | External interrupt and EPROM programmer  | Input         |
| RST/PE           | System reset and EPROM programmer enable | Input         |
| A0 - A7          | External CRU bit address                 | Output        |
| CRUCLK           | External CRU clock                       | Output        |
| CRUOUT           | External serial I/O output               | Output        |
| CRUIN            | External serial I/O input                | Input         |
| TC               | Multiprocessor data I/O clock            | Bidirectional |
| TD               | Multiprocessor data I/O                  | Bidirectional |
| EC               | Event counter input                      | Input         |
| IDLE             | Idle state indicator                     | Output        |
| HLD              | Hold request                             | Input         |
| HLDA             | Hold acknowledge                         | Output        |
| Φ                | Synchronizing clock                      | Output        |
| XTAL2, XTAL1     | External crystal connections             |               |
| V <sub>CC1</sub> | Standby +5V power                        |               |
| V <sub>CC2</sub> | Normal +5V power                         |               |
| V <sub>SS</sub>  | Ground reference                         |               |

(In this figure, Pn and An numbering conforms to Texas Instruments' policy of beginning with N=0 for the high-order bit. We use N=0 for the low-order bit.)

Figure 18-21. TMS 9940 Microcomputer Signals and Pin Assignments

**Table 18-7 shows how the TMS 9940 interprets its 512 available bit addresses.**

Table 18-7. TMS 9940 CRU Bit Address Assignments

| CRU Address | Read Function                                                                                                             | Write Function                                                                                      |
|-------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| 000 to 0FF  | { External CRU bits; the address is output via A1-A8. Data is transferred via CRUIN, CRUOUT and CRUCLK                    |                                                                                                     |
| 100 to 17F  | { Unused                                                                                                                  | Unused                                                                                              |
| 180         | INT1 state                                                                                                                | Unused                                                                                              |
| 181         | Decrementer interrupt level                                                                                               | Clear decrementer interrupt                                                                         |
| 182         | INT2 state                                                                                                                | Unused                                                                                              |
| 183         | Unused                                                                                                                    | Configuration bit 0 (CB0)                                                                           |
| 184         | Unused                                                                                                                    | Configuration bit 1 (CB1)                                                                           |
| 185         | Unused                                                                                                                    | Configuration bit 2 (CB2)                                                                           |
| 186         | Unused                                                                                                                    | Configuration bit 3 (CB3)                                                                           |
| 190 to 19D  | { Decrementer register. 190 is the least significant bit and 19D is the most significant bit                              |                                                                                                     |
| 19E         | Unused                                                                                                                    | Timer (high) or Counter (low) select                                                                |
| 19F         | Unused                                                                                                                    | Unused                                                                                              |
| 1A0 to 1AF  | { Multiprocessor System Interface buffer register<br>1A0 is the least significant bit and 1AF is the most significant bit |                                                                                                     |
| 1B0 to 1BF  | { General purpose flag bits                                                                                               |                                                                                                     |
| 1C0 to 1DF  | { Unused                                                                                                                  | Identify direction for P0 (via 1C0) through P31 (via 1DF).<br>1 specifies output. 0 specifies input |
| 1E0 to 1FF  | { Local CRU pins (P0 = 1E0, P31 = 1FF                                                                                     |                                                                                                     |

The place to begin looking at Table 18-7 is at CRU bits 183, 184, 185, and 186. These four CRU bits represent write-only locations which determine how the 32 CRU pins illustrated in Figure 18-21 will be used.

**TMS 9940  
CRU BIT  
UTILIZATION**

If you look again at Figure 18-21, you will see that P0 through P17 have shared functions. P18 through P31 are simple I/O pins without other programmable options.

**CRU addresses 183, 184, 185 and 186 control the functions of P0 through P16, as illustrated in Table 18-8. P17 options depend on real-time clock logic, which we will describe later.**

**Let us look at the programmable options available with CRU pins P0 through P31.**

It does not matter what options you have selected; **you will actually access the 32 CRU pins P0 - P31 via CRU addresses 1E0<sub>16</sub> through 1FF<sub>16</sub>.**

**In the simplest case, all 32 pins, P0 - P31, will be used for input or output. We call this Simple I/O mode.** In order to use all 32 pins for data input or output. (that is, in Simple I/O mode), all four of the configuration bits, CB0, CB1, CB2, and CB3, must be 0. At any time, a CRU bit can either input data or output data, but it cannot be used for bidirectional data transfer. **You must identify the direction for each pin by outputting appropriate data to CRU addresses 1C0<sub>16</sub> through 1DF<sub>16</sub>.** As shown in Table 18-7, each pin has a dedicated CRU address, beginning with pin P0 controlled by

**TMS 9940  
SIMPLE  
CRU I/O  
MODE**

1C0<sub>16</sub> and ending with pin P31 controlled by CRU address 1DF16. A 1 written to any Direction CRU bit causes the associated pin to output data only. A 0 written to any CRU Direction bit causes the associated pin to input data only. Of course, you can at any time change a pin from input to output or from output to input, under program control, by rewriting control information to Direction CRU bits 1C0<sub>16</sub> through 1DF16.

Table 18-8. TMS 9940 CRU Bits Whose Functions are Determined Under Program Control

| CRU |         |       | Function as Configured |         |               |
|-----|---------|-------|------------------------|---------|---------------|
| Bit | Address | Pin   | CB0 = 0                | CB0 = 1 | CB1, CB2, CB3 |
| 0-7 | 1E0-1E7 | 23-30 | P0-P7                  | A1-A8   | No Effect     |
| 8   | 1E8     | 18    | P8                     | CRUIN   | No Effect     |
| 9   | 1E9     | 17    | P9                     | CRUOUT  | No Effect     |
| 10  | 1EA     | 16    | P10                    | CRUCLK  | No Effect     |
|     |         |       | CB1 = 0                | CB1 = 1 | CB0, CB2, CB3 |
| 11  | 1EB     | 14    | P11                    | TC      | No Effect     |
| 12  | 1EC     | 11    | P12                    | TD      | No Effect     |
|     |         |       | CB2 = 0                | CB2 = 1 | CB0, CB1, CB3 |
| 13  | 1ED     | 15    | P13                    | φ       | No Effect     |
|     |         |       | CB3 = 0                | CB3 = 1 | CB0, CB1, CB2 |
| 14  | 1EE     | 10    | P14                    | HLD     | No Effect     |
| 15  | 1EF     | 9     | P15                    | HLDA    | No Effect     |
| 16  | 1F0     | 8     | P16                    | IDLE    | No Effect     |

You will always have to define the direction of data transfer for pins P18 through P31 — assuming that you are using these pins. When pins P0 through P17 are being used in any of the special ways which we are about to describe, then the data direction associated with the special operation will apply, and it makes no difference what you output to the associated Direction CRU bit.

If you wish to use 256 external CRU bits, then you must set CRU bit 183 (CB0) to 1. This is called I/O expansion mode. I/O expansion mode modifies the functions of pins P0 through P10. When you use CRU addresses 00 through FF<sub>16</sub> in I/O expansion mode, the address is output via pins P0 - P7, which now function as CRU address lines A1 - A8. P8, P9, and P10 serve as the standard CRU data transfer lines: CRUIN, CRUOUT, and CRUCLK. Timing for data input and output via these three lines has been described for the TMS 9900. Refer to the TMS 9900 description for details. In order to illustrate the use of external CRU, consider execution of the instructions:

TMS 9940  
CRU I/O  
EXPANSION  
MODE

|             |                                         |
|-------------|-----------------------------------------|
| LI R3,>00   | LOAD 1010 BINARY INTO UPPER BYTE OF R3  |
| LI R12,>140 | LOAD A BASE ADDRESS OF 82 HEX INTO R12  |
| LDCR R3,4   | OUTPUT FOUR LOW-ORDER BITS OF R3 TO CRU |

Note that R12 contains 0140<sub>16</sub> to represent the address 082<sub>16</sub>, since R12 bit 0 is unused; therefore the internal address is, in effect, doubled.

This instruction outputs 1010 to CRU bit 082<sub>16</sub> (0), 083<sub>16</sub> (1), 084<sub>16</sub> (0), and 085<sub>16</sub> (1). Since fewer than eight bits will be transferred, they will come from the upper byte of the general purpose register. This is the event sequence which occurs:

- 1) The address 82<sub>16</sub> is output via A1 - A8. Remember, Texas Instruments' literature uses 0 to represent the high-order bit; therefore A1 represents the high-order address bit, and A8 represents the low-order address bit. CRUIN is inactive, but CRUOUT is low to represent 0 while CRUCLK is pulsed high to time the 0 bit on CRUOUT.

- 2) The address output on A1 - A8 increments to  $83_{16}$ , and CRUOUT goes high, then CRUCLK pulses high.
- 3) The address on A1 - A8 increments to  $84_{16}$ , CRUOUT goes low again, and CRUCLK pulses high.
- 4) The address on A1 - A8 increments to  $85_{16}$ , and CRUOUT goes high, and CRUCLK pulses high.

1010 has now been transmitted to four external CRU bits.

Note that it is up to external logic to decode the CRU address output; however, the Parallel System interface (which we will describe in later editions) will connect directly to the TMS 9940 Address and CRU outputs that we have just described.

**When you write 1 to CRU bit 18416 (CB1), pins P11 and P12 function as serial data transfer pins. The purpose of this logic is to allow the TMS 9940 to operate in multi-CPU configurations.** This logic is very simple. You output data by writing the data to CRU bits 1AO<sub>16</sub> through 1AF<sub>16</sub>. This data is immediately transmitted via TD (P12) as a serial data stream which is clocked by TC (P11). In keeping with normal bit sequence protocol, data is transmitted low-order bit first. Thus, 16 bits of data being output may be illustrated as follows:

**TMS 9940  
MULTIPROCESSOR  
SYSTEM  
INTERFACE**



When a TMS 9940 has a 1 written to CB1, it can also receive data via TD. Data input is again clocked by TC. Input logic is the reverse of the output logic illustrated above; that is say, as a data stream is input, the first input bit is loaded into CRU bit 1AF<sub>16</sub>, and the sixteenth input bit is loaded into CRU bit 1AO<sub>16</sub>.

**TMS 9940 multiprocessor system interface logic is used to transfer data from a memory location in one TMS 9940 to a memory location in another TMS 9940. You will not normally use this logic to transfer data between a TMS 9940 and external logic; the CRU serves that purpose better. There are three reasons why you may want to use the TMS 9940 multiprocessor system interface; they are:**

- 1) **To transmit status information.** For example, one TMS 9940 could tell another how far it has progressed through various phases of a task by transmitting a status word whose bits have some predefined interpretation.
- 2) **To transmit data.** One TMS 9940 may generate data which another TMS 9940 needs in order to execute its programs.
- 3) **To transmit instruction sequences.** Instructions could be transmitted from the read-only memory (or the read/write memory) of one TMS 9940 to the read/write memory of another TMS 9940. The receiving TMS 9940 could then execute the instruction sequence out of its read/write memory.



Figure 18-22. Handshaking Logic in a TMS 9940 Multi-Microcomputer Network Communicating via the TD Data Line

You could use the CRU to perform any of the three data transfers described above, but the multiprocessor system interface is somewhat easier to use. We say that data transfer via the multiprocessor system interface is "somewhat" easier to use because many problems still remain when you use the multiprocessor system interface. These problems arise from the fact that **there is absolutely no handshaking protocol associated with the multiprocessor system interface**. For example, there is absolutely no protection against two TMS 9940s simultaneously trying to output data via TD and TC. There is no predefined protocol whereby a transmitting TMS 9940 identifies the receiving TMS 9940 or the instant data has been transmitted and should be read. Any protocol is your responsibility — to be provided by logic external to the TMS 9940s. Fortunately, **this protocol is easy to implement. Figure 18-22 shows how eight TMS 9940s can communicate with each other, such that each TMS 9940 may transmit data to, or receive data from, any other TMS 9940.** The logic illustrated in Figure 18-22 is more complex than the logic you would need for a small system — for example, a two-microcomputer system, or a system where there are dedicated transmitters and receivers.

While Figure 18-22 shows TMS 9940s communicating with each other, you will in fact use TMS 9940s just as frequently with other microprocessors — such as a TMS 9900. Nevertheless, the concepts embodied in Figure 18-22 would apply, from the viewpoint of the TMS 9940, in any other configuration.

#### Let us look at how the logic in Figure 18-22 works.

The first problem we must resolve is the problem of transmission contentions. How will we make sure that one TMS 9940 does not try to transmit data while another TMS 9940 is already transmitting data? A simple scheme would be to set aside a particular CRU pin to serve as a "Busy" line. For example, every TMS 9940 could use P31 as a "Busy" output pin and P30 as a "Sense" input pin. We could wire-OR together all P31 Busy outputs and input this wire-OR to all P30 Sense inputs. Now any TMS 9940 that wishes to transmit data will read its P30 CRU bit. If this bit is 0, then it will output 1 to P31. Outputting 1 to P31 causes all other TMS 9940s to receive 1 at their P30 inputs. Thus, no other TMS 9940 will begin transmitting data if another TMS 9940 was in the process of transmitting data. This logic may be illustrated as follows:



The problem with the logic illustrated above is that two TMS 9940s could simultaneously read P30, find it was 0, output 1 to P31, then output competing data on TD. While the chances of two microcomputers executing identical instructions at exactly the same time are very small, a well-designed microcomputer system must account for every potential error. In Figure 18-22 we resolve our problem by using a 74148 8-to-3 decoder. The P31 output from every TMS 9940 is connected to a different 74148 input. The 74148 outputs, via O0, O1, and O2, the line number for the highest priority active input. This three-line output is connected to the P28, P29, and P30 pins of every TMS 9940; we assume that these three pins are inputs at every TMS 9940. Now every TMS 9940 that wishes to transmit data via TD must output a 1 to P31. It must then input the contents of P30, P29, and P28. Upon detecting its own ID on these three inputs, it begins data transmission. If a TMS 9940 outputs 1 via P31 and then reads in some other ID via P30, P29, and P28, then it must wait. Here is an appropriate instruction sequence:

|      |      |          |                                            |
|------|------|----------|--------------------------------------------|
|      | LI   | R12,>3F8 | LOAD P28 ADDRESS, X2, INTO R12             |
|      | SBO  | 3        | SET P31 ON                                 |
| LOOP | STCR | R2.3     | INPUT P28, P29, AND P30                    |
|      | CI   | R2.ID    | COMPARE INPUT WITH DEVICE ID               |
|      | JNE  | LOOP     | RETURN AND RE-ENTER CODE IF NOT CORRECT ID |
|      | LI   | R12,>340 | LOAD MPSI OUTPUT DATA BASE ADDRESS X2      |
|      | LDCR | R3.16    | OUTPUT CONTENTS OF R3 VIA TD               |

Assuming that a TMS 9940 has output 1 to P31 and has received back its own ID via P28, P29, and P30, the TMS 9940 is ready to transmit data. However, in addition to simply transmitting the data, the TMS 9940 must tell the intended recipient that the data has been transmitted. In Figure 18-22 we use a 74138 3-to-8 demultiplexer for this purpose. Pins P25, P26, and P27 of every TMS 9940 are outputs that connect to the I<sub>0</sub>, I<sub>1</sub>, and I<sub>2</sub> inputs of the 74138. The transmitting TMS 9940 outputs data which will be received by every other TMS 9940; however, the transmitting TMS 9940 follows up by outputting a 3-bit code via P25, P26, and P27; this 3-bit code identifies the intended recipient. The 3-bit code is input to the 74138, which generates one of eight possible outputs. These eight outputs become external interrupt request inputs to the eight TMS 9940s. Only the single TMS 9940 will receive the data which was transmitted by the eighth TMS 9940, only one TMS 9940 will receive an interrupt request signal; this is the TMS 9940 for which the transmitted data was intended. The TMS 9940 which receives data simply executes an STRCR instruction to move the data from CRU bits 1A0<sub>16</sub> through 1AF<sub>16</sub> to the appropriate general purpose register.

**CRU bit 18516, the CB2 bit, serves the very limited purpose of outputting a synchronizing signal. When you output 1 to CB2, P13 ceases to be an I/O pin and instead outputs the internal TMS 9940 clock signal.**

TMS 9940  
SYNC MODE

**CRU bit 18616 (CB3) controls idle and hold logic for the TMS 9940.** When you write a 1 to CRU bit 18616, pins P14 and P15 act as hold request input (HLD) and hold acknowledge output (HLDA) signals, respectively. P16 generates an IDLE output.

**The Hold request/acknowledge logic of the TMS 9940 is quite standard.** The purpose of this logic is to remove the TMS 9940 from any shared busses when some other microprocessor or microcomputer is bus master. If CB3 is 1, then a low signal arriving at the TMS 9940 HLD input will cause the TMS 9940 to enter a Hold state at the conclusion of the current instruction's execution. A low HLDA output marks the beginning of the Hold state.

TMS 9940  
HOLD LOGIC

**The IDLE signal is output low when an IDLE instruction is executed and CB3 is 1.** The only way in which you can terminate an Idle state is by requesting an interrupt via INT1 or INT2. The TMS 9940 three-state signals are not floated in the Idle state. You must additionally enter the Hold state for this.

TMS 9940  
IDLE LOGIC

**The purpose of the IDLE instruction and signal is to enable standby power logic.** This may be illustrated as follows:



Under normal circumstances, the power supply will input power to V<sub>CC</sub><sup>1</sup> and V<sub>CC</sub><sup>2</sup>. When IDLE goes low, the power input to V<sub>CC</sub><sup>2</sup> is switched off. While V<sub>CC</sub><sup>1</sup> only is receiving power, the TMS 9940 read/write memory and interrupt logic is active, but all other logic is inactive. Since the interrupt logic is active, any arriving interrupt request will be acknowledged. The process of acknowledging an interrupt request sets IDLE high again. This closes the switch and restores power to V<sub>CC</sub><sup>2</sup>, which allows the TMS 9940 to resume normal execution.

In the illustration above, note that IDLE is connected to HLD.

## TMS 9940 GENERAL PURPOSE FLAGS

If you look again at Table 18-7, you will see that CRU addresses 1B0<sub>16</sub> through 1BF<sub>16</sub> address 16 general purpose flags. These general purpose flags have no special hardware functions. They are programming aids and that is all. You can write data out to these flags, and you can read back the data. How you use this data is entirely up to program logic.

## TMS 9940 TIMER/EVENT COUNTER LOGIC

The TMS 9940 has a timer which can also be used as an event counter. CRU bit 19E<sub>16</sub> determines whether this logic will function as a timer or as an event counter. If CRU bit 19E<sub>16</sub> is high, then this logic serves as a Timer. If CRU bit 19E<sub>16</sub> is low, then this logic serves as an event counter.

Timer and Event Counter logic both use CRU bits 190<sub>16</sub> through 19D<sub>16</sub> as a 14-bit register whose contents are decremented by Timer or Event Counter logic. This 14-bit register is buffered. That is to say, the initial value which you output to CRU bits 190<sub>16</sub> through 19D<sub>16</sub> is stored in a buffer, in addition to being loaded into CRU bits 190<sub>16</sub> through 19D<sub>16</sub>. Subsequently, CRU bits 190<sub>16</sub> through 19D<sub>16</sub> are decremented, but the buffer contents remain unaltered. When CRU bits 190<sub>16</sub> through 19D<sub>16</sub> decrement to 0, they are reloaded from the buffer. Thus Timer/Event Counter logic runs continuously. An interrupt request is generated internally when CRU bits 190<sub>16</sub> through 19D<sub>16</sub> decrement to 0.

Remember, CRU bit 190<sub>16</sub> is the low-order bit, and CRU 19D<sub>16</sub> is the high-order bit. This is the reverse of normal Texas Instruments bit numbering, where the high-order bit has the lowest bit number. However, this is consistent with the fact that Texas Instruments outputs data to the CRU low-order bit first, and addresses CRU bits in numerically ascending address sequence.

When you write 0 to CRU bits 190<sub>16</sub> through 19D<sub>16</sub>, you disable Timer/Event Counter logic.

**When the Timer/Event Counter is operating as a timer, the 14-bit register represented by CRU bits 190<sub>16</sub> through 19D<sub>16</sub> are decremented once every 30 internal clock oscillations.** The crystal connected across XTAL1 and XTAL2 determines clock oscillation frequency. When CRU bits 190<sub>16</sub> through 19D<sub>16</sub> time out to zero, an interrupt request is generated.

**When Timer/Event Counter logic is operating as an event counter, pin P17 serves as an input, receiving the event sequence to be counted.** Every low-to-high transition of the signal input at P17 decrements the counter. Once again, when the counter counts out to 0, an interrupt request occurs and the counter is reloaded from its buffer register.

## TMS 9940 INTERRUPT LOGIC

The TMS 9940 has four external interrupts and twelve internal software interrupts.

These are the four external interrupts:

- 1) Reset. This has highest priority.
- 2) A level 1 interrupt occurring at the INT1 pin. This has second highest priority.
- 3) A Decrementer/Event Counter interrupt. This has third highest priority.
- 4) A level 2 interrupt occurring at the INT2 pin. This has lowest priority.

As described for the TMS 9900, you execute XOP instructions to generate software interrupts. XOP4 through XOP15 are active. XOP0 through XOP3 do not exist on the TMS 9940.

TMS 9940 interrupt vectors, together with a complete TMS 9940 memory map, are illustrated in Figure 18-20.

The actual interrupt acknowledge sequence for a TMS 9940 is identical to that which we have described for the TMS 9900.

## TMS 9940 RESET

You Reset the TMS 9940 by inputting a low signal at RST/PE (pin 20). This low signal must last for at least five clock cycles. A Reset resets to 0 the contents of all pointer registers and all CRU configuration bits. Following a Reset, level 0 interrupt response begins — which means that read-only memory bytes 0 through 3 provide the initial Program Counter and Word Pointer register contents, and therefore the address of the program which will be executed following the Reset.

Note that the TMS 9940, being a smaller and simpler system than the TMS 9900, can use elementary logic to generate an interrupt acknowledge. For the TMS 9900 we suggested an Address Bus decoding technique in order to create an interrupt acknowledge signal. For the TMS 9940 a CRU bit will do just fine. The following circuit is recommended by Texas Instruments:



A simple D-type flip-flop has its D input connected to +5V. Every time an interrupt request pulse is input to the clock pin, the Q output will go low — generating a valid interrupt request at the TMS 9940. In order to acknowledge the interrupt and remove the interrupt request signal, you can output a low pulse via any of the P pins. This low pulse clears the D-type flip-flop and forces Q high again.

## **PROGRAMMING A TMS 9940E ERASABLE, PROGRAMMABLE READ-ONLY MEMORY**

The TMS 9940E has a transparent quartz lid over the device in its dual in-line package. **In order to erase the TMS 9940E EPROM, you should expose it to a high-intensity ultraviolet light with a wavelength of 2537 angstroms.** An intensity of 10 watt-seconds per square centimeter is recommended.

After the TMS 9940E EPROM has been erased, all EPROM memory bits will be 0.

**These are the steps required in order to program a TMS 9940E EPROM:**

- 1) Reset the device.
- 2) Apply the first data byte — to be stored in memory location 0000 to pins P24 through P31. Remember, P24 represents the most significant bit of the byte, and P31 represents the least significant bit of the byte.
- 3) Apply a 26-volt level to pin 20, the RST/PE pin. This being the first programming pulse, it resets the internal program memory address point at 0000 and writes the data byte at P24 through P31 into memory location 0.
- 4) After at least 80 clock cycles, apply 26 volts to pin 37, INT2/PROG, for 50 milliseconds while changing the data byte (step 5).
- 5) Apply the next data byte to P24 through P31. At the high-to-low transition of PROG, the data will be written into the next location.
- 6) Remove the 26 volts from pin 37 for a minimum of 50 clock cycles. Then apply 26V to pin 37 for 50 milliseconds.
- 7) Return to Step 5 until all of program memory has been programmed.

## **LOADING A PROGRAM INTO TMS 9940 READ/WRITE MEMORY**

You can load a program directly into TMS 9940 read/write memory via pins P24 (MSB) through P31 (LSB) for either the TMS 9940E or the TMS 9940M. Typically, this is done in order to load a small test program. The procedure for loading data into the TMS 9940 read/write memory is exactly as described in the previous section for loading data into EPROM; except: the 26-volt level is applied to pin 19, the TST pin, after the device has been reset by inputting a low signal to pin 20, the RST/PE pin; and the high pulses at PROG are logic '1' level rather than 26 volts.

When you input data to a TMS 9940 read/write memory using the TEST pin and P24 through P31, the address pointer is initialized to address 8300<sub>16</sub>. The address keeps incrementing the high-to-low transition of each 50 millisecond programming pulse applied at pin 37. When you finally stop applying programming pulses, the last 16 bits of data input are interpreted as the beginning address for the program to be executed. This address may point to a read/write memory location, or to a read/write memory location. That is to say, the test program may be in read/write memory, in read-only memory, or in both areas.

## **THE TMS 9940 INSTRUCTION SET**

**The TMS 9940 instruction set is identical to the TMS 9900 instruction set, with these exceptions:**

- 1) **The RSET, CKOF, CKON and LREX instructions have been deleted.** That is, all the external instructions except IDLE.

2) The XOP instructions will not work with operands 0, 1, 2, or 3.

3) There are new DCA and DCS instructions that enable 8-bit binary-coded decimal arithmetic.

Assuming that you start with two valid 8-bit binary-coded decimal operands, you can add these two 8-bit operands using normal binary addition. The result will be a meaningless 8-bit number; however, if you immediately execute the DCA instruction, this meaningless 8-bit number will be converted to a meaningful 8-bit, 2-BCD-digit number.

DCS, likewise, allows you to perform 8-bit binary-coded decimal subtraction. Assuming that the subtrahend and minuend are both valid 8-bit binary-coded decimal numbers, you perform a subtraction using binary arithmetic and you generate a meaningless 8-bit result. By executing the DCS instruction, you convert this meaningless 8-bit result into a valid 8-bit, 2-BCD-digit binary-coded decimal difference.

The DCA and DCS instructions both generate in the low-order eight bits of the 16-bit word.

For a discussion of decimal adjust logic in BCD addition or subtraction, see Volume 1, Chapter 3.

**The LIIM instruction loads a 2-bit interrupt mask into the two low-order bits of the Status register.**

Here are the instruction object codes used by the DCA, DCS, and LIIM instructions:

| Instruction | Object Code      | Bytes | Clock Periods |
|-------------|------------------|-------|---------------|
| DCA r       | 0010110000bbssss | 2     | 7             |
| DCS r       | 0010110001bbssss | 2     | 7             |
| LIIM n      | 001011001xxxxxnn | 2     | 10            |

The object code notation above conforms to that which we have described for Table 18-3. For the LIIM instruction, x represents "don't care" bits and n represents the two binary digits that get loaded into the two low-order Status register bits.

## THE TIM 9904 FOUR-PHASE CLOCK GENERATOR/DRIVER

This part is also given the generic TTL name: the SN74LS362. The TIM 9904 provides TMS 9900 microprocessors with the four clock signals:  $\Phi_1$ ,  $\Phi_2$ ,  $\Phi_3$ , and  $\Phi_4$ . These are +12V MOS driver signals. In addition, four complementary +5V clock signals,  $\bar{\Phi}_1$ ,  $\bar{\Phi}_2$ ,  $\bar{\Phi}_3$ , and  $\bar{\Phi}_4$ , are generated for use elsewhere in a TMS 9900 microcomputer system.

**The TIM 9904 device may be driven by an external crystal, an external LC circuit, or a single external clock signal.**

The TIM 9904 is manufactured using low-power Schottky technology; hence the 74LS part number. It is packaged as a 20-pin DIP. All signals, other than the four MOS level clocks, are TTL-compatible.

The TIM 9904 allows one asynchronous input signal to be synchronized, via a D flip-flop, with the  $\Phi_3$  signal. The synchronized signal is output, frequently to be used as a ~~RESET~~ input to the TMS 9900.

Figure 18-23 illustrates TIM 9904 pins and signal assignments.

**The four clock signals,  $\Phi_1$ ,  $\Phi_2$ ,  $\Phi_3$ , and  $\Phi_4$ , conform to Figure 18-3.  $\Phi_1$ ,  $\Phi_2$ ,  $\Phi_3$ , and  $\Phi_4$  are complements of  $\bar{\Phi}_1$ ,  $\bar{\Phi}_2$ ,  $\bar{\Phi}_3$ , and  $\bar{\Phi}_4$ .**

**A logic level input at D will be output at Q on the high-to-low transition of  $\Phi_3$ :**





| Pin Name                         | Description                      | Type   |
|----------------------------------|----------------------------------|--------|
| $\Phi_1, \Phi_2, \Phi_3, \Phi_4$ | + 12V clocks to drive a TMS 9900 | Output |
| $\Phi_1, \Phi_2, \Phi_3, \Phi_4$ | + 5V clock complements           | Output |
| D                                | Asynchronous control             | Input  |
| Q                                | Synchronized control             | Output |
| TANK1, TANK2                     | Crystal overtone controls        |        |
| XTAL1, XTAL2                     | External crystal connections     |        |
| OSCIN                            | External clock                   | Input  |
| OSCOUT                           | Clock with frequency $4\Phi$     | Output |
| VCC1, VCC2, GND1, GND2           | Power, Ground                    |        |

Figure 18-23. TIM 9904 Signals and Pin Assignments

**OSCOUT provides a clock frequency four times that of the  $\Phi$  clocks.** Its phase relationship to the  $\Phi$  clocks may be illustrated as follows:



When an external quartz crystal is used to drive the TIM 9904, the following connections are required:



OSCIN must be tied to a high logic level for the internal clock logic to work properly.

Required capacitor and inductance values are shown in the illustration above for a TMS 9900 microprocessor operating with its standard 3 MHz frequency. The crystal must have a resonant frequency of 48 MHz. For 48 MHz operation, a third overtone crystal is used.

For less precise timing, the quartz crystal may be replaced with a 0.1  $\mu$ F capacitor. The LC-tuned circuit now establishes the clock frequency according to the following equation:

$$f_{osc} = 1/(2\pi\sqrt{LC})$$

where L is the inductance, with units of Henries, and C is the capacitance with units of Farads. This includes the capacitance of the circuit into which the components are mounted.

If an external clock signal is input, it must occur at OSCIN. The crystal connections XTAL1 and XTAL2 should be connected to V<sub>CC</sub> as follows:



The clock input OSCIN must have a frequency which is four times the clock period frequency and has a 25% duty cycle. Thus, for a 3 MHz frequency, a 12 MHz signal must be input via OSCIN:



In TMS 9900 microcomputer systems, the D input is used for an asynchronous reset; Q is output as a synchronous reset. This may be illustrated as follows:



The illustration above shows recommended resistor and capacitor values.

## THE TMS 9901 PROGRAMMABLE SYSTEM INTERFACE (PSI)

The TMS 9901 Programmable System Interface (PSI) is a special support part designed for the TMS 9900 series of microprocessors. This relatively primitive device uses 32 bits of the TMS 9900 CRU bit field to support parallel I/O and interrupt request logic. Programmable timer logic is also available.

Figure 18-24 illustrates that part of general microcomputer system logic which has been implemented on the TMS 9901 PSI.

The TMS 9901 PSI is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL-compatible. The device is implemented using N-channel silicon gate MOS technology.



Figure 18-24. Logic of the TMS 9901 Programmable System Interface



| Pin Name     | Description                    | Type            |
|--------------|--------------------------------|-----------------|
| CRUIN        | CRU data output                | Output          |
| CRUOUT       | CRU data input                 | Input           |
| CRUCLK       | CRU data input strobe          | Input           |
| P0 - P15     | I/O data                       | Input or Output |
| INT1 - INT15 | External interrupt requests    | Input           |
| INTREQ       | Interrupt request to CPU       | Output          |
| IC0 - IC3    | Interrupt priority designation | Output          |
| CE           | Chip Enable                    | Input           |
| S0 - S4      | CRU bit select                 | Input           |
| RST1         | Chip reset                     | Input           |
| Φ            | Synchronizing clock signal     | Input           |
| VCC, VSS     | Power, Ground reference        |                 |

Figure 18-25. TMS 9901 Programmable System Interface Signals and Pin Assignments

In the illustration above, Address lines have been numbered using our standard notation, whereby A14 is the highest-order address line and A0 is the lowest-order address line. This is the opposite of Texas Instruments' notation. The CRU select lines are numbered according to Texas Instruments' notation and Figure 18-25. Therefore, S4 is connected to A0, and S0 is connected to A4.

## TMS 9901 PSI PINS AND SIGNALS

The TMS 9901 pins and signals are illustrated in Figure 18-25. The signals which connect the TMS 9901 to a TMS 9900 series microprocessor are quite straightforward; they consist of the CRU and interrupt signals.

The CRU signals include CRUIN, CRUOUT, and CRUCLK.

The interrupt signals consist of INTREQ, ICO, IC1, IC2, and IC3.

For a description of CRU and interrupt signals, refer back to our TMS 9900 discussion.

**Device select logic includes a chip enable input,  $\overline{CE}$ , together with five CRU bit select pins, S0 - S4.  $\overline{CE}$  and S0 - S4 will connect to the Address Bus as follows:**



In the illustration above, Address lines have been numbered using our standard notation, whereby A14 is the highest-order address line and A0 is the lowest-order address line. This is the opposite of Texas Instruments' notation. The CRU select lines are numbered according to Texas Instruments' notation and Figure 18-25. Therefore, S4 is connected to A0, and S0 is connected to A4.

Device select logic determines the CRU address space that will be reserved for the TMS 9901 PSI. This may be illustrated as follows:



The high-order three address lines, which we call A14, A13, and A12, are all zero during a CRU access, at which time MEMEN is inactive (high). Thus we decode address lines A11 through A5 to select a particular TMS 9901 device.

Since the TMS 9980 uses the Address Bus differently during a CRU operation, TMS 9901 device select logic would connect to the Address Bus in a different way. The CRU bit select lines S0 - S4 would be tied to lines A5 - A1; device select logic would decode lines A11 - A6; and lines A13 and A12, along with MEMEN, would indicate a CRU access. We illustrate this as follows:



$\Phi$  is a synchronizing clock signal used to time data output and to sample interrupts.  $\bar{\Phi}_3$  is the complement of  $\Phi_3$ . For the TMS 9900,  $\bar{\Phi}_3$  is generated by the TMS 9904. The TMS 9980 outputs  $\bar{\Phi}_3$  directly.

The best way of understanding the interface between a TMS 9901 and external logic is to look at functions performed, as illustrated in Figure 18-26.



Figure 18-26. TMS 9901 PSI General Data Flows and CRU Bit Assignments

From the programmer's viewpoint, a TMS 9901 looks like 32 contiguous CRU bits. Thus, you will access any part of a TMS 9901 device's logic using CRU input and output instructions.

**As you read through the TMS 9901 description that follows, you should bear in mind the power of multi-bit CRU load and store instructions as they apply to TMS 9901 architecture.** A single instruction transferring an appropriate bit pattern can frequently perform multiple control and data transfer operations.

**The manner in which CRU bits are used by the TMS 9901 is not straightforward. This is because CRU bits share functions and pins. Functions and pins are shared in different ways.**

Let us first look at pin connections. CRU bits 1-6 connect to pins INT1 - INT6; thus, in interrupt mode each of these CRU bits has its own dedicated input pin.

CRU bits 7-15 share nine input or output pins with CRU bits 23-31. CRU bits share pins as follows:



Each of the CRU bits shown above shares a pin with another CRU bit. That is to say, within the illustrated CRU address range, there are two CRU bits which will access the same pin, although each CRU bit performs a different operation. Thus you use the same pin in one of two different ways, using a bit address to select one operation. This may be illustrated as follows:



CRU bits 16-22 connect to parallel I/O pins. These bit addresses are not shared with any other TMS 9901 functions.

**CRU bit 0 is a select bit that is not connected to any pin.** A 1 written into this bit causes bits 1-15 to support real-time clock logic. A 0 written into CRU bit 0 selects interrupt logic. When CRU clock logic is selected, bits 1-14 function as two 14-bit real-time Clock Buffer registers — one a read-only register, the other write-only. Real-time clock logic is separate from, and operates simultaneously with, and/or parallel I/O logic. That is to say, the process of selecting real-time clock logic does not disable any other logic. The select bit merely chooses which registers CRU addresses will access, rather than enabling or disabling any operations.

## TMS 9901 PSI INTERRUPT LOGIC

**The easiest place to start understanding the TMS 9901 is at its interrupt logic.**

**External logic can input data to CRU bits 1-15 via their connected pins. These input data signals will be interpreted as interrupt requests if interrupts are enabled. If interrupts are disabled, then these CRU bits act simply as data input.**

**You access interrupt logic through the CRU when the select bit, CRU bit 0, contains a 0.**

CRU bit addresses 1-15 each access separate read-only and write-only locations. The read-only location stores the signal level input at the attached pin. The write-only location accesses an interrupt mask bit. This may be illustrated as follows:



Signals arriving at pins connected to CRU bits 1-15 are immediately reflected by CRU bit contents:



A low level (that is, a 0 bit) is interpreted as an interrupt request. The interrupt request is passed on to the mask bit. If the mask bit contains 1, the interrupt is enabled and the interrupt request is passed on:



If the mask bit is 0, the interrupt request is disabled and therefore denied:



Quite apart from interrupt logic, the CPU can at any time read the contents of one or more CRU bits in the address range 1-15. Here are some instructions that may access CRU bits 1-15 in various ways:

|      |           |                                           |
|------|-----------|-------------------------------------------|
| LI   | R12,PSI+1 | LOAD CRU BASE ADDRESS INTO R12            |
| LI   | R1,MASK   | LOAD INTERRUPT MASK BITS INTO R1          |
| LDCR | R1,15     | OUTPUT TO WRITE-ONLY MASK LOCATIONS       |
| -    |           |                                           |
| STCR | R2,15     | INPUT CRU BITS 1 THROUGH 15 AS DATA TO R2 |
| -    |           |                                           |

For some randomly selected data levels, CRU bits 1-15 may be illustrated as follows:



If one or more CRU bit's interrupt requests are low, and the corresponding mask bit is 1, then interrupt priority encoder logic outputs INTREQ low. Simultaneously, the level of the active interrupt request which has highest priority is identified via IC0 - IC3.

- INT1, input to CRU bit 1, has highest priority;
- INT15, input to CRU bit 15, has lowest priority.

The levels at IC0 - IC3 are maintained until the interrupt request signal is removed at the external pin, or the interrupt mask bit for the level is reset to 0.

## TMS 9901 PSI DATA INPUT AND OUTPUT

You can use CRU I/O instructions to input, output, or test external data at CRU bits 16-31. Data is output from the CPU to the TMS 9901 via CRUOUT; it is input from the TMS 9901 to the CPU via CRUIN. Bits are addressed via S0 - S4, as we have already described.

**Following a reset, pins connected to CRU bits 16-31 are in input mode.** In this mode, external logic can assert high or low levels at connected pins, in which case one or two CRU bits will be affected: a signal input to P0 - P6 will generate data in CRU bits 16-22; if interrupt mode is selected (by a 0 in CRU bit 0), a signal input to INT7/P15-INT15/P7 will

generate data in two CRU bits, one in the CRU bit range 7-15, the other in CRU bit range 31-23. In interrupt mode, if the CPU inputs data from CRU bits 7-15 or 31-23, then it will input the same data, but in reverse order. This may be illustrated as follows:



Note that, as in all CRU transfers, the first CRU bit transferred goes to the least significant bit position of the destination register.

**As soon as the CPU outputs data to any bit capable of supporting data output, the I/O logic associated with this bit is put into output mode.** In this mode, a pin will output a voltage level reflecting data in the corresponding CRU bit. External logic cannot input data to a CRU bit that is in output mode; in fact, driving input currents into an output pin may damage the TMS 9901.

**Once a CRU bit has been placed in output mode, it remains in output mode until the TMS 9901 is reset.** That is to say, you cannot selectively return CRU bits from output mode to input mode. However, you can always read output bits back to the CPU; that is, **although external logic must never attempt to input to a pin that is in output mode, the CPU can always read the contents of any I/O bit, whether it is an input or an output.**

You cannot output data via CRU bits 7-15, even though these bits are connected to the same pins as CRU bits 31-23. When you output data to CRU bits 7-15, the data is routed to one of two write-only locations, depending on the contents of CRU bit 0: if the select bit is 0, the data goes to interrupt mask bits 7-15; if clock mode is selected (CRU bit 0 contains 1), the data goes to the Clock Load Buffer register (bits 7-14) and RST2 (bit 15).

In interrupt mode you can input external data from CRU bits 1-6. Once again, you cannot output data via these CRU bit addresses, since any data output will be routed to corresponding interrupt mask bits or Clock Load Buffer bits.

## TMS 9901 REAL-TIME CLOCK LOGIC

If you write a 1 into CRU bit 0 of a TMS 9901 device, then CRU bits 1-14 are used as two 14-bit Clock buffers, which may be illustrated as follows:



Besides these two buffers, **real-time Clock logic contains a decrementing register which we call the Clock Counter register**. The CPU loads the Clock Counter register via the Clock Load Buffer, and reads the Counter contents via the Clock Read Buffer. We illustrate this in the following way:



The Clock Counter register decrements continuously as long as the TMS 9901 is powered up. This will cause no problems as long as the clock interrupt is disabled.

When you write any non-zero value into the Clock Load Buffer (CRU bits 1-14), the Clock Counter register starts decrementing from that value. A decrement occurs once every  $64 \Phi$  clock pulses. Thus, with a 3 MHz clock, a decrement occurs once every 21.3 microseconds. When the CRU Clock Counter register decrements to 0, an interrupt request is generated, the previously output starting value is reloaded, and the clock starts to decrement again. Thus, with a 21.3-microsecond time interval between decrements, the maximum time interval between interrupt requests will be 249 milliseconds.

An enabled clock interrupt request causes INTREQ to be output low, together with a level 3 interrupt identified via IC0 - IC3. That is to say, the INT3 external interrupt and the Clock logic share the same interrupt level and interrupt mask bit. In clock mode, CRU bit 15 is used to record the state of the INTREQ signal. Thus, if interrupt requests are disabled, the CPU program can check for a time-out by testing the level at CRU bit 15. This bit will be low if no time-out has occurred, and it will be high if a time-out has occurred; thus this bit is the complement of INTREQ.

Following a CRU real-time clock interrupt request, you must write into interrupt mask bit 3 in order to clear the interrupt request. You can write a 0 or a 1 into the interrupt mask bit. Normally, you will write a 1 in order to keep interrupts enabled. Writing a 0 will clear any active real-time clock interrupt request, and will simultaneously disable further real-time clock interrupt requests.

The Clock Read Buffer register contents do not change as long as the TMS 9901 is in clock mode. This characteristic insures that the Clock Read Buffer will hold a stable value while the CPU is reading it — even though the Clock Counter may decrement during the read operation.

Either of the following two events will cause the Clock Counter contents to transfer to the Clock Read Buffer:

- The  $\bar{\Phi}$  pulse which causes the Clock Counter to decrement.
- An exit from clock mode.

**Thus, the Clock Read Buffer register is updated whenever the TMS 9901 leaves clock mode, and every time the Clock Counter decrements outside of clock mode.**

Beware — even if CRU bit 0 contains a 1, the TMS 9901 will exit clock mode for as long as it sees a 1 on select line S0; this will happen whether or not  $\bar{CE}$  is active. Thus the Clock Read Buffer will not hold the same value indefinitely just because the TMS 9901 select bit is set. The PSI will leave clock mode whenever the CPU reads to or writes from CRU bits 16-31, or if any device accesses a memory address with a 1 on the address line connected to S0 (A4 in a TMS 9900 system).

The logic controlling clock mode and the Clock Read Buffer may be illustrated as follows:



This logic summarizes our discussion above. There are two important things to note about clock mode and Clock Read Buffer update. First, you cannot inadvertently exit clock mode while you are reading the Clock Read Buffer, since you access it as CRU bits 1-14. Second, you cannot enter clock mode solely by accessing CRU bits 0-15; S0 changes clock mode only when the select bit is 1 (clock mode selected).

**In order to read the most recent Clock Counter value, you must do two things:**

- **Exit clock mode** so the Clock Read Buffer will receive the current Clock Counter contents.
- **Enter clock mode** so the Clock Read Buffer will be stable during the read itself.

Here is the appropriate instruction sequence:

|        |           |                                           |
|--------|-----------|-------------------------------------------|
| LI     | R12,PSI+1 | LOAD PSI CRU BASE ADDRESS                 |
| SBZ    | -1        | EXIT CLOCK MODE TO UPDATE READ BUFFER     |
| SBO    | -1        | ENTER CLOCK MODE TO STABILIZE READ BUFFER |
| \ STCR | R1,14     | READ 14-BIT CLOCK READ BUFFER             |

## TMS 9901 RESET LOGIC

You can reset a TMS 9901 in one of two ways:

- 1) **By inputting a low signal at RST1.**
- 2) **By using a programmed reset via RST2, a CRU bit.**

In order to use RST1, a low level must be input at this pin for at least two clock periods.

You can reset the TMS 9901 under program control only when clock mode is selected (CRU bit 0 is 0). At this time, writing a 0 to CRU bit 15 (RST2) causes the device to be reset. Thus, the following instruction sequence causes a TMS 9901 device reset:

|     |         |                           |
|-----|---------|---------------------------|
| LI  | R12,PSI | LOAD PSI CRU BASE ADDRESS |
| SBO | 0       | ENTER CLOCK MODE          |
| SBZ | 15      | RESET PSI                 |

When the TMS 9901 is reset, the INTREQ signal is output high. IC0 through IC3 are output low, all interrupt requests are disabled, and all I/O CRU bits are placed in input mode.

## **DATA SHEETS**

The following electrical specifications for the TMS 9900 and the TMS 9980A are out of date; we provide them here only to give a rough idea of timing and electrical requirements. Texas Instruments is revising its documentation on the TMS 9900 series parts. Revised data sheets will appear in updates to this volume and in the next edition.

## TMS 9900

### TMS 9900 ELECTRICAL AND MECHANICAL SPECIFICATIONS

#### ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)\*

|                                                   |           |                |
|---------------------------------------------------|-----------|----------------|
| Supply voltage, V <sub>CC</sub> (see Note 1)      | . . . . . | -0.3 to 20 V   |
| Supply voltage, V <sub>DD</sub> (see Note 1)      | . . . . . | -0.3 to 20 V   |
| Supply voltage, V <sub>SS</sub> (see Note 1)      | . . . . . | -0.3 to 20 V   |
| All input voltages (see Note 1)                   | . . . . . | -0.3 to 20 V   |
| Output voltage (with respect to V <sub>SS</sub> ) | . . . . . | -2 V to 7 V    |
| Continuous power dissipation                      | . . . . . | 1.2 W          |
| Operating free-air temperature range              | . . . . . | 0°C to 70°C    |
| Storage temperature range                         | . . . . . | -65°C to 150°C |

\*Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

NOTE 1: Under absolute maximum ratings voltage values are with respect to the most negative supply, V<sub>BB</sub> (substrate), unless otherwise noted. Throughout the remainder of this section, voltage values are with respect to V<sub>SS</sub>.

Data sheets on pages 18-D2 through 18-D8 are reproduced by permission of Texas Instruments, Incorporated.

## TMS 9900

## RECOMMENDED OPERATING CONDITIONS

|                                                               | MIN        | NOM | MAX        | UNIT               |
|---------------------------------------------------------------|------------|-----|------------|--------------------|
| Supply voltage, $V_{BB}$                                      | -5.25      | -5  | -4.75      | V                  |
| Supply voltage, $V_{CC}$                                      | 4.75       | 5   | 5.25       | V                  |
| Supply voltage, $V_{DD}$                                      | 11.4       | 12  | 12.6       | V                  |
| Supply voltage, $V_{SS}$                                      | 0          |     |            | V                  |
| High-level input voltage, $V_{IH}$ (all inputs except clocks) | 2.2        | 2.4 | $V_{CC}+1$ | V                  |
| High-level clock input voltage, $V_{IH(\phi)}$                | $V_{DD}-2$ |     | $V_{DD}$   | V                  |
| Low-level input voltage, $V_{IL}$ (all inputs except clocks)  | -1         | 0.4 | 0.8        | V                  |
| Low-level clock input voltage, $V_{IL(\phi)}$                 | -0.3       | 0.3 | 0.6        | V                  |
| Operating free-air temperature, $T_A$                         | 0          | 70  |            | $^{\circ}\text{C}$ |

ELECTRICAL CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS  
(UNLESS OTHERWISE NOTED)

| PARAMETER                                                      | TEST CONDITIONS                                                 | MIN | TYP†     | MAX       | UNIT          |
|----------------------------------------------------------------|-----------------------------------------------------------------|-----|----------|-----------|---------------|
| $I_I$ Input current                                            | $V_I = V_{SS}$ to $V_{CC}$                                      |     | $\pm 50$ | $\pm 100$ | $\mu\text{A}$ |
|                                                                | $V_I = V_{SS}$ to $V_{CC}$                                      |     | $\pm 50$ | $\pm 100$ |               |
|                                                                | $V_I = -0.3$ to $12.6$ V                                        |     | $\pm 25$ | $\pm 75$  |               |
|                                                                | $V_I = V_{SS}$ to $V_{CC}$                                      |     | $\pm 1$  | $\pm 10$  |               |
| $V_{OH}$ High-level output voltage                             | $I_O = -0.4$ mA                                                 | 2.4 | $V_{CC}$ |           | V             |
| $V_{OL}$ Low-level output voltage                              | $I_O = 3.2$ mA                                                  |     | 0.65     |           | V             |
|                                                                | $I_O = 2$ mA                                                    |     | 0.50     |           |               |
| $I_{BB}$ Supply current from $V_{BB}$                          |                                                                 | 0.1 | 1        |           | mA            |
| $I_{CC}$ Supply current from $V_{CC}$                          |                                                                 | 50  | 75       |           | mA            |
| $I_{DD}$ Supply current from $V_{DD}$                          |                                                                 | 25  | 45       |           | mA            |
| $C_i$ Input capacitance (any inputs except clock and data bus) | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 10  | 15       |           | pF            |
| $C_{i(\phi 1)}$ Clock-1 input capacitance                      | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 100 | 150      |           | pF            |
| $C_{i(\phi 2)}$ Clock-2 input capacitance                      | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 150 | 200      |           | pF            |
| $C_{i(\phi 3)}$ Clock-3 input capacitance                      | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 100 | 150      |           | pF            |
| $C_{i(\phi 4)}$ Clock-4 input capacitance                      | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 100 | 150      |           | pF            |
| $C_{DB}$ Data bus capacitance                                  | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 15  | 25       |           | pF            |
| $C_o$ Output capacitance (any output except data bus)          | $V_{BB} = -5$ , $f = 1\text{MHz}$ , unmeasured pins at $V_{SS}$ | 10  | 15       |           | pF            |

† All typical values are at  $T_A = 25^{\circ}\text{C}$  and nominal voltages.

\* D.C. Component of Operating Clock

# TMS 9900

TIMING REQUIREMENTS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS  
(SEE FIGURES 12 AND 13)

| PARAMETER                                                                                    | MIN | NOM   | MAX | UNIT    |
|----------------------------------------------------------------------------------------------|-----|-------|-----|---------|
| $t_{cl}(\phi)$ Clock cycle time                                                              | 0.3 | 0.333 | 0.5 | $\mu s$ |
| $tr(\phi)$ Clock rise time                                                                   | 5   | 12    | 25  | ns      |
| $tf(\phi)$ Clock fall time                                                                   | 10  | 12    | 25  | ns      |
| $tw(\phi)$ Pulse width, any clock high                                                       | 40  | 45    | 100 | ns      |
| $t_{\phi 1L, \phi 2H}$ Delay time, clock 1 low to clock 2 high (time between clock pulses)   | 0   | 5     |     | ns      |
| $t_{\phi 2L, \phi 3H}$ Delay time, clock 2 low to clock 3 high (time between clock pulses)   | 0   | 5     |     | ns      |
| $t_{\phi 3L, \phi 4H}$ Delay time, clock 3 low to clock 4 high (time between clock pulses)   | 0   | 5     |     | ns      |
| $t_{\phi 4L, \phi 1H}$ Delay time, clock 4 low to clock 1 high (time between clock pulses)   | 0   | 5     |     | ns      |
| $t_{\phi 1H, \phi 2H}$ Delay time, clock 1 high to clock 2 high (time between leading edges) | 73  | 80    |     | ns      |
| $t_{\phi 2H, \phi 3H}$ Delay time, clock 2 high to clock 3 high (time between leading edges) | 73  | 80    |     | ns      |
| $t_{\phi 3H, \phi 4H}$ Delay time, clock 3 high to clock 4 high (time between leading edges) | 73  | 80    |     | ns      |
| $t_{\phi 4H, \phi 1H}$ Delay time, clock 4 high to clock 1 high (time between leading edges) | 73  | 80    |     | ns      |
| $t_{su}$ Data or control setup time before clock 1                                           | 30  |       |     | ns      |
| $t_h$ Data hold time after clock 1                                                           | 10  |       |     | ns      |

SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS  
(SEE FIGURE 13)

| PARAMETER                                                        | TEST CONDITIONS        | MIN | TYP | MAX | UNIT |
|------------------------------------------------------------------|------------------------|-----|-----|-----|------|
| $t_{PLH}$ or $t_{PHL}$ Propagation delay time, clocks to outputs | $C_L = 200 \text{ pF}$ | 20  | 40  |     | ns   |



NOTE: All timing and voltage levels shown on  $\phi 1$  applies to  $\phi 2$ ,  $\phi 3$ , and  $\phi 4$  in the same manner.

FIGURE 12 – CLOCK TIMING

## TMS 9900



<sup>†</sup>The number of cycles over which input/output data must/will remain valid can be determined from Section 3.9. Note that in all cases data should not change during  $\phi_1$ .

FIGURE 13—SIGNAL TIMING

# TMS 9980A

## TMS 9980A/TMS 9981 ELECTRICAL AND MECHANICAL SPECIFICATIONS

### ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)\*

|                                                           |       |                |
|-----------------------------------------------------------|-------|----------------|
| Supply voltage, V <sub>CC</sub> (see Note 1)              | ..... | -0.3 to 15 V   |
| Supply voltage, V <sub>DD</sub> (see Note 1)              | ..... | -0.3 to 15 V   |
| Supply voltage, V <sub>BB</sub> (see Note 1) (9980A only) | ..... | -5.25 to 0 V   |
| All input voltages (see Note 1)                           | ..... | -0.3 to 15 V   |
| Output voltage (see Note 1)                               | ..... | -2 V to 7 V    |
| Continuous power dissipation                              | ..... | 1.4 W          |
| Operating free-air temperature range                      | ..... | 0°C to 70°C    |
| Storage temperature range                                 | ..... | -55°C to 150°C |

\*Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

NOTE 1: Under absolute maximum ratings voltage values are with respect to V<sub>SS</sub>.

### 4.2 RECOMMENDED OPERATING CONDITIONS

|                                                |       | MIN   | NOM | MAX                | UNIT |
|------------------------------------------------|-------|-------|-----|--------------------|------|
| Supply voltage, V <sub>BB</sub> (9980A only)   | ..... | -5.25 | -5  | -4.75              | V    |
| Supply voltage, V <sub>CC</sub>                | ..... | 4.75  | 5   | 5.25               | V    |
| Supply voltage, V <sub>DD</sub>                | ..... | 11.4  | 12  | 12.6               | V    |
| Supply voltage, V <sub>SS</sub>                | ..... | 0     |     |                    | V    |
| High-level input voltage, V <sub>IH</sub>      | ..... | 2.2   | 2.4 | V <sub>CC</sub> +1 | V    |
| Low-level input voltage, V <sub>IL</sub>       | ..... | -1    | 0.4 | 0.8                | V    |
| Operating free-air temperature, T <sub>A</sub> | ..... | 0     | 20  | 70                 | °C   |

### 4.3 ELECTRICAL CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS (UNLESS OTHERWISE NOTED)

| PARAMETER       |                                                            | TEST CONDITIONS                                     | MIN | TYP* | MAX | UNIT |
|-----------------|------------------------------------------------------------|-----------------------------------------------------|-----|------|-----|------|
| I <sub>I</sub>  | Data bus during DBIN                                       | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> |     | ±75  |     | μA   |
|                 | WE, M <sub>E</sub> M <sub>E</sub> N, DBIN<br>during HOLD A | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> |     | ±75  |     |      |
|                 | Any other inputs                                           | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> |     | ±10  |     |      |
| V <sub>OH</sub> | High-level output voltage                                  | I <sub>O</sub> = -0.4 mA                            | 2.4 |      |     | V    |
| V <sub>OL</sub> | Low-level output voltage                                   | I <sub>O</sub> = 2 mA                               |     | 0.5  |     | V    |
|                 |                                                            | I <sub>O</sub> = 3.2 mA                             |     | 0.65 |     |      |
| I <sub>BB</sub> | Supply current from V <sub>BB</sub> (9980A Only)           |                                                     |     | 1    |     | mA   |
| I <sub>CC</sub> | Supply current from V <sub>CC</sub>                        | 0°C                                                 | 50  | 60   |     | mA   |
|                 |                                                            | 70°C                                                | 40  | 50   |     |      |
| I <sub>DD</sub> | Supply current from V <sub>DD</sub>                        | 0°C                                                 | 70  | 80   |     | mA   |
|                 |                                                            | 70°C                                                | 65  | 75   |     |      |
| C <sub>I</sub>  | Input capacitance (any inputs<br>except data bus)          | f = 1 MHz, unmeasured<br>pins at V <sub>SS</sub>    |     | 15   |     | pF   |
| C <sub>DB</sub> | Data bus capacitance                                       | f = 1 MHz, unmeasured<br>pins at V <sub>SS</sub>    |     | 25   |     | pF   |
| C <sub>O</sub>  | Output capacitance (any output<br>except data bus)         | f = 1 MHz, unmeasured<br>pins at V <sub>SS</sub>    |     | 15   |     | pF   |

\*All typical values are at T<sub>A</sub> = 25°C and nominal voltages.

**TMS 9980A****CLOCK CHARACTERISTICS**

The TMS 9980A and TMS 9981 have an internal 4-phase clock generator/driver. This is driven by an external TTL compatible signal to control the phase generation. In addition, the TMS 9981 provides an output (OSCOUT) that in conjunction with CKIN forms an on-chip crystal oscillator. This oscillator requires an external crystal and two capacitors as shown in Figure 13. The external signal or crystal must be 4 times the desired system frequency.



FIGURE 13 – CRYSTAL OSCILATOR CIRCUIT

**Internal Crystal Oscillator (9981 Only)**

The internal crystal oscillator is used as shown in Figure 13. The crystal should be a fundamental series resonant type. C<sub>1</sub> and C<sub>2</sub> represent the total capacitance on these pins including strays and parasitics.

| PARAMETER                       | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
|---------------------------------|-----------------|-----|-----|-----|------|
| Crystal frequency               | 0°C-70°C        | 6   | 10  | 10  | MHZ  |
| C <sub>1</sub> , C <sub>2</sub> | 0°C-70°C        | 10  | 15  | 25  | pF   |

**External Clock**

The external clock on the TMS 9980A and optional on the TMS 9981, uses the CKIN pin. In this mode the OSCOUT pin of the TMS 9981 must be left floating. The external clock source must conform to the following specifications.

| PARAMETER                                                     | MIN | TYP | MAX | UNIT |
|---------------------------------------------------------------|-----|-----|-----|------|
| f <sub>ext</sub> External source frequency*                   | 6   | 10  | 10  | MHZ  |
| V <sub>H</sub> External source high level                     | 2.2 |     |     | V    |
| V <sub>L</sub> External source low level                      |     |     | 0.8 | V    |
| T <sub>r</sub> /T <sub>f</sub> External source rise/fall time |     | 10  |     | ns   |
| T <sub>WH</sub> External source high level pulse width        | 40  |     |     | ns   |
| T <sub>WL</sub> External source low level pulse width         | 40  |     |     | ns   |

\*This allows a system speed of 1.5 MHz to 2 MHz.

# TMS 9980A

## SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS

The timing of all the inputs and outputs are controlled by the internal 4 phase clock; thus all timings are based on the width of one phase of the internal clock. This is  $1/f(\text{CKIN})$  (whether driven or from a crystal). This is also  $\frac{1}{4}f_{\text{system}}$ . In the following table this phase time is denoted  $t_w$ .

All external signals are with reference to  $\phi_3$  (see Figure 14).

| PARAMETER         | TEST CONDITIONS                                                                 | MIN         | TYP        | MAX         | UNIT |
|-------------------|---------------------------------------------------------------------------------|-------------|------------|-------------|------|
| $t_r(\phi_3)$     | $t_w = 1/f(\text{CKIN}) = \frac{1}{4}f_{\text{system}}$<br>$C_L = 200\text{pf}$ | 3           | 5          | 10          | ns   |
| $t_f(\phi_3)$     |                                                                                 | 5           | 7.5        | 15          | ns   |
| $t_w(\phi_3)$     |                                                                                 | $t_w - 15$  | $t_w - 10$ | $t_w + 10$  | ns   |
| $t_{su}$          |                                                                                 | $t_w - 30$  |            |             | ns   |
| $t_h$             |                                                                                 | $2t_w + 10$ |            |             | ns   |
| $t_{PHL(WE)}$     |                                                                                 | $t_w - 10$  | $t_w$      | $t_w + 20$  | ns   |
| $t_{PLH(WE)}$     |                                                                                 | $t_w$       | $t_w + 10$ | $t_w + 30$  | ns   |
| $t_{PHL(CRUCLK)}$ |                                                                                 | -20         | -10        | +10         | ns   |
| $t_{PLH(CRUCLK)}$ |                                                                                 | $2t_w - 10$ | $2t_w$     | $2t_w + 20$ | ns   |
| $t_{OV}$          |                                                                                 | $t_w - 50$  | $t_w - 30$ |             | ns   |
| $t_{OX}$          |                                                                                 | $t_w - 20$  | $t_w$      |             | ns   |

\*All inputs except ICO-IC2 must be synchronized to meet these requirements. ICO-IC2 may change asynchronously. See section 2.10.4.



FIGURE 14 – EXTERNAL SIGNAL TIMING DIAGRAM

## Chapter 19

# SINGLE CHIP NOVA MINICOMPUTER CENTRAL PROCESSING UNITS

In this chapter we are going to look at two microprocessors which are the world's first single chip reproductions of established 16-bit minicomputers. We are going to describe two products which reproduce, on a single chip, the logic of a Nova Central Processing Unit.

Nova minicomputers are built by Data General Corporation.

Data General Corporation offer a set of LSI chips centered on the MicroNova microprocessor. These chips are described quite superficially in this chapter since Data General is not actively marketing them as LSI devices. Rather, Data General favor the sale of MicroNova microcomputer systems.

Fairchild manufacture the 9440 microprocessor, which is sold primarily as an LSI device. The 9440 is therefore described in some detail, together with standard Nova I/O bus and typical memory bus interface bus logic.

The Nova minicomputer was designed as a next generation enhancement of the PDP-8. The IM6100, which we have described in Chapter 13, is a single chip implementation of the PDP-8 Central Processing Unit.

If you compare the Nova architectures, which we describe in this chapter, with the IM6100 described in Chapter 13, the two products will indeed look very different. But conceptually they are similar. Both the Nova and the PDP-8 Central Processing Units have few addressable registers; for computing power they rely upon instructions which may perform complex sequences of operations. Similarities between the Nova and the PDP-8 will become more apparent if you compare these two devices with the CP1600 and the TMS9900 — which we have described in Chapters 16 and 18, respectively.

What is interesting about the Nova minicomputer is that it is one of the most popular in the world; and Data General Corporation is the second largest minicomputer manufacturer in the world, despite the fact that many aspects of the Nova Central Processing Unit may, on first inspection, appear to be very restricting.

**The MicroNova is manufactured by:**

DATA GENERAL CORPORATION  
Mail Stop 6-58  
Southborough, MA 01772

**The 9440 is manufactured by:**

FAIRCHILD SEMICONDUCTOR  
464 Ellis Street  
Mountain View, CA 94040

**The MicroNova and the 9440 are not the same; differences, however, are small.**

**The MicroNova is equivalent to the Nova 3 minicomputer.** The Nova 3 is a low-end minicomputer recently introduced by Data General. Although it is a low-end product, it includes a number of features not found in the basic Nova architecture.

**The 9440 reproduces basic Nova architecture** — that is, the lowest common denominator of architectural features found in any Nova Central Processing Unit. As such, the 9440 lacks a number of logic features provided by the MicroNova. The 9440, however, has higher instruction execution speeds.

Because the MicroNova and the 9440 are very similar, we are going to describe them together in this chapter.

The MicroNova is manufactured using NMOS LSI technology. The 9440 is manufactured using Isoplanar integrated injection logic ( $I^3L$ ) technology.

Both products are packaged as 40-pin DIPs.

The MicroNova requires four power supplies: -4.25V, +5V, +10V and +14V. The 9440 requires two power supplies: +5V and +350 mA.

Using a 240 nanosecond clock, the MicroNova executes instructions in 2.4 to 10 microseconds. Using a 100 nanosecond clock, 9440 instructions will execute in 1 to 2.5 microseconds.

## A PRODUCT OVERVIEW

**Figure 19-1 illustrates that part of our general microcomputer system logic which has been implemented by the MicroNova and the 9440.**

**Note that only the MicroNova has a Stack Pointer, and DMA logic.**

Most Nova minicomputers do not have a Stack; the 9440 is a reproduction of the basic Nova architecture, which is why the 9440 lacks a Stack.

The MicroNova and Nova 3 do contain Stacks, because the addition of the Stack is technologically straightforward, while the lack of a Stack had been one of the most distressing features of earlier Nova minicomputers.

Both the 9440 and the MicroNova have DMA request and DMA acknowledge signals; however, in response to a DMA request, the 9440 does nothing except float the System Bus. It is up to you to provide any and all external logic needed to actually perform a data transfer via direct memory access. The MicroNova, on the other hand, executes the required sequence of I/O operations to actually perform the DMA transfer. That is why in Figure 19-1 DMA logic is shown as being present on the MicroNova but not the 9440.

**What about I/O ports? I/O ports interface logic is shown as absent in Figure 19-1. The I/O port is a microcomputer concept.**

In any microcomputer configuration, you will look upon I/O ports as the ultimate interface between the microcomputer system and external logic. You need a conduit via which data bits or signals can be transferred to, or received from logic beyond the microcomputer system. Each conduit becomes an I/O port and an I/O port becomes a set of pins, which can be addressed as a unit on a support device. Minicomputers take a conceptually different approach to I/O operations. To begin with, data is generally transferred to or from the CPU — not signals. The data finishes up on a System Bus. Therefore a minicomputer's interface with the outside world consists of an I/O System Bus and a memory System Bus. In some cases the two busses are one; in other cases, such as the Nova minicomputers, these two are separate and distinct busses. Conceptually, what is important is the fact that the minicomputer anticipates transferring data via its I/O System Bus to line printers, disk units, or other substantial devices each of which is capable of having a significant amount of local logic. Thus the System Bus is as far as the minicomputer attempts to go when defining its interface to the outside world.

**Figure 19-1, including bus interface logic within the logic of the Central Processing Unit, needs some clarification.** As we have just stated, the Nova minicomputer creates two separate System Busses: one for memory, the other for I/O devices. All the signals of these two busses originate at card edge pins. There is nothing very expensive about adding more pins to the edge of a card, as there is to adding more pins to a DIP. Therefore the Nova System Bus has 47 signals. Since neither the MicroNova nor the 9440 can have 47 signals, neither of these two devices creates standard Nova System Busses; but each device creates its own System Bus which could be used to drive external logic. That is why interface logic is shown as being present in Figure 19-1.



Figure 19-1. Logic of the Data General MicroNova and the Fairchild 9440

**There is one further major difference between the MicroNova and the 9440 which is not evident from Figure 19-1. The MicroNova provides transparent dynamic memory refresh logic. The 9440 has no dynamic memory refresh logic.**

**The MicroNova, but not the 9440, contains an elementary interval timer capability.** Providing interrupt timer logic is enabled, the MicroNova will generate an interrupt request every 20,000 instruction cycles. Using a standard 8.333 MHz clock, this translates to an interrupt request occurring every 2.4 msec.

Note that the MicroNova and the Nova 3 interval timer logic differ. The Nova 3 provides four programmable interval timer options; the MicroNova provides just one.

## NOVA PROGRAMMABLE REGISTERS

**These are the programmable registers of the MicroNova and the 9440:**



Data General literature numbers registers and memory words from left to right, rather than as illustrated above, from right to left. Also Data General is one of the few minicomputer manufacturers that uses octal numbering. In order to remain consistent with the rest of this book, we will use hexadecimal numbers, and we will number registers from right to left; where confusions may arise, we will show both our standard numbers and Data General equivalents.

**AC0 and AC1 are typical primary Accumulators. AC2 and AC3 may be used as Accumulators or as Index registers. The Jump-to-Subroutine instruction automatically stores the return address in AC3.** If one subroutine is going to call another (i.e., you are nesting subroutines), then the calling subroutine must save the contents of AC3 before itself calling another subroutine.

**Only the MicroNova has a Stack Pointer.** The only instructions that access the Stack Pointer are "Push" and "Pop" instructions.

**The MicroNova, but not the 9440, also contains a Frame Pointer register.** The Frame Pointer register is an address buffer used to access the Stack. This may be illustrated as follows:



The Frame Pointer is a buffer register; it is not a Data Counter. There are no instructions that access the memory location addressed by the Frame Pointer.

Observe that we show no programmable registers identified as Data Counters, even though in Figure 19-1 we show Data Counter logic as being present. This is because the Data Counter is another microcomputer concept — in effect, a subset of the Index register. If a memory reference instruction specifies direct, indexed addressing with a zero displacement, then Index Registers AC2 and AC3 are equivalent to Data Counters.

## NOVA MEMORY ADDRESSING MODES

Both the MicroNova and the 9440 offer the following standard Nova memory addressing modes:

- 1) Base page, direct addressing
- 2) Program relative, paged, direct addressing
- 3) Indirect addressing
- 4) Indirect addressing with auto-increment
- 5) Indirect addressing with auto-decrement
- 6) Direct, indexed addressing
- 7) Pre-indexed, indirect addressing

These addressing modes have been described in Volume 1, Chapter 6.

Nova memory addressing modes are heavily influenced by the fact that every Nova instruction generates a single 16-bit object code — just as the predecessor PDP-8 instructions each generated a single 12-bit object code. Even memory reference instructions are confined to 16 bits of object code; therefore the memory reference instruction can only provide a short address displacement. Whereas PDP-8 memory reference instructions provide a 7-bit address displacement, the Nova provides an 8-bit address displacement, which is handled in a much more intelligent fashion.

**Nova instructions that use simple, direct addressing treat the 8-bit displacements as a direct, page zero address, or as a signed binary, program relative displacement.** Thus you can directly address the first 256 words of memory, or you can address any location within +127 to -128 words of the memory reference instruction itself:



Remember, in microcomputer applications, program relative direct addressing is fine for Jump instructions, but is of limited value when accessing data memory. When a microcomputer program is stored in read-only memory, program relative, direct addressing can be used to read constant data only.

**Nova instructions that specify direct, indexed addressing, compute the effective memory address as the contents of either AC2 or AC3, plus the 8-bit displacement provided by the instruction object code.** The 8-bit dis-

placement is treated as a signed binary number. Since the Index registers are 16 bits wide, direct indexed addressing allows you to address any memory word. This may be illustrated as follows:



**Indirect addressing may be superimposed on any of the memory addressing options described thus far.** Indirect addressing is identified by a "1" in bit 10 of the Memory Reference instruction's object code. When indirect addressing is specified, the effective memory address is the contents of the directly addressed memory word.

**Let us examine the various indirect addressing options.** First there is page zero indirect addressing:

|                                             |
|---------------------------------------------|
| NOVA<br>DIRECT<br>MEMORY<br>ADDRESSING      |
| NOVA<br>INDIRECT<br>PAGE ZERO<br>ADDRESSING |



In the illustration above, arbitrary, real memory addresses have been selected to make the illustration easier to understand.

**NOVA  
INDIRECT  
PROGRAM  
RELATIVE  
ADDRESSING**

Program relative, indirect addressing may be illustrated as follows:



Indirect indexed addressing may be illustrated as follows:

**NOVA  
INDIRECT  
INDEXED  
ADDRESSING**



The illustration above arbitrarily uses indexed addressing via Accumulator AC2. Also the computed effective memory address is identical to that which was obtained in the indirect, program relative addressing illustration.

**Observe that Nova indirect addressing logic results in pre-indexed indirect addressing.** As described in Volume 1, Chapter 6, this is less desirable than post-indexed indirect addressing.

If, and only if indirect addressing has been specified by a "1" in bit 10 of a Memory Reference instruction's object code, then the contents of the data fetched from memory are treated as a direct address, providing the high-order bit of the direct address is 0. If the high-order bit of the address is 1, then the address is treated as another indirect address pointer. This may be illustrated as follows:

**NOVA  
MULTIPLE  
INDIRECT  
ADDRESSING**



Note carefully that multilevel indirect addressing will occur only when indirect addressing is specified in the first place. If you execute a direct memory reference instruction, data will never be interpreted as an address.

The Nova indirect addressing logic means that, given a 16-bit indirect address, only 15 bits actually address memory; therefore you are limited to a 32,768 word memory address space:



**The Nova minicomputers and microcomputers also provide indirect addressing with auto-increment and auto-decrement addressing.** If you indirectly address one of the eight memory locations, 0010<sub>16</sub> through 0017<sub>16</sub>, then the contents of the addressed memory location are incremented at the beginning of the memory access. Thus you have indirect addressing with auto-increment.

If you indirectly address any one of the locations, 0018<sub>16</sub> through 001F<sub>16</sub> then the contents of the addressed memory location will be decremented at the beginning of the memory access. Thus you have indirect addressing with auto-decrement.

**Neither the MicroNova nor the 9440 provide memory mapping logic.** Memory mapping is a technique whereby more than 32,768 words of addressable memory may be accessed. The Nova 3 minicomputer is capable of supporting memory mapping as an option.

Nova minicomputers have separate memory and I/O device spaces. I/O instructions include six bits which identify one of 64 I/O devices. Because Nova minicomputers and microcomputers treat I/O devices in a manner that differs significantly from the typical microcomputer, we will defer our discussion of I/O addressing until we have looked at pins, signals and System Busses.

**NOVA I/O  
DEVICE  
ADDRESSING**

## NOVA STATUS FLAGS

Nova minicomputers contain just one status flag, as we would define it, and that is the Carry status. Instructions are able to test for a zero or nonzero condition occurring at the conclusion of an instruction's execution, but no permanent zero status flag exists.

MicroNova also has these interrupt related status flags:

- Interrupt Enable
- Real Time Clock Enable
- Real Time Clock Request
- Stack Overflow Request

MicroNova Only

The interrupt related status flags do not occur as addressable locations in any Status register; rather they represent flip-flops which are set or reset during the course of interrupt handling.

The interrupt enable bit is a master enable which is set to 1 in order to enable all interrupts. Specific instructions allow all interrupts to be enabled or disabled.

The MicroNova has a Real Time Clock interrupt enable bit and a Real Time Clock request bit. The Real Time Clock enable bit must be set to 1 in order to enable Real Time Clock interrupts; as soon as a Real Time Clock interrupt occurs, the Real Time Clock enable bit and the Real Time Clock request bit are reset to 0.

The Stack Overflow request bit is only present in the MicroNova, since only the MicroNova has a Stack. A Stack overflow condition occurs if, following a push operation, the incremented contents of the Stack register have zeros in the eight low-order bits. What this implies is that the Stack must reside within a 256-word memory page:



When a Stack overflow occurs, the Stack Overflow request bit is set to 1 and an interrupt is requested.

## MICRONOVA AND 9440 CPU PINS AND SIGNALS

As we stated earlier in this chapter, minicomputer Central Processing Units are implemented on cards, not DIPs; therefore they usually have System Busses containing more than 40 signals. The standard Nova System I/O Bus contains 47 signals; furthermore, the Nova System Bus is, in effect, two busses: one communicating with memory, while a separate and distinct bus communicates with I/O devices:



**Table 19-1 briefly defines the functions of bus signals.** The I/O Bus is standard for all Nova line computers, while the Memory Bus is different for each model. We give the Memory Bus signals of the Nova 2 in Table 19-1.

Table 19-1. Nova System Bus Signals

## STANDARD NOVA SYSTEM I/O BUS

| SIGNAL                | DIRECTION     | FUNCTION OR INDICATION                                                             |
|-----------------------|---------------|------------------------------------------------------------------------------------|
| <u>DS0 - DS5</u>      | To Device     | Device selection                                                                   |
| <u>DATA0 - DATA15</u> | Bidirectional | Data and address lines                                                             |
| DATOA                 | To Device     | Data out to device's A buffer                                                      |
| DATIA                 | To Device     | Data in from device's A buffer                                                     |
| DATOB                 | To Device     | Data out to device's B buffer                                                      |
| DATIB                 | To Device     | Data in from device's B buffer                                                     |
| DATOC                 | To Device     | Data out to device's C buffer                                                      |
| DATIC                 | To Device     | Data in from device's C buffer                                                     |
| STRT                  | To Device     | Start device — clear Done flag, set Busy flag and clear device's INT REQ flip-flop |
| CLR                   | To Device     | Clear device's Busy and Done flags and INT REQ flip-flop                           |
| IOPLS                 | To Device     | I/O Pulse — user-defined function                                                  |
| SELB                  | To Processor  | Selected device's Busy flag is set                                                 |
| SELD                  | To Processor  | Selected device's Done flag is set                                                 |
| ROENB                 | To Device     | Enable interrupt or DMA requests                                                   |
| INTR                  | To Processor  | Interrupt request                                                                  |
| INTP                  | To Device     | Interrupt priority                                                                 |
| INTA                  | To Device     | Interrupt acknowledge                                                              |
| MSKO                  | To Device     | Interrupt mask out                                                                 |
| DCHR                  | To Processor  | Data channel request (DMA request)                                                 |
| DCHP                  | To Device     | Data channel priority                                                              |
| DCHA                  | To Device     | Data channel acknowledge                                                           |
| DCHM0,DCHM1           | To Processor  | Data channel mode:                                                                 |
|                       |               | DCHM0   DCHM1                                                                      |
|                       |               | 1      1      Data out                                                             |
|                       |               | 1      0      Increment memory                                                     |
|                       |               | 0      1      Data in                                                              |
|                       |               | 0      0      Add to memory                                                        |
| DCHI                  | To Device     | Data channel in                                                                    |
| DCHO                  | To Device     | Data channel out                                                                   |
| OVFLO                 | To Device     | Overflow: result of memory increment or add exceeds FFFF <sub>16</sub>             |
| IORST                 | To Device     | Clear all I/O devices                                                              |

## THE NOVA 2 MEMORY BUS

| SIGNAL          | DIRECTION     | FUNCTION OR INDICATION                                                    |
|-----------------|---------------|---------------------------------------------------------------------------|
| A0 - A14        | To Memory     | Memory address lines                                                      |
| DATA0 - DATA15  | Bidirectional | Memory data lines                                                         |
| INHIBIT SELECT  | To Memory     | Inhibits selection of memory module                                       |
| BMEMEN          | To Memory     | Starts memory cycle                                                       |
| WRITE           | To Memory     | Memory write                                                              |
| BRMW            | To Memory     | Causes pause between read and write                                       |
| WE              | To Memory     | Enable write after pause in read-pause-write cycle                        |
| SYNC ENABLE     | To Processor  | CPU hold control                                                          |
| RELOAD DISABLE  | To Memory     | Inhibits loading of memory buffer                                         |
| WAIT            | To CPU        | Disables other memory modules during write portion of memory cycle        |
| MEM CLOCK       | To Memory     | Memory Clock                                                              |
| EXTERNAL SELECT | To Memory     | Allows module to be selected despite contents of address lines            |
| EXTERNAL MBLD   | To Memory     | Allows data to be stored in memory buffer without starting a memory cycle |

If you are using the MicroNova or 9440 in a new product, then there is no reason why you should create the standard Nova System Busses. Providing the signals generated by the MicroNova or the 9440 are adequate for your needs, you can interface external logic directly to these two devices.

**Let us first look at the MicroNova pins and signals, which are illustrated in Figure 19-2.**

**Two clock signals,  $\Phi_1$  and  $\Phi_2$ , must be input to synchronize all MicroNova logic.**

**The Memory Bus consists of a 16-bit Address/Data Bus, plus three control signals: SAE, P and WE.**

**MICRONOVA  
MEMORY BUS**

The Address/Data Bus connects to pins MB0 - MB15. P is a synchronization signal, SAE is a read enable and WE is a write enable.

**The I/O Bus consists of just four signals:**

**MICRONOVA  
I/O BUS**

I/O CLOCK synchronizes I/O transfers.

I/O DATA1 and I/O DATA2 are bidirectional data and control signals.

I/O INPUT identifies the direction of data transfers occurring via I/O DATA1 and I/O DATA2.

As compared to other microcomputers described in this book, the MicroNova I/O interface is very unusual. Only the TMS 9900 I/O logic is at all similar. A 16-bit I/O data transfer occurs as two 8-bit serial units. This may be illustrated as follows:



Eight serial bits are input in less than one microsecond; therefore this method of handling I/O is as fast as the parallel data input operations described for other microcomputers.

Each data transfer is preceded by one of four codes generated by levels output via I/O DATA1 and I/O DATA2. These are the four codes:

| I/O DATA1 | I/O DATA2 | INTERPRETATION                                                                             |
|-----------|-----------|--------------------------------------------------------------------------------------------|
| 1         | 1         | Accompanying I/O low pulse may be used to synchronize interrupt requests and DMA requests. |
| 1         | 0         | DMA request acknowledge.                                                                   |
| 0         | 1         | I/O data transfer. The transfer direction is specified by I/O INPUT.                       |
| 0         | 0         | I/O command out.                                                                           |

Thus every I/O operation will begin with I/O DATA1 and I/O DATA2 being output during a low I/O CLOCK pulse. I/O INPUT will be low at this time since data is being output via I/O DATA1 and I/O DATA2. Providing I/O DATA1 and I/O DATA2 specify a data transfer to follow, the actual data transfer will occur via I/O DATA1 and I/O DATA2 with I/O INPUT identifying the data transfer direction.



Figure 19-2. MicroNova CPU Signals and Pin Assignments

**There are two CPU control signals which are not part of either the Memory Bus or the I/O Bus.**

**Following power-up, the MicroNova CPU will not perform any operation until a high input occurs at CLAMP.** When CLAMP goes high, interrupts are enabled, Real Time Clock and Stack Overflow interrupt requests are cleared, and the CPU is halted. Once CLAMP has been input high, it is ignored until the MicroNova is powered down and then powered up again.

The HALT signal is output by the MicroNova as a high pulse while the MicroNova CPU has been halted — either in response to execution of a Halt instruction, or following CLAMP going high.

**There are two MicroNova signals associated with interrupt logic. DMA requests are made via DCH INT while any external interrupt is requested via EXT INT.** Both the DMA request and the interrupt request must be synchronized with instruction execution timing. This synchronization is provided by I/O DATA1 and I/O DATA2, as we have already described. The DMA acknowledge occurs via I/O DATA1 and I/O DATA2. There is no external interrupt acknowledge signal; however, such a signal can be derived from the Memory Bus, as we will describe later in this chapter.

**PAUSE is output low by the CPU when devices other than the CPU are permitted to access memory.**

**Now look at 9440 pins and signals, which are illustrated in Figure 19-3.**

**These pins and signals create a single System Bus. No attempt is made to create separate Memory and I/O Busses.**

**You may connect a crystal across CP and XTL in order to create a master clock signal, or you may input a clock signal via CP.**



Figure 19-3. 9440 CPU Signals and Pin Assignments

The 9440 generates a single synchronizing output (SYN). The CPU clock is output to the system via CLK OUT.

IB0 - IB15 provides the 9440 with a multiplexed 16-bit Data and Address Bus. This bus carries addresses to memory and I/O devices, and it carries bidirectional data between the CPU and memory or I/O devices. IB0 - IB15 are low true; a low signal level represents a 1 bit.

IB0 is the high-order bus line while IB15 is the low-order bus line. This agrees with Nova conventions. This chapter, and this whole book describe the low-order bit as bit 0 — exactly the reverse of IB0 - IB15.

There are three control signals on the 9440 CPU-memory interface.

M0 is output low to identify a memory read.

M1 is output low to identify a memory write.

M2 is output low to identify a memory-address being output.

External memory interface logic inputs MBUSY low while it is responding to any memory access. MBUSY is similar to the WAIT signals that we have described for other microcomputers; it can be used to make the CPU wait for slow memory to respond to a CPU access request.

The 9440 has two I/O control signals O0 and O1. These two control signals define I/O and memory accesses as follows:

- O1 = 0 O0 = 0 Instruction Fetch
- O1 = 0 O0 = 1 Data Channel Access
- O1 = 1 O0 = 0 Execute I/O Operation
- O1 = 1 O0 = 1 No I/O

9440  
SYSTEM  
BUS

**There are two signals associated with 9440 interrupt logic.**

An external interrupt is requested by inputting INT REQ low.

**INT ON** indicates whether or not interrupts are enabled. This signal is high when interrupts are enabled; if this signal is low, interrupts are disabled.

**A DMA request is made by inputting DCH REQ low.** The DMA request is acknowledged by O1 and O0 being output low and high, respectively.

**There are seven signals provided by the 9440 specifically to support a front panel or console.**

**Two of the front panel or console signals are outputs; these are the RUN and CARRY signals.**

RUN is output high while the CPU is executing programs; it is output low while the CPU is halted. RUN is used to generate an appropriate front-panel display light; it is also equivalent to a Halt acknowledge, as described in this book for many other microcomputers.

CARRY represents the condition of the Carry status. This signal is output specifically to drive a front-panel light.

**Five input control signals are provided for switches on a front-panel. Four of these signals are C0, C1, C2 and C3; they perform the following operations:**

| C3 | C2 | C1 | C0 | FUNCTION                                                                     |
|----|----|----|----|------------------------------------------------------------------------------|
| 0  | 0  | 0  | 0  | Display AC0 contents at console                                              |
| 0  | 0  | 0  | 1  | Display AC1 contents at console                                              |
| 0  | 0  | 1  | 0  | Display AC2 contents at console                                              |
| 0  | 0  | 1  | 1  | Display AC3 contents at console                                              |
| 0  | 1  | 0  | 0  | Increment Program Counter and then display contents of addressed memory word |
| 0  | 1  | 0  | 1  | Display contents of addressed memory word                                    |
| 0  | 1  | 1  | 0  | Load memory from console switches                                            |
| 0  | 1  | 1  | 1  | Halt                                                                         |
| 1  | 0  | 0  | 0  | Deposit switches into AC0                                                    |
| 1  | 0  | 0  | 1  | Deposit switches into AC1                                                    |
| 1  | 0  | 1  | 0  | Deposit switches into AC2                                                    |
| 1  | 0  | 1  | 1  | Deposit switches into AC3                                                    |
| 1  | 1  | 0  | 0  | Load Program Counter from console switches                                   |
| 1  | 1  | 0  | 1  | Continue/Run                                                                 |
| 1  | 1  | 1  | 0  | Increment Program Counter and then load memory from console switches         |
| 1  | 1  | 1  | 1  | No Operation                                                                 |

**The first 9440 devices decoded the C lines in a slightly different manner.** The following combinations were different operations:

| C3 | C2 | C1 | C0 | FUNCTION                                   |
|----|----|----|----|--------------------------------------------|
| 0  | 1  | 0  | 0  | Load Program Counter from console switches |
| 0  | 1  | 1  | 0  | Not used                                   |
| 1  | 1  | 0  | 1  | Load memory from console switches          |
| 1  | 1  | 1  | 0  | Continue/Run                               |

**MR is the Reset input to the 9440.** When this line is pulled low, the 9440 halts immediately and clears the Interrupt Enable flip-flop. Once MR goes high, the CPU will remain in the Halt state until it receives the "Run" command from lines C3- C0.



Figure 19-4. The Nova Arithmetic and Logic Unit



Figure 19-5. Arithmetic/Logic Instruction Object Code Interpretation

## CPU LOGIC AND INSTRUCTION EXECUTION

The manner in which the Nova CPU executes instructions differs markedly from microcomputers described earlier in this book. We will therefore begin our discussion of CPU operations by looking at overall CPU architecture.

Our discussion of Nova CPU logic is tied to instruction object code bit patterns: this happens to be the simplest way of describing the Nova CPU. We will look at instructions from a programmer's perspective when we examine the Nova instruction set.

**Nova instructions may be divided into these three groups:**

- 1) Arithmetic, Boolean and logical operations which are essentially internal to the CPU.
- 2) Memory reference instructions which offer a variety of memory addressing modes and very little else.
- 3) I/O instructions which are designed to allow a considerable amount of intelligence in I/O devices.

Let us examine each group of instructions and associated CPU logic.

### ARITHMETIC/LOGIC INSTRUCTIONS

The power of the Nova CPU lies in the fact that many logic functions are implemented sequentially along a single data path through the CPU. This is illustrated in Figure 19-4. This figure shows how individual bits of arithmetic and logic instruction object codes directly identify the many options available as data makes a single tour through the CPU. Figure 19-5 provides specific arithmetic and logic instruction object code interpretations.

Data to be operated on is always fetched from the Accumulators. Results are always returned to an Accumulator. For two-operand instructions, such as binary addition, the Destination Accumulator also serves as the second Source Accumulator. For one-operand instructions, such as a complement, there will be one Source Accumulator and one Destination Accumulator; the same Accumulator may serve as source and destination.

As the source and destination definitions would imply, the Nova has no Secondary Memory Reference (or Memory Operate) instructions as we define them; for example, you cannot directly add the contents of a memory word to the contents of an Accumulator.

In addition to one or two 16-bit data words, the Carry status is input to the Arithmetic and Boolean logic unit. You may input the Carry status as is, or you may complement it, reset it to 0 or set it to 1. If you modify the Carry status, then the modified Carry status becomes the new input to the Arithmetic and Boolean logic.

You may specify one of eight Arithmetic and Logic operations. The Move operation serves both as a Move and a No Operation. By specifying the same Accumulator as the source and destination for a Move, Arithmetic and Boolean logic is bypassed. Notice that only one Boolean operation, the AND, is provided. This is an inconvenience rather than a problem. As discussed in Volume 1, Chapter 2, you can combine the AND and complement operations to generate an OR or an Exclusive-OR. The following Nova instruction sequences substitute for the OR and Exclusive-OR:

```
;OR the contents of ACX with ACY. Leave the result in ACY
    COM    ACX,ACX    Complement ACX
    AND    ACX,ACY    AND ACX with ACY. Result to ACY
    ADC    ACX,ACY    Add original ACX. Result to ACY
;Exclusive-OR ACX with ACY. Leave the result in ACY.
;ACZ is needed for temporary data storage
    MOV    ACY,ACZ    Save ACY in ACZ
    ANDZL   ACX,ACZ   Store twice ACX AND ACY in ACZ
    ADD    ACX,ACY    Add ACX to ACY
    SUB    ACZ,ACY    Subtract twice ACX AND ACY
```

The 16-bit output from the Arithmetic and Boolean logic, together with the Carry status, passes to the Shifter and Byte Swap logic; here the 17-bit data unit may be rotated left or right, high and low-order bytes of the 16-bit data unit may be swapped, or this logic may be bypassed.

The Shifter and Byte Swap logic outputs 16 bits of data, plus the Carry status. The data and the Carry status may be tested separately, and based on one of eight identifiable conditions, the Program Counter contents may be incremented; this provides conditional skip logic. Figure 19-5 defines the eight conditions that may cause a skip.

Finally you have the option of preventing results from being stored in the Destination register; this enables conditional branch logic without modifying the contents of any Accumulator.

In summary, the five operations that can be specified by a single arithmetic/logic instruction may be illustrated as follows:



It would take four or five typical microprocessor instructions to perform the same operations that a single Nova instruction can perform.

Arithmetic/logic instruction options are specified in the source program using compound mnemonics. The mnemonics are created as follows:



The numbers ①, ②, ③, ④ and ⑤ and the letters A), B), C), D), E), F), G) and H) are keyed to the previous illustration. ACs represents "Source Accumulator" while ACd represents "Destination Accumulator". Thus the instruction "set carry to 0, then add AC1 contents to AC2, shift the result left one bit, keep the result, but skip on carry set" will create the mnemonic:

ADDZL AC1.AC2, SNC

All logic associated with the execution of arithmetic/logic instructions is provided by the MicroNova and the 9440 chips.



Figure 19-6. Load and Store Instruction Object Codes



Figure 19-7. Jump and Modify Memory Instruction Object Codes



Figure 19-8. General Input/Output Instruction Object Code Interpretation

## MEMORY REFERENCE INSTRUCTIONS

Since the four Accumulators of the Nova CPU must provide data sources and destinations for all arithmetic and logic instructions, you will constantly move data between memory and one of the four Accumulators. We have already described the Nova addressing modes. Figure 19-6 illustrates memory reference instruction object codes and addressing mode specifications. You can load data into any Accumulator, or you can store the contents of any Accumulator in memory.

**There are four Jump and Modify Memory instructions. Object codes are given in Figure 19-7.** The memory addressing options described earlier in the chapter apply also to the Jump and Modify Memory instructions.

**The Jump-to-Subroutine instruction** requires special mention: this instruction stores the subroutine return address in Accumulator AC3. If you are going to nest subroutines then you must write your own subroutine to create a software stack. Note that even the MicroNova, which has a stack, does not use it when a Jump-to-Subroutine instruction is executed.

MicroNova and 9440 chips provide all effective memory address computation logic and reduce memory reference instructions, as external logic sees them, to typical address and data transmissions with accompanying control strobe signals.

But remember, there is no such thing as a "standard" Nova memory bus.

## INPUT/OUTPUT INSTRUCTIONS

Figure 19-8 illustrates input/output instruction object code interpretations.

Every I/O device that communicates with a Nova minicomputer must have a **Busy status** and **Done status**. These are bidirectional statuses; they are modified by the CPU to control the I/O device and they are modified by the I/O device to indicate the status of the I/O operation.

|                                         |
|-----------------------------------------|
| NOVA I/O DEVICE<br>BUSY AND DONE STATUS |
|-----------------------------------------|

**This is how the Busy and Done statuses are interpreted:**

BUSY    DONE

- |   |   |                                                                               |
|---|---|-------------------------------------------------------------------------------|
| 0 | 0 | Device Idle                                                                   |
| 1 | 0 | CPU "starts" device by setting Busy to 1.                                     |
| 0 | 1 | Device resets Busy to 0 and sets Done to 1 when device operation is complete. |
| 1 | 0 | CPU resets Done to idle device, or sets Busy for next device operation.       |
| 1 | 1 | Illegal                                                                       |



Figure 19-9. Input/Output Skip Instruction Object Code Interpretation

You start and stop I/O devices by manipulating device Busy and Done statuses.

**Every I/O device may optionally have up to three individually addressable registers, referred to as Registers A, B and C.**

You transfer data between one of the four CPU Accumulators and one of the three I/O device registers.

**NOVA  
I/O DEVICE  
REGISTERS**



Figure 19-10. CPU Device 3F16 Input/Output Instruction Object Code Interpretation

Both a status manipulation and a data transfer may be specified by a single I/O instruction; these two operations occur in parallel and are supported by appropriate control signals on the I/O bus.

The Nova CPU must be able to poll the Busy and Done statuses of an I/O device, just as most microprocessors read the contents of an I/O device Status register. The Nova CPU responds to status condition tests by optionally performing a Skip (which means the Program Counter contents are incremented). **This variation of I/O instructions is illustrated in Figure 19-9.**

**Six bits of every I/O instruction object code are used to identify the I/O device being addressed. This gives you a total of 64 devices in the I/O device address space.** But in order to enhance its instruction set, the Nova uses selected I/O device numbers to encode instructions internal to the CPU. I/O device numbers 0, 1 and 3F16 are reserved for this purpose. **I/O device 3F16 selects a number of interrupt related instructions whose object codes are defined in Figure 19-10. I/O device numbers 0 and 1 implement instructions illustrated in Figure 19-11.**

**You will have to add considerable logic beyond the 9440, or the MicroNova, if you are going to execute all I/O instructions described in Figures 19-8, 19-9, 19-10 and 19-11.** The only logic provided by the CPU chips themselves support that part of the I/O operation which is exclusively internal to the CPU — and that is not much. The CPU will route data to or from the selected Accumulator, if needed, and it will increment the Program Counter in response to a Skip true condition. Everything else is the responsibility of logic beyond the CPU chip.

NOVA I/O  
DEVICE  
ADDRESS  
SPACE



Figure 19-11. CPU Device 1 Input/Output Instruction Object Code Interpretation

## A NOVA CPU SUMMARY

If you compare Nova CPU logic with microprocessors described earlier in this book, a number of minicomputer characteristics become self-evident. These characteristics have important implications when we look at bus signals, interfaces and timing; therefore they must be clearly defined.

Minicomputer Central Processing Units are more complex than their microprocessor counterparts. Look at the number of operations which may be performed during execution of a single Nova instruction; only the 8X300 makes any attempt to provide such serial logic. The microprocessor CPU architect has been severely restricted by the fact that only a limited amount of logic can be put on a chip without drastically affecting chip yield — and therefore the price of the microprocessor. When minicomputers were designed, making CPU logic more complex increased the size of the CPU card, or cards, which had some effect on eventual product price, but nothing like the microprocessor price escalations that result from low chip yields.

Thus unconstrained by logic limitations, minicomputer CPU architects also designed complex system busses, requiring equivalently complex logic within I/O devices attached to the system busses. For example, consider the fact that Figure 19-5 defines 32,768 different Register-Register Operate instructions, while the instruction format in Figure 19-8 assumes an I/O System Bus that can simultaneously manipulate I/O device status while transferring data.

These are formidable burdens placed on the designer of a chip which is supposed to reproduce the Nova CPU — with the result that chip designers have elected to tackle only part of the task. Both the MicroNova and the 9440 terminate at 40-pin DIPs; their busses are, in consequence, less than the standard Nova System Busses.

## 9440 TIMING AND INSTRUCTION EXECUTION

We will now examine 9440 instruction timing in detail.

**9440 instructions and internal logic are timed by a master 10 MHz clock signal. Instructions are executed in machine cycles. This is the number of clock periods per machine cycle:**

|                               |                    |                                 |
|-------------------------------|--------------------|---------------------------------|
| Memory read/instruction fetch | - 15 clock periods | Depends on actual memory timing |
| Memory write                  | - 15 clock periods |                                 |
| I/O data in                   | - 10 clock periods |                                 |
| I/O data out                  | - 10 clock periods |                                 |

Let us begin by looking at timing for an instruction fetch or a memory read; these two machine cycles have the timing illustrated in Figure 19-12.

At the end of clock period 2, the three memory control signals  $\overline{M_0}$ ,  $\overline{M_1}$  and  $\overline{M_2}$  are output with levels that identify the memory access which will be performed during the current machine cycle. For a memory read or instruction fetch,  $\overline{M_0}$  and  $\overline{M_2}$  are output low while  $\overline{M_1}$  remains high.



Figure 19-12. 9440 Memory Read/Instruction Fetch Timing .

An instruction fetch and a memory read are differentiated by signals O0 and O1; these signals are both low for an instruction fetch and both high for a memory read. The address of the memory location to be accessed is output on the Information Bus ( $\overline{IB_0} - \overline{IB_{15}}$ ) beginning at the end of clock period 8. At the end of clock period 9  $\overline{SYN}$  is output low; external logic must use the high-to-low transition of  $\overline{SYN}$  as a strobe to latch an address off the Information Bus. External logic must also use the high-to-low transition of  $\overline{SYN}$  as a trigger to input  $\overline{MBUSY}$  low to the 9440.  $\overline{MBUSY}$  must be input low until addressed data has been read from memory and is stable on the Information Bus. At that time  $\overline{MBUSY}$  goes high again. When  $\overline{MBUSY}$  goes high, the 9440 will read data off the Information Bus. If the Memory Read machine cycle is to execute in the minimum 15 clock periods, then  $\overline{MBUSY}$  must be low for one clock period only.

$\overline{MBUSY}$  is a signal used by external memory interface logic to synchronize itself with the CPU. If  $\overline{MBUSY}$  is low while  $\overline{SYN}$  is high, early in any memory access machine cycle, then the high-to-low transition of  $\overline{SYN}$  will be delayed until

MBUSY goes high. For a Memory Read or Instruction Fetch machine cycle, the trailing edge of the low MBUSY pulse also acts as an end-of-machine-cycle trigger. Three clock periods after MBUSY's low-to-high transition, the machine cycle ends and SYN goes high again. Here is an example of MBUSY and SYN interaction during termination of a Memory Read or Instruction Fetch machine cycle:



MBUSY and SYN interaction at the high-to-low SYN transition may be illustrated as follows:



Figure 19-13. 9440 Memory Write Timing

Every instruction's execution will begin with an instruction fetch machine cycle. This machine cycle will be followed by internal operations, another memory read, a memory write, an I/O read, or an I/O write.

If the instruction to be executed requires internal operations only, that is, it is an arithmetic/logic instruction, then internal operations are executed during clock periods 1 through 8 of the next machine cycle — which must be another instruction fetch machine cycle.

**If a memory read operation is to be performed, then another machine cycle is executed,** exactly equivalent to Figure 19-12.

**If a memory write is to be performed, then two machine cycles must follow the instruction fetch.** During the first machine cycle the external memory address is output. During the second machine cycle data to be written to memory is output. Timing is illustrated in Figure 19-13. This figure is self-evident. During the first machine cycle only M<sub>2</sub> is low since a memory address is being output without a read or a write operation occurring during the same machine cycle. During the second machine cycle only M<sub>1</sub> is output low since a memory write operation alone will occur.

During both machine cycles of a Memory Write operation, MBUSY acts as a synchronizing signal, however only the high-to-low transition of MBUSY can modify instruction execution time. If MBUSY is low prior to SYN making its high-to-low transition, then the SYN high-to-low transition will be delayed until MBUSY goes high. Once SYN goes low, the processor waits for MBUSY to go low; three clock periods after the MBUSY high-to-low transition, the memory write machine cycle will end. The subsequent low-to-high transition of MBUSY has no effect on the SYN signal, or on internal CPU operations.

**The only memory addressing modes that change instruction execution time are indirect addressing and indirect addressing with auto-increment or auto-decrement.**

Each level of indirect addressing is equivalent to an additional memory read and an additional memory write. In order to compute instruction execution times for memory references with indirect addressing, therefore, add one memory read machine cycle and one memory write machine cycle for each level of indirection.

Recall that memory locations 10<sub>16</sub> through 1F<sub>16</sub> are used to store addresses which, when accessed indirectly, will be incremented or decremented. When you use indirect addressing and specify a memory location from 10<sub>16</sub> through 17<sub>16</sub>, the address fetched from the specified location will be incremented. An indirect address fetched from locations 18<sub>16</sub> through 1F<sub>16</sub> will be decremented. The increment or decrement operation requires the memory address to be loaded into the CPU, incremented or decremented, then written back out. Loading the address into the CPU is a routine part of any indirect addressing sequence; however, writing the address back out represents an additional step requiring an additional memory write machine cycle. This may be illustrated as follows:



**The increment or decrement and Skip-if-Zero instructions require an instruction fetch, a memory read and a memory write machine cycle.** Timing may be illustrated for direct memory addressing as follows:



Let us now look at I/O instruction execution.

**There are no special I/O device select or control signals output by the 9440, rather external I/O devices must have select logic which is created by decoding instruction object codes on the Information Bus.** This is done by decoding the three high-order Information Bus lines during an instruction fetch, as characterized by 00 and 01 both low. The three high-order Information Bus lines will at this time be 011 if the instruction to be executed is an I/O instruction. If these conditions are met, then the six low-order Information Bus lines must be decoded by device select logic. If the device code is 3F<sub>16</sub>, then all I/O devices must be selected simultaneously; for this to occur a special overriding device select signal must be created in response to device code 3F. If device code 00<sub>16</sub> occurs, then no device should be selected; this requires no special select logic, rather it means that no external device should have the address 00<sub>16</sub>. If any device code other than 00<sub>16</sub> or 3F<sub>16</sub> appears on the six low-order Information Bus lines, then one external device's select logic should go true.

If device code 3F<sub>16</sub> has been output, then one of the operations defined by Figure 19-10 is about to occur. A significant amount of external logic associated with execution of these instructions may be required. A specific implementation

consistent with standard Nova 1200 I/O interface logic is given later in this chapter. Alternatively, you may create a variety of individual control signals unrelated to the standard Nova I/O bus by suitably decoding I/O instruction object code bits 10 through 6.

An I/O instruction which identifies a specific device further identifies the I/O operations which are to occur, via bits 10 through 6 of the instruction object code (Information Bus lines  $\overline{IB5}$  through  $\overline{IB9}$ ). Figures 19-8 and 19-9 show the I/O operations which may be specified. **If data is to be input or output, then timing will conform to Figures 19-14 and 19-15.** But a significant amount of parallel control logic will accompany any I/O data transfer.

An I/O Skip on Busy or Done instruction, as illustrated in Figure 19-9, requires the addressed I/O device to return Busy and Done statuses to the CPU. The addressed I/O device returns these statuses on the two high-order Information Bus lines  $\overline{IB0}$  and  $\overline{IB1}$ , respectively, with timing conforming to Figure 19-14.



Figure 19-14. 9440 I/O Data Input Timing



Figure 19-15. 9440 I/O Data Output Timing

## MICRONOVA AND 9440 INTERRUPT PROCESSING

At the most elementary level, the MicroNova and the 9440 respond to interrupts in a very simple way.

External logic requests an interrupt by inputting a low signal via INT REQ.

Providing interrupts are enabled, the CPU acknowledges the interrupt upon completing execution of the current instruction; the CPU disables its own interrupt logic, saves the Program Counter contents in memory location 0000, then jumps indirect via location 0001. Thus memory location 0001 must contain the address of the first interrupt service routine instruction.



A single interrupt service routine will be executed in response to any external interrupt. In order to discriminate between interrupts, the interrupt service routine must identify the source of the interrupt, then jump to an appropriate individual program. This may be illustrated as follows:



There will be a separate device interrupt service routine for every I/O device capable of representing an interrupt.

**There are many ways in which the initial interrupt service routine may identify the interrupting I/O device in a multiple interrupt configuration.**

**The most primitive method** used to identify an interrupting I/O device is to test the device's Done status. Standard Nova protocol requires an I/O device to request an interrupt when it sets its Done status. This may be illustrated as follows:

| Interrupt |      |                   |
|-----------|------|-------------------|
| Request   | Busy | Done              |
| False     | 0    | 0                 |
| False     | 1    | 0                 |
| True      | 0    | 1                 |
|           |      | End I/O operation |

Primitive I/O device interface logic will request an interrupt by applying a low signal at INT REQ when it sets its Done status high. Now the initial interrupt service routine will execute a sequence of "Skip on Done False" instructions in order to identify the highest priority interrupting device. This may be illustrated as follows:



The order in which the initial interrupt service routine program logic tests device Done statuses becomes interrupt priority. You can modify this priority sequence at any time simply by changing the program.

**A faster method of identifying an interrupting device is to daisy chain the interrupting devices.** Daisy chain logic has been described in Volume 1, and again in Chapter 6 of this book (in conjunction with the 8048). Daisy chains are resolved by an interrupt acknowledge signal; but there is no interrupt acknowledge signal output by the MicroNova or

the 9440; rather an interrupt acknowledge instruction is executed. This is an I/O instruction addressing device 3F16; bits 10 through 6 ( $\overline{IB5}$  through  $\overline{IB9}$ ) of the instruction object code must be decoded in order to create an interrupt acknowledge signal. Here is appropriate logic:



Recall that the Information Bus is low true; that is, a low logic level represents a bit value of 1. To ensure that INTA is generated only when a valid instruction code is on the Information Bus, it should be qualified by SYN low and MBUSY low-to-high transition. This is illustrated in Figure 19-16.

The highest priority interrupting device identifies itself by placing its device code on the Information Bus lines. The CPU stores the device number in one of the four Accumulators. Thus the interrupt acknowledge instruction is an I/O Data In instruction. Interrupt acknowledge timing is illustrated in Figure 19-16.

#### **Interrupt enable and disable logic exists separately at the CPU and at external I/O devices.**

At the CPU all interrupts are disabled as soon as an interrupt is detected. You can disable interrupts at any other time by executing a disable interrupt instruction (NIOS CPU).

In order to enable interrupts you must execute an interrupt enable instruction (NIOS CPU); when an NIOS CPU instruction is executed, interrupts are enabled following execution of the next instruction. This next instruction will usually be a Return instruction:

```

    -
    -
    -
    NIOS      CPU      ;Enable interrupts
    JMP       @0       ;Return from interrupt service routine
                    ;Interruptions are now enabled
  
```

When nested interrupts are not allowed, all interrupts are disabled following the interrupt detection; interrupts remain disabled until the end of the interrupt service routine. You terminate the interrupt service routine with the two instructions illustrated above; one re-enables interrupts, the other returns from the interrupt service routine. Interrupts are not actually re-enabled until after the Return instruction has been executed; this prevents pending interrupts from being acknowledged before you have finally exited the current interrupt service routine.



Figure 19-16. 9440 Interrupt Acknowledge Instruction Execution Timing

If you want to nest interrupts then you must execute an interrupt enable instruction within the interruptable interrupt service routine. But make sure that you do not re-enable interrupts until the initial interrupt service routine has executed; remember, the initial interrupt service routine is determining the source of the interrupt — and it makes no sense to allow another interrupt to occur until this determination has been completed.

**You can disable interrupts selectively at external devices that have local interrupt disable logic. This is done using the Mask Out instruction (MSKO);** MSKO is another I/O instruction addressing device 3F16. The MSKO instruction outputs data from one of the CPU Accumulators onto the Information Bus. Every I/O device capable of having its interrupt logic disabled must be connected to one of the Information Bus lines. When the MSKO instruction is executed, the I/O device must first decode the MSKO instruction in order to activate its interrupt disable logic; subsequently, if the Information Bus line to which device interrupt disable logic is connected is low, then interrupt request logic must be disabled locally. Timing is illustrated in Figure 19-17.

In order to re-enable interrupts at any external device you output a new mask with a high level on the Information Bus line to which the device's interrupt disable logic is connected.

**Interrupt logic again demonstrates the minicomputer emphasis of the Nova.** We have assumed that an external device capable of requesting interrupts can decode I/O instruction object codes on the Information Bus and have a considerable amount of logic associated with Busy, Done and Interrupt request flags.



Figure 19-17. 9440 Mask Out Instruction Execution Timing

## MICRONOVA AND 9440 DIRECT MEMORY ACCESS LOGIC

**MicroNova and 9440 direct memory access logic differ markedly.**

In both cases external logic represents a DMA access by inputting a low signal via DCH REQ.

The MicroNova responds by acknowledging the DMA request. This is done by outputting a high I/O DATA1 with a low I/O DATA2 signal. External logic then identifies the direction of the data transfer via the I/O INPUT control signal. Subsequently, MicroNova logic performs the entire DMA transfer by creating appropriate I/O Bus and Memory Bus signal sequences — but only data may be transferred in only one direction.

The 9440 has a more primitive DMA capability. It responds to DCH INT by outputting lines O1 and O0 low and high, respectively, and floating the Data Bus. External logic must implement the actual DMA transfer.

Standard Nova protocol allows four DMA operations to be defined by external logic via the DCHM0 and DCHM1 I/O bus signals. These are the four DMA operations that may be defined:

| DCHM0 | DCHM1 |                  |
|-------|-------|------------------|
| 0     | 0     | Add to memory    |
| 0     | 1     | Data in          |
| 1     | 0     | Increment memory |
| 1     | 1     | Data out         |

The MicroNova, as we have already stated, handles data in and data out only; increment memory and add to memory are not available.

**The 9440** on the other hand, **does nothing in response to a DMA request other than float the Information Bus. All external logic associated with DMA operations must exist outside the 9440 chip.**

## THE MICRONOVA AND 9440 INSTRUCTION SETS

**Table 19-2 summarizes the instruction sets for the MicroNova and the 9440.** Observe that there are some instructions available with MicroNova that the 9440 lacks.

The power of the Nova instruction set is derived from the fact that many instructions perform multiple operations. Register Operate instructions, for example, allow you to set, or reset or complement a Carry status before the specified operation is performed. Primary Memory Reference and Register Operate instructions allow you to also perform data shifts, or to swap the high and low-order bytes of the data word being moved or generated.

Primary Memory Reference and Register Operate instructions also allow you to perform a conditional skip based on the results of the operation.

It is the ability of the Nova instruction set to perform a combination of operations, during a single instruction's execution, that makes the instruction set so effective.

## THE BENCHMARK PROGRAM

**Our benchmark program may be illustrated as follows for the MicroNova and the 9440:**

|      |          |                                       |                                        |
|------|----------|---------------------------------------|----------------------------------------|
| LDA  | 2,CNT    | LOAD WORD COUNT COMPLEMENT INTO AC2   |                                        |
| LDA  | 0,IOBUF  | LOAD IOBUF BASE ADDRESS INTO AUTO-    |                                        |
| STA  | 0,10     | INCREMENT LOCATION                    |                                        |
| LDA  | 0,@TABLE | LOAD ADDRESS OF FIRST FREE TABLE WORD |                                        |
| STA  | 0,11     | INTO AUTO-INCREMENT LOCATION          |                                        |
| LOOP | LDA      | 0,@10                                 | LOAD NEXT BYTE FROM IOBUF              |
|      | STA      | 0,@11                                 | STORE IN NEXT TABLE WORD               |
|      | INC      | 2,2,SZR                               | INCREMENT WORD COUNT SKIP IF ZERO      |
|      | JMP      | LOOP                                  | RETURN FOR MORE                        |
|      | LDA      | 0,21                                  | RETURN NEW ADDRESS OF FIRST FREE TABLE |
|      | STA      | 0,@TABLE                              | WORD                                   |

This benchmark program uses indirect addressing with auto-incrementing in order to sequentially access IOBUF and TABLE. We begin the program by loading the word count (CNT) into Accumulator 2, and table base addresses into memory words 1016 and 1116. We assume that the address of the first free word in TABLE is stored in the first word of TABLE; thus we can fetch the address of the first free TABLE word by executing a load to Register 0 with indirect addressing.

Data is moved by a four-instruction loop. Two instructions load data from IOBUF and store data in TABLE using indirect addressing with auto-increment. Next we increment the counter stored in Register 2 and skip the following instruction upon detecting a zero count. The following instruction is a jump back to the beginning of the loop.

The final two instructions simply restore the new address for the first free TABLE word into the first word of the TABLE.

The benchmark program makes no assumptions. The source and destination tables may be any size and any number of data words may be transferred, limited only by the available memory space.

The following notation is used in Table 19-2.

An "X" in the column labeled "9440" indicates that the instruction is available on the 9440 CPU.

|       |                                                                                                                                                                 |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AC    | Any of the four Accumulators.                                                                                                                                   |
| ACX   | A specific Accumulator. For example, AC1 is Accumulator 1.                                                                                                      |
| C     | Carry status                                                                                                                                                    |
| D     | An Accumulator which serves as the destination for the results of an operation.                                                                                 |
| DEV   | A 6-bit device code.                                                                                                                                            |
| DEVX  | A specific device register. For example, DEVA is Device Register A.                                                                                             |
| DEVBD | Device Busy-Done flags.                                                                                                                                         |
| EA    | Effective address determined by @DISP (.IX ).                                                                                                                   |
| FP    | Frame Pointer (not present in 9440).                                                                                                                            |
| ION   | Interrupt ON flag                                                                                                                                               |
| PC    | Program Counter                                                                                                                                                 |
| PM    | Priority Mask                                                                                                                                                   |
| S     | An Accumulator which serves as the source of an operand.                                                                                                        |
| SP    | Stack Pointer (not present in 9440).                                                                                                                            |
| (CS#) | Represents three options which are used by the Register-Register operations.<br>C is a 2-bit field which determines the carry state prior to the ALU operation. |

| Coded Character | Result Bits | Operation        |
|-----------------|-------------|------------------|
| option omitted  | 00          | No operation     |
| Z               | 01          | Set carry to 0   |
| O               | 10          | Set carry to 1   |
| C               | 11          | Complement carry |

For example, ADDO 2,2 would set carry to 1 before adding AC2 to AC2.

S is a 2-bit field which determines how the result of the ALU will be shifted.

| Coded Character | Result Bits | Operation                               |
|-----------------|-------------|-----------------------------------------|
| option omitted  | 00          | No shift                                |
| L               | 01          | Shift result and carry left<br>one bit  |
| R               | 10          | Shift result and carry right<br>one bit |
| S               | 11          | Swap result bytes                       |

For example, MOVS 1,2 would swap the bytes of AC1 and store into AC2.

# is a 1-bit field which determines whether the result is stored in ACD.

| Coded Character | Result Bits | Operation                   |
|-----------------|-------------|-----------------------------|
| option omitted  | 0           | Load result into ACD        |
| #               | 1           | Do not load result into ACD |

For example, NEGOL# 1,2 would set carry to 1 then negate AC1, shift the result and carry left one bit, but would not store into AC2.

- (f) A 2-bit I/O command whose meaning depends on whether the CPU or another device is being referenced.

| CPU           | f  | Device                                             |
|---------------|----|----------------------------------------------------|
| No operation  | 00 | No operation                                       |
| Set Interrupt | 01 | Start device by setting Busy to 1<br>and Done to 0 |
| On to 1       | 10 | Idle device by setting Busy to 0<br>and Done to 0  |
| Set Interrupt | 11 | Pulse a special device dependent<br>line           |

(.SKCND) A 3-bit skip-on-condition field which is used by the Register-Register Operate instructions.

| Coded Character | Result Bits | Operation                          |
|-----------------|-------------|------------------------------------|
| option omitted  | 000         | No operation                       |
| SKP             | 001         | Always skip                        |
| SZC             | 010         | Skip if Carry = 0                  |
| SNZ             | 011         | Skip if Carry = 1                  |
| SZR             | 100         | Skip if result = 0                 |
| SNR             | 101         | Skip if result ≠ 0                 |
| SEZ             | 110         | Skip if either carry or result = 0 |
| SBN             | 111         | Skip if both carry and result ≠ 0  |

(@ ) DISP (IX) Generates the address EA

@ is the indirect bit. If @=1 then indirection is specified.

DISP is an 8-bit address value.

(IX) is a 2-bit field which indicates the addressing Mode:

Bits are Mode

00 Zero page addressing. DISP is an unsigned address between 0 and 256.

$$EA = DISP$$

01 PC relative addressing. DISP is a signed two's complement address displacement.

$$EA = DISP + [PC]$$

10 Indexed addressing via AC2. DISP is a signed two's complement address displacement.

$$EA = DISP + [AC2]$$

11 Indexed addressing via AC3. DISP is a signed two's complement address displacement.

$$EA = DISP + [AC3]$$

(t) A 2-bit I/O test field whose meaning depends on whether the CPU or another device is referenced.

CPU      t      Device

Test for Interrupt On=1 00 Test for Busy=1

Test for Interrupt On=0 01 Test for Busy=0

Never skip            10 Test for Done=1

Always skip          11 Test for Done=0

x<y,z> Bits y through z of the quantity x. [AC]<5,0> is the low six bits of the specified Accumulator.

[ ] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.

[[ ]] Implied memory addressing; the contents of the memory location designated by the contents of a register.

Λ Logical AND

← Data is transferred in the direction of the arrow.

Under the heading of STATUS in Table 19-2, an X indicates statuses which are modified in the course of the instruction's execution. If there is no X, it means that the status maintains the value it had before the instruction was executed.

Table 19-2. MicroNova and 9440 Instruction Set Summary

| TYPE | MNEMONIC | OPERAND(S) | BYTES | STATUS |      | 9440                                                                                                   | OPERATION PERFORMED                                                                                                  |
|------|----------|------------|-------|--------|------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
|      |          |            |       | C      | 9440 |                                                                                                        |                                                                                                                      |
| I/O  | NIO (f)  | DEV        | 2     |        | X    | [DEVB0] — f                                                                                            | Set the device's Busy and Done flags according to I/O command.                                                       |
|      | DIA (f)  | AC,DEV     | 2     |        | X    | [AC] — [DEVA]                                                                                          | [DEVB0] — f                                                                                                          |
|      | DIB (f)  | AC,DEV     | 2     |        | X    | Read device's A buffer into Accumulator. Set the device Busy and Done flags.                           | [AC] — [DEVB]                                                                                                        |
|      | DIC (f)  | AC,DEV     | 2     |        | X    | Read device's B buffer into Accumulator. Set the device Busy and Done flags.                           | [AC] — [DEVC]                                                                                                        |
|      | DOA (f)  | AC,DEV     | 2     |        | X    | Read device's C buffer into Accumulator. Set the device Busy and Done flags.                           | [DEVA] — [AC]                                                                                                        |
|      | DOB (f)  | AC,DEV     | 2     |        | X    | Write Accumulator into device's A buffer. Set the device Busy and Done flags.                          | [DEVB] — [AC]                                                                                                        |
|      | DOC (f)  | AC,DEV     | 2     |        | X    | Write Accumulator into device's B buffer. Set the device Busy and Done flags.                          | [DEVC] — [AC]                                                                                                        |
|      | SKP (t)  | DEV        | 2     |        | X    | Write the Accumulator into device's C buffer. Set the Busy and Done flags.                             | [DEVB0] — f                                                                                                          |
|      | IORST    |            |       |        | X    | If T is true for DEV, [PC] — [PC] + 1<br>Skip if I/O test true.<br>[PM] — 0<br>[ION] — 10 <sub>2</sub> | The Busy and Done flags in all I/O devices are set to 0. The Priority Mask is set to 0 and interrupts are turned on. |

Table 19-2. MicroNova and 9440 Instruction Set Summary (Continued)

| TYPE                           | MNEMONIC   | OPERAND(S)       | BYTES | STATUS |   | 9440 | OPERATION PERFORMED                                                                                                                                  |
|--------------------------------|------------|------------------|-------|--------|---|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                |            |                  |       | C      |   |      |                                                                                                                                                      |
| PRIMARY<br>MEMORY<br>REFERENCE | LDA        | AC,(“) DISP,(IX) | 2     |        | X |      | [AC] — [EA]<br>Load contents of memory to Accumulator.                                                                                               |
|                                | STA        | AC,(“) DISP,(IX) | 2     |        | X |      | [EA] — [AC]<br>Store contents of Accumulator into memory.                                                                                            |
| REGISTER-REGISTER OPERATE      | ADD (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [D] + [S]<br>Add contents of Source register to contents of Destination register. Perform the specified options.                               |
|                                | SUB (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [D] - [S]<br>Subtract contents of Source register from contents of Destination register. Perform the specified options.                        |
|                                | NEG (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [S] + 1 (twos complement)<br>Place twos complement of the Source register contents in the Destination register. Perform the specified options. |
|                                | ADC (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [D] + [S]<br>Add the ones complement of the Source register contents to contents of Destination register. Perform the specified option.        |
|                                | MOV (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [S]<br>Move contents of Source register to Destination register. Perform the specified options.                                                |
|                                | INC (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [S] + 1<br>Place incremented Source register contents into Destination register. Perform specified options.                                    |
|                                | COM (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [S]<br>Complement the Source register contents, then move to Destination register. Perform specified options.                                  |
|                                | AND (CS #) | S,D (SKCND)      | 2     | X      | X |      | [D] — [D] $\wedge$ [S]<br>AND the Source register contents with the Destination register contents. Perform specified options.                        |

Table 19-2. MicroNova and 9440 Instruction Set Summary (Continued)

| TYPE                             | MNEMONIC | OPERAND(S) | BYTES | STATUS |  | 9440 | OPERATION PERFORMED                                                                                                                                                                                                                                                                 |
|----------------------------------|----------|------------|-------|--------|--|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  |          |            |       | C      |  |      |                                                                                                                                                                                                                                                                                     |
| REGISTER-REGISTER<br>(CONTINUED) | MUL      |            | 2     |        |  |      | $[AC0] \leftarrow (([AC1] * [AC2]) + [AC0]) <31,16>$<br>$[AC1] \leftarrow ([AC1] * [AC2]) + [AC0] <15,0>$<br>Multiply contents of AC1 by contents of AC2 and add contents of AC0 to result.                                                                                         |
|                                  | DIV      |            | 2     | X      |  |      | $[AC1] \leftarrow ([AC0], [AC1])/[AC2]$ (quotient)<br>$[AC0] \leftarrow ([AC0], [AC1])/[AC2]$ (remainder)<br>Divide the 32-bit quantity contained in AC0 (high order) and AC1 (low order) by the contents of AC2.                                                                   |
| STACK                            | PSHA     | AC         | 2     |        |  |      | $[SP] \leftarrow [SP] + 1$ ; $[SP] \leftarrow [AC]$<br>Push the Accumulator onto the Stack.                                                                                                                                                                                         |
|                                  | POPA     | AC         | 2     |        |  |      | $[AC] \leftarrow [SP]$ ; $SP \leftarrow [SP] - 1$<br>Pop the top of the Stack to the Accumulator.                                                                                                                                                                                   |
|                                  | SAV      |            | 2     |        |  |      | $[SP] + 1 \leftarrow [AC]$<br>$[SP] + 2 \leftarrow [AC1]$<br>$[SP] + 3 \leftarrow [AC2]$<br>$[SP] + 4 \leftarrow [AC3]$<br>$[SP] + 5 <14,0> \leftarrow [PC]$<br>$[SP] + 5 <15> \leftarrow [C]$<br>$SP \leftarrow SP + 5$<br>$FP \leftarrow SP$<br>Save a return block in the Stack. |
|                                  | MTSP     | AC         | 2     |        |  |      | $SP \leftarrow [AC] <14,0>$<br>Move the low 15 bits of the Accumulator to the Stack Pointer.                                                                                                                                                                                        |
|                                  | MTFP     | AC         | 2     |        |  |      | $FP \leftarrow [AC] <14,0>$<br>Move the low 15 bits of the Accumulator to the Frame Pointer.                                                                                                                                                                                        |

Table 19-2. MicroNova and 9440 Instruction Set Summary (Continued)

| TYPE                 | MNEMONIC | OPERAND(S)    | BYTES | STATUS |  | 9440 | OPERATION PERFORMED                                                                                                                                                                                         |
|----------------------|----------|---------------|-------|--------|--|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      |          |               |       | C      |  |      |                                                                                                                                                                                                             |
| STACK<br>(CONTINUED) | MFSP     | AC            | 2     |        |  |      | [AC] <14,0> ← [SP]<br>[AC] <15> ← 0<br>Move the Stack Pointer to low 15 bits of Accumulator.                                                                                                                |
|                      | MFFP     | AC            | 2     |        |  |      | [AC] <14,0> ← [FP]<br>[AC] <15> ← 0<br>Move the Frame Pointer to the Accumulator.                                                                                                                           |
| JUMP                 | JMP      | (“) DISP,(IX) | 2     |        |  | X    | [PC] ← [EA]<br>Branch unconditional.<br>[AC3] ← [PC] + 1                                                                                                                                                    |
|                      | JSR      | (“) DISP,(IX) | 2     |        |  | X    | [PC] ← [EA]<br>Branch to subroutine.<br>[SP] ← [FP]<br>[C] ← [[SP]] <15><br>[PC] ← [[SP]] <14,0><br>[AC3] ← [[SP]] - 1<br>[AC2] ← [[SP]] - 2<br>[AC1] ← [[SP]] - 3<br>[AC2] ← [[SP]] - 4<br>[SP] ← [SP] - 5 |
|                      | RET      |               | 2     | X      |  |      | Return from subroutine and pop a return block off the Stack.                                                                                                                                                |
| REAL TIME<br>CLOCK   | RTCE(N)f |               | 2     |        |  | X    | [ION] ← f<br>Enable Real Time Clock then set ION via I/O command.                                                                                                                                           |
|                      | RTCDS(f) |               | 2     |        |  | X    | [ION] ← f<br>Disable Real Time Clock then set ION via I/O command.                                                                                                                                          |

Table 19-2. MicroNova and 9440 Instruction Set Summary (Continued)

| TYPE                                 | MNEMONIC | OPERAND(S)    | BYTES | STATUS |      | OPERATION PERFORMED                                                                                                                                                                             |
|--------------------------------------|----------|---------------|-------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      |          |               |       | C      | 9440 |                                                                                                                                                                                                 |
| MEMORY OPERATE AND SKIP-ON-CONDITION | ISZ      | (“) DISP,(IX) | 2     |        | X    | [EA] — [EA] + 1<br>If [EA] = 0 then [PC] — [PC] + 1<br>Increment memory contents and skip if zero.                                                                                              |
|                                      | DSZ      | (“) DISP,(IX) | 2     |        | X    | [EA] — [EA] - 1<br>If [EA] = 0 then [PC] — [PC] + 1<br>Decrement memory contents and skip if zero.                                                                                              |
| INTERRUPT                            | INTEN    |               | 2     |        | X    | [ION] — 1<br>Enable interrupts. Same as NIOS CPU.                                                                                                                                               |
|                                      | INTDS    |               | 2     |        | X    | [ION] — 0<br>Disable interrupts. Same as NIOC CPU.                                                                                                                                              |
|                                      | INTA (f) | AC            | 2     |        | X    | [AC] <5,0> — DEV<br>[ION] — f                                                                                                                                                                   |
|                                      | MSKO (f) | AC            |       |        | X    | The 6-bit device code of the device closest to the CPU that is requesting an interrupt is loaded into the low six bits of the Accumulator. Set ION via I/O command.<br>[PM] — [AC]<br>[ION] — f |
|                                      | TRAP     |               | 2     |        |      | Move contents of Accumulator to Priority Mask. Set ION via I/O command.<br>[26 <sub>15</sub> ] — [PC]<br>[PC] — [27 <sub>15</sub> ]                                                             |
|                                      | SKP (t)  | CPU           | 2     |        | X    | Performs a software interrupt.<br>If t is true, [PC] — [PC] + 1<br>If interrupt or power fail condition satisfied, skip next instruction.                                                       |
|                                      | HALT (f) |               | 2     |        | X    | [ION] — f<br>Set ION via I/O command, then halt.                                                                                                                                                |

Table 19-3. MicroNova and 9440 Instruction Set Object Codes

| INSTRUCTION | OBJECT CODE      | BYTES             | CLOCK PERIODS | 9440    |
|-------------|------------------|-------------------|---------------|---------|
| ADC(CS #)   | S,D,(SKCND)      | 1ssdd100rrccnwww  | 2             | 5/7 X   |
| ADD(CS #)   | S,D,(SKCND)      | 1ssdd110rrccnwww  | 2             | 5/7 X   |
| AND(CS #)   | S,D,(SKCND)      | 1ssdd111rrccnwww  | 2             | 5/7 X   |
| COM(CS #)   | S,D,(SKCND)      | 1ssdd000rrccnwww  | 2             | 5/7 X   |
| DIAf        | AC,DEV           | 011aa001ffpppppp  | 2             | 15 X    |
| DBIf        | AC,DEV           | 011aa011ffpppppp  | 2             | 15 X    |
| DICf        | AC,DEV           | 011aa101ffpppppp  | 2             | 15 X    |
| DIV         |                  | 7641              | 2             | 123     |
| DOAf        | AC,DEV           | 011aa010ffpppppp  | 2             | 10 X    |
| DOBf        | AC,DEV           | 011aa100ffpppppp  | 2             | 10 X    |
| DOCf        | AC,DEV           | 011aa110ffpppppp  | 2             | 10 X    |
| DSZ         | (n) DISP,(JX)    | 00011ixxbbbbbbbb  | 2             | 8/10* X |
| HALTf       |                  | 011aa110ff111111  | 2             | 10 X    |
| INC(CS #)   | S,D,(SKCND)      | 1ssdd011rrccnwww  | 2             | 5/7 X   |
| INTAf       | AC               | 011aa011ff111111  | 2             | 15 X    |
| INTDS       |                  | 60BF              | 2             | 10 X    |
| INTEN       |                  | 607F              | 2             | 10 X    |
| IORSR       |                  | 011aa010ff111111  | 2             | 10 X    |
| ISZ         | (n) DISP,(JX)    | 00010ixxbbbbbbbb  | 2             | 8/10* X |
| JMP         | (n) DISP,(JX)    | 00000ixxbbbbbbbb  | 2             | 6/8* X  |
| JSR         | (n) DISP,(JX)    | 00001ixxbbbbbbbb  | 2             | 7/9* X  |
| LDA         | AC,(d),DISP,(JX) | 011aaixxbbbbbbbb  | 2             | 6/8* X  |
| MFFP        | AC               | 011aa000100000001 | 2             | 8       |
| MFSP        | AC               | 011aa010100000001 | 2             | 7       |
| MOV(CS #)   | S,D,(SKCND)      | 1ssdd010rrccnwww  | 2             | 5/7 X   |
| MSKOf       | AC               | 011aa100ff111111  | 2             | 10 X    |
| MTFP        | AC               | 011aa000000000001 | 2             | 6       |
| MTSP        | AC               | 011aa010000000001 | 2             | 6       |
| MUL         |                  | 76C1              | 2             | 86      |
| NEG(CS #)   | S,D,(SKCND)      | 1ssdd001rrccnwww  | 2             | 5/7 X   |
| NIOf        | DEV              | 01100000ffpppppp  | 2             | 10 X    |
| POPA        | AC               | 011aa011100000001 | 2             | 7       |
| PSHA        | AC               | 011aa010000000001 | 2             | 7       |
| RET         |                  | 6581              | 2             | 15      |
| RTCDsf      |                  | 01101010ff111111  | 2             | 10 X    |
| RTCENf      |                  | 01110010ff111111  | 2             | 10 X    |
| SAV         |                  | 6501              | 2             | 16      |
| SKPt        |                  | 01100111ttpppppp  | 2             | 15/17 X |
| SKPT        | DEV              | 01100111tt111111  | 2             | 15/17 X |
| STA         | CPU              | 010aaixxbbbbbbbb  | 2             | 6/8* X  |
| SUBS(CS #)  | AC,(n) DISP,(JX) | 1ssdd101rrccnwww  | 2             | 5/7 X   |
| TRAP        | S,D,(SKCND)      | 1ssddqqqqqq1000   | 2             | 9       |

\*Direct addressing. For indirect addressing, add two clock periods for each level of indirection. For auto-increment or auto-decrement locations, add three clock periods, plus two for each level of indirection.

The following symbols are used in Table 19-3:

- aa Two bits selecting an Accumulator
- bbbbbbb 8-bit signed two's complement address displacement
- cc Two bits selecting the carry option
- dd Two bits selecting the destination Accumulator
- ff Two bits selecting the I/O command
- i One bit selecting indirect addressing
- n One bit choosing the no load option
- pppppp Six-bit device number
- rr Two bits determining the shift option
- ss Two bits choosing the source Accumulator

tt        Two bits choosing the I/O test  
www      Three bits selecting the skip-on-condition option  
xx        Two bits selecting the index option

Execution times shown are for MicroNova. Where two execution times are shown (for example, 5/7), the second is the instruction time if the skip or branch is taken.

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- MicroNova
- 9440

**ABSOLUTE MAXIMUM RATINGS\***

|                                            |                                 |
|--------------------------------------------|---------------------------------|
| Supply Voltage Range V <sub>BB</sub>       | <u>-2</u> to <u>-7</u> Volts    |
| Supply Voltage Range V <sub>CC</sub>       | <u>-0.3</u> to <u>+7</u> Volts  |
| Supply Voltage Range V <sub>DD</sub>       | <u>-0.3</u> to <u>+13</u> Volts |
| Supply Voltage Range V <sub>GG</sub>       | <u>-0.3</u> to <u>+17</u> Volts |
| Input Voltage Range V <sub>I</sub>         | <u>-0.3</u> to <u>+7</u> Volts  |
| Input Current Range I <sub>I</sub>         | <u>0</u> to <u>6</u> mAmps      |
| Operating Temperature Range T <sub>A</sub> | <u>0</u> to <u>+70</u> °C       |
| Storage Temperature Range T <sub>Stg</sub> | <u>-55</u> to <u>+125</u> °C    |
| Average Power Dissipation                  | <u>1</u> Watt                   |

**NOTES** All voltages in this document are referenced to V<sub>SS</sub> (ground).

\*Subjecting a circuit to conditions either outside these limits or at these limits for an extended period of time may cause irreparable damage to the circuit. As such, these ratings are not intended to be used during the operation of the circuit. Operating specifications are given in the DC (STATIC) CHARACTERISTICS TABLE.

## MICRONOVA

D. C. (STATIC) CHARACTERISTICS  
mN601

## OPERATING SPECIFICATIONS

$T_A$  range 0 to  $70^\circ\text{C}$   $V_{CG} = 14 \pm 1.0$  Volts  $I_{CC} = 20$  mAmps Average  $I_{BB} = -1$  mAmps Average  
 $V_{CC} = 5 \pm 0.25$  Volts  $V_{BB} = -4.25 \pm .25$  Volts  $I_{DD} = 50$  mAmps Average  $I_{SS} = -150$  mAmps Average  
 $V_{DD} = 10 \pm 1.0$  Volts  $V_{SS} = 0 \pm 0.0$  Volts  $I_{GG} = 20$  mAmps Average

| CHARACTERISTIC                | SYMBOL   | UNITS         | PINS                                                              | LIMITS |              |
|-------------------------------|----------|---------------|-------------------------------------------------------------------|--------|--------------|
|                               |          |               |                                                                   | MIN.   | MAX.         |
| INPUT LOW VOLTAGE             | $V_{IL}$ | Volts         | $\alpha_1, 3$ and $\alpha_2, 4$                                   | -2.0   | +0.5         |
|                               |          |               | MB 0-15, CLAMP EXTINT, DCH INT                                    | -1.0   | +1.0         |
|                               |          |               | I O CLOCK, I O DATA 1, I O DATA 2                                 | -1.0   | +0.5         |
|                               |          |               | $\alpha_1, 3$ and $\alpha_2, 4$                                   | -      | +0.01        |
| INPUT CURRENT FOR LOW STATE   | $I_{IL}$ | mAmps         | MB 0-15                                                           | 0      | -2.0         |
|                               |          |               | EXTINT, DCH INT, CLAMP                                            | -2.0   | -4.0         |
|                               |          |               | I O CLOCK, I O DATA 1, I O DATA 2                                 | -2.0   | -4.0         |
|                               |          |               | $\alpha_1, 3$ and $\alpha_2, 4$                                   | +13.0  | +15.0        |
| INPUT HIGH VOLTAGE            | $V_{IH}$ | Volts         | MB 0-15, CLAMP EXTINT, DCH INT                                    | +4.25  | +5.8         |
|                               |          |               | I O CLOCK, I O DATA 1, I O DATA 2                                 | +2.5   | +5.8         |
|                               |          |               | $\alpha_1, 3$ and $\alpha_2, 4$                                   | -      | -0.01        |
|                               |          |               | MB 0-15                                                           | -      | -0.05        |
| INPUT CURRENT FOR HIGH STATE  | $I_{IH}$ | mAmps         | I O CLOCK, I O DATA 1, I O DATA 2                                 | -      | -1.0         |
|                               |          |               | EXTINT, DCH INT                                                   | -      | -0.02        |
|                               |          |               | CLAMP                                                             | -      | +0.001       |
|                               |          |               | HALT                                                              | -      | +3.0         |
| OUTPUT LOW VOLTAGE            | $V_{OL}$ | Volts         | MB 0-15, I O INPUT, PAUSE, SAEG, NEG, PG                          | -      | +0.4         |
|                               |          |               | I O CLOCK, I O DATA 1, I O DATA 2                                 | -      | +0.5         |
| OUTPUT CURRENT FOR LOW STATE  | $I_{OL}$ | mAmps         | PG, I O INPUT                                                     | +4.0   | -            |
|                               |          |               | MB 0-15, I O CLOCK, I O DATA 1, I O DATA 2, PAUSE, SAEG, PG, HALT | +2.0   | -            |
|                               |          |               | HALT                                                              | -      | $V_{CC}-0.5$ |
|                               |          |               | HALT,                                                             | -      | -0.01        |
| OUTPUT HIGH VOLTAGE           | $V_{OH}$ | Volts         | MB 0-15                                                           | -      | -0.05        |
|                               |          |               | I O INPUT, PAUSE, SAEG, NEG, PG                                   | -      | -0.02        |
|                               |          |               | I O CLOCK, I O DATA 1, I O DATA 2, PAUSE, SAEG, NEG               | -      | -0.01        |
|                               |          |               | HALT                                                              | -      | 100          |
| OUTPUT CURRENT FOR HIGH STATE | $I_{OH}$ | mAmps         | $\alpha_1, 3$ and $\alpha_2, 4$                                   | -      | 10           |
|                               |          |               | CLAMP                                                             | -      | -            |
| INPUT CAPACITANCE             | $C_I$    | $\mu\text{F}$ | MB 0-15, I O CLOCK, I O DATA 1, I O DATA 2                        | -      | -            |
|                               |          |               | EXTINT, DCH INT                                                   | -      | -            |

## NOTE

Logic "1" is defined as the more positive voltage as are the maximum figures given under voltage limits. Logic "0" is defined as the more negative voltage as are the minimum figures given under voltage limits.

Positive current, in the conventional sense, is defined as flowing into the pin.

On power-up,  $V_{BB}$  must be within its specified operating range (with respect to  $V_{SS}$ ) before any of the other power supply voltages are applied to the circuit.

**ABSOLUTE MAXIMUM RATINGS** (beyond which the useful life of the device may be impaired)

|                                             |                   |  |  |
|---------------------------------------------|-------------------|--|--|
| Storage Temperature                         | -65° to 150°C     |  |  |
| Ambient Temperature Under Bias              | -55 to +125°C     |  |  |
| V <sub>CC</sub> Pin Potential to Ground Pin | -0.5 to +6.0 V    |  |  |
| Input Voltage (dc)                          | -0.5 to +5.5 V    |  |  |
| Input Current (dc)                          | -20 to +5 mA      |  |  |
| Output Voltage (Output HIGH)                | -0.5 to +5.5 V    |  |  |
| Output Current (dc) (Output LOW)            | +20 mA<br>+500 mA |  |  |
| Injector Current (I <sub>INJ</sub> )        | -0.5 to +1.5 V    |  |  |
| Injector Voltage (V <sub>INJ</sub> )        |                   |  |  |

**DC CHARACTERISTICS OVER OPERATING TEMPERATURE RANGE (0 to 75°C)**I<sub>INJ(min)</sub> = 300 mA, I<sub>INJ(max)</sub> = 400 mA, V<sub>CC(min)</sub> = 4.75 V, V<sub>CC(max)</sub> = 5.25 V

| SYMBOL           | CHARACTERISTIC                                                                                      | LIMITS |       |       | UNITS | TEST CONDITIONS                                                                  |
|------------------|-----------------------------------------------------------------------------------------------------|--------|-------|-------|-------|----------------------------------------------------------------------------------|
|                  |                                                                                                     | MIN    | TYP   | MAX   |       |                                                                                  |
| V <sub>IH</sub>  | Input HIGH Voltage                                                                                  | 2.0    |       |       | V     | Guaranteed Input HIGH Voltage                                                    |
| V <sub>IL</sub>  | Input LOW Voltage                                                                                   |        |       | 0.8   | V     | Guaranteed Input LOW Voltage                                                     |
| V <sub>CD</sub>  | Input Clamp Diode Voltage                                                                           |        | -0.9  | -1.5  | V     | V <sub>CC</sub> = 4.75 V, I <sub>IN</sub> = -18 mA<br>I <sub>INJ</sub> = 300 mA  |
| V <sub>OH</sub>  | Output HIGH Voltage<br>RUN, CARRY, INT ON, SYN, CLK OUT, O <sub>0</sub> , O <sub>1</sub>            | 2.4    | 3.4   |       | V     | V <sub>CC</sub> = 4.75 V, I <sub>OH</sub> = -400 μA<br>I <sub>INJ</sub> = 300 mA |
|                  | Output HIGH Voltage<br>IB <sub>0</sub> - IB <sub>15</sub>                                           | 2.4    | 3.4   |       | V     | V <sub>CC</sub> = 4.75 V, I <sub>OH</sub> = -1.0 mA<br>I <sub>INJ</sub> = 300 mA |
| I <sub>CEx</sub> | Output Leakage M <sub>0</sub> , M <sub>1</sub> , M <sub>2</sub>                                     |        |       | 1.0   | mA    | V <sub>CC</sub> = 4.75 V, V <sub>OH</sub> = 5.25 V<br>I <sub>INJ</sub> = 300 mA  |
| V <sub>OL</sub>  | Output LOW Voltage                                                                                  |        | 0.25  | 0.5   | V     | V <sub>CC</sub> = 4.75 V, I <sub>OL</sub> = 8.0 mA<br>I <sub>INJ</sub> = 300 mA  |
| I <sub>IH</sub>  | Input HIGH Current<br>C <sub>0</sub> - C <sub>3</sub> , DCH REQ, INT REQ, MBSY, MR                  |        | 1.0   | 20    | μA    | V <sub>CC</sub> = 5.25 V, V <sub>IN</sub> = 2.7 V<br>I <sub>INJ</sub> = 300 mA   |
|                  | Input HIGH Current<br>CP                                                                            |        | 2.0   | 40    | μA    | V <sub>CC</sub> = 5.25 V, V <sub>IN</sub> = 2.7 V<br>I <sub>INJ</sub> = 300 mA   |
|                  | Input HIGH Current<br>IB <sub>0</sub> - IB <sub>15</sub> (3-State)                                  |        | 5.0   | 100   | μA    | V <sub>CC</sub> = 4.75 V, V <sub>IN</sub> = 2.7 V<br>I <sub>INJ</sub> = 300 mA   |
|                  | Input HIGH Current<br>All Inputs                                                                    |        |       | 1.0   | mA    | V <sub>CC</sub> = 4.75 V, V <sub>IN</sub> = 5.5 V<br>I <sub>INJ</sub> = 300 mA   |
| I <sub>IL</sub>  | Input LOW Current<br>All inputs except CP                                                           |        | -0.21 | -0.36 | mA    | V <sub>CC</sub> = 5.25 V, V <sub>IN</sub> = 0.4 V<br>I <sub>INJ</sub> = 300 mA   |
|                  | Input LOW Current<br>CP                                                                             |        | -0.42 | -0.72 | mA    | V <sub>CC</sub> = 5.25 V, V <sub>IN</sub> = 0.4 V<br>I <sub>INJ</sub> = 300 mA   |
| I <sub>OZH</sub> | OFF State (High Impedance)<br>Output Current IB <sub>0</sub> - IB <sub>15</sub>                     |        |       | 100   | μA    | V <sub>CC</sub> = 5.25 V, V <sub>OUT</sub> = 2.4 V<br>I <sub>INJ</sub> = 300 mA  |
| I <sub>OZL</sub> | OFF State (High Impedance)<br>Output Current IB <sub>0</sub> - IB <sub>15</sub>                     |        | -0.21 | -0.36 | mA    | V <sub>CC</sub> = 5.25 V, V <sub>OUT</sub> = 0.4 V<br>I <sub>INJ</sub> = 300 mA  |
| I <sub>OS</sub>  | Output Short Circuit Current<br>All Outputs Except M <sub>0</sub> , M <sub>1</sub> , M <sub>2</sub> | -15    |       | -100  | mA    | V <sub>CC</sub> = 5.25 V, V <sub>OUT</sub> = 0.0 V<br>I <sub>INJ</sub> = 300 mA  |
| I <sub>CC</sub>  | Supply Current                                                                                      |        | 150   | 200   | mA    | V <sub>CC</sub> = 5.25 V                                                         |
| V <sub>INJ</sub> | Injector Voltage                                                                                    |        | 1.0   |       | V     | I <sub>INJ</sub> = 300 mA                                                        |

## AC CHARACTERISTICS: TA = 0 to 75°C — Figures 8 &amp; 9

| SYMBOL | CHARACTERISTIC                                                                 | LIMITS-ns |      |     | NOTE        |
|--------|--------------------------------------------------------------------------------|-----------|------|-----|-------------|
|        |                                                                                | MIN       | TYP  | MAX |             |
| tCPSYL | Propagation Delay, CLOCK to SYN going LOW                                      |           | 150  |     |             |
| tCPSYH | Propagation Delay, CLOCK to SYN going HIGH                                     |           | 160  |     |             |
| tMBSYL | Propagation Delay, MBSY going HIGH to SYN going LOW                            |           | 70   |     |             |
| tMBW   | MBSY Min Pulse Width (HIGH)                                                    |           | 30   |     |             |
| tMBS   | Set-up Time, MBSY HIGH to CLOCK                                                |           | -40  |     |             |
| tMBHD  | Hold Time, MBSY HIGH after CLOCK                                               |           | 60   |     |             |
| tCPMH  | Propagation Delay, CLOCK to $\bar{M}_2$ , $\bar{M}_1$ , $\bar{M}_0$ going HIGH |           | 160  |     |             |
| tCPML  | Propagation Delay, CLOCK to $\bar{M}_2$ , $\bar{M}_1$ , $\bar{M}_0$ going LOW  |           | 170  |     |             |
| tCPOH  | Propagation Delay, CLOCK to $O_1$ , $O_0$ going HIGH                           |           | 160  |     | Fig. 9 Only |
| tCPOL  | Propagation Delay, CLOCK to $O_1$ , $O_0$ going LOW                            |           | 170  |     | Fig. 8 Only |
| tCPAH  | Propagation Delay, CLOCK to ADDRESS $\bar{I}_{B0-15}$ going HIGH               |           | 170  |     |             |
| tCPAL  | Propagation Delay, CLOCK to ADDRESS $\bar{I}_{B0-15}$ going LOW                |           | 180  |     |             |
| tMBAF  | Propagation Delay, CLOCK to ADDRESS $\bar{I}_{B0-15}$ going 3-state            |           | 110  |     |             |
| tDS    | Set-up Time, DATA $\bar{I}_{B0-15}$ to CLOCK                                   |           | -110 |     |             |
| tDHD   | Hold Time, DATA $\bar{I}_{B0-15}$ after CLOCK                                  |           | 130  |     |             |
| tCS    | Set-up Time, $C_3$ , $C_2$ , $C_1$ , $C_0$ to CLOCK                            |           | -110 |     |             |
| tCHD   | Hold Time, $C_3$ , $C_2$ , $C_1$ , $C_0$ after CLOCK                           |           | 130  |     |             |
| tCPRH  | Propagation Delay, CLOCK to RUN HIGH                                           |           | 160  |     |             |
| tCPRL  | Propagation Delay, CLOCK to RUN LOW                                            |           | 170  |     |             |
| tDCS   | Set-up Time, DCH REQ to CLOCK                                                  |           | -110 |     |             |
| tDCHD  | Hold Time, DCH REQ after CLOCK                                                 |           | 130  |     |             |
| tIS    | Set-up Time, INT REQ to CLOCK                                                  |           | -100 |     |             |
| tIHd   | Hold Time, INT REQ after CLOCK                                                 |           | 120  |     |             |
| tCPCYH | Propagation Delay, CLOCK to CARRY HIGH                                         |           | 160  |     |             |
| tCPCYL | Propagation Delay, CLOCK to CARRY LOW                                          |           | 150  |     |             |
| tCPIOH | Propagation Delay, CLOCK to INT ON HIGH                                        |           | 200  |     |             |
| tCPIOL | Propagation Delay, CLOCK to INT ON LOW                                         |           | 190  |     |             |

## NOTES:

1. The Information Bus is driven as a result of the previous cycle.
2. The Fetch and Read cycles will be stretched out for slower memories.
3. Applies to console operation using this cycle type.

Fig. 8 Only



**Fig. 8 Fetch Cycle**



**RUN, DCH REQ, INT REQ, CARRY, INT ON**  
unaffected during this cycle.

**Fig. 9 Read Cycle**

AC CHARACTERISTICS:  $T_A = 0$  to  $75^\circ\text{C}$  — Figures 10 & 11

| SYMBOL | CHARACTERISTIC                                                           | LIMITS-ns |      |     | NOTE         |
|--------|--------------------------------------------------------------------------|-----------|------|-----|--------------|
|        |                                                                          | MIN       | TYP  | MAX |              |
| tCPSYL | Propagation Delay, CLOCK to SYN going LOW                                |           | 150  |     |              |
| tCPSYH | Propagation Delay, CLOCK to SYN going HIGH                               |           | 160  |     |              |
| tMBSYL | Propagation Delay, MBSY going HIGH to SYN going LOW                      |           | 70   |     |              |
| tMBW   | MBSY Min Pulse Width (HIGH)                                              |           | 30   |     |              |
| tMBS   | Set-up Time, MBSY LOW to CLOCK                                           |           | -40  |     |              |
| tMBHD  | Hold Time, MBSY LOW after CLOCK                                          |           | 60   |     |              |
| tCPMH  | Propagation Delay, CLOCK to $\bar{M}_2, \bar{M}_1, \bar{M}_0$ going HIGH |           | 160  |     |              |
| tCPML  | Propagation Delay, CLOCK to $\bar{M}_2, \bar{M}_1, \bar{M}_0$ going LOW  |           | 170  |     |              |
| tCPOH  | Propagation Delay, CLOCK to $O_1, O_0$ going HIGH                        |           | 160  |     |              |
| tCPOL  | Propagation Delay, CLOCK to $O_1, O_0$ going LOW                         |           | 170  |     |              |
| tCPDH  | Propagation Delay, CLOCK to DATA $\bar{I}B_{0-15}$ going HIGH            |           | 170  |     | Fig. 10 Only |
| tCPDL  | Propagation Delay, CLOCK to DATA $\bar{I}B_{0-15}$ going LOW             |           | 180  |     |              |
| tCPDF  | Propagation Delay, CLOCK to DATA $\bar{I}B_{0-15}$ going 3-state         |           | 110  |     |              |
| tCPAH  | Propagation Delay, CLOCK to ADDRESS $\bar{I}B_{0-15}$ going HIGH         |           | 170  |     |              |
| tCPAL  | Propagation Delay, CLOCK to ADDRESS $\bar{I}B_{0-15}$ going LOW          |           | 180  |     | Fig. 11 Only |
| tCPAF  | Propagation Delay, CLOCK to ADDRESS $\bar{I}B_{0-15}$ going 3-state      |           | 160  |     |              |
| tCS    | Set-up Time, $C_3, C_2, C_1, C_0$ to CLOCK                               |           | -110 |     |              |
| tCHD   | Hold Time, $C_3, C_2, C_1, C_0$ after CLOCK                              |           | 130  |     |              |

## NOTES:

- 3. Applies to console operation using this cycle type.
- 4. The Information Bus is driven as a result of the previous cycle.
- 5. The 9440 waits for MBSY to go LOW. By holding MBSY HIGH, the user may idle the processor.



Fig. 10 Write Cycle



Fig. 11 Load Memory Address Register Cycle



Fig. 12 I/O Out Cycle

AC CHARACTERISTICS:  $T_A = 0$  to  $75^\circ C$  — Figures 12, 13, 14, 15

| SYMBOL | CHARACTERISTIC                                                           | LIMITS-ns |     |     | NOTE         |
|--------|--------------------------------------------------------------------------|-----------|-----|-----|--------------|
|        |                                                                          | MIN       | TYP | MAX |              |
| tCPSYL | Propagation Delay, CLOCK to SYN going LOW                                |           | 150 |     |              |
| tCPSYH | Propagation Delay, CLOCK to SYN going HIGH                               |           | 160 |     |              |
| tCPMH  | Propagation Delay, CLOCK to $\bar{M}_2, \bar{M}_1, \bar{M}_0$ going HIGH |           | 160 |     |              |
| tCPML  | Propagation Delay, CLOCK to $\bar{M}_2, \bar{M}_1, \bar{M}_0$ going LOW  |           | 170 |     |              |
| tCPOH  | Propagation Delay, CLOCK to $O_1, O_0$ going HIGH                        |           | 160 |     |              |
| tCPOL  | Propagation Delay, CLOCK to $O_1, O_0$ going LOW                         |           | 170 |     |              |
| tCPDH  | Propagation Delay, CLOCK to DATA $\bar{I}_{B0-15}$ going HIGH            |           | 170 |     | Fig. 12 Only |
| tCPDL  | Propagation Delay, CLOCK to DATA $\bar{I}_{B0-15}$ going LOW             |           | 180 |     |              |
| tCPDF  | Propagation Delay, CLOCK to DATA $\bar{I}_{B0-15}$ going 3-state         |           | 110 |     |              |
| tDS    | Set-up Time, DATA $\bar{I}_{B0-15}$ to CLOCK                             | -110      |     |     | Fig. 13 Only |
| tDHD   | Hold Time, DATA $\bar{I}_{B0-15}$ after CLOCK                            | 130       |     |     |              |
| tCS    | Set-up Time, $C_3, C_2, C_1, C_0$ to CLOCK                               | -110      |     |     | Fig. 14 Only |
| tCHD   | Hold Time, $C_3, C_2, C_1, C_0$ after CLOCK                              | 130       |     |     |              |

## NOTES:

6. During  $\bar{DCH}$ , the 9440 is not driving the  $\bar{M}$  lines. An external device can control the memory when a LOW is applied to the appropriate  $\bar{M}$  line.  
 7. The 9440 floats the  $\bar{I}_{B0-15}$ . The Information Bus is available to the I/O devices and the memory as needed.



Fig. 13 I/O In Cycle



Fig. 14 Wait Cycle



Fig. 15 Data Channel Request Cycle

# Chapter 20

## THE INTEL 8086

**The 8086 is Intel's first 16-bit microprocessor. It is significantly more powerful than any prior microprocessor.**

**The 8086 assembly language instruction set is upward compatible with 8080A — but at the source program level only.** That is to say, every 8080A assembly language instruction can be converted into one or more 8086 assembly language instructions. There is no reason why anyone would try to convert 8086 assembly language instructions, one at a time, into one or more 8080A assembly language instructions, but if you did, you would soon become hopelessly tangled in conflicting memory allocations and special translation rules. That is why we say that the 8086 and 8080A assembly language instruction sets are "upward" compatible.

The 8086 and 8080A assembly language instruction sets are not compatible at the object code level, which means that 8080A programs stored in read-only memory are useless in an 8086 system.

The 8085 and 8080A assembly language instruction sets are identical, with the exception of the 8085 RIM and SIM instructions. The 8085 RIM and SIM instructions cannot be translated into 8086 instructions. This is because the RIM and SIM instructions use the serial I/O logic of the 8085, which has no 8086 counterpart. Without the RIM and SIM instructions, the 8085 and 8080A assembly language instruction sets are identical; therefore **the 8086 assembly language instruction set must also be upward compatible with the 8085 assembly language instruction set — apart from the RIM and SIM instructions.**

The 8085 and 8080A assembly language instruction sets are object code compatible — with the exception of the 8085 RIM and SIM instructions. That is to say, a program existing in read-only memory could be used with one microprocessor or the other.

The 8080A assembly language instruction set is a subset of the Z80 assembly language instruction set. That is to say, the Z80 will execute an 8080A object program — but the reverse is not true. The 8080A cannot execute Z80 programs when the full Z80 instruction set is used. **The 8086 assembly language instruction set is not upward compatible with the Z80 assembly language instruction set.**

As a historical note, it is worth mentioning that the 8008 microprocessor, which preceded the 8080A, was also compatible only at the source program level. That is to say, there is an 8080A assembly language instruction for every 8008 assembly language instruction, but the two microprocessor object code sets are not the same.

**The various instruction set compatibilities that we have described may be illustrated as follows:**



**These are the most interesting innovations to be found in 8086 hardware design:**

- 1) 8086 Central Processing Unit logic has been divided into an Execution Unit (EU) and a Bus Interface Unit (BIU). These two halves operate asynchronously. The Bus Interface Unit handles all interfaces with the external bus; it generates external memory and I/O addresses and has a 6-byte instruction object code queue. Whenever the EU needs to access memory or an I/O device, it makes a bus access request to the Bus Interface Unit. Providing the Bus Interface Unit is not currently busy, it acknowledges the bus access request from the EU. When the Bus Interface Unit has no active pending bus access requests from the EU, it performs instruction fetch machine cycles to fill the 6-byte instruction object code queue. The CPU takes its instruction object codes from the front of the queue. Thus instruction fetch time is largely eliminated.
- 2) The 8086 has been designed to work in a wide range of microcomputer system configurations, ranging from a simple one-CPU system to a multiple-CPU network. To support this wide flexibility, a number of 8086 pins output alternate signals. This may be illustrated as follows:



The same pins output these two sets of signals, based on a level of MN/MX. This wholesale re-allocation of signals is a highly imaginative and innovative first for the microprocessor industry.

- 3) The 8086 has built-in logic to handle bus access priorities in multi-CPU configurations. (This is not a new concept; National Semiconductor's SC/MP has had it for years.)
- 4) In multi-CPU configurations, each 8086 CPU can have its own local memory, while simultaneously sharing common memory. The common memory may be shared by all CPUs, or by selected CPUs.
- 5) The 8086 has been designed to compete effectively in program intensive applications that have been the domain of the minicomputer. Up to a million bytes of external memory can be addressed directly. All memory addressing is base relative; this memory addressing technique naturally generates relocatable object programs. (Relocatable object programs can be moved from one memory address space to another and re-executed without modification.) Also, since the 8086 utilizes stack-relative addressing, re-entrant programs are easily written. (Re-entrant programs can be interrupted in mid-execution and re-executed. For example, a subroutine which calls itself is re-entrant; a program which can be interrupted in mid-execution by an external interrupt, and then re-executed within the interrupt service routine, is also re-entrant.)
- 6) The 8086 uses prefix instructions that modify the interpretation of the next instruction's object code.

**The 8086, like its predecessor, the 8080A, is really one component of a multiple-chip microprocessor configuration.**

**In addition to the 8086 microprocessor itself, you must have an 8284 Clock Generator/Driver.** You could create the required clock signal using alternative logic, but it would be neither practical nor economical to do so.

**The third device necessary in some 8086 microprocessor configurations is the 8288 Bus Controller.**

You will usually have an 8288 Bus Controller between an 8086 and its System Bus (or busses), just as you will usually have an 8228 System Bus controller between an 8080A and its System Bus. In the case of the 8086, however, you can dispense with the 8288 Bus Controller in single-bus configurations — and pay no penalty for it.

The 8086 has a large family of support devices. Most of these support devices are not yet available. In this chapter we describe the following support devices:

- The 8282/8283 8-bit input/output ports
- The 8284 Clock Generator/Driver
- The 8286/8287 8-bit parallel bidirectional bus drivers
- The 8288 Bus Controller

The only manufacturer of the 8086 is:

INTEL CORPORATION  
3065 Bowers Avenue  
Santa Clara, CA 95051

It is probable that Advanced Micro Devices will become a second source for this part within the U.S.A., while Siemens AG becomes the second source in Europe.

The 8086 is manufactured using N-channel depletion load, silicon gate technology. It is packaged in a 40-pin DIP. A single +5V power supply is required. All signals, with the exception of the clock input, are TTL-compatible. The clock input must be an MOS level signal; it is generated by the 8284 Clock Generator/Driver device, which is described later in this chapter.

Instruction execution times will vary depending on how effectively instruction queuing is used. Typically, between 2 and 30 clock cycles are required to execute an instruction. Multiplication and division instructions require more execution time. Clock cycles may be as short as 125 nanoseconds. Future versions of the 8086 will likely allow faster clocks.

## THE 8086 CPU

**Functions implemented on the 8086 microprocessor chip are illustrated in Figure 20-1.**

Interrupt priority arbitration logic is shown as only half present; external logic, such as an 8259A, must provide a device code identifying an interrupt, but all arbitration and vectoring logic is subsequently handled by logic within the CPU.

It is worth noting that bus interface logic, which is shown as present in Figure 20-1, is much more extensive than other microprocessors provide. One could rightfully demand that bus interface logic therefore be shown as absent in equivalent figures for other microprocessors.

### 8086 PROGRAMMABLE REGISTERS AND ADDRESSING MODES

We describe 8086 programmable registers in conjunction with 8086 addressing modes, since many 8086 programmable registers are there only to support memory addressing logic. 8086 programmable registers are illustrated in Figure 20-2.

Shaded registers are 8086 equivalents for 8080A registers. 8080A register names are shown in the left margin.

**Let us first examine the general purpose registers, AX, BX, CX and DX.** These locations are treated as four 16-bit registers or eight 8-bit registers; they also reproduce the 8080A general purpose registers as follows:

AH has no 8080A equivalent. Do not confuse it with the 8080A PSW.

**8086 AND  
8080A  
REGISTERS'  
COMPAT-  
IBILITY**

AL is equivalent to the 8080A A register  
BH is equivalent to the 8080A H register  
BL is equivalent to the 8080A L register  
CH is equivalent to the 8080A B register  
CL is equivalent to the 8080A C register  
DH is equivalent to the 8080A D register  
DL is equivalent to the 8080A E register

Consistent with 8080A register utilization, **register AX serves as a primary Accumulator.** Input and output instructions pass data through AX (or AL) in preference to other general purpose registers; also, selected instruction access AX (or AL) contents only.

**8086 AX  
REGISTER**

**In addition to serving as a general purpose Accumulator, register BX can serve as a base register when computing data memory addresses.**

**8086 BX  
REGISTER**



Figure 20-1. Logic of the Intel 8086 CPU



Figure 20-2. 8086 Programmable Registers

**Register CX** serves as an Accumulator; it is also used as a counter by multi-iteration instructions; these instructions terminate execution when register CX contents increment or decrement to 0.

Some I/O instructions move data between an identified I/O port and the memory location addressed by register DX. Register DX may also serve as an Accumulator.

When looking at general purpose registers AX, BX, CX and DX, there is plenty of opportunity to be confused by terminology.

Intel literature identifies the four 16-bit registers via the labels AX, BX, CX and DX. Each of these 16-bit registers is subdivided by Intel literature into two 8-bit registers, as follows:

|          |
|----------|
| 8086     |
| CX       |
| REGISTER |
| 8086     |
| DX       |
| REGISTER |



The 8080A Accumulator must be reproduced by AL, since selected 8080A and 8086 instructions access this register and none other.

BH and BL must reproduce the 8080A H and L registers, since only BX can contribute to an 8086 data memory address. On the surface this would appear to present a problem, since the 8080A has a limited number of instructions which use the BC and DE registers to provide 16-bit memory addresses. When 8080A source programs are reassembled to execute on an 8086 microprocessor, 8080A instructions that seek memory addresses out of the BC or DE registers become 8086 instructions that use Index registers.

**All 8086 memory addresses are computed by summing the contents of a Segment register and an effective memory address.** The effective memory address is computed via a variety of addressing modes, as it would be for any other microprocessor. The selected Segment register contents are left-shifted four bits, then added to the effective memory address to generate the actual address output as follows:

**8086  
SEGMENT  
REGISTERS**

$$\begin{array}{r}
 \text{Segment Register contents:} \quad \text{XXXXXXXXXXXXXXX X 0 0 0} \\
 \text{Effective memory address:} \quad + \quad \underline{\text{0 0 0 YYYYYYYYYYYY}} \\
 \text{Actual address output:} \quad \text{Z Z Z Z Z Z Z Z Z Z Z Z Z Y Y Y Y}
 \end{array}$$

X, Y and Z represent any binary digits.

Thus a 20-bit memory address is computed — which allows 1,048,576 bytes of external memory to be addressed directly.

The Segment registers of the 8086 are unlike any other microprocessor registers described in this book. They act as base registers which can point to any memory location that lies on an address boundary that is an even multiple of 16 bytes. Using arbitrary memory addresses, this may be illustrated as follows:



As illustrated above, each Segment register identifies the beginning of a 65,536-byte memory segment. Since the 8086 has four Segment registers, there will at any time be four selected 65,536-byte memory segments. The actual address output will always select a memory location within one of these four segments. For example, if an actual address output is the sum of the DS Segment register and an effective memory address, then the actual address output must select a memory location within the DS segment; that is to say, within the address range  $021F0_{16}$  through  $121EF_{16}$  in the illustration above. Likewise, an actual address output which is the sum of the CS Segment register and an effective memory address must select a memory location within the CS segment, which in the illustration above will lie in the address range  $234E0_{16}$  through  $334DF_{16}$ .

No restrictions are placed on the contents of Segment registers. Therefore 8086 memory is not divided into 65,536-byte pages, nor do the four Segment registers have to specify non-overlapping memory spaces. Each Segment register identifies the origin of a 65,536-byte memory segment which may lie anywhere within addressable memory, and may or may not overlap with one or more other segments.

Even though Segment registers can create overlapping or non-overlapping segments, they do have dedicated addressing functions. That is to say, **different types of memory accesses compute memory address within specific segments.**

**During an instruction fetch, the Program Counter contents are added to the Code Segment register (CS) contents in order to compute the memory address for the instruction to be fetched.** This may be illustrated as follows:

**8086 CODE  
SEGMENT  
REGISTER  
AND PROGRAM  
COUNTER**



M, N and P represent any hexadecimal digits.

**Any Stack instruction** such as a push, pop, call or return **adds the Stack Pointer contents to the Stack Segment register (SS) contents** in order to compute the address of the Stack location to be accessed. This may be illustrated as follows:

**8086 STACK SEGMENT AND STACK POINTER REGISTERS**



Once again, M, N and P represent any hexadecimal digits.

**Instructions that process data strings use the SI and DI Index registers, together with the Data Segment register (DS) and the Extra Segment register (ES), in order to identify string source and destination addresses.** This may be illustrated as follows:

**8086 EXTRA SEGMENT, SOURCE INDEX AND DESTINATION INDEX REGISTERS**



J, K, M, R and S all represent any hexadecimal digits.

As the above illustration would imply, instructions that process strings require that the source and destination strings reside within a single 65,536-byte address range, but not necessarily the same 65,536-byte range.

**Instructions that access data memory add an effective memory address to the Data Segment register (DS) or the Stack Segment register (SS).** This may be illustrated as follows:

**8086  
DATA  
SEGMENT AND  
STACK SEG-  
MENT  
REGISTERS**



X, Y and Z represent any hexadecimal digits.

When a data memory address is created, as illustrated above, the BX, BP, SI and DI registers' contents, plus a displacement coming from the instruction object code, may contribute to the effective memory address. There are, however, very specific register and displacement combinations that can create an effective memory address, as summarized in Table 20-1. Each case specifies either the DS or SS register as the default source for the segment base address.

Table 20-1. A Summary of Intel 8086 Memory Addressing Options

| MEMORY<br>REFERENCE                | SEGMENT<br>REGISTER              | BASE<br>REGISTER | INDEX<br>REGISTER | POSSIBLE DISPLACEMENTS |                                     |      |
|------------------------------------|----------------------------------|------------------|-------------------|------------------------|-------------------------------------|------|
|                                    |                                  |                  |                   | 16-BIT<br>UNSIGNED     | 8-BIT<br>HIGH ORDER BIT<br>EXTENDED | NONE |
| NORMAL DATA<br>MEMORY<br>REFERENCE | DS<br>(Alternate*: CS, SS or ES) | None             | SI                | X                      | X                                   | X    |
|                                    |                                  |                  | DI                | X                      | X                                   | X    |
|                                    |                                  | BX               | SI                | X                      | X                                   | X    |
|                                    |                                  |                  | DI                | X                      | X                                   | X    |
|                                    | DS                               | None             | None              | X                      | X                                   | X    |
|                                    |                                  |                  | SI                | X                      | X                                   | X    |
|                                    |                                  |                  | DI                | X                      | X                                   | X    |
|                                    | SS<br>(Alternate*: CS, DS or ES) | BP               | None              | X                      | X                                   | X    |
| STACK                              | SS                               | SP               | None              |                        |                                     |      |
| STRING<br>DATA                     | ES                               | None             | SI                |                        |                                     |      |
| INSTRUCTION<br>FETCH               | CS                               | PC               | None              |                        |                                     |      |
| BRANCH                             | CS                               | PC               | None              |                        | X                                   |      |
| I/O DATA                           | DS                               | DX               | None              |                        |                                     |      |

\* The segment override allows DS or SS to be replaced by one of the other segment registers

X These are displacements that can be used to compute memory addresses.

When creating any data memory address, you can execute an extra instruction to select a Segment register other than the default Segment register. You can only select a Segment register other than the default Segment register when addressing data memory. You must live with the default Segment register when creating program memory addresses, Stack addresses, or string instruction addresses.

**It is very important to note that the 8086 has a whole set of data memory addressing options aimed at accessing the Stack as though it were a data area.** That is to say, in addition to the normal "Push" and "Pop" type Stack instructions, the 8086 allows normal data memory accesses instructions to address the Stack. Many assembly language programmers use the Stack to store addresses, and as a general depository for data which must be transmitted between program modules. Anyone favoring this assembly language programming philosophy will be delighted with 8086 data memory addressing options.

Let us now examine the various data memory addressing options in detail. Refer to Table 20-1.

In the simplest case, we have straightforward direct memory addressing. A 16-bit displacement provided by two instruction object code bytes is added to the Data Segment register in order to create the actual memory address. This may be illustrated as follows:

**8086 DIRECT  
MEMORY  
ADDRESSING**



H, L, M, N, P, R and S all represent any hexadecimal digits.

Note that a 16-bit address displacement, when stored in program memory, has the low-order byte preceding the high-order byte. This is consistent with the way the 8080A stores addresses in program memory.

DS must provide the Segment base address when addressing data memory directly, as illustrated above.

**Direct, indexed addressing is also provided.** The SI or DI register may be selected as the Index register. You have the option of adding a displacement to the contents of the selected Index register in order to generate the effective address. **If you do not add a displacement, then you have, in effect, implied memory addressing via the SI or DI register.** This may be illustrated as follows:

**8086  
IMPLIED  
MEMORY  
ADDRESSING**



(You may substitute CS, SS or ES for DS by executing an additional 1-byte instruction.)

X, R and S represent any hexadecimal digits.

**If a displacement is added to the contents of the selected Index register, then you may specify an 8-bit displacement or a 16-bit displacement.** A 16-bit displacement is stored in two object code bytes; the low-order byte of the displacement precedes the high-order byte of the displacement, as illustrated for direct memory addressing. If an 8-bit displacement is specified, then the high-order bit of the low-order byte is propagated into the high-order byte to create a 16-bit displacement. This may be illustrated as follows:

**8086 DIRECT,  
INDEXED  
ADDRESSING**

|                |                 |                 |                 |               |
|----------------|-----------------|-----------------|-----------------|---------------|
| Displacements: | 1 0 1 1 0 1 0 1 | 0 1 1 0 1 0 1 1 |                 |               |
| Sign extended: | 1 1 1 1 1 1 1 1 | 0 1 1 0 1 0 1   | 0 0 0 0 0 0 0 0 | 1 1 0 1 0 1 1 |

We may now illustrate direct, indexed addressing as follows:



(You may substitute CS, SS or ES for DS by executing an additional 1-byte instruction.)

M, N, P, R, X, Y and Z all represent any hexadecimal digits.

YYYY is the 16-bit or 8-bit displacement taken from program memory.

XXXX is the index taken from either the DI or the SI register.

**The effective memory address can be computed using base relative addressing. You have two sets of base relative addressing options:**

- 1) Data memory base relative addressing, which is within the DS segment (data memory).
- 2) Stack base relative addressing, which is in the SS segment (Stack memory).

**Data memory base relative addressing uses the BS register contents to provide the base for the effective address. All of the data memory addressing options thus far described are available with base relative data memory addressing. In effect, base relative data memory addressing merely adds the contents of the BX register to the effective memory address which would otherwise have been generated.** Here, for example, is an illustration of base relative direct addressing:

|                                                  |
|--------------------------------------------------|
| <b>8086 BASE RELATIVE, INDEXED ADDRESSING</b>    |
| <b>8086 DATA MEMORY BASE RELATIVE ADDRESSING</b> |



(You may substitute CS, ES or SS for DS by executing an additional 1-byte instruction.)

Simple, direct addressing, which we described earlier, always generated a 16-bit displacement. Base relative, direct addressing allows the displacement, illustrated above as HHLL, to be a 16-bit displacement, an 8-bit displacement with sign extended, or no displacement at all.

Base relative implied data memory addressing simply adds the contents of the BX register to the selected Index register in order to compute the effective memory address. This may be illustrated as follows:



(You may substitute CS, SS or ES for DS by executing an additional 1-byte instruction.)

Base relative, direct, indexed data memory addressing may appear to be complicated, but in fact it is not. We simply add the contents of the BX register to the effective memory address, as computed for normal direct, indexed addressing. Thus, base relative, direct, indexed data memory addressing may be illustrated as follows:



(You may substitute CS, s or ES for DS by executing an additional 1-byte instruction.)

The 8086 also has Stack memory addressing variations of the base relative, data memory addressing options just described. Here, for example, is base relative, direct Stack memory addressing:



(You may substitute CS, ES or SS for DS by executing an additional 1-byte instruction.)

In the illustration above, the displacement HHLL must be present, either as a 16-bit displacement, or as an 8-bit displacement with sign extended. Remember, base relative, direct data memory addressing also allows no displacement. However, base relative, direct Stack memory addressing requires a displacement. These options are summarized in Table 20-1.

Here is an illustration of base relative implied Stack memory addressing:



(You may substitute CS, DS or ES for SS by executing an additional 1-byte instruction.)

X, R and S represent any hexadecimal digits.

Here is an illustration of base relative, direct, indexed Stack memory addressing:



(You may substitute CS, DS or ES for SS by executing an additional 1-byte instruction.)

There is one anomalous 8086 addressing mode which can cause confusion. **One variation of I/O instructions addresses an I/O port via the DX register.** The DX register contents are output on the Address Bus, to be interpreted as an I/O port address. This means you can have up to 65,536 I/O port addresses. Since the DX register contents are being output as an I/O port address, it is not added to any Segment register contents. Thus, the DX register outputs an address in the range  $0000_{16}$  through  $FFFF_{16}$ . This is the only case in which a register's contents are output directly as an address on the Address Bus, without first passing through segmentation logic.

### 8086 I/O PORT ADDRESSING

**All 8086 Branch-on-Condition instructions use program relative addressing.** This feature allows dynamically relocatable code. The Branch-on-Condition instruction provides an 8-bit, signed binary displacement which is added to the contents of the Program Counter. Thus, Branch-on-Condition instructions have an addressing range of +128 through -127 bytes from the location of the Branch-on-Condition. **The queuing of instruction object codes has no impact on Branch-on-Condition logic,** or the branch addressing range.

### 8086 PROGRAM RELATIVE ADDRESSING

**8086 Jump and Subroutine Call instructions offer these addressing options:**

- 1) **Program relative addressing.** An 8-bit or 16-bit displacement is added to the contents of the Program Counter.
- 2) **Direct addressing.** New 16-bit addresses provided by the instruction are loaded into the Program Counter and the CS Segment register.
- 3) **Indirect addressing.** Any of the data memory addressing options may be used to read data from data memory. However, the data input is interpreted as a memory address. You have two indirect addressing options. A single 16-bit data word may be read, in which case it is loaded into the Program Counter and the Jump or Call references a memory location within the current CS segment. You can also read two 16-bit data words; the first is loaded into the Program Counter and the second is loaded into the CS Segment register. Thus you can Jump or Call indirectly any addressable memory location.

### 8086 INDIRECT ADDRESSING

## 8086 STATUS

The 8086 has a 16-bit Status register with the following status bit assignments:



**The Carry, Auxiliary Carry, Overflow and Sign statuses are quite standard;** see Volume 1 for a description of these statuses. The Auxiliary Carry status is identical to the 8080A status with the same name. It represents carries out of bit 3 in an 8-bit data unit as described in Volume I, Chapter 2.

**Subtract instructions use two's complement arithmetic in order to subtract the minuend from the subtrahend. However, the Carry status is inverted. That is to say, following a subtract operation, the Carry status is set to 1 if there was no carry out of the high-order bit, and the Carry status is reset to 0 if there was a carry out of the high-order bit. The Carry Status therefore indicates a borrow.**

**The Parity status** is set to 1 when there is an even number of 1 bits in the result of a data operation; an odd number of 1 bits causes the Parity status to be reset to 0.

**The Zero status** is completely standard. It is set to 1 when the result of a data operation is zero; it is set to 0 when the result of a data operation is not zero.

**The Direction status determines whether string operations will auto-increment or auto-decrement the contents of Index registers.** If the Direction status is 1, then the SI and DI Index registers' contents will be decremented; that is to say, strings will be accessed from the highest memory address down to the lowest memory address. If the Direction status is 0, then the SI and DI Index register contents will be incremented; that is to say, strings will be accessed beginning with the lowest memory address.

**The Interrupt status is a master interrupt enable/disable.** This status must be 1 in order to enable interrupts within the 8086. If this status is 0, then all interrupts will be disabled.

**The Trap status is a special debugging aid** which puts the 8086 into a "single step" mode. The single step mode is described in detail together with 8086 interrupt logic, since it depends on this interrupt logic for its existence.

**The Carry, Auxiliary Carry, Parity, Sign and Zero statuses are also found in the 8080A. The Overflow, Direction, Interrupt and Trap statuses are new in the 8086.**

## 8086 CPU PINS AND SIGNALS

8086 CPU pins and signals are illustrated in Figure 20-3.

|      |     |    |    |                 |
|------|-----|----|----|-----------------|
|      | GND | 1  | 40 | V <sub>CC</sub> |
| AD14 | ↔   | 2  | 39 | AD15            |
| AD13 | ↔   | 3  | 38 | A16/S3          |
| AD12 | ↔   | 4  | 37 | A17/S4          |
| AD11 | ↔   | 5  | 36 | A18/S5          |
| AD10 | ↔   | 6  | 35 | A19/S6          |
| AD9  | ↔   | 7  | 34 | BHE/S7          |
| AD8  | ↔   | 8  | 33 | MN/MX           |
| AD7  | ↔   | 9  | 32 | RD              |
| AD6  | ↔   | 10 | 31 | RQ/GT0, HOLD    |
| AD5  | ↔   | 11 | 30 | RQ/GT1, HLDA    |
| AD4  | ↔   | 12 | 29 | LOCK, WR        |
| AD3  | ↔   | 13 | 28 | S2, M/I/O       |
| AD2  | ↔   | 14 | 27 | S1, DT/R        |
| AD1  | ↔   | 15 | 26 | S0, DEN         |
| AD0  | ↔   | 16 | 25 | QS0, ALE        |
| NMI  | →   | 17 | 24 | QS1, INTA       |
| INTR | →   | 18 | 23 | TEST            |
| CLK  | →   | 19 | 22 | READY           |
|      | GND | 20 | 21 | RESET           |

  

| Pin Name              | Description                            | Type                    |
|-----------------------|----------------------------------------|-------------------------|
| AD0-AD15              | Data/Address Bus                       | Bidirectional, tristate |
| A16/S3, A17/S4        | Address/Segment identifier             | Output, tristate        |
| A18/S5                | Address/Interrupt enable status        | Output, tristate        |
| A19/S6                | Address/status                         | Output, tristate        |
| BHE/S7                | High-order byte/status                 | Output, tristate        |
| RD                    | Read control                           | Output, tristate        |
| READY                 | Wait state request                     | Input                   |
| TEST                  | Wait for test control                  | Input                   |
| INTR                  | Interrupt request                      | Input                   |
| NMI                   | Non-maskable interrupt request         | Input                   |
| RESET                 | System Reset                           | Input                   |
| CLK                   | System Clock                           | Input                   |
| MN/MX                 | = GND for a maximum system             |                         |
| S0, S1, S2            | Machine cycle status                   | Output, tristate        |
| RQ/GT0, RQ/GT1        | Local bus priority control             | Bidirectional           |
| QS0, QS1              | Instruction queue status               | Output                  |
| LOCK                  | Bus hold control                       | Output, tristate        |
| MN/MX                 | = V <sub>CC</sub> for a minimum system |                         |
| M/I/O                 | Memory or I/O access                   | Output, tristate        |
| WR                    | Write control                          | Output, tristate        |
| ALE                   | Address Latch enable                   | Output                  |
| DT/R                  | Data transmit/receive                  | Output, tristate        |
| DEN                   | Data enable                            | Output, tristate        |
| INTA                  | Interrupt acknowledge                  | Output                  |
| HOLD                  | Hold request                           | Input                   |
| HLDA                  | Hold acknowledge                       | Output                  |
| V <sub>CC</sub> , GND | Power, ground                          |                         |

Figure 20-3. 8086 Pins and Signal Assignments

The 8086 outputs a 20-bit memory address. Data is accessed as 16-bit words, subdivided into a low-order byte and a high-order byte. Therefore **the 8086 needs a 20-line Address Bus and a 16-line Data Bus**. In order to have a 40-pin package, the **low-order 16 Address Bus lines are multiplexed with the Data Bus**.

**BHE** may be looked upon as an additional Address Bus line, since it is used to identify the high-order byte of a memory word, while ADO identifies the low-order byte of the memory word.

The four high-order Address Bus lines, together with BHE, are multiplexed with five status lines. thus, we can illustrate Address Bus line multiplexing as follows:

| Data/Status      | Address                                        |
|------------------|------------------------------------------------|
| Status           | S7 - BHE High-order byte of selected word      |
| 16-bit data word | D0 - A0 Low-order byte of selected word        |
| Status           | D1 - D15 - A1 - A15 } Address of a 16-bit word |
| Status           | S3 - S6 - A16 - A19 }                          |

It is easy to become confused when looking at how the **Address Bus, together with BHE**, is used to access memory. As seen by external memory, Address Bus lines are interpreted as follows:

**8086  
EXTERNAL  
MEMORY  
ADDRESSING**



In the illustration above you will see that memory is indeed organized as bytes.

The data pins of the low-order byte memory bank connect to AD0-AD7. The high-order byte memory bank data pins connect to AD8-AD15.

The low-order and high-order byte memory banks each have memory select logic which decodes AD1-A19. These 19 address lines become inputs A0-A18 at the illustrated memory select logic. Since each memory bank receives 19 address lines, select logic can address up to 524,288 (512K) bytes of memory. These two memory banks, taken together, constitute the advertised one million bytes of directly addressable memory.

Now, you may well ask why one should bother dividing memory into separate low-order byte and high-order byte banks. If a sixteen-bit word lies on an even-byte address boundary, then we could ignore the memory select logic connections to AD0 and BHE. The address on AD1-A19 becomes an address identifying a 16-bit word which just happens to be implemented as two separate 8-bit memory banks.

If an 8086 16-bit memory word does lie on an even-byte address boundary, then the low-order byte address is, in fact, the only address output. BHE is pulsed low while the low-order byte address is being output, and both memory banks consider themselves selected even though (in theory) the high-order memory bank's address has not been output.

To illustrate what happens, consider the memory addresses  $02A40_{16}$  and  $02A41_{16}$ . One would normally expect the two addresses to be output sequentially in order to access the low-order byte and then the high-order byte of the 16-bit word. This may be illustrated as follows:



But we could just as easily output the low-order byte address only, using BHE as an extra address line to substitute for the odd-byte address — which is never output. This may be illustrated as follows:



If a word lies on an odd-byte address boundary, then two byte addresses must be output to access the two halves of the 16-bit word. This may be illustrated as follows:



When a 16-bit word lies on an odd-byte address boundary, as illustrated above, the low-order byte is input first via AD8-AD15, then the high-order byte is input via AD0-AD7. Logic internal to the 8086 switches the data bytes into their correct locations.

**Intel could have elected to implement external memory as 16-bit words, which would eliminate BHE along with the Address Bus complexities we have just described. But this would have forced all instruction object codes, and data, to be accessed as 16-bit units. Why not do it?**

One of the most interesting hindsight discoveries that 8080A users have made is the fact that the 8080A is extremely efficient in its use of memory. By having a large number of 8-bit object codes, the 8080A generates object programs as compact as the most powerful minicomputers on the market.

But if the 8086 is to keep 8-bit object codes, and therefore the efficient memory utilization of the 8080A, then it can no longer guarantee that data will lie on even-byte address boundaries. The first 8-bit object code will force the next instruction or data entity to begin on an odd-byte boundary.

By including BHE and the extra logic needed to access 16-bit data units originated at odd-byte boundaries, the 8086 has allowed instructions to generate 1-byte, 3-byte or other odd-byte object codes, rather than 2-byte, 4-byte and even-byte object codes only.

**Simply stated, this is the trade-off: simplify memory addressing so that external memory is accessed only as 16-bit data units and you will use memory less efficiently.** Intel elected to make memory addressing logic more complex and memory utilization more efficient.

**Moving on from the Data/Address Bus, 8086 signals may be grouped into those that do not change with system complexity, and those that do. Let us first look at the unchanging signals.**

**CLK** is the single clock signal output by the 8284 clock generator to synchronize all 8086 logic.

**READY** is the Wait state request which slows external logic inputs if it requires more time to respond to an access. A high READY input occurring at the proper time early in a machine cycle causes the 8086 to extend the machine cycle by inserting Wait state clock periods.

**$\overline{RD}$**  is a single bus control signal which does not change with system configuration. This signal is output low when the CPU is inputting data from any external source.

Even though  $\overline{RD}$  is output by the same physical pin under all circumstances, this signal is functionally part of the group which change their nature depending on signal complexity. We will therefore refer again to  $\overline{RD}$  when describing the signals which are a function of system complexity.

#### There are four interrupt and interrupt-related signals.

INTR is a normal interrupt request input.

NMI is a non-maskable interrupt request input.

**RESET** is a system reset signal; it must be input high to the 8284 clock generator for at least four CLK clock periods. The 8284 transmits a synchronized RESET signal to the CPU. When the 8086 is reset, the following events occur:

8086  
RESET

- 1) The Status register is cleared. This disables external interrupts.
- 2) The Program Counter and the three Segment registers, DS, SS, and ES, are cleared.
- 3) The CS Segment register is set to FFFF<sub>16</sub>. Following a Reset, program execution therefore restarts with the instruction located at memory byte FFFF0<sub>16</sub>.

These reset operations take approximately 10 clock periods to occur — during which time no other operations should occur.

**TEST** is not really an interrupt input, but it is used by program logic that otherwise would rely upon an interrupt. The 8086 has a special "Wait-for-Test" instruction that puts the CPU into a Idle state; this Idle state ends when the TEST input goes low.

An 8080A (and other microprocessors) will duplicate the logic of the 8086 "Wait-for-Test" instruction by executing a "no operation" loop which is terminated by an interrupt request:

|           |                                                 |
|-----------|-------------------------------------------------|
| ENI       | Enable interrupts                               |
| LOOP      | NOP                                             |
| JMP * - 1 | Only an interrupt will terminate loop execution |

There are eight pins which can output one of two signals, depending on whether MN/MX is tied to power or ground. By having two sets of signals, the 8086 can be used in simple configurations, best served by elementary control signals, or in complex configurations, where control signals must provide sufficient information to resolve the contentions and access conflicts that complex microcomputer systems may encounter.

8086  
DUAL BUS  
COMPLEXITY

The two sets of signals may be illustrated as follows:

|             | Minimum Systems | Maximum Systems |         |   |       |   |  |  |
|-------------|-----------------|-----------------|---------|---|-------|---|--|--|
| MN/MX = Vcc |                 | MN/MX = GND     |         |   |       |   |  |  |
| M/I/O       | S2 0            | 0 0             | 0       | 1 | 1 1   | 1 |  |  |
| DT/R        | S1 0            | 0 1             | 1       | 0 | 0 1   | 1 |  |  |
| DEN         | S0 0            | 1 0             | 1       | 0 | 1 0   | 1 |  |  |
|             | I I I           | H               | I M M   | M | M N   |   |  |  |
|             | N O O           | A               | F E E   | E | E O   |   |  |  |
|             | T R W           | L               | E M M   | M | M N   |   |  |  |
|             | A               |                 | T T R W | T | R W E |   |  |  |
|             |                 |                 | C       |   |       |   |  |  |
|             |                 |                 | H       |   |       |   |  |  |
| INTA        | QS1 0           | 0 1             | 1       | 1 |       |   |  |  |
| ALE         | QS0 0           | 1 0             | 0 1     |   |       |   |  |  |
|             | N Q Q           | Q Q             | Q       |   |       |   |  |  |
|             | O B E           | E B             | B       |   |       |   |  |  |
|             | O               |                 |         |   |       |   |  |  |
|             | P I             |                 | S       |   |       |   |  |  |
| WR          | LOCK            |                 |         |   |       |   |  |  |
| HOLD        | RQ/G0           |                 |         |   |       |   |  |  |
| HLDA        | RQ/G1           |                 |         |   |       |   |  |  |

**Let us first look at the simple set of control signals which are output when MN/MX is connected to +5V. These are completely standard microprocessor control signals.**

Since data and addresses are multiplexed on a single bus, AIE is output high to identify a valid memory address.

**8086 SIMPLE CONTROL SIGNALS**

When data are being transmitted or received via the Data/Address Bus, WR is pulsed low to identify data output, while RD is pulsed low as a request for external logic to place data on the Data/Address Bus. We have already described RD. It is not one of the changing signals; nevertheless, it is used by both simple and complex system busses.

For a read or a write operation, M/I<sub>O</sub> indicates whether memory (M/I<sub>O</sub> high) or an I/O port (M/I<sub>O</sub> low) is being accessed.

DT/R and DEN are two new control signals not found in earlier Intel microprocessors. These two control signals have been designed specifically to control 8286/8287-type bidirectional latched buffers. DT/R identifies the data direction, while DEN is the latching signal. The 8286 and 8287 latched buffers are described later in this chapter.

**HOLD and HLDA are standard hold request/acknowledge signals.** When external logic inputs HOLD high, the 8086 CPU enters a Hold state upon completing the current instruction's execution; the 8086 acknowledges the Hold State by outputting HLDA high. We will describe the Hold state in more detail later in the chapter.

**Let us now look at the complex System Bus which is generated when MN/MX is tied to ground.** Control signals are output as a three-signal combination, decoded by a 3-to-8 decoder, and a two-signal combination, decoded by a 2-to-4 decoder. Complex System Bus signals have been designed to act as inputs to an 8288 Bus Controller.

**8086 COMPLEX CONTROL SIGNALS**

S<sub>2</sub>, S<sub>1</sub> and S<sub>0</sub> are decoded to provide eight separate control signals. However, the simple system signals M/I<sub>O</sub>, DT/R and DEN represent a subset of the eight S<sub>2</sub>, S<sub>1</sub> and S<sub>0</sub> combinations. In our earlier illustration, we identify this simple system subset by shading the applicable complex system S<sub>2</sub>, S<sub>1</sub> and S<sub>0</sub> levels.

**The eight combinations of S<sub>2</sub>, S<sub>1</sub> and S<sub>0</sub> generate the following control signals:**

| S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> |        |                                                              |
|----------------|----------------|----------------|--------|--------------------------------------------------------------|
| 0              | 0              | 0              | INTA   | Interrupt acknowledge                                        |
| 0              | 0              | 1              | IOR    | I/O device read                                              |
| 0              | 1              | 0              | IOW    | I/O device write                                             |
| 0              | 1              | 1              | HALT   | CPU has executed a HALT instruction and is in the Halt state |
| 1              | 0              | 0              | IFETCH | The CPU is fetching an instruction object code byte          |
| 1              | 0              | 1              | MEMR   | Memory read                                                  |
| 1              | 1              | 0              | MEMW   | Memory write                                                 |
| 1              | 1              | 1              | NONE   | The System Bus is inactive                                   |

The control signal descriptions above use the words "read" and "write" as seen by the CPU. That is to say, a "read" operation moves data from a memory device or I/O port to the CPU, while a "write" operation moves data from the CPU to a memory location or I/O port.

QS0 and QS1 combine to identify conditions within the 8086 instruction object code queue — which we will describe soon. **The QS0 and QS1 combinations are interpreted as follows:**

| QS0 | QS1 |      |                                                                                     |
|-----|-----|------|-------------------------------------------------------------------------------------|
| 0   | 0   | NOOP | No operation. This is the default case.                                             |
| 0   | 1   | QB1  | The first instruction object code in the queue is being executed.                   |
| 1   | 0   | QE   | The queue is empty.                                                                 |
| 1   | 1   | QBS  | An instruction object code other than the first one in the queue is being executed. |

Observe that the simple bus signals INTA and ALE do not correspond to any combination of QS0 and QS1. This is in contrast to M/I<sub>O</sub>, DT/R and DEN, which constitute a subset of S<sub>2</sub>, S<sub>1</sub> and S<sub>0</sub>.

**LOCK, RQ/GT<sub>0</sub> and RQ/GT<sub>1</sub> are not related to their simple system equivalent signals: WR, HOLD and HLDA. LOCK, RQ/GT<sub>0</sub> and RQ/GT<sub>1</sub> provide the 8086 with its System Bus priority and control logic in complex configurations.**

LOCK is output high to prevent the 8086 from losing bus control while executing a sequence of machine cycles that must not be interrupted. Typically these will be a memory access combination of read-modify-write machine cycles, where an error could result if the CPU lost bus control after the read and before the write.

RQ/GT<sub>0</sub> and RQ/GT<sub>1</sub> are two-bus priority, bidirectional type signals. They are used to determine which CPU in a multi-CPU configuration will at any time have control of a shared bus. We will discuss these signals in more detail later in the chapter when looking at the capabilities of the 8086 in multi-CPU shared bus configurations.

## 8086 TIMING AND INSTRUCTION EXECUTION

The most important concept to understand when looking at 8086 instruction execution timing is the fact that 8086 bus control logic has been separated from the 8086 instruction execution logic. That is to say, the 8086 has an Execution Unit (EU), and a Bus Interface Unit (BIU).

The Execution Unit (EU) contains Data and Address registers, the Arithmetic and Logic Unit, plus the Control Unit. The Bus Interface Unit (BIU) contains bus interface logic, Segment registers, memory addressing logic, and a six-byte instruction object code queue. This may be illustrated as follows:



**The Execution Unit (EU) and the Bus Interface Unit (BIU) operate asynchronously.** Whenever the Execution Unit is ready to execute a new instruction, it fetches the instruction object code from the front of the Bus Interface Unit instruction queue, then it executes the instruction in some number of clock periods that have nothing to do with machine cycles. If the instruction object code queue is empty, then the Bus Interface Unit (BIU) executes an instruction fetch machine cycle — and the CPU waits for the instruction object code to be fetched. But the queue will rarely be empty, for reasons that will soon become apparent; therefore, the EU will usually not have to wait while an instruction fetch is executed.



If memory or an I/O device must be accessed in the course of executing an instruction, then the EU informs the BIU of its needs. The BIU executes an appropriate external access machine cycle in response to the EU demand.

The Bus Interface Unit (BIU), for its part, is independent of the Execution Unit (EU), and attempts to keep the six-byte queue filled with instruction object codes. If two or more of these six bytes are empty, then the Bus Interface Unit (BIU) executes instruction fetch machine cycles — providing the EU does not have an active request for bus access pending. If the EU issues a request for bus access while the BIU is in the middle of an instruction fetch machine cycle, then the BIU will complete the instruction fetch machine cycle before honoring the EU bus access request.

### 8086 INSTRUCTION QUEUE

## 8086 BUS CYCLES

If we look at the way clock logic is used by the 8086, the term "machine cycle" no longer applies. The EU does not use machine cycles; it executes instructions in some number of clock periods that are not subject to any type of machine cycle grouping. **The only time clock periods are grouped is when the bus control logic wishes to access memory or I/O devices.** Each external access requires four clock periods. This is the minimum amount of time required to handle the normal bus protocol which accompanies any transfer of information between a microprocessor and logic beyond the microprocessor. **Since this is the only time the 8086 groups clock periods, it is more accurate to talk about 8086 bus cycles, rather than machine cycles.**

**Figure 20-4 illustrates two 8086 bus cycles executed back-to-back.** In common with machine cycles, 8086 bus cycles, as illustrated in Figure 20-4 assign individual clock periods to time specific events.

Memory and I/O device addresses are output on the Data/Address Bus during T<sub>1</sub>.

Data is transferred between the 8086 and memory or I/O devices during T<sub>3</sub> and T<sub>4</sub>. If these two clock periods provide external logic with insufficient time to respond to an access, then Wait state clock periods (T<sub>W</sub>) may be inserted between T<sub>3</sub> and T<sub>4</sub>.

T<sub>2</sub> is a buffer clock period during which the Data/Address Bus stops outputting an address and starts outputting or inputting data.

During T<sub>4</sub> the CPU identifies the status of the next bus cycle or clock period. In simple configurations when MN/MX is tied to \$5V, DT/R is the only external signal that changes state during T<sub>4</sub>. When MN/MX is tied to ground, S0, S1, and S2 change state during T<sub>4</sub>. Thus, by examining these three status outputs, external logic knows whether to expect another bus cycle, and, if so, what type of bus cycle.

Now if you look at Figure 20-4, there is very little about it that differentiates an 8086 bus cycle from any other microprocessor's machine cycle. The characteristic of the bus cycle which differentiates it from standard machine cycles is the fact that bus cycles occur only on demand.



Figure 20-4. Two 8086 Bus Cycles

## 8086 INSTRUCTION QUEUE

Consider what happens when an instruction is executed. Beginning with the simplest case, the instruction object code queue within the Bus Interface Unit will be empty. When the EU requests an object code byte there is none, so the BIU executes a bus cycle which fetches the first byte of the instruction object code:



Let us assume that this particular instruction requires two bytes of object code; keeping things simple, we will illustrate another instruction cycle executed immediately to fetch the next instruction byte:



Let us suppose that this instruction reads a word of data from memory, then performs an arithmetic operation using this data. The instruction is going to require some number of clock periods to compute the effective address for the data memory location to be accessed (we will assume seven clock periods are needed). Some additional number of clock periods will also be needed to perform the arithmetic operation (we will assume nine clock periods). In a normal microprocessor, this instruction might be executed as the following sequence of machine cycles:



But the 8086, having asynchronous CPU and Bus Control Unit logic, will use clock periods to execute the instruction illustrated above as follows:



Now, the illustration above is not accurate because, you will recall, the 8086 fetches data in 16-bit increments, providing the data address lies on an even-byte boundary. Also, the BIU fetches instruction bytes and loads them into the queue only when there are at least two free bytes in the queue. Let us assume that all data does lie on even-byte boundaries. This is how our timing will now look:



### **There are some important points to note regarding 8086 bus cycle timing.**

Bus cycles are a Bus Interface Unit (BIU) phenomenon.

So far as the EU logic is concerned, bus cycles do not exist. The EU experiences periods of activity while executing instructions, and periods of inactivity while waiting for instruction object codes or data that the BIU must process via bus cycles. Periods of EU activity are timed by a sequence of clock periods. The EU makes no attempt to group clock periods into machine cycles, nor do EU clock periods have to occur in any special numeric combinations.

So far as the BIU is concerned, clock periods are grouped into bus cycles only when data must be transferred to or from the 8086. First priority is given to a bus access request coming from the EU. If the EU is not requesting bus access, then the BIU executes instruction fetch bus cycles until the queue is full. **These are the prerequisites for the BIU to execute an instruction fetch bus cycle:**

- 1) The clock period which initiates the bus cycle would otherwise be an idle clock period.
- 2) The EU does not have an active bus access request pending.
- 3) There are at least two bytes empty in the queue.

If the queue is full, then the BIU ceases to execute bus cycles; as illustrated above, a sequence of idle clock periods occurs.

Note that the CPU may have to wait for bus access. In the illustrations above, the CPU requires seven clock periods in order to compute a data memory address. At the end of the seventh clock period, the EU issues a bus access request to the BIU. But at this time the BIU is part way through executing an instruction fetch bus cycle. The BIU completes the instruction fetch bus cycle, then honors the EU bus access request.

In the final illustration above, no bus cycle accompanies the beginning of a new instruction's execution. We are assuming that the next instruction executed has one byte of object code. This object code byte is fetched from the front of the queue — which then has just one empty byte. No bus cycle is executed to fetch the instruction object code, since it is taken out of the queue. Subsequently, the BIU does not execute an instruction fetch bus cycle since there is only one empty byte; there must be at least two empty bytes in the queue before the BIU will execute an instruction fetch bus cycle.

**Based on the foregoing discussion of 8086 instruction fetch queuing, we can see that the 8086 has essentially eliminated instruction fetch time.** The only time the EU will have to wait while the BIU fetches instruction object codes is when a Branch-on-Condition instruction causes execution to branch out of the queue sequence, or when (for any reason) the memory accesses accompanying an instruction's execution are so dense that the BIU has insufficient idle clock periods within which to insert instruction fetch bus cycles.

## 8086 MEMORY AND I/O DEVICE READ BUS CYCLE FOR SIMPLE CONFIGURATIONS

Figure 20-5 shows timing for an 8086 memory read bus cycle when  $MN/MX = +5V$ ; that is to say, for the minimum mode bus configuration.



Figure 20-5. 8086 Memory Read Bus Cycle for a Minimum Mode System ( $MN/MX = +5V$ )

The memory or I/O device address is output via the Address Bus  $\overline{BHE}$  during clock period T<sub>1</sub>. ADO-AD15 starts floating in T<sub>2</sub> while turning around internal pin logic so that data can be input during T<sub>3</sub> and T<sub>4</sub>. Address lines A16 through A19 are all low when an I/O device address is being output. These address lines output status during T<sub>2</sub>, T<sub>3</sub> and T<sub>4</sub>. Close to the end of T<sub>4</sub>, A16 through A19 start to float.

$\overline{BHE}$  timing follows Address lines A16-A19; that is to say,  $\overline{BHE}$  is output low for the time that A16 through A19 is outputting an address.

The trailing edge of the high ALE pulse should be used as the "valid address" strobe. If your 8086 configuration demultiplexes the Data and Address Busses, then the Address Bus demultiplexing buffers should use the high-to-low transition of ALE as their latching strobe.

Remaining control signals consist of M/ $\overline{IO}$  and  $\overline{RD}$ , which are directed at external memory or I/O devices, plus DT/ $\overline{R}$  and DEN, which are directed at bus buffers.

M/ $\overline{IO}$  differentiates between a memory access and an I/O device access. M/ $\overline{IO}$  will be high for a memory access bus cycle; it will be low for an I/O device access bus cycle. M/ $\overline{IO}$  will contribute to memory and I/O device select logic when memory and I/O devices have similar addresses.

$\overline{RD}$  is pulsed low as a memory or I/O device read strobe. The addressed memory device must use this low signal to place data on ADO-AD15.

DT/ $\overline{R}$  and DEN are control signals designed to control bidirectional latched buffers on the Data Bus. DT/ $\overline{R}$  is output low for the entire memory or I/O device read bus cycle; it should be used to turn the latched buffers around so that they will transmit data to the CPU. DEN subsequently acts as a latching strobe. These two signals have been designed specifically to work with the 8286 and 8287 Data Bus transceivers; however, their logic is quite general.

**There is no difference between external timing for an instruction fetch or memory read bus cycle.** Given the pipelining instruction fetch logic of the 8086, this makes sense.

**The only timing difference between a memory read bus cycle and an I/O device input bus cycle occurs at the M/ $\overline{IO}$  signal.** This signal will be low for the duration of an I/O input bus cycle, whereas in Figure 20-5 it is shown high for the duration of a memory read bus cycle.

**Except for this difference, Figure 20-5 also illustrates I/O input bus cycle timing for a simple 8086 configuration.**

**During any simple configuration memory access operation, the following status is output on address lines A16 through A19:**



The interrupt enable status appearing on A18 may be used to illuminate an indicator on a control panel, should there be one. This indicator will show whether interrupts are enabled or disabled at any time. This status has no other value.

**S3 and S4 together identify the memory segment which is being accessed. This is not very useful information.** Even a code segment access cannot be interpreted as an instruction fetch, since data can be addressed out of the program segment.

## 8086 MEMORY OR I/O DEVICE WRITE BUS CYCLE FOR MINIMUM MODE

**Figure 20-6 illustrates timing for an 8086 memory or I/O device write bus cycle when the 8086 is operating in a minimum mode with MN/MX tied to +5V.**

Address output logic is identical in read and write bus cycles. As was the case for a read bus cycle, the address is output on the Address Bus, together with  $\overline{BHE}$ , during T<sub>1</sub>. External logic should use the high-to-low transition of the ALE pulse in order to latch a valid address. During T<sub>2</sub>, ADO-AD15 switches to outputting data, while A16-A19 outputs status. The same status is output in read and write bus cycles.

M/ $\overline{IO}$  is output high for the duration of a memory write bus cycle; it is output low for the duration of an I/O device write bus cycle.

$\overline{WR}$  is output low beginning early in T<sub>2</sub> and ending shortly after T<sub>3</sub>. Note that  $\overline{RD}$  does not go low for a read bus cycle until halfway through T<sub>2</sub>.

For an 8286 or 8287 Bus Transceiver, or any similar device, DT/ $\overline{R}$  is output high for the entire duration of the write bus cycle. This conditions the device to transmit data from the CPU to external logic. DEN is the chip enable signal provided for the bus transceiver. DEN is output high from the end of T<sub>1</sub> until the end of T<sub>4</sub>. Note that this high pulse is longer than the DEN pulse accompanying a read bus cycle.



Figure 20-6. 8086 Memory Write Bus Cycle for a Minimum Mode System ( $MN/MX = +5V$ )

An I/O write bus cycle has timing identical to Figure 20-6, except that the M/I/O signal will be low for the duration of the bus cycle, rather than high as shown in Figure 20-6. Wherever a memory word and an I/O port may have the same address, M/I/O must contribute to device select logic in order to discriminate between memory and I/O devices.

The status output on A16-A19 is no more useful in a write bus cycle than it is in a read bus cycle.

## 8086 READ AND WRITE BUS CYCLES FOR MAXIMUM MODE

It is not very rewarding looking at maximum mode memory or I/O access bus cycle timing, if we look at timing for an 8086 device on its own. This is because in maximum mode, with MN/MX tied to ground, the 8086 has been designed to operate with the 8288 Bus Controller.

Figures 20-7 and 20-8 provide maximum mode timing for the 8086 on its own when executing read or write bus cycles. Only the status signal levels differentiate memory or I/O access bus cycles.

Timing for the Address/Data Bus is identical in minimum and maximum modes. The read strobe  $\overline{RD}$  does not change; however, remaining control signals become control inputs to the 8288 Bus Controller.

Observe that QS0 and QS1 change levels on a clock period by clock period basis in order to identify events for individual clock periods. S0, S1 and S2 hold their levels from shortly before T<sub>1</sub> until shortly after the end of T<sub>2</sub>.



Figure 20-7. 8086 Memory or I/O Read Bus Cycle for a Maximum Mode System ( $MN/MX = 0V$ )



Figure 20-8. 8086 Memory or I/O Write Bus Cycle for a Maximum Mode System ( $MN/MX = 0V$ )

The 8288 Bus Controller, described later in this chapter, decodes S0, S1 and S2 in order to generate control signals which are comparable to those illustrated in Figures 20-5 and 20-6. For a complete discussion of bus cycle timing in complex 8086 microcomputer configurations, see the discussion of 8288 Bus Controller.

## THE 8086 WAIT STATE

**8086 Wait state logic is independent of the MN/MX pin connection and the external access bus cycle being executed.** In any bus cycle it is possible to insert one or more Wait clock periods ( $T_W$ ) between  $T_3$  and  $T_4$ . In order to extend a bus cycle with Wait clock periods, external logic must input a low READY signal during  $T_2$  of the bus cycle which is to be extended. The READY input to the 8086 must be synchronized with the falling edge of CLK at the end of  $T_2$ ; this synchronized READY input is created by the 8284 clock generator. External logic will normally input an asynchronous READY to the 8284 clock device, which outputs a synchronous READY for the 8086. Wait clock periods will continue to be inserted to the bus cycle until READY goes high again. **Timing is illustrated in Figure 20-9.** All output signal levels are maintained for the duration of the Wait state.

## THE 8086 HOLD STATE

The 8086 can be forced into a Hold state, at which time all three-state signals are floated. The 8086 Hold state is used to enable direct memory access logic, and in addition to disable inactive 80986 devices when more than one CPU accesses the same System Bus in a multi-CPU configuration.



Figure 20-9. The 8086 READY Input and Wait States

In a minimum mode configuration, when MN/MX is tied to +5V, the 8086 has a traditional Hold request input (HOLD) and a Hold Acknowledge output (HLDA). Upon receiving a high HOLD input, the 8086 will complete execution of its current instruction bus cycle before entering the Hold state and outputting HLDA high. **Timing may be illustrated as follows:**

**8086 HOLD IN MINIMUM MODE SYSTEM**



The 8086 samples the HOLD input on the low-to-high transition of CLK. Therefore, HOLD must make its transitions away from this sampling point; that is to say, HOLD must be stable when CLK is making its low-to-high transition.

The 8086 will acknowledge the Hold request by outputting HLDA high during any idle clock period, or at the end of a bus cycle. If a bus cycle is being executed when a Hold request occurs, the Hold request will not be acknowledged until the end of T<sub>4</sub> for the currently executing bus cycle.

The Hold state will last until the HOLD input goes low again. The 8086 continues to sample the HOLD input on all low-to-high transitions of CLK; therefore, HOLD must make its high-to-low transition away from the rising edge of CLK. When HOLD goes low, the Hold state will immediately end and HLDA will be output low again.

In 8086 maximum mode configurations where MN/MX is tied to ground, the HOLD and HLDA pins convert to bidirectional type control signals. There are two bidirectional signals: RQ/GT<sub>0</sub> and RQ/GT<sub>1</sub>. RQ/GT<sub>0</sub> has higher priority than RQ/GT<sub>1</sub>.

**8086 HOLD  
IN MAXIMUM  
MODE SYSTEM**

Any external logic that wishes to put an 8086 CPU into the Hold state transmits a low pulse to RQ/GT<sub>0</sub> or RQ/GT<sub>1</sub>. The 8086 CPU will acknowledge this Hold request immediately, if a bus cycle is not being executed, or at the conclusion of a currently executing bus cycle. The 8086 acknowledges the Hold request by outputting a low pulse via the same RQ/GT line; simultaneously the 8086 floats its three-state bus lines. External logic must allow at least one clock period to elapse following the Hold Acknowledge pulse, before attempting to input via the same pin. External logic terminates the Hold state by inputting another low pulse. Timing may be illustrated as follows:



In the illustration above, (A) identifies the instant at which external logic requests a Hold state by inputting a low pulse via either RQ/GT<sub>0</sub> or RQ/GT<sub>1</sub>. The 8086 samples RQ/GT on the rising edge of CLK; therefore, all signal transitions on RQ/GT must occur away from the CLK low-to-high transitions.

The 8086 will now acknowledge a Hold request during a bus cycle. If a bus cycle is in progress, then the Hold acknowledge will occur at the end of the bus cycle — that is to say, at the end of T<sub>4</sub>. If a bus cycle is not in progress, then the Hold request will be acknowledged immediately. In the illustration above, (B) identifies the low pulse which the 8086 will output as its Hold acknowledge. The Hold state will last until external logic again inputs a low pulse via RQ/GT. This is identified above as (C). Once again the 8086 samples RQ/GT on the rising edge of CLK; therefore, RQ/GT should be stable at this time.

**When the 8086 enters the Hold state, it continues executing instructions which it takes out of the pipeline, until a bus access is required.** When the EU requires a bus access, it stops operating until the end of the Hold state — at which time its bus access request will be honored by the Bus Interface Unit.

**In the event that Hold requests occur simultaneously on RQ/GT<sub>0</sub> and RQ/GT<sub>1</sub>, the acknowledge pulse will be output on RQ/GT<sub>0</sub>.** RQ/GT<sub>1</sub> will not be acknowledged until the Hold state initiated via RQ/GT<sub>0</sub> has ended.

When one Hold state ends, another Hold state can begin immediately for either of these reasons:

- 1) RQ/GT<sub>1</sub> was active when RQ/GT<sub>0</sub> was acknowledged; the RQ/GT<sub>1</sub> Hold request, being of lower priority, was denied and is pending.
- 2) While the 8086 was in a Hold state, a new hold request occurs on the other RQ/GT line.

If a new hold request occurs while the 8086 is in Hold state, priorities no longer apply. For example, if the CPU has acknowledged a Hold request occurring at RQ/GT<sub>1</sub> and is in a Hold state, then it will deny a new Hold request arriving via RQ/GT<sub>0</sub> until the current Hold state has ended.

If there is an active Hold request when the CPU ends a Hold state, then the CPU will immediately acknowledge the pending Hold request. This may be illustrated as follows:



When a Hold state ends, if the CPU has a bus access request pending, then the CPU bus access request will be denied until all active Hold requests have been acknowledged.

Note that there are no 8086 instructions that specifically affect the level of  $\overline{RQ}/\overline{GT0}$  or  $\overline{RQ}/\overline{GT1}$ . That is to say, external logic is entirely responsible for the interfaces to these two signals.

We will discuss  $\overline{RQ}/\overline{GT0}$  and  $\overline{RQ}/\overline{GT1}$  in more detail later in this chapter when we look at some multiple CPU 8086 configurations.

## THE 8086 HALT STATE

The 8086 enters a Halt state after a HALT instruction is executed. In the Halt state no signals are floated, and undefined data is output on the Data/Address Bus. No bus cycles can be executed while the 8086 is in the Halt state.

When a Halt instruction is executed, a bus cycle initiates the Halt state. This Halt state initializing bus cycle has nothing to do with instruction fetch logic. If the Halt instruction object code is fetched by the CPU from the queue, then there will be no preceding instruction fetch bus cycle. If the Halt instruction must be fetched from memory because the queue is empty, or is at the conditional end of a Branch-on-Condition, then the Halt initializing bus cycle will be preceded by an instruction fetch bus cycle.

For a simple system, the HALT initialization bus cycle is given by Figure 20-5, except that  $\overline{RD}$ ,  $M/\overline{IO}$ ,  $DT/R$  and  $DEN$  are not active. ALE is active, although the address output has no meaning.

For a complex system, the HALT initializing bus cycle is illustrated in Figure 20-10. The Halt state combination occurring at S0, S1 and S2 causes the 8288 Bus Controller to issue an ALE pulse before entering the Halt state; however, the occurrence of ALE could not be deduced simply by looking at 8086 timing.



Figure 20-10. 8086 HALT Instruction and Bus Cycle Timing for a Complex Bus Configuration

### The Halt state is terminated by an interrupt request or a Reset.

You can freely enter and leave a Hold state within an 8086 Halt state via any of the means that we have just described. The fact that the 8086 is in a Halt state in no way modifies Hold logic.

## THE 8086 LOCK

### A potential for serious error exists in the Hold request/acknowledge logic of the 8086.

The 8086 will acknowledge a Hold request occurring on the RQ/GT0 or RQ/GT1 lines at the end of the current bus cycle, if one is being executed, or at the next idle clock period, if a bus cycle is not being executed. The 8086 does not wait until the conclusion of the current instruction's execution before acknowledging the Hold request. Therefore, if an instruction reads the contents of a memory location (or I/O port), modifies these contents, then writes it back, a Hold state may separate the read bus cycle from the write bus cycle:



This can cause unexpected errors. If the 8086 enters a Hold state after reading memory location X contents and before writing these contents back, then it is possible for external logic — either direct memory access logic or another Central Processing Unit — to modify the contents of memory location X while the 8086 is in the Hold state. Now when the 8086 writes back the modified word, it may destroy data which should have been preserved.

If a 16-bit data word lies on an odd-byte boundary, it will require two bus cycles to access the data word. Under normal circumstances, a Hold request could be acknowledged between the first and second memory access bus cycles. But what if the word being accessed gets modified during the Hold state? If the Hold state splits two memory read bus cycles, this is what the CPU is going to read:



If a Hold state splits two memory write bus cycles, this is what ultimately gets written:



You use the 8086 LOCK instruction in order to prevent the types of errors described above.

**When a LOCK instruction is executed, the LOCK signal is output high for the duration of the next sequential instruction's execution. Also, while the next sequential instruction is being executed, a Hold request will not be acknowledged.**

You cannot extend protection against a Hold acknowledge beyond a single instruction's execution. For example, suppose you have two instructions, each of which is preceded by a Lock:

```

LOCK
AND    MEMX, AX
LOCK
OR     MEMX, BX

```

In the instruction sequence above, MEMX is a label which represents the address of a memory location. The contents of this memory location are ANDed with a mask stored in AX, then ORed with a mask stored in BX. The contents of MEMX are read, modified, and written back at each step.

Now, you may wish to inhibit Hold logic for both the AND and the OR operation. You cannot do so using the LOCK instruction. The first LOCK instruction will protect the following AND instruction from being interrupted by a Hold state; however, any pending Hold state will be acknowledged before the second LOCK instruction is executed.

Each Lock instruction extends protection against a Hold Acknowledge for the duration of the next sequential instruction only. The fact that the following instruction is also a Lock is irrelevant. The second Lock instruction will be the first instruction executed following the Hold state, and it will guarantee that no new Hold state begins until it, and the OR instruction, have both been executed.

You can use the LOCK instruction and signal to identify individual instruction execution times. If for any reason external logic needs to know the execution time for certain instructions, then by preceding these instructions with a LOCK instruction you will generate a high pulse on the LOCK output. The width of this high pulse exactly equals the execution time of the instruction which follows the LOCK.

8086 SINGLE  
INSTRUCTION  
TIME  
IDENTIFIED

## THE 8086 PROCESSOR WAIT FOR TEST STATE

The 8086 has a program-initiated Wait state which external logic must terminate via the TEST input signal. The WAIT instruction initiates this Wait state. After the WAIT instruction is executed, the 8086 generates an endless sequence of idle clock periods. This sequence lasts until external logic inputs a low signal at the TEST input.

While the endless sequence of idle clock pulses is being executed, the System Bus is not floated and the Bus Interface Unit may execute memory read bus cycles in order to fill up the instruction object code queue.

The processor Wait state can be used to synchronize an 8086 with any external time sequence. For example, you could start two programs, executing in two separate 8086 systems, at exactly the same time, by preceding each program with a Wait instruction. If both 8086's receive low TEST inputs simultaneously, then both microprocessors will start executing their programs at the same instant.

## THE 8086 PROCESSOR ESCAPE

The 8086 has a special escape instruction (ESC) intended for use in multi-CPU configurations. When the ESC instruction is executed, the contents of an addressed memory location are input to the CPU, but the input data is not stored anywhere. The purpose of the ESC instruction is to place the addressed data on the Data/Address Bus so that any other microprocessor (or external logic) connected to the Data/Address Bus can receive the data.

We will examine the value of the ESC instruction later in the chapter when looking at the 8086 in multiple CPU configurations.

## THE 8086 RESET OPERATION

The 8086 has an asynchronous Reset input. This signal can be input high at any time in order to reset the 8086. The high RESET must be at least four clock cycles long.

The 8086 terminates all current operations as soon as the RESET input makes a low-to-high transition. Nothing more happens until the RESET signal subsequently makes a high-to-low transition. It then takes approximately ten clock periods in order to execute the following operations:

- 1) The Status register is cleared. Among other things, this resets the interrupt enable flag to 0, thus disabling interrupts.
- 2) The CS Segment register is set to FFFF<sub>16</sub>.
- 3) The DS, SS and ES Segment registers and the Program Counter are all reset to 0.
- 4) Program execution begins. Since the CS Segment register contains FFFF<sub>16</sub> and the Program Counter contains 0, the first instruction executed is taken from memory location FFFF0<sub>16</sub>.

## 8086 INTERRUPT PROCESSING

The 8086 allows interrupts to originate in one of three ways:

- 1) From software or within program logic.
- 2) From external logic as a non-maskable interrupt.
- 3) From external logic as a maskable interrupt.

There is, in addition, a special "single step" condition that makes use of interrupt logic. We will describe single stepping after our discussion of interrupt logic.

In the event that two or more of the three interrupt types occur simultaneously, software generated interrupts have the highest priority and maskable interrupts have the lowest priority.

These are the ways in which a software interrupt request may occur:

- 1) Following an attempt to divide by 0. A special divide by 0 interrupt request will occur any time the divide instruction is executed with a 0 dividend.
- 2) Following execution of an Interrupt instruction (INT).
- 3) Following execution of an Interrupt-on-Overflow instruction (INTO) — if the Overflow status is set.

8086  
SOFTWARE  
INTERRUPTS

A non-maskable interrupt request is initiated when external logic inputs a low-to-high transition at the NMI pin. This is an edge-triggered signal. A non-maskable interrupt has lower priority than a software interrupt, but higher priority than a maskable interrupt.

A maskable interrupt request will be generated when external logic inputs a high level at the INTR pin. This input is level sensitive; it is the high level at INTR that causes the interrupt requests to occur.

Central to all 8086 interrupt processing is a Vector table that can be up to 1024 bytes in length, occupying absolute memory addresses 00000 through 003FF<sub>16</sub>. This Vector table consists of up to 256 four-byte entries. Each entry contains two 16-bit addresses which get loaded into the CS Segment register and the Program Counter.

|                                    |
|------------------------------------|
| <b>8086 NON-MASKABLE INTERRUPT</b> |
| <b>8086 MASKABLE INTERRUPT</b>     |
| <b>8086 INTERRUPT VECTOR TABLE</b> |

Figure 20-11 illustrates the 8086 Interrupt Vector table.



Figure 20-11. 8086 Interrupt Vector

A number of the Vector table entries serve specific interrupts. Other entries are reserved by Intel and should be avoided if compatibility with Intel software is desired. These entries are identified in Figure 20-11. As illustrated in Figure 20-11, 32 of the 256 interrupt vectors are not available to external logic; that leaves 224 vectors available to maskable external interrupts — which is plenty.

Taking each of the three interrupt types in turn, let us examine the interrupt acknowledge process.

**When any of the software interrupts are acknowledged, the following steps occur:**

- 1) The Status register contents are pushed onto the Stack; Stack Pointer contents, in consequence, are decremented by two.
- 2) The Interrupt and Test status flags are cleared; this enables maskable interrupts and single step logic (which we describe after our discussion of interrupt logic).
- 3) The CS Segment register contents are pushed onto the stack; Stack Pointer contents, in consequence, are decremented by two.
- 4) The new CS Segment register contents are taken from the appropriate interrupt vector location. With the exception of the INT instruction, software-generated interrupts have dedicated vector locations as illustrated in Figure 20-11. The INT instruction allows any one of the 256 vector locations to be selected; a default option selects Vector 3.
- 5) The Program Counter contents are pushed onto the Stack; Stack Pointer contents are decremented by two.
- 6) The new Program Counter contents are taken from the interrupt vector.

**8086  
SOFTWARE  
INTERRUPT**

**When a non-maskable interrupt is acknowledged, the following events occur:**

- 1) The Status register contents are pushed onto the Stack. The Stack Pointer contents are decremented by two.
- 2) The Interrupt and Test statuses are reset to 0; this disables non-maskable interrupts and single stepping mode.
- 3) The CS Segment register and Program Counter are reloaded from Interrupt Vector 2. See Figure 20-11.

**8086  
NON-MASKABLE  
INTERRUPT**

**When a maskable interrupt is acknowledged, the following steps occur:**

- 1) Two interrupt acknowledge bus cycles are executed by the Bus Interface Unit of the 8086. An interrupt acknowledge bus cycle is identical to the memory read bus cycles, as illustrated in Figures 20-5 and 20-7, with the exception that an interrupt acknowledge low pulse replaces the memory read low pulse. For a minimum mode system, INTA will provide the low RD pulse shown in Figure 20-5. Figure 20-7 accurately illustrates timing for an interrupt acknowledge bus cycle in a maximum mode system; however, S0, S1 and S2 will all be output low, identifying an interrupt acknowledge, whereas a read I/O port or read memory status combination would be output otherwise.
- 2) The acknowledged external device must send back a byte of data on lines AD0-AD7 in response to the second interrupt acknowledge bus cycle. This data byte is interpreted as a pointer into the interrupt vector. Multiplying this 8-bit value by 4 creates the correct beginning address for the interrupt vector.
- 3) The Status register contents are pushed onto the Stack.
- 4) The Interrupt and Test flags in the Status register are cleared. This disables further maskable interrupts and single step logic.
- 5) The CS Segment register contents are pushed onto the Stack.
- 6) The next CS Segment register contents are taken from the interrupt vector location identified in Step 2.
- 7) The Program Counter contents are pushed onto the Stack.
- 8) The new Program Counter contents are taken from the interrupt vector location identified in Step 2.
- 9) The first instruction of the interrupt routine is fetched using the new PC and CS.

**8086  
MASKABLE  
INTERRUPT**

It takes 60 clock periods to complete the nine interrupt acknowledge steps listed above.

You should use the IRET instruction to exit any interrupt service routine. This instruction restores Program Counter, CS Segment register, and Status register contents from the Stack.

**8086  
INTERRUPT  
RETURN**

## SINGLE STEPPING MODE

When the T status bit is set to 1, the 8086 operates in single stepping mode. In the single stepping mode the 8086 executes a software interrupt after each instruction's execution. The software interrupt vectors through Location 1 of the interrupt vector table, as illustrated in Figure 20-11.

Since the process of acknowledging an interrupt resets the TF flag, the single stepping mode will cease to exist once the interrupt service routine identified by Vector 1 is executed. But since the Status register contents prior to the interrupt acknowledge are saved on the Stack and are restored when a return from interrupt instruction is executed, single stepping mode will be restored as soon as the interrupt service routine corresponding to Interrupt Vector 1 concludes execution. Interrupt Vector 1 should therefore vector to a debug routine. Any user program executed in the single step mode will now execute instructions one at a time, branching to the debug program following execution of each instruction.

A particularly pleasing aspect of the 8086 single step mode is the fact that it can cope with interrupt logic. Frequently, microprocessor programs cannot be debugged once interrupt logic is introduced. In the case of the 8086, the interrupt acknowledge process automatically takes the 8086 out of the single step mode. You can insert instructions into any interrupt service routine in order to restore single stepping mode for that particular interrupt service routine. Thus, you have the option of executing any program or interrupt service routine in single step mode, without impacting any other program or interrupt service routine.

## THE 8086 INSTRUCTION SET

The 8086 instruction set is summarized in Table 20-4. When compared to other microprocessor instruction sets, the 8086 instruction set might appear quite large. If you look at Table 20-4, you will see that a single instruction mnemonic may appear many times. In reality, these are variations of the same instruction. We show the variations of a single instruction as though they were separate instructions in order to make this description of the 8086 instruction set consistent with similar tables for other microprocessors.

**The two I/O instructions, IN and OUT, become eight instructions because each has two sets of options.**

Each I/O instruction can access 16-bit words or 8-bit bytes. In each case, the instruction may have a short addressing range or a long addressing range. The short addressing range instruction requires two bytes of object code and can access one of the first 256 I/O port addresses. The I/O address is specified in the second object code byte. The long-range I/O instructions occupy only one byte of object code; however, register DX provides the I/O port address — which can therefore range between 0 and  $65,536_{10}$ .

**Primary memory reference instructions, and memory reference instructions in general, all have byte and word versions. In Table 20-4, the data memory location accessed is identified by the operand label DADDR.** Because data memory reference instructions may or may not include a displacement, the object code may be two, three, or four bytes long, as defined in Table 20-5.

By preceding any data memory reference instruction with the SEG instruction, you can force the data memory reference to access a segment other than the data segment. Here, for example, are the two instructions that load a byte of data from the extra segment to Register AL, using direct, indexed addressing:

|     |               |                                   |
|-----|---------------|-----------------------------------|
| SEG | ES            | Select extra segment              |
| MOV | AL, (DI) ADDR | Load data word from extra segment |

The LEA and LES instructions are unusual in that they load a memory address, rather than the contents of a memory location, into an identified 16-bit register. For the LEA instruction, this may be illustrated as follows:



In the illustration above, RRRRP represents a five hexadecimal digit data memory address — the actual location which will be accessed. This address is the sum of QQQQ0, the DS Segment register contents, and PPPP, the operand address. The LEA instruction loads the operand address PPPP into the identified 16-bit register.

The LES instruction serves primarily to initialize the address register for string operations. As discussed earlier in this chapter, string instructions access the extra segment via the DI and SI Index registers.

**The XLAT Instruction is designed for table look-ups.** An obvious application for an XLAT instruction would be to convert between ASCII and EBCDIC character codes. EBCDIC character codes being input could be translated into ASCII character codes, prior to being stored in memory, via the following instruction sequence:

| LABEL | IN    | PORTS |                                      |
|-------|-------|-------|--------------------------------------|
| XLAT  |       |       | Input an EBCDIC code                 |
| STOB  | AL    |       | Convert to ASCII                     |
| LOOP  | LABEL |       | Store in memory                      |
|       |       |       | Return for next byte if there is one |

The instruction sequence above inputs character codes from I/O Port 5. These are assumed to be EBCDIC codes which arrive at the AL register. The XLAT instruction uses each EBCDIC code as an index into a conversion table whose base address is assumed held in the BX register. Part of this conversion table may be illustrated as follows:



After the XLAT instruction has executed, the ASCII version of the input EBCDIC code will be in the AL register. The STOB instruction stores this ASCII code in the Extra Segment memory location addressed by the DI register; the DI register contents are then incremented so that on the next pass of the iterative loop it addresses the next free memory byte in the Extra Segment table.

The LOOP instruction decrements the CX register and branches back to the IN instruction if the CX register contents are not zero.

**Secondary memory reference instructions occur in four versions.** Each instruction may access a memory byte or a memory word; in either case, the result of the operation may be returned to a register, or to the memory word from which one operand was fetched.

**Note carefully that the Subtract instruction inverts the Carry status.**

The following numeric options are available with Add, Subtract, Multiply and Divide instructions:

| Operation | Unsigned Binary |        | Signed Binary |        | Packed Decimal |         | Unpacked Decimal |         |
|-----------|-----------------|--------|---------------|--------|----------------|---------|------------------|---------|
|           | 8-bit           | 16-bit | 8-bit         | 16-bit | 2 digit        | 4 digit | 1 digit          | 2 digit |
| Add       | X               | X      | X             | X      | X              |         | X                |         |
| Subtract  | X               | X      | X             | X      | X              |         | X                |         |
| Multiply  | X               | X      | X             | X      |                |         | X                |         |
| Divide    | X               | X      | X             | X      |                |         | X                |         |

### Let us first look at addition and subtraction.

Little needs to be said about **signed and unsigned binary addition or subtraction**; these are standard operations described in Volume 1. The only point to note is that the 8086 Subtract instructions invert the Carry status.

Packed binary coded decimal (BCD) addition and subtraction are also quite standard in that they closely follow the logic described in Volume 1. However, like the 8080A, the 8086 uses Decimal Adjust instructions to handle packed binary coded decimal data.

### 8086 BCD ADDITION

When you add two packed binary coded decimal numbers, it is assumed that the two numbers are indeed valid packed binary coded decimal data. The sum, which will not initially be a valid packed binary coded decimal number, is converted into one by the DAA instruction. This may be illustrated as follows:

ADD            AL, BL            Add BCD data in BL to AL  
                  DAA                    Decimal adjust result

Note that you can only add bytes, and AL must be the destination when adding packed BCD data.

Using abbreviations of Table 20-4, **DAA instruction logic may be summarized as follows:**

If  $(AL) \text{ AND } OF_{16}$  is greater than  $09_{16}$ , or if  $(AF) = 1$ , then:  
 $(AL) \leftarrow (AL) + 06_{16}$   
 $(AF) \leftarrow 1$

If  $(AL)$  is greater than  $9F_{16}$  or if  $(CF) = 1$ , then:  
 $(AL) \leftarrow (AL) + 60_{16}$   
 $(CF) \leftarrow 1$

If one of the numbers being added is not a valid packed binary coded decimal number, then no error indication is given, but the answer will be wrong. For example, there is nothing to stop you from adding  $1F_{16}$  to  $A3_{16}$  and then executing the DAA instruction to modify the sum; however, the result will be meaningless.

When you subtract packed binary coded decimal numbers, once again it is assumed that the subtrahend and minuend are both valid packed binary coded decimal numbers. The difference will initially be meaningless; however, executing the DAS instruction generates a valid packed binary coded decimal result. This may be illustrated as follows:

### 8086 BCD SUBTRACT

SBB            AL, BL  
                  DAS

Once again you must subtract bytes, and the difference must be returned to the AL register.

Using abbreviations of Table 20-4, DAS instruction logic may be summarized as follows:

If  $(AL) \text{ AND } OF_{16}$  is greater than  $09_{16}$ , or  $(AF) = 1$ , then:

$(AL) \leftarrow (AL) - 06_{16}$   
 $(AF) \leftarrow 1$

If  $(AL)$  is greater than  $9F_{16}$ , or  $(CF) = 1$ , then:

$(AL) \leftarrow (AL) - 60_{16}$   
 $(CF) \leftarrow 1$

When you subtract packed binary coded decimal numbers and generate a negative result, the Carry status will be 0 (as is the case for binary subtraction) but the numeric negative difference will be a tens complement number rather than a twos complement number. Refer to Volume 1 for details.

**You can also add and subtract unpacked binary coded decimal numbers.** These numbers may occupy the low-order four bits of a byte, leaving the high-order four bits empty:



Or you may add and subtract ASCII characters. An ASCII character contains the binary coded decimal digit in the low-order four bits and 0011 in the high-order four bits.

**When you add unpacked binary coded decimal (BCD) digits,** it is assumed that the two numbers being added are indeed valid ASCII characters or unpacked BCD digits. **The sum is initially meaningless; however, after executing the AAA instruction it is converted into one or two valid unpacked binary coded decimal digits.** Note carefully that the AAA instruction does not generate ASCII characters; it generates one binary coded decimal digit per byte — which the four high-order bits zero. **AAA instruction operations may be illustrated as follows:**

If  $(AL) \text{ AND } OF_{16}$  is greater than  $09_{16}$  or  $(AF) = 1$ , then:

$(AL) \leftarrow (AL) + 06_{16}$   
 $(AH) \leftarrow (AH) + 1$   
 $(AF) \leftarrow 1$

Unconditionally:

$(AL) \leftarrow (AL) \text{ AND } OF_{16}$   
 $(CF) \leftarrow (AF)$

Note that AH is incremented if the sum in AX is more than  $09_{16}$ , since  $09_{16}$  is the highest one-byte unpacked BCD value that is legal.

**When you subtract unpacked binary coded decimal numbers, you can subtract ASCII characters or bytes which have the four high-order bits blank.** It makes no difference which option you choose; if you subtract two ASCII characters you will cancel out the four high-order bits — which are identical anyway.

Assuming that the subtrahend and minuend are initially valid unpacked binary coded decimal numbers, the difference, which initially is meaningless, will be converted into one or two valid unpacked binary coded decimal digits by executing the AAS instruction. This may be illustrated as follows:

SUB            AL, BL  
AAS

**AAS instruction operations may be summarized as follows:**

If  $(AL) \text{ AND } OF_{16}$  is greater than  $09_{16}$  or  $(AF) = 1$  then:

$(AL) \leftarrow (AL) - 6$   
 $(AH) \leftarrow (AH) - 1$   
 $(AF) \leftarrow 1$

Unconditionally:

$(CF) \leftarrow (AF)$   
 $(AL) \leftarrow (AL) \text{ AND } OF_{16}$

If you generate a negative result when subtracting unpacked binary coded decimal numbers, the Carry status will be zero and the answer will be in its tens complement form.

**You can multiply unpacked binary coded decimal numbers, but not packed binary coded decimal numbers.** The multiplier and multiplicand must each be one byte long, with a single binary coded decimal digit in the low-order four bits and 0000 in the high-order four bits. Consider the multiplication  $7 \times 8 = 56_{10}$ . The instruction sequence:

**8086 BCD MULTIPLICATION**

MUL AL, BL  
AAM

results in these register contents' changes:

|    | Before |   |   |   | After |   |   |   |    |    |
|----|--------|---|---|---|-------|---|---|---|----|----|
| AX | 0      | 0 | 0 | 7 | AL    | 0 | 5 | 0 | 6  | AL |
|    |        |   | 0 | 8 | BL    |   | 0 | 8 | BL |    |

Assuming that the multiplier and multiplicand are valid, as illustrated above, the product will initially be meaningless. However, after executing the AAM instruction, a valid two-digit product will be generated, with the high-order digit in the AH register and the low-order digit in the AL register.

**AAM instruction logic is, in fact, quite simple. It may be illustrated as follows:**

$(AH) \leftarrow (AL) / OA_{16}$       (/ means "divided by")  
 $(AL) \leftarrow (AL) \text{ modulo } OA_{16}$

Consider again  $7 \times 8 = 56_{10}$ . This is initially computed as  $7 \times 8 = 38_{16}$ ; therefore, AH contains 00 and AL contains 38 — before the AAM instruction is executed.

$$(AL)/OA_{16} = 5$$

Therefore, 05 is loaded into AH. "Modulo" is the remainder after division; therefore  $(AL) \text{ modulo } OA_{16}$  is the remainder following  $(AL)/OA_{16}$ ; it is 6, which is loaded into AL.

Binary coded decimal multiplication does not take sign into account. It is up to your program logic to keep track of the sign.

**Binary coded decimal division, like multiplication, works only with unpacked binary coded decimal data.** However, you must execute the AAD instruction before the DIV instruction in order to generate a valid unpacked binary coded decimal answer. This may be illustrated as follows:

**8086 BCD DIVISION**

AAD  
DIV AX, BL

The AAD instruction takes the dividend, which we assume to be a valid unpacked binary coded decimal number in the AX register, and **packs it into the AL register as follows:**

$(AL) \leftarrow (AH) * OA_{16} + (AL)$   
 $(AH) \leftarrow 0$

Consider the reverse of our multiplication examples:

$$56/8 = 7$$

Initially, AH contains 05 and AL contains 06. After the AAD instruction is executed, AL contains:

$$05_{16} * OA_{16} + 06_{16}$$

which is  $38_{16}$ . Thus the DIV instruction can perform a pure binary division.

**The 8086 allows you to shift and rotate the contents of memory bytes or words.** This is very useful since it allows counters and masks to be held in memory, rather than in CPU registers as is the usual case.

**Immediate instructions allow immediate data to be loaded into registers or memory locations.** When loading immediate data into memory locations, you can generate 3, 4, 5 or 6 byte instruction object codes, depending on the length of the immediate data and the addressing options. See Table 20-5 for details.

The Loop instructions are, in fact, variations of the multi-byte, string-handling 8086 capability. These instructions allow you to set up a counter in the CX register, which is decremented in order to identify the number of iterations for any instruction loop. This may be illustrated as follows for the 8080A and the 8086:

| 8080A |          | 8086 |                         |
|-------|----------|------|-------------------------|
| MVI   | C, COUNT | MOV  | CX, DATA                |
| NEXT  | -        | NEXT | -                       |
| -     | -        | -    | ← Initialize counter    |
| -     | -        | -    | { Repeated instructions |
| -     | -        | -    |                         |
| -     | -        | -    |                         |
| -     | -        | -    |                         |
| DCR   | C        | LOOP | NEXT                    |
| JNZ   | NEXT     |      | ← Count and loop logic  |

Jump-on-Condition instructions are limited in that they all provide an 8-bit signed binary displacement. Thus, you are limited to jumping within a 256-byte program relative memory page.

Jump-on-Condition instructions are confusing at the best of times, because status combinations determine whether a jump will or will not occur. This is not very interesting information to you as a programmer. It is much easier to jump based on signed and unsigned binary numbers being less than, greater than, or equal to each other. **Table 20-2 therefore summarizes the way in which you should use 8086 Jump-on-Condition instructions.** This table is similar to the table on page 7-29 of Volume 1; however, the Carry status is inverted, since the 8086 Subtract instruction inverts the Carry status.

**The way the 8086 creates Block Transfer and Search instructions is interesting. You begin with a set of instructions, each of which performs a single operation. Each of these instructions can be made to repeat some number of times by preceding the instruction with a repeat (REP).** For example, the MOVW instruction, executed on its own, will move one 16-bit word of data from a source memory location to a destination memory location, using Data Segment and Extra Segment addressing as follows:



Table 20-2. 8086 Branch-on-Condition Instructions

| BRANCH CONDITION                         | STATUS CONDITIONS    | 8086 INSTRUCTION |                                                                                                                |
|------------------------------------------|----------------------|------------------|----------------------------------------------------------------------------------------------------------------|
| Unsigned branch on less than or equal    | .C = 1 or Z = 1      | JBE, JNA         |                                                                                                                |
| Unsigned branch on less                  | C = 1                | JB, JNAE         |                                                                                                                |
| Unsigned branch on equal                 | Z = 1                | JE, JZ           |                                                                                                                |
| Unsigned branch on not equal             | Z = 0                | JNE, JNZ         |                                                                                                                |
| Unsigned branch on greater               | C = 0 or Z = 0       | JA, JNBE         |                                                                                                                |
| Unsigned branch on greater than or equal | C = 0                | JAE, JNB         |                                                                                                                |
| Signed branch on less than or equal      | Z = 1 or S XOR O = 1 | JLE, JNG         |                                                                                                                |
| Signed branch on less                    | S XOR O = 1          | JL, JNGE         |                                                                                                                |
| Signed branch on equal                   | Z = 1                | JE, JZ           |                                                                                                                |
| Signed branch on not equal               | Z = 0                | JNE, JNZ         |                                                                                                                |
| Signed branch on greater                 | Z = 0 or S XOR O = 0 | JG, JNLE         |                                                                                                                |
| Signed branch on greater than or equal   | S XOR O = 0          | JGE, JNL         |                                                                                                                |
| Branch on counter decrement to zero      | O = 0                | JCXZ             |                                                                                                                |
| Branch on no overflow                    | O = 1                | JNO              |                                                                                                                |
| Branch on overflow                       | P = 1                | JO               |                                                                                                                |
| Branch on even parity                    | P = 0                | JP, JPE          |                                                                                                                |
| Branch on odd parity                     | S = 0                | JNP, JPO         |                                                                                                                |
| Branch on positive                       | S = 1                | JNS              |                                                                                                                |
| Branch on negative                       |                      | JS               |                                                                                                                |
|                                          |                      |                  | These are general status test branch instructions<br>These instructions to be used after a subtract or compare |

But, precede this instruction with a repeat and you move an entire block of data. This may be illustrated as follows:



**When a Block Transfer or Search instruction is executed, the Program Counter contains the address of the prior instruction until it and the Block Transfer or Search instruction has completed executing.** For example, when the REP and MOVW instruction pair executes, the Program Counter keeps pointing to the REP instruction as follows:

REP ← PC points here until end of block move  
MOVW

Only after the MOVW instruction has executed the number of times specified by the repeat will the Program Counter advance to the instruction following MOVW. **This little piece of logic is designed to protect repeat instructions during interrupts.** Interrupts are not locked out for the duration of a repeat instruction's execution; that would create intolerable delays between an interrupt request and acknowledge. Providing interrupts are enabled, an interrupt request can be acknowledged at any time during a repeat loop. Within the interrupt service routine, it is only necessary that you save the contents of the SI, DI, and CX registers in order to preserve the repeat loop logic. When you return from the interrupt, the Program Counter is pointing the REP instruction which picks up where it left off, using the restored contents of the SI, DI, and CX registers.

**A problem arises if you precede a Block Transfer or Search instruction with more than one single prefix. Suppose, for example, you have a LOCK and a REP instruction preceding an MOVW:**

REP  
LOCK  
MOVW

The LOCK must directly precede MOVW; otherwise, it would protect REP against a Hold.

The Program Counter points to the LOCK instruction, not the REP instruction, while the MOVW repeatedly executes the specified number of times. **If at some point an interrupt request is acknowledged,** then after the interrupt service routine completes execution you will return to the LOCK instruction, not the REP. **This will cause the MOVW instruction to be executed once more, rather than the number of times remaining in the repeat loop, as specified by the CX register contents and the REP instruction.** Thus, if both prefixes must be used, then interrupts should be disabled.

## 8086 — 8080A INSTRUCTION COMPATIBILITY

As we have already stated, the 8086 instruction set is upward compatible with the 8080A at the source program level. That is, every 8080A instruction can be converted to one or more 8086 instructions. Table 20-6 identifies the source program conversions recommended by Intel. These are by no means the only conversions which are possible, but they are the ones you should use, since they are the ones that Intel plans to support.

## THE BENCHMARK PROGRAM

The 8086 makes short work of our Benchmark program, which is well suited to the 8086 block transfer instruction. We assume that the I/O buffer and the table being filled both lie within single 65,536-byte program segments. The displacement to the beginning of the I/O buffer is loaded into the SI Index register, while the displacement to the first free byte of the data table is loaded into the DI Index register. **Our Benchmark program now consists of these few instructions:**

|      |           |                                                                                  |
|------|-----------|----------------------------------------------------------------------------------|
| MOV  | SI, IOBUF | Load I/O Buffer base address displacement in SI                                  |
| LES  | DI, ADDR  | Load Data table starting address in ES and displacement to first free byte in DI |
| MOV  | CX, COUNT | Load word count into CX                                                          |
| REP  |           |                                                                                  |
| MOVW |           | Move the data block                                                              |
| MOV  | ADDR, DI  | Return new address of first free table byte                                      |

**The following abbreviations are used in Table 20-4:**

|        |                                                                                                           |
|--------|-----------------------------------------------------------------------------------------------------------|
| AH     | Accumulator, high-order byte                                                                              |
| AL     | Accumulator, low-order byte                                                                               |
| AL7    | The value of register AL high-order bit (0 or 1) extended to a byte ( $00_{16}$ or $FF_{16}$ )            |
| AX     | Accumulator, both bytes                                                                                   |
| AX15   | The value of register AH high-order bit (0 or 1) extended to a 16-bit word ( $0000_{16}$ or $FFFF_{16}$ ) |
| BH     | B register, high-order byte                                                                               |
| BL     | B register, low-order byte                                                                                |
| BRANCH | Program memory direct address, used in Branch addressing option shown in Tables 20-1 and 20-2             |
| BX     | B register, both bytes                                                                                    |
| C      | Carry status                                                                                              |
| CH     | C register, high-order byte                                                                               |
| CL     | C register, low-order byte                                                                                |
| CS     | Code Segment register                                                                                     |
| CX     | C register, both bytes                                                                                    |
| DADDR  | Data memory address operands identified in Table 20-2                                                     |
| DATA8  | Eight bits of immediate data                                                                              |
| DATA16 | 16 bits of immediate data                                                                                 |
| DH     | D register, high-order byte                                                                               |
| DI     | Destination Index register                                                                                |
| DISP   | An 8-bit or 16-bit signed displacement                                                                    |
| DISP8  | An 8-bit signed displacement                                                                              |
| DL     | D register, low-order byte                                                                                |
| DS     | Data Segment register                                                                                     |
| DX     | D register, both bytes                                                                                    |
| EA     | Effective data memory address using any of the memory addressing options identified in Table 20-2         |
| ES     | Extra Segment register                                                                                    |
| I      | Status flag set to 1                                                                                      |
| I/D    | Increment/decrement selector for string operations; increment if D is 0, decrement if D is 1              |
| LABEL  | Direct data memory address, as identified in Table 20-2                                                   |
| N      | A binary digit (0 or 1)                                                                                   |
| O      | Status flag reset to 0                                                                                    |
| OEA    | Offset data memory address used to compute EA:<br>EA = OEA + [DS] * 16                                    |
| PC     | Program Counter                                                                                           |
| PDX    | I/O port addressed by DX register contents; port number can range from 0 through 65,536                   |
| PORT   | A label identifying an I/O port number in the range 0 through $255_{10}$                                  |
| RB     | Any one of the eight byte registers: AH, AL, BH, BL, CH, CL, DH or DL                                     |
| RBD    | Any RB register as a destination                                                                          |
| RBS    | Any RB register as a source                                                                               |
| RW     | Any one of the eight 16-bit registers: AX, BX, CX, DX, SP, BP, SI or DI                                   |
| RWD    | Any RW register as a destination                                                                          |
| RWS    | Any RW register as a source                                                                               |
| SEGM   | Label identifying a 16-bit value loaded into the CS Segment register to execute a segment jump            |
| SFR    | Status Flags register                                                                                     |
| SI     | Source Index register                                                                                     |
| SP     | Stack Pointer                                                                                             |
| SR     | Any one of the Segment registers CS, DS, ES or SS                                                         |
| SS     | Stack Segment register                                                                                    |
| U      | Status flag modified, but undefined                                                                       |
| V      | Any number in the range 0 through $255_{10}$                                                              |
| X      | Status flag modified to reflect result                                                                    |
| [[ ]]  | Contents of the memory location addressed by the contents of the location enclosed in the double brackets |
| [ ]    | The contents of the location enclosed in the brackets                                                     |
| →      | Data on the right-hand side of the arrow is moved to the location on the left-hand side of the arrow      |
| ↔      | Contents of locations on each side of ↔ are exchanged                                                     |
| —      | The two's complement of the value under the —                                                             |
| =      | Not equal to                                                                                              |

Table 20-3. A Summary of Intel 8086 Memory Addressing Options Identified by the EA Abbreviations in Table 20-3

| MEMORY<br>REFERENCE                | SEGMENT<br>REGISTER              | BASE<br>REGISTER | INDEX<br>REGISTER | POSSIBLE DISPLACEMENTS |                                      |      | ASSEMBLY<br>LANGUAGE<br>OPERAND<br>MNEMONIC |
|------------------------------------|----------------------------------|------------------|-------------------|------------------------|--------------------------------------|------|---------------------------------------------|
|                                    |                                  |                  |                   | 16-BIT,<br>UNSIGNED    | 8-BIT,<br>HIGH ORDER BIT<br>EXTENDED | NONE |                                             |
| NORMAL DATA<br>MEMORY<br>REFERENCE | DS<br>(Alternate*: CS, SS or ES) | None             | SI                | X                      | X                                    | X    |                                             |
|                                    |                                  |                  | DI                | X                      | X                                    | X    |                                             |
|                                    |                                  | BX               | SI                | X                      | X                                    | X    |                                             |
|                                    | SS<br>(Alternate*: CS, DS or ES) | None             | DI                | X                      | X                                    | X    |                                             |
|                                    |                                  |                  | None              | X                      | X                                    | X    |                                             |
|                                    |                                  | DS               | None              | X                      | X                                    | X    |                                             |
|                                    |                                  | None             | None              | X                      | X                                    | X    |                                             |
|                                    |                                  | BP               | SI                | X                      | X                                    | X    |                                             |
|                                    |                                  |                  | DI                | X                      | X                                    | X    |                                             |
| STACK                              | SS                               | SP               | None              |                        |                                      |      |                                             |
| STRING<br>DATA                     | ES                               | None             | SI                |                        |                                      |      |                                             |
|                                    |                                  |                  | DI                |                        |                                      |      |                                             |
| INSTRUCTION<br>FETCH               | CS                               | PC               | None              |                        |                                      |      |                                             |
| BRANCH                             | CS                               | PC               | None              |                        | X                                    |      |                                             |
| I/O DATA                           | DS                               | DX               | None              |                        |                                      |      |                                             |

\* The segment override allows DS or SS to be replaced by one of the other segment registers

X These are displacements that can be used to compute memory addresses.

// Shaded rows apply to EA and DADDR.

\ \ Shaded row applies to EA and LABEL.

Table 20-4. The 8086 Instruction Set Summary

| TYPE                     | MNEMONIC | OPERAND(S) | BYTES     | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                                        |
|--------------------------|----------|------------|-----------|----------|---|---|---|---|---|---|---|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          |          |            |           | O        | D | I | T | S | Z | A | P | C                   |                                                                                                                                                                                                                                                        |
| I/O                      | IN       | PORT       | 2         |          |   |   |   |   |   |   |   |                     | $[AL] \leftarrow [PORT]$<br>Load one byte of data from I/O port PORT into AL                                                                                                                                                                           |
|                          | IN       | [DX]       | 1         |          |   |   |   |   |   |   |   |                     | $[AL] \leftarrow [PDX]$<br>Load into AL one byte of data from I/O port whose address is held in the DX register                                                                                                                                        |
|                          | INW      | PORT       | 2         |          |   |   |   |   |   |   |   |                     | $[AL] \leftarrow [PORT], [AH] \leftarrow [PORT+1]$<br>Load 16 bits of data into AX. AL receives data from I/O port PORT, AH receives data from I/O port PORT+1                                                                                         |
|                          | INW      | [DX]       | 1         |          |   |   |   |   |   |   |   |                     | $[AL] \leftarrow [PDX], [AH] \leftarrow [PDX+1]$<br>Load 16 bits of data into AX. AL receives data from I/O port whose address is held in the DX register, AH receives data from the I/O port whose address is one higher                              |
|                          | OUT      | PORT       | 2         |          |   |   |   |   |   |   |   |                     | $[PORT] \leftarrow [AL]$<br>Output one byte of data from register AL to I/O port PORT                                                                                                                                                                  |
|                          | OUT      | [DX]       | 1         |          |   |   |   |   |   |   |   |                     | $[PDX] \leftarrow [AL]$<br>Output one byte of data from register AL to the I/O port whose address is held in the DX register                                                                                                                           |
|                          | OUTW     | PORT       | 2         |          |   |   |   |   |   |   |   |                     | $[PORT] \leftarrow [AL]; [PORT+1] \leftarrow AH$<br>Output 16 bits of data. The AL register contents are output to I/O port PORT. The AH register contents are output to I/O port PORT+1                                                               |
|                          | OUTW     | [DX]       | 1         |          |   |   |   |   |   |   |   |                     | $[PDX] \leftarrow [PORT+1] \leftarrow [PDX+1]$<br>Output 16 bits of data. The AL register contents are output to the I/O port whose address is held in the DX register. The AH register contents is output to the I/O port whose address is one higher |
|                          |          |            |           |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                        |
| PRIMARY MEMORY REFERENCE | LDS      | RW,DADDR   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[RW] \leftarrow [EA], [DS] \leftarrow [EA+2]$<br>Load 16 bits of data from the memory word addressed by DADDR into register RW. Load 16 bits of data from the next sequential memory word into the DS register                                        |
|                          | LEA      | RW,DADDR   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[RW] \leftarrow OEA$<br>Load into RW the 16-bit address displacement which, when added to the segment register contents, creates the effective data memory address                                                                                    |
|                          | LES      | RW,DADDR   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[RW] \leftarrow [EA], [ES] \leftarrow [EA+2]$<br>Load 16 bits of data from the memory word addressed by DADDR into register RW. Load 16 bits of data from the next sequential memory word into the ES register                                        |
|                          | MOV      | RB,DADDR   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[RB] \leftarrow [EA]$<br>Load one byte of data from the data memory location addressed by DADDR to register RB                                                                                                                                        |
|                          | MOV      | RW,DADDR   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[RW] \leftarrow [EA]$<br>Load 16 bits of data from the data memory word addressed by DADDR to register RW                                                                                                                                             |
|                          | MOV      | DADDR,RB   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[EA] \leftarrow [RB]$<br>Store the data byte from register RB in the memory byte addressed by DADDR                                                                                                                                                   |
|                          | MOV      | DADDR,RW   | 2, 3 or 4 |          |   |   |   |   |   |   |   |                     | $[EA] \leftarrow [RW]$<br>Store the 16-bit data word from register RW in the memory word addressed by DADDR                                                                                                                                            |
|                          | MOV      | AL,LABEL   | 3         |          |   |   |   |   |   |   |   |                     | $[AL] \leftarrow [EA]$<br>Load the data memory byte directly addressed by LABEL into register AL                                                                                                                                                       |
|                          | MOV      | AX,LABEL   | 3         |          |   |   |   |   |   |   |   |                     | $[AX] \leftarrow [EA]$<br>Load the 16-bit data memory word directly addressed by LABEL into register AX                                                                                                                                                |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                                        | MNEMONIC | OPERAND(S) | BYTES    | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                           |
|---------------------------------------------|----------|------------|----------|----------|---|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |            |          | O        | D | I | T | S | Z | A | P |                     |                                                                                                                                                           |
| PRIMARY MEMORY REFERENCE                    | MOV      | LABEL,AL   | 3        |          |   |   |   |   |   |   |   |                     | $[EA] \leftarrow [AL]$<br>Store the 8-bit contents of register AL into the data memory byte directly addressed by LABEL                                   |
|                                             | MOV      | LABEL,AX   | 3        |          |   |   |   |   |   |   |   |                     | $[EA] \leftarrow [AX]$<br>Store the 16-bit contents of register AX into the data memory word directly addressed by LABEL                                  |
|                                             | MOV      | SR,DADDR   | 2,3 or 4 |          |   |   |   |   |   |   |   |                     | $[SR] \leftarrow [EA]$<br>Load into Segment register SR the contents of the 16-bit memory word addressed by DADDR                                         |
|                                             | MOV      | DADDR,SR   | 2,3 or 4 |          |   |   |   |   |   |   |   |                     | $[EA] \leftarrow [SR]$<br>Store the contents of Segment register SR in the 16-bit memory location addressed by DADDR                                      |
|                                             | XCHG     | RB,DADDR   | 2,3 or 4 |          |   |   |   |   |   |   |   |                     | $[RB] \leftrightarrow [EA]$<br>Exchange a byte of data between register RB and the data memory location addressed by DADDR                                |
|                                             | XCHG     | RW,DADDR   | 2,3 or 4 |          |   |   |   |   |   |   |   |                     | $[RW] \leftrightarrow [EA]$<br>Exchange 16 bits of data between register RW and the data memory location addressed by DADDR                               |
|                                             | XLAT     |            | 1        |          |   |   |   |   |   |   |   |                     | $[AL] \leftarrow [(AL) + (BX)]$<br>Load into AL the data byte stored in the memory location addressed by summing initial AL contents with BX contents     |
| SECONDARY MEMORY REFERENCE (Memory Operate) | ADC      | RB,DADDR   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[RB] \leftarrow [EA] + [RB] + [C]$<br>Add the contents of the data byte addressed by DADDR, plus the Carry status, to register RB                        |
|                                             | ADC      | RW,DADDR   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[RW] \leftarrow [EA] + [RW] + [C]$<br>Add the contents of the 16-bit data word addressed by DADDR, plus the Carry status, to register RW                 |
|                                             | ADC      | DADDR,RB   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + [RB] + [C]$<br>Add the 8-bit contents of register RB, plus the Carry status, to the data memory byte addressed by DADDR           |
|                                             | ADC      | DADDR,RW   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + [RW] + [C]$<br>Add the 16-bit contents of register RW, plus the Carry status, to the data word addressed by DADDR                 |
|                                             | ADD      | RB,DADDR   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[RB] \leftarrow [EA] + [RB]$<br>Add the contents of the data byte addressed by DADDR to register RB                                                      |
|                                             | ADD      | RW,DADDR   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[RW] \leftarrow [EA] + [RW]$<br>Add the contents of the 16-bit data word addressed by DADDR to register RW                                               |
|                                             | ADD      | DADDR,RB   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + [RB]$<br>Add the 8-bit contents of register RB to the data memory byte addressed by DADDR                                         |
|                                             | ADD      | DADDR,RW   | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + [RW]$<br>Add the 16-bit contents of register RW to the data memory word addressed by DADDR                                        |
|                                             | AND      | RB,DADDR   | 2,3 or 4 | O        |   |   |   | X | X | U | X | O                   | $[RB] \leftarrow [EA] \text{ AND } [RB]$<br>AND the 8-bit contents of register RB with the data memory byte addressed by DADDR.<br>Store the result in RB |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                                        | MNEMONIC | OPERAND(S) | BYTES    | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------------|----------|------------|----------|----------|---|---|---|---|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |            |          | O        | D | I | T | S | Z | A | P |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SECONDARY MEMORY REFERENCE (Memory Operate) | AND      | RW,DADDR   | 2,3 or 4 | O        |   |   | X | X | U | X | O | [RW] ← [EA] AND [RW]<br>AND the 16-bit contents of register RW with the data memory word addressed by DADDR.<br>Store the result in RW                                                                                                                                                                                                                                                                                                                      |
|                                             | AND      | DADDR,RB   | 2,3 or 4 | O        |   |   | X | X | U | X | O | [EA] ← [EA] AND [RB]<br>AND the 8-bit contents of register RB with the data memory byte addressed by DADDR.<br>Store the result in the addressed data memory byte                                                                                                                                                                                                                                                                                           |
|                                             | AND      | DADDR, RW  | 2,3 or 4 | O        |   |   | X | X | U | X | O | [EA] ← [EA] AND [RW]<br>AND the 16-bit contents of register RW with the data memory word addressed by DADDR.<br>Store the result in the addressed data memory word                                                                                                                                                                                                                                                                                          |
|                                             | CMP      | RB,DADDR   | 2,3 or 4 | X        |   |   | X | X | X | X | X | [RB] – [EA]<br>Subtract the contents of the data memory byte addressed by DADDR from the contents of register RB. Discard the result, but adjust status flags                                                                                                                                                                                                                                                                                               |
|                                             | CMP      | RW,DADDR   | 2,3 or 4 | X        |   |   | X | X | X | X | X | [RW] – [EA]<br>Subtract the 16-bit contents of the data memory word addressed by DADDR from the contents of register RW. Discard the result, but adjust status flags                                                                                                                                                                                                                                                                                        |
|                                             | CMP      | DADDR,RB   | 2,3 or 4 | X        |   |   | X | X | X | X | X | [EA] – [RB]<br>Subtract the 8-bit contents of register RB from the data memory byte addressed by DADDR.<br>Discard the result, but adjust status flags                                                                                                                                                                                                                                                                                                      |
|                                             | CMP      | DADDR,RW   | 2,3 or 4 | X        |   |   | X | X | X | X | X | [EA] – [RW]<br>Subtract the 16-bit contents of register RW from the data memory word addressed by DADDR. Discard the result, but adjust status flags                                                                                                                                                                                                                                                                                                        |
|                                             | DEC      | DADDR      | 2,3 or 4 | X        |   |   | X | X | X | X |   | [EA] ← [EA] – 1<br>Decrement the contents of the memory location addressed by DADDR. Depending on the prior definition of DADDR, an 8-bit or a 16-bit memory location may be decremented                                                                                                                                                                                                                                                                    |
|                                             | DIV      | AX,DADDR   | 2,3 or 4 | U        |   |   | U | U | U | U | U | [AX] ← [AX]/[EA]<br>Divide the 16-bit contents of register AX by the 8-bit contents of the memory byte addressed by DADDR. Store the integer quotient in AL and the remainder in AH. If the quotient is greater than FF <sub>16</sub> , execute a "divide by 0" interrupt                                                                                                                                                                                   |
|                                             | DIV      | DX,DADDR   | 2,3 or 4 | U        |   |   | U | U | U | U | U | [DX][AX] ← [DX][AX]/[EA]<br>Divide the 32-bit contents of registers DX (high order) and AX (low order) by the 16-bit contents of the memory word addressed by DADDR. Store the integer quotient in AX and the remainder in DX. If the quotient is greater than FFFF <sub>16</sub> , execute a "divide by 0" interrupt                                                                                                                                       |
| IDIV                                        | AX,DADDR | 2,3 or 4   | U        |          |   |   | U | U | U | U | U | [AX] ← [AX]/[EA]<br>Divide the 16-bit contents of register AX by the 8-bit contents of the memory byte addressed by DADDR, treating both contents as signed binary numbers. Store the quotient, as a signed binary number, in AL. Store the remainder, as an unsigned binary number, in AH. If the quotient is greater than 7F <sub>16</sub> , or less than –80 <sub>16</sub> , execute a "divide by 0" interrupt                                           |
|                                             | IDIV     | DX,DADDR   | 2,3 or 4 | U        |   |   | U | U | U | U | U | [DX][AX] ← [DX][AX]/[EA]<br>Divide the 32-bit contents of register DX (high order) and AX (low order) by the 16-bit contents of the memory word addressed by DADDR. Treat both contents as signed binary numbers. Store the quotient, as a signed binary number, in AX. Store the remainder, as an unsigned binary number, in AH. If the quotient is greater than 7FFF <sub>16</sub> , or less than –8000 <sub>16</sub> , execute a "divide by 0" interrupt |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                                        | MNEMONIC | OPERAND(S) | BYTES    | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                                                                   |
|---------------------------------------------|----------|------------|----------|----------|---|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |            |          | O        | D | I | T | S | Z | A | F |                     |                                                                                                                                                                                                                                                                                   |
| SECONDARY MEMORY REFERENCE (Memory Operate) | IMUL     | AL,DADDR   | 2,3 or 4 | X        |   |   |   | U | U | U | U | X                   | $[AX] \leftarrow [AL] * [EA]$<br>Multiply the 8-bit contents of register AL by the contents of the memory byte addressed by DADDR. Treat both numbers as signed binary numbers. Store the 16-bit product in AX                                                                    |
|                                             | IMUL     | AX,DADDR   | 2,3 or 4 | X        |   |   |   | U | U | U | U | X                   | $[DX][AX] \leftarrow [AX] * [EA]$<br>Multiply the 16-bit contents of register AX by the 16-bit contents of the memory word addressed by DADDR. Treat both numbers as signed binary numbers. Store the 32-bit product in DX (high order word) and AX (low order word)              |
|                                             | INC      | DADDR      | 2,3 or 4 | X        |   |   |   | X | X | X | X |                     | $[EA] \leftarrow [EA] + 1$<br>Increment the contents of the memory location addressed by DADDR. Depending on the prior definition of DADDR, an 8-bit or a 16-bit memory location may be incremented                                                                               |
|                                             | MUL      | AL,DADDR   | 2,3 or 4 | X        |   |   |   | U | U | U | U | X                   | $[AX] \leftarrow [AL] * [EA]$<br>Multiply the 8-bit contents of register AL by the contents of the memory byte addressed by DADDR. Treat both numbers as unsigned binary numbers. Store the 16-bit product in AX                                                                  |
|                                             | MUL      | AX,DADDR   | 2,3 or 4 | X        |   |   |   | U | U | U | U | X                   | $[DX][AX] \leftarrow [AX] * [EA]$<br>Multiply the 16-bit contents of register AX by the 16-bit contents of the memory word addressed by DADDR. Treat both numbers as unsigned binary numbers. Store the 32-bit product in DX (high order word) and AX (low order word)            |
|                                             | NEG      | DADDR      | 2,3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [\overline{EA}]$<br>Twos complement the contents of the addressed memory location. Depending on the prior definition of DADDR, an 8-bit or 16-bit memory location may be twos complemented                                                                       |
|                                             | NOT      | DADDR      | 2,3 or 4 |          |   |   |   |   |   |   |   |                     | $[EA] \leftarrow \text{NOT } [EA]$<br>Ones complement the contents of the addressed memory location. Depending on the prior definition of DADDR, an 8-bit or 16-bit memory location may be ones complemented                                                                      |
|                                             | OR       | RB,DADDR   | 2,3 or 4 | X        |   |   |   | X | X | U | X | X                   | $[RB] \leftarrow [EA] \text{ OR } [RB]$<br>OR the 8-bit contents of register RB with the data memory byte addressed by DADDR.<br>Store the result in RB                                                                                                                           |
|                                             | OR       | RW,DADDR   | 2,3 or 4 | X        |   |   |   | X | X | U | X | X                   | $[RW] \leftarrow [EA] \text{ OR } [RW]$<br>OR the 16-bit contents of register RW with the data memory word addressed by DADDR.<br>Store the result in RW                                                                                                                          |
|                                             | OR       | DADDR,RB   | 2,3 or 4 | X        |   |   |   | X | X | U | X | X                   | $[EA] \leftarrow [EA] \text{ OR } [RB]$<br>OR the 8-bit contents of register RB with the data memory byte addressed by DADDR.<br>Store the result in the data memory byte                                                                                                         |
|                                             | OR       | DADDR,RW   | 2,3 or 4 | X        |   |   |   | X | X | U | X | X                   | $[EA] \leftarrow [EA] \text{ OR } [RW]$<br>OR the 16-bit contents of register RW with the data memory word addressed by DADDR.<br>Store the result in the data memory word                                                                                                        |
|                                             | RCL      | DADDR,N    | 2,3 or 4 | X        |   |   |   |   |   |   |   | X                   | Rotate the contents of the data memory location addressed by DADDR left through the Carry status. If N = 1, then rotate one bit position. If N = CL, then register CL contents provides the number of bit positions. Depending on prior definition, DADDR may address a byte:<br> |

or DADDR may address a word:



Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                                        | MNEMONIC | OPERAND(S) | BYTES     | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------|----------|------------|-----------|----------|---|---|---|---|---|---|---|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |            |           | O        | D | I | T | S | Z | A | P |                     |                                                                                                                                                                                                                                                                                                                                                                      |
| SECONDARY MEMORY REFERENCE (Memory Operate) | RCR      | DADDR,N    | 2, 3 or 4 | X        |   |   |   |   |   |   |   |                     | As RCL, but rotate right                                                                                                                                                                                                                                                                                                                                             |
|                                             | ROL      | DADDR,N    | 2, 3 or 4 | X        |   |   |   |   |   |   |   |                     | Rotate the contents of the data memory location addressed by DADDR left. Move the left most bit into the Carry status. If N = 1, then rotate one bit position. If N = CL, then register CL contents provides the number of bit positions. Depending on prior definition, DADDR may address a byte:<br><br>or DADDR may address a word:<br>                           |
|                                             | ROR      | DADDR,N    | 2, 3 or 4 | X        |   |   |   | X | X | U | X | X                   | As ROL, but rotate right<br>Shift the contents of the data memory location addressed by DADDR left. Move the left most bit into the Carry status. If N = 1, then shift one bit position. If N = CL, then register CL contents provides the number of bit positions. Depending on prior definition, DADDR may address a byte:<br><br>or DADDR may address a word:<br> |
|                                             | SAL      | DADDR,N    | 2, 3 or 4 | X        |   |   |   | X | X | U | X | X                   | As SAL, but shift right and propagate sign:<br><br>or<br>                                                                                                                                                                                                                                                                                                            |
|                                             | SAR      | DADDR,N    | 2, 3 or 4 | X        |   |   |   | X | X | U | X | X                   | As SAL, but shift right and propagate sign:<br><br>or<br>                                                                                                                                                                                                                                                                                                            |
|                                             | SBB      | RB,DADDR   | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[RB] \leftarrow [RB] - [EA] - [C]$<br>Subtract the contents of the data byte addressed by DADDR from the contents of 8-bit register RB, using twos complement arithmetic. Decrement the result in RB if the Carry status was initially set                                                                                                                          |
|                                             | SBB      | RW,DADDR   | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[RW] \leftarrow [RW] - [EA] - [C]$<br>Subtract the contents of the 16-bit data word addressed by DADDR from the contents of the 16-bit register RW, using twos complement arithmetic. Decrement the result in RW if the Carry status was initially set                                                                                                              |
| SECONDARY MEMORY REFERENCE (Memory Operate) | SBB      | DADDR,RB   | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] - [RB] - [C]$<br>Subtract the contents of 8-bit register RB from the data byte addressed by DADDR, using twos complement arithmetic. Decrement the result in data memory if the Carry status was initially set                                                                                                                                 |
|                                             | SBB      | DADDR,RW   | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] - [RW] - [C]$<br>Subtract the contents of 16-bit register RW from the 16-bit data word addressed by DADDR, using twos complement arithmetic. Decrement the result in data memory if the Carry status was initially set                                                                                                                         |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                                        | MNEMONIC | OPERAND(S)   | BYTES     | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                          |
|---------------------------------------------|----------|--------------|-----------|----------|---|---|---|---|---|---|---|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |              |           | O        | D | I | T | S | Z | A | P | C                   |                                                                                                                                                                                          |
| SECONDARY MEMORY REFERENCE (Memory Operate) | SHL      | DADDR,N      | 2, 3 or 4 | X        |   |   |   | X | X | U | X | X                   | This is an alternate mnemonic for SAL.<br>As SAL, but shift right:<br><br>[EA]<br>0 → + → + → + → + → + → + → C<br>or 0 → + → + → + → + → + → + → + → C                                  |
|                                             | SHR      | DADDR,N      | 2, 3 or 4 | X        |   |   |   | X | X | U | X | X                   |                                                                                                                                                                                          |
|                                             | SUB      | RB,DADDR     | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | [RB] ← [RB] – [EA]<br>Subtract the contents of the data memory byte addressed by DADDR from the contents of 8-bit register RB, using twos complement arithmetic                          |
|                                             | SUB      | RW,DADDR     | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | [RW] ← [RW] – [EA]<br>Subtract the contents of the 16-bit data memory word addressed by DADDR from the contents of 16-bit register RW, using twos complement arithmetic                  |
|                                             | SUB      | DADDR,RB     | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | [EA] ← [EA] – [RB]<br>Subtract the contents of 8-bit register RB from the data memory byte addressed by DADDR, using twos complement arithmetic                                          |
|                                             | SUB      | DADDR,RW     | 2, 3 or 4 | X        |   |   |   | X | X | X | X | X                   | [EA] ← [EA] – [RW]<br>Subtract the contents of 16-bit register RW from the 16-bit data memory word addressed by DADDR, using twos complement arithmetic                                  |
|                                             | TEST     | DADDR,RB     | 2, 3 or 4 | O        |   |   |   | X | X | U | X | O                   | [EA] AND [RB]<br>AND the 8-bit contents of the data memory location addressed by DADDR with the contents of 8-bit register RB. Discard the result, but adjust status flags appropriately |
|                                             | TEST     | DADDR,RW     | 2, 3 or 4 | O        |   |   |   | X | X | U | X | O                   | [EA] AND [RW]<br>AND the 16-bit contents of the data memory word addressed by DADDR with the contents of 16-bit register RW. Discard the result, but adjust status flags appropriately   |
|                                             | XOR      | RB,DADDR     | 2, 3 or 4 | O        |   |   |   | X | X | U | X | O                   | [RB] ← [RB] XOR [EA]<br>Exclusive OR the 8-bit contents of register RB with the data memory byte addressed by DADDR. Store the result in RB                                              |
|                                             | XOR      | RW,DADDR     | 2, 3 or 4 | O        |   |   |   | X | X | U | X | O                   | [RW] ← [RW] XOR [EA]<br>Exclusive OR the 16-bit contents of register RW with the 16-bit data memory word addressed by DADDR. Store the result in RW                                      |
| IMMEDIATE                                   | MOV      | DADDR,DATA8  | 3, 4 or 5 |          |   |   |   |   |   |   |   |                     | [EA] ← DATA8<br>Load the immediate data byte DATA8 into the data memory byte addressed by DADDR                                                                                          |
|                                             | MOV      | DADDR,DATA16 | 4, 5 or 6 |          |   |   |   |   |   |   |   |                     | [EA] ← DATA16<br>Load the immediate 16-bit data word DATA16 into the data memory word addressed by DADDR                                                                                 |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                       | MNEMONIC | OPERAND(S)     | BYTES  | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------|----------|----------------|--------|----------|---|---|---|---|---|---|---|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |          |                |        | O        | D | I | T | S | Z | A | P |                     |                                                                                                                                                                                                                                                                                                                                                                                                                           |
| IMMEDIATE                  | MOV      | RB,DATA8       | 3      |          |   |   |   |   |   |   |   |                     | [RB] $\leftarrow$ DATA8<br>Load the immediate data byte DATA8 into 8-bit register RB                                                                                                                                                                                                                                                                                                                                      |
|                            | MOV      | iW,DATA16      | 4      |          |   |   |   |   |   |   |   |                     | [RW] $\leftarrow$ DATA16<br>Load the immediate 16-bit data word DATA16 into 16-bit register RW                                                                                                                                                                                                                                                                                                                            |
| JUMP                       | JMP      | BRANCH         | 2 or 3 |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [PC] + DISP<br>Jump direct to program memory location identified by label BRANCH. The displacement DISP which must be added to the Program Counter will be computed as an 8-bit or 16-bit signed binary number, as needed, by the assembler                                                                                                                                                             |
|                            | JMP      | BRANCH,SEGMENT | 5      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ DATA16, [CS] $\leftarrow$ DATA16<br>Jump direct into a new segment. BRANCH is a label which becomes a 16-bit unsigned data value which is loaded into PC. SEGMENT is a label which becomes another 16-bit unsigned data value that is loaded into the CS segment register                                                                                                                               |
|                            | JMP      | DADDR          | 2      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [EA]<br>Jump indirect in current segment. The 16-bit contents of the data memory word addressed by DADDR is loaded into PC                                                                                                                                                                                                                                                                              |
|                            | JMP      | DADDR,CS       | 2      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [EA], [CS] $\leftarrow$ [EA+2]<br>Jump indirect into a new segment. The 16-bit contents of the data memory word addressed by DADDR is loaded into PC. The next sequential 16-bit data memory word's contents is loaded into the CS segment register                                                                                                                                                     |
| SUBROUTINE CALL AND RETURN | CALL     | BRANCH         | 3      |          |   |   |   |   |   |   |   |                     | [SP] $\leftarrow$ [PC], [SP] $\leftarrow$ [SP] -2, [PC] $\leftarrow$ [PC] + DISP<br>Call a subroutine in the current program segment using direct addressing                                                                                                                                                                                                                                                              |
|                            | CALL     | BRANCH,SEGMENT | 5      |          |   |   |   |   |   |   |   |                     | [SP] $\leftarrow$ [CS], [SP] $\leftarrow$ [SP] -2, [SP] $\leftarrow$ [PC], [SP] $\leftarrow$ [SP] -2, [PC] $\leftarrow$ DATA16, [CS] $\leftarrow$ DATA16<br>Call a subroutine in another program segment using direct addressing. BRANCH and SEGMENT are labels that become different 16-bit data words; they are loaded into PC and CS, respectively                                                                     |
|                            | CALL     | DADDR          | 2      |          |   |   |   |   |   |   |   |                     | [SP] $\leftarrow$ [PC], [SP] $\leftarrow$ [SP] -2, [PC] $\leftarrow$ [EA]<br>Call a subroutine in the current program segment using indirect addressing. The address of the subroutine called is stored in the 16-bit data memory word addressed by DADDR                                                                                                                                                                 |
|                            | CALL     | DADDR,CS       | 2      |          |   |   |   |   |   |   |   |                     | [SP] $\leftarrow$ [CS], [SP] $\leftarrow$ [S2] -2, [SP] $\leftarrow$ [PC], [SP] $\leftarrow$ [SP] -2, [PC] $\leftarrow$ [EA], [CS] $\leftarrow$ [EA+2]<br>Call a subroutine in a different program segment using indirect addressing. The address of the subroutine called is stored in the 16-bit data memory word addressed by DADDR. The new CS register contents is stored in the next sequential program memory word |
|                            | RET      |                | 1      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [SP], [SP] $\leftarrow$ [SP] +2<br>Return from a subroutine in the current segment                                                                                                                                                                                                                                                                                                                      |
|                            | RET      | CS             | 1      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [SP], [SP] $\leftarrow$ [SP] +2, [CS] $\leftarrow$ [SP], [SP] $\leftarrow$ [SP] +2<br>Return from a subroutine in another segment                                                                                                                                                                                                                                                                       |
|                            | RET      | DATA16         | 3      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [SP], [SP] $\leftarrow$ [SP] +2+DATA16<br>Return from a subroutine in the current segment and add an immediate displacement to SP                                                                                                                                                                                                                                                                       |
|                            | RET      | CS,DATA16      | 3      |          |   |   |   |   |   |   |   |                     | [PC] $\leftarrow$ [SP], [SP] $\leftarrow$ [SP] +2, [CS] $\leftarrow$ [SP], [SP] $\leftarrow$ [SP] +2+DATA16<br>Return from a subroutine in another segment and add an immediate displacement to SP                                                                                                                                                                                                                        |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE              | MNEMONIC | OPERAND(S)   | BYTES     | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                     |
|-------------------|----------|--------------|-----------|----------|---|---|---|---|---|---|---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------|
|                   |          |              |           | O        | D | I | T | S | Z | A | P |                     |                                                                                                                                     |
| IMMEDIATE OPERATE | ADD      | AL,DATA8     | 2         | X        |   |   |   | X | X | X | X | X                   | $[AL] \leftarrow [AL] + DATA8$<br>Add 8-bit immediate data to the AL register                                                       |
|                   | ADD      | AX,DATA16    | 3         | X        |   |   |   | X | X | X | X | X                   | $[AX] \leftarrow [AX] + DATA16$<br>Add 16-bit immediate data to the AX register                                                     |
|                   | ADD      | RB,DATA8     | 3         | X        |   |   |   | X | X | X | X | X                   | $[RB] \leftarrow [RB] + DATA8$<br>Add 8-bit immediate data to the RB register                                                       |
|                   | ADD      | RW,DATA16    | 4         | X        |   |   |   | X | X | X | X | X                   | $[RW] \leftarrow [RW] + DATA16$<br>Add 16-bit immediate data to the RW register                                                     |
|                   | ADD      | DADDR,DATA8  | 3, 4 or 5 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + DATA8$<br>Add 8-bit immediate data to the data memory byte addressed by DADDR                               |
|                   | ADD      | DADDR,DATA16 | 4, 5 or 6 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + DATA16$<br>Add 16-bit immediate data to the data memory word addressed by DADDR                             |
|                   | ADC      | AL,DATA8     | 2         | X        |   |   |   | X | X | X | X | X                   | $[AL] \leftarrow [AL] + DATA8 + [C]$<br>Add 8-bit immediate data, plus carry, to the AL register                                    |
|                   | ADC      | AX,DATA16    | 3         | X        |   |   |   | X | X | X | X | X                   | $[AX] \leftarrow [AX] + DATA16 + [C]$<br>Add 16-bit immediate data, plus carry, to the AX register                                  |
|                   | ADC      | RB,DATA8     | 3         | X        |   |   |   | X | X | X | X | X                   | $[RB] \leftarrow [RB] + DATA8 + [C]$<br>Add 8-bit immediate data, plus carry, to the RB register                                    |
|                   | ADC      | RW,DATA16    | 4         | X        |   |   |   | X | X | X | X | X                   | $[RW] \leftarrow [RW] + DATA16 + [C]$<br>Add 16-bit immediate data, plus carry, to the RW register                                  |
|                   | ADC      | DADDR,DATA8  | 3, 4 or 5 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + DATA8 + [C]$<br>Add 8-bit immediate data, plus carry, to the data memory byte addressed by DADDR            |
|                   | ADC      | DADDR,DATA16 | 4, 5 or 6 | X        |   |   |   | X | X | X | X | X                   | $[EA] \leftarrow [EA] + DATA16 + [C]$<br>Add 16-bit immediate data, plus carry, to the data memory word addressed by DADDR          |
|                   | AND      | AL,DATA8     | 2         | O        |   |   |   | X | X | U | X | O                   | $[AL] \leftarrow [AL] \text{ AND } DATA8$<br>AND 8-bit immediate data with AL register contents                                     |
|                   | AND      | AX,DATA16    | 3         | O        |   |   |   | X | X | U | X | O                   | $[AX] \leftarrow [AX] \text{ AND } DATA16$<br>AND 16-bit immediate data with AX register contents                                   |
|                   | AND      | RB,DATA8     | 3         | O        |   |   |   | X | X | U | X | O                   | $[RB] \leftarrow [RB] \text{ AND } DATA8$<br>AND 8-bit immediate data with RB register contents                                     |
|                   | AND      | RW,DATA16    | 4         | O        |   |   |   | X | X | U | X | O                   | $[RW] \leftarrow [RW] \text{ AND } DATA16$<br>AND 16-bit immediate data with RW register contents                                   |
|                   | AND      | DADDR,DATA8  | 3, 4 or 5 | O        |   |   |   | X | X | U | X | O                   | $[EA] \leftarrow [EA] \text{ AND } DATA8$<br>AND 8-bit immediate data with contents of data memory byte addressed by DADDR          |
|                   | AND      | DADDR,DATA16 | 4, 5 or 6 | O        |   |   |   | X | X | U | X | O                   | $[EA] \leftarrow [EA] \text{ AND } DATA16$<br>AND 16-bit immediate data with contents of 16-bit data memory word addressed by DADDR |
|                   | CMP      | AL,DATA8     | 2         | X        |   |   |   | X | X | X | X | X                   | $[AL] \leftarrow DATA8$<br>Subtract 8-bit immediate data from AL register contents. Discard result, but adjust status flags         |
|                   | CMP      | AX,DATA16    | 3         | X        |   |   |   | X | X | X | X | X                   | $[AX] \leftarrow DATA16$<br>Subtract 16-bit immediate data from AX register contents. Discard result, but adjust status flags       |
|                   | CMP      | RB,DATA8     | 3         | X        |   |   |   | X | X | X | X | X                   | $[RB] \leftarrow DATA8$<br>Subtract 8-bit immediate data from RB register contents. Discard result, but adjust status flags         |
|                   | CMP      | RW,DATA16    | 4         | X        |   |   |   | X | X | X | X | X                   | $[RW] \leftarrow DATA16$<br>Subtract 16-bit immediate data from RW register contents. Discard result, but adjust status flags       |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE              | MNEMONIC  | OPERAND(S)   | BYTES     | STATUSES |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                    |
|-------------------|-----------|--------------|-----------|----------|---|---|---|---|---|---|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |           |              |           | O        | D | I | T | S | Z | A | P                   |                                                                                                                                                                                                                                    |
| IMMEDIATE OPERATE | CMP       | DADDR,DATA8  | 3, 4 or 5 | X        |   |   |   | X | X | X | X                   | [EA] – DATA8<br>Subtract 8-bit immediate data from contents of data memory byte addressed by DADDR.<br>Discard result, but adjust status flags                                                                                     |
|                   | CMP       | DADDR,DATA16 | 4, 5 or 6 | X        |   |   |   | X | X | X | X                   | [EA] – DATA16<br>Subtract 16-bit immediate data from contents of 16-bit data memory word addressed by DADDR. Discard result, but adjust status flags                                                                               |
|                   | OR        | AL,DATA8     | 2         | O        |   |   |   | X | X | U | X                   | [AL] ← [AL] OR DATA8<br>OR 8-bit immediate data with AL register contents                                                                                                                                                          |
|                   | OR        | AX,DATA16    | 3         | O        |   |   |   | X | X | U | X                   | [AX] ← [AX] OR DATA16<br>OR 16-bit immediate data with AX register contents                                                                                                                                                        |
|                   | OR        | RB,DATA8     | 3         | O        |   |   |   | X | X | U | X                   | [RB] ← [RB] OR DATA8<br>OR 8-bit immediate data with RB register contents                                                                                                                                                          |
|                   | OR        | RW,DATA16    | 4         | O        |   |   |   | X | X | U | X                   | [RW] ← [RW] OR DATA16<br>OR 16-bit immediate data with RW register contents                                                                                                                                                        |
|                   | OR        | DADDR,DATA8  | 3, 4 or 5 | O        |   |   |   | X | X | U | X                   | [EA] ← [EA] OR DATA8<br>OR 8-bit immediate data with contents of data memory byte addressed by DADDR                                                                                                                               |
|                   | OR        | DADDR,DATA16 | 4, 5 or 6 | O        |   |   |   | X | X | U | X                   | [EA] ← [EA] OR DATA16<br>OR 16-bit immediate data with contents of 16-bit data memory word addressed by DADDR                                                                                                                      |
|                   | SBB       | AL,DATA8     | 2         | X        |   |   |   | X | X | X | X                   | [AL] ← [AL] – DATA8 – [C]<br>Subtract 8-bit immediate signed binary data from AL register contents using twos complement arithmetic. If the Carry status was originally 1 decrement the result                                     |
|                   | SBB       | AX,DATA16    | 3         | X        |   |   |   | X | X | X | X                   | [AX] ← [AX] – DATA16 – [C]<br>Subtract 16-bit immediate signed binary data from AX register contents using twos complement arithmetic. If the Carry status was originally 1 decrement the result                                   |
|                   | SBB       | RB,DATA8     | 3         | X        |   |   |   | X | X | X | X                   | [RB] ← [RB] – DATA8 – [C]<br>Subtract 8-bit immediate signed binary data from RB register contents using twos complement arithmetic. If the Carry status was originally 1 decrement the result                                     |
|                   | SBB       | RW,DATA16    | 4         | X        |   |   |   | X | X | X | X                   | [RW] ← [RW] – DATA16 – [C]<br>Subtract 16-bit immediate signed binary data from RW register contents using twos complement arithmetic. If the Carry status was originally 1 decrement the result                                   |
|                   | SBB       | DADDR,DATA8  | 3, 4 or 5 | X        |   |   |   | X | X | X | X                   | [EA] ← [EA] – DATA8 – [C]<br>Subtract 8-bit immediate signed binary data from contents of data memory byte addressed by DADDR using twos complement arithmetic. If the Carry status was originally 1 decrement the result          |
|                   | SBB       | DADDR,DATA16 | 4, 5 or 6 | X        |   |   |   | X | X | X | X                   | [EA] ← [EA] – DATA16 – [C]<br>Subtract 16-bit immediate signed binary data from contents of 16-bit data memory word addressed by DADDR using twos complement arithmetic. If the Carry status was originally 1 decrement the result |
| SUB               | AL,DATA8  | 2            | X         |          |   |   |   | X | X | X | X                   | [AL] ← [AL] – DATA8<br>Subtract the 8-bit immediate signed binary data from AL register contents using twos complement arithmetic                                                                                                  |
| SUB               | AX,DATA16 | 3            | X         |          |   |   |   | X | X | X | X                   | [AX] ← [AX] – DATA16<br>Subtract the 16-bit immediate signed binary data from AX register contents using twos complement arithmetic                                                                                                |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE              | MNEMONIC | OPERAND(S)   | BYTES     | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                      |
|-------------------|----------|--------------|-----------|----------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |          |              |           | O        | D | I | T | S | Z | A | P |                                                                                                                                                                                          |
| IMMEDIATE OPERATE | SUB      | RB,DATA8     | 3         | X        |   |   | X | X | X | X | X | [RB] $\leftarrow$ [RB] - DATA8<br>Subtract the 8-bit immediate signed binary data from RB register contents using twos complement arithmetic                                             |
|                   | SUB      | RW,DATA16    | 4         | X        |   |   | X | X | X | X | X | [RW] $\leftarrow$ [RW] - DATA16<br>Subtract the 16-bit immediate signed binary data from RW register contents using twos complement arithmetic                                           |
|                   | SUB      | DADDR,DATA8  | 3, 4 or 5 | X        |   |   | X | X | X | X | X | [EA] $\leftarrow$ [EA] - DATA8<br>Subtract the 8-bit immediate signed binary data from the contents of the data memory byte addressed by DADDR using twos complement arithmetic          |
|                   | SUB      | DADDR,DATA16 | 4, 5 or 6 | X        |   |   | X | X | X | X | X | [EA] $\leftarrow$ [EA] - DATA16<br>Subtract the 16-bit immediate signed binary data from the contents of the 16-bit data memory word addressed by DADDR using twos complement arithmetic |
|                   | TEST     | AL,DATA8     | 2         | O        |   |   | X | X | U | X | O | [AL] AND DATA8<br>AND the 8-bit immediate data and AL register contents. Discard the result but adjust status flags                                                                      |
|                   | TEST     | AX,DATA16    | 3         | O        |   |   | X | X | U | X | O | [AX] AND DATA16<br>AND the 16-bit immediate data and AX register contents. Discard the result but adjust status flags                                                                    |
|                   | TEST     | RB,DATA8     | 3         | O        |   |   | X | X | U | X | O | [RB] AND DATA8<br>AND the 8-bit immediate data and RB register contents. Discard the result but adjust status flags                                                                      |
|                   | TEST     | RW,DATA16    | 4         | O        |   |   | X | X | U | X | O | [RW] AND DATA16<br>AND the 16-bit immediate data and RW register contents. Discard the result but adjust status flags                                                                    |
|                   | TEST     | DADDR,DATA8  | 3, 4 or 5 | O        |   |   | X | X | U | X | O | [EA] AND DATA8<br>AND the 8-bit immediate data and the contents of the data memory location addressed by DADDR. Discard the result but adjust status flags                               |
|                   | TEST     | DADDR,DATA16 | 4, 5 or 6 | O        |   |   | X | X | U | X | O | [EA] AND DATA16<br>AND the 16-bit immediate data and the contents of the 16-bit data memory word addressed by DADDR. Discard the result but adjust status flags                          |
|                   | XOR      | AL,DATA8     | 2         | O        |   |   | X | X | U | X | O | [AL] $\leftarrow$ [AL] XOR DATA8<br>Exclusive OR 8-bit immediate data with AL register contents                                                                                          |
|                   | XOR      | AX,DATA16    | 3         | O        |   |   | X | X | U | X | O | [AX] $\leftarrow$ [AX] XOR DATA16<br>Exclusive OR 16-bit immediate data with AX register contents                                                                                        |
|                   | XOR      | RB,DATA8     | 3         | O        |   |   | X | X | U | X | O | [RB] $\leftarrow$ [RB] XOR DATA8<br>Exclusive OR 8-bit immediate data with RB register contents                                                                                          |
|                   | XOR      | RW,DATA16    | 4         | O        |   |   | X | X | U | X | O | [RW] $\leftarrow$ [RW] XOR DATA16<br>Exclusive OR 16-bit immediate data with RW register contents                                                                                        |
|                   | XOR      | DADDR,DATA8  | 3, 4 or 5 | O        |   |   | X | X | U | X | O | [EA] $\leftarrow$ [EA] XOR DATA8<br>Exclusive OR 8-bit immediate data with contents of the data memory byte addressed by DADDR                                                           |
|                   | XOR      | DADDR,DATA16 | 4, 5 or 6 | O        |   |   | X | X | U | X | O | [EA] $\leftarrow$ [EA] XOR DATA16<br>Exclusive OR 16-bit immediate data with contents of the 16-bit data memory word addressed by DADDR                                                  |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                               |
|---------------------|----------|------------|-------|----------|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|                     |          |            |       | O        | D | I | T | S | Z | A | P                   |                                                                                                                                               |
| JUMP ON CONDITION   | LOOP     | DISP8      | 2     |          |   |   |   |   |   |   |                     | [CX] ← [CX] -1 If [CX] ≠ 0 then [PC] ← [PC] + DISP8<br>Decrement CX register and branch if CX contents is not 0                               |
|                     | LOOPE    | DISP8      | 2     |          |   |   |   |   |   |   |                     | [CX] ← [CX] -1 If [CX] ≠ 0 and [Z] = 1 then [PC] ← [PC] + DISP8<br>Decrement CX register and branch if CX contents is not 0 and Z status is 1 |
|                     | LOOPNE   | DISP8      | 2     |          |   |   |   |   |   |   |                     | [CX] ← [CX] -1 If [CX] ≠ 0 and [Z] = 0 then [PC] ← [PC] + DISP8<br>Decrement CX register and branch if CX contents is not 0 and Z status is 0 |
|                     | LOOPNZ   | DISP8      | 2     |          |   |   |   |   |   |   |                     | See LOOPNE                                                                                                                                    |
|                     | LOOPZ    | DISP8      | 2     |          |   |   |   |   |   |   |                     | See LOOPE                                                                                                                                     |
|                     | JA       | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if C or Z is 0                                                                                                  |
|                     | JAE      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if C is 0                                                                                                       |
|                     | JB       | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if C is 1                                                                                                       |
| BRANCH ON CONDITION | JBE      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if C or Z is 1                                                                                                  |
|                     | JCXZ     | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if the CX register contents is 0                                                                                |
|                     | JE       | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if Z is 1                                                                                                       |
|                     | JG       | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if Z is 0 or the S and O statuses are the same                                                                  |
|                     | JGE      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if the S and O statuses are the same                                                                            |
|                     | JL       | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if the S and O statuses differ                                                                                  |
|                     | JLE      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if Z is 1 or the S and O statuses differ                                                                        |
|                     | JNA      | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JBE                                                                                                                                       |
|                     | JNAE     | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JB                                                                                                                                        |
|                     | JNB      | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JAE                                                                                                                                       |
|                     | JNBE     | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JA                                                                                                                                        |
|                     | JNE      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if Z is 0                                                                                                       |
|                     | JNG      | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JLE                                                                                                                                       |
|                     | JNGE     | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JL                                                                                                                                        |
|                     | JNL      | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JGE                                                                                                                                       |
|                     | JNLE     | DISP8      | 2     |          |   |   |   |   |   |   |                     | See JG                                                                                                                                        |
|                     | JNO      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if O is 0                                                                                                       |
|                     | JNP      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if P is 0                                                                                                       |
|                     | JNS      | DISP8      | 2     |          |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if S is 0                                                                                                       |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                      | MNEMONIC | OPERAND(S) | BYTES | STATUSES |     |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                               |
|---------------------------|----------|------------|-------|----------|-----|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           |          |            |       | O        | D   | I | T | S | Z | A | P | C                   |                                                                                                                                                                                                                                               |
| BRANCH ON CONDITION       | JNZ      | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | See JNE<br>[PC] ← [PC] + DISP8                                                                                                                                                                                                                |
|                           | JO       | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | Branch if O is 1                                                                                                                                                                                                                              |
|                           | JP       | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8                                                                                                                                                                                                                           |
|                           | JPE      | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | Branch if P is 1                                                                                                                                                                                                                              |
|                           | JPO      | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | See JP                                                                                                                                                                                                                                        |
|                           | JS       | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | See JNP                                                                                                                                                                                                                                       |
| REGISTER - REGISTER MOVE  | JZ       | DISP8      | 2     |          |     |   |   |   |   |   |   |                     | [PC] ← [PC] + DISP8<br>Branch if S is 1<br>See JE                                                                                                                                                                                             |
|                           | MOV      | RBD,RBS    | 2     |          |     |   |   |   |   |   |   |                     | [RBD] ← [RBS]<br>Move the contents of any RB register to any RB register                                                                                                                                                                      |
|                           | MOV      | RWD,RWS    | 2     |          |     |   |   |   |   |   |   |                     | [RWD] ← [RWS]<br>Move the contents of any RW register to any RW register                                                                                                                                                                      |
|                           | MOV      | SR,RW      | 2     |          |     |   |   |   |   |   |   |                     | [SR] ← [RWS]<br>Move the contents of any RW register to any Segment register                                                                                                                                                                  |
|                           | MOV      | RW,SR      | 2     |          |     |   |   |   |   |   |   |                     | [RWD] ← [SR]<br>Move the contents of any Segment register to any RW register                                                                                                                                                                  |
|                           | XCHG     | AX,RW      | 1     |          |     |   |   |   |   |   |   |                     | [AX] ↔ [RW]<br>Exchange the contents of AX and any RW register                                                                                                                                                                                |
|                           | XCHG     | RB,RB      | 2     |          |     |   |   |   |   |   |   |                     | [RB] ↔ [RB]<br>Exchange the contents of any two RB registers                                                                                                                                                                                  |
| BLOCK TRANSFER AND SEARCH | XCHG     | RW,RW      | 2     |          |     |   |   |   |   |   |   |                     | [RW] ↔ [RW]<br>Exchange the contents of any two RW registers                                                                                                                                                                                  |
|                           | CMPB     |            | 1     | X        | I/D |   |   | X | X | X | X | X                   | [[SI]] ← [[DI]], [SI] ← [SI] ≠ 1, [DI] ← [DI] ≠ 1<br>Compare the extra segment data bytes addressed by the SI and DI Index registers using string data addressing                                                                             |
|                           | CMPW     |            | 1     | X        | I/D |   |   | X | X | X | X | X                   | [[SI]] ← [[DI]], [SI] ← [SI] ≠ 2, [DI] ← [DI] ≠ 2<br>Compare the extra segment 16-bit data words addressed by the SI and DI Index registers using string data addressing                                                                      |
|                           | LODB     |            | 1     |          | I/D |   |   |   |   |   |   |                     | [AL] ← [[SI]], [SI] ← [SI] ± 1<br>Move a data byte from the extra segment location addressed by the SI Index register to the AL register using string data addressing                                                                         |
|                           | LODW     |            | 1     |          | I/D |   |   |   |   |   |   |                     | [AX] ← [[SI]], [SI] ← [SI] ± 1<br>Move a data word from the 16-bit extra segment location addressed by the SI Index register to the AX register using string data addressing                                                                  |
|                           | MOVB     |            | 1     |          | I/D |   |   |   |   |   |   |                     | [[DI]] ← [[SI]], [SI] ← [SI] ≠ 1, [DI] ← [DI] ≠ 1<br>Move a data byte from the extra segment location addressed by the SI Index register to the extra segment location addressed by the DI register using string data addressing              |
|                           | MOVW     |            | 1     |          | I/D |   |   |   |   |   |   |                     | [[DI]] ← [[SI]], [SI] ← [SI] ≠ 2, [DI] ← [DI] ≠ 2<br>Move a 16-bit data word from the extra segment location addressed by the SI Index register to the extra segment location addressed by the DI Index register using string data addressing |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                        | MNEMONIC | OPERAND(S) | BYTES | STATUSES |     |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                                                                                                        |
|-----------------------------|----------|------------|-------|----------|-----|---|---|---|---|---|---|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |          |            |       | O        | D   | I | T | S | Z | A | P | C                   |                                                                                                                                                                                                                                                                                                        |
| BLOCK TRANSFER AND SEARCH   | REP      | N          | 1     |          | I/D |   |   |   |   |   |   |                     | Repeat the next sequential instruction (which must be a Block Transfer and Search instruction) until CX contents decrements to 0. Decrement CX contents on each repeat. If the next instruction is CMPB, CMPW, SCAB or SCAW then repeat until CX contents decrements to 0 or Z status does not equal N |
|                             | SCAB     |            | 1     | X        | I/D |   |   | X | X | X | X | X                   | $[AL] \leftarrow [DI]$ , $[DI] \leftarrow [DI] \pm 1$<br>Compare AL register contents with the extra segment data byte addressed by the DI Index register using string data addressing                                                                                                                 |
|                             | SCAW     |            | 1     | X        | I/D |   |   | X | X | X | X | X                   | $[AX] \leftarrow [DI]$ , $[DI] \leftarrow [DI] \pm 2$<br>Compare AX register contents with the extra segment 16-bit data word addressed by the DI Index register using string data addressing                                                                                                          |
|                             | STOB     |            | 1     | X        | I/D |   |   | X | X | X | X | X                   | $[(DI)] \leftarrow [AL]$ , $[DI] \leftarrow [DI] \pm 1$<br>Store the AL register contents in the extra segment data memory byte addressed by the DI Index register using string data addressing                                                                                                        |
|                             | STOW     |            | 1     | X        | I/D |   |   | X | X | X | X | X                   | $[(DI)] \leftarrow [AX]$ , $[DI] \leftarrow [DI] \pm 2$<br>Store the AX register contents in the extra segment 16-bit data memory:word addressed by the DI Index register using string data addressing.                                                                                                |
| REGISTER - REGISTER OPERATE | ADC      | RBD,RBS    | 2     | X        |     |   |   | X | X | X | X | X                   | $[RBD] \leftarrow [RBD] + [RBS] + [C]$<br>Add the 8-bit contents of register RBS, plus the Carry status, to register RBD                                                                                                                                                                               |
|                             | ADC      | RWD,RWS    | 2     | X        |     |   |   | X | X | X | X | X                   | $[RWD] \leftarrow [RWD] + [RWS] + [C]$<br>Add the 16-bit contents of register RWS, plus the Carry status, to register RWD                                                                                                                                                                              |
|                             | ADD      | RBD,RBS    | 2     | X        |     |   |   | X | X | X | X | X                   | $[RBD] \leftarrow [RBD] + [RBS]$<br>Add the 8-bit contents of register RBS to register RBD                                                                                                                                                                                                             |
|                             | ADD      | RWD,RWS    | 2     | X        |     |   |   | X | X | X | X | X                   | $[RWD] \leftarrow [RWD] + [RWS]$<br>Add the 16-bit contents of register RWS to register RWD                                                                                                                                                                                                            |
|                             | AND      | RBD,RBS    | 2     | O        |     |   |   | X | X | U | X | O                   | $[RAD] \leftarrow [RBD] \text{ AND } [RBS]$<br>AND the 8-bit contents of register RBS with register RBD                                                                                                                                                                                                |
|                             | AND      | RWD,RWS    | 2     | O        |     |   |   | X | X | U | X | O                   | $[RWD] \leftarrow [RWD] \text{ AND } [RWS]$<br>AND the 16-bit contents of register RWS with register RWD                                                                                                                                                                                               |
|                             | CBW      |            | 1     |          |     |   |   |   |   |   |   |                     | $[AH] \leftarrow [AL7]$<br>Extend AL sign bit into AH                                                                                                                                                                                                                                                  |
|                             | CWD      |            | 1     |          |     |   |   |   |   |   |   |                     | $[DX] \leftarrow [AX15]$<br>Extend AX sign bit into DX                                                                                                                                                                                                                                                 |
|                             | OR       | RBD,RBS    | 2     | O        |     |   |   | X | X | U | X | O                   | $[RBD] \leftarrow [RBD] \text{ OR } [RBS]$<br>OR the 8-bit contents of register RBS with register RBD                                                                                                                                                                                                  |
|                             | OR       | RWD,RWS    | 2     | O        |     |   |   | X | X | U | X | O                   | $[RWD] \leftarrow [RWD] \text{ OR } [RWS]$<br>OR the 16-bit contents of register RWS with register RWD                                                                                                                                                                                                 |
| SBB                         | RBD,RBS  | 2          | X     |          |     |   |   | X | X | X | X | X                   | $[RBD] \leftarrow [RBD] - [RBS] - [C]$<br>Subtract the 8-bit contents of register RBS from RBD using twos complement arithmetic.<br>If the Carry status was originally 1 decrement the result                                                                                                          |
|                             | RWD,RWS  | 2          | X     |          |     |   |   | X | X | X | X | X                   | $[RWD] \leftarrow [RWD] - [RWS] - [C]$<br>Subtract the 16-bit contents of register RWS from RWD using twos complement arithmetic.<br>If the Carry status was originally 1 decrement the result                                                                                                         |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE                           | MNEMONIC | OPERAND(S) | BYTES  | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                        |                                                                                                                                                               |
|--------------------------------|----------|------------|--------|----------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                |          |            |        | O        | D | I | T | S | Z | A | P |                                                                                                                                                            |                                                                                                                                                               |
| REGISTER -<br>REGISTER OPERATE | SUB      | RBD,RBS    | 2      | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RBD] \leftarrow [RBD] - [RBS]$<br>Subtract the 8-bit contents of register RBS from RBD using twos complement arithmetic                                     |
|                                | SUB      | RWD,RWS    | 2      | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RWD] \leftarrow [RWD] - [RWS]$<br>Subtract the 16-bit contents of register RWS from RWD using twos complement arithmetic                                    |
|                                | XOR      | RBD,RBS    | 2      | O        |   |   |   | X | X | U | X | O                                                                                                                                                          | $[RBD] \leftarrow [RBD] \text{ XOR } [RBS]$<br>Exclusive OR the 8-bit contents of register RBS with register RBD                                              |
|                                | XOR      | RWD,RWS    | 2      | O        |   |   |   | X | X | U | X | O                                                                                                                                                          | $[RWD] \leftarrow [RWD] \text{ XOR } [RWS]$<br>Exclusive OR the 16-bit contents of register RWS with register RWD                                             |
| REGISTER OPERATE               | AAA      |            | 1      | U        |   |   |   | U | U | X | U | X                                                                                                                                                          | ASCII adjust AL register contents for addition (as described in accompanying text)                                                                            |
|                                |          | 2          | U      |          |   |   | X | X | U | X | U | Decimal adjust dividend in AL prior to dividing an unpacked decimal divisor, to generate an unpacked decimal quotient. (See accompanying text for details) |                                                                                                                                                               |
|                                | AAM      |            | 2      | U        |   |   |   | X | X | U | X | U                                                                                                                                                          | After multiplying two unpacked decimal operands, adjust product in AX to become an unpacked decimal result. (See accompanying text for details)               |
|                                | AAS      |            | 1      | U        |   |   |   | U | U | X | U | X                                                                                                                                                          | After subtracting two unpacked decimal numbers, adjust the difference in AL so that it too is an unpacked decimal number. (See accompanying text for details) |
|                                | DAA      |            | 1      | U        |   |   |   | X | X | X | X | X                                                                                                                                                          | After adding two packed decimal numbers, adjust the sum in AL so that it too is a packed decimal number. (See accompanying text for details)                  |
|                                | DAS      |            | 1      | U        |   |   |   | X | X | X | X | X                                                                                                                                                          | After subtracting two packed decimal numbers, adjust the difference in AL so that it too is a packed decimal number. (See accompanying text for details)      |
|                                | DEC      | RB         | 2      | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RB] \leftarrow [RB] - 1$<br>Decrement the 8-bit contents of register RB                                                                                     |
|                                | DEC      | RW         | 1 or 2 | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RW] \leftarrow [RW] - 1$<br>Decrement the 16-bit contents of register RW                                                                                    |
|                                | INC      | RB         | 2      | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RB] \leftarrow [RB] + 1$<br>Increment the 8-bit contents of register RB                                                                                     |
|                                | INC      | RW         | 1 or 2 | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RW] \leftarrow [RW] + 1$<br>Increment the 16-bit contents of register RW                                                                                    |
|                                | NEG      | RB         | 2      | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RB] \leftarrow [RB] + 1$<br>Twos complement the 8-bit contents of register RB                                                                               |
|                                | NEG      | RW         | 2      | X        |   |   |   | X | X | X | X | X                                                                                                                                                          | $[RW] \leftarrow [RW] + 1$<br>Twos complement the 16-bit contents of register RW                                                                              |
|                                | NOT      | RB         | 2      |          |   |   |   |   |   |   |   |                                                                                                                                                            | $[RB] \leftarrow [RB]$<br>Ones complement the 8-bit contents of register RB                                                                                   |
|                                | NOT      | RW         | 2      |          |   |   |   |   |   |   |   |                                                                                                                                                            | $[RW] \leftarrow [RW]$<br>Ones complement the 16-bit contents of register RW                                                                                  |
|                                | RCL      | RB         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate left through Carry the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                         |
|                                | RCL      | RW         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate right through Carry the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                        |
|                                | RCR      | RB         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate left the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                       |
|                                | RCR      | RW         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate right the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                      |
|                                | ROL      | RB         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate left the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                       |
|                                | ROL      | RW         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate right the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                      |
|                                | ROR      | RB         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate left the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                       |
|                                | ROR      | RW         | 2      | X        |   |   |   |   |   |   |   | X                                                                                                                                                          | Rotate right the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                      |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE             | MNEMONIC | OPERAND(S) | BYTES  | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                   |
|------------------|----------|------------|--------|----------|---|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |          |            |        | O        | D | I | T | S | Z | A | P | C                   |                                                                                                                                                                                   |
| REGISTER OPERATE | SAL      | RB         | 2      | X        |   |   |   | X | X | U | X | X                   | Shift left the 8-bit contents of RB register, or the 16-bit contents of RW register, as illustrated for memory operate                                                            |
|                  | SAL      | RW         | 2      | X        |   |   |   | X | X | U | X | X                   | Shift right the 8-bit contents of register RB, or the 16-bit contents of register RW, as illustrated for memory operate                                                           |
|                  | SAR      | RB         | 2      | X        |   |   |   | X | X | U | X | X                   | See SAL                                                                                                                                                                           |
|                  | SAR      | RW         | 2      | X        |   |   |   | X | X | U | X | X                   | See SAL                                                                                                                                                                           |
|                  | SHL      | RB         | 2      | X        |   |   |   | X | X | U | X | X'                  | Shift right the 8-bit contents of register RB, or the 16-bit contents of register RW, as illustrated for memory operate                                                           |
|                  | SHL      | RW         | 2      | X        |   |   |   | X | X | U | X | X                   | See SAL                                                                                                                                                                           |
|                  | SHR      | RB         | 2      | X        |   |   |   | X | X | U | X | X                   | Shift right the 8-bit contents of register RB, or the 16-bit contents of register RW, as illustrated for memory operate                                                           |
|                  | SHR      | RW         | 2      | X        |   |   |   | X | X | U | X | X                   | See SAL                                                                                                                                                                           |
| STACK            | POP      | DADDR      | 2      |          |   |   |   |   |   |   |   |                     | [EA] ← [ISP], [SP] ← [SP] +2<br>Load the 16-bit stack word, addressed using stack addressing, into the 16-bit data memory word addressed by DADDR. Increment SP by 2              |
|                  | POP      | RW         | 1 or 2 |          |   |   |   |   |   |   |   |                     | [RW or SR] ← [ISP], [SP] ← [SP] +2<br>Load the 16-bit stack word, addressed using stack addressing, into the specified 16-bit register. Increment SP by 2                         |
|                  | POPF     | SR         | 1      | X        | X | X | X | X | X | X | X |                     | [SFR] ← [ISP], [SP] ← [SP] +2<br>Load the 16-bit stack word, addressed using stack addressing, into the Status flags register                                                     |
|                  | PUSH     | DADDR      | 2      |          |   |   |   |   |   |   |   |                     | [SP] ← [SP] -2, [ISP] ← [EA]<br>Store the 16-bit contents of the data memory word addressed by DADDR in the 16-bit stack word addressed using stack addressing. Decrement SP by 2 |
|                  | PUSH     | RW         | 1 or 2 |          |   |   |   |   |   |   |   |                     | [SP] ← [SP] -2, [ISP] ← [RW or SR]<br>Store the contents of the specified 16-bit register in the 16-bit stack word addressed using stack addressing. Decrement SP by 2            |
|                  | PUSH     | SR         | 1      |          |   |   |   |   |   |   |   |                     | [SP] ← [SP] +2, [ISP] ← [SFR]<br>Store the Status flags register contents in the 16-bit stack word addressed using stack addressing. Decrement SP by 2                            |
|                  | PUSHF    |            | 1      |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                                   |
| INTERRUPTS       | INT      | 3          | 1      |          |   | O | O |   |   |   |   |                     | Execute a software interrupt and vector through table entry 3                                                                                                                     |
|                  | INT      | V          | 2      |          |   | O | O |   |   |   |   |                     | Execute a software interrupt and vector through table entry V                                                                                                                     |
|                  | INTO     |            | 1      |          |   | O | O |   |   |   |   |                     | If the O status is 1, execute a software interrupt and vector through table entry 10 <sub>16</sub>                                                                                |
|                  | IRET     |            | 1      |          |   |   |   |   |   |   |   |                     | Return from interrupt service routine                                                                                                                                             |
| STATUS           | CLC      |            | 1      |          |   |   |   |   |   |   | O |                     | [C] ← 0<br>Clear Carry status                                                                                                                                                     |
|                  | CLD      |            | 1      |          | O |   |   |   |   |   |   |                     | [D] ← 0<br>Clear Decrement/Increment select                                                                                                                                       |
|                  | CLI      |            | 1      |          | O |   |   |   |   |   |   |                     | [I] ← 0<br>Clear Interrupt enable status, disabling all interrupts                                                                                                                |
|                  | CMC      |            | 1      |          |   |   |   |   |   |   |   |                     | [C] ← [C̄]<br>Complement Carry status                                                                                                                                             |
|                  | FALC     |            | 1      |          |   |   |   |   |   |   | X |                     | [AL] ← 0 if [C] = 0, [AL] ← FF if [C] = 1<br>Fill AL with Carry                                                                                                                   |

Table 20-4. The 8086 Instruction Set Summary (Continued)

| TYPE   | MNEMONIC | OPERAND(S) | BYTES | STATUSES |   |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|--------|----------|------------|-------|----------|---|---|---|---|---|---|---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
|        |          |            |       | O        | D | I | T | S | Z | A | P | C                   |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| STATUS | LAHF     |            | 1     |          |   |   |   |   |   |   |   |                     | Transfer flags to AH register as follows:<br>7 6 5 4 3 2 1 0 Bit no.<br><br>S Z O A O P I C | Transfer AH register contents to status flags as follows:<br>7 6 5 4 3 2 1 0 Bit no.<br><br>S Z A P C<br>[C] ← 1<br>Set Carry status to 1<br>[D] ← 1<br>Set Decrement/Increment status to 1<br>[I] ← 1<br>Set Interrupt enable status to 1, enabling all interrupts |  |  |  |  |  |  |  |  |  |
|        | SAHF     |            | 1     |          |   |   |   | X | X | X | X | X                   |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|        | STC      |            | 1     |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|        | STD      |            | 1     |          |   | 1 |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|        | STI      |            | 1     |          |   | 1 |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| I/O    | ESC      | DADDR      | 2     |          |   |   |   |   |   |   |   |                     | ? ← [EA]<br>The contents of the data memory location addressed by DADDR is read out of memory and placed on the data bus; however, it is not input to the CPU                 | CPU Halt<br>Guarantee the CPU bus control during execution of the next sequential instruction<br>The next sequential allowed memory reference instruction accesses the segment identified by Segment register SR. See Table 20-1 for allowed memory reference instructions<br>CPU enters the WAIT state until TEST pin receives a high input signal   |  |  |  |  |  |  |  |  |  |
|        | HLT      | SR         | 1     |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|        | LOCK     |            | 1     |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|        | SEG      |            | 1     |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|        | WAIT     |            | 1     |          |   |   |   |   |   |   |   |                     |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |

## INSTRUCTION EXECUTION TIMES AND CODES

Table 20-5 lists instructions in alphabetical order, showing object codes and execution times, expressed in whole clock cycles. Execution time is the time required from beginning execution of an instruction that is in the queue to beginning execution of the next instruction in the queue. The time required to place an instruction from memory into the queue (instruction fetch time) is not shown in the table; because of queuing, instruction fetch time occurs concurrently with instruction execution time and thus has no effect on overall timing, except as specifically noted in the table.

Instruction object codes are represented as two hexadecimal digits for instruction bytes without variations.

Instruction object codes are represented as eight binary digits for instruction bytes with variations for the instruction.

The following notation is used in Table 20-5:

| [ ]  | indicate an optional object code byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|----|-----|----|----|
| a    | one bit choosing data length:<br>a <sub>0</sub> = 1 data byte a <sub>1</sub> 0 = 2 data bytes<br>1 = 2 data bytes 1 = 1 data byte                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| aa   | two bits choosing address length:<br>no DISP = 00<br>one DISP byte = 01<br>two DISP bytes = 10, or 00 with bbb = 110                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| bbb  | three bits choosing addressing mode:<br>000 EA = (BX) + (SI) + DISP<br>001 EA = (BX) + (DI) + DISP<br>010 EA = (BP) + (SI) + DISP<br>011 EA = (BP) + (DI) + DISP<br>100 EA = (SI) + DISP<br>101 EA = (DI) + DISP<br>110 EA = (BP) + DISP<br>111 EA = (BX) + DISP                                                                                                                                                                                                                                                                                                                 |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| DISP | represents two hexadecimal digit memory displacement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| ddd  | represents three binary digits identifying a destination register (see reg).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| rr   | two binary digits identifying a segment register:<br>00 = ES<br>01 = CS<br>10 = SS<br>11 = DS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| reg  | three binary digits identifying a register:<br><table style="margin-left: 20px;"> <thead> <tr> <th></th> <th>16-bit</th> <th>8-bit</th> </tr> </thead> <tbody> <tr> <td>000</td> <td>AX</td> <td>AL</td> </tr> <tr> <td>001</td> <td>CX</td> <td>CL</td> </tr> <tr> <td>010</td> <td>DX</td> <td>DL</td> </tr> <tr> <td>011</td> <td>BX</td> <td>BL</td> </tr> <tr> <td>100</td> <td>SP</td> <td>AH</td> </tr> <tr> <td>101</td> <td>BP</td> <td>CH</td> </tr> <tr> <td>110</td> <td>SI</td> <td>DH</td> </tr> <tr> <td>111</td> <td>DI</td> <td>BH</td> </tr> </tbody> </table> |       | 16-bit | 8-bit | 000 | AX | AL | 001 | CX | CL | 010 | DX | DL | 011 | BX | BL | 100 | SP | AH | 101 | BP | CH | 110 | SI | DH | 111 | DI | BH |
|      | 16-bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 8-bit |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 000  | AX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | AL    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 001  | CX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CL    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 010  | DX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DL    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 011  | BX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BL    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 100  | SP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | AH    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 101  | BP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CH    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 110  | SI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DH    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| 111  | DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BH    |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| sss  | represents three binary digits identifying a source register (see reg).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| ppqq | represents four hexadecimal digit memory address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| v    | one bit choosing shift length:<br>0 count = 1<br>1 count = (CL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| x    | "don't care" bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| YY   | represents two hexadecimal data digits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| YYYY | represents four hexadecimal data digits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| Z    | one bit where Z XOR (ZF) = 1 terminates loop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| *    | Execution time is less than or equal to instruction fetch time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| **   | Includes up to eight clock cycles of overhead on each transfer due to queue maintenance. For conditional jumps, the lesser figure is when the test fails (no jump taken).                                                                                                                                                                                                                                                                                                                                                                                                        |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |
| EA   | = from five to twelve additional cycles, depending on addressing mode, required for address calculation only (R/W cycles are included above).                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |        |       |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |     |    |    |

Table 20-5. A Summary of 8086 Instruction Object Codes and Execution Cycles

| INSTRUCTION | OBJECT CODE    | BYTES                                     | CLOCK PERIODS |         |
|-------------|----------------|-------------------------------------------|---------------|---------|
| AAA         | 37             | 1                                         | 4*            |         |
| AAD         | D5 0A          | 2                                         | 60            |         |
| AAM         | D4 0A          | 2                                         | 83            |         |
| AAS         | 3F             | 1                                         | 4*            |         |
| ADC         | AL,DATA8       | 14 YY                                     | 2             | 4*      |
| ADC         | AX,DATA16      | 15 YYYY                                   | 3             | 4*      |
| ADC         | DADDR,DATA8    | 80 aa010bbb<br>[DISP] [DISP] YY           | 3, 4 or 5     | 17+EA   |
| ADC         | DADDR,DATA16   | 100000a1 aa010bbb<br>[DISP] [DISP] YY[YY] | 3, 4, 5 or 6  | 17+EA   |
| ADC         | DADDR,RB       | 10 aaddbbb                                | 2, 3 or 4     | 16+EA   |
| ADC         | DADDR,RW       | 11 aaddbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 16+EA   |
| ADC         | RB,DADDR       | 12 aassbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 9+EA    |
| ADC         | RB,DATA8       | 80 11010ddd YY                            | 3             | 4*      |
| ADC         | RBD,RBS        | 12 11dddsss                               | 2             | 3*      |
| ADC         | RW,DADDR       | 13 aassbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 9+EA    |
| ADC         | RW,DATA16      | 100000a1 11010ddd<br>YY[YY]               | 3 or 4        | 4*      |
| ADC         | RWD,RWS        | 13 11dddsss                               | 2             | 3*      |
| ADD         | AL,DATA8       | 04 YY                                     | 2             | 4*      |
| ADD         | AX,DATA16      | 05 YYYY                                   | 3             | 4*      |
| ADD         | DADDR,DATA8    | 80 aa000bbb<br>[DISP] [DISP] YY           | 3, 4 or 5     | 17+EA   |
| ADD         | DADDR,DATA16   | 100000a1 aa000bbb<br>[DISP] [DISP] YY[YY] | 3, 4, 5 or 6  | 17+EA   |
| ADD         | DADDR,RB       | 00 aaddbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 16+EA   |
| ADD         | DADDR,RW       | 01 aaddbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 16+EA   |
| ADD         | RB,DADDR       | 02 aassbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 9+EA    |
| ADD         | RB,DATA8       | 80 1100ddd YY                             | 3             | 4*      |
| ADD         | RBD,RBS        | 02 11dddsss                               | 2             | 3*      |
| ADD         | RW,DADDR       | 03 aassbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 9+EA    |
| ADD         | RW,DATA16      | 100000a1 11000ddd<br>YY[YY]               | 3 or 4        | 4*      |
| ADD         | RWD,RWS        | 03 11dddsss                               | 2             | 3*      |
| AND         | AL,DATA8       | 24 YY                                     | 2             | 4*      |
| AND         | AX,DATA16      | 25 YYYY                                   | 3             | 4*      |
| AND         | DADDR,DATA8    | 80 aa10bbb<br>[DISP] [DISP] YY            | 3, 4 or 5     | 17+EA   |
| AND         | DADDR,DATA16   | 81 aa10bbb<br>[DISP] [DISP] YYYY          | 4, 5 or 6     | 17+EA   |
| AND         | DADDR,RB       | 20 aassbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 16+EA   |
| AND         | DADDR,RW       | 21 aassbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 16+EA   |
| AND         | RB,DADDR       | 22 aaddbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 9+EA    |
| AND         | RB,DATA8       | 80 1110sss YY                             | 3             | 4*      |
| AND         | RBD,RBS        | 22 11dddsss                               | 2             | 3*      |
| AND         | RW,DADDR       | 23 aaddbbb<br>[DISP] [DISP]               | 2, 3 or 4     | 9+EA    |
| AND         | RW,DATA16      | 81 1110sss YYYY                           | 4             | 4*      |
| AND         | RWD,RWS        | 23 11dddsss                               | 2             | 3*      |
| CALL        | BRANCH         | E8 DISP                                   | 3             | 19**    |
| CALL        | BRANCH,SEGMENT | 9A ppqqppqq                               | 5             | 28**    |
| CALL        | DADDR          | FF aa010bbb<br>[DISP] [DISP]              | 2, 3 or 4     | 21+EA** |

Table 20-5. A Summary of 8086 Instruction Object Codes and Execution Cycles (Continued)

| INSTRUCTION |              | OBJECT CODE                               | BYTES        | CLOCK PERIODS |
|-------------|--------------|-------------------------------------------|--------------|---------------|
| CALL        | DADDR,CS     | FF aa011bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 37+EA**       |
| CALL        | RW           | FF 11010reg                               | 2            | 21+EA**       |
| CBW         |              | 98                                        | 1            | 5             |
| CLC         |              | F8                                        | 1            | 2*            |
| CLD         |              | FC                                        | 1            | 2*            |
| CLI         |              | FA                                        | 1            | 2*            |
| CMC         |              | F5                                        | 1            | 2*            |
| CMP         | AL,DATA8     | 3C YY                                     | 2            | 4*            |
| CMP         | AX,DATA16    | 3D YYYY                                   | 3            | 4*            |
| CMP         | DADDR,DATA8  | 80 aa111bbb<br>[DISP] [DISP] YY           | 3, 4 or 5    | 17+EA         |
| CMP         | DADDR,DATA16 | 100000a1 aa111bbb<br>[DISP] [DISP] YY[YY] | 3, 4, 5 or 6 | 17+EA         |
| CMP         | DADDR,RB     | 38 aaaaaaaaaa<br>[DISP] [DISP]            | 2, 3 or 4    | 16+EA         |
| CMP         | DADDR,RW     | 39 aaaaaaaaaa<br>[DISP] [DISP]            | 2, 3 or 4    | 16+EA         |
| CMP         | RB,DADDR     | 3A aaaaaaaaaa<br>[DISP] [DISP]            | 2, 3 or 4    | 9+EA          |
| CMP         | RB,DATA8     | 80 11111ddd YY                            | 3            | 4*            |
| CMP         | RBD,RBS      | 3A 11dddddss                              | 2            | 3*            |
| CMP         | RW,DADDR     | 3B aaaaaaaaaa<br>[DISP] [DISP]            | 2, 3 or 4    | 9+EA          |
| CMP         | RW,DATA16    | 100000a1 11111ddd<br>YY[YY]               | 3 or 4       | 4*            |
| CMP         | RWD,RWS      | 3B 11dddddss<br>A6                        | 2            | 3*            |
| CMPB        |              | A7                                        | 1            | 22            |
| CMPW        |              | 99                                        | 1            | 22            |
| CWD         |              | 27                                        | 1            | 5             |
| DAA         |              | 2F                                        | 1            | 4*            |
| DAS         |              | 1111.111a aa001bbb<br>[DISP] [DISP]       | 2, 3 or 4    | 4*            |
| DEC         | DADDR        | 1111.111a aa001bbb<br>[DISP] [DISP]       | 2, 3 or 4    | 15+EA         |
| DEC         | RB           | FE 11001ddd                               | 2            | 2*            |
| DEC         | RW           | 01001ddd                                  | 1            | 2*            |
| DIV         | AX,DADDR     | F6 aa110bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 90+EA         |
| DIV         | DX,DADDR     | F7 aa110bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 155+EA        |
| ESC         | DADDR        | 1101xxxx aaxxxbbb<br>[DISP] [DISP]        | 2, 3 or 4    | 7+EA          |
| FALC        |              | D6                                        | 1            | 4*            |
| HLT         |              | F4                                        | 1            | 2*            |
| IDIV        | AX,DADDR     | F6 aa111bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 112+EA        |
| IDIV        | DX,DADDR     | F7 aa111bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 177+EA        |
| IMUL        | AL,DADDR     | F6 aa101bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 90+EA         |
| IMUL        | AX,DADDR     | F7 aa101bbb<br>[DISP] [DISP]              | 2, 3 or 4    | 144+EA        |
| IN          |              | EC                                        | 1            | 8             |
| IN          | PORT         | E4 YY                                     | 2            | 10            |
| INC         | DADDR        | 1111111a aa000bbb<br>[DISP] [DISP]        | 2, 3 or 4    | 15+EA         |
| INC         | RB           | FE 11000ddd                               | 2            | 2*            |
| INC         | RW           | 01000ddd                                  | 1            | 2*            |
| INT         | 3            | CC                                        | 1            | 60            |
| INT         | V            | CD YY                                     | 2            | 60            |
| INTO        |              | CE                                        | 1            | 60            |
| INW         |              | ED                                        | 1            | 8             |
| INW         | PORT         | E5 YY                                     | 2            | 10            |
| IRET        |              | CF                                        | 1            | 32**          |

Table 20-5. A Summary of 8086 Instruction Object Codes and Execution Cycles (Continued)

| INSTRUCTION   | OBJECT CODE  | BYTES                             | CLOCK PERIODS |
|---------------|--------------|-----------------------------------|---------------|
| JA/JNB        | DISP8        | 77 DISP                           | 2             |
| JAE/JNB       | DISP8        | 73 DISP                           | 2             |
| JB/JNAE       | DISP8        | 72 DISP                           | 2             |
| JBE/JNA       | DISP8        | 76 DISP                           | 2             |
| JCXZ          | DISP8        | 63 DISP                           | 2             |
| JE/JZ         | DISP8        | 74 DISP                           | 2             |
| JG/JNLE       | DISP8        | 7F DISP                           | 2             |
| JGE/JNL       | DISP8        | 7D DISP                           | 2             |
| JL/JNGE       | DISP8        | 7C DISP                           | 2             |
| JLE/JNG       | DISP8        | 7E DISP                           | 2             |
| JMP           | BRANCH       | 111010X1 DISP [DISP]              | 2 or 3        |
| JMP           | BRANCH,SEGM  | EA ppqq ppqq                      | 5             |
| JMP           | DADDR        | FF aa100bbb<br>[DISP] [DISP]      | 2, 3 or 4     |
| JMP           | DADDR,CS     | FF aa101bbb<br>[DISP] [DISP]      | 2, 3 or 4     |
| JMP           | RW           | FF 1110reg                        | 2             |
| JNE/JNZ       | DISP8        | 75 DISP                           | 2             |
| JNO           | DISP8        | 71 DISP                           | 2             |
| JNP/JPO       | DISP8        | 6B DISP                           | 2             |
| JNS           | DISP8        | 79 DISP                           | 2             |
| JO            | DISP8        | 70 DISP                           | 2             |
| JP/JPE        | DISP8        | 7A DISP                           | 2             |
| JS            | DISP8        | 78 DISP                           | 2             |
| LAHF          |              | 9F                                | 1             |
| LDS           | RW,DADDR     | C5 aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| LEA           | RW,DADDR     | 8D aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| LES           | RW,DADDR     | C4 aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| LOCK          |              | F0                                | 1             |
| LODB          |              | AC                                | 1             |
| LODW          |              | AD                                | 1             |
| LOOP          | DISP8        | E2 DISP                           | 2             |
| LOOPE/LOOPZ   | DISP8        | E1 DISP                           | 2             |
| LOOPNE/LOOPNZ | DISP8        | E0 DISP                           | 2             |
| MOV           | AL,LABEL     | A0 ppqq                           | 3             |
| MOV           | AX,LABEL     | A1 ppqq                           | 3             |
| MOV           | DADDR,DATA8  | C6 aa000bbb<br>[DISP] [DISP] YY   | 3, 4 or 5     |
| MOV           | DADDR,DATA16 | C7 aa000bbb<br>[DISP] [DISP] YYYY | 4, 5 or 6     |
| MOV           | DADDR,RB     | 88 aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| MOV           | DADDR,RW     | 89 aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| MOV           | DADDR,SR     | 8C aa0rrbbb<br>[DISP] [DISP]      | 2, 3 or 4     |
| MOV           | LABEL,AL     | A2 ppqq                           | 3             |
| MOV           | LABEL,AX     | A3 ppqq                           | 3             |
| MOV           | RB,DADDR     | 8A aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| MOV           | RB,DATA8     | 10110ddd YY                       | 2             |
| MOV           | RBD,RBS      | 8A 11ddsss                        | 2             |
| MOV           | RW,DADDR     | 8B aaaaaaaaaa<br>[DISP] [DISP]    | 2, 3 or 4     |
| MOV           | RW,DATA16    | 10111ddd YYYY                     | 3             |
| MOV           | RW,SR        | 8C 11Orsss                        | 2             |
| MOV           | RWD,RWS      | 8B 11ddsss                        | 2             |
| MOV           | SR,DADDR     | 8E aa0rrbbb<br>[DISP] [DISP]      | 2, 3 or 4     |
| MOV           | SR,RW        | 8E 11Orsss                        | 2             |
| MOV           | MOVB         | A4                                | 1             |

Table 20-5. A Summary of 8086 Instruction Object Codes and Execution Cycles (Continued)

| INSTRUCTION     |              | OBJECT CODE                        | BYTES     | CLOCK PERIODS                    |
|-----------------|--------------|------------------------------------|-----------|----------------------------------|
| MOVW            |              | A5                                 | 1         | 17                               |
| MUL             | AL,DADDR     | F6 aa100bbb<br>[DISP] [DISP]       | 2, 3 or 4 | 71+EA                            |
| MUL             | AX,DADDR     | F7 aa100bbb<br>[DISP] [DISP]       | 2, 3 or 4 | 124+EA                           |
| NEG             | DADDR        | 1111011a aa011bbb<br>[DISP] [DISP] | 2, 3 or 4 | 16+EA                            |
| NEG             | RB           | F6 11011ddd                        | 2         | 3*                               |
| NEG             | RW           | F7 11011ddd                        | 2         | 3*                               |
| NOT             | DADDR        | 1111011a aa010bbb<br>[DISP] [DISP] | 2, 3 or 4 | 16+EA                            |
| NOT             | RB           | F6 11010sss                        | 2         | 3*                               |
| NOT             | RW           | F7 11010sss                        | 2         | 3*                               |
| OR              | AL,DATA8     | OC YY                              | 2         | 4*                               |
| OR              | AX,DATA16    | OD YYYY                            | 3         | 4*                               |
| OR              | DADDR,DATA8  | 80 aa001bbb<br>[DISP] [DISP] YY    | 3, 4 or 5 | 17+EA                            |
| OR              | DADDR,DATA16 | 81 aa001bbb<br>[DISP] [DISP] YYYY  | 4, 5 or 6 | 17+EA                            |
| OR              | DADDR,RB     | 08 aassssbb<br>[DISP] [DISP]       | 2, 3 or 4 | 16+EA                            |
| OR              | DADDR,RW     | 09 aasssbbs<br>[DISP] [DISP]       | 2, 3 or 4 | 16+EA                            |
| OR              | RB,DADDR     | OA aaddbbb<br>[DISP] [DISP]        | 2, 3 or 4 | 9+EA                             |
| OR              | RB,DATA8     | 80 11001ss YY                      | 3         | 4*                               |
| OR              | RBD,RBS      | OA 11ddsss                         | 2         | 3*                               |
| OR              | RW,DADDR     | OB aaddbbb<br>[DISP] [DISP]        | 2, 3 or 4 | 9+EA                             |
| OR              | RW,DATA16    | 81 11001sss YYYY                   | 4         | 4*                               |
| OR              | RWD,RWS      | OB 11ddddss                        | 2         | 3*                               |
| OUT             |              | EE                                 | 1         | 8                                |
| OUT             | PORT         | E6 YY                              | 2         | 10                               |
| OUTW            |              | EF                                 | 1         | 8                                |
| OUTW            | PORT         | E7 YY                              | 2         | 10                               |
| POP             | DADDR        | 8F aa000bbb<br>[DISP] [DISP]       | 2, 3 or 4 | 17+EA                            |
| POP             | RW           | 01011ddd                           | 1         | 8                                |
| POP             | SR           | 000rr111                           | 1         | 8                                |
| POPF            |              | 9D                                 | 1         | 8                                |
| PUSH            | DADDR        | FF aa110bbb<br>[DISP] [DISP]       | 2, 3 or 4 | 16+EA                            |
| PUSH            | RW           | 01010sss                           | 1         | 10                               |
| PUSH            | SR           | 000rr110                           | 1         | 10                               |
| PUSHF           |              | 9C                                 | 1         | 10                               |
| RCL             | DADDR,N      | 110100va aa010bbb<br>[DISP] [DISP] | 2, 3 or 4 | 15+EA (single)<br>or 4/bit+20+EA |
| RCL             | RB,N         | 110100v0 11010sss                  | 2         | 2* (single)<br>or 4/bit+8        |
| RCL             | RW,N         | 110100v1 11010sss                  | 2         | "                                |
| RCR             | DADDR,N      | 110100va aa011bbb<br>[DISP] [DISP] | 2, 3 or 4 | 15+EA (single)<br>or 4/bit+20+EA |
| RCR             | RB,N         | 110100v0 11011sss                  | 2         | 2* (single)<br>or 4/bit+8        |
| RCR             | RW,N         | 110100v1 11011sss                  | 2         | "                                |
| REP/REPNE/REPNZ | N            | F3                                 | 1         | +6 per loop                      |
| REPE/REPZ       | N            | F2                                 | 1         | +6 per loop                      |
| RET             |              | C3                                 | 1         | 16**                             |
| RET             | CS           | CB                                 | 1         | 26**                             |
| RET             | CS,DATA16    | CA YYYY                            | 3         | 25**                             |
| RET             | DATA16       | C2 YYYY                            | 3         | 20**                             |
| ROL             | DADDR,N      | 110100va aa000bbb<br>[DISP] [DISP] | 2, 3 or 4 | 15+EA (single)<br>or 4/bit+20+EA |

Table 20-5. A Summary of 8086 Instruction Object Codes and Execution Cycles (Continued)

| INSTRUCTION |              | OBJECT CODE                               | BYTES        | CLOCK PERIODS                    |
|-------------|--------------|-------------------------------------------|--------------|----------------------------------|
| ROL         | RB,N         | 110100v0 11000sss                         | 2            | 2* (single)<br>or 4/bit+8<br>"   |
| ROL         | RW,N         | 110100v1 11000sss                         | 2            | "                                |
| ROR         | DADDR,N      | 110100va aa001bbb<br>[DISP] [DISP]        | 2, 3 or 4    | 15+EA (single)<br>or 4/bit+20+EA |
| ROR         | RB,N         | 110100v0 11001sss                         | 2            | 2* (single)<br>or 4/bit+8        |
| ROR         | RW,N         | 110100v1 11001sss                         | 2            | "                                |
| SAHF        |              | 9E                                        | 1            | 4*                               |
| SAL/ShL     | DADDR,N      | 110100va aa100bbb<br>[DISP] [DISP]        | 2, 3 or 4    | 15+EA (single)<br>or 4/bit+20+EA |
| SAL/ShL     | RB,N         | 110100v0 11100sss                         | 2            | 2* (single)<br>or 4/bit+8        |
| SAL/ShL     | RW,N         | 110100v1 11100sss                         | 2            | "                                |
| SAR         | DADDR,N      | 110100va aa111bbb<br>[DISP] [DISP]        | 2, 3 or 4    | 15+EA (single)<br>or 4/bit+20+EA |
| SAR         | RB,N         | 110100v0 11111sss                         | 2            | 2* (single)<br>or 4/bit+8        |
| SAR         | RW,N         | 110100v1 11111sss                         | 2            | "                                |
| SBB         | AL,DATA8     | 1C YY                                     | 2            | 4*                               |
| SBB         | AX,DATA16    | 1D YYYY                                   | 3            | 4*                               |
| SBB         | DADDR,DATA8  | 80 aa01bbb<br>[DISP] [DISP] YY            | 3, 4 or 5    | 17+EA                            |
| SBB         | DADDR,DATA16 | 100000a1 aa01bbb<br>[DISP] [DISP] YY[YY]  | 3, 4, 5 or 6 | 17+EA                            |
| SBB         | DADDR,RB     | 18 adddbbb<br>[DISP] [DISP]               | 2, 3 or 4    | 16+EA                            |
| SBB         | DADDR,RW     | 19 adddbbb<br>[DISP] [DISP]               | 2, 3 or 4    | 16+EA                            |
| SBB         | RB,DADDR     | 1A aassssbbb<br>[DISP] [DISP]             | 2, 3 or 4    | 9+EA                             |
| SBB         | RB,DATA8     | 80 11011ddd YY                            | 3            | 4*                               |
| SBB         | RBD,RBS      | 1A 11ddsss                                | 2            | 3*                               |
| SBB         | RW,DADDR     | 1B aassssbbb<br>[DISP] [DISP]             | 2, 3 or 4    | 9+EA                             |
| SBB         | RW,DATA16    | 100000a1 11011ddd<br>YY[YY]               | 3 or 4       | 4*                               |
| SBB         | RWD,RWS      | 1B 11ddsss                                | 2            | 3*                               |
| SCAB        |              | AE                                        | 1            | 15                               |
| SCAW        |              | AF                                        | 1            | 15                               |
| SEG Prefix  | SR           | 001rr101                                  | 1            | +2                               |
| SHR         | DADDR,N      | 110100va aa101bbb<br>[DISP] [DISP]        | 2, 3 or 4    | 15+EA (single)<br>or 4/bit+20+EA |
| SHR         | RB,N         | 110100v0 11101sss                         | 2            | 2* (single)<br>or 4/bit+8        |
| SHR         | RW,N         | 110100v1 11101sss                         | 2            | "                                |
| STC         |              | F9                                        | 1            | 2*                               |
| STD         |              | FD                                        | 1            | 2*                               |
| STI         |              | FB                                        | 1            | 2*                               |
| STOB        |              | AA                                        | 1            | 10                               |
| STOW        |              | AB                                        | 1            | 10                               |
| SUB         | AL,DATA8     | 2C YY                                     | 2            | 4*                               |
| SUB         | AX,DATA16    | 2D YYYY                                   | 3            | 4*                               |
| SUB         | DADDR,DATA8  | 80 aa101bbb<br>[DISP] [DISP] YY           | 3, 4 or 5    | 17+EA                            |
| SUB         | DADDR,DATA16 | 100000a1 aa101bbb<br>[DISP] [DISP] YY[YY] | 3, 4, 5 or 6 | 17+EA                            |
| SUB         | DADDR,RB     | 28 adddbbb<br>[DISP] [DISP]               | 2, 3 or 4    | 16+EA                            |
| SUB         | DADDR,RW     | 29 adddbbb<br>[DISP] [DISP]               | 2, 3 or 4    | 16+EA                            |
| SUB         | RB,DADDR     | 2A aassssbbb<br>[DISP] [DISP]             | 2, 3 or 4    | 9+EA                             |

Table 20-5. A Summary of 8086 Instruction Object Codes and Execution Cycles (Continued)

| INSTRUCTION       | OBJECT CODE                       | BYTES     | CLOCK PERIODS |
|-------------------|-----------------------------------|-----------|---------------|
| SUB RB,DATA8      | 80 11101ddd YY                    | 3         | 4*            |
| SUB RBD,RBS       | 2A 11dddsss                       | 2         | 3*            |
| SUB RW,DADDR      | 2B aassssbbb<br>[DISP] [DISP]     | 2, 3 or 4 | 9+EA          |
| SUB RW,DATA16     | 100000a1 11101ddd<br>YY[YY]       | 3 or 4    | 4*            |
| SUB RWD,RWS       | 2B 11dddsss                       | 2         | 3*            |
| TEST AL,DATA8     | A8 YY                             | 2         | 4*            |
| TEST AX,DATA16    | A9 YYYY                           | 3         | 4*            |
| TEST DADDR,DATA8  | F6 aa000bbb<br>[DISP] [DISP] YY   | 3, 4 or 5 | 10+EA         |
| TEST DADDR,DATA16 | F7 aa000bbb<br>[DISP] [DISP] YYYY | 4, 5 or 6 | 10+EA         |
| TEST DADDR,RB     | 84 aaregbbb<br>[DISP] [DISP]      | 2, 3 or 4 | 9+EA          |
| TEST DADDR,RW     | 85 aaregbbb<br>[DISP] [DISP]      | 2, 3 or 4 | 9+EA          |
| TEST RB,DATA8     | F6 11000reg YY                    | 3         | 4*            |
| TEST RBD,RBS      | 84 11regreg                       | 2         | 3*            |
| TEST RW,DATA16    | F7 11000reg YYYY                  | 4         | 4*            |
| TEST RWD,RWS      | 85 11regreg                       | 2         | 3*            |
| WAIT              | 9B                                | 1         | 3             |
| XCHG AX,RW        | 10010reg                          | 1         | 3*            |
| XCHG RB,DADDR     | 86 aaregbbb<br>[DISP] [DISP]      | 2, 3 or 4 | 17+EA         |
| XCHG RB,RB        | 86 11regreg                       | 2         | 4*            |
| XCHG RW,DADDR     | 87 aaregbbb<br>[DISP] [DISP]      | 2, 3 or 4 | 17+EA         |
| XCHG RW,RW        | 87 11regreg                       | 2         | 4*            |
| XLAT              | D7                                | 1         | 11            |
| XOR AL,DATA8      | 34 YY                             | 2         | 4*            |
| XOR AX,DATA16     | 35 YYYY                           | 3         | 4*            |
| XOR DADDR,DATA8   | 80 aa010bbb<br>[DISP] [DISP] YY   | 3, 4 or 5 | 17+EA         |
| XOR DADDR,DATA16  | 81 aa010bbb<br>[DISP] [DISP] YYYY | 4, 5 or 6 | 17+EA         |
| XOR DADDR,RB      | 30 aassssbbb<br>[DISP] [DISP]     | 2, 3 or 4 | 16+EA         |
| XOR DADDR,RW      | 31 aassssbbb<br>[DISP] [DISP]     | 2, 3 or 4 | 16+EA         |
| XOR RB,DADDR      | 32 aadddbbb<br>[DISP] [DISP]      | 2, 3 or 4 | 9+EA          |
| XOR RB,DATA8      | 80 11110sss YY                    | 3         | 4*            |
| XOR RBD,RBS       | 32 11dddsss                       | 2         | 3*            |
| XOR RW,DADDR      | 33 aadddbbb<br>[DISP] [DISP]      | 2, 3 or 4 | 9+EA          |
| XOR RW,DATA16     | 81 11110sss YYYY                  | 4         | 4*            |
| XOR RWD,RWS       | 33 11dddsss                       | 2         | 3*            |

Table 20-6. 8080A to 8086 Instruction Mapping

| 8080A<br>INSTRUCTION |  | EQUIVALENT 8086<br>INSTRUCTION(S) |  | 8080A<br>INSTRUCTION |      | EQUIVALENT 8086<br>INSTRUCTION(S)                          |           |
|----------------------|--|-----------------------------------|--|----------------------|------|------------------------------------------------------------|-----------|
| IN DEV               |  | IN PORT                           |  | RM                   |      | JNS                                                        | next-inst |
| OUT DEV              |  | OUT PORT                          |  | RP                   |      | RET                                                        |           |
|                      |  |                                   |  | RPE                  |      | JS                                                         | next-inst |
| LDAX B *             |  | MOV SI,CX                         |  |                      |      | RET                                                        |           |
| LDAX D               |  | MOV SI,DX                         |  |                      |      | JPO                                                        | next-inst |
| STAX B               |  | MOV DI,CX                         |  | RPO                  |      | RET                                                        |           |
| STAX D               |  | MOV DI,DX                         |  | ADI                  | DATA | ADD                                                        | AL,DATA8  |
|                      |  | STOB                              |  | ACI                  | DATA | ADC                                                        | AL,DATA8  |
| MOV REG,M            |  | MOV RB,DADDR                      |  | SUI                  | DATA | SUB                                                        | AL,DATA8  |
| MOV M,REG            |  | MOV DADDR,RB                      |  | SBI                  | DATA | SBB                                                        | AL,DATA8  |
| LDA ADDR             |  | MOV AL,LABEL                      |  | ANI                  | DATA | AND                                                        | AL,DATA8  |
| STA ADDR             |  | MOV LABEL,AL                      |  | XRI                  | DATA | XOR                                                        | AL,DATA8  |
| LHLD ADDR            |  | MOV BX,DADDR                      |  | ORI                  | DATA | OR                                                         | AL,DATA8  |
| SHLD ADDR            |  | MOV DADDR,BX                      |  | CPI                  | DATA | CMP                                                        | AL,DATA8  |
| ADD M                |  | ADD AL,DADDR                      |  | JC                   | ADDR | JB                                                         | DISP8 *** |
| ADC M                |  | ADC AL,DADDR                      |  | JNC                  | ADDR | JNB                                                        | DISP8     |
| SUB M                |  | SUB AL,DADDR                      |  | JZ                   | ADDR | JZ                                                         | DISP8     |
| SBB M                |  | SBB AL,DADDR                      |  | JNZ                  | ADDR | JNZ                                                        | DISP8     |
| ANA M                |  | AND AL,DADDR                      |  | JP                   | ADDR | JNS                                                        | DISP8     |
| XRA M                |  | XOR AL,DADDR                      |  | JM                   | ADDR | JS                                                         | DISP8     |
| ORA M                |  | OR AL,DADDR                       |  | JPE                  | ADDR | JPE                                                        | DISP8     |
| CMP M                |  | CMP AL,DADDR                      |  | JPO                  | ADDR | JPO                                                        | DISP8     |
| INR M                |  | INC DADDR                         |  | MOV d,s              |      | MOV RBD,RBS                                                |           |
| DCR M                |  | DEC DADDR                         |  | XCHG                 |      | XCHG DX,BX                                                 |           |
|                      |  |                                   |  | SPHL                 |      | MOV SP,BX                                                  |           |
| LXI RP,DATA16        |  | MOV RW,DATA16                     |  |                      |      |                                                            |           |
| MVI M,DATA           |  | MOV DADDR,DATA8                   |  | ADD REG              |      | ADD AL,RBS                                                 |           |
| MVI REG,DATA         |  | MOV RB,DATA8                      |  | ADC REG              |      | ADC AL,RBS                                                 |           |
| JMP ADDR             |  | JMP BRANCH **                     |  | SUB REG              |      | SUB AL,RBS                                                 |           |
| PCHL                 |  | JMP BX                            |  | SBB REG              |      | SBB AL,RBS                                                 |           |
|                      |  |                                   |  | ANA REG              |      | AND AL,RBS                                                 |           |
| CALL ADDR            |  | CALL BRANCH                       |  | XRA REG              |      | XOR AL,RBS                                                 |           |
| CC ADDR              |  | JNB next-inst                     |  | ORA REG              |      | OR AL,RBS                                                  |           |
|                      |  | CALL BRANCH                       |  | CMP REG              |      | CMP AL,RBS                                                 |           |
| CNC ADDR             |  | JB next-inst                      |  | DAD RP               |      | LAHF                                                       |           |
|                      |  | CALL BRANCH                       |  |                      |      | ADD BX,RW                                                  |           |
| CZ ADDR              |  | JNZ next-inst                     |  |                      |      | RCR AL                                                     |           |
|                      |  | CALL BRANCH                       |  |                      |      | SAHF                                                       |           |
| CNZ ADDR             |  | JZ next-inst                      |  |                      |      | RCL AL                                                     |           |
|                      |  | CALL BRANCH                       |  |                      |      | or ADD BX,RW (unlike DAD - will affect AF, PF, SF, and ZF) |           |
| CP ADDR              |  | JS next-inst                      |  |                      |      |                                                            |           |
|                      |  | CALL BRANCH                       |  |                      |      |                                                            |           |
| CM ADDR              |  | JNS next-inst                     |  | INR REG              |      | INC RB                                                     |           |
|                      |  | CALL BRANCH                       |  | DCR REG              |      | DEC RB                                                     |           |
| CPE ADDR             |  | JPO next-inst                     |  | CMA                  |      | NOT AL                                                     |           |
|                      |  | CALL BRANCH                       |  | DAA                  |      | DAA                                                        |           |
| CPO ADDR             |  | JPE next-inst                     |  | RLC                  |      | ROL AL                                                     |           |
|                      |  | CALL BRANCH                       |  | RRC                  |      | ROR AL                                                     |           |
| RET                  |  | CALL RET                          |  | RAL                  |      | RCL AL                                                     |           |
|                      |  |                                   |  | RAR                  |      | RCR AL                                                     |           |
| RC                   |  | JNB next-inst                     |  | INX RP               |      | LAHF                                                       |           |
|                      |  | RET                               |  |                      |      | INC RW                                                     |           |
| RNC                  |  | JB next-inst                      |  |                      |      | SAHF                                                       |           |
|                      |  | RET                               |  |                      |      | or INC RW (unlike INX - will affect AF, PF, SF, and ZF)    |           |
| RZ                   |  | JNZ next-inst                     |  | DCX RP               |      | LAHF                                                       |           |
|                      |  | RET                               |  |                      |      | DEC RW                                                     |           |
| RNZ                  |  | JZ next-inst                      |  |                      |      |                                                            |           |

Table 20-6. 8080A to 8086 Instruction Mapping (Continued)

| 8080A<br>INSTRUCTION | EQUIVALENT 8086<br>INSTRUCTION(S)                                  | 8080A<br>INSTRUCTION     | EQUIVALENT 8086<br>INSTRUCTION(S) |
|----------------------|--------------------------------------------------------------------|--------------------------|-----------------------------------|
| PUSH RP<br>PUSH PSW  | SAHF<br>or DEC RW (unlike DCX - will<br>affect AF, PF, SF, and ZF) | EI<br>DI<br>RST N        | STI<br>CLI<br>CALL 8*N            |
| POP RP<br>POP PSW    | PUSH RW<br>LAHF<br>PUSH AX<br>POP RW<br>POP AX<br>SAHF             | STC<br>CMC<br>NOP<br>HLT | STC<br>CMC<br>XCHG AX,AX<br>HLT   |
| XTHL                 | POP SI<br>XCHG BX,SI<br>PUSH SI                                    |                          |                                   |

\*8080A registers map into 8086 registers as follows:

| 8080A | 8086 | 8080A | 8086 |
|-------|------|-------|------|
| A     | AL   | L     | BL   |
| B     | CH   | BC    | CX   |
| C     | CL   | DE    | DX   |
| D     | DH   | HL    | BX   |
| E     | DL   | SP    | SP   |
| H     | BH   | PC    | IP   |

\*\* Addresses on 8086 jumps and calls are adjusted to be self-relative.

\*\*\* Conditional jumps to a location out of the short self-relative range must be implemented by using a reversed-sense conditional jump around a normal jump to the location, e.g.:

|    |      |         |     |           |
|----|------|---------|-----|-----------|
| JC | ADDR | becomes | JNB | next-inst |
|    |      |         | JMP | BRANCH    |

Refer to Table 4-4 for a complete description of 8080A mnemonics shown above.

Refer to Table 20-4 for a complete description of 8086 mnemonics shown above.



Figure 20-12. Logic of the 8284 Clock Generator and Driver



| Pin Name              | Description                                 | Type   |
|-----------------------|---------------------------------------------|--------|
| RESET                 | Control signal output to 8086               | Output |
| RES                   | Reset logic input                           | Input  |
| RDY1, RDY2            | Wait state ready inputs                     | Input  |
| AEN1, AEN2            | Address enable qualifiers for RDY1 and RDY2 | Input  |
| READY                 | Control signal output to 8086               | Output |
| X1, X2                | External crystal connections                | Input  |
| TANK                  | Overtone crystal tank circuit connection    | Input  |
| EF1                   | Alternate clock input                       | Input  |
| F/C                   | Clock source select                         | Input  |
| CLK                   | MOS level clock signal to 8086              | Output |
| PCLK                  | TTL clock for peripherals                   | Output |
| OSC                   | Crystal oscillator output                   | Output |
| CSYNC                 | Clock synchronizer                          | Input  |
| V <sub>CC</sub> , GND | Power, ground                               |        |

Figure 20-13. 8284 Clock Generator and Driver Pins and Signal Assignments

## THE INTEL 8284 CLOCK GENERATOR/DRIVER

**The 8284 Clock Generator/Driver is a standard component that will be present in every 8086 microcomputer system. In a multimicroprocessor system, each 8086 microprocessor will have its own 8284 Clock Generator/Driver.** While one could conceivably have a single 8284 servicing more than one 8086 microprocessor, it will rarely make any economic sense to design a system in this fashion.

**Logic implemented on the 8284 Clock Generator/Driver corresponds generally to the block labeled clock logic in Figure 20-1.** To be completely accurate, however, a small portion of the bus interface logic should also be illustrated as provided by the 8284 device.

**Figure 20-12 illustrates 8284 device internal logic.**

The 8284 is manufactured using bipolar technology. It is packaged as a 18-pin DIP. All signals are TTL compatible.

### 8284 CLOCK GENERATOR/DRIVER PINS AND SIGNALS

**8284 device pins and signals are illustrated in Figure 20-13. Figure 20-19 illustrates the 8284 device in a single 8086 microprocessor configuration.**

**Signals may be divided between timing and control logic.**

**Clock frequency is controlled by a crystal connected across the X1 and X2 pins.** Clock frequency must be exactly three times the required clock period. Since the standard 8086 clock period is 200 nanoseconds, a 15MHz crystal frequency is required.

**If an overtone mode crystal is employed, then it must be supported by an external LC network connected to TANK to insure oscillation of the overtone frequency. This is standard clock logic practice; for the 8284 it is illustrated along with other normal connections in Figure 20-14.**

You have the option of connecting a crystal across X1 and X2 in order to generate a fundamental frequency, or you can input the fundamental frequency via EFI. The level of F/C determines whether an external crystal or a signal input will provide the fundamental frequency. If F/C is high, then the fundamental frequency is taken from the EFI input. If F/C is low, then the crystal connected across X1 and X2 provides the fundamental frequency.

**Three clock outputs are generated:**

- 1) CLK is an MOS level signal designed to meet the requirements of the 8086.
- 2) PCLK is a TTL level clock signal, output for support circuits. PCLK runs at half the frequency of CLK.
- 3) OSC is an oscillator output running at the crystal or EFI input frequency.

**These timing signals may be illustrated as follows:**





NOTES:

1.  $C_X$  should be 3 to 10 pF
2.  $C_C$  (when used) should be 1 to 10 nF
3.  $C_R$  and  $R_R$  determine Reset time constant
4.  $C_T$  and  $L_T$  determine tank frequency:  $f_0 = \frac{1}{2\pi\sqrt{L_T C_T}}$

Figure 20-14. Normal 8284 Clock Generator Circuit

In multi-CPU configurations you will probably need to synchronize all 8086 clock signals. You use the CSYNC signal for this purpose. When CSYNC is input high, logic internal to the 8284 Clock Generator/Driver is stopped. When CSYNC subsequently goes low, clock outputs restart. If the same CSYNC signal is input to a number of 8284 devices that receive the same EFI input, then all microprocessors in a multi-CPU configuration will be exactly synchronized. Appropriate logic is illustrated in Figure 20-15.

### SYNCHRONIZING MULTI-8086 CLOCK SIGNALS

Note that you cannot use individual crystals for 8284 Clock Generator/Drivers that are supposed to be synchronized with each; minor variations in crystal frequency, which must occur, will quickly distort clock signal synchronization. You can use a crystal to generate the fundamental frequency for one 8284 Clock Generator/Driver, then use the OSC output of this Clock Generator/Driver as the EFI input to other 8284 Clock Generator/Drivers.

**The 8086 requires its RESET input to be synchronized with clock logic. The 8284 will receive an asynchronous Reset input at RES and will generate synchronized RESET output which the 8086 requires.** Appropriate logic is illustrated in Figure 20-14. Timing is illustrated in the data sheets at the end of the chapter.

### 8086 RESET

The 8284 RES input need not make a sharp transition. The 8284 inputs RES to a Schmitt trigger that generates the RESET output. RES can make a slow low-to-high transition.



Figure 20-15. Clock Synchronization Logic in a Multi-CPU 8086 Configuration

We have described earlier in this chapter how external logic can extend a bus cycle by inserting Wait clock periods between T3 and T4. Figure 20-9 illustrates the READY input which controls Wait states within the 8086 bus controller. As illustrated in Figure 20-9, the 8086 READY input must be synchronized with the clock signal. The 8284 Clock Generator/Driver outputs an appropriately synchronized READY signal to the 8086. **The 8284 creates its READY output from one of two inputs: RDY1 or RDY2.** The 8284 has two READY inputs to support MULTIBUS configurations, as illustrated in Figure 20-22. A single 8086 may connect to two separate System Busses. Memory or I/O devices attached to either bus may wish to create a Wait state within a bus cycle. Each System Bus may therefore have its own READY line. In order to arbitrate bus priorities, RDY1 and RDY2 have companion enable signals AEN1 and AEN2, respectively. The 8284 will respond to RDY1 only when AEN1 is low. Similarly, the 8284 will respond to RDY2 only when AEN2 is low.

### 8284 WAIT STATE LOGIC

AEN1 and AEN2 are general bus priority signals which you must generate through your own bus priority arbitration logic. We will describe these two signals, and methods of generating them, later in this chapter.

## THE INTEL 8288 BUS CONTROLLER

In maximum 8086 configurations, where the 8086 MN/MX signal is low, you must use an 8288 Bus Controller in order to decode the S0, S1 and S2 status lines, and thus create System Bus control signals. You can also use the 8288 Bus Controller in order to connect more than one 8086 to a single System Bus, or in order to create more than one System Bus for a single 8086.

Although the primary purpose of the 8288 Bus Controller is to decode the three 8086 status signals S0, S1 and S2, a simple 1-of-8 decoder could accomplish this limited task. The 8288 has these additional capabilities:

- 1) The 8288 can generate control signals for a System Bus or an I/O device only bus.
- 2) You can float a System Bus's control signals to enable direct memory access, or to arbitrate bus priorities.
- 3) The two Write control lines have alternate advanced outputs designed for slow memories or I/O devices.
- 4) You can suppress control signals as a means of implementing memory protect logic in multi-bus or multimicroprocessor configurations.
- 5) The 8288 generates control signals needed by line drivers.
- 6) The 8288 generates control signals needed by simple or complex interrupt logic.

The 8288 Bus Controller is manufactured using bipolar technology. It is packaged as a 20-pin DIP. All signals are TTL compatible.

### 8288 BUS CONTROLLER SIGNALS AND PIN ASSIGNMENTS

Figure 20-16 illustrates 8288 Bus Controller signals and pin assignments. Figure 20-20 illustrates an 8288 within an 8086 microcomputer system.



Figure 20-16. 8288 Bus Controller Pins and Signal Assignments

**Control signals are generated from S0, S1 and S2 as follows:**

| S0 | S1 | S2 | 8086 State            | 8288 Control Output |
|----|----|----|-----------------------|---------------------|
| 0  | 0  | 0  | Interrupt acknowledge | INTA and MCE        |
| 0  | 0  | 1  | I/O read              | IORC                |
| 0  | 1  | 0  | I/O write             | IOWC, AIOWC         |
| 0  | 1  | 1  | Halt                  | None                |
| 1  | 0  | 0  | Code access           | MRDC                |
| 1  | 0  | 1  | Memory read           | MRDC                |
| 1  | 1  | 0  | Memory write          | MWTC, AMWC          |
| 1  | 1  | 1  | No operation          | None                |

8288 and 8086 control signal timing is essentially the same. For details, see the data sheets given at the end of this chapter.

If you look again at the Read and Write bus cycle timing descriptions given earlier in this chapter for the 8086 you will see that Read control signals pulse low approximately one clock period earlier than Write control signals. **The 8288 creates two alternate Write control signals whose timing is the same as the Read control signals.** These alternative Write control signals are referred to as advanced Write control signals, because they go low one clock pulse in advance of the standard Write control signals.

**8288  
ADVANCED  
WRITE  
CONTROL  
SIGNALS**

We can thus summarize 8288 System Bus control signals as follows:

MRDC is the memory read control.

MWTC is the memory write control.

AMWC is a memory write control whose timing conforms to MRDC.

INTA is a memory read control signal which is output during the two interrupt acknowledge bus cycles.

IORC is an I/O device read control signal.

IOWC is an I/O device write control signal.

AIOWC is an alternative I/O device write control signal with timing that conforms to IORC.

Devices connected to a bus are likely to use both IOWC and MWTC or AIOWC and AMWC, but not all four signals. That is, you will use either the normal write control signals or you will use the advanced write control signals.

**All 8288 control signals are tri-state.** They can be disabled and thus disconnected from the System Bus.

**You have two control options which modify the control signal logic of the 8288 Bus Controller.**

**Using the IOB pin, you can operate the 8288 device in I/O bus mode or in System Bus mode.**

**Using the CEN pin, you can suppress control signals.**

**Let us examine each of these capabilities in turn.**

When the IOB pin is connected to +5V, the 8288 Bus Controller generates an I/O bus. IOB high floats MRDC, MWTC and AMWC all of the time, but continuously outputs INTA, IORC, IOWC and AIOWC. In I/O bus mode, these four I/O control signals cannot be floated. Since the four I/O control lines will always be active, it is assumed that the I/O bus generated by an 8288 is a local bus. You cannot share this local I/O bus with another microprocessor, nor can it be used by direct memory access logic.

**8288 I/O  
BUS MODE**

The 8288 I/O bus has two control signals, PDEN and DT/R, which drive I/O ports and line drivers. DT/R, which we have described for the 8086, is used to control a bidirectional bus driver. When high, DT/R puts the bus driver in output mode, while when low, DT/R puts the bus driver in input mode. PDEN pulses low as a data enable signal. PDEN is equivalent to DEN, the standard bus data enable signal output by the 8086.

When IOB is low, a normal System Bus is generated. All seven control signals are active; however, AEN is a bus enable control (much as the BUSEN input is used by the 8228 Bus Controller in an 808A system).

AEN is inactive when IOB is high and an I/O bus is being generated. AEN is active only when IOB is low and a System Bus is generated.

When IOB is low and AEN is high, all control signals are floated. When IOB is low and AEN is low, control signals are connected to the System Bus. You will use AEN to implement bus priority arbitration logic, or direct memory access logic, as described later in this chapter.

**CEN is used to disable, but not float, control signals. CEN can be used when an 8288 is generating a System Bus or an I/O bus. CEN will normally be high. When CEN is low, control signals are inactive. CEN does not float signals; it just disables the logic which might otherwise have made a control signal pulse low.**

**Table 20-7 summarizes the effect of IOB and CEN on control signals generated by the 8288 Bus Controller.**

**8288 BUS  
CONTROLLER  
MEMORY  
PROTECT**

Table 20-7. Effect of IOB, CEN and AEN on Control Signals Output by the 8288 Bus Controller

| CONTROL INPUT |     |            | EFFECT ON CONTROL OUTPUT |           |          |                  |           |          |
|---------------|-----|------------|--------------------------|-----------|----------|------------------|-----------|----------|
| IOB           | CEN | <u>AEN</u> | INTA, IORC, IOWC, AIOWC  |           |          | MRDC, MWTC, AMWC |           |          |
|               |     |            | Mode                     | Floated?  | Active?  | Mode             | Floated?  | Active?  |
| 0             | 0   | 0          | System                   | Floated   | Active   | System           | Floated   | Active   |
| 0             | 0   | 1          | System                   | Floated   | Inactive | System           | Floated   | Inactive |
| 0             | 1   | 0          | System                   | Connected | Active   | System           | Connected | Active   |
| 0             | 1   | 1          | System                   | Connected | Inactive | System           | Connected | Inactive |
| 1             | 0   | 0          | I/O                      | Floated   | Active   | Not Used         | Floated   | Inactive |
| 1             | 0   | 1          | I/O                      | Floated   | Active   | Not Used         | Floated   | Inactive |
| 1             | 1   | 0          | I/O                      | Connected | Active   | Not Used         | Floated   | Inactive |
| 1             | 1   | 1          | I/O                      | Connected | Active   | Not Used         | Floated   | Inactive |

The CEN control enables memory mapping. Here are some possibilities:

- 1) In multi-bus configurations, one block of memory addresses may access memory on two or more busses. In order to avoid contentions, you can use the CEN signal to selectively disable busses so that only one bus will actually respond when the 8086 accesses duplicated memory addresses.
- 2) Privileged memory is frequently present in large microcomputer systems. Privileged memory is likely to become more common in microcomputer systems as they grow larger. Privileged memory is memory which can be accessed only under special circumstances. Frequently, system programs are run out of privileged memory, while application programs are run out of non-privileged memory. This prevents errors in application programs from destroying system programs; it also prevents unauthorized access of reserved memory spaces.

**DT/R and DEN, the two standard buffer control signals, are generated by the 8288 when it is creating a normal System Bus.** These two control signals, when generated by the 8288 Bus Controller, are identical in form and purpose to the signals which the 8086 creates. DT/R determines the data direction for bidirectional buffers, while DEN is a latching strobe.

**The 8288 generates two interrupt control signals: INTA and MCE. INTA is active on a System Bus or an I/O Bus. MCE shares a pin with PDEN and is active only on a System Bus.**

**8288 BUS  
CONTROLLER  
INTERRUPT  
SIGNALS**

As we discussed earlier in this chapter, the 8086 executes two bus cycles when acknowledging an interrupt. During each bus cycle, INTA is output as a low read pulse. On the second low INTA pulse, the acknowledged device must return an 8-bit code which the 8086 uses as an interrupt vector. The INTA control signal which is generated by the 8288 Bus Controller is identical to the 8086 INTA control signal and serves the same purpose, on a System Bus or an I/O Bus. The MCE control signal has been added for use in large 8086 microcomputer systems that use a variation of the 8259A Priority Interrupt Control Unit. (The 8259A Priority Interrupt Control Unit is described in Chapter 4.) When you have a master 8259A Priority Interrupt Control Unit and slave 8259A Priority Interrupt Control Units, you will use MCE as a control to the master, while INTA becomes a control to the slaves. The 8086 version of the 8259A Priority Interrupt Control Unit is not described in this chapter. We will therefore defer further discussion of the MCE signal until a subsequent revision of this chapter.

## THE 8282/8283 8-BIT INPUT/OUTPUT PORT

These are simple unidirectional 8-bit latch buffers. The 8283 inverts inputs in order to create outputs; the 8282 does not. That is the only difference between these two devices.

**Both devices have three-state outputs. When a device is not selected, its outputs are floated.**

These devices are manufactured using bipolar technology. All signals are TTL compatible. Outputs have a high drive capability, as defined in the data sheets at the end of this chapter. The devices are packaged as 20-pin DIPs.

### THE 8282/8283 INPUT/OUTPUT PORT PINS AND SIGNAL ASSIGNMENTS

Figure 20-17 illustrates the pins and signal assignments for the 8282 and 8283 8-bit input/output ports.

**Data must be input at D10-DI7.**

When STB is high, the internal latches appear transparent and data on the output pins track data on the input pins. The transition from high to low of STB latches the data. The outputs remain stable while STB is low.

**Data which is latched internally is output when CS is low.** The 8282 outputs data unaltered, while the 8283 inverts the data.

Were you to simply ground  $\overline{OE}$  and tie STB to +5V, the 8282 or 8283 I/O ports will function as simple bus drivers. The outputs will continuously track the inputs, but will support heavier signal loads.

If you tie STB high, but use the low  $\overline{OE}$  pulse, then input data is constantly available but outputs only become valid while  $\overline{OE}$  is low. Timing may be illustrated as follows:





| Pin Name              | Description       | Type             |
|-----------------------|-------------------|------------------|
| DIO-DI7               | Data input        | Input            |
| DO0-DO7               | Data output       | Output, tristate |
| OE                    | Output Enable     | Input            |
| STB                   | Input data strobe | Input            |
| V <sub>CC</sub> , GND | Power, ground     |                  |

Figure 20-17. 8282 and 8283 Input/Output Port Pins and Signal Assignments

When the Strobe and Output Enable signal are both active, I/O port logic may be illustrated as follows:





| Pin Name              | Description      | Type                    |
|-----------------------|------------------|-------------------------|
| A0-A7                 | Local Bus        | Bidirectional, tristate |
| BO-B7                 | System Bus       | Bidirectional, tristate |
| OE                    | Output Enable    | Input                   |
| T                     | Direction select | Input                   |
| V <sub>CC</sub> , GND | Power, ground    |                         |

Figure 20-18. 8286 and 8287 Bidirectional Bus Transceiver Pins and Signal Assignments

## THE 8286/8287 8-BIT BIDIRECTIONAL BUS TRANSCEIVERS

These two devices are used to buffer bidirectional lines on a System Bus. The 8286 transmits data unaltered, while the 8287 inverts the data. The two devices are otherwise the same.

The 8286 and 8287 bidirectional bus drivers are manufactured using bipolar technology. All pins are TTL-compatible. The devices are packaged as 20-pin DIPs.

### 8286 AND 8287 BIDIRECTIONAL BUS TRANSCEIVER PINS AND SIGNAL ASSIGNMENTS

Figure 20-18 illustrates pins and signal assignments for the 8286 and 8287 bidirectional bus drivers.

A0-A7 constitute eight parallel data lines that connect with the microprocessor Data/Address Bus. BO-B7 constitute eight equivalent lines that connect with the System Bus. System Bus outputs have a higher line drive capability (as defined in the data sheets at the end of this chapter); otherwise, there is no difference between the two busses.

When the T input is low, data arriving at the B pins is output via the A pins. When T is high, data arriving at the A pins is output via the B pins. The actual data transfer occurs only while OE is low. When used as an 8086 Data Bus transceiver, T should be connected to DT/R and OE connected to DEN.

## SOME 8086 MICROPROCESSOR BUS CONFIGURATIONS

We are now going to look at some 8086 microprocessor bus configurations.

The flexibility of the 8086 gives rise to such a bewildering array of system configuration possibilities that a whole book could be written on the subject. We are going to fulfill the more limited objective of identifying possibilities.

**Figure 20-19 illustrates the simplest case.** Here we are using the 8086 to generate a simple microcomputer system. Addresses taken off the bidirectional 8086 Data/Address Bus are unidirectional. We therefore use 8282 I/O ports to latch addresses of the 8086 Data/Address Bus. In Figure 20-19, we show just two 8282 I/O ports generating a 16-line Address Bus. Address lines A16 through A19 are wasted. By adding one more 8282 I/O port to the logic in Figure 20-19, you could include the four missing Address Bus lines.



Figure 20-19. Generating a System Bus for a Simple 8086 Configuration

In Figure 20-19, we ground the Output Enable inputs of the 8282 I/O ports; the Address Bus will therefore never be floated. We use the 8086 ALE pulse to strobe addresses into the 8282 I/O ports.

Since the Data Bus is bidirectional, we use 8286 bidirectional Bus Transceivers in order to create a separate Data Bus from the 8086 Address/Data Bus. Two 8286 bidirectional Bus Transceivers are required to create the 16-line Data Bus. We can use the DT/R and DEN outputs of the 8086 as the 8286 T and CS inputs.

We can now illustrate timing for creation of the Address Bus and Data Bus during a read bus cycle, as follows:



The simple system illustrated in Figure 20-19 will not make use of the dual READY clock logic. A single READY input is connected to RDY1, and both of the READY enables are grounded. Thus, the 8086 READY input will be created directly from the 8284 RDY1 input.

**Figure 20-20 illustrates a slightly more complex 8086 microcomputer configuration. Figure 20-20 uses an 8288 Bus Controller to generate System Bus control signals.** The DEN, DT/R, and ALE control outputs, which in Figure 20-19 were generated by the 8086 microprocessor, are now generated by the 8288 Bus Controller.

As a stand-alone microcomputer configuration, Figure 20-20 offers little or no advantage over Figure 20-19. In a single bus, single 8086 microcomputer configuration, there is no compelling reason to use the 8288 Bus Controller. All it does is add an extra component to the system without offering any significant logic enhancement.



Figure 20-20. Generating a System Bus in an 8086 Microcomputer System Using an 8288 Bus Controller

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- 8086 CPU
- 8282/8283 I/O Ports
- 8284 Clock Generator
- 8286/8287 Bidirectional Bus Drivers
- 8288 Bus Controller

**ABSOLUTE MAXIMUM RATINGS\***

Ambient Temperature Under Bias . . . . . 0°C to 70°C  
 Storage Temperature . . . . . -65°C to +150°C  
 Voltage on Any Pin with  
 Respect to Ground . . . . . -0.3 to +7V  
 Power Dissipation . . . . . 2.5 Watt

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

**D.C. CHARACTERISTICS**

8086-4:  $T_A = 0^\circ\text{C}$  to  $50^\circ\text{C}$ ,  $V_{CC} = 5\text{V} \pm 5\%$ ,  $V_{SS} = 0\text{V}$

| Symbol   | Parameter                                                                     | Min.           | Max.           | Units         | Test Conditions                         |
|----------|-------------------------------------------------------------------------------|----------------|----------------|---------------|-----------------------------------------|
| $I_{IL}$ | Input Low Voltage                                                             | -0.5           | +0.8           | V             |                                         |
| $V_{IH}$ | Input High Voltage                                                            | 2.0            | $V_{CC} + 0.5$ | V             |                                         |
| $V_{OL}$ | Output Low Voltage                                                            |                | 0.45           | V             | $I_{OL} = 2.0\text{ mA}$                |
| $V_{OH}$ | Output High Voltage                                                           | 2.4            |                | V             | $I_{OH} = 400\text{ }\mu\text{A}$       |
| $I_{CC}$ | Power Supply Current                                                          |                | 275            | mA            |                                         |
| $I_{LI}$ | Input Leakage Current                                                         |                | $\pm 10$       | $\mu\text{A}$ | $V_{IN} = V_{CC}$                       |
| $I_{LO}$ | Output Leakage Current                                                        |                | $\pm 10$       | $\mu$         | $0.45\text{V} \leq V_{OUT} \leq V_{CC}$ |
| $V_{CL}$ | Clock Input Low Voltage                                                       | -0.5           | +0.6           | V             |                                         |
| $V_{CH}$ | Clock Input High Voltage                                                      | $V_{CC} - 0.5$ | $V_{CC} + 1.0$ | V             |                                         |
| $C_{IN}$ | Capacitance of Input Buffer<br>(All input except<br>$AD_0 - AD_{15}$ , RQ/GT) |                | 10             | pF            | $f_c = 1\text{ MHz}$                    |
| $C_{IO}$ | Capacitance of I/O Buffer<br>( $AD_0 - AD_{15}$ , RQ/GT)                      |                | 20             | pF            | $f_c = 1\text{ MHz}$                    |

Data sheets on pages 20-D2 through 20-D15 reprinted by permission of Intel Corporation, Copyright 1978.

**8086****A.C. CHARACTERISTICS**8086-4:  $T_A = 0^\circ\text{C}$  to  $50^\circ\text{C}$ ,  $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ **8086 MINIMUM COMPLEXITY SYSTEM (Figure 8)****TIMING REQUIREMENTS**

| Symbol  | Parameter                                | Min. | Max.         | Units | Test Conditions                                  |
|---------|------------------------------------------|------|--------------|-------|--------------------------------------------------|
| TCLCL   | CLK Cycle Period                         | 200  | 2000         | ns    |                                                  |
| TCL1CH1 | CLK Low Time                             | 115  |              | ns    |                                                  |
| TCH2CL2 | CLK High Time                            | 60   |              | ns    |                                                  |
| TCH1CH2 | CLK Rise Time                            |      | 10           | ns    | From $V_{CL_{max}} + .4$ to $V_{CH_{min}} - 1.0$ |
| TCL2CL1 | CLK Fall Time                            |      | 10           | ns    | From $V_{CH_{min}} - 1.0$ to $V_{CL_{max}} + .4$ |
| TDVCL   | Data In Setup Time                       | 30   |              | ns    |                                                  |
| TCLDZ   | Data In Hold Time                        | 10   |              | ns    |                                                  |
| TR1VCL  | RDY Setup Time into 8284 (SEE NOTES 1,2) | 50   |              | ns    |                                                  |
| TCLR1X  | RDY Hold Time into 8284 (SEE NOTES 1,2)  | 0    |              | ns    |                                                  |
| TRYVCH  | READY Setup Time into 8086               |      | TCL1CH1 + 10 | ns    |                                                  |
| TCHRYX  | READY Hold Time into 8086                |      | TCLCL + 30   | ns    |                                                  |
| THVCH   | HOLD Setup Time                          | 35   |              | ns    |                                                  |
| TIVCH   | INTR, NMI, TEST Setup Time (SEE NOTE 2)  | 30   |              | ns    |                                                  |

**TIMING RESPONSES**

| Symbol  | Parameter                          | Min. | Max.         | Units | Test Conditions        |
|---------|------------------------------------|------|--------------|-------|------------------------|
| TCLAV   | Address Valid Delay                | 15   | 110          | ns    | $C_L = 100 \text{ pF}$ |
| TCLAX   | Address Hold Time                  | 10   |              | ns    |                        |
| TCLAZ   | Address Float Delay                |      | TCLAX        | 80    | ns                     |
| TLHLL   | ALE Width                          |      | TCL1CH1 - 20 |       | ns                     |
| TCLLH   | ALE Active Delay                   |      |              | 80    | ns                     |
| TCHLL   | ALE Inactive Delay                 |      |              | 85    | ns                     |
| TLLAZ   | ALE Inactive to Address Float      |      | TCH2CL2 - 10 |       | ns                     |
| TCLDV   | Data Valid Delay                   | 15   | 110          | ns    |                        |
| TCHDZ   | Data Float Delay                   |      | TCLAX        |       | ns                     |
| TWHDZ   | Data Hold Time After WR            |      | TCL1CH1 - 30 | 85    | ns                     |
| TCVCTV  | Control Active Delay 1             | 10   | 110          | ns    |                        |
| TCHCTV  | Control Active Delay 2             | 15   | 110          | ns    |                        |
| TCVCTX1 | Control Hold Time                  | 10   |              | ns    |                        |
| TCVCTX2 | Control Inactive Delay             | 10   | 110          | ns    |                        |
| TAZRL1  | Address Float to READ Active       | 0    |              | ns    |                        |
| TCLR1L2 | RD Active Delay                    | 10   | 165          | ns    |                        |
| TCLR1H  | RD Inactive Delay                  | 10   | 150          | ns    |                        |
| TRHAV   | RD Inactive to Next Address Active |      | TCLCL - 45   |       | ns                     |

NOTES: 1. SIGNAL AT 8284 SHOWN FOR REFERENCE ONLY.

2. SETUP REQUIREMENT FOR ASYNCHRONOUS SIGNAL ONLY TO GUARANTEE RECOGNITION AT NEXT CLK.

# 8086

## 8086 MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) (Figure 9) TIMING REQUIREMENTS

| Symbol  | Parameter                                                   | Min.         | Max. | Units | Test Conditions                                  |
|---------|-------------------------------------------------------------|--------------|------|-------|--------------------------------------------------|
| TCLCL   | CLK Cycle Period                                            | 200          | 2000 | ns    |                                                  |
| TCL1CH1 | CLK Low Time                                                | 115          |      | ns    |                                                  |
| TCH2CL2 | CLK High Time                                               | 60           |      | ns    |                                                  |
| TCH1CH2 | CLK Rise Time                                               |              | 10   | ns    | From $V_{CL_{max}} + .4$ to $V_{CH_{min}} - 1.0$ |
| TCL2CL1 | CLK Fall Time                                               |              | 10   | ns    | From $V_{CH_{min}} - 1.0$ to $V_{CL_{max}} + .4$ |
| TDVCL   | Data In Setup Time                                          | 30           |      | ns    |                                                  |
| TCLDZ   | Data In Hold Time                                           | 10           |      | ns    |                                                  |
| TR1VCL  | RDY Setup Time into 8284 (See Notes 1,2)                    | 50           |      | ns    |                                                  |
| TCLR1X  | RDY Hold Time into 8284 (See Notes 1,2)                     | 0            |      | ns    |                                                  |
| TRYVCH  | READY Setup Time into 8086                                  | TCL1CH1 + 10 |      | ns    |                                                  |
| TCHRYX  | READY Hold Time into 8086                                   | TCLCL + 30   |      | ns    |                                                  |
| TIVCH   | Setup Time for Recognition (INTR, NMI,<br>TEST)(See Note 2) | 30           |      | ns    |                                                  |
| TGVCH   | RQ/GT Setup Time                                            | 35           |      | ns    |                                                  |

## TIMING RESPONSES

| Symbol  | Parameter                                        | Min.       | Max.          | Units | Test Conditions                               |
|---------|--------------------------------------------------|------------|---------------|-------|-----------------------------------------------|
| TCHSV   | Status Active Delay                              | 10         | 110           | ns    | Local Bus & Control<br>$C_L = 100 \text{ pF}$ |
| TCLSX   | Status Inactive Delay                            |            | 130           | ns    |                                               |
| TCLAV   | Address Valid Delay                              | 15         | 110           | ns    |                                               |
| TCLAX   | Address Hold Time                                | 10         |               | ns    |                                               |
| TCLAZ   | Address Float Delay                              | TCLAX      | 80            | ns    |                                               |
| TSVLV   | Status Valid to ALE Valid (See Note 1)           |            | 15            |       |                                               |
| TCLLA   | CLK Valid to ALE Active (See Note 1)             | 0          |               |       |                                               |
| TCLLV   | CLK Valid to ALE Valid (See Note 1)              |            | 15            |       |                                               |
| TCHLL   | ALE Inactive Delay (See Note 1)                  |            | 15            | ns    |                                               |
| TCLDV   | Data Valid Delay                                 | 15         | 110           | ns    |                                               |
| TCHDZ   | Data Float Delay                                 | TCLAX      | 85            | ns    |                                               |
| TCVCTV  | Control Active Delay                             | 10         | 35            | ns    |                                               |
| TCVCTX1 | Control Hold Time                                | 10         |               | ns    |                                               |
| TCVCTX2 | Control Inactive Delay                           | 10         | 40            | ns    |                                               |
| TAZRL1  | Address Float to Read Active                     | 0          |               | ns    |                                               |
| TCLR1L  | RD Active Delay                                  | 10         | 165           | ns    |                                               |
| TCLR1H  | RD Inactive Delay                                | 10         | 150           | ns    |                                               |
| TRHAV   | RD Inactive to Next Address Active               | TCLCL - 45 |               |       |                                               |
| TCHDCV1 | Direction Control Active Delay (SEE NOTE 1)      |            | 50            | ns    |                                               |
| TCHDCV2 | Direction Control Inactive Delay (SEE NOTE 1)    |            | 30            | ns    |                                               |
| TCVEV   | Data Enable Active Delay (SEE NOTE 1)            | 5          | 45            | ns    |                                               |
| TCVEX   | Data Enable Inactive Delay (SEE NOTE 1)          | 10         | 45            | ns    |                                               |
| TCLGV   | GT Active Delay                                  |            | 85            | ns    |                                               |
| TCLGX   | GT Inactive Delay                                |            | 85            | ns    |                                               |
| TCHMV   | Master Cascade Enable Delay (SEE NOTE 1)         |            | TCHSV + TSVLV | ns    |                                               |
| TCLMV   | CLK Low to Master Cascade Enable<br>(SEE NOTE 1) | 0          |               | ns    |                                               |

NOTES: 1. SIGNAL AT 8284 OR 8288 SHOWN FOR REFERENCE ONLY.

2. SETUP REQUIREMENT FOR ASYNCHRONOUS SIGNAL ONLY TO GUARANTEE RECOGNITION AT NEXT CLK.



**NOTES**

- 1. ALL SIGNALS SWITCH BETWEEN Y<sub>24H</sub> AND Y<sub>01L</sub> UNLESS OTHERWISE SPECIFIED.
- 2. ROT Y SAMPLED NEAR THE END OF T<sub>2</sub>, T<sub>3</sub> AND T<sub>4</sub> TO DETERMINE IF T<sub>0</sub> MACHINE SLATES ARE TO BE INSERTED.
- 3. FOLLOWING A WRITE CYCLE, DATA REMAINS VALID ON THE LOCAL BUS UNTIL A LOCAL BUS MASTER DECIDES TO RUIN ANOTHER BUS CYCLE. THE LOCAL BUS IS FLOATING BY THE 8086 ONLY THE 8086 ENTERS A "HOLD ACKNOWLEDGE" STATE.
- 4. TWO INTA CYCLES RUIN BACK TO RACE. THE 8086 LOCAL ADDRESS BUS IS FLOATING DURING THE SECOND INTA CYCLE.
- 5. SIGNALS AT Y<sub>24H</sub> ARE SHOWN FOR REFERENCE ONLY.

**Figure 8. 8086 Bus Timing — Minimum Mode System**



**Figure 9. 8086 Bus Timing – Maximum Mode System (Using 8288)**

# **PRELIMINARY**

---



**NOTE-**

- #### **1. SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE RECOGNITION AT NEXT CLK**

**Figure 10. Asynchronous Signal Recognition**



**Figure 11. Bus Lock Signal Timing (Maximum Mode Only)**



**NOTES:**

1. THE 80806 FLOATS  $S_2$ ,  $S_1$ ,  $S_0$  FROM 1.1.1 STATE ON THIS EDGE
  2. THE 80806 FLOATS  $A_{Dx}$  BUS, BHE, AND LOCK ON THIS EDGE
  3. THE OTHER MASTER FLOATS  $S_2$ ,  $S_1$ ,  $S_0$  FROM 1.1.1 STATE ON THIS EDGE
  4. THE OTHER MASTER FLOATS  $A_{Dx}$  BUS, BHE, AND LOCK ON THIS EDGE

**Figure 12. Request/Grant Sequence Timing (Maximum Mode Only)**



**Figure 13. Hold/Hold Acknowledge Timing (Minimum Mode Only)**

## 8282/8283

### D.C. CHARACTERISTICS FOR 8282/8283

**Conditions:**  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$

| Symbol    | Parameter             | Min | Max  | Units   | Test Conditions                                                                |
|-----------|-----------------------|-----|------|---------|--------------------------------------------------------------------------------|
| $V_C$     | Input Clamp Voltage   |     | -1   | V       | $I_C = -5 \text{ mA}$                                                          |
| $I_{CC}$  | Power Supply Current  |     | 160  | mA      |                                                                                |
| $I_F$     | Forward Input Current |     | -0.2 | mA      | $V_F = 0.45V$                                                                  |
| $I_R$     | Reverse Input Current |     | 50   | $\mu A$ | $V_R = 5.25V$                                                                  |
| $V_{OL}$  | Output Low Voltage    |     | 0.50 | V       | $I_{OL} = 32 \text{ mA}$                                                       |
| $V_{OH}$  | Output High Voltage   | 2.4 |      | V       | $I_{OH} = -5 \text{ mA}$                                                       |
| $I_{OFF}$ | Output Off Current    |     | 50   | $\mu A$ | $V_{OFF} = 0.45 \text{ to } 5.25V$                                             |
| $V_{IL}$  | Input Low Voltage     |     | 0.8  | V       |                                                                                |
| $V_{IH}$  | Input High Voltage    | 2.0 |      | V       |                                                                                |
| $C_{IN}$  | Input Capacitance     |     | 12   | pF      | $F = 1 \text{ MHz}$<br>$V_{BIAS} = 2.5V$ , $V_{CC} = 5V$<br>$T_A = 25^\circ C$ |

### A.C. CHARACTERISTICS FOR 8282/8283

**Conditions:**  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$

**Loading:** Outputs —  $I_{OL} = 32 \text{ mA}$ ,  $I_{OH} = -5 \text{ mA}$ ,  $C_L = 300 \text{ pF}$

| Symbol | Parameter                                           | Min | Max      | Units    |
|--------|-----------------------------------------------------|-----|----------|----------|
| TIVOV  | Input to Output Delay<br>Inverting<br>Non-Inverting |     | 25<br>35 | ns<br>ns |
| TSHOV  | STB to Output Delay<br>Inverting<br>Non-Inverting   |     | 45<br>55 | ns<br>ns |
| TEHOZ  | Output Disable Time                                 |     | 25       | ns       |
| TELOV  | Output Enable Time                                  | 10  | 50       | ns       |
| TIVSL  | Input to STB Setup Time                             | 0   |          | ns       |
| TSLIX  | Input to STB Hold Time                              | 25  |          | ns       |

**Notes:** 1. See waveforms and test load circuit on following page.

## 8282/8283

## 8282/8283 TIMING



NOTE: 1. 8283 ONLY — OUTPUT MAY BE MOMENTARILY INVALID FOLLOWING THE HIGH GOING STB TRANSITION.

**PRELIMINARY**  
Subject to Change  
Without Notice or Obligation Since  
Performance Levels Are Subject to Change

## OUTPUT TEST LOAD CIRCUITS



## D.C. CHARACTERISTICS FOR 8284

Conditions:  $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ;  $V_{CC} = 5 \pm 10\%$

| Symbol              | Parameter                                | Min                   | Max  | Units         | Test Conditions        |
|---------------------|------------------------------------------|-----------------------|------|---------------|------------------------|
| $I_F$               | Forward Input Current                    |                       | -0.5 | mA            | $V_F = 0.45\text{V}$   |
| $I_R$               | Reverse Input Current                    |                       | 50   | $\mu\text{A}$ | $V_R = 5.25\text{V}$   |
| $V_C$               | Input Forward Clamp Voltage              |                       | -1.0 | V             | $I_C = -5\text{ mA}$   |
| $I_{CC}$            | Power Supply Current                     |                       | 140  | mA            |                        |
| $V_{IL}$            | Input LOW Voltage                        |                       | 0.8  | V             | $V_{CC} = 5.0\text{V}$ |
| $V_{IH}$            | Input HIGH Voltage                       | 2.0                   |      | V             | $V_{CC} = 5.0\text{V}$ |
| $V_{IHR}$           | Reset Input HIGH Voltage                 | 2.6                   |      | V             | $V_{CC} = 5.0\text{V}$ |
| $V_{OL}$            | Output LOW Voltage                       |                       | 0.45 | V             | 5 mA                   |
| $V_{OH}$            | Output HIGH Voltage CLK<br>Other Outputs | $V_{CC} - 0.5$<br>2.4 |      | V             | -1 mA<br>-1 mA         |
| $V_{IHR} - V_{ILR}$ | RES Input Hysteresis                     | 0.25                  |      | V             | $V_{CC} = 5.0\text{V}$ |

## A.C. CHARACTERISTICS FOR 8284

Conditions:  $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ;  $V_{CC} = 5 \pm 10\%$ 

## TIMING REQUIREMENTS

| Symbol  | Parameter                       | Min                          | Max | Units | Test Conditions |
|---------|---------------------------------|------------------------------|-----|-------|-----------------|
| TEH2EL2 | External Frequency High Time    | 20                           |     | ns    |                 |
| TEL1EH1 | External Frequency Low Time     | 20                           |     | ns    |                 |
| TELEL   | EFI Period                      | TEH2EH2 + TEL1EH1 + $\delta$ |     | ns    | (Note 1)        |
|         | XTAL Frequency                  | 12                           | 25  | MHz   |                 |
| TR1VCL  | RDY1, RDY2 Set-Up to CLK        | 45                           |     | ns    |                 |
| TCLR1X  | RDY1, RDY2 Hold to CLK          | 0                            |     | ns    |                 |
| TNVR1V  | AEN1, AEN2 Set-Up to RDY1, RDY2 | 15                           |     | ns    |                 |
| TCLNX   | AEN1, AEN2 Hold to CLK          | 0                            |     | ns    |                 |
| TYHEH   | CSYNC Set-Up to EFI             | 20                           |     | ns    |                 |
| TEHYL   | CSYNC Hold to EFI               | 20                           |     | ns    |                 |
| TYLEH   | CSYNC Width                     | $2 \cdot t_c$                |     | ns    |                 |
| TCLI1H  | RES Set-Up to CLK               | 50                           |     | ns    | (Note 2)        |
| TI1HCL  | RES Hold to CLK                 | 20                           |     | ns    | (Note 2)        |

## TIMING RESPONSES

| Symbol             | Parameter                   | Min              | Max | Units | Test Conditions |
|--------------------|-----------------------------|------------------|-----|-------|-----------------|
| TCLCL              | CLK Cycle Period            | 125              |     | ns    |                 |
| TCH2CL2            | CLK High Time               | (TCLCL/3) - 11.7 |     | ns    |                 |
| TCL1CH1            | CLK Low Time                | (TCLCL/3) - 23.3 |     | ns    |                 |
| TCH1CH2<br>TCL2CL1 | CLK Rise and Fall Time      |                  | 10  | ns    |                 |
| TPH2PL2            | PCLK High Time              | TCLCL - 20       |     | ns    |                 |
| TPL1PH1            | PCLK Low Time               | TCLCL - 20       |     | ns    |                 |
| TRYHCL             | Ready Set-Up to CLK         | 0                |     | ns    |                 |
| TCLRYL             | Ready Hold to CLK           | TCLCL + 30       |     | ns    |                 |
| TELRYL             | EFI to Ready Inactive Delay |                  | 60  | ns    |                 |
| TCLIL              | CLK to Reset Delay          | 40               |     | ns    |                 |

Note: 1.  $\delta$  = EFI rise + EFI fall.

2. Violating these parameters will not create metastable conditions.

ALL MEASUREMENTS ARE MADE AT 1.5 VOLTS, EXCEPT T<sub>1</sub>, T<sub>2</sub>, T<sub>R</sub>, T<sub>F</sub> WHICH ARE MADE AT 0.8 AND 3.5 VOLTS.

Figure 3

# 8286/8287

## D.C. CHARACTERISTICS FOR 8286/8287

Conditions:  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$

| Symbol    | Parameter                                     | Min        | Max          | Units    | Test Conditions                                                             |
|-----------|-----------------------------------------------|------------|--------------|----------|-----------------------------------------------------------------------------|
| $V_C$     | Input Clamp Voltage                           |            | -1           | V        | $I_C = -5 \text{ mA}$                                                       |
| $I_{CC}$  | Power Supply Current<br>8287<br>8286          |            | 130<br>160   | mA<br>mA |                                                                             |
| $I_F$     | Forward Input Current                         |            | -0.2         | mA       | $V_F = 0.45V$                                                               |
| $I_R$     | Reverse Input Current                         |            | 50           | $\mu A$  | $V_R = 5.25V$                                                               |
| $V_{OL}$  | Output Low Voltage<br>B Outputs<br>A Outputs  |            | 0.50<br>0.50 | V<br>V   | $I_{OL} = 32 \text{ mA}$<br>$I_{OL} = 16 \text{ mA}$                        |
| $V_{OH}$  | Output High Voltage<br>B Outputs<br>A Outputs | 2.4<br>2.4 |              | V<br>V   | $I_{OH} = -5 \text{ mA}$<br>$I_{OH} = -1 \text{ mA}$                        |
| $I_{OFF}$ | Output Off Current                            |            | $I_F$        | $\mu A$  | $V_{OFF} = 0.45 \text{ to } 5.25V$                                          |
| $V_{IL}$  | Input Low Voltage                             |            | 0.8          | V        |                                                                             |
| $V_{IH}$  | Input High Voltage                            | 2.0        |              | V        |                                                                             |
| $C_{IN}$  | Input Capacitance                             |            | 12           | pF       | $F = 1 \text{ MHz}$<br>$V_{BIAS} = 2.5V, V_{CC} = 5V$<br>$T_A = 25^\circ C$ |

## A.C. CHARACTERISTICS FOR 8286/8287

Conditions:  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$

Loading: B Outputs —  $I_{OL} = 32 \text{ mA}$ ,  $I_{OH} = -5 \text{ mA}$ ,  $C_L = 300 \text{ pF}$   
A Outputs —  $I_{OL} = 16 \text{ mA}$ ,  $I_{OH} = -1 \text{ mA}$ ,  $C_L = 100 \text{ pF}$

| Symbol            | Parameter                                           | Min   | Max      | Units    | Test Conditions |
|-------------------|-----------------------------------------------------|-------|----------|----------|-----------------|
| T <sub>IVOV</sub> | Input to Output Delay<br>Inverting<br>Non-Inverting |       | 25<br>35 | ns<br>ns | (See Note 1)    |
| TEHTV             | Transmit/Receive Hold Time                          | TEHOZ |          | ns       |                 |
| TTVEL             | Transmit/Receive Setup                              | 30    |          | ns       |                 |
| TEHOZ             | Output Disable Time                                 |       | 25       | ns       |                 |
| TELOV             | Output Enable Time                                  | 10    | 50       | ns       |                 |

Note: 1. See waveforms and test load circuit on following page.

## 8286/8287 TIMING

**PRELIMINARY**  
*Notice: This is not a final specification. Some parametric limits are subject to change.*



## TEST LOAD CIRCUITS



B OUTPUT



A OUTPUT



B OUTPUT



B OUTPUT



A OUTPUT



A OUTPUT

**8288****D.C. CHARACTERISTICS FOR THE 8288**Conditions:  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$ 

| Symbol    | Parameter                                                 | Min        | Max          | Units   | Test Conditions                                      |
|-----------|-----------------------------------------------------------|------------|--------------|---------|------------------------------------------------------|
| $V_C$     | Input Clamp Voltage                                       |            | -1           | V       | $I_C = -5 \text{ mA}$                                |
| $I_{CC}$  | Power Supply Current                                      |            | 170          | mA      |                                                      |
| $I_F$     | Forward Input Current                                     |            | -0.2         | mA      | $V_F = 0.45V$                                        |
| $I_R$     | Reverse Input Current                                     |            | 50           | $\mu A$ | $V_R = 5.25V$                                        |
| $V_{OL}$  | Output Low Voltage<br>Command Outputs<br>Control Outputs  |            | 0.45<br>0.45 | V<br>V  | $I_{OL} = 32 \text{ mA}$<br>$I_{OL} = 16 \text{ mA}$ |
| $V_{OH}$  | Output High Voltage<br>Command Outputs<br>Control Outputs | 2.4<br>2.4 |              | V<br>V  | $I_{OH} = -5 \text{ mA}$<br>$I_{OH} = -1 \text{ mA}$ |
| $V_{IL}$  | Input Low Voltage                                         |            | 0.8          | V       |                                                      |
| $V_{IH}$  | Input High Voltage                                        | 2.0        |              | V       |                                                      |
| $I_{OFF}$ | Output Off Current                                        |            | 100          | $\mu A$ | $V_{OFF} = 0.4 \text{ to } 5.25V$                    |

**A.C. CHARACTERISTICS FOR THE 8288**Conditions:  $V_{CC} = 5V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$ **TIMING REQUIREMENTS**

| Symbol  | Parameter             | Min | Max           | Unit | Loading |
|---------|-----------------------|-----|---------------|------|---------|
| TCLCL   | CLK Cycle Period      | 125 |               | ns   |         |
| TCL1CH1 | CLK Low Time          | 65  |               | ns   |         |
| TCH2CL2 | CLK High Time         | 35  |               | ns   |         |
| TSVCH   | Status Active Setup   | 65  | $t_{CY} - 10$ | ns   |         |
| TSHCL   | Status Inactive Setup | 55  | $t_{CY} - 10$ | ns   |         |

**TIMING RESPONSES**

| Symbol | Parameter                        | Min | Max | Unit | Loading |
|--------|----------------------------------|-----|-----|------|---------|
| TCLNH  | Control Active Delay             | 5   | 45  | ns   |         |
| TCHNH  | Control Inactive Delay           | 10  | 45  | ns   |         |
| TCLNL  | ALE Active Delay (from CLK)      |     | 15  | ns   |         |
| TCHNL  | ALE Inactive Delay               |     | 15  | ns   |         |
| TCLLH  | ALE Active Delay (from Status)   |     | 15  | ns   |         |
| TSVLH  | ALE Inactive Delay               |     | 15  | ns   |         |
| TCHLL  | ALE Active Delay (from Control)  |     | 15  | ns   |         |
| TCLRL  | Command Active Delay             | 10  | 35  | ns   |         |
| TCLRH  | Command Inactive Delay           | 10  | 40  | ns   |         |
| TCHDTL | Direction Control Active Delay   |     | 50  | ns   |         |
| TCLDTH | Direction Control Inactive Delay |     | 30  | ns   |         |
| TAELCV | Command Enable Time              |     | 30  | ns   |         |
| TAEHCZ | Command Disable Time             |     | 30  | ns   |         |
| TAEVCV | Enable Delay Time                | 85  | 190 | ns   |         |
| TAEVNV | AEN to DEN                       |     | 20  | ns   |         |
| TCEVNV | CEN to DEN                       |     | 20  | ns   |         |
| TCEVNV | CEN to PDEN                      |     | 20  | ns   |         |

$$\left. \begin{array}{l} \text{MRDC} \\ \text{IORC} \\ \text{MWTC} \\ \text{IOWC} \\ \text{INTA} \\ \text{AMWTC} \\ \text{AIOWC} \end{array} \right\} \begin{array}{l} I_{OL} = 32 \text{ mA} \\ I_{OH} = -2 \text{ mA} \\ C_L = 300 \text{ pF} \end{array}$$

$$\left. \begin{array}{l} \text{Other} \end{array} \right\} \begin{array}{l} I_{OL} = 10 \text{ mA} \\ I_{OH} = -1 \text{ mA} \\ C_L = 80 \text{ pF} \end{array}$$

## 8288 TIMING DIAGRAM



**PRELIMINARY**  
This is not a final specification. Some parametric limits are subject to change.

## DEN, PDEN QUALIFICATION TIMING



## 8288 ADDRESS ENABLE (AEN) TIMING (3-STATE ENABLE/DISABLE)



## TEST LOAD CIRCUITS



# **Chapter 21**

## **THE ZILOG Z8000**

**This chapter will be provided at a later date as an update.**

## Chapter 22

# 2900 SERIES AND 6700 SERIES CHIP SLICE PRODUCTS

In the next two chapters of this book we are going to summarize chip slice logic products. The chip slice product descriptions given in the next two chapters have not been updated from the previous revision (which appeared in June of 1977). Since that time the 10800 series chip slice products, described in Chapter 23, have not progressed; however, the 2900 series chip slice products, described in this chapter, have become the standard of the industry. Moreover, many of the 2900 series parts have been enhanced, while new parts have been added to the family. In order to do justice to the 2900 series chip slice products, this chapter should have been significantly expanded. When reading this chapter, therefore, you should understand that it does not do justice to the 2900 series chip slice products, nor does it describe some of the new powerful parts that have been added to the family. This chapter will be updated with one of the early updates.

The 2900 and 6700 series 4-bit slice products conform very closely to the general chip slice logic description given in Volume 1, Chapter 4. The 6700 series product came first, and the 2900 series represents a relatively small enhancement.

Since the 2900 and 6700 series devices are very similar, this chapter is going to concentrate on the 2900 series — the more recent product. Differences between the 2900 series and 6700 series products, where they exist, will be identified.

In this chapter we are going to describe the general capabilities of the various devices, relying upon Volume 1, Chapter 4 to provide basic concepts. If you do not already have a basic understanding of chip slice products, then you should refer to Volume 1, Chapter 4 before proceeding with this chapter.

**All 2900 series and 6700 series devices use bipolar LSI technology.**

**The 2900 series microinstruction execution time is 100 nanoseconds; the 6700 series microinstruction execution time is 200 nanoseconds.**

The primary source for the 2900 series chip slice logic is:

ADVANCED MICRO DEVICES  
901 Thompson Place  
Sunnyvale, CA 94086

There are two second sources for the 2900 series logic:

MOTOROLA SEMICONDUCTOR  
Box 20912  
Phoenix, AZ 85036  
RAYTHEON SEMICONDUCTOR  
350 Ellis Street  
Mountain View, CA 94042

The primary source for the 6700 series chip slice logic is:

MONOLITHIC MEMORIES  
1165 East Arques Avenue  
Sunnyvale, CA 94086



Figure 22-1. The 2901/6701 Arithmetic and Logic Unit

## THE 2901/6701 ARITHMETIC AND LOGIC UNIT (ALU)

**These devices constitute the center of any chip slice logic product.**

**Figure 22-1 illustrates the logic provided by a 2901 or 6701 ALU.** Figure 22-1 is a reproduction of Figure 4-3 from Volume 1, except that the AA and BB Register Block ports have been switched in order to become compatible with 2901 literature.

The first thing to notice about the 2901/6701 ALU is the fact that it represents a 4-bit slice through the arithmetic and logic unit of a typical central processing unit. But being a discrete logic device, it must provide more than simple arithmetic and Boolean logic; it must provide some method of identifying data sources and destinations. Also, as we saw in Volume 1, Chapter 4, an ALU chip slice is going to acquire some additional responsibilities toward its neighbors. Within this context, let us examine the pins and signals of the 2901 and 6701, as illustrated in Figure 22-2.



Figure 22-2. 2901 ALU Logic

Table 22-1. 2901 ALU Function Control

| MICRO CODE |    |    |               | ALU<br>FUNCTION | SYMBOL                     |
|------------|----|----|---------------|-----------------|----------------------------|
| I5         | I4 | I3 | OCTAL<br>CODE |                 |                            |
| L          | L  | L  | 0             | R Plus S        | R + S                      |
| L          | L  | H  | 1             | S Minus R       | S - R                      |
| L          | H  | L  | 2             | R Minus S       | R - S                      |
| L          | H  | H  | 3             | R OR S          | RVS                        |
| H          | L  | L  | 4             | R AND S         | RAS                        |
| H          | L  | H  | 5             | $\bar{R}$ AND S | $\bar{R} \wedge S^*$       |
| H          | H  | L  | 6             | R EX-OR S       | RVS                        |
| H          | H  | H  | 7             | R EX-NOR S      | $\bar{R} \wedge \bar{S}^*$ |

\*2901 ONLY

Table 22-2. ALU Source Operand Control

| MICRO CODE |    |    |               | ALU SOURCE<br>OPERANDS |
|------------|----|----|---------------|------------------------|
| I2         | I1 | I0 | OCTAL<br>CODE |                        |
| L          | L  | L  | 0             | A Q                    |
| L          | L  | H  | 1             | A B                    |
| L          | H  | L  | 2             | O Q                    |
| L          | H  | H  | 3             | O B                    |
| H          | L  | L  | 4             | O A                    |
| H          | L  | H  | 5             | D A/B*                 |
| H          | H  | L  | 6             | D O                    |
| H          | H  | H  | 7             | D O                    |

\*A for 2901  
B for 6701

First of all, note that the ALU device receives two types of input:

- 1) Status and control signals via which it communicates with its neighbors.
- 2) An instruction code, plus data, via which it is sequenced by a Control Unit.

**2901 ALU  
OPERATIONS  
SPECIFICATION**

The focus of attention for the 2901/6701 ALU is the logic which actually performs arithmetic and logic operations — the ALU Block. This block of logic performs **eight operations** which are specified by instruction signal inputs I3, I4 and I5, as defined in Table 22-1. Observe that these eight functions consist of three arithmetic functions and four Boolean functions. Shift logic is missing. Shift logic is taken out of the ALU and placed within source and destination data paths.

**2901 ALU  
SOURCE  
SPECIFICATION**

There are two ALU Block sources, shown in Figure 22-2 as the R and S inputs; they are the P---P and Q---Q inputs of Figure 22-1. Each source is four bits wide, since we are dealing with a 4-bit chip slice.

**Inputs may consist of:**

- 1) External data transmitted from the control unit to data pins D0 - D3.
- 2) Temporary data extracted from a small, 16 x 4-bit read/write memory within the 2901/6701.
- 3) The output of a shifter or temporary 4-bit register, identified in Figures 22-1 and 22-2 as the Q register. In reality, the Q register is a short circuit from ALU logic to ALU logic input.

**The results of ALU operations may be output directly from the 2901/6701 via the Y0 - Y3 output pins (DO---DO in Figure 22-1); alternatively, the data may be routed to the Register Block, or the Q register.**

**The three instruction code bits, I0 - I2, define what the R and S inputs to the ALU will be. Table 22-2 defines how I0 - I2 will be interpreted.**

Now take a look at the 16 x 4-bit read/write memory. We have seen that 2901/6701 logic allows the contents of any two 4-bit registers to be output; also, data is input to any one of the sixteen registers. External logic must define input and output registers using select pins. Ideally, three 4-bit select codes would be required:



But that is going to require 12 pins — and that is too many pins; therefore, the B output address code does double duty, also providing the Z input address; this eliminates the four Z pins, but reduces your options.

In summary, these 11 signals constitute a complete set of inputs:

- Three microinstruction signals, I0, I1 and I2.
- Two 4-bit register select codes, B0 - B3 and A0 - A3.

External logic must provide all 11 signal inputs simultaneously for every microinstruction's execution, simply to define the data entering the ALU Block.

We have not yet defined destination logic within the 2901/6701 ALU because the shifter and destination logic are combined. **The single ALU 4-bit result can go to one of three places:**

- 1) The output pins Y0 - Y3
- 2) The Q register
- 3) The 4-bit read/write memory register addressed by the B input

Of these three destinations, two — the Q register and the read/write memory — are optionally preceded by shifter logic.

You could specify a variety of destination options for the ALU Block results which are output via R---R. This data may be transmitted to one, two or all three of the identified destinations; and for two of the destinations data may optionally be shifted. It would require five pins simply to define the possible combinations of shifting and destination; but there

are additional options. Observe that the contents of the 4-bit register addressed by the A address lines may be output directly to DO---DO. This data path is an important one, since we must have some means of outputting shifting data without transmitting it through the ALU Block. To enable all destination combinations would require too many pins; not only would more pins be expensive in terms of device packaging, but each pin must be backed up by a microinstruction — and if you increase the size of the microinstruction word, you will also increase the size of the control read-only memory within which the microprogram must be stored. Therefore, a judicious subset of the possible destination combinations is selected via the three microinstruction input pins I6, I7 and I8. Table 22-3 defines the way in which these three microinstructions are decoded.

**Let us then summarize the signals which must be input to a 2901/6701 simply to identify a single microinstruction.**

The actual microinstruction object code must be input via the nine pins I0 - I8.

Two 4-bit register select codes must be input via A0 - A3 and B0 - B3. These address inputs must occur with the execution of every microinstruction.

A 4-bit direct data nibble may or may not be needed. If it is needed, it must be input along with the microinstruction object code via pins B0 - B3.

**The principal output created following the execution of each microinstruction appears via the pins Y0 - Y3.**

**A number of timing and status signals remain to be described.**

Timing is controlled by a single clock signal input via CP.

The ALU Block has two sets of status signals. One set allows normal CPU statuses to be created, the other set enables carry look ahead logic. The carry look ahead signals have been described in Volume 1, Chapter 4.

These are the normal status signals provided:

- 1) A Zero status shown in Figure 22-2 as F0. This signal is the NOR of ALU Block outputs. For a number of 2901/6701 devices, you can create an overall Zero status by a wire-OR of the F0 outputs.
- 2) The high order bit of the ALU Block output appears as the F3 status in Figure 22-2. This status, when output by the high order 4-bit ALU slice, can be used to create a Sign status. **The 6701 does not provide this status.**

Cn+4 and OVR are outputs which, when taken from the high order slice, can be used to generate Carry and Overflow statuses, respectively.

Each of the two shifters has a shift-in and a shift-out pin so that shifts may be rippled from one ALU slice to the next.

Two enhancements of the 2901 have appeared. The 2901A is a higher speed version of the 2901, while the 2903 is an enhancement of the 2901. The most important enhancement that the 2903 has is its ability to address external high-speed read/write memory as additional registers. Thus, if the 16 registers available in a 2901 are insufficient for your needs, you should look at the 2903.

The 2901A and the 2903 ALU devices are not described further in this chapter.

|                                                                      |
|----------------------------------------------------------------------|
| <b>ZERO STATUS<br/>IN CHIP SLICE<br/>LOGIC</b>                       |
| <b>SIGN<br/>STATUS<br/>IN CHIP SLICE<br/>LOGIC</b>                   |
| <b>OVERFLOW<br/>AND<br/>CARRY STATUS<br/>IN CHIP SLICE<br/>LOGIC</b> |

## THE 2909 MICROPROGRAM SEQUENCER

**A group of 2901/6701 ALU slices must be driven by microprograms which will be stored in read-only memory. The read-only memory requires address logic. The responsibility of the address logic is to ensure that microinstructions are fetched in the correct sequence, so that in response to an instruction's object code, the ALU logic will perform necessary operations.**

**The 2909 microprogram sequencer provides you with the logic needed to create any address sequence for instructions stored in a microprogram ROM. Figure 22-3 illustrates the logic of the 2909 microprogram sequencer.**



Table 22-3. ALU Destination Control

| MICRO CODE |   |             | RAM FUNCTION            |             | Q-REG. FUNCTION           |                       | Y OUTPUT | RAM SHIFTER |            | Q SHIFTER |          |
|------------|---|-------------|-------------------------|-------------|---------------------------|-----------------------|----------|-------------|------------|-----------|----------|
|            |   |             |                         |             |                           |                       |          | RAM0 LO/RI  | RAM3 LI/RO | Q0 LO/RI  | Q3 LI/RO |
| L L L      | 0 | -           | -                       | -           | NONE                      | ALU (F <sub>i</sub> ) | F        | X           | X          | X         | X        |
| L L H      | 1 | -           | -                       | -           | -                         | -                     | F        | X           | X          | X         | X        |
| L L H      | 1 | -           | -                       | -           | ALU (F <sub>i</sub> )     | -                     | B        | X           | X          | X         | X        |
| L H L      | 2 | NONE        | -                       | -           | ALU (F <sub>i</sub> )     | -                     | A        | X           | X          | X         | X        |
| L H H      | 3 | NONE        | -                       | -           | ALU (F <sub>i</sub> )     | -                     | F        | X           | X          | X         | X        |
| H L L      | 4 | LEFT (DOWN) | ALU (F <sub>i+1</sub> ) | LEFT (DOWN) | Q-REG (Q <sub>i+1</sub> ) | F                     | F0       | IN3         | Q0         | IN3       |          |
| H L H      | 5 | LEFT (DOWN) | ALU (F <sub>i+1</sub> ) | -           | -                         | F                     | F0       | IN3         | Q0         | X         |          |
| H H L      | 6 | RIGHT (UP)  | ALU (F <sub>i-1</sub> ) | RIGHT (UP)  | Q-REG (Q <sub>i-1</sub> ) | F                     | IN0      | F3          | IN0        | Q3        |          |
| H H H      | 7 | RIGHT (UP)  | ALU (F <sub>i-1</sub> ) | -           | -                         | F                     | IN0      | F3          | X          | Q3        |          |

X : Don't care. Electrically, the shift pin is a TTL input internally connected to a three-state output which is in the high-impedance state.

**Monolithic Memories provides the 67110 Control Unit which performs the same functions as the 2909, but in a substantially different way. The 67110 is not described in this chapter.**

The most important thing to note about microprogram sequencer logic is that it bears a striking resemblance to the program memory addressing logic which will be provided on any microprocessor CPU. The principal difference is that microprogram sequencer logic is more elementary and therefore can execute faster — a necessary prerequisite if microprogram instruction executions are to concatenate in order to generate macroprogram instruction executions.

The next important point to note is that the 2909 microprogram sequencer logic, like the 2901 ALU, is a chip slice product. Each 2909 is a 4-bit chip slice. One 2909 device is capable of generating four address lines — addressing just sixteen microinstructions stored in ROM. By having two 2909 devices in parallel, you can create an 8-bit address which will access 256 microinstructions stored in program ROM. Each additional 2909 will increase the size of the address by four bits; and the number of microinstructions that can be accessed will increase accordingly.

**Let us take a look at Figure 22-3. You should begin by looking at the multiplexer. This logic selects and outputs one of four possible address inputs.** The two control signals, S0 and S1, determine which of the four addresses will be output.

The four lines of the address which is selected for output are ORed individually with external inputs OR0 - OR3, then the result of the OR is ANDed with a possible zero input.

The reason for having the individual OR0 - OR3 inputs is to allow branch logic to unilaterally modify an address which is being created. This is the point at which you would implement logic associated with a conditional branch.

The AND with zero allows you to unilaterally zero the output address — which you might want to do in response to a RESTART or other initialization.

#### These are the four possible address inputs:

- 1) A direct address input via the pins D0 - D3. This is an input which you would use initially to start the execution of a microinstruction sequence, after decoding a macroinstruction object code. You could also use these inputs subsequently to force a unilateral branch.
- 2) The incremented contents of the Microprogram Counter register. The Microprogram Counter register serves exactly the same function as the Program Counter register in a microcomputer. You would initially load a starting address into the Microprogram Counter register. Subsequently the Microprogram Counter register is going to be the normal location from which the multiplexer chooses its output address. After each address from the Microprogram Counter register is selected, the address will be incremented and returned, just as it would be in any microprocessor Program Counter. But there is a difference: since we are dealing with a chip slice product, the total Microprogram Counter register will consist of a number of 4-bit sections. There will accordingly be a carry-in pin and a carry-out pin, so that incrementing can ripple down from one 4-bit section to the next.

There is an additional feature of Microprogram Counter register logic. As described in Volume I, Chapter 4, it is frequently necessary to re-execute the same microinstruction many times. For example, you may execute a no operation code a number of times in order to maintain synchronization between microinstructions and the macroinstruction system clock. You may also re-execute a Shift or Rotate microinstruction many times to perform multiple shifts or rotates. In order to save on microprogram ROM, you can inhibit the Microprogram Counter register increment logic by inputting a high value at the CI input to the low order four bits of the Microprogram Counter register. Clearly, this carry input must be zero in the normal course of events, since there is no lower shift that could possibly generate a legitimate carry input.

- 3) Just as assembly language programs can contain subroutines, so a microinstruction program can also contain subroutines. From our discussion of microprogramming in Chapter 4 of Volume I, you will recall that having subroutines in a microprogram is a very desirable feature. For example, large portions of an instruction fetch, a memory read and a memory write will be implemented via exactly the same microinstruction sequences. By including these microinstruction sequences in a microprogram subroutine, you can save significant amounts of microprogram memory. Microprogram subroutines are just as useful and memory-saving devices as assembly language subroutines. However, since microprograms are likely to be shorter than assembly language programs, the 2909 provides a four-level subroutine Stack. This means that you can nest microprogram subroutines to a depth of four. By inputting FILE ENABLE low, you can pop the top of the four-deep Stack into the multiplexer, or you can push the Microprogram Counter contents into the top of the Stack. Signal PUP, when high, forces the push; when low, PUP forces a pop.
- 4) The fourth possible input for the multiplexer address is the contents of the Address register. You can at any time input an address to the Address register via the R0 - R4 pins.

**The OE control input allows you to disconnect the microprogram sequencer from the Address Bus. Thus, address outputs may be floated.**

**Observe that although the 2909 microprogram sequencer provides a good deal of the logic needed in order to create address sequences, a great deal of additional logic must still be provided in order to access microprogram sequencer logic appropriately.**

The 2910 microprogram sequencer is essentially equivalent to three 2909 slices. That is to say, it provides a 4096 instruction addressing range. The 2910 microprogram sequencer is not described in this chapter.

The 2930 and 2931 address generation devices are also new additions to the 2900 series chip slice products. The 2930 and 2931 devices compute effective memory addresses needed by assembly language memory reference instructions. Thus, the 2930 and 2931 devices are used to compute external memory addresses which may be required by assembly language level macroinstructions, while the 2909 and the 2910 compute internal memory addresses that may be needed within the microprogram itself.

## THE 2902 CARRY LOOK AHEAD

**This device serves just one function: when performing binary addition, it creates parallel carry inputs for those 4-bit slices that are going to need a carry. Carry look ahead logic has been described in detail, in Volume 1, Chapter 4. We will therefore provide a simple summary of this device in this chapter.**

Suppose two 16-bit binary numbers are to be added. If each 16-bit number is implemented in four 4-bit slices, then how are you going to generate the carry for the second, third and fourth 4-bit slice? You could perform the binary addition in four steps — in which case at the conclusion of each step you would generate the necessary carry for the next step. This is an unsatisfactory method of performing binary addition when using chip slice logic because it is slow. The whole purpose of chip slice logic is to obtain maximum execution speed. The alternative is to create a device which will anticipate the carry that would be generated and provide it so that all four segments of the 16-bit binary addition can be performed simultaneously. That is exactly what the 2902 device does.

**Figure 22-4 illustrates the way in which a 2902 Carry Look Ahead device will connect to 2901 ALU slices.**

As illustrated in this figure, the 2902 device can compute carry look ahead for up to three 4-bit slices — which means that it will support a 16-bit word; remember, the low order slice does not need any carry look ahead.

You can generate carry look ahead for larger words by using a number of 2902s together.

In order to generate carry look ahead, the 2902 receives, as inputs, the Carry Generate and Carry Propagate signals from the 2901/6701 ALU slices. For a discussion of this carry look ahead logic see Volume 1, Chapter 4.

22-9



Figure 22-4. Four 2901s In a 16-Bit CPU Using the 2902 for Carry Look Ahead

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- Am2901 Arithmetic and Logic Unit
- Am2902 Carry Look Ahead
- Am2909 Microprogram Sequencer

# Am2901

| MICRO CODE |       |       | ALU SOURCE OPERANDS |     |
|------------|-------|-------|---------------------|-----|
| $I_2$      | $I_1$ | $I_0$ | Octal Code          | R S |
| L          | L     | L     | 0                   | A Q |
| L          | L     | H     | 1                   | A B |
| L          | H     | L     | 2                   | O Q |
| L          | H     | H     | 3                   | O B |
| H          | L     | L     | 4                   | O A |
| H          | L     | H     | 5                   | D A |
| H          | H     | L     | 6                   | D Q |
| H          | H     | H     | 7                   | D O |

Figure 2. ALU Source Operand Control.

| MICRO CODE |       |       | Octal Code | ALU Function | Symbol |
|------------|-------|-------|------------|--------------|--------|
| $I_5$      | $I_4$ | $I_3$ |            |              |        |
| L          | L     | L     | 0          | R Plus S     | R + S  |
| L          | L     | H     | 1          | S Minus R    | S - R  |
| L          | H     | L     | 2          | R Minus S    | R - S  |
| L          | H     | H     | 3          | R OR S       | R ∨ S  |
| H          | L     | L     | 4          | R AND S      | R ∧ S  |
| H          | L     | H     | 5          | R AND S      | R ∧ S  |
| H          | H     | L     | 6          | R EX-OR S    | R ∨ S  |
| H          | H     | H     | 7          | R EX-NOR S   | R ∨ S  |

Figure 3. ALU Function Control.

| MICRO CODE |       |       | RAM FUNCTION |       | Q-REG. FUNCTION |       | Y OUTPUT | RAM SHIFTER      |                  | Q SHIFTER       |                 |                 |
|------------|-------|-------|--------------|-------|-----------------|-------|----------|------------------|------------------|-----------------|-----------------|-----------------|
| $I_8$      | $I_7$ | $I_6$ | Octal Code   | Shift | Load            | Shift | Load     | RAM <sub>0</sub> | RAM <sub>3</sub> | Q <sub>0</sub>  | Q <sub>3</sub>  |                 |
| L          | L     | L     | 0            | X     | NONE            | NONE  | F → Q    | F                | X                | X               | X               | X               |
| L          | L     | H     | 1            | X     | NONE            | X     | NONE     | F                | X                | X               | X               | X               |
| L          | H     | L     | 2            | NONE  | F → B           | X     | NONE     | A                | X                | X               | X               | X               |
| L          | H     | H     | 3            | NONE  | F → B           | X     | NONE     | F                | X                | X               | X               | X               |
| H          | L     | L     | 4            | DOWN  | F/2 → B         | DOWN  | Q/2 → Q  | F                | F <sub>0</sub>   | IN <sub>3</sub> | Q <sub>0</sub>  | IN <sub>3</sub> |
| H          | L     | H     | 5            | DOWN  | F/2 → B         | X     | NONE     | F                | F <sub>0</sub>   | IN <sub>3</sub> | Q <sub>0</sub>  | X               |
| H          | H     | L     | 6            | UP    | 2F → B          | UP    | 2Q → Q   | F                | IN <sub>0</sub>  | F <sub>3</sub>  | IN <sub>0</sub> | O <sub>3</sub>  |
| H          | H     | H     | 7            | UP    | 2F → B          | X     | NONE     | F                | IN <sub>0</sub>  | F <sub>3</sub>  | X               | O <sub>3</sub>  |

X= Don't care. Electrically, the shift pin is a TTL input internally connected to a three-state output which is in the high-impedance state.

B = Register Addressed by B inputs.

Up is toward MSB, Down is toward LSB.

Figure 4. ALU Destination Control.

| $I_{210}$ OCTAL                 | 0                                                     | 1                  | 2                  | 3         | 4         | 5         | 6                  | 7                  |           |
|---------------------------------|-------------------------------------------------------|--------------------|--------------------|-----------|-----------|-----------|--------------------|--------------------|-----------|
| O<br>C<br>I<br>T<br>A<br>L<br>3 | ALU Source                                            | A, Q               | A, B               | O, Q      | O, B      | O, A      | D, A               | D, Q               | D, O      |
| 0                               | C <sub>n</sub> = L<br>R Plus S<br>C <sub>n</sub> = H  | A+Q                | A+B                | Q         | B         | A         | D+A                | D+Q                | D         |
| 1                               | C <sub>n</sub> = L<br>S Minus R<br>C <sub>n</sub> = H | A+Q+1              | A+B+1              | Q+1       | B+1       | A+1       | D+A+1              | D+Q+1              | D+1       |
| 2                               | C <sub>n</sub> = L<br>R Minus S<br>C <sub>n</sub> = H | Q-A-1              | B-A-1              | Q-1       | B-1       | A-1       | A-D-1              | Q-D-1              | -D-1      |
| 3                               | R OR S                                                | A V Q              | A V B              | Q         | B         | A         | D V A              | D V Q              | D         |
| 4                               | R AND S                                               | A $\wedge$ Q       | A $\wedge$ B       | 0         | 0         | 0         | D $\wedge$ A       | D $\wedge$ Q       | 0         |
| 5                               | R AND S                                               | $\bar{A} \wedge Q$ | $\bar{A} \wedge B$ | Q         | B         | A         | $\bar{D} \wedge A$ | $\bar{D} \wedge Q$ | 0         |
| 6                               | R EX-OR S                                             | A $\vee$ Q         | A $\vee$ B         | Q         | B         | A         | D $\vee$ A         | D $\vee$ Q         | D         |
| 7                               | R EX-NOR S                                            | $\bar{A} \vee Q$   | $\bar{A} \vee B$   | $\bar{Q}$ | $\bar{B}$ | $\bar{A}$ | $\bar{D} \vee A$   | $\bar{D} \vee Q$   | $\bar{D}$ |

+ = Plus; - = Minus; V = OR;  $\wedge$  = AND;  $\vee$  = EX-OR

Figure 5. Source Operand and ALU Function Matrix.

Data sheets on pages 22-D2 through 22-D10 Copyright © 1978 by Advanced Micro Devices, Inc. Reproduced with permission of copyright owner.

**Am2901****MAXIMUM RATINGS** (Above which the useful life may be impaired)

|                                                     |                                 |  |  |
|-----------------------------------------------------|---------------------------------|--|--|
| Storage Temperature                                 | -65°C to +150°C                 |  |  |
| Temperature (Ambient) Under Bias                    | -55°C to +125°C                 |  |  |
| Supply Voltage to Ground Potential                  | -0.5 V to +6.3 V                |  |  |
| DC Voltage Applied to Outputs for HIGH Output State | -0.5 V to +V <sub>CC</sub> max. |  |  |
| DC Input Voltage                                    | -0.5 V to +5.5 V                |  |  |
| DC Output Current, Into Outputs                     | 30 mA                           |  |  |
| DC Input Current                                    | -30 mA to +5.0 mA               |  |  |

**OPERATING RANGE**

| P/N          | Ambient Temperature | V <sub>CC</sub>  |
|--------------|---------------------|------------------|
| Am2901PC, DC | 0°C to +70°C        | 4.75 V to 5.25 V |
| Am2901DM, FM | -55°C to +125°C     | 4.50 V to 5.50 V |

**STANDARD SCREENING**

(Conforms to MIL-STD-883 for Class C Parts)

| Step                                               | MIL-STD-883 Method | Conditions                                    | Level        |              |
|----------------------------------------------------|--------------------|-----------------------------------------------|--------------|--------------|
|                                                    |                    |                                               | Am2901PC, DC | Am2901DM, FM |
| Pre-Seal Visual Inspection                         | 2010               | B                                             | 100%         | 100%         |
| Stabilization Bake                                 | 1008               | C 24-hour<br>150°C                            | 100%         | 100%         |
| Temperature Cycle                                  | 1010               | C -65°C to +150°C<br>10 cycles                | 100%         | 100%         |
| Centrifuge                                         | 2001               | B 10,000 G                                    | 100% *       | 100%         |
| Fine Leak                                          | 1014               | A 5 x 10 <sup>-8</sup> atm-cc/cm <sup>3</sup> | 100% *       | 100%         |
| Gross Leak                                         | 1014               | C2 Fluorocarbon                               | 100% *       | 100%         |
| Electrical Test<br>Subgroups 1 and 7               | 5004               | See below for<br>definitions of subgroups     | 100%         | 100%         |
| Insert Additional Screening here for Class B Parts |                    |                                               |              |              |
| Group A Sample Tests                               |                    |                                               |              |              |
| Subgroup 1                                         |                    |                                               | LTPD = 5     | LTPD = 5     |
| Subgroup 2                                         |                    |                                               | LTPD = 7     | LTPD = 7     |
| Subgroup 3                                         |                    |                                               | LTPD = 7     | LTPD = 7     |
| Subgroup 7                                         |                    |                                               | LTPD = 7     | LTPD = 7     |
| Subgroup 8                                         |                    |                                               | LTPD = 7     | LTPD = 7     |
| Subgroup 9                                         |                    |                                               | LTPD = 7     | LTPD = 7     |

\*Not applicable for Am2901PC

**ADDITIONAL SCREENING FOR CLASS B PARTS**

| Step                                                                                  | MIL-STD-883 Method | Conditions                | Level                                |
|---------------------------------------------------------------------------------------|--------------------|---------------------------|--------------------------------------|
| Burn-In                                                                               | 1015               | D 125°C<br>160 hours min. | 100%                                 |
| Electrical Test<br>Subgroup 1<br>Subgroup 2<br>Subgroup 3<br>Subgroup 7<br>Subgroup 9 | 5004               |                           | 100%<br>100%<br>100%<br>100%<br>100% |
| Return to Group A Tests in Standard Screening                                         |                    |                           |                                      |

**ORDERING INFORMATION**

| Package Type            | Temperature Range | Order Number | GROUP A SUBGROUPS<br>(as defined in MIL-STD-883, method 5005) |           |                                       |
|-------------------------|-------------------|--------------|---------------------------------------------------------------|-----------|---------------------------------------|
|                         |                   |              | Subgroup                                                      | Parameter | Temperature                           |
| Molded DIP              | 0°C to +70°C      | AM2901PC     | 1                                                             | DC        | 25°C                                  |
| Hermetic DIP            | 0°C to +70°C      | AM2901DC     | 2                                                             | DC        | Maximum rated temperature             |
| Hermetic DIP            | -55°C to +125°C   | AM2901DM     | 3                                                             | DC        | Minimum rated temperature             |
| Hermetic Flat Pack Dice | -55°C to +125°C   | AM2901FM     | 7                                                             | Function  | 25°C                                  |
|                         | 0°C to +70°C      | AM2901XC     | 8                                                             | Function  | Maximum and minimum rated temperature |
|                         |                   |              | 9                                                             | Switching | 25°C                                  |
|                         |                   |              | 10                                                            | Switching | Maximum Rated Temperature             |
|                         |                   |              | 11                                                            | Switching | Minimum Rated Temperature             |

**Am2901**
**ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)**  
 (Group A, Subgroups 1, 2 and 3)

| Parameters                                 | Description                               | Test Conditions (Note 1)                                                                               | Min.                                                                                                    | Typ. (Note 2)                  | Max.  | Units |
|--------------------------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------------------------|-------|-------|
| <b>V<sub>OH</sub></b>                      | Output HIGH Voltage                       | V <sub>CC</sub> = MIN.<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub>                         | I <sub>OH</sub> = -1.6mA<br>Y <sub>0</sub> , Y <sub>1</sub> , Y <sub>2</sub> , Y <sub>3</sub>           | 2.4                            |       |       |
|                                            |                                           |                                                                                                        | I <sub>OH</sub> = -1.0mA, C <sub>n+4</sub>                                                              | 2.4                            |       |       |
|                                            |                                           |                                                                                                        | I <sub>OH</sub> = -800μA, OVR, $\bar{P}$                                                                | 2.4                            |       |       |
|                                            |                                           |                                                                                                        | I <sub>OH</sub> = -600μA, F <sub>3</sub>                                                                | 2.4                            |       |       |
|                                            |                                           |                                                                                                        | I <sub>OH</sub> = -600μA, RAM <sub>0, 3, Q<sub>0, 3</sub></sub>                                         | 2.4                            |       |       |
|                                            |                                           |                                                                                                        | I <sub>OH</sub> = -1.6mA, $\bar{G}$                                                                     | 2.4                            |       |       |
| <b>I<sub>CEx</sub></b>                     | Output Leakage Current for F = 0 Output   | V <sub>CC</sub> = MIN., V <sub>OH</sub> = 5.5V<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> |                                                                                                         |                                | 250   | μA    |
| <b>V<sub>OL</sub></b>                      | Output LOW Voltage                        | V <sub>CC</sub> = MIN.,<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub>                        | I <sub>OL</sub> = 16mA<br>Y <sub>0</sub> , Y <sub>1</sub> , Y <sub>2</sub> , Y <sub>3</sub> , $\bar{G}$ |                                | 0.5   |       |
|                                            |                                           |                                                                                                        | I <sub>OL</sub> = 10mA, C <sub>n+4</sub> , F = 0                                                        |                                | 0.5   |       |
|                                            |                                           |                                                                                                        | I <sub>OL</sub> = 8.0mA, OVR, $\bar{P}$                                                                 |                                | 0.5   |       |
|                                            |                                           |                                                                                                        | I <sub>OL</sub> = 6.0mA, F <sub>3</sub><br>RAM <sub>0, 3, Q<sub>0, 3</sub></sub>                        |                                | 0.5   |       |
| <b>V<sub>IH</sub></b>                      | Input HIGH Level                          | Guaranteed input logical HIGH voltage for all inputs                                                   |                                                                                                         |                                | 2.0   |       |
| <b>V<sub>IL</sub></b>                      | Input LOW Level                           | Guaranteed input logical LOW voltage for all inputs                                                    | Military                                                                                                |                                | 0.7   |       |
|                                            |                                           |                                                                                                        | Commercial                                                                                              |                                | 0.8   |       |
| <b>V<sub>I</sub></b>                       | Input Clamp Voltage                       | V <sub>CC</sub> = MIN., I <sub>IN</sub> = -18mA                                                        |                                                                                                         |                                | -1.5  |       |
| <b>I<sub>IL</sub></b>                      | Input LOW Current                         | V <sub>CC</sub> = MAX.<br>V <sub>IN</sub> = 0.5V                                                       | Clock, $\bar{OE}$                                                                                       |                                | -0.36 |       |
|                                            |                                           |                                                                                                        | A <sub>0</sub> , A <sub>1</sub> , A <sub>2</sub> , A <sub>3</sub>                                       |                                | -0.36 |       |
|                                            |                                           |                                                                                                        | B <sub>0</sub> , B <sub>1</sub> , B <sub>2</sub> , B <sub>3</sub>                                       |                                | -0.36 |       |
|                                            |                                           |                                                                                                        | D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> , D <sub>3</sub>                                       |                                | -0.72 |       |
|                                            |                                           |                                                                                                        | I <sub>0</sub> , I <sub>1</sub> , I <sub>2</sub> ; I <sub>6</sub> , I <sub>8</sub>                      |                                | -0.36 |       |
|                                            |                                           |                                                                                                        | I <sub>3</sub> , I <sub>4</sub> , I <sub>5</sub> , I <sub>7</sub>                                       |                                | -0.72 |       |
|                                            |                                           |                                                                                                        | RAM <sub>0, 3, Q<sub>0, 3</sub></sub> (Note 4)                                                          |                                | -0.8  |       |
|                                            |                                           |                                                                                                        | C <sub>n</sub>                                                                                          |                                | -3.6  |       |
|                                            |                                           |                                                                                                        |                                                                                                         |                                |       |       |
| <b>I<sub>IH</sub></b>                      | Input HIGH Current                        | V <sub>CC</sub> = MAX.<br>V <sub>IN</sub> = 2.7V                                                       | Clock, $\bar{OE}$                                                                                       |                                | 20    |       |
|                                            |                                           |                                                                                                        | A <sub>0</sub> , A <sub>1</sub> , A <sub>2</sub> , A <sub>3</sub>                                       |                                | 20    |       |
|                                            |                                           |                                                                                                        | B <sub>0</sub> , B <sub>1</sub> , B <sub>2</sub> , B <sub>3</sub>                                       |                                | 20    |       |
|                                            |                                           |                                                                                                        | D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> , D <sub>3</sub>                                       |                                | 40    |       |
|                                            |                                           |                                                                                                        | I <sub>0</sub> , I <sub>1</sub> , I <sub>2</sub> ; I <sub>6</sub> , I <sub>8</sub>                      |                                | 20    |       |
|                                            |                                           |                                                                                                        | I <sub>3</sub> , I <sub>4</sub> , I <sub>5</sub> , I <sub>7</sub>                                       |                                | 40    |       |
|                                            |                                           |                                                                                                        | RAM <sub>0, 3, Q<sub>0, 3</sub></sub> (Note 4)                                                          |                                | 100   |       |
|                                            |                                           |                                                                                                        | C <sub>n</sub>                                                                                          |                                | 200   |       |
| <b>I<sub>I</sub></b>                       | Input HIGH Current                        | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 5.5V                                                         |                                                                                                         |                                | 1.0   |       |
| <b>I<sub>OZH</sub><br/>I<sub>OZL</sub></b> | Off State (High Impedance) Output Current | V <sub>CC</sub> = MAX.                                                                                 | Y <sub>0</sub> , Y <sub>1</sub> , Y <sub>2</sub> , Y <sub>3</sub>                                       | V <sub>O</sub> = 2.4V          | 50    |       |
|                                            |                                           |                                                                                                        |                                                                                                         | V <sub>O</sub> = 0.5V          | -50   |       |
|                                            |                                           |                                                                                                        | RAM <sub>0, 3, Q<sub>0, 3</sub></sub>                                                                   | V <sub>O</sub> = 2.4V (Note 4) | 100   |       |
|                                            |                                           |                                                                                                        |                                                                                                         | V <sub>O</sub> = 0.5V (Note 4) | -800  |       |
|                                            |                                           |                                                                                                        |                                                                                                         |                                |       |       |
| <b>I<sub>OS</sub></b>                      | Output Short Circuit Current (Note 3)     | V <sub>CC</sub> = 5.75V<br>V <sub>O</sub> = 0.5V                                                       | Y <sub>0</sub> , Y <sub>1</sub> , Y <sub>2</sub> , Y <sub>3</sub> , $\bar{G}$                           | -15                            | -40   |       |
|                                            |                                           |                                                                                                        | C <sub>n+4</sub>                                                                                        | -15                            | -40   |       |
|                                            |                                           |                                                                                                        | OVR, $\bar{P}$                                                                                          | -15                            | -40   |       |
|                                            |                                           |                                                                                                        | F <sub>3</sub>                                                                                          | -15                            | -40   |       |
|                                            |                                           |                                                                                                        | RAM <sub>0, 3, Q<sub>0, 3</sub></sub>                                                                   | -15                            | -40   |       |
| <b>I<sub>CC</sub></b>                      | Power Supply Current                      | V <sub>CC</sub> = MAX.                                                                                 | Military                                                                                                |                                | 185   | 280   |
|                                            |                                           |                                                                                                        | Commercial                                                                                              |                                | 185   | 280   |
|                                            |                                           |                                                                                                        |                                                                                                         |                                |       | mA    |

Notes: 1. For conditions shown as MIN. or MAX., use the appropriate value specified under Electrical Characteristics for the applicable device type.

2. Typical limits are at V<sub>CC</sub> = 5.0V, 25°C ambient and maximum loading.

3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

4. These are three-state outputs internally connected to TTL inputs. Input characteristics are measured with I<sub>678</sub> in a state such that the three-state output is OFF.

**Am2901****GUARANTEED OPERATING CONDITIONS  
OVER TEMPERATURE AND VOLTAGE**

Tables I, II, and III below define the timing requirements of the Am2901 in a system. The Am2901 is guaranteed to function correctly over the operating range when used within the delay and set-up time constraints of these tables for the appropriate device type. The tables are divided into three types of parameters; clock characteristics, combinational delays from inputs to outputs, and set-up and hold time requirements. The latter table defines the time prior to the end of the cycle (i.e., clock LOW-to-HIGH transition) that each input must be stable to guarantee that the correct data is written into one of the internal registers.

The performance of the Am2901 within the limits of these tables is guaranteed by the testing defined as "Group A, Subgroup 9" Electrical Testing. For a copy of the tests and limits used for subgroup 9, contact Advanced Micro Devices' Product Marketing.

TABLE I

**CYCLE TIME AND CLOCK CHARACTERISTICS**

| TIME                                                                                     | Am2901DC,PC | Am2901DM,FM |
|------------------------------------------------------------------------------------------|-------------|-------------|
| Read-Modify-Write Cycle<br>(time from selection of<br>A, B registers to end of<br>cycle) | 105ns       | 120ns       |
| Maximum Clock Frequency to<br>Shift Q Register (50% duty<br>cycle)                       | 9.5MHz      | 8.3MHz      |
| Minimum Clock LOW Time                                                                   | 30ns        | 30ns        |
| Minimum Clock HIGH Time                                                                  | 30ns        | 30ns        |
| Minimum Clock Period                                                                     | 105ns       | 120ns       |

TABLE II

**MAXIMUM COMBINATIONAL PROPAGATION DELAYS (all in ns,  $C_L \leq 15\text{pF}$ )**

| From<br>Input                | Am2901DC, PC ( $0^\circ\text{C}$ to $+70^\circ\text{C}$ ; $5\text{V} \pm 5\%$ ) |                |                  |                    |                       |     |                                      |                                  | Am2901DM, FM ( $-55^\circ\text{C}$ to $+125^\circ\text{C}$ ; $5\text{V} \pm 10\%$ ) |                |                  |                    |                       |     |                                      |                                  |    |
|------------------------------|---------------------------------------------------------------------------------|----------------|------------------|--------------------|-----------------------|-----|--------------------------------------|----------------------------------|-------------------------------------------------------------------------------------|----------------|------------------|--------------------|-----------------------|-----|--------------------------------------|----------------------------------|----|
|                              | Y                                                                               | F <sub>3</sub> | C <sub>n+4</sub> | $\bar{G}, \bar{P}$ | F=0<br>$R_L =$<br>470 | OVR | Shift<br>Outputs                     |                                  | Y                                                                                   | F <sub>3</sub> | C <sub>n+4</sub> | $\bar{G}, \bar{P}$ | F=0<br>$R_L =$<br>470 | OVR | Shift<br>Outputs                     |                                  |    |
|                              |                                                                                 |                |                  |                    |                       |     | RAM <sub>0</sub><br>RAM <sub>3</sub> | Q <sub>0</sub><br>Q <sub>3</sub> |                                                                                     |                |                  |                    |                       |     | RAM <sub>0</sub><br>RAM <sub>3</sub> | Q <sub>0</sub><br>Q <sub>3</sub> |    |
| A, B                         | 110                                                                             | 85             | 80               | 80                 | 110                   | 75  | 110                                  | —                                | 120                                                                                 | 95             | 90               | 90                 | 120                   | 85  | 120                                  | —                                |    |
| D (arithmetic mode)          | 100                                                                             | 70             | 70               | 70                 | 100                   | 60  | 95                                   | —                                | 110                                                                                 | 80             | 75               | 75                 | 110                   | 65  | 105                                  | —                                |    |
| D (I = X37) (Note 5)         | 60                                                                              | 50             | —                | —                  | 60                    | —   | 60                                   | —                                | 65                                                                                  | 55             | —                | —                  | 65                    | —   | 65                                   | —                                |    |
| C <sub>n</sub>               | 55                                                                              | 35             | 30               | —                  | 50                    | 40  | 55                                   | —                                | 60                                                                                  | 40             | 30               | —                  | 55                    | 45  | 60                                   | —                                |    |
| I <sub>012</sub>             | 85                                                                              | 65             | 65               | 65                 | 80                    | 65  | 80                                   | —                                | 90                                                                                  | 70             | 70               | 70                 | 85                    | 70  | 85                                   | —                                |    |
| I <sub>345</sub>             | 70                                                                              | 55             | 60               | 60                 | 70                    | 60  | 65                                   | —                                | 75                                                                                  | 60             | 65               | 65                 | 75                    | 65  | 70                                   | —                                |    |
| I <sub>678</sub>             | 55                                                                              | —              | —                | —                  | —                     | —   | 45                                   | 45                               | 60                                                                                  | —              | —                | —                  | —                     | —   | 50                                   | 50                               |    |
| OE Enable/Disable            | 40/25                                                                           | —              | —                | —                  | —                     | —   | —                                    | —                                | 40/25                                                                               | —              | —                | —                  | —                     | —   | —                                    | —                                |    |
| A bypassing<br>ALU (I = 2xx) | 60                                                                              | —              | —                | —                  | —                     | —   | —                                    | —                                | 65                                                                                  | —              | —                | —                  | —                     | —   | —                                    | —                                |    |
| Clock                        | (Note 6)                                                                        | 115            | 85               | 100                | 100                   | 110 | 95                                   | 105                              | 60                                                                                  | 125            | 95               | 110                | 110                   | 120 | 105                                  | 115                              | 65 |

**SET-UP AND HOLD TIMES (all in ns) (Note 1)**

TABLE III

| From Input                            | Notes        | Am2901DC, PC ( $0^\circ\text{C}$ to $+70^\circ\text{C}$ , $5\text{V} \pm 5\%$ ) |   |           |                | Am2901DM, FM ( $-55^\circ\text{C}$ to $+125^\circ\text{C}$ , $5\text{V} \pm 10\%$ ) |   |           |   |
|---------------------------------------|--------------|---------------------------------------------------------------------------------|---|-----------|----------------|-------------------------------------------------------------------------------------|---|-----------|---|
|                                       |              | Set-Up Time                                                                     |   | Hold Time |                | Set-Up Time                                                                         |   | Hold Time |   |
| A, B<br>Source                        | 2, 4<br>3, 5 | 105<br>$t_{pwL} + 30$                                                           | — | 0         | —              | 120<br>$t_{pwL} + 30$                                                               | — | 0         | — |
| B Dest.                               | 2, 4         | $t_{pwL} + 15$                                                                  | — | 0         | $t_{pwL} + 15$ | —                                                                                   | 0 | —         | — |
| D (arithmetic mode)                   |              | 100                                                                             | — | 0         | 110            | —                                                                                   | 0 | —         | — |
| D (I = X37) (Note 5)                  |              | 60                                                                              | — | 0         | 65             | —                                                                                   | 0 | —         | — |
| C <sub>n</sub>                        |              | 55                                                                              | — | 0         | 60             | —                                                                                   | 0 | —         | — |
| I <sub>012</sub>                      |              | 85                                                                              | — | 0         | 90             | —                                                                                   | 0 | —         | — |
| I <sub>345</sub>                      |              | 70                                                                              | — | 0         | 75             | —                                                                                   | 0 | —         | — |
| I <sub>678</sub>                      | 4            | $t_{pwL} + 15$                                                                  | — | 0         | $t_{pwL} + 15$ | —                                                                                   | 0 | —         | — |
| RAM <sub>0, 3, Q<sub>0, 3</sub></sub> |              | 30                                                                              | — | 0         | 30             | —                                                                                   | 0 | —         | — |

- Notes: 1. See Figure 11 and 12.  
 2. If the B address is used as a source operand, allow for the "A, B source" set-up time; if it is used only for the destination address, use the "B dest." set-up time.  
 3. Where two numbers are shown, both must be met.  
 4. " $t_{pwL}$ " is the clock LOW time.  
 5. DVO is the fastest way to load the RAM from the D inputs. This function is obtained with I = 337.  
 6. Using Q register as source operand in arithmetic mode. Clock is not normally in critical speed path when Q is not a source.

## Am2902

### SET-UP AND HOLD TIMES (minimum cycles from each input)

Set-up and hold times are defined relative to the clock LOW-to-HIGH edge. Inputs must be steady at all times from the set-up

time prior to the clock until the hold time after the clock. The set-up times allow sufficient time to perform the correct operation on the correct data so that the correct ALU data can be written into one of the registers.



Figure 11. Minimum Cycle Times from Inputs. Numbers Shown are Minimum Data Stable Times for Am2901DC, in ns. See Table III for Detailed Information.



- Notes:
1. This delay is the max.  $t_{pd}$  of the register containing A, B, D, and I. For the Am2918, use 13ns.
  2. 10ns for look-ahead carry. For ripple carry over 16 bits use  $2 \times (C_n \rightarrow C_{n+4})$ , or 60ns.
  3. This is the delay associated with the multiplexer between the shift outputs and shift inputs on the Am2901s. See Figure 19.
  4. Not applicable for logic operations.
  5. Clock rising edge may occur here if add and shift do not occur on same cycle.

Figure 12. Switching Waveforms for 16-Bit System Assuming A, B, D and I are all Driven from Registers with the same Propagation Delay, Clocked by the Am2901 Clock.

**MAXIMUM RATINGS** (Above which the useful life may be impaired)

|                                                     |                                |  |  |
|-----------------------------------------------------|--------------------------------|--|--|
| Storage Temperature                                 | -65°C to +150°C                |  |  |
| Temperature (Ambient) Under Bias                    | -55°C to +125°C                |  |  |
| Supply Voltage to Ground Potential                  | -0.5V to +7.0V                 |  |  |
| DC Voltage Applied to Outputs for HIGH Output State | -0.5V to +V <sub>CC</sub> max. |  |  |
| DC Input Voltage                                    | -0.5V to +5.5V                 |  |  |
| DC Output Current, Into Outputs                     | 30 mA                          |  |  |
| DC Input Current                                    | -30 mA to +5.0 mA              |  |  |

**ELECTRICAL CHARACTERISTICS OVER OPERATING TEMPERATURE RANGE** (Unless Otherwise Noted)

| Parameters                  | Description                      | Test Conditions (Note 1)                                                                                 | Min.                              | Typ. | (Note 2) | Max. | Units |
|-----------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------|------|----------|------|-------|
| V <sub>OH</sub>             | Output HIGH Voltage              | V <sub>CC</sub> = MIN., I <sub>OH</sub> = -0.8mA<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | 2.4                               | 3.0  |          |      | Volts |
| V <sub>OL</sub>             | Output LOW Voltage               | V <sub>CC</sub> = MIN., I <sub>OL</sub> = 16mA<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub>   |                                   | 0.2  | 0.4      |      | Volts |
| V <sub>IH</sub>             | Input HIGH Level                 | Guaranteed input logical HIGH voltage for all inputs                                                     | 2.0                               |      |          |      | Volts |
| V <sub>IL</sub>             | Input LOW Level                  | Guaranteed input logical LOW voltage for all inputs                                                      |                                   |      | 0.8      |      | Volts |
| V <sub>I</sub>              | Input Clamp Voltage              | V <sub>CC</sub> = MIN., I <sub>IN</sub> = -12mA                                                          |                                   |      | -1.5     |      | Volts |
| I <sub>IL</sub><br>(Note 3) | Input LOW Current                | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 0.4V                                                           | C <sub>n</sub>                    |      | -3.2     | mA   |       |
|                             |                                  |                                                                                                          | $\bar{P}_3$                       |      | -4.8     |      |       |
|                             |                                  |                                                                                                          | $\bar{P}_2$                       |      | -6.4     |      |       |
|                             |                                  |                                                                                                          | $\bar{P}_0, \bar{P}_1, \bar{G}_3$ |      | -8.0     |      |       |
|                             |                                  |                                                                                                          | $\bar{G}_0, \bar{G}_2$            |      | -14.4    |      |       |
|                             |                                  |                                                                                                          | $\bar{G}_1$                       |      | -16      |      |       |
| I <sub>IH</sub><br>(Note 3) | Input HIGH Current               | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 2.4V                                                           | C <sub>n</sub>                    |      | 80       | μA   |       |
|                             |                                  |                                                                                                          | $\bar{P}_3$                       |      | 120      |      |       |
|                             |                                  |                                                                                                          | $\bar{P}_2$                       |      | 160      |      |       |
|                             |                                  |                                                                                                          | $\bar{P}_0, \bar{P}_1, \bar{G}_3$ |      | 200      |      |       |
|                             |                                  |                                                                                                          | $\bar{G}_0, \bar{G}_2$            |      | 360      |      |       |
|                             |                                  |                                                                                                          | $\bar{G}_1$                       |      | 400      |      |       |
| I <sub>I</sub>              | Input HIGH Current               | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 5.5V                                                           |                                   |      | 1.0      |      | mA    |
| I <sub>SC</sub>             | Output Short Circuit<br>(Note 4) | V <sub>CC</sub> = MAX., V <sub>OUT</sub> = 0.0V                                                          |                                   | -40  |          | -100 | mA    |
| I <sub>CC</sub>             | Power Supply Current             | V <sub>CC</sub> = MAX.<br>All Outputs LOW                                                                | MIL                               |      | 62       | 99   | mA    |
|                             |                                  |                                                                                                          | COM'L                             |      | 58       | 94   |       |
|                             |                                  | V <sub>CC</sub> = MAX.<br>All Outputs HIGH                                                               | MIL                               |      | 37       |      | mA    |
|                             |                                  |                                                                                                          | COM'L                             |      | 35       |      |       |

Notes: 1. For conditions shown as MIN. or MAX., use the appropriate value specified under Electrical Characteristics for the applicable device type.

2. Typical limits are at V<sub>CC</sub> = 5.0V, 25°C ambient and maximum loading.

3. Actual input currents = Unit Load Current X Input Load Factor (see Loading Rules).

4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

**SWITCHING CHARACTERISTICS** V<sub>CC</sub> = 5.0V, T<sub>A</sub> = 25°C, C<sub>L</sub> = 15pF, R<sub>L</sub> = 400Ω

| Parameter        | From (Input)   | To (Output)            | Test Figure | Test Conditions                                                                                        | Min | Typ | Max | Units |
|------------------|----------------|------------------------|-------------|--------------------------------------------------------------------------------------------------------|-----|-----|-----|-------|
| t <sub>PLH</sub> | C <sub>n</sub> | C <sub>n+j</sub>       | 2           | $\bar{P}_0 = \bar{P}_1 = \bar{P}_2 = 0\text{ V}$<br>$\bar{G}_0 = \bar{G}_1 = \bar{G}_2 = 4.5\text{ V}$ | 11  | 14  |     | ns    |
| t <sub>PHL</sub> |                |                        |             |                                                                                                        | 11  | 14  |     |       |
| t <sub>PLH</sub> | $\bar{P}_i$    | C <sub>n+j</sub>       | 3           | $\bar{P}_i = 0\text{ V } (i > l)$<br>$C_n = \bar{G}_0 = \bar{G}_1 = \bar{G}_2 = 4.5\text{ V}$          | 6.0 | 8.0 |     | ns    |
| t <sub>PHL</sub> |                |                        |             |                                                                                                        | 6.0 | 8.0 |     |       |
| t <sub>PLH</sub> | $\bar{G}_i$    | C <sub>n+j</sub>       | 3           | $\bar{G}_i = 0\text{ V } (i > l)$<br>$C_n = \bar{P}_0 = \bar{P}_1 = \bar{P}_2 = 4.5\text{ V}$          | 8.0 | 10  |     | ns    |
| t <sub>PHL</sub> |                |                        |             |                                                                                                        | 8.0 | 10  |     |       |
| t <sub>PLH</sub> | $\bar{P}_i$    | $\bar{G}$ or $\bar{P}$ | 2           | $\bar{P}_i = 0\text{ V } (i > l)$<br>$C_n = \bar{G}_0 = \bar{G}_1 = \bar{G}_2 = 4.5\text{ V}$          | 11  | 14  |     | ns    |
| t <sub>PHL</sub> |                |                        |             |                                                                                                        | 11  | 14  |     |       |
| t <sub>PLH</sub> | $\bar{G}_i$    | $\bar{G}$ or $\bar{P}$ | 2           | $\bar{G}_i = 0\text{ V } (i > l)$<br>$C_n = \bar{P}_0 = \bar{P}_1 = \bar{P}_2 = 4.5\text{ V}$          | 12  | 14  |     | ns    |
| t <sub>PHL</sub> |                |                        |             |                                                                                                        | 12  | 14  |     |       |

# Am2909/11

## MAXIMUM RATINGS (Above which the useful life may be impaired)

|                                                     |                                 |
|-----------------------------------------------------|---------------------------------|
| Storage Temperature                                 | -65°C to +150°C                 |
| Temperature (Ambient) Under Bias                    | -55°C to +125°C                 |
| Supply Voltage to Ground Potential                  | -0.5 V to +7.0 V                |
| DC Voltage Applied to Outputs for HIGH Output State | -0.5 V to +V <sub>CC</sub> max. |
| DC Input Voltage                                    | -0.5 V to +7.0 V                |
| DC Output Current, Into Outputs                     | 30 mA                           |
| DC Input Current                                    | -30 mA to +5.0 mA               |

## OPERATING RANGE

| P/N               | Ambient Temperature | V <sub>CC</sub>  |
|-------------------|---------------------|------------------|
| Am2909/2911DC, PC | 0°C to +70°C        | 4.75 V to 5.25 V |
| Am2909/2911DM, FM | -55°C to +125°C     | 4.50 V to 5.50 V |

## STANDARD SCREENING

(Conforms to MIL-STD-883 for Class C Parts)

| Step                                               | MIL-STD-883 Method | Conditions                                       | Level               |                     |
|----------------------------------------------------|--------------------|--------------------------------------------------|---------------------|---------------------|
|                                                    |                    |                                                  | Am2909/Am2911PC, DC | Am2909/Am2911DM, FM |
| Pre-Seal Visual Inspection                         | 2010               | B                                                | 100%                | 100%                |
| Stabilization Bake                                 | 1008               | C<br>150°C<br>24-hour                            | 100%                | 100%                |
| Temperature Cycle                                  | 1010               | C<br>-65°C to +150°C<br>10 cycles                | 100%                | 100%                |
| Centrifuge                                         | 2001               | B<br>10,000 G                                    | 100% *              | 100%                |
| Fine Leak                                          | 1014               | A<br>5 x 10 <sup>-8</sup> atm-cc/cm <sup>3</sup> | 100% *              | 100%                |
| Gross Leak                                         | 1014               | C2 Fluorocarbon                                  | 100% *              | 100%                |
| Electrical Test<br>Subgroups 1 and 7               | 5004               | See below for definitions of subgroups           | 100%                | 100%                |
| Insert Additional Screening here for Class B Parts |                    |                                                  |                     |                     |
| Group A Sample Tests                               |                    |                                                  |                     |                     |
| Subgroup 1                                         |                    |                                                  | LTPD = 5            | LTPD = 5            |
| Subgroup 2                                         |                    |                                                  | LTPD = 7            | LTPD = 7            |
| Subgroup 3                                         |                    |                                                  | LTPD = 7            | LTPD = 7            |
| Subgroup 7                                         |                    |                                                  | LTPD = 7            | LTPD = 7            |
| Subgroup 8                                         |                    |                                                  | LTPD = 7            | LTPD = 7            |
| Subgroup 9                                         |                    |                                                  | LTPD = 7            | LTPD = 7            |

\* Not applicable for Am2909PC or Am2911PC.

## ADDITIONAL SCREENING FOR CLASS B PARTS

| Step            | MIL-STD-883 Method | Conditions                   | Level                 |  |
|-----------------|--------------------|------------------------------|-----------------------|--|
|                 |                    |                              | Am2909/Am2911DMB, FMB |  |
| Burn-In         | 1015               | D<br>125°C<br>160 hours min. | 100%                  |  |
| Electrical Test | 5004               |                              | 100%                  |  |
| Subgroup 1      |                    |                              | 100%                  |  |
| Subgroup 2      |                    |                              | 100%                  |  |
| Subgroup 3      |                    |                              | 100%                  |  |
| Subgroup 7      |                    |                              | 100%                  |  |
| Subgroup 9      |                    |                              | 100%                  |  |

Return to Group A Tests in Standard Screening

## ORDERING INFORMATION

| Package Type      | Temperature Range | Am2909 Order Number | Am2911 Order Number |
|-------------------|-------------------|---------------------|---------------------|
| Molded DIP        | 0°C to +70°C      | AM2909PC            | AM2911PC            |
| Hermetic DIP      | 0°C to +70°C      | AM2909DC            | AM2911DC            |
| Hermetic DIP      | -55°C to +125°C   | AM2909DM            | AM2911DM            |
| Hermetic Flat Pak | -55°C to +125°C   | Am2909FM            | —                   |
| Dice              | 0°C to +70°C      | Am2909XC            | —                   |

## GROUP A SUBGROUPS

(as defined in MIL-STD-883, method 5005)

| Subgroup | Parameter | Temperature                           |
|----------|-----------|---------------------------------------|
| 1        | DC        | 25°C                                  |
| 2        | DC        | Maximum rated temperature             |
| 3        | DC        | Minimum rated temperature             |
| 7        | Function  | 25°C                                  |
| 8        | Function  | Maximum and minimum rated temperature |
| 9        | Switching | 25°C                                  |
| 10       | Switching | Maximum Rated Temperature             |
| 11       | Switching | Minimum Rated Temperature             |

## Am2909/11

## ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted)

| Parameters       | Description                           | Test Conditions (Note 1)                                                     |                           |                                    | Min. | Typ. (Note 2) | Max. | Units   |
|------------------|---------------------------------------|------------------------------------------------------------------------------|---------------------------|------------------------------------|------|---------------|------|---------|
|                  |                                       | V <sub>CC</sub> = MIN., V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | MIL                       | I <sub>OH</sub> = -1.0mA           |      |               |      |         |
| V <sub>OH</sub>  | Output HIGH Voltage                   | V <sub>CC</sub> = MIN., V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | COM'L                     | I <sub>OH</sub> = -2.6mA           | 2.4  |               |      | Volts   |
| V <sub>OL</sub>  | Output LOW Voltage                    |                                                                              |                           | I <sub>OL</sub> = 4.0mA            |      | 0.4           |      | Volts   |
|                  |                                       |                                                                              |                           | I <sub>OL</sub> = 8.0mA            |      | 0.45          |      |         |
|                  |                                       |                                                                              |                           | I <sub>OL</sub> = 12mA<br>(Note 5) |      |               | 0.5  |         |
| V <sub>IH</sub>  | Input HIGH Level                      | Guaranteed input logical HIGH voltage for all inputs                         |                           |                                    | 2.0  |               |      | Volts   |
| V <sub>IL</sub>  | Input LOW Level                       | Guaranteed input logical LOW voltage for all inputs                          |                           | MIL                                |      | 0.7           |      | Volts   |
|                  |                                       |                                                                              |                           | COM'L                              |      | 0.8           |      |         |
| V <sub>I</sub>   | Input Clamp Voltage                   | V <sub>CC</sub> = MIN., I <sub>IN</sub> = -18mA                              |                           |                                    |      | -1.5          |      | Volts   |
| I <sub>IL</sub>  | Input LOW Current                     | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 0.4V                               | C <sub>n</sub>            |                                    |      | -1.08         |      | mA      |
|                  |                                       |                                                                              | Push/Pop, $\overline{OE}$ |                                    |      | -0.72         |      |         |
|                  |                                       |                                                                              | Others (Note 6)           |                                    |      | -0.36         |      |         |
| I <sub>IH</sub>  | Input HIGH Current                    | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 2.7V                               | C <sub>n</sub>            |                                    | 40   |               |      | $\mu$ A |
|                  |                                       |                                                                              | Push/Pop                  |                                    |      | 40            |      |         |
|                  |                                       |                                                                              | Others (Note 6)           |                                    |      | 20            |      |         |
| I <sub>I</sub>   | Input HIGH Current                    | V <sub>CC</sub> = MAX., V <sub>IN</sub> = 7.0V                               | C <sub>n</sub> , Push/Pop |                                    |      | 0.2           |      | mA      |
|                  |                                       |                                                                              | Others (Note 6)           |                                    |      | 0.1           |      |         |
| I <sub>OS</sub>  | Output Short Circuit Current (Note 3) | V <sub>CC</sub> = MAX.                                                       |                           |                                    | -40  |               | -100 | mA      |
| I <sub>CC</sub>  | Power Supply Current                  | V <sub>CC</sub> = MAX. (Note 4)                                              |                           |                                    |      | 80            | 130  | mA      |
| I <sub>OZL</sub> | Output OFF Current                    | V <sub>CC</sub> = MAX., $\overline{OE}$ = 2.7V                               | V <sub>OUT</sub> = 0.4V   |                                    |      | -20           |      | $\mu$ A |
| I <sub>OZH</sub> |                                       |                                                                              | V <sub>OUT</sub> = 2.7V   |                                    |      | 20            |      |         |

Notes: 1. For conditions shown as MIN. or MAX., use the appropriate value specified under Electrical Characteristics for the applicable device type.

2. Typical limits are at V<sub>CC</sub> = 5.0V, 25°C ambient and maximum loading.

3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

4. Apply GND to C<sub>n</sub>, R<sub>0</sub>, R<sub>1</sub>, R<sub>2</sub>, R<sub>3</sub>, OR<sub>0</sub>, OR<sub>1</sub>, OR<sub>2</sub>, OR<sub>3</sub>, D<sub>0</sub>, D<sub>1</sub>, D<sub>2</sub>, and D<sub>3</sub>. Other inputs open. All outputs open. Measured after a LOW-to-HIGH clock transition.

5. The 12mA guarantee applies only to Y<sub>0</sub>, Y<sub>1</sub>, Y<sub>2</sub> and Y<sub>3</sub>.

6. For the Am2911, D<sub>j</sub> and R<sub>j</sub> are internally connected. Loading is doubled (to same values as Push/Pop).

## SWITCHING CHARACTERISTICS OVER OPERATING RANGE

All parameters are guaranteed worst case over the operating voltage and temperature range for the device type.  
(Grade C = 0°C to +70°C, 4.75V to 5.25V; Grade M = -55°C to +125°C, 4.5V to 5.5V)

TABLE I  
MINIMUM CLOCK REQUIREMENTS

|                         |    |
|-------------------------|----|
| Minimum Clock LOW Time  | 50 |
| Minimum Clock HIGH Time | 30 |

TABLE II  
MAXIMUM COMBINATORIAL  
PROPAGATION DELAYS

| OUTPUTS<br>INPUTS | $Y_i$ | $C_{n+4}$ |
|-------------------|-------|-----------|
| $\overline{OE}$   | 25    | —         |
| $\overline{ZERO}$ | 35    | 45        |
| $OR_i$            | 20    | 32        |
| $S_0, S_1$        | 40    | 50        |
| $D_i$             | 20    | 32        |
| $C_n$             | —     | 18        |

TABLE III  
MAXIMUM DELAYS  
FROM CLOCK TO OUTPUTS

| FUNCTIONAL PATH                             | GRADE | CLOCK TO $Y_i$ | CLOCK TO $C_{n+4}$ |
|---------------------------------------------|-------|----------------|--------------------|
| Register<br>( $S_1 S_0 = LH$ )              | C     | 48             | 58                 |
|                                             | M     | 55             | 65                 |
| $\mu$ Program Counter<br>( $S_1 S_0 = LL$ ) | C     | 48             | 58                 |
|                                             | M     | 55             | 65                 |
| File<br>( $S_1 S_0 = HL$ )                  | C     | 70             | 80                 |
|                                             | M     | 80             | 90                 |

$R_L = 2.0\text{k}\Omega \quad C_L = 15\text{pF}$

TABLE IV  
SET-UP AND HOLD TIME  
REQUIREMENTS

| EXTERNAL INPUTS   | $t_s$ | $t_h$ |
|-------------------|-------|-------|
| $\overline{RE}$   | 20    | 5.0   |
| $R_i$             | 15    | 0     |
| PUSH/POP          | 20    | 5.0   |
| $\overline{FE}$   | 20    | 0     |
| $C_n$             | 15    | 0     |
| $D_i$             | 20    | 0     |
| $OR_i$            | 20    | 0     |
| $S_0, S_1$        | 40    | 0     |
| $\overline{ZERO}$ | 40    | 0     |



Figure 12. Switching Waveforms. See Tables for Specific Values.

# Chapter 23

## THE MC10800 SERIES CHIP SLICE LOGIC

The MC10800 chip slice logic devices manufactured by Motorola Semiconductor represent the most recently introduced chip slice logic products.

**Figure 23-1 illustrates the devices which constitute the MC10800 device set and the way in which they connect in order to generate a central processing unit.**

**The MC10800 ALU represents a 4-bit slice through an Arithmetic and Logic Unit.** In contrast to the 2901 and 6701, the MC10800 does not include read/write memory for registers. You create a register file with external memory; that allows you to design central processing units with a substantial number of programmable registers. Combining the register file and the MC10800 ALU chip slice, you have logic equivalent to an ALU chip slice as described in Volume I, Chapter 4.

**The microprogram which drives the entire system will be stored in a control memory which is sequenced by the MC10801 Microprogram Control Unit.** Each MC10801 provides a 4-bit slice of the total control memory sequencing logic. Conceptually the MC10801 does not differ from the description given in Volume I, Chapter 4; however, in implementation it does. The MC10801 Microprogram Control Unit has 16 instruction codes which allow you to sequence microinstructions within control memory using branch-on-condition, subroutine and interrupt logic. There is no limit to the manner in which you create microinstruction execution sequence logic; sequences may depend on status conditions created within, or beyond the ALU; moreover, external interrupts may directly influence microinstruction sequences.



Figure 23-1. MC10800 Series Devices in a Central Processing Unit Configuration

**The MC10803 Memory Interface device performs all of the memory addressing operations required to address program and data memory.** This device contains its own small arithmetic and logic unit, so that computations needed by indexed addressing or any other addressing scheme do not use the ALU logic — and can therefore proceed in parallel. The MC10803 is also a 4-bit slice product which can be cascaded to any word size; it has sufficient capabilities to handle all common memory addressing schemes, ranging from the simplest microcomputer to the

largest mainframe computer. Using a 2901 or 6701 ALU slice product, you must perform memory addressing operations using ALU logic and the 16 RAM locations provided within the ALU slice itself.

**The MC10802 timing device can, under program control, create four timing signals**, with any required signal interactions or interdependences. This is not a chip slice part, but if four timing signals are insufficient, additional MC10802 devices will be needed to create additional timing signals.

If you look at Figure 23-1, you will see that the various devices described cover a substantial portion of the logic within any central processing unit. This is in marked contrast to 2900 series or 6700 series devices which leave undefined a great deal of memory interface logic, timing logic and control memory - ALU interface logic.

**We will now look at each of the MC10800 series devices in overview. These overviews will summarize the capabilities of devices; however, refer to manufacturer's literature for detailed information.**

**MC10800 series devices are manufactured by:**

MOTOROLA SEMICONDUCTOR  
Box 20912  
Phoenix, Arizona 85036

At the present time there is no second source.

All devices are manufactured using Emitter Coupled Logic. Devices are fabricated using unique Quad Inline Packages, which provide two sets of parallel pins on each side of the package. This configuration will require special modifications to existing PC cards; however, it results in very compact packaging.



Figure 23-2. The MC10800 ALU Slice Functional Diagram

## THE MC10800 ARITHMETIC AND LOGIC UNIT SLICE

**Figure 23-2 illustrates the data flows and logic functions of the MC10800 ALU slice.**

The Arithmetic and Logic Unit block is similar to logic with the same name, as described for the 2901/6701 — or the general case ALU logic, as described in Volume I, Chapter 4.

Functions which the Arithmetic and Logic Unit can perform include:

- Binary and BCD addition and subtraction
- Boolean operations, AND, OR and Exclusive-OR
- Status signals generated by the Arithmetic and Logic Unit are comprehensive and adequate. PG and GG are standard carry look ahead signals. OF is an Overflow status. Carry In (CIN) and Carry Out (COUT) allow arithmetic operations to be performed by a number of cascaded ALU slices. Notice that there is a Parity status.
- ALU logic automatically creates statuses appropriate for BCD or binary arithmetic.

Table 23-1. MC10800 ALU Logical Operations

| Y MUX |     | X MUX |     | INVERT | ACC     | FUNCTION                           |
|-------|-----|-------|-----|--------|---------|------------------------------------|
| AS0   | AS1 | AS2   | AS3 | AS10   | AS5 AS6 |                                    |
| 0     | 1   | 0     | 1   | 1      | 0       | LOGIC 0                            |
| 0     | 0   | 1     | 0   | 1      | 0       | A                                  |
| 0     | 0   | 0     | 1   | 1      | 0       | 0                                  |
| 0     | 0   | 1     | 0   | 0      | 0       | $\bar{A}$                          |
| 0     | 0   | 0     | 1   | 0      | 0       | $\overline{A}$                     |
| 0     | 0   | 1     | 1   | 1      | 0       | AV0                                |
| 0     | 1   | 0     | 0   | 0      | 0       | $\overline{AV0}$                   |
| 1     | 0   | 0     | 0   | 0      | 0       | $\overline{AV0}$                   |
| 0     | 0   | 0     | 0   | 1      | 0       | $A \wedge 0$                       |
| 0     | 1   | 1     | 1   | 1      | 0       | $A \wedge \overline{0}$            |
| 0     | 1   | 0     | 0   | 1      | 0       | $\overline{A} \wedge 0$            |
| 0     | 1   | 1     | 0   | 1      | 0       | $\overline{A} \wedge \overline{0}$ |
| 0     | 1   | 1     | 0   | 0      | 0       | $\overline{A} \vee 0$              |
| 0     | 0   | 0     | 0   | 0      | 0       | $\overline{A} \wedge 0$            |
| 0     | 0   | 1     | 1   | 0      | 0       | AV0                                |
| 0     | 1   | 0     | 1   | 0      | 0       | LOGIC 1                            |
| 1     | 0   | 1     | 0   | 1      | 1       | $ACC \wedge \overline{A}$          |
| 0     | 1   | 0     | 1   | 1      | 1       | $ACC \wedge \overline{0}$          |
| 1     | 0   | 1     | 0   | 0      | 1       | $ACC \vee A$                       |
| 0     | 1   | 0     | 1   | 0      | 1       | $ACC \vee 0$                       |
| 0     | 0   | 1     | 0   | 1      | 1       | $ACC \vee \overline{A}$            |
| 0     | 0   | 0     | 1   | 1      | 1       | $ACC \vee \overline{0}$            |
| 0     | 0   | 0     | 1   | 0      | 1       | $ACC \vee A \wedge 0$              |
| 0     | 0   | 0     | 0   | 1      | 1       | $ACC \vee A \wedge \overline{0}$   |
| 0     | 0   | 1     | 1   | 1      | 1       | $ACC \vee AV0$                     |
| 0     | 0   | 1     | 1   | 0      | 1       | $ACC \vee AVO$                     |



Table 23-2. MC10800 Arithmetic Operations

| Y MUX |     | X MUX |     | $\pm 2$ | COMP. | ACC                     | BINARY FUNCTION<br>(PLUS C <sub>N</sub> ) | BCD FUNCTION<br>(PLUS C <sub>N</sub> ) |
|-------|-----|-------|-----|---------|-------|-------------------------|-------------------------------------------|----------------------------------------|
| AS0   | AS1 | AS2   | AS3 | AS4     | AS10  | <u>AS5</u> / <u>AS6</u> | AS11=1                                    | AS11=0                                 |
| 1     | 0   | 0     | 1   | 1       | 1     | 0                       | A PLUS O                                  | A PLUS O                               |
| 1     | 0   | 0     | 1   | 1       | 0     | 0                       | A PLUS O                                  | A PLUS 9s COMP. O                      |
| 0     | 1   | 1     | 0   | 1       | 0     | 0                       | O PLUS A                                  | O PLUS 9s COMP. A                      |
| 0     | 0   | 1     | 0   | 1       | 1     | 0                       | A                                         | A                                      |
| 0     | 0   | 0     | 1   | 1       | 1     | 0                       | O                                         | O                                      |
| 0     | 0   | 1     | 0   | 1       | 0     | 0                       | A                                         | 9s COMP. A                             |
| 0     | 0   | 0     | 1   | 1       | 0     | 0                       | O                                         | 9s COMP. O                             |
| 1     | 1   | 1     | 0   | 1       | 1     | 0                       | -1 PLUS A                                 | *                                      |
| 1     | 1   | 0     | 1   | 1       | 1     | 0                       | -1 PLUS O                                 | *                                      |
| 1     | 1   | 1     | 0   | 0       | 1     | 0                       | -2 PLUS A                                 | *                                      |
| 1     | 1   | 0     | 1   | 0       | 1     | 0                       | -2 PLUS O                                 | *                                      |
| 0     | 0   | 1     | 0   | 0       | 1     | 0                       | +2 PLUS A                                 | +2 PLUS A                              |
| 0     | 0   | 0     | 1   | 0       | 1     | 0                       | +2 PLUS O                                 | +2 PLUS O                              |
| 1     | 0   | 1     | 0   | 1       | 1     | 0                       | A PLUS A                                  | A PLUS A                               |
| 0     | 1   | 0     | 1   | 1       | 1     | 0                       | O PLUS O                                  | O PLUS O                               |
| 0     | 0   | 1     | 0   | 1       | 1     | 1                       | ACC PLUS A                                | ACC PLUS A                             |
| 0     | 0   | 0     | 1   | 1       | 1     | 1                       | ACC PLUS O                                | ACC PLUS O                             |
| 0     | 0   | 1     | 0   | 1       | 0     | 1                       | ACC PLUS A AND O                          | ACC PLUS 9s COMP. A                    |
| 0     | 0   | 0     | 0   | 1       | 1     | 1                       | ACC PLUS A AND O                          | ACC PLUS A AND O                       |
| 0     | 0   | 0     | 0   | 1       | 0     | 1                       | ACC PLUS A OR O                           | ACC PLUS 9s COMP. A AND O              |
| 0     | 0   | 1     | 1   | 1       | 1     | 0                       | ACC PLUS A OR O                           | *                                      |
| 0     | 0   | 1     | 1   | 1       | 0     | 1                       | ACC PLUS A OR O                           | *                                      |

\*Not defined in BCD



MC10800 shift logic is confined to one location; it is on the Arithmetic and Logic Unit output path. However, data paths do allow you to bypass the Arithmetic and Logic Unit if a simple shift operation is to be performed.

The most important aspect of the MC10800 ALU is the freedom you have to move data via innumerable paths. Overall, there are three busses: the A, I and O Busses. Each is a 4-bit bus. The A Bus is input only, while the I and O Busses are bidirectional. The various data paths are illustrated in Figure 23-2.

The mask logic needs definition.

When activated, this logic allows one of the ALU inputs to be the AND or OR of the A and I Bus inputs.

**The various operations which can be performed by the MC10800 ALU are summarized, along with the microinstruction codes, in Tables 23-1 and 23-2.**

Table 23-1 defines the logical operations which may be performed while Table 23-2 defines the arithmetic operations which may be performed.

## THE MC10801 MICROPROGRAM CONTROL UNIT

**The MC10801 Microprogram Control Unit consists of "Next Address" logic, plus eight 4-bit registers. Four of the 4-bit registers are organized as a Stack, while the remaining four may be defined as follows:**

- CR0 Microprogram Counter
- CR1 Retry, post-interrupt CR0 buffer or cycle counter
- CR2 General purpose storage or microinstruction data storage
- CR3 Status register

**Program sequencing is controlled by 16 instructions which are specified via a 4-bit instruction code, input to the next address logic as four signals.** The 16 instructions listed below refer to the contents of the four programmable registers, two branch flags, plus two external 4-bit inputs.

The external 4-bit inputs are referred to as the "NA inputs" and the "O Bus".

The NA (Next Address) inputs, along with the 4-bit instruction code, must come from the control read-only memory, along with microinstruction code. Thus, as each microinstruction code is being executed, the address for the next microinstruction code is being computed.

The O Bus represents external data which may be input from any source.

One of the two branch flags is common to all MC10801 slices in a unit; the other branch flag may be individually created for each MC10801 slice.

Any instruction listed below which causes a Branch- or Jump-to-Subroutine automatically pushes the contents of CR0 onto the Stack before loading the microsubroutine starting address into CR0. Any instruction which causes a Return-from-Subroutine pops the Stack into CR0.

By combining the 16 instructions listed below in various ways, it is possible to create virtually any type of branch logic to access the control read-only memory.

- INC - Increment
- JMP - Jump to NA inputs
- JIB - Jump to I Bus
- JIN - Jump to I Bus and load CR2
- JPI - Jump to CR2
- JEP - Jump to External Port (O Bus)
- JL2 - Jump to NA inputs and load CR2
- JLA - Jump to NA inputs and load CR1
- JSR - Jump-to-Subroutine
- RTN - Return-from-Subroutine
- RSR - Repeat subroutine (load CR1 from NA inputs)
- RPI - Repeat Instruction
- BCR - Branch to NA inputs on condition; otherwise increment
- BSR - Branch-to-Subroutine on condition; otherwise increment
- ROC - Return-from-Subroutine on condition or jump to NA inputs
- BRM - Branch and Modify address with branch inputs (multiway branches).

## THE MC10802 TIMING DEVICE

This device is capable of creating four output clock signals. Clock signals can be output in 1, 2, 3 or 4 phases; and the duration of any single clock phase may be doubled by inputting an appropriate control signal. This allows single slow steps in asynchronous logic sequences to be accommodated.

A number of MC10802 devices may be cascaded together if more than four clock signals are required.

A number of control signals allow the MC10802 to be started and stopped on demand. Thus, almost any timing sequence that you require may be generated.

## THE MC10803 MEMORY INTERFACE DEVICE

You will use this device in a CPU configuration in order to create memory addresses. Program Counter logic, Data Counter logic, indexed addressing, indirect addressing or any other address computations can be handled by this device. Logic is illustrated in Figure 23-3. Each MC10803 memory interface device is a 4-bit slice. You can create memory addresses of any width by cascading MC10803 4-bit slices.

In order to provide total address creation flexibility, the MC10803 has five separate 4-bit data ports, five 4-bit registers, plus an arithmetic and logic unit.

Let us first look at the MC10803 data ports.

The two 4-bit bidirectional O and I Busses connect to internal CPU logic busses. Via these two busses data is transferred to or from other parts of the CPU. The bidirectional 4-bit Data Bus allows data transfers between the memory interface device and logic beyond the CPU. The final effective memory address is output via the 4-bit Address Bus. There is a further 4-bit Pointer input bus via which data can be input directly to the arithmetic and logic unit.

The arithmetic and logic unit is capable of performing binary addition or subtraction, logical AND, OR or Exclusive-OR, plus shift left and shift right operations. The possible sources and destinations for ALU operations are illustrated in Figure 23-3.

There are six 4-bit registers within the MC10803 memory interface device.

MAR is the Memory Address register, out of which the final effective memory address will be output to external memory.

MDR is a 4-bit Data register within which temporary data can be held in any way.



Figure 23-3. MC10803 Memory Interface Device Block Diagram

Four 4-bit registers in a register file are used to hold frequently needed data. For example, R0 will invariably become the Program Counter. R1, R2 and R3 can be used to hold indexes, base addresses or other similar data. Note that the four registers in the register file represent additional logic over and above the external register file, which can have any size. Thus, a number of Index registers could be maintained in the external register file, while data that is being frequently manipulated will be maintained in the MC10803 internal register file.

The data matrix has a number of control signals which usually will be input from the microprogram control read-only memory; the control signals allow one of the following data transfers to be specified:

- FOB - Register File to O Bus
- ROB - Data Register to O Bus
- RDB - Register File to Data Bus
- ODB - O Bus to Data Bus
- RDB - Data Register to Data Bus
- ADR - ALU to Data Register
- BDR - Data Bus to Data Register
- AIB - ALU to I Bus
- BIB - Data Bus to I Bus
- IDR - I Bus to Data Register
- ODR - O Bus to Data Register
- NOP - No Operation
- BRF - Data Bus to Register File
- BAR - Data Bus to Address Register
- MDR - Modify Data Register (I Bus to Data Register and Data Register to O Bus)
- PFB - Pipeline from Data Bus (Data Bus to Register File and Data Register to O Bus)
- PTB - Pipeline to Data Bus (I Bus to Data Register and Data Register to Data Bus)

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- MC10800 4-Bit ALU Slice
- MC10801 Microprogram Control Function

**MC10800**

## ABSOLUTE MAXIMUM RATINGS (see Note 1)

| RATING                                 | SYMBOL                          | VALUE                   | UNIT         |
|----------------------------------------|---------------------------------|-------------------------|--------------|
| Supply Voltage<br>( $V_{cc} = 0$ )     | $V_{EE}$<br>$V_{TT}$            | -8 to 0<br>-4 to 0      | Vdc<br>Vdc   |
| Input Voltage<br>( $V_{cc} = 0$ )      | Std Bus<br>$V_{in}$<br>$V_{in}$ | 0 to $V_{EE}$<br>Note 2 | Vdc<br>Vdc   |
| Output Source Current<br>Current Surge | $I_o$<br>$I_o$                  | < 50<br><100            | mAdc<br>mAdc |
| Storage Temp.<br>Junction Temp.        | $T_{stg.}$<br>$T_j$             | -55 to +150<br>165      | °C<br>°C     |

NOTE: 1. Permanent device damage may occur if absolute maximum ratings are exceeded. Functional operation should be restricted to RECOMMENDED OPERATING CONDITIONS. Exposure to higher than recommended voltages for extended periods of time could affect device reliability.

NOTE: 2. Input voltage limit is  $V_{CC}$  to -2 Volts when the bus is used as an input and the output drivers are disabled.

Data sheets on pages 23-D2 through 23-D9 reprinted by permission of Motorola Semiconductor Products, Inc.

## RECOMMENDED OPERATING CONDITIONS

| PARAMETER                                                 | SYMBOL                             | VALUE                          | UNIT |
|-----------------------------------------------------------|------------------------------------|--------------------------------|------|
| Supply Voltage<br>(V <sub>CC</sub> = 0 Volts)             | V <sub>TT</sub><br>V <sub>EE</sub> | -1.9 to -2.2<br>-4.68 to -5.72 | Vdc  |
| Operating Temp.<br>(Functional)                           | T <sub>A</sub>                     | -30 to +85                     | °C   |
| Output Drive                                              | —                                  | 50Ω to -2.0 Vdc                | —    |
| Maximum Clock Input<br>Rise and Fall Time<br>(20% to 80%) | t <sub>r</sub> , t <sub>f</sub>    | 10                             | ns   |
| Minimum Clock<br>Pulse Width                              | PW                                 | 5                              | ns   |

## ELECTRICAL CHARACTERISTICS

Each MECL 10,000 series circuit has been designed to meet the dc specifications shown in the test table, after thermal equilibrium has been established. The circuit is in a test socket or mounted on a printed circuit board and transverse air flow greater than 500 linear fpm is maintained. Outputs are terminated through a 50-ohm resistor to -2.0 volts. Test procedures are shown for only one input, or for one set of input conditions. Other inputs tested in the same manner.

| @Test Temperature | TEST VOLTAGE VALUES |                    |                     |                    |                 |                 | (V <sub>CC</sub> ) Gnd |
|-------------------|---------------------|--------------------|---------------------|--------------------|-----------------|-----------------|------------------------|
|                   | Volts               |                    |                     |                    |                 |                 |                        |
| -30°C             | V <sub>IHMax</sub>  | V <sub>ILMin</sub> | V <sub>IHAMin</sub> | V <sub>ILMax</sub> | V <sub>EE</sub> | V <sub>TT</sub> |                        |
| +25°C             | - .890              | -1.890             | -1.205              | -1.500             | -5.2            | -2              |                        |
| +85°C             | - .810              | -1.85              | -1.105              | -1.475             | -5.2            | -2              |                        |
|                   | - .700              | -1.825             | -1.035              | -1.440             | -5.2            | -2              |                        |

  

| Characteristic              | Symbol                                                                                        | Pin Under Test       | TEST LIMITS |        |        |     |        |        |        |                    | (V <sub>CC</sub> ) Gnd |                     |                    |                 |                 |                 |
|-----------------------------|-----------------------------------------------------------------------------------------------|----------------------|-------------|--------|--------|-----|--------|--------|--------|--------------------|------------------------|---------------------|--------------------|-----------------|-----------------|-----------------|
|                             |                                                                                               |                      | -30°C       |        | +25°C  |     | +85°C  |        | Unit   | V <sub>IHMax</sub> | V <sub>ILMin</sub>     | V <sub>IHAMin</sub> | V <sub>ILMax</sub> | V <sub>EE</sub> | V <sub>TT</sub> |                 |
| Power Supply Drain Current  | I <sub>EE</sub><br>I <sub>TT</sub>                                                            | 1, 24<br>25, 48      | -           | -      | -      | 195 | -      | -      | μAdc   |                    |                        |                     |                    | 1, 24           | 25, 48          | 12, 36<br>7, 17 |
| Input Current               | I <sub>inH</sub><br>I <sub>31</sub><br>I <sub>27</sub><br>I <sub>inL</sub><br>I <sub>31</sub> | 23<br>31<br>27<br>31 | -           | -      | -      | -   | 65     | -      | -      | μAdc               | 23<br>31<br>27         |                     |                    |                 |                 |                 |
| Logic "0" Output Voltage    | V <sub>OH</sub><br>V <sub>10</sub>                                                            | 13<br>10             | -1.060      | - .89  | - .960 | -   | - .810 | - .890 | - .700 | Vdc                | 8, 26, 46, 47          |                     |                    |                 |                 |                 |
| Logic "1" ** Output Voltage | V <sub>OL</sub><br>V <sub>10</sub>                                                            | 13<br>10             | -1.94       | -1.675 | -1.90  | -   | -1.65  | -1.875 | -1.615 | Vdc                | 26, 46, 47             |                     |                    |                 |                 |                 |
| Logic "0" Threshold Voltage | V <sub>OHA</sub><br>V <sub>10</sub>                                                           | 13<br>10             | -1.08       | -1.675 | -1.85  | -   | -1.65  | -1.825 | -1.615 | Vdc                | 26, 46, 47             |                     |                    |                 |                 |                 |
| Logic "1" Threshold Voltage | V <sub>OLO</sub><br>V <sub>10</sub>                                                           | 13<br>10             | -           | -1.655 | -      | -   | -1.63  | -      | -1.595 | Vdc                | 26, 46, 47             |                     |                    |                 |                 |                 |

\* V<sub>IH</sub> on pins 19, 26, 30, 31, 32, 33, 34, 35, 37\*\* The bi-directional outputs are specified at -1.90 volts for V<sub>OL</sub> min.This is lower than the normal V<sub>OL</sub> min. output to give increased noise margin for bussing applications.

## SET UP AND HOLD TIMES (NANOSECONDS AT 25°C)

| PATH                  | LONGEST PATH |      |      |      |       |      | SHORTEST PATH |      |      |      |       |      |
|-----------------------|--------------|------|------|------|-------|------|---------------|------|------|------|-------|------|
|                       | SET UP       |      |      | HOLD |       |      | SET UP        |      |      | HOLD |       |      |
|                       | MIN.         | TYP. | MAX. | MIN. | TYP.  | MAX. | MIN.          | TYP. | MAX. | MIN. | TYP.  | MAX. |
| A BUS → ACC (Via ALU) |              | 31.0 |      |      | -17.0 |      |               | 15.0 |      |      | - 7.5 |      |
| Ø BUS → ACC (via ALU) |              | 32.5 |      |      | -16.5 |      |               | 16.0 |      |      | - 7.5 |      |
| Ø BUS → ACC (DIRECT)  |              | 3.5  |      |      | + 5.5 |      |               | 3.5  |      |      | + 4.5 |      |
| 1 BUS → ACC (DIRECT)  |              | 4.0  |      |      | + 4.5 |      |               | 4.0  |      |      | + 5.0 |      |
| AS0, AS1, AS4 → ACC   |              | 28.5 |      |      | -18.5 |      |               | 12.0 |      |      | - 5.0 |      |
| AS2, AS3 → ACC        |              | 31.0 |      |      | -21.0 |      |               | 17.5 |      |      | - 8.0 |      |
| AS5, AS6 → ACC        |              | 40.0 |      |      | -23.5 |      |               | 19.0 |      |      | - 6.0 |      |
| AS10, AS11 → ACC      |              | 35.5 |      |      | -26.0 |      |               | 17.5 |      |      | - 5.0 |      |
| AS12 → ACC            |              | 23.0 |      |      | -10.5 |      |               | 13.0 |      |      | - 3.0 |      |
| R-1, R4 → ACC         |              | 6.5  |      |      | + 1.0 |      |               | 5.5  |      |      | + 2.5 |      |
| AS7 → ACC             |              | 7.5  |      |      | + 4.5 |      |               | 7.5  |      |      | + 4.5 |      |
| AS13, AS14 → ACC      |              | 12.5 |      |      | + 4.5 |      |               | 8.0  |      |      | 0.0   |      |
| AS9, AS15 → ACC       |              | 5.0  |      |      | + 1.5 |      |               | 4.5  |      |      | + 7.0 |      |
| AS16 → ACC            |              | 35.5 |      |      | -18.5 |      |               | 19.0 |      |      | - 9.5 |      |
| CIN → ACC             |              | 19.0 |      |      | - 8.0 |      |               | 10.0 |      |      | - 2.5 |      |
| Ø BUS → LATCH         |              | 1.0  |      |      | + 4.5 |      |               | 1.5  |      |      | + 5.0 |      |

## PROPAGATION DELAY TIMES (NANOSECONDS AT 25°C)

| INPUT                                         | OUTPUT        |                           |                    | I BUS        |      |      | PG, G <sub>G</sub> |      |      | COUT |      |      | OF, ZD, R1, R4 |      |      | P <sub>C</sub> , P <sub>R</sub> |      |      | Ø BUS |      |      |  |
|-----------------------------------------------|---------------|---------------------------|--------------------|--------------|------|------|--------------------|------|------|------|------|------|----------------|------|------|---------------------------------|------|------|-------|------|------|--|
|                                               | VIA           | MODE                      | FUNCTION           | MIN.         | TYP. | MAX. | MIN.               | TYP. | MAX. | MIN. | TYP. | MAX. | MIN.           | TYP. | MAX. | MIN.                            | TYP. | MAX. | MIN.  | TYP. | MAX. |  |
| A BUS, Ø BUS                                  | ALU           | ARITH                     | SUBTRACT           | 33.0         |      | 18.0 |                    |      | 19.5 |      |      | 33.0 |                |      | 30.5 |                                 |      |      |       |      |      |  |
| CIN                                           | ALU           | ARITH                     | ADDITION           | 19.0         |      | -    |                    |      | 7.5  |      |      | 15.5 |                |      | 18.5 |                                 |      |      |       |      |      |  |
| AS*                                           | ALU           | ARITH                     | SUBTRACT ACC       | 40.0         |      | 23.5 |                    |      | 25.5 |      |      | 39.5 |                |      | 37.5 |                                 |      |      |       |      |      |  |
| AS16                                          | ALU           | ARITH                     | SUBTRACT           | 35.0         |      | 20.5 |                    |      | 22.0 |      |      | 35.0 |                |      | 33.0 |                                 |      |      |       |      |      |  |
| R-1, R4                                       | SHIFT         | SHIFT LEFT<br>SHIFT RIGHT |                    | 8.0          |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| AS7, AS13, AS14                               | SHIFT         | SHIFT LEFT<br>SHIFT RIGHT |                    | 13.5         |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| AS9, AS15                                     | DIRECT        | SHIFT ACC                 | -                  | 9.0          |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| AS8                                           | DIRECT        | ENABLE<br>DISABLE         |                    | 7.5          |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| AS5, AS6                                      | DIRECT        | ENABLE<br>DISABLE         |                    | -            |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      | 7.5   |      |      |  |
| CLK                                           | A BUS         | ALU                       | ARITH              | SUBTRACT ACC | 47.5 |      | 35.0               |      |      | 36.5 |      |      | 41.0           |      |      | 42.0                            |      |      |       |      |      |  |
| CLK                                           | ALU           | ARITH                     | ADD ACC            | 41.5         |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| CLK                                           | SHIFT         | AS7 0                     | MULTIPLE SHIFT     | 19.0         |      | -    |                    |      | -    |      |      | 19.5 |                |      | 20.5 |                                 |      |      |       |      |      |  |
| CLK                                           | DIRECT        | ACC TO 1 Ø BUS            |                    | 12.0         |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       | 11.5 |      |  |
| Ø BUS                                         | ALU (MASK)    | LOGIC                     | WITHOUT COMPLEMENT | 31.5         |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| Ø BUS                                         | A BUS (MASK)  | LOGIC                     | WITHOUT COMPLEMENT | 42.0         |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| CLK                                           | A BUS (MASK)  | LOGIC                     | WITH COMPLEMENT    | 44.5         |      | -    |                    |      | -    |      |      | -    |                |      | -    |                                 |      |      |       |      |      |  |
| CLK                                           | A BUS (Y MUX) | LOGIC                     | WITHOUT COMPLEMENT | 37.5         |      | -    |                    |      | -    |      |      | 34.5 |                |      | -    |                                 |      |      |       |      |      |  |
| OUTPUT RISE TIME, t <sub>r</sub> (20% to 80%) |               |                           |                    | 3.5          |      | 3.5  |                    |      | 3.5  |      |      | 3.5  |                |      | 3.5  |                                 |      |      |       | 3.5  |      |  |
| OUTPUT FALL TIME, t <sub>f</sub> (20% to 80%) |               |                           |                    | 2.5          |      | 2.5  |                    |      | 2.5  |      |      | 2.5  |                |      | 2.5  |                                 |      |      |       | 2.5  |      |  |

AS\* AS0, AS1, AS2, AS1, AS4, AS5, AS6, AS10, AS11, AS12



MOTOROLA Semiconductor Products Inc.

## MC10800

## SWITCHING WAVEFORMS

## PROPAGATION DELAYS



## SETUP AND HOLD



## TEST PROCEDURE:

- Establish setup time with long  $t_{hold}$ .
- Keeping the leading edge of the input constant ( $t_{setup}$ ) vary the trailing edge of the input to determine  $t_{hold}$ .

NOTE:  $t_{setup}$  and  $t_{hold}$  as defined are positive. Internal delays in the data path may result in a shift of the data waveform to the left, with respect to the clock, resulting in negative hold times.

## SWITCHING TIME TEST CIRCUIT

50 ohm termination to ground located in each scope channel input.

All input and output cables to the scope are equal lengths of 50 ohm coaxial cable. Wire length should be  $\leq \frac{1}{4}$  inch from  $TP_{in}$  to input pin and  $TP_{out}$  to output pin.



MOTOROLA Semiconductor Products Inc.

## ABSOLUTE MAXIMUM RATINGS (see Note 1)

| RATING                                  | SYMBOL                              | VALUE                          | UNIT                                   |
|-----------------------------------------|-------------------------------------|--------------------------------|----------------------------------------|
| Supply Voltage<br>(V <sub>CC</sub> = 0) | V <sub>EE</sub><br>V <sub>TT</sub>  | -8 to 0<br>-4 to 0             | V <sub>d</sub> c<br>V <sub>d</sub> c   |
| Input Voltage<br>(V <sub>CC</sub> = 0)  | V <sub>in</sub><br>Std.<br>Bus      | 0 to V <sub>EE</sub><br>Note 2 | V <sub>d</sub> c<br>V <sub>d</sub> c   |
| Output Source<br>Current<br>Surge       | I <sub>o</sub><br>I <sub>o</sub>    | < 50<br><100                   | mA <sub>d</sub> c<br>mA <sub>d</sub> c |
| Storage Temp.<br>Junction Temp.         | T <sub>stg.</sub><br>T <sub>j</sub> | -55 to +150<br>165             | °C<br>°C                               |

NOTE: 1. Permanent device damage may occur if absolute maximum ratings are exceeded. Functional operation should be restricted to RECOMMENDED OPERATING CONDITIONS. Exposure to higher than recommended voltages for extended periods of time could affect device reliability.

NOTE: 2. Input voltage limit is V<sub>CC</sub> to -2 Volts when the bus is used as an input and the output drivers are disabled.

**RECOMMENDED OPERATING CONDITIONS**

| PARAMETER                                                 | SYMBOL                             | VALUE                          | UNIT       |
|-----------------------------------------------------------|------------------------------------|--------------------------------|------------|
| Supply Voltage<br>(V <sub>CC</sub> = 0 Volts)             | V <sub>TT</sub><br>V <sub>EE</sub> | -1.9 to -2.2<br>-4.68 to -5.72 | Vdc<br>Vdc |
| Operating Temp.<br>(Functional)                           | T <sub>A</sub>                     | -30 to +85                     | °C         |
| Output Drive                                              | -                                  | 50Ω to -2.0 Vdc                | -          |
| Maximum Clock Input<br>Rise and Fall Time<br>(20% to 80%) | t <sub>r, tf</sub>                 | 10                             | ns         |
| Minimum Clock<br>Pulse Width                              | PW                                 | 5                              | ns         |

**ELECTRICAL CHARACTERISTICS**

Each MECL 10,000 series circuit has been designed to meet the dc specifications shown in the test table, after thermal equilibrium has been established. The circuit is in a test socket or mounted on a printed circuit board and transverse air flow greater than 500 linear fpm is maintained. Outputs are terminated through a 50-ohm resistor to -2.0 volts. Test procedures are shown for only one input, or for one set of input conditions. Other inputs tested in the same manner.

| Characteristic                 | Symbol                             | Pin Under Test       | TEST LIMITS      |                  |                  |     |                  |                  |                  |                    | VOLTAGE APPLIED TO PINS LISTED BELOW: | (V <sub>CC</sub> )<br>Gnd |                    |                 |                 |                                |                          |
|--------------------------------|------------------------------------|----------------------|------------------|------------------|------------------|-----|------------------|------------------|------------------|--------------------|---------------------------------------|---------------------------|--------------------|-----------------|-----------------|--------------------------------|--------------------------|
|                                |                                    |                      | -30°C            |                  | +25°C            |     | +85°C            |                  | Unit             | Volts              |                                       |                           |                    |                 |                 |                                |                          |
|                                |                                    |                      | Min              | Max              | Min              | Typ | Max              | Min              | Max              | V <sub>IHmax</sub> | V <sub>ILmin</sub>                    | V <sub>IHmin</sub>        | V <sub>ILmax</sub> | V <sub>EE</sub> | V <sub>TT</sub> |                                |                          |
| Power Supply Drain Current     | I <sub>EE</sub><br>I <sub>TT</sub> | 1, 24<br>25, 48      | -                | -                | -                | 200 | -                | -                | -                | mAdc               | -                                     | -                         | -                  | -               | -               | 1, 24, 25, 48<br>1, 24, 25, 48 | 7,12,17,36<br>7,12,17,36 |
| Input Current                  | I <sub>inH</sub>                   | 23<br>42<br>40<br>18 | -                | -                | -                | -   | 45               | -                | -                | μAdc               | 23<br>42<br>40                        | -                         | -                  | -               | -               | 1, 24, 25, 48<br>1, 24, 25, 48 | 7,12,17,36<br>7,12,17,36 |
|                                | I <sub>inL</sub>                   |                      |                  |                  |                  |     | 370              | -                | -                |                    |                                       |                           |                    |                 |                 |                                |                          |
| Logic "0"<br>Output Voltage    | V <sub>OH</sub>                    | 16<br>2              | -1.060<br>-1.060 | -0.890<br>-0.890 | -0.960<br>-0.960 | -   | -0.810<br>-0.810 | -0.890<br>-0.890 | -0.700<br>-0.700 | Vdc                | *18,26,27,45<br>41,44,46              | -                         | 16<br>2            | -               | -               | 1, 24, 25, 48<br>1, 24, 25, 48 | 7,12,17,36<br>7,12,17,36 |
| Logic "1"<br>Output Voltage    | V <sub>OL</sub>                    | 16<br>2              | -1.940<br>-1.890 | -1.675<br>-1.675 | -1.900<br>-1.850 | -   | -1.650<br>-1.650 | -1.875<br>-1.825 | -1.615<br>-1.615 | Vdc                | 45<br>**42,43,45<br>40414446,47       | 26,27,40<br>16            | -                  | -               | -               | 1, 24, 25, 48<br>1, 24, 25, 48 | 7,12,17,36<br>7,12,17,36 |
| Logic "0"<br>Threshold Voltage | V <sub>OHA</sub>                   | 2                    | -1.080           | -                | -0.980           | -   | -                | -0.910           | -                | Vdc                | **42,43,45<br>40,41,44,47             | 46                        | -                  | -               | -               | 1, 24, 25, 48                  | 7,12,17,36               |
| Logic "1"<br>Threshold Voltage | V <sub>OLO</sub>                   | 2                    | -                | -1.655           | -                | -   | -1.630           | -                | -1.595           | Vdc                | **42,43,45<br>40,41,44,47             | -                         | 46                 | 1, 24, 25, 48   | 7,12,17,36      |                                |                          |

<sup>†</sup>The bi-directional outputs are specified at -1.90 volts for V<sub>OL</sub> min.

Preset Conditions

\*PS1: Apply V<sub>IH</sub> at 37, 43; V<sub>IL</sub> at 40, 41, 42, 44; then clock once (↑↓).

\*\*PS2: Apply V<sub>IH</sub> at 41, 42, 43, 44; V<sub>IL</sub> at 33, 34, 35, 37, 40, 47; then clock once (↑↓).

## SET UP AND HOLD TIMES (NANOSECONDS AT 25°C)

| INPUT                  | SETUP |      | HOLD |      |
|------------------------|-------|------|------|------|
|                        | MIN.  | TYP. | MIN. | TYP. |
| IC0-IC3 (1)            |       | 17   |      | -6.0 |
| IC0-IC3 (2, 3)         |       | 30   |      | -10  |
| NA0-NA3                |       | 14   |      | -1.0 |
| I Bus, $\emptyset$ Bus |       | 19   |      | -4.0 |
| CS0-CS3                |       | 24   |      | -2.0 |
| CS4 (4)                |       | 15   |      | -4.0 |
| CS6-CS8                |       | 14   |      | -1.0 |
| B (4)                  |       | 14   |      | -3.0 |
| C <sub>in</sub>        |       | 9.0  |      | 0    |
| D <sub>in</sub>        |       | 13   |      | 0    |
| RST                    |       | 13   |      | +3.0 |
| X <sub>B</sub>         |       | 13   |      | -4.0 |
| X <sub>B</sub> (4)     |       | 19   |      | -7.0 |

## NOTES:

- (1) All instructions except 2 and 3 below.
- (2) BSR, BRC, BRM or ROC instruction when  $B \cdot \overline{CS4} = 1$ .
- (3) BSR, BRC, BRM, ROC, JSR, RPI or RTN instruction when RSQ = 1.
- (4) BRM instruction only.

## PROPAGATION DELAY TIMES (NANOSECONDS AT 25°C)

| INPUT                | CR0  |      | CR3  |      | I BUS, $\emptyset$ BUS |      | X <sub>B</sub> |      | C <sub>out</sub> |      |
|----------------------|------|------|------|------|------------------------|------|----------------|------|------------------|------|
|                      | TYP. | MAX. | TYP. | MAX. | TYP.                   | MAX. | TYP.           | MAX. | TYP.             | MAX. |
| Clock                | 11   |      | 10   |      | 17                     |      | 17             |      | 15               |      |
| IC0-IC3              | —    |      | —    |      | 19                     |      | 15             |      | 18*              |      |
| CS0, CS1, CS3, CS4   | —    |      | —    |      | —                      |      | 12             |      | —                |      |
| CS5                  | 4.0  |      | —    |      | —                      |      | —              |      | —                |      |
| CS6-CS8              | —    |      | —    |      | 13                     |      | —              |      | —                |      |
| B                    | —    |      | —    |      | —                      |      | 8.0            |      | —                |      |
| C <sub>in</sub>      | —    |      | —    |      | —                      |      | —              |      | 3.0              |      |
| X <sub>B</sub> , RST | —    |      | —    |      | 21                     |      | —              |      | —                |      |

\*C<sub>out</sub> cannot change if RSQ = 0.



MOTOROLA Semiconductor Products Inc.

## SWITCHING WAVEFORMS

## PROPAGATION DELAYS



## SETUP AND HOLD



## TEST PROCEDURE:

- Establish setup time with long  $t_{hold}$ .
- Keeping the leading edge of the input constant ( $t_{setup}$ ) vary the trailing edge of the input to determine  $t_{hold}$ .

NOTE:  $t_{setup}$  and  $t_{hold}$  as defined are positive. Internal delays in the data path may result in a shift of the data waveform to the left, with respect to the clock, resulting in negative hold times.

## SWITCHING TIME TEST CIRCUIT

50 ohm termination to ground located in each scope channel input.

All input and output cables to the scope are equal lengths of 50 ohm coaxial cable. Wire length should be  $\leq \frac{1}{4}$  inch from  $TP_{in}$  to input pin and  $TP_{out}$  to output pin.



## Chapter 24

# THE HEWLETT PACKARD MC2

**The MC2 is the first microprocessor manufactured by Hewlett Packard. The MC2 is a 16-bit microprocessor designed specifically for process control applications; it has been designed for internal use within the many instruments and electronic products manufactured by Hewlett Packard. The MC2 is most unlikely to be sold as a single chip in the foreseeable future; even its availability as a computer card is not guaranteed at the present time.**

Since the MC2 microprocessor is unlikely to be available to anyone outside Hewlett Packard, we may question the value of describing it in this book. We have decided to do so since MC2 includes many interesting conceptual innovations. However, we do not plan to upgrade the coverage of MC2 beyond the superficial level presented on the following pages until (and unless) the part becomes generally available.

**The most important aspect of the MC2 is its technology; it is built using CMOS logic with Silicon On Sapphire (SOS technology). The CMOS logic gives the MC2 typical CMOS low power requirements and noise insensitivity, while Silicon On Sapphire technology gives it high speed.**

**Using a +12V power supply, the MC2 operates with a 125 nanosecond clock and executes instructions in 4 to 12 clock cycles. Typical instructions are therefore executed in less than one microsecond.**

**The MC2 is packaged on a squared, 48-pin leadless ceramic substrate.**

The sole manufacturer of the MC2 is:

HEWLETT PACKARD COMPANY  
Data Systems Division  
11000 Wolfe Road  
Cupertino, CA 95014

A second source for this microprocessor is unlikely in the foreseeable future.

### AN MC2 SYSTEM OVERVIEW

**Logic implemented on the MC2 CPU chip is illustrated in Figure 24-1. A number of support devices for the MC2 has been manufactured, but no information on these support devices is available at the present time.**

**Clock logic is external to the MC2 chip; however a simple single waveform external clock signal will suffice.**

Figure 24-1 shows I/O interface logic as being implemented on the MC2 CPU chip. This reflects the unusual way in which the MC2 handles external devices. The MC2 CPU has eight 16-bit general-purpose programmable registers. Every I/O device is assumed to have a CPU equivalent set of eight programmable registers. Instructions and control signals of the MC2 treat registers of the CPU and I/O devices similarly, which means that no special I/O interface logic is required.



Figure 24-1. Logic of the Hewlett Packard MC2 Microprocessor

## MC2 PROGRAMMABLE REGISTERS AND STATUS

The MC2 has eight 16-bit programmable registers and an 8-bit Stack Pointer. In addition there is an 8-bit I/O Device Identification register. Registers may be illustrated as follows:



Any one of the eight 16-bit registers may be used as a Data Counter.

Register R0 serves as the Status register. Its contents are interpreted as follows:



The Zero, Negative, Carry and Overflow statuses in bits 11, 12, 13 and 14, respectively, apply to the 16-bit result of the most recent data operation performed. Zero, Carry and Overflow are standard statuses, as described in Volume I, Chapter 6. The Negative status reflects the sign of the 16-bit result; that is to say, it is set to the value of the result's high-order bit.

The Interrupt Enable flag in Status register bit 7 is set to 1 in order to enable interrupts. It is reset to 0 in order to disable interrupts.

The low-order byte Zero and Negative statuses are identical to standard Zero and Negative statuses, except that they reflect the low-order 8 bits of the most recent operation's result. This may be illustrated as follows:



The low-order three Status register bits are referred to as a Priority Code. This Priority Code identifies the highest order 1 bit in the low-order byte of the most recent operation's result. The Priority Code has the value of the bit position being identified. Here are some examples of Priority Codes:



The Stack Pointer enables a 256-word Stack. The Stack occupies the first 256 words of read/write memory, with memory word 0 being the top of the Stack.



Figure 24-2. CPU and I/O Device Registers' Organization for the MC2

**The I/O Device Identification register, also referred to as a Base register, identifies one of 256 possible external I/O devices.** The identified external I/O device will be interpreted as consisting of eight 16-bit registers. **When executing Register-Register instructions, there is little differentiation made between the eight CPU registers and the eight registers of the identified external device.** The two sets of eight registers constitute a 16-register bank out of which two operands are selected. The two operands may or may not come from the same register. The destination, which is the first identified operand register, is usually one of the CPU registers (R0 - R7); only the Register-Register Move instruction permits an external register (R8 - R15) to be the destination. **This scheme is illustrated in Figure 24-2.**

## MC2 MEMORY ADDRESSING MODES

The MC2 is quite limited in its memory reference capabilities. Instructions allow you to load data from memory into a CPU register, or to store data from CPU registers to memory. **Data access instructions use direct memory addressing or implied memory addressing.**

Direct memory addressing instructions are two words long; the second instruction object code word provides the 16-bit direct memory address.

Instructions that use implied memory addressing allow any one of the eight CPU registers to specify the 16-bit memory address.

Conditional Branch instructions and Subroutine Call instructions allow direct and indirect addressing; however direct addressing is program relative and the displacement is an 8-bit signed binary number.

## HARDWARE ASPECTS OF THE MC2

We are not going to describe pins and signals of the MC2 because Hewlett Packard has not made sufficient information available at the present time. Also, such information will be irrelevant until you can buy the MC2 as a chip. Instead we will provide a brief summary of principal MC2 hardware characteristics.

The MC2 is packaged as a 48-pin package. This allows separate 16-bit Data and Address Buses, together with an adequate set of control signals. Control logic on the System Bus is asynchronous, having a request/acknowledge control

philosophy. This simplifies multiple CPU configurations. Execution of a "No Operation" instruction puts any CPU into a slave state on the System Bus, at which time its internal registers may be accessed by some other "master" CPU. A slave CPU may be converted into the master via an interrupt request.

MC2 interrupt logic is primitive but effective. There is one interrupt request line; when an interrupt is acknowledged, a subroutine call to memory location FFFE<sub>16</sub> is executed. Memory location FFFE<sub>16</sub> must contain the beginning address for the interrupt service routine.

## THE MC2 INSTRUCTION SET

The MC2 instruction set is characterized by a lack of distinction between CPU registers and I/O devices. Most instructions that operate on data or move data are Register-Register instructions; as illustrated in Figure 24-2, each register may be an internal CPU register or a register out of an I/O device. Thus there is no difference between Move instructions that access two CPU registers, one CPU register and an I/O device, or two registers from the same I/O device. This similarity between Register-Register and I/O instructions is manifest by the way in which the MC2 instruction set has been defined in Table 24-1.

For a better understanding of MC2 instructions, you must understand the way in which Register-Register instruction object codes are defined. This may be illustrated as follows:



Source registers 1 and 2 may each be identified as any one of the eight CPU 16-bit registers, or any one of the eight I/O device 16-bit registers. The particular I/O device which is currently selected is defined by the contents of the I/O Device Identification register.

Source register 1 also becomes the Destination register for the result of the operation. In all instructions except MOVE, Source register 1 must be one of the eight CPU registers.

The contents of Source register 2 are manipulated before becoming an operand for the operation to be performed. The manipulation performed on Source register 2 contents is defined by the field descriptor. Register-Register instructions therefore perform an operation identified by bits 12 through 15 of the instruction object code; the operation uses two 16-bit operands as inputs. These two operands may come from the CPU register or the currently selected I/O device's registers. One 16-bit operand may be manipulated as defined by the field descriptor before it becomes an input to the operation specified by the instruction code.

## THE BENCHMARK PROGRAM

For the Hewlett Packard MC2 our benchmark program may be illustrated as follows:

|       |                 |                                             |
|-------|-----------------|---------------------------------------------|
| LDWI  | R1 = IOBUF      | LOAD INPUT BUFFER ADDRESS IN REGISTER 1     |
| LOAD  | R2 = COUNT      | LOAD BUFFER SIZE IN REGISTER 2              |
| LOAD  | R3 = TABLE      | LOAD NEXT FREE TABLE LOCATION IN REGISTER 3 |
| LOOP: | LOAD R4 = (R1)  | INPUT DATA WORD TO REGISTER 4               |
|       | STOR (R3) = R4  | STORE WORD TO NEXT FREE TABLE LOCATION      |
|       | ADDI R1,1       | INCREMENT BUFFER ADDRESS                    |
|       | ADDI R3,1       | INCREMENT TABLE ADDRESS                     |
|       | SUBI R2,1       | DECREMENT WORD COUNT                        |
|       | CBR LOOP IF G   | REITERATE IF COUNT STILL GREATER THAN ZERO  |
|       | STOR TABLE = R3 | SAVE ADDR OF NEXT TABLE WORD                |

This benchmark program makes very few assumptions. Memory is addressed in 16-bit units (rather than 8-bit bytes), and data is transferred 16 bits at a time. The input table IOBUF and the data table TABLE can have any length, and can reside anywhere in memory. The address of the first free word in TABLE is stored in the first word of the TABLE.

The following notation is used in Table 24-1:

|                            |                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYTE                       | 8 bits of immediate data — the lower byte of the instruction word.                                                                                                                                                                                                                                                                                   |
| CDST {<br>CREG }<br>CSRC } | Any of the CPU registers (Registers 0 through 7).                                                                                                                                                                                                                                                                                                    |
| DST                        | Any of the 16 registers, used as the destination of a move or result.                                                                                                                                                                                                                                                                                |
| DI                         | The I/O Device Identification register (Base register).                                                                                                                                                                                                                                                                                              |
| F                          | Fill specification for register shift: if F is 0, the bit is reset to 0; if F is 1, the bit is set to 1.                                                                                                                                                                                                                                             |
| <,FD>                      | Optional field descriptor:<br>SWB Swap bytes<br>LJL Left justify lower byte<br>LJU Left justify upper byte<br>RJU Right justify upper byte<br>RJL Right justify lower byte<br>RJ0 Right justify high-order nibble<br>RJ1 Right justify next-to-high-order nibble<br>RJ2 Right justify next-to-low-order nibble<br>RJ3 Right justify low-order nibble |
| REG (FD)                   | The result of the operation of the field descriptor on the specified register.                                                                                                                                                                                                                                                                       |
| SRC (K)                    | Operand field specification of one bit of the register. Register may be any of the 16 registers; K may be any number from 0 to 15.                                                                                                                                                                                                                   |
| SRC <K>                    | Bit K of Register SRC.                                                                                                                                                                                                                                                                                                                               |
| <,I>                       | Optional indirection specification. When I is present, the address used is the contents of the memory location addressed.                                                                                                                                                                                                                            |

|               |                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <,IF CC>      | Optional Condition Code representing a linear combination of the Zero and Negative status flags and "Greater Than":<br>N Z NVZ<br>0 0 0 Not true<br>0 0 1 G - greater than 0<br>0 1 0 E - equal to 0<br>0 1 1 GE - greater than or equal to 0<br>1 0 0 L - less than 0<br>1 0 1 LG - not equal to 0<br>1 1 0 LE - less than or equal to 0<br>1 1 1 Unconditional branch |
| LABEL         | A 16-bit address; it may be the second word in the instruction, or its lower byte may be the lower byte of a one-word instruction.                                                                                                                                                                                                                                      |
| REG           | Any of the CPU or external registers.                                                                                                                                                                                                                                                                                                                                   |
| <(REG <,FD>)> | Optional indexing specification. For example, the instruction:<br>IBR TABLE(9.RJL)<br>will calculate an address by clearing the upper byte of the contents of Register 9 and adding the result to the 16-bit word TABLE. Then the contents of the location thus addressed will be the address at which instruction execution continues.                                 |
| R0            | Register 0, the Status register, as described earlier in this chapter.                                                                                                                                                                                                                                                                                                  |
| PC            | The Program Counter.                                                                                                                                                                                                                                                                                                                                                    |
| SP            | The Stack Pointer.                                                                                                                                                                                                                                                                                                                                                      |
| SRC           | Any of the 16 registers, used as the source of an operand.                                                                                                                                                                                                                                                                                                              |
| STATUSES      | The following status flags are affected by the instructions:<br>O The Overflow status<br>C The Carry status<br>N The Negative or Sign status<br>Z The Zero status<br>L The lower byte statuses NL and ZL                                                                                                                                                                |
| WORD          | The following symbols are used in the STATUSES columns:                                                                                                                                                                                                                                                                                                                 |
| x <y,z>       | A blank means the status flag is not affected by the operation.<br>X The operation affects the status flag in a meaningful manner.<br>? The operation affects the status flag, but it is meaningless.                                                                                                                                                                   |
| [ ]           | 16 bits of immediate data.                                                                                                                                                                                                                                                                                                                                              |
| [[ ]]         | Bits y through z of the Register x. For example, PC<15,8> represents the upper byte of the Program Counter.                                                                                                                                                                                                                                                             |
| Λ             | Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, then the designated register's contents are specified. If a memory address is enclosed within the brackets, then the contents of the addressed memory location are specified.                                                                                 |
| ∨             | Implied memory addressing: the contents of the memory location designated by the contents of a register.                                                                                                                                                                                                                                                                |
| ⊕             | Logical AND                                                                                                                                                                                                                                                                                                                                                             |
| ⊖             | Logical OR                                                                                                                                                                                                                                                                                                                                                              |
| ⊖⊖            | Logical Exclusive-OR                                                                                                                                                                                                                                                                                                                                                    |
| ←             | Data is transferred in the direction of the arrow.                                                                                                                                                                                                                                                                                                                      |
| **            | Exponentiation. $2^{**}K$ represents a 16-bit word with a 1 in bit K, and 0 in all the other bits.                                                                                                                                                                                                                                                                      |

Table 24-1. A Summary of the MC2 Instruction Set

| TYPE                               | MNEMONIC | OPERAND(S)                  | BYTES | STATUSES |   |   |   |   |  | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------|----------|-----------------------------|-------|----------|---|---|---|---|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                    |          |                             |       | O        | C | N | Z | L |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PRIMARY MEMORY<br>REFERENCE        | LOAD     | CDST = LABEL <(CSRC <,FD>)> | 4     |          |   |   |   |   |  | [CDST]—[LABEL + [CSRC(FD)]]<br>Load CPU register from memory using direct addressing or indexed addressing via a CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                    | LOAD     | CDST = (CSRC)               | 2     |          |   |   |   |   |  | [CDST]—[[CSRC]]<br>Load CPU register from memory using implied addressing via a CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                    | STOR     | LABEL <(CDST <,FD>)> = CSRC | 4     |          |   |   |   |   |  | [LABEL + [CDST(FD)]]—[CSRC]<br>Store CPU register to memory using direct addressing or indexed addressing via a CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                    | STOR     | (CDST) = CSRC               | 2     |          |   |   |   |   |  | [[CDST]]—[CSRC]<br>Store CPU register to memory using implied addressing via a CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| I/O AND<br>IMMEDIATE               | LDWI     | CDST = WORD                 | 4     |          |   |   |   |   |  | [CDST]—WORD<br>Load immediate 16 bits to CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                    | LDBI     | REG = BYTE                  | 2     | ?        | ? | X | X | X |  | [REG <7,0>]—BYTE<br>Load immediate 8 bits to CPU or external register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| IMMEDIATE<br>OPERATE               | ADDI     | CDST,BYTE                   | 2     | X        | X | X | X | X |  | [CDST]—[CDST] + BYTE<br>Add immediate 8 bits to lower half of CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                    | SUBI     | CDST,BYTE                   | 2     | X        | X | X | X | X |  | [CDST]—[CDST] - BYTE<br>Subtract immediate 8 bits from lower half of CPU register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                    | CMPRI    | CREG,BYTE                   | 2     | X        | X | X | X | X |  | [CREG] - BYTE<br>Compare immediate 8 bits with lower half of CPU register. Only the statuses are affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| I/O, JUMP, AND BRANCH ON CONDITION | BR       | REG <,FD>                   | 2     |          |   |   |   |   |  | [PC]—[REG(FD)]<br>Branch to memory location addressed by register contents or by some operation on the register's contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                    | IBR      | LABEL <(REG <,FD>)>         | 4     |          |   |   |   |   |  | [PC]—[LABEL + [REG(FD)]]<br>Branch using direct addressing or indexed addressing via any CPU or external register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                    | CALL     | LABEL <,I> <IF CC>          | 2     | ?        | ? | ? | ? | ? |  | If CC is true then<br>[[SP]]—[R0]<br>[SP]—[SP] + 1<br>[R0]—[PC]<br>[PC]—[PC] <15,8> LABEL <,0> or<br>[PC]—[[PC] <15,8> LABEL <,0>] if I is specified<br>Subroutine call — may be conditional or unconditional. If condition is not satisfied, Program Counter is incremented and next instruction is executed. If condition is satisfied, statuses are saved on the stack, the incremented Program Counter is saved in Register 0, and the lower 8 bits of the Program Counter are replaced by the second byte of the instruction. Subroutine starting location must be within 256 words of CALL instruction location. |
|                                    | RTN      | CREG                        | 2     |          |   |   |   |   |  | [PC]—[CREG]<br>[CREG]—[[SP] - 1]<br>[SP]—[SP] - 1<br>Subroutine return — get return address from specified CPU register and pop the stack into that register.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Table 24-1. A Summary of the MC2 Instruction Set (Continued)

| TYPE                                                 | MNEMONIC | OPERAND(S)         | BYTES | STATUSES |   |   |   |    | OPERATION PERFORMED                                                                                                                                                                                                                                                                                   |
|------------------------------------------------------|----------|--------------------|-------|----------|---|---|---|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                      |          |                    |       | O        | C | N | Z | L  |                                                                                                                                                                                                                                                                                                       |
| I/O, JUMP, AND<br>BRANCH ON CONDITION<br>(CONTINUED) | CBR      | LABEL <,I> <IF CC> | 2     |          |   |   |   |    | If CC is true then<br>[PC]—[PC]<15,8>LABEL<7,0> or<br>[PC]—[[PC]<15,8>LABEL<7,0>] if I is specified<br>Conditional branch — if condition is satisfied, then replace lower 8 bits of Program Counter with lower 8 bits of instruction. Branch destination must be within 256 words of CBR instruction. |
| I/O AND<br>REGISTER-REGISTER<br>MOVE                 | MOVE     | DST = SRC<,FD>     | 2     | ?        | ? | X | X | X  | [DST]—[SRC(FD)]<br>Move data from register to register, optionally operating on source word.                                                                                                                                                                                                          |
|                                                      | STRB     | CDST               |       |          |   |   |   |    | [CDST]—[DI]<br>Move contents of Device Identification register into specified CPU register.                                                                                                                                                                                                           |
|                                                      | LDRB     | CSRC<,FD>          | 2     |          |   |   |   |    | [DI]—[CSRC(FD)]<br>Load Device Identification register with contents of a CPU register, or with some function of those contents.                                                                                                                                                                      |
| I/O AND REGISTER-REGISTER<br>OPERATE                 | ADD      | CDST,SRC<,FD>      | 2     | X        | X | X | X | -X | [CDST]—[SRC(FD)] + [CDST]<br>Add contents of CPU register and any register; deposit result in CPU register.                                                                                                                                                                                           |
|                                                      | SUBR     | CDST,SRC<,FD>      | 2     | X        | X | X | X | X  | [CDST]—[SRC(FD)] - [CDST]<br>Subtract contents of CPU register from any register's contents; deposit result in CPU register.                                                                                                                                                                          |
|                                                      | AND      | CDST,SRC<,FD>      | 2     | ?        | ? | X | X | X  | [CDST]—[SRC(FD)] $\wedge$ [CDST]<br>AND CPU register contents with any register's contents; deposit result in CPU register.                                                                                                                                                                           |
|                                                      | OR       | CDST,SRC<,FD>      | 2     | ?        | ? | X | X | X  | [CDST]—[SRC(FD)] V [CDST]<br>OR CPU register contents with any register's contents; deposit result in CPU register.                                                                                                                                                                                   |
|                                                      | XOR      | CDST,SRC<,FD>      | 2     | ?        | ? | X | X | X  | [CDST]—[SRC(FD)] $\oplus$ [CDST]<br>Exclusive-OR CPU register contents with any register's contents; deposit result in CPU register.                                                                                                                                                                  |
|                                                      | CMPR     | CDST,SRC<,FD>      | 2     | X        | X | X | X | X  | [SRC(FD)] - [CDST]<br>Compare contents of CPU register with those of any register. Only the statuses are affected.                                                                                                                                                                                    |
| REGISTER OPERATE                                     | ADDC     | CREG               | 2     | X        | X | X | X | X  | [CREG]—[CREG] + [C]<br>Add Carry bit to contents of CPU register.                                                                                                                                                                                                                                     |
|                                                      | NEG      | CREG               | 2     | X        | X | X | X | X  | [CREG]—0 - [CREG]<br>Negate contents of CPU register (twos complement).                                                                                                                                                                                                                               |
|                                                      | CMPL     | CREG               | 2     | ?        | ? | X | X | X  | [CREG]—[CREG]<br>Complement contents of CPU register (ones complement).                                                                                                                                                                                                                               |
|                                                      | SHFTL    | RRL,CREG<,C>       | 2     | X        | X | X | X | X  | <br>Rotate CPU register contents left one bit position, through Carry if specified.                                                                                                                               |

Table 24-1. A Summary of the MC2 Instruction Set (Continued)

| TYPE                            | MNEMONIC | OPERAND(S)    | BYTES | STATUSES |   |   |   |   |  | OPERATION PERFORMED                                                                                                                                                                |
|---------------------------------|----------|---------------|-------|----------|---|---|---|---|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |          |               |       | O        | C | N | Z | L |  |                                                                                                                                                                                    |
| REGISTER OPERATE<br>(CONTINUED) | SHFTL    | LSL,CREG,F    | 2     | X        | X | X | X | X |  | <br>[CREG]<br>Shift CPU register contents left one bit position, filling bit 0 according to F.  |
|                                 | SHFTR    | RRR,CREG <,C> | 2     | ?        | X | X | X | X |  | <br>[CREG]<br>Rotate CPU register contents right one bit position, through Carry if specified.   |
|                                 | SHFTR    | LSR,CREG,F    | 2     | ?        | X | X | X | X |  | <br>[CREG]<br>Shift CPU register contents right one bit position, filling bit 15 according to F. |
| I/O AND BIT MANIPULATION        | SBIT     | CDST,SRC(K)   | 2     | ?        | ? | X | X | X |  | [SRC <K>]—1<br>[CDST]—[SRC]<br>Set the specified bit of the specified register to 1, then deposit result in a CPU register.                                                        |
|                                 | RBIT     | CDST,SRC(K)   | 2     | ?        | ? | X | X | X |  | [SRC <K>]—0<br>[CDST]—[SRC]<br>Reset the specified bit of the specified register to 0, then deposit result in a CPU register.                                                      |
|                                 | CBIT     | CDST,SRC(K)   | 2     | ?        | ? | X | X | X |  | [SRC <K>]—[SRC <K>]<br>[CDST]—[SRC]<br>Complement the specified bit of the specified register, then deposit result in a CPU register.                                              |
|                                 | TBIT     | CDST,SRC(K)   | 2     | ?        | ? | X | X | X |  | [CDST]—[SRC] $\wedge$ $2^{*}K$<br>Set all bits of the specified register, except the specified bit, to 0; deposit result in a CPU register.                                        |
| STACK                           | PUSH     | CREG          | 2     |          |   |   |   |   |  | [SP]—[CREG]<br>[SP]—[SP] + 1<br>Store CPU register's contents on top of stack.                                                                                                     |
|                                 | POP      | CREG          | 2     |          |   |   |   |   |  | [CREG]—[SP] - 1; [SP]—[SP] - 1<br>Load CPU register from top of stack.                                                                                                             |
|                                 | HALT     |               | 2     |          |   |   |   |   |  | CPU enters idle state.                                                                                                                                                             |

# Chapter 25

## SELECTING A MICROCOMPUTER

**So you have a product and you may want to build it using microcomputer devices. You have two decisions to make:**

- 1) Should you use a microcomputer at all?
- 2) And if so, which?

**Of course, both decisions must be based on minimizing costs.**

The eventual unit price for any product, whether or not it includes a microcomputer, is given by the equation:

$$P = \frac{F}{N} + V$$

In the above equation, P represents unit price, F represents fixed costs, V represents variable costs and N represents the number of units you plan to build.

**Fixed costs are the front-end expense which is essentially insensitive to the number of units you plan to build. Fixed costs include the following items:**

- 1) Product evaluation expense, including preliminary market research.
- 2) Product advertising and promotion expense.
- 3) The cost of doing a competitive analysis to select a microcomputer.
- 4) The cost of going from specification to product.

**FIXED COST  
CONTRIBUTING  
FACTORS**

**Variable costs are the costs that must be incurred for every unit built. These are the contributors to variable costs:**

- 1) The cost of logic components and particularly, whether you have access to second sources for all logic components. A product without a second source may be a product that becomes significantly more expensive as time goes by.
- 2) Assembly line expenses.
- 3) Product testing expenses.

**VARIABLE COST  
CONTRIBUTING  
FACTORS**

**While you are still deciding whether to use microcomputer logic or discrete logic, two further considerations must be taken into account:**

- 1) Subsequent product modification
- 2) After sales servicing

**Remember, if your product is built around a microcomputer you can make very drastic changes to the product simply by rewriting the microcomputer program.** That will result in a single ROM or PROM device having to be replaced. Were the product completely implemented using discrete logic, a similar product change may require one or more boards of logic to be completely replaced.

**CONTINUING  
ENGINEERING  
COSTS**

**The cost of servicing a product built around a microcomputer is significantly less than the cost of servicing a product that uses discrete logic. There are two reasons why this is so.**

**AFTER SALES  
SERVICE**

**First, a product that is built around a microcomputer is likely to have far fewer components than the same product implemented entirely out of discrete logic.** This means that not only are there fewer parts to malfunction, but when a part does malfunction, it is easier to locate.

**The second reason that servicing a microcomputer-based product is cheaper than servicing the same product implemented in discrete logic is that you can write a diagnostic program to test every logic device on a card.** Suppose there are 200 logic devices on a large card that includes a microcomputer system. Give each device a number.

and place eight light-emitting diodes at the card edge. Then write a program which systematically tests every single device on the card to ensure that it is functioning correctly. Any malfunctioning device may be identified using the eight light-emitting diodes to display a binary device number. There are, of course, numerous applications where this simplistic approach to diagnostics will not work, but in many applications the concept has potential.

**In order to determine whether you should use a microcomputer at all, you must estimate costs, based on fixed and variable expenses, for a product built around a microcomputer, and for a product built entirely out of discrete logic. You must then consider continuing engineering and after sales service economies that may accrue when you build your product around a microcomputer.**

**Assuming that you are going to use a microcomputer, which should you use? Let us examine the impact that microcomputer selection has on fixed and variable costs. First consider variable costs.**

**If it may not be immediately apparent, but a microcomputer's instruction set and execution speed will usually have very little impact on variable costs, being overwhelmed by simple pricing considerations.** For example, the F8 has an instruction set that will invariably generate longer object programs than an equivalent 8080A system. On the other hand, by combining the 3850 CPU with a 3851 PSU, you have a two-device system which includes a CPU, 1024 bytes of ROM, 64 bytes of RAM, four I/O ports (each of which are 8 bits wide), a programmable timer and a single external interrupt line. Providing your application is simple enough to fit into this small configuration, the fact that the 8080A instruction set is superior, or that 8080A programs execute faster, becomes irrelevant. If your F8 program fits in the minimum 1K bytes of memory, memory savings become irrelevant, and it would take seven 8080A devices to give you the same functional capacity as the two F8 devices. Clearly, the seven 8080A devices will cost considerably more.

**VARIABLE COSTS**

**If the F8-based product provides lower parts costs (Variable Costs), but the 8080A-based product costs less to develop (Fixed Costs), at what point will fixed costs become more important than variable costs?**

**Let us answer the question by looking more closely at factors that contribute to fixed costs.** **FIXED COSTS**

**Of the four cost factors that contribute to fixed costs, only the fourth, the cost of going from specification to product, can be critically evaluated.**

**We will begin by summarizing, without comment, the steps that lead from a specification to an end product. Using this sequence of events as a framework, we will describe the decisions you must make, and the basis on which you should make these decisions.**

## **DESIGNING LOGIC WITH MICROCOMPUTERS — A SEQUENCE OF EVENTS**

**Any microcomputer development project will involve some minor variations of these nine steps:**

- 1) **Specify the product.** The need for clear and accurate specifications is more critical when a product is to be built around a microcomputer than it would be if the product were to be built around discrete logic.  
Remember that designing with discrete logic involves a single set of choices — the selection of discrete logic components. When you use a microcomputer, there are two sets of choices: having decided on the CPU and the devices that will surround the CPU, you still have to create a program, which means that enormous flexibilities and variables remain unresolved even after the hardware has been selected. In other words, you are going to be faced with constant hardware/software tradeoffs. Unless an excellent specification defines the product which is to be built, the process of compromising between hardware and software will be difficult at best, and will result in unforeseen errors at worst.
- 2) **Prepare a preliminary hardware design.** Even before you have selected a microcomputer, you will lay out a preliminary product design, leaving as "black boxes" those parts of the product which will eventually become the microcomputer system.
- 3) **Specify the microcomputer requirements.** The "black boxes" from step 2 can now be expanded into a set of performance criteria upon which the selection of a microcomputer will be based. Some iteration between steps 2 and 3 may be required.

If the first time you perform step 3, you discover that no microcomputer on the market can meet your performance criteria, redo step 2; relax the demands placed on the microcomputer by identifying the critical steps that the microcomputers cannot handle, then implement these critical steps using discrete logic. In other words, shrink the "black box".

If you find that virtually every microcomputer provides overkill for your job as specified, it is worth going back to step 2 to see if some additional logic functions can be performed by the microcomputer. In other words, expand the "black box".

A frequently made error, when specifying the logic that must be implemented by a microcomputer, is to needlessly include steps that demand extremely fast logic. Remember, none of the microcomputers described in this book are capable of performing real-time events in much less than ten microseconds.

Erring in the other direction, another common mistake is to underestimate what a microcomputer can do. A microcomputer can handle large volumes of data, and can perform complex data manipulations, providing program execution speed is unimportant.

- 4) **Depending on your history as a microcomputer user, it may or may not be worthwhile doing a competitive analysis of microcomputer products. If it is worthwhile, you will, at this point, narrow the field to two or three products.**
- 5) **Write source programs. You must now make a major decision: do you write source programs in assembly language or in a higher level language?**

Most microcomputer manufacturers now allow you to write source programs in FORTRAN Intel's new programming language, PL/M, is also being adopted by a number of microcomputer manufacturers. In all probability, a growing number of higher level languages will be made available to microcomputer users. As we will discuss later in this chapter, however, using assembly language is frequently less expensive.

- 6) **Convert the source program to an object program.** This step may be handled in one of two ways: you may use a time-sharing computer service or you may use a microcomputer development system.

A microcomputer development system looks like a minicomputer system, but is built around the microcomputer of your choice.

Until you have made a final microcomputer selection, you will likely use a time-sharing service to convert your source programs to object program format. Eventually you are going to need access to a microcomputer development system (for step 7); therefore, it makes sense to get off the time-sharing service and to start using a microcomputer development system as soon as you have made your final microcomputer selection.

- 7) **Convert the object program into Programmable Read Only Memory devices (PROMs).** You will do this using the microcomputer development system that supports the microcomputer of your final choice.
- 8) **Build a prototype of your product.** Now is the time to ensure that all conceivable errors have been detected and corrected, both in the programs driving the microcomputer and in the logic supporting it. Correcting programming errors and logic design errors will require constant iteration between development steps, perhaps as far back as step 2.
- 9) **Create a ROM mask.** Unless your product is a low volume item, or is still being developed, economics dictate that you stop using PROMs and start using ROMs.

When you are certain that all your programs are correct, you will define ROM masks for your read only memory devices. ROMs will likely be created for you by the microcomputer manufacturer.

Programs that drive your microcomputer now become nothing more than logic devices, and will be handled routinely on the production line, like any other logic device.

**Within the framework of these nine steps, we are now in a position to explain how you go about estimating product development costs.**

**The most important factor determining microcomputer-based product development costs is the type of assistance you receive, either from the microcomputer manufacturer, or from an alternative source. Product development assistance can be divided into development hardware and system software.**

**Development hardware consists of a minicomputer-like device which you will use to implement some or all of steps 6 through 9. System software consists of programs that make the hardware usable.**

**We will describe microcomputer development hardware first, and system software next.**

## **MICROCOMPUTER DEVELOPMENT HARDWARE**

**At the center of any hardware development system, there will be a box that looks like a minicomputer.**

**In its simplest form, this box closely parallels a minicomputer.** Its Central Processing Unit is a microcomputer, which is surrounded by read/write memory, I/O interface, and logic to support the various options available with the microcomputer. All this is packaged in a minicomputer-like box, with a power supply and a front console. This "micro-minicomputer" will have minicomputer-style peripherals, including an input device, an output device and bulk storage devices.

A very simple micro-minicomputer system will consist of the microcomputer box and a teletype. The teletype keyboard is the input device, the teletype printer is the output device, and the teletype paper tape reader/punch is the bulk storage device.

#### SIMPLE MICROCOMPUTER DEVELOPMENT SYSTEMS

Source programs and any other human readable documentation will be printed by the teletype printer.

The source program you enter and the object program which the computer creates will both be output by the teletype paper tape punch. Subsequently, these paper tapes may be input via the teletype paper tape reader.

The first enhancement of this very simple hardware development system will be to stop using the teletype paper tape reader/punch as the bulk storage device, replacing it with a tape cartridge or floppy disk system, which is much faster and easier to handle.

The next enhancements will be to replace the teletype keyboard with a CRT terminal, and the teletype printer with a line printer.

At this point your microcomputer development system looks remarkably like a small minicomputer system, and you will use it, just as you would use a minicomputer system, to create source programs, and to convert source programs into object programs.

However, your microcomputer development system will have one feature which no minicomputer ever had: on the console of the microcomputer box there will be a plug, into which you can insert unused Programmable Read Only Memory devices. The development system will give you the ability to write any part of your object program into a PROM, via the console plug. You may take the PROM, plug it into a prototype board, and test the prototype product in the traditional way.

Every microcomputer manufacturer provides a straightforward microcomputer development system, as described above. The oldest and most popular microcomputers, such as the Intel 8080, now have more sophisticated development systems available. These more sophisticated development systems are produced not only by the microcomputer manufacturer, but by a number of independent companies who are rapidly entering the microcomputer development products business.

The first enhancement of the straightforward microcomputer development product, as described above, is a product that allows you to include a hardware simulation of the logic you are developing, within the microcomputer development system. Conceptually, such a system may be illustrated as follows:

#### SIMULATING MICROCOMPUTER DEVELOPMENT SYSTEMS



Since there is no established term to describe microcomputer development systems as illustrated above, we will call it a "Simulating Microcomputer Development System". In reality, the only parts of your system that will indeed be simulated are read only memory, interrupts, direct memory access and I/O.

If read only memory can be accurately simulated within the development system, then you will be able to bypass the Programmable Read Only Memory creation step, at least until you are certain (to the extent that you can be certain) that your programs are error-free.

By allowing the product you are developing to be handled as though it is an external device, the microcomputer development system serves the double purpose of allowing you to create object programs and, at the same time, of allowing you to check that the object programs, together with your external digital logic, perform as required. In theory, the microcomputer development system can now take you right up to the point where you can define your ROMs and organize a production line.

**Another development system enhancement that is appearing with greater frequency is the system that can handle more than one microcomputer.** Intel, for example, sells not only the Intel 8080A, which is described in this book, but also the Intel 8008, two 4-bit microprocessors and the 3000 Series chip slice. You can use Intel's ICE microcomputer development system to develop logic around any of the microcomputers sold by Intel.

Independent manufacturers of microcomputer development products are attracted to the idea of a microcomputer development system that can be used with more than one microcomputer, since this gives them the flexibility of selling into more than one manufacturer's market.

## MICROCOMPUTER SYSTEM SOFTWARE

**Neither a time-sharing computer service nor a microcomputer development system is of any value without programs that give you access to the capabilities of the system. We refer to these programs collectively as system software.**

We have described in Volume I, Chapter 6 how a program must first be written in a programming language using pencil and paper. The program is then converted into a sequence of binary digits, stored in computer memory. Microcomputer systems demand an additional step, that is, the creation of a read only memory device, within which the object program is implemented.

Figure 25-1 illustrates the components of system software which are routinely found in **EDITOR** microcomputer systems. The Editor, Assembler and Compiler have already been described in Volume I, Chapter 6. Referring to Figure 25-1, step 1 shows how an Editor program is loaded into computer memory and is used to create a source program, which is then stored in a computer-readable form on paper tape, magnetic cartridge or disk.

The Monitor is a small resident program that simply lets you identify and load individual system software modules.

**MONITOR**

In Figure 25-1, step 2, the source program is either assembled or compiled, depending upon whether the source program was written in assembly language or a higher level language. An object program is created.

**ASSEMBLER**

A number of aspects of source and object program creation are not self-evident. The first and most obvious question to ask is whether the amount of memory available in the microcomputer development system for source and object programs will be sufficient. In Figure 25-1, step 2, memory is illustrated holding, at one time, source programs, object programs, an Assembler or Compiler, and a Monitor. What if the source program and object program are simply too big to fit into memory as illustrated?

There is another potential problem, the object program developed in step 2 is almost certain to contain errors, and it is not unreasonable for a source program to be corrected and re-assembled ten, twenty or more times before an error-free object program results. **How long will it take to load the Editor for step 1, then reload the Assembler for step 2?**

Let us first consider those problems associated with the need to constantly edit and re-assemble a source program, while detecting and correcting program errors. Are there any hidden problems to watch out for in this process?

**EDITOR/  
ASSEMBLER  
COMBINED**



Figure 25-1 System Software Modules

If your development system uses magnetic tape cassettes or floppy disks as the bulk storage device, you will have no problems; it will just take a few seconds to load either the Assembler or Editor into memory; therefore, an inconsequential amount of time will be wasted shuttling between steps 1 and 2 of Figure 25-1.

On the other hand, if you are working with a very low budget and your development system uses the teletype paper tape reader/punch as the storage medium for all programs, you could be faced with a very severe problem; it could take as much as half an hour simply to load the Editor and Assembler into memory. This being the case, you will waste a very substantial amount of time and money watching the teletype paper tape reader monotonously load and punch paper tapes. **Some microcomputer manufacturers get around this problem by combining an Editor and Assembler into one program.** By breaking up your application into sufficiently small modules, you can generate a single memory load as follows:



Now you do not need to waste time reloading the Editor, and then the Assembler, every time you wish to make a correction to your source program.

**Let us first describe how you go about developing programs which are too big to constitute a single memory load, as illustrated in step 2 of Figure 25-1. The solution is self-evident: create the program in pieces. Implementation of this solution is not quite so straightforward.**

**RELOCATABLE  
OBJECT  
PROGRAMS**

If the program is to be developed in pieces, then clearly the pieces will each occupy different areas of memory. On the other hand, one specific area of memory may be assigned to object programs by the Assembler. This is the situation which arises:



The necessary solution is to create object programs which are one step removed from being truly executable. In these "pseudo-object programs", every object program byte that encodes an absolute memory address will instead encode a displacement from the beginning of the object program. This may be illustrated as follows:



This pseudo-object program will be loaded into memory by a system software program referred to as a "Relocatable Loader"; the Relocatable Loader acquires its name from the fact that it can relocate the pseudo-object program anywhere in memory, changing all the displacement addresses to reflect a new origin.

**RELOCATABLE  
LOADER**

An Assembler which is able to create pseudo-object programs as described above is called a Relocating Assembler.

**RELOCATING  
ASSEMBLER**

If programs have been written in pieces and the pieces must be loaded into memory to form a unit, then it is quite possible that a memory reference instruction in one piece of program may reference a label in another piece of program:

PROGRAM  
LINKING



A loader that can relocate program modules and, in addition, link memory references from one module to another is called a "Linking Loader".

LINKING  
LOADER

A Linking Loader works in conjunction with an Assembler that generates linkable object program modules.

LABEL TABLE

A Relocating Assembler will replace every absolute address in the object program with a code which represents a label number. Then, at the end of the object program, the Assembler will generate a Label Table identifying every label number as representing a specific object program byte in a defined object program module.

When the Linking Loader loads object program modules, it will identify the real memory address into which every object program byte which owns a label actually gets loaded. Now the Linking Loader can replace label numbers in object programs with the actual memory address that happens to correspond to the label number. For example, the Jump instruction illustrated above may get encoded by the Assembler as three bytes which say:

Jump to label number 4 in program module number 3.

At the end of the object program, the Assembler will, in some coded fashion, identify label number 4 as corresponding to byte number 32A16 of program module 3.

The Linking Loader will wait until program module number 3 has been loaded into memory, at which time it can determine the exact memory address for byte number 32A16 of program module 3. This memory address is equal to the origin of program module 3, plus 32A16. This becomes the address which the Linking Loader inserts into the Jump instruction.

The only thing that is important to you, as a microcomputer programmer, is to realize that, given a Relocating Assembler and a Linking Loader, you can write programs in small modules and not have to worry about changing object code depending upon where each module resides in memory.

It is very important to ascertain whether a microcomputer development system offers Relocating Assemblers and Linking Loaders, because they will make the task of developing object programs much simpler.

DEBUG

Once an object program has been created, it must be executed in order to check it for errors.

Another system software module, referred to as a Debug program, will always be required

at this point. The Debug program allows you to conditionally execute your object code, stopping at will to examine the contents of memory or programmable registers, or to temporarily make changes to the object program as a means of determining what went wrong.

While you are debugging your object programs, there are certain parts of your system which do not exist and whose presence must therefore be simulated. If you have a Simulating Microcomputer Development System, then the Simulator program only has to simulate interrupts, direct memory access, and external devices communicating through I/O ports.

If you have a simple microcomputer development system, then it must have a Simulator capable of representing the entire environment beyond your microcomputer.

UTILITIES

There is one further set of software modules which is extremely important in the world of minicomputers, but less important in the world of microcomputers; these are Utility and Input/Output routines.

There are a number of programming procedures which virtually every microcomputer application is going to encounter; these include routines to move data around memory, to transfer data between memory and external devices, or to perform arithmetic operations. In the world of minicomputers, such programs are bundled up as a package so that a minicomputer programmer never has to write programs to

SUBROUTINE  
LIBRARY

perform such basic operations. Instead, a minicomputer program will simply call subroutines out of a subroutine library in order to perform standard operations.

Is the same idea feasible in the world of microcomputers? Unfortunately, not always.

The concept of an I/O subroutine library is doubtful, since from one application to the next, you cannot even be sure that I/O will be implemented in the same way, let alone that external devices will be similar enough to allow any form of general purpose program to control input/output operations. Remember that we are no longer dealing with a CPU that interfaces with standard peripheral devices, such as disk, line printer, card reader, etc; we are dealing with a microcomputer that is connected to various and sundry discrete logic systems.

Even such routine operations as multibyte arithmetic frequently cannot be standardized. One microcomputer system may have a total of 512 bytes of memory; another may have 4096 bytes of memory. In each case, saving bytes will be extremely important. Any type of generalized program will be unacceptable if generality is bought at the price of extra memory bytes. An application that will never require more than 16 binary digit numbers cannot efficiently use a multibyte addition subroutine which has been written to handle multibyte numbers of indefinite length. The fact that someone else has already written that very general purpose multibyte addition program will not prevent you from rewriting your own addition program to serve your very limited needs — and nothing more. Your highly specialized addition program may only require half as much memory and in a product that may be reproduced thousands of times.

A microcomputer program written making liberal use of subroutines out of a library may well finish up using twice as much memory as a program written to meet the immediate needs of a single application. Suppose writing your own program allows you to reduce program memory from 2K bytes to 1K bytes of ROM. **Realistically, your programming expenses may be increased \$3,000 or \$4,000 because you did not use an existing subroutine library (presuming that such a library exists). However, your product does not have to have a very large volume before the extra programming expense becomes trivial compared to the money spent on extra memory devices, larger PC cards, more power supply and higher assembly expenses.**

**The very same argument determines whether you will write your source programs in assembly language or in a higher level language.** A higher level language will result in object programs that are anywhere from 2 to 1.4 times as long as the object program would have been had the source program been written in assembly language. On the other hand, it will probably take twice as long to develop programs in assembly language as it would to develop the same programs in a higher level language. You may have to deduct from the time saved, time your programmers spend learning a new language. In any event, it is clear that for very low volume systems, programming in a higher level language has always got to be more economical. In high volume systems, programming in assembly language has always got to be more economical and, depending upon individual circumstances, it becomes a tossup at some intermediate level.

## AN ECONOMIC EXAMPLE

**We will now give substance to the discussion of microcomputer development economics by looking at some hypothetical but realistic numbers.** Table 25-1 lists possible numbers for three different microcomputers. If we assume that fixed costs consist of programming expense and product development expense only, while variable costs consist of CPU and support device costs only, then Table 25-2 shows how unit costs will vary as a function of product volume.

Observe from Table 25-2 that **at very low volume, higher language program development is less expensive. If you are building more than a thousand units, on the other hand, in almost every case it will be cheaper to use assembly language programming.**

Costs associated with products A, B and C have been purposely skewed to demonstrate the impact of fixed and variable costs. Notice that product C, having lower fixed costs, generates the smallest unit price at low volume even though the cost of the microcomputer devices themselves is high.

The problem with Table 25-2 is that it oversimplifies the factors which influence eventual unit price. You should look at Table 25-2 as an illustration of general price versus volume relationships and nothing more.

Table 25-1. Some Typical Microcomputer Based Product and Development Costs

| SOURCE OF EXPENSE                                                               | MICROCOMPUTER SELECTED |           |           |
|---------------------------------------------------------------------------------|------------------------|-----------|-----------|
|                                                                                 | PRODUCT A              | PRODUCT B | PRODUCT C |
| Microcomputer CPU, plus support devices and logic (\$/unit)                     | 63                     | 78        | 91        |
| Cost of extra memory if programs are written in higher level language (\$/unit) | 10                     | 8         | 3         |
| Cost of writing programs (\$ total):                                            |                        |           |           |
| a) In assembly language                                                         | 8000                   | 7500      | 6500      |
| b) In higher level language                                                     | 5500                   | 5000      | 3000      |
| Cost of developing prototype (\$ total)                                         | 42000                  | 40000     | 40000     |

Table 25-2. Unit Prices For Microcomputer Based Products

| VOLUME | UNIT PRICE (\$)    |                  |                    |                  |                    |                  |
|--------|--------------------|------------------|--------------------|------------------|--------------------|------------------|
|        | PRODUCT A ASSEMBLY | PRODUCT A HIGHER | PRODUCT B ASSEMBLY | PRODUCT B HIGHER | PRODUCT C ASSEMBLY | PRODUCT C HIGHER |
| 100    | 563.00             | 548.00           | 553.00             | 536.00           | 556.00             | 524.00           |
| 500    | 163.00             | 168.00           | 173.00             | 176.00           | 184.00             | 180.00           |
| 1000   | 113.00             | 120.50           | 125.30             | 131.00           | 137.50             | 137.00           |
| 5000   | 73.00              | 82.50            | 87.50              | 95.00            | 100.30             | 102.60           |
| 10000  | 68.00              | 77.75            | 82.75              | 90.95            | 95.65              | 98.30            |

Assembly = Assembly language programming.

Higher = Higher level language programming

## A LOOK AT THE FUTURE

**Let us take a moment to gaze into a crystal ball.**

**What types of microcomputer products can we expect to see in the future, and what impact will they have on the minicomputer market?**

If there is one key aspect of microcomputer design which was not immediately apparent but is becoming more apparent every day, it is that the way logic is distributed among various devices of a microcomputer chip set is fundamentally the most important feature of any microcomputer product. Assembly language instruction sets, addressing modes and even instruction execution times are all of secondary importance in that they become inconsequential providing they meet modest criteria of sufficiency. The logic designer using microcomputers is likely to be far more influenced by control signals on the system bus and by the number of devices he has to work with, rather than by the complexity of the instruction set or its addressing modes. And this, we believe, is the key to a future drift into two types of microcomputer product: the logic device and the computer.

If there will be a branch of the microcomputer industry which builds minicomputer look-alikes, what impact will this have on the microcomputer industry? In truth, most manufacturers of computers, mini or larger, are already scrambling to build their central processing units and support logic out of large scale integration devices; therefore, we may conclude that within ten years every computer will be a microcomputer in that every computer will be built out of large scale integrated logic. This does not mean that the microcomputer manufacturers of today will overwhelm the minicomputer and large computer manufacturers of yesterday. This is because programming expenses constitute an already expended front end fixed cost for most users of minicomputers and larger computers; the hardware savings that might be gained by switching from a minicomputer to a microcomputer are simply insignificant when compared to reprogramming expenses.

Therefore, those minicomputer manufacturers who can defend their current sales with existing software are likely to be impacted very little by microcomputers. Those minicomputer manufacturers who are essentially selling components are likely to be eliminated from the component market entirely, unless they are able to scale down their minicomputers into microcomputers and survive as component suppliers at the new microcomputer price levels. It is this reduction in prices that opens a window for new products such as the National Semiconductor and Signetics microcomputers to attack markets that look characteristically like minicomputer markets. These are markets which were suited to minicomputer-type products, but in the past could not use minicomputers because of pricing considerations. Now that minicomputer-like devices are available for a few hundred dollars, a large number of new markets open up, none of

which have used minicomputers before and none of which have invested in the front end program development fixed costs; the new markets are therefore equally likely candidates for the old minicomputer manufacturer's product or the new microcomputer manufacturer's product. This pseudo-minicomputer buyer will be interested in buying a great deal of support in addition to hardware and will not be quite so influenced by small dollar differences going from one product to another.

It is in the area of discrete logic replacement that we may expect to see the greatest volatility among microcomputer manufacturers. The microcomputer user in this market will usually be buying in huge volumes with very little front end programming expense; therefore, this user has a much greater incentive to switch from one microcomputer to another, based solely on pricing considerations. This being the case, the logic device replacement market is the one which will be hardest for established microcomputer manufacturers to defend, and the most attractive to latecomers into the field.

It is quite probable that a microcomputer manufacturer who has not established a market for mls on the system bus and by the number of devices he has to work with, rather than by the complexity of the instruction set or its addressing modes. And this we believe is the key to a future drift into two types of microcomputer product: the logic device and the computer.

If there will be a branch of the microcomputer industry which builds minicomputer look-alikes, what impact will this have on the microcomputer industry? In truth, most manufacturers of computers, mini or larger, are already scrambling to build their central processing units and support logic out of large scale integration devices; therefore, we may conclude that within ten years every computer will be a microcomputer in that every computer will be built out of large scale integrated logic. This does not mean that the microcomputer manufacturers of today will overwhelm the minicomputer and large computer manufacturers of yesterday. This is because programming expenses constitute an already expended front end fixed cost for most users of minicomputers and larger computers; the hardware savings that might be gained by switching from a minicomputer to a microcomputer are simply insignificant when compared to reprogramming expenses.

Therefore, those minicomputer manufacturers who can defend their current sales with existing software are likely to be impacted very little by microcomputers. Those minicomputer manufacturers who are essentially selling components are likely to be eliminated from the component market entirely, unless they are able to scale down their minicomputers into microcomputers and survive as component suppliers at the new microcomputer price levels. It is this reduction in prices that opens a window for new products such as the National Semiconductor and Signetics microcomputers to attack markets that look characteristically like minicomputer markets. These are markets which were suited to minicomputer-type products, but in the past could not use minicomputers because of pricing considerations. Now that minicomputer-like devices are available for a few hundred dollars, a large number of new markets open up, none of which have used minicomputers before and none of which have invested in the front end program development fixed costs; the new markets are therefore equally likely candidates for the old minicomputer manufacturer's product or the new microcomputer manufacturer's product. This pseudo-minicomputer buyer will be interested in buying a great deal of support in addition to hardware and will not be quite so influenced by small dollar differences going from one product to another.

It is in the area of discrete logic replacement that we may expect to see the greatest volatility among microcomputer manufacturers. The microcomputer user in this market will usually be buying in huge volumes with very little front end programming expense; therefore, this user has a much greater incentive to switch from one microcomputer to another, based solely on pricing considerations. This being the case, the logic device replacement market is the one which will be hardest for established microcomputer manufacturers to defend, and the most attractive to latecomers into the field.

It is quite probable that a microcomputer manufacturer who has not established a market for minicomputer-like devices within the next two or three years will have no further opportunity to do so, however interesting the products he designs. No such window exists in the logic replacement market, where ten years from now a manufacturer who is able to sell microcomputer devices for 10¢ each, where the going rate has been 25¢ each, will be able to establish himself.

**In conclusion, we predict that microcomputer devices will separate into minicomputer look-alike and logic device replacements. The minicomputer look-alike market will become increasingly harder to break into and will stabilize fairly quickly. The logic device replacement market will continue to spawn products that look nothing like minicomputers and will continue to be extremely volatile until prices have been driven so low that there is simply no room left for further economies.**

**(We have not changed a word of this prediction from the first edition of December, 1975.)**

# **AN INTRODUCTION TO MICROCOMPUTERS VOLUME 2**

## **SOME REAL MICROPROCESSORS**

**1978-1979 Update Series**

**Update 5**

**July 1979**

**OSBORNE/McGraw-Hill  
Berkeley, California**

Update 5 of six of 1978-1979 Update Series to AN INTRODUCTION TO MICROCOMPUTERS: VOLUME 2 —SOME REAL MICROPROCESSORS September 1978, by Adam Osborne with Jerry Kane, published by the Osborne division of McGraw-Hill, Inc. Updates sold on a yearly subscription basis.

This update contains the following pages:

|                                                   |                                |
|---------------------------------------------------|--------------------------------|
| <b>Table of Contents</b> .....                    | <b>xx-c through xx-d</b>       |
| replace current page xx-c                         |                                |
| <b>List of Figures</b> .....                      | <b>xxx-a through xxx-b</b>     |
| replace current page xxx-a                        |                                |
| <b>List of Tables</b> .....                       | <b>xxxiv-a through xxxiv-b</b> |
| replace current page xxxiv-a                      |                                |
| <b>Quick Index</b> .....                          | <b>xlvii-g through xlvi-h</b>  |
| replace current page xlvi-g                       |                                |
| <b>Chapter 1, The PPS4/1</b> .....                | <b>1-49 through 1-D2</b>       |
| insert new material in page number order          |                                |
|                                                   | <b>1-D17 through 1-D22</b>     |
| <b>Chapter 9, The MC6809 Microprocessor</b> ..... | <b>9-175 through 9-D2</b>      |
| insert new material in page number order          |                                |
|                                                   | <b>9-D31 through 9-D39</b>     |

**OSBORNE/McGraw-Hill**  
630 Bancroft Way, Berkeley, California 94710  
United States of America  
(415) 548-2805  
TWX 910-366-7277

Copyright © 1979 by McGraw-Hill, Inc. All rights reserved. Printed in the United States of America. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form, or by any means, electronic, mechanical, photocopying, recording or otherwise, without the prior written permission of the publishers.

## TABLE OF CONTENTS — UPDATE 4

| CHAPTER |                                                                | PAGE       |
|---------|----------------------------------------------------------------|------------|
| 8       | <b>The Zilog Z8</b>                                            | <b>8-1</b> |
|         | Z8 Programmable Registers, Memory Spaces, and Addressing Modes | 8-3        |
|         | Z8 Status                                                      | 8-14       |
|         | Z8 Microcomputer Pins and Signals                              | 8-14       |
|         | Z8 External Memory Select Logic                                | 8-19       |
|         | Z8 Timing and Instruction Execution                            | 8-21       |
|         | Interrupt Logic                                                | 8-23       |
|         | Z8 Reset Operation                                             | 8-26       |
|         | Z8 Power-Down and Standby Power Supply                         | 8-27       |
|         | Z8 I/O Ports and I/O Data Transfers                            | 8-28       |
|         | Z8 Serial Input/Output                                         | 8-37       |
|         | Z8 Counter/Timer Logic                                         | 8-39       |
|         | The Z8 Instruction Set                                         | 8-44       |
|         | The Z8 Benchmark Program                                       | 8-44       |
|         | The Z8/64 Development Microcomputer                            | 8-53       |
|         | Data Sheets                                                    | 8-D1       |

## TABLE OF CONTENTS — UPDATE 5

| CHAPTER |                                                   | PAGE         |
|---------|---------------------------------------------------|--------------|
| 1       | <b>The PPS4/1</b>                                 | <b>1-50</b>  |
|         | PPS4/1 Programmable Registers                     | 1-52         |
|         | PPS4/1 Memory Addressing                          | 1-53         |
|         | PPS4/1 Status Flags                               | 1-53         |
|         | PPS4/1 Input and Output Logic                     | 1-54         |
|         | PPS4/1 Pins and Signals                           | 1-55         |
|         | PPS4/1 MM76C High-Speed Counter Option            | 1-59         |
|         | Description of PPS4/1 MM76C Counter Subsystem     | 1-60         |
|         | PPS4/1 Series Microcomputer Instruction Execution | 1-65         |
|         | PPS4/1 Series Microcomputer Instruction Set       | 1-65         |
|         | The Benchmark Program                             | 1-65         |
|         | PPS4/1 Instruction Mnemonics                      | 1-65         |
|         | PPS4/1 Instruction Object Codes                   | 1-65         |
|         | PPS4/1 Instruction Execution Times                | 1-66         |
|         | PPS4/1 Abbreviations                              | 1-66         |
|         | Data Sheets                                       | 1-D1         |
| 9       | <b>The MC6809 Microprocessor</b>                  | <b>9-175</b> |
|         | The MC6809 CPU                                    | 9-175        |
|         | The MC6809 Programmable Registers                 | 9-176        |
|         | MC6809 Memory Addressing Modes                    | 9-178        |
|         | MC6809 Status Flags                               | 9-186        |
|         | MC6809 CPU Pins and Signals                       | 9-186        |
|         | MC6809 Timing and Instruction Execution           | 9-189        |
|         | MC6809 Direct Memory Access                       | 9-191        |
|         | MC6809 Interrupt Processing and Reset             | 9-193        |
|         | The MC6809 Instruction Set                        | 9-198        |
|         | Data Sheets                                       | 9-D1         |



## LIST OF FIGURES — UPDATE 3

### FIGURE

| FIGURE                                                                          | PAGE  |
|---------------------------------------------------------------------------------|-------|
| 1-10 Logic of the COP400 Series of Microcomputers                               | 1-24  |
| 1-11 MICROBUS® Read Sequence                                                    | 1-29  |
| 1-12 MICROBUS® Write Sequence                                                   | 1-29  |
| 1-13 COP410L Signals and Pin Assignments                                        | 1-32  |
| 1-14 COP411L Signals and Pin Assignments                                        | 1-33  |
| 1-15 COP420, COP420C, and COP420L Signals and Pin Assignments                   | 1-34  |
| 1-16 COP421, COP421C, and COP421L Signals and Pin Assignments                   | 1-35  |
| 1-17 COP402 and COP402M Signals and Pin Assignments                             | 1-36  |
| 1-18 COP400 Clock Options                                                       | 1-38  |
| <br>                                                                            |       |
| 9-40 Logic of the MC6801 Microcomputer                                          | 9-132 |
| 9-41 MC6801 Functional Block Diagram                                            | 9-134 |
| 9-42 MC6801 Port 3 and Port 4 Usage                                             | 9-136 |
| 9-43 MC6801 Memory Map                                                          | 9-137 |
| 9-44 MC6801 Internal Registers                                                  | 9-138 |
| 9-45 MC6801 Signals and Pin Assignments                                         | 9-141 |
| 9-46 MC6801 Typical Mode Selection Circuit                                      | 9-143 |
| 9-47 MC6801 Interrupt Vectors                                                   | 9-144 |
| 9-48 MC6801 Port 3 Control/Status Register                                      | 9-146 |
| 9-49 MC6801 Port 3 Used in Handshake Mode                                       | 9-147 |
| 9-50 MC6801 Single-Chip Mode (Mode 7)                                           | 9-149 |
| 9-51 MC6801 Expanded, Non-Multiplexed Mode (Mode 5)                             | 9-149 |
| 9-52 Interfacing Standard MC6800 Peripherals to the MC6801                      | 9-151 |
| 9-53 MC6801 Non-Multiplexed Bus Timing (Read Cycle)                             | 9-151 |
| 9-54 MC6801 Non-Multiplexed Bus Timing (Write Cycle)                            | 9-152 |
| 9-55 Expanded, Multiplexed Mode (Mode 6)                                        | 9-152 |
| 9-56 MC6801 Expanded, Multiplexed System                                        | 9-154 |
| 9-57 MC6801 Bus Timing for MUX Operation (Read and Write)                       | 9-154 |
| 9-58 MC6801 Memory Maps for Multiplexed Operation                               | 9-155 |
| 9-59 MC6801 Timer Control/Status Register (TCSR)                                | 9-157 |
| 9-60 MC6801 Transmit/Receive Control and Status Register (TRCS)                 | 9-162 |
| 9-61 MC6801 SCI Rate/Mode Control Register                                      | 9-162 |
| <br>                                                                            |       |
| 10-1 Logic of MCS6500 Series CPU Devices                                        | 10-3  |
| 10-2 MCS6502 Signals and Pin Assignments                                        | 10-9  |
| 10-3 MCS6503 Signals and Pin Assignments                                        | 10-10 |
| 10-4 MCS6504 Signals and Pin Assignments                                        | 10-11 |
| 10-5 MCS6505 Signals and Pin Assignments                                        | 10-12 |
| 10-6 MCS6506 Signals and Pin Assignments                                        | 10-13 |
| 10-7 MCS6512 Signals and Pin Assignments                                        | 10-14 |
| 10-8 MCS6513 Signals and Pin Assignments                                        | 10-15 |
| 10-9 MCS6514 Signals and Pin Assignments                                        | 10-16 |
| 10-10 MCS6515 Signals and Pin Assignments                                       | 10-17 |
| 10-11 Time Base Generation for MCS650X CPU Input Clocks                         | 10-21 |
| 10-12 Logic of the MCS6522 PIA                                                  | 10-35 |
| 10-13 MCS6522 PIA Signals and Pin Assignments                                   | 10-36 |
| 10-14 Auxiliary Control Register Bit Assignments                                | 10-40 |
| 10-15 Peripheral Control Register Bit Assignments                               | 10-40 |
| 10-16 Logic of the MCS6530, the R6531 and MCS6532 Multifunction Support Devices | 10-55 |
| 10-17 Logic Provided by the MCS6530 Multifunction Device                        | 10-56 |
| 10-18 MCS6530 Multifunction Device Signals and Pin Assignments                  | 10-57 |
| 10-19 Logic Provided by the MCS6532 Multifunction Device                        | 10-60 |
| 10-20 MCS6532 Multifunction Device Signals and Pin Assignments                  | 10-61 |
| 10-21 Logic Provided by the R6531 Multifunction Device                          | 10-64 |
| 10-22 R6531 Multifunction Device Signals and Pin Assignments                    | 10-65 |
| 10-23 SY6551 ACIA Signals and Pin Assignments                                   | 10-77 |
| 10-24 SY6551 Interrupt Service Routine, Status Register Testing Logic Portion   | 10-85 |

## LIST OF FIGURES — UPDATE 4

| FIGURE |                                                     | PAGE |
|--------|-----------------------------------------------------|------|
| 8-1    | Functional Logic Included in the Z8 Microcomputer   | 8-2  |
| 8-2    | Z8 Microcomputer Block Diagram                      | 8-3  |
| 8-3    | Z8 Microcomputer Address Spaces                     | 8-4  |
| 8-4    | Z8 Microcomputer Internal Registers                 | 8-5  |
| 8-5    | Z8 Microcomputer Signals and Pin Assignments        | 8-13 |
| 8-6    | A Z8 Memory Read or Instruction Fetch Machine Cycle | 8-22 |
| 8-7    | A Z8 Memory Write Machine Cycle                     | 8-23 |
| 8-8    | Z8 Interrupt Acknowledge Sequence                   | 8-26 |
| 8-9    | Z8 Counter/Timer Logic                              | 8-39 |

## LIST OF FIGURES — UPDATE 5

| FIGURE |                                                    | PAGE  |
|--------|----------------------------------------------------|-------|
| 1-19   | Logic of the PPS4/1 Family of Microcomputers       | 1-51  |
| 1-20   | PPS4/1 MM75 Pins and Signals                       | 1-55  |
| 1-21   | PPS4/1 MM76 and MM76E Pins and Signals             | 1-56  |
| 1-22   | PPS4/1 MM76L and MM76EL Pins and Signals           | 1-57  |
| 1-23   | PPS4/1 MM77 and MM78 Pins and Signals              | 1-58  |
| 1-24   | MM76C Counter Logic                                | 1-61  |
| 1-25   | PPS4/1 MM76C Pins and Signals                      | 1-62  |
| 1-26   | Generation of Quadrature Inputs                    | 1-63  |
| 9-62   | Logic of the MC6809 Microprocessor                 | 9-176 |
| 9-63   | MC6809 Direct Page Addressing Scheme               | 9-178 |
| 9-64   | MC6809 Post Byte Bit Assignments                   | 9-179 |
| 9-65   | MC6809 Constant Offset (Indexed Mode) Addressing   | 9-180 |
| 9-66   | MC6809 Constant Offset Indexed Indirect Addressing | 9-183 |
| 9-67   | MC6809 Long Branch Addressing                      | 9-184 |
| 9-68   | MC6809 Relative Indirect Addressing                | 9-185 |
| 9-69   | MC6809 CPU Signals and Pin Assignments             | 9-187 |
| 9-70   | MC6809 E and Q Timing for Write Cycles             | 9-190 |
| 9-71   | MC6809 E and Q Timing for Read Cycles              | 9-190 |
| 9-72   | MC6809 Timing and Signals for Cycle-Stealing DMA   | 9-192 |
| 9-73   | MC6809 Signals for Externally Vectored Interrupts  | 9-195 |
| 9-74   | MC6809 SYNC Instruction Logic                      | 9-197 |

## LIST OF TABLES — UPDATE 4

### TABLE

|     | PAGE |
|-----|------|
| 8-1 | 8-24 |
| 8-2 | 8-27 |
| 8-3 | 8-29 |
| 8-4 | 8-30 |
| 8-5 | 8-41 |
| 8-6 | 8-45 |
| 8-7 | 8-46 |
| 8-8 | 8-55 |

- |                                                                       |      |
|-----------------------------------------------------------------------|------|
| Z8 Interrupt Sources                                                  | 8-24 |
| Z8 Control Register Contents Following a Reset                        | 8-27 |
| Z8 I/O Port Data Transfers with Handshaking                           | 8-29 |
| Z8 I/O Ports 0, 1, and 2 Options Summary                              | 8-30 |
| Counter/Timer 0 Baud Rate Generation                                  | 8-41 |
| Mnemonics, Object Code Bits and Interpretation for Z8 Condition Codes | 8-45 |
| A Summary of the Z8 Microcomputer Instruction Set                     | 8-46 |
| Z8 Instructions Listed by Op-code                                     | 8-55 |

## LIST OF TABLES — UPDATE 5

|      | PAGE  |
|------|-------|
| 1-11 | 1-50  |
| 1-12 | 1-53  |
| 1-13 | 1-68  |
| 1-14 | 1-75  |
| 1-15 | 1-76  |
| 1-16 | 1-77  |
| 9-19 | 9-179 |
| 9-20 | 9-188 |
| 9-21 | 9-202 |
| 9-22 | 9-204 |

### TABLE

- |                                                               |       |
|---------------------------------------------------------------|-------|
| Summary of the PPS4/1 Family of Microcomputers                | 1-50  |
| PPS4/1 ROM Addressing Sequence                                | 1-53  |
| A Summary of the PPS4/1 Microcomputer Instruction Set         | 1-68  |
| PPS4/1 Instruction Mnemonics                                  | 1-75  |
| PPS4/1 MM75, MM76 Instruction Object Codes                    | 1-76  |
| PPS4/1 MM77, MM78 Instruction Object Codes                    | 1-77  |
| MC6809 Indexed Addressing Post Byte Register Bit Assignments  | 9-179 |
| MC6809 Bus Status Signals                                     | 9-188 |
| MC6809 Mnemonics (New and Modified Instructions are Shaded)   | 9-202 |
| A Summary of the New and Enhanced Instructions for the MC6809 | 9-204 |



## **QUICK INDEX — UPDATE 4 (Continued)**

### **INDEX**

|                                                   | <b>PAGE</b> |
|---------------------------------------------------|-------------|
| Z8 Register Indirect Addressing                   | 8-9         |
| Z8 Registers                                      | 8-6         |
| Z8 Serial I/O Character Format                    | 8-38        |
| Z8 Serial I/O Counter/Timer O Baud Rate Generator | 8-40        |
| Z8 Serial I/O Overflow Error                      | 8-38        |
| Z8 Serial I/O Overrun                             | 8-38        |
| Z8 Serial I/O Parity Error                        | 8-38        |
| Z8 Serial I/O Parity Logic                        | 8-37        |
| Z8 Serial I/O Receive Logic                       | 8-38        |
| Z8 Serial I/O Select                              | 8-37        |
| Z8 Serial I/O Transmit Logic                      | 8-38        |
| Z8 Stack                                          | 8-12        |
| Z8 Stack Location Select                          | 8-35        |
| Z8 Stack Pointer                                  | 8-35        |
| Z8 Word Addressing                                | 8-9         |
| Z8 Working Registers                              | 8-6         |

## QUICK INDEX — UPDATE 5

| <b>INDEX</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>PAGE</b>                                                                                                                                                                                                                                                                                                                               |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>E</b>     | External VMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 9-192                                                                                                                                                                                                                                                                                                                                     |
| <b>M</b>     | MC6809 Accessing Slow Devices<br>MC6809 Accumulator Offset Addressing<br>MC6809 Added Mnemonics<br>MC6809 Auto Decrement Addressing<br>MC6809 Auto Increment Addressing<br>MC6809 Bus Grant<br>MC6809 Bus State Controls<br>MC6809 Clock Options<br>MC6809 Constant Offset Indexing Addressing<br>MC6809 Cycle-Stealing DMA<br>MC6809 Direct Page Addressing<br>MC6809 Exchange Register and Transfer Register Post Byte<br>MC6809 Fast Interrupt Request<br>MC6809 Halt Mode DMA<br>MC6809 Hardware-Software Synchronization<br>MC6809 Indexed Addressing<br>MC6809 Indexed Indirect Addressing<br>MC6809 Interrupt Priorities<br>MC6809 Interrupt Vector Addresses<br>MC6809 Interrupt Vectoring by External Devices<br>MC6809 LEA Instruction<br>MC6809 Missing Mnemonics<br>MC6809 Non-Maskable Interrupt<br>MC6809 Post Byte<br>MC6809 Push and Pull Instructions<br>MC6809 Read Timing<br>MC6809 Relative Addressing<br>MC6809 Relative Indirect Addressing<br>MC6809 Reset<br>MC6809 Software Interrupts SWI, SWI2 and SWI3<br>MC6809 Stacking During Interrupts<br>MC6809 Standard Hardware Interrupts<br>MC6809 SYNC Instruction<br>MC6809 Use of SYNC for DMA<br>MC6809 VMA Condition<br>MC6809 Write Timing<br>MC6809 Zero Offset Addressing | 9-191<br>9-181<br>9-199<br>9-182<br>9-182<br>9-191<br>9-188<br>9-189<br>9-180<br>9-192<br>9-178<br>9-200<br>9-194<br>9-191<br>9-196<br>9-178<br>9-182<br>9-194<br>9-193<br>9-194<br>9-200<br>9-199<br>9-194<br>9-178<br>9-199<br>9-190<br>9-182<br>9-185<br>9-194<br>9-196<br>9-196<br>9-194<br>9-196<br>9-198<br>9-188<br>9-190<br>9-181 |
| <b>P</b>     | PPS4/1 Clock Logic<br>PPS4/1 MM76C Clock Logic<br>PPS4/1 MM76C Counter Instructions<br>PPS4/1 Decode Matrix<br>PPS4/1 Interrupt Inputs<br>PPS4/1 Memory Addressing<br>PPS4/1 Parallel I/O<br>PPS4/1 Serial I/O<br>PPS4/1 Status Flags                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1-58<br>1-65<br>1-64<br>1-54<br>1-54<br>1-53<br>1-54<br>1-54<br>1-54<br>1-53                                                                                                                                                                                                                                                              |

## ATTENTION WRITERS

OSBORNE/McGraw-Hill is seeking qualified contributors to future updates of Volumes 2 and 3. Qualified contributors must have an excellent technical background, and they must be able to write clearly and without bias toward any manufacturer of products covered. Faculty at universities are particularly welcome as contributors.

A contributor, when selected, will be assigned a specific category of parts to keep updated. Keeping parts updated will include describing new parts in the category as they appear, and improving the description of parts that are already covered. Individual one-time contributions are also welcome.

If you would like to become a contributor to Volume 2 and/or Volume 3, please write stating your qualifications and the categories that you believe you could cover competently. If possible, send us a sample of your work; we suggest two or three pages of a part description following the format presented in these books as closely as possible. Send material to:

**OSBORNE/McGraw-Hill  
630 Bancroft Way  
Berkeley, California 94710**

**Attention: Volume 2/3 Contributors**

Table 1-10. National Semiconductor COP400 Series Instruction Object Codes

| INSTRUCTION | OBJECT CODE                     | BYTES          |   |
|-------------|---------------------------------|----------------|---|
| ADD         | 31                              | 1              |   |
| ADT         | 4A                              | 1              | * |
| AISC        | data4<br>0101dddd               | 1              |   |
| ASC         |                                 | 1              |   |
| CAB         | 50                              | 1              |   |
| CAMQ        | 33 3C                           | 2              |   |
| CASC        | 10                              | 1              | * |
| CBA         | 4E                              | 1              |   |
| CLRA        | 00                              | 1              |   |
| COMP        | 40                              | 1              |   |
| CQMA        | 33 2C                           | 2              | * |
| HLTT        | 33 39                           | 2              | * |
| ING         | 33 2A                           | 2              |   |
| INIL        | 33 29                           | 2              | * |
| ININ        | 33 28                           | 2              | * |
| INL         | 33 2E                           | 2              |   |
| JID         | FF                              | 1              |   |
| JMP         | addr10<br>011000pp<br>mm        | 2              |   |
| JP          |                                 | 11qqqqqq       | 1 |
| JP          | addr7<br>1nnnnnnn               | 1              |   |
| JSR         |                                 | 011010pp<br>mm | * |
| JSRP        | addr6<br>LBI<br>reg,digit<br>33 | 10qqqqqq       | 1 |
| LBI         |                                 | 10rrrrrr       | 2 |
| LD          | reg,digitp<br>00rr0101          | 00rreeee       | 1 |
| LDD         |                                 | 00rr0100       | 1 |
|             |                                 | 23             | 2 |
|             |                                 | 00rrrrrr       |   |

\* This instruction is not available on all COP400 models.

| INSTRUCTION | OBJECT CODE           | BYTES    |   |
|-------------|-----------------------|----------|---|
| LEI         | data4<br>0110dddd     | 33       | 2 |
| LQID        |                       | BF       | 1 |
| NOP         | 44                    | 1        |   |
| OBD         | 33 3E                 | 2        |   |
| OGI         | data4<br>0101dddd     | 33       | * |
| OMG         |                       | 33 3A    | 2 |
| RC          | 32                    | 1        |   |
| RET         | 48                    | 1        |   |
| RETSK       | 49                    | 1        |   |
| RMB         | bit<br>0100bbbb       | 22       | 1 |
| SC          |                       | 20       | 1 |
| SKC         | 21                    | 1        |   |
| SKE         | 33                    | 2        |   |
| SKGBZ       | bit<br>000cccc1       | 000cccc1 |   |
| SKGZ        |                       | 33 21    | 2 |
| SKMBZ       | bit<br>000cccc1       | 000cccc1 | 1 |
| SKT         |                       | 41       | * |
| SMB         | bit<br>0100aaaa       | 0100aaaa | 1 |
| STII        |                       | 0111dddd | 1 |
| X           | reg<br>00rr0110       | 00rr0110 | 1 |
| XABR        |                       | 12       | 1 |
| XAD         | reg,digit<br>10rrrrrr | 23       | 2 |
| XAS         |                       | 4F       | 1 |
| XDS         | reg<br>00rr0111       | 00rr0111 | 1 |
| XIS         |                       | 00rr0100 | 1 |
| XOR         | 02                    | 1        |   |

\* This instruction is not available on all COP400 models.

## THE PPS4/1

**The PPS4/1 family of microcomputers was developed as the single-chip replacement for the Rockwell PPS4 family.** The PPS4/1 family has been used extensively in consumer products. Its sales, like those of the other established 4-bit microcomputers, number in the millions. The PPS4/1 is very similar to the TMS1000. Both share similar approaches to memory organization, both have a similar I/O structure, and both lack a true interrupt capability. The major differences between the two families are:

- 1) Most models of the PPS4/1 family have a serial I/O capability.
- 2) The PPS4/1 microcomputers are not microprogrammable, as is the TMS1000.
- 3) The PPS4/1 family has a special purpose member, the PPS4/1 MM76C, which handles high-speed counting. The TMS1000 has no counterpart to this processor.

There are ten members of the PPS4/1 family. They are summarized in Table 1-11.

Figure 1-19 illustrates those parts of our general microcomputer model implemented by the PPS4/1 microcomputer. This figure is deceptive, since it would appear that a PPS4/1 has a System Bus. This is not the case. The bus illustrated is purely internal. The only means available to a PPS4/1 for communication to the outside world is via its I/O pins. **No provision for external RAM or ROM has been made.** Furthermore, the operations provided are primitive compared to those in 8-bit microprocessors or their support devices. For example, the serial I/O logic of the PPS4/1 cannot be compared to that of the Intel 8251 USART, or even the 1602 UART. The serial I/O logic merely serializes a 4-bit nibble into a bit stream (and the inverse). No provision is made for synchronization or for detecting framing or overrun errors. Buffering must be explicitly performed by the software. Nonetheless, the serial I/O interface is a very useful feature.

Table 1-11. Summary of the PPS4/1 Family of Microcomputers

|                                               | MM75        | MM76        | MM76C       | MM76E       | MM76EL      | MM76L       | MM77        | MM77L       | MM78        | MM78L       |
|-----------------------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| <b>ROM (bytes)</b>                            | 640         | 640         | 640         | 1024        | 1024        | 640         | 1344        | 1536        | 2048        | 2048        |
| <b>RAM (nibbles)</b>                          | 48          | 48          | 48          | 48          | 48          | 48          | 96          | 96          | 128         | 128         |
| <b>Total I/O Lines</b>                        | 22          | 31          | 39          | 31          | 31          | 31          | 31          | 31          | 31          | 31          |
| <b>Conditional Interrupt</b>                  | 1           | 2           | 2           | 2           | 2           | 2           | 2           | 2           | 2           | 2           |
| <b>Input</b>                                  | 4           | 8           | 8           | 8           | 8           | 8           | 8           | 8           | 8           | 8           |
| <b>Bidirectional</b>                          | 17          | 18          | 18          | 18          | 18          | 18          | 18          | 18          | 18          | 18          |
| <b>Serial</b>                                 | --          | 3           | 3           | 3           | 3           | 3           | 3           | 3           | 3           | 3           |
| <b>Package (Dual In-Line or Quad In-Line)</b> | 28-pin dual | 42-pin quad | 52-pin quad | 42-pin quad | 40-pin dual | 40-pin dual | 42-pin quad | 40-pin dual | 42-pin quad | 40-pin dual |
| <b>Supply Voltage (V)</b>                     | -15         | -15         | -15         | -15         | -11 to -6.5 | -11 to -6.5 | -15         | -11 to -6.5 | -15         | -11 to -6.5 |
| <b>Supply Current (mA)</b>                    | 8           | 8           | 12          | 3           | 3           | 3           | 8           | 3           | 8           | 3           |

All devices of the PPS4/1 family are implemented using PMOS technology.

A single -15 volt power supply is required for all members of the PPS4/1 family except the L series parts (MM76EL, MM76L, MM77L, and MM78L). The L series parts will work with a power supply in the range of -11.0 to -6.5 volts with as little as 3 mA of current. This makes them quite suitable for battery powered applications.

Most members of the PPS4/1 family operate at a maximum clock frequency of 80 kHz, which gives a 12.5 microsecond cycle time. The L series parts can run at up to 100 kHz, yielding a 10 microsecond cycle time. Since all instructions execute in one or two clock cycles, the PPS4/1 has a slight speed advantage over the TMS1000, but is at a severe speed disadvantage to the COP series.

The primary manufacturer of the PPS4/1 series is:

ROCKWELL INTERNATIONAL  
Microelectronic Device Division  
P.O. Box 3669  
Anaheim, CA 92803



Figure 1-19. Logic of the PPS4/1 Family of Microcomputers

## PPS4/1 PROGRAMMABLE REGISTERS

PPS4/1 programmable registers may be illustrated as follows:



**The Accumulator acts as a primary Accumulator in a single-address machine architecture.** It is the principal source and destination of every arithmetic and logical operation.

**The B register is the primary Data Counter.** The only way to access locations in RAM is implied addressing via the B register. RAM cannot be directly addressed on the PPS4/1. The RAM memory is addressed as a contiguous block of 4-bit nibbles. **The B register is often treated as two separate registers concatenated together, called B lower and B upper.** B lower consists of the least significant four bits of the B register, while B upper consists of the most significant two or three bits of the B register. This division is necessary due to the 4-bit data paths within the PPS4/1. Many instructions will operate on B lower differently than on B upper. For example, the INCB instruction increments B lower while exclusive-ORing B upper with an immediate value. For this reason **it is often convenient to view the RAM memory as a collection of 16-nibble pages.** Many operations will show a wrap-around effect within a single 16-nibble page, since these operations modify B lower but not B upper.

**The X register is used as a scratch register and as a buffer register for certain I/O operations.** The X register is present on the MM77, MM77L, MM78, and MM78L models of the PPS4/1 family.

**The S register** is used by serial I/O logic. It **holds parallel data that is being shifted in or shifted out.**

**The P register is the Program Counter.** It consists of two parts, a 5-bit Page register and a 6-bit Offset register. Program memory is separate from data memory and is read-only. **Program memory is organized as 32 pages of 64 bytes each.** Single-byte subroutine call instructions always transfer to the two highest pages of the program address space, i.e., pages 30 and 31 (addresses 780<sub>16</sub> - 7FF<sub>16</sub>). The PPS4/1 uses circular shift logic rather than an adder to increment the Program Counter. This means that the instructions in a given page are not in sequential order. This is of no significance except to the assembler and other program development software. Table 1-12 lists the correspondence between execution sequence and physical addresses within a page.

**The SA register is a return address save register.** It is used for saving the return address during a subroutine call. The MM77, MM77L, MM78, and MM78L all have an additional save register called the SB register. The SA and SB registers function as a two-level Stack. Hence the MM77, MM77L, MM78, and MM78L can have two levels of subroutine nesting rather than just one.

Table 1-12. PPS4/1 ROM Addressing Sequence

| Execution Sequence | Address      |           |
|--------------------|--------------|-----------|
|                    | Binary Value | Hex Value |
| 0                  | 000000       | 00        |
| 1                  | 100000       | 20        |
| 2                  | 010000       | 10        |
| 3                  | 001000       | 08        |
| 4                  | 000100       | 04        |
| 5                  | 000010       | 02        |
| 6                  | 100001       | 21        |
| 7                  | 110000       | 30        |
| 8                  | 011000       | 18        |
| 9                  | 001100       | 0C        |
| 10                 | 000110       | 06        |
| 11                 | 100011       | 23        |
| 12                 | 010001       | 11        |
| 13                 | 101000       | 28        |
| 14                 | 010100       | 14        |
| 15                 | 001010       | 0A        |
| 16                 | 100101       | 25        |
| 17                 | 110010       | 32        |
| 18                 | 111001       | 39        |
| 19                 | 111100       | 3C        |
| 20                 | 011110       | 1E        |
| 21                 | 101111       | 2F        |
| 22                 | 010111       | 17        |
| 23                 | 001011       | 0B        |
| 24                 | 000101       | 05        |
| 25                 | 100010       | 22        |
| 26                 | 110001       | 31        |
| 27                 | 111000       | 38        |
| 28                 | 011100       | 1C        |
| 29                 | 001110       | 0E        |
| 30                 | 100111       | 27        |
| 31                 | 010011       | 13        |
| 32                 | 001001       | 09        |
| 33                 | 100100       | 24        |
| 34                 | 010010       | 12        |
| 35                 | 101001       | 29        |
| 36                 | 110100       | 34        |
| 37                 | 011010       | 1A        |
| 38                 | 101101       | 2D        |
| 39                 | 110110       | 36        |
| 40                 | 111011       | 3B        |
| 41                 | 011101       | 1D        |
| 42                 | 101110       | 2E        |
| 43                 | 110111       | 37        |
| 44                 | 011011       | 1B        |
| 45                 | 001101       | 0D        |
| 46                 | 100110       | 26        |
| 47                 | 110011       | 33        |
| 48                 | 011001       | 19        |
| 49                 | 101100       | 2C        |
| 50                 | 010110       | 16        |
| 51                 | 101011       | 2B        |
| 52                 | 010101       | 15        |
| 53                 | 101010       | 2A        |
| 54                 | 110101       | 35        |
| 55                 | 111010       | 3A        |
| 56                 | 111101       | 3D        |
| 57                 | 111110       | 3E        |
| 58                 | 111111       | 3F        |
| 59                 | 011111       | 1F        |
| 60                 | 001111       | 0F        |
| 61                 | 000111       | 07        |
| 62                 | 000011       | 03        |
| 63                 | 000001       | 01        |

## PPS4/1 MEMORY ADDRESSING

The PPS4/1 contains separate and distinct program and data memories. Program memory is strictly read-only. Instructions cannot be executed out of data memory. Program memory can be addressed only by instruction execution. No means of storing constants in program memory has been provided other than as the operand of immediate instructions. The branch instructions provided allow program memory to be addressed in its entirety, in banks of 16 pages or as 64-byte pages. The top two pages of program memory are the primitive subroutine pages. These pages can be addressed from anywhere in the program address space by the TM instruction with only a 6-bit address. Frequently used subroutines should be located in these pages.

Data memory is addressed via implied addressing. The B register is used as a data counter which addresses data memory. There are no other means of accessing data memory.

## PPS4/1 STATUS FLAGS

The PPS4/1 has only one program-accessible status flag — the Carry.

There is also an internal skip status bit; if this bit is set during an instruction execution, the following instruction will be skipped.

**PPS4/1  
MEMORY  
ADDRESSING**

**PPS4/1  
STATUS  
FLAGS**

## PPS4/1 INPUT AND OUTPUT LOGIC

All members of the PPS4/1 family have parallel I/O capability. All members of the PPS4/1 family except the MM75 also have a serial I/O capability.

There are four types of parallel I/O available in the PPS4/1 series. They are:

- 1) 4-bit parallel input ports
- 2) 4-bit bidirectional ports
- 3) Discrete I/O lines
- 4) Conditional interrupts

PPS4/1  
PARALLEL  
I/O

**All members of the PPS4/1 family except the MM75 have two parallel input ports.** The MM75 has only one parallel input port. These 4-bit ports are referred to as the **P inputs**. The two P ports are referred to as Channel 1 (pins P1 - P4) and Channel 2 (pins P5 - P8). The signals entering Channel 2 are internally inverted before reaching the Accumulator. The MM75 implements only Channel 1.

**All members of the PPS4/1 family have two bidirectional 4-bit ports, referred to as the R ports.** On all PPS4/1 microprocessors pins R1 - R4 are called Channel A. On the MM75, MM76, MM76E, MM76EL, and MM76L pins R5 - R8 are called Channel B. On the MM75, MM76, MM76E, MM76EL, and MM76L both the A and B channels' outputs can be obtained from a 16 x 8 decode matrix. This matrix allows a 4-bit quantity in the Accumulator to generate an 8-bit output. This is very helpful for applications using seven-segment displays. The contents of the decode matrix are alterable as a mask option. The standard chip comes with a BCD to seven-segment conversion table in the decode matrix. Loading the Accumulator with the digits 0 - F<sub>16</sub> allows Channels A and B to output the seven-segment codes for 0 - 9, A, -, P, D, E, and blank, respectively. The MM77, MM77L, MM78, and MM78L lack this decode matrix capability. On these processors R5 - R8 are referred to as Channel X. Channel X is routed through the X register on both input and output. Channel A functions normally except for the lack of the decode matrix on output.

PPS4/1  
DECODE  
MATRIX

**All members of the PPS4/1 family except the MM75 have a 10-bit discrete I/O port called the D port. The MM75 has a 9-bit D port.** The lines comprising the D port can be read or written independently (i.e., individual bits of the port can be manipulated). This port is designed for use with asynchronous inputs.

**All members of the PPS4/1 family have two conditional interrupt lines.** The MM75 has only one dedicated conditional interrupt input. However, R8 can be used as either an R input or an interrupt line. The conditional interrupt lines INT0 and INT1 are very similar to the D port lines, except that they can be tested by a single instruction. This feature allows the rapid testing of the conditional interrupt lines. Note that this is not a true interrupt capability. The microprocessor is not interrupted asynchronously. Instead, the program must test for the interrupt condition and take appropriate action.

PPS4/1  
INTERRUPT  
INPUTS

All members of the PPS4/1 family except the MM75 have a serial I/O facility. This facility is implemented via three I/O lines connected to the S register: a serial input line, a serial output line, and a bidirectional serial shift clock line. The serial output line is connected to the high-order bit of the S register. Data to be shifted out is first transferred from the Accumulator to the S register. When the S register is shifted, the new high-order bit appears on the serial output line, and the value of the serial input line is shifted into the low-order bit of S. Two types of serial I/O timing are allowed: internal and external. If operation with the internal shift clock is selected, then the shift operation begins after an IOS instruction and takes two cycles of the internal clock (CLK<sub>A</sub>) for each bit or eight cycles for four bits. A data clock is output on the Shift Clock line. The timing can be illustrated as follows:

PPS4/1  
SERIAL I/O



If an externally supplied shift clock is provided, the S register is shifted left once for each CLKA cycle that the shift clock is input high. This timing is shown below:



## PPS4/1 PINS AND SIGNALS

**Figures 1-20 through 1-23 illustrate the pins and signals for most members of the PPS4/1 family.** Note that the majority of the signals are consistent across the entire PPS4/1 family. For this reason we will combine the discussions of pins and signals for all members of the PPS4/1 family. The MM76C and its pins and signals are described later in this section.

Data inputs are provided by P1 - P8. P1 - P4 constitute the Channel 1 input port, while P5 - P8 constitute the Channel 2 input port.



| Pin Name                         | Description       | Type                      |
|----------------------------------|-------------------|---------------------------|
| DO-D8                            | Discrete I/O Pins | Bidirectional, Open Drain |
| P1-P4                            | Input Port        | Input                     |
| R1-R8/INT1                       | I/O Port          | Bidirectional, Open Drain |
| INT0,R8/INT1                     | Interrupt Request | Input                     |
| P0                               | Power-on Reset    | Input                     |
| V <sub>C</sub>                   | Clock             | Input                     |
| CLKA                             | Clock             | Output                    |
| TEST                             | Device Test       | Input                     |
| V <sub>DD</sub> ,V <sub>SS</sub> | Power, Ground     | Input                     |

Figure 1-20. PPS4/1 MM75 Pins and Signals



| Pin Name                            | Description        | Type                      |
|-------------------------------------|--------------------|---------------------------|
| D0-D9                               | Discrete I/O Pins  | Bidirectional, Open Drain |
| P1-P8                               | Input Port         | Input                     |
| R1-R8                               | I/O Port           | Bidirectional, Open Drain |
| SDI                                 | Serial Data Input  | Input                     |
| SDO                                 | Serial Data Output | Output                    |
| SSC                                 | Serial Shift Clock | Bidirectional, Open Drain |
| INT0, INT1                          | Interrupt Request  | Input                     |
| PO                                  | Power-on Reset     | Input                     |
| V <sub>C</sub> , EXCLK, CLKIN       | Clock              | Input                     |
| CLK <sub>A</sub> , CLK <sub>B</sub> | Clock              | Output                    |
| TEST                                | Device Test        | Input                     |
| V <sub>DD</sub> , V <sub>SS</sub>   | Power, Ground      | Input                     |

Figure 1-21. PPS4/1 MM76 and MM76E Pins and Signals



| Pin Name                            | Description        | Type                      |
|-------------------------------------|--------------------|---------------------------|
| D0-D9                               | Discrete I/O Pins  | Bidirectional, Open Drain |
| P1-P8                               | Input Port         | Input                     |
| R1-R8                               | I/O Port           | Bidirectional, Open Drain |
| SDI                                 | Serial Data Input  | Input                     |
| SDO                                 | Serial Data Output | Output                    |
| SSC                                 | Serial Shift Clock | Bidirectional, Open Drain |
| INT0, INT1                          | Interrupt Request  | Input                     |
| PO                                  | Power-on Reset     | Input                     |
| V <sub>C</sub> , XTLIN,<br>XTLOUT   | Clock              | Input                     |
| CLK <sub>A</sub> , CLK <sub>B</sub> | Clock              | Output                    |
| TEST                                | Device Test        | Input                     |
| V <sub>DD</sub> , V <sub>SS</sub>   | Power, Ground      | Input                     |

Figure 1-22. PPS4/1 MM76L and MM76EL Pins and Signals



| Pin Name                            | Description        | Type                      |
|-------------------------------------|--------------------|---------------------------|
| D0-D9                               | Discrete I/O Pins  | Bidirectional, Open Drain |
| P1-P8                               | Input Port         | Input                     |
| R1-R8                               | I/O Port           | Bidirectional, Open Drain |
| SDI                                 | Serial Data Input  | Input                     |
| SDO                                 | Serial Data Output | Output, Open Drain        |
| SSC                                 | Serial Shift Clock | Bidirectional, Open Drain |
| INT0, INT1                          | Interrupt Request  | Input                     |
| PO                                  | Power-on Reset     | Input                     |
| V <sub>C</sub> , CLKIN,<br>EXCLK    | Clock Inputs       | Input                     |
| CLK <sub>A</sub> , CLK <sub>B</sub> | Clock Outputs      | Output                    |
| TEST                                | Device Test        | Input                     |
| V <sub>DD</sub> , V <sub>SS</sub>   | Power, Ground      | Input                     |

Figure 1-23. PPS4/1 MM77 and MM78 Pins and Signals

The bidirectional I/O port is provided by pins R1 - R8. R1 - R4 implement the A port while R5 - R8 implement the B or X port, depending on the microcomputer.

The discrete I/O lines are provided by D0 - D9.

Serial I/O logic is implemented via the SDO, SDI, and SSC pins. SDO is the Serial Data Output line, SDI is the Serial Data Input line, and SSC is the Serial Shift Clock line.

CLK<sub>A</sub>, CLK<sub>B</sub> (except MM75), V<sub>C</sub>, and PO are common timing and reset pins present on all members of the PPS4/1 family. There are differences in the clock oscillator options for the low power L series. The L series uses two pins, called XTLOUT and XTLIN, while the other members of the PPS4/1 family use EXCLK and CLKIN. The standard PPS4/1 (except the MM75) can be connected for either an internal or an external clock. To use the internal clock, a resistor is connected between V<sub>C</sub> and V<sub>DD</sub>. A 56 kΩ resistor will set the clock frequency to a nominal 80 kHz ±50%. If more precise timing is required, a precision external oscillator can be used. The external oscillator is connected to CLKIN, and the EXCLK pin is tied to V<sub>DD</sub>. Frequencies within the range 40 kHz to 80 kHz are allowed.

**PPS4/1  
CLOCK  
LOGIC**

The L series microcomputers have four timing options available: internal oscillator, external oscillator, crystal, and slave. The internal oscillator and external oscillator options are the same as the standard internal and external clock modes. The crystal mode allows connection of a crystal to drive the internal oscillator. Slave mode is used to synchronize two microcomputers. In this mode  $CLK_A$  and  $CLK_B$  are employed as inputs which accept the  $CLK_A$  and  $CLK_B$  outputs from another PPS4. The table below shows how an L series device is connected for the four clock options.

| Mode             | $V_C$    | XTLIN               | XTLOUT                | $CLK_A$ , $CLK_B$ | Frequency (kHz @ $V_{DD} = -8$ V) |
|------------------|----------|---------------------|-----------------------|-------------------|-----------------------------------|
| Internal         | $V_{DD}$ | $V_{SS}$            | nc                    | Outputs           | 70-130                            |
| External Clock   | $V_{SS}$ | Clock Input         | nc                    | Outputs           | 400-800                           |
| External Crystal | $V_{SS}$ | One side of crystal | Other side of crystal | Outputs           | ≈ 800                             |
| Slave            | $V_{DD}$ | $V_{DD}$            | nc                    | Inputs            | 50-100                            |

The PO input pin is the standard power-on reset input. The following circuit will generate a proper reset pulse:



The standard power-on reset causes the microprocessor to start execution at location 3C016. This location must contain either a NOP, a Reset Carry, or a Set Carry instruction. The following location may contain any valid PPS4/1 instruction.

The INT0 and INT1 inputs can cause conditional branching when tested by the INT0L, INT0H, INT1L, INT1H, DIN0, and DIN1 instructions.

The TEST input is normally connected to  $V_{SS}$ . ROM, RAM, and instruction logic can be tested by connecting TEST to  $V_{DD}$ .

### PPS4/1 MM76C HIGH-SPEED COUNTER OPTION

The PPS4/1 MM76C is an enhanced version of the standard PPS4/1 MM76 that contains 16 bits of high-speed counter capability. Fourteen programmable modes of counter operation are available. The options available include:

- 1) Single 16-bit counter
- 2) Dual 8-bit counters
- 3) Quadrature input
- 4) Event input
- 5) Up or down counting
- 6) Automatic preset of counters
- 7) Shifting of counters

Counter control is provided by assigning special meanings to five of the standard PPS4/1 MM76 I/O instructions when the microprocessor is executing in the special counter mode. The rich variety of counter configurations makes the PPS4/1 MM76C a very powerful tool in producing minimal hardware systems. Applications for the PPS4/1 MM76C include motor control with direction sensing, frequency counting, digital-to-analog conversion, and frequency synthesis. Entire control systems can be implemented with only a PPS4/1 MM76C microcomputer.

## Description of PPS4/1 MM76C Counter Subsystem

In addition to the standard PPS4/1 MM76 hardware the PPS4/1 MM76C contains logic for the counters. This logic consists of the following functional blocks:

- 1) Input circuitry
- 2) Lower counter register (8 bits)
- 3) Lower data register (8 bits)
- 4) Lower carry
- 5) Upper counter register (8 bits)
- 6) Upper data register (8 bits)
- 7) Upper carry
- 8) Control register (4 bits)
- 9) Control flip-flops (3 bits)

Figure 1-24 shows the relationship of each of these functional blocks to the architecture of the PPS4/1 MM76. The additions to the standard PPS4/1 MM76 are shaded. Eight additional pins are provided for counter control and status. Figure 1-25 shows the device's pins and signals and summarizes those signals not present on the PPS4/1 MM76.

The 16-bit counter of the PPS4/1 MM76C is divided into two 8-bit counters called the Upper Counter and the Lower Counter. When the counter circuitry is configured as a single 16-bit counter the Upper Counter contains the most significant eight bits and the Lower Counter contains the least significant eight bits. Both counters can be preset using the C/DI serial input line. Data is clocked onto the C/DI serial input line by the serial shift clock SCC/D. The timing of this serial input operation is exactly the same as the standard PPS4/1 serial I/O explained above. By this arrangement, external logic can preset the counters. To preset the counters under program control by the PPS4/1 MM76C, simply wire the microprocessor as shown below:



Since the PPS4/1 serial I/O logic handles only four bits at a time, two serial transmissions must be executed to load an 8-bit counter. The first serial transmission loads the least significant four bits of the Lower Counter; the second loads the most significant four bits of the Lower Counter; the third loads the least significant four bits of the Upper Counter; and the fourth loads the most significant four bits of the Upper Counter. Note that the serial input line C/DI will also be used to load the Control register. Care should be taken to preset the counters only when the PPS4/1 MM76C expects to receive counter data on the C/DI line. Each counter has a carry bit that is set whenever the counter overflows or underflows. The state of these carries is made available to external logic at the CA8 (Lower Counter) and CA16/D (Upper Counter) pins. Associated with each counter is an 8-bit buffer register; these are called the Upper Data register and the Lower Data register. Via the Data registers, the Counters may be read while counting is taking place. The Upper Data register has two special functions not implemented in the Lower Data register: shifting and presetting. Shifting of the Upper Data register can occur in only two of the 14 operational modes. Data can be shifted into the Upper Data register via the control/data serial input pin (C/DI) and out of the Upper Data register via the Upper Counter's carry bit (CA16/D). Control of all shifting operations is governed by the control/data serial shift clock (SCC/D). The presetting function automatically transfers the contents of the Upper Data register to the Upper Counter register whenever the Upper Counter overflows.

Two input modes are implemented: these are event input and quadrature input. Event input simply counts transitions on the input line. PC1 is the event input for the Lower Counter and SYEV is the event input for the Upper Counter. Both the Upper and Lower Counters can count up or down. The control of up or down counting on the Lower Counter is set by PC2. When PC2 is high the Lower Counter will count up; when PC2 is low the Lower Counter counts down. The Upper Counter can be set by the program to count either up or down. If the Upper Counter has been configured as the most significant eight bits of a 16-bit counter, its counting direction follows that of the Lower Counter. Event counting can take place at rates up to 2 MHz.



Figure 1-24. MM76C Counter Logic



| Pin Name      | Description                  | Type                      |
|---------------|------------------------------|---------------------------|
| D0-D9         | Discrete I/O Pins            | Bidirectional, Open Drain |
| P1-P8         | Input Port                   | Input                     |
| R1-R8         | I/O Port                     | Bidirectional, Open Drain |
| SDI           | Serial Data Input            | Input                     |
| SDO           | Serial Data Output           | Output                    |
| SSC           | Serial Shift Clock           | Bidirectional, Open Drain |
| INT0,INT1     | Interrupt Request            | Input                     |
| PO            | Power-on Reset               | Input                     |
| XTLIN, XTLOUT | Clock                        | Input                     |
| CLK_A, CLK_B  | Clock                        | Output                    |
| TEST          | Device Test                  | Input                     |
| PC1, PC2      | Input to Lower Counter       | Input                     |
| ENABL         | Upper & Lower Counter Enable | Input                     |
| CA8           | Lower Counter Carry Status   | Output                    |
| CA16/D        | Upper Counter Carry Status   | Output                    |
| SYEV          | Input to Upper Counter       | Input                     |
| C/DI          | Serial Control or Data Input | Input                     |
| SCC/D         | Shift Clock for C/DI Input   | Input                     |
| XTPWR         | Clock Control                | Input                     |
| VDD, VSS      | Power, Ground                |                           |

Figure 1-25. PPS4/1 MM76C Pins and Signals

Quadrature input mode measures the frequency and relative phase relationship of two input signals. It uses two signals 90 degrees out of phase at PC1 and PC2. Input signals of this type are commonly generated by standard incremental rotation sensors. (See Figure 1-26.) A count is generated any time a transition occurs at PC1 or PC2. The counting direction is determined by the phase relationship between the two inputs. If the signal at PC1 leads the signal at PC2, the counter counts up; if the signal at PC1 lags the signal at PC2, the counter counts down. In systems such as the one outlined in Figure 1-26, a change of phase indicates a change of direction of rotation. The count recorded in the counter over a fixed period is proportional to the rotational velocity.



Figure 1-26. Generation of Quadrature Inputs

In quadrature input mode a maximum input frequency of 500 kHz on each input is allowed. Quadrature input imposes a few timing constraints that must be maintained to ensure proper operation of the input logic. A count reversal must not occur sooner than 500 ns after the last count. This timing is illustrated below:



Another constraint exists when quadrature input is used with a 16-bit counter. When a carry is produced from the Lower Counter to the Upper Counter, a single phase reversal is handled as outlined above. However, any subsequent phase reversals must not occur for at least three cycles of the microprocessor's  $\text{CLK}_A$ . This timing may be illustrated as follows:



The Control register and the Control flip-flops control the operation of the counter logic. One of the 14 possible modes of counter operation is selected by writing an appropriate bit pattern into the Control register. The Control flip-flops are set and reset by the special I/O instructions used in counter mode to control the state of the counter logic.

Control register contents are interpreted as illustrated below:



Rather than adding new instructions to the MM76 instruction set to control the counter on the MM76C, a second meaning is given to a subset of MM76 instructions when the MM76C is operated in counter mode. On the MM76C the SEG1 instruction performs the combined functions of the standard SEG1 and SEG2 instructions. SEG2 does not perform its regular function; rather, it initiates the counter mode of operation. In the counter mode the instructions SEG2, IAM, IBM, I1, and I2C are used to control the counter logic. You must use these instructions carefully since their function depends on their sequence in the program. For example, I1 transfers the lower bits of the Lower Data register to the Accumulator if it precedes an I2C instruction, while it transfers the lower bits of the Upper Data register if it follows an I2C instruction.

**PPS4/1  
MM76C  
COUNTER  
INSTRUCTIONS**

**PPS4/1  
MM76C  
CLOCK  
LOGIC**

The PPS4/1 MM76C internal clock provides a slightly different set of operating modes than the rest of the PPS4/1 family. These operating modes are summarized below:

| Mode             | XPWR            | XTLIN                        | XTLOUT                         | CLK <sub>A</sub><br>CLK <sub>B</sub> | Frequency (kHz) |
|------------------|-----------------|------------------------------|--------------------------------|--------------------------------------|-----------------|
| Internal         | V <sub>SS</sub> | V <sub>DD</sub>              | No Connection                  | Outputs                              | 75-125          |
| External Crystal | V <sub>DD</sub> | One side of 3.57 MHz crystal | Other side of 3.57 MHz crystal | Outputs                              | 89              |
| Slave            | V <sub>SS</sub> | V <sub>SS</sub>              | No Connection                  | Inputs                               | Unspecified     |

## PPS4/1 SERIES MICROCOMPUTER INSTRUCTION EXECUTION

Almost all PPS4/1 instructions execute in a single clock cycle. Notable exceptions are transfer, conditional transfer, and macro instructions.

## PPS4/1 SERIES MICROCOMPUTER INSTRUCTION SET

There are variations in the instruction sets of the different microcomputers of the PPS4/1 series. However, the similarities outweigh the differences, so all the instruction sets are described in Table 1-13. Separate columns have been provided to show which instructions correspond to which microcomputer.

The PPS4/1 instruction set is weak when compared to that of other microprocessors. However, the PPS4/1 series was designed as a low-cost digital logic replacement and functions more than adequately in this role. The economics of its use in a high-volume product make any programmer inconvenience irrelevant. The type of product for which the PPS4/1 is designed is produced in the tens of thousands. An extra week or two of programming effort is insignificant in such an application.

## THE BENCHMARK PROGRAM

As stated in the TMS1000 section of this chapter, a special benchmark more suited to the 4-bit microcomputers will be used. This benchmark consists of inputting a 1- to 16-nibble packet of data from an input port.

|      |        |                     |
|------|--------|---------------------|
| LBL  | BUFFER | GET BUFFER ADDRESS  |
| I1   |        | INPUT BUFFER LENGTH |
| LBA  |        | SAVE BUFFER LENGTH  |
| LOOP | I1     | INPUT DATA          |
| XDSK | 0      | STORE DATA          |
| T    | LOOP   | GET MORE DATA       |

## PPS4/1 INSTRUCTION MNEMONICS

Table 1-13 summarizes the PPS4/1 instruction set. The MNEMONIC column shows the instruction mnemonic, and the operands, if any, are shown in the OPERAND column. Macro instructions (combinations of basic instructions) are not included.

The fixed part of an assembly language instruction is shown in UPPER CASE. The variable part (immediate data, label or address) is shown in lower case.

## PPS4/1 INSTRUCTION OBJECT CODES

For instruction bytes without variations, object codes are represented as two hexadecimal digits (e.g., 4D).

For instruction bytes with variations in one of the two digits, the object code is shown as one 4-bit binary number and one hexadecimal digit (e.g., 5 dddd). For other instruction bytes with variations, the object code is shown as eight binary digits (e.g., 11aa aaa).

The object code, execution time, and instruction length in bytes is shown in Table 1-14 for each instruction. Tables 1-15 and 1-16 list the object codes in numerical order.

## PPS4/1 INSTRUCTION EXECUTION TIMES

Tables 1-13 and 1-14 list the instruction execution times in clock periods. Real time can be obtained by dividing the given number of clock periods by the clock frequency. For example, for an instruction that requires one clock period, a 100 kHz clock will result in a 10 microsecond execution time.

## PPS4/1 ABBREVIATIONS

These are the abbreviations used in this chapter:

|         |                                                                                                                                                                                                                                                                                                              |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A       | The 4-bit Accumulator                                                                                                                                                                                                                                                                                        |
| aaaaaa  | A 6-bit address used to specify an offset within a page (low-order address bits)                                                                                                                                                                                                                             |
| AB      | The 4-bit Accumulator Buffer register                                                                                                                                                                                                                                                                        |
| addr6   | A 6-bit address constant                                                                                                                                                                                                                                                                                     |
| addr7   | A 7-bit address constant                                                                                                                                                                                                                                                                                     |
| addr10x | A 10-bit address constant in the range 0-37F16                                                                                                                                                                                                                                                               |
| addr10y | A 10-bit address constant in the range 0-3FF16                                                                                                                                                                                                                                                               |
| addr10z | A 10-bit address constant in the range 40016 - 77F16                                                                                                                                                                                                                                                         |
| B       | The 6-bit Data Counter (7 bits in MM77, MM78)                                                                                                                                                                                                                                                                |
| bit2,bb | A 2-bit immediate field used to specify a single bit in a 4-bit nibble as follows:<br>00 <sub>2</sub> - selects least significant bit<br>01 <sub>2</sub> - selects next to least significant bit<br>10 <sub>2</sub> - selects next to most significant bit<br>11 <sub>2</sub> - selects most significant bit |
| C       | Carry flag                                                                                                                                                                                                                                                                                                   |
| CR      | The 4-bit Control register (MM76C only)                                                                                                                                                                                                                                                                      |
| CR1     | Control flip-flop 1 (MM76C only)                                                                                                                                                                                                                                                                             |
| CR2     | Control flip-flop 2 (MM76C only)                                                                                                                                                                                                                                                                             |
| CR3     | Control flip-flop 3 (MM76C only)                                                                                                                                                                                                                                                                             |
| D       | The 10-bit discrete I/O port (9 bits on MM75)                                                                                                                                                                                                                                                                |
| data2   | A 2-bit immediate field                                                                                                                                                                                                                                                                                      |
| data3   | A 3-bit immediate field                                                                                                                                                                                                                                                                                      |
| data4   | A 4-bit immediate field                                                                                                                                                                                                                                                                                      |
| data4x  | A 4-bit non-zero immediate field                                                                                                                                                                                                                                                                             |
| dd      | Two bits of immediate data                                                                                                                                                                                                                                                                                   |
| ddd     | Three bits of immediate data                                                                                                                                                                                                                                                                                 |
| dddd    | Four bits of immediate data                                                                                                                                                                                                                                                                                  |
| DM      | The 128-bit Decode Matrix (not on MM77, MM78)                                                                                                                                                                                                                                                                |
| eeee    | A 4-bit non-zero immediate field                                                                                                                                                                                                                                                                             |
| ffff    | Least significant four bits of an immediate data field wider than four bits                                                                                                                                                                                                                                  |
| gg      | Most significant two bits of a 6-bit immediate value                                                                                                                                                                                                                                                         |
| ggg     | Most significant three bits of a 7-bit immediate value                                                                                                                                                                                                                                                       |
| hhhh    | Four bits of non-zero immediate data                                                                                                                                                                                                                                                                         |
| [INT0]  | The INT0 flip-flop                                                                                                                                                                                                                                                                                           |
| [INT1]  | The INT1 flip-flop                                                                                                                                                                                                                                                                                           |
| LC      | The 8-bit Lower Counter register                                                                                                                                                                                                                                                                             |
| LDR     | The 8-bit Lower Data register                                                                                                                                                                                                                                                                                |
| P       | The 8-bit Input Port (4 bits on MM75)                                                                                                                                                                                                                                                                        |
| PC      | The 10-bit Program Counter (11 bits in MM77, MM78)                                                                                                                                                                                                                                                           |
| PPPP    | A 4-bit page address (high-order address bits)                                                                                                                                                                                                                                                               |
| R       | The 8-bit Input/Output port                                                                                                                                                                                                                                                                                  |
| S       | The 4-bit Serial Input/Output register                                                                                                                                                                                                                                                                       |
| SA      | The 10-bit Subroutine Save register (11 bits in MM77, MM78)                                                                                                                                                                                                                                                  |
| SB      | The 11-bit Subroutine Save register (MM77, MM78 only)                                                                                                                                                                                                                                                        |
| UC      | The 8-bit Upper Counter register (MM76C only)                                                                                                                                                                                                                                                                |
| UDR     | The 8-bit Upper Data register (MM76C only)                                                                                                                                                                                                                                                                   |
| X       | The 4-bit X register (MM77, MM78 only)                                                                                                                                                                                                                                                                       |
| XB      | The 4-bit X register buffer                                                                                                                                                                                                                                                                                  |
| xx      | A 2-bit "don't care"                                                                                                                                                                                                                                                                                         |
| xxxx    | A 4-bit "don't care." Values of 0000 <sub>2</sub> and 0001 <sub>2</sub> are not allowed.                                                                                                                                                                                                                     |
| []      | Contents of the location within brackets. If a register is enclosed by brackets, then the contents of that register                                                                                                                                                                                          |

|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| < >     | Subfield specifier. Specifies a subset for a register or memory location. A single digit enclosed by angle brackets specifies only a single bit. Two numbers separated by a comma and enclosed by angle brackets specify a range of bits. The first number specifies the least significant bit position of the subfield, while the second digit specifies the most significant bit. All bits are numbered from least to most significant, with bit 0 being the least significant bit. For example: |
| A<0>    | specifies the least significant bit of the Accumulator                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| UC<4,7> | specifies the most significant four bits of the Upper Counter register                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ↑       | Data is transferred in the direction of the arrow                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ↔       | Data is exchanged between two locations                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| iff     | If and only if                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| =       | Test for equality between two values                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Λ       | Logical AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| •       | Multiplication                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| +       | Addition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| x       | Complement of x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ⊕       | Exclusive OR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ••      | New carry not valid until second cycle after instruction execution completes                                                                                                                                                                                                                                                                                                                                                                                                                       |
| •••     | Value of Carry during previous cycle is used                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ••••    | New B register contents may not be valid until second cycle following execution of this instruction                                                                                                                                                                                                                                                                                                                                                                                                |
| •••••   | IOS executes in one cycle. I/O register shifting continues for 8 more cycles.                                                                                                                                                                                                                                                                                                                                                                                                                      |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set

| TYPE | MNEMONIC | OPERAND(S) | OBJECT CODE  |              | CLOCK CYCLES | STATUS | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                             |
|------|----------|------------|--------------|--------------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          |            | MM75<br>MM76 | MM77<br>MM78 |              |        |                                                                                                                                                                                                                                                                                                                                                 |
| I/O  | IAM      |            | 1A           |              | 1            |        | $[A] \leftarrow [R] <0,3> \wedge [A]$<br>Input least significant 4 bits of the R port, ANDed with A, to A.                                                                                                                                                                                                                                      |
|      | IBM      |            | 1B           |              | 1            |        | $[A] \leftarrow [R] <4,7> \wedge [A]$<br>Input most significant 4 bits of the R port, ANDed with A, to A.                                                                                                                                                                                                                                       |
|      | IOA      |            |              | 7B           | 1            |        | $[A]_{new} \leftarrow [AB]_{old} \wedge [R]_{old} <0,3>$<br>$[AB]_{new} \leftarrow [A]_{old}$<br>$[R]_{new} <0,3> \leftarrow [AB]_{new}$<br>Simultaneously input the least significant 4 bits of the R port, ANDed with the A buffer, to A while transferring the contents of A to the least significant 4 bits of the R port via the A buffer. |
|      | I1       |            | 4A           |              | 1            |        | $[A] \leftarrow [P] <0,3>$<br>Input least significant 4 bits of the P port to A.                                                                                                                                                                                                                                                                |
|      | I1SK     |            |              | 60           | 1            | X      | $[A] \leftarrow [P] <0,3> + [A]$<br>Input and add least significant 4 bits of the P port to A. Skip if no overflow.<br>Serial                                                                                                                                                                                                                   |
|      | IOS      |            | 4D           | 2D           | 1***         |        | <br>Shift the Serial I/O register left 4 times. Shifting takes 8 cycles after IOS executes.                                                                                                                                                                   |
|      | I2C      |            | 4B           | 78           | 1            |        | $[A] \leftarrow [P] <4,7>$<br>Input the complement of the most significant 4 bits of the P port to A.                                                                                                                                                                                                                                           |
|      | IX       |            |              | 72           | 1            |        | $[X] \leftarrow [XB] \wedge [R] <4,7>$<br>Input most significant 4 bits of the R port, ANDed with the X register buffer, to the X register.                                                                                                                                                                                                     |
|      | OA       |            | 18           |              | 1            |        | $[R] <0,3> \leftarrow [A]$<br>Output Accumulator to least significant 4 bits of the R port.                                                                                                                                                                                                                                                     |
|      | OB       |            | 19           |              | 1            |        | $[R] <4,7> \leftarrow [A]$<br>Output Accumulator to most significant 4 bits of the R port.                                                                                                                                                                                                                                                      |
|      | OX       |            |              | 73           | 1            |        | $[XB] \leftarrow [X]$<br>$[R] <4,7> \leftarrow [XB]$<br>Output X register to 4 most significant bits of the R port via the X buffer.                                                                                                                                                                                                            |
|      | ROS      |            | 1 01xx       |              | 71           |        | $[D] <[B] <0,3> > \leftarrow 0$<br>Reset the discrete I/O pin selected by the least significant 4 bits of B when $B <4,5> = 11_2$ (MM75, MM76) or $B <6> = 0$ (MM77, MM78). If $B <0,3> = 1010_2$ , reset INT1 flip-flop. If $B <0,3> = 1011_2$ , reset INTO flip-flop.                                                                         |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set (Continued)

| TYPE              | MNEMONIC | OPERAND(S) | OBJECT CODE  |              | CLOCK CYCLES | STATUS<br>C      SKIP | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|----------|------------|--------------|--------------|--------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |          |            | MM75<br>MM76 | MM77<br>MM78 |              |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| I/O (Continued)   | SEG1     |            | OE           |              | 1            |                       | [R] <0,3> ← [DM] < [A] • 8, ([A] • 8) + 3 ><br>Output the lower order 4 bits of the Decode Matrix entry selected by A to the least significant 4 bits of the R port. B must point to the complement of A. (Except MM76C).                                                                                                                                                                                                                                                                                           |
|                   | SEG1     |            | OE           |              | 1            |                       | [R] ← [DM] < [A] • 8, ([A] • 8) + 7 ><br>Output to the R port the 8 bits selected from the Decode Matrix by the contents of the Accumulator. The B register must point to a RAM location that holds the complement of A. A mask option allows the most significant bit of R to display the current state of C. (MM76C only)                                                                                                                                                                                         |
|                   | SEG2     |            | OF           |              | 1            |                       | [R] <4,7> ← [DM] < ([A] • 8) + 4, ([A] • 8) + 7 ><br>Output the higher order 4 bits of the Decode Matrix entry selected by A to the most significant 4 bits of the R port. B must point to the complement of A. Also, a mask option allows R <7> to be set to the current state of C. (Except MM76C)                                                                                                                                                                                                                |
|                   | SOS      |            | 1 00xx       | 70           | 1            |                       | [D < [B] <0,3> > ← 1<br>Set the discrete I/O pin selected by the least significant 4 bits of B when B <4,5> = 11 <sub>2</sub> (MM75, MM76) or B <6> = 0 (MM77, MM78). If B <0,3> = 1010 <sub>2</sub> , reset INT1 flip-flop. If B <0,3> = 1011 <sub>2</sub> , reset INTO flip-flop.                                                                                                                                                                                                                                 |
| MM76C COUNTER I/O | IAM      |            | 1A           |              | 1            |                       | [A] ← [R] <0,3> Λ [A]<br>[UC] ← [LC] ← 0 iff modes 1-5 (16-bit counter modes)<br>[UC] ← 0 iff modes 6-14 Λ [CR2] = 1 (8-bit counter modes)<br>[LC] ← 0 iff modes 6-14 Λ [CR1] = 1 (8-bit counter modes)<br>Input least significant 4 bits of R port, ANDed with A, to A. Clear both counters if configured as a single 16-bit counter. If configured as two 8-bit counters clear Lower Counter register if CR1 flip-flop set, and clear Upper Counter register if CR2 set.<br>[A] ← [R] <4,7> Λ [A]<br>[UC] ← [UDR] |
|                   | IBM      |            | 1B           |              | 1            |                       | Input most significant 4 bits of R port, ANDed with A, to A. Load Upper Counter register from Upper Data register.<br>[A] ← [LDR] <0,3> iff [CR1] = 1 Λ [CR2] = 0<br>[A] ← [UDR] <0,3> iff [CR1] = 0 Λ [CR2] = 1                                                                                                                                                                                                                                                                                                    |
|                   | I1       |            | 4A           |              | 1            |                       | If no I2C instruction has been executed, then load A with the least significant 4 bits of the Lower Data register. If an I2C instruction has been executed, then load A with the least significant 4 bits of the Upper Data register.                                                                                                                                                                                                                                                                               |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set (Continued)

| TYPE                          | MNEMONIC | OPERAND(S) | OBJECT CODE  |              | CLOCK CYCLES | STATUS<br>C      SKIP | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------------|----------|------------|--------------|--------------|--------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               |          |            | MM75<br>MM76 | MM77<br>MM78 |              |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| MM76C COUNTER I/O (Continued) | I2C      |            | 4B           |              | 1            |                       | <p>[A] — [LDR] &lt;4,7&gt; iff [CR1] = 1 <math>\wedge</math> [CR2] = 0<br/>         or<br/>         [A] — [UDR] &lt;4,7&gt; iff [CR1] = 1 <math>\wedge</math> [CR2] = 0<br/>         [CR1] — 0<br/>         [CR2] — [CR2]<br/>         [CR3] — 0</p> <p>The first I2C instruction will load A with the most significant 4 bits of the Lower Data register. The second I2C will load A with the most significant 4 bits of the Upper Data register and exit counter mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                               | SEG2     |            | 0F           |              | 1            |                       | <p>Enables counter logic iff [CR1] = 0<br/>         [LDR] — [LC] iff [CR1] = 0<br/>         [UDR] — [UC] iff [CR1] = 0<br/>         Gate serial data input to UDR iff [CR1] = 0<br/>         Gate serial data input to CR iff [CR1] <math>\neq</math> 0<br/>         UC configured to count up iff [CR1] <math>\neq</math> 0<br/>         Disable UC enable input iff [CR1] <math>\neq</math> 0<br/>         Disable UC preset iff [CR1] <math>\neq</math> 0<br/>         LC configured to quadrature mode iff [CR1] <math>\neq</math> 0<br/>         [CR3] — 1 iff [CR1] = 0<br/>         [CR1] — 1</p> <p>First SEG2 executed enables counter logic, loads the Upper and Lower Data registers from their respective counters, gates the serial control/data input to the Upper Data register, and sets the CR1 flip-flop. The second and all subsequent SEG2s executed (until counter mode terminates) cause the Upper Counter register to be configured as an up counter, the Lower Counter register to be configured for quadrature inputs, the serial control/data input to be gated to the Control register, the Upper Counter register enable input and preset control to be disabled, and the CR1 and CR3 flip-flops to be set (MM76C only).</p> |
| PRIMARY MEMORY REFERENCE      | L        | data2      | 5 00dd       | 5 00dd       | 1            |                       | <p>[A] — [[B]];<br/>         [B] &lt;4,5&gt; — [B] &lt;4,5&gt; + data2</p> <p>Load the Accumulator from the RAM location addressed by B. Exclusive-OR bits 4,5 of B with data2.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                               | X        | data2      | 5 10dd       | 5 11dd       | 1            |                       | <p>[A] — — [[B]];<br/>         [B] &lt;4,5&gt; — [B] &lt;4,5&gt; + data2.</p> <p>Exchange the Accumulator with the RAM location addressed by B. Exclusive-OR bits 4,5 of B with data2</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set (Continued)

| TYPE                                    | MNEMONIC | OPERAND(S) | OBJECT CODE  |              | CLOCK CYCLES | STATUS<br>C      SKIP | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------|----------|------------|--------------|--------------|--------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                         |          |            | MM75<br>MM76 | MM77<br>MM78 |              |                       |                                                                                                                                                                                                                                                                                                                                      |
| PRIMARY MEMORY<br>REFERENCE (Continued) | XDSK     | data2      | 5 11dd       | 5 10dd       | 1***         | X                     | [A] $\leftarrow$ [[B]];<br>[B] <0,3> $\leftarrow$ [B] <0,3> - 1<br>[B] <4,5> $\leftarrow$ [B] <4,5> $\oplus$ data2<br>Exchange the Accumulator with the RAM location addressed by B. Exclusive-OR bits 4,5 of B with data2. Decrement least significant 4 bits of B. Skip if least significant 4 bits of B equal 1111 <sub>2</sub> . |
|                                         | XNSK     | data2      | 5 01dd       | 5 01dd       | 1***         | X                     | [A] $\leftarrow$ [[B]]; [B] <0,3> - 1<br>[B] <0,3> $\leftarrow$ [B] <4,5> $\leftarrow$ [B] <4,5> $\oplus$ data2<br>Exchange the Accumulator with the RAM location addressed by B. Exclusive-OR bits 4,5 of B with data2. Increment least significant 4 bits of B. Skip if least significant 4 bits of B equal 0000 <sub>2</sub> .    |
| SECONDARY MEMORY REFERENCE              | A        |            | 42           | 7E           | 1            |                       | [A] $\leftarrow$ [A] + [[B]]<br>Add contents of RAM location addressed by B to Accumulator.                                                                                                                                                                                                                                          |
|                                         | AC       |            | 40           | 7C           | 1*           | X                     | [A] $\leftarrow$ [A] + [[B]] + C<br>Add contents of RAM location addressed by B with Carry to Accumulator.<br>Carry not valid for one additional cycle.                                                                                                                                                                              |
|                                         | ACSK     |            | 41           | 7D           | 1*           | X                     | [A] $\leftarrow$ [A] + [[B]] + C<br>Add contents of RAM location addressed by B with Carry to Accumulator.<br>Skip if no carry (overflow). Carry not valid for one additional cycle.                                                                                                                                                 |
|                                         | ASK      |            | 43           |              | 1            | X                     | [A] $\leftarrow$ [A] + [[B]]<br>Add contents of RAM location addressed by B to Accumulator.                                                                                                                                                                                                                                          |
|                                         | RB       | bit2       | 1 01bb       | 2 01bb       | 1            |                       | [[B]] <bit2> $\leftarrow$ 0<br>Reset bit bit2 of the RAM location addressed by B.                                                                                                                                                                                                                                                    |
|                                         | SB       | bit2       | 1 00bb       | 2 00bb       | 1            |                       | [[B]] <bit2> $\leftarrow$ 1<br>Set bit bit2 of the RAM location addressed by B.                                                                                                                                                                                                                                                      |
| IMMEDIATE OPERATE                       | AISK     | data4x     | 6 eeee       | 6 eeee       | 1            | X                     | [A] $\leftarrow$ [A] + data4<br>Add immediate to Accumulator. Skip if no overflow.                                                                                                                                                                                                                                                   |
|                                         | DC       |            | 66,00        | 66,00        | 2            | X                     | Same as AISK 6. Must always be followed by NOP as shown.                                                                                                                                                                                                                                                                             |
|                                         | EOB      | data2      | 1 11dd       |              | 1            | X                     | [B] <4,5> $\leftarrow$ [B] <4,5> $\oplus$ data2<br>Exclusive-OR data2 with most significant 2 bits of B. Skip until next non-LB, -EOB or -LBL instruction.                                                                                                                                                                           |
|                                         | EOB      | data3      |              | 0 1ddd       | 1            | X                     | [B] <4,6> $\leftarrow$ [B] <4,6> $\oplus$ data3<br>Exclusive-OR data3 with most significant 3 bits of B. Skip until next non-LB, -EOB or -LBL instruction.                                                                                                                                                                           |
|                                         | LAI      | data4      | 7 dddd       | 4 dddd       | 1            | X                     | [A] $\leftarrow$ data4<br>Load Accumulator immediate. Skip until first non-LAI instruction.                                                                                                                                                                                                                                          |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set (Continued)

| TYPE                             | MNEMONIC | OPERAND(S) | OBJECT CODE         |                               | CLOCK CYCLES | STATUS | OPERATION PERFORMED                                                                                                                                                                                                                                               |
|----------------------------------|----------|------------|---------------------|-------------------------------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  |          |            | MM75<br>MM76        | MM77<br>MM78                  |              |        |                                                                                                                                                                                                                                                                   |
| IMMEDIATE OPERATE<br>(Continued) | LB       | data4      | 2 dddd              | 1 dddd                        | 1            | X      | [B] <0,3> ← data4<br>[B] <4,5> ← 0<br>Clear bits 4,5 of B and load least significant 4 bits with data4. Execute any EOB instruction that immediately follows. Skip until next non-LB,-EOB, or -LBL instruction.                                                   |
| JUMP                             | T        | addr6      | 11aa aaaa           |                               | 2            |        | [PC] <0,5> ← addr6<br>[PC] <6,9> ← 1110 <sub>2</sub> iff PC is 380 <sub>16</sub> - 3FF <sub>16</sub><br>On-page transfer if executing from pages 0-13. If executing on pages 14-15, always jump to page 14.                                                       |
|                                  | T        | addr6      |                     | 11aa aaaa                     | 2            |        | [PC] <6,10> ← 11110 <sub>2</sub> if PC is 780 <sub>16</sub> - 7FF <sub>16</sub><br>On-page transfer if executing on pages 0-29. If executing on pages 30-31, always jump to page 30.                                                                              |
|                                  | TL       | addr10x    | 3 pppp<br>11aa aaaa |                               | 3            |        | [PC] ← addr10x<br>Transfer to an address on pages 0-13.                                                                                                                                                                                                           |
|                                  | TL       | addr10y    |                     | 3 pppp<br>11aa aaaa           | 3            |        | [PC] ← addr10y<br>Transfer to an address on pages 0-15.                                                                                                                                                                                                           |
|                                  | TLB      | addr10z    |                     | 3 pppp<br>3 xxxx<br>11aa aaaa | 4            |        | [PC] ← addr10z<br>Transfer to an address on pages 16-29.                                                                                                                                                                                                          |
| SUBROUTINE CALL AND RETURN       | RT       |            | 02                  | 2F                            | 2            |        | [PC] ← [SA]<br>[SA] ← [SB] (MM77, MM78 only)<br>Return from subroutine.                                                                                                                                                                                           |
|                                  | RTSK     |            | 03                  | 2E                            | 2            | X      | [PC] ← [SA]<br>[SA] ← [SB] (MM77, MM78 only)<br>Return from subroutine and skip next instruction.                                                                                                                                                                 |
|                                  | TM       | addr6      | 10aa aaaa           |                               | 2            |        | [SA] ← [PC] + 1 iff executing from 0 - 37F <sub>16</sub><br>[PC] <0,5> ← addr6<br>[PC] <6,9> ← 1111 <sub>2</sub>                                                                                                                                                  |
|                                  | TM       | addr6      |                     | 10aa aaaa                     | 2            |        | Subroutine call to primitive subroutine page (page 15) if executing on pages 0-13. Jump to primitive subroutine page if executing on pages 14-15.<br>[SB] ← [SA] iff executing from 0-77F <sub>16</sub><br>[SA] ← [PC] + 1 iff executing from 0-77F <sub>16</sub> |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set (Continued)

| TYPE                                      | MNEMONIC | OPERAND(S) | OBJECT CODE         |                           |       | CLOCK CYCLES | STATUS | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------|----------|------------|---------------------|---------------------------|-------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                           |          |            | MM75<br>MM76        | MM77<br>MM78              | C     |              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| SUBROUTINE CALL AND RETURN<br>(Continued) | TML      | addr10x    | 3 pppp<br>10aa aaaa |                           |       | 3            |        | [PC] <0,5> ← <u>addr6</u><br>[PC] <6,10> 11111 <sub>2</sub><br>Subroutine call to primitive subroutine page (page 31) if executing on pages 0-29. Jump to primitive subroutine page if executing on pages 30-31.<br>[SA] ← [PC] + 1<br>[PC] ← addr10x<br>Subroutine call to pages 0-13.<br>[SB] ← [SA]<br>[SA] ← [PC] + 1<br>[PC] ← addr10y<br>Subroutine call to pages 0-15.<br>[SB] ← [SA]<br>[SA] ← [PC] + 1<br>[PC] ← addr10z<br>Subroutine call to pages 16-29. |
|                                           | TML      | addr10y    |                     | 3 pppp<br>10aa aaaa       |       | 3            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                           | TMLB     | addr10z    |                     | 30<br>3 pppp<br>10aa aaaa |       | 4            |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| BRANCH ON CONDITION                       | DINO     |            | 07                  |                           | 1     |              | X      | [INT0] ← 1<br>Skip next instruction if INT0 = 0. Set INT0 = 1.                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                           | DIN1     |            | 06                  |                           | 1     |              | X      | [INT1] ← 1<br>Skip next instruction if INT1 = 0. Set INT1 = 1.                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                           | INTOH    |            |                     |                           |       |              |        | Skip next instruction if INTO = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           | INTOL    |            | 04                  |                           |       |              |        | Skip next instruction if INTO = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           | INT1H    |            | 05                  |                           |       |              |        | Skip next instruction if INT1 = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           | INT1L    |            |                     |                           |       |              |        | Skip next instruction if INT1 = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           | SKBF     |            |                     |                           |       |              |        | Skip if bit of RAM location addressed by B and selected by bit2 is 0.                                                                                                                                                                                                                                                                                                                                                                                                |
|                                           | SKISL    | bit2       | 0 10bb              | 03                        | 1     |              | X      | Skip if discrete input selected by least significant 4 bits of B is 0.                                                                                                                                                                                                                                                                                                                                                                                               |
|                                           | SKISL    |            | 0 10xx              | 04                        | 1     |              | X      | Skip next instruction if INT0 = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           | SKISL    |            |                     | 04                        | 1     |              | X      | Skip next instruction if INT1 = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           | SKMEA    |            | 47                  | 01                        | 1     |              | X      | Skip if bit of RAM location addressed by B and selected by bit2 is 1.                                                                                                                                                                                                                                                                                                                                                                                                |
|                                           | SKNC     |            | 01                  | 7F                        | 1     |              | X      | Skip if discrete input selected by least significant 4 bits of B is 1. B <4,5> must be 11 <sub>2</sub> .                                                                                                                                                                                                                                                                                                                                                             |
|                                           | TAB      |            | 01                  | 02                        | 1**   |              | X      | Skip if discrete input selected by least significant 4 bits of B is 0. B <6> must be 0.                                                                                                                                                                                                                                                                                                                                                                              |
|                                           |          |            | 2C                  | 2C                        | 3+[A] |              | X      | B <0,3> = 1010 <sub>2</sub> selects INT1 flip-flop.<br>B <0,3> = 1011 <sub>2</sub> selects INTO flip-flop.                                                                                                                                                                                                                                                                                                                                                           |
|                                           |          |            |                     |                           |       |              |        | Skip if A equals contents of RAM location addressed by B.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                           |          |            |                     |                           |       |              |        | Skip if Carry = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                           |          |            |                     |                           |       |              |        | Table lookup based on contents of A. Executes the next instruction, which must be a NOP, TM, T, RT, RTSK, SC, RC, SB, RB, SOS, ROS, OX, IX, or TL. Then skips the next [A] + 1 instructions.                                                                                                                                                                                                                                                                         |
|                                           |          |            |                     |                           |       |              |        | [A] ← 1111 <sub>2</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Table 1-13. A Summary of the PPS4/1 Microcomputer Instruction Set (Continued)

| TYPE                   | MNEMONIC | OPERAND(S) | OBJECT CODE  |              | CLOCK CYCLES | STATUS | OPERATION PERFORMED                                                                                                                                    |
|------------------------|----------|------------|--------------|--------------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |          |            | MM75<br>MM76 | MM77<br>MM78 |              |        |                                                                                                                                                        |
| REGISTER OPERATE       | COM      |            | 45           | 77           | 1            |        | [A] — [A]<br>Complement Accumulator.                                                                                                                   |
|                        | DC       |            | 66,00        | 66,00        | 2            | X      | [A] — [A] + 6<br>Decimal correct Accumulator by adding 6.                                                                                              |
| REGISTER-REGISTER MOVE | LBA      |            | 44           | 76           | 1***         |        | [B] <0,3> — [A]<br>Load least significant 4 bits of B from A.                                                                                          |
|                        | LSA      |            | 4C           |              | 1            |        | [S] — [A]<br>Load S register from A.                                                                                                                   |
|                        | LXA      |            |              | 75           | 1            |        | [X] — [A]<br>Load X register from A.                                                                                                                   |
|                        | SAG      |            |              | 07           | 1            |        | [B] <4,6> 011 <sub>2</sub> (for next instruction only)<br>Causes B to address row 3 for the next instruction only. The contents of B are not modified. |
|                        | XAB      |            | 46           | 7A           | 1***         |        | [B] — → [A]<br>Exchange B with A.                                                                                                                      |
|                        | XAS      |            | 4E           | 74           | 1            |        | [S] — → [A]<br>Exchange S with A.                                                                                                                      |
|                        | XAX      |            |              | 79           | 1            |        | [X] — → [A]<br>Exchange X with A.                                                                                                                      |
| STATUS                 | RC       |            | 0D           | 05           | 1            | 0      | [C] — 0<br>Reset Carry.                                                                                                                                |
|                        | SC       |            | 0C           | 06           | 1            | 1      | [C] — 1<br>Set Carry.                                                                                                                                  |
|                        | NOP      |            | 00           | 00           | 1            |        | No operation.                                                                                                                                          |

Table 1-14. PPS4/1 Instruction Mnemonics

| MNEMONIC    | MM75, MM76<br>OBJECT CODE | MM77, MM78<br>OBJECT CODE | BYTES | CLOCK | MNEMONIC     | MM75, MM76<br>OBJECT CODE | MM77, MM78<br>OBJECT CODE | BYTES     | CLOCK   |
|-------------|---------------------------|---------------------------|-------|-------|--------------|---------------------------|---------------------------|-----------|---------|
| A           | 42                        | 7E                        | 1     | 1     | ROS          | 1 01xx                    | 71                        | 1         | 1       |
| AC          | 40                        | 7C                        | 1     | 1*    | RT           | 02                        | 2F                        | 1         | 1       |
| ACSK        | 41                        | 7D                        | 1     | 1*    | RTSK         | 03                        | 2E                        | 1         | 2       |
| AISK data4x | 6 eeee                    | 6 eeee                    | 1     | 1     | SAG          |                           | 07                        | 1         | 1       |
| ASK         | 43                        |                           |       |       | SB bit2      | 1 00bb                    | 2 00bb                    | 1         | 1       |
| COM         | 45                        | 77                        | 1     | 1     | SC           | 0C                        | 06                        | 1         | 1       |
| DC          | 66,00                     | 66,00                     | 2     | 2     | SEG1         | OE                        |                           | 1         | 1       |
| DINO        | 07                        |                           | 1     | 1     | SEG2         | OF                        |                           | 1         | 1       |
| DIN1        | 06                        |                           | 1     | 1     | SKBF bit2    | 0 10bb                    | 2 10bb                    | 1         | 1       |
| EOB data2   | 1 11dd                    |                           | 1     | 1     | SKISL        | 0 10xx                    | 01                        | 1         | 1       |
| EOB data3   |                           | 0 1ddd                    | 1     | 1     | SKMEA        | 47                        | 7F                        | 1         | 1       |
| IAM         | 1A                        |                           | 1     | 1     | SKNC         | 01                        | 02                        | 1         | 1**     |
| IBM         | 1B                        |                           | 1     | 1     | SOS          | 1 00xx                    | 70                        | 1         | 1       |
| INTOL       | 04                        |                           | 1     | 1     | T addr6      | 11aa aaaa                 | 11aa aaaa                 | 1         | 2       |
| INTOH       |                           | 03                        | 1     | 1     | TAB          |                           | 2C                        | 1         | 3 + [A] |
| INT1L       |                           | 04                        | 1     | 1     | TL addr10x   | 3 pppp                    |                           | 2         | 3       |
| INT1H       | 05                        |                           | 1     | 1     | TL addr10y   | 11aa aaaa                 |                           | 3 pppp    | 2       |
| IOA         |                           | 7B                        | 1     | 1     | TLB addr10z  |                           |                           | 11aa aaaa | 3       |
| IOS         | 4D                        | 2D                        | 1     | 1***  |              |                           |                           | 3 pppp    | 4       |
| IX          |                           | 72                        | 1     | 1     |              |                           |                           | 3 xxxx    |         |
| II          | 4A                        |                           | 1     | 1     |              |                           |                           | 11aa aaaa |         |
| I1SK        |                           | 60                        | 1     | 1     | TM addr6     | 10aa aaaa                 | 10aa aaaa                 | 1         | 2       |
| I2C         | 4B                        | 78                        | 1     | 1     | TML addr10x  | 3 pppp                    | 10aa aaaa                 | 2         | 3       |
| L data2     | 5 00dd                    | 5 00dd                    | 1     | 1     |              | 10aa aaaa                 |                           |           |         |
| LAI data4   | 7 dddd                    | 4 dddd                    | 1     | 1     | TML addr10y  |                           |                           | 3 pppp    | 2       |
| LB data4    | 2 dddd                    | 1 dddd                    | 1     | 1     |              |                           |                           | 10aa aaaa | 3       |
| LBA         | 44                        | 76                        | 1     | 1***  | TMLB addr10z |                           |                           | 30        | 4       |
| LSA         | 4C                        |                           | 1     | 1     |              |                           |                           | 3 pppp    |         |
| LXA         |                           | 75                        | 1     | 1     |              |                           |                           | 10aa aaaa |         |
| NOP         | 00                        | 00                        | 1     | 1     | X data2      | 5 10dd                    | 5 11dd                    | 1         | 1       |
| OA          | 18                        |                           | 1     | 1     | XAB          | 46                        | 7A                        | 1         | 1***    |
| OB          | 19                        |                           | 1     | 1     | XAS          | 4E                        | 74                        | 1         | 1       |
| OX          |                           | 73                        | 1     | 1     | XAX          |                           | 79                        | 1         | 1       |
| RB bit2     | 1 01bb                    | 2 01bb                    | 1     | 1     | XDSK data2   | 5 11dd                    | 5 10dd                    | 1         | 1***    |
| RC          | 0D                        | 05                        | 1     | 1     | XNSK data2   | 5 01dd                    | 5 01dd                    | 1         | 1***    |

Table 1-15. PPS4/1 MM75, MM76 Instruction Object Codes

| OBJECT CODE      | MNEMONIC                    | OBJECT CODE | MNEMONIC        |
|------------------|-----------------------------|-------------|-----------------|
| 00               | NOP                         | 42          | A               |
| 01               | SKNC                        | 43          | ASK             |
| 02               | RT                          | 44          | LBA             |
| 03               | RTSK                        | 45          | COM             |
| 04               | INTOL                       | 46          | XAB             |
| 05               | INT1H                       | 47          | SKMEA           |
| 06               | DIN1                        | 48, 49      | not used        |
| 07               | DINO                        | 4A          | I1              |
| 08 - 0B          | SKISL or<br>SKBF 0 - SKBF 3 | 4B          | I2C             |
| 0C               | SC                          | 4C          | LSA             |
| 0D               | RC                          | 4D          | IOS             |
| 0E               | SEG1                        | 4E          | XAS             |
| 0F               | SEG2                        | 4F          | not used        |
| 10 - 13          | SOS or<br>SB 0 - SB 3       | 50 - 53     | L 0 - L 3       |
| 14 - 17          | ROS or<br>RB 0 - RB 3       | 54 - 57     | XNSK 0 - XNSK 3 |
| 18               | OA                          | 58 - 5B     | X 0 - X 3       |
| 19               | OB                          | 5C - 5F     | XDSK 0 - XDSK 3 |
| 1A               | IAM                         | 60 - 6F     | AISK 0 - AISK F |
| 1B               | IBM                         | 66, 00      | DC, NOP         |
| 1C - 1F          | EOB 0 - EOB 3               | 70 - 7F     | LAI 0 - LAI F   |
| 20 - 2F          | LB 0 - LB F                 | 80 - 8F     | TM 3F - TM 30   |
| 3 pppp 10aa aaaa | TML pp ppaa aaaa            | 90 - 9F     | TM 2F - TM 20   |
| 3 pppp 11aa aaaa | TL pp ppaa aaaa             | A0 - AF     | TM 1F - TM 10   |
| 40               | AC                          | B0 - BF     | TM 0F - TM 00   |
| 41               | ACSK                        | C0 - CF     | T 3F - T 30     |
|                  |                             | D0 - DF     | T 2F - T 20     |
|                  |                             | E0 - EF     | T 1F - T 10     |
|                  |                             | F0 - FF     | T 0F - T 00     |

Table 1-16. PPS4/1 MM77, MM78 Instruction Object Codes

| OBJECT CODE           | MNEMONIC            | OBJECT CODE | MNEMONIC        |
|-----------------------|---------------------|-------------|-----------------|
| 00                    | NOP                 | 61 - 6F     | AISK 1 - AISK F |
| 01                    | SKISL               | 66,00       | DC              |
| 02                    | SKNC                | 70          | SOS             |
| 03                    | INTOH               | 71          | ROS             |
| 04                    | INT1L               | 72          | IX              |
| 05                    | RC                  | 73          | OX              |
| 06                    | SC                  | 74          | XAS             |
| 07                    | SAG                 | 75          | LXA             |
| 08 - OF               | EOB 0 - EOB 7       | 76          | LBA             |
| 10 - 1F               | LB 0 - LB F         | 77          | COM             |
| 20 - 23               | SB 0 - SB 3         | 78          | I2C             |
| 24 - 27               | RB 0 - RB 3         | 79          | XAX             |
| 28 - 2B               | SKBF 0 - SKBF 3     | 7A          | XAB             |
| 2C                    | TAB                 | 7B          | IOA             |
| 2D                    | IOS                 | 7C          | AC              |
| 2E                    | RTSK                | 7D          | ACSK            |
| 2F                    | RT                  | 7E          | A               |
| 30, 3 pppp, 10aa aaaa | TMLB 01pp ppaa aaaa | 7F          | SKMEA           |
| 30, 3 pppp, 11aa aaaa | TLB 01pp ppaa aaaa  | 80 - 8F     | TM 3F - TM 30   |
| 3 pppp, 10aa aaaa     | TML 00pp ppaa aaaa  | 90 - 9F     | TM 2F - TM 20   |
| 3 pppp, 11aa aaaa     | TL 00pp ppaa aaaa   | A0 - AF     | TM 1F - TM 10   |
| 40 - 4F               | LAI 0 - LAI F       | B0 - BF     | TM OF - TM 00   |
| 50 - 53               | L 0 - L 3           | CO - CF     | T 3F - T 30     |
| 54 - 57               | XNSK 0 - XNSK 3     | D0 - DF     | T 2F - T 20     |
| 58 - 5B               | XDSK 0 - XDSK 3     | E0 - EF     | T 1F - T 10     |
| 5C - 5F               | X 0 - X 3           | F0 - FF     | T OF - T 00     |
| 60                    | I1SK                |             |                 |



## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- TMS1000 series microcomputer
- COP420/421 microcomputers
- COP402/COP402M ROMless microcomputers
- PPS4/1 Series Microcomputers

**ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE  
(UNLESS OTHERWISE NOTED)\***

\*Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

#### **RECOMMENDED OPERATING CONDITIONS**

| PARAMETER                                                         |               | MIN      | NOM | MAX   | UNIT        |
|-------------------------------------------------------------------|---------------|----------|-----|-------|-------------|
| Supply voltage, $V_{DD}$ (see Note 3)                             |               | -14      | -15 | -17.5 | V           |
| High-level input voltage, $V_{IH}$ (see Note 4)                   | K             | -1.3     | -1  | 0.3   | V           |
|                                                                   | INIT or Clock | -1.3     | -1  | 0.3   |             |
| Low-level input voltage, $V_{IL}$ (see Note 4)                    | K             | $V_{DD}$ |     | -4    | V           |
|                                                                   | INIT or Clock | $V_{DD}$ | -15 | -8    |             |
| Clock cycle time, $t_C(\phi)$                                     |               | 2.5      | 3   | 10    | $\mu s$     |
| Instruction cycle time, $t_c$                                     |               | 15       |     | 60    |             |
| Pulse width, clock high, $t_W(\phi H)$                            |               | 1        |     |       | $\mu s$     |
| Pulse width, clock low, $t_W(\phi L)$                             |               | 1        |     |       | $\mu s$     |
| Sum of rise time and pulse width, clock high, $t_r + t_W(\phi H)$ |               | 1.25     |     |       | $\mu s$     |
| Sum of fall time and pulse width, clock low, $t_f + t_W(\phi L)$  |               | 1.25     |     |       | $\mu s$     |
| Oscillator frequency, $f_{osc}$                                   |               | 100      |     | 400   | kHz         |
| Operating free-air temperature, $T_A$                             |               | 0        |     | 70    | $^{\circ}C$ |

**NOTES:**

- 1. Unless otherwise noted, all voltages are with respect to  $V_{SS}$ .
- 2. These average values apply for any 100-ms period.
- 3. Ripple must not exceed 0.2 volts peak-to-peak in the operating frequency range.
- 4. The algebraic convention where the most-positive (least-negative) limit is designated as maximum is used in this specification for logic voltage levels only.



NOTE: Timing points are 90% (high) and 10% (low).

#### **EXTERNALLY DRIVEN CLOCK INPUT WAVEFORM**

## COP402/COP402M



Output Sink Current



Depletion Load OFF Source Current



Standard Output Source Current



High Drive Source Current



Push-Pull Source Current



LED Output Source Current



LED Output Direct LED Drive



TRI-STATE® Output Source Current



Input Load Source Current

### Output Characteristics

# PPS4/1 MM75

## SPECIFICATIONS

### OPERATING CHARACTERISTICS

#### Supply Voltage:

V<sub>DD</sub> = 15 Volts  $\pm 5\%$   
 (Logic "1" = most negative voltage V<sub>IH</sub> and V<sub>OL</sub>)  
 V<sub>SS</sub> = 0 Volts (Gnd.)  
 (Logic "0" = most positive voltage V<sub>IH</sub> and V<sub>OH</sub>.)

#### System Operating Frequencies:

80 kHz  $\pm 50\%$  with external resistor

#### Device Power Consumption:

75 mW, typical

#### Input Capacitance:

<5 pF

#### Input Leakage:

<10  $\mu$ A

#### Open Drain Driver Leakage (R OFF):

$\leq 10 \mu$ A at -30 Volts

#### Operating Ambient Temperature (TA):

0°C to 70°C (TA = 25°C unless otherwise specified.)

#### Storage Temperature:

-55°C to 120°C

### ABSOLUTE MAXIMUM VOLTAGE RATINGS

(with respect to V<sub>SS</sub>)

Maximum negative voltage on any pin -30 volts.

Maximum positive voltage on any pin +0.3 volts.

| INPUT/OUTPUT                                 | SYMBOL                                    | LIMITS (V <sub>SS</sub> = 0) |          |     | LIMITS (V <sub>SS</sub> = +5V) |          |     | TIMING<br>(SAMPLE/<br>GOOD) | TEST<br>CONDITIONS                    |
|----------------------------------------------|-------------------------------------------|------------------------------|----------|-----|--------------------------------|----------|-----|-----------------------------|---------------------------------------|
|                                              |                                           | MIN                          | TYP      | MAX | MIN                            | TYP      | MAX |                             |                                       |
| Supply Current (Average) for V <sub>DD</sub> | IDD                                       | 5 mA                         | 8 mA     |     | 5 mA                           | 8 mA     |     |                             | V <sub>DD</sub> = -15.75V<br>T = 25°C |
| Discrete I/O's                               |                                           |                              |          |     |                                |          |     |                             |                                       |
| DI/O 0-DI/O 8                                | V <sub>IH</sub><br>V <sub>IL</sub>        | -1.0V<br>-4.2V               |          |     | +4.0V<br>+0.8V                 |          |     | φ34                         |                                       |
| DI/O 0-5                                     | RON                                       |                              | 500 ohms |     |                                | 500 ohms |     |                             |                                       |
| DI/O 6-8                                     | RON                                       |                              | 400 ohms |     |                                | 400 ohms |     | φ2*                         |                                       |
| Channel 1 Input<br>PI1-PI4                   | V <sub>IH</sub><br>V <sub>IL</sub>        | -1.5V<br>-4.2V               |          |     | +3.5V<br>+0.8V                 |          |     | φ1                          |                                       |
| I/O Channel A<br>RI/O1-RI/O4                 | V <sub>IH</sub><br>V <sub>IL</sub><br>RON | -1.5V<br>-4.2V<br>250 ohms   |          |     | +3.5V<br>+0.8V<br>250 ohms     |          |     | φ3<br>φ2*                   | 3.0 mA max.                           |
| I/O Channel B<br>RI/O5-RI/O8                 | V <sub>IH</sub><br>V <sub>IL</sub><br>RON | -1.5V<br>-4.2V<br>250 ohms   |          |     | +3.5V<br>+0.8V<br>250 ohms     |          |     | φ3<br>φ2*                   | 6.0 mA max.                           |
| INT0                                         | V <sub>IH</sub><br>V <sub>IL</sub>        | -1.5V<br>-4.2V               |          |     | +3.5V<br>+0.8V                 |          |     | φ3                          |                                       |
| Clock<br>A                                   | V <sub>OH</sub><br>V <sub>OL</sub>        | -1.0V<br>-10.0V              |          |     | +4.0V<br>-5.0V                 |          |     |                             | CL = 50 pF (max)                      |
| VC                                           | V <sub>IH</sub><br>V <sub>IL</sub>        |                              |          |     |                                |          |     |                             | 56 K $\pm 5\%$                        |
| PO                                           | V <sub>IH</sub><br>V <sub>IL</sub>        | -2.0V<br>-6.0V               |          |     | +3.0V<br>-1.0V                 |          |     |                             | Special circuit                       |

\*State established by φ2 (minimum impedance after φ4).

\*\*Same as above except φ4 minimum at φ2 of next cycle.

# PPS4/1 MM76 and MM76E

## SPECIFICATIONS

### OPERATING CHARACTERISTICS

#### Supply Voltage:

V<sub>DD</sub> = 15 Volts  $\pm 5\%$   
 (Logic "1" = most negative voltage V<sub>IH</sub> and V<sub>OL</sub>)  
 V<sub>SS</sub> = 0 Volts (Gnd.)  
 (Logic "0" = most positive voltage V<sub>IL</sub> and V<sub>OH</sub>)

#### System Operating Frequencies:

80 kHz  $\pm 50\%$  with external resistor

#### Device Power Consumption:

75 mw, typical

#### Input Capacitance:

<5 pf

#### Input Leakage:

<10  $\mu$ A

#### Open Drain Driver Leakage (R OFF):

$\leq 10 \mu$ A at -30 Volts

#### Operating Ambient Temperature (TA):

0°C to 70°C (TA = 25°C unless otherwise specified.)

#### Storage Temperature:

-55°C to 120°C

### ABSOLUTE MAXIMUM VOLTAGE RATINGS (with respect to V<sub>SS</sub>)

Maximum negative voltage on any pin -30 volts.

Maximum positive voltage on any pin +0.3 volts.

| INPUT/OUTPUT                                 | SYMBOL                                                | LIMITS (V <sub>SS</sub> = 0) |      |          | LIMITS (V <sub>SS</sub> = +5V) |          |       | TIMING<br>(SAMPLE/<br>GOOD) | TEST<br>CONDITIONS                   |
|----------------------------------------------|-------------------------------------------------------|------------------------------|------|----------|--------------------------------|----------|-------|-----------------------------|--------------------------------------|
|                                              |                                                       | MIN                          | TYP  | MAX      | MIN                            | TYP      | MAX   |                             |                                      |
| Supply Current (Average) for V <sub>DD</sub> | IDD                                                   | -5 mA                        | 8 mA |          | 5 mA                           | 8 mA     |       |                             | V <sub>DD</sub> = 15.75V<br>T = 25°C |
| Discrete I/O's                               |                                                       |                              |      |          |                                |          |       |                             |                                      |
| DI/O 0-DI/O 9                                | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.0V                        |      | -4.2V    | +4.0V                          |          | +0.8V | $\phi 34$                   |                                      |
| DI/O 0-5                                     | R <sub>ON</sub>                                       |                              |      | 500 ohms |                                | 500 ohms |       |                             |                                      |
| DI/O 6-9                                     | R <sub>ON</sub>                                       |                              |      | 400 ohms |                                | 400 ohms |       | $\phi 2^*$                  |                                      |
| Channel 1 Input<br>P11-P14                   | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.5V                        |      | -4.2V    | +3.5V                          |          | +0.8V | $\phi 1$                    |                                      |
| Channel 2 Input<br>P15-P18                   | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.5V                        |      | -4.2V    | +3.5V                          |          | +0.8V | $\phi 3$                    |                                      |
| I/O Channel A<br>RI/O1-RI/O4                 | V <sub>IH</sub><br>V <sub>IL</sub><br>R <sub>ON</sub> | -1.5V                        |      | -4.2V    | +3.5V                          |          | +0.8V | $\phi 3$                    |                                      |
|                                              |                                                       |                              |      | 250 ohms |                                | 250 ohms |       | $\phi 2^*$                  |                                      |
| I/O Channel B<br>RI/O5-RI/O8                 | V <sub>IH</sub><br>V <sub>IL</sub><br>R <sub>ON</sub> | -1.5V                        |      | -4.2V    | +3.5V                          |          | +0.8V | $\phi 3$                    |                                      |
|                                              |                                                       |                              |      | 250 ohms |                                | 250 ohms |       | $\phi 2^*$                  |                                      |
| DATA I                                       | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.0V                        |      | -4.2V    | +4.0V                          |          | +0.8V | $\phi 4$                    |                                      |
| DATA O                                       | R <sub>ON</sub>                                       |                              |      | 500 ohms |                                | 500 ohms |       | $\phi 4^{**}$               |                                      |
| INT0                                         | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.5V                        |      | -4.2V    | +3.5V                          |          | +0.8V | $\phi 3$                    |                                      |
| INT1                                         | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.5V                        |      | -4.2V    | +3.5V                          |          | +0.8V | $\phi 1$                    |                                      |
| Clock<br>A, BP, (B)                          | V <sub>OH</sub><br>V <sub>OL</sub>                    | -1.0V                        |      | -10.0V   | +4.0V                          |          | -5.0V |                             |                                      |
| EXCLK***                                     | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.5V                        |      | -9.0V    | +3.5V                          |          | -4.0V | -4.0V                       |                                      |
| CLK IN                                       | V <sub>IH</sub><br>V <sub>IL</sub>                    | -1.0V                        |      | -10.0V   | +4.0V                          |          | -5.0V |                             |                                      |
| Shift Clock<br>Clock                         | V <sub>IH</sub><br>V <sub>IL</sub><br>R <sub>ON</sub> | -1.0V                        |      | -4.2V    | +4.0V                          |          | +0.8V | $\phi 34$                   |                                      |
|                                              |                                                       |                              |      | 500 ohms |                                | 500 ohms |       | $\phi 4^{**}$               |                                      |
| VC                                           | V <sub>IH</sub><br>V <sub>IL</sub>                    |                              |      |          |                                |          |       |                             | 2.0 mA max.<br>56K $\pm 5\%$         |
| PO                                           | V <sub>IH</sub><br>V <sub>IL</sub>                    | -2.0V                        |      | -6.0V    | +3.0V                          |          | -1.0V |                             | Special circuit                      |

\*State established by  $\phi 2$  (minimum impedance after  $\phi 4$ ).

\*\*Same as above except  $\phi 4$  minimum at  $\phi 2$  of next cycle.

\*\*\*Requires selected resistor at VC. Contact Rockwell for specific requirements when using external oscillator.

# PPS4/1 MM76C

## SPECIFICATIONS

### 52-PIN IN-LINE SOCKET

Burndy P/N: DILE-52P1  
 Burndy Corp., 931 S. Douglas  
 El Segundo, Calif. 90245

### OPERATING CHARACTERISTICS

VDD = -15 Volts ±5%  
 (Logic "1" = most negative voltage VIL and VOL)  
 VSS = 0 Volts (GND)  
 (Logic "0" = most positive voltage VIH and VOH)  
 System Operating Frequencies:  
 89 kHz ±25% (internal clock)  
 Device Power Consumption:  
 200 mW, typical

### Input Capacitance:

<5 pf

### Input Leakage:

<10 μA

### Open Drain Driver Leakage (R OFF):

<10 μA at -30 Volts

### Operating Ambient Temperature (TA):

0°C to 70°C (TA = 25°C unless otherwise specified)

### Storage Temperature:

-55°C to 120°C

### ABSOLUTE MAXIMUM VOLTAGE RATINGS

(with respect to VSS)

Maximum negative voltage on any pin -30 volts.

Maximum positive voltage on any pin +0.3 volt.

| Input/Output                          | Symbol          | Limits (VSS = 0) |          |       | Limits (VSS = +5V) |     |     | Timing<br>(Sample/<br>Good) | Test<br>Conditions   |
|---------------------------------------|-----------------|------------------|----------|-------|--------------------|-----|-----|-----------------------------|----------------------|
|                                       |                 | Min              | Typ      | Max   | Min                | Typ | Max |                             |                      |
| Supply Current (Average) for VDD      | I <sub>DD</sub> |                  | 12 mA    |       |                    |     |     |                             |                      |
| Discrete I/O's<br>DI/O 0-DI/O 9       | VIH<br>VIL      | -1.0V            | -4.2V    | +4.0V | +0.8V              |     |     | 03 & 04                     |                      |
| DI/O 0-5                              | RON             |                  | 500 ohms |       | 500 ohms           |     |     | 02*                         |                      |
| DI/O 6-9                              | RON             |                  | 400 ohms |       | 400 ohms           |     |     |                             |                      |
| Channel 1 Input<br>PI1-PI4            | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 01                          |                      |
| Channel 2 Input<br>PI5-PI8            | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 03                          |                      |
| I/O Channel A<br>RI/O1-RI/O4          | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 03                          |                      |
|                                       | RON             |                  | 250 ohms |       | 250 ohms           |     |     | 02*                         |                      |
| I/O Channel B<br>RI/O5-RI/O8          | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 03                          |                      |
|                                       | RON             |                  | 250 ohms |       | 250 ohms           |     |     | 02*                         |                      |
| DATA1                                 | VIH<br>VIL      | -1.0V            | -4.2V    | +4.0V | +0.8V              |     |     | 04                          |                      |
| DATA0                                 | RON             |                  | 500 ohms |       | 500 ohms           |     |     | 04**                        |                      |
| INT0                                  | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 03                          |                      |
| INT1                                  | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 01                          |                      |
| Clock<br>A, BP, (B)                   | VOH<br>VOL      | -1.0V            | -10.0V   | +4.0V | -5.0V              |     |     | -5.0V                       | CL ≠ 50 pf (max)     |
| XPWR                                  | VIH<br>VIL      | VSS              | VDD      | VSS   | VDD                |     |     |                             |                      |
| XTLIN, XTLOUT                         | VIH<br>VIL      |                  |          |       |                    |     |     |                             | Crystal<br>3.579 MHz |
| Shift Clock<br>CLOCK                  | VIH<br>VIL      | -1.0V            | -4.2V    | +4.0V | +0.8V              |     |     | 03 & 04                     |                      |
|                                       | RON             |                  | 500 ohms |       | 500 ohms           |     |     | 04**                        |                      |
| PO                                    | VIH<br>VIL      | -2.0V            | -6.0V    | +3.0V | -1.0V              |     |     |                             |                      |
| PC1                                   | VIH<br>VIL      | -1.5V            | -4.2V    | +4.5V | +0.8V              |     |     | DC                          |                      |
| PC2                                   | VIH<br>VIL      | -1.5V            | -4.2V    | +4.5V | +0.8V              |     |     | DC                          |                      |
| CA8 LOWER CARRY<br>OUT                | RON             |                  | 500 ohms |       | 500 ohms           |     |     | DC                          |                      |
| CA16/D UPPER CARRY<br>SERIAL DATA OUT | RON             |                  | 500 ohms |       | 500 ohms           |     |     | 03 & 04                     |                      |
| SYEV SERIAL EVENT<br>INPUT            | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | 03                          |                      |
| SCC/D SHIFT CLOCK<br>CONTROL/DATA     | VIH<br>VIL      | -1.0V            | -10.0V   | +4.0V | +0.8V              |     |     | 03 & 04                     |                      |
| C/DI CONTROL/DATA<br>INPUT            | VIH<br>VIL      | -1.0V            | -10.0V   | +4.0V | +0.8V              |     |     | 03                          |                      |
| ENABL                                 | VIH<br>VIL      | -1.5V            | -4.2V    | +3.5V | +0.8V              |     |     | DC                          |                      |

\*State established by 02 (minimum impedance after 04)

\*\*Same as above except 04 minimum at 02 of next cycle.

# PPS4/1 MM76L and MM76EL

## SPECIFICATIONS

### OPERATING CHARACTERISTICS

#### Supply Voltage:

$V_{DD}$  = -8.5 Volts -2.5, +2.0 Volts  
 (Logic "1" = most negative voltage  $V_{IL}$  and  $V_{OL}$ )  
 $V_{SS}$  = 0 Volts (Gnd.)  
 (Logic "0" = most positive voltage  $V_{IH}$  and  $V_{OH}$ )

#### System Operating Frequencies:

- (1) Internal: 100 kHz Nominal at  $V_{DD}$  = -8.5V
- (2) External 800 kHz Crystal: 100 kHz

#### Device Power Consumption: 15 mw, typical

Input Capacitance: <5 pf

Input Leakage: <10  $\mu$ A

Open Drain Driver Leakage (R OFF): <10  $\mu$ A at -30 Volts

Operating Ambient Temperature ( $T_A$ )

0°C to +70°C (Commercial): MM76L and MM76EL  
 -40°C to +85°C (Industrial): MM76L-2 and MM76EL-2

Storage Temperature: -55°C to 120°C

### ABSOLUTE MAXIMUM VOLTAGE RATINGS (with respect to $VSS$ )

Maximum negative voltage on any pin -30 volts.  
 Maximum positive voltage on any pin +0.3 volts.

TEST CONDITIONS:  $V_{DD} = -8.5V$ ,  $T_A = 25^\circ C$

| INPUT/OUTPUT                          | SYMBOL   | LIMITS ( $VSS = 0$ ) |      |          | LIMITS ( $VSS = +5V$ ) |      |          | TIMING (SAMPLE/GOOD) | TEST CONDITIONS                 |
|---------------------------------------|----------|----------------------|------|----------|------------------------|------|----------|----------------------|---------------------------------|
|                                       |          | MIN                  | TYP  | MAX      | MIN                    | TYP  | MAX      |                      |                                 |
| Supply Current (Average) for $V_{DD}$ | IDD      | 1.75 mA              | 3 mA |          | 1.75 mA                | 3 mA |          |                      |                                 |
| Discrete I/O's<br>DI/O 0-9            | $V_{IH}$ | -1.0V                |      | -4.2V    | +4.0V                  |      | +0.8V    | $\phi 34$            | 10.0 mA max.                    |
|                                       | $V_{IL}$ |                      |      |          | 100 ohms               |      | 100 ohms | $\phi 2^*$           |                                 |
| Channel 1 Input<br>PI1-PI4            | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.5V                  |      | +0.8V    | $\phi 1$             |                                 |
| Channel 2 Input<br>PI5-PI8            | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.5V                  |      | +0.8V    | $\phi 3$             |                                 |
| I/O Channel A<br>RIO1-RIO4            | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.5V                  |      | +0.8V    | $\phi 4$             | 6.0 mA max.                     |
|                                       | RON      |                      |      | 250 ohms |                        |      | 250 ohms | $\phi 2^*$           |                                 |
| I/O Channel B<br>RIO5-RIO8            | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.5V                  |      | +0.8V    | $\phi 4$             | 6.0 mA max.                     |
|                                       | RON      |                      |      | 250 ohms |                        |      | 250 ohms | $\phi 2^*$           |                                 |
| DATA I                                | $V_{IH}$ | -1.0V                |      | -4.2V    | +4.0V                  |      | +0.8V    | $\phi 4$             |                                 |
| DATA O                                | RON      |                      |      | 500 ohms |                        |      | 500 ohms | $\phi 4^{**}$        | 3.0 mA max.                     |
| INT0                                  | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.5V                  |      | +0.8V    | $\phi 3$             |                                 |
| INT1                                  | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.5V                  |      | +0.8V    | $\phi 1$             |                                 |
| Clock<br>A, BP, (B)                   | $V_{OH}$ | -1.0V                |      | -6.0V    | +4.0V                  |      | -1.0V    |                      | $CL = 50 \text{ pf (max)}$      |
| XTLIN                                 | $V_{IH}$ | -1.5V                |      | -6.0V    | +3.5V                  |      | -1.0V    | -4.0V                |                                 |
| Shift Clock                           | $V_{IH}$ | -1.0V                |      | -4.2V    | +4.0V                  |      | +0.8V    | $\phi 34$            | 2.0 mA max.<br>$V = 11.0V$ max. |
|                                       | RON      |                      |      | 500 ohms |                        |      | 500 ohms | $\phi 4^{**}$        |                                 |
| VC                                    | $V_{IH}$ |                      |      |          |                        |      |          |                      | Special circuit                 |
| PO                                    | $V_{IH}$ | -1.5V                |      | -4.2V    | +3.0V                  |      | -1.0V    |                      |                                 |

\*State established by  $\phi 2$  (minimum impedance after  $\phi 4$ ).

\*\*Same as above except  $\phi 4$  minimum at  $\phi 2$  of next cycle.

#### NOTES:

#### MASK PROGRAMMED PULL-UP RESISTORS ON OUTPUTS

Resistor pull-ups are available as an option on all RIO and DI/O outputs. These pull-ups are connected to  $V_{DD}$ . The following values  $\pm 25\%$  are available: 3K, 5K, 10K, 15K, 25K, and Open Circuit.

#### PULL-UPS ON INPUTS

MOS FET Pull-ups are also available on the PI, INT, and DATA I inputs. The connection of this pull-up is optional. The output current is  $50 \mu\text{A} \pm 25 \mu\text{A}$  with the input grounded and  $V_{DD}$  at -8.5 volts.

# PP24/1 MM77 and MM78

## SPECIFICATIONS

### OPERATING CHARACTERISTICS

#### Supply Voltage:

V<sub>DD</sub> = 15 Volts  $\pm 5\%$   
 (Logic "1" = most negative voltage V<sub>IH</sub> and V<sub>OL</sub>)  
 V<sub>SS</sub> = 0 Volts (Gnd.)  
 (Logic "0" = most positive voltage V<sub>IH</sub> and V<sub>OH</sub>)

#### System Operating Frequencies:

80 kHz  $\pm 50\%$  with external resistor

#### Device Power Consumption:

75 mw, typical

#### Input Capacitance:

<5 pf

#### Input Leakage:

<10  $\mu$ A

#### Open Drain Driver Leakage (R OFF):

$\leq 10 \mu$ A at -30 Volts

#### Operating Ambient Temperature (TA):

0°C to 70°C (TA = 25°C unless otherwise specified.)

#### Storage Temperature:

-55°C to 120°C

### ABSOLUTE MAXIMUM VOLTAGE RATINGS (with respect to V<sub>SS</sub>)

Maximum negative voltage on any pin -30 volts.

Maximum positive voltage on any pin +0.3 volts.

| FUNCTION                                     | SYMBOL          | LIMITS (V <sub>SS</sub> = 0) |          |       | LIMITS (V <sub>SS</sub> = +5V) |       |      | TIMING<br>(SAMPLE/<br>GOOD)                  | TEST<br>CONDITIONS                   |
|----------------------------------------------|-----------------|------------------------------|----------|-------|--------------------------------|-------|------|----------------------------------------------|--------------------------------------|
|                                              |                 | MIN                          | TYP      | MAX   | MIN                            | TYP   | MAX  |                                              |                                      |
| Supply Current (Average) for V <sub>DD</sub> | I <sub>DD</sub> | 5 mA                         | 8 mA     |       | 5 mA                           | 8 mA  |      |                                              | V <sub>DD</sub> = 15.75V<br>T = 25°C |
| Discrete I/O's<br>DI/O 0 DI/O 9              | V <sub>IH</sub> | -1.0V                        |          | +4.0V |                                | +0.8V |      | Φ3                                           | 3.0 mA max.                          |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
|                                              | RON             |                              | 500 ohms |       | 500 ohms                       |       | Φ2*  |                                              |                                      |
| Channel 1 Input<br>P11-P14                   | V <sub>IH</sub> | -1.5V                        |          | +3.5V |                                | +0.8V |      | Φ1                                           | 3.0 mA max.                          |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
| Channel 2 Input<br>P15-P18                   | V <sub>IH</sub> | -1.5V                        |          | +3.5V |                                | +0.8V |      | Φ3                                           |                                      |
| I/O Channel A<br>RI/01-RI/04                 | V <sub>IH</sub> | -1.5V                        |          | +3.5V |                                | +0.8V |      | Φ3                                           | 3.0 mA max.                          |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
|                                              | RON             |                              | 500 ohms |       | 500 ohms                       |       | Φ2*  |                                              |                                      |
| I/O Channel X<br>RI/05-RI/08                 | V <sub>IH</sub> | -1.0V                        |          | +4.0V |                                | +0.8V |      | Not sync.<br>Must be stable at<br>Φ1 and Φ2. | 3.0 mA max.                          |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
|                                              | RON             |                              | 500 ohms |       | 500 ohms                       |       | Φ2*  |                                              |                                      |
| DATA I                                       | V <sub>IH</sub> | -1.0V                        |          | +4.0V |                                | +0.8V |      | Φ4                                           | 3.0 mA max.                          |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
|                                              | RON             |                              |          |       |                                |       |      | Φ4**                                         |                                      |
| INT0                                         | V <sub>IH</sub> | 1.5V                         |          | +3.5V |                                | +0.8V |      | Φ3                                           | CL = 50 pf (max.)                    |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
| INT1                                         | V <sub>IH</sub> | 1.5V                         |          | +3.5V |                                | +0.8V |      | Φ1                                           |                                      |
| Clock<br>A, BP, (B)                          | V <sub>OH</sub> | -1.0V                        |          | +4.0V |                                | 5.0V  |      |                                              | F max = 80 kHz                       |
|                                              | V <sub>OL</sub> |                              | 10.0V    |       |                                |       |      |                                              |                                      |
|                                              | EXCLK***        | V <sub>IH</sub>              | -1.5V    | +3.5V |                                | 2.0V  |      | STRAP                                        |                                      |
| CLK IN                                       | V <sub>IH</sub> | 1.0V                         |          | +4.0V |                                | -5.0V |      |                                              | 2.0 mA max.<br>56K $\pm 5\%$         |
|                                              | V <sub>IL</sub> |                              | 10.0V    |       |                                |       |      |                                              |                                      |
| Shift Clock<br>Clock                         | V <sub>IH</sub> | 1.0V                         |          | +4.0V |                                | +0.8V |      | Φ34                                          |                                      |
|                                              | V <sub>IL</sub> |                              | 4.2V     |       |                                |       |      |                                              |                                      |
|                                              | RON             |                              | 500 ohms |       | 500 ohms                       |       | Φ4** |                                              |                                      |
| VC                                           | V <sub>IH</sub> |                              |          |       |                                |       |      |                                              | Special circuit                      |
|                                              | V <sub>IL</sub> |                              |          |       |                                |       |      |                                              |                                      |
| PO                                           | V <sub>IH</sub> | 2.0V                         |          | +3.0V |                                | -1.0V |      |                                              |                                      |
|                                              | V <sub>IL</sub> |                              | 6.0V     |       |                                |       |      |                                              |                                      |

\* State established by Φ2 (minimum impedance after Φ1).

\*\* Same as above except Φ4 minimum at Φ2 of next cycle.

\*\*\* Requires selected resistor at VC. Contact Rockwell for specific requirements when using external oscillator.

## THE MC6809 MICROPROCESSOR

**The MC6809 is an advanced processor within the 6800 family. It is a high performance machine, both faster and more powerful than its predecessor (the MC6800), yet it retains hardware and software compatibility (at the source code level) with existing MC6800 parts.**

The MC6809 has been developed with particular attention to the software needs of the user. Because it **provides powerful new addressing modes and an extended register complement**, the MC6809 is capable of supporting modern software techniques, such as modular programming, position independent (self-relative) coding, recursive programming, reentrancy, and high level language generation.

The MC6809 instruction set contains fewer instructions than the MC6800; some existing 6800 instructions have been combined into more general and powerful ones, leaving room for some new ones. Many of these new MC6809 instructions perform 16-bit manipulations.

**The MC6809 retains all the MC6800 addressing modes and adds some new ones. These modes include long relative branches, sixteen variations of indexed addressing, Program Counter relative modes, and extended indirect modes.** This extension of existing modes retains the ease and familiarity of the 6800 language, but adds high performance capability where needed.

**Hardware improvements have also been implemented on the MC6809.** On-chip clock facilities have been added, an internal Schmitt trigger circuit has been incorporated to permit the use of an RC Reset Circuit, and the bus timing specifications have been improved to make the system easier to use. Some bus signals have been redefined, and new ones have been added, to permit the CPU to function in multiprocessor applications while **still retaining compatibility with existing parts.** In all, these enhancements, combined with the software enhancements, simplify the use, increase the throughput, and make the CPU tremendously more capable than its predecessor.

Motorola has clearly aimed the MC6809 at the vast consumer markets yet to come, as well as at existing markets that have already been penetrated by the MC6800. With the MC6809, Motorola has maximized the performance of its mid-range 6800 family, and now offers an updated product line that spans the range from the low-end single-chip MC6805 series through the expandable single-chip MC6801 and the mid-range MC6809, up to the newly introduced 16-bit processor, the MC68000.

The principal manufacturer is Motorola. The primary second source is AMI, and other firms that second source the MC6800 may also second source the MC6809.

**The MC6809 family is fabricated using N-channel, silicon gate, ion-implanted depletion load technology. It has TTL-level compatible inputs and outputs and operates from a single +5 volt power supply. All outputs are able to drive 130 pf (typically eight MOS devices) plus one standard TTL load (or four Low Power Schottky loads) at full rated bus speed.**

### THE MC6809 CPU

**Figure 9-62 illustrates that part of our general microcomputer system that is implemented on the MC6809.** Enhancements over the MC6800 include an on-chip clock, control logic for cycle-stealing DMA, and interrupt-priority arbitration. Not evident in this illustration is the enhanced register complement provided by the MC6809.



Figure 9-62. Logic of the MC6809 Microprocessor

## THE MC6809 PROGRAMMABLE REGISTERS

The MC6809 has an enriched set of registers as compared to the basic MC6800. The register complement consists of two Accumulators, a Status register, two Index registers, two stack Pointers, a Program Counter and a Direct Page register. The mobility of data between the registers has been improved by the introduction of a "Transfer Registers" instruction (TFR). This instruction, and the indexing capability of four of the MC6809 registers, overcomes most of the weaknesses of the 6800 CPU identified at the beginning of this chapter.

The following illustration shows the programmable registers provided by the MC6809. The registers that have been added beyond the basic 6800 CPU complement are shown shaded.



**Sixteen-bit operations are implemented by concatenating the A and B Accumulators to form one double-precision Accumulator D as follows:**



This concatenated Accumulator is referred to as ACCD.

**Four registers (X, Y, S, and U) provide indexing capability.** They permit a 16-bit Effective Address (EA) to be formed by the addition of an optional offset to the pre-loaded contents of the specified register. **There are some differences in the ways in which these registers operate and can be used.**

**Registers X and Y have been designated the Index registers.** Both are capable of performing the same indexing functions as were implemented on the basic MC6800, plus a great deal more. Full details are included below, in the memory addressing section.

**Two Stack Pointers have been provided, permitting the implementation of two independent Stacks.** These Stacks are implemented in read/write memory at the locations pointed to by their respective Stack Pointers. These Stacks function on a "Last-In, First-Out" (LIFO) basis.

**Stack Pointer S is a hardware stack pointer used by the processor to automatically save machine status and active register contents during subroutines and interrupts** in a manner similar to that of the MC6800. With the MC6809, however, the user has the option to save a subset only, or the entire register complement.

**Stack Pointer U is a User's Stack Pointer, controlled exclusively by the user's software.** It facilitates the passage of arguments to and from subroutines.

The Stack Pointers U and S feature the same indexing capabilities as the X and Y registers; thus, **S and U are essentially enhanced index registers.** (There are some differences when using the "Load Effective Address" (LEA) instructions. This will be discussed later.)

The Program Counter points to the next instruction to be executed. Its capability has been enhanced such that **Program Counter relative addressing is now provided.** This capability effectively permits the Program Counter to be used as an index register with limited capabilities.

**The Direct Page register (DPR) permits enhanced direct addressing by allowing a page (in addition to the base page) to be software relocated anywhere in memory during program execution.** By way of contrast, the MC6800 does not have a Direct Page register. All MC6800 instructions using the direct mode have their high-order address bytes fixed at 00 by hardware. This limits direct addressing in the MC6800 to the first 256 memory locations (0000 to 00FF).



Figure 9-63. MC6809 Direct Page Addressing Scheme

To enforce compatibility with the MC6800, the contents of the Direct Page register on the MC6809 are automatically cleared on Reset. To move the page to some other location, the user must software relocate it by loading the high-order address bytes into the Direct Page register during program execution. When an instruction using Direct Page addressing is executed, the contents of the Direct Page register are automatically concatenated with the usual 8-bit address byte contained in a direct instruction.

## MC6809 MEMORY ADDRESSING MODES

Let us now look at the addressing enhancements provided by the MC6809.

With the incorporation of a Direct Page register, direct addressing has been extended throughout all memory. Direct page addressing uses a two-byte instruction format in which the second byte specifies the address to be added to the Direct Page register contents. This scheme is illustrated in Figure 9-63. The Direct Page register contains the most significant byte of the 16-bit address to be accessed, while the second byte of the instruction contains the least significant byte.

**MC6809  
DIRECT PAGE  
ADDRESSING**

Since the contents of the Direct Page register are software defined, this page can be dynamically relocated within the read/write memory as desired during program execution.

Many of the new addressing modes require a byte immediately following the operation code to further define the interpretation of the instruction. This is called a Post Byte.

**MC6809  
POST BYTE**



While this added byte may at first seem wasteful of memory space, the extra power and flexibility provided far outweigh the small additional amount of memory required. It should also be noted that many programs will be composed primarily of familiar 6800-type instructions and that the amount of additional memory space consumed by those instructions requiring Post Bytes will usually constitute a relatively small percentage of the total memory used.

The meaning ascribed to the various bits in the Post Byte depends on the addressing mode — see Table 9-19.

The four registers X, Y, S, and U are indexable. The Post Byte in this case defines the options according to the scheme shown in Figure 9-64.

**MC6809  
INDEXED  
ADDRESSING**



Figure 9-64. MC6809 Post Byte Bit Assignments

Table 9-19. MC6809 Indexed Addressing Post Byte Register Bit Assignments

| Bit Number |   |   |   |   |   |   |   | Addressing Mode                | Line |
|------------|---|---|---|---|---|---|---|--------------------------------|------|
| 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                |      |
| 0          | R | R | X | X | X | X | X | ±4-Bit Offset                  | 1    |
| 1          | R | R | 0 | 0 | 0 | 0 | 0 | Auto Increment by One          | 2    |
| 1          | R | R | I | 0 | 0 | 0 | 1 | Auto Increment by Two          | 3    |
| 1          | R | R | 0 | 0 | 0 | 1 | 0 | Auto Decrement by One          | 4    |
| 1          | R | R | I | 0 | 0 | 1 | 1 | Auto Decrement by Two          | 5    |
| 1          | R | R | I | 0 | 1 | 0 | 0 | Zero Offset                    | 6    |
| 1          | R | R | I | 0 | 1 | 0 | 1 | Accumulator B Offset           | 7    |
| 1          | R | R | I | 0 | 1 | 1 | 0 | Accumulator A Offset           | 8    |
| 1          | R | R | I | 1 | 0 | 0 | 0 | ±7-Bit Offset                  | 9    |
| 1          | R | R | I | 1 | 0 | 0 | 1 | ±15-Bit Offset                 | 10   |
| 1          | R | R | I | 1 | 0 | 1 | 1 | Accumulator D Offset           | 11   |
| 1          | X | X | I | 1 | 1 | 0 | 0 | Program Counter ±7-Bit Offset  | 12   |
| 1          | X | X | I | 1 | 1 | 0 | 1 | Program Counter ±15-Bit Offset | 13   |
| 1          | X | X | I | 1 | 1 | 1 | 1 | Indirect                       | 14   |

Addressing Mode Field

Indirect Field  
(Sign bit when B7 = 0)

Register Field

00: R = X  
01: R = Y  
10: R = U  
11: R = S



Figure 9-65. MC6809 Constant Offset (Indexed Mode) Addressing

**Many options are provided — they are constant offset, accumulator offset (using Accumulator A, Accumulator B, or Accumulator D), auto increment or decrement (by one or two) and indirection.**

Figure 9-65 illustrates a two-byte offset. However, some options do not require any offset, while others require one and still others require two. Thus, depending on the option chosen, the indexed mode may require two, three, or four bytes.

**Note: Most MC6800 indexed instructions map into an equivalent two bytes on the MC6809.**

**In the constant offset mode, the offset is temporarily added to the value contained in the specified register to form an Effective Address (EA).** Note that these offsets may be positive or negative. In contrast, the MC6800 permits only positive offsets.

**Several variations of constant offset indexing are provided.** One of the variations uses bit space in the Post Byte itself to specify the offset. In this case, the offset is limited to that which may be specified by four bits. The instruction thus consists of the op-code and the Post Byte — no additional offset bytes are used. The offset is specified by the bit pattern contained in bit positions 0 through 3. Bit position 4 contains the sign of the displacement. This can be illustrated as follows:

**MC6809  
CONSTANT  
OFFSET  
INDEXING  
ADDRESSING**



The second constant offset mode is a three-byte instruction, consisting of an op-code, a Post Byte, and a 7-bit two's complement offset. This mode can be illustrated as follows:



To achieve longer offsets than provided above, two offset bytes are used; a four-byte instruction results. The offset is specified in two's complement form. The applicable Post Byte is shown as line 10 in Table 9-19.

**Accumulator offset is implemented as a two-byte instruction. There are three variations, one for each of the Accumulators A, B, and D** (see lines 8, 7, and 11 of Table 9-19). The contents of the specified accumulator are treated by the instruction as a two's complement offset. Since this is rather complex, let us illustrate with an example. Suppose Accumulator D contains 1107<sub>16</sub> and Index Register X contains 1032<sub>16</sub>. The Post Byte, shown here,

**MC6809  
ACCUMULATOR  
OFFSET  
ADDRESSING**



specifies that the contents of Accumulator D are to be added to the contents of the X register to form an Effective Address (EA):

$$EA = 1107_{16} + 1032_{16} = 2139_{16}$$

This is the address to be accessed by the instruction.

**A zero offset addressing option is also defined in which the selected pointer register (X, Y, S, or U) contains the effective address of the data to be used by the instruction.** This is a two-byte instruction which may incorporate an automatic increment or automatic decrement of the addressing register's contents as part of the addressing mode mechanization.

**MC6809  
ZERO OFFSET  
ADDRESSING**

**When auto increment is employed, the address in the designated register (X, Y, U, or S) is used to access the desired memory location, then the contents of the register are automatically incremented.** Incrementation is by one or two, depending on the bit configuration of the Post Byte — see Table 9-19, lines 2 and 3 (reproduced below).

**MC6809 AUTO INCREMENT ADDRESSING**



**When auto decrement is employed, the address in the designated register (X, Y, U, or S) is decremented, then the updated address is used to access the desired memory location.** Decrementation is by one or two, depending on the bit configuration of the Post Byte — see Table 9-19, lines 4 and 5.

**MC6809 AUTO DECREMENT ADDRESSING**

**Indexed indirect addressing is also provided for all indexed options except the  $\pm 5$ -bit offset case and the auto increment/decrement-by-one cases.** Bit 4 of the Post Byte is used to define whether the instruction is indirect or not (see Table 9-19). Indexed indirect addressing as implemented on the MC6809 is a pre-indexed mechanization, as described in Volume 1, Chapter 6. The offset value referenced by the instruction is temporarily added to the contents of the designated pointer register (X, Y, U, or S) to form an indexed address. The memory location pointed to by this indexed address contains the actual address desired.

**MC6809 INDEXED INDIRECT ADDRESSING**

The offset for indexed indirect addressing is specified as 8-bit or 16-bit twos complement offset following the Post Byte, as illustrated in Figure 9-66.

**Accumulator indexed indirect addressing** obtains the offset as a twos complement number from one of the Accumulators A, B, or D as specified by the instruction.

**Indirect addressing for the auto increment/decrement cases is implemented only for the increment by two and decrement by two cases** — thus indirect increment and indirect decrement by one are not permitted.

**For the case of auto increment indirect, the address in the designated pointer register (X, Y, U, or SP) is used to recover an address from memory. This recovered address is the address of the location to be accessed (the Effective Address). Following this transaction, the contents of the Pointer register are incremented by two.** Post Byte bit definitions are indicated in Table 9-19.

**Auto decrement indirect is similar to auto increment indirect.** In this case, however, the specified register contents are decremented twice before the indirect address is abstracted from the register. Post Byte bit definitions are indicated in Table 9-19.

**Limited indexed mode addressing is also permitted with the Program Counter.** This is detailed in Table 9-19 (lines 12 and 13). Note that 8-bit and 16-bit offsets only are provided.

**Relative addressing in the MC6809 has been greatly enhanced over that provided in the basic MC6800.** First, it is no longer limited to branch instructions and, second, the relative range has been extended through the use of a 16-bit twos complement offset.

**MC6809 RELATIVE ADDRESSING**

Relative addressing is an important ingredient in position-independent coding, and the enhanced scheme provided on the MC6809 greatly facilitates this method of program structuring.

All branch instructions have been implemented in the traditional MC6800 form (referred to as the short form) and in a long form. The short form takes a one-byte op-code with a one-byte offset, while the long form takes a one- or two-byte op-code with a two-byte offset. For the long branch case, the actual address is formed by adding the two bytes following the op-code as a twos complement number to the Program Counter. (Remember, the Program Counter points to the next instruction — thus, it has already stepped over the offset bytes.)



Figure 9-66. MC6809 Constant Offset Indexed Indirect Addressing

**Relative addressing has been extended to include all memory reference instructions. It has been implemented as Program Counter relative indexed addressing.** Two variations are permitted; one uses an 8-bit two's complement offset (for short reaches), and the other uses a 16-bit two's complement offset (for long reaches). Table 9-19 defines the Post Bytes for these two cases (lines 12 and 13). The general address formation scheme is similar to that of Figure 9-67. This is illustrated below for a short relative transfer.



Figure 9-67. MC6809 Long Branch Addressing

This example illustrates the position-independent nature of this form of addressing:



The MC6809 assembler requires that you use the mnemonic "PCR" for Program Counter relative addressing. The assembler then automatically computes the distance or offset from the "present" Program Counter value to the specified location.

From Table 9-21, we determine that the hex code for LDA (indexed) is A6. From Table 9-19, line 12, we get the Post Byte.





Figure 9-68. MC6809 Relative Indirect Addressing

Assume the program segment starts at address 100016.



During execution, the updated Program Counter value is added to the offset; thus, if the program is relocated, it still functions correctly since the location referenced remains the same relative distance away.

Long reaches are similar to the above, except that the Post Byte is 8D<sub>16</sub> (line 13 of Table 9-19), and two bytes are required for the two's complement offset.

**Relative indirect addressing is an extension of relative addressing. The Program Counter is used again as an indexed register. The general scheme is illustrated in Figure 9-68.**

The offset (one or two bytes, two's complement) is added to the updated contents of the Program Counter to form a pointer to a pair of memory locations which contain the actual address to be accessed. For a one-byte offset, the Post Byte is 9C<sub>16</sub>; for a two-byte offset, the Post Byte is 9D<sub>16</sub> — see Table 9-19, lines 12 and 13.

**Instructions that use indirect addressing require four bytes of object code: an op-code, a Post Byte and two bytes which specify a 16-bit address. These last two bytes are a pointer to a location that contains the actual address to be referenced.** This approach to indirect addressing differs from that of Volume 1, Chapter 6 only in that a Post Byte is used. The Post Byte has a value of 10011111 (9F<sub>16</sub>) as defined by line 14 of Table 9-19. (This mode is shown in Table 9-19, since it is actually implemented as an indexed, indirect instruction, relative to the Program Counter.)

**MC6809  
RELATIVE  
INDIRECT  
ADDRESSING**

## MC6809 STATUS FLAGS

The MC6809 has a Status register which maintains five status flags and three interrupt control bits. The five status flags are:

Carry (C)  
Overflow (V)  
Sign (S)  
Zero (Z)  
Auxiliary or Half-Carry (H)

Statuses are assigned bit positions within the Status register as follows:



Note that the two high-order condition codes (bits 6 and 7) are used here; in the MC6800, MC6801, and MC6802 they are permanently set to 1.

**Bits 0 through 5 are the same as the corresponding MC6800/MC6801/MC6802 Status register bits; however, there are differences in how some of the instructions affect these bits:**

- 1) On the MC6800 and MC6802, only the Z bit is set correctly when the CPX instruction is executed. On the MC6809, all bits are handled correctly.
- 2) The multiply instruction (MUL) on the MC6809 sets the Z bit (if appropriate). The MUL instruction of the MC6801 does not.
- 3) On the MC6800, MC6801, and MC6802, the right shift instructions (ASR, LSR, and ROR) set the overflow bit (V) if applicable; the corresponding instructions on the MC6809 do not affect Overflow status.
- 4) The TST instruction on the MC6800, MC6801, and MC6802 clears the C bit; the MC6809 TST does not affect it.
- 5) The H bit is undefined on the MC6809 after the operations CMP, NEG, SBC, and SUB. The corresponding MC6800, MC6801, and MC6802 instructions all clear H.

Details of the effect of each instruction on the Status register bits are included in the MC6809 Instruction Set Summary — Table 9-23.

**Before describing the three remaining status bits, we must look at the hardware and software interrupts that are provided on the MC6809.**

**An additional maskable hardware interrupt, designated FIRQ, has been provided on the MC6809. This is a Fast Interrupt Request input, masked by bit 6(F) of the Status register.** FIRQ causes only a subset of registers to be pushed onto the Stack. The three hardware interrupts are, in order of priority, NMI (highest and non-maskable), FIRQ (maskable by the F bit) and IRQ (lowest and maskable by the I bit).

**Three software interrupts are provided. They are SWI, SWI2 and SWI3.**

**Let us now return to the three status bits I, F, and E.**

**I is the external interrupt disable flag associated with hardware interrupt input IRQ.** When I = 1, interrupts via IRQ are disabled; when I = 0, interrupts via IRQ are enabled. NMI, FIRQ, IRQ, RESET and SWI all set I to 1. SWI2 and SWI3 have no effect on I.

**F is the external interrupt disable flag associated with hardware interrupt input FIRQ.** When F = 1, interrupts via FIRQ are disabled; when F = 0, interrupts via FIRQ are enabled. NMI, FIRQ, IRQ, SWI and RESET all set F to 1: IRQ, SWI2 and SWI3 have no effect on F.

**E is the Entire flag bit.** The occurrence of NMI, IRQ, SWI, SWI2 or SWI3 sets E and stacks the entire machine register complement, while FIRQ clears E and stacks only the Program Counter and the Status register. Note that only the E bit in the saved or Stack Status register has any significance.

**E is used at the end of interrupt processing to determine how much to unstack.** When the RTI instruction is executed at the end of an interrupt, the processor checks the E bit from the recovered Status register. If E = 1, the full complement of registers is restored from the Stack, whereas, if E = 0, only the subset consisting of the Program Counter and Status register is retrieved.

## MC6809 CPU PINS AND SIGNALS

The MC6809 CPU pins and signals are illustrated in Figure 9-69. A description of these signals is useful as a guide to the way in which the MC6809 works and to the ways in which it differs from the MC6800.



| Pin Name    | Description            | Type                    |
|-------------|------------------------|-------------------------|
| *A0-A15     | Address Lines          | Tristate, Output        |
| *D0-D7      | Data Bus Lines         | Tristate, Bidirectional |
| *E, Q       | Clock Signals          | Output                  |
| *R/W        | Read/Write             | Tristate, Output        |
| *BA         | Bus Available          | Output                  |
| *BS         | Bus State              | Output                  |
| EXTAL, XTAL | Crystal                | Input                   |
| *MRDY       | Memory Ready           | Input                   |
| *DMA/BREQ   | DMA/Bus Request        | Input                   |
| *HALT       | Halt                   | Input                   |
| *RESET      | Reset                  | Input                   |
| NMI         | Non-Maskable Interrupt | Input                   |
| *FIRO       | Fast Interrupt Request | Input                   |
| *IRQ        | Interrupt Request      | Input                   |
| VDD, VSS    | Power and Ground       |                         |

\*These signals connect to the System Bus.

Figure 9-69. MC6809 CPU Signals and Pin Assignments

The RESET input is used to initialize the CPU. To reset it, the RESET line must be asserted low for at least one bus cycle. This aborts the current operation. An internal Schmitt Trigger circuit on the RESET input permits the use of a simple RC network to reset the entire system.



**EXTAL and XTAL are inputs for a parallel resonant crystal;** alternatively, EXTAL may be driven by an external TTL-level compatible clock by grounding the XTAL pin.

**The Enable pin E distributes the clocking signal to the rest of the system.** It is a standard 6800 Bus system timing signal and is usually connected to the E inputs of MC6800 family devices.

**Q is a new clocking output signal that has no counterpart in the MC6800, MC6801, or MC6802 versions.** Its positive transition indicates when stable address exist on the system busses.

**Memory Ready (MRDY)** is an input control signal that is used to extend the data access time when slow memories are used. It is also used to extend the access time in multiprocessor applications when shared memories are used.

**The Address Bus lines (A0 to A15) and Data Bus lines (D0 to D7) are standard 6800 peripheral-compatible busses.** Their relationship with bus control signals is detailed later.

**R/W is the same as the MC6800 signal.** It is valid with the positive transition of Q.

**Control signals on the MC6809 Control Bus may be divided into bus state controls, bus data identification, and interrupt processing.** There are some lines here that do not exist on the MC6800.

MC6809  
BUS STATE  
CONTROLS

**These are the bus state control lines:**

**DMA/Bus Request (DMA/BREQ):** This is an input line used for DMA or memory refresh operations. When asserted low, it suspends CPU operation (by stretching the internal CPU clock), takes the processor off the bus and tristates the system busses. (There is no equivalent to this line on the MC6800 — in fact, it takes two lines, TSC and DBE, just to float the system busses.)

**No DBE (Data Bus Enable) input is provided on the MC6809.** The equivalent of DBE is generated internally by the processor.

**HALT:** When this input is asserted low, the CPU ceases operation at the end of the current instruction and the system busses (Address, Data and R/W) are tristated. The CPU may remain in the halted state indefinitely without loss of data.

**Bus Available (BA):** This output line (when driven high by internal logic) indicates that the system busses (Address, Data and R/W) are in their high impedance state and available to external devices for Direct Memory Access (DMA) transactions or any other form of bus sharing activities permitted. BA high does not imply that the bus will be available for more than one cycle, however. When driven low (by internal logic) an additional bus cycle at high impedance occurs before resuming operation.

**Bus State (BS): This is an encoded output** which, in conjunction with output BA, indicates the current state of the CPU. Combinations are listed in Table 9-20.

Table 9-20. MC6809 Bus Status Signals

| BA | BS | Function                      |
|----|----|-------------------------------|
| 0  | 0  | Normal Operation (Running)    |
| 0  | 1  | Interrupt Acknowledge         |
| 1  | 0  | SYNC Acknowledge              |
| 1  | 1  | BUS GRANT or HALT Acknowledge |

Status indications are valid on the leading edge of Q.

**No VMA (Valid Memory Address) output is provided on the MC6809 — instead, when the processor does not need to use the system busses for a data transfer, it simultaneously sets all address lines high (FFFF<sub>16</sub>) and R/W = 1.** This is a "dummy" read of address FFFF. During this dummy read, both BA and BS = 0. The only other required read of address FFFF occurs during a fetch of the low-order Reset vector address. During this access of FFFF, however, BA = 0 and BS = 1 (see Table 9-20). Thus, the status of lines BA and BS permits the user to differentiate between these two situations. (Note that MRDY cannot be used to extend one of these dummy cycles.)

MC6809  
VMA  
CONDITION

**These are the three interrupt processing signals:**

**Non-Maskable Interrupt (NMI):** This interrupt cannot be masked. It is an edge-sensitive (as opposed to level-sensitive) input that responds to a high-to-low transition. On NMI, the full register complement is stacked. NMI has the highest priority.

**IRQ** is a hardware Interrupt Request input. An interrupt generated at **IRQ** stacks the full complement of CPU registers. **IRQ** has lowest priority.

**FIRQ** is a Fast Hardware Interrupt Request input. It provides fast response by stacking only the return address and the Status register. It has higher priority than IRQ but less than NMI.

## MC6809 TIMING AND INSTRUCTION EXECUTION

An internal divide-by-four circuit on the MC6809 permits the use of inexpensive, parallel resonant crystals. Alternatively, EXTAL may be driven by an external TTL-level compatible clock. Since the internal divide-by-four circuit is still utilized, the bus frequency is 1/4 input frequency.

**MC6809  
CLOCK  
OPTIONS**



The phase relationship between the MC6809 timing outputs E and Q is shown below. Q is a quadrature clocking signal that leads E.





Figure 9-70. MC6809 E and Q Timing for Write Cycles



Figure 9-71. MC6809 E and Q Timing for Read Cycles

Addresses from the CPU may start to change after the hold time from the falling edge of E, but they are guaranteed to be stable on the leading edge of Q, as shown in Figure 9-70. The timing shown in this figure is for an MC6809 write cycle.

**MC6809  
WRITE  
TIMING**

During the write cycle, the processor starts to propagate data onto the Data Bus at the positive transition of Q; this data is guaranteed to be valid on the trailing edge of Q.

Figure 9-71 illustrates the timing for an MC6809 read cycle.

**MC6809  
READ  
TIMING**

Peripherals generally propagate data into the system via the Data Bus during E high. Data needs to be stable a short time before and after E goes low. This is the hold time.

Note that the Data Bus is floated during the interval when both E and Q are low (on a write cycle) or for 1/2 cycle when E is low (on a read cycle.) This interval allows "turn-around" time on the bidirectional Data Bus.

**Several control signals are provided to increase timing parameters so that the MC6809 can be easily interfaced to slow devices.**

If E (high) is too short for the external device logic to respond to during the write cycle, the slow device may be accommodated if we stretch the bus clocks. MRDY permits this stretching. By asserting MRDY low, the clocks are stretched as indicated in the following illustration:



A low input on MRDY when E goes high causes E to remain high; stretching terminates when MRDY is returned high. Stretching will always be an integral number of high-frequency clock cycles (that is, 1/4 bus cycles) and must not exceed 10 microseconds in order to maintain the integrity of the CPU internal registers.

Note that MRDY alters the system E signal. Devices which require a constant clock frequency must therefore use a different clock source if this clock stretching technique is implemented.

### MC6809 DIRECT MEMORY ACCESS

**The MC6809 bus state control monitoring signals permit all three of the most widely used DMA techniques (Halt mode, cycle stealing, and bus multiplexing) to be implemented. With the on-chip clock version of the MC6809, cycle-stealing DMA is controlled by the chip itself.**

**Consider first Halt mode DMA.** This is the simplest mode, as one simply shuts down the CPU while transactions take place on the bus. The MC6809 Halt state is equivalent to the Halt on the 6800, or the Hold state of the 8080A. The CPU will float its Address Bus, Data Bus, and R/W line and suspend instruction execution in response to a low level applied to the HALT input. The CPU will maintain this condition indefinitely (without loss of data) until the HALT input is driven high again. While in this state, BA and BS are asserted high by internal CPU logic. When HALT is driven low, the CPU will continue to run until the end of the current instruction before it enters the Hold state. The worst case latency is 20 machine cycles. This occurs with the Software Interrupt instructions SWI2 and SWI3.

CPU output lines Bus Available (BA) and Bus State (BS) both go high in the Halt mode. These lines may be asynchronously decoded to yield a BUS GRANT signal.

**MC6809  
ACCESSING  
SLOW  
DEVICES**

**MC6809  
HALT MODE  
DMA**

**MC6809  
BUS  
GRANT**





Figure 9-72. MC6809 Timing and Signals for Cycle-Stealing DMA

In most cases, it will be sufficient to use BA alone as a BUS GRANT signal.

With the above as background, we can summarize the Halt mode DMA activity as follows:

- The external device asserts the CPU HALT line low.
- At the end of the current instruction, the CPU suspends operation, floats the system busses (Address, Data and R/W), and outputs BA high to signify to the DMA device that it may take over the busses and commence a DMA transaction.
- The bus clocks E and Q continue to furnish synchronization signals to the DMA interface.
- At the end of the transaction, the external device asserts HALT high. This terminates the DMA activity by making BA = 0 and restores the CPU to normal operation one cycle later.

**Now consider cycle-stealing DMA. This mode is easily implemented because the internal circuitry of the MC6809 incorporates all the clock stretching and bus floating logic required.**

**MC6809  
CYCLE-STEALING  
DMA**

The external DMA device initiates cycle-stealing DMA by pulling the MC6809 Bus Request line DMA/BREQ low. Recognition of this low on DMA/BREQ causes the internal CPU clocks to be stretched, while the bus clocks (E and Q) continue to function normally. In addition, both BA and BS go high, and the system busses (Address, Data and R/W) are floated. Figure 9-72 illustrates the timing sequence for cycle-stealing DMA.

A DMA transaction is initiated by pulling the DMA/BREQ line low before the trailing edge of Q. This suspends operation of the internal clocks (it stretches them an integral number of basic machine cycles), and starts to float the system busses (a hold time after the trailing edge of E).

**To prevent false reads or writes to memory and peripherals as the address and R/W lines are floated, the system must generate an external VMA signal (denoted DMAVMA). This**

**EXTERNAL VMA**

DMAVMA signal is used to disable the memory and peripherals until the DMA device has control of the system busses. A circuit that could be used to generate this DMAVMA signal is as follows:



The CPU acknowledges DMA/BREQ by asserting BA and BS high. This is the BUS GRANT signal. It signifies to the DMA device that the CPU has been removed from the busses, and that a DMA transaction may take place. The bus clock signals E and Q continue to furnish bus timing to the DMA interface.

At the end of the transfer, the external device returns DMA/BREQ high, restoring the CPU to normal operation. This must occur before the trailing edge of Q, and the DMA device must get off the bus a hold time after the trailing edge of E (in the same cycle). The CPU busses will begin to emerge from their floating condition after the dead cycle. Again, the system must provide a low VMA signal (DMAVMA) to prevent false accesses while the Address Bus and R/W line are going through this floating state.

Dynamic memory refresh can also be implemented on a cycle-stealing basis by making the refresh controller a high priority DMA device, and accessing the required number of consecutive locations within the time required to maintain data integrity. Another way of refreshing dynamic memory would be to simply perform a high-speed scan through 64 or 128 consecutive memory locations. This is easily done through a single-instruction subroutine consisting of 63 (or 127) pre-bytes and an RTS (or RTI).

**MC6809  
DYNAMIC  
MEMORY  
REFRESH  
OPERATIONS**

## MC6809 INTERRUPT PROCESSING AND RESET

Interrupt capabilities implemented on the MC6809 are:

- Hardware Interrupts NMI, FIRQ, and IRQ
- Software Interrupts SWI, SWI2 and SWI3
- RESTART

NMI and IRQ are equivalent to the corresponding interrupts on the MC6800.

FIRQ is a Fast Interrupt Request that has no counterpart on the MC6800. It is a maskable, hardware interrupt of higher priority than IRQ. Its implementation provides the MC6809 with an easy to use two-level vectored interrupt scheme. An interrupt on IRQ automatically vectors to its own software handler routine, while an interrupt on FIRQ automatically vectors to its unique software handler routine. The higher priority device is connected to FIRQ to achieve priority response.

Within each of these levels, software polling may be used if more than one interrupt device is connected on each interrupt input. However, as noted in the MC6800 description, software polling greatly increases interrupt latency and can quickly become untenable.

An alternate scheme that permits direct vectoring by the interrupting device itself to anywhere in memory may be implemented. This is described later.

The MC6809 sets aside the sixteen highest addressable memory locations for interrupt processing purposes. Seven 16-bit addresses are stored in these locations (one pair of locations is reserved for future definition). These seven addresses identify the starting addresses of the service routines for the seven possible sources of interrupt.

**MC6809  
INTERRUPT  
VECTOR  
ADDRESSES**

**This is how the memory locations are used to store the interrupt vectors:**

|                |          |
|----------------|----------|
| FFF0 and FFF1  | Reserved |
| FFF2 and FFF3  | SWI3     |
| FFF4 and FFF5  | SWI2     |
| FFF6 and FFF7  | FIRQ     |
| FFF8 and FFF9  | IRQ      |
| FFF A and FFFB | SWI      |
| FFF C and FFFD | NMI      |
| FFF E and FFFE | RESET    |

The lower address of each pair (FFF0, FFF2, FFF4, ... FFFE) holds the high-order byte of the starting address.

In the event of simultaneous interrupt requests, **this is the priority sequence** during the acknowledge process:

- |         |   |                                      |
|---------|---|--------------------------------------|
| Highest | ↑ | 1) <u>RESET</u>                      |
|         | ↓ | 2) Non-Maskable Interrupt (NMI)      |
|         | ↓ | 3) Software Interrupt (SWI)          |
|         | ↓ | 4) Fast Interrupt Request FIRQ       |
| Lowest  | ↓ | 5) Standard Hardware Interrupt (IRQ) |

**MC6809  
INTERRUPT  
PRIORITIES**

We will begin our discussion of **MC6809 interrupt processing** by describing the various interrupts.

Consider first FIRQ. FIRQ permits high-speed response to hardware interrupts by stacking only a subset of the register complement — only the return address and the Stack register contents are pushed onto the Stack. At the end of the interrupt, these two items only are restored from the Stack. Status register flag bits F and I are set to mask out the present FIRQ and further IRQ and FIRQ interrupts. (If you wish to admit multiple-level interrupts, you can now clear the F and I flags.)

We will refer to IRQ as the standard hardware interrupt. It provides slower response than FIRQ, because it stacks the entire machine state. Thus, IRQ functions in the same way as the MC6800 IRQ. FIRQ can interrupt IRQ, but IRQ cannot interrupt FIRQ, since FIRQ disables IRQ by setting the I bit of the Status register.

The **MC6809 includes three software interrupts. SWI has higher priority than IRQ and FIRQ, and disables these interrupts by setting the Status flags F and I. SWI2 and SWI3 do not disable any interrupts. All three save the entire machine status by pushing the contents of all the active registers onto the Stack.**

SWI is implemented on the MC6800, but the MC6800 has no counterpart to SWI2 and SWI3.

Note that these instructions cause the MC6809 to go through the complete logic of an interrupt request, even though the interrupting source is within the CPU.

The non-maskable interrupt NMI, as with the MC6800, cannot be disabled. Like IRQ, it stacks the entire machine status.

Because NMI is not masked, repeated NMI interrupts occurring before the previous ones have been terminated by an RTI (Return from Interrupt) instruction can cause the Stack to overflow. This will cause a fatal error.

A detailed discussion of RESET versus Interrupt response is included with the MC6800 description and will not be repeated here. However, the following points should be noted:

- If the HALT or DMA/BREQ inputs are asserted low when RESET makes its low-to-high transition, it will be latched, and the CPU will wait until the resumption of a running state before completing the reset.
- Asserting RESET will not bring the CPU out of tristate during a HALT or DMA condition.
- Because a Schmitt trigger is used on the RESET input, a simple RC network can be used to reset the CPU. This is much less stringent than the 100 nanosecond rise time limit of the MC6800.

Normally, the reset action takes five bus cycles. However, since DMA may occur during reset, the actual reset may take considerably longer.

Through the use of some external logic, it is possible for the interrupting device to force a vectored jump to anywhere in memory. This scheme makes use of the Interrupt Acknowledge (IACK) signal.

Table 9-20 shows the IACK is indicated by BA = 0 and BS = 1. These status indications are valid on the leading edge of Q.

**MC6809  
FAST  
INTERRUPT  
REQUEST**

**MC6809  
STANDARD  
HARDWARE  
INTERRUPTS**

**MC6809  
SOFTWARE  
INTERRUPTS SWI,  
SWI2 AND SWI3**

**MC6809  
NON-MASKABLE  
INTERRUPT**

**MC6809  
RESET**

**MC6809  
INTERRUPT  
VECTORING  
BY EXTERNAL  
DEVICES**



Figure 9-73. MC6809 Signals for Externally Vectored Interrupts

IACK indicates that a byte of vector address is being retrieved from one of the memory locations FFF0 to FFFF as a result of an interrupt (RESET, NMI, FIR<sub>Q</sub>, IR<sub>Q</sub>, SWI, SWI2 or SWI3). IACK is valid during both the high-order and low-order vector address byte fetches.

Note that the address locations corresponding to the seven vectors are all of the form FFFX, where X is between 0 and F; thus, only the last four bits of the address differ. By externally decoding these four low-order bits plus the IACK signals BA and BS, you can determine what type of interrupt has been accepted, disable the ROM containing addresses FFF0 to FFFF, and jam onto the Data Bus the address of an appropriate interrupt service routine. This is done in turn for both the high-order and low-order address bytes by external device logic. Figure 9-73 illustrates the sequence for externally vectoring an interrupt.

Note that the address byte jammed onto the Data Bus is loaded into the Program Counter by the CPU as its normal response to an interrupt request, but now the 16-bit address loaded is the address supplied by the external device, not the address normally retrieved from the applicable address pairs FFF0/FFF1 to FFFE/FFFF.

At the end of this transaction, the program commences execution at the address supplied by the interrupting device. Thus, a vectored jump to the device service routine has been effected.

**This technique can drastically reduce interrupt response time as compared to a polled approach.**

**Stack Pointer SP is used during interrupts. For all interrupts except FIRQ, the full complement of registers is stacked.** The sequence in which the registers are saved on the Stack can be illustrated as follows:

**MC6809  
STACKING  
DURING  
INTERRUPTS**



The MC6809 Stack Pointer(s) points to the last item placed in the Stack, instead of to the next empty location as with the MC6800, MC6801, and MC6802. The new stacking order interchanges the order of Accumulators A and B to make A the high-order byte instead of B, as is the case on the MC6800, MC6801, and MC6802.

The MC6809 provides two methods of achieving external process synchronization.

The first method we will consider is similar to the one implemented on the MC6800.

It uses the **CWAI instruction**, which is similar to the MC6800 sequence CLI WAI. However, CWAI does not float the system busses as WAI does on the MC6800. (No WAI instruction exists on the MC6809.)

**MC6809  
HARDWARE-  
SOFTWARE  
SYNCHRONIZATION**

When the CWAI instruction is executed, the processor logically ANDs the immediate-byte of the instruction into the status register, stacks the entire machine status, then sits idle until an interrupt occurs. When an interrupt occurs, it can be processed immediately, as no time need be spent in stacking machine status.

The CWAI instruction is an immediate mode instruction, with the immediate data being a mask byte. During execution, this byte is automatically ANDed with the Status register byte to clear interrupt bits F and I if required.

When an interrupt occurs, it will (if it hasn't been masked) cause a transfer to the appropriate interrupt service routine. Note that when an FIRQ occurs, it will enter its service routine with the entire machine status stacked (instead of just the Program Counter and Status register); however, the corresponding RTI instruction will correctly unstack it, since the state of the stacked E bit will properly indicate how much status was stacked.

The second method of synchronization uses the new MC6809 **SYNC** instruction. When executed, SYNC causes the processor to cease further execution and wait for an interrupt to occur. Any of the interrupts NMI, FIRQ or IRQ may release the processor from the SYNC state. If the interrupt is enabled, the processor will service it; if it is disabled, the processor simply continues on to the next instruction in sequence, without stacking the machine status. The logic of the SYNC Instruction is illustrated in Figure 9-74.

**MC6809  
SYNC  
INSTRUCTION**



Figure 9-74. MC6809 SYNC Instruction Logic

**One obvious use of the SYNC instruction would be to implement high-throughput program/device synchronization.** The following diagram illustrates this concept. (To keep it simple, we have assumed that only one interrupting device is connected to the system.)



External logic can determine when the CPU is in the SYNC state by decoding the MC6809 BA and BS signals. A SYNC acknowledge status is indicated by BA = 1 and BS = 0, as shown in Table 9-20. Note that since BA = 1, the system busses are floated.

**SYNC can also be used to mechanize block transfer of data under DMA control. When SYNC is executed, the busses are floated and BA = 1, BS = 0 announces to the DMA device that it may take over the system busses.** At the end of each block transfer, the DMA device advises the CPU by asserting an interrupt request, and the program resumes execution.

**MC6809 USE OF SYNC FOR DMA**

Note that the MC6800 does not have a SYNC instruction. Block transfer DMA for the 6800 can be implemented via the WAI instruction as described in the MC6800 section.

## THE MC6809 INSTRUCTION SET

**Table 9-21 lists the MC6809 instruction mnemonics, while Table 9-22 summarizes the instructions which differ from those that appear in the MC6800 instruction set.** Note that all MC6800 addressing modes have been implemented, plus the enhanced modes that we described at the beginning of this section.

When comparing the MC6809 instruction set to the MC6800 set, you will notice that Direct Page addressing for the MC6809 applies to all memory reference instructions, not just the primary memory reference instructions as is the case for the MC6800. In addition, the Direct page can be dynamically relocated.

**During our discussion of the MC6800, we noted the paucity of index registers and the lack of data mobility between them. These deficiencies have been corrected and the MC6809 set includes two types of instructions for register-to-register transfers — the Exchange and the Transfer instructions.** The only restriction on the use of these instructions is that the source and destination registers must be the same size (i.e., both 8 bits or both 16 bits).

An examination of the MC6809 set reveals that some of the familiar MC6800 instructions are missing. However, provision has been made to perform the missing operations in alternate ways. For example, the instruction to clear the Carry bit C is implemented on the MC6800 as CLC; to perform this on the MC6809, one must use ANDCC #\$FE. The result of these changes is that, even though the MC6809 is fully software compatible (at the source code level) and much more powerful, it uses fewer mnemonics than the MC6800 (59 versus 72).

**MC6809  
MISSING  
MNEMONICS**

The MC6809 contains many instructions that the MC6800 does not. Some of these we have already noted, such as Synchronize with Interrupt (SYNC), Clear and Wait for Interrupt (CWAI), Exchange Registers (EXG), Transfer Register (TFR), and the Software Interrupts SWI2 and SWI3. Some of the remaining differences are simply extensions of the existing instructions to make them apply to the new registers — e.g., ANDCC, LDY, etc. — while others are totally new — e.g., Sign Extend (SEX) and Load Effective Address (LEA).

**MC6809  
ADDED  
MNEMONICS**

Some mnemonics that are used with both the MC6800 and the MC6809 have slightly altered meanings. This is illustrated below for the "Load Accumulator" instruction.

**MC6800/MC6801/MC6802**
**Generic Form: LDA**

LDAA = Load Accumulator A  
LDAB = Load Accumulator B

**MC6809**
**Generic Form: LD**

LDA = Load Accumulator A  
LDB = Load Accumulator B  
LDD = Load Accumulator D  
LDS = Load Hardware Stack Pointer  
LDU = Load User Stack Pointer  
LDX = Load Index Register X  
LDY = Load Index Register Y

The "Store Accumulator" instruction has similarly been altered.

The Push and Pull instructions have been enhanced such that any, all, any subset, or none of the CPU registers can be pushed or pulled from the stacks. PSHS and PULS access the Hardware Stack, while PSHU and PULU access the User Stack. These instructions require a Post Byte, as shown in the following illustration:

**MC6809 PUSH  
AND PULL  
INSTRUCTIONS**


To illustrate, the assembler instruction PSHS D is encoded as follows:



Note the interpretation of bit 6. When executing PSHS, if bit 6 = 1, the contents of U are saved. When executing PSHU, if bit 6 = 1, the contents of SP are saved. Note that PSHS cannot save the contents of SP and PSHU cannot save the contents of U.

**The Exchange Registers and Transfer Register instructions also require a Post Byte to identify the source and destination registers, as shown in the following diagram:**

**MC6809 EXCHANGE  
REGISTER AND  
TRANSFER REGISTER  
POST BYTE**



**One of the strengths of the MC6809 system is the ease with which position independent code can be generated. The Load Effective Address instruction (LEA) is provided to help facilitate this.** This instruction can be used with any of the indexed registers, yielding the four source forms LEAX, LEAY, LEAS, and LEAU. A Post Byte is required (from Table 9-19).

**MC6809  
LEA  
INSTRUCTION**

The following program segment illustrates how LEA is used to generate position independent code. During the assembly process, the offset (from the end of the LEA instruction) to the beginning of the table is determined and inserted as the two-byte offset 0009.

| Address | Op   | Post | Source Code |       |      |                       |
|---------|------|------|-------------|-------|------|-----------------------|
|         | Code | Byte | Offset      |       |      |                       |
| 0100    | 30   | 8D   | 0009        | START | LEAX | TABLE,PCR             |
| 0104    | A6   | 80   |             | LOOP  | LDA  | X+                    |
| 0106    | .    | .    |             | .     | .    |                       |
| .       | .    | .    |             | .     | .    |                       |
| .       | .    | .    |             | .     | .    |                       |
| .       | .    | .    |             | .     | .    |                       |
| .       | .    | .    |             | .     | .    |                       |
| .       | .    | .    |             | .     | .    |                       |
| 010D    |      |      |             | TABLE | FCC  | /TABLE OF CHARACTERS/ |

Assume that the program is stored at the locations shown. During execution, the offset 0009 is added to the updated Program Counter value 0104 to yield the start of table address 010D. This value is loaded into Index Register X, rather than put out on the Address Bus. When the indexed instruction LDA,X+ is executed, this newly computed address (stored in the Index register) is used to access data from the table.



PCR = Program Counter Relative

Notice what happens if the above block of code is moved to another location in memory as shown below.



During execution, the new table address 040D is formed in Index Register X when LEAX is executed and used by the instruction LDA,X+ to correctly abstract entries from the table. Truly, this is position independent code.

**The instructions shown shaded in Table 9-21 are the new (or modified) instructions. They are summarized in detail in Table 9-22. The remaining instructions have already been summarized in the MC6800 section (Table 9-1).** It should be noted that many of the unchanged instructions take fewer machine cycles to execute on the MC6809 than on the MC6800.

When comparing the MC6800 family processors, it should be noted that the MC6800 and MC6802 have the same instruction set, and the MC6801 has a superset of the MC6800, but a subset of the MC6809.

Table 9-21. MC6809 Mnemonics (New and Modified Instructions are Shaded)

| Instruction         | Source Forms | Instruction      | Source Forms      | Instruction      | Source Forms      | Instruction      | Source Forms       |
|---------------------|--------------|------------------|-------------------|------------------|-------------------|------------------|--------------------|
| ABX                 |              | BLS              | BLS               | DEC              | DECA              | OR               | ORA                |
| ADC                 | ADCA         | BLT              | LBLS              |                  | DEC B             | ORB              | ORB                |
| ADCB                | ADCB         |                  | BLT               |                  | DEC               |                  | ORCC               |
| ADD                 | ADDA         |                  | LBLT              | EOR              | EORA              | PSH              | PSHS <sup>11</sup> |
|                     | ADD B        | BMI              | BMI               |                  | EORB              | PUL              | PSHU               |
|                     | ADD D        |                  | LBMI              | EXG R1, R2       |                   |                  | PULS <sup>12</sup> |
| AND                 | ANDA         | BNE              | BNE               | INC              | INCA              | ROL              | PULU               |
|                     | ANDB         |                  | LBNE              |                  | INC B             |                  | ROLA               |
|                     | ANDCC        | BPL              | BPL               | JMP              | INC               | ROL B            | ROLB               |
| ASL <sup>3</sup>    | ASLA         | BRA              | BRA               | JSR              |                   | ROR              | ROL                |
|                     | ASLB         |                  | LBRA              | LD               | LDA <sup>10</sup> | ROR <sup>6</sup> | RORA               |
|                     | ASL D        | BRN              | BRN               |                  | LDB <sup>10</sup> |                  | RORB               |
| ASR <sup>3, 6</sup> | ASRA         |                  | LBRN              |                  | LDD               | RTI <sup>8</sup> | ROR                |
|                     | ASRB         | BSR              | BSR               |                  | LDS               | RTS              |                    |
|                     | ASR D        |                  | LSR               |                  | LDU               | SBC <sup>3</sup> |                    |
| BCC                 | BCC          |                  | LSR               |                  | LDX               |                  | SBCA               |
|                     | LBCC         | BVC              | BVC               |                  | LDY               | SEX              | SBCB               |
| BCS                 | BCS          |                  | LBVC              |                  |                   | ST               |                    |
|                     | LBCS         | BVS              | BVS               | LEA              | LEAS              |                  | STA <sup>10</sup>  |
| BEQ                 | BEQ          |                  | LBVS              |                  | LEAU              |                  | STB <sup>10</sup>  |
|                     | LBEQ         | CLR              | CLRA              |                  | LEAX              |                  | STD                |
| BGE                 | BGE          |                  | CLRB              |                  | LEAY              |                  | STS                |
|                     | LBGE         |                  | CLR               | LSL              | LSLA              |                  | STU                |
| BGT                 | BGT          | CMP <sup>3</sup> | CMPA              |                  | LSLB              |                  | STX                |
|                     | LBGT         |                  | CMPB              |                  | LSL               |                  | STY                |
| BHI                 | BHI          |                  | CMPD              | LSR              |                   | SUB <sup>3</sup> | SUBA               |
|                     | LBHI         |                  | CMPS              |                  | LSRA              |                  | SUBB               |
| BHS                 | BHS          |                  | CMPU              |                  | LSRB              |                  | SUBD               |
|                     | LBHS         |                  | CMPX <sup>7</sup> | MUL <sup>4</sup> | LSR               | SWI <sup>9</sup> | SWI                |
| BIT                 | BITA         |                  | CMPY              | NEG <sup>3</sup> |                   |                  | SWI2               |
|                     | BITB         | COM              | COMA              | NEGA             |                   |                  | SWI3               |
| BLE                 | BLE          |                  | COMB              | NEGB             |                   | SYNC             |                    |
|                     | LBLE         |                  | COM               | NEG              | TFR R1, R2        | TST              |                    |
| BLO                 | BLO          | CWAI             |                   | NOP              |                   |                  | TSTA               |
|                     | LBLO         | DAA              |                   |                  |                   |                  | TSTB               |
|                     |              |                  |                   |                  |                   |                  | TST                |

**Notes**

1. The unshaded instructions are described in the MC6800 section. They have the same object codes for both the MC6800 and the MC6809 processors.
2. R1 and R2 may be any pair of 8-bit or 16-bit registers. The 8-bit registers are A, B, SR and BPR. The 16-bit registers are X, Y, U, SP, D, and PC.
3. The Auxiliary or Half-Carry bit H is undefined for these cases.
4. This MUL sets the Z bit if appropriate. The MC6801 MUL does not.
5. This instruction does not affect the C bit. On the MC6800/6801/6802 it clears C.
6. These do not affect the overflow bit (V). On the MC6800/6801/6802 they may.
7. This instruction correctly sets all flags. On the MC6800/6802 it does not.
8. On the MC6809, the E status bit is checked during RTI to determine how much to unstack — the complete register complement or just the Stack register and Return Address.
9. SWI sets bits F and I: SWI2 and SWI3 have no effect on F and I.
10. These instructions are implemented on the MC6800 with slightly different mnemonics, as discussed above.
11. This instruction is implemented on the MC6800 as PSH.
12. This instruction is implemented on the MC6800 as PUL.

In Table 9-22, the following symbols are used in addition to those used in Table 9-1.

|          |                                                                                                                                                                                                                                                                  |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACD,D    | Accumulator D                                                                                                                                                                                                                                                    |
| b0-b7    | Bits of Post Byte or other registers                                                                                                                                                                                                                             |
| U        | User Stack Pointer                                                                                                                                                                                                                                               |
| Y        | Y Index Register                                                                                                                                                                                                                                                 |
| DP       | Direct Page Register                                                                                                                                                                                                                                             |
| B4       | Instruction Byte 4                                                                                                                                                                                                                                               |
| DISP16   | A 16-bit, twos complement displacement                                                                                                                                                                                                                           |
| REG      | A 16-bit register (S, U, X, or Y, as the context demands)                                                                                                                                                                                                        |
| [PC']    | Contents of the Program Counter after it has "stepped over" the offset bytes in a multi-byte instruction — thus, PC' is the address of the next instruction in sequence.                                                                                         |
| R1, R2   | Register pairs, both 8-bit or both 16-bit                                                                                                                                                                                                                        |
| LIST     | List of registers to be stored on or retrieved from the Stack                                                                                                                                                                                                    |
| EA       | Effective Address                                                                                                                                                                                                                                                |
| OFFSET,R | This symbology is used to denote all forms of indexed addressing and all forms of indirect addressing. For this addressing scheme, the total byte count is the sum of the base count indicated in Table 9-22 and the appropriate value from the following chart. |

| Type                                                                                                                                                                                                              | Form                | Non-indirect   |                   | Bytes | Indirect       |                   | Bytes |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------|-------------------|-------|----------------|-------------------|-------|
|                                                                                                                                                                                                                   |                     | Assembler Form | Post-Byte Op-code |       | Assembler Form | Post-Byte Op-code |       |
| Constant Offset from R                                                                                                                                                                                            | No Offset           | , R            | 1RR00100          | 0     | [, R]          | 1RR10100          | 0     |
|                                                                                                                                                                                                                   | 5-Bit Offset        | n, R           | 0RRnnnnn          | 0     |                | defaults to 8-bit |       |
|                                                                                                                                                                                                                   | 8-Bit Offset        | n, R           | 1RR01000          | 1     | [n, R]         | 1RR11000          | 1     |
|                                                                                                                                                                                                                   | 16-Bit Offset       | n, R           | 1RR01001          | 2     | [n, R]         | 1RR11001          | 2     |
| Accumulator Offset from R                                                                                                                                                                                         | A — Register Offset | A, R           | 1RR00110          | 0     | [A, R]         | 1RR10110          | 0     |
|                                                                                                                                                                                                                   | B — Register Offset | B, R           | 1RR00101          | 0     | [B, R]         | 1RR10101          | 0     |
|                                                                                                                                                                                                                   | D — Register Offset | D, R           | 1RR01011          | 0     | [D, R]         | 1RR11011          | 0     |
| Auto Increment/Decrement R                                                                                                                                                                                        | Increment by 1      | , R +          | 1RR00000          | 0     |                | not allowed       |       |
|                                                                                                                                                                                                                   | Increment by 2      | , R ++         | 1RR00001          | 0     | [, R + +]      | 1RR10001          | 0     |
|                                                                                                                                                                                                                   | Decrement by 1      | , -R           | 1RR00010          | 0     |                | not allowed       |       |
|                                                                                                                                                                                                                   | Decrement by 2      | , --R          | 1RR00011          | 0     | [, -R]         | 1RR10011          | 0     |
| Constant Offset from PC                                                                                                                                                                                           | 8-Bit Offset        | n, PCR         | 1XX01100          | 1     | [n, PCR]       | 1XX11100          | 1     |
|                                                                                                                                                                                                                   | 16-Bit Offset       | n, PCR         | 1XX01101          | 2     | [n, PCR]       | 1XX11101          | 2     |
| Extended Indirect                                                                                                                                                                                                 | 16-Bit Address      | —              | —                 | -     | [n]            | 10011111          | 2     |
| R = X, Y, U, or S<br>X = Don't Care                                                                                                                                                                               |                     |                |                   |       |                |                   |       |
| Note: This chart conforms to Motorola nomenclature; their use of square brackets [ ] indicates to the assembler that the addressing mode is indirect — thus, their use of [ ] differs from the use in Table 9-22. |                     |                |                   |       |                |                   |       |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809

| TYPE                                           | MNEMONIC | OPERAND(S)                 | BYTES        | STATUS |   |   |   |   |   |   | OPERATION PERFORMED |                                                                                                                                                                                                                         |
|------------------------------------------------|----------|----------------------------|--------------|--------|---|---|---|---|---|---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                |          |                            |              | E      | F | C | Z | S | V | H | I                   |                                                                                                                                                                                                                         |
| PRIMARY MEMORY REFERENCE                       | LDD      | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        |   | X | X | 0 |   |   |                     | [ACA] ← [MEM], [ACB] ← [MEM + 1]<br>Load double Accumulator using base page direct, extended direct, indirect or indexed addressing.                                                                                    |
|                                                | STD      | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        |   | X | X | 0 |   |   |                     | [MEM] ← [ACA], [MEM + 1] ← [ACB]<br>Store double Accumulator using direct, extended, indirect or indexed addressing.                                                                                                    |
|                                                | LDU      | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        |   | X | X | 0 |   |   |                     | [REG(HI)] ← [MEM], [REG(LO)] ← [MEM + 1]<br>Load specified register (U or Y) using direct, extended, indirect or indexed addressing.                                                                                    |
|                                                | LDY      | ADR8<br>ADR16<br>OFFSET,R  | 3<br>4<br>3+ |        |   | X | X | 0 |   |   |                     | Sign status reflects REG bit 15.                                                                                                                                                                                        |
|                                                | STU      | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        |   | X | X | 0 |   |   |                     | [MEM] ← [REG(HI)], [MEM + 1] ← [REG(LO)]<br>Store contents of specified register (U or Y) using direct, extended, indirect or indexed addressing. Sign status reflects REG bit 15.                                      |
|                                                | STY      | ADR8<br>ADR16<br>OFFSET,R  | 3<br>4<br>3+ |        |   | X | X | 0 |   |   |                     |                                                                                                                                                                                                                         |
|                                                |          |                            |              |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                         |
| SECONDARY MEMORY REFERENCE<br>(MEMORY OPERATE) | ADDD     | ADR8<br>ADR16<br>OFFSET, R | 2<br>3<br>2+ |        | X | X | X | X | X |   |                     | [ACD] ← [ACD] + [MEM]: [MEM + 1]<br>Add 16-bit value from locations MEM and MEM + 1 to D Accumulator using direct, extended, indirect or indexed addressing.                                                            |
|                                                | CMPD     | ADR8<br>ADR16<br>OFFSET,R  | 3<br>4<br>3+ |        | X | X | X | X |   |   |                     | [ACD] - [MEM]: [MEM + 1]<br>Compares 16-bit number from locations M and M + 1 with contents of D Accumulator and sets status bits as appropriate. Only Status register is affected.                                     |
|                                                | CMPS     | ADR8<br>ADR16<br>OFFSET,R  | 3<br>4<br>3+ |        | X | X | X | X |   |   |                     | [REG] - [MEM]: [MEM + 1]<br>Compares 16-bit number from locations M and M + 1 with contents of register (S, U, Y or X) specified in the mnemonic and sets status bits as appropriate. Only Status register is affected. |
|                                                | CMPU     | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        | X | X | X | X |   |   |                     |                                                                                                                                                                                                                         |
|                                                | CMPY     | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        | X | X | X | X |   |   |                     |                                                                                                                                                                                                                         |
|                                                | CMPX     | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        | X | X | X | X |   |   |                     |                                                                                                                                                                                                                         |
|                                                | LSL      | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        | X | X | X | X |   |   |                     |                                                                                                                                                                                                                         |
|                                                | SUBD     | ADR8<br>ADR16<br>OFFSET,R  | 2<br>3<br>2+ |        | X | X | X | X |   |   |                     |                                                                                                                                                                                                                         |



Logical Shift Left.

[ACD] ← [ACD] - [MEM]: [MEM + 1]  
Subtract 16-bit number contained in locations MEM and MEM + 1 from number contained in D Accumulator using direct, extended, indirect or indexed addressing.

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE                | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                             |
|---------------------|----------|------------|-------|--------|---|---|---|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |          |            |       | E      | F | C | Z | S | V | H |                                                                                                                                                                                                 |
| IMMEDIATE           | LDI      | DATA16     | 3     |        |   |   | X | X | 0 |   | [ACA] ← [B2], [ACB] ← [B3]<br>Load Accumulator immediate.                                                                                                                                       |
|                     | LDU      | DATA16     | 3     |        |   |   | X | X | 0 |   | [U(HI)] ← [B2], [U(LO)] ← [B3]<br>Load User Pointer immediate.                                                                                                                                  |
|                     | LDY      | DATA16     | 4     |        |   |   | X | X | 0 |   | [Y(HI)] ← [B3], [Y(LO)] ← [BA]                                                                                                                                                                  |
| IMMEDIATE OPERATE   | ADDD     | DATA16     | 3     |        |   | X | X | X | X | X | [ACD] ← [ACD] + [B2]: [B3]<br>Add 16-bit number following Op-code to contents of D Accumulator.                                                                                                 |
|                     | SUBD     | DATA16     | 3     |        |   | X | X | X | X |   | [ACD] ← [ACD] - [B2]: [B3]<br>Subtract 16-bit number following Op-Code from contents of D Accumulator.                                                                                          |
|                     | CMPD     | DATA16     | 4     |        |   | X | X | X | X |   | [ACD] - [B3]: [B4]<br>Compare immediate contents of D Accumulator and 16-bit number following (two byte) Op-code. Only status bits are affected.                                                |
|                     | CMPS     | DATA16     | 4     |        |   | X | X | X | X |   | [REG] - [B3]: [B4]<br>Compare immediate contents of designated Register (S, U, Y or X) specified in instruction with 16-bit number following (two byte) Op-code. Only Status bits are affected. |
|                     | CMPU     | DATA16     | 3     |        |   | X | X | X | X |   |                                                                                                                                                                                                 |
| JUMP                | CMPY     | DATA16     | 3     |        |   | X | X | X | X |   |                                                                                                                                                                                                 |
|                     | CMPX     | DATA16     | 3     |        |   | X | X | X | X |   |                                                                                                                                                                                                 |
| JUMP                | LBRA     | DISP16     | 3     |        |   |   |   |   |   |   | [PC] ← [PC'] + DISP16<br>Unconditional long branch relative to present Program Counter contents.                                                                                                |
|                     | LBSR     | DISP16     | 3     |        |   |   |   |   |   |   | [ISP] - 1 ← [PC(LO)], [ISP] - 2 ← [PC(HI)], [SP] ← [SP] - 2<br>[PC] ← [PC'] + DISP16<br>Unconditional long branch to subroutine located relative to present Program Counter contents.           |
| BRANCH ON CONDITION | BHS      | DISP       | 2     |        |   |   |   |   |   |   | [PC] ← [PC'] + DISP if condition true                                                                                                                                                           |
|                     | BLO      | DISP       | 2     |        |   |   |   |   |   |   | C = 0<br>C = 1<br>[PC] ← [PC'] + DISP16 if condition true                                                                                                                                       |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE                            | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                     |
|---------------------------------|----------|------------|-------|--------|---|---|---|---|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |          |            |       | E      | F | C | Z | S | V | H | I |                                                                                                                                                                                                                         |
| BRANCH ON CONDITION (Continued) | LBCC     | DISP16     | 4     |        |   |   |   |   |   |   |   | Conditions are the same as shown in the Branch On Condition Table for the MC6800.                                                                                                                                       |
|                                 | LBCS     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBEQ     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBGE     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBGT     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBHI     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBHS     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBLE     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBLO     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBLS     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBLT     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBMI     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBNE     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBPL     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBVC     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
|                                 | LBVS     | DISP16     | 4     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                         |
| REGISTER TO REGISTER MOVE       | EXG      | R1, R2     | 2     |        |   |   |   |   |   |   |   | [R1] $\rightarrow$ [R2]<br>Exchange contents of specified registers. Status register not affected unless R1 or R2 is Status register.                                                                                   |
|                                 | TFR      | R1, R2     | 2     |        |   |   |   |   |   |   |   | [R2] $\leftarrow$ [R1]<br>Transfer contents of R1 to R2. Status register is not affected unless R2 is Status register.                                                                                                  |
| REGISTER-REGISTER OPERATE       | ABX      |            | 1     |        |   |   |   |   |   |   |   | [X] $\leftarrow$ [X] + [B]<br>Add unsigned contents of B Accumulator to Index register.                                                                                                                                 |
|                                 | MUL      |            | 1     |        |   | X |   |   |   |   |   | [D] $\leftarrow$ [A] x [B]<br>Multiply unsigned numbers in Accumulators A and B and place result in D. Carry bit is set if Accumulator B bit 7 is set.                                                                  |
|                                 | SEX      |            | 1     |        |   | X | X | 0 |   |   |   | [A] $\leftarrow$ FF <sub>16</sub> if Accumulator B bit 7 = 1<br>[A] $\leftarrow$ 00 <sub>16</sub> if Accumulator B bit 7 = 0<br>Transform an 8-bit twos complement number in B to a 16-bit twos complement number in D. |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE             | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|----------|------------|-------|--------|---|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |          |            |       | E      | F | C | Z | S | V | H | I |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| REGISTER OPERATE | LEAS     | OFFSET,R   | 2+    |        |   |   |   |   |   |   |   | [S] ← EA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | LEAU     | OFFSET,R   | 2+    |        |   |   |   |   |   |   |   | [U] ← EA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| REGISTERS        | LEAX     | OFFSET,R   | 2+    |        |   | X |   |   |   |   |   | [X] ← EA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | LEAY     | OFFSET,R   | 2+    |        |   | X |   |   |   |   |   | [Y] ← EA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| REGISTERS        | LSL      | ACX        | 1     |        |   | X | X | X | X |   |   | Form the Effective Address EA according to the addressing variation used.<br>Load this address into designated register (for later use) rather than outputting it on Address Bus at this time.                                                                                                                                                                                                                                                                                                                                                                     |
|                  |          |            |       |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| STACK            | PSHS     | LIST       | 2     |        |   |   |   |   |   |   |   | Test Post Byte and stack as follows.<br>Condition:<br>b7 = 1; [SP] ← [SP] - 1, [[SP]] ← [PC(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [PC(HI)]<br>b6 = 1; [SP] ← [SP] - 1, [[SP]] ← [U(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [U(HI)]<br>b5 = 1; [SP] ← [SP] - 1, [[SP]] ← [Y(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [Y(HI)]<br>b4 = 1; [SP] ← [SP] - 1, [[SP]] ← [X(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [X(HI)]<br>b3 = 1; [SP] ← [SP] - 1, [[SP]] ← [DP]<br>b2 = 1; [SP] ← [SP] - 1, [[SP]] ← [B]<br>b1 = 1; [SP] ← [SP] - 1, [[SP]] ← [A]<br>b0 = 1; [SP] ← [SP] - 1, [[SP]] ← [SR] |
|                  |          |            |       |        |   |   |   |   |   |   |   | Push any, all, none or any subset of registers onto Hardware Stack (except the Hardware Stack Pointer itself).                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE              | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|----------|------------|-------|--------|---|---|---|---|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |          |            |       | E      | F | C | Z | S | V | H | I |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| STACK (Continued) | PSHU     | LIST       | 2     |        |   |   |   |   |   |   |   | Test Post Byte and stack as follows.<br>Condition:<br>b7 = 1; [U] ← [U] - 1, [[U]] ← [PC(LO)]<br>[U] ← [U] - 1, [[U]] ← [PC(HI)]<br>b6 = 1; [U] ← [U] - 1, [[U]] ← [SP(LO)]<br>[U] ← [U] - 1, [[U]] ← [SP(HI)]<br>b5 = 1; [U] ← [U] - 1, [[U]] ← [Y(LO)]<br>[U] ← [U] - 1, [[U]] ← [Y(HI)]<br>b4 = 1; [U] ← [U] - 1, [[U]] ← [X(LO)]<br>[U] ← [U] - 1, [[U]] ← [X(HI)]<br>b3 = 1; [U] ← [U] - 1, [[U]] ← [DP]<br>b2 = 1; [U] ← [U] - 1, [[U]] ← [B]<br>b1 = 1; [U] ← [U] - 1, [[U]] ← [A]<br>b0 = 1; [U] ← [U] - 1, [[U]] ← [SR]                                     |
|                   | PULS     | LIST       | 2     |        |   |   |   |   |   |   |   | Push any, all, none or any subset of registers onto User Stack (except the User Stack Pointer itself).                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   |          |            |       |        |   |   |   |   |   |   |   | Test Post Byte and unstack as follows.<br>Condition:<br>b0 = 1; [SR] ← [[SP]], [SP] ← [SP] + 1<br>b1 = 1; [A] ← [[SP]], [SP] ← [SP] + 1<br>b2 = 1; [B] ← [[SP]], [SP] ← [SP] + 1<br>b3 = 1; [DP] ← [[SP]], [SP] ← [SP] + 1<br>b4 = 1; [X(HI)] ← [[SP]], [SP] ← [SP] + 1<br>[X(LO)] ← [[SP]], [SP] ← [SP] + 1<br>b5 = 1; [Y(HI)] ← [[SP]], [SP] ← [SP] + 1<br>[Y(LO)] ← [[SP]], [SP] ← [SP] + 1<br>b6 = 1; [U(HI)] ← [[SP]], [SP] ← [SP] + 1<br>[U(LO)] ← [[SP]], [SP] ← [SP] + 1<br>b7 = 1; [PC(HI)] ← [[SP]], [SP] ← [SP] + 1<br>[PC(LO)] ← [[SP]], [SP] ← [SP] + 1 |
|                   |          |            |       |        |   |   |   |   |   |   |   | Pull any, all, none or any subset of registers from Hardware Stack (except the Hardware Stack Pointer itself). The Status register bits are determined by byte pulled from Stack.                                                                                                                                                                                                                                                                                                                                                                                    |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE              | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|----------|------------|-------|--------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |          |            |       | E      | F | C | Z | S | V | H | I |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| STACK (Continued) | PULU     | LIST       | 2     |        |   |   |   |   |   |   |   | <p>Test Post Byte and unstack as follows.<br/>         Condition:<br/> <math>b0 = 1; [SR] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b1 = 1; [A] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b2 = 1; [B] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b3 = 1; [DP] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b4 = 1; [X(HI)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>[X(LO)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b5 = 1; [Y(HI)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>[Y(LO)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b6 = 1; [SP(HI)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>[SP(LO)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>b7 = 1; [PC(HI)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math><br/> <math>[PC(LO)] \leftarrow [[U]], [U] \leftarrow [U] + 1</math></p> <p>Pull any, all, none or any subset of registers from User Stack (except the User Stack Pointer itself). Status register bits are determined by byte pulled from Stack.</p>                                                                                                                                                         |
| INTERRUPT         | RTI      |            | 1     |        |   |   |   |   |   |   |   | <p>Pull registers from Hardware Stack in accordance with value of E of Status Register.</p> <p>If E = 0, pull the subset.<br/> <math>[SR] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[PC(HI)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[PC(LO)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math></p> <p>If E = 1, pull the full complement.<br/> <math>[SR] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[A] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[B] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[DP] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[X(HI)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[X(LO)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[Y(HI)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[Y(LO)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[U(HI)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[U(LO)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[PC(HI)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math><br/> <math>[PC(LO)] \leftarrow [[SP]], [SP] \leftarrow [SP] + 1</math></p> <p>Status bits are as received from Stack.</p> |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE                  | MNEMONIC | OPERAND(S) | BYTES | STATUS |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------|----------|------------|-------|--------|---|---|---|---|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       |          |            |       | E      | F | C | Z | S | V | H | I |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| INTERRUPT (Continued) | CWAI     |            | 2     |        |   |   |   |   |   |   |   | [SR] ← [SR] Λ [B2] This may clear SR bits.<br>E ← 1<br>[SP] ← [SP] - 1, [[SP]] ← [PC]<br>[SP] ← [SP] - 1, [[SP]] ← [PC]<br>[SP] ← [SP] - 1, [[SP]] ← [U]<br>[SP] ← [SP] - 1, [[SP]] ← [U]<br>[SP] ← [SP] - 1, [[SP]] ← [Y]<br>[SP] ← [SP] - 1, [[SP]] ← [Y]<br>[SP] ← [SP] - 1, [[SP]] ← [X]<br>[SP] ← [SP] - 1, [[SP]] ← [X]<br>[SP] ← [SP] - 1, [[SP]] ← [DP]<br>[SP] ← [SP] - 1, [[SP]] ← [B]<br>[SP] ← [SP] - 1, [[SP]] ← [A]<br>[SP] ← [SP] - 1, [[SP]] ← [SR]<br><br>Pushes registers onto Stack and waits for an interrupt. When non-masked interrupt occurs, vectors to corresponding interrupt service routine. FIRQ enters its service routine with all registers saved, but since E = 1, they will unstack correctly on RTI. (System busses are not floated by CWAI.) |

Table 9-22. A Summary of the New and Enhanced Instructions for the MC6809 (Continued)

| TYPE                  | MNEMONIC   | OPERAND(S)     | BYTES  | STATUS |   |   |   |   |   |   |   | OPERATION PERFORMED                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------|------------|----------------|--------|--------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       |            |                |        | E      | F | C | Z | S | V | H | I |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| INTERRUPT (Continued) | SWI        |                | 1      |        |   |   |   |   |   |   |   | E ← 1<br>[SP] ← [SP] - 1, [[SP]] ← [PC(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [PC(HI)]<br>[SP] ← [SP] - 1, [[SP]] ← [U(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [U(HI)]<br>[SP] ← [SP] - 1, [[SP]] ← [Y(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [Y(HI)]<br>[SP] ← [SP] - 1, [[SP]] ← [X(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [X(HI)]<br>[SP] ← [SP] - 1, [[SP]] ← [DP]<br>[SP] ← [SP] - 1, [[SP]] ← [B]<br>[SP] ← [SP] - 1, [[SP]] ← [A]<br>[SP] ← [SP] - 1, [[SP]] ← [SR]<br>1 ← 1, F ← 1, [PC] ← [FFFFA]: [FFFFB] |
|                       | SWI2       |                | 2      |        |   |   |   |   |   |   |   | Transfer control to interrupt subroutine.<br>E ← 1<br>Push registers onto Hardware Stack (same as above).<br>[PC] ← [FFF4]: [FFF5]                                                                                                                                                                                                                                                                                                                                                             |
|                       | SWI3       |                | 2      |        |   |   |   |   |   |   |   | Transfer control to interrupt subroutine.<br>E ← 1<br>Push registers onto Hardware Stack (same as above).<br>[PC] ← [FFF2]: [FFF3]                                                                                                                                                                                                                                                                                                                                                             |
|                       | SYNC       |                | 1      |        |   |   |   |   |   |   |   | Transfer control to interrupt subroutine.<br>Stop processing instructions: float system busses: wait for an interrupt. When an interrupt occurs, resume processing as follows:<br>i) If interrupt is enabled, transfer to the service routine.<br>ii) If interrupt is disabled, continue execution at next instruction in sequence.                                                                                                                                                            |
| STATUS                | ANDCC      | DATA           | 2      |        |   | 1 |   |   |   |   |   | [SR] ← [SR] $\wedge$ DATA<br>AND immediate. Used to clear SR bits.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                       | ORCC       | DATA           | 2      |        |   |   |   |   |   |   |   | [SR] ← [SR] $\vee$ DATA<br>OR immediate. Used to set SR bits.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                       | BRN<br>LBN | DISP<br>DISP16 | 2<br>4 |        |   |   |   |   |   |   |   | Branch Never. This is a No Operation<br>Long Branch Never. This is a No Operation.                                                                                                                                                                                                                                                                                                                                                                                                             |

## **DATA SHEETS**

This section contains specific electrical and timing data for the following devices:

- MC6800 CPU
- MC6802 CPU/RAM
- MC6870A Clock
- MC6871A Clock
- MC6871B Clock
- MC6820 PIA
- MC6850 ACIA
- MC6852 SSDA
- MC6840 PTM
- MC6844 DMAC
- MC6846 ROM-I/O-Timer
- MC6801 One-Chip Microcomputer
- MC6809 CPU

## MC6800, MC68A00, MC68B00

TABLE 1 – MAXIMUM RATINGS

| Rating                                                                                                                                  | Symbol           | Value                                 | Unit |
|-----------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------|------|
| Supply Voltage                                                                                                                          | V <sub>CC</sub>  | -0.3 to +7.0                          | Vdc  |
| Input Voltage                                                                                                                           | V <sub>in</sub>  | -0.3 to +7.0                          | Vdc  |
| Operating Temperature Range—T <sub>L</sub> to T <sub>H</sub><br>MC6800, MC68A00, MC68B00<br>MC6800C, MC68A00C<br>MC6800BQCS, MC6800CQCS | T <sub>A</sub>   | 0 to +70<br>-40 to +85<br>-55 to +125 | °C   |
| Storage Temperature Range                                                                                                               | T <sub>stg</sub> | -55 to +150                           | °C   |
| Thermal Resistance<br>Plastic Package<br>Ceramic Package                                                                                | θ <sub>JA</sub>  | 70<br>50                              | °C/W |

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.

TABLE 2 – ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V, ±5%, V<sub>SS</sub> = 0, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub> unless otherwise noted)

| Characteristic                                                                                                                                                                                       | Symbol                              | Min                                                                     | Typ                   | Max                                            | Unit  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------|-----------------------|------------------------------------------------|-------|
| Input High Voltage<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = max)<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = 0.0 V)                                                             | V <sub>IH</sub><br>V <sub>IHC</sub> | V <sub>SS</sub> + 2.0<br>V <sub>CC</sub> - 0.6                          | —<br>—                | V <sub>CC</sub><br>V <sub>CC</sub> + 0.3       | Vdc   |
| Input Low Voltage<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = min)                                                                                                                          | V <sub>IL</sub><br>V <sub>ILC</sub> | V <sub>SS</sub> - 0.3<br>V <sub>SS</sub> - 0.3                          | —<br>—                | V <sub>SS</sub> + 0.8<br>V <sub>SS</sub> + 0.4 | Vdc   |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = max)<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = 0.0 V)                                                          | I <sub>in</sub>                     | —<br>—                                                                  | 1.0<br>—              | 2.5<br>100                                     | μA/dc |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 V, V <sub>CC</sub> = max)                                                                                                     | D0-D7<br>A0-A15,R/W                 | I <sub>TSI</sub>                                                        | —<br>—                | 2.0<br>10<br>100                               | μA/dc |
| Output High Voltage<br>(I <sub>Load</sub> = -205 μA/dc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -145 μA/dc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -100 μA/dc, V <sub>CC</sub> = min) | V <sub>OH</sub>                     | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | —<br>—<br>—           | —<br>—<br>—                                    | Vdc   |
| Output Low Voltage (I <sub>Load</sub> = 1.6 mA/dc, V <sub>CC</sub> = min)                                                                                                                            | V <sub>OL</sub>                     | —                                                                       | —                     | V <sub>SS</sub> + 0.4                          | Vdc   |
| Power Dissipation                                                                                                                                                                                    | P <sub>D</sub>                      | —                                                                       | 0.5                   | 1.0                                            | W     |
| Capacitance<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                                                                             | C <sub>in</sub>                     | —<br>—<br>—<br>—                                                        | 25<br>45<br>10<br>6.5 | 35<br>70<br>12.5<br>10                         | pF    |
| Logic Inputs<br>A0-A15,R/W,VMA                                                                                                                                                                       | C <sub>out</sub>                    | —                                                                       | —                     | 12                                             | pF    |

TABLE 3 – CLOCK TIMING (V<sub>CC</sub> = 5.0 V, ±5%, V<sub>SS</sub> = 0, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub> unless otherwise noted)

| Characteristics                                                                                                                                                                                                                                      | Symbol                            | Min                     | Typ         | Max                  | Unit |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------------|-------------|----------------------|------|
| Frequency of Operation<br>MC6800<br>MC68A00<br>MC68B00                                                                                                                                                                                               | f                                 | 0.1<br>0.1<br>0.1       | —<br>—<br>— | 1.0<br>1.5<br>2.0    | MHz  |
| Cycle Time (Figure 1)<br>MC6800<br>MC68A00<br>MC68B00                                                                                                                                                                                                | t <sub>cyc</sub>                  | 1.000<br>0.666<br>0.500 | —<br>—<br>— | 10<br>10<br>10       | μs   |
| Clock Pulse Width<br>(Measured at V <sub>CC</sub> - 0.6 V)<br>φ1,φ2 – MC6800<br>φ1,φ2 – MC68A00<br>φ1,φ2 – MC68B00                                                                                                                                   | PW <sub>φH</sub>                  | 400<br>230<br>180       | —<br>—<br>— | 9500<br>9500<br>9500 | ns   |
| Total φ1 and φ2 Up Time<br>MC6800<br>MC68A00<br>MC68B00                                                                                                                                                                                              | t <sub>ut</sub>                   | 900<br>600<br>440       | —<br>—<br>— | —<br>—<br>—          | ns   |
| Rise and Fall Times<br>(Measured between V <sub>SS</sub> + 0.4 and V <sub>CC</sub> - 0.6)                                                                                                                                                            | t <sub>φR</sub> , t <sub>φF</sub> | —                       | —           | 100                  | ns   |
| Delay Time or Clock Separation (Figure 1)<br>(Measured at V <sub>Ov</sub> = V <sub>SS</sub> + 0.6 V @ t <sub>r</sub> = t <sub>f</sub> ≤ 100 ns)<br>(Measured at V <sub>Ov</sub> = V <sub>SS</sub> + 1.0 V @ t <sub>r</sub> = t <sub>f</sub> ≤ 35 ns) | t <sub>d</sub>                    | 0<br>0                  | —<br>—      | 9100<br>9100         | ns   |

## MC6809, MC68A09, MC68B09

### MAXIMUM RATINGS

| Rating                      | Symbol           | Value        | Unit |
|-----------------------------|------------------|--------------|------|
| Supply Voltage              | V <sub>CC</sub>  | -0.3 to +7.0 | Vdc  |
| Input Voltage               | V <sub>in</sub>  | -0.3 to +7.0 | Vdc  |
| Operating Temperature Range | T <sub>A</sub>   | 0 to +70     | °C   |
| Storage Temperature Range   | T <sub>stg</sub> | -55 to +150  | °C   |
| Thermal Resistance          | θ <sub>JA</sub>  | 70           | °C/W |

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.

### ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0 V ±5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to 70°C unless otherwise noted.)

| Characteristic                                                                                                                                                                                    | Symbol                               | Min                                            | Typ                                                                     | Max                                | Unit        |      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------|-------------------------------------------------------------------------|------------------------------------|-------------|------|
| Input High Voltage<br>Logic, EXtal<br>RESET                                                                                                                                                       | V <sub>IH</sub>                      | V <sub>SS</sub> + 2.0<br>V <sub>SS</sub> + 4.0 | —                                                                       | V <sub>DD</sub><br>V <sub>DD</sub> | Vdc         |      |
| Input Low Voltage<br>Logic, EXtal, RESET                                                                                                                                                          | V <sub>IL</sub>                      | V <sub>SS</sub> - 0.3                          | —                                                                       | V <sub>SS</sub> + 0.8              | Vdc         |      |
| Input Leakage Current<br>(V <sub>in</sub> = 0 to 5.25 V, V <sub>CC</sub> = max)                                                                                                                   | I <sub>in</sub>                      | —                                              | 1.0                                                                     | 2.5                                | μAdc        |      |
| Output High Voltage<br>(I <sub>Load</sub> = -205 μAdc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -145 μAdc, V <sub>CC</sub> = min)<br>(I <sub>Load</sub> = -100 μAdc, V <sub>CC</sub> = min) | D0-D7<br>A0-A15, R/W, Q, E<br>BA, BS | V <sub>OH</sub>                                | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | —<br>—<br>—                        | Vdc         |      |
| Output Low Voltage<br>(I <sub>Load</sub> = 2.0 mAdc, V <sub>CC</sub> = min)                                                                                                                       | V <sub>OL</sub>                      | —                                              | —                                                                       | V <sub>SS</sub> + 0.5              | Vdc         |      |
| Power Dissipation                                                                                                                                                                                 | P <sub>D</sub>                       | —                                              | —                                                                       | 1.0                                | W           |      |
| Capacitance #<br>(V <sub>in</sub> = 0, T <sub>A</sub> = 25°C, f = 1.0 MHz)                                                                                                                        | C <sub>in</sub>                      | —<br>—<br>—                                    | 10<br>7<br>12                                                           | 15<br>10<br>12                     | pF          |      |
| Frequency of Operation<br>(Crystal or External Input)                                                                                                                                             | MC6809<br>MC68A09<br>MC68B09         | f                                              | f <sub>X</sub> TAL<br>f <sub>X</sub> TAL                                | —<br>—<br>—                        | 4<br>6<br>8 | MHz  |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 V, V <sub>CC</sub> = max)                                                                                                  | D0-D7<br>A0-A15, R/W                 | I <sub>TSI</sub>                               | —<br>—                                                                  | 2.0<br>—                           | 10<br>100   | μAdc |

### READ/WRITE TIMING (Reference Figures 1 and 2)

| Characteristic                                                                         | Symbol                         | MC6809 |     |     | MC68A09 |     |     | MC68B09 |     |     | Unit |
|----------------------------------------------------------------------------------------|--------------------------------|--------|-----|-----|---------|-----|-----|---------|-----|-----|------|
|                                                                                        |                                | Min    | Typ | Max | Min     | Typ | Max | Min     | Typ | Max |      |
| Cycle Time                                                                             | t <sub>CYC</sub>               | 1000   | —   | —   | 667     | —   | —   | 500     | —   | —   | ns   |
| Total Up Time                                                                          | t <sub>UT</sub>                | 975    | —   | —   | 640     | —   | —   | 480     | —   | —   | ns   |
| Peripheral Read Access Time<br>t <sub>ac</sub> = (t <sub>AD</sub> + t <sub>DSR</sub> ) | t <sub>ACC</sub>               | 695    | —   | —   | 440     | —   | —   | 320     | —   | —   | ns   |
| Data Setup Time (Read)                                                                 | t <sub>DSR</sub>               | 80     | —   | —   | 60      | —   | —   | 40      | —   | —   | ns   |
| Input Data Hold Time                                                                   | t <sub>DHR</sub>               | 10     | —   | —   | 10      | —   | —   | 10      | —   | —   | ns   |
| Output Data Hold Time                                                                  | t <sub>DHW</sub>               | 30     | —   | —   | 30      | —   | —   | 30      | —   | —   | ns   |
| Address Hold Time<br>(Address, R/W)                                                    | t <sub>AH</sub>                | 30     | —   | —   | 30      | —   | —   | 30      | —   | —   | ns   |
| Address Delay                                                                          | t <sub>AD</sub>                | —      | —   | 200 | —       | —   | 140 | —       | —   | 110 | ns   |
| Data Delay Time (Write)                                                                | t <sub>DDW</sub>               | —      | —   | 225 | —       | —   | 180 | —       | —   | 145 | ns   |
| Elow to Qhigh Time                                                                     | t <sub>AVS</sub>               | —      | —   | 250 | —       | —   | 165 | —       | —   | 125 | ns   |
| Address Valid to Qhigh                                                                 | t <sub>AQ</sub>                | 25     | —   | —   | 25      | —   | —   | 15      | —   | —   | ns   |
| Processor Clock Low                                                                    | t <sub>PWEL</sub>              | 450    | —   | —   | 295     | —   | —   | 210     | —   | —   | ns   |
| Processor Clock High                                                                   | t <sub>PWEH</sub>              | 450    | —   | —   | 280     | —   | —   | 220     | —   | —   | ns   |
| MRDY Set Up Time                                                                       | t <sub>PCSR</sub>              | 60     | —   | —   | 60      | —   | —   | 60      | —   | —   | ns   |
| Interrupts Set Up Time                                                                 | t <sub>PCS</sub>               | 200    | —   | —   | 140     | —   | —   | 110     | —   | —   | ns   |
| HALT Set Up Time                                                                       | t <sub>PCSH</sub>              | 200    | —   | —   | 140     | —   | —   | 110     | —   | —   | ns   |
| RESET Set Up Time                                                                      | t <sub>PCSR</sub>              | 200    | —   | —   | 140     | —   | —   | 110     | —   | —   | ns   |
| DMA/BREQ Set Up Time                                                                   | t <sub>PCSD</sub>              | 125    | —   | —   | 125     | —   | —   | 125     | —   | —   | ns   |
| Crystal Osc Start Time                                                                 | t <sub>rc</sub>                | 100    | —   | —   | 100     | —   | —   | 100     | —   | —   | ms   |
| E Rise and Fall Time                                                                   | t <sub>ER, E<sub>F</sub></sub> | 5      | —   | 25  | 5       | —   | 25  | 5       | —   | 20  | ns   |
| Processor Control Rise/Fall                                                            | t <sub>PCR,<br/>PLF</sub>      | —      | —   | 100 | —       | —   | 100 | —       | —   | 100 | ns   |
| Q Rise and Fall Time                                                                   | t <sub>QR, QF</sub>            | 5      | —   | 25  | 5       | —   | 25  | 5       | —   | 20  | ns   |
| Q Clock High                                                                           | t <sub>PWQH</sub>              | 450    | —   | —   | 280     | —   | —   | 220     | —   | —   | ns   |

Data sheets on pages 9-D31 through 9-D39 reprinted by permission of Motorola Semiconductor Products, Inc.

## MC6809, MC68A09, MC68B09

### READ DATA FROM MEMORY OR PERIPHERALS



### WRITE DATA TO MEMORY OR PERIPHERALS



## MC6809, MC68A09, MC68B09

### BUS TIMING TEST LOAD



C = 30 pF for BA, BS      R = 11.7 k $\Omega$  for D0-D7  
130 pF for D0-D7, E, Q      16.5 k $\Omega$  for A0-A15, E, Q  
90 pF for A0-A15, R/W      24 k $\Omega$  for BA, BS

### RESET TIMING



\*Note: Parts with date codes prefixed by 7F will come out of Reset one cycle sooner than shown.

### CRYSTAL CONNECTIONS AND OSCILLATOR START UP



| 6809 Crystal Parameters*           |          |          |            |            |
|------------------------------------|----------|----------|------------|------------|
|                                    | 3.58 MHz | 4.00 MHz | 6.0 MHz    | 8.0 MHz    |
| R <sub>S</sub>                     | 60 Ω     | 50 Ω     | 30-50 Ω    | 20-40 Ω    |
| C <sub>0</sub>                     | 3.5 pF   | 6.5 pF   | 4.6 pF     | 4.6 pF     |
| C <sub>1</sub>                     | .015 pF  | .025 pF  | .01-.02 pF | .01-.02 pF |
| C <sub>in</sub> , C <sub>out</sub> | 25 pF    | 25 pF    | 25 pF      | 25 pF      |
| Q                                  | 40 K     | 30 K     | 20 K       | 20 K       |

All Parameters Are ±10%

\*Note: These are representative AT-cut crystal parameters only. Crystals of other types of cut that work may also be used.



## MC6809, MC68A09, MC68B09

### HALT AND SINGLE INSTRUCTION EXECUTION FOR SYSTEM DEBUG



### IRQ AND NMI INTERRUPT TIMING



### FIRQ INTERRUPT TIMING



## MC6809, MC68A09, MC68B09

### E/O RELATIONSHIP



FIGURE 13 MRDY TIMING



## MC6809, MC68A09, MC68B09

TYPICAL DMA TIMING (~ 14 CYCLES)



**NOTE:**  
DMAVMA is a signal which  
 is developed externally but  
 is a system requirement for DMA

AUTO-REFRESH DMA TIMING (~ 14 CYCLES)



## SYNC TIMING



## NOTE:

1. If the mask bit is set when the interrupt is requested processing will continue with instruction execution fetched from previous step. However, if an NMI or an unmasked FIRQ or IRQ caused interrupt, the address placed on bus from previous cycle ( $M + 1$ ) remains on bus and processing continues with this cycle as ( $m + 1$ ) or ( $n + 1$ ) of interrupt timing.
2. If mask bits are clear IRQ & FIRQ must be held low for three cycles to guarantee interrupt to be taken, although only one cycle is necessary to bring the processor out of SYNC.

## **ATTENTION WRITERS**

OSBORNE/McGraw-Hill is seeking qualified contributors to future updates of Volumes 2 and 3. Qualified contributors must have an excellent technical background, and they must be able to write clearly and without bias toward any manufacturer of products covered. Faculty at universities are particularly welcome as contributors.

A contributor, when selected, will be assigned a specific category of parts to keep updated. Keeping parts updated will include describing new parts in the category as they appear, and improving the description of parts that are already covered. Individual one-time contributions are also welcome.

If you would like to become a contributor to Volume 2 and/or Volume 3, please write stating your qualifications and the categories that you believe you could cover competently. If possible, send us a sample of your work; we suggest two or three pages of a part description following the format presented in these books as closely as possible. Send material to:

**OSBORNE/McGraw-Hill  
630 Bancroft Way  
Berkeley, California 94710**

**Attention: Volume 2/3 Contributors**